:root{
  --navy:#063955;--navy-700:#0a4a6e;--teal:#009AB9;--teal-tint:#E3F4F8;--teal-tint-2:#D0ECF3;
  --app-bg:#F1F5F8;--card:#FFFFFF;--line:#E2EAEF;--line-soft:#EDF2F5;--ink:#0E2A3B;
  --muted:#5E7689;--muted-2:#8AA0AF;--pos:#1F9D78;--pos-tint:#E4F4EE;--neg:#DB5A4B;--neg-tint:#FBE9E6;--amber:#E0942A;
  --radius:14px;--radius-sm:10px;--shadow:0 1px 2px rgba(6,57,85,.04),0 6px 20px rgba(6,57,85,.06);--shadow-lg:0 12px 40px rgba(6,57,85,.14);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:"DM Sans",system-ui,-apple-system,sans-serif;background:var(--app-bg);color:var(--ink);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:"Plus Jakarta Sans",system-ui,sans-serif}
.num{font-family:"Plus Jakarta Sans",system-ui,sans-serif;font-variant-numeric:tabular-nums}
a{color:var(--teal)}

/* ---- report identity + tabs ---- */
.report-top{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:18px}
.report-id{display:flex;align-items:center;gap:14px}
.client-logo{width:46px;height:46px;border-radius:11px;display:grid;place-items:center;color:#fff;font-family:"Plus Jakarta Sans";font-weight:800;font-size:19px;box-shadow:0 4px 12px rgba(6,57,85,.18)}
.report-id h1{font-size:20px;font-weight:800;letter-spacing:-.02em;color:var(--navy)}
.report-id .sub{font-size:12.5px;color:var(--muted);margin-top:2px}
.report-id .sub b{color:var(--teal);font-weight:600}
.rtabs{display:inline-flex;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:4px;margin-bottom:20px;flex-wrap:wrap}
.rtabs button{border:0;background:transparent;cursor:pointer;font-family:"DM Sans";font-size:13px;font-weight:600;color:var(--muted);padding:9px 16px;border-radius:8px;transition:.15s}
.rtabs button.on{background:var(--teal);color:#fff}
.tab-note{font-size:12.5px;color:var(--muted);margin:-4px 0 18px}

/* ---- KPI tiles ---- */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px 16px 36px;box-shadow:var(--shadow);position:relative;overflow:hidden;display:flex;flex-direction:column;min-height:150px}
.kpi .label{font-size:12px;color:var(--muted);font-weight:500}
.kpi .val{font-size:27px;font-weight:800;color:var(--navy);letter-spacing:-.02em;margin-top:7px;line-height:1}
.kpi .foot{display:flex;align-items:center;gap:8px;margin-top:10px;position:relative;z-index:2}
.delta{display:inline-flex;align-items:center;gap:3px;font-size:11.5px;font-weight:700;padding:2px 7px;border-radius:20px}
.delta svg{width:11px;height:11px}
.delta.up{color:var(--pos);background:var(--pos-tint)}.delta.down{color:var(--neg);background:var(--neg-tint)}
.delta.up.inv{color:var(--neg);background:var(--neg-tint)}.delta.down.inv{color:var(--pos);background:var(--pos-tint)}
.kpi .vs{font-size:11px;color:var(--muted-2)}
.kpi .spark{position:absolute;right:0;bottom:0;width:100%;height:30px;opacity:.75;z-index:1}

.grid{display:grid;gap:14px}.g-2{grid-template-columns:1.6fr 1fr}.g-2e{grid-template-columns:1fr 1fr}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.card h3{font-size:13.5px;font-weight:700;color:var(--navy);margin-bottom:3px}
.card .csub{font-size:11.5px;color:var(--muted);margin-bottom:14px}
svg.chart{display:block;width:100%;height:auto;overflow:visible}
.legend{display:flex;gap:16px;margin-top:6px;flex-wrap:wrap}
.legend span{display:inline-flex;align-items:center;gap:7px;font-size:11.5px;color:var(--muted);font-weight:500}
.legend i{width:11px;height:3px;border-radius:2px;display:inline-block}
.section-head{display:flex;align-items:center;gap:10px;margin-bottom:13px}
.section-head h2{font-size:14.5px;font-weight:700;color:var(--navy)}
.section-head .eyebrow{font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;font-weight:700;color:var(--teal)}
.section-head .src{margin-left:auto;font-size:11px;color:var(--muted-2);display:inline-flex;align-items:center;gap:6px;font-weight:500}
.dot{width:6px;height:6px;border-radius:50%;background:var(--teal);display:inline-block}

.chan{display:flex;flex-direction:column;gap:13px;margin-top:2px}
.chan-row{display:grid;grid-template-columns:84px 1fr 52px;align-items:center;gap:12px}
.chan-row .nm{font-size:12.5px;color:var(--ink);font-weight:600}
.chan-row .bar{height:9px;border-radius:6px;background:var(--line-soft);overflow:hidden}
.chan-row .bar i{display:block;height:100%;border-radius:6px}
.chan-row .pc{font-size:12.5px;font-weight:700;color:var(--navy);text-align:right;font-family:"Plus Jakarta Sans"}

table{width:100%;border-collapse:collapse}
th{font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted-2);font-weight:700;text-align:left;padding:0 10px 9px;border-bottom:1px solid var(--line)}
th.r,td.r{text-align:right}
td{padding:11px 10px;border-bottom:1px solid var(--line-soft);font-size:13px}
tr:last-child td{border-bottom:0}
td .q{font-weight:600;color:var(--ink)}td.r .num{font-weight:600;color:var(--navy)}
.pos-pill{display:inline-block;min-width:30px;text-align:center;font-family:"Plus Jakarta Sans";font-weight:700;font-size:12px;padding:3px 8px;border-radius:7px;background:var(--teal-tint);color:var(--navy)}
.mini-delta{font-size:11px;font-weight:700}.mini-delta.up{color:var(--pos)}.mini-delta.down{color:var(--neg)}
.cited{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700}
.cited.y{color:var(--pos)}.cited.n{color:var(--muted-2)}
.cited i{width:8px;height:8px;border-radius:50%;background:currentColor;display:inline-block}
.eng-chips{display:flex;gap:4px}
.eng-chips span{font-size:9.5px;font-weight:800;font-family:"Plus Jakarta Sans";color:#fff;width:19px;height:19px;border-radius:5px;display:grid;place-items:center}

/* ---- AIO panel ---- */
.aio{background:linear-gradient(180deg,#082f47 0%,#063955 60%,#07415f 100%);border-radius:18px;color:#dcebf2;overflow:hidden;position:relative;border-top:3px solid var(--teal);box-shadow:0 16px 44px rgba(6,57,85,.28)}
.aio:before{content:"";position:absolute;right:-80px;top:-80px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(0,154,185,.34),transparent 70%)}
.aio-inner{position:relative;padding:24px 26px;display:grid;grid-template-columns:230px 1fr;gap:30px}
.aio-eyebrow{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:#5fd0e8;font-weight:700;display:flex;align-items:center;gap:8px}
.aio-eyebrow svg{width:15px;height:15px}
.aio h2{font-family:"Plus Jakarta Sans";color:#fff;font-size:18px;font-weight:800;margin:10px 0 4px}
.aio .blurb{font-size:12.5px;color:#a9c9d8;line-height:1.55;max-width:230px;margin-top:8px}
.gauge-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px}
.gauge{width:200px;max-width:100%}
.delta-line{font-size:12px;color:#9fe0c9;font-weight:600;text-align:center}
.engines{display:flex;flex-direction:column;gap:13px}
.eng-row{display:grid;grid-template-columns:140px 1fr 86px;align-items:center;gap:14px}
.eng-row .en{display:flex;align-items:center;gap:9px;font-size:12.5px;color:#dbeaf1;font-weight:600}
.eng-row .en .ic{width:22px;height:22px;border-radius:6px;display:grid;place-items:center;font-size:11px;font-weight:800;font-family:"Plus Jakarta Sans";color:#fff;flex:0 0 auto}
.eng-row .track{height:8px;background:rgba(255,255,255,.12);border-radius:6px;overflow:hidden}
.eng-row .track i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,#00b4d8,#5fd0e8)}
.eng-row .vv{text-align:right;font-family:"Plus Jakarta Sans";font-weight:700;font-size:13px;color:#fff}
.eng-row .vv small{display:block;font-size:10px;color:#7fb0c4;font-weight:600}
.insight{display:flex;gap:13px;align-items:flex-start;background:var(--teal-tint);border:1px solid var(--teal-tint-2);border-radius:12px;padding:14px 16px;margin-top:14px}
.insight svg{width:18px;height:18px;flex:0 0 auto;color:var(--teal);margin-top:1px}
.insight p{font-size:12.5px;color:#0a4a66;line-height:1.5}.insight b{color:var(--navy);font-weight:700}

/* ---- buttons ---- */
.btn{border:0;cursor:pointer;font-family:"DM Sans";font-weight:600;font-size:13px;padding:9px 15px;border-radius:10px;display:inline-flex;align-items:center;gap:7px;transition:.15s}
.btn svg{width:15px;height:15px}
.btn-ghost{background:var(--app-bg);color:var(--navy);border:1px solid var(--line)}.btn-ghost:hover{background:#e7eef3}
.btn-solid{background:var(--teal);color:#fff}.btn-solid:hover{background:#0089a5}
.btn-sm{padding:6px 11px;font-size:12px}
.btn-danger{background:var(--neg-tint);color:#a33}

/* ---- agency shell ---- */
.app{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.sidebar{background:var(--navy);color:#cfe3ec;padding:22px 16px;display:flex;flex-direction:column;gap:22px;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:11px;padding:4px 8px}
.brand-mark{width:34px;height:34px}
.brand-name{font-family:"Plus Jakarta Sans";font-weight:800;font-size:16px;color:#fff;line-height:1.05}
.brand-name small{display:block;font-weight:500;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);margin-top:3px}
.nav-label{font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:#5b87a0;padding:0 10px;margin-bottom:8px;font-weight:600}
.snav{display:flex;flex-direction:column;gap:2px}
.snav a{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:9px;color:#bcd5e1;text-decoration:none;font-size:13.5px;font-weight:500;cursor:pointer}
.snav a:hover{background:rgba(255,255,255,.06);color:#fff}.snav a.active{background:var(--teal);color:#fff}
.sb-foot{margin-top:auto;border-top:1px solid rgba(255,255,255,.09);padding-top:14px;font-size:12px;color:#9fc1d2}
.sb-foot a{color:#cfe3ec;cursor:pointer;display:block;margin-top:6px}
.main{min-width:0;display:flex;flex-direction:column}
.canvas{padding:26px 30px 60px;max-width:1180px;width:100%}
.page-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.page-head h1{font-size:22px;font-weight:800;color:var(--navy)}
.page-head .pg-sub{font-size:13px;color:var(--muted);margin-top:2px}

/* lists / rows */
.row-list{display:flex;flex-direction:column;gap:10px}
.lrow{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 16px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow);cursor:pointer;transition:.12s}
.lrow:hover{border-color:var(--teal-tint-2);transform:translateY(-1px)}
.lrow .lg{width:38px;height:38px;border-radius:9px;display:grid;place-items:center;color:#fff;font-weight:800;font-family:"Plus Jakarta Sans";flex:0 0 auto}
.lrow .lt{font-weight:700;color:var(--navy);font-size:14px}
.lrow .ls{font-size:12px;color:var(--muted)}
.lrow .lright{margin-left:auto;display:flex;align-items:center;gap:10px}
.pill{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;background:var(--teal-tint);color:#0a4a66}
.pill.live{background:#E4F4EE;color:#15795c}.pill.warn{background:#FBEFE3;color:#8A4B08}.pill.off{background:#eef2f5;color:#8AA0AF}

/* forms */
.field{margin-bottom:14px}
.field label{display:block;font-size:11.5px;font-weight:700;color:var(--navy);margin-bottom:6px}
.field input,.field select{width:100%;border:1px solid var(--line);border-radius:9px;padding:10px 12px;font-family:"DM Sans";font-size:13px;color:var(--ink);background:#fff}
.help{font-size:11px;color:var(--muted-2);margin-top:4px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* auth */
.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:20px;background:linear-gradient(160deg,#f1f5f8,#e3f0f4)}
.auth-card{background:#fff;border-radius:18px;box-shadow:var(--shadow-lg);padding:30px;max-width:380px;width:100%}
.auth-card .brand{justify-content:center;margin-bottom:18px}
.auth-card h2{font-size:18px;color:var(--navy);text-align:center;margin-bottom:4px}
.auth-card p.sub{font-size:12.5px;color:var(--muted);text-align:center;margin-bottom:20px}
.auth-card .btn{width:100%;justify-content:center;margin-top:6px}
.err{color:var(--neg);font-size:12.5px;margin-top:10px;text-align:center;min-height:16px}

/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(6,57,85,.42);display:none;align-items:center;justify-content:center;z-index:60;padding:20px}
.modal-bg.open{display:flex}
.modal{background:#fff;border-radius:16px;max-width:440px;width:100%;box-shadow:var(--shadow-lg);overflow:hidden}
.modal-h{padding:20px 22px 0}.modal-h h3{font-size:16px;color:var(--navy)}.modal-h p{font-size:12.5px;color:var(--muted);margin-top:4px}
.modal-b{padding:18px 22px}.modal-f{padding:14px 22px 20px;display:flex;justify-content:flex-end;gap:9px;border-top:1px solid var(--line-soft)}
.url-box{display:flex;align-items:center;gap:8px;background:var(--app-bg);border:1px solid var(--line);border-radius:9px;padding:11px 13px;font-family:"Plus Jakarta Sans";font-weight:600;font-size:12.5px;color:var(--navy);word-break:break-all}

/* client share shell */
.share-page{max-width:1120px;margin:0 auto;padding:28px 24px 60px}
.share-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.share-brand{display:flex;align-items:center;gap:9px;font-size:12px;color:var(--muted)}
.share-brand svg{width:24px;height:24px}
.client-footer{display:flex;align-items:center;gap:12px;margin-top:30px;padding-top:20px;border-top:1px solid var(--line);color:var(--muted);font-size:12px}
.client-footer svg{width:26px;height:26px}.client-footer b{color:var(--navy);font-weight:700}

.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--navy);color:#fff;padding:13px 20px;border-radius:11px;font-size:13px;font-weight:600;box-shadow:var(--shadow-lg);opacity:0;transition:.25s;z-index:80}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@media (max-width:980px){
  .app{grid-template-columns:1fr}.sidebar{display:none}
  .kpis{grid-template-columns:repeat(2,1fr)}.g-2,.g-2e,.grid2{grid-template-columns:1fr}
  .aio-inner{grid-template-columns:1fr}.canvas{padding:20px 16px 50px}
}
@media print{.sidebar,.rtabs,.share-brand,.report-actions{display:none!important}.app{grid-template-columns:1fr}.card,.kpi,.aio{break-inside:avoid;box-shadow:none}}
