/* ============================================================================
   SEISER · HUB — styles.css  (standalone, sin dependencias)
   Tokens del Design System SEISER incrustados + componentes del HUB.
   Dark-first · acento ámbar Seiser · tipografía Inter + JetBrains Mono.
   ============================================================================ */

/* Fuentes (CDN para preview; para offline, autoaloja los woff2). */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap');

/* ─────────────────────────── TOKENS ─────────────────────────── */
:root {
  --bg:#0c0c0d; --bg-2:#131316; --sf:#18181c; --sf-2:#1e1e23; --sf-3:#25252c;
  --b1:#26262d; --b2:#34343d; --b3:#44444f;
  --t1:#f3f1ec; --t2:#a8a8b0; --t3:#6e6e78; --t4:#4a4a52;
  --accent:#d4a85a; --accent-soft:rgba(212,168,90,.14); --accent-strong:#e9bc6e; --accent-ink:#1a1408;
  --ok:#5cd29b; --ok-soft:rgba(92,210,155,.14);
  --warn:#ffb84c; --warn-soft:rgba(255,184,76,.14);
  --err:#ff6b6b; --err-soft:rgba(255,107,107,.14);
  --info:#7c9eff; --info-soft:rgba(124,158,255,.14);
  --mod-organizacion:#7c9eff; --mod-finanzas:#e9bc6e; --mod-proveedores:#5cd29b;
  --ring:0 0 0 3px rgba(212,168,90,.28);

  --font-sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,'SF Mono',monospace;

  --r-sm:8px; --r:12px; --r-lg:16px; --r-xl:22px; --r-full:999px;
  --sidebar-w:240px; --content-max:1280px;
  --shadow-sm:0 1px 2px rgba(0,0,0,.35);
  --shadow:0 8px 24px -8px rgba(0,0,0,.50),0 2px 6px -2px rgba(0,0,0,.40);
  --shadow-lg:0 16px 40px -12px rgba(0,0,0,.55),0 4px 12px -4px rgba(0,0,0,.40);
  --ease-out:cubic-bezier(.2,.7,.3,1);
}
body[data-theme="light"]{
  --bg:#f5f3ee; --bg-2:#ebe8df; --sf:#ffffff; --sf-2:#f5f3ee; --sf-3:#ebe8df;
  --b1:#e2ddd0; --b2:#c9c2b0; --b3:#aa9f86;
  --t1:#14130f; --t2:#4a473e; --t3:#7a766a; --t4:#a39e8e;
  --accent:#a87a2e; --accent-soft:rgba(168,122,46,.10); --accent-strong:#8c6520; --accent-ink:#fff;
  --ok:#2a8a5b; --ok-soft:rgba(42,138,91,.10);
  --warn:#c08020; --warn-soft:rgba(192,128,32,.12);
  --err:#c5384a; --err-soft:rgba(197,56,74,.10);
  --info:#4a6cc4; --info-soft:rgba(74,108,196,.10);
  --ring:0 0 0 3px rgba(168,122,46,.22);
  --shadow:0 8px 24px -10px rgba(20,19,15,.10),0 2px 6px -2px rgba(20,19,15,.06);
  --shadow-lg:0 16px 40px -12px rgba(20,19,15,.14);
}

/* ─────────────────────────── RESET ─────────────────────────── */
*,*::before,*::after{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;background:var(--bg);color:var(--t1);
  font-family:var(--font-sans);font-size:13.5px;line-height:1.5;
  font-feature-settings:'cv11','ss01','tnum';
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
button{font-family:inherit;cursor:pointer}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent-soft)}
.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}
.num{font-variant-numeric:tabular-nums;letter-spacing:-.01em}
[hidden]{display:none!important}

/* scrollbars */
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:var(--b2);border-radius:99px;border:3px solid transparent;background-clip:content-box}
*::-webkit-scrollbar-thumb:hover{background:var(--b3)}

/* ─────────────────────────── LAYOUT ─────────────────────────── */
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}

