/* ===========================================================================
   GRAND LEDGER — Monopoli Siklus Akuntansi
   Aesthetic: 1930s Art-Deco accounting house.
   Warm manila ledger paper · deep ledger-green · brass-gold · ink-red.
   =========================================================================== */

/* ---------- Tokens ---------- */
:root {
  --paper:      #f1e6cd;
  --paper-2:    #e8d9b6;
  --paper-3:    #ddc99c;
  --cream-hi:   #fbf5e6;
  --ink:        #211d16;
  --ink-soft:   #5a5142;
  --ink-faint:  #8a7f68;

  --ledger:     #14533f;
  --ledger-2:   #0d3a2c;
  --ledger-3:   #082b20;
  --ledger-line:#b9cabb;

  --brass:      #c79a3a;
  --brass-hi:   #e8c86a;
  --brass-2:    #9c7522;
  --brass-deep: #6e4f12;

  --red:        #9b2226;
  --red-2:      #6e1417;
  --red-hi:     #c5484c;

  --teal:       #1f7a6b;
  --plum:       #6d2f5b;

  --shadow-1: 0 1px 2px rgba(33,29,22,.18);
  --shadow-2: 0 6px 22px -8px rgba(8,43,32,.45);
  --shadow-3: 0 26px 60px -22px rgba(8,43,32,.6);

  --font-display: 'Ultra', 'Arial Black', 'Impact', sans-serif;
  --font-deco:    'Cinzel', 'Times New Roman', Georgia, serif;
  --font-ui:      'Fjalla One', 'Arial Narrow', 'Helvetica Neue', sans-serif;
  --font-body:    'Spectral', Georgia, 'Times New Roman', serif;
  --font-mono:    'Space Mono', 'Courier New', monospace;

  --radius: 10px;
  --rule: 2px solid var(--brass-2);
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--ink);
  background-color: var(--ledger-2);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* Paper grain + ledger-green field behind everything */
body::before {
  content: '';
  position: fixed; inset: 0; z-index: -2;
  background:
    radial-gradient(120% 90% at 50% -10%, #1d6650 0%, var(--ledger-2) 55%, var(--ledger-3) 100%);
}
body::after {
  content: '';
  position: fixed; inset: 0; z-index: -1; pointer-events: none;
  opacity: .5; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E");
}

/* ---------- Paper utility & deco frame ---------- */
.paper {
  position: relative;
  background-color: var(--paper);
  background-image:
    linear-gradient(var(--paper) 0 0);
  color: var(--ink);
  box-shadow: var(--shadow-2);
}
.paper--grain::before {
  content: ''; position: absolute; inset: 0; pointer-events: none; border-radius: inherit;
  opacity: .35; mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='p'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23p)' opacity='0.5'/%3E%3C/svg%3E");
}
/* Art-deco double brass rule frame */
.deco-frame {
  border: 2px solid var(--brass-2);
  outline: 4px solid var(--paper);
  outline-offset: 0;
  box-shadow:
    inset 0 0 0 1px var(--brass-hi),
    inset 0 0 0 8px var(--paper),
    inset 0 0 0 10px var(--brass-2),
    var(--shadow-3);
}
.deco-corner { position: relative; }
.deco-corner::before, .deco-corner::after {
  content: ''; position: absolute; width: 22px; height: 22px; pointer-events: none;
  border: 2px solid var(--brass-2);
}
.deco-corner::before { top: 8px; left: 8px; border-right: 0; border-bottom: 0; }
.deco-corner::after  { bottom: 8px; right: 8px; border-left: 0; border-top: 0; }

/* ---------- Typography helpers ---------- */
.display { font-family: var(--font-display); letter-spacing: .5px; line-height: .96; }
.deco    { font-family: var(--font-deco); font-weight: 700; letter-spacing: .14em; text-transform: uppercase; }
.ui      { font-family: var(--font-ui); letter-spacing: .04em; }
.mono    { font-family: var(--font-mono); }
.eyebrow {
  font-family: var(--font-deco); text-transform: uppercase; letter-spacing: .34em;
  font-size: .72rem; color: var(--brass-2); font-weight: 700;
}
.rule-deco { display: flex; align-items: center; gap: .6rem; color: var(--brass-2); }
.rule-deco::before, .rule-deco::after {
  content: ''; height: 2px; flex: 1; background: linear-gradient(90deg, transparent, var(--brass-2), transparent);
}
.rule-deco .dot { width: 7px; height: 7px; transform: rotate(45deg); background: var(--brass); }

