:root{
  --bg:#f6f5f3; --card:#ffffff; --line:#e5e2db; --text:#1a1918; --muted:#6e6a63;
  --accent:#4338ca; --accentbg:#eef2ff;
  --ok:#0f6e56; --okbg:#e1f5ee; --warn:#854f0b; --warnbg:#faeeda;
  --err:#a32d2d; --errbg:#fcebeb;
  --side-bg:#1e1b2e; --side-text:#c8c5d6; --side-hover:#2a2640; --side-active:#352f57;
  --topnav-h:52px;
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--text);font-size:15px;line-height:1.55}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
code{background:var(--accentbg);padding:1px 6px;border-radius:5px;font-size:13px}

/* ═══════════════════════════════════════════════════════════════════
   TOP NAVIGATION BAR
   ═══════════════════════════════════════════════════════════════════ */
.topnav{display:flex;align-items:center;height:var(--topnav-h);
  background:#fff;border-bottom:1px solid var(--line);
  padding:0 16px;position:sticky;top:0;z-index:35;gap:12px}
.topnav-left{display:flex;align-items:center;gap:10px;min-width:0}
.topnav-left .ham{display:none;background:none;border:1px solid var(--line);border-radius:8px;
  width:36px;height:36px;cursor:pointer;color:var(--text);
  align-items:center;justify-content:center;padding:0;flex-shrink:0}
.topnav-brand{display:flex;align-items:center;gap:8px;font-weight:700;font-size:16px;
  color:var(--text);text-decoration:none;white-space:nowrap}
.topnav-brand:hover{text-decoration:none}
.topnav-logo{width:26px;height:26px;flex-shrink:0}
.topnav-center{flex:1;display:flex;justify-content:center;min-width:0}
.topnav-search{display:flex;align-items:center;gap:8px;width:min(460px,100%);
  background:var(--bg);border:1px solid var(--line);color:var(--muted);
  border-radius:10px;padding:7px 12px;cursor:pointer;font-size:13px;
  transition:border-color .15s,box-shadow .15s}
.topnav-search:hover{border-color:var(--accent);box-shadow:0 0 0 3px var(--accentbg)}
.topnav-search svg{flex-shrink:0;opacity:.5}
.topnav-search span{flex:1;text-align:left}
.topnav-search kbd{font-size:11px;background:rgba(0,0,0,.06);border-radius:5px;padding:2px 7px;font-family:inherit}
.topnav-right{display:flex;align-items:center;gap:8px}
.topnav-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;
  border-radius:8px;color:var(--muted);transition:background .12s}
.topnav-icon:hover{background:var(--bg);text-decoration:none;color:var(--text)}
.topnav-profile{position:relative;cursor:pointer}
.topnav-avatar{width:34px;height:34px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),#7c3aed);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;
  transition:box-shadow .15s}
.topnav-avatar:hover{box-shadow:0 0 0 3px var(--accentbg)}
.profile-menu{position:absolute;top:calc(100% + 8px);right:0;width:200px;
  background:#fff;border:1px solid var(--line);border-radius:10px;
  box-shadow:0 12px 40px rgba(0,0,0,.12);overflow:hidden;
  display:none;z-index:100}
.profile-menu.open{display:block}
.pm-head{padding:12px 14px;border-bottom:1px solid var(--line)}
.pm-name{font-weight:600;font-size:14px}
.pm-role{font-size:12px;color:var(--muted);text-transform:capitalize}
.pm-item{display:block;padding:9px 14px;font-size:14px;color:var(--text);text-decoration:none}
.pm-item:hover{background:var(--bg);text-decoration:none}
.pm-sep{border-top:1px solid var(--line);margin:2px 0}
.pm-logout{color:var(--err)}
.pm-logout:hover{background:var(--errbg)}

/* ═══════════════════════════════════════════════════════════════════
   SIDEBAR — dark theme with icons
   ═══════════════════════════════════════════════════════════════════ */
.app{display:flex;min-height:calc(100vh - var(--topnav-h))}
.side{width:220px;background:var(--side-bg);border-right:none;
  padding:14px 10px;display:flex;flex-direction:column;overflow-y:auto;
  scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}
