/* ============================================================
   FNB Toolkit — Menu Planning Tool
   Brand-aligned stylesheet · June 2026
   ============================================================ */

:root{
  /* Primary blue family */
  --blue:#1C5FE5;
  --blue-deep:#1546B8;
  --blue-bright:#3D7BF7;
  --blue-soft:#EAF1FE;
  --blue-tint:#F4F8FF;

  /* Dark / neutral */
  --navy:#0B2545;
  --ink:#10243F;
  --text:#33425A;
  --muted:#647387;
  --line:#E4EAF3;
  --line-2:#d3dcec;
  --surface:#ffffff;
  --logo-gray:#3D4452;

  /* Data-viz only — never for UI chrome */
  --green:#16A363;
  --green-dark:#1d9e75;
  --green-soft:#E3F3EA;
  --amber:#E2A437;
  --amber-dark:#b5731a;
  --gray:#8a8980;
  --red:#C0392B;

  /* Tool internals */
  --input-color:#1546B8;
  --input-fill:#EAF1FE;
  --total-fill:#F4F8FF;
  --kpi-fill:#F4F8FF;

  --font:"Plus Jakarta Sans",system-ui,-apple-system,"Segoe UI",sans-serif;
  --mono:ui-monospace,"SF Mono","Cascadia Mono",Menlo,Consolas,monospace;
}

*{box-sizing:border-box}
html,body{margin:0}
body{background:var(--surface);color:var(--text);font-family:var(--font);font-size:17px;line-height:1.6;
  font-variant-numeric:tabular-nums;-webkit-font-smoothing:antialiased}
.wrap{max-width:1560px;margin:0 auto;padding:20px 30px 60px}

/* ---- Topbar ---- */
.topbar{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:0 0 16px;
  border-bottom:1px solid var(--line);margin-bottom:18px}
.topbar .back-to-tools{margin:0}
.wordmark{font-family:var(--font);font-weight:800;font-size:21px;letter-spacing:-.02em;
  text-decoration:none;line-height:1;display:inline-flex;align-items:baseline;gap:0}
.wordmark .wm-fnb{color:var(--blue-deep)}
.wordmark .wm-tk{color:var(--logo-gray)}
.toolcount{font-size:12px;font-weight:600;letter-spacing:.06em;color:var(--muted);text-transform:uppercase}
.back-to-tools{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:600;
  color:var(--muted);text-decoration:none;margin:0 0 16px;transition:color .15s}
.back-to-tools:hover{color:var(--blue)}
.back-to-tools .tb-arrow{font-size:15px;line-height:1}

/* ---- Masthead ---- */
.masthead{display:flex;justify-content:space-between;align-items:flex-end;gap:18px;flex-wrap:wrap;
  background:var(--blue-tint);border-radius:14px;padding:24px 28px 22px;
  border:1px solid var(--line);margin-bottom:20px}
.eyebrow{font-family:var(--font);font-weight:700;font-size:13px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--blue);margin:0 0 12px}
.eyebrow a{color:var(--blue);text-decoration:none;opacity:.8}
.eyebrow a:hover{opacity:1}
h1{font-weight:800;font-size:30px;line-height:1.1;margin:0;letter-spacing:-.02em;color:var(--ink)}
.sub{margin:6px 0 0;color:var(--muted);font-size:15px}
.variant-badge{display:inline-block;font-size:11px;font-family:var(--font);font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;border-radius:6px;padding:3px 9px;
  vertical-align:middle;position:relative;top:-3px}
