/* ============================================================
   Arboretum Ingredients — shared stylesheet
   Consolidates the charte from the reference templates.
   ============================================================ */

:root{
  --ink:#222220;
  --soft:#6a6e60;
  --white:#ffffff;
  --cloud:#f6f6f1;
  --leaf:#6d714c;
  --leaf-deep:#565a39;
  --lime:#c8d182;
  --lime-soft:#dfe6b8;
  --citrus:#b3a05a;
  --sky:#8a9a86;
  --line:#e6e6dd;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--white);color:var(--ink);font-family:'Inter',sans-serif;font-weight:400;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3{font-family:'Inter',sans-serif;font-weight:400;line-height:1.1;letter-spacing:-.02em}
h1 em,h2 em,h3 em{font-weight:300;font-style:italic}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1240px;margin:0 auto;padding:0 40px}
.eyebrow{font-size:12px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;color:var(--leaf-deep)}

/* ---------- BUTTONS (light surfaces by default) ---------- */
.btn-primary{display:inline-block;background:var(--leaf-deep);color:var(--white);padding:15px 30px;border-radius:42px;font-size:14px;letter-spacing:.04em;font-weight:500;transition:transform .3s ease,background .3s ease}
.btn-primary:hover{background:var(--ink);transform:translateY(-2px)}
.btn-ghost{display:inline-block;padding:15px 30px;border:1px solid var(--ink);border-radius:42px;font-size:14px;letter-spacing:.04em;transition:all .3s ease}
.btn-ghost:hover{background:var(--ink);color:var(--white)}

/* ---------- NAV ---------- */
nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:80px;gap:24px}
.logo{display:flex;align-items:center}
.logo-full{height:50px;width:auto;display:block}
.logo-sym{height:46px;width:auto;display:none}
.nav-links{display:flex;align-items:center;gap:26px;font-size:14px;letter-spacing:.02em}
.nav-links>a,.nav-top{position:relative;padding:6px 0;color:var(--ink)}
.nav-links>a::after,.nav-top::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--leaf);transition:width .35s ease}
.nav-links>a:hover::after,.nav-item:hover .nav-top::after,.nav-item:focus-within .nav-top::after{width:100%}
.nav-cta{background:var(--leaf-deep);color:var(--white);border-radius:40px;padding:12px 24px;font-size:13px;letter-spacing:.04em;transition:all .3s ease;white-space:nowrap}
.nav-cta:hover{background:var(--ink);transform:translateY(-2px)}

/* dropdown (Ingredients) */
.nav-item{position:relative;display:flex;align-items:center}
.nav-top{display:inline-flex;align-items:center;gap:7px;cursor:pointer}
.nav-top .caret{font-size:9px;line-height:1;transition:transform .25s ease}
.nav-item:hover .caret,.nav-item:focus-within .caret{transform:rotate(180deg)}
.dropdown{position:absolute;top:calc(100% + 6px);left:0;min-width:210px;background:var(--white);border:1px solid var(--line);border-radius:14px;box-shadow:0 24px 44px -28px rgba(22,36,28,.45);padding:10px;display:flex;flex-direction:column;gap:2px;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .25s ease,transform .25s ease,visibility .25s;z-index:60}
.dropdown a{padding:11px 14px;border-radius:9px;font-size:14px;color:var(--ink);transition:background .2s ease,color .2s ease}
.dropdown a::after{content:none}
.dropdown a:hover{background:var(--cloud);color:var(--leaf-deep)}
.nav-item:hover .dropdown,.nav-item:focus-within .dropdown{opacity:1;visibility:visible;transform:translateY(0)}

/* burger (mobile) */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;border:1px solid var(--line);border-radius:10px;background:var(--white);cursor:pointer}
.nav-toggle span{display:block;width:18px;height:2px;background:var(--ink);margin:0 auto;transition:transform .3s ease,opacity .3s ease}
nav.open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
nav.open .nav-toggle span:nth-child(2){opacity:0}
nav.open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- BREADCRUMB ---------- */
.crumb{padding:26px 0 0;font-size:13px;color:var(--soft);letter-spacing:.02em}
.crumb a:hover{color:var(--leaf-deep)}

