/* Monopoly Ady — iPhone-first, low-poly elegant, OKLCH. GPU-only (transform/opacity). */
:root{
  --bg:#0e1410; --panel:oklch(0.22 0.02 150 / .82); --panel-solid:#16201a;
  --ink:oklch(0.96 0.01 120); --muted:oklch(0.72 0.02 140);
  --gold:oklch(0.82 0.13 85); --gold-deep:oklch(0.66 0.12 80);
  --line:oklch(0.4 0.02 150 / .4); --ok:oklch(0.8 0.15 150); --danger:oklch(0.65 0.2 25);
  --r:18px; --r-sm:12px; --pad:env(safe-area-inset-top,0);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%;background:var(--bg);color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;
  overscroll-behavior:none;-webkit-user-select:none;user-select:none}
canvas#scene{position:fixed;inset:0;width:100%;height:100%;display:block;touch-action:none}
#vignette{position:fixed;inset:0;z-index:4;pointer-events:none;
  background:radial-gradient(125% 95% at 50% 44%, transparent 52%, rgba(0,0,0,.20) 78%, rgba(0,0,0,.5) 100%)}

/* Poster */
#poster{position:fixed;inset:0;z-index:50;display:grid;place-items:center;
  background:radial-gradient(120% 90% at 50% 0%,#1b2a20,#0a0f0c);transition:opacity .5s}
#poster.hide{opacity:0;pointer-events:none}
.poster-inner{text-align:center}
.logo-mark{font-size:54px;filter:drop-shadow(0 6px 20px #0008)}
.logo{font-size:30px;letter-spacing:.14em;margin:.3em 0 0;font-weight:800}
.logo span{color:var(--gold)}
.tagline{color:var(--muted);letter-spacing:.32em;font-size:11px;margin:.5em 0 1.6em}
.loader{display:flex;gap:7px;justify-content:center}
.loader span{width:9px;height:9px;border-radius:50%;background:var(--gold);animation:b 1s infinite}
.loader span:nth-child(2){animation-delay:.15s}.loader span:nth-child(3){animation-delay:.3s}
@keyframes b{0%,100%{opacity:.25;transform:translateY(0)}50%{opacity:1;transform:translateY(-6px)}}
.load-status{color:var(--muted);font-size:12px;margin-top:1.4em}

/* Overlays / panels */
.overlay{position:fixed;inset:0;z-index:40;display:grid;place-items:center;padding:20px;
  background:oklch(0.1 0.02 150 / .55);backdrop-filter:blur(8px);animation:fade .25s}
/* decizii în joc: tabla rămâne vizibilă CURAT în fundal (cerere Adrian) */
#buy-dialog,#auction{background:oklch(0.08 0.02 60 / .22);backdrop-filter:blur(1.5px)}
@keyframes fade{from{opacity:0}}
.panel{background:var(--panel);backdrop-filter:blur(20px);border:1px solid var(--line);
  border-radius:var(--r);padding:22px;box-shadow:0 20px 60px #0007;max-width:360px;width:100%}
.dialog{text-align:center}.center{text-align:center}
.lobby-card h2,.dialog h3{margin:.1em 0 .6em;font-weight:700}
.field{display:flex;justify-content:space-between;align-items:center;margin:14px 0;color:var(--muted)}
.stepper{display:flex;align-items:center;gap:14px}
.stepper button{width:44px;height:44px;border-radius:var(--r-sm);border:1px solid var(--line);
  background:#0003;color:var(--ink);font-size:22px}
.stepper b{min-width:24px;text-align:center;font-size:20px;color:var(--ink)}

/* Buttons (touch >=44px) */
button{font:inherit;cursor:pointer;border:none}
.btn-primary{background:linear-gradient(180deg,var(--gold),var(--gold-deep));color:#231a06;
  font-weight:700;padding:14px 22px;border-radius:var(--r-sm);min-height:48px;width:100%;
  box-shadow:0 8px 24px oklch(0.66 0.12 80 / .35);transition:transform .12s}
.btn-primary:active{transform:scale(.96)}
.btn-primary.big{font-size:18px}
.btn-ghost{background:#0004;color:var(--ink);border:1px solid var(--line);
  padding:12px 18px;border-radius:var(--r-sm);min-height:44px;width:100%}
.dialog-actions{display:grid;gap:10px;margin-top:18px}

/* Titlu de proprietate (deed) */
.deed{padding:0;overflow:hidden;max-width:340px;background:var(--panel-solid)}
.deed-band{padding:18px 16px;font-weight:800;font-size:21px;letter-spacing:.01em;color:#fff;
  text-align:center;text-shadow:0 1px 3px #0006;border-bottom:3px solid #0003;line-height:1.15}
.deed-kind{text-align:center;font-size:10px;letter-spacing:.22em;color:var(--muted);
  margin:11px 0 4px;font-weight:700}
.deed-body{padding:4px 18px 6px}
.deed-row{display:flex;justify-content:space-between;align-items:center;gap:12px;
  padding:7px 0;border-bottom:1px solid var(--line);font-size:14px;color:var(--ink)}
.deed-row span{color:var(--muted)}
.deed-row b{color:var(--ink);font-variant-numeric:tabular-nums}
.deed-row.strong{font-weight:700}
.deed-row.strong span,.deed-row.strong b{color:var(--gold)}
.deed-note{margin:10px 0 2px;font-size:11px;line-height:1.4;color:var(--muted);text-align:center}
.deed .dialog-actions{padding:0 18px 18px;margin-top:12px}

/* Alegere pion */
.pawn-card{max-width:560px}
.pawn-head{display:flex;align-items:center;gap:10px;justify-content:center}
.pawn-head h3{margin:0}
.pawn-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(84px,1fr));gap:8px;
  max-height:64vh;overflow-y:auto;padding:2px}
.pawn-cell{position:relative;background:#0003;border:1px solid var(--line);border-radius:12px;
  padding:6px;display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--ink);
  min-height:44px;transition:transform .1s,border-color .1s}
.pawn-cell img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:8px;background:#2c2620}
.pawn-cell span{font-size:11px;font-weight:600;text-align:center;line-height:1.1}
.pawn-cell:not(.taken):active{transform:scale(.94)}
.pawn-cell:not(.taken):hover{border-color:var(--gold)}
.pawn-cell.taken{opacity:.34;filter:grayscale(1);pointer-events:none}
.pawn-lock{position:absolute;top:6px;right:6px;background:var(--gold);color:#1a1510;
  width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:13px;font-weight:800;font-style:normal}

/* Banner aterizare: nume + preț, apare scurt sus-centru */
.landbanner{position:fixed;top:calc(64px + var(--pad));left:50%;transform:translateX(-50%);z-index:24;
  display:flex;align-items:center;gap:9px;background:oklch(0.16 0.02 150 / .9);backdrop-filter:blur(8px);
  border:1px solid var(--line);border-radius:999px;padding:9px 18px;box-shadow:0 8px 24px #0006;
  white-space:nowrap;max-width:92vw;animation:lbIn .3s ease}
.landbanner b{font-size:15px}
.landbanner #lb-sub{font-size:13px}
.lb-dot{width:12px;height:12px;border-radius:50%;flex:0 0 auto}
.landbanner.out{opacity:0;transform:translateX(-50%) translateY(-8px);transition:.4s}
@keyframes lbIn{from{opacity:0;transform:translateX(-50%) translateY(-10px)}}

/* Buton transparent „Proprietățile mele" în HUD */
.hud-chip{background:oklch(1 0 0 / .07);border:1px solid var(--line);color:var(--ink);
  border-radius:999px;padding:6px 12px;min-height:38px;font-size:14px;display:flex;align-items:center;gap:5px}
.hud-chip b{color:var(--gold);font-variant-numeric:tabular-nums}
.hud-chip:active{transform:scale(.95)}

/* Pagina „Proprietățile mele" — galerie de cărți */
.myprops-card{max-width:620px;max-height:88vh;display:flex;flex-direction:column}
.myprops-head{display:flex;align-items:center;justify-content:space-between}
.myprops-head h3{margin:0}
.myprops-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(138px,1fr));gap:12px;
  overflow-y:auto;padding:4px;perspective:1100px}
/* card flip 3D */
.flip-card{height:228px;cursor:pointer}
.flip-inner{position:relative;width:100%;height:100%;transition:transform .55s cubic-bezier(.4,.1,.2,1);
  transform-style:preserve-3d}
.flip-card.flipped .flip-inner{transform:rotateY(180deg)}
.flip-front,.flip-back{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;
  border-radius:12px;overflow:hidden;background:var(--panel-solid);border:1px solid var(--line);
  display:flex;flex-direction:column}
.flip-back{transform:rotateY(180deg);align-items:center;justify-content:center;text-align:center;padding:14px;gap:4px}
.fc-band{padding:9px 6px;font-weight:800;font-size:13px;text-align:center;line-height:1.1;text-shadow:0 1px 2px #0004}
.fc-kind{text-align:center;font-size:8px;letter-spacing:.16em;color:var(--muted);margin:6px 0 3px;font-weight:700}
.fc-rows{flex:1;padding:0 9px;font-size:10px;display:flex;flex-direction:column;justify-content:center;gap:2px}
.fc-row{display:flex;justify-content:space-between;color:var(--ink)}
.fc-row span{color:var(--muted)}
.fc-row.hot{color:var(--gold);font-weight:700}
.fc-foot{padding:7px 9px;border-top:1px solid var(--line);font-size:11px;font-weight:700;text-align:center}
.fc-stat{color:var(--gold);font-size:10px}
.fc-back-title{font-size:11px;letter-spacing:.2em;color:var(--muted);font-weight:700}
.fc-back-val{font-size:32px;font-weight:800;color:var(--gold)}
.fc-back-un{font-size:12px;color:var(--ink)}
.fc-act{margin-top:8px;background:#0004;border:1px solid var(--line);color:var(--ink);
  border-radius:10px;padding:9px 14px;min-height:40px;font-weight:600;font-size:13px;width:100%}
.fc-hint{font-size:9px;color:var(--muted);margin-top:6px}

/* HUD */
.hud{position:fixed;top:calc(10px + var(--pad));left:10px;right:10px;z-index:30;
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  background:var(--panel);backdrop-filter:blur(16px);border:1px solid var(--line);
  border-radius:var(--r);padding:10px 14px}
.hud-player{display:flex;align-items:center;gap:10px}
.hud-cash{font-size:20px}.hud-cash b{color:var(--gold)}
.icon-btn{background:#0004;border:1px solid var(--line);border-radius:10px;width:40px;height:40px;font-size:18px;flex:0 0 auto}
.dot{width:14px;height:14px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 3px #fff2}
.dot.lg{width:22px;height:22px;display:inline-block;margin-bottom:6px}

/* Action bar */
.actionbar{position:fixed;bottom:calc(16px + env(safe-area-inset-bottom,0));left:14px;right:14px;
  z-index:30;display:flex;gap:10px}
.actionbar .btn-primary,.actionbar .btn-ghost{width:auto;flex:1}

/* Log toasts */
.log{position:fixed;bottom:90px;left:14px;right:14px;z-index:25;display:flex;
  flex-direction:column;gap:6px;pointer-events:none}
.log .toast{background:var(--panel-solid);border:1px solid var(--line);border-radius:10px;
  padding:8px 12px;font-size:13px;color:var(--ink);opacity:0;transform:translateY(8px);
  animation:toast 3.2s forwards}
@keyframes toast{8%{opacity:1;transform:translateY(0)}85%{opacity:1}100%{opacity:0}}
.over-ico{font-size:48px}
.muted{color:var(--muted)}.xs{font-size:11px}
[hidden]{display:none!important}

/* Lobby online */
.inp{width:100%;padding:13px 14px;border-radius:var(--r-sm);border:1px solid var(--line);
  background:#0004;color:var(--ink);font-size:16px;min-height:48px}
.inp::placeholder{color:var(--muted)}
.or{text-align:center;color:var(--muted);font-size:12px;margin:14px 0;position:relative}
.roomcode{font-size:30px;font-weight:800;letter-spacing:.18em;color:var(--gold);
  text-align:center;padding:14px;background:#0004;border-radius:var(--r-sm);
  border:1px dashed var(--line);margin:6px 0 14px;user-select:all}
.seats{list-style:none;padding:0;margin:0 0 14px;display:flex;flex-direction:column;gap:6px}
.seats li{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#0003;
  border-radius:10px;font-size:14px}
.seats li .s-dot{width:10px;height:10px;border-radius:50%;background:var(--ok)}
.seats li.off .s-dot{background:var(--danger)}

/* Manage panel */
.manage-card{max-width:380px}
.manage-list{max-height:60vh;overflow-y:auto;display:flex;flex-direction:column;gap:8px}
.m-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:9px 11px;
  background:#0003;border-radius:10px}
.m-name{flex:1;font-size:14px;font-weight:600;min-width:90px}
.m-acts{display:flex;gap:6px;flex-wrap:wrap;width:100%}
.m-btn{background:#0005;border:1px solid var(--line);color:var(--ink);
  padding:8px 10px;border-radius:9px;font-size:12px;min-height:38px}
.m-btn:active{transform:scale(.95)}
.m-btn.on{background:var(--gold);color:#231a06;border-color:var(--gold)}

/* Trade */
.trade-card{max-width:400px}
.trade-pick{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.trade-col{margin-bottom:14px}
.trade-col h4{margin:.2em 0 .5em;font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.chip{display:inline-flex;align-items:center;gap:6px;background:#0004;border:1px solid var(--line);
  color:var(--ink);padding:7px 10px;border-radius:9px;font-size:12px;margin:0 6px 6px 0;min-height:36px}
.chip.on{background:oklch(0.5 0.12 150 / .5);border-color:var(--ok)}
.chip .dot{width:9px;height:9px}
.inp.cash{margin-top:6px;max-width:140px}

/* Players hub */
.pl-card{background:#0003;border:1px solid var(--line);border-radius:12px;padding:10px 12px;margin-bottom:8px}
.pl-head{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:14px}
.pl-head .muted{margin-left:auto}
.pl-props{display:flex;flex-wrap:wrap;gap:6px}
.pl-props .chip{font-size:11px;padding:6px 9px}
