:root{
  /* — Fuentes (Fraunces editorial + Spline Sans + IBM Plex Mono datos) — */
  --font-display:"Fraunces",Georgia,"Times New Roman",serif;
  --font-body:"Spline Sans",system-ui,-apple-system,"Segoe UI",sans-serif;
  --font-mono:"IBM Plex Mono",ui-monospace,SFMono-Regular,monospace;

  /* — Superficie (OKLCH, idéntico al hex previo) — */
  --bg:oklch(0.9832 0.0017 325.6); --surface:oklch(1 0 0); --surface-2:oklch(0.9613 0.0051 325.6);
  --surface-inset:oklch(0.9450 0.0070 330);
  /* — Texto — */
  --ink:oklch(0.2264 0.0448 341.7); --ink-soft:oklch(0.3600 0.0380 340);
  --muted:oklch(0.4788 0.0258 335.4); --faint:oklch(0.6573 0.0192 340.2);
  /* — Líneas — */
  --line:oklch(0.9239 0.0076 332.1); --line2:oklch(0.8688 0.0119 334.1);
  --line-faint:oklch(0.9239 0.0076 332 / .5);
  /* — Marca plum — */
  --brand:oklch(0.3651 0.0873 338.3); --brand-2:oklch(0.2670 0.0664 339.5); --brand-soft:oklch(0.9500 0.0100 335.5);
  --brand-tint:oklch(0.3651 0.0873 338 / .10); --panel-fg:oklch(0.9447 0.0150 338.9);
  /* — Acento ámbar — */
  --accent:oklch(0.7530 0.1431 78); --accent-strong:oklch(0.7050 0.1500 76); --accent-ink:oklch(0.5165 0.1032 75.1);
  --accent-soft:oklch(0.9604 0.0297 85.6); --accent-tint:oklch(0.7530 0.1431 78 / .16); --on-accent:oklch(0.2889 0.0542 77);

  /* — Escala de tipo fluida — */
  --step--2:clamp(0.72rem,0.70rem + 0.08vw,0.78rem);
  --step--1:clamp(0.82rem,0.79rem + 0.14vw,0.92rem);
  --step-0:clamp(0.97rem,0.94rem + 0.17vw,1.07rem);
  --step-1:clamp(1.12rem,1.04rem + 0.32vw,1.31rem);
  --step-2:clamp(1.34rem,1.18rem + 0.62vw,1.72rem);
  --step-3:clamp(1.60rem,1.36rem + 0.95vw,2.25rem);
  --step-4:clamp(1.95rem,1.55rem + 1.6vw,3.00rem);
  --step-5:clamp(2.35rem,1.80rem + 2.2vw,3.60rem);
  --step-6:clamp(2.55rem,1.70rem + 3.6vw,4.20rem);

  /* — Radios / movimiento / sombras — */
  --r:12px; --r-sm:8px; --r-lg:20px;
  --ease:cubic-bezier(.4,0,.1,1); --ease-out:cubic-bezier(.16,1,.3,1); --ease-spring:cubic-bezier(.34,1.4,.5,1);
  --dur-1:200ms; --dur-2:380ms; --dur-3:640ms;
  --shadow-sm:0 1px 2px oklch(0.2264 0.0448 342 / .06);
  --shadow-md:0 20px 44px -22px oklch(0.2264 0.0448 342 / .26);
  --shadow-card:0 40px 80px -44px oklch(0.2264 0.0448 342 / .40);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--font-body);font-size:var(--step-0);-webkit-font-smoothing:antialiased;line-height:1.55;letter-spacing:-.005em}
h1,h2,h3,h4,h5,h6,.cn,.rn,.xn,.area-n,.coa-l h2{font-family:var(--font-display);font-optical-sizing:auto}
.wrap{max-width:1140px;margin:0 auto;padding:0 32px}
.mono{font-family:var(--font-mono);font-feature-settings:"tnum";letter-spacing:0}
::selection{background:var(--brand-soft)}
a:focus-visible,button:focus-visible,summary:focus-visible,.btn:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:6px}

