/* ============================================================
   fnbtoolkit.com — TOOL SCAFFOLD stylesheet
   ------------------------------------------------------------
   This is the SHARED shell stylesheet. Everything here is the
   fixed system that must look identical on every tool — copy it
   verbatim when you clone this folder, and DO NOT restyle it.

   The only place you add tool-specific CSS is the clearly marked
   "BESPOKE ZONE" near the bottom. Reuse the shared components
   (.grid, .panel, inputs, .kpi, .vmain, .chartbox, donut classes)
   before inventing anything — see DESIGN-SYSTEM.md §5.

   Source of truth: menu-engineering / menu-planning-tool.
   ============================================================ */

: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:16px;line-height:1.6;
  font-variant-numeric:tabular-nums;-webkit-font-smoothing:antialiased}
.wrap{max-width:1560px;margin:0 auto;padding:20px 30px 30px}
.wrap:has(> .foot){padding-bottom:0}

/* ---- Masthead (title + description only — no buttons) ---- */
.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:13px}
.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}

/* ---- Royalty / commission toggle + segmented controls ---- */
.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:13px;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:13px;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}
.fee-opt:focus-visible{outline:2px solid var(--blue);outline-offset:1px;position:relative;z-index:1}
.btn:focus-visible{outline:2px solid var(--blue);outline-offset:2px}
#royRateCtrl[hidden]{display:none}

/* ---- Control bar / toolbar ----
   Left group (How-to + currency) pinned left via 768-gated margin-right:auto;
   right group (royalty, VAT, Reset, Undo) stays right and drops as one unit. */
.panel.toolbar{display:flex;justify-content:flex-end;align-items:center;gap:12px 18px;flex-wrap:wrap;
  padding-top:14px;padding-bottom:14px}
.toolbar-left{display:flex;align-items:center;gap:12px 18px;flex-wrap:wrap}
@media(min-width:768px){.toolbar-left{margin-right:auto}}
.toolbar-right{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}
.toolbar .royalty-ctrl{border:0;background:transparent;padding:0}
.toolbar .action-btns{gap:8px}

/* VAT field — inline in the toolbar, grey fill matching grid cells */
.vat-inline{display:flex;align-items:center;gap:8px}
.vat-inline label{font-size:13px;font-weight:600;color:var(--ink);white-space:nowrap}
.vat-inline input[type=number]{width:64px;background:#fff;color:var(--ink);font-family:var(--font);
  font-size:13px;border:none;box-shadow:inset 0 0 0 1px #DCE3EE;border-radius:6px;padding:6px 8px;text-align:center}
.vat-inline .pct{color:var(--muted)}

/* ---- 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:600;color:var(--muted);white-space:nowrap}
.ctrl .pct{color:var(--muted)}
.roy-pct{display:inline-flex;align-items:center;gap:3px}
.roy-pct input[type=number]{width:84px;text-align:center;padding:5px 8px;border:none;
  border-radius:6px;font:inherit;font-size:13px;background:#fff;color:var(--ink);box-shadow:inset 0 0 0 1px #DCE3EE}
.roy-pct input[type=number]:focus{box-shadow:inset 0 0 0 2px rgba(28,95,229,.35)}
.roy-pct .pct{color:var(--muted);font-size:13px}
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:13px;color:var(--ink);width:84px;
  text-align:center;border:none;border-radius:6px;padding:5px 8px;
  background:#fff;box-shadow:inset 0 0 0 1px #DCE3EE}
input:focus{outline:2px solid rgba(28,95,229,.35);outline-offset:0}

/* ---- Hints & notes ---- */
.hint{font-size:13px;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}

/* ---- Report-details dialog ---- */
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:16px;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:13px;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}
.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}

/* ---- Verdict block (the plain-English answer) ---- */
.verdict{margin:0}
.vmain{font-weight:800;font-size:20px;line-height:1.2;letter-spacing:-.01em;color:var(--green)}
.vmain.bad{color:var(--red)}
.vmain.flat{color:var(--ink)}
.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:16px;color:var(--ink);font-variant-numeric:tabular-nums}
.vsub b.pos{color:var(--green)} .vsub b.neg{color:var(--red)} .vsub b.warn{color:var(--amber)}
.vsub em{font-style:normal;font-size:13px;color:var(--muted)}