/* ── Sidebar (rail oscuro, siempre el más oscuro) ── */
.sidebar{
  background:var(--bg-2);border-right:1px solid var(--b1);
  display:flex;flex-direction:column;gap:4px;padding:18px 14px;
  position:sticky;top:0;height:100vh;overflow:hidden auto;
}
.sb-brand{display:flex;align-items:center;gap:11px;padding:6px 8px 14px}
.sb-logo{
  width:34px;height:34px;border-radius:9px;flex:none;display:grid;place-items:center;
  background:linear-gradient(145deg,var(--accent-strong),var(--accent));
  color:var(--accent-ink);font-weight:700;font-size:17px;box-shadow:var(--shadow-sm);
}
.sb-brand .nm{font-weight:600;font-size:14px;letter-spacing:-.01em;line-height:1.1}
.sb-brand .dm{font-family:var(--font-mono);font-size:10.5px;color:var(--t3);margin-top:2px}

.app-switcher{display:flex;flex-direction:column;gap:2px;padding:6px 0;margin:2px 0 6px;border-top:1px solid var(--b1);border-bottom:1px solid var(--b1)}
.app-tab{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:9px;color:var(--t2);font-size:13px;font-weight:500;transition:background .12s var(--ease-out),color .12s}
.app-tab:hover{background:var(--sf);color:var(--t1)}
.app-tab.on{background:var(--sf);color:var(--t1)}
.app-tab .dot{width:8px;height:8px;border-radius:99px;flex:none}
.app-tab .ext{margin-left:auto;color:var(--t4)}

.sb-section{font-size:10.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--t4);padding:12px 10px 5px}
.sb-item{display:flex;align-items:center;gap:11px;padding:8px 10px;border-radius:9px;color:var(--t2);font-size:13px;font-weight:500;transition:background .12s,color .12s;width:100%;border:none;background:none;text-align:left}
.sb-item:hover{background:var(--sf);color:var(--t1)}
.sb-item.on{background:var(--sf-2);color:var(--t1)}
.sb-item .ic{color:var(--t3);flex:none}
.sb-item.on .ic{color:var(--accent)}
.sb-item .badge{margin-left:auto;font-family:var(--font-mono);font-size:10.5px;font-weight:600;padding:1px 7px;border-radius:99px;background:var(--sf-3);color:var(--t2)}
.sb-item .badge.warn{background:var(--warn-soft);color:var(--warn)}
.sb-item .badge.err{background:var(--err-soft);color:var(--err)}

.sb-spacer{flex:1}
.sb-user{display:flex;align-items:center;gap:10px;padding:9px 8px;border-top:1px solid var(--b1);margin-top:6px}
.sb-user .nm{font-size:12.5px;font-weight:600;line-height:1.2}
.sb-user .rl{font-size:11px;color:var(--t3)}
.sb-user .out{margin-left:auto;color:var(--t3);background:none;border:none;padding:6px;border-radius:7px;display:grid;place-items:center}
.sb-user .out:hover{background:var(--sf);color:var(--t1)}

/* avatar */
.avatar{width:30px;height:30px;border-radius:99px;flex:none;display:grid;place-items:center;font-size:11.5px;font-weight:700;color:#15140f}

/* ── Main ── */
.main{min-width:0;display:flex;flex-direction:column}
.topbar{
  position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:14px;
  padding:14px 36px;background:color-mix(in srgb,var(--bg) 86%,transparent);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--b1);
}
.crumbs{display:flex;align-items:center;gap:8px;color:var(--t3);font-size:13px}
.crumbs .cur{color:var(--t1);font-weight:500}
.crumbs .sep{color:var(--t4)}
.topbar-actions{margin-left:auto;display:flex;align-items:center;gap:9px}
.live-dot{display:inline-flex;align-items:center;gap:7px;font-size:11.5px;color:var(--t3);padding:5px 11px;border:1px solid var(--b1);border-radius:99px}
.live-dot i{width:7px;height:7px;border-radius:99px;background:var(--ok);box-shadow:0 0 0 3px var(--ok-soft)}
.live-dot.off i{background:var(--err);box-shadow:0 0 0 3px var(--err-soft)}