.variant-badge--roy{background:var(--navy);color:#fff}
.variant-badge--no{background:var(--green);color:#fff}
.actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.action-btns{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.savenote{font-size:13px;color:var(--muted);margin-left:4px}
.masthead-hint{font-size:13px;color:var(--muted);line-height:1.5;margin:9px 0 0;max-width:72ch}

/* Royalty / commission toggle */
.royalty-ctrl{display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  background:var(--surface);border:1.5px solid var(--line-2);border-radius:12px;
  padding:9px 14px}
.royalty-q{font-size:13px;font-weight:600;color:var(--ink);line-height:1.3;max-width:230px}
.switch{position:relative;display:inline-block;width:42px;height:24px;flex:none;cursor:pointer}
.switch input{position:absolute;opacity:0;width:0;height:0}
.switch-track{position:absolute;inset:0;background:#cdd6e4;border-radius:999px;transition:background .15s}
.switch-track::before{content:"";position:absolute;left:3px;top:3px;width:18px;height:18px;
  background:#fff;border-radius:50%;box-shadow:0 1px 3px rgba(11,37,69,.3);transition:transform .15s}
.switch input:checked + .switch-track{background:var(--blue)}
.switch input:checked + .switch-track::before{transform:translateX(18px)}
.switch input:focus-visible + .switch-track{box-shadow:0 0 0 3px rgba(28,95,229,.25)}
.fee-opts{display:inline-flex;align-items:center;gap:7px;flex-wrap:wrap}
.fee-opts[hidden]{display:none}
.fee-lab{font-size:12px;font-weight:600;color:var(--muted)}
.fee-seg{display:inline-flex;border:1.5px solid var(--line-2);border-radius:9px;overflow:hidden}
.fee-seg[hidden]{display:none}
.fee-opt{font-family:var(--font);font-size:12.5px;font-weight:700;color:var(--muted);
  background:var(--surface);border:0;padding:6px 12px;cursor:pointer;line-height:1.4}
.fee-opt + .fee-opt{border-left:1.5px solid var(--line-2)}
.fee-opt.active{background:var(--blue);color:#fff}
#royRateCtrl[hidden]{display:none}

/* Control bar (toggle + undo + reset), aligned right */
.panel.toolbar{display:flex;justify-content:flex-end;align-items:center;gap:18px;flex-wrap:wrap;
  padding-top:14px;padding-bottom:14px}
.toolbar .royalty-ctrl{border:0;background:transparent;padding:0}
.toolbar .action-btns{gap:8px}
@media(max-width:620px){.panel.toolbar{justify-content:flex-start}}

/* ---- Buttons ---- */
.btn{font-family:var(--font);font-size:14px;font-weight:700;letter-spacing:.01em;
  color:var(--ink);background:var(--surface);
  border:1.5px solid var(--line-2);border-radius:9px;padding:8px 14px;cursor:pointer;
  transition:background .12s,border-color .12s,color .12s;line-height:1}
.btn:hover{border-color:var(--blue);color:var(--blue)}
.btn:active{transform:translateY(1px)}
.btn.small{padding:5px 11px;font-size:13px}
.btn.primary{background:var(--blue);color:#fff;border-color:var(--blue);
  box-shadow:0 6px 18px rgba(28,95,229,.22)}
.btn.primary:hover{background:var(--blue-deep);border-color:var(--blue-deep)}

/* ---- Inputs & controls ---- */
.controls{display:flex;gap:26px;align-items:center;flex-wrap:wrap;margin-bottom:4px}
.ctrl{display:flex;align-items:center;gap:12px;flex:1;min-width:260px;max-width:560px}
.ctrl.narrow{flex:0 0 auto;min-width:0}
.ctrl label{font-size:13px;font-weight:500;color:var(--muted);white-space:nowrap}
.ctrl output{font-weight:800;font-size:18px;color:var(--ink);min-width:48px;text-align:right}
.ctrl .pct{color:var(--muted)}
input[type=range]{flex:1;height:4px;-webkit-appearance:none;appearance:none;background:var(--line-2);
  border-radius:3px;outline:none;cursor:pointer}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;
  background:var(--blue);border:3px solid var(--surface);box-shadow:0 0 0 1px var(--blue);cursor:pointer}
input[type=range]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--blue);
  border:3px solid var(--surface);box-shadow:0 0 0 1px var(--blue);cursor:pointer}
input[type=number]{font-family:var(--font);font-size:15px;color:var(--input-color);width:64px;
  text-align:right;border:1.5px solid var(--line-2);border-radius:9px;padding:5px 8px;
  background:var(--input-fill)}
input:focus{outline:2px solid rgba(28,95,229,.35);outline-offset:0}

/* ---- Hints & template bar ---- */
.hint{font-size:14px;color:var(--muted);margin:-4px 0 14px;max-width:78ch}
.note-box{font-size:13px;color:var(--text);line-height:1.55;background:#F1F4F8;
  border:1px solid var(--line);border-left:3px solid var(--line-2);border-radius:8px;
  padding:9px 13px;margin:0 0 14px;max-width:78ch}
.note-box strong{color:var(--ink);font-weight:700}
.templatebar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;
  background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:12px 18px;margin-bottom:16px}
.templatelab{font-size:14px;color:var(--muted);flex:1;min-width:200px;display:flex;flex-direction:column;gap:5px}
.privacynote{font-size:12px;color:var(--muted);display:block}
.templatebtns{display:flex;gap:8px;flex-shrink:0;flex-wrap:wrap}

/* ---- Intro panel ---- */
.introrow{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.introrow .panel{margin-bottom:0}
@media(max-width:760px){.introrow{grid-template-columns:1fr}}
.intro{background:var(--blue-tint);border-color:var(--line)}
.intro p{font-size:14px;color:var(--muted);margin:0 0 10px;max-width:90ch;line-height:1.6}
.intro .introsteps{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:14px 0 0}
.intro .introsteps span{font-size:14px;color:var(--muted);line-height:1.55;
  border-top:2px solid var(--blue);padding-top:8px}
.intro .introsteps b{color:var(--blue);font-weight:800;margin-right:4px}
@media(max-width:760px){.intro .introsteps{grid-template-columns:1fr}}
.steps{margin:8px 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:12px;counter-reset:step}
.steps li{font-size:14px;color:var(--text);line-height:1.6;padding-left:32px;position:relative;counter-increment:step}
.steps li::before{content:counter(step);position:absolute;left:0;top:2px;font-family:var(--font);
  font-size:10px;font-weight:700;color:var(--blue);border:1.5px solid var(--blue);border-radius:50%;
  width:18px;height:18px;display:flex;align-items:center;justify-content:center}

/* ---- Dialogs ---- */
dialog#reportDlg{border:1px solid var(--line-2);border-radius:14px;background:var(--surface);
  color:var(--text);padding:24px 26px;width:min(440px,92vw)}
dialog#reportDlg::backdrop{background:rgba(11,37,69,.45)}
dialog#reportDlg h2{font-weight:800;font-size:15px;letter-spacing:-.01em;
  color:var(--ink);margin:0 0 6px}
dialog#reportDlg .hint{margin:0 0 16px}
.dlgfields label{display:flex;flex-direction:column;gap:5px;font-size:13px;color:var(--muted);margin-bottom:13px}
.dlgfields input,.dlgfields textarea{font-family:var(--font);font-size:14px;color:var(--ink);
  border:1.5px solid var(--line-2);border-radius:9px;padding:7px 10px;background:#fff;width:100%}
.dlgfields textarea{resize:vertical;min-height:78px;line-height:1.5}
.dlgfields input::placeholder,.dlgfields textarea::placeholder{color:var(--muted);opacity:.7}
.lab-opt{font-weight:400;color:var(--muted);text-transform:none;letter-spacing:0}
.char-count{align-self:flex-end;font-size:11px;color:var(--muted);margin-top:-1px}
.dlgrow{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.dlgfields input[type=file]{font-size:13px;color:var(--text);border:1.5px dashed var(--line-2);
  background:var(--input-fill);padding:9px 10px;border-radius:9px;cursor:pointer;width:100%}
.logo-row{display:flex;align-items:center;gap:12px;margin:-4px 0 13px}
.logo-row img{max-height:48px;max-width:160px;border:1px solid var(--line);border-radius:7px;
  padding:5px 8px;background:#fff;object-fit:contain}
.dlgactions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}

dialog#pasteDlg{border:1px solid var(--line-2);border-radius:14px;background:var(--surface);
  color:var(--text);padding:24px 26px;width:min(620px,94vw)}
dialog#pasteDlg::backdrop{background:rgba(11,37,69,.45)}
dialog#pasteDlg h2{font-weight:800;font-size:15px;letter-spacing:-.01em;
  color:var(--ink);margin:0 0 6px}
dialog#pasteDlg .hint{margin:0 0 14px}
dialog#pasteDlg textarea{font-family:var(--mono);font-size:12px;color:var(--input-color);
  border:1.5px solid var(--line-2);border-radius:9px;padding:10px 12px;background:var(--input-fill);
  width:100%;min-height:130px;resize:vertical;line-height:1.6;margin-bottom:14px;
  white-space:pre;overflow-wrap:normal}
