:root{
  --y:#FFDD2D;--blk:#080808;--w:#fff;
  --panel:#0d0d0d;--card:#141414;--brd:#1e1e1e;
  --brown:#8B4513;--lb:#5bb8e0;--pink:#e0559a;
  --orange:#e07a00;--red:#c0192c;--cyellow:#c8a800;
  --green:#1a7a1a;--dblue:#1a3ab5;--svc:#5a5a8a;
}
*{margin:0;padding:0;box-sizing:border-box;}
html,body{width:100%;height:100%;overflow:hidden;font-family:'Inter',sans-serif;background:var(--blk);color:var(--w);}
button{touch-action:manipulation;-webkit-tap-highlight-color:transparent;}

/* ===== LOBBY ===== */
#lobby{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;padding:20px;
  background:#FFF8E7;position:relative;overflow:hidden;}
#lb-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0;}
#lobby>*:not(#lb-canvas){position:relative;z-index:1;}

.logo{font-family:'Unbounded',sans-serif;font-size:clamp(32px,5vw,64px);font-weight:900;color:#111;
  letter-spacing:-2px;}
.logo-s{font-family:'Unbounded',sans-serif;font-size:13px;color:rgba(0,0,0,.35);letter-spacing:5px;margin:8px 0 40px;}
.lcard{background:rgba(18,18,18,.97);border:1px solid rgba(255,255,255,.07);border-radius:20px;padding:36px;
  width:100%;max-width:440px;display:flex;flex-direction:column;gap:20px;box-shadow:0 30px 70px rgba(0,0,0,.25);}
.lcard h2{font-family:'Unbounded',sans-serif;font-size:13px;color:var(--y);letter-spacing:2px;}
.ig{display:flex;flex-direction:column;gap:6px;}
.ig label{font-size:11px;color:rgba(255,255,255,.35);letter-spacing:1.5px;text-transform:uppercase;}
.ig input{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:10px;
  padding:13px 16px;color:white;font-size:15px;outline:none;transition:all .2s;}
.ig input:focus{border-color:rgba(255,221,45,.6);background:rgba(255,221,45,.04);}
.btn{padding:15px 20px;border-radius:12px;border:none;font-family:'Unbounded',sans-serif;
  font-size:12px;font-weight:700;cursor:pointer;transition:all .2s;letter-spacing:.5px;}
.by{background:var(--y);color:#000;}.by:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(255,221,45,.35);}
.bo{background:rgba(255,255,255,.07);color:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.14);}
.bo:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.3);}
.hdiv{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.18);font-size:12px;}
.hdiv::before,.hdiv::after{content:'';flex:1;height:1px;background:rgba(255,255,255,.08);}

/* ===== WAITING ===== */
#waiting{display:none;flex-direction:column;align-items:center;justify-content:flex-start;min-height:100dvh;padding:20px;
  background:#FFF8E7;position:relative;overflow-y:auto;}
#waiting-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0;}
#waiting>*:not(#waiting-canvas){position:relative;z-index:1;}
#waiting .lcard{transform:translateY(-18px);}
.wait-lbl{font-family:'Unbounded',sans-serif;font-size:12px;color:rgba(255,255,255,.35);letter-spacing:4px;}
.rcode{font-family:'Unbounded',sans-serif;font-size:clamp(22px,4vw,44px);font-weight:900;
  color:#FFDD2D;letter-spacing:clamp(3px,.7vw,8px);line-height:1.02;margin:10px 0;
  white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:clip;}
#show-code{display:block;width:100%;text-align:center;font-size:clamp(18px,3.1vw,32px);letter-spacing:clamp(1px,.24vw,3px);}
.wplist{display:flex;flex-direction:column;gap:8px;width:100%;max-width:400px;margin:10px 0;}
.wpi{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px 16px;color:#fff;}

/* ===== GAME ===== */
#game{display:none;height:100vh;height:100dvh;overflow:hidden;}
.gl{display:grid;grid-template-columns:230px 1fr 310px;grid-template-rows:100vh;grid-template-rows:100dvh;height:100vh;height:100dvh;}

/* LEFT */
.lp{background:var(--panel);border-right:1px solid var(--brd);overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px;min-height:0;}
.ptit{font-family:'Unbounded',sans-serif;font-size:9px;letter-spacing:3px;color:rgba(255,255,255,.2);
  text-transform:uppercase;padding-bottom:6px;border-bottom:1px solid var(--brd);}
.pc{background:var(--card);border:1px solid var(--brd);border-radius:10px;padding:11px 12px;
  transition:all .25s;position:relative;overflow:hidden;}
.pc::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:transparent;border-radius:2px 0 0 2px;}
.pc.cur{border-color:rgba(255,221,45,.35);background:rgba(255,221,45,.04);}
.pc.cur::before{background:var(--y);}
.pc.bk{opacity:.3;}
.react-fly{position:fixed;font-size:26px;pointer-events:none;z-index:9999;will-change:transform,opacity;}
.react-bar{display:flex;gap:4px;flex-wrap:wrap;}
.react-bar button{background:none;border:1px solid rgba(255,255,255,.1);border-radius:8px;font-size:15px;cursor:pointer;padding:3px 6px;transition:all .15s;line-height:1;}
.react-bar button:hover{background:rgba(255,255,255,.1);transform:scale(1.25);}
.money-pop{position:fixed;font-family:'Unbounded',sans-serif;font-size:20px;
  font-weight:700;pointer-events:none;white-space:nowrap;z-index:9000;
  transform:translate(-50%,-50%);
  animation:mfloat 5s ease-out forwards;}