/* ---------- Buttons ---------- */
.btn {
  font-family: var(--font-ui); font-size: 1rem; letter-spacing: .08em; text-transform: uppercase;
  border: 2px solid var(--ink); border-radius: 6px; padding: .7em 1.5em; cursor: pointer;
  background: var(--paper); color: var(--ink); box-shadow: 3px 3px 0 var(--ink);
  transition: transform .08s ease, box-shadow .08s ease, background .15s ease;
  position: relative;
}
.btn:hover { transform: translate(-1px,-1px); box-shadow: 4px 4px 0 var(--ink); }
.btn:active { transform: translate(2px,2px); box-shadow: 1px 1px 0 var(--ink); }
.btn:disabled { opacity: .45; cursor: not-allowed; box-shadow: 2px 2px 0 var(--ink); transform: none; }
.btn--brass  { background: linear-gradient(180deg, var(--brass-hi), var(--brass)); color: var(--ink); border-color: var(--brass-deep); box-shadow: 3px 3px 0 var(--brass-deep); }
.btn--brass:hover { box-shadow: 4px 4px 0 var(--brass-deep); }
.btn--brass:active { box-shadow: 1px 1px 0 var(--brass-deep); }
.btn--ledger { background: linear-gradient(180deg, var(--ledger), var(--ledger-2)); color: var(--cream-hi); border-color: var(--ledger-3); box-shadow: 3px 3px 0 var(--ledger-3); }
.btn--ledger:hover { box-shadow: 4px 4px 0 var(--ledger-3); }
.btn--red    { background: linear-gradient(180deg, var(--red-hi), var(--red)); color: #fff; border-color: var(--red-2); box-shadow: 3px 3px 0 var(--red-2); }
.btn--lg { font-size: 1.3rem; padding: .8em 2.2em; }
.btn.is-off { opacity: .4; }
.btn.is-off::after { content: ''; position: absolute; left: 12%; right: 12%; top: 50%; height: 2px; background: currentColor; transform: rotate(-18deg); }
.btn--ghost { background: transparent; box-shadow: none; border-color: var(--brass-2); color: var(--cream-hi); }
.btn--ghost:hover { background: rgba(199,154,58,.16); box-shadow: none; transform: translateY(-1px); }

/* ---------- Screen scaffolding ---------- */
.screen { display: none; min-height: 100vh; }
.screen.is-active { display: block; }
.wrap { width: min(1180px, 94vw); margin: 0 auto; }

/* =====================================================================
   COVER
   ===================================================================== */
#screen-cover { display: none; place-items: center; padding: 3vh 0 6vh; min-height: 100vh; }
#screen-cover.is-active { display: grid; }
.cover {
  width: min(940px, 94vw); padding: clamp(1.6rem, 4vw, 3.4rem);
  text-align: center; border-radius: var(--radius);
}
.cover__crest {
  width: 86px; height: 86px; margin: 0 auto .6rem; display: grid; place-items: center;
  border: 3px solid var(--brass-2); border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, var(--brass-hi), var(--brass) 60%, var(--brass-2));
  box-shadow: inset 0 0 0 4px var(--paper), var(--shadow-1);
  font-family: var(--font-deco); font-weight: 900; letter-spacing: .02em;
  font-size: 2rem; color: var(--ledger-2);
}
.cover__eyebrow { margin: .2rem 0 .1rem; }
.cover__title {
  font-family: var(--font-display);
  font-size: clamp(2.7rem, 9vw, 6.2rem);
  color: var(--ledger);
  line-height: .9; margin: .1em 0 .12em;
  text-shadow: 3px 3px 0 var(--paper-3), 4px 4px 0 var(--brass-2);
}
.cover__title .sm { display: block; font-size: .42em; color: var(--red); letter-spacing: .04em; -webkit-text-stroke: 0; text-shadow: 2px 2px 0 var(--paper-3); }
.cover__sub { font-family: var(--font-deco); letter-spacing: .22em; text-transform: uppercase; color: var(--ink-soft); font-size: clamp(.7rem,1.7vw,.95rem); margin: .3rem 0 1.4rem; }
.cover__actions { display: flex; gap: .8rem; flex-wrap: wrap; justify-content: center; margin-top: 1.2rem; }
.cover__meta { margin-top: 1.6rem; font-size: .82rem; color: var(--ink-soft); font-style: italic; }
.cover__dice { font-size: 1.5rem; filter: drop-shadow(2px 2px 0 var(--paper-3)); }

/* =====================================================================
   SETUP
   ===================================================================== */
