/* ===========================================================
   KNIFFEL — Design Tokens
   Holz  : #2b1a10 (dunkel) → #7a4a26 (mittel) → #a8703f (hell)
   Filz  : #0b3d26 (dunkel) → #146b3f (mittel) → #1f8a52 (highlight)
   Gold  : #f3d97b (hell) → #d4af37 (mittel) → #8a6a1f (dunkel)
   Papier: #f6efdd
   Tinte : #241a12
   Orange (Vorschlag): #ff8a3d
   =========================================================== */

:root{
  --wood-dark:   #241209;
  --wood-mid:    #6b3f22;
  --wood-light:  #a06b3d;
  --wood-shine:  #c99260;

  --felt-dark:   #062818;
  --felt-mid:    #0e4b2c;
  --felt-light:  #1a7a49;

  --gold:        #d4af37;
  --gold-light:  #f3d97b;
  --gold-dark:   #8a6a1f;

  --paper:       #f6efdd;
  --paper-line:  #d9c9a3;
  --ink:         #241a12;
  --ink-soft:    #5a4a38;

  --orange:      #ff8a3d;
  --orange-glow: rgba(255,138,61,.45);

  --font-display: "Fraunces", serif;
  --font-body: "Inter", sans-serif;
  --font-mono: "JetBrains Mono", monospace;

  --radius-lg: 22px;
  --radius-md: 14px;
  --radius-sm: 8px;

  --shadow-deep: 0 20px 50px rgba(0,0,0,.55);
}

*{ box-sizing:border-box; margin:0; padding:0; }