/* ---------- HERO (home — dark video) ---------- */
.hero{position:relative;min-height:90vh;margin:16px;border-radius:28px;display:flex;align-items:center;overflow:hidden;background:#04140c}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-media video,.hero-media img{width:100%;height:100%;object-fit:contain;object-position:right bottom;display:block;background:#04140c}
.hero-media::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(4,20,12,.92) 0%,rgba(4,20,12,.75) 32%,rgba(4,20,12,.25) 60%,rgba(4,20,12,0) 100%)}
.hero-inner{position:relative;z-index:2;width:100%}
.hero .eyebrow{color:var(--lime)}
.hero-copy{max-width:560px}
.hero h1{font-size:clamp(44px,5.6vw,82px);font-weight:300;color:var(--white);margin-top:18px}
.hero h1 em{font-style:italic;color:var(--lime)}
.hero-lead{margin-top:26px;max-width:430px;font-size:18px;color:rgba(255,255,255,.82)}
.hero-actions{margin-top:38px;display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.hero .btn-primary{background:var(--lime);color:var(--ink);padding:16px 34px}
.hero .btn-primary:hover{background:var(--white);transform:translateY(-2px)}
.hero .btn-ghost{border:none;padding:0 0 4px;color:var(--white);border-bottom:2px solid var(--lime);border-radius:0}
.hero .btn-ghost:hover{background:transparent;color:var(--white)}
.hero-scroll{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:2;color:rgba(255,255,255,.6);font-size:11px;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px}
.hero-scroll span{width:1px;height:34px;background:linear-gradient(rgba(255,255,255,.6),transparent)}

/* ---------- MARQUEE ---------- */
.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--cloud)}
.strip-inner{display:flex;gap:56px;padding:20px 0;white-space:nowrap;animation:slide 30s linear infinite}
.strip span{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--soft);display:flex;align-items:center;gap:56px;font-weight:500}
.strip span::after{content:"\25CF";color:var(--leaf);font-size:8px}
@keyframes slide{to{transform:translateX(-50%)}}

/* ---------- SECTION SHELL ---------- */
section{padding:104px 0}
.sec-head{max-width:680px;margin-bottom:54px}
.sec-head h2{font-size:clamp(33px,3.7vw,52px);margin-top:15px;font-weight:300}
.sec-head h2 em{font-style:italic;color:var(--leaf-deep)}

/* ---------- PILLARS (home) ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.pillar{border-radius:22px;background:var(--white);border:1px solid var(--line);overflow:hidden;transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease}
.pillar:hover{transform:translateY(-8px);box-shadow:0 32px 54px -34px rgba(22,36,28,.34);border-color:transparent}
.pillar-img{aspect-ratio:5/3;overflow:hidden;background:var(--cloud)}
.pillar-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.pillar:hover .pillar-img img{transform:scale(1.06)}
.pillar-body{padding:30px 30px 36px}
.pillar .ico{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.pillar:nth-child(1) .ico{background:rgba(58,166,111,.16);color:var(--leaf-deep)}
.pillar:nth-child(2) .ico{background:rgba(255,138,61,.16);color:var(--citrus)}
.pillar:nth-child(3) .ico{background:rgba(61,181,214,.16);color:var(--sky)}
.pillar .ico svg{width:24px;height:24px}
.pillar h3{font-size:23px;margin-bottom:10px}
.pillar p{font-size:15px;color:var(--soft)}

/* ---------- PRODUCTS (home / ingredients) ---------- */
.products{background:var(--cloud)}
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:12px}
.prod{border-radius:22px;background:var(--white);border:1px solid var(--line);overflow:hidden;transition:transform .35s ease,box-shadow .35s ease;display:flex;flex-direction:column}
.prod:hover{transform:translateY(-8px);box-shadow:0 32px 54px -34px rgba(22,36,28,.34)}
.prod-img{aspect-ratio:4/3;overflow:hidden;position:relative}
.prod-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.prod:hover .prod-img img{transform:scale(1.05)}
.prod-img .badge{position:absolute;top:18px;left:18px;background:var(--white);border-radius:30px;padding:7px 14px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--ink)}
.prod-body{padding:28px 30px 32px;flex:1;display:flex;flex-direction:column}
.prod .swatch{height:4px;border-radius:4px;width:42px;margin-bottom:18px}
.prod:nth-child(1) .swatch{background:var(--leaf)}
.prod:nth-child(2) .swatch{background:var(--citrus)}
.prod:nth-child(3) .swatch{background:var(--sky)}
.prod h3{font-size:28px;margin-bottom:10px}
.prod p{font-size:14.5px;color:var(--soft);margin-bottom:22px;flex:1}
.prod .more{font-size:13px;letter-spacing:.04em;font-weight:500;display:inline-flex;align-items:center;gap:7px;align-self:flex-start;color:var(--leaf-deep)}
.prod .more svg{width:15px;height:15px;transition:transform .3s ease}
.prod:hover .more svg{transform:translateX(4px)}

