/* Shared design system for fnbtoolkit.com workplace tools */
:root{
  --paper:#f7f6f2;
  --surface:#ffffff;
  --ink:#23262a;
  --slate:#2e3338;
  --muted:#6b6a63;
  --line:#e4e2da;
  --line-strong:#d4d1c8;
  --teal:#0f6e56;
  --teal-bright:#1d9e75;
  --amber:#b5731a;
  --gray:#8a8980;
  --red:#a32d2d;
  --input:#1f5fa5;
  --input-fill:#f0f5fb;
  --total-fill:#f1efe8;
  --kpi-fill:#f3f1ea;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI","Helvetica Neue",Helvetica,Arial,sans-serif;
  --mono:ui-monospace,"SF Mono","Cascadia Mono",Menlo,Consolas,monospace;
}
*{box-sizing:border-box}
html,body{margin:0}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:15px;line-height:1.55;
  font-variant-numeric:tabular-nums;-webkit-font-smoothing:antialiased}
.wrap{max-width:1560px;margin:0 auto;padding:20px 30px 60px}
.wrap.narrow{max-width:1000px}

.topbar{display:flex;justify-content:space-between;align-items:center;padding:0 0 18px;
  border-bottom:2px solid var(--slate);margin-bottom:30px}
@font-face{font-family:"Cocogoose";src:url("../fonts/Cocogoose-Pro-Regular-trial.ttf") format("truetype");font-weight:normal;font-style:normal}
.wordmark{font-family:"Cocogoose",var(--sans);font-size:28px;letter-spacing:.01em;text-decoration:none;line-height:1}
.wordmark .wm-fnb{color:#cc1722}
.wordmark .wm-tk{color:#1a1a1a}
.toolcount{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--muted)}

.masthead{display:flex;justify-content:space-between;align-items:flex-end;gap:18px;flex-wrap:wrap;
  padding-bottom:18px;border-bottom:1px solid var(--line-strong);margin-bottom:24px}
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--muted);margin:0 0 10px}
.eyebrow a{color:var(--muted);text-decoration:none}
.eyebrow a:hover{color:var(--teal)}
h1{font-weight:800;font-size:32px;line-height:1;margin:0;letter-spacing:-.02em;
  text-transform:uppercase;color:var(--slate)}
.sub{margin:6px 0 0;color:var(--muted);font-size:14px}
.actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.savenote{font-size:12px;color:var(--muted);margin-left:4px}

.btn{font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--slate);background:var(--surface);
  border:1px solid var(--line-strong);border-radius:6px;padding:8px 13px;cursor:pointer;
  transition:background .12s,border-color .12s}
.btn:hover{background:#fbfaf7;border-color:#bdbab0}
.btn:active{transform:translateY(1px)}
.btn.small{padding:5px 10px;font-size:12px}
.btn.primary{background:var(--slate);color:var(--paper);border-color:var(--slate)}
.btn.primary:hover{background:var(--teal);border-color:var(--teal)}

.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;color:var(--muted);white-space:nowrap}
.ctrl output{font-weight:700;font-size:18px;color:var(--slate);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-strong);
  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(--teal);border:3px solid var(--surface);box-shadow:0 0 0 1px var(--teal);cursor:pointer}
input[type=range]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--teal);
  border:3px solid var(--surface);box-shadow:0 0 0 1px var(--teal);cursor:pointer}
input[type=number],input[type=text],input[type=date],select{font-family:var(--sans);font-size:14px;color:var(--input);
  border:1px solid var(--line-strong);border-radius:6px;padding:6px 8px;background:var(--input-fill)}
input[type=number]{width:80px;text-align:right}
input:focus,select:focus{outline:2px solid rgba(15,110,86,.35);outline-offset:0}

.fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;max-width:1000px}
.fields label{display:flex;flex-direction:column;gap:5px;font-size:12px;color:var(--muted)}
.fields input,.fields select{width:100%}

.hint{font-size:13px;color:var(--muted);margin:-4px 0 14px;max-width:78ch}
.datadefs{margin:-4px 0 16px}
.datadefs p{font-size:13px;color:var(--muted);margin:0 0 7px;max-width:88ch}
.datadefs strong{color:var(--slate);font-weight:700}

.panel{background:var(--surface);border:1px solid var(--line-strong);border-radius:8px;padding:20px 22px;margin-bottom:16px}
.panel h2{font-weight:800;font-size:15px;letter-spacing:.01em;text-transform:uppercase;color:var(--slate);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}
.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:3fr minmax(320px,2fr)}
@media(max-width:900px){.panelrow,.panelrow.flip{grid-template-columns:1fr}}

.verdict{margin:0}
.vmain{font-weight:800;font-size:20px;line-height:1.2;letter-spacing:.01em;text-transform:uppercase;color:var(--teal)}
.vmain.bad{color:var(--red)}
.vsub{margin-top:6px}
.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-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);min-width:84px}
.vsub b{font-weight:800;font-size:18px;color:var(--slate);font-variant-numeric:tabular-nums}
.vsub b.pos{color:var(--teal)} .vsub b.neg{color:var(--red)} .vsub b.warn{color:var(--amber)}
.vsub em{font-style:normal;font-size:12px;color:var(--muted)}
.lever{background:var(--paper);border-radius:6px;padding:9px 12px;margin:10px 0 0;font-size:13px}
.leverlab{color:var(--muted);margin-right:8px}
.lever span:last-child{font-weight:500}

.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.teal{background:var(--teal-bright)} .sw.amber{background:var(--amber)}
.sw.gray{background:var(--gray)} .sw.red{background:var(--red)}

