  :root{
    --paper:#F4F6F1; --paper-alt:#EBF0E8; --ink:#13201A; --muted:#5B6B61;
    --surface:#FFFFFF; --line:#E1E7DE;
    --canopy:#1B6B43; --canopy-press:#155234; --sprout:#2F9E63; --sprout-soft:#E4F1E9;
    --sun:#DE9F36;
    --shadow:0 1px 2px rgba(20,40,30,.05), 0 10px 28px rgba(20,40,30,.07);
    --shadow-lift:0 2px 6px rgba(20,40,30,.07), 0 18px 40px rgba(20,40,30,.12);
    --radius:16px; --radius-sm:10px;
    --font-display:"Space Grotesk", ui-sans-serif, system-ui, sans-serif;
    --font-body:"Inter", ui-sans-serif, system-ui, sans-serif;
    --font-mono:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
    --maxw:1180px;
  }
  html[data-theme="dark"]{
    --paper:#0E140F; --paper-alt:#10180F; --ink:#E9EFE8; --muted:#93A199;
    --surface:#161D17; --line:#28312A;
    --canopy:#39B070; --canopy-press:#2C915B; --sprout:#54C083; --sprout-soft:#16241B;
    --sun:#E6B14E;
    --shadow:0 1px 2px rgba(0,0,0,.30), 0 12px 32px rgba(0,0,0,.40);
    --shadow-lift:0 2px 8px rgba(0,0,0,.35), 0 22px 48px rgba(0,0,0,.50);
  }
  *{box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{margin:0; background:var(--paper); color:var(--ink); font-family:var(--font-body); font-size:17px; line-height:1.6;
    -webkit-font-smoothing:antialiased; transition:background .35s ease, color .35s ease}
  .wrap{max-width:var(--maxw); margin:0 auto; padding:0 24px}
  h1,h2,h3{font-family:var(--font-display); font-weight:700; letter-spacing:-.02em; line-height:1.06; margin:0}
  p{margin:0}
  a{color:inherit; text-decoration:none}
  .eyebrow{font-family:var(--font-mono); font-size:12.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--canopy); font-weight:500}
  html[data-theme="dark"] .eyebrow{color:var(--sprout)}
  .skip{position:absolute; left:-9999px; top:0; background:var(--canopy); color:#fff; padding:10px 16px; border-radius:8px; z-index:100}
  .skip:focus{left:16px; top:16px}

  /* nav */
  header.nav{position:sticky; top:0; z-index:50; backdrop-filter:saturate(140%) blur(10px);
    background:color-mix(in srgb, var(--paper) 82%, transparent); border-bottom:1px solid var(--line)}
  .nav-inner{display:flex; align-items:center; gap:18px; height:68px}
  .brand{display:flex; align-items:center; gap:10px; font-family:var(--font-display); font-weight:700; font-size:19px; letter-spacing:-.01em}
  .brand .mark{width:30px; height:30px; flex:0 0 auto}
  .links{display:flex; gap:24px; margin-left:6px}
  .links a{font-size:15px; color:var(--muted); position:relative; padding:6px 0; transition:color .2s}
  .links a::after{content:""; position:absolute; left:0; bottom:0; height:2px; width:0; background:var(--canopy); transition:width .22s ease}
  .links a:hover{color:var(--ink)} .links a:hover::after{width:100%}
  .nav-actions{margin-left:auto; display:flex; align-items:center; gap:10px}
  .langset{display:inline-flex; border:1px solid var(--line); border-radius:999px; overflow:hidden; background:var(--surface)}
  .lang{border:0; background:transparent; color:var(--muted); font-family:var(--font-mono); font-size:12.5px; font-weight:500; letter-spacing:.06em;
    padding:8px 11px; cursor:pointer; transition:background .2s, color .2s}
  .lang:hover{color:var(--ink)} .lang.is-active{background:var(--canopy); color:#fff}
  .toggle{width:40px; height:40px; border-radius:50%; border:1px solid var(--line); background:var(--surface); color:var(--ink);
    display:grid; place-items:center; cursor:pointer; transition:border-color .2s, transform .2s}
  .toggle:hover{border-color:var(--canopy); transform:translateY(-1px)}
  .toggle svg{width:18px; height:18px}
  .toggle .moon{display:none} html[data-theme="dark"] .toggle .moon{display:block} html[data-theme="dark"] .toggle .sun{display:none}
  .btn{display:inline-flex; align-items:center; gap:8px; background:var(--canopy); color:#fff; font-family:var(--font-body); font-weight:600;
    font-size:15px; padding:11px 20px; border-radius:999px; border:0; cursor:pointer; transition:background .2s, transform .2s, box-shadow .2s}
  .btn:hover{background:var(--canopy-press); transform:translateY(-1px); box-shadow:var(--shadow)}
  .btn-ghost{display:inline-flex; align-items:center; gap:8px; background:transparent; color:var(--ink); font-weight:600; font-size:15px;
    padding:11px 20px; border-radius:999px; border:1px solid var(--line); cursor:pointer; transition:border-color .2s, background .2s, transform .2s}
  .btn-ghost:hover{border-color:var(--canopy); background:var(--sprout-soft); transform:translateY(-1px)}
  .nav .btn{padding:9px 17px}

  /* sections */
  .section{padding:100px 0}
  .section.alt{background:var(--paper-alt)}
  .section-head{max-width:680px; margin-bottom:46px}
  .section-head h2{font-size:clamp(28px,4vw,40px); margin:14px 0 14px}
  .section-head p{color:var(--muted); font-size:18px}

  /* hero */
  .hero{position:relative; overflow:hidden; padding:84px 0 80px}
  .hero::before{content:""; position:absolute; inset:0; pointer-events:none;
    background:radial-gradient(720px 420px at 78% 16%, color-mix(in srgb, var(--sun) 26%, transparent), transparent 60%),
               radial-gradient(680px 520px at 88% 72%, color-mix(in srgb, var(--sprout) 22%, transparent), transparent 62%);
    opacity:.5}
  html[data-theme="dark"] .hero::before{opacity:.36}
  .hero-grid{position:relative; display:grid; grid-template-columns:1.04fr .96fr; gap:54px; align-items:center}
  .hero-copy .eyebrow{display:inline-block; margin-bottom:18px}
  .hero h1{font-size:clamp(37px,5.4vw,62px)}
  .hero h1 .accent{color:var(--canopy)} html[data-theme="dark"] .hero h1 .accent{color:var(--sprout)}
  .lead{color:var(--muted); font-size:19px; margin:22px 0 30px; max-width:32em}
  .cta-row{display:flex; gap:14px; flex-wrap:wrap}
  .trust{position:relative; margin-top:42px; display:flex; flex-wrap:wrap; gap:10px 24px; align-items:center;
    font-family:var(--font-mono); font-size:12.5px; letter-spacing:.03em; color:var(--muted)}
  .trust b{color:var(--ink); font-weight:500} .trust .sep{opacity:.4}

  /* live panel */
  .panel{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-lift); padding:22px}
  .panel-head{display:flex; align-items:center; gap:10px; padding-bottom:16px; margin-bottom:16px; border-bottom:1px solid var(--line);
    font-family:var(--font-mono); font-size:13px; color:var(--muted)}
  .panel-live{margin-left:auto; color:var(--sprout); font-weight:700; letter-spacing:.12em; text-transform:uppercase; font-size:11px}
  .dot{width:9px; height:9px; border-radius:50%; background:var(--sprout); animation:pulse 2.4s infinite}
  @keyframes pulse{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--sprout) 55%,transparent)}70%{box-shadow:0 0 0 9px transparent}100%{box-shadow:0 0 0 0 transparent}}
  .readout{display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:12px; overflow:hidden}
  .metric{background:var(--surface); padding:15px 15px 12px; min-height:104px; display:flex; flex-direction:column; gap:6px}
  .m-top{display:flex; align-items:baseline; justify-content:space-between}
  .m-label{font-family:var(--font-mono); font-size:11.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted)}
  .m-unit{font-family:var(--font-mono); font-size:11px; color:var(--muted); opacity:.8}
  .m-value{font-family:var(--font-display); font-weight:600; font-size:27px; letter-spacing:-.01em; font-variant-numeric:tabular-nums}
  .spark{width:100%; height:24px; margin-top:auto; display:block}
  .spark polyline{fill:none; stroke:var(--sprout); stroke-width:1.6; vector-effect:non-scaling-stroke; opacity:.9}
  .metric.warm .m-value{color:var(--sun)} .metric.warm .spark polyline{stroke:var(--sun)}

  /* band */
  .band{background:var(--canopy); color:#fff}
  html[data-theme="dark"] .band{background:#123E27}
  .band .wrap{padding-top:30px; padding-bottom:30px}
  .band p{font-family:var(--font-display); font-weight:500; font-size:clamp(19px,2.4vw,25px); letter-spacing:-.01em; max-width:none}

  /* cards grids */
  .grid-3{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
  .grid-2{display:grid; grid-template-columns:repeat(2,1fr); gap:18px}
  .card{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:24px; transition:transform .2s, box-shadow .2s, border-color .2s}
  .card:hover{transform:translateY(-3px); box-shadow:var(--shadow-lift); border-color:color-mix(in srgb, var(--canopy) 35%, var(--line))}
  .card .ic{width:38px; height:38px; border-radius:10px; background:var(--sprout-soft); color:var(--canopy); display:grid; place-items:center; margin-bottom:16px}
  html[data-theme="dark"] .card .ic{color:var(--sprout)}
  .card .ic svg{width:20px; height:20px}
  .card h3{font-size:18px; margin-bottom:8px; display:flex; align-items:baseline; gap:8px; flex-wrap:wrap}
  .card h3 .u{font-family:var(--font-mono); font-size:12px; font-weight:500; color:var(--muted); letter-spacing:.04em}
  .card p{color:var(--muted); font-size:15.5px}

  /* steps (process) */
  .steps{display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-bottom:44px}
  .pstep{position:relative; padding-top:30px}
  .pstep .pn{position:absolute; top:0; left:0; width:30px; height:30px; border-radius:50%; background:var(--canopy); color:#fff;
    font-family:var(--font-mono); font-size:13px; font-weight:700; display:grid; place-items:center}
  .pstep h3{font-size:17px; margin:6px 0 7px} .pstep p{color:var(--muted); font-size:15px}

  /* timeline */
  .timeline{display:grid; grid-template-columns:repeat(4,1fr); gap:22px}
  .tstep{position:relative; padding-top:26px}
  .tstep::before{content:""; position:absolute; top:7px; left:0; right:0; height:2px; background:var(--line)}
  .tstep .no{font-family:var(--font-mono); font-size:13px; font-weight:700; color:var(--canopy); position:absolute; top:15px; left:0; background:var(--paper); padding-right:10px}
  html[data-theme="dark"] .tstep .no{color:var(--sprout)}
  .section.alt .tstep .no{background:var(--paper-alt)}
  .tstep h3{font-size:17px; margin:18px 0 8px} .tstep p{color:var(--muted); font-size:15px}

  /* support */
  .sup-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
  .sup{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:24px}
  .sup .badge{font-family:var(--font-mono); font-size:12px; color:var(--sun); letter-spacing:.1em; text-transform:uppercase}
  .sup h3{font-size:17px; margin:10px 0 7px} .sup p{color:var(--muted); font-size:15.5px}

  /* cta band */
  .ctaband{background:var(--ink)} html[data-theme="dark"] .ctaband{background:#16241B; border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
  .ctaband .wrap{padding:70px 24px; text-align:center}
  .ctaband h2{color:#fff; font-size:clamp(26px,3.6vw,38px); margin-bottom:14px}
  .ctaband p{color:rgba(255,255,255,.78); font-size:18px; max-width:46ch; margin:0 auto 26px}

  /* contact */
  .contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:46px; align-items:start}
  .contact-copy h2{font-size:clamp(28px,4vw,40px); margin:14px 0 16px}
  .contact-copy p{color:var(--muted); font-size:18px; margin-bottom:22px; max-width:34em}
  .mailrow{display:inline-flex; align-items:center; gap:10px; font-family:var(--font-mono); font-size:15px; color:var(--ink); border:1px solid var(--line);
    padding:10px 16px; border-radius:999px; transition:border-color .2s, background .2s}
  .mailrow:hover{border-color:var(--canopy); background:var(--sprout-soft)}
  .company{margin-top:26px; font-size:14.5px; color:var(--muted)} .company b{color:var(--ink); font-weight:600}
  form{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:26px; box-shadow:var(--shadow)}
  .field{margin-bottom:16px} .field label{display:block; font-size:13px; font-weight:600; margin-bottom:7px}
  .field input, .field textarea{width:100%; font-family:var(--font-body); font-size:15px; color:var(--ink); background:var(--paper);
    border:1px solid var(--line); border-radius:var(--radius-sm); padding:12px 14px; transition:border-color .2s, box-shadow .2s}
  .field textarea{min-height:120px; resize:vertical}
  .field input:focus, .field textarea:focus{outline:none; border-color:var(--canopy); box-shadow:0 0 0 3px var(--sprout-soft)}
  form .btn{width:100%; justify-content:center; margin-top:4px}
  .form-note{margin-top:14px; font-size:14px; color:var(--canopy); display:none} html[data-theme="dark"] .form-note{color:var(--sprout)}

  /* footer */
  footer.foot{border-top:1px solid var(--line); padding:46px 0 54px; background:var(--paper-alt)}
  .foot-grid{display:flex; flex-wrap:wrap; gap:24px; align-items:center; justify-content:space-between}
  .foot .brand{font-size:17px} .foot p{font-size:14px; color:var(--muted)}
  .foot .links-foot{display:flex; gap:20px; font-size:14px; color:var(--muted)} .foot .links-foot a:hover{color:var(--ink)}

  /* cookie consent */
  .consent{position:fixed; left:16px; right:16px; bottom:16px; z-index:80; max-width:560px; margin:0 auto;
    background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-lift);
    padding:18px 20px; display:none; gap:14px; align-items:center; flex-wrap:wrap}
  .consent.show{display:flex}
  .consent p{font-size:14px; color:var(--muted); flex:1 1 240px; margin:0}
  .consent .c-actions{display:flex; gap:10px; margin-left:auto}
  .consent .btn, .consent .btn-ghost{padding:9px 18px; font-size:14px}

  :focus-visible{outline:2.5px solid var(--canopy); outline-offset:2px; border-radius:4px}

  @media (max-width:900px){
    .hero-grid{grid-template-columns:1fr; gap:40px}
    .contact-grid{grid-template-columns:1fr; gap:30px}
    .grid-3,.timeline,.steps,.sup-grid{grid-template-columns:repeat(2,1fr)}
    .grid-2{grid-template-columns:1fr}
    .links{display:none}
    .section{padding:72px 0}
  }
  @media (max-width:560px){
    body{font-size:16px}
    .readout{grid-template-columns:repeat(2,1fr)}
    .grid-3,.timeline,.steps,.sup-grid{grid-template-columns:1fr}
    .hero{padding:54px 0 58px}
    .nav-inner{gap:10px} .nav .btn{display:none}
  }
  @media (prefers-reduced-motion: reduce){ *{animation:none !important; transition:none !important; scroll-behavior:auto !important} }

  /* ============ multi-page + motion additions ============ */
  /* scroll reveal */
  .reveal{opacity:0; transform:translateY(18px); transition:opacity .6s ease, transform .6s ease}
  .reveal.in{opacity:1; transform:none}

  /* header shrink on scroll */
  header.nav .nav-inner{transition:height .25s ease}
  header.nav.shrink{box-shadow:var(--shadow)}
  header.nav.shrink .nav-inner{height:54px}
  .links a.is-active{color:var(--ink)} .links a.is-active::after{width:100%}

  /* hero rotating crop */
  .growing{margin-top:18px; font-family:var(--font-mono); font-size:13px; letter-spacing:.04em; color:var(--muted)}
  .growing .rot{color:var(--canopy); font-weight:500; transition:opacity .3s ease}
  html[data-theme="dark"] .growing .rot{color:var(--sprout)}

  /* stat strip */
  .stats{display:grid; grid-template-columns:repeat(3,1fr); gap:18px; text-align:center}
  .stat{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:28px 18px}
  .stat .n{font-family:var(--font-display); font-weight:700; font-size:clamp(34px,5vw,48px); color:var(--canopy); letter-spacing:-.02em; line-height:1; font-variant-numeric:tabular-nums}
  html[data-theme="dark"] .stat .n{color:var(--sprout)}
  .stat .l{margin-top:10px; font-size:15px; color:var(--muted)}

  /* FAQ */
  .faq{max-width:840px}
  .faq-item{border-bottom:1px solid var(--line)}
  .faq-q{width:100%; text-align:left; background:none; border:0; cursor:pointer; padding:22px 0; color:var(--ink);
    font-family:var(--font-display); font-weight:600; font-size:18px; display:flex; align-items:center; justify-content:space-between; gap:18px}
  .faq-q .pm{flex:0 0 auto; width:22px; height:22px; position:relative; transition:transform .3s ease}
  .faq-q .pm::before,.faq-q .pm::after{content:""; position:absolute; background:var(--canopy); border-radius:2px}
  html[data-theme="dark"] .faq-q .pm::before, html[data-theme="dark"] .faq-q .pm::after{background:var(--sprout)}
  .faq-q .pm::before{top:10px; left:2px; right:2px; height:2px}
  .faq-q .pm::after{left:10px; top:2px; bottom:2px; width:2px}
  .faq-item.open .pm{transform:rotate(45deg)}
  .faq-a{max-height:0; overflow:hidden; transition:max-height .35s ease}
  .faq-a div{padding:0 0 22px; color:var(--muted); font-size:16px; max-width:70ch}
  .faq-item.open .faq-a{max-height:340px}

  /* page hero (inner pages) */
  .page-hero{position:relative; overflow:hidden; padding:72px 0 16px}
  .page-hero::before{content:""; position:absolute; inset:0; pointer-events:none; opacity:.42;
    background:radial-gradient(620px 320px at 88% 0%, color-mix(in srgb, var(--sun) 22%, transparent), transparent 60%)}
  html[data-theme="dark"] .page-hero::before{opacity:.3}
  .page-hero .eyebrow{display:inline-block; margin-bottom:16px}
  .page-hero h1{font-size:clamp(34px,5vw,54px)} .page-hero h1 .accent{color:var(--canopy)}
  html[data-theme="dark"] .page-hero h1 .accent{color:var(--sprout)}
  .page-hero p{color:var(--muted); font-size:19px; max-width:48ch; margin-top:18px}

  /* contact page: big number + heading */
  .contact-top{display:grid; grid-template-columns:auto 1fr; gap:34px; align-items:center; margin-bottom:44px}
  .bignum{font-family:var(--font-display); font-weight:700; font-size:clamp(96px,17vw,190px); line-height:.78;
    color:transparent; -webkit-text-stroke:2px var(--line); letter-spacing:-.05em}
  .contact-top .ct-copy{align-self:center}
  .contact-top .eyebrow{display:flex; align-items:center; gap:10px; justify-content:flex-end; margin-bottom:10px}
  .contact-top h2{font-size:clamp(28px,4.4vw,46px); text-align:right; letter-spacing:-.02em}
  @media (max-width:760px){ .contact-top{grid-template-columns:1fr; gap:8px} .contact-top .eyebrow,.contact-top h2{justify-content:flex-start; text-align:left} }

  /* Priva-style contact card */
  .contactcard{display:grid; grid-template-columns:auto 1fr; gap:34px; align-items:center;
    background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:34px; box-shadow:var(--shadow-lift)}
  .cc-photo{width:158px; height:212px; border-radius:96px; object-fit:cover; flex:0 0 auto; background:var(--sprout-soft);
    display:grid; place-items:center; overflow:hidden; border:1px solid var(--line)}
  .cc-photo .ph{font-family:var(--font-display); font-weight:700; font-size:54px; color:var(--canopy); letter-spacing:.02em}
  html[data-theme="dark"] .cc-photo .ph{color:var(--sprout)}
  .cc-role{font-size:15px; color:var(--muted)}
  .cc-name{font-family:var(--font-display); font-weight:700; font-size:clamp(26px,3.4vw,34px); letter-spacing:-.02em; margin:3px 0 16px}
  .cc-row{display:flex; align-items:center; gap:14px; margin:13px 0}
  .cc-ic{width:44px; height:44px; border-radius:50%; background:var(--canopy); color:#fff; display:grid; place-items:center; flex:0 0 auto; transition:transform .2s}
  .cc-row:hover .cc-ic{transform:translateY(-1px)}
  .cc-ic svg{width:19px; height:19px}
  .cc-row a, .cc-row .txt{font-size:17px; color:var(--ink)} .cc-row a{color:var(--canopy)}
  html[data-theme="dark"] .cc-row a{color:var(--sprout)}
  .cc-row a:hover{text-decoration:underline}
  .cc-note{margin-top:8px; font-size:13px; color:var(--muted); font-family:var(--font-mono)}
  @media (max-width:620px){ .contactcard{grid-template-columns:1fr; gap:22px; justify-items:start} .cc-row a, .cc-row .txt{font-size:15px; overflow-wrap:anywhere} }

  /* prose / legal pages */
  .prose{max-width:780px}
  .prose .updated{font-family:var(--font-mono); font-size:13px; color:var(--muted); margin-bottom:24px}
  .prose h2{font-family:var(--font-display); font-size:22px; margin:32px 0 10px}
  .prose h3{font-family:var(--font-display); font-size:17px; margin:22px 0 8px}
  .prose p, .prose li{color:var(--muted); font-size:16px; line-height:1.7; margin:0 0 12px}
  .prose ul{padding-left:20px; margin:0 0 12px}
  .prose a{color:var(--canopy); text-decoration:underline} html[data-theme="dark"] .prose a{color:var(--sprout)}
  .prose b{color:var(--ink); font-weight:600}

  /* multi-column footer */
  .foot-cols{display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:30px}
  .foot-col h4{font-family:var(--font-mono); font-size:12px; font-weight:500; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin:0 0 14px}
  .foot-col a{display:block; font-size:14.5px; color:var(--muted); padding:5px 0; cursor:pointer}
  .foot-col a:hover{color:var(--ink)}
  .foot-col p{font-size:14px; color:var(--muted); margin-top:10px; max-width:30ch}
  .foot-bottom{border-top:1px solid var(--line); margin-top:34px; padding-top:20px; display:flex; flex-wrap:wrap;
    gap:8px 20px; align-items:center; justify-content:space-between; font-size:13.5px; color:var(--muted)}
  .foot-bottom a{color:var(--muted)} .foot-bottom a:hover{color:var(--ink)}
  .foot-bottom .fb-links{display:flex; gap:18px; flex-wrap:wrap}
  @media (max-width:760px){ .foot-cols{grid-template-columns:1fr 1fr} }
  @media (max-width:480px){ .foot-cols{grid-template-columns:1fr} .stats{grid-template-columns:1fr} }

  @media (prefers-reduced-motion: reduce){ .reveal{opacity:1 !important; transform:none !important} }
