/* DEVORA — Linear-Inspired Design System */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#0f0f11;--s1:#16161a;--s2:#1e1e23;--s3:#27272e;
  --border:#2a2a35;--border2:#35353f;
  --text:#e8e8f0;--t2:#9898a8;--t3:#525260;--t4:#35353f;
  --acc:#5e6ad2;--acc2:#7c84e8;--acc-bg:#5e6ad215;--acc-border:#5e6ad235;
  --grn:#34d399;--grn-bg:#34d39912;
  --ylw:#f59e0b;--ylw-bg:#f59e0b12;
  --red:#f87171;--red-bg:#f8717112;
  --pur:#a78bfa;--pur-bg:#a78bfa12;
  --blu:#60a5fa;--blu-bg:#60a5fa12;
  --font:'Inter',system-ui,sans-serif;
  --mono:'JetBrains Mono',monospace;
  --ease:.18s cubic-bezier(.4,0,.2,1);
  --r:7px;--r-sm:5px;
  --nav-h:52px;
}

[data-theme="light"]{
  --bg:#f5f5f7;--s1:#ffffff;--s2:#f0f0f2;--s3:#e4e4e8;
  --border:#e0e0e6;--border2:#c8c8d0;
  --text:#1a1a2e;--t2:#52526a;--t3:#9898b0;--t4:#d0d0e0;
  --acc:#4b56c8;--acc2:#5e6ad2;--acc-bg:#5e6ad212;--acc-border:#5e6ad230;
  --grn:#16a34a;--grn-bg:#16a34a12;
  --ylw:#ca8a04;--ylw-bg:#ca8a0412;
  --red:#dc2626;--red-bg:#dc262612;
  --pur:#7c3aed;--pur-bg:#7c3aed12;
  --blu:#2563eb;--blu-bg:#2563eb12;
}

html{scroll-behavior:smooth}
body{background:var(--bg);font-family:var(--font);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;line-height:1.5;font-size:14px;transition:background .2s,color .2s}
a{color:var(--acc2);text-decoration:none}
a:hover{text-decoration:underline;text-underline-offset:3px}
::selection{background:var(--acc)40;color:var(--text)}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--s3);border-radius:3px}