#screen-setup { padding: 5vh 0; }
.setup { width: min(760px, 94vw); margin: 0 auto; padding: clamp(1.4rem,3.5vw,2.6rem); border-radius: var(--radius); }
.setup h2 { font-family: var(--font-display); color: var(--ledger); font-size: clamp(1.6rem,4vw,2.4rem); margin: .2rem 0 .1rem; }
.field { margin: 1.4rem 0; }
.field > label { display: block; font-family: var(--font-deco); text-transform: uppercase; letter-spacing: .12em; font-size: .82rem; color: var(--ink-soft); margin-bottom: .55rem; }
.chip-row { display: flex; gap: .5rem; flex-wrap: wrap; }
.chip {
  font-family: var(--font-ui); font-size: 1.1rem; min-width: 3rem; padding: .5rem .9rem;
  border: 2px solid var(--ink); border-radius: 6px; background: var(--cream-hi); cursor: pointer;
  box-shadow: 2px 2px 0 var(--ink); transition: all .1s ease;
}
.chip.is-on { background: var(--ledger); color: var(--cream-hi); border-color: var(--ledger-3); box-shadow: 2px 2px 0 var(--ledger-3); }
.players-grid { display: grid; gap: .7rem; }
.player-row {
  display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: .8rem;
  padding: .55rem .7rem; background: var(--cream-hi); border: 1.5px solid var(--paper-3); border-radius: 8px;
}
.player-row__swatch { width: 26px; height: 26px; border-radius: 50%; border: 2px solid var(--ink); }
.player-row input[type=text] {
  font-family: var(--font-body); font-size: 1.05rem; border: none; background: transparent;
  border-bottom: 2px solid var(--paper-3); padding: .25rem .1rem; color: var(--ink); width: 100%;
}
.player-row input[type=text]:focus { outline: none; border-bottom-color: var(--brass-2); }
.token-pick { display: flex; gap: .25rem; }
.token-pick button { font-size: 1.2rem; line-height: 1; padding: .2rem .35rem; border: 2px solid transparent; border-radius: 6px; background: transparent; cursor: pointer; }
.token-pick button.is-on { border-color: var(--brass-2); background: var(--paper); }
.setup__foot { display: flex; justify-content: space-between; align-items: center; gap: 1rem; margin-top: 1.8rem; flex-wrap: wrap; }

/* =====================================================================
   GAME
   ===================================================================== */
#screen-game { padding: clamp(.4rem, 1.4vw, 1rem) 0 1rem; }
.game {
  width: min(1320px, 97vw); margin: 0 auto;
  display: grid; grid-template-columns: minmax(0,1fr) 340px; gap: clamp(.8rem,1.8vw,1.6rem);
  align-items: start;
}
.game__topbar {
  grid-column: 1 / -1; display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  padding: .5rem .9rem; margin-bottom: .2rem; border-radius: 8px; flex-wrap: wrap;
}
.game__brand { font-family: var(--font-deco); text-transform: uppercase; letter-spacing: .2em; color: var(--cream-hi); font-size: .85rem; }
.game__brand b { color: var(--brass-hi); }
.game__topbar .btn { font-size: .8rem; padding: .45em .9em; }

/* ---- Board ---- */
.board-stage { display: grid; place-items: center; }
.board {
  /* selalu persegi & muat: dibatasi lebar tersedia (dikurangi sidebar) ATAU tinggi viewport (dikurangi topbar+padding) */
  width: min(calc(94vw - 360px), calc(100vh - 126px), 760px);
  aspect-ratio: 1 / 1;
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  grid-template-rows: repeat(7, 1fr);
  gap: 0.4%; padding: 1%; border-radius: 8px;
  background:
    repeating-linear-gradient(0deg, transparent 0 22px, rgba(255,255,255,.05) 22px 23px),
    linear-gradient(160deg, var(--ledger), var(--ledger-2) 70%, var(--ledger-3));
  border: 3px solid var(--brass-2);
  box-shadow: inset 0 0 0 2px var(--ledger-3), inset 0 0 60px rgba(0,0,0,.35), var(--shadow-3);
}

