/* ============================================================================
   site.css — AromatizaPro · componentes y estética "Rosa & Grafito"
   Consume tokens.css + base.css. Aquí vive la firma visual: pétalos, ondas de
   aroma, secciones grafito, showcase del difusor, planes, sectores, catálogo.
   ========================================================================== */

/* ---- Tipografía display serif (override del base) ------------------------ */
h1,h2,h3,h4{font-family:var(--font-display);letter-spacing:-.01em}
h1,h2{font-weight:600}
.script{font-family:var(--font-script);font-weight:600;color:var(--magenta);
  font-style:normal;letter-spacing:0;line-height:1}
body{font-weight:400}
p{max-width:60ch}

/* baseline seguro para iconos SVG en línea: span.ic nunca desborda -------- */
.ic{display:inline-flex;align-items:center;justify-content:center;width:1.15em;height:1.15em;flex:none;vertical-align:-.15em}
.ic svg{width:100%;height:100%;display:block}

/* nav fija: los anchors no quedan tapados por la barra ---------------------- */
section[id]{scroll-margin-top:90px}

.lead{color:var(--muted);font-weight:400}
strong,b{font-weight:600;color:var(--ink)}

/* eyebrow luxury con líneas y loto */
.eyebrow{display:inline-flex;align-items:center;gap:.7rem;color:var(--magenta);
  font-family:var(--font-body);font-weight:600;font-size:var(--fs-300);
  text-transform:uppercase;letter-spacing:var(--tracking-label)}
.eyebrow::before{content:"";width:26px;height:1px;background:currentColor;opacity:.6}
.eyebrow.solo::before{display:none}

/* ---- Fondo global sutil de textura rosa ---------------------------------- */
body{background:
  radial-gradient(120% 80% at 90% -10%, rgba(244,156,196,.16), transparent 55%),
  radial-gradient(90% 60% at -10% 8%, rgba(225,19,131,.06), transparent 50%),
  var(--bg);
}
/* background-attachment:fixed solo en escritorio: en móvil provoca jank/glitches al hacer scroll */
@media (min-width:1041px) and (hover:hover){ body{background-attachment:fixed} }

/* ---- Header de sección ---------------------------------------------------- */
.shead{max-width:none;margin-bottom:var(--space-5)}
.shead h2{margin:.55rem 0 .8rem;max-width:20ch}
.shead .lead{max-width:56ch}
.shead.center{margin-inline:auto;text-align:center}
.shead.center .eyebrow::after{content:"";width:26px;height:1px;background:currentColor;opacity:.6}
.shead.center h2{margin-inline:auto}
.shead.center .lead{margin-inline:auto}

/* ---- Divisor de loto ------------------------------------------------------ */
.lotus-div{display:flex;align-items:center;justify-content:center;gap:1rem;color:var(--rose);margin:0 auto}
.lotus-div::before,.lotus-div::after{content:"";height:1px;width:min(22vw,120px);
  background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--magenta) 45%,transparent))}
.lotus-div::after{background:linear-gradient(270deg,transparent,color-mix(in srgb,var(--magenta) 45%,transparent))}
.lotus-div svg{width:30px;height:30px;color:var(--magenta)}

/* ============================================================================
   NAV
   ========================================================================== */
.nav{padding-block:1.1rem}
.nav.scrolled{background:color-mix(in srgb,var(--bg) 88%,transparent);
  backdrop-filter:blur(16px) saturate(150%);border-bottom-color:var(--line);box-shadow:0 10px 40px -30px rgba(120,10,70,.5)}
.brand{display:flex;align-items:center;gap:.65rem}
.brand__mark{width:36px;height:36px;color:var(--magenta);flex:none;display:grid;place-items:center}
.brand__mark svg{width:100%;height:100%}
.brand__txt{font-family:var(--font-display);font-weight:600;font-size:1.4rem;
  letter-spacing:.02em;line-height:1;color:var(--ink);text-transform:uppercase}
.brand__txt b{color:var(--magenta);font-weight:600}
.brand__txt small{display:block;font-family:var(--font-body);font-size:.52rem;
  letter-spacing:.34em;color:var(--muted);text-transform:uppercase;margin-top:2px}
.nav__links a{font-family:var(--font-body);letter-spacing:.02em}
.nav__links a:hover,.nav__links a.active{color:var(--magenta)}
.nav .btn{padding:.6rem 1.15rem}