/* ---------- PROCESS (home) ---------- */
.process-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:70px;align-items:center}
.process-visual{aspect-ratio:1;border-radius:28px;overflow:hidden;position:relative;background:var(--cloud)}
.process-visual img{width:100%;height:100%;object-fit:cover}
.steps{counter-reset:s}
.step{display:flex;gap:24px;padding:26px 0;border-bottom:1px solid var(--line)}
.step:last-child{border-bottom:none}
.step .n{counter-increment:s;font-family:'Inter',sans-serif;font-size:17px;min-width:44px;height:44px;border-radius:50%;background:var(--cloud);color:var(--leaf-deep);display:flex;align-items:center;justify-content:center}
.step .n::before{content:"0" counter(s)}
.step h3{font-size:22px;margin-bottom:6px}
.step p{font-size:14.5px;color:var(--soft)}

/* ---------- LAB BAND (home) ---------- */
.labband{position:relative;padding:0;height:340px;overflow:hidden;border-radius:24px}
.labband img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.labband::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,rgba(31,125,77,.85) 0%,rgba(31,125,77,.4) 60%,transparent 100%)}
.labband-content{position:relative;z-index:2;height:100%;display:flex;align-items:center;padding:0 52px}
.labband h2{color:var(--white);font-size:clamp(28px,3.3vw,46px);font-weight:300;max-width:620px}
.labband h2 em{font-style:italic;color:var(--lime)}

/* ---------- PROOF (home) ---------- */
.proof{color:var(--white)}
.proof-band{background:var(--leaf-deep);border-radius:24px;padding:72px 48px}
.proof .eyebrow{color:var(--lime)}
.proof-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center;margin-top:12px}
.proof-grid .num{font-family:'Inter',sans-serif;font-size:clamp(44px,5vw,68px);color:var(--white);font-weight:300}
.proof-grid .lbl{font-size:13px;letter-spacing:.04em;color:rgba(255,255,255,.78);margin-top:8px}

/* ---------- CTA ---------- */
.cta{text-align:center;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:680px;height:680px;border-radius:50%;background:radial-gradient(circle,rgba(183,227,74,.4),transparent 62%);z-index:-1}
.cta h2{font-size:clamp(36px,4.4vw,64px);font-weight:300;max-width:780px;margin:18px auto 0}
.cta h2 em{font-style:italic;color:var(--leaf-deep)}
.cta p{max-width:480px;margin:24px auto 38px;color:var(--soft);font-size:16px}

/* ---------- PRODUCT HERO ---------- */
.phero{padding:46px 0 90px}
.phero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.phero .tag{display:inline-block;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--leaf-deep);font-weight:600;background:rgba(58,166,111,.12);padding:7px 14px;border-radius:30px}
.phero h1{font-size:clamp(48px,6vw,82px);font-weight:300;margin:22px 0 0}
.phero h1 em{font-style:italic;color:var(--leaf-deep)}
.phero .sub{font-size:21px;color:var(--ink);margin-top:18px;font-weight:500;font-family:'Inter',sans-serif}
.phero .lead{font-size:17px;color:var(--soft);margin-top:18px;max-width:480px}
.phero-actions{margin-top:34px;display:flex;gap:16px;flex-wrap:wrap}
.phero-visual{position:relative;aspect-ratio:4/5;border-radius:28px;overflow:hidden;background:var(--cloud)}
.phero-visual img{width:100%;height:100%;object-fit:cover}
.phero-badge{position:absolute;left:24px;bottom:24px;background:rgba(255,255,255,.94);backdrop-filter:blur(6px);border-radius:14px;padding:14px 18px;font-size:13px;max-width:230px;box-shadow:0 20px 40px -24px rgba(22,36,28,.5)}
.phero-badge strong{display:block;font-family:'Inter',sans-serif;font-size:15px;color:var(--leaf-deep);margin-bottom:2px}

/* ---------- QUICK SPECS ---------- */
.specs-bar{background:var(--cloud);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.specs-bar .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;padding-top:34px;padding-bottom:34px}
.spec .k{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--soft);font-weight:600}
.spec .v{font-family:'Inter',sans-serif;font-size:19px;color:var(--ink);margin-top:6px}

/* ---------- BENEFITS ---------- */
.benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.benefit{border:1px solid var(--line);border-radius:20px;padding:36px 30px;transition:transform .35s ease,box-shadow .35s ease}
.benefit:hover{transform:translateY(-6px);box-shadow:0 30px 50px -34px rgba(22,36,28,.32)}
.benefit .ico{width:48px;height:48px;border-radius:12px;background:rgba(58,166,111,.14);color:var(--leaf-deep);display:flex;align-items:center;justify-content:center;margin-bottom:22px}
.benefit .ico svg{width:25px;height:25px}
.benefit h3{font-size:21px;margin-bottom:10px}
.benefit p{font-size:14.5px;color:var(--soft)}

