:root{
  /* ── light theme ── */
  --bg:#f3f4f6; --bp:#ffffff; --bs:#f4f5f7; --bt:#eaecef;
  --ct:#16181d; --cs:#646b78; --cf:#9aa0ab;
  --red:#D7282B; --red-dark:#b81f22; --cd:#a32d2d; --bd:#fbe9e9;
  --ci:#185fa5; --bi:#e8f1fb; --cg:#0b7a43; --bgr:#e7f4ec; --cw:#92610a; --bw:#fbf1da;
  --br:rgba(0,0,0,.07); --br2:rgba(0,0,0,.14);
  --shadow:0 1px 2px rgba(17,24,39,.04),0 1px 3px rgba(17,24,39,.04);
  --shadow-lg:0 12px 32px rgba(17,24,39,.10);
  --radius:16px;
  color-scheme:light;
}
:root[data-theme="dark"], :root[data-theme="dark"] *{ }
:root[data-theme="dark"]{
  /* ── dark theme (premium near-black) ── */
  --bg:#0b0c0f; --bp:#15171d; --bs:#1c1f27; --bt:#262a34;
  --ct:#f1f2f5; --cs:#9aa1ad; --cf:#6b7280;
  --red:#ff5a5c; --red-dark:#ff7375; --cd:#ff9092; --bd:rgba(255,90,92,.16);
  --ci:#6fb1ff; --bi:rgba(111,177,255,.14); --cg:#3ddc97; --bgr:rgba(61,220,151,.14); --cw:#f7c352; --bw:rgba(247,195,82,.14);
  --br:rgba(255,255,255,.08); --br2:rgba(255,255,255,.17);
  --shadow:0 1px 2px rgba(0,0,0,.5); --shadow-lg:0 16px 40px rgba(0,0,0,.55);
  color-scheme:dark;
}
@media (prefers-color-scheme: dark){
  :root:not([data-theme="light"]){
    --bg:#0b0c0f; --bp:#15171d; --bs:#1c1f27; --bt:#262a34;
    --ct:#f1f2f5; --cs:#9aa1ad; --cf:#6b7280;
    --red:#ff5a5c; --red-dark:#ff7375; --cd:#ff9092; --bd:rgba(255,90,92,.16);
    --ci:#6fb1ff; --bi:rgba(111,177,255,.14); --cg:#3ddc97; --bgr:rgba(61,220,151,.14); --cw:#f7c352; --bw:rgba(247,195,82,.14);
    --br:rgba(255,255,255,.08); --br2:rgba(255,255,255,.17);
    --shadow:0 1px 2px rgba(0,0,0,.5); --shadow-lg:0 16px 40px rgba(0,0,0,.55);
    color-scheme:dark;
  }
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;background:var(--bg);color:var(--ct);font-size:14px;-webkit-font-smoothing:antialiased;font-feature-settings:"cv01","ss01"}
a{color:inherit;text-decoration:none}