.side-brand{display:flex;align-items:center;gap:9px;padding:4px 10px 16px;
  font-weight:700;font-size:15px;color:#fff;white-space:nowrap}
.side-logo-svg{width:22px;height:22px;flex-shrink:0;color:var(--accent)}
/* legacy brand classes — still referenced in a few templates */
.brand{font-weight:600;font-size:16px;margin-bottom:18px}
.brand.big{font-size:20px}
.logo{color:var(--accent)}
.side nav{display:flex;flex-direction:column;gap:1px}
.side nav .navsection{display:block;font-size:10px;font-weight:600;color:rgba(255,255,255,.35);
  text-transform:uppercase;letter-spacing:.08em;padding:14px 10px 5px}
.side nav .navsection:first-of-type{padding-top:4px}
.side nav a{display:flex;align-items:center;gap:9px;padding:7px 10px;
  border-radius:8px;color:var(--side-text);font-size:13.5px;transition:background .1s}
.side nav a:hover{background:var(--side-hover);text-decoration:none;color:#fff}
.side nav a.on{background:var(--side-active);color:#fff;font-weight:600}
.side nav a .ni{width:16px;height:16px;flex-shrink:0;opacity:.6}
.side nav a.on .ni{opacity:1}
.side-foot{margin-top:auto;padding-top:12px;border-top:1px solid rgba(255,255,255,.08)}
.side-foot a{color:rgba(255,255,255,.4);font-size:13px}
.side-foot a:hover{color:#fff}
.main{flex:1;padding:26px 30px;min-width:0;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));
  gap:16px;align-content:start}

/* ═══════════════════════════════════════════════════════════════════
   SPLIT-SCREEN LOGIN PAGE
   ═══════════════════════════════════════════════════════════════════ */
.login-page{background:#fff;min-height:100vh}
.login-split{display:flex;min-height:100vh}
.login-brand{flex:0 0 46%;background:linear-gradient(145deg,#1e1b2e 0%,#312a5c 50%,#4338ca 100%);
  color:#fff;display:flex;align-items:center;justify-content:center;padding:40px}
.login-brand-inner{max-width:380px}
.login-logo-mark{width:56px;height:56px;margin-bottom:24px}
.login-logo-mark svg{width:100%;height:100%}
.login-hero{font-size:38px;font-weight:800;line-height:1.1;letter-spacing:-1px;margin:0}
.login-hero span{font-weight:400;opacity:.7}
.login-taglines{margin-top:32px;display:flex;flex-direction:column;gap:14px}
.login-tagline{display:flex;align-items:flex-start;gap:12px;font-size:15px;line-height:1.45;opacity:.85}
.tl-icon{font-size:18px;flex-shrink:0;margin-top:1px}
.login-brand-foot{margin-top:36px;font-size:13px;opacity:.5;border-top:1px solid rgba(255,255,255,.12);padding-top:16px}
.login-form-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 32px}
.login-form-inner{width:100%;max-width:380px}
.login-form-head{margin-bottom:28px}
.login-form-logo-sm{width:36px;height:36px;margin-bottom:16px}
.login-form-logo-sm svg{width:100%;height:100%}
.login-form-head h2{font-size:24px;font-weight:700;margin:0}
.login-form-head p{margin:6px 0 0}
.login-fields{display:flex;flex-direction:column;gap:16px}
.login-label{display:flex;flex-direction:column;gap:6px;font-size:14px;font-weight:500}
.login-label input{padding:11px 14px;border:1px solid var(--line);border-radius:10px;
  font-size:15px;transition:border-color .15s,box-shadow .15s}
.login-label input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accentbg)}
.btn-login{background:var(--accent);color:#fff;border:none;border-radius:10px;
  padding:12px;font-size:15px;font-weight:600;cursor:pointer;transition:opacity .12s}
.btn-login:hover{opacity:.9}
.login-error{background:var(--errbg);color:var(--err);padding:10px 14px;border-radius:10px;
  font-size:14px;margin-bottom:8px}
.login-msg{background:var(--okbg);color:var(--ok);padding:10px 14px;border-radius:10px;
  font-size:14px;margin-bottom:8px}
.login-links{text-align:center;margin-top:4px}
.login-links a{font-size:13px;color:var(--muted)}
.login-links a:hover{color:var(--accent)}
.login-trust{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);cursor:pointer}
.login-trust input{width:auto;margin:0}
.login-foot{margin-top:32px;text-align:center}
.reset-option{background:var(--bg);border-radius:10px;padding:16px;margin-bottom:12px}
.reset-option h3{margin:0 0 6px;font-size:15px}

@media(max-width:800px){
  .login-split{flex-direction:column}
  .login-brand{flex:none;padding:32px 24px;min-height:auto}
  .login-brand-inner{max-width:100%}
  .login-hero{font-size:28px}
  .login-taglines{gap:10px;margin-top:20px}
  .login-tagline{font-size:14px}
  .login-brand-foot{display:none}
  .login-form-wrap{padding:28px 20px}
}
/* zero out card-style bottom margins on direct grid children — gap handles spacing */
.main > *{margin-bottom:0}
/* page-level chrome and self-contained grids span the full row */
.main > .topbar,
.main > .deck-hero,
.main > .kpis,
.main > .deck-cols,
.main > .deck-row2,
.main > .worldgrid,
.main > .scorecards,
.main > .progresswrap,
.main > .bulkbar,
.main > .pills,
.main > .tabs,
.main > .filterbox,
.main > .banner,
.main > .empty,
.main > .codearea,
.main > .askcard,
.main > .rail,
.main > .rail-calm,
.main > .feed,
.main > .todoprog,
.main > .docview,
.main > h1,.main > h2,
.main > script,.main > style{grid-column:1/-1}
/* explicit opt-out — any card the page marks .full takes the whole row */
.main > .card.full,
.main > form.card.full,
.main > details.card.full,
.main > .full{grid-column:1/-1}
/* the email-review feed stacks vertically — defined once below in the live-run section */
.feed > *{margin-bottom:0}

.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:18px}
.topactions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.topactions form{margin:0}
h1{font-size:22px;font-weight:600;margin:0}
.muted{color:var(--muted)} .small{font-size:13px}

