/* ============================================================
   BARREL — Home · Sistema visual (Brandbook v2.1)
   Producción unificada (desktop + mobile responsive).
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  /* Paleta principal */
  --sol:#F1B33C;
  --cielo:#B6DCEC;
  --marina:#0E1F3D;
  --brasa:#E66B2C;
  --coral:#F4A05E;
  --sal:#FAF7F0;
  --roca:#1A1612;

  /* Escalas usadas */
  --sol-300:#F4C45C; --sol-600:#D59D2C;
  --cielo-50:#F4FAFC; --cielo-100:#E6F3F7; --cielo-200:#D2E9F1; --cielo-700:#6F9EB1;
  --marina-700:#0A1730; --marina-800:#070F1F; --marina-400:#3F4F6E;
  --coral-100:#FCE4CF; --coral-200:#F9CBA7;

  /* Sistema */
  --hero-bg: var(--cielo);
  --section-air: clamp(96px, 13vh, 188px);
  --cta-bg: var(--sol);
  --cta-fg: var(--marina);

  /* Layout */
  --container: 1240px;
  --gutter: clamp(20px, 5vw, 64px);

  --font-display:"Bricolage Grotesque", system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-body:"Poppins", system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-serif:"Instrument Serif", Georgia, "Times New Roman", serif;
}

/* ---------- Reset ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--sal);
  color:var(--marina);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit}
::selection{background:var(--sol);color:var(--marina)}

/* Skip link accesibilidad */
.skip-link{
  position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;
}
.skip-link:focus{
  position:fixed;left:16px;top:16px;width:auto;height:auto;
  background:var(--marina);color:var(--sal);padding:10px 18px;border-radius:8px;z-index:200;
  font-family:var(--font-display);font-weight:600;
}

:focus-visible{outline:2px solid var(--marina);outline-offset:3px;border-radius:6px}
.btn:focus-visible{outline-offset:4px}

/* ---------- Tipografía ---------- */
.type-display{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(54px,10.5vw,168px);line-height:.88;letter-spacing:-.045em;
}
.type-title{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(38px,6.4vw,104px);line-height:.92;letter-spacing:-.04em;
}
.type-subtitle{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(26px,3.6vw,56px);line-height:.98;letter-spacing:-.032em;
}
.type-lede{
  font-family:var(--font-display);font-weight:400;
  font-size:clamp(20px,2.3vw,31px);line-height:1.32;letter-spacing:-.012em;
}
.type-body{
  font-family:var(--font-body);font-weight:400;
  font-size:clamp(16.5px,1.15vw,19px);line-height:1.62;letter-spacing:0;
}
.type-mono{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(11px,.85vw,13px);line-height:1;letter-spacing:.16em;text-transform:uppercase;
}
.accent{font-family:var(--font-serif);font-style:italic;font-weight:400;letter-spacing:-.01em}

.eyebrow{color:var(--marina);opacity:.62}
em.accent{font-style:italic}

/* Resaltado tipo marcador (Sol) */
.hl{
  background:var(--sol);color:var(--marina);
  padding:.02em .26em;border-radius:.16em;
  box-decoration-break:clone;-webkit-box-decoration-break:clone;
}

