/* ===========================================================
   PeptiPet MX — Premium design system  (v2 · editorial)
   Warm boutique pet-wellness: teal + cream + warm amber
   Display: Fraunces (opsz) · Body/UI: Manrope
   =========================================================== */
:root{
  /* Brand palette (logo: teal cyan + warm orange) — refined */
  --teal-900:#083a44; --teal-800:#0a4a56; --teal-700:#0d8496; --teal-600:#0e97a8;
  --teal-500:#12b0c2; --teal-300:#7fd6e2; --teal-050:#e6f5f4;
  --cream:#fcf9f2; --cream-2:#f4ecdd; --cream-3:#efe6d4;
  --ink:#182525; --ink-soft:#516260; --ink-mute:#7c8b89;
  --amber:#ef8a2a; --amber-600:#e0791a; --amber-soft:#f9b877;
  --line:#e9e0cf; --line-2:#efe8da; --white:#ffffff;
  /* Layered soft shadows */
  --sh-sm:0 2px 8px -4px rgba(8,58,68,.18), 0 6px 20px -14px rgba(8,58,68,.20);
  --sh:0 8px 24px -14px rgba(8,58,68,.28), 0 22px 48px -28px rgba(8,58,68,.30);
  --sh-lg:0 18px 40px -18px rgba(8,58,68,.30), 0 40px 80px -34px rgba(8,58,68,.38);
  --shadow:var(--sh); --shadow-lg:var(--sh-lg);
  --radius:22px; --radius-lg:28px; --radius-sm:14px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --wrap:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Manrope','Segoe UI',system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink); background:var(--cream); line-height:1.65;
  font-size:17px; letter-spacing:-.006em;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{
  font-family:'Fraunces','Georgia',serif;
  line-height:1.08; letter-spacing:-.018em; font-weight:600;
  font-optical-sizing:auto;
}
h1{font-weight:600}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
b,strong{font-weight:700}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
::selection{background:var(--teal-050);color:var(--teal-900)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;font-family:'Manrope',sans-serif;
  font-weight:800;font-size:1.02rem;letter-spacing:-.01em;line-height:1;
  background:linear-gradient(180deg,#2ee06f,#22c85f);color:#053a1a;
  padding:16px 30px;border-radius:999px;
  box-shadow:0 1px 0 rgba(255,255,255,.5) inset, 0 10px 26px -10px rgba(34,200,95,.65);
  transition:transform .2s var(--ease), box-shadow .2s var(--ease), filter .2s;
  border:none;cursor:pointer;
}
.btn:hover{transform:translateY(-3px);box-shadow:0 1px 0 rgba(255,255,255,.5) inset,0 18px 38px -12px rgba(34,200,95,.7);filter:brightness(1.03)}
.btn:active{transform:translateY(-1px)}
.btn.alt{background:linear-gradient(180deg,var(--teal-600),var(--teal-700));color:#fff;box-shadow:0 1px 0 rgba(255,255,255,.18) inset,0 10px 26px -10px rgba(13,132,150,.6)}
.btn.alt:hover{box-shadow:0 1px 0 rgba(255,255,255,.18) inset,0 18px 38px -12px rgba(13,132,150,.66)}
.btn.ghost{background:#fff;color:var(--teal-700);border:1.5px solid var(--line);box-shadow:var(--sh-sm)}
.btn.ghost:hover{border-color:var(--teal-500);color:var(--teal-800);box-shadow:var(--sh)}
.btn.sm{font-size:.94rem;padding:13px 24px}

/* ---------- Eyebrow / kicker ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.5em;font-family:'Manrope',sans-serif;
  font-weight:800;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--teal-700);background:var(--teal-050);
  padding:8px 15px;border-radius:999px;border:1px solid #d3ebe8;
}

/* ---------- NAV ---------- */
header.nav{position:sticky;top:0;z-index:50;background:rgba(252,249,242,.78);backdrop-filter:saturate(1.4) blur(16px);-webkit-backdrop-filter:saturate(1.4) blur(16px);border-bottom:1px solid rgba(233,224,207,.7)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:74px}
.logo{font-family:'Fraunces',serif;font-weight:700;font-size:1.35rem;color:var(--teal-900);letter-spacing:-.02em;display:inline-flex;align-items:center;gap:10px}
.logo span{color:var(--amber)}
.brandmark{height:52px;width:auto;display:block;border-radius:14px;
  background:radial-gradient(circle at 50% 42%,#1c2228,#0a0c0f);
  box-shadow:0 6px 18px -8px rgba(8,58,68,.55), inset 0 0 0 1px rgba(255,255,255,.07)}
.nav .brandmark{height:50px}
footer .brandmark{height:64px;border-radius:16px;margin-bottom:14px}
@media(max-width:520px){.nav .brandmark{height:44px}}
.nav-links{display:flex;gap:30px;align-items:center;font-weight:600;font-size:.96rem;color:var(--ink-soft)}
.nav-links a{position:relative;transition:color .18s}
.nav-links a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--amber);border-radius:2px;transition:width .25s var(--ease)}
.nav-links a:not(.nav-cta):hover{color:var(--teal-800)}
.nav-links a:not(.nav-cta):hover::after{width:100%}
.nav-cta{background:linear-gradient(180deg,var(--teal-600),var(--teal-700));color:#fff !important;padding:11px 20px;border-radius:999px;font-weight:800;font-size:.9rem;box-shadow:0 8px 20px -10px rgba(13,132,150,.7);transition:transform .18s,box-shadow .18s}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 14px 28px -10px rgba(13,132,150,.72)}
@media(max-width:860px){.nav-links a:not(.nav-cta){display:none}}

/* ---------- HERO ---------- */
.hero{position:relative;overflow:hidden;
  background:
    radial-gradient(900px 520px at 88% -8%, #d3efe9 0%, transparent 58%),
    radial-gradient(700px 460px at -6% 12%, #fbe6cf 0%, transparent 55%),
    linear-gradient(180deg,#fdfaf3 0%, #f4ecdd 100%);
  padding:78px 0 96px}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:linear-gradient(90deg,transparent,var(--line),transparent)}
.hero-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(2.5rem,5.4vw,4.15rem);font-weight:600;color:var(--teal-900);margin:22px 0 20px;letter-spacing:-.025em;line-height:1.02}
.hero p.sub{font-size:1.2rem;color:var(--ink-soft);max-width:40ch;margin-bottom:32px;line-height:1.6}
.hero-cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-note{font-size:.9rem;color:var(--ink-soft);margin-top:24px;display:flex;gap:10px;align-items:center;flex-wrap:wrap;font-weight:600}
.hero-photo{position:relative}
.hero-photo img{width:100%;height:520px;object-fit:cover;border-radius:var(--radius-lg);box-shadow:var(--sh-lg);border:6px solid #fff}
.hero-photo::before{content:"";position:absolute;inset:-6px;border-radius:34px;background:linear-gradient(150deg,rgba(18,176,194,.22),transparent 45%,rgba(239,138,42,.18));z-index:-1;filter:blur(2px)}
.hero-badge{position:absolute;bottom:-20px;left:-20px;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:20px;box-shadow:var(--sh);padding:15px 20px;display:flex;gap:12px;align-items:center;font-weight:800;color:var(--teal-900)}
.hero-badge .ic{font-size:28px}
.hero-badge small{display:block;font-weight:600;color:var(--ink-soft);font-size:.78rem}
.paw-float{position:absolute;font-size:32px;opacity:.45;pointer-events:none;animation:pawdrift 6s ease-in-out infinite}
.paw-float.p1{top:-16px;right:26px} .paw-float.p2{top:40%;right:-16px;font-size:26px;animation-delay:1.5s}
@keyframes pawdrift{0%,100%{transform:translateY(0) rotate(-6deg)}50%{transform:translateY(-10px) rotate(6deg)}}
@media(max-width:860px){.hero{padding:56px 0 68px}.hero-grid{grid-template-columns:1fr;text-align:center;gap:40px}.hero p.sub{margin-left:auto;margin-right:auto}.hero-cta-row,.hero-note{justify-content:center}.hero-photo{order:-1}.hero-photo img{height:360px}.hero-badge{left:14px}}

/* ---------- TRUST STRIP ---------- */
.trust-strip{background:linear-gradient(90deg,var(--teal-900),var(--teal-800));color:#d4efeb;position:relative}
.trust-strip::before,.trust-strip::after{content:"";position:absolute;top:0;bottom:0;width:60px;z-index:2;pointer-events:none}
.trust-strip .wrap{display:flex;flex-wrap:wrap;gap:14px 40px;justify-content:center;padding:18px 24px;font-weight:600;font-size:.94rem;letter-spacing:.01em}
.trust-strip b{color:#fff;font-weight:800}

/* ---------- SECTIONS ---------- */
section{padding:100px 0}
.sec-head{text-align:center;max-width:680px;margin:0 auto 60px}
.sec-head h2{font-size:clamp(2rem,3.8vw,2.9rem);font-weight:600;color:var(--teal-900);margin:16px 0 16px;letter-spacing:-.02em}
.sec-head p{color:var(--ink-soft);font-size:1.12rem;line-height:1.6}
.alt-bg{background:linear-gradient(180deg,#f5eede 0%, #fcf9f2 100%)}

/* ---------- GOAL CARDS ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.goal{background:#fff;border:1px solid var(--line-2);border-radius:var(--radius);overflow:hidden;box-shadow:var(--sh-sm);transition:transform .3s var(--ease), box-shadow .3s var(--ease);display:flex;flex-direction:column}
.goal:hover{transform:translateY(-7px);box-shadow:var(--sh-lg)}
.goal .ph{height:196px;overflow:hidden;position:relative}
.goal .ph img{width:100%;height:100%;object-fit:cover;transition:transform .55s var(--ease)}
.goal:hover .ph img{transform:scale(1.07)}
.goal .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(8,58,68,.28));opacity:0;transition:opacity .3s}
.goal:hover .ph::after{opacity:1}
.goal .ph .ic{position:absolute;bottom:12px;left:14px;background:rgba(255,255,255,.94);backdrop-filter:blur(4px);width:48px;height:48px;border-radius:15px;display:flex;align-items:center;justify-content:center;font-size:25px;box-shadow:var(--sh-sm);z-index:2}
.goal .goal-media{display:block}
.goal .bd{padding:24px 24px 26px;display:flex;flex-direction:column;flex-grow:1}
.goal h3{font-size:1.26rem;margin:0 0 10px;color:var(--teal-900);letter-spacing:-.015em}
.goal h3 a{color:inherit}
.goal:hover h3 a{color:var(--teal-700)}
.goal p{font-size:.97rem;color:var(--ink-soft);flex-grow:1}
.goal .comp-tags{margin-top:18px;display:flex;flex-wrap:wrap;gap:8px}
.goal .comp-tags a{background:var(--teal-050);color:var(--teal-700);font-weight:800;font-size:.75rem;letter-spacing:.02em;padding:6px 12px;border-radius:999px;border:1px solid #d3ebe8;transition:.2s}
.goal .comp-tags a:hover{background:var(--teal-700);color:#fff;border-color:var(--teal-700)}
@media(max-width:900px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.cards{grid-template-columns:1fr}}

/* ---------- COMPOUND CARDS ---------- */
.comp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.comp{background:#fff;border:1px solid var(--line-2);border-radius:var(--radius);padding:28px;box-shadow:var(--sh-sm);display:flex;flex-direction:column;transition:transform .3s var(--ease), box-shadow .3s var(--ease);position:relative;overflow:hidden}
.comp::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--teal-500),var(--amber));transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease)}
.comp:hover{transform:translateY(-6px);box-shadow:var(--sh-lg)}
.comp:hover::before{transform:scaleX(1)}
.comp .tag{align-self:flex-start;background:var(--teal-050);color:var(--teal-700);font-weight:800;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;padding:6px 12px;border-radius:999px;border:1px solid #d3ebe8}
.comp h3{font-size:1.5rem;margin:16px 0 4px;color:var(--teal-900);letter-spacing:-.02em}
.comp .pres{font-size:.82rem;font-weight:800;letter-spacing:.02em;color:var(--amber-600);margin-bottom:12px}
.comp p{font-size:.96rem;color:var(--ink-soft);flex-grow:1}
.comp .more{margin-top:20px;font-weight:800;color:var(--teal-700);font-size:.93rem;display:inline-flex;align-items:center;gap:.35em;transition:gap .2s,color .2s}
.comp:hover .more{color:var(--amber-600);gap:.7em}
@media(max-width:900px){.comp-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.comp-grid{grid-template-columns:1fr}}

/* ---------- TRUST CARDS ---------- */
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.tcard{text-align:center;padding:34px 22px;background:#fff;border:1px solid var(--line-2);border-radius:var(--radius);box-shadow:var(--sh-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.tcard:hover{transform:translateY(-5px);box-shadow:var(--sh)}
.tcard .ic{font-size:42px;display:inline-block;line-height:1}
.tcard h3{font-size:1.1rem;margin:14px 0 8px;color:var(--teal-900)}
.tcard p{font-size:.92rem;color:var(--ink-soft)}
@media(max-width:900px){.trust-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.trust-grid{grid-template-columns:1fr}}

/* ---------- SPLIT ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split.rev .txt{order:2}
.split .ph{position:relative}
.split .ph img{width:100%;height:440px;object-fit:cover;border-radius:var(--radius-lg);box-shadow:var(--sh-lg);border:6px solid #fff}
.split .ph::before{content:"";position:absolute;inset:-6px;border-radius:34px;background:linear-gradient(150deg,rgba(18,176,194,.2),transparent 50%,rgba(239,138,42,.16));z-index:-1}
.split h2{font-size:clamp(1.9rem,3.6vw,2.7rem);color:var(--teal-900);margin:16px 0 18px;letter-spacing:-.02em}
.split p{color:var(--ink-soft);font-size:1.08rem;margin-bottom:14px;line-height:1.65}
.split ul{list-style:none;display:flex;flex-direction:column;gap:14px;margin-top:22px}
.split li{display:flex;gap:12px;font-weight:500;color:var(--ink);padding-left:2px;line-height:1.5}
.split li b{color:var(--teal-800);font-weight:800}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:36px}.split.rev .txt{order:0}.split .ph img{height:320px}}

/* ---------- FAQ ---------- */
.faq{max-width:840px;margin:0 auto}
details{background:#fff;border:1px solid var(--line-2);border-radius:16px;margin-bottom:14px;box-shadow:var(--sh-sm);overflow:hidden;transition:box-shadow .25s,border-color .25s}
details[open]{box-shadow:var(--sh);border-color:#d9ede9}
details summary{list-style:none;cursor:pointer;padding:22px 26px;font-family:'Fraunces',serif;font-weight:600;color:var(--teal-900);font-size:1.14rem;letter-spacing:-.01em;display:flex;justify-content:space-between;align-items:center;gap:14px}
details summary::-webkit-details-marker{display:none}
details summary::after{content:"+";font-size:1.6rem;color:var(--amber);font-weight:400;transition:transform .25s var(--ease);line-height:1;font-family:'Manrope',sans-serif}
details[open] summary::after{transform:rotate(45deg)}
details .a{padding:0 26px 24px;color:var(--ink-soft);font-size:1rem;line-height:1.68}

/* ---------- CTA FINAL ---------- */
.cta-final{background:radial-gradient(900px 460px at 50% -20%, var(--teal-500) 0%, transparent 62%), linear-gradient(155deg,var(--teal-900) 0%, var(--teal-700) 100%);color:#fff;text-align:center}
.cta-final h2{color:#fff;font-size:clamp(2.1rem,4.2vw,3rem);font-weight:600;margin-bottom:18px;letter-spacing:-.02em}
.cta-final p{color:#cdeee8;font-size:1.16rem;max-width:48ch;margin:0 auto 34px;line-height:1.6}
.cta-final .pawline{font-size:36px;margin-bottom:10px}
.cta-final.photo{position:relative;overflow:hidden;background:var(--teal-900)}
.cta-final.photo .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;border:0;border-radius:0}
.cta-final.photo::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(155deg,rgba(8,58,68,.9) 0%,rgba(13,132,150,.78) 100%)}
.cta-final.photo .wrap{position:relative;z-index:2}

/* ---------- FOOTER ---------- */
footer{background:linear-gradient(180deg,#072d35,#05242b);color:#a7cfc9;padding:64px 0 34px;font-size:.92rem}
footer .cols{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;margin-bottom:40px}
footer .logo{color:#fff;margin-bottom:12px}
footer p{line-height:1.7;color:#94beb8}
footer a{color:#a7cfc9;transition:color .18s}footer a:hover{color:#fff}
footer h4{color:#fff;font-family:'Manrope',sans-serif;font-size:.78rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;margin-bottom:16px}
footer ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.disclaimer{border-top:1px solid rgba(255,255,255,.1);padding-top:26px;font-size:.8rem;color:#7fb3ac;line-height:1.75}
.disclaimer b{color:#cfe9e4}
@media(max-width:760px){footer .cols{grid-template-columns:1fr 1fr}}
@media(max-width:480px){footer .cols{grid-template-columns:1fr}}

/* ---------- FAB ---------- */
.fab{position:fixed;bottom:24px;right:24px;z-index:60;background:linear-gradient(180deg,#2ee06f,#22c85f);color:#fff;width:62px;height:62px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:31px;box-shadow:0 12px 30px -8px rgba(34,200,95,.7);transition:transform .2s var(--ease)}
.fab::before{content:"";position:absolute;inset:0;border-radius:50%;box-shadow:0 0 0 0 rgba(34,200,95,.5);animation:fabpulse 2.6s ease-out infinite}
@keyframes fabpulse{0%{box-shadow:0 0 0 0 rgba(34,200,95,.45)}70%,100%{box-shadow:0 0 0 18px rgba(34,200,95,0)}}
.fab:hover{transform:scale(1.09)}

/* ===================== FICHA ===================== */
.crumb{font-size:.85rem;color:var(--ink-soft);padding:22px 0 0;font-weight:600}
.crumb a{color:var(--teal-700);font-weight:700}
.ficha-hero{background:
    radial-gradient(800px 420px at 85% -12%,#d3efe9,transparent 58%),
    radial-gradient(620px 400px at -4% 10%,#fbe6cf,transparent 55%),
    linear-gradient(180deg,#fdfaf3 0%, #f4ecdd 100%);padding:28px 0 74px}
.ficha-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:56px;align-items:center;margin-top:24px}
.ficha-photo{position:relative}
.ficha-photo img{width:100%;height:460px;object-fit:cover;border-radius:var(--radius-lg);box-shadow:var(--sh-lg);border:6px solid #fff}
.ficha-photo .vialtag{position:absolute;top:16px;right:16px;background:rgba(255,255,255,.92);backdrop-filter:blur(6px);border:1px solid var(--line);border-radius:14px;padding:11px 15px;font-weight:800;color:var(--teal-900);box-shadow:var(--sh-sm);font-size:.88rem}
.ficha-hero h1{font-size:clamp(2.3rem,4.8vw,3.4rem);color:var(--teal-900);margin:14px 0 12px;letter-spacing:-.025em;line-height:1.03}
.ficha-hero .lead{font-size:1.16rem;color:var(--ink-soft);margin-bottom:22px;line-height:1.6}
.chips{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:26px}
.chip{background:#fff;color:var(--teal-700);border:1px solid #d3ebe8;border-radius:999px;padding:8px 15px;font-size:.82rem;font-weight:800;box-shadow:var(--sh-sm)}
@media(max-width:820px){.ficha-grid{grid-template-columns:1fr;gap:34px}.ficha-photo{order:-1}.ficha-photo img{height:340px}}

/* prose */
.prose{max-width:840px;margin:0 auto}
.prose h2{font-size:clamp(1.7rem,3.4vw,2.3rem);color:var(--teal-900);margin:0 0 16px;letter-spacing:-.02em}
.prose h3{font-size:1.3rem;color:var(--teal-900);margin:30px 0 12px}
.prose p{color:var(--ink-soft);font-size:1.08rem;margin-bottom:18px;line-height:1.72}
.prose ul,.prose ol{color:var(--ink-soft);font-size:1.08rem;margin:0 0 18px 22px;display:flex;flex-direction:column;gap:10px;line-height:1.6}
.blk{padding:76px 0}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:10px 0}
@media(max-width:640px){.grid2{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--line-2);border-left:4px solid var(--amber);padding:26px;border-radius:16px;box-shadow:var(--sh-sm);transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.card:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.card h3{margin:0 0 10px;font-size:1.14rem;color:var(--teal-900)}
.card p{margin:0;font-size:.96rem;color:var(--ink-soft);line-height:1.6}

/* COA box */
.coa-box{background:linear-gradient(135deg,var(--teal-050),#fff 70%);border:1.5px solid var(--teal-500);border-radius:20px;padding:34px;margin:10px 0;box-shadow:var(--sh);position:relative;overflow:hidden}
.coa-box::before{content:"🔬";position:absolute;top:-18px;right:-6px;font-size:110px;opacity:.06;transform:rotate(-12deg)}
.coa-box h3{color:var(--teal-900);font-size:1.4rem;margin-bottom:12px;display:flex;gap:10px;align-items:center;position:relative}
.coa-box p{color:var(--ink-soft);margin:0;position:relative;line-height:1.68}
.coa-box a{color:var(--teal-700);font-weight:800}

/* related */
.related{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px}
.rel{background:#fff;border:1px solid var(--line-2);border-radius:16px;padding:18px 20px;transition:border-color .25s,transform .25s var(--ease),box-shadow .25s;box-shadow:var(--sh-sm)}
.rel:hover{border-color:var(--teal-500);transform:translateY(-4px);box-shadow:var(--sh)}
.rel .n{font-weight:800;color:var(--teal-900);font-size:1.04rem}
.rel .c{font-size:.8rem;color:var(--amber-600);font-weight:700;margin-top:4px}

/* disclaimer inline */
.disc-inline{background:#fff;border:1px solid var(--line-2);border-radius:14px;padding:24px 26px;font-size:.86rem;color:var(--ink-soft);line-height:1.75;box-shadow:var(--sh-sm)}
.disc-inline b{color:var(--teal-900)}

/* article hero */
.art-hero{position:relative;height:400px;overflow:hidden}
.art-hero img{width:100%;height:100%;object-fit:cover}
.art-hero .ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,58,68,.12) 0%,rgba(6,42,49,.85) 100%);display:flex;align-items:flex-end}
.art-hero .ov .wrap{padding-bottom:38px;color:#fff}
.art-hero h1{color:#fff;font-size:clamp(2.1rem,4.6vw,3.1rem);max-width:22ch;letter-spacing:-.02em;line-height:1.05}
.art-hero .eyebrow{background:rgba(255,255,255,.16);color:#fff;border-color:rgba(255,255,255,.22);margin-bottom:16px}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.step{background:#fff;border:1px solid var(--line-2);border-radius:var(--radius);padding:30px;box-shadow:var(--sh-sm);transition:transform .28s var(--ease),box-shadow .28s var(--ease)}
.step:hover{transform:translateY(-5px);box-shadow:var(--sh)}
.step .n{width:42px;height:42px;border-radius:50%;background:linear-gradient(150deg,var(--teal-500),var(--teal-700));color:#fff;font-family:'Fraunces',serif;font-weight:600;font-size:1.1rem;display:flex;align-items:center;justify-content:center;margin-bottom:16px;box-shadow:0 8px 18px -8px rgba(13,132,150,.6)}
.step h3{color:var(--teal-900);font-size:1.14rem;margin-bottom:8px}
.step p{color:var(--ink-soft);font-size:.96rem;line-height:1.6}
@media(max-width:760px){.steps{grid-template-columns:1fr}}

/* --- Vial product imagery --- */
.ficha-photo.vial img{object-fit:contain;background:radial-gradient(130% 120% at 50% 0%,#eef8f6,#f9fdfc);padding:26px}
.comp .vimg{display:block;width:100%;height:230px;object-fit:contain;background:radial-gradient(130% 120% at 50% 0%,#eef8f6,#f9fdfc);border-radius:16px;border:1px solid var(--line-2);margin-bottom:16px;transition:transform .5s var(--ease)}
.comp:hover .vimg{transform:scale(1.04)}
.goal .ph.vial img{object-fit:contain;background:radial-gradient(130% 120% at 50% 0%,#eef8f6,#f9fdfc);padding:16px}

/* ===================== SCROLL REVEAL ===================== */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease), transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1 !important;transform:none !important;transition:none}
  .paw-float,.fab::before{animation:none}
  html{scroll-behavior:auto}
}