/* ---------- EVIDENCE (dark) ---------- */
.evidence{background:var(--leaf-deep);color:var(--white)}
.evidence .eyebrow{color:var(--lime)}
.evidence h2{color:var(--white)}
.evidence h2 em{color:var(--lime)}
.ev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:14px}
.ev{border:1px solid rgba(255,255,255,.18);border-radius:18px;padding:34px 30px;background:rgba(255,255,255,.05)}
.ev .num{font-family:'Inter',sans-serif;font-size:54px;font-weight:300;color:var(--lime);line-height:1}
.ev .num span{font-size:26px}
.ev p{font-size:14.5px;color:rgba(255,255,255,.85);margin-top:12px}
.ev-note{font-size:12.5px;color:rgba(255,255,255,.6);margin-top:30px;max-width:680px}

/* ---------- BEFORE / AFTER (inside .evidence) ---------- */
.ba-block{margin-top:52px;display:flex;flex-direction:column;align-items:center}
.ba-title{color:var(--white);font-weight:300;font-size:23px;margin-bottom:8px}
.ba-sub{color:rgba(255,255,255,.7);font-size:14px;margin-bottom:24px;text-align:center}
.ba-figure{margin:0;max-width:600px;width:100%}
.ba{--pos:50%;position:relative;width:100%;aspect-ratio:4/3;border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.25);background:var(--cloud);touch-action:none;user-select:none;cursor:ew-resize}
.ba-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
.ba-before{clip-path:inset(0 calc(100% - var(--pos)) 0 0)}
.ba--portrait{aspect-ratio:3/4;max-width:360px;margin:0 auto}
.ba-divider{position:absolute;top:0;bottom:0;left:var(--pos);width:2px;margin-left:-1px;background:var(--white);box-shadow:0 0 0 1px rgba(34,34,32,.18)}
.ba-handle{position:absolute;top:50%;left:var(--pos);width:46px;height:46px;transform:translate(-50%,-50%);border:none;border-radius:50%;background:var(--white);color:var(--leaf-deep);cursor:ew-resize;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 20px -7px rgba(34,34,32,.55)}
.ba-handle svg{width:22px;height:22px}
.ba-handle:focus-visible{outline:2px solid var(--lime);outline-offset:3px}
.ba-tag{position:absolute;top:14px;font-size:11px;letter-spacing:.07em;text-transform:uppercase;color:#fff;background:rgba(34,34,32,.55);padding:5px 11px;border-radius:30px;pointer-events:none;transition:opacity .2s ease}
.ba-tag--before{left:14px}
.ba-tag--after{right:14px}
.ba-figure figcaption{margin-top:16px;font-size:13px;color:rgba(255,255,255,.75);line-height:1.55;text-align:center}
/* static before/after pair on dark evidence band */
.clin-pair{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:780px;width:100%;margin:0 auto}
.clin-pair figure{margin:0;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.25);border-radius:16px;overflow:hidden}
.clin-pair img{width:100%;display:block;height:auto}
.clin-pair figcaption{padding:14px 18px;font-size:12.5px;color:rgba(255,255,255,.78);line-height:1.5;text-align:center}

/* ---------- MECHANISM / EX VIVO ---------- */
.mech{background:var(--cloud)}
.mech-figure{margin:26px 0 0;border:1px solid var(--line);border-radius:20px;overflow:hidden;background:var(--white)}
.mech-figure img{width:100%;display:block;height:auto}
.mech-figure figcaption{padding:18px 26px;font-size:13.5px;color:var(--soft);line-height:1.6}
.mech-pair{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:26px}
.mech-pair figure{margin:0;border:1px solid var(--line);border-radius:20px;overflow:hidden;background:var(--white)}
.mech-pair img{width:100%;display:block;height:auto}
.mech-pair figcaption{padding:16px 22px;font-size:13px;color:var(--soft);line-height:1.55}

/* ---------- STORY (product) ---------- */
.story-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:64px;align-items:center}
.story-visual{aspect-ratio:1;border-radius:24px;overflow:hidden;background:var(--cloud)}
.story-visual img{width:100%;height:100%;object-fit:cover}
.story h2{font-size:clamp(30px,3.4vw,44px);font-weight:300}
.story h2 em{font-style:italic;color:var(--leaf-deep)}
.story p{font-size:16px;color:var(--soft);margin-top:20px}
.story .pill{display:inline-flex;align-items:center;gap:8px;margin-top:24px;font-size:13px;letter-spacing:.03em;color:var(--leaf-deep);font-weight:500;border:1px solid var(--line);border-radius:30px;padding:9px 16px}