/* ---------- Layout helpers ---------- */
.container{max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.narrow{max-width:880px}
.section{padding-block:var(--section-air)}
.center{text-align:center}
.measure{max-width:62ch}
.stack-sm>*+*{margin-top:1.1em}
.stack-md>*+*{margin-top:1.5em}

/* ---------- Buttons ---------- */
.btn{
  font-family:var(--font-display);font-weight:600;font-size:clamp(16px,1.2vw,19px);
  letter-spacing:-.01em;display:inline-flex;align-items:center;gap:.6em;
  padding:1.05em 1.7em;border-radius:999px;cursor:pointer;border:2px solid transparent;
  transition:transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s, background-color .25s;
  will-change:transform;
  min-height:44px;
}
.btn-cta{
  background:var(--cta-bg);color:var(--cta-fg);
  box-shadow:0 10px 24px -10px color-mix(in srgb, var(--sol) 80%, #000 0%);
}
.btn-cta:hover{transform:translateY(-3px);box-shadow:0 18px 34px -12px color-mix(in srgb, var(--sol) 70%, #000 10%)}
.btn-cta:active{transform:translateY(-1px)}
.btn-cta .arrow{transition:transform .25s}
.btn-cta:hover .arrow{transform:translateX(4px)}

.link-arrow{
  font-family:var(--font-display);font-weight:600;font-size:clamp(17px,1.3vw,21px);
  letter-spacing:-.01em;display:inline-flex;align-items:center;gap:.45em;
  border-bottom:2px solid currentColor;padding-bottom:2px;transition:gap .25s,opacity .2s;
}
.link-arrow:hover{gap:.75em}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:90;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--gutter);
  transition:background-color .35s, box-shadow .35s, padding .35s;
}
.nav__logo{height:42px;width:auto;transition:height .35s}
.nav.scrolled{
  background:color-mix(in srgb, var(--sal) 86%, transparent);
  backdrop-filter:blur(14px) saturate(1.1);
  -webkit-backdrop-filter:blur(14px) saturate(1.1);
  box-shadow:0 1px 0 rgba(14,31,61,.08);
  padding-block:13px;
}
.nav.scrolled .nav__logo{height:34px}
.nav__links{display:flex;align-items:center;gap:clamp(14px,2vw,30px)}
.nav__link{
  font-family:var(--font-display);font-weight:500;font-size:16px;letter-spacing:-.01em;
  color:var(--marina);opacity:.8;transition:opacity .2s;
}
.nav__link:hover{opacity:1}
.nav__cta{
  font-family:var(--font-display);font-weight:600;font-size:15px;letter-spacing:-.01em;
  background:var(--sol);color:var(--marina);padding:.62em 1.15em;border-radius:999px;
  transition:transform .2s, box-shadow .2s;
  box-shadow:0 6px 16px -8px rgba(241,179,60,.9);
  min-height:44px;display:inline-flex;align-items:center;
}
.nav__cta:hover{transform:translateY(-2px);box-shadow:0 12px 22px -10px rgba(241,179,60,.95)}
.nav__burger{
  display:none;background:none;border:none;cursor:pointer;
  flex-direction:column;gap:5px;padding:10px;border-radius:8px;
  z-index:60;
}
.nav__burger span{
  width:24px;height:2px;background:var(--marina);border-radius:2px;
  transition:transform .3s, opacity .3s;
}
.nav__burger.open span{background:var(--sal)}
.nav__burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger.open span:nth-child(2){opacity:0}
.nav__burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============================================================
   DRAWER (móvil)
   ============================================================ */
.m-drawer{
  position:fixed;inset:0;z-index:55;
  display:none;flex-direction:column;justify-content:center;gap:8px;
  padding:80px 40px 40px;
  background:var(--marina);
  opacity:0;visibility:hidden;
  transition:opacity .35s, visibility .35s;
}
.m-drawer.open{opacity:1;visibility:visible}
.m-drawer a{
  font-family:var(--font-display);font-weight:600;letter-spacing:-.02em;
  color:var(--sal);font-size:clamp(28px,7vw,36px);line-height:1.25;padding:10px 0;
  border-bottom:1px solid color-mix(in srgb,var(--sal) 16%, transparent);
}
.m-drawer a.cta{color:var(--sol)}
.m-drawer__foot{margin-top:auto;padding-top:24px}
.m-drawer__foot a{
  font-size:16px;border:0;
  color:color-mix(in srgb,var(--sal) 70%, transparent);padding:4px 0;
}

/* ============================================================
   HERO — Sección 1
   ============================================================ */
.hero{
  background:var(--hero-bg);
  position:relative;overflow:hidden;
  padding-top:clamp(120px,16vh,180px);padding-bottom:0;
  min-height:clamp(640px,82vh,740px);
}
.hero__wave{
  position:absolute;left:0;right:0;bottom:-2px;
  width:100%;height:clamp(120px,13vw,190px);display:block;
  color:var(--sal);z-index:3;
}
.hero__grid{
  display:grid;grid-template-columns:1fr 1.08fr;gap:clamp(24px,3vw,52px);align-items:center;
  position:relative;z-index:2;
}
.hero__photo{position:static}

/* Figura de Marta integrada en el fondo (sin caja), anclada al hero.
   En viewports anchos (>1400px) se mantiene cerca del contenedor del texto
   en lugar de irse al borde del navegador (max() entre -1% y un offset relativo al container).
   Sin z-index para que NO cree un stacking context: así el badge (hijo) puede
   pintarse por encima de la ola usando su propio z-index. */
.hero__figure{
  position:absolute;
  right:max(-1%, calc(50% - var(--container)/2 - 80px));
  top:clamp(118px,14vh,155px);
  margin:0;width:min(44vw,510px);pointer-events:none;
}
.hero__marta{
  display:block;width:100%;height:auto;
  filter:drop-shadow(0 30px 50px rgba(14,31,61,.18));
}
.hero__badge{
  /* Posicionado relativo a .hero__figure (no a .hero) para que ancle en Marta en ambos viewports.
     z-index:5 lo sitúa por encima de la ola (z:3); como el figure ya no es stacking context,
     el badge participa en el contexto raíz y la ola pasa por detrás. */
  position:absolute;right:8%;bottom:32%;z-index:5;
  background:var(--marina);color:var(--sal);
  font-family:var(--font-display);font-weight:700;letter-spacing:-.01em;
  font-size:clamp(15px,1.3vw,19px);padding:.7em 1.2em;border-radius:999px;
  box-shadow:0 16px 32px -14px rgba(14,31,61,.6);
  pointer-events:auto;
  white-space:nowrap;
}
.hero__eyebrow{
  font-size:clamp(12px,1.05vw,15px);letter-spacing:.075em;
  white-space:nowrap;margin-bottom:1.4em;
}
.hero__title{margin-bottom:.16em}
.hero__sub{margin-bottom:.3em;color:color-mix(in srgb, var(--marina) 88%, transparent)}
.hero__desc{
  max-width:46ch;margin-bottom:2.1em;
  color:color-mix(in srgb,var(--marina) 84%, transparent);
}
/* Texto e CTA del hero por encima de la ola (z:3) — la ola pasa por detrás dando profundidad */
.hero__text{padding-bottom:clamp(40px,7vh,90px);position:relative;z-index:5}
/* CTA del hero con sombra reforzada cuando se solapa con la ola — efecto de elevación */
.hero .btn-cta{
  box-shadow:
    0 12px 28px -10px color-mix(in srgb, var(--sol) 80%, #000 0%),
    0 24px 48px -20px rgba(14,31,61,.35);
}
.hero .btn-cta:hover{
  box-shadow:
    0 18px 36px -12px color-mix(in srgb, var(--sol) 70%, #000 10%),
    0 32px 60px -24px rgba(14,31,61,.45);
}

/* Photo frame reutilizable */
.photo-frame{
  position:relative;aspect-ratio:4/5;border-radius:26px;overflow:hidden;
  background:
    linear-gradient(160deg, var(--cielo-200), color-mix(in srgb,var(--marina) 14%, var(--cielo)));
  box-shadow:0 40px 80px -40px rgba(14,31,61,.5);
  display:flex;align-items:flex-end;justify-content:center;
}
.photo-frame img.real{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

/* ============================================================
   El Espejo — Panel "puente" entre Rejilla y Marketing.
   Padding compacto para que enlace narrativamente con las dos
   secciones que lo rodean en lugar de respirar como sección suelta.
   ============================================================ */
.espejo{padding-block:clamp(24px,3.5vh,56px)}
.espejo__panel{
  background:var(--marina);border-radius:30px;
  padding:clamp(34px,4.6vw,76px);
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,4.5vw,72px);align-items:start;
  position:relative;overflow:hidden;
  box-shadow:0 50px 110px -55px rgba(14,31,61,.7);
}
.espejo__panel::before{
  content:"";position:absolute;right:-6%;top:-26%;
  width:min(40%,360px);aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle, color-mix(in srgb,var(--sol) 36%, transparent), transparent 66%);
  pointer-events:none;
}
.espejo__panel .type-title{
  color:var(--sal);font-size:clamp(34px,4.3vw,62px);line-height:1.08;
  max-width:9ch;position:relative;z-index:1;
}
.espejo__panel .accent{color:var(--sol)}
.espejo__text{position:relative;z-index:1}
.espejo__text p{color:color-mix(in srgb,var(--sal) 78%, transparent);max-width:52ch}

/* ============================================================
   Rejilla de método — Sección 2
   ============================================================ */
.rejilla{padding-top:clamp(54px,7vh,96px);padding-bottom:clamp(40px,5.5vh,80px)}
.rejilla__intro{margin-bottom:clamp(28px,4vh,52px)}
.rejilla__intro .type-title{margin-bottom:.55em;max-width:16ch}
.rejilla__intro p{color:color-mix(in srgb,var(--marina) 84%, transparent);max-width:56ch}

.block{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,84px);align-items:center;
  padding-block:clamp(28px,4vh,56px);
}
.block__copy .type-mono{color:var(--brasa);margin-bottom:1em;display:inline-block}
.block__copy .type-subtitle{margin-bottom:.5em}
.block__copy p{color:color-mix(in srgb,var(--marina) 84%, transparent);max-width:46ch}
.block--reverse .block__visual{order:2}
.block--reverse .block__copy{order:1}

/* ---- Mockup: Antes / Después (slider interactivo) ---- */
.beforeafter{
  --ba-progress: 50%;
  border-radius:22px;overflow:hidden;position:relative;aspect-ratio:4/3;
  box-shadow:0 30px 60px -34px rgba(14,31,61,.42);border:1px solid rgba(14,31,61,.06);
  background:linear-gradient(160deg, var(--coral-100), var(--sol-300));
  user-select:none;-webkit-user-select:none;touch-action:none;
}
.ba-room{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  pointer-events:none;
}
.ba-after-img{z-index:1}
.ba-before-layer{
  position:absolute;inset:0;z-index:2;
  clip-path: inset(0 calc(100% - var(--ba-progress)) 0 0);
  background:linear-gradient(160deg,#cdd2d8,#9aa3ad);
  transition:clip-path .05s linear;
}
.beforeafter.dragging .ba-before-layer{transition:none}
.ba-tag{
  position:absolute;bottom:18px;z-index:6;
  background:color-mix(in srgb,var(--sal) 92%, transparent);color:var(--marina);
  padding:6px 11px;border-radius:8px;
  pointer-events:none;
}
.ba-tag--before{left:18px}
.ba-tag--after{right:18px;background:var(--marina);color:var(--sal)}
.ba-divider{
  position:absolute;top:0;bottom:0;
  left:var(--ba-progress);
  width:3px;background:var(--sal);
  transform:translateX(-50%);z-index:5;
  pointer-events:none;
}
.ba-handle{
  position:absolute;top:50%;
  left:var(--ba-progress);
  transform:translate(-50%,-50%);z-index:7;
  width:44px;height:44px;border-radius:50%;background:var(--sal);
  box-shadow:0 6px 16px rgba(14,31,61,.3);
  display:flex;align-items:center;justify-content:center;color:var(--marina);
  cursor:ew-resize;touch-action:none;
  transition:transform .15s ease, box-shadow .2s;
}
.ba-handle:hover,.ba-handle:focus-visible{
  transform:translate(-50%,-50%) scale(1.08);
  box-shadow:0 8px 20px rgba(14,31,61,.4);
}
.beforeafter.dragging .ba-handle{transform:translate(-50%,-50%) scale(1.12)}
.ba-ia{
  position:absolute;top:14px;right:14px;z-index:6;
  background:var(--sol);color:var(--marina);padding:5px 10px;border-radius:999px;
  display:inline-flex;gap:6px;align-items:center;white-space:nowrap;
  pointer-events:none;
}

/* ---- Mockup: Tarjetas de inversión ---- */
.invest-stack{display:flex;flex-direction:column;gap:18px;max-width:440px;margin-inline:auto;width:100%}
.invest-card{
  background:var(--sal);border-radius:16px;padding:24px 26px;
  box-shadow:0 22px 44px -28px rgba(14,31,61,.4);border:1px solid rgba(14,31,61,.07);
  position:relative;overflow:hidden;
}
.invest-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px}
.invest-card.c1::before{background:var(--sol)}
.invest-card.c2::before{background:var(--cielo-700)}
.invest-card .ic-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:4px}
.invest-card .ic-head .type-mono{white-space:nowrap}
.invest-card .ic-loc{color:color-mix(in srgb,var(--marina) 60%, transparent);margin-bottom:18px;font-size:14px}
.invest-card .ic-dot{width:9px;height:9px;border-radius:50%}
.invest-card.c1 .ic-dot{background:var(--sol)}
.invest-card.c2 .ic-dot{background:var(--cielo-700)}
.invest-card .ic-row{display:flex;justify-content:space-between;align-items:center;padding-top:13px;border-top:1px solid rgba(14,31,61,.1)}
.invest-card .ic-row+.ic-row{margin-top:4px}
.ic-label{font-family:var(--font-body);font-size:14.5px;color:color-mix(in srgb,var(--marina) 78%, transparent)}
.ic-val{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em}
.ic-val .gt{color:var(--brasa);font-size:1.5em;font-weight:800;vertical-align:-.02em;margin-right:.06em}
.ic-val .pct{font-size:1.6em}

/* ---- Mockup: Evento / Open house ---- */
.event-card{
  background:var(--sal);border-radius:22px;padding:28px;width:100%;
  box-shadow:0 30px 60px -34px rgba(14,31,61,.42);border:1px solid rgba(14,31,61,.06);
}
.event-card .ev-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:22px}
.event-date{background:var(--marina);color:var(--sal);border-radius:14px;padding:10px 16px;text-align:center;line-height:1}
.event-date .d{font-family:var(--font-display);font-weight:700;font-size:30px;letter-spacing:-.03em}
.event-date .m{margin-top:5px;color:var(--sol)}
.ev-coffee{display:inline-flex;gap:7px;align-items:center;color:color-mix(in srgb,var(--marina) 62%, transparent)}
.ev-slot{display:flex;align-items:center;gap:14px;padding:13px 0;border-top:1px solid rgba(14,31,61,.1)}
.ev-avatars{display:flex}
.ev-avatars span{
  width:34px;height:34px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:600;font-size:13px;color:var(--marina);
  margin-left:-9px;border:2px solid var(--sal);
}
.ev-avatars span:first-child{margin-left:0}
.ev-time{font-family:var(--font-display);font-weight:600;letter-spacing:-.01em;margin-left:auto;color:var(--marina)}
.ev-fam{font-size:14.5px;color:color-mix(in srgb,var(--marina) 80%, transparent)}

