/* ========== RESET & BASE ========== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{width:100%;height:100%;overflow:hidden;font-family:'Segoe UI',system-ui,-apple-system,sans-serif;background:#0a0a14;color:#e8e8f0}
button{cursor:pointer;font-family:inherit}
input{font-family:inherit}

/* ========== SCREENS ========== */
.screen{display:none;width:100%;height:100%;position:absolute;top:0;left:0}
.screen.active{display:flex}

/* ========== READY-UP / CHARACTER SELECT ========== */
#readyUp{justify-content:center;align-items:center;background:linear-gradient(135deg,#0a0a14 0%,#141428 50%,#0a1420 100%);overflow-y:auto;padding:20px 0}
.readyup-container{max-width:900px;width:95%;margin:0 auto;text-align:center}
.readyup-title{font-size:2.2rem;font-weight:900;margin-bottom:4px}
.readyup-title span{color:#00d4aa}
.readyup-sub{color:#888;margin-bottom:24px;font-size:.95rem}
.readyup-players{display:flex;flex-direction:column;gap:16px}
.rup-player{background:rgba(30,30,50,.85);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:16px 20px;text-align:left;transition:all .3s}
.rup-player.rup-ready{border-color:rgba(74,222,128,.35);background:rgba(30,50,40,.85)}
.rup-player-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.rup-color{width:16px;height:16px;border-radius:50%;flex-shrink:0}
.rup-name{font-weight:700;font-size:1rem;flex:1}
.rup-badge{font-size:.65rem;font-weight:700;padding:3px 10px;border-radius:6px;text-transform:uppercase;letter-spacing:.5px}
.rup-badge-ready{background:rgba(74,222,128,.2);color:#4ade80}
.rup-badge-waiting{background:rgba(251,191,36,.15);color:#fbbf24}
.rup-chars{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.rup-char{width:100px;cursor:pointer;text-align:center;padding:8px 6px;border-radius:12px;border:2px solid transparent;background:rgba(255,255,255,.03);transition:all .2s;position:relative}
.rup-char:hover{border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.06)}
.rup-char-selected{border-color:#00d4aa !important;background:rgba(0,212,170,.1) !important}
.rup-char-taken{opacity:.35;cursor:not-allowed}
.rup-char img{width:72px;height:72px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.1)}
.rup-char-selected img{border-color:#00d4aa}
.rup-char-name{display:block;font-size:.7rem;color:#aaa;margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rup-char-taken-label{position:absolute;bottom:2px;left:0;right:0;font-size:.55rem;color:#f87171;font-weight:600}
.rup-ready-btn{width:100%;padding:10px;border-radius:10px;border:1px solid rgba(74,222,128,.3);background:rgba(74,222,128,.1);color:#4ade80;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s}
.rup-ready-btn:hover{background:rgba(74,222,128,.2)}
.rup-unready-btn{width:100%;padding:10px;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);color:#888;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}
.rup-unready-btn:hover{background:rgba(255,255,255,.08)}
.readyup-status{text-align:center;margin:16px 0 8px;font-size:.9rem;color:#888;font-weight:600}
.readyup-launch{margin-top:8px}
.readyup-launch.hidden{display:none}

/* ========== LOBBY ========== */
#lobby{justify-content:center;align-items:center;background:linear-gradient(135deg,#0a0a14 0%,#141428 50%,#0a1420 100%);overflow-y:auto}
.lobby-container{text-align:center;max-width:480px;width:90%}
.logo{font-size:3.5rem;font-weight:900;letter-spacing:-2px;margin-bottom:4px}
.logo span{color:#00d4aa}
.tagline{color:#888;margin-bottom:20px;font-size:1.1rem}

/* ========== LOBBY TABS ========== */
.lobby-tabs{display:flex;gap:4px;margin-bottom:16px;background:rgba(255,255,255,.04);border-radius:12px;padding:4px}
.lobby-tab{flex:1;padding:10px;border-radius:10px;border:none;background:transparent;color:#888;font-size:.9rem;font-weight:600;transition:all .25s}
.lobby-tab.active{background:rgba(0,212,170,.15);color:#00d4aa}
.lobby-tab:hover{color:#fff}

/* ========== ONLINE LOBBY ========== */
.lobby-input{width:100%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:10px 14px;color:#fff;font-size:.95rem;margin-top:4px}
.lobby-input:focus{outline:none;border-color:rgba(0,212,170,.4)}
.code-input{text-transform:uppercase;letter-spacing:4px;text-align:center;font-weight:700;font-size:1.1rem}
.online-btns{display:flex;flex-direction:column;gap:10px;margin-top:16px}
.join-row{display:flex;gap:8px}
.join-row .lobby-input{flex:1}
.btn-join{white-space:nowrap;padding:10px 24px}
.room-code-display{text-align:center;margin:16px 0}
.room-code{font-size:2.4rem;font-weight:900;letter-spacing:8px;color:#00d4aa;padding:12px;background:rgba(0,212,170,.08);border:1px dashed rgba(0,212,170,.3);border-radius:12px;margin-top:6px}
.room-hint{color:#666;font-size:.75rem;margin-top:6px}
.lobby-player-list{display:flex;flex-direction:column;gap:6px;margin-top:4px}
.lobby-player-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06)}
.lobby-player-item .lp-color{width:16px;height:16px;border-radius:50%;flex-shrink:0}
.lobby-player-item .lp-name{font-size:.9rem;font-weight:600;flex:1}
.lobby-player-item .lp-host{font-size:.7rem;color:#00d4aa;font-weight:600}
.waiting-msg{text-align:center;color:#888;font-size:.85rem;margin-top:16px}
.conn-status{text-align:center;font-size:.75rem;margin-top:12px}
.conn-status.connected{color:#4ade80}
.conn-status.disconnected{color:#f87171}
.conn-status.connecting{color:#fbbf24}
.lobby-card{background:rgba(30,30,50,.85);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:32px;text-align:left}
.lobby-card h2{font-size:1.4rem;margin-bottom:20px;text-align:center}
.lobby-card label{display:block;font-size:.85rem;color:#aaa;margin-bottom:6px;margin-top:16px}
.player-setup{display:flex;flex-direction:column;gap:8px}
.player-row{display:flex;align-items:center;gap:10px}
.player-color{width:20px;height:20px;border-radius:50%;flex-shrink:0;border:2px solid rgba(255,255,255,.2)}
.player-row input{flex:1;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:8px 12px;color:#fff;font-size:.95rem}
.player-btns{display:flex;gap:8px;margin-top:8px}
.btn-sm{padding:6px 14px;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.05);color:#ccc;font-size:.8rem;transition:all .2s}
.btn-sm:hover{background:rgba(255,255,255,.12)}
.btn-danger{border-color:rgba(231,76,60,.4);color:#e74c3c}
.btn-danger:hover{background:rgba(231,76,60,.15)}
.mode-select{display:flex;gap:8px;margin-top:4px}
.mode-btn{flex:1;padding:12px 8px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);color:#aaa;font-size:.9rem;transition:all .25s}
.mode-btn:hover{border-color:rgba(0,212,170,.3)}
.mode-btn.active{border-color:#00d4aa;background:rgba(0,212,170,.12);color:#fff}
.mode-btn small{color:#666;font-size:.7rem}
.target-row{margin-top:12px}
.target-row input{width:140px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:6px 10px;color:#fff;font-size:.95rem}
.btn-primary{background:linear-gradient(135deg,#00d4aa,#00b894);color:#000;font-weight:700;border:none;border-radius:12px;padding:14px 32px;font-size:1.1rem;transition:all .25s;width:100%}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,212,170,.3)}
.btn-large{margin-top:24px}

/* ========== TOP BAR ========== */
#topBar{position:absolute;top:0;left:0;right:0;height:48px;background:rgba(10,10,20,.92);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:space-between;padding:0 20px;z-index:100;font-size:.9rem}
.round-info{color:#00d4aa;font-weight:700}
.turn-info{font-weight:600}
.mode-info{color:#888;font-size:.8rem}

/* ========== BOARD ========== */
#boardWrap{position:absolute;top:48px;left:0;right:0;bottom:0;overflow:hidden;background:#0d0d1a}
#boardCanvas{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}
#minimap{position:absolute;bottom:12px;left:12px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:rgba(10,10,20,.8);z-index:50}

/* ========== PLAYER HUD ========== */
#playerHUD{position:absolute;bottom:0;left:180px;right:0;height:80px;background:rgba(10,10,20,.92);backdrop-filter:blur(12px);border-top:1px solid rgba(255,255,255,.06);display:flex;align-items:center;padding:0 16px;z-index:90;overflow-x:auto}
#hudPlayers{display:flex;gap:12px;width:100%}
.hud-player{display:flex;align-items:center;gap:10px;padding:8px 14px;border-radius:12px;border:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.03);min-width:200px;transition:all .3s}
.hud-player.active{border-color:rgba(0,212,170,.4);background:rgba(0,212,170,.08)}
.hud-player.eliminated{opacity:.4;text-decoration:line-through}
.hud-player.jailed{border-color:rgba(231,76,60,.4);background:rgba(231,76,60,.06)}
.hud-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0}
.hud-icon{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.2);flex-shrink:0}
.hud-name{font-weight:600;font-size:.85rem;white-space:nowrap}
.hud-cash{font-size:.8rem;color:#00d4aa}
.hud-props{font-size:.7rem;color:#888}
.hud-heat{font-size:.7rem;margin-left:auto}
.heat-0{color:#4ade80}.heat-1{color:#a3e635}.heat-2{color:#facc15}.heat-3{color:#fb923c}.heat-4{color:#f87171}.heat-5{color:#dc2626;font-weight:700}

/* ========== ACTION PANEL ========== */
#actionPanel{position:absolute;top:56px;right:12px;width:380px;max-height:calc(100% - 140px);background:rgba(16,16,36,.96);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:16px;z-index:80;overflow-y:auto}
.panel-title{font-size:1.1rem;font-weight:700;margin-bottom:12px;color:#fff}
.panel.hidden{display:none}
#actionBody{font-size:.88rem;color:#ccc;line-height:1.5}
#actionBody .prop-name{color:#00d4aa;font-weight:600}
#actionBody .prop-price{color:#fbbf24;font-weight:600}
#actionBody .prop-income{color:#4ade80}
#actionBody .prop-fine{color:#f87171}
.action-btn{display:block;width:100%;margin-top:8px;padding:12px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);color:#fff;font-size:.9rem;font-weight:600;transition:all .2s;text-align:center}
.action-btn:hover{background:rgba(0,212,170,.15);border-color:rgba(0,212,170,.3);transform:translateY(-1px)}
.action-btn.danger{border-color:rgba(231,76,60,.3)}
.action-btn.danger:hover{background:rgba(231,76,60,.15)}
.action-btn:disabled{opacity:.4;cursor:not-allowed}

/* ========== TILE PROPERTY CARD ========== */
.tile-card{background:rgba(20,20,45,.9);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:0;overflow:hidden;margin-bottom:8px}
.tile-card-image{width:100%;height:140px;overflow:hidden;position:relative}
.tile-card-image img{width:100%;height:100%;object-fit:cover}
.tile-card-image::after{content:'';position:absolute;bottom:0;left:0;right:0;height:40px;background:linear-gradient(transparent,rgba(20,20,45,.95))}
.tile-card-header{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;border-bottom:3px solid #888}
.tile-card-district{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px}
.tile-card-status{font-size:.65rem;font-weight:700;padding:3px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.5px}
.status-sale{background:rgba(0,212,170,.2);color:#00d4aa}
.status-owned{background:rgba(74,222,128,.2);color:#4ade80}
.status-trespass{background:rgba(248,113,113,.2);color:#f87171}
.status-construction{background:rgba(251,191,36,.2);color:#fbbf24}
.tile-card-name{font-size:1.15rem;font-weight:800;color:#fff;padding:12px 14px 4px;text-align:center}
.tile-card-tier{text-align:center;padding:2px 14px 10px;font-size:.85rem}
.tier-stars{font-size:1rem;letter-spacing:2px}
.tier-label{color:#888;font-size:.75rem;margin-left:6px}
.tile-card-stats{padding:0 14px 10px}
.tcs-row{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:.85rem}
.tcs-row:last-child{border:none}
.tcs-label{color:#888}
.tcs-val{font-weight:600}
.tcs-bonus{text-align:center;color:#00d4aa;font-size:.75rem;font-weight:600;padding:4px 0;background:rgba(0,212,170,.08);border-radius:6px;margin-top:4px}
.tile-card-section-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#666;padding:8px 14px 4px}
.tile-card-upgrades{padding:0 14px 8px}
.tcu-row{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:6px;font-size:.8rem;margin-bottom:2px;background:rgba(255,255,255,.02)}
.tcu-row.tcu-active{background:rgba(251,191,36,.1);border:1px solid rgba(251,191,36,.25)}
.tcu-row.tcu-done{opacity:.4}
.tcu-tier{color:#fbbf24;font-size:.7rem;min-width:48px}
.tcu-name{color:#ccc;font-weight:600;flex:1}
.tcu-stats{display:flex;gap:10px;font-size:.75rem;font-weight:600}
.tcu-stats span{min-width:48px;text-align:right}
.tcu-legend{display:flex;gap:10px;justify-content:flex-end;padding:2px 8px 0;font-size:.6rem;color:#555;text-transform:uppercase;letter-spacing:.5px}
.tcu-legend span{min-width:48px;text-align:right}
.tile-card-district-info{padding:0 14px 8px}
.tcd-level{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:6px;font-size:.8rem;margin-bottom:2px;color:#666}
.tcd-level.tcd-reached{color:#4ade80;background:rgba(74,222,128,.06)}
.tcd-count{font-weight:600;min-width:52px}
.tcd-bonus{flex:1}
.tcd-check{color:#4ade80;font-weight:700}
.tcd-total{text-align:center;font-size:.75rem;color:#888;padding:4px 0 2px}
.tile-card-owner{display:flex;align-items:center;gap:8px;padding:8px 14px;background:rgba(255,255,255,.03);border-top:1px solid rgba(255,255,255,.06);font-size:.85rem;font-weight:600}
.tco-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}

/* ========== STOCK TICKER ========== */
#stockTicker{position:absolute;top:56px;left:12px;width:300px;background:rgba(20,20,40,.94);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);border-radius:12px;z-index:80;transition:all .3s}
.stock-header{padding:10px 14px;cursor:pointer;font-size:.85rem;font-weight:600;display:flex;justify-content:space-between;align-items:center;color:#aaa}
.stock-header:hover{color:#fff}
.stock-header .arrow{transition:transform .3s}
#stockTicker.collapsed .stock-body{display:none}
#stockTicker.collapsed .arrow{transform:rotate(-90deg)}
.stock-body{padding:0 10px 12px;max-height:420px;overflow-y:auto}
.stock-row{padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.04);border-radius:8px;margin-bottom:2px}
.stock-row.stock-owned{background:rgba(74,222,128,.04);border:1px solid rgba(74,222,128,.1)}
.stock-info{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:2px}
.stock-name{color:#ddd;font-weight:600;font-size:.85rem}
.stock-sector{color:#666;font-size:.65rem}
.stock-pricing{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.stock-price{font-weight:700;font-size:.85rem}
.stock-change{font-size:.75rem;font-weight:600}
.stock-up{color:#4ade80}.stock-down{color:#f87171}.stock-flat{color:#888}
.stock-position{background:rgba(255,255,255,.03);border-radius:6px;padding:6px 8px;margin:4px 0;display:grid;grid-template-columns:1fr 1fr;gap:2px;font-size:.72rem}
.sp-label{color:#888;grid-column:1/3;font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-size:.6rem}
.sp-shares{color:#ddd;font-weight:600}
.sp-invested{color:#888;text-align:right}
.sp-value{color:#fbbf24;font-weight:600}
.sp-pl{text-align:right;font-weight:700}
.stock-actions{display:flex;gap:6px;margin-top:4px}
.stock-btn{flex:1;padding:5px 10px;border-radius:6px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);color:#aaa;font-size:.75rem;font-weight:600;text-align:center;cursor:pointer;transition:all .2s}
.stock-buy-btn:hover{background:rgba(74,222,128,.12);border-color:rgba(74,222,128,.3);color:#4ade80}
.stock-sell-btn:hover{background:rgba(248,113,113,.12);border-color:rgba(248,113,113,.3);color:#f87171}

/* Stock trade modal */
.stock-modal-card{text-align:center}
.smc-name{font-size:1.15rem;font-weight:800;color:#fff}
.smc-sector{font-size:.75rem;color:#888;margin-bottom:8px}
.smc-price{font-size:.9rem;color:#ccc;margin-bottom:4px}
.smc-available{font-size:.85rem;color:#4ade80}
.smc-preview{margin:6px 0}
.smc-calc{display:flex;justify-content:space-between;padding:8px 12px;background:rgba(255,255,255,.04);border-radius:8px;font-size:.85rem;color:#ccc}
.smc-calc strong{color:#fff}
.smc-position-detail{text-align:left}
.smpd-row{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:.85rem;color:#ccc}
.smpd-row:last-child{border:none}
.smpd-pl{padding-top:6px;margin-top:2px;border-top:1px solid rgba(255,255,255,.08)}

/* ========== ROLL ========== */
.roll-btn{position:absolute;bottom:100px;left:50%;transform:translateX(-50%);padding:16px 48px;font-size:1.3rem;font-weight:800;background:linear-gradient(135deg,#00d4aa,#00b894);color:#000;border:none;border-radius:16px;z-index:95;transition:all .25s;box-shadow:0 4px 20px rgba(0,212,170,.3)}
.roll-btn:hover{transform:translateX(-50%) translateY(-3px);box-shadow:0 8px 32px rgba(0,212,170,.4)}
.roll-btn.hidden{display:none}
.roll-flash{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);font-size:7rem;font-weight:900;color:#fff;z-index:200;pointer-events:none;text-shadow:0 0 60px rgba(0,212,170,.6);animation:flashIn .3s ease-out forwards}
.roll-flash.hidden{display:none}
@keyframes flashIn{0%{opacity:0;transform:translate(-50%,-50%) scale(2)}30%{opacity:1;transform:translate(-50%,-50%) scale(1)}100%{opacity:1;transform:translate(-50%,-50%) scale(1)}}
@keyframes flashOut{0%{opacity:1}100%{opacity:0;transform:translate(-50%,-50%) scale(.6)}}

/* ========== END TURN ========== */
.end-turn-btn{position:absolute;bottom:100px;left:50%;transform:translateX(-50%);padding:12px 36px;font-size:1rem;font-weight:700;background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.15);border-radius:12px;z-index:95;transition:all .2s}
.end-turn-btn:hover{background:rgba(0,212,170,.15);border-color:rgba(0,212,170,.3)}
.end-turn-btn.hidden{display:none}

/* ========== PORTFOLIO ========== */
.portfolio-btn{position:absolute;top:6px;right:140px;padding:6px 16px;border-radius:8px;border:1px solid rgba(255,255,255,.12);background:rgba(20,20,40,.9);color:#aaa;font-size:.8rem;font-weight:600;z-index:101;cursor:pointer;transition:all .2s;backdrop-filter:blur(8px)}
.portfolio-btn:hover{background:rgba(0,212,170,.12);border-color:rgba(0,212,170,.3);color:#fff}
.portfolio-panel{position:absolute;top:48px;right:0;width:400px;height:calc(100% - 48px);background:rgba(14,14,32,.97);backdrop-filter:blur(16px);border-left:1px solid rgba(255,255,255,.08);z-index:85;display:flex;flex-direction:column;overflow:hidden}
.portfolio-panel.hidden{display:none}
.portfolio-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid rgba(255,255,255,.06)}
.portfolio-title{font-size:1rem;font-weight:700;color:#fff}
.portfolio-close{background:none;border:none;color:#888;font-size:1.4rem;cursor:pointer;padding:0 4px}
.portfolio-close:hover{color:#fff}
.portfolio-body{flex:1;overflow-y:auto;padding:12px 16px}

.pf-summary{text-align:center;padding:12px;background:rgba(255,255,255,.03);border-radius:12px;margin-bottom:12px}
.pf-player{display:flex;align-items:center;justify-content:center;gap:8px;font-size:1rem;font-weight:700;margin-bottom:4px}
.pf-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0}
.pf-nw{font-size:1.2rem;color:#fbbf24;margin-bottom:2px}
.pf-cash{font-size:.8rem;color:#888}

.pf-section-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#555;padding:10px 0 4px}
.pf-stats{background:rgba(255,255,255,.02);border-radius:8px;padding:4px 10px;margin-bottom:4px}
.pf-stat-row{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px solid rgba(255,255,255,.03);font-size:.82rem;color:#ccc}
.pf-stat-row:last-child{border:none}
.pf-stat-total{border-top:1px solid rgba(255,255,255,.08);margin-top:2px;padding-top:6px;font-weight:700;font-size:.9rem}

.pf-projected{text-align:center;padding:12px;background:rgba(74,222,128,.06);border:1px solid rgba(74,222,128,.15);border-radius:10px;margin:4px 0 8px}
.pf-projected-amount{display:block;font-size:1.3rem;font-weight:900;color:#4ade80}
.pf-projected-label{font-size:.7rem;color:#888}

.pf-district-header{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;border-left:3px solid #888;margin:6px 0 2px;font-size:.82rem;font-weight:700}
.pf-district-count{color:#888;font-weight:400;font-size:.75rem}
.pf-prop-row{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:rgba(255,255,255,.02);border-radius:6px;margin-bottom:2px;font-size:.8rem}
.pf-prop-row.pf-prop-construction{opacity:.6}
.pf-prop-name{color:#ddd;font-weight:600;flex:1}
.pf-prop-tier{margin-left:4px;font-size:.7rem}
.pf-prop-stats{display:flex;gap:10px;font-size:.75rem;font-weight:600}
.pf-empty{text-align:center;color:#555;font-size:.85rem;padding:12px}

/* ========== CARTEL HAND ========== */
.cartel-hand{position:absolute;bottom:88px;right:12px;width:240px;background:rgba(20,20,40,.94);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px;z-index:80}
.cartel-hand.hidden{display:none}
.cartel-hand-title{font-size:.8rem;font-weight:600;color:#aaa;margin-bottom:8px}
#cartelCards{display:flex;flex-direction:column;gap:4px}
.cartel-card{padding:8px 10px;border-radius:8px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);font-size:.78rem;cursor:pointer;transition:all .2s;display:flex;justify-content:space-between;align-items:center}
.cartel-card:hover{border-color:rgba(139,92,246,.4);background:rgba(139,92,246,.1)}
.cartel-card .cc-name{color:#c4b5fd;font-weight:600}
.cartel-card .cc-heat{color:#f87171;font-size:.7rem}

/* ========== AUCTION ========== */
.auction-info{margin:8px 0 12px}
.auction-current-bid{text-align:center;padding:12px;background:rgba(251,191,36,.08);border:1px solid rgba(251,191,36,.2);border-radius:10px;margin-bottom:8px}
.auction-label{display:block;font-size:.7rem;color:#888;text-transform:uppercase;letter-spacing:1px;margin-bottom:2px}
.auction-amount{display:block;font-size:1.6rem;font-weight:900;color:#fbbf24}
.auction-bidder{display:block;font-size:.85rem;font-weight:600;margin-top:2px}
.auction-your-turn{display:flex;align-items:center;gap:8px;padding:10px 12px;background:rgba(255,255,255,.04);border-radius:8px;font-size:.9rem;font-weight:600}
.auction-turn-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0}
.auction-cash{margin-left:auto;color:#888;font-size:.8rem;font-weight:400}
.auction-quick-bids{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin:10px 0 8px}
.auction-quick-btn{padding:10px;border-radius:8px;border:1px solid rgba(251,191,36,.25);background:rgba(251,191,36,.08);color:#fbbf24;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .2s;text-align:center}
.auction-quick-btn:hover{background:rgba(251,191,36,.2);border-color:rgba(251,191,36,.5);transform:translateY(-1px)}
.auction-custom{display:flex;gap:6px;margin:8px 0 4px}
.auction-input{flex:1;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.15);border-radius:8px;padding:10px 12px;color:#fff;font-size:1rem;font-weight:600;text-align:center}
.auction-input:focus{outline:none;border-color:rgba(251,191,36,.5)}
.auction-custom .action-btn{flex:0 0 auto;width:auto;padding:10px 20px;margin:0}
.auction-min-hint{text-align:center;font-size:.7rem;color:#666;margin-top:2px}

/* ========== MODAL ========== */
.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);backdrop-filter:blur(6px);z-index:300;display:flex;justify-content:center;align-items:center}
.modal-overlay.hidden{display:none}
.modal-box{background:rgba(25,25,50,.96);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:28px;max-width:460px;width:90%;max-height:80vh;overflow-y:auto}
.modal-title{font-size:1.2rem;font-weight:700;margin-bottom:14px}
.modal-body{font-size:.9rem;color:#ccc;line-height:1.6;margin-bottom:16px}
.modal-body p{margin-bottom:8px}
.modal-actions{display:flex;gap:8px;flex-wrap:wrap}
.modal-actions button{flex:1;min-width:100px}

/* ========== GAME OVER ========== */
#gameOver{justify-content:center;align-items:center;background:linear-gradient(135deg,#0a0a14 0%,#141428 50%,#0a1420 100%)}
.gameover-container{text-align:center;max-width:500px;width:90%}
.gameover-container h1{font-size:2.8rem;font-weight:900;margin-bottom:8px}
.gameover-container h1 span{color:#00d4aa}
#winnerDesc{color:#888;margin-bottom:24px;font-size:1.1rem}
#finalStats{background:rgba(30,30,50,.85);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:20px;margin-bottom:24px;text-align:left}
.stat-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:.9rem}
.stat-row:last-child{border:none}
.stat-label{color:#888}.stat-val{color:#00d4aa;font-weight:600}

/* ========== SCROLLBAR ========== */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.2)}

/* ========== CONSTRUCTION BADGE (on canvas, handled in JS) ========== */
