*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;overflow:hidden;background:#05050a;color:#c8e8ff;font-family:'Pixeloid',monospace,sans-serif;touch-action:none;}
#g{display:flex;height:100vh;overflow:hidden;}
/* SIDEBAR */
#sb{width:200px;flex-shrink:0;background:#080814;border-right:1px solid rgba(0,212,255,.15);display:flex;flex-direction:column;overflow-y:auto;z-index:10;transition:width .25s ease,min-width .25s ease;min-width:200px;}
#sb::-webkit-scrollbar{width:2px;}#sb::-webkit-scrollbar-thumb{background:rgba(0,212,255,.15);}
#sbt{padding:8px 10px;border-bottom:1px solid rgba(0,212,255,.12);flex-shrink:0;}
.gtitle{font-size:8px;color:rgba(0,212,255,.5);letter-spacing:.16em;margin-bottom:3px;}
.nname{font-size:12px;color:#00d4ff;text-shadow:0 0 8px rgba(0,212,255,.4);line-height:1.2;}
.ngov{font-size:8px;color:rgba(0,212,255,.4);letter-spacing:.1em;margin-top:2px;}
.resblock{padding:8px 10px;border-bottom:1px solid rgba(0,212,255,.08);flex-shrink:0;}
.rrow{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;}
.rrow:last-child{margin-bottom:0;}
.rlbl{font-size:8px;color:rgba(200,232,255,.4);letter-spacing:.1em;}
.rval{font-size:12px;color:#00d4ff;}
.rinc{font-size:8px;color:rgba(64,255,128,.6);margin-left:2px;}
.ssec{font-size:8px;color:rgba(200,232,255,.3);letter-spacing:.16em;padding:6px 10px 3px;flex-shrink:0;}
.pi{padding:4px 10px;font-size:9px;color:rgba(200,232,255,.6);cursor:pointer;border-left:2px solid transparent;transition:all .1s;}
.pi:hover{background:rgba(0,212,255,.05);color:#00d4ff;}
.pi.active{background:rgba(0,212,255,.08);color:#00d4ff;border-left-color:#00d4ff;}
.pisub{font-size:7px;color:rgba(200,232,255,.3);}
/* MAP */
#ma{flex:1;position:relative;overflow:hidden;background:#0a0a14;touch-action:none;}
#mc{display:block;position:absolute;top:32px;left:0;cursor:grab;image-rendering:pixelated;}
#mc.grabbing{cursor:grabbing;}
#mi{display:none;}
/* RIGHT PANEL */
#rp{width:240px;flex-shrink:0;background:#080814;border-left:1px solid rgba(0,212,255,.15);display:flex;flex-direction:column;overflow-y:auto;z-index:10;transition:transform .25s ease;}
#rp::-webkit-scrollbar{width:2px;}#rp::-webkit-scrollbar-thumb{background:rgba(0,212,255,.2);}
.rph{background:rgba(0,212,255,.06);border-bottom:1px solid rgba(0,212,255,.2);padding:7px 10px;font-size:9px;color:#00d4ff;letter-spacing:.12em;flex-shrink:0;}
.rpb{padding:10px;}
.irow{display:flex;justify-content:space-between;padding:3px 0;border-bottom:.5px solid rgba(0,212,255,.06);font-size:9px;}
.irow:last-child{border-bottom:none;}
.ik{color:rgba(200,232,255,.4);}
.iv{color:#c8e8ff;}
.iv.cy{color:#00d4ff;}.iv.gd{color:#f0c040;}.iv.gr{color:#40ff80;}.iv.rd{color:#ff6b6b;}
.rdiv{height:1px;background:rgba(0,212,255,.08);margin:8px 0;}
.rsec{font-size:8px;color:rgba(200,232,255,.3);letter-spacing:.14em;margin-bottom:5px;}
.abtn{width:100%;font-family:inherit;font-size:9px;letter-spacing:.1em;padding:6px 8px;border:1px solid;background:transparent;cursor:pointer;transition:all .15s;margin-bottom:4px;text-align:left;color:#c8e8ff;}
.abtn.prim{border-color:rgba(0,212,255,.35);color:#00d4ff;}.abtn.prim:hover,.abtn.prim:active{background:rgba(0,212,255,.1);border-color:#00d4ff;}
.abtn.warn{border-color:rgba(240,192,64,.35);color:#f0c040;}.abtn.warn:hover{background:rgba(240,192,64,.08);}
.abtn.dng{border-color:rgba(255,107,107,.3);color:#ff6b6b;}.abtn.dng:hover{background:rgba(255,107,107,.08);}
.abtn:disabled{opacity:.35;cursor:not-allowed;}
/* TOPBAR */
#tb{position:absolute;top:0;left:0;right:0;height:32px;background:rgba(8,8,20,.95);border-bottom:1px solid rgba(0,212,255,.12);display:flex;align-items:center;padding:0 8px;gap:8px;z-index:100;font-size:8px;color:rgba(200,232,255,.4);letter-spacing:.1em;}
.tbd{width:5px;height:5px;border-radius:50%;background:#40ff80;box-shadow:0 0 4px #40ff80;flex-shrink:0;}
.tbv{color:#00d4ff;}.tbs{color:rgba(0,212,255,.2);margin:0 1px;}
.tbl{color:rgba(0,212,255,.4);text-decoration:none;letter-spacing:.1em;transition:color .15s;}.tbl:hover{color:#00d4ff;}
/* ZOOM CONTROLS */
#zc{position:absolute;bottom:16px;left:8px;display:flex;flex-direction:column;gap:4px;z-index:50;}
.zbtn{width:28px;height:28px;background:rgba(8,8,20,.88);border:1px solid rgba(0,212,255,.25);color:#00d4ff;font-family:inherit;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;}
.zbtn:hover,.zbtn:active{background:rgba(0,212,255,.15);}
/* TOOLTIP */
#tip{position:fixed;background:#0d0d1a;border:1px solid rgba(0,212,255,.3);padding:5px 8px;font-size:9px;color:#c8e8ff;pointer-events:none;z-index:600;display:none;}
#tipN{color:#00d4ff;font-size:10px;margin-bottom:2px;}
#tipO{color:#40ff80;font-size:8px;}
#tipT{color:rgba(200,232,255,.4);font-size:8px;}
/* LEGEND */
#leg{position:absolute;bottom:12px;right:8px;background:rgba(8,8,20,.9);border:1px solid rgba(0,212,255,.15);padding:6px 8px;font-size:8px;pointer-events:none;z-index:50;}
.lgr{display:flex;align-items:center;gap:5px;margin-bottom:2px;}.lgr:last-child{margin-bottom:0;}
.lgsq{width:8px;height:8px;flex-shrink:0;}.lgl{color:rgba(200,232,255,.5);}
/* TOAST */
#toast{position:fixed;bottom:16px;left:50%;transform:translateX(-50%);background:#0d0d1a;border:1px solid rgba(0,212,255,.4);padding:6px 14px;font-size:9px;color:#00d4ff;letter-spacing:.08em;z-index:9999;display:none;white-space:nowrap;pointer-events:none;}
#toast.show{display:block;animation:fu .2s ease;}
@keyframes fu{from{opacity:0;transform:translateX(-50%) translateY(8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
/* MOBILE TOGGLE */
#mobSbBtn,#mobRpBtn{display:none;position:absolute;z-index:200;top:40px;background:rgba(8,8,20,.9);border:1px solid rgba(0,212,255,.25);color:#00d4ff;font-size:11px;padding:4px 6px;cursor:pointer;}
#mobSbBtn{left:0;border-left:none;}#mobRpBtn{right:0;border-right:none;}
/* AUTH */
#auth{position:fixed;inset:0;z-index:9000;background:rgba(5,5,10,.97);display:flex;align-items:center;justify-content:center;}
.aw{width:380px;max-width:96vw;background:#0d0d1a;border:1px solid rgba(0,212,255,.4);box-shadow:0 0 40px rgba(0,212,255,.2);position:relative;}
.aw::before,.aw::after{content:"";position:absolute;width:8px;height:8px;border-color:#00d4ff;border-style:solid;}
.aw::before{top:-1px;left:-1px;border-width:2px 0 0 2px;}.aw::after{bottom:-1px;right:-1px;border-width:0 2px 2px 0;}
.abar{background:rgba(0,212,255,.07);border-bottom:1px solid rgba(0,212,255,.25);padding:7px 14px;font-size:9px;color:#00d4ff;letter-spacing:.14em;display:flex;justify-content:space-between;}
.abody{padding:20px 18px;display:flex;flex-direction:column;gap:10px;}
.atabs{display:flex;border-bottom:1px solid rgba(0,212,255,.2);margin-bottom:3px;}
.atab{flex:1;padding:6px;font-family:inherit;font-size:9px;letter-spacing:.1em;text-align:center;background:none;border:none;color:rgba(200,232,255,.4);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s;}
.atab.active{color:#00d4ff;border-bottom-color:#00d4ff;}
.afield{display:flex;flex-direction:column;gap:4px;}
.albl{font-size:8px;color:rgba(200,232,255,.4);letter-spacing:.12em;}
.ainp{background:rgba(0,212,255,.04);border:1px solid rgba(0,212,255,.25);padding:7px 9px;font-family:inherit;font-size:11px;color:#c8e8ff;outline:none;caret-color:#00d4ff;transition:border-color .15s;width:100%;}
.ainp:focus{border-color:#00d4ff;}
.abtn2{font-family:inherit;font-size:10px;letter-spacing:.12em;padding:9px;border:1px solid #00d4ff;background:rgba(0,212,255,.1);color:#00d4ff;cursor:pointer;transition:all .15s;width:100%;}
.abtn2:hover{background:rgba(0,212,255,.2);}.abtn2:disabled{opacity:.4;cursor:not-allowed;}
.aerr{font-size:9px;color:#ff6b6b;background:rgba(255,107,107,.08);border:1px solid rgba(255,107,107,.3);padding:6px 9px;display:none;}
.aerr.show{display:block;}
.aok{font-size:9px;color:#40ff80;background:rgba(64,255,128,.06);border:1px solid rgba(64,255,128,.3);padding:6px 9px;display:none;text-align:center;}
.aok.show{display:block;}
.aback{font-size:8px;color:rgba(200,232,255,.3);text-align:center;margin-top:4px;}
.aback a{color:rgba(0,212,255,.5);text-decoration:none;}.aback a:hover{color:#00d4ff;}
/* SETUP */
#setup{position:fixed;inset:0;z-index:8000;background:rgba(5,5,10,.96);display:none;align-items:center;justify-content:center;overflow-y:auto;}
.sw{width:480px;max-width:96vw;background:#0d0d1a;border:1px solid rgba(0,212,255,.4);box-shadow:0 0 40px rgba(0,212,255,.2);position:relative;max-height:90vh;display:flex;flex-direction:column;}
.sw::before,.sw::after{content:"";position:absolute;width:8px;height:8px;border-color:#00d4ff;border-style:solid;pointer-events:none;}
.sw::before{top:-1px;left:-1px;border-width:2px 0 0 2px;}.sw::after{bottom:-1px;right:-1px;border-width:0 2px 2px 0;}
.sbar{background:rgba(0,212,255,.07);border-bottom:1px solid rgba(0,212,255,.25);padding:7px 14px;font-size:9px;color:#00d4ff;letter-spacing:.14em;display:flex;justify-content:space-between;align-items:center;flex-shrink:0;}
.sbody{padding:18px 16px;display:flex;flex-direction:column;gap:10px;overflow-y:auto;}
.sfield{display:flex;flex-direction:column;gap:4px;}
.slbl{font-size:8px;color:rgba(200,232,255,.4);letter-spacing:.12em;}
.sinp{background:rgba(0,212,255,.04);border:1px solid rgba(0,212,255,.25);padding:7px 9px;font-family:inherit;font-size:11px;color:#c8e8ff;outline:none;caret-color:#00d4ff;width:100%;}
.sinp:focus{border-color:#00d4ff;}
.ssel{background:#0a0a14;border:1px solid rgba(0,212,255,.25);padding:7px 9px;font-family:inherit;font-size:10px;color:#c8e8ff;outline:none;cursor:pointer;width:100%;}
.gbonus{font-size:9px;color:#f0c040;padding:5px 9px;background:rgba(240,192,64,.05);border:1px solid rgba(240,192,64,.15);}
.capnote{font-size:9px;color:#f0c040;padding:7px 9px;background:rgba(240,192,64,.05);border:1px solid rgba(240,192,64,.15);line-height:1.6;}
.capdsp{font-size:11px;color:#00d4ff;padding:7px 9px;background:rgba(0,212,255,.04);border:1px solid rgba(0,212,255,.2);}
.cfbox{font-size:10px;color:#c8e8ff;line-height:1.7;padding:10px;background:rgba(0,212,255,.04);border:1px solid rgba(0,212,255,.15);}
.cfwarn{font-size:9px;color:rgba(240,192,64,.7);padding:5px;border:1px solid rgba(240,192,64,.2);}
.sbtn{font-family:inherit;font-size:10px;letter-spacing:.12em;padding:9px;border:1px solid #00d4ff;background:rgba(0,212,255,.1);color:#00d4ff;cursor:pointer;transition:all .15s;width:100%;}
.sbtn:hover,.sbtn:active{background:rgba(0,212,255,.2);}.sbtn:disabled{opacity:.4;cursor:not-allowed;}
.sbtn.sec{border-color:rgba(200,232,255,.2);color:rgba(200,232,255,.4);background:transparent;}
.sbtn.sec:hover{border-color:#00d4ff;color:#00d4ff;}
.steplbl{font-size:8px;color:rgba(200,232,255,.3);letter-spacing:.1em;}
/* GOV MODAL */
#govModal{position:fixed;inset:0;z-index:8500;background:rgba(0,0,0,.88);display:none;align-items:center;justify-content:center;overflow-y:auto;}
#govModal.open{display:flex;}
.gmbox{width:440px;max-width:95vw;background:#0d0d1a;border:1px solid rgba(240,192,64,.4);max-height:88vh;display:flex;flex-direction:column;}
.gmbar{background:rgba(240,192,64,.07);border-bottom:1px solid rgba(240,192,64,.3);padding:7px 12px;font-size:9px;color:#f0c040;letter-spacing:.14em;display:flex;justify-content:space-between;flex-shrink:0;}
.gmscroll{overflow-y:auto;padding:10px;}
.gmscroll::-webkit-scrollbar{width:3px;}.gmscroll::-webkit-scrollbar-thumb{background:rgba(240,192,64,.2);}
.gcard{border:1px solid rgba(255,255,255,.07);padding:8px 10px;margin-bottom:6px;cursor:pointer;transition:all .15s;position:relative;}
.gcard:hover,.gcard:active{border-color:rgba(240,192,64,.4);background:rgba(240,192,64,.04);}
.gcard.current{border-color:rgba(0,212,255,.5);background:rgba(0,212,255,.05);}
.gcard.locked{opacity:.4;cursor:not-allowed;}
.gcname{font-size:10px;letter-spacing:.06em;margin-bottom:2px;}
.gcdesc{font-size:8px;color:rgba(200,232,255,.4);line-height:1.5;}
.gcreq{font-size:8px;margin-top:3px;}
.gcbadge{position:absolute;top:6px;right:6px;font-size:7px;padding:1px 5px;border:1px solid;letter-spacing:.08em;}
/* OWNER PANEL */
#ownerPanel{position:fixed;inset:0;z-index:9100;background:rgba(0,0,0,.92);display:none;align-items:center;justify-content:center;}
#ownerPanel.open{display:flex;}
.opbox{width:440px;max-width:95vw;background:#0d0d1a;border:1px solid rgba(240,192,64,.6);box-shadow:0 0 60px rgba(240,192,64,.2);max-height:88vh;display:flex;flex-direction:column;}
.opbar{background:rgba(240,192,64,.1);border-bottom:1px solid rgba(240,192,64,.4);padding:7px 12px;font-size:9px;color:#f0c040;letter-spacing:.14em;display:flex;justify-content:space-between;flex-shrink:0;}
.opscroll{overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px;}
.opsec{border:1px solid rgba(240,192,64,.15);padding:10px;}
.opstitle{font-size:8px;color:rgba(240,192,64,.6);letter-spacing:.16em;margin-bottom:8px;}
.opsel{background:#0a0a14;border:1px solid rgba(240,192,64,.25);padding:6px 9px;font-family:inherit;font-size:9px;color:#c8e8ff;outline:none;width:100%;margin-bottom:6px;}
.opinp{background:rgba(240,192,64,.04);border:1px solid rgba(240,192,64,.2);padding:6px 9px;font-family:inherit;font-size:9px;color:#c8e8ff;outline:none;width:100%;margin-bottom:6px;caret-color:#f0c040;}
.opbtn{font-family:inherit;font-size:8px;letter-spacing:.1em;padding:5px 10px;border:1px solid rgba(240,192,64,.4);background:transparent;color:#f0c040;cursor:pointer;transition:all .15s;}
.opbtn:hover,.opbtn:active{background:rgba(240,192,64,.12);}.opbtn.red{border-color:rgba(255,107,107,.4);color:#ff6b6b;}.opbtn.red:hover{background:rgba(255,107,107,.1);}
.opmsg{font-size:8px;color:#40ff80;margin-top:5px;min-height:12px;}
/* MOBILE */
@media(max-width:768px){
  #sb{position:fixed;top:32px;bottom:0;left:0;width:220px;transform:translateX(-100%);z-index:300;box-shadow:4px 0 20px rgba(0,0,0,.6);}
  #sb.open{transform:translateX(0);}
  #rp{position:fixed;top:32px;bottom:0;right:0;width:220px;transform:translateX(100%);z-index:300;box-shadow:-4px 0 20px rgba(0,0,0,.6);}
  #rp.open{transform:translateX(0);}
  #mobSbBtn{display:block;left:0;}
  #mobRpBtn{display:block;right:0;}
  .sw{max-width:100vw;max-height:100vh;border-left:none;border-right:none;}
  #zc{bottom:60px;}
  #leg{display:none;}
}

/* FLAG + LEADER */
#sbFlagWrap{width:100%;height:48px;overflow:hidden;margin-bottom:0;position:relative;display:none;}
#sbFlagImg{width:100%;height:100%;object-fit:cover;display:block;}
#sbLeaderRow{display:none;align-items:center;gap:7px;padding:6px 10px 0;}
#sbLeaderAvatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:1px solid rgba(240,192,64,.5);flex-shrink:0;background:rgba(240,192,64,.08);display:flex;align-items:center;justify-content:center;font-size:18px;overflow:hidden;}
#sbLeaderAvatar img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
#sbLeaderName{font-size:10px;color:#f0c040;letter-spacing:.04em;}
#sbLeaderTitle{font-size:8px;color:rgba(200,232,255,.3);letter-spacing:.08em;}
/* Upload zone in setup */
.fupzone{border:1px dashed rgba(0,212,255,.25);padding:8px;text-align:center;cursor:pointer;font-size:8px;color:rgba(200,232,255,.3);letter-spacing:.08em;transition:all .15s;margin-top:4px;}
.fupzone:hover{border-color:var(--c);color:var(--c);}
.fupthumb{max-width:100%;max-height:48px;display:none;margin-top:5px;border:1px solid rgba(0,212,255,.2);}
.fupthumb-r{width:40px;height:40px;border-radius:50%;object-fit:cover;display:none;margin:5px auto 0;border:1px solid rgba(240,192,64,.4);}


/* SIDEBAR COLLAPSED/PINNED (desktop) */
#sb{transition:width .25s ease,transform .25s ease;}
#sb.collapsed{width:0;overflow:hidden;border-right:none;}
#sb.collapsed *{visibility:hidden;}
/* Toggle button on left edge */
#sbToggleBtn{position:absolute;left:0;top:50%;transform:translateY(-50%);z-index:110;background:rgba(8,8,20,.9);border:1px solid rgba(0,212,255,.25);border-left:none;color:#00d4ff;font-size:10px;padding:8px 4px;cursor:pointer;letter-spacing:.1em;writing-mode:vertical-lr;transition:left .25s;}
#sb.collapsed~#ma>#sbToggleBtn,#sb:not(.collapsed)~#ma>#sbToggleBtn{display:none;}

/* LEGEND hidden */
#leg{display:none;}

/* PARTY BARS */
.party-section{padding:8px 10px;border-top:1px solid rgba(0,212,255,.08);}
.party-title{font-size:8px;color:rgba(200,232,255,.35);letter-spacing:.14em;margin-bottom:6px;}
.party-row{margin-bottom:5px;}
.party-name{display:flex;justify-content:space-between;font-size:8px;color:rgba(200,232,255,.45);margin-bottom:2px;}
.party-pct{color:#f0c040;}
.party-track{height:4px;background:rgba(255,255,255,.06);border-radius:2px;overflow:hidden;}
.party-fill{height:100%;border-radius:2px;transition:width .6s ease;}

/* HOI4-STYLE LEADER CARD */
.leader-card{padding:8px 10px 0;display:none;}
.leader-card.show{display:block;}
.leader-card-inner{display:flex;gap:8px;align-items:flex-start;border:1px solid rgba(240,192,64,.2);background:rgba(240,192,64,.04);padding:6px 8px;}
.leader-portrait{width:52px;height:64px;object-fit:cover;object-position:top;border:1px solid rgba(240,192,64,.35);flex-shrink:0;background:rgba(240,192,64,.06);display:flex;align-items:center;justify-content:center;font-size:24px;}
.leader-portrait img{width:100%;height:100%;object-fit:cover;object-position:top;display:block;}
.leader-info{flex:1;min-width:0;}
.leader-name{font-size:11px;color:#f0c040;letter-spacing:.04em;margin-bottom:2px;}
.leader-gov{font-size:8px;color:rgba(200,232,255,.35);letter-spacing:.1em;margin-bottom:4px;}
.leader-edit-btn{font-family:inherit;font-size:7px;letter-spacing:.08em;padding:2px 6px;border:1px solid rgba(0,212,255,.2);background:transparent;color:rgba(0,212,255,.5);cursor:pointer;transition:all .15s;width:100%;}
.leader-edit-btn:hover{border-color:#00d4ff;color:#00d4ff;}

/* FLAG/LEADER EDITOR MODAL */
#fleModal{position:fixed;inset:0;z-index:8800;background:rgba(0,0,0,.9);display:none;align-items:center;justify-content:center;}
#fleModal.open{display:flex;}
.fle-box{width:400px;max-width:95vw;background:#0d0d1a;border:1px solid rgba(0,212,255,.4);box-shadow:0 0 40px rgba(0,212,255,.15);max-height:90vh;display:flex;flex-direction:column;}
.fle-bar{background:rgba(0,212,255,.07);border-bottom:1px solid rgba(0,212,255,.3);padding:7px 12px;font-size:9px;color:#00d4ff;letter-spacing:.14em;display:flex;justify-content:space-between;flex-shrink:0;}
.fle-scroll{overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px;}
.fle-row{display:flex;gap:10px;align-items:flex-start;}
.fle-col{flex:1;}
.fle-label{font-size:8px;color:rgba(200,232,255,.4);letter-spacing:.12em;margin-bottom:5px;}
.fle-preview{width:100%;height:50px;object-fit:cover;display:none;border:1px solid rgba(0,212,255,.2);margin-top:5px;}
.fle-preview-r{width:52px;height:64px;object-fit:cover;object-position:top;display:none;border:1px solid rgba(240,192,64,.3);margin-top:5px;}
.fle-inp{background:rgba(0,212,255,.04);border:1px solid rgba(0,212,255,.25);padding:6px 9px;font-family:inherit;font-size:10px;color:#c8e8ff;outline:none;width:100%;caret-color:#00d4ff;}
.fle-cd{font-size:9px;margin-top:8px;text-align:center;}
.fle-submit{font-family:inherit;font-size:10px;letter-spacing:.12em;padding:9px;border:1px solid #00d4ff;background:rgba(0,212,255,.1);color:#00d4ff;cursor:pointer;width:100%;transition:all .15s;}
.fle-submit:hover{background:rgba(0,212,255,.2);}
.fle-submit:disabled{opacity:.4;cursor:not-allowed;}

/* SIDEBAR COLLAPSED — map fills full width */
#sb.collapsed{width:0;min-width:0;overflow:hidden;border-right:none;}
/* Desktop toggle button */
#sbTogBtn{position:absolute;left:0;top:50%;transform:translateY(-50%);z-index:300;background:rgba(8,8,20,.9);border:1px solid rgba(0,212,255,.3);border-left:none;color:#00d4ff;font-size:9px;padding:10px 3px;cursor:pointer;writing-mode:vertical-lr;letter-spacing:.12em;display:none;transition:left .25s;}
/* CAPITAL MARKER */
.cap-star{color:#f0c040;text-shadow:0 0 6px rgba(240,192,64,.8);}
/* POLITICIAN CARD */
.pol-card{border:1px solid rgba(0,212,255,.12);padding:7px 9px;margin-bottom:5px;background:rgba(0,212,255,.03);}
.pol-name{font-size:10px;color:#c8e8ff;margin-bottom:2px;}
.pol-ideo{font-size:8px;letter-spacing:.08em;}
.pol-effect{font-size:8px;color:rgba(200,232,255,.35);margin-top:2px;}
/* LAW CARD */
.law-card{border:1px solid rgba(240,192,64,.15);padding:7px 9px;margin-bottom:5px;cursor:pointer;transition:all .15s;}
.law-card:hover{border-color:rgba(240,192,64,.4);background:rgba(240,192,64,.04);}
.law-card.active{border-color:rgba(64,255,128,.4);background:rgba(64,255,128,.04);}
.law-name{font-size:10px;color:#f0c040;}
.law-effect{font-size:8px;color:rgba(200,232,255,.4);margin-top:2px;}
/* POLITICS MODAL */
#polModal{position:fixed;inset:0;z-index:9200;background:rgba(0,0,0,.9);display:none;align-items:center;justify-content:center;pointer-events:none;}
#polModal.open{display:flex;animation:fadeUp .2s ease;pointer-events:all;}
.pol-box{width:500px;max-width:96vw;background:#0d0d1a;border:1px solid rgba(240,192,64,.4);box-shadow:0 0 40px rgba(240,192,64,.1);max-height:88vh;display:flex;flex-direction:column;pointer-events:all;}
.pol-bar{background:rgba(240,192,64,.07);border-bottom:1px solid rgba(240,192,64,.3);padding:7px 12px;font-size:9px;color:#f0c040;letter-spacing:.14em;display:flex;justify-content:space-between;flex-shrink:0;}
.pol-tabs{display:flex;border-bottom:1px solid rgba(240,192,64,.1);flex-shrink:0;}
.pol-tab{flex:1;font-family:inherit;font-size:8px;padding:7px;border:none;background:transparent;color:rgba(200,232,255,.4);cursor:pointer;letter-spacing:.1em;transition:all .15s;border-bottom:2px solid transparent;}
.pol-tab.active{color:#f0c040;border-bottom-color:#f0c040;background:rgba(240,192,64,.04);}
.pol-body{overflow-y:auto;padding:12px;}
.pol-body::-webkit-scrollbar{width:3px;}
.pol-body::-webkit-scrollbar-thumb{background:rgba(240,192,64,.2);}
/* ── ENHANCED POLITICS v3 ── */
.law-cat-header{font-size:8px;letter-spacing:.14em;padding:5px 0 4px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:6px;}
.pol-card{border:1px solid rgba(0,212,255,.12);padding:7px 9px;margin-bottom:5px;background:rgba(0,212,255,.03);transition:all .15s;}
.pol-card:hover,.pol-card:active{border-color:rgba(0,212,255,.35);background:rgba(0,212,255,.06);}
.pol-card.active{border-color:rgba(64,255,128,.4);background:rgba(64,255,128,.04);}
.law-card{border:1px solid rgba(240,192,64,.15);padding:7px 9px;margin-bottom:5px;transition:all .15s;}
.law-card:hover{border-color:rgba(240,192,64,.4);background:rgba(240,192,64,.04);}
.law-card.active{border-color:rgba(64,255,128,.4);background:rgba(64,255,128,.04);}
.law-name{font-size:10px;color:#f0c040;}
.law-effect{font-size:8px;color:rgba(200,232,255,.4);margin-top:2px;}