/* ---- Mockup: Anuncio estancado vs nuevo ---- */
.contrast{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:stretch}
.listing{background:#fff;border-radius:16px;overflow:hidden;border:1px solid rgba(14,31,61,.1);display:flex;flex-direction:column}
.listing .li-photo{aspect-ratio:4/3;position:relative;display:flex;align-items:flex-start;padding:10px;overflow:hidden}
.li-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.listing .li-flag{position:relative;z-index:2}
.listing.old .li-photo{background:#9aa3ad}
.listing.new .li-photo{background:var(--cielo-200)}
.listing .li-flag{font-family:var(--font-display);font-weight:600;font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:5px 9px;border-radius:7px}
.listing.old .li-flag{background:rgba(26,22,18,.62);color:#e9e9e9}
.listing.new .li-flag{background:var(--marina);color:var(--sol)}
.listing .li-body{padding:14px 16px 16px;flex:1}
.listing .li-title{font-family:var(--font-display);font-weight:600;font-size:16px;letter-spacing:-.01em;margin-bottom:3px}
.listing.old .li-title{color:#5b5f64}
.li-meta{font-size:12.5px;color:color-mix(in srgb,var(--marina) 55%, transparent);margin-bottom:11px}
.li-stat{display:flex;justify-content:space-between;font-size:12.5px;padding:5px 0;border-top:1px dashed rgba(14,31,61,.16)}
.listing.old .li-stat{color:#7a7f85}
.li-stat b{font-family:var(--font-display)}
.listing.new .li-stat b{color:var(--brasa)}
.contrast-arrow{display:flex;align-items:center;justify-content:center;color:var(--marina);margin:2px 0}

/* ---- Embudo / Funnel ---- */
.embudo{
  margin-top:clamp(56px,9vh,120px);
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,90px);align-items:center;
}
.embudo__copy .type-lede{margin-bottom:1.4em}
.embudo__copy p{color:color-mix(in srgb,var(--marina) 86%, transparent);max-width:48ch}
.embudo__copy p+p{margin-top:1.3em}
.funnel-visual{display:flex;flex-direction:column;align-items:center;gap:30px}

/* Phone */
.phone{
  width:244px;max-width:70vw;border-radius:40px;background:var(--marina);
  padding:11px;
  box-shadow:0 50px 90px -40px rgba(14,31,61,.6), 0 0 0 1px rgba(14,31,61,.4) inset;
  position:relative;
}
.phone__notch{position:absolute;top:20px;left:50%;transform:translateX(-50%);width:96px;height:26px;background:var(--marina);border-radius:0 0 16px 16px;z-index:5}
.phone__screen{background:#fff;border-radius:32px;overflow:hidden}
.ig-top{display:flex;align-items:center;gap:9px;padding:34px 13px 11px}
.ig-ava{
  width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,var(--sol),var(--brasa));
  display:flex;align-items:center;justify-content:center;
}
.ig-ava img{width:18px;height:auto}
.ig-handle{font-family:var(--font-display);font-weight:600;font-size:13px;line-height:1.1}
.ig-handle small{display:block;font-weight:400;font-size:11px;color:#8a8f96}
.ig-more{margin-left:auto;color:#222;font-weight:700;letter-spacing:1px}
.ig-photo{
  aspect-ratio:1;position:relative;
  background:linear-gradient(165deg,var(--cielo),var(--coral) 120%);
  display:flex;align-items:flex-end;padding:14px;overflow:hidden;
}
.ig-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.ig-photo .ig-pill{
  background:rgba(14,31,61,.78);color:var(--sal);padding:6px 11px;border-radius:999px;
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  position:relative;z-index:2;
}
.ig-photo .ig-fototag{
  position:absolute;top:12px;left:12px;
  background:rgba(250,247,240,.85);color:var(--marina);
  padding:4px 9px;border-radius:7px;z-index:2;
}
.ig-cta{display:flex;align-items:center;justify-content:space-between;padding:12px 13px;background:var(--cielo-50)}
.ig-cta .lbl{font-family:var(--font-display);font-weight:600;font-size:13.5px}
.ig-cta .go{font-family:var(--font-display);font-weight:700;font-size:12px;background:var(--sol);color:var(--marina);padding:6px 12px;border-radius:999px}
.ig-actions{display:flex;gap:15px;padding:11px 13px;color:#222}
.ig-actions .spacer{flex:1}
.ig-cap{padding:0 13px 14px;font-size:12.5px;color:#3a3f45}
.ig-cap b{font-family:var(--font-display)}

/* Funnel steps */
.funnel-steps{display:flex;align-items:flex-start;justify-content:center;gap:10px;width:100%;max-width:620px}
.fstep{flex:1;text-align:center;display:flex;flex-direction:column;align-items:center;gap:13px}
.fstep__icon{width:68px;height:68px;border-radius:20px;background:var(--cielo-100);display:flex;align-items:center;justify-content:center;color:var(--marina)}
.fstep:nth-child(5) .fstep__icon{background:var(--sol);color:var(--marina)}
.fstep__txt{font-family:var(--font-display);font-weight:500;font-size:15.5px;letter-spacing:-.01em;line-height:1.28;max-width:14ch}
.fsep{align-self:center;margin-top:24px;color:var(--cielo-700);flex:0 0 auto}

/* ============================================================
   Marketing visible — Sección 4
   ============================================================ */
.marketing{background:var(--cielo-50)}
.marketing__grid{display:grid;grid-template-columns:1fr 1.02fr;gap:clamp(36px,5vw,80px);align-items:center}
/* Título reducido específicamente: el .type-title por defecto rompe en 6 líneas dentro de esta columna */
.marketing__copy .type-title{
  margin-bottom:.35em;
  font-size:clamp(34px, 4.6vw, 76px);
  line-height:1.02;
  max-width:none;
}
.marketing__copy p{color:color-mix(in srgb,var(--marina) 84%, transparent);max-width:46ch}
.marketing__copy p+p{margin-top:1.15em}

/* Informe quincenal */
.report{
  background:var(--sal);border-radius:18px;padding:clamp(24px,3vw,38px);
  box-shadow:0 40px 80px -38px rgba(14,31,61,.5);border:1px solid rgba(14,31,61,.07);
  position:relative;
}
.report__head{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:18px;border-bottom:2px solid var(--marina);margin-bottom:20px}
.report__head img{height:22px;width:auto}
.report__head .rh-meta{text-align:right;font-size:12.5px;color:color-mix(in srgb,var(--marina) 64%, transparent);line-height:1.5}
.report__sec{margin-bottom:18px}
.report__sec h4{font-family:var(--font-display);font-weight:500;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--brasa);margin-bottom:9px}
.r-row{display:flex;justify-content:space-between;align-items:baseline;padding:7px 0;border-bottom:1px solid rgba(14,31,61,.09)}
.r-row .rl{font-size:14.5px;color:color-mix(in srgb,var(--marina) 82%, transparent)}
.r-row .rv{font-family:var(--font-display);font-weight:700;font-size:21px;letter-spacing:-.02em}
.r-actions{font-size:14px;color:color-mix(in srgb,var(--marina) 84%, transparent);line-height:1.65}
.r-actions .next{color:var(--marina);font-family:var(--font-display);font-weight:600}
.report__foot{
  margin-top:20px;background:var(--cielo);border-radius:12px;
  padding:13px 18px;display:flex;align-items:center;justify-content:space-between;
}
.report__foot .ff{font-family:var(--font-display);font-weight:600;color:var(--marina)}
.report__foot .badge{
  background:var(--sol);color:var(--marina);padding:5px 11px;border-radius:999px;
  font-family:var(--font-display);font-weight:600;font-size:13px;white-space:nowrap;
}

/* ============================================================
   Marta y Barrel — Sección 5
   ============================================================ */
.marta{background:var(--sal)}
.marta__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(36px,5vw,84px);align-items:center}
.marta .photo-frame{aspect-ratio:4/5;border-radius:26px}
.marta__copy .type-title{font-size:clamp(33px,4.3vw,62px);line-height:1.02;margin-bottom:.45em;max-width:15ch}
.marta__copy p{color:color-mix(in srgb,var(--marina) 86%, transparent);max-width:52ch}
.marta__copy p+p{margin-top:1.05em}
.marta__copy .sign{margin-top:1.6em}
.marta__cta{margin-top:2.2em;display:inline-block}

/* ============================================================
   Cómo funciona — Sección 6 (Marina dark)
   ============================================================ */
.como{background:var(--marina);color:var(--sal);position:relative;overflow:hidden}
.como .type-title,.como .type-subtitle{color:var(--sal)}
.como__intro{margin-bottom:clamp(56px,8vh,96px);max-width:760px;margin-inline:auto;text-align:center}
.como__intro .type-title{margin-bottom:.3em;max-width:16ch;margin-inline:auto;line-height:1.0}
.como__intro p{color:color-mix(in srgb,var(--sal) 80%, transparent)}
.como__heads{display:grid;grid-template-columns:1fr 56px 1fr;gap:0;max-width:980px;margin-inline:auto;margin-bottom:14px}
.como__heads .h{font-family:var(--font-display);font-weight:600;letter-spacing:.12em;text-transform:uppercase;font-size:14px}
.como__heads .h.you{color:var(--sol)}
.como__heads .h.barrel{color:var(--cielo);text-align:left}

/* Timeline */
.timeline{position:relative;max-width:980px;margin-inline:auto}
.tl-line{position:absolute;top:0;bottom:0;left:50%;width:2px;background:color-mix(in srgb,var(--cielo) 36%, transparent);transform:translateX(-50%)}
.tl-row{
  display:grid;grid-template-columns:1fr 56px 1fr;align-items:start;gap:0;
  padding-block:clamp(18px,3vh,30px);position:relative;
}
.tl-you{text-align:right;padding-right:8px}
.tl-barrel{text-align:left;padding-left:8px;color:color-mix(in srgb,var(--sal) 82%, transparent)}
.tl-node{grid-column:2;display:flex;justify-content:center;align-items:flex-start;position:relative}
.tl-dot{
  width:52px;height:52px;border-radius:50%;
  background:var(--marina-700);border:2px solid var(--cielo);
  display:flex;align-items:center;justify-content:center;color:var(--cielo);
  position:relative;z-index:2;
}
.tl-dot.you{background:var(--sol);border-color:var(--sol);color:var(--marina)}
.tl-dot.small{width:14px;height:14px;border-width:0;background:color-mix(in srgb,var(--cielo) 50%, transparent)}
.tl-step{font-family:var(--font-display);font-weight:500;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--sol);margin-bottom:5px}
.tl-you .tl-h{font-family:var(--font-display);font-weight:700;font-size:clamp(18px,1.7vw,24px);letter-spacing:-.02em;color:var(--sal);line-height:1.15}
.tl-barrel .tl-bh{font-family:var(--font-display);font-weight:600;font-size:clamp(15px,1.3vw,18px);letter-spacing:-.01em;color:var(--cielo);margin-bottom:3px}
.tl-barrel p{font-size:14.5px;line-height:1.5}
.tl-barrel .phase{font-family:var(--font-display);font-weight:600;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--sol);display:block;margin-bottom:4px}
.tl-barrel-item+.tl-barrel-item{margin-top:18px}

/* Highlight */
.tl-row.highlight{padding-block:clamp(26px,4vh,44px)}
.tl-finish{grid-column:1 / -1;text-align:center;display:flex;justify-content:center}
.tl-finish .badge{
  background:var(--sol);color:var(--marina);border-radius:999px;
  padding:16px 34px;font-family:var(--font-display);font-weight:700;
  font-size:clamp(19px,2.2vw,30px);letter-spacing:-.02em;
  display:inline-flex;align-items:center;gap:14px;
  box-shadow:0 24px 50px -20px rgba(241,179,60,.6);
  position:relative;z-index:3;
}
.tl-finish .badge .spark{font-size:.8em}

/* Final */
.tl-end{grid-column:1/-1;text-align:center}
.tl-end .home-node{
  width:84px;height:84px;border-radius:50%;background:var(--sol);color:var(--marina);
  display:flex;align-items:center;justify-content:center;margin:0 auto;
  box-shadow:0 24px 50px -20px rgba(241,179,60,.6);
  position:relative;z-index:3;
}
.tl-coda{text-align:center;margin-top:28px}
.tl-coda .type-subtitle{margin-bottom:.6em}
.tl-coda .closing{
  color:color-mix(in srgb,var(--sal) 80%, transparent);
  font-family:var(--font-serif);font-style:italic;
  font-size:clamp(19px,2vw,26px);line-height:1.5;
}

/* ============================================================
   Cierre + CTA — Sección 7
   ============================================================ */
.cierre{background:var(--cielo);text-align:center;position:relative;overflow:hidden}
.cierre__sun{
  position:absolute;width:min(70vw,720px);aspect-ratio:1;border-radius:50%;
  left:50%;top:115%;transform:translate(-50%,-50%);
  background:radial-gradient(circle,color-mix(in srgb,var(--sol) 70%, transparent),transparent 64%);
  pointer-events:none;
}
.cierre .type-display{font-size:clamp(42px,6.4vw,96px);line-height:.98;max-width:18ch;margin-inline:auto;margin-bottom:.55em;position:relative;z-index:2}
.cierre .type-lede{max-width:34ch;margin-inline:auto;margin-bottom:1.8em;color:color-mix(in srgb,var(--marina) 84%, transparent);position:relative;z-index:2}
.cierre .btn-cta{position:relative;z-index:2;font-size:clamp(18px,1.5vw,23px);padding:1.15em 2.1em}

/* ============================================================
   Footer
   ============================================================ */
.footer{
  background:var(--roca);color:color-mix(in srgb,var(--sal) 70%, transparent);
  padding-block:clamp(56px,7vh,88px);
}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:48px}
.footer__logo{height:30px;width:auto;margin-bottom:16px}
.footer__tag{
  font-family:var(--font-serif);font-style:italic;font-size:20px;
  color:color-mix(in srgb,var(--sal) 82%, transparent);max-width:24ch;
}
.footer h5{font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--sol);margin-bottom:16px}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.footer ul a{font-size:15px;opacity:.82;transition:opacity .2s}
.footer ul a:hover{opacity:1;color:var(--sal)}
.footer__social{display:flex;gap:12px;margin-top:6px}
.footer__social a{
  width:38px;height:38px;border-radius:50%;
  border:1px solid color-mix(in srgb,var(--sal) 24%, transparent);
  display:flex;align-items:center;justify-content:center;
  color:color-mix(in srgb,var(--sal) 80%, transparent);
  transition:.25s;
}
.footer__social a:hover{background:var(--sol);color:var(--marina);border-color:var(--sol)}
.footer__bottom{
  border-top:1px solid color-mix(in srgb,var(--sal) 14%, transparent);
  padding-top:24px;display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:14px;
}
.footer__legal{display:flex;gap:20px;flex-wrap:wrap}
.footer__legal a{font-size:13px;opacity:.66;transition:opacity .2s}
.footer__legal a:hover{opacity:1}
.footer__copy{font-size:13px;opacity:.55}

/* ============================================================
   Scroll reveal — estado base visible, oculto solo con html.anim.
   ============================================================ */
.reveal{opacity:1;transform:none}
html.anim .reveal{
  opacity:0;transform:translateY(26px);
  transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1);
}
html.anim .reveal.in{opacity:1;transform:none}
html.anim .reveal[data-d="1"]{transition-delay:.08s}
html.anim .reveal[data-d="2"]{transition-delay:.16s}
html.anim .reveal[data-d="3"]{transition-delay:.24s}
html.anim .reveal[data-d="4"]{transition-delay:.32s}

@media print{html.anim .reveal{opacity:1 !important;transform:none !important;transition:none !important}}
@media(prefers-reduced-motion:reduce){
  html.anim .reveal{opacity:1 !important;transform:none !important;transition:none !important}
  html{scroll-behavior:auto}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

/* --- Tablet / large mobile (≤980px) ----------------------- */
@media (max-width:980px){
  .hero__grid{grid-template-columns:1fr;gap:40px}
  .hero__photo{display:none}
  /* La figura pasa a flow normal bajo el texto */
  .hero__figure{
    position:relative;right:auto;top:auto;
    width:min(90%,460px);margin:0 auto -40px;
    pointer-events:auto;
  }
  .hero__badge{right:0;bottom:30%}

  .block,.embudo,.marketing__grid,.marta__grid,.espejo__panel{
    grid-template-columns:1fr;gap:36px;
  }
  .block--reverse .block__visual,.block--reverse .block__copy{order:initial}
  .block__copy{order:0}
  .block__visual{order:1}
  .marta__grid .marta__photo{max-width:380px;margin-inline:auto;width:100%}
  .footer__grid{grid-template-columns:1fr 1fr}
}

/* --- Nav burger (≤760px) ---------------------------------- */
@media (max-width:760px){
  .nav__links{display:none}
  .nav__burger{display:flex}
  .m-drawer{display:flex}
}

/* --- Phone (≤680px) --------------------------------------- */
@media (max-width:680px){
  .como__heads{display:none}
  /* Timeline → carril único a la izquierda */
  .timeline{padding-left:4px}
  .tl-line{left:21px;transform:none;bottom:70px}
  .tl-row{grid-template-columns:44px 1fr;column-gap:16px;row-gap:4px;padding-block:18px}
  .tl-node{grid-column:1;grid-row:1;justify-content:flex-start}
  .tl-you{grid-column:2;grid-row:1;text-align:left;padding:0;align-self:center}
  .tl-barrel{grid-column:2;grid-row:2;padding:0}
  .tl-row.highlight .tl-finish{grid-column:1 / -1;justify-content:flex-start}
  .tl-finish .badge{font-size:clamp(17px,4.6vw,22px);padding:13px 22px}
  .tl-dot{width:42px;height:42px}
  .tl-dot.small{width:12px;height:12px;margin-left:15px}
  .tl-end{text-align:left}
  .tl-end .home-node{margin:0;margin-left:-1px}
  .tl-coda{text-align:left;margin-top:22px}
  .tl-coda .closing{font-size:19px}

  .footer__grid{grid-template-columns:1fr}
  .footer__bottom{flex-direction:column;align-items:flex-start;gap:18px}

  /* Embudo: pasos en columna estrechada */
  .funnel-steps{flex-direction:column;align-items:center;gap:0;max-width:340px}
  .funnel-steps .fstep{
    flex-direction:row;align-items:center;text-align:left;gap:14px;width:100%;
    background:#fff;border:1px solid rgba(14,31,61,.08);border-radius:18px;
    padding:16px 20px 16px 16px;box-shadow:0 18px 40px -28px rgba(14,31,61,.5);
  }
  .funnel-steps .fstep:nth-child(3){width:88%}
  .funnel-steps .fstep:nth-child(5){width:76%}
  .funnel-steps .fstep__icon{flex:0 0 auto;width:50px;height:50px;border-radius:14px}
  .funnel-steps .fstep__txt{max-width:none;font-size:16px;font-weight:600;line-height:1.3;flex:1}
  .funnel-steps .fstep:last-of-type{background:var(--marina);border-color:var(--marina)}
  .funnel-steps .fstep:last-of-type .fstep__icon{background:var(--sol);color:var(--marina)}
  .funnel-steps .fstep:last-of-type .fstep__txt{color:var(--sal)}
  .funnel-steps .fsep{transform:none;margin:0;color:color-mix(in srgb,var(--marina) 40%, transparent);padding:7px 0}
  .funnel-steps .fsep svg{display:block;transform:rotate(90deg);width:18px;height:18px}

  .contrast{grid-template-columns:1fr 1fr;gap:12px}
}

/* --- Small mobile (≤480px) — valores específicos de teléfono real - */
@media (max-width:480px){
  :root{--gutter:22px}

  .hero{padding-top:100px}
  .hero__grid{gap:4px}
  .hero__eyebrow{white-space:normal;margin-bottom:.5em}
  .hero__title{font-size:62px !important;line-height:.9}
  .hero__sub{font-size:34px !important;line-height:1.02;margin-bottom:.55em}
  .hero__desc{font-size:16.5px;max-width:none;margin-bottom:1.6em}
  .hero .btn-cta{width:100%;justify-content:center}
  .hero__figure{width:114%;max-width:none;margin:-32px -7% -100px;position:relative;right:auto;top:auto}
  .hero__badge{right:14%;bottom:42%;font-size:14px;padding:.6em 1em}
  .hero__wave{height:clamp(60px,16vw,90px)}

  .espejo__panel{gap:22px;border-radius:24px;padding:32px 26px}
  .espejo__panel .type-title{font-size:38px !important;line-height:1.05;max-width:none}
  .espejo__text p{font-size:16px;max-width:none}

  .rejilla{padding-top:54px}
  .rejilla__intro{margin-bottom:14px}
  .rejilla__intro .type-title{font-size:40px}
  .block{gap:22px;padding-block:34px}
  .block__copy .type-subtitle{font-size:30px}
  .block__copy p{max-width:none}
  .invest-stack{max-width:none}

  .embudo{gap:34px;margin-top:54px}
  .embudo__copy p{max-width:none}
  .funnel-visual{gap:30px}
  .phone{width:230px}

  .marketing__grid{gap:30px}
  .marketing__copy .type-title{font-size:40px}
  .marketing__copy p{max-width:none}
  .report{padding:24px}

  .marta__grid{gap:26px}
  .marta__photo{max-width:300px;margin-inline:auto;width:100%}
  .marta .photo-frame{aspect-ratio:4/4.4;border-radius:22px}
  .marta__copy .type-title{font-size:38px !important;max-width:none}
  .marta__copy p{max-width:none}

  .como__intro .type-title{font-size:40px}

  .cierre .type-display{font-size:50px;max-width:none}
  .cierre .type-lede{max-width:none}
  .cierre .btn-cta{width:100%;justify-content:center}
}

/* --- Hero eyebrow envuelve en pantallas estrechas --------- */
@media (max-width:560px){
  .hero__eyebrow{white-space:normal}
}

/* ============================================================
   QUIÉN ES BARREL — Página /quien-es-barrel
   Capa sobre el sistema base · misma paleta/tipografía
   ============================================================ */
.qpage{background:var(--sal)}

/* La página no tiene hero translúcido — nav siempre con fondo */
.qpage .nav{
  background:color-mix(in srgb,var(--sal) 86%, transparent);
  backdrop-filter:blur(14px) saturate(1.1);
  -webkit-backdrop-filter:blur(14px) saturate(1.1);
  box-shadow:0 1px 0 rgba(14,31,61,.06);
}

/* Espacio para la nav fija */
.qpage main{padding-top:clamp(96px,12vh,132px)}

/* ---- Bloque genérico de dos columnas ---- */
.qblock{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,96px);align-items:center;
  padding-block:clamp(56px,9vh,128px);
}
.qblock--reverse .qblock__media{order:2}
.qblock--reverse .qblock__copy{order:1}
/* Título reducido: el .type-title por defecto domina demasiado dentro de la columna */
.qblock__copy .type-title{
  margin-bottom:.7em;
  font-size:clamp(34px, 4.6vw, 72px);
  line-height:1.02;
  max-width:none;
}
.qblock__copy .stack-lg>p{max-width:46ch;color:color-mix(in srgb,var(--marina) 84%, transparent)}
.stack-lg>*+*{margin-top:1.3em}

/* Intro: párrafos con un punto de aire (menos vertical que antes) */
.qintro__copy .type-body{font-size:clamp(16.5px,1.2vw,19px);line-height:1.6}

/* ---- Marco de foto (component reutilizable) ---- */
.qphoto{
  position:relative;border-radius:26px;overflow:hidden;
  box-shadow:0 40px 84px -42px rgba(14,31,61,.5);
}
.qphoto img.real{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.qphoto__label{
  position:absolute;left:16px;top:16px;z-index:3;white-space:nowrap;
  background:color-mix(in srgb,var(--sal) 92%, transparent);color:var(--marina);
  padding:7px 12px;border-radius:999px;display:inline-flex;gap:7px;align-items:center;
}
.qphoto__label .dot{
  width:7px;height:7px;border-radius:50%;background:var(--brasa);
  animation:pulse 2.4s infinite;
}
.qphoto__hint{
  position:absolute;right:16px;bottom:16px;z-index:3;
  color:color-mix(in srgb,var(--marina) 52%, transparent);
}

/* Intro: foto vertical de Marta al atardecer */
.qphoto--intro{aspect-ratio:4/5.3;
  background:
    radial-gradient(130% 100% at 78% 12%, color-mix(in srgb,var(--sol) 34%, transparent), transparent 58%),
    linear-gradient(158deg, var(--cielo-200), color-mix(in srgb,var(--marina) 12%, var(--cielo)));
}

/* ---- Bloque 2 · Qué es Barrel (texto centrado) ---- */
.qname-solo{padding-block:clamp(16px,2.5vh,38px)}
.qname-solo .narrow{margin-inline:auto}
.qname-solo .type-subtitle{max-width:20ch;margin-inline:auto;margin-bottom:.3em}
.qname-solo__text{display:flex;flex-direction:column;align-items:center}
.qname-solo__text p{max-width:60ch;color:color-mix(in srgb,var(--marina) 84%, transparent)}

/* ---- Bloque 3 · El nombre · reutiliza .espejo, leve ajuste de padding ---- */
.qname-panel{padding-block:clamp(40px,6vh,80px)}

/* ---- Bloque 4 · Las personas ---- */
.qpeople{padding-block:clamp(56px,9vh,128px)}
.qpeople__head{margin-bottom:clamp(36px,5vh,64px);max-width:none}
.qpeople__head .type-subtitle{max-width:12ch}
.qpeople__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,60px);align-items:start}
.person__name{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(26px,2.4vw,38px);letter-spacing:-.03em;
  color:var(--marina);margin-bottom:14px;
}
.person__photo{
  aspect-ratio:1;border-radius:22px;overflow:hidden;position:relative;
  box-shadow:0 34px 70px -40px rgba(14,31,61,.5);
  display:flex;align-items:flex-end;justify-content:center;margin-bottom:22px;
}
.person__photo img.real{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.person--marta .person__photo{
  background:
    radial-gradient(120% 90% at 74% 8%, color-mix(in srgb,var(--sol) 34%, transparent), transparent 56%),
    linear-gradient(158deg, var(--cielo-200), color-mix(in srgb,var(--marina) 14%, var(--cielo)));
}
.person--guille .person__photo{
  background:
    radial-gradient(120% 90% at 26% 8%, color-mix(in srgb,var(--cielo) 50%, transparent), transparent 56%),
    linear-gradient(158deg, color-mix(in srgb,var(--marina) 22%, var(--cielo)), var(--cielo-700));
}
.person__lead{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(17px,1.4vw,21px);line-height:1.4;letter-spacing:-.01em;
  color:var(--marina);margin-bottom:.8em;
}
.person__note{
  margin-top:1em;
  font-family:var(--font-serif);font-style:italic;
  font-size:clamp(18px,1.5vw,22px);color:var(--marina);
}

/* ---- Bloque 5 · El plan ---- */
.qphoto--pareja{aspect-ratio:4/3.6;
  background:
    radial-gradient(120% 90% at 28% 14%, color-mix(in srgb,var(--sol) 30%, transparent), transparent 56%),
    radial-gradient(120% 90% at 100% 100%, color-mix(in srgb,var(--brasa) 30%, transparent), transparent 58%),
    linear-gradient(158deg, var(--cielo-200), color-mix(in srgb,var(--marina) 16%, var(--cielo)));
  display:flex;align-items:flex-end;justify-content:center;
}
.qphoto--pareja .scene{
  width:72%;height:78%;align-self:flex-end;
  color:color-mix(in srgb,var(--marina) 24%, transparent);
}
.qplan__copy .type-subtitle{margin-bottom:1.2em;max-width:15ch}
.proyecto{
  font-family:var(--font-display);font-weight:800;
  color:var(--brasa);font-size:1.04em;letter-spacing:-.01em;
}

/* ---- Bloque 6 · Cierre Quién es Barrel ---- */
.qclose{
  text-align:center;position:relative;overflow:hidden;
  padding-block:clamp(96px,15vh,180px);
}
.qclose__sun{
  position:absolute;width:min(64vw,640px);aspect-ratio:1;border-radius:50%;
  left:50%;top:128%;transform:translate(-50%,-50%);
  background:radial-gradient(circle,color-mix(in srgb,var(--sol) 50%, transparent),transparent 64%);
  pointer-events:none;
}
.qclose .type-display{
  font-size:clamp(42px,6.2vw,92px);max-width:16ch;margin-inline:auto;margin-bottom:.4em;
  position:relative;z-index:2;
}
.qclose .type-lede{
  max-width:34ch;margin-inline:auto;margin-bottom:1.8em;
  color:color-mix(in srgb,var(--marina) 84%, transparent);
  position:relative;z-index:2;
}
.qclose .btn-cta{
  position:relative;z-index:2;
  font-size:clamp(18px,1.5vw,23px);padding:1.15em 2.1em;
}

/* ---- Responsive Quién es Barrel ---- */
@media (max-width:980px){
  .qblock{grid-template-columns:1fr;gap:30px}
  .qblock--reverse .qblock__media,.qblock--reverse .qblock__copy{order:initial}
  .qblock__copy{order:0}
  .qblock__media{order:1;max-width:440px;margin-inline:auto;width:100%}
  .qblock__copy .type-title{max-width:none}
  .qblock__copy .stack-lg>p{max-width:none}
  .qplan__copy .type-subtitle{max-width:none}
  .qpeople__grid{grid-template-columns:1fr;gap:44px;max-width:440px;margin-inline:auto}
}

@media (max-width:480px){
  .qblock{gap:26px;padding-block:46px}
  .qblock__copy .type-title{font-size:42px !important;line-height:1.02}
  .qblock__copy .type-subtitle{font-size:34px}
  .qintro .qphoto--intro{aspect-ratio:4/4.6}
  .qname-solo{padding-block:18px}
  .qname-solo .type-subtitle{font-size:46px !important;max-width:none}
  .qname-solo__text p{max-width:none}
  .qname-panel .espejo__panel .type-title{font-size:44px !important;line-height:1.04;max-width:none}
  .qname-panel .espejo__text p{max-width:none;font-size:16px}
  .qpeople{padding-block:46px}
  .qpeople__head .type-subtitle{font-size:40px !important;max-width:none}
  .qpeople__grid{gap:42px}
  .person__photo{margin-inline:auto;max-width:340px;width:100%}
  .qclose{padding-block:clamp(64px,15vw,110px)}
  .qclose .type-display{font-size:46px;max-width:none;line-height:1.06;margin-bottom:1em}
  .qclose .type-lede{max-width:none}
  .qclose .btn-cta{width:100%;justify-content:center}
}

/* ============================================================
   LANDING DE CAPTACIÓN — /vender-mi-casa
   Conversión pura · sin nav · sin enlaces de fuga
   ============================================================ */
.lp{background:var(--sal)}

/* ---- Contenedor de bloque ---- */
.lp-block{padding-block:clamp(34px,5vh,64px)}
.lp-block .container{max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.lp-narrow{max-width:820px;margin-inline:auto}
.lp-block .block{padding-block:clamp(20px,2.6vh,40px)}

/* ============================================================
   ZONA HERO — Cielo · bloques 1-4 unificados
   ============================================================ */
.lp-hero{
  background:
    radial-gradient(120% 80% at 84% -6%, color-mix(in srgb,var(--sol) 26%, transparent), transparent 52%),
    var(--cielo);
  position:relative;overflow:hidden;
  padding-bottom:clamp(56px,8vh,96px);
}
.lp-header{
  display:flex;justify-content:center;align-items:center;
  padding:20px var(--gutter) 0;position:relative;z-index:2;
}
.lp-header img{height:38px;width:auto}
.lp-hero__inner{
  position:relative;z-index:2;text-align:center;
  padding-top:clamp(14px,2.4vh,26px);
  display:flex;flex-direction:column;align-items:center;
}
.lp-hero__wave{
  position:absolute;left:0;right:0;bottom:-1px;
  width:100%;height:clamp(44px,5vw,70px);display:block;
  color:var(--sal);z-index:1;
}

/* Bloque 1 · pre-titular */
.lp-pretitle{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(12px,1vw,14px);line-height:1.35;letter-spacing:.04em;
  text-transform:uppercase;
  color:color-mix(in srgb,var(--marina) 58%, transparent);
  max-width:none;margin-inline:auto;
  margin-bottom:clamp(10px,1.4vh,16px);
}
.lp-pretitle .accent{
  text-transform:none;color:var(--brasa);
  font-size:1.15em;letter-spacing:-.01em;font-weight:400;
}

/* Bloque 2 · headline + subhead */
.lp-headline__h{
  font-size:clamp(30px,3.4vw,50px);line-height:1.08;
  max-width:30ch;margin-inline:auto;margin-bottom:.45em;
}
.lp-headline__h .accent{color:var(--marina)}
.lp-headline__h .hl{
  padding:.02em .2em;border-radius:.12em;
  box-decoration-break:clone;-webkit-box-decoration-break:clone;
}
.lp-sub{
  font-family:var(--font-display);font-weight:400;
  font-size:clamp(18px,1.9vw,25px);line-height:1.3;letter-spacing:-.015em;
  color:color-mix(in srgb,var(--marina) 76%, transparent);
  max-width:32ch;margin-inline:auto;
  margin-bottom:clamp(26px,3.6vh,42px);margin-top:0;
}

/* Bloque 3 · VSL (placeholder visual) */
.vsl-frame{
  position:relative;width:100%;max-width:760px;margin-inline:auto;
  aspect-ratio:16/9;border-radius:22px;overflow:hidden;
  background:linear-gradient(158deg, var(--marina-700), var(--marina));
  box-shadow:0 40px 80px -38px rgba(14,31,61,.6);
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  margin-bottom:clamp(24px,3.4vh,40px);
}
.vsl-frame::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(60% 50% at 50% 42%, color-mix(in srgb,var(--sol) 18%, transparent), transparent 70%);
  pointer-events:none;
}
.vsl-play{
  position:relative;z-index:2;
  width:clamp(68px,7vw,88px);height:clamp(68px,7vw,88px);
  border-radius:50%;background:var(--sol);color:var(--marina);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 18px 40px -14px rgba(241,179,60,.8);
  transition:transform .25s;
}
.vsl-frame:hover .vsl-play,.vsl-frame:focus-visible .vsl-play{transform:scale(1.07)}
.vsl-play svg{margin-left:5px}
.vsl-label{
  position:absolute;z-index:2;left:0;right:0;bottom:20px;text-align:center;
  color:color-mix(in srgb,var(--sal) 82%, transparent);
}
.vsl-tag{
  position:absolute;z-index:2;top:16px;left:16px;
  background:color-mix(in srgb,var(--marina) 60%, transparent);color:var(--sal);
  padding:6px 12px;border-radius:999px;
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
}

/* CTA blocks repetidos */
.lp-cta{text-align:center;padding-top:clamp(8px,1.2vh,16px);padding-bottom:clamp(30px,4.2vh,54px)}
.lp-method{padding-bottom:clamp(8px,1.2vh,16px)}
.lp-cta__pre{margin-bottom:1.5em}
.lp-cta__pre .l1{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(22px,2.6vw,34px);letter-spacing:-.025em;
  color:var(--marina);line-height:1.1;
}
.lp-cta__pre .l2{
  font-family:var(--font-body);font-size:clamp(16px,1.3vw,19px);
  color:color-mix(in srgb,var(--marina) 70%, transparent);margin-top:.4em;
}
.lp-cta .btn-cta{font-size:clamp(17px,1.4vw,21px)}

/* Bloque 5 · Qué es Barrel */
.lp-quees{padding-top:clamp(40px,6vh,72px)}
.lp-quees__head{text-align:center;margin-bottom:clamp(30px,4.4vh,56px)}
.lp-quees__head .type-mono{color:var(--brasa);display:inline-block;margin-bottom:1em}
.lp-quees__head .type-title{margin-inline:auto;max-width:14ch}
.lp-quees__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,5vw,72px);align-items:center}
.lp-quees__text p{max-width:48ch;color:color-mix(in srgb,var(--marina) 84%, transparent)}
.lp-quees__text p+p{margin-top:1em}
.lp-quees__text p .accent{color:var(--brasa)}
.lp-online{
  background:var(--sol);font-weight:600;padding:.05em .3em;border-radius:.18em;
  box-decoration-break:clone;-webkit-box-decoration-break:clone;
}