dialog#pasteDlg textarea::placeholder{font-family:var(--font);font-size:13px;color:var(--muted);line-height:1.55;white-space:normal}

/* ---- Data section ---- */
.datadefs{margin:-4px 0 16px}
.datadefs p{font-size:14px;color:var(--muted);margin:0 0 7px;max-width:88ch}
.datadefs strong{color:var(--ink);font-weight:700}

/* ---- Verdict ---- */
.verdict{margin:0}
.vmain{font-weight:800;font-size:19px;line-height:1.2;letter-spacing:-.01em;color:var(--green)}
.vsub{margin-top:8px}
.vsub .vlead{display:block;font-size:13px;color:var(--muted);margin:0 0 9px}
.vsub .vstat{display:flex;align-items:baseline;gap:10px;margin:0 0 5px}
.vsub .vlab{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--muted);min-width:64px}
.vsub b{font-weight:800;font-size:18px;color:var(--ink);font-variant-numeric:tabular-nums}
.vsub b.pos{color:var(--green)} .vsub b.neg{color:var(--red)}
.vsub em{font-style:normal;font-size:12px;color:var(--muted)}

/* ---- Panels ---- */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:20px 24px;margin-bottom:16px}
.panelrow{display:grid;grid-template-columns:minmax(300px,2fr) 3fr;gap:16px;align-items:start;margin-bottom:16px}
.panelrow .panel{margin-bottom:0}
.panelrow.flip{grid-template-columns:1fr 1fr;align-items:stretch}
.panelrow.flip .panel{height:100%;box-sizing:border-box}
@media(max-width:900px){.panelrow.flip{grid-template-columns:1fr}}
.panelrow .controls{flex-direction:column;align-items:stretch;gap:20px;margin:6px 0 4px}
.panelrow .ctrl{min-width:0}
@media(max-width:900px){.panelrow{grid-template-columns:1fr}}
.panel h2{font-weight:800;font-size:14px;letter-spacing:.04em;text-transform:uppercase;
  color:var(--ink);margin:0 0 14px}