.content{padding:26px 36px 64px;max-width:var(--content-max);width:100%;margin:0 auto}
.page-hdr{margin-bottom:22px}
.page-greet{font-size:22px;font-weight:600;letter-spacing:-.02em;margin:0}
.page-sub{color:var(--t3);font-size:13.5px;margin-top:5px}
.page-sub b{color:var(--t2);font-weight:600}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:38px;padding:0 15px;border-radius:var(--r-sm);font-size:13px;font-weight:500;border:1px solid var(--b1);background:var(--sf);color:var(--t1);transition:background .12s,border-color .12s,transform .08s}
.btn:hover{background:var(--sf-2);border-color:var(--b2)}
.btn:active{transform:scale(.98)}
.btn.primary{background:var(--accent);color:var(--accent-ink);border-color:transparent;font-weight:600}
.btn.primary:hover{background:var(--accent-strong)}
.btn.ghost{background:none;border-color:transparent;color:var(--t2)}
.btn.ghost:hover{background:var(--sf-2);color:var(--t1)}
.btn.sm{height:30px;padding:0 11px;font-size:12px}
.btn:focus-visible{outline:none;box-shadow:var(--ring)}
.icon-btn{width:34px;height:34px;border-radius:8px;display:grid;place-items:center;border:1px solid var(--b1);background:var(--sf);color:var(--t2)}
.icon-btn:hover{background:var(--sf-2);color:var(--t1)}

/* ─────────────────────────── SECTIONS ─────────────────────────── */
.section{margin-bottom:30px}
.section-hdr{display:flex;align-items:center;gap:11px;margin:0 0 13px}
.section-hdr h2{font-size:15px;font-weight:600;letter-spacing:-.01em;margin:0;display:flex;align-items:center;gap:9px}
.section-hdr .ic{color:var(--t3)}
.section-hdr .count{font-family:var(--font-mono);font-size:11px;color:var(--t3);background:var(--sf);border:1px solid var(--b1);padding:1px 8px;border-radius:99px}
.section-hdr .more{margin-left:auto;font-size:12.5px;color:var(--t3);display:inline-flex;align-items:center;gap:5px}
.section-hdr .more:hover{color:var(--accent)}

/* cards / grids */
.grid{display:grid;gap:14px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--sf);border:1px solid var(--b1);border-radius:var(--r-xl);padding:18px}
.card.pad-lg{padding:22px}
.card-link{transition:border-color .12s,background .12s,transform .1s;cursor:pointer;display:block}
.card-link:hover{border-color:var(--b2);background:var(--sf-2)}
.card-link:active{transform:translateY(1px)}

/* ── KPI strip ── */
.kpi{background:var(--sf);border:1px solid var(--b1);border-radius:var(--r-lg);padding:16px 17px}
.kpi.accent{background:linear-gradient(180deg,var(--accent-soft),transparent),var(--sf);border-color:color-mix(in srgb,var(--accent) 30%,var(--b1))}
.kpi-hdr{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:11px}
.kpi-lbl{font-size:10.5px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--t3)}
.kpi-icon{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;color:var(--accent);background:var(--accent-soft)}
.kpi-val{font-size:26px;font-weight:600;letter-spacing:-.025em;font-variant-numeric:tabular-nums;line-height:1}
.kpi-trend{display:inline-flex;align-items:center;gap:5px;font-size:12px;margin-top:9px;color:var(--t3)}
.kpi-trend.up{color:var(--ok)} .kpi-trend.dn{color:var(--err)} .kpi-trend.flat{color:var(--t3)}
.kpi-trend .ctx{color:var(--t4)}

