@import url("https://fonts.googleapis.com/css2?family=Bungee:wght@400&family=Manrope:wght@400;600;700;800&display=swap");

:root {
  --bg-1: #f3ede2;
  --bg-2: #d4e2cf;
  --paper: rgba(255, 255, 255, 0.72);
  --ink: #172119;
  --accent: #d84f2a;
  --accent-soft: #f8be66;
  --ok: #2f7a4e;
  --warn: #984214;
  --shadow: 0 16px 40px rgba(24, 25, 18, 0.14);
  --radius: 18px;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: "Manrope", "Segoe UI", sans-serif;
  color: var(--ink);
  background: radial-gradient(circle at 10% 10%, #f9f2e7 0%, #f0e8db 30%, #d7e6d1 100%);
}

.background-shapes {
  position: fixed;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
}

.shape {
  position: absolute;
  border-radius: 999px;
  filter: blur(2px);
  opacity: 0.45;
}

.shape-a {
  width: 380px;
  height: 380px;
  background: #f8be66;
  top: -80px;
  right: -60px;
}

.shape-b {
  width: 280px;
  height: 280px;
  background: #9fc19a;
  bottom: 10%;
  left: -90px;
}

.shape-c {
  width: 220px;
  height: 220px;
  background: #de7c4f;
  top: 38%;
  left: 52%;
}

.app {
  position: relative;
  z-index: 1;
  width: 80%;
  margin: 24px auto 40px;
  display: grid;
  gap: 18px;
}

.hero,
.setup-section,
.controls,
.name-editor,
.card,
.board-section,
.history {
  background: var(--paper);
  backdrop-filter: blur(6px);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

.hero {
  padding: 24px;
}

.kicker {
  margin: 0;
  text-transform: uppercase;
  font-weight: 800;
  letter-spacing: 0.08em;
  color: #5f6c5b;
}

h1,
h2,
h3 {
  margin: 0;
  font-family: "Bungee", "Trebuchet MS", sans-serif;
  letter-spacing: 0.02em;
}

h1 {
  margin-top: 8px;
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  line-height: 1.1;
}

.subtitle {
  margin: 12px 0 0;
  max-width: 66ch;
}

.controls {
  margin-top: 10px;
  padding: 16px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  background: rgba(246, 250, 243, 0.88);
  box-shadow: none;
}

.controls label {
  font-weight: 700;
}

.control-break {
  flex-basis: 100%;
  height: 0;
}

.name-editor {
  margin-top: 12px;
  padding: 16px;
  background: rgba(246, 250, 243, 0.88);
  box-shadow: none;
}

.name-input-grid {
  margin-top: 10px;
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.name-input-group {
  display: grid;
  gap: 6px;
}

.name-input-group label {
  font-weight: 700;
  color: #40533d;
}

.name-input-group input {
  border: 1px solid #bfd0b8;
  border-radius: 10px;
  padding: 9px 10px;
  font: inherit;
  background: #f8fbf6;
}

.toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  background: #f2f7ed;
  border: 1px solid #c8d6c2;
  border-radius: 12px;
}

.toggle input {
  accent-color: var(--accent);
}

select,
.btn {
  border: none;
  border-radius: 12px;
  font: inherit;
}

select {
  min-width: 110px;
  padding: 10px 12px;
  background: #f3f7ef;
  border: 1px solid #c8d6c2;
}

.btn {
  padding: 10px 14px;
  font-weight: 700;
  cursor: pointer;
  background: #e7ede3;
  color: #172119;
  transition: transform 140ms ease, background-color 180ms ease;
}

.btn:hover {
  transform: translateY(-1px);
}

.btn:active {
  transform: translateY(0);
}

.btn-primary {
  background: linear-gradient(110deg, var(--accent) 0%, #bf3e1b 100%);
  color: #fff;
}

.btn-subtle {
  background: hsl(17, 95%, 46%);
}

.status-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.players {
  margin-top: 12px;
  padding: 16px;
  background: rgba(246, 250, 243, 0.88);
  box-shadow: none;
}

.setup-section {
  padding: 16px;
}

.setup-content {
  margin-top: 6px;
}

.setup-content.collapsed {
  display: none;
}

.players-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.player-card {
  border: 1px solid transparent;
  transition: border-color 180ms ease, transform 160ms ease, background-color 180ms ease;
}

.player-card.active {
  border-color: #3f8e58;
  background: linear-gradient(120deg, rgba(179, 229, 167, 0.75) 0%, rgba(226, 245, 216, 0.9) 100%);
  transform: translateY(-1px);
}

.player-meta {
  margin: 10px 0 0;
  font-size: 0.95rem;
  font-weight: 700;
  color: #3f4d3b;
}

.player-name-input {
  width: 100%;
  margin: 0;
  border: 1px solid #bfd0b8;
  border-radius: 9px;
  padding: 7px 9px;
  font: inherit;
  font-weight: 800;
  color: #243027;
  background: #f8fbf6;
}

.player-notice {
  margin: 0 0 10px;
  padding: 8px 10px;
  border-radius: 10px;
  background: #ffd8a8;
  border: 1px solid #e58a17;
  color: #7f3f00;
  font-size: 0.9rem;
  font-weight: 800;
  opacity: 0;
  transform: translateY(-4px);
  pointer-events: none;
  transition: opacity 180ms ease, transform 180ms ease;
}

.player-notice.show {
  opacity: 1;
  transform: translateY(0);
}

.player-throw-list {
  margin: 10px 0 0;
  padding-left: 18px;
  max-height: 120px;
  overflow: auto;
}

.player-throw-list li {
  color: #16753a;
  font-size: 0.84rem;
  font-weight: 800;
  line-height: 1.28;
  padding: 1px 0;
}

.throw-hit {
  color: #16753a;
}

.throw-miss {
  color: #b42318;
}

.throw-sum {
  color: #0f5d2f;
  font-weight: 900;
}

.player-throw-empty {
  opacity: 0.8;
}

.card {
  padding: 16px;
}

.label {
  margin: 0;
  font-size: 0.86rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #5a6856;
  font-weight: 800;
}

.value {
  margin: 10px 0 0;
  font-family: "Bungee", "Trebuchet MS", sans-serif;
  line-height: 1;
}

.value.small {
  font-family: "Manrope", "Segoe UI", sans-serif;
  line-height: 1.35;
  font-size: 1rem;
  font-weight: 700;
}

#lastThrow {
  white-space: pre-line;
}

.score-card .value {
  font-size: clamp(2.2rem, 5vw, 3.5rem);
}

.status-card .value {
  color: var(--warn);
}

.status-card .value.ok {
  color: var(--ok);
}

.board-section {
  padding: 16px;
}

.board-headline {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.dart-actions {
  display: inline-flex;
  flex-direction: column;
  align-items: stretch;
  gap: 6px;
}

.setup-actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.language-select {
  border: 1px solid #c8d6c2;
  border-radius: 12px;
  padding: 8px 10px;
  min-width: 92px;
  background: #f3f7ef;
  font: inherit;
  font-weight: 700;
  color: #1e2b1f;
}

.board-columns {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.board-top-layout {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(280px, 1fr);
  gap: 14px;
  align-items: start;
  margin-bottom: 14px;
}

.board-sidebar {
  display: grid;
  gap: 12px;
  align-content: start;
}

.board-sidebar .setup-section,
.board-sidebar .players {
  margin-top: 0;
}

.board-top-layout .dartboard-wrap {
  margin-bottom: 0;
}

.board-players {
  margin-top: 0;
  height: 100%;
}

.dartboard-wrap {
  margin-bottom: 14px;
  padding: 12px;
  border-radius: 14px;
  background: rgba(246, 250, 243, 0.9);
  border: 1px solid #c7d9c0;
}

.board-stats-grid {
  margin-bottom: 14px;
}

.dartboard-svg-container {
  margin-top: 10px;
  display: grid;
  place-items: center;
}

.dartboard-svg {
  width: min(920px, 96vw);
  height: auto;
}

.board-segment {
  cursor: pointer;
  transition: opacity 140ms ease;
}

.board-segment:hover {
  opacity: 0.72;
}

.board-miss-ring {
  opacity: 1;
  transition: stroke 140ms ease;
}

.board-miss-ring:hover {
  stroke: #2a2a2a;
}

.board-number {
  font-size: 12px;
  font-weight: 800;
  fill: #1f2b20;
  font-family: "Manrope", "Segoe UI", sans-serif;
  pointer-events: none;
}

.field-grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.field-btn {
  border: 1px solid #cbd6c6;
  border-radius: 10px;
  padding: 8px 6px;
  background: #f8fbf6;
  color: #1f2b20;
  font-weight: 800;
  cursor: pointer;
  transition: background-color 160ms ease, border-color 160ms ease;
}

.field-btn:hover {
  background: #ecf7e7;
  border-color: #a8c29d;
}

.field-btn strong {
  display: block;
  font-size: 0.95rem;
}

.field-btn span {
  font-size: 0.75rem;
  opacity: 0.84;
}

.history {
  padding: 16px;
}

.win-modal {
  position: fixed;
  inset: 0;
  display: none;
  place-items: center;
  padding: 20px;
  background: rgba(20, 26, 20, 0.48);
  backdrop-filter: blur(4px);
  z-index: 30;
}

.win-modal.open {
  display: grid;
}

.win-modal-card {
  width: min(560px, 94vw);
  border-radius: 22px;
  padding: 26px;
  color: #18231b;
  background: linear-gradient(145deg, #fff7e2 0%, #dbefcf 46%, #f5e6bf 100%);
  box-shadow: 0 26px 70px rgba(24, 28, 18, 0.38);
  text-align: center;
  animation: pop-win 420ms cubic-bezier(0.2, 0.9, 0.2, 1);
}

.win-kicker {
  margin: 0;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #1f7a41;
}

.win-modal-card h2 {
  margin: 8px 0 0;
  font-size: clamp(1.6rem, 4vw, 2.4rem);
}

.win-throws {
  margin: 14px 0 20px;
  font-size: 1.08rem;
  font-weight: 700;
}

@keyframes pop-win {
  0% {
    opacity: 0;
    transform: translateY(20px) scale(0.94);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

#throwCount {
  font-weight: 800;
}

#historyList {
  margin: 10px 0 0;
  padding-left: 20px;
  max-height: 210px;
  overflow: auto;
}

#historyList li {
  padding: 4px 0;
  font-weight: 600;
}

.reveal {
  opacity: 0;
  transform: translateY(12px);
  animation: reveal-up 440ms ease forwards;
}

.reveal-delay-1 {
  animation-delay: 80ms;
}

.reveal-delay-2 {
  animation-delay: 140ms;
}

.reveal-delay-3 {
  animation-delay: 210ms;
}

.reveal-delay-4 {
  animation-delay: 280ms;
}

@keyframes reveal-up {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 940px) {
  .status-grid,
  .board-top-layout,
  .board-columns {
    grid-template-columns: 1fr;
  }

  .board-sidebar {
    order: 2;
  }

  .field-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
}

@media (max-width: 560px) {
  .app {
    width: min(1160px, 95vw);
    margin: 14px auto 24px;
  }

  .hero,
  .setup-section,
  .controls,
  .name-editor,
  .card,
  .board-section,
  .history {
    border-radius: 14px;
  }

  .field-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