/* ── App shell ── */
.app{display:flex;height:100vh;width:100%}
.side{width:228px;flex:none;background:var(--bp);border-right:.5px solid var(--br);display:flex;flex-direction:column}
.brand{display:flex;align-items:center;gap:10px;padding:18px 18px 14px;font-weight:600;font-size:17px}
.brand .logo{width:28px;height:28px;border-radius:7px;background:var(--red);color:#fff;display:grid;place-items:center;font-weight:700;font-size:14px}
.nav{padding:6px 10px;flex:1;overflow:auto}
.nav a{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:9px;color:var(--cs);font-weight:500;margin-bottom:2px}
.nav a i{font-size:20px;width:22px;text-align:center}
.nav a.on{background:var(--bd);color:var(--red)}
.nav a:hover:not(.on){background:var(--bs)}
.nav .sec{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:#9aa0ab;padding:14px 12px 6px}
.side .me{border-top:.5px solid var(--br);padding:12px 14px;display:flex;align-items:center;gap:10px}
.main{flex:1;display:flex;flex-direction:column;overflow:hidden}
.top{height:60px;flex:none;border-bottom:.5px solid var(--br);background:var(--bp);display:flex;align-items:center;gap:14px;padding:0 22px}
.top h1{font-size:18px;font-weight:600;margin:0}
.content{flex:1;overflow:auto;padding:22px}
.grow{flex:1}

/* ── Bits ── */
.av{width:34px;height:34px;border-radius:50%;background:var(--bi);color:var(--ci);display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex:none}
.av.sm{width:28px;height:28px;font-size:11px}
.muted{color:var(--cs)}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:3px 10px;border-radius:999px;background:var(--bt);color:var(--cs)}
.badge{font-size:11.5px;padding:2px 9px;border-radius:8px;display:inline-block;font-weight:500;white-space:nowrap}
.b-ok{background:var(--bgr);color:var(--cg)} .b-mut{background:var(--bt);color:var(--cs)}
.b-sms{background:var(--bi);color:var(--ci)} .b-wa{background:var(--bgr);color:var(--cg)} .b-mail{background:var(--bt);color:var(--cs)}
.b-due{background:var(--bd);color:var(--cd)} .b-warn{background:var(--bw);color:var(--cw)}
.b-admin{background:#ede9fe;color:#6d28d9}

.btn{display:inline-flex;align-items:center;gap:7px;border-radius:9px;padding:9px 15px;font-size:14px;font-weight:600;cursor:pointer;border:.5px solid var(--br2);background:var(--bp);color:var(--ct)}
.btn i{font-size:17px}
.btn.pri{background:var(--red);border-color:var(--red);color:#fff}
.btn.pri:hover{background:var(--red-dark)}
.btn.sm{padding:6px 11px;font-size:13px}
.btn:disabled{opacity:.5;cursor:default}

.card{background:var(--bp);border:.5px solid var(--br);border-radius:13px;box-shadow:var(--shadow)}
.card .hd{padding:15px 18px;border-bottom:.5px solid var(--br);display:flex;align-items:center;gap:10px}
.card .hd h2{font-size:15px;font-weight:600;margin:0}
.card .bd{padding:16px 18px}
.card.pad{padding:18px}

.grid{display:grid;gap:16px}
.kpis{grid-template-columns:repeat(4,1fr)}
.kpi{background:var(--bp);border:.5px solid var(--br);border-radius:13px;padding:16px 18px;box-shadow:var(--shadow)}
.kpi .l{font-size:13px;color:var(--cs)} .kpi .v{font-size:27px;font-weight:600;margin-top:5px}
.kpi .d{font-size:12px;margin-top:4px}
.cols-2{grid-template-columns:1.4fr 1fr}

table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.4px;color:#9aa0ab;font-weight:600;padding:11px 14px;border-bottom:.5px solid var(--br)}
td{padding:12px 14px;border-bottom:.5px solid var(--br);vertical-align:middle}
tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--bs)}
.rowflex{display:flex;align-items:center;gap:11px}

.input{height:40px;border:.5px solid var(--br2);border-radius:9px;padding:0 13px;font-size:14px;width:100%;background:var(--bp);color:var(--ct)}
textarea.input{height:auto;padding:10px 13px}
label.fl{display:block;font-size:13px;font-weight:600;margin:0 0 6px}
.field{margin-bottom:14px}

.list .it{display:flex;align-items:center;gap:12px;padding:12px 0;border-top:.5px solid var(--br)}
.list .it:first-child{border-top:none}

.flash{background:var(--bgr);color:var(--cg);border:.5px solid #bfe3cd;border-radius:10px;padding:12px 16px;margin-bottom:16px;font-weight:500}
.flash.err{background:var(--bd);color:var(--cd);border-color:#f0c7c7}

.section-title{font-size:13px;font-weight:600;color:var(--cs);margin:22px 0 10px;text-transform:uppercase;letter-spacing:.4px}

/* ── Login ── */
.login-wrap{display:grid;place-items:center;height:100vh;background:linear-gradient(160deg,#fbecec,#f6f7f9)}
.login{width:380px;max-width:92vw;background:var(--bp);border-radius:16px;box-shadow:0 10px 40px rgba(0,0,0,.12);padding:30px}
.login .logo{width:46px;height:46px;border-radius:11px;background:var(--red);color:#fff;display:grid;place-items:center;font-weight:700;font-size:20px;margin-bottom:16px}

/* ── Tablet: icon rail ── */
@media(max-width:1000px){
  .side{width:64px}
  .brand span,.nav a span,.nav .sec,.side .me .who{display:none}
  .nav a{justify-content:center;padding:11px 0}
  .cols-2{grid-template-columns:1fr}
  .kpis{grid-template-columns:repeat(2,1fr)}
}
/* ── Mobile: bottom tab bar ── */
@media(max-width:680px){
  .app{flex-direction:column}
  .side{width:100%;height:60px;flex-direction:row;border-right:none;border-top:.5px solid var(--br);order:2}
  .brand,.side .me{display:none}
  .nav{display:flex;padding:0;overflow-x:auto}
  .nav .sec{display:none}
  .nav a{flex-direction:column;gap:3px;font-size:10px;padding:8px 12px}
  .nav a span{display:block!important}
  .main{order:1}
  .kpis{grid-template-columns:repeat(2,1fr)}
  .content{padding:14px}
  .hide-m{display:none}
}

/* ============================================================
   RESPONSIVE FIXES (audited + adversarially verified 2026-06-25).
   Appended after the base breakpoints. Every rule is inside a media
   query or targets a new utility class, so the desktop (>1000px)
   layout is untouched.
   ============================================================ */

/* mobile-only utility (counterpart to .hide-m) */
.hide-d{display:none}

/* horizontal-scroll wrapper so a wide table scrolls inside its card,
   not the whole page (.content is the scroll container) */
.tw{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
.card > .tw{border-radius:inherit}

/* helper classes that replace inline styles (desktop-identical) */
.row-form{display:flex;gap:8px;align-items:flex-end}
.statrow{display:flex;flex-wrap:wrap}

/* reviews 3-up KPI row: desktop only; below 1001 the .kpis rules reflow it */
@media(min-width:1001px){ .kpis-3{grid-template-columns:repeat(3,1fr)} }

/* ---- TABLET (<=1000px) ---- */
@media(max-width:1000px){
  .side .me{flex-direction:column;gap:8px;padding:10px 0;align-items:center}
  .side .me .grow{flex:none;text-align:center}
  .tw table{min-width:520px}
  th,td{padding:10px 12px}
}

/* ---- MOBILE (<=680px) ---- */
@media(max-width:680px){
  /* pinned bottom tab bar; .content reserves space so rows clear it */
  .side{position:fixed;left:0;right:0;bottom:0;z-index:50;box-shadow:0 -1px 3px rgba(0,0,0,.06);padding-bottom:env(safe-area-inset-bottom)}
  .content{padding-bottom:calc(72px + env(safe-area-inset-bottom))}
  .nav{justify-content:space-around;overflow-x:hidden}
  .nav a{flex:1;min-width:0;padding:8px 4px}
  .nav a i{font-size:21px}
  .nav a span{font-size:10px;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
  .nav .sec + a ~ a{display:none}           /* keep Settings tab; hide its 3 sub-links */
  .hide-d{display:flex}
  .top .me-mobile{align-items:center;gap:8px}

  /* tables: tighter cells + shorter scroll distance */
  th,td{padding:9px 10px;font-size:13px}
  th{font-size:11px}
  .tw table{min-width:400px}
  td code{word-break:break-all}

  /* customer-360 stat row → 2-up */
  .statrow{gap:14px 22px}
  .statrow>*{flex:1 1 calc(50% - 22px)}

  /* settings/sellers redirect form stacks vertically */
  .row-form{flex-direction:column;align-items:stretch;gap:10px}
  .row-form .btn{width:100%;justify-content:center}

  /* settings/services add-mapping controls wrap */
  .wrap-m{flex-wrap:wrap}
  .card td .input{min-width:0}

  /* topbar: tighten + truncate title so @yield('actions') never clips */
  .top{padding:0 14px;gap:10px}
  .top h1{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
  .top .btn{flex:none}

  /* login card fits a 390 viewport */
  .login{max-width:calc(100vw - 28px);padding:24px}
}

/* ============================================================
   MODERN DASHBOARD (dz-*) — data-dense, refined. Namespaced so it
   doesn't affect other pages. Red brand as a restrained accent.
   ============================================================ */
.dz-hero{display:flex;align-items:flex-end;gap:14px;margin-bottom:20px;flex-wrap:wrap}
.dz-hero h1{font-size:23px;font-weight:600;margin:0;letter-spacing:-.02em}
.dz-hero .sub{color:var(--cs);font-size:13px;margin-top:3px}
.dz-hero .grow{flex:1}
.dz-hero .chip{display:inline-flex;align-items:center;gap:7px;background:var(--bp);border:.5px solid var(--br);border-radius:999px;padding:8px 14px;font-size:13px;font-weight:500;box-shadow:var(--shadow)}
.dz-hero .chip i{font-size:16px;color:var(--cs)}
.dz-hero .chip b{font-weight:600;font-variant-numeric:tabular-nums}

.dz-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:16px}
.dz-kpi{--c:var(--cs);position:relative;background:var(--bp);border:.5px solid var(--br);border-radius:16px;padding:16px 17px;box-shadow:var(--shadow);transition:transform .16s ease,box-shadow .16s ease}
.dz-kpi:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(0,0,0,.08)}
.dz-kpi .top{display:flex;align-items:center;justify-content:space-between;margin-bottom:11px}
.dz-kpi .lbl{font-size:12.5px;color:var(--cs);font-weight:500}
.dz-kpi .kchip{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-size:18px}
.dz-kpi .val{font-size:31px;font-weight:600;line-height:1;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.dz-kpi .meta{font-size:12px;color:var(--cs);margin-top:8px}
.dz-kpi.k-red{--c:var(--red)} .dz-kpi.k-red .kchip{background:var(--bd);color:var(--cd)} .dz-kpi.k-red .val{color:var(--red)}
.dz-kpi.k-blue{--c:var(--ci)} .dz-kpi.k-blue .kchip{background:var(--bi);color:var(--ci)}
.dz-kpi.k-amber{--c:var(--cw)} .dz-kpi.k-amber .kchip{background:var(--bw);color:var(--cw)}
.dz-kpi.k-slate{--c:#5b6472} .dz-kpi.k-slate .kchip{background:var(--bt);color:var(--ct)}
.dz-spark{display:flex;align-items:flex-end;gap:3px;height:28px;margin-top:13px}
.dz-spark span{flex:1;border-radius:3px 3px 0 0;min-height:3px;background:var(--c);opacity:.55}
.dz-spark span.hi{opacity:1}

.dz-grid{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,1fr);gap:16px;align-items:start}
.dz-col{display:flex;flex-direction:column;gap:16px}
.dz-card{background:var(--bp);border:.5px solid var(--br);border-radius:16px;box-shadow:var(--shadow)}
.dz-card .hd{display:flex;align-items:center;gap:10px;padding:15px 18px;border-bottom:.5px solid var(--br)}
.dz-card .hd h2{font-size:14.5px;font-weight:600;margin:0}
.dz-card .hd .grow{flex:1}
.dz-card .bd{padding:15px 18px}

.dz-chart{display:flex;align-items:flex-end;gap:9px;height:160px;padding:8px 2px 0}
.dz-chart .bar{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:7px;height:100%}
.dz-chart .bar .col{width:100%;display:flex;align-items:flex-end;justify-content:center;flex:1}
.dz-chart .bar .fill{width:100%;max-width:32px;background:#f0c7c7;border-radius:6px 6px 0 0;min-height:4px}
.dz-chart .bar.now .fill{background:var(--red)}
.dz-chart .bar.over .fill{background:var(--cd)}
.dz-chart .bar .lab{font-size:10.5px;color:var(--cs);white-space:nowrap}
.dz-chart .bar .num{font-size:11px;font-weight:600;font-variant-numeric:tabular-nums}

.dz-bars{display:flex;flex-direction:column;gap:9px}
.dz-rowbar{position:relative;display:flex;align-items:center;gap:10px;padding:10px 13px;border-radius:10px;overflow:hidden;background:var(--bs)}
.dz-rowbar .barfill{position:absolute;inset:0 auto 0 0;border-radius:10px;z-index:0}
.dz-rowbar>*{position:relative;z-index:1}
.dz-rowbar .nm{font-weight:600;font-size:13px}
.dz-rowbar .grow{flex:1}
.dz-rowbar .num{font-weight:600;font-variant-numeric:tabular-nums;font-size:14px}
.dz-rowbar .sub{font-size:11px;color:var(--cs)}

.dz-feed .it,.dz-due .it{display:flex;align-items:center;gap:11px;padding:11px 0;border-top:.5px solid var(--br)}
.dz-feed .it:first-child,.dz-due .it:first-child{border-top:none}
.dz-feed .ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;font-size:16px;flex:none}

@media (prefers-reduced-motion: reduce){ .dz-kpi{transition:none} .dz-kpi:hover{transform:none} }
@media(max-width:1000px){ .dz-kpis{grid-template-columns:repeat(2,1fr)} .dz-grid{grid-template-columns:1fr} }
@media(max-width:680px){ .dz-chart{height:130px;gap:5px} .dz-hero h1{font-size:20px} }

/* ============================================================
   V2 OVERHAUL — premium re-skin + dark mode + bold dashboard.
   Appended so it overrides the base rules above.
   ============================================================ */
.side{width:236px;border-right:1px solid var(--br)}
.brand{padding:20px 18px 16px;font-size:16px;letter-spacing:-.01em}
.brand .logo{border-radius:9px}
.nav{padding:8px 12px}
.nav a{border-radius:11px;font-size:13.5px}
.nav a.on{font-weight:600}
.nav a:hover:not(.on){background:var(--bs);color:var(--ct)}
.nav .sec{color:var(--cf)}
.side .me{border-top:1px solid var(--br)}
.top{height:62px;border-bottom:1px solid var(--br);padding:0 24px}
.top h1{letter-spacing:-.01em}
.content{padding:24px 26px}
.card{border:1px solid var(--br);border-radius:var(--radius)}
.btn{border-radius:11px;border:1px solid var(--br2);transition:background .15s,border-color .15s,transform .1s}
.btn:active{transform:scale(.98)}
.btn.pri{background:var(--red);border-color:var(--red)}
.input{border:1px solid var(--br2);border-radius:11px;background:var(--bp);color:var(--ct)}
.input::placeholder{color:var(--cf)}
tbody tr:hover{background:var(--bs)}
.b-admin{background:rgba(139,92,246,.16);color:#8b5cf6}

.theme-tog{width:38px;height:38px;border-radius:11px;border:1px solid var(--br);background:var(--bp);color:var(--cs);display:grid;place-items:center;cursor:pointer;font-size:19px;flex:none}
.theme-tog:hover{background:var(--bs);color:var(--ct)}
.theme-tog.on{background:var(--bd);color:var(--red);border-color:transparent}

/* settings sub-nav: wraps onto multiple lines (never side-scrolls) */
.subnav{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}

/* pagination (plain-CSS pager — replaces Laravel's default unstyled Tailwind view) */
.pager{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.pager-info{color:var(--cs);font-size:13px}
.pager-ctrls{display:flex;align-items:center;gap:6px}
.pg{min-width:34px;height:34px;padding:0 11px;display:inline-flex;align-items:center;justify-content:center;
    border-radius:9px;border:1px solid var(--br);background:var(--bp);color:var(--ct);font-size:13px;
    font-weight:500;text-decoration:none;font-variant-numeric:tabular-nums;transition:background .12s}
.pg:hover{background:var(--bs)}
.pg.on{background:var(--red);border-color:transparent;color:#fff}
.pg.dis{opacity:.4;pointer-events:none}
.pg.gap{border:none;background:transparent;pointer-events:none;padding:0 2px;min-width:auto}
.pg i{font-size:17px;line-height:1}
@media(max-width:680px){ .pager{justify-content:center} .pager-info{order:2;width:100%;text-align:center} }

/* store tag — colour-coded chip showing which store a record (e.g. a Google review) belongs to */
.stag{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;
      font-size:11.5px;font-weight:600;line-height:1.4;white-space:nowrap}
.stag::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.stag.s1{background:var(--bi);color:var(--ci)}
.stag.s2{background:var(--bgr);color:var(--cg)}
.stag.s3{background:var(--bw);color:var(--cw)}
.stag.s0{background:var(--bt);color:var(--cs)}

/* small count pill inside filter chips */
.cnt{display:inline-block;min-width:18px;padding:0 5px;margin-left:4px;border-radius:999px;background:var(--bt);
     color:var(--cs);font-size:11px;font-weight:600;text-align:center;vertical-align:middle}
.btn.pri .cnt{background:rgba(255,255,255,.24);color:#fff}

/* dashboard — marketing & messaging performance */
.dz-sec{display:flex;align-items:baseline;justify-content:space-between;margin:8px 2px 12px;font-size:14px;font-weight:600;color:var(--ct);letter-spacing:-.01em}
.dz-sec-r{font-size:12px;font-weight:500;color:var(--cf)}
.dz-perf{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:18px}
.dz-pcard{background:var(--bp);border:1px solid var(--br);border-radius:16px;padding:15px 16px;box-shadow:var(--shadow)}
.dz-pcard .top{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px}
.dz-pcard .lbl{font-size:12.5px;color:var(--cs);font-weight:500}
.dz-pcard .pchip{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:var(--bs);color:var(--cs);font-size:16px;flex:none}
.dz-pcard .pchip.up{background:var(--bgr);color:var(--cg)}
.dz-pcard .val{font-size:25px;font-weight:700;letter-spacing:-.02em;line-height:1.1;color:var(--ct)}
.dz-pcard .meta{font-size:11.5px;color:var(--cf);margin-top:5px;line-height:1.45}
.dz-msgperf{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);gap:24px}
.dz-msgperf .funnel{display:flex;flex-direction:column;gap:9px}
.dz-msgperf .frow{display:flex;align-items:center;gap:11px}
.dz-msgperf .fl{width:74px;font-size:12.5px;color:var(--cs);flex:none}
.dz-msgperf .fbar{flex:1;height:9px;border-radius:6px;background:var(--bs);overflow:hidden}
.dz-msgperf .fbar span{display:block;height:100%;border-radius:6px}
.dz-msgperf .fv{width:44px;text-align:right;font-size:13px;font-weight:600;color:var(--ct);font-variant-numeric:tabular-nums}
.dz-msgperf .fmeta{display:flex;flex-wrap:wrap;gap:6px 16px;margin-top:8px;font-size:12px;color:var(--cs)}
.dz-msgperf .fmeta b{color:var(--ct)}
.roi-tbl{width:100%;border-collapse:collapse;font-size:13px}
.roi-tbl th{text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--cf);font-weight:600;padding:0 0 7px}
.roi-tbl th:not(:first-child),.roi-tbl td:not(:first-child){text-align:right;font-variant-numeric:tabular-nums}
.roi-tbl td{padding:8px 0;border-top:1px solid var(--br);color:var(--ct)}
@media(max-width:980px){ .dz-perf{grid-template-columns:repeat(2,minmax(0,1fr))} .dz-msgperf{grid-template-columns:1fr;gap:18px} }

/* reports */
.rep-bar{display:flex;flex-wrap:wrap;align-items:flex-end;gap:12px}
.rep-field{display:flex;flex-direction:column;gap:5px}
.rep-field .fl{font-size:12px;color:var(--cs);font-weight:500;margin:0}
.rep-field .input{height:38px}
.rep-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:18px}
.rep-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.kv{display:flex;flex-direction:column}
.kv .row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 0;border-top:1px solid var(--br)}
.kv .row:first-child{border-top:none;padding-top:0}
.kv .k{color:var(--cs);font-size:13px}
.kv .v{font-weight:600;color:var(--ct);font-variant-numeric:tabular-nums;text-align:right}
.tscroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
.tscroll table{width:100%;border-collapse:collapse;min-width:560px}
.tscroll th{text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--cf);font-weight:600;padding:0 14px 10px;white-space:nowrap}
.tscroll td{padding:11px 14px;border-top:1px solid var(--br);white-space:nowrap;color:var(--ct);font-size:13px}
.tscroll .num{text-align:right;font-variant-numeric:tabular-nums}
.tscroll th.num{text-align:right}
@media(max-width:980px){ .rep-kpis{grid-template-columns:repeat(2,minmax(0,1fr))} .rep-grid{grid-template-columns:1fr} }

/* print — strip the app chrome, show a report header, keep cards clean */
.print-only{display:none}
@media print{
  .side,.top,.no-print{display:none!important}
  .app{display:block!important}
  .main{margin:0!important}
  .content{padding:0!important}
  .print-only{display:block!important}
  .print-head{margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid #000;color:#000}
  .card{box-shadow:none!important;border:1px solid #bbb!important;break-inside:avoid;margin-bottom:12px!important}
  .rep-kpis,.rep-grid{display:grid!important}
  .tscroll{overflow:visible!important}
  body,.content,.card{background:#fff!important;color:#000!important}
}

/* ── dashboard v2 ── */
.dz-hero h1{font-size:25px;letter-spacing:-.025em}
.dz-kpi{border-radius:18px;padding:17px 18px}
.dz-kpi .val{font-size:33px}
.dz-card{border-radius:18px}
.dz-card .hd h2{font-size:14px;letter-spacing:-.01em}
.dz-trend{display:inline-flex;align-items:center;gap:3px;font-size:11.5px;font-weight:600;padding:2px 8px;border-radius:999px}
.dz-trend.up{background:var(--bgr);color:var(--cg)} .dz-trend.flat{background:var(--bt);color:var(--cs)}

/* area chart (svg) — aspect-ratio keeps it crisp + responsive, no distortion */
.dz-area{width:100%;aspect-ratio:72/21;display:block}
.dz-area .axis{fill:var(--cf);font-size:10px;font-variant-numeric:tabular-nums}
.dz-area .gln{stroke:var(--br);stroke-width:1}
.dz-area .ln{fill:none;stroke:var(--red);stroke-width:2.5;stroke-linejoin:round;stroke-linecap:round}
.dz-area .ar{stroke:none}
.dz-area .gs0{stop-color:var(--red);stop-opacity:.24}
.dz-area .gs1{stop-color:var(--red);stop-opacity:0}
.dz-area .dot{fill:var(--bp);stroke:var(--red);stroke-width:2.5}
.dz-area .dot.peak{fill:var(--red)}
.dz-gauge circle{fill:none;stroke-width:10;stroke-linecap:round}
.dz-gauge .trk{stroke:var(--bt)}
.dz-gauge .arc{stroke:var(--red)}
.dz-gauge .arc-gold{stroke:#e8a200}

/* circular gauges */
.dz-gauges{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.dz-gauge{display:flex;flex-direction:column;align-items:center;gap:8px;padding:8px 0}
.dz-gauge .gwrap{position:relative;width:108px;height:108px;display:grid;place-items:center}
.dz-gauge .gwrap svg{transform:rotate(-90deg)}
.dz-gauge .cen{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.dz-gauge .gv{font-size:21px;font-weight:600;font-variant-numeric:tabular-nums;line-height:1}
.dz-gauge .gv small{font-size:12px;color:var(--cs);font-weight:500}
.dz-gauge .gl{font-size:12px;color:var(--cs);text-align:center}

/* ── STRICTLY-VERTICAL MOBILE: no element scrolls sideways ──
   Wide tables become stacked cards (no overflow-x). */
@media(max-width:680px){
  .dz-kpis{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
  .dz-kpi{padding:15px 15px}
  .dz-kpi .val{font-size:27px}
  .content{padding:16px 14px;padding-bottom:calc(88px + env(safe-area-inset-bottom))}
  .dz-gauges{grid-template-columns:1fr 1fr}

  /* full-width, taller, LABELED bottom tab bar (the desktop .side width was leaking to mobile) */
  .side{position:fixed;left:0;right:0;bottom:0;top:auto;width:100%;height:auto;flex-direction:row;
        border-right:none;border-top:1px solid var(--br);background:var(--bp);
        padding:8px 4px calc(8px + env(safe-area-inset-bottom));z-index:60;box-shadow:0 -2px 14px rgba(0,0,0,.08)}
  .nav{display:flex;justify-content:space-around;align-items:stretch;padding:0;gap:2px;overflow:visible}
  .nav a{flex:1 1 0;min-width:0;flex-direction:column;align-items:center;justify-content:center;gap:4px;
         padding:6px 2px;margin:0;border-radius:12px;color:var(--cs)}
  .nav a.on{background:var(--bd);color:var(--red)}
  .nav a i{font-size:23px;width:auto}
  .nav a span{display:block!important;font-size:10px;line-height:1.05;font-weight:500;
              white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
  .nav .sec{display:none}
  .nav .sec + a ~ a{display:none}

  .tw{overflow-x:visible}
  .tw table,.tw thead,.tw tbody{display:block;width:auto;min-width:0}
  .tw thead{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
  /* each row = a flex card: name spans line 1, secondary info + action share line 2 (fills width) */
  .tw tr{display:flex;flex-wrap:wrap;align-items:center;gap:5px 14px;border:none;border-top:1px solid var(--br);
         border-radius:0;background:transparent;margin:0;padding:13px 2px}
  .tw tbody tr:first-child{border-top:none}
  .tw tr:hover{background:transparent}
  .tw td{display:block;border:none!important;padding:0;white-space:normal}
  .tw td:first-child{flex:1 1 100%;font-weight:600}
  .tw td.hide-m{display:none}   /* keep secondary columns hidden in card mode */
  .tw td:last-child{margin-left:auto;text-align:right!important}
}