/* ── Task / list rows ── */
.list{display:flex;flex-direction:column}
.row{display:flex;align-items:center;gap:13px;padding:12px 6px;border-bottom:1px solid var(--b1)}
.row:last-child{border-bottom:none}
.row.link{margin:0 -6px;padding:12px;border-radius:10px;border-bottom:1px solid var(--b1);transition:background .12s}
.row.link:hover{background:var(--sf-2)}
.prio-bar{width:3px;align-self:stretch;border-radius:99px;flex:none;background:var(--t4)}
.prio-bar.alta{background:var(--err)} .prio-bar.media{background:var(--warn)} .prio-bar.baja{background:var(--t4)}
.row-main{min-width:0;flex:1}
.row-title{font-size:13.5px;font-weight:500;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row-meta{display:flex;align-items:center;gap:8px;margin-top:4px;color:var(--t3);font-size:12px;flex-wrap:wrap}
.row-meta .cdot{width:8px;height:8px;border-radius:99px;flex:none}
.row-right{display:flex;align-items:center;gap:10px;flex:none}
.row-date{font-family:var(--font-mono);font-size:11.5px;color:var(--t3);text-align:right;white-space:nowrap}

/* day group sep */
.day-sep{display:flex;align-items:center;gap:10px;padding:13px 6px 6px;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--t3)}
.day-sep.overdue{color:var(--err)}
.day-sep.today{color:var(--accent)}
.day-sep .line{flex:1;height:1px;background:var(--b1)}

/* ── Badges / pills ── */
.badge2{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:2px 9px;border-radius:99px;border:1px solid var(--b1);color:var(--t2);background:var(--sf-2);white-space:nowrap}
.badge2.ok{color:var(--ok);background:var(--ok-soft);border-color:transparent}
.badge2.warn{color:var(--warn);background:var(--warn-soft);border-color:transparent}
.badge2.err{color:var(--err);background:var(--err-soft);border-color:transparent}
.badge2.info{color:var(--info);background:var(--info-soft);border-color:transparent}
.badge2.accent{color:var(--accent-strong);background:var(--accent-soft);border-color:transparent}
.dotlabel{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--t2);white-space:nowrap;max-width:190px;overflow:hidden;text-overflow:ellipsis}
.dotlabel .cdot{width:9px;height:9px;border-radius:99px;flex:none}

