/* =====================================================================
   UK Take Home Pay — shared site theme (forest / lime, warm paper)
   Display: Bricolage Grotesque · Body: Hanken Grotesk · Mono: JetBrains Mono
   Styles the site's legacy content-page class vocabulary in the new light
   design, and provides the shared header / footer / button components.
   ===================================================================== */
:root{
  /* new design tokens */
  --paper:oklch(0.985 0.008 95); --paper-2:oklch(0.965 0.010 95); --surface:oklch(1 0 0);
  --ink:oklch(0.24 0.018 155); --ink-soft:oklch(0.40 0.020 155); --muted:oklch(0.55 0.018 150);
  --hairline:oklch(0.90 0.012 140); --hairline-2:oklch(0.83 0.014 140);
  --forest:oklch(0.32 0.055 158); --forest-deep:oklch(0.26 0.050 160); --forest-700:oklch(0.42 0.060 158);
  --forest-tint:oklch(0.94 0.030 150);
  --lime:oklch(0.88 0.185 122); --lime-deep:oklch(0.80 0.180 124); --lime-ink:oklch(0.36 0.090 130);
  --tax:oklch(0.62 0.12 35); --ni:oklch(0.66 0.10 70); --pension:oklch(0.58 0.075 250); --student:oklch(0.60 0.085 310);
  --radius-sm:12px; --radius:18px; --radius-lg:26px; --radius-xl:36px;
  --shadow-sm:0 1px 2px oklch(0.3 0.03 150/0.06),0 2px 6px oklch(0.3 0.03 150/0.05);
  --shadow:0 2px 4px oklch(0.3 0.03 150/0.05),0 14px 34px -12px oklch(0.3 0.03 150/0.18);
  --shadow-lg:0 6px 12px oklch(0.3 0.03 150/0.07),0 40px 80px -28px oklch(0.28 0.04 155/0.32);
  --ease:cubic-bezier(0.22,0.61,0.36,1);
  --font-display:"Bricolage Grotesque","Hanken Grotesk",system-ui,sans-serif;
  --font-body:"Hanken Grotesk",system-ui,-apple-system,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,monospace;

  /* legacy aliases (so existing var(--bg-*) usages flip to light) */
  --bg-deep:var(--paper); --bg-card:var(--surface); --bg-card-alt:var(--paper-2); --bg-input:var(--surface);
  --border:var(--hairline); --border-focus:var(--forest-700);
  --text-primary:var(--ink); --text-secondary:var(--ink-soft); --text-muted:var(--muted);
  --accent:var(--forest-700); --green:var(--forest); --amber:var(--ni); --red:var(--tax);
  --radius-lg-legacy:16px;
}
*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{margin:0;font-family:var(--font-body);background:var(--paper);color:var(--ink);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.1;letter-spacing:-0.02em;}
a{color:var(--forest-700);text-decoration:none;}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--forest);color:#fff;padding:10px 16px;border-radius:0 0 8px 0;z-index:100;}
.skip-link:focus{left:0;}

/* layout */
.container{max-width:840px;margin:0 auto;padding:0 24px;}
.breadcrumb{padding:18px 0;font-size:13px;color:var(--muted);}
.breadcrumb a{color:var(--forest-700);}

/* page header (title block) */
header{padding:8px 0 28px;text-align:center;}
h1{font-size:clamp(1.9rem,4.5vw,3rem);font-weight:700;line-height:1.06;margin-bottom:14px;letter-spacing:-0.03em;}
header p{font-size:17px;color:var(--ink-soft);max-width:620px;margin:0 auto;}

/* hero / stat cards */
.hero-card{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-lg);padding:34px;margin-bottom:30px;text-align:center;box-shadow:var(--shadow);}
.hero-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--forest-700);}
.hero-amount{font-family:var(--font-display);font-size:clamp(2.4rem,5vw,3.2rem);font-weight:700;letter-spacing:-0.03em;color:var(--forest);margin:14px 0 4px;}
.hero-sub{color:var(--muted);font-size:14.5px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:24px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:24px;}
.stat-box{background:var(--paper-2);border:1px solid var(--hairline);border-radius:var(--radius-sm);padding:16px;text-align:center;}
.stat-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted);margin-bottom:4px;}
.stat-value{font-family:var(--font-mono);font-size:16px;font-weight:600;color:var(--ink);}

/* breakdown / generic cards */
.breakdown-card,.cta-box{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-lg);padding:28px;margin-bottom:28px;box-shadow:var(--shadow-sm);}
.card-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--muted);margin-bottom:18px;}
.row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--hairline);font-size:15px;}
.row:last-child{border-bottom:none;}
.row-label{color:var(--ink-soft);}
.row-value{font-family:var(--font-mono);font-weight:600;color:var(--ink);}
.row-total{border-top:2px solid var(--hairline-2);padding-top:14px;font-weight:700;}
.row-total .row-label{color:var(--forest-700);}
.row-total .row-value{color:var(--forest-700);font-size:16px;}

/* tables */
.tax-table{width:100%;border-collapse:collapse;margin:20px 0;font-size:14px;}
.tax-table th{text-align:left;padding:11px 14px;background:var(--paper-2);color:var(--ink-soft);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:0.05em;border-bottom:1px solid var(--hairline);}
.tax-table td{padding:11px 14px;border-bottom:1px solid var(--hairline);color:var(--ink-soft);font-size:14px;}
.tax-table a{color:var(--forest-700);}