/* Mockup Marta integrada */
.lp-marta{
  position:relative;aspect-ratio:4/4.2;border-radius:26px;overflow:hidden;
  background:
    radial-gradient(78% 62% at 50% 16%, color-mix(in srgb,var(--sol) 34%, transparent), transparent 60%),
    linear-gradient(158deg, var(--cielo-200), color-mix(in srgb,var(--marina) 14%, var(--cielo)));
  box-shadow:0 40px 84px -44px rgba(14,31,61,.5);
}
.lp-marta__fig{
  position:absolute;top:7%;left:50%;transform:translateX(-50%);
  width:97%;height:auto;display:block;
  filter:drop-shadow(0 26px 40px rgba(14,31,61,.22));
}
.lp-marta__badge{
  position:absolute;bottom:24px;left:20px;z-index:2;
  background:var(--sol);color:var(--marina);
  font-family:var(--font-display);font-weight:700;letter-spacing:-.01em;
  font-size:clamp(13px,1.1vw,16px);padding:.6em 1em;border-radius:999px;
  box-shadow:0 12px 26px -12px rgba(241,179,60,.9);
}

/* Bloque 6 · Rejilla método */
.lp-method__intro{text-align:center;max-width:860px;margin-inline:auto;margin-bottom:clamp(20px,3vh,40px)}
.lp-method__intro .type-mono{color:var(--brasa);display:inline-block;margin-bottom:1em}
.lp-method__intro .type-title{margin-bottom:.55em;max-width:16ch;margin-inline:auto}
.lp-method__intro .lp-introtext{display:flex;flex-direction:column;align-items:center;gap:.8em}
.lp-method__intro .lp-introtext p{max-width:56ch;color:color-mix(in srgb,var(--marina) 84%, transparent)}