.money-pop.pos{color:#2ecc71;text-shadow:0 0 12px rgba(46,204,113,.5);}
.money-pop.neg{color:#e74c3c;text-shadow:0 0 12px rgba(231,76,60,.5);}
@keyframes mfloat{0%{opacity:1;transform:translate(-50%,-50%)}55%{opacity:1;transform:translate(-50%,calc(-50% - 18px))}100%{opacity:0;transform:translate(-50%,calc(-50% - 60px))}}
.pch{display:flex;align-items:center;gap:8px;margin-bottom:4px;}
.ptok{font-size:20px;}.pnm{font-weight:600;font-size:12px;flex:1;overflow:hidden;word-break:break-word;line-height:1.2;}
.pmn{font-family:'Unbounded',sans-serif;font-size:17px;font-weight:700;color:var(--y);}
.ppos{font-size:10px;color:rgba(255,255,255,.3);}
.pprops{display:flex;flex-direction:column;gap:2px;margin-top:5px;}
.ppd{width:7px;height:7px;border-radius:2px;flex-shrink:0;}
.ppl-item{display:flex;align-items:center;gap:5px;font-size:10px;color:rgba(255,255,255,.45);line-height:1.3;}
.ppl-item:first-child{color:rgba(255,255,255,.65);}
.ytb{display:inline-block;background:var(--y);color:#000;font-family:'Unbounded',sans-serif;
  font-size:8px;font-weight:700;padding:2px 7px;border-radius:20px;margin-top:3px;animation:yp 1.5s infinite;}
@keyframes yp{0%,100%{box-shadow:0 0 0 0 rgba(255,221,45,.5)}50%{box-shadow:0 0 0 5px rgba(255,221,45,0)}}

/* CENTER */
.cc{display:flex;align-items:center;justify-content:center;background:#FFF9F0;position:relative;overflow:hidden;min-height:0;}
#game-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0;}
.bw{position:relative;z-index:1;}

/* ===== THE BOARD ===== */
/*
  Board is a 12×12 grid (including corners).
  Corner cells: 1,1 | 12,1 | 1,12 | 12,12
  Bottom row (row 12): spaces 0-10, left to right (col 1..12)
  Left col  (col 1):  spaces 10-20, bottom to top (row 12..1)
  Top row   (row 1):  spaces 20-30, right to left (col 12..1)
  Right col (col 12): spaces 30-40, top to bottom (row 1..12)
*/
#board{
  display:grid;
  grid-template-columns:var(--corner) repeat(9,var(--cell)) var(--corner);
  grid-template-rows:var(--corner) repeat(9,var(--cell)) var(--corner);
  background:#fffff0;
  border:3px solid #333;
  box-shadow:0 8px 48px rgba(0,0,0,.22),0 2px 12px rgba(0,0,0,.12),inset 0 0 0 1px rgba(0,0,0,.08);
  flex-shrink:0;
}

/* Center zone */
.board-center{
  grid-column:2/11;grid-row:2/11;
  background:#FFDD2D;
  position:relative;
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.center-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2;position:relative;}
.center-logo{font-family:'Unbounded',sans-serif;font-size:clamp(16px,2.8vw,42px);font-weight:900;color:#111;letter-spacing:-1px;}
.center-sub{font-size:clamp(6px,.9vw,12px);color:rgba(0,0,0,.38);letter-spacing:4px;margin-top:3px;}
/* Dice animation overlay */
#dice-anim{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  gap:clamp(12px,2.5vw,36px);z-index:50;pointer-events:none;
  opacity:0;transition:opacity .3s;
  background:rgba(0,0,0,.45);backdrop-filter:blur(2px);
}
#dice-anim.on{opacity:1;}
.da-die{
  width:clamp(64px,9vw,120px);height:clamp(64px,9vw,120px);
  background:#fff;border-radius:clamp(8px,1.2vw,16px);
  box-shadow:0 8px 32px rgba(0,0,0,.6),0 2px 8px rgba(0,0,0,.4),inset 0 0 0 2px rgba(0,0,0,.08);
  display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);
  padding:clamp(6px,.9vw,12px);gap:clamp(3px,.4vw,5px);box-sizing:border-box;
}
.da-dot{background:#1a1a1a;border-radius:50%;}
.da-die.rolling{animation:dRoll .13s linear infinite;}
@keyframes dRoll{
  0%  {transform:rotate(-20deg) scale(1.15);}
  25% {transform:rotate( 14deg) scale(0.9);}
  50% {transform:rotate( -9deg) scale(1.08);}
  75% {transform:rotate( 16deg) scale(0.95);}
  100%{transform:rotate(-20deg) scale(1.15);}
}
@keyframes dSettle{
  0%  {transform:scale(1.35) rotate(5deg);}
  55% {transform:scale(0.9) rotate(-2deg);}
  100%{transform:scale(1) rotate(0);}
}
/* Card decks */
.deck-ch{position:absolute;top:8%;left:10%;display:flex;flex-direction:column;align-items:center;gap:5px;}
.deck-co{position:absolute;bottom:8%;right:10%;display:flex;flex-direction:column;align-items:center;gap:5px;}
.deck-card{
  width:clamp(46px,5.8vw,86px);height:clamp(30px,3.8vw,58px);
  border-radius:6px;display:flex;align-items:center;justify-content:center;
  font-size:clamp(14px,1.9vw,30px);box-shadow:0 4px 16px rgba(0,0,0,.28);cursor:pointer;transition:transform .2s;
}
.deck-card:hover{transform:scale(1.1) rotate(3deg);}
.dc-ch{background:linear-gradient(135deg,#fff9e6,#ffd54f);border:1px solid rgba(0,0,0,.1);}
.dc-co{background:linear-gradient(135deg,#e3f2fd,#64b5f6);border:1px solid rgba(0,0,0,.1);}
.deck-lbl{font-size:clamp(5px,.65vw,9px);font-weight:700;color:rgba(0,0,0,.45);letter-spacing:1px;text-transform:uppercase;}
/* Hat mascot — positioned via JS over the "Я" letter */
.center-mascot{
  position:absolute;
  font-size:clamp(16px,2.2vw,36px);
  animation:flt 4s ease-in-out infinite;pointer-events:none;
  filter:drop-shadow(0 4px 8px rgba(0,0,0,.2));
  transform-origin:bottom center;
}
@keyframes flt{0%,100%{transform:rotate(-6deg)}50%{transform:translateY(-7px) rotate(3deg)}}
.pot-disp{position:absolute;top:8%;left:50%;transform:translateX(-50%);
  background:rgba(0,0,0,.7);border:1px solid rgba(255,221,45,.3);border-radius:7px;
  padding:3px 10px;font-size:clamp(7px,.9vw,11px);color:var(--y);
  font-family:'Unbounded',sans-serif;white-space:nowrap;display:none;pointer-events:none;}

/* ===== SPACE CELLS ===== */
.sp{
  border:1px solid #bbb;
  background:#fffff8;
  position:relative;
  overflow:hidden;
  cursor:pointer;
  transition:filter .15s;
  display:flex;
}
.sp:hover{filter:brightness(.84);}

/* Bottom row spaces (normal orientation: color bar at top, name at bottom) */
.sp.bot{
  flex-direction:column;
  align-items:center;
  justify-content:flex-end;
  padding-bottom:2px;
}
/* Top row spaces (inverted: color bar at bottom from viewer perspective = order last in flex-col-reverse) */
.sp.top{
  flex-direction:column-reverse;
  align-items:center;
  justify-content:flex-end;
  padding-bottom:2px;
}

/* Left col spaces (rotated 90° clockwise so text reads left→right when looking from left) */
.sp.lft{
  flex-direction:column;
  align-items:center;
  justify-content:flex-end;
  padding-bottom:2px;
  writing-mode:horizontal-tb;
  transform:rotate(90deg);
}

/* Right col spaces */
.sp.rgt{
  flex-direction:column;
  align-items:center;
  justify-content:flex-end;
  padding-bottom:2px;
  writing-mode:horizontal-tb;
  transform:rotate(-90deg);
}

/* Special cell icon (chance, tax, utility) */
.sp-icon{font-size:clamp(10px,1.5vw,20px);color:#333;font-weight:900;line-height:1;margin:2px 0;}
/* Big decorative icon for special / service cells */
.sp-big-wrap{position:absolute;left:0;right:0;display:flex;align-items:center;justify-content:center;pointer-events:none;}
.sp-big-sym{line-height:1;text-align:center;}
/* Richer chance/cc backgrounds */
.sp-ch{background:linear-gradient(150deg,#fffde7 0%,#ffe082 100%);}
.sp-ch::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 46%,rgba(255,193,7,.55) 0%,transparent 68%);pointer-events:none;}
.sp-cc{background:linear-gradient(150deg,#e8f4fd 0%,#90caf9 100%);}
.sp-cc::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 46%,rgba(66,133,244,.45) 0%,transparent 68%);pointer-events:none;}
.sp-tx{background:linear-gradient(150deg,#fce4ec 0%,#f48fb1 100%);}
.sp-tx::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 46%,rgba(244,67,54,.35) 0%,transparent 68%);pointer-events:none;}

/* Corner cells */
.sp.corner{
  flex-direction:column;align-items:center;justify-content:center;
  font-size:clamp(8px,1.2vw,18px);
}

/* Text inside spaces */
.sp-name{
  font-size:clamp(4px,.58vw,8.5px);font-weight:700;line-height:1.15;
  text-align:center;color:#111;word-break:break-word;padding:1px 2px;
}
.sp-price{font-size:clamp(3px,.48vw,7px);color:#444;}


/* City landmark silhouette icon */
.city-icon{position:absolute;left:1px;right:1px;pointer-events:none;overflow:hidden;opacity:.18;}
.city-icon svg{width:100%;height:100%;display:block;}

/* Color bars */
.sp-cbar{flex-shrink:0;}
.c-brown{background:var(--brown)}.c-lightblue{background:var(--lb)}.c-pink{background:var(--pink)}
.c-orange{background:var(--orange)}.c-red{background:var(--red)}.c-yellow{background:var(--cyellow)}
.c-green{background:var(--green)}.c-darkblue{background:var(--dblue)}.c-svc{background:var(--svc)}

/* Special bg */
.sp-go{background:linear-gradient(135deg,#fff8e6,#fffde7);}
.sp-jail{background:linear-gradient(135deg,#fff3e0,#ffcc80);}
.sp-fp{background:linear-gradient(135deg,#e8f5e9,#a5d6a7);}
.sp-gtj{background:linear-gradient(135deg,#ffebee,#ef9a9a);}
.sp-ch{background:linear-gradient(135deg,#fffde7,#fff59d);}
.sp-cc{background:linear-gradient(135deg,#e3f2fd,#90caf9);}
.sp-tx{background:linear-gradient(135deg,#fce4ec,#f48fb1);}

/* Owner dot & houses */
.own-dot{position:absolute;top:2px;right:2px;width:clamp(5px,.7vw,10px);height:clamp(5px,.7vw,10px);
  border-radius:50%;border:0;box-shadow:0 0 0 2px rgba(0,0,0,.18),0 1px 4px rgba(0,0,0,.55);z-index:6;}
.mort-ov{position:absolute;inset:0;background:repeating-linear-gradient(-45deg,rgba(180,0,0,.13) 0,rgba(180,0,0,.13) 3px,transparent 3px,transparent 8px);z-index:5;}
.hdisp{display:flex;gap:1px;justify-content:center;position:absolute;bottom:6px;z-index:6;flex-wrap:wrap;}
.hhouse{width:clamp(3px,.42vw,6px);height:clamp(3px,.42vw,6px);background:#27ae60;border-radius:1px;}
.hhotel{width:clamp(5px,.7vw,9px);height:clamp(3px,.42vw,5px);background:#c0392b;border-radius:1px;}

/* Property Deed Card (global floating, outside cells to avoid overflow:hidden) */
#deed{position:fixed;z-index:9999;width:190px;background:#fffff8;
  border:2px solid #444;border-radius:3px;
  box-shadow:0 14px 44px rgba(0,0,0,.85),0 0 0 1px rgba(0,0,0,.15);
  display:none;pointer-events:none;overflow:hidden;font-family:'Inter',sans-serif;color:#111;}
#deed.on{display:block;}
.deed-top{padding:9px 10px 11px;text-align:center;}
.deed-top-lbl{font-size:7px;letter-spacing:2px;text-transform:uppercase;margin-bottom:4px;opacity:.75;}
.deed-top-name{font-size:13px;font-weight:900;font-family:'Unbounded',sans-serif;line-height:1.2;text-transform:uppercase;}
.deed-mid{text-align:center;font-size:7px;letter-spacing:1.5px;text-transform:uppercase;
  color:#444;padding:3px 0;border-top:1px solid #aaa;border-bottom:2px solid #333;font-weight:700;}
.deed-table{padding:4px 10px;}
.deed-row{display:flex;justify-content:space-between;align-items:center;
  font-size:10.5px;padding:2.5px 0;border-bottom:1px solid #e8e8dc;color:#222;}
.deed-row:last-child{border:none;}
.deed-row.hl{font-weight:800;}
.deed-sep{height:2px;background:#333;margin:0;}
.deed-foot{text-align:center;font-size:8.5px;color:#444;padding:5px 8px 7px;border-top:1px solid #aaa;line-height:1.7;}

/* Tokens */
.tl{position:absolute;inset:0;pointer-events:none;z-index:20;}
.tok{position:absolute;font-size:clamp(10px,1.4vw,22px);transform:translate(-50%,-50%);
  z-index:21;transition:left 190ms ease-out, top 190ms ease-out;
  filter:drop-shadow(0 2px 7px rgba(0,0,0,.9));}

/* RIGHT */
.rp{background:var(--panel);border-left:1px solid var(--brd);display:flex;flex-direction:column;padding:12px;gap:8px;overflow-y:auto;min-height:0;}
.tbox{background:linear-gradient(135deg,rgba(255,221,45,.07),rgba(255,221,45,.02));
  border:1px solid rgba(255,221,45,.22);border-radius:12px;padding:12px;text-align:center;}
.tbox-l{font-size:10px;color:rgba(255,255,255,.3);letter-spacing:3px;text-transform:uppercase;}
.tbox-n{font-family:'Unbounded',sans-serif;font-size:15px;font-weight:700;color:var(--y);margin-top:4px;}
/* Dice */
.dw{display:flex;gap:8px;justify-content:center;align-items:center;
  background:rgba(255,255,255,.03);border:1px solid var(--brd);border-radius:12px;padding:12px;}
.die{width:50px;height:50px;background:white;border-radius:10px;display:flex;align-items:center;justify-content:center;
  font-size:26px;font-weight:900;color:#111;box-shadow:0 4px 14px rgba(0,0,0,.5);}
.die.roll{animation:rd .5s ease-in-out;}
@keyframes rd{0%{transform:rotate(0) scale(1)}20%{transform:rotate(20deg) scale(1.2)}
  50%{transform:rotate(-12deg) scale(.9)}80%{transform:rotate(7deg) scale(1.08)}100%{transform:rotate(0) scale(1)}}
.dsum{font-family:'Unbounded',sans-serif;font-size:24px;font-weight:900;color:var(--y);}
.dinfo{font-size:11px;color:rgba(255,221,45,.7);text-align:center;min-height:16px;font-weight:600;}
/* Tabs */
.tabs{display:flex;gap:2px;background:rgba(255,255,255,.03);border:1px solid var(--brd);border-radius:10px;padding:3px;}
.tb{flex:1;padding:7px 2px;background:transparent;border:none;border-radius:7px;
  color:rgba(255,255,255,.3);font-size:9px;font-family:'Unbounded',sans-serif;cursor:pointer;transition:.2s;touch-action:manipulation;-webkit-tap-highlight-color:transparent;}
.tb.on{background:rgba(255,221,45,.12);color:var(--y);border:1px solid rgba(255,221,45,.18);}
.tc{display:none;flex-direction:column;gap:7px;}
.tc.on{display:flex;}
/* Buttons */
.ab{width:100%;padding:12px;border-radius:10px;border:none;font-family:'Unbounded',sans-serif;
  font-size:11px;font-weight:700;cursor:pointer;transition:.2s;letter-spacing:.3px;touch-action:manipulation;-webkit-tap-highlight-color:transparent;}
.ab:disabled{opacity:.28;cursor:not-allowed;}
.ab-roll{background:var(--y);color:#000;}
.ab-roll:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 8px 18px rgba(255,221,45,.35);}
.ab-end{background:rgba(255,255,255,.06);color:rgba(255,255,255,.65);border:1px solid var(--brd);}
.ab-end:not(:disabled):hover{background:rgba(255,255,255,.1);}
#end-reminder{position:fixed;padding:10px 16px;border-radius:12px;background:#111;border:1px solid rgba(255,221,45,.6);color:var(--y);font-size:12px;font-weight:700;text-align:center;line-height:1.4;white-space:nowrap;animation:endPulse 1.2s ease-in-out infinite;cursor:pointer;z-index:800;}
@keyframes endPulse{0%,100%{box-shadow:0 0 0 0 rgba(255,221,45,.4);}50%{box-shadow:0 0 0 9px rgba(255,221,45,0);}}
.ab-jail{background:rgba(243,156,18,.1);color:#f39c12;border:1px solid rgba(243,156,18,.2);}
.ab-buy{background:#27ae60;color:#fff;}.ab-buy:not(:disabled):hover{background:#2ecc71;transform:translateY(-2px);}
.ab-no{background:rgba(231,76,60,.07);color:#e74c3c;border:1px solid rgba(231,76,60,.15);}
.ab-leave{background:rgba(231,76,60,.1);color:#e74c3c;border:1px solid rgba(231,76,60,.18);}
.ab-leave:hover{background:rgba(231,76,60,.18);}
.ab-trade{background:rgba(155,89,182,.1);color:#9b59b6;border:1px solid rgba(155,89,182,.2);}
.ab-money{background:rgba(26,188,156,.1);color:#1abc9c;border:1px solid rgba(26,188,156,.2);}
/* Build list */
.bl{display:flex;flex-direction:column;gap:4px;max-height:190px;overflow-y:auto;}
.bi{background:rgba(255,255,255,.03);border:1px solid var(--brd);border-radius:8px;padding:8px 10px;display:flex;align-items:center;gap:6px;}
.bcc{width:10px;height:10px;border-radius:2px;flex-shrink:0;}
.bn{flex:1;font-size:11px;font-weight:600;}.bh{font-size:10px;color:rgba(255,255,255,.3);}
.bbw{display:flex;gap:3px;}
.bb{padding:4px 7px;border-radius:5px;border:none;font-size:9px;font-weight:700;cursor:pointer;font-family:'Unbounded',sans-serif;transition:.2s;}
.bb:disabled{opacity:.3;cursor:not-allowed;}
.bb-b{background:#27ae60;color:#fff;}.bb-s{background:#e67e22;color:#fff;}
.bb-m{background:#e74c3c;color:#fff;}.bb-u{background:#3498db;color:#fff;}
/* Forms */
.fr{display:flex;flex-direction:column;gap:4px;}
.fr label{font-size:10px;color:rgba(255,255,255,.28);letter-spacing:1px;text-transform:uppercase;}
.fr select,.fr input{background:rgba(255,255,255,.05);border:1px solid var(--brd);border-radius:7px;
  padding:8px 10px;color:white;font-size:12px;outline:none;width:100%;}
.fr select:focus,.fr input:focus{border-color:rgba(255,221,45,.4);}
.pchk{display:flex;flex-wrap:wrap;gap:2px;max-height:130px;overflow-y:auto;}
.pch{display:flex;align-items:center;gap:5px;padding:3px 6px;background:rgba(255,255,255,.03);border-radius:5px;}
.pch label{font-size:11px;cursor:pointer;flex:1;}
/* Log */
.log-toggle{display:flex;align-items:center;justify-content:space-between;cursor:pointer;
  padding:7px 10px;border-radius:8px;border:1px solid var(--brd);background:rgba(255,255,255,.03);
  font-size:12px;font-weight:600;color:rgba(255,255,255,.55);user-select:none;margin-top:4px;}
.log-toggle:hover{background:rgba(255,255,255,.06);}
.log-arrow{font-size:10px;transition:transform .25s;}
.log-open .log-arrow{transform:rotate(180deg);}
.alog{background:rgba(255,255,255,.02);border:1px solid var(--brd);border-radius:8px;padding:9px;
  overflow-y:auto;min-height:70px;max-height:170px;display:none;margin-top:3px;}
.le{font-size:12px;color:rgba(255,255,255,.45);padding:3px 0;border-bottom:1px solid rgba(255,255,255,.04);line-height:1.5;}
.le:first-child{color:rgba(255,255,255,.88);font-weight:500;}

/* Voice Chat */
.voice-panel{background:rgba(255,255,255,.02);border:1px solid var(--brd);border-radius:10px;padding:10px;display:flex;flex-direction:column;gap:7px;margin-top:4px;}
.voice-title{font-size:9px;letter-spacing:3px;color:rgba(255,255,255,.25);text-transform:uppercase;}
.voice-btn{background:rgba(255,255,255,.06);color:rgba(255,255,255,.65);border:1px solid rgba(255,255,255,.1);font-size:11px;padding:9px 12px;border-radius:8px;cursor:pointer;font-family:'Unbounded',sans-serif;font-weight:700;transition:all .2s;}
.voice-btn:hover{background:rgba(255,255,255,.1);}
.voice-btn.voice-active{background:rgba(231,76,60,.12);color:#e74c3c;border-color:rgba(231,76,60,.35);}
.voice-list{display:flex;flex-wrap:wrap;gap:4px;min-height:18px;}
.voice-user{font-size:10px;background:rgba(46,204,113,.1);color:#2ecc71;border:1px solid rgba(46,204,113,.25);border-radius:20px;padding:2px 8px;}
#waiting-voice{width:100%;max-width:440px;margin-top:10px;background:rgba(18,18,18,.82);border-color:rgba(255,255,255,.06);backdrop-filter:blur(6px);}
/* MODALS */
.mo{position:fixed;inset:0;background:rgba(0,0,0,.88);display:none;align-items:center;
  justify-content:center;z-index:500;backdrop-filter:blur(8px);}
.mo.on{display:flex;}
#buy-mo,#auc-mo{backdrop-filter:none;background:rgba(0,0,0,.75);}
.mc{background:#111;border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:28px;
  max-width:400px;width:92%;text-align:center;animation:pin .35s cubic-bezier(.34,1.56,.64,1);
  box-shadow:0 40px 80px rgba(0,0,0,.7);}
@keyframes pin{from{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes cellPulse{0%{box-shadow:inset 0 0 0 0 rgba(255,221,45,0),0 0 0 0 rgba(255,221,45,0)}40%{box-shadow:inset 0 0 18px 4px rgba(255,221,45,.45),0 0 0 8px rgba(255,221,45,.18)}100%{box-shadow:inset 0 0 0 0 rgba(255,221,45,0),0 0 0 14px rgba(255,221,45,0)}}
.sp.landing{animation:cellPulse .7s ease-out forwards;z-index:2;}
@keyframes coinFly{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}80%{opacity:1}100%{opacity:0;transform:translate(var(--cx),var(--cy)) scale(.5)}}
.board-coin{position:fixed;pointer-events:none;font-size:14px;font-family:'Unbounded',sans-serif;font-weight:700;background:#FFDD2D;color:#0a0a0a;border-radius:20px;padding:2px 7px;z-index:900;white-space:nowrap;animation:coinFly .85s cubic-bezier(.25,.46,.45,.94) forwards;}
.mc h3{font-family:'Unbounded',sans-serif;font-size:17px;color:var(--y);}
.mc-price{font-size:34px;font-family:'Unbounded',sans-serif;font-weight:900;margin:12px 0;}
.mc-sub{font-size:12px;color:rgba(255,255,255,.3);}
.mc-btns{display:flex;gap:10px;margin-top:18px;}
/* Card overlay */
.cf-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:799;display:none;backdrop-filter:blur(5px);}
.cf-overlay.on{display:block;}
/* Card flash — beautiful white modal */
.cf{position:fixed;top:50%;left:50%;transform:translate(-50%,-44%);
  background:#fff;border-radius:24px;overflow:hidden;
  max-width:400px;width:92%;text-align:center;z-index:800;
  opacity:0;transition:all .4s cubic-bezier(.34,1.56,.64,1);pointer-events:none;
  box-shadow:0 32px 80px rgba(0,0,0,.45);}
.cf.on{opacity:1;transform:translate(-50%,-50%);pointer-events:auto;}
.cf-accent{height:8px;width:100%;}
.cf-inner{padding:22px 28px 24px;position:relative;}
.cf-close{position:absolute;top:10px;right:14px;background:none;border:none;color:rgba(0,0,0,.3);font-size:22px;cursor:pointer;line-height:1;padding:0;transition:.15s;}
.cf-close:hover{color:#000;}
.cf-tp{font-size:10px;letter-spacing:3px;text-transform:uppercase;margin-bottom:10px;font-weight:700;}
.cf-who{font-size:13px;font-weight:700;color:#333;margin-bottom:8px;padding:6px 14px;background:rgba(0,0,0,.06);border-radius:20px;display:inline-block;}
.cf-tx{font-size:17px;line-height:1.65;color:#111;font-weight:500;margin-top:8px;white-space:pre-line;}
/* Mini notifications */
#mini-notifs{position:fixed;bottom:80px;right:20px;z-index:8500;display:flex;flex-direction:column;gap:8px;align-items:flex-end;pointer-events:none;}
.mn{background:#fff;border-radius:12px;padding:10px 14px;box-shadow:0 4px 20px rgba(0,0,0,.25);font-size:12px;font-weight:600;color:#222;max-width:220px;line-height:1.4;opacity:0;transform:translateX(30px);transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;align-items:flex-start;gap:8px;}
.mn.mn-on{opacity:1;transform:translateX(0);}
.mn-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:2px;}
/* Land card */
.land-card{position:fixed;top:50%;left:50%;transform:translate(-50%,-42%);background:#fff;border-radius:20px;padding:22px 32px 20px;min-width:260px;max-width:340px;text-align:center;z-index:9000;pointer-events:auto;box-shadow:0 24px 70px rgba(0,0,0,.5);opacity:0;transition:all .35s cubic-bezier(.34,1.56,.64,1);}
.land-card.land-card-on{opacity:1;transform:translate(-50%,-50%);}
.land-card-bar{height:4px;border-radius:3px;margin:0 auto 14px;width:50px;}
.land-card-title{font-family:'Unbounded',sans-serif;font-size:13px;font-weight:900;color:#111;margin-bottom:5px;}
.land-card-detail{font-size:12px;color:#666;line-height:1.6;}
/* Need funds modal */
#nf-mo{position:fixed;inset:0;background:rgba(0,0,0,.92);display:none;align-items:center;justify-content:center;z-index:700;backdrop-filter:blur(10px);}
#nf-mo.on{display:flex;}
.nf-card{background:#111;border:1px solid rgba(231,76,60,.3);border-radius:24px;padding:28px;max-width:400px;width:92%;max-height:82vh;overflow-y:auto;}
.nf-header{font-family:'Unbounded',sans-serif;font-size:15px;font-weight:900;color:#e74c3c;margin-bottom:3px;}
.nf-sub{font-size:11px;color:rgba(255,255,255,.3);margin-bottom:18px;letter-spacing:.3px;}
.nf-nums{display:flex;gap:20px;margin-bottom:18px;}
.nf-num-block{flex:1;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:10px 14px;}
.nf-num-lbl{font-size:9px;letter-spacing:2px;color:rgba(255,255,255,.25);text-transform:uppercase;margin-bottom:3px;}
.nf-num-val{font-family:'Unbounded',sans-serif;font-size:22px;font-weight:900;}
.nf-sec-title{font-size:9px;letter-spacing:3px;color:rgba(255,255,255,.2);text-transform:uppercase;margin-bottom:8px;}
.nf-prop{display:flex;align-items:center;gap:9px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:10px;padding:9px 12px;margin-bottom:5px;}
.nf-prop-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0;}
.nf-prop-name{flex:1;font-size:11px;font-weight:600;}
.nf-prop-val{font-size:10px;color:rgba(255,255,255,.35);}
.nf-prop-btn{padding:5px 9px;border-radius:6px;border:none;font-family:'Unbounded',sans-serif;font-size:9px;font-weight:700;cursor:pointer;transition:.2s;}
.nf-sell-btn{background:#e67e22;color:#fff;}.nf-sell-btn:hover{background:#f39c12;}
.nf-mort-btn{background:#3498db;color:#fff;}.nf-mort-btn:hover{background:#5dade2;}
.nf-pay-btn{width:100%;margin-top:14px;background:#27ae60;color:#fff;}
.nf-pay-btn:disabled{opacity:.28;cursor:not-allowed;}
.nf-bust-btn{width:100%;margin-top:6px;background:rgba(231,76,60,.1);color:#e74c3c;border:1px solid rgba(231,76,60,.25);}
/* Trade property badges */
.tr-prop{display:flex;align-items:center;gap:6px;padding:5px 7px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:7px;cursor:pointer;transition:.15s;margin-bottom:3px;}
.tr-prop:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2);}
.tr-prop-color{width:9px;height:9px;border-radius:2px;flex-shrink:0;}
.tr-prop label{font-size:11px;cursor:pointer;flex:1;}
.tr-badge{display:inline-block;font-size:10px;border:1px solid;border-radius:20px;padding:2px 8px;margin:2px;cursor:pointer;transition:.15s;}
.tr-badge:hover{opacity:.8;}
/* Mini property card in trade popup */
.tpc{display:inline-flex;flex-direction:column;align-items:stretch;background:#1c1c1c;border:1px solid rgba(255,255,255,.1);border-radius:10px;overflow:hidden;width:82px;cursor:pointer;transition:all .15s;vertical-align:top;margin:3px;position:relative;user-select:none;touch-action:manipulation;-webkit-tap-highlight-color:transparent;}
.tpc:hover{border-color:rgba(255,255,255,.35);box-shadow:0 6px 18px rgba(0,0,0,.4);}
.tpc:not(.tpc-selectable):hover{transform:translateY(-2px);}
.tpc.tpc-sel{border-color:#f1c40f;box-shadow:0 0 0 2px rgba(241,196,15,.35),0 6px 18px rgba(0,0,0,.32);}
.tpc.tpc-selectable:hover,.tpc.tpc-sel{transform:none;}
.tpc-top{height:18px;flex-shrink:0;}
.tpc-body{padding:5px 6px 6px;text-align:center;}
.tpc-name{font-size:8.5px;font-weight:700;color:rgba(255,255,255,.88);line-height:1.3;}
.tpc-houses{font-size:9px;margin-top:3px;letter-spacing:1px;}
.tpc-price{font-size:7px;color:rgba(255,255,255,.5);margin-top:2px;}
.tpc-info{position:absolute;top:4px;right:4px;width:16px;height:16px;border-radius:50%;border:1px solid rgba(255,255,255,.16);background:rgba(10,10,10,.72);color:rgba(255,255,255,.85);font-size:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;line-height:1;}
/* Trade det layout */
.tp-row{margin-bottom:10px;}
.tp-row-lbl{font-size:10px;color:rgba(255,255,255,.35);letter-spacing:1px;text-transform:uppercase;margin-bottom:5px;}
.tp-row-amount{font-family:'Unbounded',sans-serif;font-size:18px;font-weight:900;margin-bottom:5px;}
.tp-row-cards{display:flex;flex-wrap:wrap;gap:2px;}
/* Trade popup */
#trade-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.9);
  background:#111;border:2px solid rgba(155,89,182,.45);border-radius:20px;padding:28px;
  max-width:420px;width:92%;z-index:600;display:none;opacity:0;transition:all .35s cubic-bezier(.34,1.56,.64,1);
  max-height:88vh;overflow-y:auto;}
#trade-popup.on{display:block;opacity:1;transform:translate(-50%,-50%) scale(1);}
.tp-bg{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:599;display:none;}
.tp-bg.on{display:block;}
/* Auction */
.auc-bid{font-size:30px;font-family:'Unbounded',sans-serif;font-weight:900;color:#2ecc71;margin:10px 0;}
.auc-timer{font-family:'Unbounded',sans-serif;font-size:28px;font-weight:900;color:var(--y);
  margin:8px 0;transition:color .3s;}
.auc-timer.urgent{color:#e74c3c;animation:pulse .5s infinite alternate;}
@keyframes pulse{from{opacity:1}to{opacity:.4}}
/* Auction result banner */
#auc-result{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;
  z-index:200;pointer-events:none;opacity:0;transition:opacity .4s;}
#auc-result.on{opacity:1;}
.auc-res-box{background:rgba(15,15,20,.92);border:1px solid rgba(255,255,255,.15);
  border-radius:16px;padding:28px 40px;text-align:center;backdrop-filter:blur(12px);
  box-shadow:0 16px 60px rgba(0,0,0,.7);max-width:340px;}
.auc-res-icon{font-size:40px;margin-bottom:10px;}
.auc-res-title{font-family:'Unbounded',sans-serif;font-size:15px;font-weight:700;
  color:#fff;margin-bottom:8px;}
.auc-res-sub{font-size:13px;color:rgba(255,255,255,.6);}
.auc-res-amount{font-family:'Unbounded',sans-serif;font-size:22px;font-weight:900;
  color:var(--g);margin-top:8px;}
/* Winner */
#ws{display:none;position:fixed;inset:0;background:rgba(0,0,0,.97);align-items:center;
  justify-content:center;flex-direction:column;z-index:2000;}
.wname{font-family:'Unbounded',sans-serif;font-size:clamp(28px,5vw,54px);font-weight:900;color:var(--y);text-shadow:0 0 60px rgba(255,221,45,.5);}
.ab-leave-fixed{position:fixed;bottom:20px;right:20px;z-index:200;padding:10px 18px;font-size:12px;background:rgba(180,30,30,.85);border:1px solid rgba(255,100,100,.3);border-radius:12px;color:#fff;font-family:'Unbounded',sans-serif;font-weight:700;cursor:pointer;}
.ab-leave-fixed:hover{background:rgba(200,40,40,.95);}
.ab-switch-device{position:fixed;bottom:20px;left:20px;z-index:200;width:calc(230px - 40px);max-width:calc(100vw - 40px);padding:10px 12px;font-size:10px;background:rgba(20,20,20,.92);border:1px solid rgba(255,255,255,.12);border-radius:12px;color:#fff;font-family:'Unbounded',sans-serif;font-weight:700;cursor:pointer;display:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.1px;}
.ab-switch-device:hover{background:rgba(34,34,34,.96);}
/* ===== TOKEN SELECT MODAL ===== */
#token-mo{position:fixed;inset:0;background:rgba(0,0,0,.94);display:none;align-items:center;justify-content:center;z-index:2000;backdrop-filter:blur(14px);}
.tsel-card{background:#111;border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:36px 32px 28px;max-width:520px;width:94%;text-align:center;box-shadow:0 40px 80px rgba(0,0,0,.7);animation:pin .35s cubic-bezier(.34,1.56,.64,1);}
.tsel-title{font-family:'Unbounded',sans-serif;font-size:18px;font-weight:900;color:var(--y);margin-bottom:6px;}
.tsel-sub{font-size:11px;color:rgba(255,255,255,.35);letter-spacing:.5px;margin-bottom:26px;}
#token-grid{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:20px;}
.tok-btn{width:80px;height:90px;border-radius:14px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:pointer;border:2px solid rgba(255,255,255,.15);background:rgba(255,255,255,.05);transition:all .18s;position:relative;}
.tok-btn:hover:not(.tok-taken){border-color:rgba(255,221,45,.5);background:rgba(255,221,45,.1);transform:translateY(-3px);}
.tok-btn.tok-mine{border-color:var(--y);background:rgba(255,221,45,.15);}
.tok-btn.tok-taken{opacity:.4;cursor:not-allowed;}
.tok-btn-emoji{font-size:34px;line-height:1;}
.tok-btn-lbl{font-size:9px;color:rgba(255,255,255,.4);text-align:center;max-width:74px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.tok-btn.tok-mine .tok-btn-lbl{color:var(--y);font-weight:700;}
#token-status{font-size:12px;color:rgba(255,255,255,.4);min-height:18px;}
#token-countdown-wrap{margin-top:14px;display:none;}
#token-countdown-wrap .tcd-lbl{font-size:10px;color:rgba(255,255,255,.3);letter-spacing:2px;text-transform:uppercase;margin-bottom:4px;}
#token-countdown{font-family:'Unbounded',sans-serif;font-size:48px;font-weight:900;color:var(--y);line-height:1;}

/* ===== ORDER ROLL MODAL ===== */
#orderroll-mo{position:fixed;inset:0;background:rgba(0,0,0,.94);display:none;align-items:center;justify-content:center;z-index:2000;backdrop-filter:blur(14px);}
.oroll-card{background:#111;border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:36px 32px 28px;max-width:500px;width:94%;text-align:center;box-shadow:0 40px 80px rgba(0,0,0,.7);animation:pin .35s cubic-bezier(.34,1.56,.64,1);}
.oroll-title{font-family:'Unbounded',sans-serif;font-size:17px;font-weight:900;color:var(--y);margin-bottom:6px;}
.oroll-sub{font-size:11px;color:rgba(255,255,255,.35);letter-spacing:.5px;margin-bottom:22px;}
#orderroll-list{display:flex;flex-direction:column;gap:7px;margin-bottom:20px;text-align:left;}
.oroll-row{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:11px 14px;transition:all .3s;}
.oroll-row.oroll-rolled{border-color:rgba(255,221,45,.2);}
.oroll-tok{font-size:24px;width:34px;text-align:center;flex-shrink:0;}
.oroll-name{flex:1;font-size:13px;font-weight:600;}
.oroll-result{font-family:'Unbounded',sans-serif;font-size:22px;font-weight:900;color:rgba(255,255,255,.7);}
.oroll-result.oroll-first{color:var(--y);}
.oroll-dice-sub{font-size:10px;color:rgba(255,255,255,.35);}
.oroll-waiting{font-size:11px;color:rgba(255,255,255,.25);font-style:italic;}

/* Opponent dice banner */
#opp-dice-banner{position:fixed;top:20px;left:50%;transform:translateX(-50%) translateY(-80px);
  background:rgba(20,20,20,.95);border:1px solid rgba(255,221,45,.35);border-radius:14px;
  padding:10px 22px;font-size:13px;font-weight:600;color:rgba(255,255,255,.85);
  z-index:9900;transition:transform .35s cubic-bezier(.34,1.56,.64,1);
  display:flex;align-items:center;gap:10px;white-space:nowrap;
  box-shadow:0 8px 24px rgba(0,0,0,.5);}
#opp-dice-banner.on{transform:translateX(-50%) translateY(0);}
#opp-dice-banner .opp-dice-vals{font-family:'Unbounded',sans-serif;font-size:15px;color:var(--y);}
/* Toast */
.toast{position:fixed;bottom:18px;left:50%;transform:translateX(-50%) translateY(80px);
  background:#c0392b;color:white;padding:12px 24px;border-radius:12px;
  font-size:13px;font-weight:600;z-index:9999;transition:transform .3s;
  box-shadow:0 8px 20px rgba(0,0,0,.4);max-width:380px;text-align:center;}
.toast.on{transform:translateX(-50%) translateY(0);}
.switch-link-box{margin-top:14px;padding:12px 14px;border-radius:12px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);text-align:left;word-break:break-all;font-size:12px;line-height:1.5;color:rgba(255,255,255,.82);}
::-webkit-scrollbar{width:3px;}::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:2px;}
@media(max-width:1300px){.gl{grid-template-columns:210px 1fr 290px;}}
@media(max-width:1100px){.gl{grid-template-columns:190px 1fr 270px;}}
@media(max-width:900px){.gl{grid-template-columns:170px 1fr 250px;}}

/* ===== RESPONSIVE: Tablet portrait (≤768px) ===== */
@media(max-width:768px){
  #game{height:100vh;height:100dvh;}
  .gl{grid-template-columns:1fr 230px;grid-template-rows:100vh;grid-template-rows:100dvh;}
  .lp{display:none;}
  .own-dot{width:10px;height:10px;top:3px;right:3px;box-shadow:0 0 0 2px rgba(0,0,0,.22),0 1px 4px rgba(0,0,0,.65);}
}

/* ===== RESPONSIVE: Phone (≤540px) ===== */
@media(max-width:540px){
  html,body{overflow-y:auto;height:auto;}
  #game{height:auto;min-height:100vh;min-height:100dvh;overflow:visible;}
  .gl{display:flex;flex-direction:column;height:auto;min-height:100vh;min-height:100dvh;}
  .lp{display:none;}
  .cc{width:100%;aspect-ratio:1/1;min-height:unset;flex-shrink:0;}
  .rp{flex:1;overflow-y:auto;border-left:none;border-top:1px solid var(--brd);min-height:360px;padding-bottom:80px;}
  #mobile-players{order:20;margin-top:10px;padding-top:8px;border-top:1px solid var(--brd);border-bottom:none;margin-bottom:0;}
  #tc-a{position:sticky;top:0;z-index:25;background:linear-gradient(180deg,#0d0d0d 0%,#0d0d0d 78%,rgba(13,13,13,0) 100%);padding-top:10px;padding-bottom:8px;}
  #btn-roll{box-shadow:0 10px 26px rgba(255,221,45,.22);}
  .ab-switch-device{position:static;left:auto;bottom:auto;order:999;width:100%;max-width:none;margin-top:14px;padding:9px 14px;font-size:10px;}
  .ab-leave-fixed{bottom:10px;right:10px;padding:8px 14px;font-size:10px;}
  .tbox-n{font-size:13px;}
  .die{width:38px;height:38px;font-size:20px;}
  .dsum{font-size:18px;}
  /* Убираем тяжёлый blur на модалках — основная причина лагов */
  .mo{backdrop-filter:none!important;-webkit-backdrop-filter:none!important;}
  .cf-overlay{backdrop-filter:none!important;-webkit-backdrop-filter:none!important;}
  #counter-mo{backdrop-filter:none!important;-webkit-backdrop-filter:none!important;}
  #token-mo{backdrop-filter:none!important;-webkit-backdrop-filter:none!important;}
  #orderroll-mo{backdrop-filter:none!important;-webkit-backdrop-filter:none!important;}
  /* Мини-блок игроков виден только на телефоне */
  #mobile-players{display:block!important;}
  .money-pop{font-size:18px;}
  .own-dot{width:7px;height:7px;top:3px;right:3px;box-shadow:0 0 0 1.5px rgba(0,0,0,.18),0 1px 3px rgba(0,0,0,.6);}
}

/* ===== RESPONSIVE: Phone landscape ===== */
@media(max-width:900px) and (orientation:landscape) and (max-height:500px){
  html,body{overflow:hidden;height:100%;}
  #game{height:100dvh;overflow:hidden;}
  .gl{display:grid!important;grid-template-columns:1fr 260px!important;grid-template-rows:100dvh!important;height:100dvh!important;}
  .lp{display:none!important;}
  .cc{width:100%;height:100%;aspect-ratio:unset;}
  .rp{overflow-y:auto;border-left:1px solid var(--brd);border-top:none;padding-bottom:20px;}
  #mobile-players{display:block!important;}
  .mo{backdrop-filter:none!important;-webkit-backdrop-filter:none!important;}
  #counter-mo,#token-mo,#orderroll-mo{backdrop-filter:none!important;-webkit-backdrop-filter:none!important;}
}
