/* ============================================
   MiViral Tools — Design System v5
   ============================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

/* Lucide line icons */
.lucide{display:inline-block;vertical-align:middle;width:1em;height:1em;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;fill:none;flex-shrink:0}
.btn .lucide,.bnav-icon .lucide{width:.95em;height:.95em}
.lucide.icon-sm{width:14px;height:14px}
.lucide.icon-md{width:18px;height:18px}
.lucide.icon-lg{width:24px;height:24px}
.lucide.icon-xl{width:32px;height:32px}
.lucide.icon-2xl{width:48px;height:48px}

/* ═══════════════════════════════════════════════════════════
   FOUC prevention — body hidden until app.js signals ready.
   Fallback: show anyway after 800ms so JS errors don't trap user.
   ═══════════════════════════════════════════════════════════ */
@keyframes mvFallbackShow { to { opacity: 1 } }
body { opacity: 0; transition: opacity .12s ease; animation: mvFallbackShow 0s 800ms forwards }
body.mv-ready, body.mv-app, body > .mv-app { opacity: 1 }

/* ═══════════════════════════════════════════════════════════
   Design tokens (single source of truth — used by style.css,
   _frameCSS injection in app.js, and tool inline styles)
   ═══════════════════════════════════════════════════════════ */
:root{
  /* Surfaces */
  --bg:#fafafa;
  --surface:#fff;
  --surface-2:#f4f4f5;     /* subtle panels, input bg, select bg */
  --surface-3:#ededee;     /* deeper variant */
  --card:#fff;
  --card-solid:#fff;
  --card-hover:#f8f9fb;

  /* Text */
  --text:#111115;
  --text2:#55565c;
  --text-3:#8a8b91;        /* alias for --muted */
  --text-4:#b5b6bb;        /* very faint */
  --muted:#8a8b91;
  --text-inverse:#fff;     /* button/badge text on colored bg */

  /* Borders: --border default, --border2 for hover/focused state */
  --border:#e8e8e9;
  --border2:#dcdcde;

  /* Accents */
  --accent:#1f6feb;
  --accent-dim:rgba(31,111,235,.08);
  --accent-soft:#eef3ff;
  --accent2:#2f8d5a;
  --accent2-dim:rgba(47,141,90,.08);
  --purple:#7c5ce7;
  --purple-dim:rgba(124,92,231,.06);
  --danger:#c23b3b;
  --warning:#b8761a;
  --ok:#2f8d5a;

  /* Typography */
  --f-sans:'Inter',ui-sans-serif,system-ui,-apple-system,sans-serif;
  --f-mono:'JetBrains Mono',ui-monospace,Menlo,monospace;

  /* Shapes + motion */
  --shadow:0 1px 3px rgba(0,0,0,.04);
  --radius:8px;
  --container:1440px;
  --tr:.15s ease;
  --ease:.3s cubic-bezier(0,.7,.3,1);

  /* Spacing */
  --pad-container:28px;    /* desktop side padding */
  --pad-bottom:80px;       /* clears sticky status bar */
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
body{margin:0;font-family:'Inter',ui-sans-serif,system-ui,-apple-system,sans-serif;
  background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;min-height:100vh;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}

body::before{content:'';position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(ellipse 70% 50% at 5% 0%,rgba(31,111,235,.03),transparent),
    radial-gradient(ellipse 60% 40% at 95% 8%,rgba(47,141,90,.02),transparent)}

@keyframes fadeUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes pulse{0%,100%{opacity:.5}50%{opacity:1}}
@keyframes modalIn{from{opacity:0;transform:scale(.97) translateY(6px)}to{opacity:1;transform:none}}
@keyframes toastSlide{from{opacity:0;transform:translateY(10px) scale(.97)}to{opacity:1;transform:none}}
@keyframes spin{to{transform:rotate(360deg)}}

.container{animation:fadeUp .35s .1s var(--ease) both}

::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(130,155,200,.14);border-radius:99px}
::-webkit-scrollbar-thumb:hover{background:rgba(130,155,200,.24)}
a{color:var(--accent);text-decoration:none;transition:color var(--tr)}
a:hover{opacity:.88}
::selection{background:rgba(107,161,247,.28)}

/* ─── Header ─── */
header{position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);backdrop-filter:blur(20px) saturate(1.4);
  border-bottom:1px solid var(--border);transition:background var(--tr)}
.nav{max-width:var(--container);margin:0 auto;display:flex;gap:8px;align-items:center;padding:8px 24px;min-height:50px}
.brand{font-weight:700;font-size:15px;letter-spacing:-.01em;white-space:nowrap;color:var(--text);
  display:flex;align-items:center;gap:7px;cursor:pointer;text-decoration:none;transition:opacity .2s}