/* "What this means" lever */
.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}

/* ---- KPI tiles (DESIGN-SYSTEM §5.8) ---- */
.kpirow{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:14px;padding:15px 16px 14px;box-shadow:0 1px 3px rgba(11,37,69,.06);text-align:center}
.kpi-lab{display:block;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.kpi-num{display:block;font-weight:800;font-size:20px;color:var(--ink);line-height:1.1;margin:9px 0 3px;font-variant-numeric:tabular-nums}
.kpi-num.pos{color:var(--green)} .kpi-num.neg{color:var(--red)} .kpi-num.amber{color:var(--amber)}
.kpi-sub{display:block;font-size:11px;color:var(--muted)}
.kpi-tag{display:inline-block;font-size:11px;font-weight:700;line-height:1;padding:3px 8px;border-radius:999px;margin:1px 0 3px;letter-spacing:.01em}
.kpi-tag.pos{background:#E7F5EE;color:#0E7C4F}
.kpi-tag.neg{background:#FBEAEA;color:var(--red)}
.kpi-tag.warn{background:#FBF1E2;color:var(--amber-dark)}
@media(max-width:767px){.kpirow{grid-template-columns:1fr 1fr}}

/* ---- Chips & badges (DESIGN-SYSTEM §5.9) ---- */
.chip{display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:2px 9px;border-radius:10px}
.chip.pos{background:var(--green-soft);color:var(--green)}
.chip.warn{background:#FBF1DD;color:var(--amber-dark)}
.chip.neg{background:rgba(192,57,43,.1);color:var(--red)}
.chip.neutral{background:#EEF1F6;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;min-width:0}
/* verdict + breakdown: equal columns, equal height (cards stretch), same balance as
   discount-breakeven — KPIs go 2×2 in the half-width panel and the "Bundling adds…" line
   anchors to the bottom so neither card is left half-empty. */
.panelrow.flip{grid-template-columns:1fr 1fr;align-items:stretch}
.panelrow.flip .panel{height:100%;box-sizing:border-box;display:flex;flex-direction:column}
.panelrow.flip .kpirow{grid-template-columns:1fr 1fr}
/* verdict (left): centre the statement + lever vertically so it isn't pinned to the top —
   keeps this card the same height as the taller breakdown card without dead space at the foot */
.verdict-panel .verdict{margin-top:auto}
.verdict-panel .lever{margin-bottom:auto}
/* breakdown (right): the four KPI tiles sit beneath the P&L, divided off with a little space */
.breakdown-panel #kpiRow{margin-top:20px;padding-top:18px;border-top:1px solid var(--line)}
@media(max-width:1024px){.panelrow,.panelrow.flip{grid-template-columns:1fr}}
.panel h2{font-weight:800;font-size:16px;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}
.hint-tip{display:inline-flex;vertical-align:middle;margin-left:8px;color:var(--muted);cursor:help}
.hint-tip:hover{color:var(--blue)}

/* ---- Charts: legend, donut, generic chart box ---- */
.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}
.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)}
.sw.profit{background:var(--green)} .sw.blue{background:var(--blue)}

.chartbox{position:relative;height:300px}            /* generic; set height inline per chart */

/* Break-even / profit-by-volume chart — ported verbatim from event-P&L */
.bechartbox{position:relative;height:340px;margin-top:6px}
@media(max-width:640px){.bechartbox{height:240px}}

/* Sales-volume slider under the chart — ported from event-P&L's covers slider */
.covers-slider{margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.cs-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px;max-width:50%}
.cs-label{font-size:13px;font-weight:600;color:var(--muted)}
.cs-caution{display:inline-flex;vertical-align:-2px;margin-left:6px;color:var(--amber,#E2A437);cursor:help}
.cs-caution:hover{color:#b5731a}
.cs-val{font-size:16px;font-weight:800;color:var(--ink);font-variant-numeric:tabular-nums;min-width:48px;text-align:right}
#liftRange{width:100%;max-width:50%;height:4px;-webkit-appearance:none;appearance:none;background:var(--line-2);border-radius:3px;outline:none;cursor:pointer}
#liftRange::-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}
#liftRange::-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}
/* keep the chart slider to ~half width like the Sales-forecast slider; full width on phones */
@media(max-width:640px){.cs-row,#liftRange{max-width:none}}
.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:20px;color:var(--green);line-height:1}
.cl{display:block;font-size:11px;color:var(--muted);margin-top:4px;text-transform:uppercase;letter-spacing:.04em}
.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}
.donutstats{display:flex;flex-direction:column;gap:3px}
.ds-item{padding:3px 2px;display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:8px;border-bottom:1px solid var(--line)}
.ds-item:last-child{border-bottom:none}
.ds-lab{font-size:11px;font-weight:600;color:var(--muted);flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ds-val{font-size:11px;font-weight:700;color:var(--ink);text-align:right;white-space:nowrap}
.ds-val.ds-neg{color:var(--red)}
/* donut + side-key wrapper — standard component (DESIGN-SYSTEM §6) */
.bd-body{display:flex;gap:28px;align-items:center;justify-content:center;flex-wrap:wrap}
.bd-body .donutstats{flex:0 0 auto;width:280px}
@media(max-width:640px){.bd-body{flex-direction:column;align-items:stretch;gap:12px}.bd-body .donutbox{align-self:center}.bd-body .donutstats{width:100%}}

/* ---- Summary table (generic read-only figures) ---- */
table.summary{width:100%;max-width:760px;border-collapse:collapse;font-size:13px}
.summary th{text-align:center;font-weight:600;color:var(--muted);font-size:11px;padding:6px 10px;border-bottom:1px solid var(--line-2)}
.summary th:first-child{text-align:left}
.summary td{text-align:center;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)}

/* ---- Editable data grid (DESIGN-SYSTEM §5.6 — ALWAYS reuse, never hand-roll) ---- */
.gridscroll{overflow-x:auto}
.grid-scrollhint{display:none}
@media(max-width:767px){
  .grid-scrollhint{display:flex;gap:7px;align-items:flex-start;font-size:13px;color:var(--blue-deep);
    background:var(--blue-tint);border:1px solid var(--line);border-radius:8px;padding:8px 11px;margin:-2px 0 12px;line-height:1.45}
}
table.grid{border-collapse:collapse;font-size:13px;width:100%;table-layout:fixed;min-width:760px}
.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:13px;background:#F5F9FE}
.grid th{font-size:11px;font-weight:600;color:var(--muted);text-align:center;padding:7px 8px;
  background:var(--blue-tint);border-bottom:1px solid var(--line-2);white-space:normal;line-height:1.2;vertical-align:bottom}
.grid th.item{text-align:left;width:24%;min-width:150px}
.thsub{display:block;font-weight:400;font-size:11px;color:var(--muted);opacity:.85}
.grid th[data-tip]{cursor:help}
.grid td{padding:0;border-bottom:1px solid var(--line);text-align:center;background:#fff}
.grid td.calc{padding:6px 8px;color:var(--ink);background:#F5F9FE}
.grid td.calc.emph{font-weight:700;color:var(--ink)}
.grid td:not(.calc)+td.calc{border-left:1px solid #DBE5F3}
.grid th,.grid td{border-right:1px solid var(--line)}
.grid th:last-child,.grid td:last-child{border-right:none}
.grid tr:not(.tot):hover td.calc{background:#E9F1FC}
.grid td.item{text-align:left;position:relative}
.eg-badge{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:11px;font-style:normal;letter-spacing:.04em;text-transform:uppercase;color:#b4bdcb;pointer-events:none;white-space:nowrap}
.grid tr.tot td{background:var(--blue-tint);font-weight:700;padding:7px 8px;border-top:1.5px solid var(--line-2)}
.grid input{border:none;background:transparent;color:var(--ink);font-family:var(--font);
  font-size:13px;width:100%;padding:6px 8px;text-align:center;border-radius:0;box-sizing:border-box}
.grid input.name{text-align:left;padding-right:16px}
.grid input::placeholder{color:var(--muted);opacity:.6;font-weight:400}
.grid input:focus{outline:none;background:#fff;box-shadow:inset 0 0 0 2px rgba(28,95,229,.35)}
/* Type select — matches the grid inputs (full-cell, centred, same height/look) */
.grid td.type{padding:0}
.grid select.typesel{border:none;background:transparent;color:var(--ink);font-family:var(--font);
  font-size:13px;font-weight:400;width:100%;padding:6px 8px;text-align:center;text-align-last:center;
  border-radius:0;box-sizing:border-box;cursor:pointer;-webkit-appearance:none;appearance:none}
.grid select.typesel: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:16px;line-height:1;padding:4px 6px;border-radius:6px}
.delbtn:focus-visible{outline:2px solid var(--blue);outline-offset:1px}
.delbtn:hover{background:var(--blue-soft);color:var(--blue-deep)}
.metric-note{font-size:13px;color:var(--muted);line-height:1.5;margin:12px 0 0;max-width:78ch}
.metric-note a{color:var(--blue);font-weight:600;text-decoration:underline;text-underline-offset:2px}

/* ---- "Your data" cards ---- */
#royaltyPanel[hidden]{display:none}

/* ---- Footer ---- */
.foot{background:#fff;border-top:1px solid var(--line);padding:14px 0;margin-top:0}
.foot .wrap{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.foot a,.foot span{font-weight:600;font-size:13px;color:var(--muted);text-decoration:none}
.foot a:hover{color:var(--blue)}

/* ---- Shared mobile (≤640px). Toolbar/datagroup mobile rules live in the
        page's inline <style> 767 block — see index.html. ---- */
@media(max-width:640px){
  h1{font-size:24px}
  .wrap{padding:12px 14px 40px}
  body{font-size:16px}
  .masthead{flex-direction:column;align-items:flex-start;padding:18px 16px 16px}
  .btn{padding:11px 16px;min-height:44px;font-size:14px}
  .btn.small{padding:9px 12px;min-height:40px;font-size:13px}
  .fee-opt{padding:10px 14px;min-height:40px;font-size:13px}
  .fee-opts{flex-direction:row;flex-wrap:wrap;align-items:center;gap:8px}
  .fee-lab{font-size:13px}
  .panel{padding:16px}
  .paneltop{flex-wrap:wrap;gap:8px}
  .paneltop .actions{width:100%;justify-content:flex-start;gap:8px}
  .paneltop .actions .btn{flex:1}
  .controls{flex-direction:column;align-items:stretch;gap:16px}
  .ctrl{min-width:0;width:100%}
  .gridscroll{-webkit-overflow-scrolling:touch}
  .grid input,.grid select.typesel{padding:9px 8px;min-height:42px;font-size:13px}
  table.summary{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%}
  .summary th,.summary td{padding:7px 8px;font-size:13px}
  .pies{grid-template-columns:1fr 1fr;width:100%}
  .donutbox{height:min(52vw,220px)}
}

/* ============================================================
   PDF REPORT (print only) — shared frame.
   Canonical pattern per DESIGN-SYSTEM.md §8.2:
   - #report holds ONE <div class="rpt-body"> + the .rpt-footfix footer.
     NEVER a <table class="rpt-doc"> wrapper (Chrome shoves it down the page).
   - @page{margin:0} kills the browser date/URL header. Visual margins come
     from #report padding.
   - EVERY break-before:page element must ALSO carry padding-top:12mm.
   - Long .rpt-menu tables get a .rpt-thead-pad spacer row for overflow pages.
   ============================================================ */
#report{display:none}
@media print{
  @page{margin:0}
  body{background:#fff;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  nav.nav{display:none!important}
  .wrap{display:none}
  dialog{display:none!important}
  #mobileBanner,#fnbCookie{display:none!important}
  #report{display:block;font-family:var(--font);color:var(--ink);font-size:9px;line-height:1.5;
    padding:12mm 15mm 20mm;box-sizing:border-box;word-spacing:0.1em}

  /* Fixed footer repeats on every page; #report padding-bottom keeps body clear of it */
  .rpt-footfix{position:fixed;bottom:0;left:0;right:0;background:#fff;padding:0 15mm 8px}
  .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)}

  /* Header block: kicker → H1 → meta line → plain-English purpose, optional logo */
  .rpt-head{display:flex;justify-content:space-between;align-items:flex-start;gap:20px}
  .rpt-head-text{flex:1;min-width:0}
  .rpt-userlogo{flex:none;max-width:320px;text-align:right}
  .rpt-userlogo img{max-height:120px;max-width:320px;width:auto;height:auto;object-fit:contain;display:inline-block}
  .rpt-kicker{font-size:8px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:0 0 5px}
  .rpt-h1{font-weight:800;font-size:22px;letter-spacing:-.02em;color:var(--ink);margin:4px 0 4px;line-height:1.02}
  .rpt-meta-line{display:block;margin:0 0 10px}
  .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-purpose{font-size:9.5px;color:var(--ink);line-height:1.5;margin:9px 0 16px;max-width:84ch}
  .rpt-notes{margin:6px 0 22px;padding:8px 11px;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)}

  /* Verdict banner — states the result AND that it is conditional on inputs */
  .rpt-verdict{border:none;border-left:3px solid;border-radius:3px;padding:10px 14px;margin:0 0 28px}
  .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)}

  /* KPI strip */

  /* Section heading; .brk forces a new page AND must carry padding-top:12mm */
  .rpt-h2{font-weight:700;font-size:8px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink);margin:0 0 10px}
  .rpt-h2 span{font-weight:400;color:var(--muted);text-transform:none;letter-spacing:0}
  .rpt-h2.brk{break-before:page;padding-top:12mm}
  .rpt-intro{font-size:8.5px;color:var(--muted);margin:0 0 14px;line-height:1.5}

  /* Summary table */
  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)}

  /* Data table (rows of items). thead repeats; the .rpt-thead-pad spacer row
     gives overflow pages a top margin WITHOUT an @page margin. */
  table.rpt-menu{width:100%;border-collapse:collapse;font-size:8px;table-layout:fixed}
  .rpt-menu thead{display:table-header-group}
  .rpt-menu .rpt-thead-pad td{height:12mm;padding:0;border:0;background:transparent}
  .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 td.l{text-overflow:ellipsis}
  .rpt-menu td.pos{color:var(--green-dark)} .rpt-menu td.neg{color:var(--red)}
  .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 tr{break-inside:avoid}
  .rpt-menu.brk{break-before:page;padding-top:12mm}

  /* In-report chart image (canvas → PNG, or inline SVG) */
  .rpt-chart{margin:4px 0 18px;text-align:center;break-inside:avoid}
  .rpt-chart img{max-width:100%;width:480px;height:auto;display:block;margin:0 auto}
  .rpt-chart svg{width:100%;max-width:540px;height:auto;display:block;margin:0 auto}
  .rpt-chart figcaption{font-size:7px;letter-spacing:.06em;color:var(--muted);margin-top:6px;text-transform:uppercase}

  .rpt-keep{break-inside:avoid}
}

/* ============================================================
   ╔══════════════════════════════════════════════════════════╗
   ║  BESPOKE ZONE — this tool's own component CSS goes here.   ║
   ║  Everything ABOVE is the shared shell: do not edit it.     ║
   ║  Rules of the road:                                        ║
   ║   • Reuse .grid / inputs / .panel / .kpi / .vmain /        ║
   ║     .chartbox / donut classes before inventing anything.   ║
   ║   • Use ONLY the :root tokens for colour — no new hexes    ║
   ║     except data-viz series (which live in chart-theme.js). ║
   ║   • NEVER add input{border/border-radius/background} here  ║
   ║     — it breaks the borderless grid look (DESIGN-SYS §5.6).║
   ║   • Any new print output: prefix classes rpt- and give     ║
   ║     every break-before:page element padding-top:12mm.      ║
   ╚══════════════════════════════════════════════════════════╝
   ============================================================ */

/* ---- Bundle analyser — "the deal" inputs ----
   Canonical standalone-input system, identical to the live tools
   (discount-breakeven / event-profit-loss): a .basic holds a label + an
   .inwrap with input.num. The input look is flat #F1F3F7, NO border, 6px
   radius, weight 400, LEFT-aligned. Never add border/background here. */
.basics{display:flex;gap:22px 26px;flex-wrap:wrap;align-items:flex-end}
.basic{display:flex;flex-direction:column;gap:5px}
.basic label{font-size:13px;font-weight:600;color:var(--ink);line-height:1.3}
.basic .basic-sub{display:block;font-size:11px;font-weight:400;color:var(--muted);margin-top:1px}
.basic .inwrap{display:flex;align-items:center;gap:6px}
.basic .inwrap input.num{width:84px;font-family:var(--font);font-size:13px;font-weight:400;padding:5px 8px;
  text-align:center;border:none;border-radius:6px;background:#fff;color:var(--ink);box-shadow:inset 0 0 0 1px #DCE3EE}
.basic .inwrap input.num:focus{outline:none;background:#fff;box-shadow:inset 0 0 0 2px rgba(28,95,229,.35)}
.basic .inwrap input.num-wide{width:104px}
.in-prefix,.in-suffix{font-size:13px;font-weight:400;color:var(--muted)}
.autofills-arrow{font-size:16px;color:var(--muted);align-self:flex-end;padding-bottom:6px;user-select:none}

/* uplift slider sits inline and fills the remaining width (kills the right-hand gap) */
.uplift-slide{display:flex;flex-direction:column;gap:6px;min-width:0}
.uplift-slide label{display:flex;justify-content:space-between;align-items:baseline;font-size:13px;
  font-weight:600;color:var(--muted);line-height:1.3;margin:0;gap:10px}
.uplift-slide .uplift-val{font-size:16px;font-weight:800;color:var(--ink);letter-spacing:-.01em}
.uplift-slide input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:16px;
  background:transparent;margin:5px 0 0;cursor:pointer}
.uplift-slide input[type=range]::-webkit-slider-runnable-track{height:5px;border-radius:999px;background:#E1E7F0}
.uplift-slide input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;margin-top:-5px;
  width:15px;height:15px;border-radius:50%;background:var(--blue);border:2px solid #fff;box-shadow:0 1px 2px rgba(11,37,69,.3)}
.uplift-slide input[type=range]::-moz-range-track{height:5px;border-radius:999px;background:#E1E7F0}
.uplift-slide input[type=range]::-moz-range-thumb{width:15px;height:15px;border:2px solid #fff;border-radius:50%;
  background:var(--blue);box-shadow:0 1px 2px rgba(11,37,69,.3)}
/* two columns: left = the deal controls (bundle price ⇄ discount + expected uplift on one
   row, then the two sliders stacked), right = the research read-out, hairline down the middle.
   Equal columns, top-aligned — same balance as the discount-breakeven forecast row. */
.deal-grid{display:grid;grid-template-columns:1fr 1px 1fr;gap:0 34px;align-items:stretch}
.deal-sep{align-self:stretch;width:1px;background:var(--line)}
.deal-slide{margin-top:18px}
.deal-col{display:flex;flex-direction:column;min-width:0}
.deal-col .target-result{margin-top:18px;align-self:stretch;flex:1}   /* fill remaining column height so both callouts match */
/* Top inputs row: "The deal" (left) beside "Separately vs bundled" (right), equal columns,
   equal height — copied verbatim from discount-breakeven. Stacks on narrow screens.
   Compound selector beats the shared base .panelrow rule (minmax/3fr). */
.panelrow.panelrow-inputs{grid-template-columns:1fr 1fr;align-items:start}
@media(max-width:767px){.panelrow.panelrow-inputs{grid-template-columns:1fr}}

/* Stacked input-group blocks within a panel (event-P&L style) — a hairline
   divider between each section, and matching h3 sub-headings so the two panels
   in the forecast row read identically. */
.input-group{padding-bottom:16px;margin-bottom:16px;border-bottom:1px solid var(--line)}
.input-group:last-of-type{border-bottom:none;padding-bottom:0;margin-bottom:0}
.input-group-head{font-size:13px;font-weight:700;letter-spacing:-.01em;text-transform:none;
  color:var(--ink);margin:0 0 12px}
.input-sep{border:none;border-top:1px dashed var(--line-2);margin:16px 0}
/* right column: Per sale + Forecast as two separate cards, each sized to its content */
.fc-col{display:flex;flex-direction:column;gap:16px}
.cos-metric{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:2px 0 14px}
.cos-metric .cm-q{font-size:13px;color:var(--muted)}

/* Budgeted COS / GP status line — green when the bundle hits target, red when it misses. */
.cos-status{font-size:13px;line-height:1.5;margin:10px 0 0;padding:8px 10px;border-radius:8px}
.cos-status:empty{display:none}
/* small read-only blended-target line under the food/drink inputs */
.cos-blend{font-size:11px;font-weight:600;color:var(--muted);margin:8px 0 0}
.cos-blend:empty{display:none}
.cos-status.ok{color:var(--green-dark);background:var(--green-soft)}
.cos-status.bad{color:var(--red);background:#FBEDEB}

/* Sales-forecast section (mirrors discount break-even) */
.target-row{display:grid;grid-template-columns:1fr 1fr;gap:26px;align-items:start}
.target-left{display:flex;flex-direction:column;min-width:0}
.target-left h2{margin:0 0 16px}
.target-controls{display:flex;flex-direction:column;gap:20px;min-width:0}
.target-basics{flex:0 0 auto;align-items:flex-end}
.target-row .target-result{margin-top:0}
.deal-basics + .deal-basics{margin-top:18px}
.panelrow.flip .target-result{flex:1}
/* Balanced deal/forecast grid: left col = deal then break-even check; right col = forecast spanning both */
.deal-grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start;margin-bottom:16px}
.deal-grid2>.panel{margin-bottom:0;min-width:0}
.deal-cell{grid-column:1;grid-row:1}
.forecast-cell{grid-column:2;grid-row:1}
.be-cell{grid-column:1/span 2;grid-row:2}
.deal-grid2 .panel .target-result{border:none;box-shadow:none;background:transparent;padding:0;margin-top:14px;border-left:3px solid var(--line-2);padding-left:14px}
/* keep the verdict/realism colour states visible in the deal grid (beats the 3-class rule above) */
.deal-grid2 .panel .target-result.tr-good{border-left-color:var(--green)}
.deal-grid2 .panel .target-result.tr-bad{border-left-color:#C0392B}
.deal-grid2 .panel .target-result.tr-warn{border-left-color:#C68A1F}
.deal-grid2 .panel .target-result.tr-neutral{border-left-color:var(--line-2)}
@media(max-width:1024px){.deal-grid2{grid-template-columns:1fr}.deal-cell,.forecast-cell,.be-cell{grid-column:1;grid-row:auto}}
/* read-only / auto-filled fields: greyed-out fill so editable (white) vs locked (grey) reads clearly */
.basic .inwrap input.num.ro{background:#F1F3F7;box-shadow:none;color:var(--muted);cursor:default}
.basic .inwrap input.num.ro:focus{background:#F1F3F7;box-shadow:none}
@media(max-width:767px){.target-row{grid-template-columns:1fr;gap:22px}}
#dealNote{margin-top:16px}
.legend.left .sw{flex:none}
@media(max-width:1024px){
  .deal-grid{grid-template-columns:1fr;gap:0}
  .deal-sep{width:auto;height:1px;align-self:auto;margin:22px 0}
}
@media(max-width:640px){
  .autofills-arrow{display:none}
  /* Inputs stay compact (84/104px) and the .basics flex-wrap row lets them sit two-up
     side by side (matches recipe-cost-calculator) instead of each on its own full-width
     row. Bundle-name keeps its own inline flex:1 1 100% so it spans the row. */
  /* Let the two comparison tables FILL the panel instead of shrinking to content
     (the generic table.summary{display:block} above makes a narrow table size to its content). */
  .summary.bd{display:table;width:100%}
}

/* before/after breakdown table (reuses the shared .summary look) */
#breakdownTable .summary.bd{width:100%;max-width:none;font-size:13px}
.summary.bd th{font-size:11px;font-weight:700;color:var(--muted)}
.summary.bd .bd-up{font-weight:600;color:var(--muted)}
.summary.bd tr.sub td{border-top:1px solid var(--line-2);font-weight:700;color:var(--ink)}
.summary.bd tr.tot td{background:var(--blue-tint);font-weight:800;color:var(--ink)}
.bd-diff{margin:11px 0 0;font-size:13px;font-weight:700}
.bd-diff.pos{color:var(--green)}
.bd-diff.neg{color:var(--red)}

/* research read — mirrors the discount break-even realism callout (.target-result) exactly */
.target-result{min-width:0;margin-top:16px;border:1px solid var(--line);border-left:3px solid var(--line-2);
  border-radius:12px;background:#fff;padding:16px 18px;box-shadow:0 1px 3px rgba(11,37,69,.05)}
.target-result[hidden]{display:none}
.target-result .tr-verdict{display:flex;gap:8px;align-items:flex-start}
.target-result .tr-vico{flex:none;margin-top:1px}
.target-result .tr-vbody{min-width:0}
.target-result .tr-main{font-size:13px;font-weight:700;margin:0 0 5px;line-height:1.5;color:var(--ink)}
.target-result .tr-sub{font-size:13px;color:var(--muted);line-height:1.5;margin:0}
.target-result.tr-good{border-left-color:var(--green)}
.target-result.tr-bad{border-left-color:#C0392B}
.target-result.tr-neutral{border-left-color:var(--line-2)}
.target-result .tr-note{font-size:13px;line-height:1.5;color:var(--muted);margin:0 0 13px;padding:0 0 13px;border-bottom:1px solid var(--line)}
.target-result .tr-note b{color:var(--ink);font-weight:700}
.target-result .tr-note.tr-caution{display:flex;gap:8px;align-items:flex-start}
.target-result .tr-note .tr-warn{flex:none;margin-top:1px;color:#C68A1F}
.target-result .tr-note .tr-lead{font-weight:800;color:var(--ink)}
.target-result .tr-note a{color:var(--ink);font-weight:600;text-decoration:underline;text-underline-offset:2px;text-decoration-color:rgba(11,37,69,.32);white-space:nowrap}
.target-result .tr-note a:hover{text-decoration-color:var(--ink)}
.target-result.tr-warn{border-left-color:#C68A1F}
.target-result .tr-verdict .tr-warn{flex:none;margin-top:1px;color:#C68A1F}
.target-result .tr-sub b{color:var(--ink);font-weight:700}
.target-result .tr-sub a{color:var(--ink);font-weight:600;text-decoration:underline;text-underline-offset:2px;text-decoration-color:rgba(11,37,69,.32);white-space:nowrap}
.target-result .tr-sub a:hover{text-decoration-color:var(--ink)}
.target-result .tr-deal{font-size:13px;color:var(--muted);line-height:1.5;margin:11px 0 0;padding-top:11px;border-top:1px solid var(--line)}

/* instant tooltip bubble (data-tip), identical to the live tools */
.gtip{position:fixed;z-index:9999;max-width:280px;background:var(--ink);color:#fff;white-space:pre-line;
  font-family:var(--font);font-size:13px;font-weight:600;line-height:1.45;padding:8px 11px;
  border-radius:8px;box-shadow:0 8px 24px rgba(11,37,69,.22);pointer-events:none}

/* ---- Verdict headline + At-a-glance KPIs (mirrors event-profit-loss) ----
   Split into two standard panels: a slim "Verdict" sentence (#forecastVerdictPanel)
   and an "At a glance" KPI grid (#glancePanel, sat beside the Price-breakdown donut).
   The KPI base/.kpi-lab/.kpi-num/.kpi-sub styles come from the shared shell above;
   these add the grid, the good/bad/warn card states, the .amb number colour and the
   verdict headline. The KPI grid is 2-up in its half-panel, auto-fit once stacked. */
#glancePanel .kpirow{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:0}
@media(max-width:1024px){#glancePanel .kpirow{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}}
.kpi-num.amb{color:var(--amber-dark)}
/* verdict headline — the lone child of the slim Verdict panel, so no bottom margin */
.fv-head{font-weight:700;font-size:16px;line-height:1.35;letter-spacing:-.005em;color:var(--ink);margin:0}
.fv-head .fv-bad{color:var(--red);font-weight:800}
.fv-head.neutral{color:var(--muted);font-weight:700;font-size:16px}
@media(max-width:767px){.fv-head{font-size:15px}}


/* Desktop: keep the example badge small (it must NOT grow on big screens) and reserve its space on
   the CELL so an overflowing name can never render under it (fixes badge/text overlap on large screens). */
@media(min-width:768px){
  .eg-badge{font-size:9px;right:10px}
  .grid input.name{padding-right:8px}
  .grid th.item,.grid td.item{width:250px;min-width:250px}
  .grid td.item:has(.eg-badge){padding-right:56px}
}

/* Price-breakdown donut: explicit desktop size + match the other tools' size on small screens
   (was a fixed 190px inline style that made it smaller than the donuts on the other tools) */
.bd-body .donutbox{flex:0 0 200px;width:200px;height:200px}
@media(max-width:767px){
  .bd-body{flex-direction:column;align-items:center}
  .bd-body .donutbox{flex:0 0 auto;width:100%;max-width:240px;height:230px;margin:0 auto}
  .bd-body .donutstats{width:100%}
}
