/* ============================================================
   ONCO ORAL — Dirección 1 · "AURORA INMERSIVO"
   Aurora azul viva que respira + fotografía full-bleed en duotono
   + tipografía Bricolage gigante. Premium, emotivo, humano.
   Estático puro. Progressive enhancement (.reveal visible sin JS).
   ============================================================ */

:root {
  --marino: #25335C;
  --abeto:  #2E4055;
  --jeans:  #28618B;
  --acero:  #8892AA;
  --pastel: #FFF4C9;
  --blanco: #FFFFFF;

  /* base profunda de la aurora (derivada de Marino, más oscura para legibilidad) */
  --deep:   #141d36;
  --deep-2: #0f1730;

  /* texto sobre aurora */
  --ink:      #EAF0FB;   /* texto claro principal */
  --ink-soft: #C2CCE3;   /* secundario */
  --ink-dim:  #93A0C0;   /* terciario / labels */

  --font-title: 'Bricolage Grotesque', system-ui, sans-serif;
  --font-body:  'Raleway', system-ui, sans-serif;

  --maxw: 1280px;
  --gutter: clamp(1.25rem, 5vw, 4.5rem);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--deep);
  line-height: 1.72;
  font-size: 17px;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  position: relative;
}

h1,h2,h3,h4 {
  font-family: var(--font-title);
  color: #fff;
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: -0.025em;
  margin: 0;
  text-wrap: balance;
}
p { margin: 0 0 1.15em; }
a { color: var(--pastel); text-decoration: none; }
img { max-width: 100%; display: block; }

/* ============================================================
   AURORA VIVA — fondo fijo que respira (PERCEPTIBLE)
   ============================================================ */
