/* ============================================================
   QuadDice Hub — stylesheet
   Visual language carried over from the original field map:
   dark panels, gold accent, mono labels, serif display titles.
   ============================================================ */
:root{
  --bg:#0a0e14; --panel:#131820; --panel-2:#1a2029; --panel-3:#20262f;
  --border:#2a3340; --border-soft:#1f2630;
  --text:#e8e6e0; --text-dim:#8a93a0;
  --accent:#d4a857; --accent-2:#e8b962; --accent-dim:#8b6f3a;
  --danger:#c8553d; --danger-2:#e06a50;
  --ok:#4ea374; --info:#588b8b; --warn:#c99a3a;
  --mono:'JetBrains Mono',monospace; --sans:'Manrope',system-ui,sans-serif; --serif:'DM Serif Display',serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;font-family:var(--sans);background:var(--bg);color:var(--text);overflow:hidden;font-size:14px}
.hidden{display:none!important}
.dim{color:var(--text-dim)}
.gold{color:var(--accent-2)}
.red{color:var(--danger-2)}
.green{color:var(--ok)}
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border)}

/* === AUTH === */
.auth-screen{position:fixed;inset:0;background:var(--bg);z-index:5000;display:flex;align-items:center;justify-content:center}
.auth-box{background:var(--panel);border:1px solid var(--accent);max-width:400px;width:92%;padding:36px 32px;box-shadow:0 20px 60px rgba(0,0,0,.6)}
.auth-box h1{font-family:var(--serif);font-size:28px;margin-bottom:4px}
.auth-sub{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:2.5px;color:var(--accent);margin-bottom:24px}
.auth-box label{display:block;font-family:var(--mono);font-size:9.5px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);margin:14px 0 4px}
.auth-box input{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);padding:10px 12px;font-family:var(--sans);font-size:14px;border-radius:0}
.auth-box input:focus{outline:none;border-color:var(--accent)}
.auth-actions{display:flex;gap:8px;margin-top:20px}
.auth-actions .btn{flex:1}
.auth-error{color:var(--danger);font-family:var(--mono);font-size:11px;margin-top:12px;min-height:16px}
.auth-hint{color:var(--text-dim);font-family:var(--mono);font-size:10px;margin-top:12px;text-transform:uppercase;letter-spacing:1px;line-height:1.5}

/* === LAYOUT === */
.app{display:flex;flex-direction:column;height:100vh}
.topbar{display:flex;align-items:center;gap:18px;padding:10px 18px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,#171d27,#131820);flex-shrink:0}
.brand .title{font-family:var(--serif);font-size:20px;line-height:1}
.brand .subtitle{font-family:var(--mono);font-size:9px;text-transform:uppercase;letter-spacing:2.5px;color:var(--accent);margin-top:3px}
.tabs{display:flex;gap:0;flex:1;justify-content:center}
.tabs button{background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-dim);padding:10px 16px;font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:1.5px;cursor:pointer;transition:all .12s}
.tabs button:hover{color:var(--text)}
.tabs button.active{color:var(--accent);border-bottom-color:var(--accent)}
.tabs button .badge{display:inline-block;min-width:15px;padding:1px 4px;background:var(--danger);color:#fff;font-size:8.5px;border-radius:8px;margin-left:5px;vertical-align:1px}
.userbox{display:flex;align-items:center;gap:10px}
.user-info{font-family:var(--mono);font-size:10px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;white-space:nowrap}
.user-info .role-badge{display:inline-block;padding:1px 5px;border:1px solid var(--accent-dim);color:var(--accent);font-size:8px;letter-spacing:1.5px;margin-left:4px;vertical-align:1px}
#viewAsSelect{max-width:180px}
#tabRoot{flex:1;min-height:0;position:relative}
.tab-panel{position:absolute;inset:0;display:none}
.tab-panel.active{display:block}
.tab-panel.scrolly{overflow-y:auto;padding:18px 22px 60px}

/* === CONTROLS === */
.btn{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:7px 11px;font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:1.2px;cursor:pointer;transition:all .15s;border-radius:0}
.btn:hover{border-color:var(--accent);color:var(--accent)}
.btn.primary{background:var(--accent);color:#1a1408;border-color:var(--accent);font-weight:700}
.btn.primary:hover{background:var(--accent-2);color:#1a1408}
.btn.danger:hover{border-color:var(--danger);color:var(--danger)}
.btn.small{padding:5px 8px;font-size:9.5px}
.btn.tiny{padding:2px 6px;font-size:9px;letter-spacing:.8px}
.btn:disabled{opacity:.4;cursor:not-allowed}
.btn:disabled:hover{border-color:var(--border);color:var(--text)}
.btn.ok{border-color:var(--ok);color:var(--ok)}
.btn-mini{background:transparent;border:1px dashed var(--border);color:var(--text-dim);padding:5px 8px;font-family:var(--mono);font-size:9.5px;text-transform:uppercase;letter-spacing:1px;cursor:pointer;margin-top:5px;width:100%;border-radius:0}
.btn-mini:hover:not(:disabled){border-color:var(--accent);border-style:solid;color:var(--accent)}
.btn-mini:disabled{opacity:.4;cursor:not-allowed}
label{display:block;font-family:var(--mono);font-size:9px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);margin:10px 0 3px}
input[type=text],input[type=number],input[type=email],input[type=password],textarea,select{background:var(--bg);border:1px solid var(--border);color:var(--text);padding:7px 10px;font-family:var(--sans);font-size:13px;border-radius:0;width:100%}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent)}
textarea{min-height:55px;resize:vertical;line-height:1.5}
input[type=number].narrow{width:64px}
select{cursor:pointer;font-family:var(--mono);font-size:12px}
input[type=checkbox]{accent-color:var(--accent);width:auto}
.field-row{display:flex;gap:10px}
.field-row>*{flex:1;min-width:0}
.inline-edit{background:transparent;border:1px solid transparent;padding:3px 5px}
.inline-edit:hover{border-color:var(--border)}
.inline-edit:focus{background:var(--bg);border-color:var(--accent)}