/* ---------- TECH TABLE ---------- */
.tech-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 60px;border-top:1px solid var(--line)}
.tech-row{display:flex;justify-content:space-between;gap:20px;padding:20px 0;border-bottom:1px solid var(--line)}
.tech-row .k{font-size:14.5px;color:var(--soft)}
.tech-row .v{font-size:14.5px;color:var(--ink);font-weight:500;text-align:right}

/* ---------- TECHNOLOGY PAGE ---------- */
.thero{padding:46px 0 70px}
.thero .eyebrow{margin-bottom:18px;display:block}
.thero h1{font-size:clamp(48px,6vw,84px);font-weight:300}
.thero h1 em{font-style:italic;color:var(--leaf-deep)}
.thero .lead{font-size:19px;color:var(--soft);max-width:620px;margin-top:24px}
.tvideo{margin:0 16px;border-radius:24px;overflow:hidden;position:relative;background:#0c1108;aspect-ratio:16/7;display:flex;align-items:center;justify-content:center}
.tvideo img,.tvideo video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.55}
.tvideo iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.tvideo.playing{cursor:default}
.tvideo .play{position:relative;z-index:2;text-align:center;color:#fff;max-width:520px;padding:0 30px}
.tvideo .play .circle{width:74px;height:74px;border-radius:50%;border:1.5px solid rgba(255,255,255,.7);display:flex;align-items:center;justify-content:center;margin:0 auto 22px;transition:all .3s ease;cursor:pointer}
.tvideo .play .circle:hover{background:rgba(255,255,255,.15)}
.tvideo .play h3{font-size:24px;font-weight:300;color:#fff}
.tvideo .play p{font-size:15px;color:rgba(255,255,255,.8);margin-top:12px}
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split.alt{direction:rtl}.split.alt>*{direction:ltr}
.split h2{font-size:clamp(30px,3.4vw,46px);font-weight:300}
.split h2 em{font-style:italic;color:var(--leaf-deep)}
.split p{font-size:16px;color:var(--soft);margin-top:18px}
.split .visual{aspect-ratio:4/3;border-radius:24px;overflow:hidden;background:var(--cloud)}
.split .visual img{width:100%;height:100%;object-fit:cover}
.chips{margin-top:26px;display:flex;flex-wrap:wrap;gap:10px}
.chip{font-size:13px;color:var(--leaf-deep);background:rgba(109,113,76,.1);border-radius:30px;padding:9px 16px}
.metrics{margin-top:28px;display:flex;gap:30px;flex-wrap:wrap}
.metric .n{font-family:'Inter',sans-serif;font-size:32px;color:var(--leaf-deep);font-weight:300}
.metric .l{font-size:13px;color:var(--soft);max-width:150px;margin-top:4px}
.pipeline{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:14px}
.stage{border:1px solid var(--line);border-radius:20px;padding:34px 30px;background:var(--white)}
.stage .tagn{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--leaf-deep);font-weight:600}
.stage h3{font-size:24px;margin:12px 0 10px}
.stage p{font-size:14.5px;color:var(--soft)}
.eco-split{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:start}
.eco-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:14px}
.eco{border:1px solid rgba(255,255,255,.18);border-radius:18px;padding:28px 24px;background:rgba(255,255,255,.05)}
.eco h4{font-family:'Inter',sans-serif;font-size:18px;color:var(--lime);font-weight:400;margin-bottom:8px}
.eco p{font-size:13.5px;color:rgba(255,255,255,.82)}