/* ── Semáforo client cards ── */
.client-card{display:flex;flex-direction:column;gap:10px;border-left:3px solid var(--t4)}
.client-card.verde{border-left-color:var(--ok)}
.client-card.naranja{border-left-color:var(--warn)}
.client-card.rojo{border-left-color:var(--err)}
.client-card .cc-top{display:flex;align-items:center;gap:10px;min-width:0}
.client-card .cc-name{font-size:14px;font-weight:600;letter-spacing:-.01em;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.client-card .cc-reason{font-size:12.5px;color:var(--t2);line-height:1.45}
.client-card .cc-stats{display:flex;gap:16px;margin-top:2px;flex-wrap:wrap}
.cc-stat{display:flex;flex-direction:column;gap:1px}
.cc-stat .v{font-size:14px;font-weight:600;font-variant-numeric:tabular-nums}
.cc-stat .l{font-size:10.5px;color:var(--t3);text-transform:uppercase;letter-spacing:.05em}
.sem{width:9px;height:9px;border-radius:99px;flex:none;margin-left:auto}
.sem.verde{background:var(--ok);box-shadow:0 0 0 3px var(--ok-soft)}
.sem.naranja{background:var(--warn);box-shadow:0 0 0 3px var(--warn-soft)}
.sem.rojo{background:var(--err);box-shadow:0 0 0 3px var(--err-soft)}

/* ── Ranking rows (consumers / providers) ── */
.rank{display:flex;align-items:center;gap:13px;padding:11px 6px;border-bottom:1px solid var(--b1)}
.rank:last-child{border-bottom:none}
.rank .pos{font-family:var(--font-mono);font-size:12px;color:var(--t4);width:18px;text-align:center;flex:none}
.rank .bar-wrap{flex:1;min-width:0}
.rank .bar-top{display:flex;align-items:baseline;gap:8px;justify-content:space-between;margin-bottom:6px}
.rank .nm{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rank .amt{font-family:var(--font-mono);font-size:12.5px;font-weight:600;color:var(--t1);white-space:nowrap}
.rank .track{height:6px;border-radius:99px;background:var(--bg-2);overflow:hidden}
.rank .fill{height:100%;border-radius:99px;background:var(--accent);min-width:3px}
.rank .sub{font-size:11.5px;color:var(--t3);margin-top:5px;display:flex;gap:8px;align-items:center;white-space:nowrap;overflow:hidden}
.delta{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:600}
.delta.up{color:var(--err)}  /* en GASTO, subir es malo → rojo */
.delta.dn{color:var(--ok)}
.delta.flat{color:var(--t3)}

/* ── Finanzas expense rows ── */
.tx{display:grid;grid-template-columns:64px 1fr 150px 100px;gap:12px;align-items:center;padding:10px 6px;border-bottom:1px solid var(--b1)}
.tx:last-child{border-bottom:none}
.tx-date{font-family:var(--font-mono);font-size:11px;color:var(--t3)}
.tx-desc{min-width:0}
.tx-desc .t{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tx-desc .r{font-family:var(--font-mono);font-size:10.5px;color:var(--t4);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.tx-cat{justify-self:start}
.cat-pill{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;padding:3px 10px;border-radius:99px;border:1px solid;white-space:nowrap}
.cat-pill .cdot{width:7px;height:7px;border-radius:99px;flex:none}
.tx-amt{font-family:var(--font-mono);font-size:13px;font-weight:600;text-align:right;font-variant-numeric:tabular-nums}
.tx-amt.pos{color:var(--ok)} .tx-amt.neg{color:var(--t1)}

/* ── Activity timeline ── */
.tl{display:flex;flex-direction:column}
.tl-item{display:flex;gap:13px;padding:11px 4px;position:relative}
.tl-item:not(:last-child)::before{content:'';position:absolute;left:12px;top:30px;bottom:-6px;width:1.5px;background:var(--b1)}
.tl-dot{width:25px;height:25px;border-radius:99px;flex:none;display:grid;place-items:center;background:var(--sf-2);border:1px solid var(--b1);color:var(--t3);z-index:1}
.tl-body{min-width:0;flex:1;padding-top:2px}
.tl-text{font-size:13px;color:var(--t1);line-height:1.4}
.tl-text b{font-weight:600}
.tl-meta{font-size:11.5px;color:var(--t3);margin-top:3px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* ── Quick access ── */
.qa-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.qa{display:flex;flex-direction:column;gap:13px;border-radius:var(--r-xl);padding:20px;border:1px solid var(--b1);background:var(--sf);transition:border-color .12s,background .12s,transform .1s}
.qa:hover{background:var(--sf-2);transform:translateY(-2px)}
.qa-top{display:flex;align-items:center;gap:12px}
.qa-mono{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;font-weight:700;font-size:17px;color:#15140f;flex:none}
.qa-name{font-size:15px;font-weight:600}
.qa-dom{font-family:var(--font-mono);font-size:11px;color:var(--t3);margin-top:2px}
.qa-desc{font-size:12.5px;color:var(--t2);line-height:1.5}
.qa-foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:6px}
.qa-count{font-size:12.5px;color:var(--t3)}
.qa-count b{color:var(--t1);font-weight:600;font-variant-numeric:tabular-nums}
.qa-go{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;color:var(--accent)}

/* ── Insights / conclusiones ── */
.insight{display:flex;gap:13px;padding:14px 16px;border-radius:var(--r);border:1px solid var(--b1);border-left-width:3px;background:var(--sf)}
.insight.err{border-left-color:var(--err)}
.insight.warn{border-left-color:var(--warn)}
.insight.info{border-left-color:var(--info)}
.insight.ok{border-left-color:var(--ok)}
.insight .ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;flex:none}
.insight.err .ic{background:var(--err-soft);color:var(--err)}
.insight.warn .ic{background:var(--warn-soft);color:var(--warn)}
.insight.info .ic{background:var(--info-soft);color:var(--info)}
.insight.ok .ic{background:var(--ok-soft);color:var(--ok)}
.insight-body{min-width:0;flex:1}
.insight-title{font-size:13px;font-weight:600;margin-bottom:2px}
.insight-msg{font-size:12.5px;color:var(--t2);line-height:1.5}
.insight-msg b{color:var(--t1);font-weight:600}

/* ── Empty / error states ── */
.empty{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;padding:30px 18px;color:var(--t3)}
.empty .e-ic{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;background:var(--sf-2);border:1px solid var(--b1);color:var(--t3)}
.empty .e-title{font-size:13.5px;font-weight:600;color:var(--t2)}
.empty .e-sub{font-size:12px;max-width:340px;line-height:1.5}
.empty.warn .e-ic{background:var(--warn-soft);color:var(--warn);border-color:transparent}

/* skeleton */
.sk{background:linear-gradient(90deg,var(--sf-2) 25%,var(--sf-3) 37%,var(--sf-2) 63%);background-size:400% 100%;animation:sk 1.3s ease-in-out infinite;border-radius:8px}
@keyframes sk{0%{background-position:100% 0}100%{background-position:-100% 0}}

/* ─────────────────────────── LOGIN ─────────────────────────── */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(120% 80% at 50% -10%,rgba(212,168,90,.07),transparent 60%),var(--bg)}
.login-card{width:100%;max-width:380px;background:var(--sf);border:1px solid var(--b1);border-radius:var(--r-xl);padding:30px 28px;box-shadow:var(--shadow-lg)}
.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:22px}
.login-brand .nm{font-size:16px;font-weight:600}
.login-brand .dm{font-family:var(--font-mono);font-size:11px;color:var(--t3);margin-top:2px}
.login-hd{font-size:19px;font-weight:600;letter-spacing:-.02em;margin:0 0 4px}
.login-sub{font-size:13px;color:var(--t3);margin:0 0 22px}
.field{margin-bottom:14px}
.flbl{display:block;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--t3);margin-bottom:7px}
.input{width:100%;height:42px;padding:0 13px;border-radius:var(--r-sm);border:1px solid var(--b1);background:var(--bg-2);color:var(--t1);font-size:14px;font-family:inherit;transition:border-color .12s,box-shadow .12s}
.input:hover{border-color:var(--b2)}
.input:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}
.login-btn{width:100%;height:44px;margin-top:6px;font-size:14px}
.login-err{font-size:12.5px;color:var(--err);background:var(--err-soft);border-radius:9px;padding:9px 12px;margin-bottom:14px;display:flex;gap:8px;align-items:flex-start}
.login-foot{margin-top:18px;text-align:center;font-size:11.5px;color:var(--t4);font-family:var(--font-mono)}