html, body{
  height:100%;
  font-family: var(--font-body);
  color: var(--paper);
  background:
    radial-gradient(ellipse at 30% -10%, #201410 0%, transparent 55%),
    radial-gradient(ellipse at 90% 110%, #140c08 0%, transparent 50%),
    linear-gradient(160deg, #0f0906 0%, #1a1109 45%, #0c0705 100%);
  overflow-x:hidden;
}

button{ font-family: inherit; cursor:pointer; border:none; background:none; }
::selection{ background: var(--gold); color:#241a12; }

.hidden{ display:none !important; }

/* ===================== SCREENS ===================== */
.screen{
  min-height:100vh;
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
}

/* ===================== LOGO ===================== */
.logo{
  font-family: var(--font-display);
  font-weight:900;
  font-size:3.2rem;
  letter-spacing:-1px;
  color: var(--paper);
  text-shadow: 0 2px 0 rgba(0,0,0,.4), 0 12px 30px rgba(0,0,0,.5);
}
.logo.small{ font-size:1.6rem; }
.logo-dot{ color: var(--orange); }

/* ===================== SETUP SCREEN ===================== */
.setup-card{
  background: linear-gradient(160deg, #1c130c, #100a06);
  border: 1px solid rgba(212,175,55,.25);
  border-radius: var(--radius-lg);
  padding: 3rem 3.2rem;
  width: min(460px, 90vw);
  text-align:center;
  box-shadow: var(--shadow-deep);
  animation: rise .6s cubic-bezier(.2,.8,.2,1);
}
@keyframes rise{
  from{ opacity:0; transform: translateY(24px) scale(.97); }
  to{ opacity:1; transform:none; }
}

.setup-sub{
  margin-top:.6rem;
  color: #c9b8a0;
  font-size:1rem;
}

.player-count-row{
  display:flex;
  gap:.7rem;
  justify-content:center;
  margin: 1.8rem 0 1.4rem;
}
.count-btn{
  width:52px; height:52px;
  border-radius: 50%;
  background: linear-gradient(160deg, #3a2413, #201207);
  border: 1px solid rgba(212,175,55,.3);
  color: var(--paper);
  font-family: var(--font-display);
  font-weight:700;
  font-size:1.15rem;
  transition: transform .15s ease, box-shadow .15s ease, background .2s ease;
}
.count-btn:hover{ transform: translateY(-2px); }
.count-btn.active{
  background: linear-gradient(160deg, var(--gold-light), var(--gold));
  color:#241a12;
  box-shadow: 0 6px 22px var(--orange-glow);
  transform: translateY(-2px);
}

.name-inputs{
  display:flex;
  flex-direction:column;
  gap:.7rem;
  margin-bottom: 1.8rem;
}
.name-inputs input{
  background: #150d07;
  border: 1px solid rgba(212,175,55,.25);
  border-radius: var(--radius-sm);
  padding: .8rem 1rem;
  color: var(--paper);
  font-size: .95rem;
  outline:none;
  transition: border .15s ease, box-shadow .15s ease;
}
.name-inputs input:focus{
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(212,175,55,.15);
}
.name-inputs input::placeholder{ color:#7a6a55; }

.primary-btn{
  width:100%;
  padding: 1rem 1.4rem;
  border-radius: 999px;
  background: linear-gradient(160deg, var(--gold-light), var(--gold) 60%, var(--gold-dark));
  color:#241a12;
  font-weight:700;
  font-size:1rem;
  letter-spacing:.02em;
  box-shadow: 0 10px 28px rgba(212,175,55,.28), inset 0 1px 0 rgba(255,255,255,.4);
  transition: transform .15s ease, box-shadow .15s ease, filter .15s ease;
}
.primary-btn:hover{ transform: translateY(-2px); filter:brightness(1.05); }
.primary-btn:active{ transform: translateY(0); }

/* ===================== GAME SCREEN ===================== */
.game-screen, #game-screen{ align-items:stretch; }
#game-screen{
  flex-direction:column;
  padding: 1.4rem 2.4rem 2.4rem;
  max-width: 1360px;
  margin: 0 auto;
  gap: 1.2rem;
}

.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:1rem;
}

.players-bar{
  display:flex;
  gap:.6rem;
  flex-wrap:wrap;
}
.player-chip{
  display:flex;
  align-items:center;
  gap:.5rem;
  padding:.5rem .9rem;
  border-radius:999px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  font-size:.85rem;
  color:#cbb99e;
  transition: all .25s ease;
}
.player-chip .dot{
  width:8px; height:8px; border-radius:50%;
  background:#5a4a38;
}
.player-chip.active{
  background: linear-gradient(160deg, rgba(212,175,55,.22), rgba(212,175,55,.06));
  border-color: rgba(212,175,55,.5);
  color: var(--gold-light);
  box-shadow: 0 4px 16px rgba(212,175,55,.15);
}
.player-chip.active .dot{
  background: var(--orange);
  box-shadow: 0 0 8px var(--orange);
}
.player-chip .score{ font-family: var(--font-mono); font-weight:700; color:#f0e2c4; }

.game-wrap{
  display:grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 1.6rem;
  align-items:start;
}

/* ===================== TABLE / BOWL ===================== */
.table-area{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:1.2rem;
}

.round-indicator{
  font-family: var(--font-mono);
  font-size:.8rem;
  letter-spacing:.08em;
  color:#a08b6b;
  text-transform:uppercase;
}

.bowl-wrap{
  width:100%;
  display:flex;
  justify-content:center;
}

.bowl{
  width:100%;
  max-width:680px;
  aspect-ratio: 16/9.2;
  border-radius: 50% / 34%;
  padding: 26px;
  background:
    repeating-linear-gradient(100deg,
      var(--wood-shine) 0 3px,
      var(--wood-light) 3px 9px,
      var(--wood-mid) 9px 15px,
      var(--wood-dark) 15px 20px
    );
  box-shadow:
    inset 0 10px 30px rgba(0,0,0,.55),
    0 25px 55px rgba(0,0,0,.6),
    0 0 0 1px rgba(0,0,0,.4);
  position:relative;
}
.bowl::before{
  content:"";
  position:absolute; inset:0;
  border-radius:inherit;
  background: radial-gradient(ellipse at 30% 20%, rgba(255,255,255,.1), transparent 60%);
  pointer-events:none;
}

.felt{
  width:100%; height:100%;
  border-radius: 50% / 34%;
  background:
    radial-gradient(ellipse at 35% 25%, var(--felt-light) 0%, var(--felt-mid) 45%, var(--felt-dark) 100%);
  box-shadow:
    inset 0 10px 34px rgba(0,0,0,.65),
    inset 0 0 0 3px rgba(0,0,0,.3),
    inset 0 0 40px rgba(0,0,0,.4);
  position:relative;
  overflow:hidden;
}
.felt::after{
  content:"";
  position:absolute; inset:0;
  background-image:
    repeating-linear-gradient(45deg, rgba(255,255,255,.025) 0 2px, transparent 2px 5px);
  mix-blend-mode: overlay;
}

#dice-canvas{
  width:100%; height:100%;
  display:block;
  position:relative;
  z-index:2;
}

/* ===================== CONTROLS ===================== */
.controls{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:.6rem;
}
.rolls-left{
  font-family: var(--font-mono);
  font-size:.85rem;
  color: var(--gold-light);
  letter-spacing:.04em;
}

.roll-btn{
  display:flex;
  align-items:center;
  gap:.6rem;
  padding: .95rem 2.4rem;
  border-radius:999px;
  background: linear-gradient(160deg, var(--gold-light), var(--gold) 55%, var(--gold-dark));
  color:#241a12;
  font-weight:700;
  font-size:1.05rem;
  box-shadow: 0 12px 30px rgba(212,175,55,.3), inset 0 1px 0 rgba(255,255,255,.45);
  transition: transform .15s ease, box-shadow .15s ease, filter .15s ease, opacity .2s ease;
}
.roll-btn:hover:not(:disabled){ transform: translateY(-3px); filter:brightness(1.06); }
.roll-btn:active:not(:disabled){ transform: translateY(0); }
.roll-btn:disabled{ opacity:.35; cursor:not-allowed; box-shadow:none; }
.roll-btn-icon{ font-size:1.2rem; display:inline-block; }
.roll-btn.rolling .roll-btn-icon{ animation: spin .5s linear infinite; }
@keyframes spin{ to{ transform: rotate(360deg); } }

.hint{
  font-size:.85rem;
  color:#a08b6b;
  text-align:center;
  min-height:1.2em;
  transition: color .2s ease;
}
.hint.emph{ color: var(--orange); font-weight:600; }

/* ===================== SCORECARD ===================== */
.scorecard{
  background: var(--paper);
  color: var(--ink);
  border-radius: var(--radius-lg);
  padding: 1.4rem 1.3rem 1.6rem;
  box-shadow: var(--shadow-deep), inset 0 0 0 1px rgba(0,0,0,.05);
  position:relative;
  background-image:
    repeating-linear-gradient(rgba(0,0,0,.025) 0 1px, transparent 1px 34px);
}

.scorecard h2{
  font-family: var(--font-display);
  font-size:1.15rem;
  font-weight:700;
  margin-bottom:.8rem;
  padding-bottom:.5rem;
  border-bottom: 2px solid var(--ink);
  display:flex;
  justify-content:space-between;
  align-items:baseline;
}
.scorecard h2 small{
  font-family: var(--font-mono);
  font-weight:500;
  font-size:.7rem;
  color: var(--ink-soft);
  text-transform:uppercase;
}

table.score-table{
  width:100%;
  border-collapse:collapse;
  font-size:.86rem;
}
table.score-table th{
  text-align:right;
  font-family: var(--font-mono);
  font-weight:600;
  font-size:.68rem;
  text-transform:uppercase;
  letter-spacing:.04em;
  color: var(--ink-soft);
  padding: .35rem .5rem;
  border-bottom: 1px solid var(--paper-line);
}
table.score-table th:first-child{ text-align:left; }

table.score-table td{
  padding: .42rem .5rem;
  border-bottom: 1px dashed var(--paper-line);
  text-align:right;
  font-family: var(--font-mono);
  font-weight:600;
}
table.score-table td.cat-name{
  text-align:left;
  font-family: var(--font-body);
  font-weight:500;
  color: var(--ink);
}

tr.section-row td{
  padding-top:.55rem;
  font-style:italic;
  color: var(--ink-soft);
  font-family: var(--font-body);
  font-weight:600;
  font-size:.78rem;
  border-bottom:none;
}
tr.section-row.first td{ padding-top:0; }

tr.sum-row td{ color: var(--ink-soft); font-weight:700; }
tr.total-row td{
  font-size:1.02rem;
  color: var(--ink);
  border-top: 2px solid var(--ink);
  border-bottom:none;
  padding-top:.6rem;
}

.cell-empty{ color:#c9bda2; }
.cell-final{ color: var(--ink); }

.cell-suggest{
  color: var(--orange);
  cursor:pointer;
  border-radius:6px;
  padding:.15rem .4rem;
  transition: background .15s ease, transform .1s ease, color .15s ease;
  display:inline-block;
}
.cell-suggest:hover{
  background: var(--orange);
  color:#fff;
  transform: scale(1.08);
}
.cell-suggest.pop{ animation: pop .3s ease; }
@keyframes pop{
  0%{ transform:scale(1); }
  40%{ transform:scale(1.3); }
  100%{ transform:scale(1); }
}

.player-col.active-col{
  background: rgba(255,138,61,.06);
  box-shadow: inset 0 0 0 9999px rgba(255,138,61,.04);
}

/* ===================== DICE HELD LABEL ===================== */
.dice-tip{
  position:absolute;
  bottom:6px; left:50%; transform:translateX(-50%);
  font-size:.72rem;
  color: rgba(255,255,255,.55);
  font-family: var(--font-mono);
  letter-spacing:.03em;
  z-index:3;
  pointer-events:none;
}

/* ===================== END SCREEN ===================== */
#end-screen{
  position:fixed; inset:0;
  z-index:50;
  background: rgba(6,4,3,.88);
  backdrop-filter: blur(6px);
}
#confetti-canvas{
  position:absolute; inset:0;
  width:100%; height:100%;
  pointer-events:none;
}
.end-card{
  position:relative;
  z-index:2;
  background: linear-gradient(160deg, #1c130c, #100a06);
  border: 1px solid rgba(212,175,55,.3);
  border-radius: var(--radius-lg);
  padding: 3rem 3rem 2.4rem;
  width:min(460px, 90vw);
  text-align:center;
  box-shadow: var(--shadow-deep);
  animation: rise .5s cubic-bezier(.2,.8,.2,1);
  max-height:88vh;
  overflow:auto;
}
.trophy{ font-size:3.4rem; filter: drop-shadow(0 8px 20px rgba(212,175,55,.4)); }
.end-title{
  font-family: var(--font-display);
  font-size:1rem;
  color:#a08b6b;
  text-transform:uppercase;
  letter-spacing:.1em;
  margin-top:.4rem;
}
.winner-name{
  font-family: var(--font-display);
  font-weight:900;
  font-size:2.1rem;
  color: var(--gold-light);
  margin-top:.3rem;
}
.winner-score{
  font-family: var(--font-mono);
  color:#cbb99e;
  margin: .4rem 0 1.4rem;
}
.final-table{
  text-align:left;
  font-family: var(--font-mono);
  font-size:.82rem;
  color:#cbb99e;
  margin-bottom:1.6rem;
  display:flex;
  flex-direction:column;
  gap:.3rem;
}
.final-row{
  display:flex;
  justify-content:space-between;
  padding:.3rem .6rem;
  border-radius:8px;
}
.final-row.winner{
  background: rgba(212,175,55,.12);
  color: var(--gold-light);
  font-weight:700;
}

/* ===================== RESPONSIVE ===================== */
@media (max-width: 980px){
  .game-wrap{ grid-template-columns:1fr; }
  #game-screen{ padding: 1rem 1rem 1.6rem; }
  .logo{ font-size:2.2rem; }
}

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001ms !important; transition-duration:.001ms !important; }
}
