:root{
  --parchment:#f4ecd8;
  --parchment-2:#ece0c4;
  --ink:#2a2118;
  --felt:#10402a;
  --felt-2:#0c3322;
  --gold:#b8893b;
  --gold-2:#9a6f2c;
  --crimson:#9c2b2b;
  --good:#2f7d4f;
  --line:#cdbf9d;
  --shadow:0 10px 30px rgba(20,14,4,.35);
}

*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:"Spectral",Georgia,serif;
  color:var(--ink);
  background:
    radial-gradient(circle at 30% 10%, #1a5638 0, transparent 45%),
    radial-gradient(circle at 80% 80%, #1a5638 0, transparent 45%),
    var(--felt);
  min-height:100vh;
}
h1,h2,h3,h4{font-family:"Playfair Display",Georgia,serif;margin:.2em 0}
a{color:var(--gold)}
.hidden{display:none !important}
.muted{color:#7c7059;font-size:.85rem}
.error{color:#ffd2d2;text-align:center;min-height:1.2em}

/* ---------- lobby ---------- */
.lobby{max-width:880px;margin:0 auto;padding:6vh 20px 40px}
.brandmark{text-align:center;color:var(--parchment);margin-bottom:32px}
.brand-rule{width:90px;height:4px;background:var(--gold);margin:0 auto 14px;border-radius:2px}
.brandmark h1{font-size:clamp(2.4rem,6vw,4rem);font-weight:800;letter-spacing:.5px;
  color:var(--parchment);text-shadow:2px 2px 0 rgba(0,0,0,.35)}
.tag{font-style:italic;color:#cdbf9d;margin-top:-4px}
.lobby-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
@media(max-width:680px){.lobby-grid{grid-template-columns:1fr}}
.card{
  background:linear-gradient(180deg,var(--parchment),var(--parchment-2));
  border:1px solid var(--gold-2);border-radius:14px;padding:22px 22px 26px;
  box-shadow:var(--shadow);position:relative;
}
.card:before{content:"";position:absolute;inset:6px;border:1px solid rgba(154,111,44,.35);
  border-radius:9px;pointer-events:none}
.card h2{color:var(--crimson)}
label{display:block;margin:12px 0 4px;font-weight:500}
input,select{
  width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:8px;
  background:#fbf6e9;font-family:inherit;font-size:1rem;color:var(--ink)
}
label.inline{display:flex;align-items:center;gap:8px;margin:8px 0}
label.inline input{width:auto;flex:1}
.code-input{text-transform:uppercase;letter-spacing:.4em;font-weight:700;text-align:center}
button{
  cursor:pointer;font-family:inherit;font-size:.95rem;border:1px solid var(--gold-2);
  background:linear-gradient(180deg,#f0e4c6,#e2d2a8);color:var(--ink);
  padding:9px 14px;border-radius:8px;margin-top:8px;transition:transform .05s, filter .15s
}
button:hover{filter:brightness(1.05)}
button:active{transform:translateY(1px)}
button:disabled{opacity:.45;cursor:not-allowed}
button.primary{background:linear-gradient(180deg,var(--crimson),#7e1f1f);color:#fff;border-color:#5e1414;width:100%}
button.good{background:linear-gradient(180deg,#3a9b63,#27784b);color:#fff;border-color:#1c5836}
button.warn{background:linear-gradient(180deg,#c98a2b,#a86e1c);color:#fff;border-color:#7c5012}
button.ghost{background:transparent;border-color:rgba(180,137,59,.5);color:inherit}
button.small{padding:5px 10px;font-size:.85rem;margin:0}
.tokens{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}
.tok{font-size:1.5rem;line-height:1;padding:4px 6px;border:2px solid transparent;border-radius:8px;cursor:pointer;background:#fbf6e9}
.tok.sel{border-color:var(--crimson);background:#fff}
.adminlink{text-align:center;margin-top:26px}
.adminlink a{color:#cdbf9d;text-decoration:none;font-style:italic}

/* ---------- game layout ---------- */
.game{display:grid;grid-template-columns:minmax(320px,1fr) 380px;gap:18px;
  max-width:1320px;margin:0 auto;padding:18px}
@media(max-width:1000px){.game{grid-template-columns:1fr}}
.board-wrap{display:flex;align-items:flex-start;justify-content:center}

.board{
  width:min(86vh,720px);aspect-ratio:1/1;
  display:grid;grid-template-columns:repeat(11,1fr);grid-template-rows:repeat(11,1fr);
  background:linear-gradient(135deg,#e9f3ea,#d7e8da);
  border:10px solid #0c3322;border-radius:8px;box-shadow:var(--shadow);overflow:hidden
}
.cell{
  position:relative;border:1px solid #b9c9bb;background:var(--parchment);
  font-size:.52rem;line-height:1.05;padding:2px;overflow:hidden;display:flex;flex-direction:column
}
.cell .nm{font-weight:600;font-family:"Spectral";letter-spacing:.1px}
.cell .pr{margin-top:auto;color:#6b6047;font-size:.5rem}
.cell .bar{height:14px;margin:-2px -2px 2px;border-bottom:1px solid rgba(0,0,0,.25)}
.cell.corner{font-size:.6rem;justify-content:center;align-items:center;text-align:center;background:var(--parchment-2)}
.cell.special{background:#e7efe8;align-items:center;justify-content:center;text-align:center}
.cell.mortg{filter:grayscale(.7) brightness(.92)}
.cell .owner-dot{position:absolute;top:2px;right:2px;width:9px;height:9px;border-radius:50%;border:1px solid #00000055}
.cell .houses{position:absolute;bottom:2px;left:2px;font-size:.55rem;letter-spacing:-1px;color:#1f7d3f}
.cell .houses.hotel{color:#b81b1b}
.center{grid-column:2/11;grid-row:2/11;background:
   repeating-linear-gradient(45deg,#10402a,#10402a 16px,#0e3a26 16px,#0e3a26 32px);
  display:flex;align-items:center;justify-content:center;flex-direction:column;color:var(--parchment)}
.center .logo{font-family:"Playfair Display";font-weight:800;font-size:clamp(1.2rem,3vw,2.4rem);
  transform:rotate(-8deg);color:var(--gold);text-shadow:2px 2px 0 #00000055}
.center .sub{font-style:italic;color:#cdbf9d;font-size:.8rem}
.tokens-here{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  display:flex;flex-wrap:wrap;gap:1px;justify-content:center;width:100%}
.pawn{font-size:.85rem;filter:drop-shadow(0 1px 1px rgba(0,0,0,.4))}

/* ---------- sidebar ---------- */
.sidebar{background:linear-gradient(180deg,var(--parchment),var(--parchment-2));
  border:1px solid var(--gold-2);border-radius:14px;padding:16px;box-shadow:var(--shadow);
  display:flex;flex-direction:column;gap:12px;max-height:calc(100vh - 36px);overflow:auto}
.side-head{display:flex;justify-content:space-between;align-items:center}
.code-badge{font-family:"Playfair Display";font-size:1.4rem;letter-spacing:.25em;color:var(--crimson)}
.turn-banner{background:#0c3322;color:var(--parchment);padding:8px 12px;border-radius:8px;
  text-align:center;font-weight:600}
.turn-banner.mine{background:var(--crimson)}
.players{display:flex;flex-direction:column;gap:6px}
.pl{display:flex;align-items:center;gap:8px;padding:6px 8px;border:1px solid var(--line);
  border-radius:8px;background:#fbf6e9}
.pl.active{border-color:var(--crimson);box-shadow:0 0 0 1px var(--crimson)}
.pl.broke{opacity:.45;text-decoration:line-through}
.pl .pawn{font-size:1.1rem}
.pl .nm{font-weight:600}
.pl .money{margin-left:auto;font-variant-numeric:tabular-nums;font-weight:600}
.badge{font-size:.62rem;background:var(--gold);color:#3a2a08;padding:1px 5px;border-radius:5px;margin-left:4px}
.badge.jail{background:#6b6b6b;color:#fff}
.badge.off{background:#bbb;color:#444}
.actions{display:flex;flex-wrap:wrap;gap:8px}
.actions button{margin:0;flex:1;min-width:90px}
.dice{text-align:center;font-size:1.6rem;min-height:1.2em;letter-spacing:6px}
.debt{background:#7e1f1f;color:#fff;padding:8px;border-radius:8px;font-size:.85rem}
.debt button{margin-top:6px;width:100%}

.panel{border:1px solid var(--line);border-radius:10px;background:#fbf6e9;overflow:hidden}
.panel-tabs{display:flex;border-bottom:1px solid var(--line);flex-wrap:wrap}
.tab{margin:0;border:none;border-radius:0;background:transparent;flex:1;border-bottom:2px solid transparent;font-size:.82rem}
.tab.active{border-bottom-color:var(--crimson);color:var(--crimson);font-weight:600}
.pane{display:none;padding:12px}
.pane.active{display:block}
.myprops{display:flex;flex-direction:column;gap:5px;max-height:230px;overflow:auto}
.mp{display:flex;align-items:center;gap:6px;padding:5px 7px;border:1px solid var(--line);border-radius:7px}
.mp .swatch{width:12px;height:12px;border-radius:3px;border:1px solid #0003}
.mp .nm{font-size:.82rem;flex:1}
.mp button{margin:0;padding:2px 6px;font-size:.72rem}
.trade-cols{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:8px 0}
.checklist{max-height:120px;overflow:auto;border:1px solid var(--line);border-radius:6px;padding:5px;font-size:.78rem}
.checklist label{display:flex;gap:5px;margin:2px 0;align-items:center}
.checklist input{width:auto}
.incoming{margin-top:10px;display:flex;flex-direction:column;gap:8px}
.trade-card{border:1px solid var(--gold-2);border-radius:8px;padding:8px;background:#fff7e6;font-size:.82rem}
.trade-card .row{display:flex;gap:6px;margin-top:6px}
.row{display:flex;gap:8px;flex-wrap:wrap}
.log,.chatlog{font-size:.8rem;max-height:220px;overflow:auto;display:flex;flex-direction:column-reverse}
.log div{padding:2px 0;border-bottom:1px dotted #e0d6bb}
.chat{border:1px solid var(--line);border-radius:10px;background:#fbf6e9;padding:8px}
.chatlog{max-height:120px}
.chatlog b{color:var(--crimson)}
.chat-input{display:flex;gap:6px;margin-top:6px}
.chat-input input{flex:1}

.prop-dialog{border:1px solid var(--gold-2);border-radius:12px;background:var(--parchment);
  padding:18px;max-width:340px;box-shadow:var(--shadow)}
.prop-dialog::backdrop{background:rgba(8,20,12,.6)}

.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);
  background:#0c3322;color:#fff;padding:10px 16px;border-radius:8px;opacity:0;
  transition:opacity .25s;pointer-events:none;box-shadow:var(--shadow);max-width:90vw;z-index:50}
.toast.show{opacity:1}

/* ---------- admin ---------- */
.admin{max-width:1100px;margin:0 auto;padding:5vh 20px}
.admin .card{max-width:420px;margin:0 auto}
.games-table{width:100%;border-collapse:collapse;background:var(--parchment);border-radius:10px;overflow:hidden}
.games-table th,.games-table td{padding:9px 12px;text-align:left;border-bottom:1px solid var(--line);font-size:.9rem}
.games-table th{background:#0c3322;color:var(--parchment);font-family:"Playfair Display"}
.games-table tr:hover{background:#fff7e6}
.admin-game{margin-top:24px}