.aurora {
  position: fixed; inset: 0; z-index: -2;
  background:
    radial-gradient(120% 90% at 50% -10%, #2a3b66 0%, rgba(42,59,102,0) 55%),
    linear-gradient(180deg, var(--deep) 0%, var(--deep-2) 60%, #0b1228 100%);
  overflow: hidden;
}
.aurora__blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(70px);
  opacity: 0.9;
  will-change: transform;
  mix-blend-mode: screen;
}
.blob-jeans {
  width: 65vw; height: 65vw; left: -10vw; top: -8vh;
  background: radial-gradient(circle at 50% 50%, rgba(40,97,139,0.95), rgba(40,97,139,0) 68%);
  animation: drift1 26s ease-in-out infinite alternate;
}
.blob-marino {
  width: 70vw; height: 70vw; right: -18vw; top: 12vh;
  background: radial-gradient(circle at 50% 50%, rgba(60,86,150,0.9), rgba(60,86,150,0) 70%);
  animation: drift2 32s ease-in-out infinite alternate;
}
.blob-pastel {
  width: 48vw; height: 48vw; left: 20vw; bottom: -16vh;
  background: radial-gradient(circle at 50% 50%, rgba(255,244,201,0.42), rgba(255,244,201,0) 66%);
  animation: drift3 30s ease-in-out infinite alternate;
  opacity: 0.7;
}
.blob-abeto {
  width: 55vw; height: 55vw; right: 6vw; bottom: -10vh;
  background: radial-gradient(circle at 50% 50%, rgba(46,64,85,0.95), rgba(46,64,85,0) 70%);
  animation: drift4 36s ease-in-out infinite alternate;
}
/* segundo velo pastel cálido, más chico, vagando alto */
.blob-glow {
  width: 30vw; height: 30vw; right: 14vw; top: 4vh;
  background: radial-gradient(circle at 50% 50%, rgba(255,244,201,0.36), rgba(255,244,201,0) 64%);
  animation: drift5 22s ease-in-out infinite alternate;
  opacity: 0.65;
}

@keyframes drift1 { from { transform: translate3d(0,0,0) scale(1); } to { transform: translate3d(8vw,6vh,0) scale(1.18); } }
@keyframes drift2 { from { transform: translate3d(0,0,0) scale(1.05); } to { transform: translate3d(-9vw,8vh,0) scale(1.25); } }
@keyframes drift3 { from { transform: translate3d(0,0,0) scale(1); } to { transform: translate3d(10vw,-7vh,0) scale(1.3); } }
@keyframes drift4 { from { transform: translate3d(0,0,0) scale(1.1); } to { transform: translate3d(-7vw,-6vh,0) scale(1); } }
@keyframes drift5 { from { transform: translate3d(0,0,0) scale(0.9); } to { transform: translate3d(-6vw,9vh,0) scale(1.25); } }

/* grano sutil para evitar banding del gradiente */
.aurora__grain {
  position: fixed; inset: 0; z-index: -1; pointer-events: none;
  opacity: 0.05; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ============================================================
   CONTENEDORES / RITMO
   ============================================================ */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.wrap--narrow { max-width: 980px; }
.section { position: relative; padding-block: clamp(5rem, 13vw, 11rem); z-index: 1; }
.section--hero { padding-block: clamp(4rem, 9vw, 7rem); min-height: min(94vh, 920px); display: flex; align-items: center; }

/* ============================================================
   TIPOGRAFÍA
   ============================================================ */
.display {
  font-size: clamp(2.9rem, 8.5vw, 6.6rem);
  line-height: 0.98;
  letter-spacing: -0.04em;
  font-weight: 800;
}
.h-xl { font-size: clamp(2.1rem, 5.2vw, 4rem); line-height: 1.03; letter-spacing: -0.03em; }
.h-lg { font-size: clamp(1.6rem, 3.2vw, 2.5rem); }
.lead {
  font-size: clamp(1.15rem, 1.7vw, 1.45rem);
  line-height: 1.6; color: var(--ink-soft); font-weight: 400; max-width: 46ch;
}
.body-lg { font-size: 1.12rem; color: var(--ink-soft); }

/* glow pastel detrás de títulos grandes */
.glow-text { position: relative; }
.glow-text::before {
  content: ""; position: absolute; z-index: -1;
  left: -6%; top: 8%; width: 62%; height: 86%;
  background: radial-gradient(60% 60% at 30% 50%, rgba(255,244,201,0.32), rgba(255,244,201,0) 70%);
  filter: blur(28px); pointer-events: none;
}

/* eyebrow */
.eyebrow {
  display: inline-flex; align-items: center; gap: 0.7rem;
  font-family: var(--font-title); font-size: 0.82rem; font-weight: 600;
  letter-spacing: 0.26em; text-transform: uppercase; color: var(--pastel);
  margin-bottom: 1.7rem;
}
.eyebrow .num { color: var(--acero); font-variant-numeric: tabular-nums; }
.eyebrow .tick { width: 2.4rem; height: 1px; background: rgba(255,244,201,0.5); display: inline-block; }

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-header {
  position: sticky; top: 0; z-index: 60;
  transition: background .35s ease, backdrop-filter .35s ease, border-color .35s ease;
  border-bottom: 1px solid transparent;
}
.site-header.is-scrolled {
  background: rgba(15,23,48,0.62);
  backdrop-filter: saturate(160%) blur(16px);
  -webkit-backdrop-filter: saturate(160%) blur(16px);
  border-bottom-color: rgba(136,146,170,0.18);
}
.nav { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; height: 80px; }
.brand-logo { height: 40px; width: auto; }
.nav-links { display: flex; align-items: center; gap: clamp(1rem, 2.4vw, 2.3rem); }
.nav-link {
  font-family: var(--font-title); font-size: 0.95rem; font-weight: 500;
  color: var(--ink-soft); position: relative; padding: 0.3rem 0; transition: color .25s ease;
}
.nav-link:hover { color: #fff; }
.nav-link::after { content: ""; position: absolute; left: 0; bottom: -1px; width: 0; height: 1.5px; background: var(--pastel); transition: width .28s ease; }
.nav-link:hover::after { width: 100%; }

.btn {
  --bg: var(--pastel); --fg: var(--marino);
  display: inline-flex; align-items: center; justify-content: center; gap: 0.6rem;
  font-family: var(--font-title); font-weight: 600; font-size: 0.98rem;
  background: var(--bg); color: var(--fg);
  padding: 0.9rem 1.7rem; border-radius: 999px; border: 1.5px solid var(--bg);
  cursor: pointer; transition: transform .2s ease, box-shadow .3s ease, filter .25s ease;
  box-shadow: 0 14px 40px -16px rgba(255,244,201,0.55);
  white-space: nowrap;
}
.btn:hover { transform: translateY(-2px); filter: brightness(1.04); box-shadow: 0 22px 50px -16px rgba(255,244,201,0.7); }
.btn:active { transform: translateY(0); }
.btn--lg { padding: 1.1rem 2.2rem; font-size: 1.06rem; }
.btn--ghost {
  --bg: transparent; --fg: #fff;
  border-color: rgba(234,240,251,0.28); box-shadow: none;
}
.btn--ghost:hover { border-color: var(--pastel); color: var(--pastel); filter: none; box-shadow: none; }
.btn .ico { width: 1.05em; height: 1.05em; }
.nav-cta { display: inline-flex; }

.nav-toggle { display: none; background: none; border: 0; cursor: pointer; width: 46px; height: 46px; color: #fff; }
.mobile-menu {
  display: none; flex-direction: column; gap: 0.2rem;
  padding: 1rem var(--gutter) 1.6rem;
  background: rgba(15,23,48,0.92); backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(136,146,170,0.2);
}
.mobile-menu.open { display: flex; }
.mobile-menu a { font-family: var(--font-title); font-weight: 500; color: var(--ink-soft); padding: 0.7rem 0; }
.mobile-menu .btn { margin-top: 0.8rem; }

/* ============================================================
   HERO
   ============================================================ */
.hero-grid {
  display: grid; grid-template-columns: 1.08fr 0.92fr;
  gap: clamp(2rem, 5vw, 5rem); align-items: center; width: 100%;
}
.hero-eyebrow { margin-bottom: 2rem; }
.hero-title { margin-bottom: 1.8rem; color: #fff; }
.hero-title .accent { color: var(--pastel); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 1.1rem; margin-top: 2.6rem; align-items: center; }
.hero-note { font-size: 0.95rem; color: var(--ink-dim); display: inline-flex; align-items: center; gap: 0.55rem; }

.hero-figure { position: relative; }
.hero-figure .duo {
  border-radius: 28px; aspect-ratio: 1068 / 1380;
  box-shadow: 0 60px 110px -50px rgba(0,0,0,0.75);
}
.hero-figure .float-quote {
  position: absolute; left: -1.5rem; bottom: 2.2rem; z-index: 5;
  background: rgba(15,23,48,0.55); backdrop-filter: blur(14px);
  border: 1px solid rgba(255,244,201,0.25); border-radius: 18px;
  padding: 1.1rem 1.35rem; max-width: 16rem;
  box-shadow: 0 30px 60px -28px rgba(0,0,0,0.7);
  display: flex; gap: 0.85rem; align-items: flex-start;
}
.hero-figure .float-quote .fq-ico {
  flex: none; width: 2.4rem; height: 2.4rem; border-radius: 11px;
  background: var(--pastel); color: var(--marino); display: grid; place-items: center;
}
.hero-figure .float-quote .fq-ico svg { width: 1.25rem; height: 1.25rem; }
.hero-figure .float-quote p { margin: 0; font-size: 0.9rem; line-height: 1.45; color: var(--ink); }
.hero-figure .float-quote strong { font-family: var(--font-title); color: var(--pastel); font-weight: 700; }

/* ============================================================
   DUOTONO (tratamiento on-brand; Elena horneará los .webp finales)
   ============================================================ */
/* Elena horneó el duotono azul on-brand directamente en los .webp.
   No re-procesamos la imagen (nada de grayscale/multiply): solo un velo
   muy tenue para coser los bordes con la aurora del fondo. */
.duo { position: relative; overflow: hidden; isolation: isolate; background: var(--deep-2); }
.duo img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 1.4s cubic-bezier(.2,.7,.2,1);
}
.duo::after {
  content: ""; position: absolute; inset: 0; z-index: 2; pointer-events: none;
  background: linear-gradient(160deg, rgba(37,51,92,0.12), rgba(40,97,139,0.05) 55%, rgba(255,244,201,0.06));
  mix-blend-mode: soft-light;
}
.duo .duo-scrim {
  position: absolute; inset: 0; z-index: 3;
  background: linear-gradient(180deg, rgba(20,29,54,0) 45%, rgba(15,23,48,0.6) 100%);
}
.duo:hover img { transform: scale(1.05); }
.ph-tag {
  position: absolute; right: 0.8rem; bottom: 0.8rem; z-index: 6;
  font-family: var(--font-title); font-size: 0.62rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-soft); background: rgba(15,23,48,0.55); padding: 0.28rem 0.6rem; border-radius: 999px;
  border: 1px solid rgba(136,146,170,0.3); backdrop-filter: blur(4px);
}

/* ============================================================
   SECCIONES INMERSIVAS (alternancia foto / texto)
   ============================================================ */
.split { display: grid; grid-template-columns: repeat(12, 1fr); gap: clamp(2rem, 5vw, 5rem); align-items: center; }
.split .col-text { grid-column: span 6; }
.split .col-media { grid-column: span 6; }
.split.reverse .col-text { order: 2; }
.split.reverse .col-media { order: 1; }

.media-figure { position: relative; }
.media-figure .duo { border-radius: 24px; aspect-ratio: 3/2; box-shadow: 0 50px 90px -50px rgba(0,0,0,0.7); }
.media-figure .duo.tall { aspect-ratio: 4/5; }

/* lista clínica sobre aurora */
.clin-list { list-style: none; margin: 1.8rem 0 0; padding: 0; display: grid; gap: 1.15rem; }
.clin-list li { position: relative; padding-left: 2.2rem; font-size: 1.06rem; color: var(--ink-soft); line-height: 1.62; }
.clin-list li::before {
  content: ""; position: absolute; left: 0; top: 0.5em;
  width: 0.9rem; height: 0.9rem; border-radius: 50%;
  border: 2px solid var(--pastel); background: rgba(255,244,201,0.14);
  box-shadow: 0 0 14px rgba(255,244,201,0.35);
}

/* ============================================================
   SECCIÓN FULL-BLEED con foto de fondo + texto encima
   ============================================================ */
.immersive {
  position: relative; min-height: min(86vh, 760px);
  display: flex; align-items: flex-end;
  padding-block: clamp(3rem, 7vw, 6rem);
  overflow: hidden;
}
.immersive .duo { position: absolute; inset: 0; z-index: 0; border-radius: 0; }
.immersive .duo img { filter: brightness(0.72); }
.immersive .immersive-inner { position: relative; z-index: 4; }
.immersive .duo .duo-scrim {
  background: linear-gradient(110deg, rgba(15,23,48,0.86) 0%, rgba(20,29,54,0.55) 45%, rgba(20,29,54,0.15) 100%);
}

/* remate gigante (sección 2) */
.remate { display: grid; gap: 0.4rem; margin-top: 2.8rem; }
.remate .line {
  font-family: var(--font-title); font-weight: 800;
  font-size: clamp(1.9rem, 5vw, 3.6rem); line-height: 1.08;
  color: #fff; display: flex; align-items: baseline; gap: 1rem;
}
.remate .line .plus { color: var(--pastel); font-size: 0.75em; text-shadow: 0 0 24px rgba(255,244,201,0.5); }
.remate .line:nth-child(2) { color: var(--ink); }
.remate .line:nth-child(3) { color: var(--ink-soft); }

/* ============================================================
   SECCIÓN 5 — ETAPAS (paneles glass, NO tarjetas blancas)
   ============================================================ */
.stages { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 2.2vw, 1.7rem); margin-top: 3.4rem; }
.stage {
  position: relative; overflow: hidden;
  background: linear-gradient(160deg, rgba(234,240,251,0.10), rgba(234,240,251,0.03));
  border: 1px solid rgba(136,146,170,0.28); border-radius: 22px;
  padding: 2.4rem 2rem 2.2rem; backdrop-filter: blur(8px);
  transition: transform .35s ease, border-color .35s ease, background .35s ease;
}
.stage::before {
  content: ""; position: absolute; left: 0; top: 0; width: 100%; height: 3px;
  background: linear-gradient(90deg, var(--jeans), var(--pastel));
  opacity: 0.7;
}
.stage:hover { transform: translateY(-6px); border-color: rgba(255,244,201,0.45); background: linear-gradient(160deg, rgba(234,240,251,0.16), rgba(234,240,251,0.05)); }
.stage .st-index { font-family: var(--font-title); font-weight: 800; font-size: 3rem; color: rgba(255,244,201,0.3); line-height: 1; margin-bottom: 0.4rem; }
.stage .st-title { font-family: var(--font-title); font-size: 1.7rem; color: #fff; margin-bottom: 0.7rem; }
.stage p { font-size: 1rem; color: var(--ink-soft); margin: 0; }

/* ============================================================
   SECCIÓN 7 — Programa de Ciclos (logo)
   ============================================================ */
.ciclos-inner { display: grid; grid-template-columns: 0.95fr 1.05fr; gap: clamp(2rem, 5vw, 5rem); align-items: center; }
.ciclos-logo-box {
  position: relative; border-radius: 26px; padding: clamp(2.4rem, 5vw, 4rem);
  background: linear-gradient(155deg, rgba(234,240,251,0.10), rgba(234,240,251,0.02));
  border: 1px solid rgba(136,146,170,0.28); backdrop-filter: blur(8px);
  display: grid; place-items: center; text-align: center;
  box-shadow: 0 50px 100px -60px rgba(0,0,0,0.7);
}
.ciclos-logo-box::after {
  content: ""; position: absolute; inset: 0; border-radius: 26px; pointer-events: none;
  background: radial-gradient(60% 50% at 50% 30%, rgba(255,244,201,0.18), rgba(255,244,201,0) 70%);
}
.ciclos-logo-box img { width: min(330px, 82%); height: auto; }
.ciclos-logo-box .sub { margin-top: 1.3rem; font-family: var(--font-title); font-size: 0.8rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-dim); }

/* ============================================================
   CIERRE / FORMULARIO (glass, no blanco plano)
   ============================================================ */
.cta-grid { display: grid; grid-template-columns: 1.02fr 0.98fr; gap: clamp(2.4rem, 5vw, 5rem); align-items: center; }
.form-card {
  position: relative; border-radius: 26px; padding: clamp(1.9rem, 3.4vw, 2.8rem);
  background: linear-gradient(160deg, rgba(234,240,251,0.13), rgba(234,240,251,0.04));
  border: 1px solid rgba(136,146,170,0.32); backdrop-filter: blur(18px);
  box-shadow: 0 60px 120px -60px rgba(0,0,0,0.8);
}
.form-card::before {
  content: ""; position: absolute; left: 0; top: 0; width: 100%; height: 4px;
  border-radius: 26px 26px 0 0;
  background: linear-gradient(90deg, var(--jeans), var(--pastel));
}
.form-card h3 { font-size: 1.45rem; margin-bottom: 0.4rem; color: #fff; }
.form-card .fc-hint { font-size: 0.95rem; color: var(--ink-soft); margin-bottom: 1.7rem; }
.field { margin-bottom: 1.15rem; }
.field label { display: block; font-family: var(--font-title); font-weight: 600; font-size: 0.86rem; color: var(--ink); margin-bottom: 0.45rem; }
.field input {
  width: 100%; font-family: var(--font-body); font-size: 1rem; color: #fff;
  padding: 0.9rem 1.05rem; border: 1.5px solid rgba(136,146,170,0.4); border-radius: 13px;
  background: rgba(15,23,48,0.45); transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
.field input::placeholder { color: var(--ink-dim); }
.field input:focus { outline: none; border-color: var(--pastel); background: rgba(15,23,48,0.6); box-shadow: 0 0 0 4px rgba(255,244,201,0.16); }
.form-card .btn { width: 100%; margin-top: 0.5rem; }
.form-legal { margin-top: 1.05rem; font-size: 0.79rem; color: var(--ink-dim); text-align: center; }
.field-error input { border-color: #e08a6e; }
.err-msg { display: none; color: #f0a98e; font-size: 0.79rem; margin-top: 0.35rem; }
.field-error .err-msg { display: block; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer { position: relative; z-index: 1; padding-block: clamp(4rem, 8vw, 5.5rem) 2.2rem; border-top: 1px solid rgba(136,146,170,0.18); }
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: clamp(2rem, 5vw, 4rem); }
.footer-logo { height: 50px; width: auto; margin-bottom: 1.5rem; }
.site-footer p { color: var(--ink-soft); font-size: 0.97rem; max-width: 34ch; }
.footer-col h4 { color: #fff; font-size: 0.92rem; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 1.15rem; font-weight: 600; }
.footer-col a { color: var(--ink-soft); display: inline-flex; align-items: center; gap: 0.55rem; padding: 0.34rem 0; transition: color .2s ease; }
.footer-col a:hover { color: var(--pastel); }
.footer-col .ico { width: 1.05em; height: 1.05em; color: var(--acero); flex: none; }
.footer-bottom { margin-top: clamp(2.5rem, 5vw, 3.5rem); padding-top: 1.7rem; border-top: 1px solid rgba(136,146,170,0.16); display: flex; flex-wrap: wrap; gap: 1rem 1.8rem; align-items: center; justify-content: space-between; }
.footer-legal-links { display: flex; flex-wrap: wrap; gap: 0.4rem 1.5rem; }
.footer-legal-links a { color: var(--ink-dim); font-size: 0.85rem; }
.footer-legal-links a:hover { color: var(--pastel); }
.footer-copy { font-size: 0.82rem; color: var(--ink-dim); }

/* ============================================================
   REVEAL (progressive enhancement: oculto SOLO si hay JS)
   ============================================================ */
html.js .reveal { opacity: 0; transform: translateY(30px); transition: opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1); }
html.js .reveal.in { opacity: 1; transform: none; }
html.js .reveal.d1 { transition-delay: .09s; }
html.js .reveal.d2 { transition-delay: .18s; }
html.js .reveal.d3 { transition-delay: .27s; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 980px) {
  .hero-grid { grid-template-columns: 1fr; gap: 2.8rem; }
  .hero-figure { max-width: 460px; }
  .split .col-text, .split .col-media { grid-column: span 12; }
  .split.reverse .col-text { order: 1; }
  .split.reverse .col-media { order: 2; }
  .stages { grid-template-columns: 1fr; }
  .ciclos-inner { grid-template-columns: 1fr; }
  .cta-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 720px) {
  .nav-links { display: none; }
  .nav-toggle { display: grid; place-items: center; }
  .nav-cta.desktop-only { display: none; }
  .footer-grid { grid-template-columns: 1fr; }
  .hero-figure .float-quote { left: 0.7rem; right: 0.7rem; max-width: none; bottom: 0.7rem; }
  .immersive { min-height: auto; }
}

@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior: auto !important; }
  .aurora__blob { animation: none !important; }
  html.js .reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
  .duo img { transition: none !important; }
}