/* content prose */
.content h2{font-family:var(--font-display);font-size:clamp(1.4rem,2.6vw,1.8rem);font-weight:700;margin:40px 0 14px;letter-spacing:-0.02em;color:var(--ink);}
.content h3{font-size:1.15rem;margin:24px 0 10px;color:var(--ink);}
.content p{font-size:15.5px;color:var(--ink-soft);margin-bottom:14px;line-height:1.7;}
.content strong{color:var(--ink);font-weight:600;}
.content a{color:var(--forest-700);font-weight:500;}
.content ul,.content ol{margin:0 0 14px 22px;color:var(--ink-soft);font-size:15.5px;line-height:1.8;}

/* CTA box + buttons */
.cta-box{text-align:center;}
.cta-box a,.cta a{display:inline-block;padding:13px 26px;background:var(--forest);color:var(--paper);border-radius:999px;font-weight:600;font-size:15px;margin-top:12px;box-shadow:var(--shadow-sm);transition:background .2s var(--ease);}
.cta-box a:hover,.cta a:hover{background:var(--forest-deep);}
.cta{background:var(--forest-tint);border:1px solid var(--hairline);border-radius:var(--radius-lg);padding:26px;text-align:center;margin:28px 0;}
.cta p{color:var(--ink-soft);margin-bottom:4px;}

/* link tiles */
.links-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;margin:20px 0;}
.link-item{display:block;padding:13px;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-sm);text-align:center;color:var(--ink);font-family:var(--font-mono);font-size:14px;font-weight:500;transition:border-color .15s,transform .15s;}
.link-item:hover{border-color:var(--forest-700);transform:translateY(-2px);}

/* footer */
footer{text-align:center;padding:34px 0;border-top:1px solid var(--hairline);margin-top:48px;color:var(--muted);}
footer p{font-size:13px;color:var(--muted);}
footer a{color:var(--forest-700);}

/* ===== shared site header (sticky nav) ===== */
.site-header{position:sticky;top:0;z-index:50;background:oklch(0.985 0.008 95/0.85);backdrop-filter:blur(14px);border-bottom:1px solid var(--hairline);}
.site-header .sh-wrap{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:28px;height:64px;padding:0 24px;}
.logo{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:700;font-size:18px;letter-spacing:-0.03em;color:var(--ink);}
.leaf{width:28px;height:28px;font-size:28px;border-radius:8px;background:linear-gradient(150deg,var(--forest-700),var(--forest-deep));flex:none;display:inline-grid;place-items:center;box-shadow:var(--shadow-sm);overflow:hidden;}
.leaf::before{content:"£";font-family:var(--font-display);font-weight:800;font-size:0.6em;line-height:1;color:var(--lime);}
.sh-nav{display:flex;align-items:center;gap:22px;font-size:14.5px;font-weight:500;color:var(--ink-soft);}
.sh-nav a{color:var(--ink-soft);}
.sh-nav a:hover{color:var(--ink);}
.sh-cta{margin-left:auto;display:inline-flex;align-items:center;padding:10px 18px;background:var(--forest);color:var(--paper);border-radius:999px;font-weight:600;font-size:14px;}
.sh-cta:hover{background:var(--forest-deep);color:var(--paper);}
@media(max-width:760px){.sh-nav{display:none;}.sh-cta{margin-left:auto;}}

/* ===== compact-template support (.c/.bc/.hn/.sb/.tt/.lg/.li + article) ===== */
:root{
  --bg:var(--paper); --card:var(--surface); --card2:var(--paper-2);
  --text:var(--ink); --sub:var(--ink-soft); --dim:var(--muted);
  --r:12px; --rl:16px; --purple:var(--pension);
}
.c{max-width:840px;margin:0 auto;padding:0 24px;}
.bc{padding:18px 0;font-size:13px;color:var(--muted);}
.bc a{color:var(--forest-700);}
.hero{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-lg);padding:34px;margin-bottom:30px;text-align:center;box-shadow:var(--shadow);}
.hl{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--forest-700);}
.hn{font-family:var(--font-display);font-size:clamp(2.4rem,5vw,3.2rem);font-weight:700;letter-spacing:-0.03em;color:var(--forest);margin:14px 0 4px;}
.hs{color:var(--muted);font-size:14.5px;}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:24px;}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:24px;}
.sb{background:var(--paper-2);border:1px solid var(--hairline);border-radius:var(--radius-sm);padding:16px;text-align:center;}
.sl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted);margin-bottom:4px;}
.sv{font-family:var(--font-mono);font-size:16px;font-weight:600;color:var(--ink);}
.tt{width:100%;border-collapse:collapse;margin:20px 0;font-size:14px;}
.tt th{text-align:left;padding:11px 14px;background:var(--paper-2);color:var(--ink-soft);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:0.05em;border-bottom:1px solid var(--hairline);}
.tt td{padding:11px 14px;border-bottom:1px solid var(--hairline);color:var(--ink-soft);font-size:14px;}
.tt td a{color:var(--forest-700);}
.lg{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px;margin:20px 0;}
.li{display:block;padding:13px;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius-sm);text-align:center;color:var(--ink);font-size:14px;font-weight:500;transition:border-color .15s,transform .15s;}
.li:hover{border-color:var(--forest-700);transform:translateY(-2px);}
article h2{font-family:var(--font-display);font-size:clamp(1.4rem,2.6vw,1.8rem);font-weight:700;margin:36px 0 14px;letter-spacing:-0.02em;color:var(--ink);}
article h3{font-size:1.15rem;margin:22px 0 10px;color:var(--ink);}
article p{font-size:15.5px;color:var(--ink-soft);margin-bottom:14px;line-height:1.7;}
article strong{color:var(--ink);font-weight:600;}
article a{color:var(--forest-700);font-weight:500;}
article ul,article ol{margin:0 0 14px 22px;color:var(--ink-soft);font-size:15.5px;line-height:1.8;}