/* === SECTIONS / CARDS === */
.section-label{font-family:var(--mono);font-size:9px;text-transform:uppercase;letter-spacing:2px;color:var(--text-dim);margin:18px 0 8px;display:flex;justify-content:space-between;align-items:center}
.section-label:first-child{margin-top:0}
.section-label .count{color:var(--accent)}
.section-label .acts{display:flex;gap:6px}
.card{background:var(--panel);border:1px solid var(--border-soft);padding:12px 14px;margin-bottom:10px}
.card.accent{border-color:var(--accent-dim)}
.card h3{font-family:var(--serif);font-size:17px;color:var(--accent-2);margin-bottom:2px}
.card .sub{font-family:var(--mono);font-size:9px;text-transform:uppercase;letter-spacing:2px;color:var(--text-dim);margin-bottom:8px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:start}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;align-items:start}
@media(max-width:1100px){.grid-3{grid-template-columns:1fr 1fr}}
@media(max-width:850px){.grid-2,.grid-3{grid-template-columns:1fr}}
.empty{text-align:center;padding:26px 16px;color:var(--text-dim);font-family:var(--mono);font-size:11px;line-height:1.9}
.empty b{color:var(--accent)}

/* === TABLES === */
table.tbl{width:100%;border-collapse:collapse;font-size:12.5px}
table.tbl th{font-family:var(--mono);font-size:8.5px;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-dim);text-align:left;padding:5px 7px;border-bottom:1px solid var(--border);font-weight:500;white-space:nowrap}
table.tbl td{padding:5px 7px;border-bottom:1px solid var(--border-soft);vertical-align:middle}
table.tbl tr:hover td{background:rgba(212,168,87,.04)}
table.tbl td.num,table.tbl th.num{text-align:right;font-family:var(--mono);font-size:11.5px}
table.tbl input,table.tbl select{padding:3px 6px;font-size:12px}
table.tbl .row-acts{white-space:nowrap;text-align:right}