.muted{color:var(--muted);font-weight:400;font-size:13px;text-transform:none;letter-spacing:0}
.paneltop{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}
.paneltop h2{margin:0}

/* ---- Breakdown / charts ---- */
.legend{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;font-size:13px;color:var(--muted);margin-bottom:6px}
.legend.left{justify-content:flex-start;margin-bottom:10px}
.legend span{display:flex;align-items:center;gap:6px}

.panelrow-bottom{grid-template-columns:3fr 2fr;align-items:end}
@media(max-width:900px){.panelrow-bottom{grid-template-columns:1fr}}
.breakdown-body{display:flex;align-items:flex-start;gap:32px}
.breakdown-legend{display:flex;flex-direction:column;gap:14px;min-width:100px;padding-top:28px;flex-shrink:0}
.breakdown-legend span{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}

.breakdown-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:998}
.breakdown-expanded{position:fixed!important;inset:24px;z-index:999;overflow-y:auto;box-shadow:0 12px 48px rgba(11,37,69,.25)}
.breakdown-expanded .donutbox{height:240px}
.breakdown-expanded .pies{grid-template-columns:repeat(2,minmax(0,400px));gap:40px}
.breakdown-expanded .donutstats{grid-template-columns:repeat(4,1fr)}
.sw{width:11px;height:11px;border-radius:2px;display:inline-block}
.sw.cos{background:var(--gray)} .sw.roy{background:var(--amber-dark)} .sw.con{background:var(--green-dark)}