.chartbox{position:relative;width:100%;height:320px}
.matrices{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.matrixbox{position:relative;height:340px}
@media(max-width:900px){.matrices{grid-template-columns:1fr}}
figure{margin:0;text-align:center}
figcaption{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);margin-bottom:8px}

.chip{display:inline-block;font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;padding:2px 9px;border-radius:10px;white-space:nowrap}
.chip.star,.chip.good{background:rgba(29,158,117,.14);color:var(--teal)}
.chip.plough,.chip.warn{background:rgba(181,115,26,.14);color:var(--amber)}
.chip.puzzle,.chip.neutral{background:rgba(138,137,128,.16);color:#5f5e57}
.chip.dog,.chip.bad{background:rgba(163,45,45,.12);color:var(--red)}

table.summary{width:100%;max-width:860px;border-collapse:collapse;font-size:14px}
.summary th{text-align:right;font-weight:500;color:var(--muted);font-size:12px;padding:6px 10px;
  border-bottom:1px solid var(--line-strong)}
.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(--total-fill);font-weight:600}
.delta-pos{color:var(--teal)} .delta-neg{color:var(--red)}

.gridscroll{overflow-x:auto}
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:12px}
.grid th{font-size:11px;font-weight:500;color:var(--muted);text-align:right;padding:7px 8px;
  background:var(--paper);border-bottom:1px solid var(--line-strong);white-space:nowrap;vertical-align:bottom}
.grid th.item{text-align:left;width:18%;min-width:140px}
.thsub{display:block;font-weight:400;font-size:10px;color:var(--muted);opacity:.85}
.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 td.chipcell{padding:4px 8px;text-align:left}
.grid tr.tot td{background:var(--total-fill);font-weight:600;padding:7px 8px}
.grid tr.flag td{background:#fdf6f5}
.grid input,.grid select{border:none;background:var(--input-fill);color:var(--input);font-family:var(--sans);font-size:13px;
  width:100%;padding:6px 8px;text-align:right;border-radius:0}
.grid select{text-align:left;padding:5px 6px}
.grid input.name{text-align:left;color:var(--ink)}
.grid input:focus,.grid select:focus{outline:2px solid rgba(15,110,86,.4);outline-offset:-2px}
.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:5px}
.delbtn:hover{background:#f3eceb;color:var(--red)}

textarea{font-family:var(--mono);font-size:13px;color:var(--input);border:1px solid var(--line-strong);
  border-radius:6px;padding:10px 12px;background:var(--input-fill);width:100%;min-height:170px;resize:vertical;line-height:1.6}

.foot{margin-top:8px;font-size:12px;color:var(--muted);line-height:1.6}
.foot p{margin:0 0 4px}
.foot a{color:var(--muted)}
.foot a:hover{color:var(--teal)}

@media(max-width:640px){ h1{font-size:25px} }

/* ---------- PDF report (print only) ---------- */
#report{display:none}
@media print{
  @page{margin:14mm}
  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(--sans);color:var(--ink);font-size:11px;line-height:1.5}

  .rpt-top{display:flex;justify-content:space-between;align-items:baseline;
    border-bottom:2px solid var(--slate);padding-bottom:8px}
  .rpt-mark{font-family:var(--mono);font-size:12px;font-weight:700;color:var(--slate)}
  .rpt-mark b{color:var(--teal)}
  .rpt-meta{font-family:var(--mono);font-size:9px;letter-spacing:.14em;color:var(--muted)}
  .rpt-h1{font-weight:800;font-size:26px;letter-spacing:-.02em;text-transform:uppercase;
    color:var(--slate);margin:18px 0 4px}
  .rpt-settings{font-size:11px;color:var(--muted);margin:0 0 16px}

  .rpt-verdict{border:1.5px solid;border-radius:6px;padding:12px 16px;margin:0 0 20px}
  .rpt-verdict.win{border-color:var(--teal)}
  .rpt-verdict.lose{border-color:var(--red)}
  .rv-main{font-weight:800;font-size:15px;text-transform:uppercase;letter-spacing:.01em}
  .rpt-verdict.win .rv-main{color:var(--teal)}
  .rpt-verdict.lose .rv-main{color:var(--red)}
  .rv-sub{font-size:13px;font-weight:600;margin-top:2px}
  .rv-sub b.pos{color:var(--teal)} .rv-sub b.neg{color:var(--red)}

  .rpt-h2{font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:.04em;
    color:var(--slate);margin:18px 0 8px}
  .rpt-h2 span{font-weight:400;color:var(--muted);text-transform:none;letter-spacing:0}
  .rpt-h2.brk{break-before:page}

  table.rpt-menu{width:100%;border-collapse:collapse;break-inside:avoid}
  .rpt-menu th{font-size:8.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
    color:var(--muted);text-align:right;padding:5px 7px;border-bottom:1px solid var(--slate)}
  .rpt-menu td{text-align:right;padding:5px 7px;border-bottom:.5px solid var(--line-strong)}
  .rpt-menu th.l,.rpt-menu td.l{text-align:left}
  .rpt-menu th.n,.rpt-menu td.n{width:18px;text-align:right;color:var(--muted)}
  .rpt-menu tr.tot td{font-weight:700;border-top:1px solid var(--slate);border-bottom:none}
  .rpt-menu td.pos{color:var(--teal)} .rpt-menu td.neg{color:var(--red)}

  .rpt-chart{text-align:center;margin:14px 0;break-inside:avoid}
  .rpt-chart img{max-width:520px;width:100%;height:auto}
  .rpt-chart figcaption{font-family:var(--mono);font-size:8px;letter-spacing:.1em;color:var(--muted);margin-top:6px}

  .rpt-foot{font-size:9px;color:var(--muted);border-top:1px solid var(--line-strong);
    padding-top:8px;margin-top:24px}
}