/* Bloque 8 · Marketing visible (fondo Cielo-50) */
.lp-marketing{background:var(--cielo-50)}

/* Bloque 10 · Tabla contra-narrativa */
.lp-tabla__title{
  text-align:center;max-width:18ch;margin-inline:auto;
  margin-bottom:clamp(32px,4.5vh,56px);line-height:1.04;
}
.lp-tabla__title .hl{padding:.02em .2em;border-radius:.12em;box-decoration-break:clone;-webkit-box-decoration-break:clone}
.cmp{
  max-width:980px;margin-inline:auto;
  border-radius:22px;overflow:hidden;border:1px solid rgba(14,31,61,.1);
  box-shadow:0 30px 70px -40px rgba(14,31,61,.4);
}
.cmp__head,.cmp__row{display:grid;grid-template-columns:1.1fr 1.5fr 1.5fr}
.cmp__head{background:var(--marina);color:var(--sal)}
.cmp__head>div{
  padding:18px 22px;
  font-family:var(--font-display);font-weight:600;letter-spacing:-.01em;
  font-size:clamp(14px,1.2vw,17px);
}
.cmp__head .h-trad{color:color-mix(in srgb,var(--sal) 64%, transparent)}
.cmp__head .h-barrel{color:var(--sol)}
.cmp__row{background:var(--sal);border-top:1px solid rgba(14,31,61,.09)}
.cmp__row:nth-child(even){background:color-mix(in srgb,var(--cielo) 12%, var(--sal))}
.cmp__row>div{padding:18px 22px;display:flex;align-items:center}
.cmp__label{
  font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;
  color:var(--marina);font-size:clamp(15px,1.3vw,18px);
}
.cmp__trad{
  color:color-mix(in srgb,var(--marina) 55%, transparent);
  font-size:15px;line-height:1.45;
  border-left:1px solid rgba(14,31,61,.09);border-right:1px solid rgba(14,31,61,.09);
}
.cmp__barrel{color:var(--marina);font-weight:500;font-size:15.5px;line-height:1.45}
.cmp__row--final .cmp__barrel{
  background:var(--sol);font-family:var(--font-serif);font-style:italic;font-weight:400;
  font-size:clamp(18px,1.7vw,23px);color:var(--marina);
}
.cmp__cards{display:none}

