  :root{
    --cream:#F2EFE6;
    --cream-2:#E9E4D4;
    --cream-3:#DDD6C1;
    --ink:#0E2A1F;
    --ink-2:#1B3A2B;
    --ink-soft:#3A5446;
    --moss:#3F6B4E;
    --fern:#5A8668;
    --lime:#BDE364;
    --lime-2:#D8EF96;
    --amber:#E8A72B;
    --navy:#162238;
    --line:rgba(14,42,31,.12);
    --line-strong:rgba(14,42,31,.22);

    --font-display:'Cabinet Grotesk','General Sans','Helvetica Neue',sans-serif;
    --font-body:'General Sans','Helvetica Neue',Arial,sans-serif;
    --font-mono:'JetBrains Mono',ui-monospace,monospace;

    --pad-section: 140px;
    --max: 1240px;
  }
  [data-density="compact"]{ --pad-section: 96px; }
  [data-font="editorial"]{ --font-display:'Fraunces', serif; --font-body:'General Sans', sans-serif; }
  [data-font="geometric"]{ --font-display:'Space Grotesk', 'Cabinet Grotesk', sans-serif; --font-body:'Space Grotesk', 'General Sans', sans-serif; }

  *{box-sizing:border-box}
  html,body{margin:0;padding:0}
  body{
    font-family:var(--font-body);
    background:var(--cream);
    color:var(--ink);
    font-size:17px;
    line-height:1.5;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
    overflow-x:hidden;
  }
  /* Global grain overlay */
  body::before{
    content:"";position:fixed;inset:0;pointer-events:none;z-index:1000;
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.05  0 0 0 0 0.15  0 0 0 0 0.12  0 0 0 0.35 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
    opacity:.32;mix-blend-mode:multiply;
  }

  a{color:inherit;text-decoration:none}
  button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}

  .wrap{max-width:var(--max);margin:0 auto;padding:0 40px}

  /* Typography utilities */
  .eyebrow{
    font-family:var(--font-mono);
    font-size:11.5px;
    letter-spacing:.22em;
    text-transform:uppercase;
    color:var(--moss);
    display:inline-flex;align-items:center;gap:10px;
  }
  .eyebrow::before{
    content:"";width:22px;height:1px;background:var(--moss);display:inline-block;
  }
  h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;margin:0;color:var(--ink)}
  h1{font-size:clamp(48px,7.4vw,104px);line-height:.98;letter-spacing:-.035em;font-weight:800}
  h2{font-size:clamp(36px,4.5vw,62px);line-height:1.02;letter-spacing:-.028em}
  h3{font-size:22px;line-height:1.2}
  p{margin:0}

  /* ---------- NAV ---------- */
  nav.top{
    position:sticky;top:0;z-index:50;
    background:color-mix(in oklab, var(--cream) 82%, transparent);
    backdrop-filter:blur(10px) saturate(1.2);
    -webkit-backdrop-filter:blur(10px) saturate(1.2);
    border-bottom:1px solid var(--line);
  }
  .nav-inner{display:flex;align-items:center;justify-content:space-between;height:74px;max-width:var(--max);margin:0 auto;padding:0 40px}
  .logo{display:flex;align-items:center;gap:12px;font-family:var(--font-display);font-weight:800;letter-spacing:.02em}
  .logo svg{height:36px;width:auto;display:block}
  .nav-links{display:flex;gap:4px;align-items:center}
  .nav-links a{
    padding:8px 14px;border-radius:999px;font-size:14.5px;color:var(--ink);opacity:.78;
    transition:.2s;
  }
  .nav-links a:hover{background:var(--cream-2);opacity:1}
  .nav-cta{display:flex;gap:10px;align-items:center}
  .btn{
    display:inline-flex;align-items:center;gap:10px;
    padding:12px 20px;border-radius:999px;
    font-family:var(--font-body);font-weight:500;font-size:14.5px;
    transition:transform .18s ease, background .2s, color .2s, border-color .2s;
    border:1px solid transparent;
  }
  .btn:hover{transform:translateY(-1px)}
  .btn-primary{background:var(--ink);color:var(--cream);}
  .btn-primary:hover{background:var(--ink-2)}
  .btn-ghost{border-color:var(--line-strong);color:var(--ink)}
  .btn-ghost:hover{background:var(--cream-2)}
  .btn-lime{background:var(--lime);color:var(--ink);border:1px solid color-mix(in oklab, var(--lime) 70%, var(--ink))}
  .btn-lime:hover{background:var(--lime-2)}
  .arrow{width:14px;height:14px;display:inline-block}

  /* ---------- HERO ---------- */
  .hero{
    position:relative;
    padding: 60px 0 var(--pad-section);
    overflow:hidden;
  }
  .hero-grid{
    display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center;
    position:relative;z-index:2;
  }
  .hero-left .pill{
    display:inline-flex;align-items:center;gap:10px;
    padding:7px 14px 7px 10px;border-radius:999px;
    background:color-mix(in oklab, var(--moss) 12%, transparent);
    border:1px solid color-mix(in oklab, var(--moss) 30%, transparent);
    font-family:var(--font-mono);font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--moss);
    margin-bottom:28px;
  }
  .pill .dot{width:7px;height:7px;border-radius:50%;background:var(--moss);box-shadow:0 0 0 3px color-mix(in oklab, var(--moss) 25%, transparent)}
  .hero h1 .em{font-style:italic;font-family:var(--font-display);font-weight:500;color:var(--moss);position:relative;white-space:nowrap}
  .hero h1 .em::after{content:"";position:absolute;left:0;right:0;bottom:.08em;height:.18em;background:var(--lime);z-index:-1;opacity:.55;border-radius:2px}
  .hero-sub{margin-top:28px;max-width:520px;font-size:18px;color:var(--ink-soft);line-height:1.55}
  .hero-ctas{margin-top:36px;display:flex;gap:12px;align-items:center;flex-wrap:wrap}
  .hero-meta{margin-top:52px;display:flex;gap:40px;flex-wrap:wrap;align-items:center}
  .hero-meta .stat{display:flex;flex-direction:column;gap:4px}
  .hero-meta .num{font-family:var(--font-display);font-weight:700;font-size:28px;letter-spacing:-.02em}
  .hero-meta .lbl{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft)}
  .hero-meta .sep{width:1px;height:30px;background:var(--line-strong)}

  /* Hero visual container */
  .hero-visual{position:relative;aspect-ratio:1/1;min-height:480px;display:flex;align-items:center;justify-content:center}

  /* Variant A: Orb */
  .orb-scene{position:absolute;inset:-10% -10% -10% -10%;border-radius:50%;overflow:visible}
  .orb{
    position:absolute;inset:8%;border-radius:50%;
    background:
      radial-gradient(circle at 30% 30%, #E8F5D2 0%, #B9DE7A 18%, #5A8B54 40%, #1F3E2B 68%, #0B1C14 92%);
    box-shadow:
      inset -20px -30px 90px rgba(0,0,0,.55),
      inset 30px 40px 120px rgba(235,255,200,.25),
      0 40px 140px -30px rgba(58,120,70,.45);
  }
  .orb::after{
    content:"";position:absolute;inset:0;border-radius:50%;
    background:radial-gradient(circle at 70% 80%, rgba(189,227,100,.28), transparent 45%);
    mix-blend-mode:screen;
  }
  .orb-halo{
    position:absolute;inset:-8%;border-radius:50%;pointer-events:none;
    background:radial-gradient(circle at 50% 50%, rgba(189,227,100,.28), rgba(189,227,100,0) 55%);
    filter:blur(8px);
  }
  .orb-ring{
    position:absolute;inset:-18%;border-radius:50%;border:1px dashed var(--line-strong);
    animation:spin 80s linear infinite;
  }
  .orb-ring.r2{inset:-6%;border:1px solid var(--line);animation-duration:120s;animation-direction:reverse}
  @keyframes spin{to{transform:rotate(360deg)}}
  .orb-tick{
    position:absolute;top:-3px;left:50%;width:6px;height:6px;border-radius:50%;background:var(--moss);transform:translateX(-50%);
    box-shadow:0 0 0 3px color-mix(in oklab, var(--moss) 20%, transparent);
  }
  .orb-label{
    position:absolute;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);
    display:flex;align-items:center;gap:8px;
  }
  .orb-label .ln{width:34px;height:1px;background:var(--line-strong)}
  .orb-label.tl{top:6%;left:-4%}
  .orb-label.br{bottom:4%;right:-6%;flex-direction:row-reverse}
  .orb-label.tr{top:18%;right:-2%;flex-direction:row-reverse}
  .orb-leaf{position:absolute;color:var(--moss);opacity:.75}
  .orb-leaf.a{top:-2%;right:8%;transform:rotate(25deg)}
  .orb-leaf.b{bottom:-4%;left:6%;transform:rotate(-160deg)}

  /* Variant B: Botanical circuit */
  .botanical{position:absolute;inset:0;display:none;align-items:center;justify-content:center}
  .botanical svg{width:100%;height:100%}

  /* Variant C: Sunrise dawn */
  .dawn{position:absolute;inset:0;display:none;align-items:flex-end;justify-content:center;overflow:hidden;border-radius:18px}
  .dawn-sky{position:absolute;inset:0;background:linear-gradient(180deg, #F2EFE6 0%, #E8E9C4 45%, #C7D98A 70%, #8FAE5E 92%)}
  .dawn-sun{position:absolute;bottom:18%;left:50%;transform:translateX(-50%);width:58%;aspect-ratio:1;border-radius:50%;
    background:radial-gradient(circle at 50% 60%, #F7F2C8, #DCE79A 40%, #9BBC5D 70%, #4F7742 100%);
    box-shadow:0 0 120px 40px rgba(220,231,154,.55), inset 0 -20px 60px rgba(47,81,49,.35);
  }
  .dawn-ground{position:absolute;left:0;right:0;bottom:0;height:30%;background:linear-gradient(180deg, rgba(78,106,60,0), #2e4a2c 70%, #122219);
  }
  .dawn-lines{position:absolute;inset:0;pointer-events:none}
  .dawn-lines::before,.dawn-lines::after{content:"";position:absolute;left:0;right:0;height:1px;background:var(--line);}
  .dawn-lines::before{top:33%}
  .dawn-lines::after{top:66%}

  /* Switch by variant */
  [data-variant="orb"] .orb-scene{display:block}
  [data-variant="orb"] .botanical,[data-variant="orb"] .dawn{display:none}
  [data-variant="botanical"] .orb-scene{display:none}
  [data-variant="botanical"] .botanical{display:flex}
  [data-variant="botanical"] .dawn{display:none}
  [data-variant="dawn"] .orb-scene,[data-variant="dawn"] .botanical{display:none}
  [data-variant="dawn"] .dawn{display:flex}

  /* Corner botanicals in hero (decorative) */
  .hero-corner{position:absolute;pointer-events:none;opacity:.55;color:var(--moss)}
  .hero-corner.tl{top:40px;left:30px;width:120px}
  .hero-corner.br{bottom:40px;right:30px;width:140px;transform:scaleX(-1)}

  /* ---------- LOGO STRIP ---------- */
  .strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:28px 0;background:color-mix(in oklab, var(--cream) 75%, var(--cream-2))}
  .strip-inner{display:flex;align-items:center;gap:40px;justify-content:space-between;max-width:var(--max);margin:0 auto;padding:0 40px;flex-wrap:wrap}
  .strip-label{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);white-space:nowrap}
  .marquee{flex:1;min-width:0;overflow:hidden;
    -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%);
            mask-image:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%);
  }
  .marquee-track{display:flex;gap:48px;align-items:center;width:max-content;
    animation:marqueeScroll 40s linear infinite;opacity:.85;
  }
  .marquee:hover .marquee-track{animation-play-state:paused}
  .marquee-track .logo-mark{font-family:var(--font-display);font-weight:700;font-size:20px;letter-spacing:-.01em;color:var(--ink);display:flex;align-items:center;gap:10px;white-space:nowrap;flex:none}
  .marquee-track .logo-mark img{height:22px;width:auto;max-width:120px;display:block;flex:none}
  .marquee-track .logo-mark.wordmark img{height:22px;max-width:110px}
  @keyframes marqueeScroll{from{transform:translateX(0)}to{transform:translateX(calc(-50% - 24px))}}
  @media (prefers-reduced-motion: reduce){ .marquee-track{animation:none} }

  /* ---------- SECTIONS ---------- */
  section{padding:var(--pad-section) 0;position:relative}
  .sec-head{display:flex;justify-content:space-between;align-items:end;gap:40px;margin-bottom:64px;flex-wrap:wrap}
  .sec-head .t{max-width:720px}
  .sec-head .t h2{margin-top:16px}
  .sec-head .aside{max-width:320px;color:var(--ink-soft);font-size:15px}

  /* SERVICES */
  .services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
  .svc{
    position:relative;
    background:#fff;
    border:1px solid var(--line);
    border-radius:22px;
    padding:36px 32px 32px;
    overflow:hidden;
    transition:transform .25s ease, box-shadow .25s, border-color .25s;
  }
  .svc:hover{transform:translateY(-3px);border-color:var(--line-strong);box-shadow:0 24px 40px -28px rgba(14,42,31,.22)}
  .svc-num{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;color:var(--ink-soft)}
  .svc h3{margin-top:28px;font-size:28px;font-family:var(--font-display);font-weight:700}
  .svc p{margin-top:12px;color:var(--ink-soft);font-size:15px;max-width:440px}
  .svc ul{list-style:none;padding:0;margin:24px 0 0;display:flex;flex-wrap:wrap;gap:8px}
  .svc li{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;padding:6px 10px;border:1px solid var(--line);border-radius:999px;color:var(--ink-soft)}
  .svc .glyph{position:absolute;top:32px;right:32px;width:48px;height:48px;border-radius:14px;background:var(--cream-2);display:flex;align-items:center;justify-content:center;color:var(--moss)}
  .svc.feature{grid-column:span 2;background:linear-gradient(135deg, var(--cream-2), var(--cream))}
  .svc.feature h3{font-size:36px;max-width:520px}

  /* PROCESS */
  .process{background:var(--cream-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative;counter-reset:step}
  .process-steps::before{
    content:"";position:absolute;left:8%;right:8%;top:46px;height:1px;
    background:repeating-linear-gradient(to right, var(--moss) 0 6px, transparent 6px 14px);
    opacity:.5;
  }
  .step{position:relative;padding:0 18px;text-align:left}
  .step .bubble{
    width:92px;height:92px;border-radius:50%;background:var(--cream);border:1px solid var(--line-strong);
    display:flex;align-items:center;justify-content:center;margin-bottom:24px;
    position:relative;z-index:1;color:var(--moss);
  }
  .step.active .bubble{background:var(--ink);color:var(--lime);border-color:var(--ink)}
  .step .n{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.2em;color:var(--ink-soft);text-transform:uppercase}
  .step h3{margin-top:6px;font-size:22px}
  .step p{margin-top:10px;color:var(--ink-soft);font-size:14.5px;max-width:240px}

  /* CASE STUDIES — dark section */
  .cases{background:var(--ink);color:#E6E9DE;border-radius:40px;max-width:var(--max);margin:var(--pad-section) auto;padding:clamp(60px,8vw,110px) clamp(28px,5vw,72px) clamp(70px,8vw,110px);position:relative;overflow:hidden}
  section#cases{padding-left:24px;padding-right:24px}
  .cases::before{
    content:"";position:absolute;right:-18%;top:-30%;width:60%;aspect-ratio:1;border-radius:50%;
    background:radial-gradient(circle at 50% 50%, rgba(189,227,100,.28), rgba(189,227,100,0) 60%);
    filter:blur(30px);pointer-events:none;
  }
  .cases::after{
    content:"";position:absolute;left:-16%;bottom:-30%;width:50%;aspect-ratio:1;border-radius:50%;
    background:radial-gradient(circle at 50% 50%, rgba(80,136,90,.3), rgba(80,136,90,0) 60%);
    filter:blur(40px);pointer-events:none;
  }
  .cases .sec-head h2{color:#F3F1E4}
  .cases .eyebrow{color:var(--lime)}
  .cases .eyebrow::before{background:var(--lime)}
  .cases .sec-head .aside{color:#B4BCAC}
  .cases-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:24px;position:relative;z-index:1}
  .case{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:22px;padding:32px;display:flex;flex-direction:column;gap:16px}
  .case.big{grid-row:span 2;justify-content:space-between}
  .case h3{color:#F3F1E4;font-size:26px;font-family:var(--font-display)}
  .case p{color:#B4BCAC;font-size:15px}
  .case .kpis{display:flex;gap:24px;margin-top:8px}
  .case .k .v{font-family:var(--font-display);font-size:40px;font-weight:800;color:var(--lime);letter-spacing:-.03em;line-height:1}
  .case .k .l{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:#9CA895;margin-top:6px}
  .case .tag{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:#8EB17A;display:inline-flex;align-items:center;gap:8px}
  .case .tag::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--lime)}
  .case .chart{height:140px;border-radius:12px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);position:relative;overflow:hidden;margin-top:auto}
  .case .chart svg{width:100%;height:100%}

  /* TESTIMONIALS */
  .quotes{display:grid;grid-template-columns:2fr 1fr 1fr;gap:20px}
  .q{background:#fff;border:1px solid var(--line);border-radius:22px;padding:32px;display:flex;flex-direction:column;gap:18px;position:relative}
  .q.hero-q{grid-row:span 2;background:var(--ink);color:#E6E9DE;border-color:var(--ink)}
  .q.hero-q p{color:#E6E9DE}
  .q .stars{color:var(--amber);font-size:16px;letter-spacing:2px}
  .q p{font-size:17px;line-height:1.5;color:var(--ink)}
  .q.hero-q p.big{font-family:var(--font-display);font-size:26px;line-height:1.25;font-weight:500;color:#F3F1E4;letter-spacing:-.01em}
  .who{display:flex;align-items:center;gap:12px;margin-top:auto}
  .avatar{width:42px;height:42px;border-radius:50%;background:var(--cream-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;color:var(--moss);font-size:14px}
  .who .name{font-weight:600;font-size:14.5px}
  .who .role{font-size:12.5px;color:var(--ink-soft);font-family:var(--font-mono);letter-spacing:.06em}
  .q.hero-q .who .role{color:#9CA895}
  .q.hero-q .avatar{background:rgba(255,255,255,.1);color:var(--lime);border-color:rgba(255,255,255,.15)}

  /* PRICING */
  .pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
  .plan{background:#fff;border:1px solid var(--line);border-radius:22px;padding:36px 30px;display:flex;flex-direction:column;gap:8px;position:relative}
  .plan.popular{background:var(--ink);color:#E6E9DE;border-color:var(--ink)}
  .plan .name{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft)}
  .plan.popular .name{color:var(--lime)}
  .plan .price{font-family:var(--font-display);font-weight:800;font-size:56px;letter-spacing:-.03em;line-height:1;margin:14px 0 2px}
  .plan .price .slash{font-size:16px;font-weight:500;color:var(--ink-soft);letter-spacing:0;margin-left:4px}
  .plan.popular .price .slash{color:#9CA895}
  .plan .blurb{color:var(--ink-soft);font-size:14.5px;margin-bottom:20px}
  .plan.popular .blurb{color:#B4BCAC}
  .plan ul{list-style:none;padding:0;margin:0 0 24px;display:flex;flex-direction:column;gap:10px}
  .plan li{font-size:14.5px;display:flex;gap:10px;align-items:flex-start}
  .plan li::before{content:"";flex:none;width:16px;height:16px;border-radius:50%;background:var(--cream-2);margin-top:2px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'><path d='M2 6.5l2.5 2.5L10 3.5' stroke='%230E2A1F' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-position:center;background-repeat:no-repeat}
  .plan.popular li::before{background-color:rgba(189,227,100,.18);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'><path d='M2 6.5l2.5 2.5L10 3.5' stroke='%23BDE364' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>")}
  .plan .cta{margin-top:auto}
  .popular-tag{position:absolute;top:-12px;right:22px;background:var(--lime);color:var(--ink);font-family:var(--font-mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;padding:6px 10px;border-radius:999px;border:1px solid color-mix(in oklab, var(--lime) 60%, var(--ink))}
  .plan-guarantee{margin-top:4px;padding:12px 14px;border-radius:12px;background:var(--cream-2);font-size:13px;line-height:1.5;color:var(--ink-soft);border:1px dashed var(--line-strong)}
  .plan.popular .plan-guarantee{background:rgba(189,227,100,.08);border-color:rgba(189,227,100,.3);color:#D3DBC6}
  .plan-scarcity{margin-top:10px;margin-bottom:18px;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--moss);display:inline-flex;align-items:center;gap:8px}
  .plan-scarcity::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--moss)}
  .plan.popular .plan-scarcity{color:var(--lime)}
  .plan.popular .plan-scarcity::before{background:var(--lime)}
  .plan .name{display:block;min-height:36px;max-width:260px}

  /* FAQ */
  .faq-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:60px;align-items:start}
  details{border-top:1px solid var(--line);padding:22px 0;cursor:pointer}
  details:last-child{border-bottom:1px solid var(--line)}
  details summary{list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px;font-family:var(--font-display);font-weight:600;font-size:20px}
  details summary::-webkit-details-marker{display:none}
  details .a{margin-top:12px;color:var(--ink-soft);font-size:15.5px;max-width:640px}
  details .plus{flex:none;width:32px;height:32px;border-radius:50%;border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;color:var(--ink);transition:.2s}
  details[open] .plus{background:var(--ink);color:var(--lime);border-color:var(--ink);transform:rotate(45deg)}

  /* CTA */
  .cta-card{
    max-width:var(--max);
    margin:0 auto;border-radius:40px;overflow:hidden;position:relative;
    background:linear-gradient(135deg, #0E2A1F 0%, #153B2A 60%, #1F5A3B 100%);
    color:#E6E9DE;padding:clamp(60px,8vw,110px) clamp(28px,5vw,72px);
  }
  #cta{padding-left:24px;padding-right:24px}
  .cta-card::before{
    content:"";position:absolute;right:-10%;top:-40%;width:70%;aspect-ratio:1;border-radius:50%;
    background:radial-gradient(circle at 50% 50%, rgba(189,227,100,.35), rgba(189,227,100,0) 60%);
    filter:blur(20px);pointer-events:none;
  }
  .cta-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:50px;align-items:center;position:relative;z-index:1}
  .cta-card h2{color:#F3F1E4;max-width:620px}
  .cta-card .eyebrow{color:var(--lime)}
  .cta-card .eyebrow::before{background:var(--lime)}
  .cta-card p{color:#B4BCAC;margin-top:20px;max-width:560px;font-size:17px}
  .cta-form{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:22px;padding:24px;display:flex;flex-direction:column;width:100%;box-sizing:border-box;min-height:500px;position:relative;overflow:hidden}
  .cta-form .chat-head{display:flex;align-items:center;gap:12px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:16px}
  .cta-form .chat-avatar{width:40px;height:40px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#E8F5D2,#5A8B54 70%,#1F3E2B);flex:none;position:relative}
  .cta-form .chat-avatar::after{content:"";position:absolute;bottom:1px;right:1px;width:10px;height:10px;border-radius:50%;background:var(--lime);border:2px solid #14301F}
  .cta-form .chat-who{display:flex;flex-direction:column;gap:3px}
  .cta-form .chat-name{font-family:var(--font-display);font-weight:600;color:#F3F1E4;font-size:15px}
  .cta-form .chat-role{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.15em;text-transform:uppercase;color:#9CA895}
  .cta-form .chat-progress{margin-left:auto;display:flex;gap:4px}
  .cta-form .chat-progress i{width:16px;height:3px;border-radius:2px;background:rgba(255,255,255,.12);transition:.3s}
  .cta-form .chat-progress i.done{background:var(--lime)}
  .cta-form .chat-progress i.cur{background:rgba(189,227,100,.55)}
  .cta-form .chat-body{display:flex;flex-direction:column;gap:12px;flex:1;overflow-y:auto;padding-right:4px;max-height:360px}
  .cta-form .msg{max-width:85%;padding:12px 16px;border-radius:16px;font-size:15px;line-height:1.45;animation:msgIn .35s ease both}
  .cta-form .msg.bot{background:rgba(255,255,255,.08);color:#F3F1E4;border-bottom-left-radius:4px;align-self:flex-start}
  .cta-form .msg.user{background:var(--lime);color:var(--ink);border-bottom-right-radius:4px;align-self:flex-end;font-weight:500}
  .cta-form .typing{display:inline-flex;gap:4px;align-items:center;padding:14px 16px;background:rgba(255,255,255,.08);border-radius:16px;border-bottom-left-radius:4px;align-self:flex-start;animation:msgIn .35s ease both}
  .cta-form .typing span{width:6px;height:6px;border-radius:50%;background:#9CA895;animation:bounce 1.2s infinite ease-in-out}
  .cta-form .typing span:nth-child(2){animation-delay:.15s}
  .cta-form .typing span:nth-child(3){animation-delay:.3s}
  @keyframes bounce{0%,80%,100%{transform:translateY(0);opacity:.5}40%{transform:translateY(-4px);opacity:1}}
  @keyframes msgIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
  .cta-form .chat-input-row{margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,255,255,.08);display:flex;gap:10px;align-items:stretch;min-height:52px}
  .cta-form .chat-input-row input,
  .cta-form .chat-input-row textarea{
    flex:1;min-width:0;
    background:rgba(0,0,0,.22);border:1px solid rgba(255,255,255,.14);border-radius:12px;padding:13px 14px;
    color:#F3F1E4;font:inherit;font-size:15px;
    box-sizing:border-box;appearance:none;-webkit-appearance:none;resize:none;
  }
  .cta-form input::placeholder,.cta-form textarea::placeholder{color:rgba(243,241,228,.35)}
  .cta-form input:focus,.cta-form textarea:focus{outline:none;border-color:var(--lime)}
  .cta-form .chat-send{flex:none;background:var(--lime);color:var(--ink);border:none;padding:0 18px;border-radius:12px;font-weight:600;cursor:pointer;font-size:15px;display:inline-flex;align-items:center;gap:8px;transition:.2s}
  .cta-form .chat-send:hover{background:var(--lime-2)}
  .cta-form .chip-row{display:flex;flex-wrap:wrap;gap:8px;align-self:flex-start;width:100%}
  .cta-form .chip{background:rgba(255,255,255,.06);color:#F3F1E4;border:1px solid rgba(255,255,255,.14);padding:8px 14px;border-radius:999px;font-size:13.5px;cursor:pointer;transition:.15s;font-family:inherit}
  .cta-form .chip:hover{background:var(--lime);color:var(--ink);border-color:var(--lime)}
  .cta-form .done-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px 20px;gap:12px;flex:1}
  .cta-form .done-state .big{font-family:var(--font-display);font-size:26px;color:#F3F1E4;font-weight:600;letter-spacing:-.01em}
  .cta-form .done-state p{color:#B4BCAC;font-size:15px;max-width:340px;margin:0}
  .cta-form .done-check{width:56px;height:56px;border-radius:50%;background:var(--lime);display:flex;align-items:center;justify-content:center;color:var(--ink);margin-bottom:4px}

  /* FOOTER */
  footer{padding:70px 0 30px;background:var(--cream);border-top:1px solid var(--line)}
  .foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;max-width:var(--max);margin:0 auto;padding:0 40px}
  .foot-grid h4{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:18px;font-weight:500}
  .foot-grid ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
  .foot-grid a{font-size:15px}
  .foot-grid a:hover{color:var(--moss)}
  .foot-about{max-width:340px;color:var(--ink-soft);font-size:14.5px;margin-top:18px}
  .foot-bottom{max-width:var(--max);margin:60px auto 0;padding:24px 40px 0;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--ink-soft);font-family:var(--font-mono);letter-spacing:.06em;flex-wrap:wrap;gap:16px}

  /* Reveal animation */
  .reveal{opacity:0;transform:translateY(20px);transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1)}
  .reveal.in{opacity:1;transform:none}

  /* Tweaks panel */
  .tweaks{
    position:fixed;right:18px;bottom:18px;z-index:2000;
    background:var(--cream);border:1px solid var(--line-strong);border-radius:18px;
    box-shadow:0 24px 60px -16px rgba(14,42,31,.25);
    width:300px;padding:18px;display:none;font-family:var(--font-body);
  }
  .tweaks.on{display:block}
  .tweaks h5{margin:0 0 14px;font-family:var(--font-display);font-weight:700;font-size:15px;display:flex;justify-content:space-between;align-items:center}
  .tweaks h5 .tag{font-family:var(--font-mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--moss);background:color-mix(in oklab, var(--moss) 12%, transparent);padding:3px 8px;border-radius:999px}
  .tweaks label{display:block;font-family:var(--font-mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-soft);margin:14px 0 6px}
  .tweaks input[type="range"]{width:100%}
  .tweaks input[type="text"],.tweaks textarea{width:100%;padding:8px 10px;border:1px solid var(--line-strong);border-radius:8px;background:#fff;color:var(--ink);font:inherit;font-size:13px;resize:vertical}
  .seg{display:flex;gap:4px;background:var(--cream-2);padding:3px;border-radius:10px}
  .seg button{flex:1;padding:6px 8px;font-size:11.5px;border-radius:7px;font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}
  .seg button.on{background:var(--ink);color:var(--lime)}
  .swatch-row{display:flex;gap:6px;align-items:center}
  .swatch{width:22px;height:22px;border-radius:50%;border:1px solid var(--line-strong);cursor:pointer}
  .swatch.on{outline:2px solid var(--ink);outline-offset:2px}

  /* Responsive */
  @media (max-width: 960px){
    .hero-grid{grid-template-columns:1fr}
    .hero-visual{min-height:360px}
    .services-grid{grid-template-columns:1fr}
    .svc.feature{grid-column:span 1}
    .process-steps{grid-template-columns:1fr 1fr}
    .process-steps::before{display:none}
    .cases-grid{grid-template-columns:1fr}
    .case.big{grid-row:auto}
    .quotes{grid-template-columns:1fr}
    .q.hero-q{grid-row:auto}
    .pricing-grid{grid-template-columns:1fr}
    .faq-grid{grid-template-columns:1fr}
    .cta-grid{grid-template-columns:1fr}
    .foot-grid{grid-template-columns:1fr 1fr}
    .nav-links{display:none}
  }

  /* Accent color variable (controlled by tweaks) */
  [data-density="compact"] .cases,[data-density="compact"] .cta-card{margin-top:0;margin-bottom:0}