.pies{display:grid;grid-template-columns:repeat(2,minmax(0,320px));gap:32px;margin-bottom:0}
figure{margin:0;text-align:center}
figcaption{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);margin-bottom:8px}
.donutbox{position:relative;height:220px}
.ct{position:absolute;top:50%;left:50%;transform:translate(-50%,-52%);text-align:center;pointer-events:none}
.cv{display:block;font-weight:800;font-size:26px;color:var(--green);line-height:1}
.cl{display:block;font-size:10px;color:var(--muted);margin-top:4px;text-transform:uppercase;letter-spacing:.04em}

.donutstats{display:flex;flex-direction:column;gap:3px;margin-top:10px}
.ds-item{background:var(--kpi-fill);border-radius:8px;padding:5px 10px;display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:8px}
.ds-lab{font-size:11px;font-weight:600;color:var(--muted);flex:1;text-align:left;white-space:nowrap}
.ds-val{font-size:12px;font-weight:700;color:var(--ink);text-align:right;white-space:nowrap}
.ds-val.ds-neg{color:var(--red)}

.matrices{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.matrixbox{position:relative;height:320px}
@media(max-width:900px){.matrices{grid-template-columns:1fr}}

/* ---- Lever / what this means ---- */
.lever{background:var(--blue-tint);border-radius:9px;padding:9px 14px;margin:10px 0 0;font-size:13px;border:1px solid var(--line)}
.leverlab{color:var(--muted);font-weight:600;margin-right:8px}
#leverTxt{font-weight:500;color:var(--text)}

/* ---- Summary table ---- */
table.summary{width:100%;max-width:760px;border-collapse:collapse;font-size:14px}
.summary th{text-align:right;font-weight:600;color:var(--muted);font-size:12px;padding:6px 10px;
  border-bottom:1px solid var(--line-2)}
.summary th:first-child{text-align:left}
.summary td{text-align:right;padding:7px 10px;border-bottom:1px solid var(--line)}
.summary td:first-child{text-align:left}
.summary tr:last-child td{border-bottom:none}
.summary tr.tot td{background:var(--blue-tint);font-weight:700}
.delta-pos{color:var(--green)} .delta-neg{color:var(--red)}

/* ---- Data grid ---- */
.gridscroll{overflow-x:auto}
table.grid{border-collapse:collapse;font-size:13px;width:100%;table-layout:fixed;min-width:1100px}
.grid th:last-child{width:34px}
.grid th.rownum{width:30px;text-align:right}
.grid td.rownum{padding:6px 8px;text-align:right;color:var(--muted);font-size:12px}
.grid th{font-size:11px;font-weight:600;color:var(--muted);text-align:right;padding:7px 8px;
  background:var(--blue-tint);border-bottom:1px solid var(--line-2);white-space:nowrap;vertical-align:bottom}
.grid th.item{text-align:left;width:16%;min-width:150px}
.thsub{display:block;font-weight:400;font-size:10px;color:var(--muted);opacity:.85}
.grid th.sortable{cursor:pointer;user-select:none}
.grid th.sortable:hover{color:var(--blue)}
.grid th.sorted{color:var(--blue)}
.grid th .sarrow{font-size:9px}
.grid td{padding:0;border-bottom:1px solid var(--line);text-align:right}
.grid td.calc{padding:6px 8px;color:var(--ink)}
.grid td.item{text-align:left}
.grid tr.tot td{background:var(--blue-tint);font-weight:700;padding:7px 8px}
.grid input{border:none;background:#F1F3F7;color:var(--ink);font-family:var(--font);
  font-size:13px;width:100%;padding:6px 8px;text-align:right;border-radius:0;box-sizing:border-box}
.grid input.name{text-align:left}
.grid input::placeholder{color:var(--muted);opacity:.6;font-weight:400}
.mwrap{display:inline-flex;flex-direction:column;align-items:flex-end;gap:3px;line-height:1.15}
.mval{font-variant-numeric:tabular-nums}
.mbar{width:46px;height:5px;background:#e6e9ef;border-radius:3px;overflow:hidden;
  -webkit-print-color-adjust:exact;print-color-adjust:exact}
.mbar-fill{display:block;height:100%;background:#16A363;border-radius:3px}
.mbar-fill.loss{background:#C0392B}
.mval.loss{color:#C0392B}
.metric-note{font-size:12px;color:var(--muted);line-height:1.5;margin:12px 0 0;max-width:78ch}
.gtip{position:fixed;z-index:9999;max-width:280px;background:var(--ink);color:#fff;
  font-family:var(--font);font-size:12px;font-weight:500;line-height:1.45;padding:8px 11px;
  border-radius:8px;box-shadow:0 8px 24px rgba(11,37,69,.22);pointer-events:none}
.grid input:focus{outline:none;background:#fff;box-shadow:inset 0 0 0 2px rgba(28,95,229,.35)}
.grid td.del{padding:0 4px}
.delbtn{border:none;background:none;color:var(--muted);cursor:pointer;font-size:15px;line-height:1;padding:4px 6px;border-radius:6px}
.delbtn:hover{background:var(--blue-soft);color:var(--blue-deep)}

/* ---- Footer ---- */
.foot{margin-top:8px;font-size:13px;color:var(--muted);line-height:1.6}
.foot p{margin:0 0 4px}
.foot a{color:var(--muted)}
.foot a:hover{color:var(--blue)}

@media(max-width:640px){
  h1{font-size:24px}
  .wrap{padding:14px 16px 40px}
  .masthead{flex-direction:column;align-items:flex-start}
  /* templatebar: stack label above buttons */
  .templatebar{flex-direction:column;gap:10px}
  .templatebtns{width:100%;flex-shrink:1}
  /* breakdown: legend across the top, donuts side-by-side below */
  .breakdown-body{flex-direction:column}
  .breakdown-legend{flex-direction:row;padding-top:0;min-width:unset;margin-bottom:10px}
  .pies{grid-template-columns:1fr 1fr;width:100%}
  .donutbox{height:min(52vw,220px)}
}

/* ---------- PDF report (print only) ---------- */
#report{display:none}
@media print{
  @page{margin:14mm 0}
  body{background:#fff;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .wrap{display:none}
  dialog{display:none!important}
  #report{display:block;font-family:var(--font);color:var(--ink);font-size:9px;line-height:1.5;
    padding:0 15mm;box-sizing:border-box}

  .rpt-doc{width:100%;border-collapse:collapse;border:0}
  .rpt-doc>thead>tr>td{padding:0 0 26px}
  .rpt-doc>tbody>tr>td{padding:0}
  .rpt-foot-space{height:15mm;padding:0;border:0}
  .rpt-footfix{position:fixed;left:0;right:0;bottom:0;padding:0 15mm 4mm;box-sizing:border-box}
  .rpt-runhead{display:flex;justify-content:space-between;align-items:flex-end;
    padding-bottom:6px;border-bottom:1.5px solid var(--ink)}
  .rpt-top-left{display:flex;flex-direction:column}
  .rpt-tool{display:block;font-size:7.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);font-weight:700}
  .rpt-by{display:block;font-size:7px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:2px}
  .rpt-date{display:block;font-size:7px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
  .rpt-head{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-top:2px}
  .rpt-head-text{flex:1;min-width:0}
  .rpt-userlogo{flex:none;max-width:320px;text-align:right;padding-top:2px}
  .rpt-userlogo img{max-height:120px;max-width:320px;width:auto;height:auto;object-fit:contain;display:inline-block}

  .rpt-h1{font-weight:800;font-size:25px;letter-spacing:-.02em;color:var(--ink);margin:12px 0 8px;line-height:1.02}
  .rpt-meta-line{display:block;margin:0 0 26px}
  .rpt-notes{margin:0 0 26px;padding:10px 13px;background:#F6F7FA;border-left:3px solid var(--line-2);border-radius:4px}
  .rpt-notes-lab{font-size:8px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
  .rpt-notes-body{font-size:10px;line-height:1.55;color:var(--ink)}
  .rpt-menu .mwrap{gap:2px}
  .rpt-menu .mbar{width:32px;height:4px}
  .rpt-menu td.mcell{white-space:nowrap}
  .rv-mark{flex:none;font-size:8px;margin-right:6px;line-height:1}
  .rv-mark.low{color:#C68A1F}
  .rv-mark.high{color:#16A363}
  .rpt-review{display:flex;gap:14px;margin:0 0 26px;break-inside:avoid}
  .rv-block{flex:1;border:1px solid var(--line-2);border-radius:8px;padding:9px 12px;background:#fafbfc}
  .rv-h{font-size:8px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);margin-bottom:6px}
  .rv-h span{font-weight:400;letter-spacing:0;text-transform:none;color:var(--muted)}
  .rv-item{display:flex;align-items:center;font-size:9.5px;padding:3px 0;border-bottom:.5px solid var(--line)}
  .rv-item:last-child{border-bottom:none}
  .rv-name{flex:1;color:var(--ink);overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
  .rv-val{flex:none;color:var(--muted);font-variant-numeric:tabular-nums;margin-left:8px}
  .rv-empty{font-size:9px;color:var(--muted);line-height:1.5}
  .rpt-caveat{font-size:8px;font-style:italic;color:var(--muted);line-height:1.45;margin:-16px 0 22px}
  .rpt-meta-line span{display:block;font-size:10px;color:var(--ink);margin-bottom:3px;line-height:1.4}
  .rpt-meta-line b{display:inline-block;min-width:96px;font-weight:700;color:var(--ink)}

  .rpt-kpis{display:flex;gap:9px;margin:0 0 30px}
  .rkpi{flex:1;background:var(--blue-tint);border-top:1.5px solid var(--ink);padding:7px 10px 8px}
  .rkpi.profit{border-top-color:var(--green-dark)}
  .rkpi.royalty{border-top-color:var(--amber-dark)}
  .rk-lab{display:block;font-size:6px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
  .rk-num{display:block;font-weight:800;font-size:16px;color:var(--ink);line-height:1.05;
    margin:3px 0 2px;font-variant-numeric:tabular-nums}
  .rk-num.pos{color:var(--green-dark)} .rk-num.neg{color:var(--red)} .rk-num.amber{color:var(--amber-dark)}
  .rk-sub{display:block;font-size:6.5px;color:var(--muted)}

  .rpt-verdict{border:none;border-left:3px solid;border-radius:3px;padding:10px 14px;margin:0 0 32px}
  .rpt-verdict.win{border-left-color:var(--green-dark);background:rgba(22,163,99,.06)}
  .rpt-verdict.lose{border-left-color:var(--red);background:rgba(192,57,43,.06)}
  .rv-main{font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:.01em;margin-bottom:4px}
  .rpt-verdict.win .rv-main{color:var(--green-dark)}
  .rpt-verdict.lose .rv-main{color:var(--red)}
  .rv-sub{font-size:9.5px;color:var(--ink);line-height:1.55}
  .rv-sub b.pos{color:var(--green-dark)} .rv-sub b.neg{color:var(--red)}

  .rpt-h2{font-weight:700;font-size:8px;text-transform:uppercase;letter-spacing:.1em;
    color:var(--ink);margin:0 0 10px;padding-bottom:4px;border-bottom:1.5px solid var(--ink)}
  .rpt-h2 span{font-weight:400;color:var(--muted);text-transform:none;letter-spacing:0}
  .rpt-h2.brk{break-before:page}

  .rpt-pies{display:flex;gap:72px;justify-content:center;margin:18px 0 26px;break-inside:avoid}
  .rpt-pies figure{margin:0;text-align:center}
  .rpt-pies svg{width:200px;height:200px;display:block}
  .rpt-pies figcaption{font-size:7px;letter-spacing:.04em;color:var(--muted);margin-top:6px;line-height:1.6}
  .rpt-pies figcaption b{display:block;color:var(--ink);font-size:7.5px;letter-spacing:.1em;margin-bottom:1px}

  .rpt-legend{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;
    font-size:7.5px;color:var(--muted);margin:0 0 30px}
  .rleg-dot{display:inline-block;width:7px;height:7px;border-radius:1px;vertical-align:middle;margin-right:2px}

  table.rpt-sum{width:100%;border-collapse:collapse;margin-bottom:0}
  .rpt-sum th{font-size:7px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
    color:var(--muted);text-align:right;padding:4px 7px;border-bottom:1.5px solid var(--ink)}
  .rpt-sum td{text-align:right;padding:4px 7px;border-bottom:.5px solid var(--line-2);
    font-size:9px;font-variant-numeric:tabular-nums}
  .rpt-sum th.l,.rpt-sum td.l{text-align:left}
  .rpt-sum tr.tot td{font-weight:700;border-top:1.5px solid var(--ink);border-bottom:none;background:rgba(28,95,229,.04)}
  .rpt-sum td.pos{color:var(--green-dark)} .rpt-sum td.neg{color:var(--red)}

  table.rpt-menu{width:100%;border-collapse:collapse;font-size:8px;table-layout:fixed}
  .rpt-menu th{font-size:6.5px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;
    color:var(--muted);text-align:right;padding:4px 4px;border-bottom:1.5px solid var(--ink);
    background:var(--blue-tint);white-space:nowrap;overflow:hidden}
  .rpt-menu td{text-align:right;padding:3.5px 4px;border-bottom:.5px solid var(--line);
    overflow:hidden;white-space:nowrap;font-variant-numeric:tabular-nums}
  .rpt-menu th.l,.rpt-menu td.l{text-align:left}
  .rpt-menu th.n,.rpt-menu td.n{text-align:right;color:var(--muted)}
  .rpt-menu td.l{text-overflow:ellipsis}
  .rpt-menu tr.tot td{font-weight:700;border-top:1.5px solid var(--ink);border-bottom:none;background:rgba(28,95,229,.04)}
  .rpt-menu.brk{break-before:page}
  .rpt-menu.split{margin-top:30px}
  .rpt-menu thead{display:table-header-group}
  .rpt-menu tr{break-inside:avoid}
  .rpt-menu-cap th{background:transparent;text-align:left;font-size:9px;font-weight:700;
    text-transform:uppercase;letter-spacing:.1em;color:var(--ink);white-space:normal;
    border-bottom:none;padding:0 0 7px}

  .rpt-foot{border-top:.5px solid var(--line-2);padding-top:8px;margin-top:0}
  .rf-main{display:block;font-size:8.5px;font-weight:400;color:var(--muted);line-height:1.45}
  .rf-copy{display:block;font-size:7px;color:var(--muted)}
}

/* dual paste dialog */
.paste-dual{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:16px 0}
.paste-col{display:flex;flex-direction:column;gap:8px}
.paste-label{font-weight:700;font-size:13px;letter-spacing:.03em;text-transform:uppercase;color:var(--ink)}
.paste-steps{margin:0 0 14px;padding:0 0 0 18px;font-size:13.5px;color:var(--ink);line-height:1.65}
.paste-steps li{margin-bottom:5px}
.paste-steps li:last-child{margin-bottom:0}
#pasteBoxCurrent,#pasteBoxProposed{font-family:var(--mono);font-size:12px;border:1.5px solid var(--line-2);border-radius:9px;padding:10px 12px;resize:vertical;min-height:120px;color:var(--ink);background:#fff;transition:border-color .12s}
#pasteBoxCurrent:focus,#pasteBoxProposed:focus{outline:none;border-color:var(--blue)}
@media(max-width:600px){.paste-dual{grid-template-columns:1fr}}

.variant-subtitle{font-size:20px;font-weight:500;color:var(--muted);letter-spacing:0}
.variant-link{font-size:13px;color:var(--muted);margin-top:8px}
.variant-link a{color:var(--blue);text-decoration:none;font-weight:600}
.variant-link a:hover{text-decoration:underline}