/* Bloque 11 · Objeción */
.lp-block.lp-objecion,.lp-block.lp-declar{padding-block:clamp(26px,3.4vh,46px)}
.lp-objecion .lp-narrow{max-width:760px}
.lp-objecion__q{
  font-family:var(--font-serif);font-style:italic;
  font-size:clamp(26px,3.4vw,46px);line-height:1.18;letter-spacing:-.02em;
  color:var(--marina);margin-bottom:.9em;
  position:relative;padding-left:.7em;
}
.lp-objecion__q::before{
  content:"\201C";position:absolute;left:-.12em;top:-.04em;
  color:var(--sol);font-size:1.5em;line-height:1;
}
.lp-objecion__a{display:flex;flex-direction:column;gap:1.1em}
.lp-objecion__a p{max-width:60ch;color:color-mix(in srgb,var(--marina) 84%, transparent)}

/* Bloque 12 · Sistema único (texto declarativo centrado) */
.lp-declar{text-align:center}
.lp-declar .type-mono{color:var(--brasa);display:inline-block;margin-bottom:1em}
.lp-declar .lp-narrow>.type-subtitle,.lp-declar .lp-narrow>.type-title{
  margin-inline:auto;margin-bottom:.65em;
}
.lp-declar .lp-stack{display:flex;flex-direction:column;align-items:center;gap:1em}
.lp-declar .lp-stack p{max-width:60ch;color:color-mix(in srgb,var(--marina) 84%, transparent)}
.lp-declar .lp-stack p .accent{color:var(--brasa)}