.brand:hover{opacity:.85}
.brand img{border-radius:7px}
.spacer{flex:1}
.navlinks{display:flex;gap:1px;flex-wrap:nowrap;align-items:center;min-width:0;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none;
  background:var(--card-hover,#f8f9fb);border-radius:8px;padding:3px;border:1px solid var(--border)}
.navlinks::-webkit-scrollbar{display:none}
.navlinks.collapsed{display:none}
.navlinks .btn.small{border:none;background:transparent;border-radius:6px;padding:6px 12px;font-size:12px;font-weight:500;
  color:var(--muted);transition:all .15s;position:relative;display:inline-flex;align-items:center;gap:5px}
.navlinks .btn.small .lucide{width:13px;height:13px;opacity:.6}
.navlinks .btn.small:hover{color:var(--text);background:var(--surface)}
.navlinks .btn.small:hover .lucide{opacity:1}
.navlinks .btn.small.nav-active{color:var(--accent);background:var(--surface);font-weight:600;box-shadow:0 1px 3px rgba(0,0,0,.06)}
.navlinks .btn.small.nav-active .lucide{opacity:1}
.nav-divider{width:1px;height:20px;background:var(--border);margin:0 4px;flex-shrink:0}
.nav-right{display:flex;align-items:center;gap:3px}
.nav-right .btn.small{border:none;background:transparent;color:var(--muted);padding:6px 8px;border-radius:6px;font-size:14px;transition:all .15s}
.nav-right .btn.small:hover{background:var(--card-hover);color:var(--text)}
.kbd-hint{display:inline-flex;align-items:center;gap:4px;font-size:10px;color:var(--muted);
  background:var(--card-hover);border:1px solid var(--border);border-radius:6px;padding:4px 10px;
  font-weight:500;letter-spacing:.2px;cursor:pointer;transition:all .15s;white-space:nowrap}
.kbd-hint:hover{border-color:var(--accent);color:var(--accent)}
.kbd-hint .kbd-key{font-size:9px;font-weight:600;background:var(--surface);border-radius:4px;padding:1px 5px;
  border:1px solid var(--border);line-height:1.3}
.hamburger{display:none}
#who{font-size:11px;white-space:nowrap;color:rgba(255,255,255,.3);max-width:140px;overflow:hidden;text-overflow:ellipsis}

/* ─── Nav scroll fade ─── */
.navlinks{-webkit-mask-image:linear-gradient(to right,transparent 0,#000 8px,#000 calc(100% - 8px),transparent 100%);mask-image:linear-gradient(to right,transparent 0,#000 8px,#000 calc(100% - 8px),transparent 100%)}

/* ─── Buttons ─── */
.btn{appearance:none;display:inline-flex;align-items:center;justify-content:center;gap:5px;
  border:1px solid var(--border);background:var(--surface);
  padding:7px 14px;border-radius:6px;cursor:pointer;
  color:var(--text);font-size:12.5px;font-weight:500;line-height:1.3;
  transition:all var(--tr);white-space:nowrap;text-decoration:none;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.btn:hover{border-color:var(--border2);background:var(--card-hover);transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn.primary{background:var(--accent);color:#fff;border-color:transparent;box-shadow:0 2px 8px rgba(31,111,235,.2)}
.btn.primary:hover{box-shadow:0 4px 14px rgba(31,111,235,.3)}
.btn.danger{background:var(--danger);color:#fff;border-color:transparent}
.btn.small{padding:5px 10px;font-size:11.5px}
.badge{background:#eef3ff;color:var(--accent);border:1px solid #d0ddf5;border-radius:10px;font-size:11px;padding:2px 8px;font-weight:500}
.badge.green{background:#e4f5ec;color:#147a54;border-color:#b4e2ca}
.badge.red{background:#fce8e8;color:#b91c1c;border-color:#f0baba}
.pill{background:#f4f4f5;border:1px solid var(--border);border-radius:6px;padding:4px 10px;font-size:12px}
.pill:hover{border-color:var(--border2)}
.hcard{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:14px}
.hcard:hover{border-color:var(--border2)}
.hicon{background:#eef3ff;border:1px solid #d0ddf5;border-radius:8px}
.code{background:var(--surface-2,#f4f4f5);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:2px 6px;font-size:12px}
.kbd{background:#eef1f6;color:#475569;border-color:#d0d5dd}
th{background:#f8f9fb}
.toast{background:#fff;color:#1e293b;border-color:#d0d5dd;box-shadow:0 8px 24px rgba(0,0,0,.12)}
.split{border-color:#dce0e8}
.tablewrap{background:#f8f9fb;border-color:#dce0e8}
.toolcard:hover{border-color:#93a8d0;box-shadow:0 4px 16px rgba(0,0,0,.06)}
.progress{background:#e2e5ea}
details{background:#f4f6f9;border-color:#d0d5dd}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none !important}
.btn.ghost{border-color:transparent;background:transparent;padding:5px 8px;box-shadow:none}
.btn.ghost:hover{background:var(--accent-dim)}

/* ─── Layout ─── */
.container{max-width:var(--container);margin:0 auto;padding:22px var(--pad-container) var(--pad-bottom)}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.grid.responsive{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.grid.responsive > *{min-width:0}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}

/* ─── Plugin page hero ─── */
.tool-hero{text-align:center;margin-bottom:20px}
.tool-hero h2{font-size:22px;font-weight:800;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin:0 0 4px;display:inline-flex;align-items:center;gap:8px}
.tool-hero p{color:var(--muted);font-size:12.5px;margin:0}

/* ─── Plugin section card ─── */
.tool-section{margin-bottom:14px;border-radius:var(--radius);border:1.5px solid var(--border);background:var(--card);overflow:hidden;transition:border-color .25s ease}
.tool-section:hover{border-color:rgba(130,155,200,.18)}
.tool-section .hd{padding:12px 16px;border-bottom:1px solid var(--border2);display:flex;align-items:center;gap:8px}
.tool-section .hd .label{margin:0}
.tool-section .bd{padding:14px 16px}

/* ─── Split layout (preview + sidebar) ─── */
.tool-split{display:flex;gap:18px;align-items:flex-start}
.tool-split .tool-preview{flex:1;min-width:0}
.tool-split .tool-sidebar{width:300px;flex-shrink:0;display:flex;flex-direction:column;gap:10px}

/* ─── Cards ─── */
.card{background:var(--card);backdrop-filter:blur(10px) saturate(1.1);
  border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow);position:relative;overflow:hidden;
  transition:border-color .25s ease,background .25s ease}
.card:hover{border-color:var(--border2)}
.card::before{display:none}
.card .hd{padding:14px 18px 6px}
.card .bd{padding:10px 18px 18px}

/* ─── Collapsible cards ─── */
.card.collapsible>.hd{cursor:pointer;user-select:none;display:flex;align-items:flex-start;gap:10px}
.card.collapsible>.hd>.hd-content{flex:1;min-width:0}
.card.collapsible>.hd::after{content:'▾';font-size:14px;color:var(--muted);transition:transform .2s ease;margin-top:3px;flex-shrink:0}
.card.collapsible.collapsed>.hd::after{transform:rotate(-90deg)}
.card.collapsible>.bd{transition:max-height .3s ease,opacity .2s ease,padding .2s ease;overflow:hidden}
.card.collapsible.collapsed>.bd{max-height:0!important;opacity:0;padding-top:0;padding-bottom:0;pointer-events:none}

/* ─── Typography ─── */
.h1{font-size:16px;font-weight:600;margin:0 0 3px;letter-spacing:-.01em;color:var(--text)}
.h2{font-size:16px;font-weight:700;margin:0;color:var(--text)}
.p{margin:2px 0 0;color:var(--muted);font-size:12.5px;line-height:1.5}
.muted{color:var(--muted)}
.label{font-size:10.5px;font-weight:600;color:var(--muted);margin:10px 0 4px;text-transform:uppercase;letter-spacing:.6px}
hr{border:none;border-top:1px solid var(--border);margin:14px 0}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}
.kbd{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:10.5px;
  background:rgba(255,255,255,.05);color:var(--muted);padding:3px 8px;border-radius:6px;border:1px solid var(--border)}

/* ─── Inputs ─── */
.input,select.input,textarea.input,select,textarea{
  width:100%;padding:8px 12px;border-radius:7px;border:1px solid var(--border);
  background:var(--surface);color:var(--text);outline:none;font-size:13px;font-family:inherit;
  transition:all var(--tr)}
.input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}
textarea{min-height:100px;resize:vertical}
.input::placeholder{color:var(--muted);opacity:.6}
.badge.red{background:rgba(244,114,114,.10);color:var(--danger);border-color:rgba(244,114,114,.08)}
.badge.orange{background:rgba(245,191,58,.10);color:var(--warning);border-color:rgba(245,191,58,.08)}

/* ─── Tables ─── */
.table{width:100%;border-collapse:collapse}
.table th,.table td{border-bottom:1px solid var(--border2);padding:9px 12px;text-align:left;font-size:13px}
.table th{color:var(--muted);font-weight:600;font-size:10.5px;text-transform:uppercase;letter-spacing:.5px}
.tablewrap{width:100%;overflow:auto;border:1px solid var(--border);border-radius:12px;background:rgba(0,0,0,.08)}
.tablewrap{background:rgba(255,255,255,.5)}
.tablewrap .table{min-width:760px;border:0}
table{border-collapse:separate;border-spacing:0;width:100%}
th{position:sticky;top:0;background:var(--surface);backdrop-filter:blur(8px);z-index:2}
td,th{padding:9px 12px}
tr:hover td{background:rgba(107,161,247,.03)}

/* ─── Toast ─── */
.toast{position:fixed;right:16px;bottom:16px;background:var(--card-solid);backdrop-filter:blur(16px);
  color:var(--text);padding:10px 16px;border-radius:11px;box-shadow:0 8px 28px rgba(0,0,0,.35);
  max-width:360px;display:none;border:1px solid var(--border);font-size:13px;z-index:99999;
  animation:toastSlide .25s var(--ease)}

/* ─── Code ─── */
.code{white-space:pre-wrap;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12px;
  background:rgba(0,0,0,.22);color:var(--text2);border-radius:10px;padding:12px;border:1px solid var(--border2)}

/* ─── Progress ─── */
.progress{height:5px;border-radius:99px;overflow:hidden;background:rgba(255,255,255,.05)}
.progress>.bar{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:99px;transition:width .5s var(--ease)}

/* ─── Pill ─── */
.pill{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:99px;
  border:1px solid var(--border);background:rgba(255,255,255,.02);font-size:12.5px;cursor:pointer;transition:all var(--tr)}
.pill:hover{border-color:rgba(107,161,247,.2)}

/* ─── Tool Cards ─── */
.toolcard{grid-column:span 3;transition:all .25s ease}
.toolcard:hover{border-color:rgba(107,161,247,.18);transform:translateY(-2px);box-shadow:var(--shadow),0 0 20px rgba(107,161,247,.04)}
.toolcard .bd{display:flex;flex-direction:column;gap:6px}
.tooltitle{display:flex;gap:10px;align-items:center;font-weight:700;font-size:13.5px}
.toolicon{font-size:17px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;
  border-radius:10px;background:linear-gradient(135deg,var(--accent-dim),rgba(61,214,160,.06));
  border:1px solid rgba(107,161,247,.08);flex:0 0 auto;color:var(--accent)}
.toolicon .lucide{width:17px;height:17px}
.tooldesc{font-size:11.5px;color:var(--muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ─── Stat Cards ─── */
.healthcards{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px}
.hcard{border:1px solid var(--border);border-radius:11px;padding:11px 13px;
  background:rgba(255,255,255,.015);position:relative;overflow:hidden;transition:all .25s ease}
.hcard:hover{border-color:rgba(107,161,247,.14);background:rgba(107,161,247,.02)}
.hcard .k{font-size:10px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.hcard .v{font-size:16px;font-weight:800;margin-top:1px;letter-spacing:-.2px;color:var(--text)}
.hcard .mini{font-size:10px;color:var(--muted);margin-top:3px}
.hcard .bar{height:5px;border-radius:99px;overflow:hidden;margin-top:7px;background:rgba(255,255,255,.04)}
.hcard .barin{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2))}
.htop{display:flex;gap:10px;align-items:flex-start}
.hicon{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:9px;
  background:linear-gradient(135deg,var(--accent-dim),var(--accent2-dim));
  border:1px solid rgba(107,161,247,.06);font-size:15px;flex:0 0 auto}

/* ─── Avatar ─── */
.avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;font-weight:800;
  font-size:17px;flex:0 0 auto;text-transform:uppercase;box-shadow:0 2px 8px rgba(107,161,247,.2)}
.avatar.large{width:64px;height:64px;font-size:24px}
.avatar.small{width:28px;height:28px;font-size:11px}

/* ─── Quick Actions ─── */
.quick-actions{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.qa-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:12px;
  border:1px solid var(--border);background:rgba(255,255,255,.02);cursor:pointer;
  transition:all var(--tr);text-decoration:none;color:var(--text);font-size:13px;font-weight:500}
.qa-btn:hover{border-color:rgba(107,161,247,.2);background:rgba(107,161,247,.05);transform:translateY(-1px);color:var(--text)}
.qa-icon{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:15px;flex:0 0 auto}
.qa-icon.blue{background:var(--accent-dim)}
.qa-icon.green{background:var(--accent2-dim)}
.qa-icon.purple{background:var(--purple-dim)}
.qa-icon.orange{background:rgba(245,191,58,.10)}

/* ─── List items ─── */
.list-item{padding:10px 0;border-bottom:1px solid var(--border2);transition:background var(--tr)}
.list-item:hover{background:rgba(107,161,247,.02);margin:0 -8px;padding:10px 8px;border-radius:8px}
.list-item:last-child{border-bottom:none}

/* ─── Inline audio player ─── */
.mini-player{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:9px;
  background:rgba(107,161,247,.06);border:1px solid rgba(107,161,247,.1)}
.mini-player audio{height:28px;flex:1;min-width:0}
.mini-player audio::-webkit-media-controls-panel{background:transparent}

/* ─── Loading skeleton ─── */
.skeleton{background:linear-gradient(90deg,rgba(107,161,247,.04) 25%,rgba(107,161,247,.08) 50%,rgba(107,161,247,.04) 75%);
  background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px;min-height:16px}
.skeleton-card{height:100px;border-radius:var(--radius)}
.skeleton-line{height:14px;margin-bottom:8px;width:80%}
.skeleton-line.short{width:40%}

/* ─── Spinner ─── */
.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.25);
  border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}

/* ─── Stack bars ─── */
.stack{display:flex;height:5px;border-radius:99px;overflow:hidden;margin-top:7px;background:rgba(255,255,255,.04)}
.stackbar{height:100%;background:var(--accent)}.stackbar.b2{background:var(--accent2)}.stackbar.b3{background:var(--danger)}

/* ─── Admin ─── */
.healthgrid{display:grid;grid-template-columns:1.3fr .7fr;gap:14px;align-items:start}
.hcharts{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.hchart{border:1px solid var(--border);border-radius:12px;padding:12px;background:rgba(0,0,0,.12)}
.hchart .label{font-size:11px;margin-top:0}
.hchart canvas{width:100%;display:block;border-radius:8px}
#healthBox{display:none}
.jobbar .input{min-width:220px}
.jqgrid{display:grid;grid-template-columns:1.3fr .7fr;gap:14px;align-items:start}
.jobcards{display:none;gap:10px}
.jobcard{border:1px solid var(--border);border-radius:12px;padding:12px;background:rgba(0,0,0,.10)}
.bulkbar{display:grid;grid-template-columns:1fr 1fr 1fr 1.2fr;gap:12px;padding:14px;border:1px dashed var(--border);border-radius:12px;background:rgba(0,0,0,.06)}
.bulkbar .bulkitem{min-width:0}
.jobbar .row{align-items:flex-end}.jobbar .row > div{min-width:180px}

/* ─── Submagic ─── */
.statgrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:10px 0 8px}
.statcard{border:1px solid var(--border);background:var(--card);border-radius:12px;padding:12px}
.statcard .k{color:var(--muted);font-size:12px}.statcard .v{font-weight:800;margin-top:4px}
.rawbox{border:1px solid var(--border);border-radius:12px;padding:10px;background:rgba(0,0,0,.12)}
.rawbox summary{cursor:pointer;color:var(--muted)}.rawbox pre{max-height:240px;overflow:auto;margin:10px 0 0}

/* ─── Modals ─── */
.modal{position:fixed;inset:0;z-index:9998;display:flex;align-items:center;justify-content:center}
.modalback{position:absolute;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(4px)}
.modalcard{position:relative;width:min(1080px,94vw);max-height:86vh;overflow:hidden;
  background:var(--card-solid);border:1px solid var(--border);border-radius:16px;
  box-shadow:0 20px 60px rgba(0,0,0,.45);animation:modalIn .2s var(--ease)}
.modalhd{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:18px 18px 0}
.modalbd{padding:18px;overflow:auto;max-height:calc(86vh - 64px)}
#toolSwitcher{position:fixed;inset:0;display:none;align-items:flex-start;justify-content:center;
  padding-top:min(14vh,120px);background:rgba(0,0,0,.5);backdrop-filter:blur(12px);z-index:9999}
#toolSwitcher .modal{position:relative;width:min(520px,92vw);max-height:60vh;overflow:hidden;display:flex;flex-direction:column;
  background:var(--card-solid);border:1px solid var(--border);border-radius:18px;padding:0;
  box-shadow:0 24px 64px rgba(0,0,0,.5),0 0 0 1px rgba(107,161,247,.06);animation:modalIn .2s var(--ease)}
#toolSwitcher .switcher-head{padding:20px 22px 0;display:flex;align-items:center;justify-content:space-between}
#toolSwitcher .switcher-head .h2{font-size:16px;font-weight:700}
#toolSwitcher .switcher-head .k{font-size:11px;color:var(--muted);background:rgba(130,155,200,.1);
  border:1px solid var(--border);border-radius:6px;padding:3px 8px;font-weight:500;font-family:'Inter',sans-serif}
#toolSwitcher input{width:calc(100% - 44px);margin:14px 22px 10px;border-radius:12px;font-size:14px;padding:11px 16px;
  border:1.5px solid var(--border);background:var(--bg);color:var(--text);outline:none;transition:all var(--tr)}
#toolSwitcher input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}
#toolSwitcher .switcher-list{padding:4px 14px 16px;overflow-y:auto;flex:1;max-height:calc(60vh - 120px)}
#toolSwitcher .item{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;
  border:1.5px solid transparent;border-radius:12px;margin-bottom:4px;text-decoration:none;
  color:var(--text);transition:all var(--tr);gap:10px}
#toolSwitcher .item:hover,.item.ts-focus{border-color:var(--accent);background:var(--accent-dim)}
#toolSwitcher .item .tool-icon{font-size:18px;width:34px;height:34px;text-align:center;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;border-radius:8px;
  background:linear-gradient(135deg,var(--accent-dim),rgba(61,214,160,.06));color:var(--accent)}
#toolSwitcher .item .tool-icon .lucide{width:16px;height:16px}
#toolSwitcher .item .tool-name{font-weight:600;font-size:14px}
#toolSwitcher .item .tool-route{font-size:11px;color:var(--muted)}
#toolSwitcher .item .k{font-size:10px;color:var(--muted);opacity:.5}
#toolSwitcher{background:rgba(0,0,0,.28)}
#toolSwitcher .modal{background:#fff;border-color:#dce0e8;box-shadow:0 24px 64px rgba(0,0,0,.16)}
#toolSwitcher input{background:#f8f9fb;border-color:#d0d5dd}
#toolSwitcher input:focus{border-color:#3b7beb;box-shadow:0 0 0 3px rgba(59,123,235,.12)}
#toolSwitcher .item:hover{background:rgba(59,123,235,.06);border-color:rgba(59,123,235,.2)}

#changePwModal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;
  background:rgba(0,0,0,.5);backdrop-filter:blur(12px);z-index:9999}
#changePwModal .modal{position:relative;width:min(440px,92vw);overflow:auto;background:var(--card-solid);
  border:1px solid var(--border);border-radius:18px;padding:0;
  box-shadow:0 24px 64px rgba(0,0,0,.5);animation:modalIn .22s var(--ease)}
#changePwModal .pw-head{padding:24px 28px 4px;display:flex;align-items:center;gap:14px}
#changePwModal .pw-head .pw-icon{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;
  font-size:22px;background:linear-gradient(135deg,var(--accent-dim),var(--purple-dim));flex-shrink:0;
  border:1px solid var(--border)}
#changePwModal .pw-head .h2{font-size:17px;font-weight:700;margin:0}
#changePwModal .pw-head .muted{font-size:12.5px;margin-top:3px}
#changePwModal .pw-body{padding:18px 28px 24px}
#changePwModal .pw-body .label{margin-top:14px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}
#changePwModal .pw-body .label:first-child{margin-top:0}
#changePwModal .pw-body .input{border-radius:11px;padding:11px 16px;font-size:14px;width:100%;
  border:1.5px solid var(--border);transition:all var(--tr)}
#changePwModal .pw-body .input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);outline:none}
#changePwModal .pw-footer{padding:0 28px 24px;display:flex;gap:10px}
#changePwModal .pw-footer .btn{flex:1;justify-content:center;padding:11px;font-size:14px;border-radius:11px}
#changePwModal{background:rgba(0,0,0,.22)}
#changePwModal .modal{background:#fff;border-color:#dce0e8;box-shadow:0 24px 64px rgba(0,0,0,.12)}
#changePwModal .pw-body .input{border-color:#d0d5dd}
#changePwModal .pw-body .input:focus{border-color:#3b7beb;box-shadow:0 0 0 3px rgba(59,123,235,.12)}
#shortcutsModal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.55);backdrop-filter:blur(5px);z-index:9999}

/* ─── Login ─── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.login-card{width:min(400px,100%)}
.login-card .card{overflow:visible;border-radius:16px}
.login-brand{text-align:center;margin-bottom:22px}
.login-brand .logo{font-size:28px;font-weight:900;color:var(--accent);letter-spacing:-.3px}
.login-brand .sub{color:var(--muted);font-size:13px;margin-top:2px}
.login-divider{display:flex;align-items:center;gap:12px;margin:18px 0 14px;color:var(--muted);font-size:11px;font-weight:500;letter-spacing:.3px}
.login-divider::before,.login-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.btn-google{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:10px 16px;
  border-radius:10px;border:1.5px solid rgba(130,155,200,.15);background:rgba(255,255,255,.03);
  color:var(--text);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit}
.btn-google:hover{border-color:rgba(66,133,244,.4);background:rgba(66,133,244,.06);transform:translateY(-1px);
  box-shadow:0 2px 8px rgba(66,133,244,.12)}
.btn-google:active{transform:translateY(0)}
.btn-google:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn-google svg{flex-shrink:0}
.btn-google{background:#fff;border-color:#dadce0;color:#3c4043;box-shadow:0 1px 2px rgba(0,0,0,.05)}
.btn-google:hover{background:#f7f8f8;border-color:#4285f4;box-shadow:0 2px 8px rgba(66,133,244,.15)}

/* ─── Empty State ─── */
.empty-state{text-align:center;padding:32px 20px;color:var(--muted)}
.empty-state .icon{font-size:34px;margin-bottom:8px;opacity:.4}
.empty-state .msg{font-size:14px;font-weight:600;margin-bottom:3px;color:var(--text2)}
.empty-state .sub{font-size:12.5px}

.ann-info{border-left-color:var(--accent)}.ann-warning{border-left-color:var(--warning)}
.ann-success{border-left-color:var(--accent2)}.ann-danger{border-left-color:var(--danger)}

/* ─── Breakpoints ─── */
@media(min-width:1600px){:root{--container:1560px}.nav{padding:10px 36px}.container{padding:26px 40px 60px}
  .card .hd{padding:18px 24px 2px}.card .bd{padding:12px 24px 24px}}
@media(max-width:1199px){:root{--container:1080px}.toolcard{grid-column:span 4}.healthcards{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media(max-width:1023px){:root{--container:960px}.toolcard{grid-column:span 6}.healthcards{grid-template-columns:repeat(3,minmax(0,1fr))}
  .healthgrid,.jqgrid{grid-template-columns:1fr}.hcharts{grid-template-columns:repeat(3,minmax(0,1fr))}
  .grid.responsive > div{grid-column:span 6 !important}.bulkbar{grid-template-columns:1fr 1fr}.split{grid-column:span 12 !important}}
@media(max-width:819px){.grid2{grid-template-columns:1fr}.grid3{grid-template-columns:1fr 1fr}.grid4{grid-template-columns:1fr 1fr}
  .tool-split{flex-direction:column}.tool-split .tool-sidebar{width:100%}
  .nav{gap:5px;padding:6px 12px;min-height:44px}.brand{font-size:14px}.hamburger{display:inline-flex}
  .navlinks{border-radius:10px;padding:2px}
  .container{padding:14px 12px 32px}.h1{font-size:16px}.card .hd{padding:12px 14px 2px}.card .bd{padding:9px 14px 14px}
  .healthcards{grid-template-columns:repeat(3,minmax(0,1fr))}.hcharts{grid-template-columns:1fr}
  .jobbar .input{min-width:0}.jobbar .row > div{min-width:0;flex:1 1 200px}.navlinks .btn.small{padding:5px 9px;font-size:11px}
  .quick-actions{gap:6px}.qa-btn{padding:8px 12px;font-size:12px}
  .grid.responsive > div{grid-column:span 12 !important}
  .split{grid-column:span 12 !important}
  .kbd-hint{display:none}
  select.input{font-size:13px}}

/* Notification bell */
.notif-bell{position:relative}
.notif-badge{position:absolute;top:-4px;right:-4px;background:var(--danger,#ef4444);color:#fff;font-size:9px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1}

/* Notification panel */
.notif-panel{position:fixed;top:56px;right:16px;width:min(380px,92vw);max-height:70vh;background:var(--card);border:1px solid var(--border);border-radius:14px;box-shadow:0 16px 48px rgba(0,0,0,.25);z-index:9999;overflow:hidden;display:flex;flex-direction:column}
.notif-head{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;font-size:14px}
.notif-list{overflow-y:auto;max-height:calc(70vh - 54px)}
.notif-item{padding:12px 16px;border-bottom:1px solid var(--border);transition:background .15s}
.notif-item:hover{background:var(--hover)}
.notif-item.unread{background:rgba(107,161,247,.06)}
.notif-item.unread{background:rgba(59,130,246,.05)}

/* Onboarding overlay */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;z-index:99999;backdrop-filter:blur(4px)}

/* Draft indicator */
.draft-saved{font-size:11px;color:var(--muted);opacity:.7;transition:opacity .3s}
.draft-saved.active{opacity:1;color:var(--accent2)}

/* ─── App Sidebar Layout (injected by loadNav) ─── */
.mv-app{display:grid;grid-template-columns:244px 1fr;grid-template-rows:56px 1fr;height:100vh;height:100dvh;overflow:hidden}
.mv-side{grid-row:1/3;grid-column:1;background:#fff;border-right:1px solid #e8e8e9;display:flex;flex-direction:column;overflow:hidden;color:#111115}
.mv-side .mv-brand{padding:16px 18px;display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text)}
.mv-side .mv-brand img{width:28px;height:28px;border-radius:7px}
.mv-side .mv-brand-nm{font-weight:600;font-size:14.5px;letter-spacing:-.01em;color:#111115}
.mv-side .mv-brand-ws{font-size:11px;color:#8a8b91;margin-top:1px;font-family:ui-monospace,Menlo,monospace}

.mv-side .mv-search{padding:0 14px 10px;flex-shrink:0}
.mv-side .mv-search-box{display:flex;align-items:center;gap:8px;padding:7px 11px;background:#f4f4f5;border:1px solid transparent;border-radius:7px;transition:all .15s}
.mv-side .mv-search-box:focus-within{background:#fff;border-color:#dcdcde;box-shadow:0 0 0 3px rgba(31,111,235,.06)}
.mv-side .mv-search-box i{width:13px;height:13px;color:#8a8b91}
.mv-side .mv-search-box input{background:transparent;border:none;width:100%;font-size:13.5px;color:#111115;outline:none;font-family:inherit}
.mv-side .mv-search-box input::placeholder{color:#8a8b91}
.mv-side .mv-search-box kbd{font-size:10px;padding:1px 6px;background:#fff;border:1px solid #e8e8e9;border-radius:4px;color:#8a8b91}

.mv-side .mv-nav{padding:4px 10px;flex-shrink:0}
.mv-ni{display:flex;align-items:center;gap:11px;padding:8px 10px;border-radius:6px;color:#55565c;cursor:pointer;transition:all .12s;font-size:13px;margin:1px 0;text-decoration:none}
.mv-ni:hover{background:#f4f4f5;color:#111115}
.mv-ni.on{background:#eef3ff;color:#1f6feb;font-weight:500}
.mv-ni i{width:15px;height:15px;flex-shrink:0}
.mv-ni .mv-nm{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mv-ni .mv-fav{color:#b8761a;font-size:11px}

.mv-nav-group{margin-top:12px}
.mv-nav-title{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:#8a8b91;padding:4px 10px;font-weight:500;display:flex;justify-content:space-between}
.mv-nav-title .ct{color:#b5b6bb}

.mv-side-tools{flex:1;min-height:0;overflow-y:auto;padding:4px 10px 10px;scrollbar-width:thin;scrollbar-color:#e8e8e9 transparent}
.mv-side-tools::-webkit-scrollbar{width:6px}
.mv-side-tools::-webkit-scrollbar-thumb{background:#e8e8e9;border-radius:3px}

.mv-side-foot{padding:12px 14px;border-top:1px solid #e8e8e9;display:flex;align-items:center;gap:10px;flex-shrink:0}
.mv-me-av{width:30px;height:30px;border-radius:7px;background:linear-gradient(135deg,#cfd9e8,#a8b8cd);display:grid;place-items:center;font-size:11px;font-weight:600;flex-shrink:0;color:#111115}
.mv-me-nm{font-size:12.5px;font-weight:500;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#111115}
.mv-me-role{font-size:10.5px;color:#8a8b91;margin-top:1px}
.mv-side-foot button{width:26px;height:26px;border-radius:5px;color:#8a8b91;display:grid;place-items:center;background:none;border:none;cursor:pointer}
.mv-side-foot button:hover{background:#f4f4f5;color:#111115}
.mv-side-foot button i{width:13px;height:13px}

.mv-top{grid-row:1;grid-column:2;background:#fff;border-bottom:1px solid #e8e8e9;display:flex;align-items:center;padding:0 24px;gap:14px;min-height:56px}
.mv-crumbs{font-size:13px;color:#8a8b91}
.mv-crumbs b{color:#111115;font-weight:500}
.mv-crumbs .sep{color:#b5b6bb;margin:0 6px}
.mv-top-btn{width:32px;height:32px;border-radius:6px;color:#8a8b91;display:grid;place-items:center;background:none;border:none;cursor:pointer;position:relative}
.mv-top-btn:hover{background:#f4f4f5;color:#111115}
.mv-top-btn i{width:15px;height:15px}
.mv-notif-dot{position:absolute;top:2px;right:2px;min-width:14px;height:14px;padding:0 4px;background:linear-gradient(135deg,#ef4444,#f97316);color:#fff;font-size:9px;font-weight:800;border-radius:7px;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 4px rgba(239,68,68,.4);line-height:1}
.mv-notif-item:hover{background:rgba(107,161,247,.08)!important}

.mv-main{grid-row:2;grid-column:2;overflow-y:auto;padding:0}
.mv-main>.container{padding:20px 24px 48px}

/* ── Mobile hamburger toggle for sidebar ── */
.mv-hamburger{display:none;width:32px;height:32px;border-radius:6px;color:#8a8b91;background:none;border:none;cursor:pointer;place-items:center;margin-right:4px}
.mv-hamburger:hover{background:#f4f4f5;color:#111115}
.mv-hamburger i{width:18px;height:18px}
.mv-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:40}

@media(max-width:960px){
  .mv-app{grid-template-columns:1fr;grid-template-rows:50px 1fr;height:100vh}
  .mv-side{position:fixed;top:0;left:0;bottom:0;width:280px;z-index:50;transform:translateX(-100%);transition:transform .22s ease;display:flex;border-right:1px solid #e8e8e9;box-shadow:0 12px 32px rgba(0,0,0,.18)}
  .mv-side.open{transform:translateX(0)}
  .mv-top{grid-column:1;padding:0 14px}
  .mv-main{grid-column:1}
  .mv-frame{grid-column:1}
  .mv-hamburger{display:grid}
  .mv-app.open .mv-backdrop{display:block}
}

/* ── Tool page redesign inside sidebar layout ── */
/* iframe fills the main area — concrete height so scroll works in all browsers */
.mv-frame{grid-row:2;grid-column:2;width:100%;height:calc(100vh - 56px);height:calc(100dvh - 56px);border:none;background:#fafafa;display:block}
@media(max-width:960px){.mv-frame{grid-column:1;height:calc(100vh - 50px);height:calc(100dvh - 50px)}}

/* Cards & sections — match dashboard .stat/.pnl sizing */
.mv-main .card,
.mv-main .rm-section,
.mv-main .sp-section,
.mv-main .rm-glass{
  background:var(--card-solid);border:1px solid var(--border);border-radius:var(--radius,8px);
  box-shadow:0 1px 3px rgba(0,0,0,.04);overflow:hidden;transition:border-color .15s,box-shadow .15s}
.mv-main .card:hover,
.mv-main .rm-section:hover{border-color:rgba(130,155,200,.2);box-shadow:0 4px 14px rgba(0,0,0,.06)}

.mv-main .h1{font-size:16px;font-weight:600;letter-spacing:-.01em}
.mv-main .card .hd{padding:14px 18px 6px;border-bottom:none}
.mv-main .card .bd{padding:10px 18px 18px}

/* Hero — match dashboard hero sizing */
.mv-main h2{font-size:22px;font-weight:600;letter-spacing:-.02em}
.mv-main h3{font-size:14px;font-weight:600}
.mv-main p{font-size:13px;line-height:1.5}

/* Buttons — match dashboard .btn sizing */
.mv-main .btn{border-radius:6px;font-size:12.5px;font-weight:500;padding:7px 14px;transition:all .15s}
.mv-main .btn:hover{transform:translateY(-1px)}
.mv-main .btn:active{transform:translateY(0)}
.mv-main .btn.primary{background:var(--accent,#1f6feb);color:#fff;border-color:transparent;box-shadow:0 2px 8px rgba(31,111,235,.15)}
.mv-main .btn.primary:hover{box-shadow:0 4px 14px rgba(31,111,235,.25)}
.mv-main .btn.small{padding:5px 10px;font-size:11.5px}

/* Inputs — match dashboard sizing */
.mv-main .input,
.mv-main select.input,
.mv-main textarea.input,
.mv-main select,
.mv-main textarea{border-radius:7px;font-size:13px;padding:8px 12px;transition:all .15s;border:1px solid var(--border);background:var(--card-solid)}
.mv-main .input:focus,
.mv-main select:focus,
.mv-main textarea:focus{border-color:var(--accent,#1f6feb);box-shadow:0 0 0 3px rgba(31,111,235,.06);outline:none}

/* Labels */
.mv-main label,.mv-main .label{font-size:12px;font-weight:500;color:var(--muted)}

/* Stats / health cards */
.mv-main .healthcards{gap:10px}
.mv-main .hcard{border-radius:8px;padding:14px;border:1px solid var(--border)}
.mv-main .hcard .k{font-size:12px}
.mv-main .hcard .v{font-size:22px;font-weight:600}

/* Badges */
.mv-main .badge{border-radius:10px;font-size:11px;padding:2px 8px}

/* Tool cards */
.mv-main .toolcard{border-radius:8px;transition:all .15s}
.mv-main .toolcard:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,.06)}

/* Lists */
.mv-main .list-item{border-radius:6px;padding:8px 10px;transition:background .12s}
.mv-main .list-item:hover{background:rgba(130,155,200,.04)}

/* Progress bars */
.mv-main .progress{height:4px;border-radius:4px;background:rgba(130,155,200,.08)}
.mv-main .progress .bar{border-radius:4px;background:var(--accent,#1f6feb)}

/* Text */
.mv-main .muted{font-size:12.5px}

/* Section headers — match dashboard .sec-hd */
.mv-main .rm-section-header,
.mv-main .sp-section .hd{padding:12px 16px;border-bottom:1px solid var(--border)}
.mv-main .rm-section-num{border-radius:6px;width:24px;height:24px;font-size:11px;background:var(--accent,#1f6feb)}
.mv-main .rm-section-title{font-size:13px;font-weight:600}
.mv-main .rm-section-body{padding:14px 16px}

/* Empty states */
.mv-main .empty-state{padding:24px;text-align:center;color:var(--muted);font-size:12.5px}

/* Tables — match dashboard table sizing */
.mv-main table{font-size:12.5px;width:100%;border-collapse:collapse}
.mv-main th{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);padding:8px 10px;text-align:left;border-bottom:1px solid var(--border)}
.mv-main td{padding:8px 10px;border-top:1px solid var(--border)}
.mv-main tr:hover td{background:rgba(130,155,200,.03)}

/* Grid — match dashboard gap */
.mv-main .grid{gap:12px}
.mv-main .grid.responsive > div{min-height:0}

/* Hide old top nav when sidebar is active */
.mv-app header:not(.mv-top){display:none}
.mv-app~.bottom-nav,.mv-app .bottom-nav{display:none!important}

/* Analytics Hub light overrides */
.mv-main .ah-controls{background:#fff;border-color:#e8e8e9}
.mv-main .ah-select{background:#f4f4f5;border-color:#e8e8e9;color:#111115}
.mv-main .ah-dates{background:#f4f4f5}
.mv-main .ah-dates button{color:#8a8b91}
.mv-main .ah-dates button:hover{color:#111115}
.mv-main .ah-dates button.active{background:#1f6feb;color:#fff}
.mv-main .ah-stat{background:#fff;border-color:#e8e8e9}
.mv-main .ah-chart-card{background:#fff;border-color:#e8e8e9}
.mv-main .ah-table-wrap{background:#fff;border-color:#e8e8e9}
.mv-main .ah-table th{background:#f4f4f5;color:#8a8b91}
.mv-main .ah-table td{color:#55565c}
.mv-main .ah-tab{color:#8a8b91}
.mv-main .ah-tab:hover{color:#111115}
.mv-main .ah-tab.active{color:#1f6feb}
.mv-main .ah-rt-card{background:#fff;border-color:#e8e8e9}
.mv-main .ah-set-field input,.mv-main .ah-set-field select{background:#f4f4f5;border-color:#e8e8e9;color:#111115}
.mv-main .ah-custom-date input{background:#f4f4f5;border-color:#e8e8e9;color:#111115}

/* ─── Bottom Navigation (mobile) ─── */
.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:100;
  background:rgba(255,255,255,.92);border-top:1px solid var(--border);
  padding:4px 6px calc(4px + env(safe-area-inset-bottom));
  backdrop-filter:blur(20px)}
.bottom-nav-inner{display:flex;justify-content:space-around;align-items:center;max-width:480px;margin:0 auto}
.bnav-item{display:flex;flex-direction:column;align-items:center;gap:2px;
  text-decoration:none;color:var(--muted);font-size:9px;font-weight:600;
  padding:5px 10px;border-radius:8px;transition:all .15s;min-width:50px}
.bnav-item:hover{color:var(--text)}
.bnav-item.active{color:var(--accent);background:var(--accent-dim)}
.bnav-item .bnav-icon{font-size:18px;line-height:1}

/* ─── Mobile pull-down refresh indicator ─── */
.pull-indicator{display:none;text-align:center;padding:8px;font-size:11px;color:var(--muted)}

@media(max-width:719px){
  /* Show bottom nav on mobile */
  .bottom-nav{display:block}
  body{padding-bottom:calc(60px + env(safe-area-inset-bottom))}
  
  /* Better touch targets */
  .btn{min-height:40px;padding:8px 14px;font-size:12.5px}
  .btn.small{min-height:34px;padding:6px 10px;font-size:11.5px}
  .btn.primary{padding:10px 18px;font-size:13px}
  .input,select.input,textarea.input,select,textarea{min-height:42px;padding:10px 14px;font-size:14px}
  .label{font-size:11px;margin:12px 0 5px}
  
  /* Nav improvements */
  .nav{flex-wrap:wrap;gap:4px;padding:6px 8px;min-height:44px}
  .nav .spacer{display:none}
  .brand{width:auto;flex:1;font-size:13px}
  .hamburger{display:inline-flex}
  #navlinks{width:100%}
  .navlinks{gap:1px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:2px;flex-wrap:nowrap;border-radius:10px}
  .navlinks .btn.small{padding:5px 10px;font-size:11px;flex-shrink:0;border-radius:8px}
  #who{display:none}
  .nav-right{padding:1px;border-radius:8px}
  .nav-right .btn.small{padding:5px 7px}
  .nav-right .btn.small{min-height:34px;min-width:34px}
  
  /* Container */
  .container{padding:10px 10px 26px}
  
  /* Grid — everything full width */
  .grid,.grid.responsive{gap:8px}
  .grid2,.grid3,.grid4{grid-template-columns:1fr}
  .tool-split{flex-direction:column}.tool-split .tool-sidebar{width:100%}
  .toolcard{grid-column:span 12}
  .grid.responsive > *{grid-column:span 12 !important}
  
  /* Cards */
  .card .hd{padding:12px 14px 2px}
  .card .bd{padding:10px 14px 14px}
  .card{border-radius:12px}
  
  /* Stats */
  .healthcards{grid-template-columns:repeat(2,minmax(0,1fr));gap:7px}
  .statgrid{grid-template-columns:1fr 1fr}
  
  /* Tables */
  .tablewrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .bulkbar{grid-template-columns:1fr}
  .jobcards{display:grid;grid-template-columns:1fr}
  #jobsTableWrap{display:none}
  .toolcard:hover{transform:none}
  
  /* Quick actions */
  .quick-actions{flex-wrap:wrap;gap:6px}
  .qa-btn{flex:1 1 calc(50% - 4px);min-width:130px;justify-content:center;padding:10px 14px}
  .row{flex-wrap:wrap;gap:6px}
  
  /* Text */
  .h1{font-size:16px}
  .p{font-size:12px}
  details{font-size:13px}
  details summary{font-size:12px}
  .badge{font-size:10px;padding:2px 6px}
  .list-item{padding:8px 0}
  
  /* Media */
  textarea.input{min-height:100px}
  audio{width:100%}
  video{width:100%;border-radius:8px}
  
  /* Modals */
  .notif-panel{top:auto;bottom:0;right:0;left:0;width:100%;max-height:60vh;border-radius:18px 18px 0 0;border-bottom:none}
  .modal-overlay .modal{max-width:94vw !important;margin:10px}
  #toolSwitcher .modal{width:96vw}
  #changePwModal .modal{width:96vw}
  
  /* Kbd hint hidden */
  .kbd-hint{display:none}
  select.input{font-size:14px}
  
  /* Submagic stat grid */
  .statgrid{grid-template-columns:1fr}
}
@media(max-width:479px){
  .healthcards{grid-template-columns:1fr}
  .navlinks{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:3px}
  .hcard .v{font-size:16px}
  .quick-actions{flex-direction:column}
  .qa-btn{width:100%;min-width:0}
  .card .hd{padding:10px 12px 2px}
  .card .bd{padding:8px 12px 12px}
  .container{padding:8px 6px 20px}
  .btn{padding:8px 12px;font-size:12px}
  .input{font-size:14px;padding:10px 12px}
  .label{font-size:10.5px}
  .statgrid{grid-template-columns:1fr}
}