/* ── CARDS ────────────────────────────────────────────────────────────── */
.card{background:var(--s1);border:1px solid var(--border);border-radius:var(--r);padding:18px}
.card-sm{background:var(--s1);border:1px solid var(--border);border-radius:var(--r-sm);padding:12px 14px}
.card-xs{background:var(--s2);border:1px solid var(--border);border-radius:var(--r-sm);padding:10px 12px}
.card-flat{background:var(--s2);border-radius:var(--r-sm);padding:10px 12px;border:1px solid var(--border)}
.card-hover{transition:border-color .15s,background .15s,transform .15s,box-shadow .15s;cursor:pointer}
.card-hover:hover{border-color:var(--border2);background:var(--s2);transform:translateY(-1px);box-shadow:0 4px 12px #0003}

/* ── INPUTS ───────────────────────────────────────────────────────────── */
input,textarea{background:var(--s2);border:1px solid var(--border);border-radius:var(--r-sm);outline:none;font-family:var(--font);color:var(--text);width:100%;padding:9px 13px;font-size:14px;transition:border-color var(--ease),box-shadow var(--ease)}
input::placeholder,textarea::placeholder{color:var(--t3)}
input:focus,textarea:focus{border-color:var(--acc);box-shadow:0 0 0 3px var(--acc)18}
textarea{resize:vertical;line-height:1.5}

/* ── BUTTONS ──────────────────────────────────────────────────────────── */
.btn{background:var(--acc);color:#fff;border:1px solid transparent;border-radius:var(--r-sm);padding:9px 18px;font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;width:100%;transition:all var(--ease);box-shadow:0 1px 3px #0004,inset 0 1px 0 #ffffff18}
.btn:hover{background:var(--acc2)}
.btn:active{transform:scale(.98)}
.btn-sm{background:var(--acc);color:#fff;border:none;border-radius:var(--r-sm);padding:7px 14px;font-size:12px;font-weight:600;font-family:var(--font);cursor:pointer;transition:all var(--ease);white-space:nowrap}
.btn-sm:hover{background:var(--acc2)}
.btn-ghost{background:transparent;color:var(--t2);border:1px solid var(--border);border-radius:var(--r-sm);padding:7px 14px;font-size:12px;font-weight:500;font-family:var(--font);cursor:pointer;transition:all var(--ease);white-space:nowrap}
.btn-ghost:hover{border-color:var(--border2);color:var(--text)}
.btn-ghost-sm{background:transparent;color:var(--t3);border:1px solid transparent;border-radius:var(--r-sm);padding:5px 9px;font-size:12px;font-weight:500;font-family:var(--font);cursor:pointer;transition:all var(--ease);white-space:nowrap;display:inline-flex;align-items:center;gap:4px}
.btn-ghost-sm:hover{color:var(--text);background:var(--s2);border-color:var(--border)}
.btn-danger{background:transparent;color:var(--red);border:1px solid var(--red)30;border-radius:var(--r-sm);padding:7px 14px;font-size:12px;font-weight:500;font-family:var(--font);cursor:pointer;transition:all var(--ease)}
.btn-danger:hover{background:var(--red-bg);border-color:var(--red)60}
.lnk{background:none;border:none;color:var(--acc2);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font);padding:0}
.lnk:hover{opacity:.75}

/* ── BADGES ───────────────────────────────────────────────────────────── */
.badge{padding:2px 7px;border-radius:100px;font-size:11px;font-weight:600;border:1px solid transparent;display:inline-block;letter-spacing:.2px}
.b-blue{background:var(--blu-bg);color:var(--blu);border-color:var(--blu)30}
.b-green{background:var(--grn-bg);color:var(--grn);border-color:var(--grn)30}
.b-yellow{background:var(--ylw-bg);color:var(--ylw);border-color:var(--ylw)30}
.b-red{background:var(--red-bg);color:var(--red);border-color:var(--red)30}
.b-purple{background:var(--pur-bg);color:var(--pur);border-color:var(--pur)30}
.b-gray{background:var(--s3);color:var(--t2);border-color:var(--border)}
.b-acc{background:var(--acc-bg);color:var(--acc2);border-color:var(--acc-border)}
.tag{padding:2px 7px;border-radius:4px;font-size:11px;font-weight:500;background:var(--s3);color:var(--t2);border:1px solid var(--border);display:inline-flex;align-items:center;gap:4px}

/* ── BARS ─────────────────────────────────────────────────────────────── */
.bar-t{border-radius:2px;height:4px;background:var(--s3);overflow:hidden}
.bar-f{height:100%;border-radius:2px;transition:width 1.2s cubic-bezier(.4,0,.2,1);animation:barGrow .3s ease}
@keyframes barGrow{from{width:0!important}}

/* ── DIVIDER ──────────────────────────────────────────────────────────── */
.div{height:1px;background:var(--border);margin:12px 0}

/* ── ALERTS ───────────────────────────────────────────────────────────── */
.al{border-radius:var(--r-sm);padding:10px 14px;font-size:12px;line-height:1.6;border:1px solid}
.al-info{background:var(--acc-bg);border-color:var(--acc-border);color:var(--t2)}
.al-success{background:var(--grn-bg);border-color:var(--grn)30;color:var(--grn)}
.al-error{background:var(--red-bg);border-color:var(--red)30;color:var(--red)}
.al-warn{background:var(--ylw-bg);border-color:var(--ylw)30;color:var(--ylw)}

/* ── CHIP ─────────────────────────────────────────────────────────────── */
.chip{display:flex;gap:8px;align-items:flex-start;padding:8px 10px;border-radius:var(--r-sm);font-size:12px;color:var(--t2);background:var(--s2);border:1px solid var(--border);line-height:1.55}
.chip-dot{width:4px;height:4px;border-radius:50%;flex-shrink:0;margin-top:5px}

/* ── SECTION HEADING ──────────────────────────────────────────────────── */
.sh{font-size:11px;font-weight:600;color:var(--t2);text-transform:uppercase;letter-spacing:.7px;display:flex;align-items:center;gap:8px;margin-bottom:14px}
.sh-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}

/* ── DEPTH BADGE ──────────────────────────────────────────────────────── */
.db{padding:3px 8px;border-radius:var(--r-sm);background:var(--s2);border:1px solid var(--border);font-size:11px;font-weight:500;color:var(--t2);display:inline-flex;align-items:center;gap:5px;transition:border-color var(--ease)}
.db:hover{border-color:var(--border2);color:var(--text)}

/* ── FILE CHECK ───────────────────────────────────────────────────────── */
.fc{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:500;padding:2px 0}
.fc.ok{color:var(--grn)}.fc.no{color:var(--t3)}

/* ── TABS ─────────────────────────────────────────────────────────────── */
.tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:20px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.tabs::-webkit-scrollbar{display:none}
.tab{padding:9px 14px;border:none;background:transparent;font-family:var(--font);font-size:13px;font-weight:500;color:var(--t3);cursor:pointer;position:relative;transition:color var(--ease);border-bottom:1.5px solid transparent;margin-bottom:-1px;white-space:nowrap;flex-shrink:0}
.tab:hover{color:var(--t2)}
.tab.on{color:var(--text);font-weight:600;border-bottom-color:var(--acc)}

/* ── GRIDS ────────────────────────────────────────────────────────────── */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.g3{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.ga{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}

/* ── STATS ────────────────────────────────────────────────────────────── */
.sv{font-family:var(--mono);font-size:20px;font-weight:700;line-height:1;margin-bottom:3px}
.sk{font-size:10px;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;font-weight:600}

/* ── RANK ─────────────────────────────────────────────────────────────── */
.rnk{width:20px;height:20px;border-radius:4px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;font-family:var(--mono);flex-shrink:0;background:var(--s2);color:var(--t2)}

/* ── INSIGHT ──────────────────────────────────────────────────────────── */
.ib{padding:14px;border-radius:var(--r-sm);background:var(--s2);border:1px solid var(--border)}
.it{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;margin-bottom:10px}
.ir{display:flex;gap:8px;align-items:flex-start;padding:7px 0;border-bottom:1px solid var(--border);font-size:12px;color:var(--t2);line-height:1.6}
.ir:last-child{border-bottom:none}
.in-n{font-family:var(--mono);font-size:10px;font-weight:700;color:var(--acc2);width:14px;flex-shrink:0;padding-top:2px}

/* ── ROADMAP ──────────────────────────────────────────────────────────── */
.ri{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--border)}
.ri:last-child{border-bottom:none;padding-bottom:0}
.rn{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:11px;font-weight:700;color:var(--acc2);flex-shrink:0;background:var(--s2)}

/* ── PROGRESS ─────────────────────────────────────────────────────────── */
.pr{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.pd{font-size:10px;color:var(--t3);width:60px;flex-shrink:0;font-family:var(--mono)}
.ps{font-family:var(--mono);font-size:11px;font-weight:700;width:24px;text-align:right;flex-shrink:0}

/* ── LANG BAR ─────────────────────────────────────────────────────────── */
.lb{height:5px;border-radius:3px;overflow:hidden;display:flex;border:1px solid var(--border)}

/* ── PENTAGON TOOLTIP ─────────────────────────────────────────────────── */
.penta-tooltip{
  position:fixed;background:var(--s1);border:1px solid var(--border2);
  border-radius:var(--r-sm);padding:10px 14px;pointer-events:none;
  z-index:1000;opacity:0;transition:opacity .15s;max-width:220px;
  box-shadow:0 8px 24px #0008;
}
.penta-tooltip.show{opacity:1}
.penta-tooltip-title{font-size:12px;font-weight:700;margin-bottom:4px}
.penta-tooltip-score{font-family:var(--mono);font-size:18px;font-weight:700;margin-bottom:6px}
.penta-tooltip-desc{font-size:11px;color:var(--t2);line-height:1.55}

/* ── PENTAGON VERTEX ──────────────────────────────────────────────────── */
.penta-vertex{cursor:pointer;transition:r .15s}
.penta-vertex:hover{filter:brightness(1.3)}

/* ── NAVBAR ───────────────────────────────────────────────────────────── */
.nav{display:flex;align-items:center;justify-content:space-between;padding:0 16px;height:var(--nav-h);background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50;gap:10px}
.nav-logo{display:flex;align-items:center;gap:9px;cursor:pointer;text-decoration:none;color:var(--text)}
.nav-logo:hover{text-decoration:none}
.logo-mark{width:26px;height:26px;border-radius:6px;background:var(--s1);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.logo-name{font-size:15px;font-weight:700;letter-spacing:-.3px}

/* ── NAV SEARCH ───────────────────────────────────────────────────────── */
.nav-search{display:flex;align-items:center;gap:7px;background:var(--s1);border:1px solid var(--border);border-radius:var(--r-sm);padding:6px 11px;flex:1;max-width:280px;transition:border-color var(--ease)}
.nav-search:focus-within{border-color:var(--acc)}
.nav-search input{background:transparent;border:none;box-shadow:none;padding:0;font-size:13px;color:var(--text);width:100%}

/* ── THEME TOGGLE ─────────────────────────────────────────────────────── */
.t-tog{position:relative;width:38px;height:21px;border-radius:100px;border:1px solid var(--border);background:var(--s2);cursor:pointer;flex-shrink:0;outline:none}
.t-knob{position:absolute;top:2px;left:2px;width:15px;height:15px;border-radius:50%;background:var(--t3);transition:left .32s cubic-bezier(.68,-.55,.27,1.55),background .2s}
[data-theme="light"] .t-knob{left:19px;background:var(--ylw)}

/* ── WAVE ─────────────────────────────────────────────────────────────── */
#wave-overlay{position:fixed;inset:0;z-index:9999;pointer-events:none;background:transparent;opacity:0;clip-path:circle(0px at 50% 50%)}
#wave-overlay.wave-shrink{opacity:1;animation:waveShrink .52s cubic-bezier(.4,0,.2,1) forwards}
@keyframes waveShrink{from{clip-path:circle(200vmax at var(--wx) var(--wy))} to{clip-path:circle(0px at var(--wx) var(--wy))}}

/* ── SIDEBAR ──────────────────────────────────────────────────────────── */
.dash-layout{display:flex;height:calc(100vh - var(--nav-h));overflow:hidden}
.sidebar{width:220px;flex-shrink:0;border-right:1px solid var(--border);background:var(--bg);overflow-y:auto;display:flex;flex-direction:column;transition:transform .25s cubic-bezier(.4,0,.2,1)}
.sb-header{padding:14px 14px 10px;border-bottom:1px solid var(--border);flex-shrink:0}
.sb-section{padding:6px 0}
.sb-label{padding:6px 14px 3px;font-size:10px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.6px}
.sb-item{display:flex;align-items:center;gap:8px;padding:7px 14px;font-size:12px;color:var(--t2);cursor:pointer;transition:background .15s,color .15s,border-color .15s;border-left:1.5px solid transparent;user-select:none;-webkit-tap-highlight-color:transparent}
.sb-item:hover{background:var(--s2);color:var(--text)}
.sb-item.on{background:var(--acc-bg);color:var(--acc2);border-left-color:var(--acc);font-weight:500}
.sb-item .si-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sb-item .si-score{font-family:var(--mono);font-size:10px;font-weight:700;flex-shrink:0}
.sb-divider{height:1px;background:var(--border);margin:4px 0}
.main-area{flex:1;overflow-y:auto;overflow-x:hidden}
.main-content{padding:18px;max-width:1100px;margin:0 auto}

/* ── MOBILE SIDEBAR OVERLAY ───────────────────────────────────────────── */
.sb-overlay{display:none;position:fixed;inset:0;background:#0007;z-index:45;-webkit-tap-highlight-color:transparent}
.sb-overlay.show{display:block}
.sidebar.mobile-open{transform:translateX(0)!important}

/* ── HAMBURGER ────────────────────────────────────────────────────────── */
.hamburger{
  display:none;background:transparent;border:1px solid var(--border);
  border-radius:var(--r-sm);padding:7px 9px;cursor:pointer;color:var(--t2);
  flex-shrink:0;align-items:center;justify-content:center;
  transition:all var(--ease);
}
.hamburger:hover{color:var(--text);background:var(--s2);border-color:var(--border2)}
.hamburger:active{background:var(--s3)}

/* ── DETAIL PANEL ─────────────────────────────────────────────────────── */
.detail-panel{position:fixed;right:0;top:var(--nav-h);bottom:0;width:440px;background:var(--s1);border-left:1px solid var(--border);overflow-y:auto;z-index:40;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s}
.detail-panel.open{box-shadow:-8px 0 32px #0005}
.detail-panel.open{transform:translateX(0)}
.dp-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--s1);z-index:10}

/* ── MODAL ────────────────────────────────────────────────────────────── */
.modal-bg{position:fixed;inset:0;background:#0009;z-index:100;display:flex;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(4px)}
.modal{background:var(--s1);border:1px solid var(--border);border-radius:var(--r);width:100%;max-width:420px;max-height:90vh;overflow-y:auto;animation:popIn .22s cubic-bezier(.34,1.56,.64,1)}
.modal-hdr{padding:16px 18px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}

/* ── RING ─────────────────────────────────────────────────────────────── */
.ring-wrap{position:relative;flex-shrink:0}

/* ── SKELETON ─────────────────────────────────────────────────────────── */
.skel{background:linear-gradient(90deg,var(--s2) 25%,var(--s3) 50%,var(--s2) 75%);background-size:200%;animation:shim 1.4s infinite;border-radius:4px}
@keyframes shim{0%{background-position:200%}100%{background-position:-200%}}

/* ── SPINNER ──────────────────────────────────────────────────────────── */
.spin{animation:spin .75s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── PAGE LAYOUTS ─────────────────────────────────────────────────────── */
.page-center{min-height:100vh;display:flex;flex-direction:column;align-items:center}
.page-full{max-width:1080px;width:100%;margin:0 auto;padding:20px 16px 80px}
.hero-wrap{max-width:580px;width:100%;padding:48px 16px 28px;text-align:center}
.content-w{width:100%;max-width:680px;padding:0 16px 40px}

/* ── GRADIENT TEXT ────────────────────────────────────────────────────── */
.grad-text{background:linear-gradient(135deg,var(--text) 40%,var(--acc2) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ── ANIMATIONS ───────────────────────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideIn{from{opacity:0;transform:translateX(10px)}to{opacity:1;transform:translateX(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes popIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
.fade-in{animation:fadeUp .35s cubic-bezier(.4,0,.2,1)}
.slide-in{animation:slideIn .25s cubic-bezier(.4,0,.2,1)}
.pop-in{animation:popIn .2s cubic-bezier(.34,1.56,.64,1)}

/* ── FEATURES ─────────────────────────────────────────────────────────── */
.feat{background:var(--s1);border:1px solid var(--border);border-radius:var(--r);padding:16px;transition:border-color var(--ease)}
.feat:hover{border-color:var(--border2)}
.feat-icon{width:34px;height:34px;border-radius:7px;background:var(--s2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;margin-bottom:11px}
.step-n{width:26px;height:26px;border-radius:6px;background:var(--s2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:11px;font-weight:700;color:var(--acc2);flex-shrink:0}

/* ── MISC ─────────────────────────────────────────────────────────────── */
.mono{font-family:var(--mono)}
.sep{height:1px;background:var(--border);margin:24px 0}
.tch{font-size:10px;font-weight:600;padding:2px 7px;border-radius:4px;background:var(--s2);border:1px solid var(--border)}
.pb{font-size:10px;font-weight:600;padding:1px 7px;border-radius:100px;border:1px solid var(--border)}
.code{font-family:var(--mono);background:var(--s2);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-size:11px;color:var(--acc2)}
.nav-user-label{font-size:12px;color:var(--grn);font-weight:500;max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.border-grad{background:linear-gradient(var(--s1),var(--s1)) padding-box,linear-gradient(135deg,var(--acc)60,var(--pur)30,transparent) border-box;border:1px solid transparent;border-radius:var(--r)}

/* ── RESPONSIVE — TABLET ──────────────────────────────────────────────── */
@media(max-width:900px){
  .g4{grid-template-columns:repeat(2,1fr)}
  .g2{grid-template-columns:1fr}
  .detail-panel{width:100%;top:0;left:0;right:0;bottom:0;border:none;z-index:60}
  .dim-strip{grid-template-columns:repeat(2,1fr)!important}
}


/* ── RESPONSIVE — TABLET + MOBILE (≤768px) ────────────────────────────── */
@media(max-width:768px){
  /* Show hamburger */
  .hamburger{display:flex!important}

  /* Sidebar becomes slide-in overlay */
  .sidebar{
    position:fixed;left:0;top:0;bottom:0;z-index:50;
    transform:translateX(-100%);width:260px;height:100vh;
    padding-top:var(--nav-h);border-right:1px solid var(--border);
    box-shadow:4px 0 24px #0006;transition:transform .25s cubic-bezier(.4,0,.2,1);
  }
  .sidebar.mobile-open{transform:translateX(0)}
  .dash-layout{height:auto;min-height:calc(100vh - var(--nav-h))}
  .main-area{width:100%;min-width:0}
  .main-content{padding:14px 14px 80px}

  /* Navbar compress */
  .nav{padding:0 10px;gap:6px}
  .nav-search{flex:1;min-width:0;max-width:none}
  .logo-name{display:none}
  .settings-label{display:none}
  .nav-back-label{display:none}
  .nav-user-label{display:none}

  /* Pages */
  .page-full{padding:12px 12px 80px}
  .hero-wrap{padding:28px 12px 18px}
  .content-w{padding:0 12px 28px}

  /* Grids */
  .g2{grid-template-columns:1fr}
  .g3{grid-template-columns:1fr}
  .g4{grid-template-columns:1fr 1fr}
  .ga{grid-template-columns:1fr 1fr}
  .dim-strip{grid-template-columns:1fr 1fr!important}

  /* Tabs */
  .tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;scrollbar-width:none}
  .tabs::-webkit-scrollbar{display:none}
  .tab{padding:9px 12px;font-size:12px;flex-shrink:0}

  /* Pentagon tooltip stays in viewport */
  .penta-tooltip{max-width:calc(100vw - 24px)!important}

  /* Cards */
  .card{padding:14px}
  .card-sm{padding:10px 12px}
}

/* ── RESPONSIVE — SMALL MOBILE (≤420px) ──────────────────────────────── */
@media(max-width:420px){
  .nav{padding:0 8px;gap:4px}
  .g4{grid-template-columns:1fr 1fr}
  .ga{grid-template-columns:1fr}
  .main-content{padding:10px 10px 80px}
  .card{padding:12px}
}