/* Bloque 14 · Lo que NO va a pasar */
.lp-no{background:var(--cielo-50)}
.lp-no__head{text-align:center;margin-bottom:clamp(34px,5vh,58px)}
.lp-no__head .type-mono{color:var(--brasa);display:inline-block;margin-bottom:1em}
.lp-no__title{max-width:22ch;margin-inline:auto}
.lp-no__title .no-strong{color:var(--brasa)}
.lp-nolist{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(14px,1.8vw,20px);
  max-width:960px;margin-inline:auto;
}
.lp-noitem{
  display:flex;align-items:flex-start;gap:15px;
  background:var(--sal);border:1px solid rgba(14,31,61,.07);border-radius:16px;
  padding:clamp(18px,2vw,24px);
  box-shadow:0 18px 40px -30px rgba(14,31,61,.4);
}
.lp-noitem .x{
  flex:0 0 auto;width:36px;height:36px;border-radius:50%;
  background:color-mix(in srgb,var(--brasa) 14%, transparent);
  color:var(--brasa);display:flex;align-items:center;justify-content:center;margin-top:1px;
}
.lp-noitem p{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(16px,1.35vw,19px);letter-spacing:-.015em;line-height:1.32;
  color:var(--marina);
}

/* Bloque 15+16 · Cierre */
.lp-cierre{
  text-align:center;background:var(--cielo);position:relative;overflow:hidden;
  padding-block:clamp(64px,9vh,112px);
}
.lp-cierre__sun{
  position:absolute;width:min(72vw,720px);aspect-ratio:1;border-radius:50%;
  left:50%;top:128%;transform:translate(-50%,-50%);
  background:radial-gradient(circle,color-mix(in srgb,var(--sol) 48%, transparent),transparent 64%);
  pointer-events:none;
}
.lp-cierre__big{
  font-size:clamp(32px,4.4vw,62px);line-height:1.08;
  max-width:none;margin-inline:auto;margin-bottom:.45em;
  position:relative;z-index:2;
}
.lp-cierre__big .hl{padding:.02em .22em;border-radius:.12em;box-decoration-break:clone;-webkit-box-decoration-break:clone}
.lp-cierre .lp-bajada{
  font-family:var(--font-display);font-weight:400;
  font-size:clamp(18px,2vw,26px);line-height:1.38;letter-spacing:-.015em;
  max-width:36ch;margin-inline:auto;
  color:color-mix(in srgb,var(--marina) 82%, transparent);
  position:relative;z-index:2;
}
.lp-cierre__cta{
  position:relative;z-index:2;margin-top:clamp(34px,5vh,60px);
  padding-top:clamp(30px,4.5vh,52px);
  border-top:1px solid color-mix(in srgb,var(--marina) 14%, transparent);
  max-width:640px;margin-inline:auto;
  display:flex;flex-direction:column;align-items:center;
}
.lp-cierre__small{
  font-size:clamp(23px,2.3vw,34px);line-height:1.06;
  margin-bottom:.7em;max-width:none;color:var(--marina);
}
.lp-cierre__sub{
  font-family:var(--font-body);font-size:clamp(15px,1.3vw,18px);line-height:1.55;
  max-width:40ch;margin-inline:auto;margin-bottom:1.6em;
  color:color-mix(in srgb,var(--marina) 72%, transparent);
}
.lp-cierre__cta .btn-cta{font-size:clamp(18px,1.5vw,23px);padding:1.15em 2.1em}