/* Tiles */
.tile {
  position: relative; border-radius: 6px; overflow: hidden;
  background: var(--paper); border: 1.5px solid rgba(33,29,22,.5);
  display: flex; flex-direction: column; cursor: default;
  box-shadow: var(--shadow-1);
  transition: transform .12s ease, box-shadow .12s ease, filter .12s ease;
}
.tile__band { height: 26%; min-height: 14px; border-bottom: 1.5px solid rgba(33,29,22,.45); }
.tile__body { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2px; padding: 2px 3px; text-align: center; }
.tile__label {
  font-family: var(--font-ui); text-transform: uppercase; letter-spacing: .01em;
  font-size: clamp(.42rem, 1.05vw, .62rem); line-height: 1.04; color: var(--ink);
  overflow-wrap: anywhere; hyphens: auto; max-width: 100%;
}
.tile__sub { font-family: var(--font-body); font-size: clamp(.36rem,.85vw,.5rem); color: var(--ink-soft); font-style: italic; }
.tile__icon { font-size: clamp(.85rem, 2.1vw, 1.35rem); line-height: 1; }
.tile--corner { background: linear-gradient(150deg, var(--paper), var(--paper-2)); }
.tile--corner .tile__label { font-family: var(--font-deco); font-size: clamp(.4rem,1vw,.6rem); letter-spacing: .04em; }
.tile--start { background: linear-gradient(150deg, #f6ecd2, #e9d6a6); }
.tile--bonus { background: linear-gradient(150deg, #eaf3e2, #cfe6c4); }
.tile--pajak { background: linear-gradient(150deg, #f4ddd6, #e8c2b6); }
.tile--istirahat { background: linear-gradient(150deg, #e6e0ef, #d2c6e2); }
.tile--kesempatan, .tile--danaumum { background: linear-gradient(150deg, var(--paper), var(--paper-2)); }
.tile.is-current { transform: scale(1.04); z-index: 5; box-shadow: 0 0 0 3px var(--brass-hi), var(--shadow-2); filter: saturate(1.1); }
.tile.is-target { box-shadow: 0 0 0 3px var(--red-hi), var(--shadow-2); }

/* corner placement (span single cells, just styled bigger text) */
.tile[data-corner] .tile__body { gap: 3px; }

/* tokens on a tile — overlap dalam satu baris agar muat hingga 5 bidak */
.tile__tokens { position: absolute; left: 3px; right: 3px; bottom: 3px; display: flex; flex-wrap: nowrap; justify-content: flex-end; pointer-events: none; }
.tok {
  width: clamp(12px, 2.1vw, 18px); height: clamp(12px, 2.1vw, 18px); border-radius: 50%;
  display: grid; place-items: center; font-size: clamp(7px,1.3vw,11px);
  border: 2px solid #fff; box-shadow: 0 1px 3px rgba(0,0,0,.5); margin-left: -5px; flex: none;
}
.tok:first-child { margin-left: 0; }
.tok.is-moving { animation: hop .28s ease; }
@keyframes hop { 50% { transform: translateY(-9px) scale(1.12); } }

/* center emblem */
.board__center {
  grid-row: 2 / 7; grid-column: 2 / 7; position: relative;
  display: grid; place-items: center; text-align: center; color: var(--cream-hi);
  border-radius: 6px;
  background:
    repeating-conic-gradient(from 0deg, rgba(255,255,255,.03) 0 12deg, transparent 12deg 24deg),
    radial-gradient(circle at 50% 45%, rgba(199,154,58,.18), transparent 60%);
  overflow: hidden;
}
.emblem { transform: rotate(-8deg); }
.emblem__ring {
  font-family: var(--font-deco); letter-spacing: .3em; color: var(--brass-hi);
  font-size: clamp(.6rem, 1.4vw, 1rem); text-transform: uppercase;
}
.emblem__big {
  font-family: var(--font-display); color: var(--cream-hi);
  font-size: clamp(1.4rem, 4.2vw, 3.1rem); line-height: .9; margin: .1em 0;
  text-shadow: 2px 2px 0 var(--ledger-3), 3px 3px 0 var(--brass-2);
}
.emblem__sub { font-family: var(--font-body); font-style: italic; color: #d9e6da; font-size: clamp(.6rem,1.4vw,.95rem); }
.emblem__rosette {
  position: absolute; width: 78%; aspect-ratio: 1; border-radius: 50%; opacity: .25;
  border: 2px dashed var(--brass-hi);
  animation: spin 90s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.legend { position: absolute; left: 6px; bottom: 6px; display: grid; gap: 2px; text-align: left; background: rgba(8,43,32,.5); padding: 5px 7px; border-radius: 6px; border: 1px solid rgba(199,154,58,.35); }
.legend__item { display: flex; align-items: center; gap: 5px; font-family: var(--font-ui); font-size: clamp(.5rem,1vw,.64rem); letter-spacing: .03em; color: #eef4ec; text-transform: uppercase; }
.legend__dot { width: 9px; height: 9px; border-radius: 2px; }

/* ---- Sidebar ---- */
.side { display: grid; gap: .9rem; align-content: start; position: sticky; top: 10px; }
.panel { border-radius: 10px; padding: .85rem .95rem; }
.panel__title { font-family: var(--font-deco); text-transform: uppercase; letter-spacing: .14em; font-size: .74rem; color: var(--brass-2); margin: 0 0 .55rem; display: flex; align-items: center; gap: .4rem; }

/* turn + dice */
.turnbox { text-align: center; }
.turnbox__who { font-family: var(--font-display); font-size: 1.25rem; color: var(--ledger); display: flex; align-items: center; justify-content: center; gap: .5rem; max-width: 100%; }
.turnbox__who span:last-child { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; min-width: 0; }
.turnbox__who .swatch { width: 16px; height: 16px; border-radius: 50%; border: 2px solid var(--ink); }
.dice-wrap { display: flex; align-items: center; justify-content: center; gap: 1rem; margin: .7rem 0 .3rem; }
.die {
  width: 64px; height: 64px; border-radius: 12px; background: linear-gradient(145deg, #fff, #e9e2cf);
  border: 2px solid var(--ink); box-shadow: var(--shadow-1), inset 0 -4px 0 rgba(0,0,0,.08);
  display: grid; grid-template-columns: repeat(3,1fr); grid-template-rows: repeat(3,1fr);
  padding: 8px; gap: 2px;
}
.die.is-rolling { animation: tumble .6s ease; }
@keyframes tumble { 0%{transform:rotate(0) scale(1)} 25%{transform:rotate(-18deg) scale(1.08)} 50%{transform:rotate(16deg) scale(.96)} 75%{transform:rotate(-8deg) scale(1.05)} 100%{transform:rotate(0) scale(1)} }
.pip { border-radius: 50%; background: var(--ink); align-self: center; justify-self: center; width: 11px; height: 11px; visibility: hidden; }
.pip.on { visibility: visible; }

/* wallets */
.wallets { display: grid; gap: .45rem; }
.wallet {
  display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: .55rem;
  padding: .4rem .55rem; border-radius: 8px; background: var(--cream-hi); border: 1.5px solid var(--paper-3);
  transition: box-shadow .15s ease, transform .15s ease;
}
.wallet.is-turn { box-shadow: 0 0 0 2px var(--brass); transform: translateX(2px); background: #fff; }
.wallet__swatch { width: 22px; height: 22px; border-radius: 50%; border: 2px solid var(--ink); display: grid; place-items: center; font-size: .8rem; }
.wallet__name { font-family: var(--font-ui); font-size: .92rem; letter-spacing: .02em; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.wallet__lap { font-family: var(--font-body); font-style: italic; font-size: .68rem; color: var(--ink-soft); }
.wallet__cash { font-family: var(--font-mono); font-weight: 700; font-size: .92rem; color: var(--ledger); text-align: right; }
.wallet__cash.neg { color: var(--red); }

/* log */
.log { max-height: 168px; overflow-y: auto; display: grid; gap: .3rem; padding-right: 4px; }
.log__line { font-family: var(--font-body); font-size: .82rem; line-height: 1.25; color: var(--ink); padding: .25rem .4rem; border-left: 3px solid var(--brass-2); background: rgba(199,154,58,.08); border-radius: 0 4px 4px 0; }
.log__line.good { border-left-color: var(--ledger); background: rgba(20,83,63,.08); }
.log__line.bad { border-left-color: var(--red); background: rgba(155,34,38,.08); }
.log__line .mono { font-weight: 700; }

/* floating cash toast on board */
.cash-float { position: fixed; z-index: 60; font-family: var(--font-mono); font-weight: 700; font-size: 1.4rem; pointer-events: none; text-shadow: 1px 1px 0 rgba(0,0,0,.2); animation: floatUp 1.1s ease forwards; }
.cash-float.pos { color: #1f7a3f; }
.cash-float.neg { color: var(--red); }
@keyframes floatUp { 0%{opacity:0; transform: translateY(6px) scale(.8)} 18%{opacity:1; transform: translateY(0) scale(1.05)} 100%{opacity:0; transform: translateY(-46px) scale(1)} }

/* =====================================================================
   MODALS (quiz / card / howto / win)
   ===================================================================== */
.overlay {
  position: fixed; inset: 0; z-index: 80; display: none; place-items: center; padding: 4vh 4vw;
  background: rgba(8,28,21,.62); backdrop-filter: blur(3px);
}
.overlay.is-open { display: grid; animation: fade .2s ease; }
@keyframes fade { from { opacity: 0; } }

/* Voucher-styled quiz card */
.voucher {
  width: min(640px, 96vw); max-height: 88vh; overflow-y: auto; border-radius: 12px; position: relative;
  animation: rise .32s cubic-bezier(.2,.9,.25,1);
}
@keyframes rise { from { opacity: 0; transform: translateY(28px) scale(.97); } }
.voucher__head { padding: 1.1rem 1.3rem .7rem; text-align: center; position: relative; border-bottom: 2px dashed var(--paper-3); }
.voucher__phase { font-family: var(--font-deco); text-transform: uppercase; letter-spacing: .2em; font-size: .68rem; display: inline-block; padding: .2rem .7rem; border-radius: 20px; color: #fff; }
.voucher__no { position: absolute; top: 1rem; right: 1.2rem; font-family: var(--font-mono); font-size: .72rem; color: var(--ink-faint); }
.voucher__title { font-family: var(--font-display); color: var(--ledger); font-size: clamp(1.3rem,3.4vw,1.9rem); margin: .35rem 0 .1rem; }
.voucher__diff { font-family: var(--font-body); font-style: italic; color: var(--ink-soft); font-size: .8rem; }
.voucher__body { padding: 1.1rem 1.3rem 1.3rem; }
.voucher__scenario {
  font-family: var(--font-body); font-size: .98rem; line-height: 1.45; color: var(--ink);
  background: rgba(199,154,58,.12); border-left: 4px solid var(--brass); border-radius: 0 8px 8px 0;
  padding: .7rem .85rem; margin-bottom: 1rem;
}
.voucher__scenario b { color: var(--red-2); }
.voucher__prompt { font-family: var(--font-body); font-weight: 600; font-size: 1.12rem; line-height: 1.4; margin: 0 0 1rem; }
.options { display: grid; gap: .55rem; }
.opt {
  display: flex; align-items: flex-start; gap: .7rem; text-align: left; width: 100%;
  font-family: var(--font-body); font-size: 1.02rem; color: var(--ink);
  padding: .7rem .85rem; border: 2px solid var(--ink); border-radius: 8px; background: var(--cream-hi);
  cursor: pointer; box-shadow: 2px 2px 0 rgba(33,29,22,.25); transition: all .1s ease;
}
.opt:hover:not(:disabled) { transform: translate(-1px,-1px); box-shadow: 3px 3px 0 rgba(33,29,22,.3); background: #fff; }
.opt:disabled { cursor: default; }
.opt__key { font-family: var(--font-ui); width: 1.7em; height: 1.7em; flex: none; display: grid; place-items: center; border-radius: 5px; background: var(--ledger); color: var(--cream-hi); font-size: .85rem; }
.opt.correct { background: #e2f0d8; border-color: var(--ledger); box-shadow: 2px 2px 0 var(--ledger-3); }
.opt.correct .opt__key { background: var(--ledger); }
.opt.wrong { background: #f4dcd8; border-color: var(--red); box-shadow: 2px 2px 0 var(--red-2); }
.opt.wrong .opt__key { background: var(--red); }
.opt.dim { opacity: .55; }

/* feedback / stamp */
.feedback { margin-top: 1.1rem; display: none; }
.feedback.show { display: block; animation: fade .25s ease; }
.stamp {
  display: inline-block; font-family: var(--font-deco); text-transform: uppercase; letter-spacing: .12em;
  border: 3px double currentColor; border-radius: 8px; padding: .25rem .8rem; font-size: 1.05rem; font-weight: 700;
  transform: rotate(-7deg); animation: stampIn .3s cubic-bezier(.2,1.4,.4,1);
}
@keyframes stampIn { from { transform: rotate(-7deg) scale(2.2); opacity: 0; } }
.stamp.benar { color: var(--ledger); }
.stamp.salah { color: var(--red); }
.feedback__reward { font-family: var(--font-mono); font-weight: 700; margin-left: .6rem; }
.feedback__why {
  margin-top: .7rem; font-family: var(--font-body); font-size: .98rem; line-height: 1.5; color: var(--ink);
  background: var(--paper-2); border-radius: 8px; padding: .7rem .85rem;
}
.feedback__why b { color: var(--ledger-2); }
.voucher__foot { margin-top: 1.1rem; text-align: right; }

/* card (kesempatan / dana umum) */
.cardface { width: min(460px, 94vw); border-radius: 14px; padding: 1.4rem 1.4rem 1.2rem; text-align: center; position: relative; animation: rise .32s cubic-bezier(.2,.9,.25,1); }
.cardface__kind { font-family: var(--font-deco); text-transform: uppercase; letter-spacing: .28em; font-size: .8rem; color: var(--brass-2); }
.cardface__icon { font-size: 3rem; margin: .5rem 0; }
.cardface__text { font-family: var(--font-body); font-size: 1.18rem; line-height: 1.45; color: var(--ink); margin: .3rem 0 1rem; }
.cardface__effect { font-family: var(--font-mono); font-weight: 700; font-size: 1.25rem; margin-bottom: 1rem; }
.cardface__effect.pos { color: #1f7a3f; } .cardface__effect.neg { color: var(--red); } .cardface__effect.info { color: var(--ledger); }

/* howto */
.sheet { width: min(720px, 95vw); max-height: 90vh; overflow-y: auto; border-radius: 12px; padding: 1.6rem 1.7rem; }
.sheet h2 { font-family: var(--font-display); color: var(--ledger); font-size: 1.9rem; margin: .1rem 0 .3rem; }
.sheet ol, .sheet ul { font-family: var(--font-body); font-size: 1.02rem; line-height: 1.6; padding-left: 1.3rem; }
.sheet li { margin: .4rem 0; }
.sheet .closebar { text-align: right; margin-top: 1.2rem; }
.kbd { font-family: var(--font-mono); background: var(--paper-2); border: 1px solid var(--paper-3); border-radius: 4px; padding: 0 .35em; font-size: .85em; }

/* =====================================================================
   MATERI (learning mode)
   ===================================================================== */
#screen-materi { padding: 4vh 0 6vh; }
.materi { width: min(1120px, 95vw); margin: 0 auto; }
.materi__head { text-align: center; margin-bottom: 1.6rem; }
.materi__head h2 { font-family: var(--font-display); color: var(--cream-hi); font-size: clamp(1.8rem,5vw,3rem); margin: .2rem 0; text-shadow: 2px 2px 0 var(--ledger-3); }
.materi__head p { color: #d7e3d6; font-style: italic; }
.materi__grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: 1.4rem; align-items: start; }
.cycle {
  position: relative; aspect-ratio: 1; border-radius: 50%; display: grid; place-items: center;
  background: radial-gradient(circle at 50% 45%, rgba(199,154,58,.12), transparent 62%);
}
.cycle__center { text-align: center; width: 46%; }
.cycle__center .display { color: var(--brass-hi); font-size: clamp(1.1rem,3vw,1.8rem); }
.cycle__center p { color: #cfe0ce; font-size: .8rem; font-style: italic; margin: .3rem 0 0; }
.cycle__node {
  position: absolute; width: clamp(58px, 12%, 92px); aspect-ratio: 1; border-radius: 50%;
  display: grid; place-items: center; text-align: center; cursor: pointer;
  border: 2px solid var(--brass-2); background: var(--paper); color: var(--ink);
  font-family: var(--font-ui); text-transform: uppercase; font-size: clamp(.42rem,1.2vw,.6rem); line-height: 1.05;
  box-shadow: var(--shadow-1); transition: transform .12s ease, box-shadow .12s ease; padding: 3px;
}
.cycle__node:hover, .cycle__node.is-on { transform: scale(1.12); box-shadow: 0 0 0 3px var(--brass-hi), var(--shadow-2); z-index: 3; }
.cycle__node small { display: block; font-family: var(--font-mono); font-size: .9em; color: var(--brass-2); }
.materi__detail { border-radius: 12px; padding: 1.3rem 1.4rem; min-height: 320px; }
.materi__detail .eyebrow { display: block; margin-bottom: .2rem; }
.materi__detail h3 { font-family: var(--font-display); color: var(--ledger); font-size: clamp(1.4rem,3.4vw,2rem); margin: .1rem 0 .5rem; }
.materi__detail .short { font-family: var(--font-body); font-style: italic; font-size: 1.05rem; color: var(--ink-soft); margin-bottom: .8rem; }
.materi__detail .detail { font-family: var(--font-body); font-size: 1.04rem; line-height: 1.6; }
.materi__example { margin-top: 1rem; font-family: var(--font-mono); font-size: .9rem; line-height: 1.5; white-space: pre-wrap; background: var(--ledger); color: var(--cream-hi); border-radius: 8px; padding: .8rem 1rem; border-left: 4px solid var(--brass); }
.materi__example .label { display:block; font-family: var(--font-deco); letter-spacing: .14em; font-size: .62rem; color: var(--brass-hi); margin-bottom: .4rem; }
.materi__foot { text-align: center; margin-top: 1.8rem; }

/* =====================================================================
   WIN
   ===================================================================== */
#screen-win { display: none; place-items: center; min-height: 100vh; padding: 5vh 0; }
#screen-win.is-active { display: grid; }
.win { width: min(720px, 94vw); text-align: center; padding: clamp(1.6rem,4vw,3rem); border-radius: var(--radius); }
.win__trophy { font-size: 3.4rem; }
.win__eyebrow { margin-top: .4rem; }
.win__champ { font-family: var(--font-display); color: var(--ledger); font-size: clamp(2rem,6vw,3.4rem); margin: .1em 0; }
.scoreboard { display: grid; gap: .5rem; margin: 1.4rem 0; text-align: left; }
.score-row { display: grid; grid-template-columns: auto auto 1fr auto; align-items: center; gap: .7rem; padding: .6rem .8rem; border-radius: 8px; background: var(--cream-hi); border: 1.5px solid var(--paper-3); }
.score-row.first { border-color: var(--brass); box-shadow: 0 0 0 2px var(--brass-hi); background: #fff; }
.score-row__rank { font-family: var(--font-display); font-size: 1.3rem; color: var(--brass-2); width: 1.4em; text-align: center; }
.score-row__swatch { width: 22px; height: 22px; border-radius: 50%; border: 2px solid var(--ink); display:grid; place-items:center; }
.score-row__name { font-family: var(--font-ui); }
.score-row__name small { display:block; font-family: var(--font-body); font-style: italic; color: var(--ink-soft); font-size: .72rem; }
.score-row__cash { font-family: var(--font-mono); font-weight: 700; color: var(--ledger); }

/* confetti canvas */
#fx { position: fixed; inset: 0; pointer-events: none; z-index: 90; display: none; }
#fx.on { display: block; }

/* =====================================================================
   Responsive
   ===================================================================== */
/* touch targets (semua ukuran) */
.token-pick button { min-width: 40px; min-height: 40px; display: grid; place-items: center; padding: 0; -webkit-tap-highlight-color: transparent; }
.chip { min-height: 44px; display: inline-flex; align-items: center; justify-content: center; }
.score-row__name { min-width: 0; }
#screen-cover, #screen-win { min-height: 100dvh; }

@media (max-width: 1040px) {
  .game { grid-template-columns: 1fr; }
  .board { width: min(calc(96vw - 14px), calc(100vh - 130px), 680px); }
  .board-stage { order: -1; }
  .side { position: static; display: flex; flex-direction: column; gap: .9rem; }
  .side .panel { width: 100%; }
  .side .panel--wallets { order: 1; }
  .side .panel--log { order: 2; }
  .side .panel--turn {
    order: 3; position: sticky; bottom: 0; z-index: 50;
    box-shadow: 0 -8px 22px -8px rgba(8,43,32,.55);
  }
  .materi__grid { grid-template-columns: 1fr; }
}

@media (max-width: 720px) {
  /* papan dibatasi agar papan + topbar + bilah dadu-sticky muat tanpa tumpang tindih */
  .board { width: min(calc(100vw - 14px), calc(100vh - 196px)); }
  .game { padding-bottom: .4rem; }

  /* bilah giliran sticky di bawah — ringkas */
  .side .panel--turn { margin: 0 -7px; border-radius: 12px 12px 0 0; }
  .panel--turn .die { width: 50px; height: 50px; padding: 6px; }
  .panel--turn .dice-wrap { margin: .4rem 0 .25rem; }
  .panel--turn .btn--lg { font-size: 1.05rem; padding: .6em 1.4em; }
  .turnbox__who { font-size: 1.1rem; }

  /* petak */
  .tile__label { font-size: clamp(.46rem, 2vw, .58rem); line-height: 1.02; }
  .tile__sub { font-size: clamp(.34rem, 1.3vw, .46rem); }
  .tile__band { height: 22%; min-height: 10px; }
  .tile__body { padding: 1px 2px; }
  .tok { width: clamp(11px, 2.9vw, 16px); height: clamp(11px, 2.9vw, 16px); margin-left: -4px; }
  .tile__tokens { justify-content: center; }
  .board__center .legend { display: none; }
  .cover__title { text-shadow: 2px 2px 0 var(--paper-3), 3px 3px 0 var(--brass-2); }

  /* topbar ringkas */
  .game__topbar { padding: .4rem .6rem; gap: .5rem; }
  .game__brand { font-size: .7rem; letter-spacing: .12em; }
  .game__topbar .btn { font-size: .74rem; padding: .42em .7em; }

  /* kuis */
  .opt { min-height: 48px; align-items: center; padding: .8rem .9rem; }
  .options { gap: .6rem; }
  .voucher__no { position: static; display: block; text-align: right; margin: .1rem 0 0; }

  /* materi: ring -> grid 2 kolom yang bisa diketuk */
  .cycle { aspect-ratio: auto; border-radius: 12px; display: grid; grid-template-columns: repeat(2, 1fr); gap: .5rem; padding: .8rem; place-items: stretch; }
  .cycle .emblem__rosette { display: none; }
  .cycle__center { grid-column: 1 / -1; width: auto; margin-bottom: .2rem; }
  .cycle__node {
    position: static !important; left: auto !important; top: auto !important; transform: none !important;
    width: auto; aspect-ratio: auto; min-height: 50px; border-radius: 10px; padding: .5rem; font-size: .66rem; place-items: center;
  }
  .cycle__node:hover, .cycle__node.is-on { transform: none !important; box-shadow: 0 0 0 2px var(--brass-hi), var(--shadow-1); }
  .materi__detail { min-height: auto; padding: 1.1rem; }
}

/* papan: gunakan dvh bila didukung agar pas dengan bilah URL ponsel */
@supports (height: 100dvh) {
  @media (max-width: 720px) { .board { width: min(calc(100vw - 14px), calc(100dvh - 196px)); } }
}

@media (max-width: 480px) {
  /* setup: token-pick pindah ke baris bawah, input nama lebar penuh */
  .player-row { grid-template-columns: auto 1fr; grid-template-rows: auto auto; row-gap: .55rem; column-gap: .7rem; }
  .player-row__swatch { grid-row: 1; grid-column: 1; }
  .player-row > input[type=text] { grid-row: 1; grid-column: 2; }
  .token-pick { grid-row: 2; grid-column: 1 / -1; justify-content: space-between; flex-wrap: nowrap; }
  .token-pick button { flex: 1 1 0; }
  .setup__foot { flex-direction: column-reverse; align-items: stretch; }
  .setup__foot .btn { width: 100%; }
  .cover__actions { flex-direction: column; align-items: stretch; }
  .cover__actions .btn { width: 100%; min-height: 46px; }
  /* menang: nilai kas pada baris sendiri */
  .score-row { grid-template-columns: auto auto 1fr; grid-template-areas: 'rank swatch name' '. . cash'; row-gap: .2rem; }
  .score-row__rank { grid-area: rank; }
  .score-row__swatch { grid-area: swatch; }
  .score-row__name { grid-area: name; }
  .score-row__cash { grid-area: cash; justify-self: start; }
}

@media (max-width: 360px) {
  .tile__label { font-size: .46rem; letter-spacing: 0; }
  .tile__tokens { left: 2px; right: 2px; }
  .tok { width: 10px; height: 10px; font-size: 7px; margin-left: -5px; border-width: 1.5px; }
  .game__topbar .btn .lbl { display: none; }
}

/* landscape pendek (ponsel mendatar) */
@media (max-height: 540px) {
  #screen-cover { align-content: start; }
  .cover { padding: 1.2rem 1.4rem; }
  .cover__crest { width: 56px; height: 56px; font-size: 1.4rem; margin: 0 auto .3rem; }
}
@media (max-height: 480px) and (orientation: landscape) {
  .overlay { padding: 2vh 4vw; }
  .voucher { max-height: 96vh; }
  .voucher__head { padding: .55rem 1.3rem .45rem; }
  .voucher__body { padding: .7rem 1.3rem .9rem; }
}

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