/* ---------- SUSTAINABILITY PAGE ---------- */
.shero{padding:46px 0 70px}
.shero .eyebrow{margin-bottom:18px;display:block}
.shero h1{font-size:clamp(46px,5.8vw,80px);font-weight:300}
.shero h1 em{font-style:italic;color:var(--leaf-deep)}
.shero .lead{font-size:19px;color:var(--soft);max-width:640px;margin-top:24px}
.sbanner{border-radius:24px;overflow:hidden;position:relative;aspect-ratio:16/6;background:var(--cloud)}
.sbanner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pillars3{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.pcard{border:1px solid var(--line);border-radius:20px;padding:36px 30px;transition:transform .35s ease,box-shadow .35s ease}
.pcard:hover{transform:translateY(-6px);box-shadow:0 30px 50px -34px rgba(34,34,32,.3)}
.pcard .ico{width:50px;height:50px;border-radius:12px;background:rgba(109,113,76,.12);color:var(--leaf-deep);display:flex;align-items:center;justify-content:center;margin-bottom:22px}
.pcard .ico svg{width:26px;height:26px}
.pcard h3{font-size:22px;margin-bottom:10px}
.pcard p{font-size:14.5px;color:var(--soft)}

/* ---------- DISTRIBUTOR NETWORK ---------- */
.dist-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.dist-card{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:20px;padding:30px;background:var(--white);transition:transform .35s ease,box-shadow .35s ease}
.dist-card:hover{transform:translateY(-6px);box-shadow:0 30px 50px -34px rgba(34,34,32,.3)}
.dist-logo{height:84px;border-radius:14px;background:rgba(109,113,76,.10);display:flex;align-items:center;justify-content:center;margin-bottom:22px}
.dist-logo span{font-size:19px;font-weight:600;letter-spacing:.01em;color:var(--leaf-deep);text-align:center;padding:0 14px}
.dist-card h3{font-size:20px;margin-bottom:6px}
.dist-terr{font-size:14px;color:var(--soft);margin-bottom:20px}
.dist-link{margin-top:auto;display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:500;letter-spacing:.03em;color:var(--leaf-deep);transition:color .3s ease}
.dist-link svg{width:15px;height:15px}
.dist-link:hover{color:var(--ink)}
.dist-cta{margin-top:50px;text-align:center;background:var(--leaf-deep);border-radius:24px;padding:56px 30px}
.dist-cta h2{color:var(--white);font-size:clamp(26px,3vw,38px);font-weight:300}
.dist-cta h2 em{font-style:italic;color:var(--lime)}
.dist-cta p{color:rgba(255,255,255,.82);max-width:500px;margin:16px auto 30px;font-size:16px}
.dist-cta .btn-primary{background:var(--lime);color:var(--ink)}
.dist-cta .btn-primary:hover{background:var(--white);transform:translateY(-2px)}
.commit-list{margin-top:24px;list-style:none}
.commit-list li{padding:14px 0;border-bottom:1px solid var(--line);font-size:15.5px;color:var(--ink);display:flex;gap:14px;align-items:flex-start}
.commit-list li::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--lime);margin-top:9px;flex-shrink:0}
.certs{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.cert{border:1px solid var(--line);border-radius:18px;padding:30px 24px;text-align:center;background:var(--white)}
.cert h4{font-family:'Inter',sans-serif;font-size:20px;color:var(--leaf-deep);font-weight:400;margin-bottom:8px}
.cert p{font-size:13px;color:var(--soft)}
.metrics-band{background:var(--leaf-deep);color:var(--white)}
.metrics-band .eyebrow{color:var(--lime)}
.mb-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:14px;text-align:center}
.mb-grid .num{font-family:'Inter',sans-serif;font-size:clamp(40px,4.4vw,58px);font-weight:300;color:var(--lime)}
.mb-grid .lbl{font-size:13px;color:rgba(255,255,255,.8);margin-top:8px}
/* ----- sustainability: enriched components ----- */
.mb-grid--5{grid-template-columns:repeat(5,1fr)}
.signature{font-style:italic;color:var(--leaf-deep);border-left:2px solid var(--citrus);padding-left:18px;margin-top:26px;font-size:17px;line-height:1.5}
.pcard .ord{display:block;font-style:italic;font-size:15px;color:var(--citrus);letter-spacing:.02em;margin-bottom:10px}
.stat-row{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;margin-top:34px}
.stat-row .stat{border-top:1px solid var(--line);padding-top:14px}
.stat-row .v{display:block;font-size:32px;font-weight:300;color:var(--leaf-deep);line-height:1}
.stat-row .k{display:block;font-size:12px;color:var(--soft);text-transform:uppercase;letter-spacing:.06em;margin-top:8px}
.compare-table{border-top:1px solid var(--line);margin-top:22px}
.compare-row{display:grid;grid-template-columns:1.5fr 1fr 1fr;border-bottom:1px solid var(--line);align-items:center}
.compare-row.head .col{padding:18px 22px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;color:var(--soft)}
.compare-row.head .col.featured{color:var(--leaf-deep);background:var(--white)}
.compare-row .col{padding:20px 22px;font-size:15px}
.compare-row .col.metric{color:var(--ink);font-weight:500}
.compare-row .col.vs{color:var(--soft)}
.compare-row .col.featured{background:var(--white);color:var(--leaf-deep);font-weight:600}
.squote{text-align:center}
.squote blockquote{margin:0 auto;max-width:840px;font-size:clamp(23px,3vw,36px);font-weight:300;font-style:italic;line-height:1.34;color:var(--leaf-deep);letter-spacing:-.01em}
.squote cite{display:block;margin-top:24px;font-style:normal;text-transform:uppercase;letter-spacing:.14em;font-size:12px;font-weight:600;color:var(--soft)}