/* preview banner */
.preview-banner{position:fixed;bottom:14px;left:50%;transform:translateX(-50%);z-index:500;background:var(--accent);color:var(--accent-ink);font-size:12px;font-weight:600;padding:8px 16px;border-radius:99px;box-shadow:var(--shadow-lg);display:flex;gap:8px;align-items:center}

/* diagnostics */
.diag{display:flex;flex-direction:column;gap:1px;font-family:var(--font-mono);font-size:12px}
.diag-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px}
.diag-row:hover{background:var(--sf-2)}
.diag-row .st{width:8px;height:8px;border-radius:99px;flex:none}
.diag-row .st.ok{background:var(--ok)} .diag-row .st.err{background:var(--err)} .diag-row .st.warn{background:var(--warn)}
.diag-row .tb{color:var(--t1);min-width:170px}
.diag-row .ms{color:var(--t3)}

/* ─────────────────────────── RESPONSIVE ─────────────────────────── */
@media (max-width:1100px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-3,.qa-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:0;z-index:200;width:84%;max-width:300px;transform:translateX(-100%);transition:transform .22s var(--ease-out);box-shadow:var(--shadow-lg)}
  .app.nav-open .sidebar{transform:none}
  .scrim{position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(2px);z-index:150;opacity:0;pointer-events:none;transition:opacity .2s}
  .app.nav-open .scrim{opacity:1;pointer-events:auto}
  .menu-btn{display:grid!important}
  .topbar,.content{padding-left:18px;padding-right:18px}
}
.menu-btn{display:none}
@media (max-width:620px){
  .grid-4,.grid-3,.grid-2,.qa-grid{grid-template-columns:1fr}
  .tx{grid-template-columns:54px 1fr 92px}
  .tx-cat{display:none}
  .content{padding-top:18px}
  .page-greet{font-size:19px}
}