/* === STAT BLOCKS === */
.statgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(72px,1fr));gap:6px}
.stat-box{background:var(--bg);border:1px solid var(--border);padding:7px 6px;text-align:center}
.stat-box .k{font-family:var(--mono);font-size:8px;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-dim)}
.stat-box .v{font-family:var(--mono);font-size:19px;color:var(--accent-2);margin-top:2px}
.stat-box .v .mod{font-size:10px;color:var(--text-dim);margin-left:2px}
.stat-box.danger .v{color:var(--danger-2)}
.kv{display:flex;justify-content:space-between;gap:8px;font-family:var(--mono);font-size:11px;line-height:1.9}
.kv .k{color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;font-size:9px;padding-top:3px}
.kv .v{color:var(--accent-2);text-align:right}
.bar{height:5px;background:var(--border-soft);position:relative;overflow:hidden;margin-top:3px}
.bar .fill{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,var(--accent-dim),var(--accent))}
.bar .fill.red{background:linear-gradient(90deg,#7d3527,var(--danger))}
.bar .fill.green{background:linear-gradient(90deg,#2d5f44,var(--ok))}

/* === PILLS / CHIPS === */
.pill{display:inline-block;padding:2px 8px;border:1px solid var(--border);font-family:var(--mono);font-size:9.5px;text-transform:uppercase;letter-spacing:1px;color:var(--text-dim);margin:0 4px 4px 0}
.pill.gold{border-color:var(--accent-dim);color:var(--accent)}
.pill.red{border-color:var(--danger);color:var(--danger-2)}
.pill.green{border-color:var(--ok);color:var(--ok)}
.pill.blue{border-color:var(--info);color:#7fb3b3}
.pill.click{cursor:pointer}
.pill.click:hover{border-color:var(--accent);color:var(--accent)}

/* === MODAL === */
.modal-backdrop{position:fixed;inset:0;background:rgba(4,6,10,.78);z-index:4000;display:flex;align-items:flex-start;justify-content:center;overflow-y:auto;padding:5vh 16px}
.modal{background:var(--panel);border:1px solid var(--accent-dim);max-width:560px;width:100%;box-shadow:0 24px 80px rgba(0,0,0,.7);margin-bottom:5vh}
.modal.wide{max-width:900px}
.modal.xwide{max-width:1200px}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:14px 18px 10px;border-bottom:1px solid var(--border)}
.modal-head h2{font-family:var(--serif);font-size:19px;color:var(--accent-2)}
.modal-head .x{background:transparent;border:1px solid var(--border);color:var(--text-dim);width:26px;height:26px;cursor:pointer;font-size:14px;line-height:1}
.modal-head .x:hover{border-color:var(--danger);color:var(--danger)}
.modal-body{padding:14px 18px;max-height:70vh;overflow-y:auto}
.modal-foot{display:flex;gap:8px;justify-content:flex-end;padding:12px 18px;border-top:1px solid var(--border)}

/* === TOASTS === */
#toastRoot{position:fixed;bottom:18px;left:18px;z-index:6000;display:flex;flex-direction:column;gap:8px}
.toast{background:var(--panel);border:1px solid var(--accent);border-left-width:4px;padding:10px 14px;font-family:var(--mono);font-size:11px;max-width:380px;box-shadow:0 8px 24px rgba(0,0,0,.5);animation:slidein .2s ease}
.toast.err{border-color:var(--danger)}
.toast.ok{border-color:var(--ok)}
@keyframes slidein{from{transform:translateX(-16px);opacity:0}to{transform:none;opacity:1}}

/* === MAP TAB === */
#tab-map{display:none}
#tab-map.active{display:grid;grid-template-columns:1fr 410px}
#map{height:100%;background:var(--bg);position:relative}
.leaflet-container{background:var(--bg)!important;font-family:var(--sans)!important}
.leaflet-interactive{outline:none!important}
.leaflet-control-zoom a{background:var(--panel)!important;color:var(--text)!important;border-color:var(--border)!important}
.leaflet-control-zoom a:hover{background:var(--panel-2)!important;color:var(--accent)!important}
.leaflet-control-attribution{background:rgba(19,24,32,.85)!important;color:var(--text-dim)!important;font-size:9px!important}
.leaflet-control-attribution a{color:var(--accent-dim)!important}
.leaflet-bar{border:1px solid var(--border)!important;box-shadow:none!important}
.map-sidebar{background:var(--panel);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;min-width:0}
.map-side-head{padding:12px 16px 10px;border-bottom:1px solid var(--border);background:var(--panel-2)}
.map-side-head label{margin-top:6px}
.map-toolbar{padding:8px 16px;border-bottom:1px solid var(--border);display:flex;gap:6px;flex-wrap:wrap}
.rank-toggle{padding:6px 16px 0;display:flex;border-bottom:1px solid var(--border-soft)}
.rank-toggle button{flex:1;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-dim);padding:6px 2px;font-family:var(--mono);font-size:8.5px;text-transform:uppercase;letter-spacing:.8px;cursor:pointer}
.rank-toggle button:hover{color:var(--text)}
.rank-toggle button.active{color:var(--accent);border-bottom-color:var(--accent)}
.map-side-content{flex:1;overflow-y:auto;padding:10px 16px}
.area-list{display:flex;flex-direction:column;gap:5px;margin-bottom:16px}
.area-item{background:var(--panel-2);border:1px solid var(--border-soft);border-left:3px solid var(--border);padding:7px 10px;cursor:pointer;transition:all .12s;display:grid;grid-template-columns:auto 1fr;gap:6px;align-items:center}
.area-item:hover{border-color:var(--border);border-left-color:var(--accent);background:#1d242e}
.area-item.selected{background:#1f2630;border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent-dim)}
.area-item.unassigned{opacity:.7}
.area-rank{font-family:var(--mono);font-size:10px;color:var(--accent);min-width:24px;text-align:right}
.area-main{min-width:0}
.area-name{font-weight:600;font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.area-meta{font-family:var(--mono);font-size:9px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.8px;display:flex;flex-wrap:wrap;gap:4px;align-items:center}
.area-meta .gang-dot{display:inline-block;width:6px;height:6px;margin-right:2px}
.area-meta .gang-name{color:var(--accent)}
.area-bar{height:3px;background:var(--border-soft);margin-top:3px;position:relative;overflow:hidden}
.area-bar-fill{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,var(--accent-dim),var(--accent))}
.area-value{font-family:var(--mono);font-size:9px;color:var(--text-dim);margin-top:2px}
.area-value .v{color:var(--accent-2)}
.map-editor{padding:12px 16px 16px;border-top:1px solid var(--accent-dim);background:linear-gradient(180deg,#1a2029,#171d27);max-height:62vh;overflow-y:auto}
.map-editor h3{font-family:var(--serif);font-size:17px;color:var(--accent-2)}
.map-editor .editor-sub{font-family:var(--mono);font-size:9px;text-transform:uppercase;letter-spacing:2px;color:var(--text-dim);margin-bottom:8px}
.factions-list{display:flex;flex-direction:column;gap:4px}
.faction-row{display:flex;gap:5px;align-items:center}
.gang-ref-btn{flex:1;min-width:0;display:flex;align-items:center;gap:6px;background:var(--bg);border:1px solid var(--border);padding:5px 8px;cursor:pointer;color:var(--text)}
.gang-ref-btn:hover{border-color:var(--accent)}
.gang-ref-color{flex-shrink:0;width:14px;height:14px;border:1px solid rgba(255,255,255,.15)}
.gang-ref-name{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:12px;text-align:left}
.pct-wrap{flex-shrink:0;display:flex;align-items:center;background:var(--bg);border:1px solid var(--border)}
.pct-wrap input{width:48px;border:none;padding:5px 3px 5px 6px;text-align:right;background:transparent}
.pct-wrap .pct-sign{padding:0 6px 0 1px;color:var(--text-dim);font-family:var(--mono);font-size:10px}
.faction-remove-btn{flex-shrink:0;width:24px;height:24px;background:transparent;border:1px solid var(--border-soft);color:var(--text-dim);font-size:14px;cursor:pointer;padding:0}
.faction-remove-btn:hover{border-color:var(--danger);color:var(--danger)}
.coverage-hint{font-family:var(--mono);font-size:9px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin-top:6px;display:flex;justify-content:space-between}
.coverage-hint .sum{color:var(--accent)}
.coverage-hint .sum.over{color:var(--danger)}
.demo-block{background:var(--bg);border:1px solid var(--border);padding:8px 10px;margin-top:4px;font-family:var(--mono);font-size:10.5px;line-height:1.7}
.area-tooltip{background:var(--panel)!important;border:1px solid var(--accent)!important;color:var(--text)!important;font-family:var(--mono)!important;font-size:10.5px!important;padding:5px 8px!important;box-shadow:0 4px 12px rgba(0,0,0,.5)!important;border-radius:0!important}
.area-tooltip:before{display:none!important}
.tt-name{color:var(--accent);font-weight:500;text-transform:uppercase;letter-spacing:1.5px;font-size:9.5px}
.tt-factions{color:var(--text);font-size:10.5px;margin-top:2px}
.tt-factions .f-dot{display:inline-block;width:6px;height:6px;margin-right:2px}
.tt-demo{color:var(--accent-2);font-size:9.5px;margin-top:2px}
.tt-fx{color:#7fb3b3;font-size:9px;margin-top:2px}
.tt-hint{color:var(--text-dim);font-size:8.5px;margin-top:2px;letter-spacing:1px}
.basemap-toggle{position:absolute;top:14px;right:14px;background:rgba(19,24,32,.92);border:1px solid var(--border);z-index:1000;backdrop-filter:blur(6px);display:flex}
.basemap-toggle button,.map-float-toggle{background:transparent;border:none;color:var(--text-dim);padding:7px 12px;font-family:var(--mono);font-size:9.5px;text-transform:uppercase;letter-spacing:1.2px;cursor:pointer}
.basemap-toggle button{border-right:1px solid var(--border)}
.basemap-toggle button:last-child{border-right:none}
.basemap-toggle button:hover{color:var(--accent)}
.basemap-toggle button.active{color:var(--accent);background:rgba(212,168,87,.12)}
.map-float{position:absolute;top:14px;left:14px;z-index:1000;display:flex;gap:8px}
.map-float .btn{background:rgba(19,24,32,.92);backdrop-filter:blur(6px)}
.map-status{position:absolute;bottom:14px;left:14px;background:rgba(19,24,32,.92);border:1px solid var(--border);padding:6px 12px;font-family:var(--mono);font-size:9.5px;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-dim);z-index:1000;backdrop-filter:blur(6px);max-width:55%}
.map-status .pulse{display:inline-block;width:5px;height:5px;background:var(--accent);border-radius:50%;margin-right:5px;animation:pulse 1.5s infinite;vertical-align:1px}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* === PERK TREE === */
.perk-tier{margin-bottom:10px}
.perk-tier-label{font-family:var(--mono);font-size:9px;text-transform:uppercase;letter-spacing:2px;color:var(--text-dim);margin-bottom:5px}
.perk-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:6px}
.perk-node{background:var(--panel-2);border:1px solid var(--border-soft);padding:8px 10px;cursor:pointer;transition:all .12s;position:relative}
.perk-node:hover{border-color:var(--border)}
.perk-node .pname{font-weight:600;font-size:12px}
.perk-node .pbranch{position:absolute;top:6px;right:8px;font-family:var(--mono);font-size:9px;color:var(--text-dim)}
.perk-node .pdesc{font-size:11px;color:var(--text-dim);margin-top:3px;line-height:1.45}
.perk-node .pcost{font-family:var(--mono);font-size:9px;color:var(--accent);margin-top:4px;text-transform:uppercase;letter-spacing:1px}
.perk-node.active{border-color:var(--accent);background:rgba(212,168,87,.10);box-shadow:inset 0 0 0 1px var(--accent-dim)}
.perk-node.locked{opacity:.45;cursor:not-allowed}
.perk-node.unaffordable{opacity:.6}
.perk-node.headonly{border-style:dashed}

/* === LOG / LEDGER === */
.loglist{font-family:var(--mono);font-size:10.5px;line-height:1.5}
.loglist .logrow{display:flex;gap:8px;padding:4px 0;border-bottom:1px solid var(--border-soft)}
.loglist .when{color:var(--text-dim);white-space:nowrap;font-size:9px;padding-top:2px}
.loglist .what{flex:1}
.loglist .amt{white-space:nowrap;text-align:right}

/* === BREAKDOWN (DC computation) === */
.breakdown{background:var(--bg);border:1px solid var(--border);padding:8px 10px;font-family:var(--mono);font-size:11px;line-height:1.8}
.breakdown .b-row{display:flex;justify-content:space-between;gap:10px}
.breakdown .b-row .src{color:var(--text-dim);font-size:9.5px}
.breakdown .b-row.total{border-top:1px solid var(--border);margin-top:4px;padding-top:4px;color:var(--accent-2);font-weight:600}
.roll-callout{background:linear-gradient(180deg,#1d2430,#171d27);border:1px solid var(--accent);padding:14px;text-align:center;margin:10px 0}
.roll-callout .formula{font-family:var(--mono);font-size:21px;color:var(--accent-2);letter-spacing:1px}
.roll-callout .vs{font-family:var(--mono);font-size:10px;color:var(--text-dim);text-transform:uppercase;letter-spacing:2px;margin-top:4px}
.choice-btns{display:flex;gap:8px;justify-content:center;margin-top:10px;flex-wrap:wrap}

/* === WIZARD === */
.wiz-steps{display:flex;gap:0;margin-bottom:14px;border:1px solid var(--border)}
.wiz-steps .ws{flex:1;text-align:center;font-family:var(--mono);font-size:8.5px;letter-spacing:1px;text-transform:uppercase;color:var(--text-dim);padding:6px 2px;border-right:1px solid var(--border)}
.wiz-steps .ws:last-child{border-right:none}
.wiz-steps .ws.on{color:var(--accent);background:rgba(212,168,87,.10)}
.task-pick{display:grid;grid-template-columns:200px 1fr;gap:12px;min-height:300px}
.task-pick .cats{border-right:1px solid var(--border);padding-right:10px}
.task-pick .cat{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:1px;padding:6px 8px;color:var(--text-dim);cursor:pointer}
.task-pick .cat:hover{color:var(--text)}
.task-pick .cat.on{color:var(--accent);background:rgba(212,168,87,.08)}
.task-opt{border:1px solid var(--border-soft);background:var(--panel-2);padding:9px 11px;margin-bottom:6px;cursor:pointer}
.task-opt:hover{border-color:var(--accent)}
.task-opt.on{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent-dim)}
.task-opt .tname{font-weight:600;font-size:13px}
.task-opt .tmeta{font-family:var(--mono);font-size:9px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin-top:2px}
.task-opt .tdesc{font-size:11.5px;color:var(--text-dim);margin-top:3px}

/* paperwork tray */
.pw-tray{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:6px}
.pw-cell{background:var(--bg);border:1px solid var(--border);padding:8px;text-align:center}
.pw-cell .k{font-family:var(--mono);font-size:8px;text-transform:uppercase;letter-spacing:1px;color:var(--text-dim);min-height:22px}
.pw-cell .v{font-family:var(--mono);font-size:20px;color:var(--text);margin:2px 0}
.pw-cell.late{border-color:var(--danger)}
.pw-cell.late .v{color:var(--danger-2)}
.pw-cell.banked .v{color:#7fb3b3}
.pw-cell .acts{display:flex;gap:3px;justify-content:center}

/* org task cards */
.otask{background:var(--panel-2);border:1px solid var(--border-soft);border-left:3px solid var(--accent-dim);padding:9px 12px;margin-bottom:7px}
.otask .head{display:flex;justify-content:space-between;gap:8px;align-items:baseline}
.otask .tname{font-weight:700;font-size:13.5px}
.otask .meta{font-family:var(--mono);font-size:9.5px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.8px;margin-top:2px;line-height:1.8}
.otask .acts{display:flex;gap:5px;margin-top:6px;flex-wrap:wrap}
.otask.sporadic{border-left-color:var(--info)}
.otask.resolved{opacity:.65}

/* pending rolls */
.proll{background:linear-gradient(180deg,#241d16,#1c1812);border:1px solid var(--warn);padding:10px 12px;margin-bottom:8px}
.proll .q{font-size:12.5px;font-weight:600}
.proll .ctx{font-family:var(--mono);font-size:9.5px;color:var(--text-dim);margin-top:2px;text-transform:uppercase;letter-spacing:.8px}

/* gm split layout */
.gm-cols{display:grid;grid-template-columns:220px 1fr;gap:18px;align-items:start}
.gm-menu{position:sticky;top:0;display:flex;flex-direction:column;gap:2px}
.gm-menu button{text-align:left;background:transparent;border:none;border-left:2px solid transparent;color:var(--text-dim);padding:7px 10px;font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:1.2px;cursor:pointer}
.gm-menu button:hover{color:var(--text)}
.gm-menu button.on{color:var(--accent);border-left-color:var(--accent);background:rgba(212,168,87,.06)}