/* ---------- NEWS ---------- */
.news-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.news-card{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:20px;overflow:hidden;background:var(--white);transition:transform .35s ease,box-shadow .35s ease}
.news-card:hover{transform:translateY(-6px);box-shadow:0 30px 50px -34px rgba(34,34,32,.3)}
.news-img{aspect-ratio:16/9;overflow:hidden;background:var(--cloud)}
.news-img img{width:100%;height:100%;object-fit:cover}
.news-body{padding:28px 30px;display:flex;flex-direction:column;flex:1}
.news-meta{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.news-cat{font-size:11px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;color:var(--leaf-deep);background:rgba(109,113,76,.12);padding:5px 11px;border-radius:30px}
.news-date{font-size:12.5px;color:var(--soft);letter-spacing:.02em}
.news-card h3{font-size:21px;line-height:1.28;margin-bottom:10px}
.news-card p{font-size:14.5px;color:var(--soft);line-height:1.6}
.news-card .more{margin-top:auto;padding-top:18px;font-size:13px;letter-spacing:.04em;font-weight:500;display:inline-flex;align-items:center;gap:7px;align-self:flex-start;color:var(--leaf-deep)}
.news-card .more svg{width:15px;height:15px;flex:none;transition:transform .3s ease}
.news-card:hover .more svg{transform:translateX(4px)}

/* ---------- COOKIE CONSENT (carte compacte, coin bas-gauche) ---------- */
.cc-banner{position:fixed;left:20px;bottom:20px;z-index:2147483647;max-width:370px;background:var(--leaf-deep);color:#fff;padding:22px 24px;border-radius:16px;box-shadow:0 24px 60px -24px rgba(0,0,0,.6);transform:translateY(180%);transition:transform .45s ease}
.cc-banner.cc-show{transform:none}
.cc-inner{display:block}
.cc-text{font-size:13px;line-height:1.55;color:rgba(255,255,255,.9);margin-bottom:16px}
.cc-text a{color:var(--lime);text-decoration:underline}
.cc-actions{display:flex;gap:10px}
.cc-btn{flex:1;border:none;border-radius:30px;padding:11px 16px;font-size:13px;font-weight:600;letter-spacing:.03em;cursor:pointer;font-family:'Inter',sans-serif;transition:all .25s ease;text-align:center}
.cc-accept{background:var(--lime);color:var(--ink)}
.cc-accept:hover{background:#fff}
.cc-refuse{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.5)}
.cc-refuse:hover{background:rgba(255,255,255,.12)}
.cc-prefs{cursor:pointer}
@media(max-width:600px){
  .cc-banner{left:12px;right:12px;bottom:16px;max-width:none}
}

/* ---------- CONTACT ---------- */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:64px;align-items:start}
.contact-info .row{padding:18px 0;border-bottom:1px solid var(--line)}
.contact-info .row:last-child{border-bottom:none}
.contact-info .k{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--soft);font-weight:600;margin-bottom:6px}
.contact-info .v{font-size:16px;color:var(--ink)}
.form{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form .full{grid-column:1/-1}
.form label{display:block;font-size:12px;letter-spacing:.04em;color:var(--soft);margin-bottom:8px;font-weight:500}
.form input,.form textarea{width:100%;font-family:inherit;font-size:15px;color:var(--ink);background:var(--cloud);border:1px solid var(--line);border-radius:12px;padding:14px 16px;transition:border-color .25s ease}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--leaf)}
.form textarea{min-height:140px;resize:vertical}

/* ---------- LEGAL ---------- */
.legal-hero{padding:54px 0 14px}
.legal-hero .eyebrow{display:block;margin-bottom:14px}
.legal-hero h1{font-size:clamp(38px,4.6vw,62px);font-weight:300}
.legal-hero h1 em{font-style:italic;color:var(--leaf-deep)}
.legal-body{padding:40px 0 96px;max-width:760px}
.legal-body h2{font-family:'Inter',sans-serif;font-size:24px;font-weight:400;margin:38px 0 12px;color:var(--ink)}
.legal-body h2:first-child{margin-top:0}
.legal-body p{font-size:15.5px;color:var(--soft);margin-bottom:14px}
.legal-body ul{margin:0 0 14px 20px}
.legal-body li{font-size:15.5px;color:var(--soft);margin-bottom:8px}
.legal-body a{color:var(--leaf-deep);text-decoration:underline}
.legal-meta{font-size:13px;color:var(--soft);margin-bottom:30px}