.btn{font-size:14px;padding:8px 14px;border:1px solid var(--line);background:#fff;border-radius:8px;cursor:pointer;color:var(--text)}
.btn:hover{background:var(--bg)}
.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn.primary:hover{opacity:.92;background:var(--accent)}
.runbtns{display:flex;gap:8px}

.pills{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.pill{font-size:13px;padding:5px 11px;border-radius:8px;border:1px solid var(--line);background:#fff;color:var(--muted)}
.pill.ok{background:var(--okbg);color:var(--ok);border-color:transparent}
.pill.warn{background:var(--warnbg);color:var(--warn);border-color:transparent}
.pill.error{background:var(--errbg);color:var(--err);border-color:transparent}

.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(108px,1fr));gap:12px;margin:8px 0 12px}
.stat{background:#fff;border:1px solid var(--line);border-radius:10px;padding:14px}
.stat .n{font-size:24px;font-weight:600}.stat .l{color:var(--muted);font-size:13px}

.banner{background:var(--accentbg);color:var(--accent);padding:10px 14px;border-radius:8px;margin-bottom:14px}
.banner.ok{background:var(--okbg);color:var(--ok)}
.empty{background:#fff;border:1px dashed var(--line);border-radius:10px;padding:20px;color:var(--muted)}

.card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:16px 18px;margin-bottom:14px}
.card h3{margin:0 0 10px;font-size:16px;font-weight:600}
.cardhead{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.chip{font-size:12px;padding:3px 9px;border-radius:7px;font-weight:500;background:var(--accentbg);color:var(--accent)}
.chip-draft{background:var(--okbg);color:var(--ok)}
.chip-forward{background:#e6f1fb;color:#0c447c}
.chip-flag{background:var(--warnbg);color:var(--warn)}
.chip-error{background:var(--errbg);color:var(--err)}
.chip-ignore{background:#f1efe8;color:#5f5e5a}
.who{font-weight:500}.subj{color:var(--muted)}
.conf{margin-left:auto;color:var(--muted);font-size:12px}
.reason{color:var(--muted);font-size:14px;margin-top:6px}
.ph{margin-top:8px;font-size:12px;color:var(--warn);background:var(--warnbg);display:inline-block;padding:3px 9px;border-radius:6px}
.mini{margin-top:6px;font-size:13px;color:var(--muted)}
pre.draft{white-space:pre-wrap;background:var(--bg);border:1px solid var(--line);border-radius:8px;
  padding:12px 14px;margin-top:10px;font-family:inherit;font-size:14px;line-height:1.5}

label{display:block;margin:16px 0 5px;font-weight:500}
input[type=text],input[type=password],input[type=number],textarea{width:100%;padding:9px 11px;
  border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:14px;background:#fff}
input:focus,textarea:focus{outline:none;border-color:var(--accent)}
textarea{resize:vertical}

.kv{width:100%;border-collapse:collapse}
.kv td{padding:6px 8px;border-bottom:1px solid var(--line)}
.kv td:first-child{color:var(--muted);width:160px}

.centered{display:flex;align-items:center;justify-content:center;min-height:100vh}
.login-box{background:#fff;border:1px solid var(--line);border-radius:12px;padding:28px;width:330px;text-align:center}
.login-box .brand{justify-content:center;display:flex;gap:6px}
.login-box input{margin:14px 0}
.err{background:var(--errbg);color:var(--err);padding:8px 10px;border-radius:8px;font-size:14px;margin-bottom:8px}

/* --- live run UI --- */
.progresswrap{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 18px;margin-bottom:16px}
.runstatusrow{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.runstatus{font-size:15px;font-weight:500}
.bar{height:8px;background:var(--line);border-radius:6px;overflow:hidden;position:relative}
.bar>i{display:block;height:100%;width:0;background:var(--accent);border-radius:6px;transition:width .35s ease}
.bar.indet>i{width:35% !important;background:var(--accent);animation:indet 1.1s ease-in-out infinite;border-radius:6px}
@keyframes indet{0%{margin-left:-35%}100%{margin-left:100%}}
.summary{margin-top:10px;font-size:14px;color:var(--ok);font-weight:500}
.tally{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.tchip{font-size:12px;padding:3px 9px;border-radius:7px;background:var(--bg);border:1px solid var(--line);color:var(--muted)}
.feed{display:flex;flex-direction:column;gap:12px}
.feed .card{margin-bottom:0}
.when{margin-left:auto;color:var(--muted);font-size:12px;white-space:nowrap}
.cardhead .conf{margin-left:0}
.cardhead .subj{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* --- knowledge documents --- */
.kcard{margin-bottom:18px}
.uploadrow{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.uploadrow input[type=file]{flex:1;min-width:220px;padding:8px;border:1px dashed var(--line);border-radius:8px;background:var(--bg)}
.doclist{width:100%;border-collapse:collapse;margin-top:14px;font-size:14px}
.doclist th{text-align:left;font-weight:500;color:var(--muted);font-size:12px;padding:4px 8px;border-bottom:1px solid var(--line)}
.doclist td{padding:8px;border-bottom:1px solid var(--line);vertical-align:middle}
.doclist .dname{font-weight:500}
.doclist .dremove{text-align:right;width:1%;white-space:nowrap}
.doclist form{margin:0}
.btn.tiny{padding:3px 10px;font-size:12px}
.warn{color:var(--warn)}
.small{font-size:13px}

/* --- identity grid --- */
.idgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px}
.idgrid label{display:flex;flex-direction:column;font-size:13px;font-weight:500;gap:4px;margin:0}
.idgrid input{margin:0}
@media(max-width:640px){.idgrid{grid-template-columns:1fr}}

/* --- needs-you-now rail --- */
.rail{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin-bottom:16px}
.rail-head{font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--warn);margin:4px 2px 8px;display:flex;align-items:center;gap:8px}
.rail-head.soft{color:var(--muted);margin-top:14px}
.rail-head .count{background:var(--bg);border:1px solid var(--line);border-radius:20px;padding:1px 8px;font-size:11px;color:var(--muted)}
.alert{display:flex;align-items:center;gap:8px;border-radius:9px;border:1px solid transparent}
.alert-link{display:flex;align-items:center;gap:12px;padding:9px 10px;text-decoration:none;color:var(--text);flex:1;min-width:0;border-radius:9px}
.alert-link:hover{background:var(--bg)}
.alert.now{border-left:3px solid var(--warn);background:rgba(220,120,40,.04)}
.doneform{margin:0;padding-right:6px}
.alert-main{display:flex;flex-direction:column;min-width:0;flex:1}
.alert-from{font-weight:600;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.alert-subj{font-size:13px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.alert-why{font-size:12px;color:var(--text);white-space:nowrap;flex-shrink:0}
.alert-when{font-size:12px;color:var(--muted);white-space:nowrap;flex-shrink:0}
.rail-calm{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px;margin-bottom:16px;color:var(--muted);font-size:14px}
@media(max-width:640px){.alert-why,.alert-when{display:none}}
.check{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500}.check input{width:auto;margin:0}

/* --- nav badge + leads --- */
.navbadge{display:inline-block;min-width:18px;text-align:center;background:rgba(255,255,255,.15);color:#fff;border-radius:20px;font-size:11px;padding:0 6px;line-height:18px;margin-left:4px}
.card.lead{border-left:3px solid var(--accent)}
.leadfoot form{margin:0}
#stopbtn{background:#fff;border-color:var(--warn);color:var(--warn)}#stopbtn:hover{background:rgba(220,120,40,.08)}
.qaform{display:flex;flex-direction:column;gap:8px}.qaform input,.qaform textarea{margin:0}.qaform button{align-self:flex-start}

/* --- decisions --- */
.card.decision{border-left:3px solid var(--accent)}
.dq{font-size:17px;font-weight:600;line-height:1.4}
.dctx{margin-top:4px}
.dmeta{margin-top:8px}
.dform{margin-top:12px;display:flex;flex-direction:column;gap:8px}
.dform textarea{margin:0}
.dopts{display:flex;flex-wrap:wrap;gap:8px}
.btn.opt{background:var(--bg);border-color:var(--line)}
.btn.opt:hover{border-color:var(--accent);color:var(--accent)}
.dform button[type=submit]{align-self:flex-start}

/* --- qa mining candidates --- */
.minebox{margin-top:16px;padding-top:14px;border-top:1px solid var(--line)}
.cands{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.cand{padding:10px 12px;border:1px solid var(--line);border-radius:9px;background:var(--bg)}
.candacts{display:flex;gap:8px;margin-top:8px}
.candacts form{margin:0}

/* --- auto-send settings --- */
.warnbox{background:rgba(220,120,40,.08);border:1px solid var(--warn);border-radius:9px;padding:11px 13px;font-size:13px;line-height:1.5;margin-top:6px}
.cats{display:flex;flex-direction:column;gap:7px;margin-top:6px}
.chip-sent{background:#e6f4ea;color:#1f7a3d}

/* --- draft actions --- */
.draftacts{display:flex;gap:8px;margin-top:10px}
.editbox{margin-top:10px;display:flex;flex-direction:column;gap:8px}
.editbox textarea{width:100%;font-family:inherit;font-size:13px}
.editbox button{align-self:flex-start}

/* auto-send ladder */
.banner.halt{background:var(--errbg);color:var(--err);font-weight:600;display:flex;align-items:center;gap:10px}
.btn.halt{background:var(--err);color:#fff;border-color:var(--err)}
.chip-queued{background:#fde7d6;color:#9a4a00}
.sendrail{border-color:#e6b07a;background:#fffaf4}
.sendrail .rail-head{color:#9a4a00}

/* memory tab */
.rowbtns{display:flex;gap:8px;margin-top:8px}

/* scoreboard */
.scorecards{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:16px}
.scorecard{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.scorecard.big{grid-column:span 2;background:var(--okbg);border-color:#bfe3c9}
.scorecard .num{font-size:30px;font-weight:700;line-height:1.1}
.scorecard .lbl{font-size:13px;color:var(--muted);margin-top:2px}
.sparkbars{display:flex;align-items:flex-end;gap:6px;height:120px;padding-top:8px}
.sparkcol{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1}
.sparkbar{width:100%;max-width:34px;background:var(--accent);border-radius:4px 4px 0 0}
.sparklbl{font-size:10px;color:var(--muted)}
.mixrow{display:flex;align-items:center;gap:10px;margin:7px 0}
.mixlbl{width:130px;font-size:13px;color:var(--text);flex-shrink:0}
.mixbarwrap{flex:1;background:var(--bg);border-radius:6px;overflow:hidden;height:14px}
.mixbar{display:block;height:100%;background:var(--accent)}
.mixn{width:42px;text-align:right;font-size:13px;color:var(--muted)}

/* decision card extras */
.suggest{background:var(--accentbg);color:var(--accent);border-radius:8px;padding:7px 10px;font-size:13px;margin:8px 0;display:flex;align-items:center;gap:8px}
.scoperow{display:flex;gap:16px;margin:8px 0 2px;flex-wrap:wrap}
.radio{font-size:13px;color:var(--text);display:flex;align-items:center;gap:5px}

/* reclassify + backup */
.reclass{display:flex;align-items:center;gap:8px;margin:4px 0 2px}
.reclass .rcl{font-size:12px;color:var(--muted)}
.catsel{font-size:13px;padding:3px 8px;border:1px solid var(--line);border-radius:7px;background:#fff}

/* rules editor */
.codearea{width:100%;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12.5px;line-height:1.5;border:1px solid var(--line);border-radius:10px;padding:12px;background:#fbfaf7;white-space:pre;overflow:auto}

/* leads aging, digest, filter */
.age{font-size:11px;padding:2px 8px;border-radius:20px;background:var(--bg);color:var(--muted);border:1px solid var(--line)}
.age.aged{background:var(--warnbg);color:var(--warn);border-color:var(--warn)}
.digrow{padding:6px 0;border-bottom:1px solid var(--line)}
.digrow:last-child{border-bottom:none}
.filterbox{width:100%;padding:9px 12px;border:1px solid var(--line);border-radius:9px;margin-bottom:12px;font-size:14px}
.leadfoot{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:8px}

/* tone dial */
.tonebar{display:flex;align-items:center;gap:8px;margin-top:8px}
.retonebox{margin-top:8px}

/* bulk actions */
.bulkbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:#fff;border:1px solid var(--line);border-radius:10px;padding:8px 12px;margin-bottom:10px;position:sticky;top:0;z-index:5}
.bulkbar .bchk{font-size:13px;display:flex;align-items:center;gap:5px}
.bulkactions{display:flex;align-items:center;gap:8px;margin-left:auto;flex-wrap:wrap}
.bulkcb{margin-right:6px;flex-shrink:0}

/* patterns chips */
.chips{display:flex;flex-wrap:wrap;gap:8px}
.bigchip{display:inline-flex;align-items:center;gap:6px;background:var(--bg);border:1px solid var(--line);border-radius:20px;padding:5px 12px;font-size:13px}
.bigchip b{color:var(--accent)}
.chipx{border:none;background:var(--errbg);color:var(--err);border-radius:12px;padding:1px 8px;font-size:11px;cursor:pointer}

/* chat */
.chatlog{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}
.chatmsg{max-width:80%;padding:10px 14px;border-radius:14px;white-space:pre-wrap;line-height:1.4}
.chatmsg.user{align-self:flex-end;background:var(--accent);color:#fff}
.chatmsg.bot{align-self:flex-start;background:var(--bg);border:1px solid var(--line)}
.chatbar{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line)}
.chatbar input{flex:1}
/* contacts */
.tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.tab{padding:5px 12px;border:1px solid var(--line);border-radius:16px;font-size:13px;text-decoration:none;color:var(--ink);text-transform:capitalize}
.tab.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.tab b{opacity:.7;font-weight:600}
table.contacts{width:100%;border-collapse:collapse}
table.contacts th{text-align:left;font-size:12px;color:var(--muted);padding:8px 12px;border-bottom:1px solid var(--line)}
table.contacts td{padding:8px 12px;border-bottom:1px solid var(--line);font-size:14px}
.catsel.tiny{padding:2px 6px;font-size:12px}

/* login questions card */
.askcard{border:1px solid var(--accent)}
.askrow{padding:12px 0;border-top:1px solid var(--line)}
.askrow:first-child{border-top:none}
.askq-text{font-weight:600;margin-bottom:4px}
.askq-input{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:8px}
.askq-input .askans{flex:1;min-width:200px}
.askstand{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:4px}

/* folder tree */
.treerow{display:flex;align-items:center;gap:8px;padding:3px 0;border-bottom:1px solid #f2f2f2}
.treerow a{text-decoration:none;color:var(--ink)}
.treerow a:hover{text-decoration:underline}

/* model picker */
.modelrow{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:8px 0;border-top:1px solid var(--line)}
.modelrow:first-of-type{border-top:none}
.modelrow select{max-width:55%}

/* health panel */
.hgrid{display:flex;gap:24px;flex-wrap:wrap}
.hbig{font-size:26px;font-weight:700}

/* to-do */
.todoitem{display:flex;gap:12px;align-items:flex-start;padding:12px 0;border-top:1px solid var(--line)}
.todoitem:first-child{border-top:none}
.todoitem.done .todotitle{text-decoration:line-through;opacity:.5}
.todoitem.done .muted{opacity:.4}
.todocheck input{width:20px;height:20px}
.todotitle{font-weight:600}
.todobody{flex:1}
/* faq pager */
.pager{display:flex;align-items:center;gap:12px;justify-content:center;padding:14px}

/* contacts search/sort */
.sorth{text-decoration:none;color:inherit;opacity:.7}
.sorth.on{opacity:1;font-weight:700}
.lockmark{margin-left:4px}
.savemark{margin-left:6px}

/* contact notes */
.notebox{width:100%;min-width:220px;font:inherit;font-size:13px;padding:6px 8px;border:1px solid var(--line);border-radius:8px;resize:vertical;background:var(--bg)}
.notebox:focus{border-color:var(--accent);outline:none}
.notemark{margin-left:2px}

/* ===== command deck ===== */
.deck-hero{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:18px;flex-wrap:wrap;gap:12px}
.deck-hello{font-size:30px;font-weight:800;letter-spacing:-.5px}
.livedot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--ok,#16a34a);box-shadow:0 0 0 0 rgba(22,163,74,.5);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(22,163,74,.5)}70%{box-shadow:0 0 0 8px rgba(22,163,74,0)}100%{box-shadow:0 0 0 0 rgba(22,163,74,0)}}

.kpis{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:14px;margin-bottom:20px}
.kpi{background:var(--card,#fff);border:1px solid var(--line,#e7e7e9);border-radius:16px;padding:18px}
.kpi.big{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border:none}
.kpi-num{font-size:34px;font-weight:800;letter-spacing:-1px;line-height:1}
.kpi.big .kpi-num{font-size:42px}
.kpi-unit{font-size:16px;font-weight:600;opacity:.7;margin-left:3px}
.kpi-label{font-size:13px;opacity:.75;margin-top:6px}
.kpi-bar{height:6px;border-radius:6px;background:#eee;margin-top:8px;overflow:hidden}
.kpi-bar span{display:block;height:100%;background:linear-gradient(90deg,#4f46e5,#7c3aed)}

.deck-cols{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-bottom:20px}
.deck-col-head{font-weight:700;font-size:14px;margin:0 2px 10px;display:flex;align-items:center;gap:8px}
.cbadge{background:#eee;border-radius:20px;padding:1px 9px;font-size:12px;font-weight:700}
.deck-col-head.crit .cbadge{background:#fee2e2;color:#b91c1c}
.deck-col-head.warn .cbadge{background:#fef3c7;color:#92660a}
.deck-card{display:block;text-decoration:none;color:inherit;background:var(--card,#fff);border:1px solid var(--line,#e7e7e9);border-left:4px solid #ccc;border-radius:12px;padding:12px 14px;margin-bottom:10px;transition:transform .08s,box-shadow .08s}
.deck-card:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(0,0,0,.06)}
.deck-card.crit{border-left-color:#ef4444}
.deck-card.warn{border-left-color:#f59e0b}
.deck-card.ok{border-left-color:#22c55e}
.dc-title{font-weight:600;margin-bottom:2px}
.deck-empty{color:var(--muted,#999);font-size:14px;padding:14px;border:1px dashed var(--line,#e7e7e9);border-radius:12px;text-align:center}

.deck-row2{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-bottom:16px}
.spark{display:flex;align-items:flex-end;gap:5px;height:90px}
.spark-bar{flex:1;background:#f0f0f3;border-radius:4px 4px 0 0;display:flex;align-items:flex-end;height:100%}
.spark-bar span{display:block;width:100%;background:linear-gradient(180deg,#7c3aed,#4f46e5);border-radius:4px 4px 0 0;min-height:2px}
.mixrow{display:flex;justify-content:space-between;font-size:13px;margin:8px 0 3px}
.mixbar{height:7px;border-radius:6px;background:#f0f0f3;overflow:hidden}
.mixbar span{display:block;height:100%;background:linear-gradient(90deg,#4f46e5,#7c3aed)}
.qline{padding:7px 0;border-top:1px solid var(--line,#eee);font-size:14px}
.qline:first-of-type{border-top:none}

@media(max-width:1100px){.kpis{grid-template-columns:1fr 1fr 1fr}.deck-cols,.deck-row2{grid-template-columns:1fr}}

/* ===== world model two-column layout + reserved right rail ===== */
.worldgrid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:24px;align-items:start}
.worldmain{min-width:0}
.worldrail{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:12px;position:sticky;top:16px;align-content:start}
.worldrail .card{padding:14px;margin-bottom:0}
.railstat{display:flex;justify-content:space-between;padding:5px 0;border-top:1px solid var(--line,#eee);font-size:14px}
.railstat:first-of-type{border-top:none}
.railstat b{font-weight:700}
a.railstat{color:inherit;text-decoration:none;cursor:pointer;padding:8px 6px;margin:0 -6px;border-radius:6px}
a.railstat:hover,a.railstat:active{background:var(--bg,#f3f3f5)}
a.railstat span{color:var(--accent,#4338ca)}
.spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--line,#ddd);
  border-top-color:var(--accent,#4338ca);border-radius:50%;animation:spin .8s linear infinite;
  vertical-align:middle;margin-right:6px}
@keyframes spin{to{transform:rotate(360deg)}}
.railsoon{background:linear-gradient(135deg,#f5f3ff,#faf5ff);border-style:dashed}
@media(max-width:1000px){.worldgrid{grid-template-columns:1fr}.worldrail{position:static}}
@media(max-width:520px){.worldrail{grid-template-columns:1fr}}

/* ===== to-do: progress, instructions, completed split ===== */
.todobar{height:8px;background:#eee;border-radius:6px;margin-top:8px;overflow:hidden}
.todobar-fill{height:100%;background:linear-gradient(90deg,#7c5cff,#a855f7);transition:width .3s}
.todohow{margin-top:8px}
.todohow summary{cursor:pointer;color:#7c5cff;font-size:13px;font-weight:600}
.todosteps{margin:8px 0 4px;padding-left:20px}
.todosteps li{margin:5px 0;font-size:14px;line-height:1.45}
.todocode{background:#1e1e2e;color:#e0e0f0;padding:10px 12px;border-radius:8px;font-size:13px;
  white-space:pre-wrap;word-break:break-word;overflow-x:auto;margin:4px 0}
.todotrouble{margin-top:8px;font-size:13px;background:#fff7ed;border:1px solid #fed7aa;
  padding:8px 10px;border-radius:8px;color:#7c2d12}
.todoitem.done .todotitle{text-decoration:line-through;opacity:.6}

/* table text wraps instead of forcing width past its column */
table.contacts td{word-break:break-word;overflow-wrap:anywhere}

/* data-heavy pages — kept as a no-op now that .main is full-width by default */
.main-wide{max-width:none}

/* ============================================================================
   Mobile layout pass — off-canvas sidebar with a hamburger top bar.
   Desktop (>= 900px): everything as-is.
   Mobile (< 900px): sidebar hidden off-screen; tap hamburger to slide in;
   backdrop overlays the main content; closing the nav restores scroll.
   ============================================================================ */

/* mobile top bar — hidden on desktop, replaced by topnav hamburger on small screens */
.mobile-top{display:none}  /* legacy, replaced by .topnav */

/* off-canvas backdrop — only visible when nav is open AND on mobile */
.nav-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.32);
  z-index:40;opacity:0;transition:opacity .2s ease}

/* sidebar close button (mobile only) */
.side-close{display:none;position:absolute;top:10px;right:10px;background:var(--side-hover);
  border:1px solid rgba(255,255,255,.1);border-radius:6px;width:30px;height:30px;
  cursor:pointer;font-size:14px;line-height:1;color:rgba(255,255,255,.6);padding:0}

@media(max-width:900px){
  /* topnav: show hamburger, hide brand in sidebar */
  .topnav-left .ham{display:flex}
  .topnav-search span{display:none}
  .topnav-search kbd{display:none}
  .topnav-search{width:auto;min-width:36px;padding:8px}

  /* collapse the responsive card grids to a single column on phone */
  .main{grid-template-columns:1fr;gap:12px}
  .feed{grid-template-columns:1fr}

  .side-close{display:flex;align-items:center;justify-content:center}

  /* app stops being a flex row — sidebar floats over content */
  .app{display:block;min-height:auto}

  /* sidebar becomes off-canvas */
  .side{position:fixed;top:0;left:0;height:100vh;width:260px;
    transform:translateX(-100%);transition:transform .25s ease;z-index:50;
    box-shadow:0 4px 24px rgba(0,0,0,.25);overflow-y:auto;
    padding-top:44px /* room for the close button */}
  body.nav-open .side{transform:translateX(0)}
  body.nav-open{overflow:hidden}
  body.nav-open .nav-backdrop{display:block;opacity:1}

  /* sidebar links: more generous tap targets on touch */
  .side nav a{padding:10px 12px;font-size:14px}

  /* main content: tighter padding, no horizontal overflow */
  .main{padding:14px 14px;max-width:100%;overflow-x:hidden}

  /* topbar stacks vertically so the title doesn't get squeezed */
  .topbar{flex-direction:column;align-items:flex-start;gap:8px}

  /* tables with lots of columns scroll horizontally instead of breaking out */
  table.contacts,.doclist,table.kv{display:block;overflow-x:auto;max-width:100%}

  /* command deck KPIs drop to 2 columns at this point (already 3 at 1100) */
  .kpis{grid-template-columns:1fr 1fr;gap:10px}
  .kpi-num{font-size:28px}
  .kpi.big .kpi-num{font-size:34px}
  .deck-hello{font-size:24px}

  /* deck columns and world-rail already stack via existing breakpoints */

  /* settings forms: model picker dropdown can take more width on phone */
  .modelrow{flex-direction:column;align-items:flex-start;gap:6px}
  .modelrow select{max-width:100%;width:100%}

  /* ideas page: filter bar wraps cleanly */
  .ideafilter-row{gap:8px}

  /* chat bubbles can be a bit wider on phone */
  .chatmsg{max-width:90%}

  /* bulk-action bar can scroll if it's packed */
  .bulkbar{flex-wrap:wrap}

  /* ---- World model mobile pass ---- */
  /* tab strip becomes a horizontal swipe instead of wrapping into a tall block */
  .tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;
    scrollbar-width:none;padding-bottom:4px}
  .tabs::-webkit-scrollbar{display:none}
  .tabs .tab{white-space:nowrap;flex:0 0 auto}
  /* filter/search rows: inputs go full width, buttons sit on their own line */
  .worldgrid form input[type=text],.worldgrid form input[type=number],
  .worldgrid form select{width:100%;min-width:0}
  /* generous touch targets for the inline role/stage selects + small buttons */
  .worldgrid .catsel,.worldgrid select{min-height:38px;font-size:15px}
  .worldgrid .btn.small,.worldgrid .btn.tiny{min-height:36px;padding:8px 12px}
  /* momentum scroll for any table that stays tabular */
  table.contacts{-webkit-overflow-scrolling:touch}

  /* People = the Rolodex you browse on the phone: reflow rows into cards */
  table.contacts.wm-cards{display:block;overflow:visible}
  table.contacts.wm-cards tr:first-child{display:none}           /* hide header row */
  table.contacts.wm-cards tr{display:block;border:1px solid var(--line);
    border-radius:10px;padding:10px 12px;margin:0 0 10px;background:#fff}
  table.contacts.wm-cards td{display:flex;justify-content:space-between;gap:12px;
    align-items:baseline;padding:4px 0;border:0;font-size:14px;text-align:right}
  table.contacts.wm-cards td::before{content:attr(data-label);color:var(--muted);
    font-size:12px;text-align:left;flex:0 0 40%;white-space:nowrap}
  table.contacts.wm-cards td[data-label=""]::before{content:""}
  table.contacts.wm-cards td[data-label=""]{justify-content:flex-start;gap:16px;
    padding-top:8px;border-top:1px solid var(--line);margin-top:4px}
  table.contacts.wm-cards td .muted.small{text-align:right}
  table.contacts.wm-cards td select{min-height:34px}
}

/* extra-narrow phones — tighten further */
@media(max-width:520px){
  .kpis{grid-template-columns:1fr}
  h1{font-size:20px}
  .main{padding:12px 10px}
  .card{padding:12px 14px}
  .deck-hello{font-size:22px}
  .mobile-top{padding:8px 12px}
  .mobile-top .mt-brand{font-size:14px}
}

/* ============================================================================
   MOBILE POLISH v2 — fixes for the systemic issues spotted across pages.
   These extend (not replace) the layout rules above. Order matters: keep this
   block AFTER the layout rules so it wins on cascade for phone-specific tweaks.
   ============================================================================ */

/* --- HARD VIEWPORT CLAMP -------------------------------------------------
   Without this, ONE wide child (a long URL, a wide table, a long filename)
   bloats the entire layout. `.main { overflow-x: hidden }` only CLIPS the
   visual; child elements still compute width against the unclipped parent.
   So nested grids see "1400px available" and render multiple columns; tables
   stay wider than the screen; textareas overflow their cards.
   The fix: clamp every level to the viewport width AND force min-width:0 on
   every direct child of .main so flex/grid children can shrink below their
   intrinsic content width. */
@media(max-width:900px){
  html,body{max-width:100vw;overflow-x:hidden}
  .app{max-width:100vw;width:100%}
  .main{max-width:100vw;width:100%;overflow-x:hidden}
  /* every direct child of .main can shrink to fit, and any unbreakable text
     inside (URLs, filenames, hashes) wraps at any char rather than blowing
     out the row. */
  .main > *{max-width:100%;min-width:0}
  .main > * *{min-width:0}
  /* Long URLs and filenames: break anywhere to stay inside the card. */
  .card a,.doclist a,.doclist td,.kv td,.dname{overflow-wrap:anywhere;
    word-break:break-word}
  /* textareas and code blocks that hold pasted content (URLs, long lists)
     must not exceed their container — fixes blocklist textarea overflow. */
  .card textarea,.card input{max-width:100%}
  /* every table inside .main scrolls within its own container instead of
     pushing the page wider. */
  .main table{max-width:100%;display:block;overflow-x:auto;
    -webkit-overflow-scrolling:touch}
  /* nested grids that used minmax(240px-380px,1fr) get forced single-column
     because their parent card on phone is often <360px wide. auto-fit math
     only works when the container actually reflects viewport width. */
  .brain-row,.playbook-grid,.teach-card .cands,.deck-cols,.deck-row2,
  .stats{grid-template-columns:1fr}
  /* kpis and scorecards keep 2 columns on phone (they fit easily) — overridden
     to 1 column at <520px via existing rules below */
  .kpis{grid-template-columns:repeat(2,1fr)}
  .scorecards{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:900px){

  /* --- TAP TARGETS ---------------------------------------------------------
     iOS HIG / Material both want >=44px tap targets. .btn was ~32px tall on
     touch and frustrating to hit. Bump padding so every button is a proper
     touch target without changing desktop appearance. */
  .btn{padding:10px 14px;min-height:42px;font-size:14px}
  .btn.tiny{padding:7px 11px;min-height:34px;font-size:12px}
  /* selects, file pickers, date inputs feel the same way */
  select,input[type=date],input[type=number]{min-height:42px;padding:9px 11px}

  /* --- PREVENT iOS INPUT-FOCUS ZOOM ----------------------------------------
     iOS Safari auto-zooms when a form control's font-size < 16px. Everywhere
     we accept user typing on phone, force 16px. The :focus rule keeps it from
     looking oversized at rest by easing back to 14px when not focused — but
     only if the page isn't typed into yet. Simpler/safer: just 16px. */
  input[type=text],input[type=password],input[type=email],input[type=url],
  input[type=search],input[type=tel],input[type=number],input[type=date],
  textarea,select{font-size:16px}
  /* the filter/search box uses .filterbox class; keep it consistent */
  .filterbox{font-size:16px;padding:11px 13px}

  /* --- BUTTON ROWS THAT WERE FLEX BUT NOT WRAPPING ------------------------
     Many topbars use inline `style="display:flex;gap:8px"` for action button
     rows (world.html, review.html, etc.). They have NO flex-wrap, so on a
     phone they overflow horizontally. Catch them by attribute selector. */
  .topbar > div[style*="display:flex"]{flex-wrap:wrap;gap:8px !important;width:100%}
  .topbar > div[style*="display:flex"] > .btn,
  .topbar > div[style*="display:flex"] > form,
  .topbar > div[style*="display:flex"] > a.btn{flex:0 1 auto}
  /* the runbtns variant used on review.html */
  .runbtns{flex-wrap:wrap;width:100%}
  .runbtns .btn{flex:1 1 140px}

  /* topbar already stacks vertically (line 466), but tighten the title margin */
  .topbar h1{font-size:22px;line-height:1.25}
  .topbar .muted{font-size:13px}

  /* --- WORLDRAIL: KILL THE CRAMPED 2-COL GRID -----------------------------
     The world page sidebar uses `repeat(auto-fit, minmax(140px, 1fr))` which
     packs into 2-3 cramped columns at narrow widths. On phone, one column
     reads cleanly and matches every other stat panel on the site. */
  .worldrail{grid-template-columns:1fr;gap:10px}
  .worldrail .card{padding:14px 16px}

  /* --- STATS / SCORECARDS GRIDS -------------------------------------------
     .stats and .scorecards already auto-fit, but 140-150px min hits at exactly
     the wrong width on a 360px phone (2 cols with squeezed labels). Force a
     friendlier breakpoint. */
  .stats{grid-template-columns:repeat(auto-fit,minmax(135px,1fr));gap:10px}
  .scorecards{grid-template-columns:1fr 1fr;gap:10px}
  .scorecard{padding:12px 14px}
  .scorecard.big{grid-column:1/-1}     /* big card spans the row, not 2 of 2 */
  .scorecard .num{font-size:24px}

  /* --- TABLES: ALREADY OVERFLOW-X:AUTO, BUT FIX THE PAINFUL ONES ----------
     The kv (key/value) table cramps the first column at 160px on a 360px
     phone. Stack it: label on top, value below — much more readable. */
  table.kv{display:table;overflow-x:visible}
  table.kv td{display:block;padding:6px 4px;border-bottom:none}
  table.kv tr{display:block;padding:6px 0;border-bottom:1px solid var(--line)}
  table.kv td:first-child{font-size:12px;text-transform:uppercase;
    letter-spacing:.04em;width:auto;padding-bottom:2px}
  /* .doclist, table.contacts stay as horizontal-scroll tables (existing rule) */

  /* --- CARDHEAD CHIPS + LONG SUBJECTS -------------------------------------
     .cardhead has flex-wrap but the conf chip sits on margin-left:auto which
     creates an awkward stranded element when the row wraps. Realign on phone. */
  .cardhead{gap:6px}
  .cardhead .conf{margin-left:0;order:99}
  .cardhead .who{font-size:14px;flex:1 1 auto;min-width:0;
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .cardhead .subj{font-size:13px;flex:1 1 100%;min-width:0;
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

  /* --- DRAFT PREVIEW PRE BLOCKS -------------------------------------------
     pre.draft has white-space:pre-wrap (good) but the font-size + padding
     gets cramped on a 360px screen. Slight bump. */
  pre.draft{font-size:13.5px;padding:10px 12px;line-height:1.5}

  /* --- DRAFT ACTION + RECLASS ROWS WRAP -----------------------------------
     .reclass and .draftacts overflow on phone — pure flex with no wrap. */
  .reclass,.draftacts,.tonebar,.leadfoot,.candacts,.rowbtns,.dopts{flex-wrap:wrap}
  .reclass .catsel,.tonebar .catsel{flex:1 1 140px;min-width:0}

  /* --- FORM CONTROLS INSIDE CARDS -----------------------------------------
     Many templates use inline `style="width:170px"` / `width:150px` (rules,
     knowledge custom-fields, etc.). These overflow at 320-360px. Force them
     to behave on phone. */
  .card input[style*="width:"],.card select[style*="width:"]{
    max-width:100% !important;width:auto !important}
  /* inputs with min-width set inline (knowledge.html uses min-width:280px) */
  input[style*="min-width:280px"],input[style*="min-width:240px"]{
    min-width:0 !important;width:100% !important}
  input[style*="min-width:220px"],input[style*="min-width:200px"]{
    min-width:0 !important;width:100% !important}
  /* upload row — file input on a phone wants to be full-width */
  .uploadrow input[type=file]{flex:1 1 100%;min-width:0}

  /* --- IDGRID (settings/identity) FORCES 1 COL ON PHONE -------------------
     CSS line 155 already does this at <=640px; widen to <=900px so 7-8" iPads
     in portrait don't break the labels. */
  .idgrid{grid-template-columns:1fr}

  /* --- SIDEBAR ON MOBILE: GROUP HEADERS FOR THE 28-LINK WALL --------------
     The nav has 28+ links with no visual grouping. Section labels show only
     on phone (where the wall-of-links problem actually bites). They render
     as faint "captions" between links, controlled by data-section attrs in
     base.html (added separately). */
  .side nav .navsection{display:block;font-size:10px;font-weight:600;color:rgba(255,255,255,.35);
    text-transform:uppercase;letter-spacing:.06em;
    padding:14px 12px 4px;margin-top:4px}
  .side nav .navsection:first-child{margin-top:0;padding-top:6px}
  /* slightly tighter line-height so 28 links + 5 sections still fit cleanly */
  .side nav a{padding:11px 12px;font-size:14px;line-height:1.2}
  /* swipe close: a "hint" gradient on the right edge so users find the close X */
  .side{padding-top:48px}
  .side-close{top:12px;right:12px;width:34px;height:34px;font-size:16px}

  /* --- BULKBAR ON MOBILE --------------------------------------------------
     Sticky bulk-actions bar overlaps the topbar on phone (both sticky).
     Drop sticky on phone — it's not useful when actions are inline anyway. */
  .bulkbar{position:static;flex-wrap:wrap;padding:10px}
  .bulkactions{margin-left:0;flex-wrap:wrap;width:100%}
  .bulkactions .btn,.bulkactions select{flex:1 1 auto}

  /* --- BANNERS / RAILS ----------------------------------------------------
     The rail-head row used `display:flex;justify-content:space-between` with
     stop buttons; on phone the right-side button can overflow. */
  .rail-head{flex-wrap:wrap;row-gap:6px}

  /* --- MODAL / COMMAND PALETTE --------------------------------------------
     The cmdk-box uses 92vw which is fine; the input is 17px which avoids
     iOS zoom. But the foot-row is dense on phone. */
  .cmdk-foot{display:none}            /* keyboard hints are desktop-only */
  .cmdk-box{padding-top:0;max-height:78vh}

  /* --- CHAT BUBBLES + INPUT BAR -------------------------------------------
     .chatmsg already widens to 90% on phone (existing rule). Make sure the
     input bar doesn't get hidden by the iOS bottom safe area. */
  .chatbar{padding:10px 10px calc(10px + env(safe-area-inset-bottom)) 10px}
  .chatbar input{font-size:16px}

  /* --- DECK CARDS: TIGHTER ON PHONE ---------------------------------------
     Deck cards used 14px padding and 12px gap — cramped after the row stack. */
  .deck-card{padding:11px 13px;margin-bottom:8px}
  .dc-title{font-size:14px}

  /* --- BUTTON GROUP INSIDE FORMS ------------------------------------------
     Some forms put buttons in a row with `display:flex`. Wrap them. */
  form > div[style*="display:flex"]{flex-wrap:wrap;gap:8px}

  /* --- WORLD PAGE TOPBAR: 6 BUTTONS DON'T FIT IN A ROW --------------------
     World page has Extract new / Test run / Re-extract all / Clear & rebuild /
     Review skipped / Review extraction — that's 6 buttons. On phone they
     should be on their own row, smaller, wrapping. */
  .topbar form{margin:0}

  /* --- MAIN PADDING: SAFE AREA --------------------------------------------
     Honor the iOS notch + bottom home indicator. */
  .main{padding-left:max(14px, env(safe-area-inset-left));
        padding-right:max(14px, env(safe-area-inset-right));
        padding-bottom:max(20px, env(safe-area-inset-bottom))}
  .topnav{padding-left:max(10px, env(safe-area-inset-left));
           padding-right:max(10px, env(safe-area-inset-right));
           padding-top:max(0px, env(safe-area-inset-top))}

}  /* end @media(max-width:900px) MOBILE POLISH v2 */

/* extra-narrow phones — additional v2 tweaks */
@media(max-width:380px){
  .scorecards{grid-template-columns:1fr}
  .scorecard.big{grid-column:auto}
  .topbar h1{font-size:20px}
  .deck-hello{font-size:20px}
  .kpi-num{font-size:24px}
  .kpi.big .kpi-num{font-size:28px}
  /* with sub-380px width, even the rail-head can be cramped — reduce gaps */
  .cardhead .when{font-size:11px}
  .reclass .btn,.draftacts .btn,.candacts .btn{flex:1 1 100%}
}

/* ultra-wide monitors — beyond 2400px, center the content so a single line of
   text doesn't sprawl edge-to-edge. The dashboard fills width up to this. */
@media(min-width:2401px){
  .main{max-width:2200px;margin-left:auto;margin-right:auto}
}