/* nav */
nav{position:sticky;top:0;z-index:40;background:rgba(250,249,250,.86);backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--line)}
.navin{display:flex;align-items:center;justify-content:space-between;height:66px}
.brand{display:flex;align-items:center;gap:9px;text-decoration:none;font-weight:700;font-size:19px;letter-spacing:-.02em;color:var(--ink)}
.brand .mk{height:30px;width:auto;display:block}
.brand .wm{height:17px;width:auto;display:block}
.foot-logo{margin-bottom:14px}
.foot-logo .mk{height:34px}.foot-logo .wm{height:20px}
.navlinks{display:flex;gap:30px}
.navlinks a{color:var(--muted);text-decoration:none;font-size:14px;transition:color .2s}
.navlinks a:hover{color:var(--ink)}
.navcta{font-size:13.5px;font-weight:600;background:var(--brand);color:#fff;padding:9px 18px;border-radius:999px;text-decoration:none;transition:.2s}
.navcta:hover{background:var(--brand-2)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14.5px;text-decoration:none;border-radius:999px;padding:13px 24px;transition:.25s var(--ease)}
.btn-pri{background:var(--brand);color:#fff}.btn-pri:hover{background:var(--brand-2);transform:translateY(-1px)}
.btn-sec{color:var(--ink);border:1px solid var(--line2);background:#fff}.btn-sec:hover{border-color:var(--ink)}
.btn-amber{background:var(--accent);color:#3a2706}.btn-amber:hover{filter:brightness(1.05)}

/* hero */
header{padding:90px 0 36px}
.hero{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
h1{font-weight:600;font-size:var(--step-6);line-height:1.04;letter-spacing:-.02em;max-width:15ch;text-wrap:balance}
.sub{margin:22px 0 0;max-width:46ch;color:var(--muted);font-size:var(--step-1);line-height:1.6}
.cta-row{display:flex;gap:12px;align-items:center;margin-top:30px;flex-wrap:wrap}
/* brand-drenched hero panel (committed color, on-logo) */
.panel{background:var(--brand-2);color:#F4E9F0;border-radius:var(--r);padding:30px 30px;box-shadow:0 24px 50px -18px rgba(58,23,48,.45)}
.panel h2{font-size:14px;font-weight:600;letter-spacing:.02em;color:#E9D5E2}
.panel .row{display:flex;justify-content:space-between;align-items:baseline;padding:15px 0;border-bottom:1px solid rgba(255,255,255,.1);font-size:14.5px}
.panel .row:last-child{border-bottom:none}
.panel .row span:first-child{color:#C9AEBF}
.panel .row b{font-family:var(--font-mono);font-weight:500;color:#fff}
.panel .amber{color:var(--accent)}

/* trust band */
.band{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--surface)}
.bandin{display:grid;grid-template-columns:repeat(4,1fr)}
.bm{padding:22px 0;border-right:1px solid var(--line)}.bm:last-child{border-right:none}.bm:nth-child(n+2){padding-left:26px}
.bm b{display:block;font-family:var(--font-mono);font-size:18px;font-weight:500}
.bm span{font-size:12.5px;color:var(--faint);margin-top:5px;display:block}

/* sections */
section{padding:80px 0}
.alt{background:var(--surface-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.sec-head{margin-bottom:34px;max-width:60ch}
.sec-head h2{font-weight:600;font-size:var(--step-3);letter-spacing:-.02em}
.sec-head p{color:var(--muted);font-size:15.5px;margin-top:10px;max-width:52ch}

/* areas */
.areas{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.area{background:var(--surface);padding:24px;text-decoration:none;color:var(--ink);transition:background .2s}
.area:hover{background:#fff}
.area-n{font-size:16.5px;font-weight:600;letter-spacing:-.02em}
.area-n::after{content:"";display:block;width:22px;height:2px;background:var(--accent);margin-top:8px}
.area-d{color:var(--muted);font-size:13px;margin-top:12px;line-height:1.55}

/* process */
.proc{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.step{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:24px}
.step .no{font-family:var(--font-mono);font-size:12px;color:var(--accent-ink)}
.step h3{font-size:16px;font-weight:600;letter-spacing:-.02em;margin:14px 0 7px}
.step p{color:var(--muted);font-size:13px;line-height:1.6}

/* faq */
.faq{max-width:840px}
.faq-list{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{cursor:pointer;padding:19px 0;font-size:15.5px;font-weight:600;list-style:none;display:flex;justify-content:space-between;gap:12px;transition:color .2s}
.faq-item summary:hover{color:var(--brand)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";color:var(--faint);font-weight:400}
.faq-item[open] summary::after{content:"−"}
.faq-item p{color:var(--muted);font-size:14.5px;line-height:1.7;padding:0 0 19px;max-width:72ch}

/* cta strip */
.ctaband{background:var(--brand);color:#F4E9F0;border-radius:var(--r);padding:44px 40px;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.ctaband h2{font-weight:700;font-size:clamp(22px,2.6vw,30px);letter-spacing:-.03em;color:#fff;max-width:20ch}
.ctaband p{color:#D7BFCD;font-size:15px;margin-top:8px}

/* footer */
footer{border-top:1px solid var(--line);background:var(--surface)}
.foot{display:grid;grid-template-columns:1.45fr .9fr .9fr .82fr 1.05fr;gap:28px;padding:52px 0 32px}
.foot-brand .brand{margin-bottom:12px}
.foot-brand p{color:var(--faint);font-size:13px;max-width:32ch;line-height:1.6}
.foot-col h4{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:14px}
.foot-col a{display:block;color:var(--muted);font-size:13.5px;text-decoration:none;padding:5px 0;transition:color .2s}
.foot-col a:hover{color:var(--ink)}
.foot-contact{align-self:start;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,#fff,#fbf7fa);padding:18px 18px 16px}
.foot-contact-k{display:block;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-ink);margin-bottom:10px}
.foot-contact a{display:block;color:var(--brand);font-weight:700;font-size:14px;text-decoration:none;overflow-wrap:anywhere}
.foot-contact a:hover{text-decoration:underline;text-underline-offset:.22em}
.foot-contact p{color:var(--faint);font-size:12.5px;line-height:1.55;margin-top:8px}
.foot-bar{border-top:1px solid var(--line);padding:18px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.foot-bar .ruo{font-family:var(--font-mono);font-size:11px;color:var(--faint);max-width:62ch}

.rv{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.rv.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;transition:none}}
@media (max-width:920px){
  .hero{grid-template-columns:1fr}
  .areas,.proc{grid-template-columns:1fr 1fr}
  .bandin{grid-template-columns:1fr 1fr}
  .foot{grid-template-columns:1fr 1fr}
  .navlinks{display:none}
}
@media (max-width:560px){.areas,.proc,.bandin,.foot{grid-template-columns:1fr}}

/* === Blossom carousel (native scroll + drag + scroll-driven bloom) === */
.carousel-sec{padding:80px 0}
.carousel-head{max-width:1140px;margin:0 auto 26px;padding:0 32px;display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap}
.carousel-head h2{font-weight:700;font-size:clamp(26px,3vw,36px);letter-spacing:-.035em}
.carousel-head .hint{font-family:var(--font-mono);font-size:11.5px;color:var(--faint);display:flex;align-items:center;gap:8px}
.carousel{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x proximity;
  padding:34px max(32px,calc((100vw - 1140px)/2 + 32px));scrollbar-width:none;cursor:grab;overscroll-behavior-x:contain}
.carousel::-webkit-scrollbar{display:none}
.carousel.dragging{cursor:grabbing;scroll-snap-type:none}
.cara-card{flex:0 0 300px;scroll-snap-align:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:24px;min-height:230px;display:flex;flex-direction:column}
@supports (animation-timeline: view(inline)){
  .cara-card{animation:bloom linear both;animation-timeline:view(inline);animation-range:entry 0% exit 100%}
}
.cara-card .tag{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent-ink);display:flex;align-items:center;gap:7px}
.cara-card .tag::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--accent)}
.cara-card .cn{font-weight:700;font-size:22px;letter-spacing:-.02em;margin:16px 0 0;color:var(--ink)}
.cara-card .cd{color:var(--muted);font-size:14px;line-height:1.55;margin-top:10px;flex:1}
.cara-card .cf{font-family:var(--font-mono);font-size:11.5px;color:var(--faint);margin-top:18px;padding-top:14px;border-top:1px solid var(--line);display:flex;justify-content:space-between}
.cara-card .cf b{color:var(--brand);font-weight:500}
@keyframes bloom{0%{opacity:.4;transform:scale(.9)}50%{opacity:1;transform:scale(1)}100%{opacity:.4;transform:scale(.9)}}
@media (prefers-reduced-motion:reduce){.cara-card{animation:none;opacity:1;transform:none}}

/* === COA certificate (clinical / pharmaceutical-grade) === */
.coa{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.coa-l h2{font-weight:700;font-size:clamp(26px,3vw,34px);letter-spacing:-.035em;margin-bottom:14px}
.coa-l p{color:var(--muted);font-size:15.5px;max-width:44ch;line-height:1.65}
.checks{margin-top:26px;display:flex;flex-direction:column;gap:14px}
.chk{display:flex;gap:12px;align-items:flex-start;font-size:14.5px}
.chk i{flex:none;width:22px;height:22px;border-radius:50%;background:var(--brand-soft);color:var(--brand);display:grid;place-items:center;font-style:normal;font-size:12px;font-weight:700}
.cert{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:0 1px 2px rgba(42,19,34,.04),0 24px 50px -16px rgba(42,19,34,.14)}
.cert-h{display:flex;justify-content:space-between;align-items:center;background:var(--brand-soft);padding:15px 22px;border-bottom:1px solid #E7D7E2}
.cert-h .t{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--brand)}
.cert-h .v{font-family:var(--font-mono);font-size:10.5px;color:var(--accent-ink);background:var(--accent-soft);border:1px solid #EBD6A6;padding:3px 9px;border-radius:999px}
.cert-b{padding:8px 22px 20px}
.cert-row{display:flex;justify-content:space-between;padding:13px 0;border-bottom:1px solid var(--line);font-family:var(--font-mono);font-size:12.5px}
.cert-row:last-child{border-bottom:none}
.cert-row span:first-child{color:var(--faint)} .cert-row span:last-child{color:var(--ink)}
@media (max-width:920px){.coa{grid-template-columns:1fr}.cara-card{flex-basis:78vw}}

/* === Catalog grid === */
.cat-intro{padding:84px 0 0}
.cat-intro h1{font-weight:700;font-size:clamp(34px,4.4vw,52px);letter-spacing:-.04em;max-width:18ch}
.cat-group{padding:44px 0 0}
.cat-group .gh{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:18px}
.cat-group .gh h2{font-weight:600;font-size:clamp(20px,2.2vw,26px);letter-spacing:-.03em}
.cat-group .gh .gc{font-family:var(--font-mono);font-size:12px;color:var(--faint)}
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.cat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:22px 20px;text-decoration:none;color:var(--ink);transition:border-color .2s,box-shadow .2s,transform .2s;position:relative}
.cat-card::before{content:"";position:absolute;left:20px;right:20px;top:0;height:2px;background:var(--brand);opacity:0;transition:opacity .2s}
.cat-card:hover{border-color:var(--line2);box-shadow:0 14px 30px -14px rgba(42,19,34,.16);transform:translateY(-3px)}
.cat-card:hover::before{opacity:1}
.cat-card .ct{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent-ink)}
.cat-card .cn{font-size:19px;font-weight:700;letter-spacing:-.025em;margin:9px 0 1px}
.cat-card .cm{color:var(--faint);font-size:12px}
.cat-card .crow{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:12px;margin:14px 0;padding:6px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cat-card .crow span:first-child{color:var(--faint)}
.cat-card .cf{display:flex;justify-content:space-between;align-items:center;margin-top:14px}
.cat-card .price{font-size:17px;font-weight:700}.cat-card .price small{font-family:var(--font-mono);font-size:10.5px;color:var(--faint);font-weight:400}
.cat-card .go{font-family:var(--font-mono);font-size:11px;color:var(--brand)}

/* === Product page (PDP) - clinical === */
.pdp{padding-top:30px}
.crumb{display:flex;gap:8px;align-items:center;font-size:12.5px;color:var(--faint);margin-bottom:24px;flex-wrap:wrap}
.crumb a{color:var(--muted);text-decoration:none}.crumb a:hover{color:var(--ink)}.crumb .cur{color:var(--ink)}
.pdp-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:44px;align-items:start;padding-bottom:50px;border-bottom:1px solid var(--line)}
.pdp-info .ct{font-family:var(--font-mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--accent-ink)}
.pdp-info h1{font-weight:700;font-size:clamp(34px,4.4vw,52px);letter-spacing:-.04em;margin:12px 0 0;line-height:1.02}
.pdp-info h1 .mg{color:var(--faint);font-weight:400}
.resumen{color:var(--muted);font-size:17px;line-height:1.6;margin:18px 0 0;max-width:52ch}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:24px}
.chip{font-size:11.5px;color:var(--muted);background:var(--surface);border:1px solid var(--line2);border-radius:6px;padding:6px 11px}
.buy{position:sticky;top:84px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:0 1px 2px rgba(42,19,34,.04),0 20px 44px -16px rgba(42,19,34,.14)}
.buy-top{height:3px;background:var(--brand)}
.buy-b{padding:22px}
.buy-price{font-size:30px;font-weight:700;letter-spacing:-.02em;color:var(--ink)}
.buy-price small{font-family:var(--font-mono);font-size:12px;color:var(--faint);font-weight:400}
.vbtns{display:flex;gap:8px;margin:16px 0 4px}
.vbtn{font-family:var(--font-mono);font-size:12.5px;padding:8px 14px;border:1px solid var(--line2);border-radius:999px;background:#fff;color:var(--ink);cursor:pointer;transition:.15s}
.vbtn.active{background:var(--brand);color:#fff;border-color:var(--brand)}
.srow{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line);font-family:var(--font-mono);font-size:12.5px}
.srow:last-of-type{border-bottom:none}
.srow span:first-child{color:var(--faint)}
.dl{margin-top:16px}
.buy-cta{display:flex;align-items:center;justify-content:center;width:100%;margin-top:10px}
.prose{max-width:70ch;padding:52px 0 8px}
.prose h2{font-weight:700;font-size:23px;letter-spacing:-.03em;margin:36px 0 10px}
.prose h2:first-child{margin-top:0}
.prose p{color:var(--muted);font-size:16px;line-height:1.78}
.refs{padding:46px 0 6px;max-width:74ch}
.refs>h2{font-weight:700;font-size:22px;letter-spacing:-.03em;margin-bottom:10px}
.refs-note{color:var(--faint);font-size:13px;line-height:1.6;margin-bottom:20px;max-width:64ch}
.refs-list{list-style:none;counter-reset:ref;display:flex;flex-direction:column;gap:13px;border-top:1px solid var(--line);padding-top:20px}
.refs-list li{counter-increment:ref;position:relative;padding-left:34px;color:var(--muted);font-size:14px;line-height:1.62}
.refs-list li::before{content:"[" counter(ref) "]";position:absolute;left:0;top:1px;font-family:var(--font-mono);font-size:12px;color:var(--accent-ink)}
.refs-list a{font-family:var(--font-mono);font-size:11.5px;color:var(--brand);text-decoration:none;margin-left:4px}
.refs-list a:hover{text-decoration:underline}
.rel{padding:50px 0}
.rel>h2{font-weight:700;font-size:22px;letter-spacing:-.03em;margin-bottom:18px}
.rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.rel-card{display:flex;flex-direction:column;gap:7px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:20px;text-decoration:none;transition:border-color .2s,box-shadow .2s,transform .2s}
.rel-card:hover{border-color:var(--line2);box-shadow:0 12px 26px -14px rgba(42,19,34,.16);transform:translateY(-2px)}
.rel-card .ct{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;color:var(--accent-ink)}
.rel-card .rn{font-size:18px;font-weight:700;color:var(--ink);letter-spacing:-.02em}
.rel-card .rg{font-family:var(--font-mono);font-size:11px;color:var(--brand);margin-top:4px}
@media (max-width:920px){.cat-grid,.rel-grid{grid-template-columns:1fr}.pdp-grid{grid-template-columns:1fr;gap:28px}.buy{position:static}}
@media (max-width:560px){.cat-grid{grid-template-columns:1fr}}

/* ── Páginas de documento (empresa / legal / trust) ── */
.pg .wrap{padding-top:30px}
.pg-head{padding:8px 0 36px;border-bottom:1px solid var(--line)}
.pg-kicker{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--brand)}
.pg-head h1{font-weight:700;font-size:clamp(32px,4.6vw,52px);letter-spacing:-.04em;line-height:1.04;margin:14px 0 0;max-width:20ch}
.pg-lede{margin:20px 0 0;font-size:18px;line-height:1.62;color:var(--muted);max-width:64ch}
.pg-meta{margin-top:18px;font-family:var(--font-mono);font-size:11.5px;color:var(--faint)}
.pg-prose{max-width:72ch;padding:40px 0 8px}
.pg-prose h2{font-weight:700;font-size:clamp(20px,2.6vw,26px);letter-spacing:-.03em;margin:36px 0 0}
.pg-prose h2:first-child{margin-top:0}
.pg-prose h3{font-weight:700;font-size:16px;letter-spacing:-.02em;margin:24px 0 0}
.pg-prose p{color:var(--muted);font-size:16px;line-height:1.75;margin:12px 0 0}
.pg-prose ul{margin:14px 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:10px}
.pg-prose li{position:relative;padding-left:20px;color:var(--muted);font-size:15.5px;line-height:1.6}
.pg-prose li::before{content:"";position:absolute;left:2px;top:10px;width:6px;height:6px;border-radius:50%;background:var(--accent)}
.pg-prose a{color:var(--brand);text-decoration:none;font-weight:600}
.pg-prose a:hover{text-decoration:underline}
.pg-prose strong{color:var(--ink);font-weight:600}
.pg-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:32px}
.pg-card{border:1px solid var(--line);border-radius:16px;padding:24px;background:var(--surface)}
.pg-card .n{font-family:var(--font-mono);font-size:11px;color:var(--accent-ink)}
.pg-card h3{font-size:16px;font-weight:700;letter-spacing:-.02em;margin:8px 0 0}
.pg-card p{font-size:13.5px;line-height:1.6;color:var(--muted);margin:8px 0 0}
.pg-cta{margin-top:36px;background:var(--brand-2);color:#F3E9F0;border-radius:18px;padding:30px 32px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.pg-cta h3{margin:0;font-size:20px;font-weight:700;letter-spacing:-.02em}
.pg-cta p{margin:6px 0 0;font-size:14px;color:#D9C4D3}
.pg-cta a{background:var(--accent);color:#3a2706;font-weight:600;font-size:14.5px;padding:13px 22px;border-radius:999px;text-decoration:none;white-space:nowrap}
.pg-note{margin-top:28px;border:1px solid var(--line2);background:var(--surface-2);border-radius:14px;padding:18px 22px;font-size:13px;color:var(--muted);line-height:1.6}
.pg-faq{display:flex;flex-direction:column;border-top:1px solid var(--line);margin-top:20px}
.pg-faq details{border-bottom:1px solid var(--line)}
.pg-faq summary{cursor:pointer;list-style:none;padding:18px 0;font-weight:600;font-size:16px;display:flex;justify-content:space-between;gap:16px}
.pg-faq summary::-webkit-details-marker{display:none}
.pg-faq summary::after{content:"+";color:var(--accent-ink);font-family:var(--font-mono)}
.pg-faq details[open] summary::after{content:"–"}
.pg-faq p{color:var(--muted);font-size:14.5px;line-height:1.7;padding:0 0 18px;max-width:74ch}
@media (max-width:760px){.pg-cards{grid-template-columns:1fr}}

/* Cross-link ficha -> dossiers de investigación (themed por acento del péptido vía --xa*) */
.xdos{padding:56px 0;border-bottom:1px solid var(--line)}
.xdos .xk{font-family:var(--font-mono);font-size:12px;color:var(--xa-ink,var(--accent-ink))}
.xdos h2{font-weight:700;font-size:clamp(22px,3vw,30px);letter-spacing:-.035em;margin:8px 0 0;max-width:24ch}
.xdos .xp{margin:16px 0 0;font-size:15.5px;line-height:1.7;color:var(--muted);max-width:66ch}
.xdos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:24px}
.xdos-card{display:flex;flex-direction:column;gap:7px;border:1px solid var(--line);border-radius:14px;padding:20px;background:var(--surface);text-decoration:none;transition:border-color .2s,transform .2s,box-shadow .2s}
.xdos-card:hover{border-color:var(--xa,var(--brand));transform:translateY(-2px);box-shadow:0 14px 30px -16px rgba(42,19,34,.18)}
.xdos-card .xc{font-family:var(--font-mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.03em;color:var(--xa-ink,var(--accent-ink))}
.xdos-card .xn{font-size:17px;font-weight:700;color:var(--ink);letter-spacing:-.02em}
.xdos-card .xg{font-family:var(--font-mono);font-size:11px;color:var(--xa-ink,var(--accent-ink));margin-top:2px}
@media (max-width:760px){.xdos-grid{grid-template-columns:1fr}}

/* Imagen de producto (vial). mix-blend-mode:multiply funde el fondo blanco del PNG con el contenedor. */
.prodimg{display:block;width:100%;max-width:230px;margin:2px auto 10px;aspect-ratio:1/1;object-fit:contain;mix-blend-mode:multiply}
.cx-img{display:block;width:100%;height:150px;object-fit:contain;mix-blend-mode:multiply;margin:-4px 0 14px}

/* Microcopy de confianza bajo el buy-box de las fichas */
.buytrust{display:flex;flex-wrap:wrap;gap:6px 14px;margin:16px 0 2px}
.buytrust span{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:11px;color:var(--muted)}
.buytrust span::before{content:"✓";color:var(--brand);font-weight:700;font-size:11px}

/* === Calculadora de reconstitución — instrumento clínico (CSS, sin SVG); themed por --ca === */
.rcalc{border:1px solid var(--ca,var(--brand));border-radius:20px;overflow:hidden;margin:40px 0;background:var(--surface);box-shadow:0 30px 70px -42px rgba(42,19,34,.42);scroll-margin-top:84px}
.rcalc-head{padding:24px 28px;border-bottom:1px solid var(--line);background:var(--ca-soft)}
.rcalc-tag{display:inline-block;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:var(--ca);padding:5px 12px;border-radius:999px}
.rcalc-head h2{font-size:22px;font-weight:700;letter-spacing:-.03em;margin:13px 0 0;color:var(--ink)}
.rcalc-head p{font-size:13.5px;color:var(--muted);margin:8px 0 0;line-height:1.6;max-width:66ch}
.rcalc-grid{display:grid;grid-template-columns:1fr 1fr}
.rcalc-controls{padding:26px 28px;display:flex;flex-direction:column;gap:24px;border-right:1px solid var(--line)}
.rcalc-flabel{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--font-mono);font-size:11.5px;color:var(--muted);margin-bottom:12px;gap:12px}
.rcalc-flabel b{font-family:var(--font-mono);font-weight:500;color:var(--ca-ink);font-size:15px}
.rcalc-vars{display:flex;gap:8px;flex-wrap:wrap}
.rcalc-var{font-family:var(--font-mono);font-size:13.5px;padding:9px 15px;border:1px solid var(--line2);border-radius:10px;background:var(--surface);color:var(--ink);cursor:pointer;transition:border-color .15s,background .15s,color .15s}
.rcalc-var:hover{border-color:var(--ca)}
.rcalc-var:focus-visible{outline:2px solid var(--ca);outline-offset:2px}
.rcalc-var.on{background:var(--ca);color:#fff;border-color:var(--ca)}
.rcalc-range{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:999px;background:var(--ca-soft);outline:none;cursor:pointer}
.rcalc-range:focus-visible{outline:2px solid var(--ca);outline-offset:4px}
.rcalc-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;background:var(--ca);border:4px solid var(--surface);box-shadow:0 2px 8px -2px rgba(42,19,34,.4);cursor:pointer;transition:transform .15s}
.rcalc-range::-webkit-slider-thumb:hover{transform:scale(1.12)}
.rcalc-range::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--ca);border:4px solid var(--surface);box-shadow:0 2px 8px -2px rgba(42,19,34,.4);cursor:pointer}
.rcalc-outs{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.rcalc-out{border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.rcalc-out.hi{background:var(--ca-soft);border-color:var(--ca)}
.rcalc-out .lab{display:block;font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--ca-ink);margin-bottom:7px}
.rcalc-out .val{font-family:var(--font-mono);font-size:27px;font-weight:500;color:var(--ink);letter-spacing:-.02em;line-height:1}
.rcalc-out .val small{font-size:13px;color:var(--muted);font-weight:400;letter-spacing:0}
.rcalc-out .sub{display:block;font-family:var(--font-mono);font-size:11.5px;color:var(--muted);margin-top:7px;line-height:1.4}
/* CSS syringe */
.rcalc-visual{padding:30px 28px;display:flex;flex-direction:column;justify-content:center;gap:8px;background:var(--surface-2)}
.rsyr{display:flex;align-items:center;height:64px}
.rsyr-thumb{width:8px;height:58px;border-radius:3px;background:var(--ink);flex:none}
.rsyr-cap{width:13px;height:30px;border-radius:2px;background:var(--ink);flex:none;opacity:.55}
.rsyr-barrel{position:relative;flex:1;height:52px;background:var(--surface);border:2px solid var(--ink);border-right:none;overflow:hidden;box-shadow:inset 0 1px 4px rgba(42,19,34,.1)}
.rsyr-liquid{position:absolute;inset:2px;border-radius:2px;background:var(--ca);opacity:.55;transform-origin:right center;transform:scaleX(0);transition:transform .55s cubic-bezier(.22,1,.36,1)}
.rsyr-ticks{position:absolute;inset:0;pointer-events:none;background-image:repeating-linear-gradient(90deg,color-mix(in srgb,var(--ink) 38%,transparent) 0 1px,transparent 1px 10%),repeating-linear-gradient(90deg,color-mix(in srgb,var(--ink) 16%,transparent) 0 1px,transparent 1px 5%)}
.rsyr-marker{position:absolute;top:-5px;bottom:-5px;right:2px;width:2px;background:var(--ca-ink);transform:translateX(0);transition:transform .55s cubic-bezier(.22,1,.36,1)}
.rsyr-chip{position:absolute;bottom:calc(100% + 4px);left:50%;transform:translateX(-50%);white-space:nowrap;font-family:var(--font-mono);font-size:10.5px;font-weight:600;color:#fff;background:var(--ca-ink);padding:3px 8px;border-radius:5px}
.rsyr-tip{width:0;height:0;border-top:8px solid transparent;border-bottom:8px solid transparent;border-left:14px solid var(--ink);flex:none}
.rsyr-needle{width:48px;height:2.5px;background:var(--ink);flex:none}
.rsyr-scale{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:9.5px;color:var(--faint);padding:0 62px 0 21px}
.rcalc-vcap{font-family:var(--font-mono);font-size:11.5px;color:var(--muted);text-align:center;margin:6px 0 0;line-height:1.5}
.rcalc-vcap b{color:var(--ca-ink)}
.rcalc-vcap .over{color:#B23A48;display:none}
.rcalc-vcap.is-over .over{display:inline}
.rcalc-tbl{width:100%;border-collapse:collapse;border-top:1px solid var(--line)}
.rcalc-tbl th{text-align:left;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:500;padding:12px 28px;border-bottom:1px solid var(--line)}
.rcalc-tbl td{font-family:var(--font-mono);font-size:13px;color:var(--ink);padding:11px 28px;border-bottom:1px solid var(--line)}
.rcalc-tbl tr:last-child td{border-bottom:none}
.rcalc-note{font-size:12px;color:var(--faint);line-height:1.55;margin:0;padding:18px 28px;border-top:1px solid var(--line)}
.rcalc-note a{color:var(--ca-ink);font-weight:600;text-decoration:none}
@media (max-width:760px){.rcalc-grid{grid-template-columns:1fr}.rcalc-controls{border-right:none;border-bottom:1px solid var(--line)}}
@media (prefers-reduced-motion:reduce){.rsyr-liquid,.rsyr-marker,.rcalc-range::-webkit-slider-thumb{transition:none}}
.rcalc-jump{display:block;text-align:center;margin-top:11px;font-family:var(--font-mono);font-size:12px;color:var(--brand);text-decoration:none}
.rcalc-jump:hover{text-decoration:underline}

/* === Blog (editorial) === */
.post{padding-top:30px;--pa:var(--brand);--pa-soft:var(--brand-soft);--pa-ink:var(--brand)}
.post-inner{max-width:760px;margin:0 auto;padding:0 32px}
.post-head{padding:8px 0 26px;border-bottom:1px solid var(--line)}
.post-eyebrow{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--pa-ink)}
.post-head h1{font-weight:700;font-size:clamp(30px,4.4vw,46px);letter-spacing:-.035em;line-height:1.08;margin:14px 0 0;text-wrap:balance}
.post-meta{font-family:var(--font-mono);font-size:12px;color:var(--faint);margin:16px 0 0}
.post-lede{font-size:20px;line-height:1.55;color:var(--ink);margin:18px 0 0;max-width:64ch}
.post-prose{font-size:17.5px;line-height:1.8;color:var(--muted);padding:6px 0 0}
.post-prose>h2{font-size:clamp(21px,2.6vw,27px);font-weight:700;letter-spacing:-.03em;color:var(--ink);margin:44px 0 0;line-height:1.22;max-width:30ch}
.post-prose>h3{font-size:18px;font-weight:700;color:var(--ink);margin:30px 0 0}
.post-prose p{margin:17px 0 0;text-wrap:pretty}
.post-prose a{color:var(--brand);font-weight:600;text-decoration:none;border-bottom:1px solid color-mix(in srgb,var(--brand) 30%,transparent)}
.post-prose a:hover{border-bottom-color:var(--brand)}
.post-prose ul,.post-prose ol{margin:16px 0 0;padding-left:4px;list-style:none}
.post-prose li{margin:11px 0 0;padding-left:24px;position:relative}
.post-prose ul li::before{content:"";position:absolute;left:4px;top:13px;width:6px;height:6px;border-radius:50%;background:var(--pa)}
.post-prose ol{counter-reset:pli}
.post-prose ol li{counter-increment:pli}
.post-prose ol li::before{content:counter(pli);position:absolute;left:0;top:1px;font-family:var(--font-mono);font-size:12px;color:var(--pa-ink);font-weight:600}
.post-prose strong{color:var(--ink);font-weight:600}
.post-prose blockquote{margin:30px 0 0;padding:22px 26px;background:var(--pa-soft);border-radius:14px;font-size:19px;line-height:1.6;color:var(--ink)}
.post-prose blockquote p{margin:0}
.post-refs{margin-top:44px;padding-top:24px;border-top:1px solid var(--line);counter-reset:pref;list-style:none}
.post-refs .h{font-family:var(--font-mono);font-size:12px;color:var(--pa-ink);text-transform:uppercase;letter-spacing:.04em;margin-bottom:14px}
.post-refs li{counter-increment:pref;position:relative;padding-left:34px;color:var(--muted);font-size:14px;line-height:1.62;margin-top:13px}
.post-refs li::before{content:"[" counter(pref) "]";position:absolute;left:0;top:1px;font-family:var(--font-mono);font-size:12px;color:var(--pa-ink)}
.post-refs a{font-family:var(--font-mono);font-size:11.5px;color:var(--brand);text-decoration:none;margin-left:4px}
.post-rel{margin-top:36px;padding-top:24px;border-top:1px solid var(--line)}
.post-rel .h{font-family:var(--font-mono);font-size:12px;color:var(--pa-ink);text-transform:uppercase;letter-spacing:.04em;margin-bottom:14px}
.post-rel .lk{display:flex;flex-wrap:wrap;gap:8px}
.post-rel .lk a{font-family:var(--font-mono);font-size:12.5px;color:var(--pa-ink);border:1px solid var(--line2);border-radius:999px;padding:8px 14px;text-decoration:none}
.post-rel .lk a:hover{border-color:var(--pa);background:var(--pa-soft)}
.post-cta{margin:40px 0 8px;background:var(--brand);color:#fff;border-radius:20px;padding:30px 32px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.post-cta h2{font-size:clamp(19px,2.3vw,24px);font-weight:700;letter-spacing:-.03em;margin:0;max-width:24ch}
.post-cta p{margin:7px 0 0;font-size:14px;color:#E7D6E1;max-width:46ch}
.post-cta a{background:var(--accent);color:#3A1730;font-weight:700;font-size:14.5px;border-radius:999px;padding:13px 24px;text-decoration:none;white-space:nowrap}
.post-note{font-size:12.5px;color:var(--faint);margin-top:24px;line-height:1.55}
.post-faq{margin-top:36px;padding-top:8px;border-top:1px solid var(--line)}
.post-faq .h{font-family:var(--font-mono);font-size:12px;color:var(--pa-ink);text-transform:uppercase;letter-spacing:.04em;margin:16px 0 6px}
.post-faq details{border-bottom:1px solid var(--line)}
.post-faq summary{cursor:pointer;list-style:none;padding:18px 0;font-weight:600;font-size:16px;color:var(--ink);display:flex;justify-content:space-between;gap:16px;align-items:baseline}
.post-faq summary::-webkit-details-marker{display:none}
.post-faq summary::after{content:"+";font-family:var(--font-mono);color:var(--pa-ink);font-size:20px;line-height:1}
.post-faq details[open] summary::after{content:"–"}
.post-faq p{margin:0 0 18px;font-size:15px;line-height:1.7;color:var(--muted)}
/* Blog index */
.blogi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;padding:40px 0 8px}
.blogi-card{display:flex;flex-direction:column;gap:10px;border:1px solid var(--line);border-radius:18px;padding:28px;background:var(--surface);text-decoration:none;transition:border-color .2s,box-shadow .2s,transform .2s}
.blogi-card:hover{border-color:var(--brand);transform:translateY(-2px);box-shadow:0 16px 34px -18px rgba(42,19,34,.22)}
.blogi-card .d{font-family:var(--font-mono);font-size:11px;color:var(--faint)}
.blogi-card h2{font-size:21px;font-weight:700;letter-spacing:-.025em;color:var(--ink);margin:0;line-height:1.15}
.blogi-card p{font-size:14px;line-height:1.6;color:var(--muted);margin:0}
.blogi-card .go{font-family:var(--font-mono);font-size:12px;color:var(--brand);margin-top:auto}
@media (max-width:760px){.blogi-grid{grid-template-columns:1fr}}
/* Blog: post destacado */
.blogi-feat{display:block;border:1px solid var(--line);border-radius:20px;padding:34px 38px;background:var(--surface);text-decoration:none;margin:40px 0 0;transition:border-color .2s,box-shadow .2s,transform .2s}
.blogi-feat:hover{border-color:var(--brand);transform:translateY(-2px);box-shadow:0 22px 46px -24px rgba(42,19,34,.26)}
.blogi-feat .tag{font-family:var(--font-mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--accent-ink)}
.blogi-feat h2{font-size:clamp(24px,3.2vw,34px);font-weight:700;letter-spacing:-.03em;color:var(--ink);margin:12px 0 0;max-width:24ch;line-height:1.12}
.blogi-feat p{font-size:16px;line-height:1.6;color:var(--muted);margin:14px 0 0;max-width:66ch}
.blogi-feat .go{font-family:var(--font-mono);font-size:12.5px;color:var(--brand);margin-top:16px;display:inline-block}
.blogi-grid.rest{padding-top:16px}
/* Blog: caja "datos clave" en artículos (themed por --pa) */
.post-prose .post-kf{margin:32px 0 0;border:1px solid var(--pa);background:var(--pa-soft);border-radius:16px;padding:22px 26px}
.post-prose .post-kf .kfh{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--pa-ink);margin:0 0 12px}
.post-prose .post-kf ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:11px}
.post-prose .post-kf ul li{font-size:15px;line-height:1.5;color:var(--ink);margin:0;padding-left:26px;position:relative}
.post-prose .post-kf ul li::before{content:"\2192";position:absolute;left:0;top:0;width:auto;height:auto;border-radius:0;background:none;color:var(--pa-ink);font-weight:700;font-family:var(--font-mono)}