/* ---------- FOOTER ---------- */
footer{background:var(--ink);color:rgba(255,255,255,.7);padding:74px 0 36px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.12)}
footer h4{font-family:'Inter',sans-serif;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--white);margin-bottom:18px;font-weight:600}
footer ul{list-style:none}
footer li{margin-bottom:11px;font-size:14px}
footer li a:hover{color:var(--lime)}
.foot-logo{font-family:'Inter',sans-serif;font-size:25px;color:var(--white);margin-bottom:14px;display:flex;align-items:center}
.foot-bottom{display:flex;justify-content:space-between;padding-top:28px;font-size:12.5px;letter-spacing:.03em;flex-wrap:wrap;gap:12px}
.foot-bottom a:hover{color:var(--lime)}

/* ---------- TEXT OVER IMAGES / BANNERS: white & bold (all screens) ---------- */
.hero .eyebrow{color:#fff;font-weight:600}
.hero h1,.hero h1 em{color:#fff;font-weight:600}
.hero-lead{color:#fff;font-weight:600}
.labband h2,.labband h2 em{color:#fff;font-weight:600}
.tvideo .play h3,.tvideo .play p{color:#fff;font-weight:600}

/* ---------- REVEAL ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- RESPONSIVE ---------- */
@media(max-width:980px){
  .wrap{padding:0 24px}
  .logo-full{display:block;height:38px}
  .nav-toggle{display:flex}
  .nav-links{display:none;position:absolute;top:80px;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--white);border-bottom:1px solid var(--line);padding:8px 24px 22px;box-shadow:0 30px 40px -28px rgba(22,36,28,.4)}
  nav.open .nav-links{display:flex}
  .nav-links>a,.nav-top{padding:15px 0;border-bottom:1px solid var(--line)}
  .nav-links>a::after,.nav-top::after{display:none}
  .nav-item{flex-direction:column;align-items:stretch}
  .nav-top{justify-content:space-between}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;border-radius:0;padding:4px 0 4px 16px;min-width:0}
  .dropdown a{padding:12px 0;font-size:14px}
  .hero{margin:10px;border-radius:20px;min-height:82vh}
  .hero-media video,.hero-media img{object-fit:cover;object-position:center}
  .hero-copy{max-width:none}
  .process-grid,.phero-grid,.story-grid,.contact-grid{grid-template-columns:1fr;gap:40px}
  .pillars,.prod-grid,.benefits,.ev-grid,.pillars3,.pipeline{grid-template-columns:1fr}
  .mech-pair,.clin-pair,.news-grid{grid-template-columns:1fr}
  .dist-grid{grid-template-columns:1fr 1fr;gap:18px}
  .split,.split.alt{grid-template-columns:1fr;gap:36px;direction:ltr}
  .proof-grid{grid-template-columns:repeat(2,1fr);gap:36px}
  .proof-band{padding:48px 24px}
  .labband-content{padding:0 28px}
  .specs-bar .wrap{grid-template-columns:1fr 1fr;gap:26px}
  .certs,.mb-grid,.eco-grid{grid-template-columns:1fr 1fr}
  .mb-grid--5{grid-template-columns:repeat(2,1fr)}
  .eco-split{grid-template-columns:1fr;gap:32px}
  .compare-row{grid-template-columns:1fr;padding:16px 0}
  .compare-row.head{display:none}
  .compare-row .col{padding:5px 4px;font-size:15px}
  .compare-row .col.metric{font-size:16px;font-weight:600;color:var(--leaf-deep);padding-top:6px}
  .compare-row .col.vs::before{content:"Conventional";display:block;font-size:11px;font-weight:600;color:var(--soft);text-transform:uppercase;letter-spacing:.1em;margin-bottom:2px}
  .compare-row .col.featured{background:transparent;font-weight:500}
  .compare-row .col.featured::before{content:"Ultrasevum\2122";display:block;font-size:11px;font-weight:600;color:var(--citrus);text-transform:uppercase;letter-spacing:.1em;margin-bottom:2px}
  .tech-grid{grid-template-columns:1fr;gap:0}
  .metrics{display:grid;grid-template-columns:1fr 1fr;gap:26px 18px;flex-wrap:nowrap}
  .metric{min-width:0}
  .metric .n{font-size:21px}
  .metric .l{max-width:none}
  .form{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  section{padding:70px 0}
  .labband{height:280px}
  .sbanner{aspect-ratio:4/3}
}
@media(max-width:560px){
  .dist-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
}