/* Footer mínimo */
.lp-footer{
  background:var(--sal);border-top:1px solid rgba(14,31,61,.08);
  padding:28px var(--gutter);text-align:center;
}
.lp-footer__inner{
  display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;
}
.lp-footer a,.lp-footer span{
  font-size:13px;color:color-mix(in srgb,var(--marina) 50%, transparent);
}
.lp-footer a{transition:color .2s}
.lp-footer a:hover{color:var(--marina)}

/* Responsive landing */
@media (max-width:900px){
  .lp-block .block,.lp-marketing .marketing__grid{grid-template-columns:1fr;gap:32px}
  .lp-block .block--reverse .block__visual,.lp-block .block--reverse .block__copy{order:initial}
  .lp-block .invest-stack{max-width:none}
  .lp-quees__grid{grid-template-columns:1fr;gap:36px}
  .lp-quees__visual{max-width:440px;margin-inline:auto;width:100%}
  /* Tabla → tarjetas apiladas */
  .cmp__head,.cmp{display:none}
  .cmp__cards{display:flex;flex-direction:column;gap:18px;max-width:480px;margin-inline:auto}
  .cmp-card{
    border-radius:18px;overflow:hidden;border:1px solid rgba(14,31,61,.1);
    box-shadow:0 20px 44px -30px rgba(14,31,61,.4);
  }
  .cmp-card__label{
    background:var(--marina);color:var(--sal);
    font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;
    font-size:17px;padding:13px 18px;
  }
  .cmp-card__side{padding:14px 18px}
  .cmp-card__side .tag{
    font-family:var(--font-display);font-weight:600;font-size:11px;letter-spacing:.12em;
    text-transform:uppercase;margin-bottom:5px;display:block;
  }
  .cmp-card__side.trad{background:color-mix(in srgb,#9aa3ad 16%, var(--sal))}
  .cmp-card__side.trad .tag{color:color-mix(in srgb,var(--marina) 55%, transparent)}
  .cmp-card__side.trad p{color:color-mix(in srgb,var(--marina) 60%, transparent);font-size:15px;line-height:1.45}
  .cmp-card__side.barrel{background:var(--sal)}
  .cmp-card__side.barrel .tag{color:var(--brasa)}
  .cmp-card__side.barrel p{color:var(--marina);font-weight:500;font-size:15.5px;line-height:1.45}
  .cmp-card--final .cmp-card__side.barrel{background:var(--sol)}
  .cmp-card--final .cmp-card__side.barrel p{font-family:var(--font-serif);font-style:italic;font-size:20px}

  .lp-nolist{grid-template-columns:1fr;max-width:520px}
}

@media (max-width:480px){
  .lp-headline__h{font-size:32px !important;line-height:1.1}
  .lp-headline__h br{display:none}
  .lp-sub{font-size:18px;max-width:none}
  .lp-quees__head .type-title{font-size:42px}
  .lp-method__intro .type-title{font-size:38px}
  .lp-tabla__title{font-size:34px}
  .lp-cierre__big{font-size:36px}
  .lp-cierre__small{font-size:24px}
  .lp-cta .btn-cta,.lp-cierre__cta .btn-cta{width:100%;justify-content:center}
}

/* ============================================================
   VELO "EN CONSTRUCCIÓN" — Tapa toda la web mientras montamos.
   Para retirarlo: quitar el <div class="construction-veil"> de las
   3 HTML (o ocultar con body[data-veil="off"] si queremos toggle).
   ============================================================ */
body:has(.construction-veil) > *:not(.construction-veil){
  filter:blur(7px);
  -webkit-filter:blur(7px);
  pointer-events:none;
  user-select:none;
  -webkit-user-select:none;
}
.construction-veil{
  position:fixed;inset:0;z-index:99999;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  background:color-mix(in srgb, var(--cielo) 14%, transparent);
  pointer-events:none;
  animation:veil-in .6s ease both;
}
@keyframes veil-in{
  from{opacity:0;transform:scale(.98)}
  to{opacity:1;transform:scale(1)}
}
.construction-veil__card{
  pointer-events:auto;
  background:var(--sal);
  border:1px solid color-mix(in srgb, var(--marina) 8%, transparent);
  border-radius:26px;
  padding:clamp(32px,5vw,56px) clamp(34px,6vw,68px);
  box-shadow:0 40px 110px -40px rgba(14,31,61,.55), 0 0 0 1px rgba(14,31,61,.04);
  text-align:center;
  max-width:560px;width:100%;
  display:flex;flex-direction:column;align-items:center;gap:14px;
  position:relative;overflow:hidden;
}
.construction-veil__card::after{
  content:"";position:absolute;right:-30%;top:-40%;
  width:min(80%,400px);aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle, color-mix(in srgb,var(--sol) 24%, transparent), transparent 64%);
  pointer-events:none;
}
.construction-veil__card>*{position:relative;z-index:1}
.construction-veil__eyebrow{
  font-family:var(--font-display);font-weight:500;
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--brasa);
}
.construction-veil__title{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(28px,4.2vw,46px);line-height:1.02;letter-spacing:-.03em;
  color:var(--marina);
  margin:0;
}
.construction-veil__title em{
  font-family:var(--font-serif);font-style:italic;font-weight:400;letter-spacing:-.01em;
}
/* Logo inline en el título (reemplaza la palabra "Barrel" por la marca) */
.construction-veil__brand{
  height:1em;width:auto;
  vertical-align:-.16em;
  display:inline-block;
  margin:0 .08em 0 .12em;
}
.construction-veil__period{display:inline}
.construction-veil__sub{
  font-family:var(--font-body);font-size:16px;line-height:1.55;
  color:color-mix(in srgb,var(--marina) 72%, transparent);
  max-width:38ch;margin:0;
}
.construction-veil__hint{
  margin-top:8px;
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-display);font-weight:500;font-size:13px;letter-spacing:.06em;text-transform:uppercase;
  color:color-mix(in srgb,var(--marina) 55%, transparent);
}
.construction-veil__hint .dot{
  width:8px;height:8px;border-radius:50%;background:var(--brasa);
  animation:veil-pulse 2s infinite;
}
@keyframes veil-pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.4;transform:scale(.8)}
}
@media (prefers-reduced-motion: reduce){
  .construction-veil,.construction-veil__hint .dot{animation:none}
}

/* Desactivar velo en URLs que no sean el dominio público real.
   El script en <head> añade html.no-veil para *.vercel.app, subdominios y localhost. */
html.no-veil .construction-veil{display:none !important}
html.no-veil body > *{
  filter:none !important;
  -webkit-filter:none !important;
  pointer-events:auto !important;
  user-select:auto !important;
  -webkit-user-select:auto !important;
}