/* nav "scrolled" sobre secciones oscuras (hero/difusor/prueba): frosted oscuro */
.nav.scrolled.over-dark{background:color-mix(in srgb,#150710 74%,transparent);border-bottom-color:rgba(255,255,255,.12)}
.nav.scrolled.over-dark .brand__txt{color:#FBEDF4}
.nav.scrolled.over-dark .brand__txt b{color:var(--rose)}
.nav.scrolled.over-dark .brand__txt small{color:rgba(251,237,244,.68)}
.nav.scrolled.over-dark .nav__links a{color:rgba(251,237,244,.82)}
.nav.scrolled.over-dark .nav__links a:hover,.nav.scrolled.over-dark .nav__links a.active{color:#fff}
.nav.scrolled.over-dark .nav__toggle{color:#FBEDF4}

/* nav en hero (dark) antes de scroll */
.nav:not(.scrolled) .brand__txt{color:#fff}
.nav:not(.scrolled) .brand__txt small{color:rgba(255,255,255,.7)}
.nav:not(.scrolled) .nav__links a{color:rgba(255,255,255,.82)}
.nav:not(.scrolled) .nav__links a:hover{color:#fff}
.nav:not(.scrolled) .nav__toggle{color:#fff}
@media (max-width:820px){
  .nav:not(.scrolled) .nav__links a{color:var(--ink)}
}

/* ---- Botones ------------------------------------------------------------- */
.btn{font-family:var(--font-body);letter-spacing:.01em;font-weight:600}
.btn--primary{background:var(--grad-magenta);color:#fff;box-shadow:var(--shadow-sm)}
.btn--primary:hover{box-shadow:var(--glow)}
/* el CTA del nav es un <a>: las reglas de color de .nav__links a (según estado
   del nav) ganaban por especificidad y ponían el texto oscuro sobre el magenta.
   El botón siempre en blanco. */
.nav__links a.btn--primary,
.nav__links a.btn--primary:hover,
.nav__links a.btn--primary.active{color:#fff}
.btn--ghost{border-color:color-mix(in srgb,var(--magenta) 35%,transparent);color:var(--magenta)}
.btn--ghost:hover{border-color:var(--magenta);background:color-mix(in srgb,var(--magenta) 8%,transparent)}
.btn--lg{padding:1.05rem 2rem;font-size:var(--fs-500)}
.btn .ic{width:1.05em;height:1.05em;display:inline-flex}
.btn .ic svg{width:100%;height:100%}
.on-dark .btn--ghost{border-color:rgba(255,255,255,.28);color:#fff}
.on-dark .btn--ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}

/* ============================================================================
   SECCIONES OSCURAS (grafito) — flip de paleta
   ========================================================================== */
.band-dark{
  --bg:var(--dk-bg); --surface:var(--dk-surface); --text:var(--dk-text);
  --muted:var(--dk-muted); --line:var(--dk-line); --ink:var(--dk-text);
  background:
    radial-gradient(80% 60% at 85% 0%, rgba(225,19,131,.20), transparent 60%),
    radial-gradient(70% 50% at 0% 100%, rgba(180,0,95,.16), transparent 55%),
    var(--dk-bg);
  color:var(--dk-text);position:relative;overflow:hidden;
}
.band-dark h1,.band-dark h2,.band-dark h3{color:var(--dk-text)}
.band-blush{background:linear-gradient(180deg,var(--blush),color-mix(in srgb,var(--blush) 40%,var(--bg)))}

/* ============================================================================
   HERO
   ========================================================================== */
.hero{min-height:100svh;color:#fff;isolation:isolate}
.hero .container{position:relative;z-index:3;width:min(100% - var(--gutter)*2, var(--container));margin-inline:auto}
.hero__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:var(--space-5);align-items:center;padding-top:5rem}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero__media::after{content:"";position:absolute;inset:0;background:
  linear-gradient(105deg, rgba(21,7,16,.94) 8%, rgba(21,7,16,.72) 46%, rgba(60,10,40,.42) 100%),
  radial-gradient(60% 60% at 78% 30%, rgba(225,19,131,.30), transparent 60%)}
.hero__petals{position:absolute;inset:0;z-index:1;pointer-events:none}
.hero__waves{position:absolute;right:-4%;bottom:-6%;width:min(52vw,620px);z-index:2;pointer-events:none;opacity:.9}
.hero__eyebrow{color:var(--rose)}
.hero h1{font-size:var(--fs-900);line-height:.98;margin:.4rem 0 1.4rem;font-weight:600;letter-spacing:-.02em}
.hero h1 .script{color:var(--rose);display:inline-block}
.hero__lead{font-size:var(--fs-600);color:rgba(255,255,255,.86);max-width:44ch;line-height:1.5}
.hero__cta{display:flex;gap:1rem;flex-wrap:wrap;margin-top:2rem}
.hero__meta{display:flex;gap:2rem;flex-wrap:wrap;margin-top:1.8rem;padding-top:1.4rem;
  border-top:1px solid rgba(255,255,255,.16)}
.hero__meta .n{font-family:var(--font-body);font-size:2.1rem;line-height:1;color:#fff;font-weight:600;letter-spacing:-.01em;font-variant-numeric:lining-nums tabular-nums}
.hero__meta .l{font-size:var(--fs-300);text-transform:uppercase;letter-spacing:.16em;color:rgba(255,255,255,.62);margin-top:.35rem}
/* tarjeta flotante del difusor */
.hero__device{position:relative;justify-self:center;display:grid;place-items:center;width:min(100%,360px);aspect-ratio:1}
.hero__device .halo{position:absolute;inset:2%;border-radius:50%;
  background:radial-gradient(circle at 50% 45%,rgba(225,19,131,.6),rgba(180,0,95,.25) 45%,transparent 68%);filter:blur(10px);z-index:0}
.hero__device .ring{position:absolute;border:1px solid rgba(249,206,224,.32);border-radius:50%;width:86%;aspect-ratio:1;z-index:1;animation:pulse 4.5s ease-out infinite}
.hero__device .ring.r2{width:62%;animation-delay:1.5s}
.hero__device .device{z-index:2}
.hero__device .plinth{position:absolute;bottom:8%;width:min(66%,220px);height:26px;border-radius:50%;
  background:radial-gradient(ellipse,rgba(249,206,224,.55),transparent 70%);filter:blur(3px);z-index:1}
/* Difusor: cara blanca + costado negro (como el aparato real), con loto, LED y rejilla */
.device{width:min(74%,240px);margin-inline:auto;aspect-ratio:3/4.5;border-radius:20px;
  background:
    linear-gradient(180deg, rgba(0,0,0,.06), transparent 10%, transparent 90%, rgba(0,0,0,.07)),
    linear-gradient(90deg,#f7eef3 0 72%, #1b1017 72% 100%);
  box-shadow:0 40px 90px -30px rgba(0,0,0,.7), inset 0 1px 0 rgba(255,255,255,.9);
  position:relative;border:1px solid rgba(255,255,255,.5)}
/* brillo diagonal sutil sobre la cara */
.device::before{content:"";position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(125deg, rgba(255,255,255,.65), transparent 38%);mix-blend-mode:screen;opacity:.5}
.device__logo{position:absolute;top:15%;left:36%;transform:translateX(-50%);width:30px;height:30px;color:var(--magenta);z-index:2}
.device__logo svg{width:100%;height:100%}
.device__led{position:absolute;top:9%;right:15%;width:7px;height:7px;border-radius:50%;
  background:var(--magenta);box-shadow:0 0 9px 1px rgba(225,19,131,.85);z-index:2}
.device__grille{position:absolute;left:14%;bottom:11%;width:44%;height:14%;z-index:2;border-radius:3px;
  background:repeating-linear-gradient(180deg, rgba(24,16,24,.18) 0 2px, transparent 2px 6px)}
/* vapor / aroma que sube (hacer visible el aroma) — partículas en canvas,
   emiten desde el borde superior del difusor y suben disipándose. Vapor blanco. */
.device__vapor{position:absolute;left:-14%;top:-74%;width:128%;height:82%;z-index:3;pointer-events:none}
@media (max-width:1040px){
  .hero__grid{grid-template-columns:1fr;padding-top:5rem;gap:var(--space-4)}
  .hero__device{display:none}
  .hero__waves{width:80vw;opacity:.5}
}

/* scroll cue */
.scrollcue{position:absolute;left:50%;bottom:1.6rem;transform:translateX(-50%);z-index:4;
  color:rgba(255,255,255,.6);display:flex;flex-direction:column;align-items:center;gap:.4rem;
  font-size:var(--fs-300);letter-spacing:.2em;text-transform:uppercase}
.scrollcue .ic{width:20px;height:20px;animation:bob 2.2s var(--ease) infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
/* el hero de móvil/tablet es más alto que el viewport → oculta el cue ahí */
@media (max-width:1040px),(max-height:820px){.scrollcue{display:none}}

/* ============================================================================
   PÉTALOS globales (canvas por sección oscura ya cubierto; helper flotante CSS)
   ========================================================================== */
.petal-field{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
/* el <canvas> es elemento reemplazado: inset:0 no lo estira → forzamos tamaño */
canvas.hero__petals{width:100%;height:100%}

/* ============================================================================
   CLAIM / intro
   ========================================================================== */
/* claim editorial a dos columnas (título izq. / texto der.) — distinto del
   servicio centrado que va debajo, para dar ritmo sin repetir lemas */
.claim-split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,5rem);align-items:start}
.claim-split__head{position:relative;padding-left:1.5rem}
.claim-split__head::before{content:"";position:absolute;left:0;top:.4rem;bottom:.4rem;width:3px;
  border-radius:3px;background:var(--grad-magenta)}
.claim-split__head h2{font-size:var(--fs-800);line-height:1.04;margin-top:.9rem;max-width:14ch}
.claim-split__head h2 .script{display:inline-block}
.claim-split__body{padding-top:.4rem}
.claim-split__body .lead{color:var(--text);font-size:var(--fs-600);line-height:1.55;max-width:46ch;margin-bottom:1.1rem}
.claim-split__body p{color:var(--muted);max-width:46ch}
@media (max-width:820px){
  .claim-split{grid-template-columns:1fr;gap:var(--space-3)}
  .claim-split__head{padding-left:1.1rem}
  .claim-split__head h2{max-width:none}
}

/* ============================================================================
   SERVICIO INTEGRAL — 7 pasos
   ========================================================================== */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.svc{background:var(--surface);padding:2rem 1.5rem;text-align:center;display:flex;flex-direction:column;
  align-items:center;gap:.5rem;transition:background var(--dur-fast),transform var(--dur-fast)}
.svc:hover{background:var(--blush)}
.svc__ic{width:52px;height:52px;display:grid;place-items:center;border-radius:50%;
  color:var(--magenta);background:color-mix(in srgb,var(--magenta) 9%,transparent);margin-bottom:.4rem}
.svc__ic svg{width:26px;height:26px}
.svc b{font-family:var(--font-body);font-size:var(--fs-400);text-transform:uppercase;letter-spacing:.08em;color:var(--ink)}
.svc span{font-size:var(--fs-400);color:var(--muted)}
/* 8ª celda: cierre de marca (rellena la rejilla 4×2) */
.svc--brand{background:var(--grad-magenta)}
.svc--brand:hover{background:var(--grad-magenta)}
.svc--brand b,.svc--brand span{color:#fff}
.svc--brand span{opacity:.9}
.svc--brand .svc__ic{background:rgba(255,255,255,.18);color:#fff}
@media (max-width:820px){.svc-grid{grid-template-columns:repeat(2,1fr)}.svc-grid .svc:nth-child(n){grid-row:auto}}
@media (max-width:560px){
  .svc{padding:1.5rem .7rem;gap:.3rem}
  .svc__ic{width:44px;height:44px;margin-bottom:.2rem}
  .svc__ic svg{width:22px;height:22px}
  .svc b{font-size:var(--fs-300)}
  .svc span{font-size:var(--fs-300)}
}

/* ============================================================================
   POR QUÉ / beneficios + stats
   ========================================================================== */
.why{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6);align-items:center}
.benefit{display:flex;gap:1rem;padding:1.1rem 0;border-bottom:1px solid var(--line)}
.benefit:last-child{border-bottom:0}
.benefit__ic{flex:none;width:46px;height:46px;border-radius:14px;display:grid;place-items:center;
  color:var(--magenta);background:color-mix(in srgb,var(--magenta) 10%,transparent)}
.benefit__ic svg{width:24px;height:24px}
.benefit h3{font-size:1.3rem;margin-bottom:.15rem}
.benefit p{font-size:var(--fs-400);color:var(--muted);margin:0}
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);text-align:center}
.stat .n{font-family:var(--font-body);font-size:clamp(2.4rem,4.6vw,3.4rem);line-height:1;color:var(--magenta);font-weight:600;letter-spacing:-.02em;font-variant-numeric:lining-nums tabular-nums}
.stat .n .u{font-size:.5em;vertical-align:super;color:var(--rose)}
.stat .l{font-size:var(--fs-400);color:var(--muted);margin-top:.4rem;text-transform:uppercase;letter-spacing:.1em}
@media (max-width:820px){.why{grid-template-columns:1fr}.stat-row{grid-template-columns:1fr 1fr;gap:var(--space-5)}}

/* ============================================================================
   SECTORES — tabs interactivos
   ========================================================================== */
.sectors{display:grid;grid-template-columns:.85fr 1.15fr;gap:var(--space-5);align-items:stretch}
.sector-tabs{display:flex;flex-direction:column;gap:.5rem}
.sector-tab{display:flex;align-items:center;gap:1rem;width:100%;text-align:left;cursor:pointer;
  padding:1.1rem 1.25rem;border-radius:var(--radius);border:1px solid var(--line);background:var(--surface);
  transition:all var(--dur-fast) var(--ease);color:var(--ink);font-family:var(--font-body)}
.sector-tab:hover{border-color:color-mix(in srgb,var(--magenta) 40%,transparent)}
.sector-tab.active{background:var(--grad-magenta);color:#fff;border-color:transparent;box-shadow:var(--shadow-sm);transform:translateX(6px)}
.sector-tab__ic{width:40px;height:40px;flex:none;display:grid;place-items:center;border-radius:11px;
  background:color-mix(in srgb,var(--magenta) 10%,transparent);color:var(--magenta)}
.sector-tab.active .sector-tab__ic{background:rgba(255,255,255,.2);color:#fff}
.sector-tab__ic svg{width:22px;height:22px}
.sector-tab b{display:block;font-size:var(--fs-500);font-weight:600;color:inherit}
.sector-tab b + span{display:block;font-size:var(--fs-300);color:var(--muted)}
.sector-tab.active b{color:#fff}
.sector-tab.active b + span{color:rgba(255,255,255,.85)}
.sector-stage{position:relative;border-radius:var(--radius-lg);overflow:hidden;min-height:440px;box-shadow:var(--shadow)}
.sector-panel{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity var(--dur) var(--ease);}
.sector-panel.active{opacity:1;visibility:visible}
.sector-panel img{width:100%;height:100%;object-fit:cover}
.sector-panel .cap{position:absolute;inset:auto 0 0 0;padding:2.2rem;color:#fff;
  background:linear-gradient(0deg,rgba(21,7,16,.92),rgba(21,7,16,.3) 60%,transparent)}
.sector-panel .cap h3{color:#fff;font-size:1.9rem}
.sector-panel .cap p{color:rgba(255,255,255,.85);font-size:var(--fs-400);max-width:44ch;margin-top:.3rem}
.sector-panel .cap .aromas{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.9rem}
.sector-panel .cap .aromas span{font-size:var(--fs-300);padding:.25rem .7rem;border-radius:99px;
  background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22)}
@media (max-width:820px){
  .sectors{grid-template-columns:1fr;gap:1rem}
  /* todos los botones visibles, mismo tamaño (rejilla 2 col) y texto centrado */
  .sector-tabs{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
  .sector-tab{justify-content:center;text-align:center;gap:0;padding:.7rem .55rem;min-height:58px;border-radius:var(--radius)}
  .sector-tab.active{transform:none}
  .sector-tab__ic{display:none}
  .sector-tab b{font-size:var(--fs-400)}
  .sector-tab b + span{display:none}
  .sector-stage{min-height:320px}
}

/* ============================================================================
   DIFUSOR — showcase (dark)
   ========================================================================== */
.device-show{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6);align-items:center}
.device-show__visual{position:relative;display:grid;place-items:center;min-height:420px}
.device-show__visual .device{width:min(60%,220px)}
.device-show__visual .ring{position:absolute;border:1px solid rgba(249,206,224,.28);border-radius:50%;
  width:120%;aspect-ratio:1;animation:pulse 4s ease-out infinite}
.device-show__visual .ring.r2{width:88%;animation-delay:1.3s}
.device-show__visual .ring.r3{width:56%;animation-delay:2.6s}
@keyframes pulse{0%{opacity:.55;transform:scale(.9)}55%{opacity:.22}100%{opacity:0;transform:scale(1.12)}}
.spec{display:flex;gap:1rem;padding:1.1rem 0;border-bottom:1px solid var(--dk-line)}
.spec:last-child{border-bottom:0}
.spec .ic{flex:none;width:40px;height:40px;border-radius:12px;display:grid;place-items:center;color:var(--rose);background:rgba(225,19,131,.14)}
.spec .ic svg{width:22px;height:22px}
.spec b{color:#fff;font-family:var(--font-body);font-weight:600}
.spec p{margin:.1rem 0 0;color:var(--dk-muted);font-size:var(--fs-400)}
@media (max-width:820px){
  .device-show{grid-template-columns:1fr}
  .device-show__visual{min-height:300px}
  .device-show__visual .device{width:190px}
}

/* ============================================================================
   FRAGANCIAS — familias + marquee + teaser
   ========================================================================== */
.fam-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3)}
.fam{position:relative;border-radius:var(--radius-lg);padding:1.8rem;overflow:hidden;
  border:1px solid var(--line);background:var(--surface);transition:transform var(--dur) var(--ease),box-shadow var(--dur)}
.fam:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.fam::after{content:"";position:absolute;right:-30px;top:-30px;width:120px;height:120px;border-radius:50%;
  background:var(--fam-c,var(--rose));opacity:.14;transition:transform var(--dur) var(--ease)}
.fam:hover::after{transform:scale(1.5)}
.fam__ic{display:grid;place-items:center;width:52px;height:52px;color:var(--fam-c,var(--magenta));
  margin-bottom:.9rem;border-radius:14px;background:color-mix(in srgb,var(--fam-c,var(--magenta)) 10%,transparent)}
.fam__ic svg{width:28px;height:28px}
.fam h3{font-size:1.5rem;margin-bottom:.4rem}
.fam .tags{color:var(--muted);font-size:var(--fs-400)}
.fam .count{position:absolute;top:1.4rem;right:1.4rem;font-family:var(--font-display);font-size:1.4rem;color:var(--fam-c,var(--magenta));font-weight:600}
@media (max-width:820px){.fam-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.fam-grid{grid-template-columns:1fr}}

.aroma-marquee{padding-block:1.4rem;border-block:1px solid var(--line);background:var(--surface)}
.aroma-marquee .marquee__track{gap:0;animation-duration:46s}
.aroma-marquee .m-item{font-family:var(--font-display);font-size:1.5rem;color:var(--muted);padding-inline:1.4rem;white-space:nowrap}
.aroma-marquee .m-item::after{content:"·";color:var(--magenta);margin-left:2.8rem}

/* ============================================================================
   PLANES
   ========================================================================== */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);align-items:stretch;padding-block:1.2rem}
.plan{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:2.2rem 1.9rem;display:flex;flex-direction:column;transition:transform var(--dur) var(--ease),box-shadow var(--dur)}
.plan:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.plan--feat{background:var(--dk-bg);color:var(--dk-text);border:0;box-shadow:var(--shadow-lg);transform:scale(1.03)}
.plan--feat:hover{transform:scale(1.03) translateY(-8px)}
.plan--feat h3,.plan--feat .price{color:#fff}
.plan--feat .plan__desc,.plan--feat li{color:var(--dk-muted)}
.plan__badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--grad-magenta);color:#fff;
  font-size:var(--fs-300);font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:.4rem 1.1rem;border-radius:99px;white-space:nowrap}
.plan__ic{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;color:var(--magenta);
  background:color-mix(in srgb,var(--magenta) 10%,transparent);margin-bottom:1rem}
.plan--feat .plan__ic{background:rgba(255,255,255,.12);color:var(--rose)}
.plan__ic svg{width:26px;height:26px}
.plan h3{font-size:1.7rem;letter-spacing:.02em}
.plan__desc{color:var(--muted);font-size:var(--fs-400);margin:.4rem 0 1.4rem;min-height:3.2em}
.plan ul{list-style:none;padding:0;margin:0 0 1.6rem;display:flex;flex-direction:column;gap:.7rem}
.plan li{display:flex;gap:.6rem;font-size:var(--fs-400);align-items:flex-start}
.plan li .ic{flex:none;width:20px;height:20px;color:var(--magenta);margin-top:1px}
.plan--feat li .ic{color:var(--rose)}
.plan li .ic svg{width:100%;height:100%}
.plan__price{margin-top:auto;padding-top:1.2rem;border-top:1px solid var(--line)}
.plan--feat .plan__price{border-top-color:rgba(255,255,255,.14)}
.price{font-family:var(--font-display);font-size:3.4rem;line-height:1;color:var(--ink);font-weight:600}
.price .u{font-size:.34em;vertical-align:super}
.plan__cycle{color:var(--muted);font-size:var(--fs-400);display:block;margin-top:.2rem}
.plan__perday{display:inline-block;margin-top:.9rem;font-size:var(--fs-300);padding:.35rem .8rem;border-radius:99px;
  background:color-mix(in srgb,var(--magenta) 10%,transparent);color:var(--magenta);font-weight:600}
.plan--feat .plan__perday{background:rgba(255,255,255,.12);color:var(--rose)}
.plan .btn{margin-top:1.4rem;width:100%;justify-content:center}
.plans-note{text-align:center;color:var(--muted);font-size:var(--fs-400);margin:var(--space-4) auto 0;max-width:56ch}
@media (max-width:900px){.plans{grid-template-columns:1fr}.plan--feat{transform:none}.plan--feat:hover{transform:translateY(-8px)}}

/* ============================================================================
   PRUEBA CTA band
   ========================================================================== */
.cta-band{text-align:center;position:relative;z-index:3}
.cta-band h2{font-size:var(--fs-800);max-width:18ch;margin:1rem auto 1rem;color:#fff}
.cta-band .lead{color:rgba(255,255,255,.85);max-width:52ch;margin:0 auto 2rem}
.cta-band .badges{display:flex;gap:1.4rem;justify-content:center;flex-wrap:wrap;margin-top:2.4rem}
.cta-band .badge{display:flex;align-items:center;gap:.5rem;font-size:var(--fs-400);color:rgba(255,255,255,.82)}
.cta-band .badge .ic{width:20px;height:20px;color:var(--rose)}

/* ============================================================================
   ZONA de servicio
   ========================================================================== */
.zona{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6);align-items:center}
.zona__map{position:relative;aspect-ratio:4/3;border-radius:var(--radius-lg);overflow:hidden;
  background:var(--blush);border:1px solid var(--line);display:grid;place-items:center}
.zona__map svg{width:78%;height:auto;filter:drop-shadow(0 20px 30px rgba(180,0,95,.25))}
.zona__pin{position:absolute;display:flex;flex-direction:column;align-items:center;color:var(--magenta);transform:translate(-50%,-100%)}
.zona__pin .dot{width:14px;height:14px;border-radius:50%;background:var(--magenta);box-shadow:0 0 0 6px rgba(225,19,131,.22);animation:ping 2.4s var(--ease) infinite}
@keyframes ping{0%{box-shadow:0 0 0 0 rgba(225,19,131,.4)}70%{box-shadow:0 0 0 16px rgba(225,19,131,0)}100%{box-shadow:0 0 0 0 rgba(225,19,131,0)}}
/* mapa de zonas: silueta + pines arriba, leyenda nítida (HTML) abajo */
.zona__mapwrap{margin:0;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:1.6rem;box-shadow:var(--shadow)}
.zona-map-viz{border-radius:var(--radius);padding:.6rem;
  background:radial-gradient(60% 70% at 50% 45%, color-mix(in srgb,var(--magenta) 7%,transparent), transparent 72%)}
.es-map{width:100%;max-width:420px;margin-inline:auto;height:auto;display:block}
/* leyenda */
.zona-legend{list-style:none;margin:1.3rem 0 0;padding:1.3rem 0 0;border-top:1px solid var(--line);
  display:flex;flex-direction:column;gap:1rem}
.zona-legend li{display:flex;gap:.85rem;align-items:flex-start}
.zona-legend .lg-dot{flex:none;width:14px;height:14px;border-radius:50%;background:var(--magenta);margin-top:.4rem;
  box-shadow:0 0 0 4px rgba(225,19,131,.16)}
.zona-legend b{display:block;font-family:var(--font-display);font-size:1.35rem;color:var(--ink);line-height:1.1}
.zona-legend span{font-size:var(--fs-400);color:var(--muted)}
@media (max-width:820px){.zona{grid-template-columns:1fr}}

/* ============================================================================
   FAQ
   ========================================================================== */
.faq{max-width:820px;margin-inline:auto}
.faq__item{border-bottom:1px solid var(--line)}
.faq__q{width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:1.4rem 0;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
  font-family:var(--font-display);font-size:1.35rem;color:var(--ink);font-weight:600}
.faq__q .ic{flex:none;width:26px;height:26px;color:var(--magenta);transition:transform var(--dur) var(--ease)}
.faq__item.open .faq__q .ic{transform:rotate(45deg)}
.faq__a{max-height:0;overflow:hidden;transition:max-height var(--dur) var(--ease)}
.faq__a p{padding:0 0 1.4rem;color:var(--muted);margin:0;max-width:70ch}

/* ============================================================================
   CONTACTO
   ========================================================================== */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6)}
.contact__info .cline{display:flex;gap:1rem;align-items:flex-start;padding:1rem 0;border-bottom:1px solid var(--line)}
.contact__info .cline:last-child{border-bottom:0}
.contact__info .ic{flex:none;width:46px;height:46px;border-radius:14px;display:grid;place-items:center;color:var(--magenta);background:color-mix(in srgb,var(--magenta) 10%,transparent)}
.contact__info .ic svg{width:22px;height:22px}
.contact__info .cline b{display:block;color:var(--ink);font-family:var(--font-body)}
.contact__info .cline a,.contact__info .cline span{color:var(--muted);font-size:var(--fs-500)}
.contact__info .cline a:hover{color:var(--magenta)}
/* tarjeta CTA de contacto (llamar / WhatsApp) */
.contact-cta{background:var(--dk-bg);color:var(--dk-text);border-radius:var(--radius-lg);padding:2.4rem;
  box-shadow:var(--shadow);display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.contact-cta::after{content:"";position:absolute;right:-40px;top:-40px;width:180px;height:180px;border-radius:50%;
  background:radial-gradient(circle,rgba(225,19,131,.4),transparent 70%)}
.contact-cta h3{color:#fff;font-size:1.9rem;margin-bottom:.5rem;position:relative}
.contact-cta p{color:var(--dk-muted);margin-bottom:1.6rem;position:relative}
.contact-cta .btn{width:100%;justify-content:center;position:relative}
.contact-cta .btn + .btn{margin-top:.8rem}
.contact-cta .btn--ghost{border-color:rgba(255,255,255,.3);color:#fff}
.contact-cta .btn--ghost:hover{border-color:#fff;background:rgba(255,255,255,.1)}
.contact-cta .cta-tel{display:block;text-align:center;margin-top:1.4rem;position:relative}
.contact-cta .cta-tel .n{font-family:var(--font-display);font-size:2rem;color:#fff;font-weight:600;letter-spacing:.02em}
.contact-cta .cta-tel .l{display:block;font-size:var(--fs-300);text-transform:uppercase;letter-spacing:.16em;color:var(--dk-muted)}
@media (max-width:820px){.contact{grid-template-columns:1fr}}

/* ============================================================================
   FOOTER
   ========================================================================== */
.footer{position:relative;overflow:hidden}
.footer .brand__txt{color:#fff}
.footer .brand__mark{color:var(--rose)}
.footer__tag{font-family:var(--font-script);font-size:1.7rem;color:var(--rose);margin:1rem 0 .4rem}
.footer h4{font-family:var(--font-body);font-size:var(--fs-300);text-transform:uppercase;letter-spacing:.16em;color:var(--rose);margin-bottom:1rem}
.footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem;font-size:var(--fs-400)}
.footer .soc{display:flex;gap:.7rem;margin-top:1.2rem}
.footer .soc a{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;
  border:1px solid rgba(255,255,255,.2);color:var(--footer-text)}
.footer .soc a:hover{background:var(--magenta);border-color:var(--magenta);color:#fff}
.footer .soc .ic{width:20px;height:20px}

/* ============================================================================
   BARRA FIJA MÓVIL — Llamar / WhatsApp
   ========================================================================== */
.mobile-cta{display:none}
@media (max-width:820px){
  .mobile-cta{display:grid;grid-template-columns:1fr 1fr;gap:.55rem;position:fixed;left:0;right:0;bottom:0;
    z-index:var(--z-nav);padding:.6rem .8rem calc(.6rem + env(safe-area-inset-bottom));
    background:color-mix(in srgb,var(--bg) 92%,transparent);backdrop-filter:blur(12px) saturate(140%);
    border-top:1px solid var(--line);box-shadow:0 -10px 30px -18px rgba(120,10,70,.4);
    transform:translateY(130%);transition:transform .4s var(--ease)}
  .mobile-cta.show{transform:translateY(0)}
  .mobile-cta__btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.95rem;
    border-radius:var(--radius-pill);font-family:var(--font-body);font-weight:600;font-size:var(--fs-400);
    letter-spacing:.01em;line-height:1}
  .mobile-cta__btn .ic{width:1.15em;height:1.15em;flex:none}
  .mcta--call{background:var(--grad-magenta);color:#fff;box-shadow:var(--shadow-sm)}
  .mcta--wa{background:#17070F;color:#fff}
  .mcta--wa .ic{color:#25D366}
  /* deja aire para que la barra no tape el final del contenido */
  body{padding-bottom:78px}
  /* menú abierto: la barra queda por debajo del overlay */
  body.menu-open .mobile-cta{display:none}
}

/* ============================================================================
   PÁGINAS LEGALES
   ========================================================================== */
.legal{max-width:840px;margin-inline:auto;padding-top:6rem}
.legal>.eyebrow{margin-bottom:.6rem}
.legal h1{font-size:var(--fs-800);line-height:1.05;margin:.3rem 0 .5rem}
.legal .updated{color:var(--muted);font-size:var(--fs-400);margin-bottom:2.5rem}
.legal h2{font-family:var(--font-display);font-size:1.7rem;margin:2.4rem 0 .7rem;color:var(--ink)}
.legal h3{font-size:1.15rem;font-family:var(--font-body);font-weight:600;margin:1.3rem 0 .3rem;color:var(--ink)}
.legal p,.legal li{color:var(--text);line-height:1.75;max-width:none}
.legal ul{padding-left:1.2rem;margin:.4rem 0 1.1rem;display:block}
.legal li{margin-bottom:.35rem}
.legal a{color:var(--magenta);text-decoration:underline;text-underline-offset:2px}
.legal .ph{background:color-mix(in srgb,var(--magenta) 12%,transparent);color:var(--magenta-deep);
  padding:.05em .4em;border-radius:5px;font-weight:600;font-size:.95em}
.legal .box{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem 1.4rem;margin:1rem 0}
.footer__legal{display:flex;gap:.4rem 1rem;flex-wrap:wrap}
.footer__legal a{color:var(--footer-text);opacity:.8}
.footer__legal a:hover{opacity:1;color:#fff}

/* utilidades */
.mt-0{margin-top:0}
.tac{text-align:center}
.chip{display:inline-flex;align-items:center;gap:.4rem;font-size:var(--fs-300);padding:.35rem .8rem;border-radius:99px;
  background:color-mix(in srgb,var(--magenta) 9%,transparent);color:var(--magenta);font-weight:600;
  text-transform:uppercase;letter-spacing:.08em}
.on-dark .chip{background:rgba(255,255,255,.1);color:var(--rose)}
.pill-row{display:flex;gap:.5rem;flex-wrap:wrap}

/* ============================================================================
   MÓVIL — menú, hero, eyebrows, chip, footer
   ========================================================================== */
/* menú abierto: bloquea el scroll del body y anula el backdrop-filter del nav
   (si no, backdrop-filter crea un bloque contenedor y el overlay fixed no cubre) */
body.menu-open{overflow:hidden}
body.menu-open .nav{backdrop-filter:none;-webkit-backdrop-filter:none;background:var(--bg)}
.nav__close{display:none;background:none;border:0;cursor:pointer;color:var(--ink)}
@media (max-width:820px){
  .nav__links{gap:var(--space-3);padding:var(--gutter)}
  .nav__close{display:grid;place-items:center;position:absolute;top:1rem;right:var(--gutter);width:46px;height:46px}
  .nav__close .ic{width:28px;height:28px}
  /* CTAs del hero: columna a ancho completo */
  .hero__cta{flex-direction:column;align-items:stretch}
  .hero__cta .btn{width:100%;justify-content:center}
}
@media (max-width:560px){
  .eyebrow{letter-spacing:.14em;font-size:.68rem}
  /* stats del hero: 3 en fila, no en columna */
  .hero__meta{display:grid;grid-template-columns:repeat(3,1fr);gap:.7rem}
  .hero__meta > div{min-width:0}
  .hero__meta .n{font-size:1.55rem}
  .hero__meta .l{font-size:.6rem;letter-spacing:.08em}
  /* chip: forzar una sola línea */
  .chip{font-size:.54rem;letter-spacing:.02em;white-space:nowrap}
  .chip .ic{width:.9em;height:.9em}
  /* footer a una columna */
  .footer__grid{grid-template-columns:1fr;gap:var(--space-4)}
  .device-show__visual{margin-inline:auto}
}

/* ============================================================================
   CATÁLOGO (catalogo.html)
   ========================================================================== */
.cat-top{padding:9rem 0 3rem;text-align:center;position:relative;overflow:hidden}
.cat-top h1{font-size:var(--fs-800);margin:.8rem 0 .8rem}
.cat-top .lead{margin-inline:auto}
.cat-controls{position:sticky;top:70px;z-index:20;padding:1rem 0;margin-bottom:var(--space-4);
  background:color-mix(in srgb,var(--bg) 90%,transparent);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line)}
.cat-search{position:relative;max-width:460px;margin:0 auto 1rem}
.cat-search .ic{position:absolute;left:1rem;top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--muted)}
.cat-search input{width:100%;padding:.85rem 1rem .85rem 2.8rem;border-radius:var(--radius-pill);
  border:1px solid var(--line);background:var(--surface);color:var(--text)}
.cat-search input:focus{outline:none;border-color:var(--magenta);box-shadow:var(--shadow-sm)}
.cat-filters{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}
.filter{cursor:pointer;font-family:var(--font-body);font-size:var(--fs-400);font-weight:500;
  padding:.5rem 1.05rem;border-radius:99px;border:1px solid var(--line);background:var(--surface);color:var(--muted);
  transition:all var(--dur-fast) var(--ease)}
.filter:hover{border-color:color-mix(in srgb,var(--magenta) 40%,transparent);color:var(--ink)}
.filter.active{background:var(--grad-magenta);color:#fff;border-color:transparent}
.filter .c{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--fc,var(--magenta));margin-right:.5rem;vertical-align:middle}
.filter.active .c{background:#fff}
.cat-count{text-align:center;color:var(--muted);font-size:var(--fs-400);margin-bottom:var(--space-3)}
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:var(--space-2)}
.aroma-card{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.2rem 1.2rem 1.1rem;transition:transform var(--dur-fast) var(--ease),box-shadow var(--dur-fast),border-color var(--dur-fast);
  overflow:hidden}
.aroma-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:color-mix(in srgb,var(--fc) 50%,var(--line))}
.aroma-card::before{content:"";position:absolute;right:-16px;top:-16px;width:64px;height:64px;border-radius:50%;
  background:var(--fc);opacity:.12;transition:transform var(--dur) var(--ease)}
.aroma-card:hover::before{transform:scale(1.7)}
.aroma-card .drop{width:30px;height:30px;color:var(--fc);margin-bottom:.7rem}
.aroma-card .drop svg{width:100%;height:100%}
.aroma-card .ref{font-family:var(--font-body);font-size:var(--fs-300);letter-spacing:.08em;color:var(--muted)}
.aroma-card .nm{font-family:var(--font-display);font-size:1.35rem;font-weight:600;color:var(--ink);line-height:1.1;margin:.15rem 0 .5rem}
.aroma-card .fam-tag{font-size:var(--fs-300);color:var(--fc);font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.aroma-card.hide{display:none}
.cat-empty{text-align:center;color:var(--muted);padding:var(--space-5) 0;display:none}
.cat-cta{text-align:center;margin-top:var(--space-6)}
@media (max-width:520px){.cat-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}

/* reduce motion extra */
@media (prefers-reduced-motion: reduce){
  .ring,.zona__pin .dot,.sm-ring,.scrollcue .ic{animation:none}
  .device-show__visual .ring{opacity:.3}
}
