:root{
    --bg:       oklch(97% 0.016 74);
    --surface:  oklch(99% 0.008 70);
    --surface-alt: oklch(94% 0.015 74);
    --fg:       oklch(23% 0.024 155);
    --muted:    oklch(55% 0.018 150);
    --border:   oklch(88% 0.014 74);
    --accent:   oklch(56% 0.05 145);
    --accent-soft: oklch(78% 0.03 145 / 0.18);
    --radius:   18px;
    --wrap:     1280px;
    --display:  "DM Sans","Avenir Next","Segoe UI",system-ui,sans-serif;
    --body:     "Manrope","Segoe UI",system-ui,sans-serif;
    --serif:    "Newsreader","Iowan Old Style",Georgia,serif;
  }
  *,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
  body{
    font-family:var(--body);color:var(--fg);background:var(--bg);
    line-height:1.72;font-size:17px;
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
    overflow-x:hidden;
  }
  img{display:block;max-width:100%;height:auto}
  ul{list-style:none}
  a{color:inherit;text-decoration:none}
  button,input,select,textarea{font:inherit;color:inherit;background:none;border:none}

  .wrap{width:min(calc(100% - clamp(24px,4vw,40px)),1280px);margin:0 auto}
  .section{padding:clamp(84px,9vw,110px) 0}
  .alt{background:var(--surface-alt);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
  .section-head{max-width:760px;margin:0 auto clamp(28px,4vw,34px);text-align:center}
  .kicker{font-family:var(--display);font-size:11px;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
  h1,h2,h3,h4{text-wrap:pretty}
  em{font-family:var(--serif);font-style:italic}
  h1{font-family:var(--display);font-size:clamp(56px,10vw,108px);font-weight:500;letter-spacing:-.04em;line-height:.92}
  h2{font-family:var(--display);font-size:clamp(38px,6vw,58px);font-weight:500;letter-spacing:-.03em;line-height:1.05}
  h3{font-family:var(--display);font-size:clamp(20px,2.5vw,28px);font-weight:500;letter-spacing:-.02em;line-height:1.2}
  .section-head p{font-size:17px;color:var(--muted);margin-top:14px;line-height:1.72}

  /* ===== HERO ===== */
  .hero{min-height:clamp(620px,88svh,940px);display:flex;align-items:center}
  .hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,84px);align-items:center;width:min(calc(100% - clamp(24px,4vw,40px)),1280px);margin:0 auto}
  .hero-copy .kicker{margin-bottom:16px}
  .hero-copy h1{margin-bottom:32px}
  .hero-lede{font-size:18px;line-height:1.72;color:var(--muted);margin-bottom:8px}
  .hero-sub{font-size:17px;line-height:1.72;color:var(--muted);margin-bottom:40px}
  .hero-actions{display:flex;flex-wrap:wrap;gap:14px}
  .hero-media{position:relative;display:flex;align-items:center;justify-content:center}
  .hero-photo{position:relative;width:100%;aspect-ratio:6/7;border-radius:28px;overflow:hidden;background:linear-gradient(135deg,var(--accent-soft),color-mix(in oklch,var(--fg) 6%,var(--surface) 94%))}
  .hero-photo img{width:100%;height:100%;object-fit:cover;opacity:.92;mix-blend-mode:multiply}
  .hero-note{position:absolute;bottom:-18px;left:24px;right:0;display:inline-flex;gap:6px;font-family:var(--body);font-size:13px;color:var(--muted);align-items:center}
  .hero-note strong{font-weight:700;color:var(--fg)}

  .button{display:inline-flex;align-items:center;justify-content:center;min-height:54px;padding:16px 28px;border-radius:999px;font-size:12px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;transition:transform .18s ease,box-shadow .18s ease;cursor:pointer}
  .button:hover{transform:translateY(-2px)}
  .button-dark{background:var(--fg);color:var(--surface);box-shadow:0 12px 24px oklch(22% 0.018 150 / .12)}
  .button-ghost{background:transparent;color:var(--fg);box-shadow:inset 0 0 0 1px color-mix(in oklch,var(--fg) 28%,var(--bg) 72%)}
  .button-ghost:hover{box-shadow:inset 0 0 0 1px var(--fg)}
  .button-light{background:oklch(98% 0.01 80);color:oklch(24% 0.022 150);box-shadow:0 14px 30px oklch(18% 0.016 150 / .18)}
  .button-light:hover{background:#fff;box-shadow:0 18px 36px oklch(18% 0.016 150 / .22)}

  /* ===== TRUST BAND ===== */
  .trust-band{padding:40px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden}
  .marquee{--speed:28s;overflow:hidden;font-family:var(--display);font-size:15px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:color-mix(in oklch,var(--muted) 60%,var(--border) 40%);white-space:nowrap}
  .marquee-track{display:inline-flex;gap:48px;animation:marquee var(--speed) linear infinite}
  .marquee-track span{flex-shrink:0}
  @keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

  /* ===== WHY / BENTO ===== */
  .why-section .split-head{display:block}
  .why-section .split-head>p{max-width:640px;margin-top:14px;font-size:17px;color:var(--muted);line-height:1.72}
  .bento-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:clamp(48px,5vw,72px)}
  .bento-card{background:var(--surface);border:1px solid color-mix(in oklch,var(--fg) 4%,white 96%);border-radius:var(--radius);padding:36px 28px;transition:transform .22s ease,box-shadow .22s ease}
  .bento-card:hover{transform:translateY(-4px);box-shadow:0 24px 48px oklch(22% 0.015 150 / .12)}
  .bento-large{grid-column:span 2}
  .bento-tall{grid-row:span 2}
  .bento-card .icon-disk{width:48px;height:48px;border-radius:50%;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
  .bento-card .icon-disk svg{width:24px;height:24px;stroke:var(--fg);stroke-width:1.5;fill:none;stroke-linecap:round;stroke-linejoin:round}
  .bento-card h3{font-size:20px;font-weight:500;margin-bottom:6px}
  .bento-card p{font-size:15px;color:var(--muted);line-height:1.65}
  .image-card{padding:0;border-radius:var(--radius);overflow:hidden;min-height:220px}
  .image-card img{width:100%;height:100%;object-fit:cover}

  /* ===== FRAMEWORK ===== */
  .framework-grid{display:grid;grid-template-columns:0.65fr 1fr;gap:clamp(32px,5vw,76px)}
  .sticky-panel{position:sticky;top:64px;align-self:start}
  .sticky-panel h2{margin:16px 0 8px}
  .sticky-panel>p{color:var(--muted);font-size:17px;line-height:1.72}
  .steps-stack{display:flex;gap:clamp(36px,4vw,64px);align-items:flex-start}
  @media(max-width:1100px){.steps-stack{flex-wrap:wrap;gap:40px}}
  @media(max-width:720px){.steps-stack{gap:32px}}
  .step-card{flex:1;min-width:0}
  .step-card .step-letter{display:block;font-family:var(--serif);font-size:clamp(52px,5vw,68px);font-style:italic;font-weight:400;letter-spacing:-.05em;line-height:.85;color:oklch(23% 0.024 155 / .18);margin:0 0 18px}
  .step-card h3{font-size:11px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--fg);margin:0 0 8px;line-height:1.1}
  .step-card>p{font-size:15px;color:oklch(55% 0.018 150 / .76);line-height:1.5;margin:0 0 18px}
  .step-card ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
  .step-card li{
    display:grid;grid-template-columns:6px 1fr;column-gap:12px;align-items:start;
    font-size:13.5px;color:var(--muted);line-height:1.55;
  }
  .step-card li::before{
    content:"";width:4px;height:4px;border-radius:999px;background:var(--accent);
    margin-top:9px;justify-self:center;
  }

  /* ===== PROGRAMS — EDITORIAL ASYMMETRIC LIST ===== */
  .programs-section{padding:clamp(112px,13vw,164px) 0}
  .programs-section .section-head{max-width:520px}
  .programs-section .section-head p{max-width:560px;margin-left:auto;margin-right:auto}

  .program-list{
    width:min(calc(100% - clamp(24px,4vw,40px)),1040px);
    margin:0 auto;
    display:flex;flex-direction:column;gap:20px;
  }

  .program-card{
    display:grid;grid-template-columns:200px 1fr;gap:32px;
    padding:28px;border-radius:24px;
    background:oklch(98% 0.01 74);
    border:1px solid color-mix(in oklch,var(--fg) 3%,var(--surface));
    position:relative;overflow:hidden;
    transition:transform 280ms cubic-bezier(.22,1,.36,1),box-shadow 280ms cubic-bezier(.22,1,.36,1);
  }
  .program-card:hover{transform:translateY(-3px);box-shadow:0 20px 48px oklch(22% 0.012 150 / .10)}
  .program-card:nth-child(even){margin-left:40px}

  .program-card-number{
    position:absolute;top:24px;right:28px;
    font-family:var(--serif);font-style:italic;
    font-size:14px;color:var(--fg);opacity:.12;
    letter-spacing:-.02em;
  }

  .program-card-image{
    aspect-ratio:4/3;border-radius:20px;overflow:hidden;
    background:linear-gradient(135deg,var(--accent-soft),var(--surface-alt));
  }
  .program-card-image img{
    width:100%;height:100%;object-fit:cover;
    filter:grayscale(15%) contrast(105%);opacity:.92;
    transition:transform 380ms cubic-bezier(.22,1,.36,1);
  }
  .program-card:hover .program-card-image img{transform:scale(1.04)}

  .program-card-content{padding-right:60px;position:relative;display:flex;flex-direction:column}
  .program-card-content .card-eyebrow{
    font-size:11px;font-weight:800;letter-spacing:.20em;text-transform:uppercase;
    color:var(--muted);margin-bottom:8px;
  }
  .program-card-content h3{
    font-size:clamp(22px,2.4vw,30px);font-weight:500;letter-spacing:-.025em;
    line-height:1.15;margin-bottom:10px;
  }
  .program-card-content>p{
    font-size:15px;color:var(--muted);line-height:1.62;
    max-width:60ch;margin-bottom:18px;
  }
  .program-card-details{display:grid;grid-template-columns:1fr 1fr;gap:16px 28px}
  .program-card-details div>strong{
    display:block;font-size:11px;font-weight:800;letter-spacing:.16em;
    text-transform:uppercase;color:var(--fg);margin-bottom:6px;
  }
  .program-card-details li{
    font-size:14px;color:var(--muted);line-height:1.65;
    padding-left:18px;position:relative;margin-bottom:3px;
  }
  .program-card-details li::before{
    content:"";position:absolute;left:0;top:.6em;
    width:5px;height:5px;border-radius:999px;background:var(--accent);
  }
  .program-card-arrow{
    display:inline-flex;align-items:center;gap:6px;
    margin-top:18px;font-size:13px;font-weight:700;letter-spacing:.06em;
    color:var(--accent);
    transition:gap 280ms cubic-bezier(.22,1,.36,1),color 180ms ease;
  }
  .program-card:hover .program-card-arrow{gap:10px;color:var(--fg)}
  .program-card-arrow svg{width:16px;height:16px;stroke:currentColor;stroke-width:2;fill:none}

  /* Programs — Tablet */
  @media(max-width:900px){
    .program-card{grid-template-columns:160px 1fr;gap:24px;padding:22px}
    .program-card:nth-child(even){margin-left:20px}
    .program-card-details{grid-template-columns:1fr}
  }
  /* Programs — Mobile */
  @media(max-width:720px){
    .program-card{grid-template-columns:1fr;padding:20px 18px}
    .program-card-image{aspect-ratio:16/9;max-height:200px}
    .program-card:nth-child(even){margin-left:0}
    .program-card-content{padding-right:0}
    .program-card-content h3{font-size:22px}
  }

  /* ===== OUTCOMES ===== */
  .outcome-shell>div:first-child{text-align:center;max-width:760px;margin:0 auto 48px}
  .outcome-list{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
  .outcome-list article{text-align:center;padding:32px 20px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);transition:transform .18s ease}
  .outcome-list article:hover{transform:translateY(-2px)}
  .outcome-list article>span{display:block;font-family:var(--display);font-size:11px;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
  .outcome-list h3{font-size:clamp(18px,2vw,24px);margin-bottom:6px}
  .outcome-list p{font-size:14px;color:var(--muted);line-height:1.65}
  @media(max-width:900px){.outcome-list{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:560px){.outcome-list{grid-template-columns:1fr}}

  /* ===== IMPACT ===== */
  .impact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px)}
  .impact-grid .impact-copy .kicker{text-align:left;margin-bottom:12px}
  .impact-grid .impact-copy h2{margin:0}
  .metric{padding:32px 0;border-top:1px solid var(--border)}
  .metric strong{font-family:var(--display);font-size:clamp(44px,5vw,64px);font-weight:500;letter-spacing:-.04em;line-height:1;color:var(--fg)}
  .metric span{font-family:var(--display);font-size:clamp(28px,3vw,40px);font-weight:400;color:var(--accent)}
  .metric p{font-size:15px;color:var(--muted);line-height:1.65}
  .metric-large{border-top:2px solid var(--fg)}
  @media(max-width:900px){.impact-grid{grid-template-columns:1fr}}

  /* ===== CTA — FULL-WIDTH DARK EDITORIAL ===== */
  .cta-shell-full{
    padding:clamp(72px,9vw,124px) 0;
    background:linear-gradient(160deg, oklch(28% 0.035 148), oklch(23% 0.028 156 / 0.6), oklch(20% 0.022 160));
    position:relative;overflow:hidden;
  }
  .cta-shell-full::before{
    content:"";position:absolute;top:-240px;right:10%;
    width:520px;height:520px;border-radius:50%;
    background:oklch(40% 0.04 145 / .18);filter:blur(120px);pointer-events:none;
  }
  .cta-inner-full{position:relative;width:min(calc(100% - clamp(24px,4vw,40px)),1280px);margin:0 auto;text-align:center}
  .cta-inner-full > .kicker{color:oklch(80% 0.018 145 / .70);display:block;margin-bottom:14px}
  .cta-inner-full h2{color:oklch(97% 0.008 120);font-size:clamp(40px,5.4vw,76px);letter-spacing:-.045em;line-height:.96;margin:0 auto 16px;max-width:740px}
  .cta-inner-full .cta-copy{color:oklch(85% 0.014 145 / .80);font-size:17px;line-height:1.72;margin:0 auto clamp(40px,5vw,64px);max-width:560px}

  .cta-route-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
  .cta-route-card{
    display:flex;flex-direction:column;
    padding:clamp(24px,2.5vw,36px) clamp(20px,2vw,28px);
    border-radius:20px;border:1px solid oklch(100% 0 0 / .08);background:oklch(100% 0 0 / .04);
    text-align:left;text-decoration:none;color:inherit;
    transition:transform .2s ease,border-color .2s ease,background .2s ease;
    position:relative;overflow:hidden;
  }
  .cta-route-card::before{
    content:"";position:absolute;top:0;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent,oklch(100% 0 0 / .06),transparent);
    opacity:0;transition:opacity .2s ease;
  }
  .cta-route-card:hover{transform:translateY(-3px);border-color:oklch(100% 0 0 / .14);background:oklch(100% 0 0 / .07)}
  .cta-route-card:hover::before{opacity:1}
  .cta-route-card,.cta-route-card *{text-decoration:none!important}
  .cta-route-card .card-eyebrow{font-size:11px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:oklch(90% 0.014 145 / .65);margin-bottom:12px;display:flex;align-items:center;gap:10px}
  .cta-route-card .card-number{font-family:var(--serif);font-size:14px;font-style:italic;color:oklch(70% 0.025 145 / .50)}
  .cta-route-card h3{color:oklch(98% 0.008 80);font-size:clamp(20px,2.2vw,26px);font-weight:500;letter-spacing:-.02em;line-height:1.18;margin:12px 0 8px}
  .cta-route-card p{color:oklch(82% 0.014 145 / .72);font-size:14.5px;line-height:1.65;margin-bottom:20px;flex-grow:1}
  .cta-route-card .card-action{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:700;letter-spacing:.06em;color:oklch(90% 0.014 145 / .80);transition:gap .18s ease,color .18s ease}
  .cta-route-card:hover .card-action{gap:10px;color:oklch(98% 0.008 120)}
  .cta-route-card .card-action svg{width:16px;height:16px;stroke:currentColor;stroke-width:2;fill:none}
  .cta-bottom-note{margin-top:clamp(28px,3vw,40px);font-size:14px;line-height:1.72;color:oklch(78% 0.012 145 / .55)}

  /* ===== RESPONSIVE ===== */
  @media(max-width:1100px){
    .hero-grid{grid-template-columns:1fr}
    .hero-media{order:-1}
    .framework-grid{grid-template-columns:1fr}
    .sticky-panel{position:static}
    .bento-grid{grid-template-columns:repeat(2,1fr)}
    .bento-large{grid-column:span 1}
    .bento-tall{grid-row:span 1}
    .cta-route-row{grid-template-columns:repeat(2,1fr)}
  }
  @media(max-width:720px){
    h1{font-size:clamp(40px,12vw,64px)}
    h2{font-size:clamp(28px,8vw,42px);line-height:1.08}
    .section{padding:64px 0}
    .hero-actions{flex-direction:column}
    .bento-grid{grid-template-columns:1fr}
    .cta-route-row{grid-template-columns:1fr}
  }
  @media(max-width:560px){
    .hero-note{display:none}
  }