:root{
  --nav-h:78px;
  --black:#0A0A0A;
  --black-soft:#141414;
  --bg:#0A0A0A;
  --bg-2:#161616;
  --bg-3:#1E1E1E;
  --bone:#F2EFE9;
  --bone-2:#E6E3DC;
  --gold:#C9A961;
  --gold-2:#D4B472;
  --text:#F0EDE6;
  --muted:rgba(240,237,230,.65);
  --muted-light:rgba(255,255,255,.72);
  --border:rgba(255,255,255,.08);
  --border-light:rgba(255,255,255,.14);
  --r-xl:36px;
  --r-lg:28px;
  --r-md:18px;
  --r-sm:10px;
  --r-pill:999px;
  --container:1240px;
  --ease:cubic-bezier(.22,1,.36,1);
  --shadow:0 30px 50px -20px rgba(0,0,0,.25);
  --font-sans:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --font-display:'Bricolage Grotesque','Inter',system-ui,sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-sans);
  font-size:16px;line-height:1.6;color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  position:relative;
}
/* Grano sutil global para profundidad cinematográfica */
body::after{
  content:"";position:fixed;inset:0;
  pointer-events:none;z-index:9999;
  opacity:.035;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 .5 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
  background-size:220px 220px;
}

/* Luces ambient doradas — orbs distribuidos a lo largo del contenido, se deslizan con el scroll */
.ambient-lights{
  position:absolute;top:0;left:0;right:0;bottom:0;
  z-index:0;pointer-events:none;overflow:hidden;
}
.ambient-lights__orb{
  position:absolute;
  border-radius:50%;
  filter:blur(70px);
  mix-blend-mode:screen;
  animation-timing-function:ease-in-out;
  animation-iteration-count:infinite;
}
.ambient-lights__orb--1{
  width:580px;height:580px;top:5%;left:-8%;
  background:radial-gradient(circle,rgba(201,169,97,.4) 0%,rgba(201,169,97,.1) 40%,transparent 70%);
  animation:orbFloat1 24s infinite;
}
.ambient-lights__orb--2{
  width:640px;height:640px;top:35%;right:-10%;
  background:radial-gradient(circle,rgba(212,180,114,.35) 0%,rgba(212,180,114,.08) 45%,transparent 70%);
  animation:orbFloat2 30s infinite;
}
.ambient-lights__orb--3{
  width:560px;height:560px;top:75%;left:10%;
  background:radial-gradient(circle,rgba(201,169,97,.32) 0%,rgba(201,169,97,.08) 40%,transparent 70%);
  animation:orbFloat3 28s infinite;
}
.ambient-lights__orb--4,.ambient-lights__orb--5{display:none}
@keyframes orbFloat1{
  0%,100%{transform:translate(0,0) scale(1);opacity:.7}
  50%{transform:translate(60px,80px) scale(1.15);opacity:1}
}
@keyframes orbFloat2{
  0%,100%{transform:translate(0,0) scale(1);opacity:.6}
  50%{transform:translate(-80px,-50px) scale(1.1);opacity:.9}
}
@keyframes orbFloat3{
  0%,100%{transform:translate(0,0) scale(1);opacity:.65}
  50%{transform:translate(40px,-70px) scale(1.2);opacity:.95}
}
@keyframes orbFloat4{
  0%,100%{transform:translate(0,0) scale(1);opacity:.55}
  50%{transform:translate(-50px,60px) scale(1.08);opacity:.85}
}

/* main contiene a los orbs, necesita position relative */
main.page-content{position:relative}

/* DECORACIONES GLOBALES — anillos doradas, marcas flotantes, puntos pulsantes */
.deco-layer{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.deco-ring{
  position:absolute;
  border:1px dashed rgba(201,169,97,.35);
  border-radius:50%;
  animation:decoRotate 38s linear infinite;
  will-change:transform;
}
.deco-ring::after{
  content:"";position:absolute;top:-3px;left:50%;
  width:7px;height:7px;border-radius:50%;
  background:var(--gold);transform:translateX(-50%);
  box-shadow:0 0 14px var(--gold),0 0 28px rgba(201,169,97,.3);
}
.deco-ring--reverse{animation-direction:reverse;animation-duration:44s}
.deco-ring--solid{border-style:solid;border-color:rgba(201,169,97,.18)}
.deco-mark{
  position:absolute;color:var(--gold);
  font-size:1.1rem;font-family:var(--font-display);
  animation:decoFloat 5s ease-in-out infinite;
  text-shadow:0 0 12px rgba(201,169,97,.5);
  will-change:transform;
}
.deco-dot{
  position:absolute;
  width:6px;height:6px;border-radius:50%;
  background:var(--gold);
  box-shadow:0 0 10px rgba(201,169,97,.7),0 0 24px rgba(201,169,97,.3);
  animation:decoPulse 3.5s ease-in-out infinite;
  will-change:transform,opacity;
}
.deco-line{
  position:absolute;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--gold) 50%,transparent);
  opacity:.5;
}
@keyframes decoRotate{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes decoFloat{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-10px) rotate(6deg)}}
@keyframes decoPulse{0%,100%{transform:scale(1);opacity:.6}50%{transform:scale(1.4);opacity:1}}

/* Asegurar que las secciones con deco son containers */
.services,.comparison,.testimonials,.cta,.faq,.why,.spotlight,.process{position:relative}

/* Reduced motion para deco */
@media (prefers-reduced-motion:reduce){
  .deco-ring,.deco-mark,.deco-dot{animation:none}
}

/* Asegurar que el contenido queda por encima de las luces */
.nav,main,.footer,.scroll-video-wrapper,.wa-float{position:relative;z-index:2}
.nav{z-index:100}
.wa-float{z-index:40}
.scroll-video-wrapper{z-index:10}

/* Luces específicas de sección para profundidad añadida */
.services{isolation:isolate}
.services .services__glow,
.services::after{
  content:"";position:absolute;
  pointer-events:none;z-index:0;
}
.services::after{
  top:-300px;right:-200px;
  width:700px;height:700px;
  background:radial-gradient(circle,rgba(201,169,97,.12),transparent 60%);
  filter:blur(60px);
}
.services > *{position:relative;z-index:1}

.cta{position:relative;isolation:isolate}
.cta::before{
  content:"";position:absolute;
  top:20%;left:-100px;
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(201,169,97,.18),transparent 60%);
  filter:blur(80px);
  pointer-events:none;z-index:0;
}
.cta > *{position:relative;z-index:1}

.portfolio{position:relative;isolation:isolate}
.portfolio::before{
  content:"";position:absolute;
  bottom:-200px;right:10%;
  width:600px;height:600px;
  background:radial-gradient(circle,rgba(212,180,114,.1),transparent 60%);
  filter:blur(70px);
  pointer-events:none;z-index:0;
}
.portfolio > *{position:relative;z-index:1}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font:inherit;color:inherit}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.05;letter-spacing:-.025em}
em{font-style:normal;color:var(--gold);font-weight:inherit}

.container{max-width:var(--container);margin:0 auto;padding:0 clamp(20px,4vw,48px)}

.overline{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:600;font-family:var(--font-sans)}
.overline--light{color:rgba(255,255,255,.7)}
.overline--dark{color:var(--muted)}

.btn{
  display:inline-flex;align-items:center;gap:10px;justify-content:center;
  padding:14px 26px;border-radius:var(--r-pill);
  font-family:var(--font-sans);
  font-size:.95rem;font-weight:600;letter-spacing:-.005em;
  transition:transform .3s var(--ease),background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease);
  white-space:nowrap;cursor:pointer;border:1px solid transparent;
}
.btn:hover{transform:translateY(-2px)}
.btn--pill{background:#fff;color:var(--black)}
.btn--pill:hover{background:var(--bone)}
.btn--gold{background:var(--gold);color:#0A0A0A}
.btn--gold:hover{background:var(--gold-2)}
.btn--dark{background:#fff;color:var(--black)}
.btn--light{background:#fff;color:#0A0A0A}
.btn--ghost{border-color:rgba(255,255,255,.3);color:#fff}
.btn--ghost-light{border-color:rgba(255,255,255,.35);color:#fff}
.btn--ghost-light:hover{background:rgba(255,255,255,.08)}
.btn--full{width:100%}

/* NAV — estilo editorial, barra full-width, capa independiente */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:var(--nav-h);
  background:rgba(8,8,8,.82);
  backdrop-filter:saturate(180%) blur(18px);
  -webkit-backdrop-filter:saturate(180%) blur(18px);
  border-bottom:1px solid var(--border);
  transition:background .4s var(--ease),border-color .4s var(--ease),box-shadow .4s var(--ease);
}
.nav__inner{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:24px;
  height:100%;
  padding:0 clamp(20px,4vw,48px);
}

/* Menú izquierda */
.nav__menu{display:flex;gap:32px;justify-self:start}
.nav__menu a{
  font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.7);font-weight:500;
  position:relative;transition:color .3s var(--ease);
}
.nav__menu a:hover{color:#fff}
.nav__menu a::after{
  content:"";position:absolute;left:0;right:0;bottom:-6px;height:1px;
  background:var(--gold);transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease);
}
.nav__menu a:hover::after{transform:scaleX(1)}

/* Logo centrado */
.nav__logo{
  display:inline-flex;align-items:center;justify-content:center;
  justify-self:center;flex-shrink:0;line-height:0;
}
.nav__logo .nav__logo__img{height:54px;width:auto;display:block;filter:drop-shadow(0 2px 12px rgba(0,0,0,.4))}
.nav__logo--footer{justify-self:start}
.nav__logo--footer img{height:88px;opacity:.95;filter:drop-shadow(0 2px 12px rgba(0,0,0,.3))}

/* CTA derecha */
.nav__cta{
  justify-self:end;
  padding:10px 22px;font-size:.72rem;
  letter-spacing:.2em;text-transform:uppercase;font-weight:600;
  border-radius:var(--r-pill);
  background:#fff;color:var(--black);
  border:1px solid #fff;
  transition:background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease),transform .3s var(--ease);
}
.nav__cta:hover{transform:translateY(-2px);background:var(--gold);border-color:var(--gold)}

.nav__toggle{display:none;width:40px;height:40px;flex-direction:column;gap:5px;align-items:center;justify-content:center;border-radius:var(--r-pill);justify-self:end}
.nav__toggle span{display:block;width:20px;height:1.5px;background:#fff;transition:transform .3s var(--ease),opacity .3s var(--ease),background .4s var(--ease)}
.nav__toggle.is-open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav__toggle.is-open span:nth-child(2){opacity:0}
.nav__toggle.is-open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* Estado sobre el vídeo — degradado sutil, vídeo 100vh visible detrás */
.nav--transparent{
  background:linear-gradient(180deg,rgba(0,0,0,.38) 0%,rgba(0,0,0,.12) 65%,rgba(0,0,0,0) 100%);
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
  border-bottom:none;
}
.nav--transparent .nav__menu a{
  color:rgba(255,255,255,.92);
  text-shadow:0 2px 14px rgba(0,0,0,.55);
}
.nav--transparent .nav__menu a:hover{color:#fff}
.nav--transparent .nav__menu a::after{background:#fff}
.nav--transparent .nav__cta{
  background:transparent;
  color:#fff;
  border-color:rgba(255,255,255,.32);
  text-shadow:0 2px 14px rgba(0,0,0,.55);
}
.nav--transparent .nav__cta:hover{
  background:rgba(255,255,255,.1);
  border-color:rgba(255,255,255,.6);
}
.nav--transparent .nav__toggle span{background:#fff}

/* =========================================
   SCROLL VIDEO HERO
   ========================================= */
.scroll-video-wrapper{
  position:relative;
  height:290vh;
}
.scroll-hero{
  position:sticky;top:0;
  width:100%;
  height:100vh;
  height:100dvh;
  overflow:hidden;
  background:#000;
  z-index:10;
  perspective:1400px;
}
.scroll-hero__video{
  position:absolute;top:0;left:0;
  width:100%;height:100%;
  object-fit:cover;
  background:#000;
}
.scroll-hero__vignette{display:none}

/* Textos animados sobre el vídeo (estilo editorial) */
.scroll-text{
  position:absolute;top:0;left:0;
  width:100%;height:100%;
  display:flex;flex-direction:column;justify-content:center;
  padding:0 clamp(24px,6vw,90px);
  z-index:15;
  pointer-events:none;
  transform-style:preserve-3d;
  transform:rotateX(var(--tilt-y,0deg)) rotateY(var(--tilt-x,0deg));
  will-change:transform,translate;
}
.scroll-text.active{animation:floatIdle 7s ease-in-out infinite}

@keyframes floatIdle{
  0%,100%{translate:0 0}
  50%{translate:0 -10px}
}

.scroll-text > *{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1);
}
.scroll-text.active > *{opacity:1;transform:translateY(0)}
.scroll-text.exiting > *{opacity:0;transform:translateY(-20px)}

/* Reveal carácter a carácter en el título (overrides parent-level) — sin blur para performance */
.scroll-text > .scroll-text__title{opacity:1;transform:none;transition:none}
.scroll-char{
  display:inline-block;
  opacity:0;
  transform:translate3d(0,.5em,0) scale(.88);
  transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1);
  transition-delay:calc(var(--ci,0) * 22ms);
}
.scroll-text.active .scroll-char{opacity:1;transform:translate3d(0,0,0) scale(1);transition-delay:calc(.12s + var(--ci,0) * 26ms)}
.scroll-text.exiting .scroll-char{opacity:0;transform:translate3d(0,-.3em,0) scale(.95);transition-delay:calc(var(--ci,0) * 8ms);transition-duration:.4s}

.scroll-text.active > *:nth-child(1){transition-delay:0s}
.scroll-text.active > *:nth-child(2){transition-delay:.14s}
.scroll-text.active > *:nth-child(3){transition-delay:.28s}
.scroll-text.active > *:nth-child(4){transition-delay:.42s}

.scroll-text--left{align-items:flex-start;text-align:left}
.scroll-text--right{align-items:flex-end;text-align:right}
.scroll-text--center{align-items:center;text-align:center}

/* Backdrop invisible — el texto se sostiene solo con text-shadow */
.scroll-text::before{display:none}

/* Índice de progreso premium */
.scroll-text__index{
  display:inline-flex;align-items:center;gap:14px;margin-bottom:18px;
  padding:7px 16px 7px 14px;
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r-pill);
  background:rgba(10,10,10,.4);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.scroll-text__index-n{
  font-family:var(--font-display);
  font-size:1.05rem;font-weight:800;
  color:var(--gold);
  letter-spacing:-.04em;line-height:1;
  text-shadow:0 1px 2px rgba(0,0,0,.8),0 0 16px rgba(201,169,97,.35);
}
.scroll-text__index-bar{
  display:block;position:relative;
  width:52px;height:2px;
  background:rgba(255,255,255,.18);
  border-radius:2px;overflow:hidden;
}
.scroll-text__index-bar i{
  position:absolute;top:0;left:0;bottom:0;
  background:linear-gradient(90deg,var(--gold),#D4B472);
  box-shadow:0 0 8px rgba(201,169,97,.6);
  border-radius:2px;
  transform:scaleX(0);transform-origin:left;
  transition:transform 1.4s cubic-bezier(.22,1,.36,1);
  transition-delay:.3s;
}
.scroll-text.active .scroll-text__index-bar i{transform:scaleX(1)}
.scroll-text__index-t{
  font-family:var(--font-display);
  font-size:.7rem;font-weight:600;
  color:rgba(255,255,255,.5);
  letter-spacing:.22em;line-height:1;
}
.scroll-text__title{
  font-family:var(--font-display);
  font-size:clamp(2.4rem,1.6rem + 3.8vw,5.2rem);
  font-weight:800;
  color:#fff;
  letter-spacing:-.035em;
  line-height:.88;
  -webkit-text-stroke:.5px rgba(0,0,0,.4);
  paint-order:stroke fill;
  text-shadow:0 1px 2px rgba(0,0,0,.9),0 4px 20px rgba(0,0,0,.8),0 12px 40px rgba(0,0,0,.6);
  max-width:720px;
  text-wrap:balance;
  margin-bottom:0;
}
.scroll-text--center .scroll-text__title{
  white-space:nowrap;
  max-width:none;
  font-size:clamp(1.8rem,1.2rem + 3vw,4.2rem);
}
.scroll-text__title em{
  color:var(--gold);font-style:normal;font-weight:700;
  text-shadow:0 1px 2px rgba(0,0,0,.95),0 2px 12px rgba(0,0,0,.9),0 0 30px rgba(201,169,97,.3);
}
.scroll-text__title .big-num{
  display:inline-block;
  font-family:var(--font-display);
  font-weight:800;
  font-size:1.25em;line-height:.85;
  letter-spacing:-.06em;
  color:var(--gold);
  -webkit-text-fill-color:var(--gold);
  background:none;
  -webkit-text-stroke:0;
  text-shadow:
    0 0 1px rgba(0,0,0,.95),
    0 2px 4px rgba(0,0,0,.95),
    0 4px 14px rgba(0,0,0,.8),
    0 10px 36px rgba(0,0,0,.55);
  padding:0 .04em;
  font-variant-numeric:tabular-nums;
}
.scroll-text__dot{
  display:inline-block;
  width:.34em;height:.34em;
  border-radius:50%;
  background:currentColor;
  vertical-align:.28em;
  margin:0 .5em;
}
.scroll-text__tag{
  font-family:var(--font-sans);
  font-size:.8rem;
  font-weight:700;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--gold);
  margin-top:14px;
  text-shadow:0 1px 2px rgba(0,0,0,.95),0 2px 14px rgba(0,0,0,.85);
  display:inline-flex;align-items:center;gap:14px;
}
.scroll-text__tag-line{
  display:inline-block;
  width:36px;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold));
  flex-shrink:0;
}
.scroll-text__tag-line:last-child{background:linear-gradient(90deg,var(--gold),transparent)}
.scroll-text__body{
  font-family:var(--font-sans);
  font-size:1.05rem;
  line-height:1.5;
  color:rgba(255,255,255,.95);
  max-width:540px;
  margin-top:14px;
  text-shadow:0 1px 2px rgba(0,0,0,.95),0 2px 14px rgba(0,0,0,.85);
  font-weight:400;
  letter-spacing:.005em;
  text-wrap:balance;
}

/* Hint inicial */
.scroll-hero__hint{
  position:absolute;bottom:32px;left:50%;
  transform:translateX(-50%);
  z-index:20;
  color:rgba(255,255,255,.55);
  animation:hintBounce 2s ease-in-out infinite;
  transition:opacity .4s ease;
  pointer-events:none;
}
.scroll-hero__hint.hidden{opacity:0}
@keyframes hintBounce{
  0%,100%{transform:translateX(-50%) translateY(0)}
  50%{transform:translateX(-50%) translateY(8px)}
}

/* Contenido de la web */
.page-content{
  opacity:0;
  transform:translateY(30px);
  transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);
}
.page-content.visible{opacity:1;transform:translateY(0)}

/* Barra de progreso */
.scroll-video-progress{
  position:fixed;top:0;left:0;
  height:2px;
  background:var(--gold);
  z-index:1001;
  width:0%;
  pointer-events:none;
}
.scroll-video-progress.hidden{opacity:0;transition:opacity .4s ease}

/* TRUST — layout profesional premium */
.trust{padding:30px 0 80px;position:relative}
.trust__grid{
  display:grid;grid-template-columns:repeat(7,auto);gap:0;align-items:center;justify-content:center;
  padding:clamp(36px,5vw,56px) clamp(20px,4vw,56px);
  background:
    radial-gradient(ellipse 70% 120% at 50% 0%,rgba(201,169,97,.08),transparent 60%),
    linear-gradient(180deg,rgba(255,255,255,.03) 0%,rgba(255,255,255,0) 100%),
    var(--bg-2);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  position:relative;overflow:hidden;
  box-shadow:0 30px 80px -40px rgba(0,0,0,.7);
}
.trust__grid::before{
  content:"";position:absolute;top:0;left:15%;right:15%;height:1px;
  background:linear-gradient(90deg,transparent 0%,var(--gold) 50%,transparent 100%);
  opacity:.6;
}
.trust__item{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  text-align:center;padding:4px clamp(14px,3vw,42px);min-width:0;
  transition:transform .5s cubic-bezier(.22,1,.36,1);
}
.trust__item:hover{transform:translateY(-4px)}
.trust__sep{
  width:1px;height:72px;
  background:linear-gradient(180deg,transparent,rgba(201,169,97,.35) 30%,rgba(201,169,97,.35) 70%,transparent);
}
.trust__num{
  font-family:var(--font-display);font-size:clamp(2.2rem,1.6rem + 1.8vw,3.2rem);
  color:#fff;font-weight:800;line-height:1;letter-spacing:-.045em;
  display:inline-flex;align-items:baseline;justify-content:center;gap:0;
  transition:color .4s var(--ease);
}
.trust__prefix,.trust__suffix{color:#fff;font-weight:800}
.trust__num em{color:#fff;font-style:normal}
.trust__item:hover .trust__num{
  background:linear-gradient(180deg,#fff,var(--gold));
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}
.trust__label{
  color:var(--gold);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
}

/* EDITORIAL — composición abstracta con fotos apiladas y elementos decorativos */
.editorial{padding:140px 0 120px;position:relative}
.editorial__layout{
  display:grid;grid-template-columns:1.05fr 1fr;gap:80px;
  align-items:center;
}
.editorial__text-col{display:flex;flex-direction:column;gap:24px;align-items:flex-start}
.editorial__overline{
  font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);font-weight:600;margin:0;
}
.editorial__title{
  font-family:var(--font-display);
  font-size:clamp(2.4rem,4.6vw,4.4rem);
  font-weight:800;line-height:1.02;letter-spacing:-.03em;
  margin:0;text-wrap:balance;
}
.editorial__title em{color:var(--gold);font-style:normal}
.editorial__text{
  color:rgba(255,255,255,.78);
  font-size:1.08rem;line-height:1.75;
  max-width:520px;margin:0;
  text-wrap:pretty;
}
.editorial__text strong{color:#fff;font-weight:600}
.editorial__cta{padding:16px 32px;font-size:.95rem;margin-top:8px}

/* Visual — composición abstracta con fotos asimétricas + decoraciones */
.editorial__visual{
  position:relative;aspect-ratio:1/1;
  min-height:520px;
}
.editorial__photo{
  margin:0;border-radius:24px;overflow:hidden;
  position:absolute;
  border:1px solid var(--border);
  box-shadow:0 40px 50px -20px rgba(0,0,0,.75),0 0 0 1px rgba(201,169,97,.05);
  -webkit-tap-highlight-color:transparent;
  transition:box-shadow .6s cubic-bezier(.22,1,.36,1),border-color .6s var(--ease);
}
.editorial__photo img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 1.2s cubic-bezier(.22,1,.36,1),filter .8s var(--ease);
  will-change:transform;transform-origin:center;
}
.editorial__photo::after{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:2;
  background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.45) 100%);
  transition:opacity .6s var(--ease);
}

/* Shine sweep dorado sobre la foto */
.editorial__photo::before{
  content:"";position:absolute;inset:0;z-index:3;pointer-events:none;
  background:linear-gradient(115deg,transparent 35%,rgba(255,255,255,.06) 46%,rgba(201,169,97,.35) 50%,rgba(255,255,255,.06) 54%,transparent 65%);
  transform:translateX(-110%);
  transition:transform 1.2s cubic-bezier(.22,1,.36,1);
  mix-blend-mode:screen;
}
/* Hover effects solo en dispositivos con hover real (no móvil) */
@media (hover:hover) and (pointer:fine){
  .editorial__photo{cursor:pointer}
  .editorial__photo:hover{
    box-shadow:0 50px 60px -20px rgba(0,0,0,.85),0 0 40px -5px rgba(201,169,97,.25),0 0 0 1px rgba(201,169,97,.25);
    border-color:rgba(201,169,97,.3);
  }
  .editorial__photo:hover img{filter:brightness(1.08) saturate(1.15) contrast(1.04)}
  .editorial__photo:hover::after{opacity:.6}
  .editorial__photo:hover::before{transform:translateX(110%)}
}
.editorial__photo--main{
  top:0;left:8%;width:62%;height:78%;
  border-radius:240px 24px 24px 24px;
  z-index:2;
}
.editorial__photo--accent{
  bottom:0;right:0;width:48%;height:48%;
  border-radius:24px 24px 24px 24px;
  z-index:3;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.85),0 0 0 4px var(--bg);
}

/* Decoraciones doradas */
.editorial__deco{position:absolute;pointer-events:none}
.editorial__deco--ring{
  top:-20px;right:8%;
  width:140px;height:140px;border-radius:50%;
  border:1px dashed rgba(201,169,97,.4);
  animation:spin 35s linear infinite;
}
.editorial__deco--ring::after{
  content:"";position:absolute;top:-3px;left:50%;
  width:6px;height:6px;border-radius:50%;
  background:var(--gold);transform:translateX(-50%);
  box-shadow:0 0 12px var(--gold);
}
.editorial__deco--mark{
  bottom:30%;left:0;
  font-size:1.6rem;color:var(--gold);
  animation:floatBob 5s ease-in-out infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes floatBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* Badge "+10 años" flotante */
.editorial__badge{
  position:absolute;top:50%;left:0;transform:translateY(-50%) translateX(-30%);
  z-index:4;
  width:120px;height:120px;border-radius:50%;
  background:linear-gradient(140deg,var(--gold),#A88744);
  color:var(--black);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  box-shadow:0 20px 50px -10px rgba(201,169,97,.5),0 0 0 6px var(--bg);
  font-family:var(--font-display);
}
.editorial__badge-num{font-size:2rem;font-weight:800;letter-spacing:-.04em;line-height:1}
.editorial__badge-num em{font-style:normal;color:var(--black)}
.editorial__badge-lbl{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;margin-top:4px}

/* COMPARISON — Slider interactivo antes/después */
.comparison{padding:80px 0 100px;position:relative;isolation:isolate}
.comparison::before{
  content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:50%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(201,169,97,.4),transparent);
}
.comparison__grid{
  display:grid;grid-template-columns:1fr 1fr;gap:32px;
}
.ba{display:flex;flex-direction:column;gap:18px}
.ba__slider{
  position:relative;
  aspect-ratio:4/5;
  border-radius:var(--r-lg);
  overflow:hidden;
  border:1px solid var(--border);
  cursor:ew-resize;
  user-select:none;
  -webkit-user-select:none;
  touch-action:none;
  background:var(--bg-2);
  box-shadow:0 30px 50px -20px rgba(0,0,0,.7);
  transition:box-shadow .4s var(--ease);
}
.ba__slider:hover{box-shadow:0 40px 100px -30px rgba(0,0,0,.9),0 0 0 1px rgba(201,169,97,.2)}
.ba__img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  pointer-events:none;
  -webkit-user-drag:none;
}
.ba__img--before{
  clip-path:inset(0 calc(100% - var(--ba-pos,50%)) 0 0);
}
.ba__divider{
  position:absolute;top:0;bottom:0;
  left:var(--ba-pos,50%);transform:translateX(-50%);
  width:2px;
  background:#fff;
  box-shadow:0 0 30px rgba(0,0,0,.6),0 0 0 1px rgba(0,0,0,.1);
  pointer-events:none;
}
.ba__divider::before,.ba__divider::after{
  content:"";position:absolute;left:50%;
  width:1px;background:rgba(255,255,255,.4);
  transform:translateX(-50%);
}
.ba__divider::before{top:0;bottom:50%;margin-bottom:30px}
.ba__divider::after{top:50%;bottom:0;margin-top:30px}
.ba__knob{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:54px;height:54px;border-radius:50%;
  background:var(--gold);
  display:grid;place-items:center;
  color:var(--black);
  box-shadow:0 8px 24px rgba(0,0,0,.4),0 0 0 4px rgba(255,255,255,.15);
  pointer-events:auto;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease);
}
.ba__slider:hover .ba__knob{transform:translate(-50%,-50%) scale(1.1);box-shadow:0 10px 30px rgba(0,0,0,.5),0 0 0 6px rgba(255,255,255,.2)}
.ba__knob svg{width:22px;height:22px}
.ba__label{
  position:absolute;top:18px;
  padding:6px 14px;border-radius:var(--r-pill);
  font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;
  font-weight:700;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  z-index:2;pointer-events:none;
  transition:opacity .3s var(--ease);
}
.ba__label--before{
  left:18px;
  background:rgba(0,0,0,.65);color:#fff;
  border:1px solid rgba(255,255,255,.15);
}
.ba__label--after{
  right:18px;
  background:var(--gold);color:var(--black);
  border:1px solid var(--gold);
}
.ba__range{
  position:absolute;inset:0;
  width:100%;height:100%;
  opacity:0;cursor:ew-resize;
  margin:0;padding:0;
}
.ba__title{
  font-family:var(--font-display);font-size:1rem;font-weight:600;
  letter-spacing:-.01em;color:var(--text);text-align:center;margin:0;
}

/* LIGHTBOX */
.lightbox{
  position:fixed;inset:0;z-index:1000;
  background:rgba(0,0,0,.96);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  display:none;
  align-items:center;justify-content:center;
  padding:80px 80px 100px;
}
.lightbox.is-open{display:flex;animation:lightboxIn .35s cubic-bezier(.22,1,.36,1)}
@keyframes lightboxIn{from{opacity:0}to{opacity:1}}
.lightbox__figure{
  margin:0;display:flex;flex-direction:column;align-items:center;gap:20px;
  max-width:1200px;width:100%;
}
.lightbox__img{
  max-width:100%;max-height:80vh;width:auto;height:auto;
  display:block;border-radius:var(--r-md);
  box-shadow:0 40px 120px rgba(0,0,0,.8);
  animation:lightboxImg .45s cubic-bezier(.22,1,.36,1);
}
@keyframes lightboxImg{from{transform:scale(.96);opacity:0}to{transform:scale(1);opacity:1}}
.lightbox__caption{
  color:rgba(255,255,255,.85);font-size:.95rem;text-align:center;
  font-family:var(--font-display);font-weight:500;letter-spacing:.01em;
}
.lightbox__counter{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);font-weight:600;
}
.lightbox__close,.lightbox__nav{
  position:absolute;
  width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  color:#fff;display:grid;place-items:center;cursor:pointer;
  transition:background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease),transform .3s var(--ease);
}
.lightbox__close:hover,.lightbox__nav:hover{
  background:var(--gold);color:var(--black);border-color:var(--gold);
}
.lightbox__close{top:24px;right:24px}
.lightbox__close:hover{transform:rotate(90deg)}
.lightbox__nav{top:50%;transform:translateY(-50%)}
.lightbox__nav--prev{left:24px}
.lightbox__nav--next{right:24px}
.lightbox__nav:hover{transform:translateY(-50%) scale(1.08)}

@media (max-width:720px){
  .lightbox{padding:60px 12px 80px}
  .lightbox__close{top:14px;right:14px;width:42px;height:42px}
  .lightbox__nav{width:42px;height:42px}
  .lightbox__nav--prev{left:8px}
  .lightbox__nav--next{right:8px}
  .lightbox__counter{bottom:18px}
}

/* SECTION HEAD */
.section-head{text-align:center;max-width:700px;margin:0 auto 56px}
.section-title{font-size:clamp(2rem,4vw,3.2rem);margin:14px 0 14px;text-wrap:balance}
.section-sub{color:var(--muted);font-size:1.05rem;text-wrap:balance;max-width:640px;margin-left:auto;margin-right:auto}
.section-sub a{color:var(--text);text-decoration:underline;text-decoration-color:var(--gold);text-underline-offset:4px}

/* SERVICES */
.services{padding:100px 0;background:var(--bg-2);border-radius:var(--r-xl);margin:0 clamp(20px,4vw,48px);position:relative;overflow:hidden;isolation:isolate}
.services::before{
  content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:60%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(201,169,97,.3),transparent);
  z-index:2;
}
.services__grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  counter-reset:service;
}
.service{
  position:relative;padding:36px 28px 56px;
  border:1px solid var(--border);border-radius:var(--r-md);
  background:var(--bg-3);overflow:hidden;
  counter-increment:service;
  transition:transform .6s var(--ease),box-shadow .6s var(--ease),border-color .6s var(--ease),background .6s var(--ease);
}
.service.reveal{transition-delay:calc(var(--i,0) * 80ms)}
/* Glow radial al hover */
.service::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 50% 0%,rgba(201,169,97,.18),transparent 70%);
  opacity:0;transition:opacity .6s var(--ease);
}
/* Línea dorada superior animada al hover */
.service::after{
  content:"";position:absolute;top:0;left:50%;right:50%;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  transition:left .7s cubic-bezier(.22,1,.36,1),right .7s cubic-bezier(.22,1,.36,1);
}
.service:hover{
  translate:0 -6px;
  box-shadow:0 24px 50px -20px rgba(0,0,0,.7),0 0 0 1px rgba(201,169,97,.2);
  border-color:rgba(201,169,97,.35);
  background:#232323;
}
.service:hover::before{opacity:1}
.service:hover::after{left:0;right:0}

/* Número del servicio (01, 02...) arriba a la derecha */
.service > h3::after{
  content:counter(service,decimal-leading-zero);
  position:absolute;top:-20px;right:-8px;
  font-family:var(--font-display);font-size:.72rem;letter-spacing:.15em;
  color:var(--muted);opacity:.5;font-weight:600;
  transition:color .4s var(--ease),opacity .4s var(--ease),transform .4s var(--ease);
}
.service:hover > h3::after{color:var(--gold);opacity:1;transform:translateX(-4px)}

.service__icon{
  width:60px;height:60px;border-radius:16px;
  background:transparent;
  display:grid;place-items:center;margin-bottom:20px;margin-left:-6px;
  transition:transform .6s cubic-bezier(.34,1.56,.64,1);
}
.service__icon img{width:46px;height:46px;display:block;transition:transform .6s cubic-bezier(.34,1.56,.64,1),filter .6s var(--ease)}
.service:hover .service__icon{transform:scale(1.08) rotate(-6deg)}
.service:hover .service__icon img{transform:rotate(6deg) scale(1.1);filter:drop-shadow(0 10px 20px rgba(201,169,97,.35))}

.service h3{font-family:var(--font-display);font-size:1.1rem;font-weight:700;margin-bottom:10px;letter-spacing:-.01em;line-height:1.3;color:var(--text);position:relative;transition:color .3s var(--ease)}
.service:hover h3{color:#fff}
.service p{color:var(--muted);font-size:.92rem;line-height:1.6;position:relative}

.service__arrow{
  position:absolute;right:24px;bottom:24px;
  width:36px;height:36px;border-radius:50%;
  display:grid;place-items:center;
  background:transparent;border:1px solid var(--border);
  color:var(--muted);
  opacity:0;transform:translateX(-12px) rotate(-45deg);
  transition:opacity .5s var(--ease),transform .6s cubic-bezier(.22,1,.36,1),background .4s var(--ease),color .4s var(--ease),border-color .4s var(--ease);
}
.service:hover .service__arrow,.service:focus-visible .service__arrow{opacity:1;transform:translateX(0) rotate(0);background:var(--gold);border-color:var(--gold);color:var(--black)}

/* Botón service como botón nativo */
button.service{
  font:inherit;text-align:left;color:inherit;cursor:pointer;width:100%;
}
button.service:focus-visible{outline:2px solid var(--gold);outline-offset:4px}
.service__more{
  display:inline-flex;align-items:center;gap:6px;
  margin-top:18px;
  font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold);opacity:.7;
  transition:opacity .3s var(--ease),letter-spacing .3s var(--ease);
}
.service:hover .service__more{opacity:1;letter-spacing:.18em}

/* SERVICE MODAL */
.service-modal{
  width:min(720px,calc(100vw - 32px));
  max-height:min(86vh,860px);
  margin:auto;padding:0;
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  background:linear-gradient(165deg,#181818 0%,#0E0E0E 100%);
  color:var(--text);
  overflow:hidden;
  box-shadow:0 60px 60px -20px rgba(0,0,0,.8),0 0 0 1px rgba(201,169,97,.08);
}
.service-modal::backdrop{
  background:rgba(0,0,0,.75);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.service-modal[open]{
  animation:modalIn .55s cubic-bezier(.22,1,.36,1);
}
@keyframes modalIn{
  from{opacity:0;transform:translateY(20px) scale(.96)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.service-modal__close{
  position:absolute;top:16px;right:16px;z-index:5;
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.06);border:1px solid var(--border);
  color:var(--text);display:grid;place-items:center;cursor:pointer;
  transition:background .3s var(--ease),color .3s var(--ease),transform .3s var(--ease),border-color .3s var(--ease);
}
.service-modal__close:hover{background:var(--gold);color:var(--black);border-color:var(--gold);transform:rotate(90deg)}

.service-modal__inner{
  display:flex;flex-direction:column;
  max-height:inherit;overflow-y:auto;
}
.service-modal__inner::-webkit-scrollbar{width:6px}
.service-modal__inner::-webkit-scrollbar-thumb{background:rgba(201,169,97,.3);border-radius:3px}

.service-modal__header{
  padding:48px clamp(28px,5vw,56px) 32px;
  position:relative;
  border-bottom:1px solid var(--border);
  background:radial-gradient(ellipse at top,rgba(201,169,97,.1),transparent 60%);
}
.service-modal__icon{
  width:64px;height:64px;border-radius:18px;
  background:linear-gradient(145deg,rgba(201,169,97,.15),rgba(201,169,97,.05));
  border:1px solid rgba(201,169,97,.25);
  display:grid;place-items:center;
  margin-bottom:22px;
}
.service-modal__icon img{width:42px;height:42px}
.service-modal__tag{
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);font-weight:600;margin-bottom:14px;
}
.service-modal__title{
  font-family:var(--font-display);font-size:clamp(1.8rem,3vw,2.4rem);
  font-weight:700;letter-spacing:-.02em;line-height:1.1;
  margin-bottom:14px;color:#fff;
}
.service-modal__lead{
  color:rgba(255,255,255,.78);font-size:1.05rem;line-height:1.6;
  max-width:560px;
}

.service-modal__body{padding:8px clamp(28px,5vw,56px) 16px}
.service-modal__section{padding:24px 0;border-bottom:1px solid var(--border)}
.service-modal__section:last-child{border-bottom:none}
.service-modal__section h4{
  font-family:var(--font-display);font-size:1.05rem;
  font-weight:700;color:var(--gold);
  margin-bottom:10px;letter-spacing:-.01em;
  display:flex;align-items:center;gap:10px;
}
.service-modal__section h4::before{
  content:"";width:8px;height:8px;border-radius:50%;
  background:var(--gold);flex-shrink:0;
  box-shadow:0 0 12px rgba(201,169,97,.6);
}
.service-modal__section p{color:rgba(255,255,255,.78);font-size:.96rem;line-height:1.7}

.service-modal__footer{
  padding:22px clamp(28px,5vw,56px);
  border-top:1px solid var(--border);
  background:#0E0E0E;
  display:flex;gap:12px;flex-wrap:wrap;
  position:sticky;bottom:0;
  box-shadow:0 -20px 30px -10px rgba(0,0,0,.6);
}
.service-modal__footer .btn--ghost{border-color:rgba(255,255,255,.25);color:#fff}
.service-modal__footer .btn--ghost:hover{background:rgba(255,255,255,.06)}

@media (max-width:520px){
  .service-modal__header,.service-modal__body,.service-modal__footer{padding-left:24px;padding-right:24px}
  .service-modal__footer{flex-direction:column}
  .service-modal__footer .btn{width:100%}
}

/* SPOTLIGHT — bloque dramático */
.spotlight{padding:100px 0;position:relative}
.spotlight__block{
  position:relative;
  background:linear-gradient(135deg,#181818 0%,#0A0A0A 70%);
  color:#fff;border-radius:var(--r-xl);
  border:1px solid var(--border);
  display:grid;grid-template-columns:1fr 1.2fr;min-height:560px;overflow:hidden;
  box-shadow:0 50px 120px -40px rgba(0,0,0,.9);
}
.spotlight__block::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  opacity:.5;z-index:4;
}
.spotlight__block::after{
  content:"";position:absolute;top:-20%;left:-10%;
  width:400px;height:400px;
  background:radial-gradient(circle,rgba(201,169,97,.18),transparent 60%);
  filter:blur(60px);
  pointer-events:none;
}
.spotlight__content{
  padding:clamp(40px,5vw,72px);
  display:flex;flex-direction:column;justify-content:center;gap:22px;
  position:relative;z-index:2;
}
.spotlight__content .overline{position:relative;padding-left:40px}
.spotlight__content .overline::before{
  content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:28px;height:1px;background:var(--gold);
}
.spotlight__title{
  font-size:clamp(2.2rem,3.8vw,3.4rem);
  line-height:1.02;font-weight:800;letter-spacing:-.025em;
}
.spotlight__title em{color:var(--gold);font-style:normal}
.spotlight__text{color:rgba(255,255,255,.78);max-width:500px;font-size:1.02rem;line-height:1.7}
.spotlight__photo{position:relative;overflow:hidden;min-height:480px;cursor:pointer}
.spotlight__photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.2s cubic-bezier(.22,1,.36,1),filter .8s var(--ease);will-change:transform}
.spotlight__photo:hover img{filter:brightness(1.06) saturate(1.1) contrast(1.03)}
.spotlight__photo::after{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:2;
  background:linear-gradient(90deg,rgba(20,20,20,.7),transparent 30%);
}
.spotlight__photo::before{
  content:"";position:absolute;inset:0;z-index:3;pointer-events:none;
  background:linear-gradient(115deg,transparent 35%,rgba(255,255,255,.06) 46%,rgba(201,169,97,.35) 50%,rgba(255,255,255,.06) 54%,transparent 65%);
  transform:translateX(-110%);
  transition:transform 1.3s cubic-bezier(.22,1,.36,1);
  mix-blend-mode:screen;
}
.spotlight__photo:hover::before{transform:translateX(110%)}

/* PROCESS */
.process{padding:120px 0;position:relative}
.process__list{
  list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
  position:relative;
}
.process__list::before{
  content:"";position:absolute;top:64px;left:10%;right:10%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(201,169,97,.35) 15%,rgba(201,169,97,.35) 85%,transparent);
  z-index:0;
  opacity:0;transform:scaleX(0);transform-origin:center;
  transition:opacity 1s ease .5s,transform 1.2s cubic-bezier(.22,1,.36,1) .5s;
}
.process__list:has(.process__step.is-visible)::before{opacity:1;transform:scaleX(1)}
.process__step{
  background:linear-gradient(160deg,rgba(255,255,255,.025) 0%,rgba(255,255,255,0) 60%),var(--bg-2);
  border:1px solid var(--border);border-radius:var(--r-md);
  padding:44px 28px 32px;position:relative;z-index:1;overflow:hidden;
  transition:border-color .5s var(--ease),background .5s var(--ease),transform .6s cubic-bezier(.22,1,.36,1),box-shadow .5s var(--ease);
  cursor:default;
}
.process__step::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  opacity:0;transform:scaleX(.2);transform-origin:center;
  transition:opacity .5s var(--ease),transform .8s cubic-bezier(.22,1,.36,1);
}
.process__step::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 50% 0%,rgba(201,169,97,.15),transparent 60%);
  opacity:0;transition:opacity .6s var(--ease);
}
.process__step:hover{
  border-color:rgba(201,169,97,.4);
  background:linear-gradient(160deg,rgba(201,169,97,.04) 0%,rgba(255,255,255,0) 60%),var(--bg-3);
  translate:0 -8px;
  box-shadow:0 40px 50px -20px rgba(0,0,0,.85);
}
.process__step:hover::before{opacity:1;transform:scaleX(1)}
.process__step:hover::after{opacity:1}

.process__num{
  font-family:var(--font-display);
  font-size:clamp(4rem,2rem + 4vw,6.2rem);
  color:var(--gold);
  display:block;margin-bottom:8px;margin-top:-20px;
  font-weight:800;letter-spacing:-.06em;line-height:.9;
  background:linear-gradient(180deg,var(--gold),rgba(201,169,97,.35));
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  transition:transform .6s cubic-bezier(.34,1.56,.64,1),filter .5s var(--ease);
  transform-origin:left bottom;
  position:relative;
}
.process__step:hover .process__num{
  transform:scale(1.15) translateY(-4px);
  filter:drop-shadow(0 10px 30px rgba(201,169,97,.4));
}
.process__step h3{
  font-family:var(--font-display);font-size:1.12rem;font-weight:700;
  margin-bottom:10px;letter-spacing:-.015em;color:var(--text);
  transition:color .4s var(--ease);
}
.process__step:hover h3{color:#fff}
.process__step p{color:var(--muted);font-size:.92rem;line-height:1.65;transition:color .4s var(--ease)}
.process__step:hover p{color:rgba(255,255,255,.85)}

/* WHY — Cards visuales premium */
.why{padding:120px 0;position:relative}
.why__cards{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
}
.why__card{
  position:relative;padding:36px 32px 32px;
  background:linear-gradient(160deg,rgba(255,255,255,.025) 0%,rgba(255,255,255,0) 60%),var(--bg-2);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  overflow:hidden;
  transition:transform .5s var(--ease),border-color .5s var(--ease),background .5s var(--ease),box-shadow .5s var(--ease);
}
.why__card.reveal{transition-delay:calc((var(--i,0)) * 60ms)}
.why__card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  opacity:0;transform:translateX(-100%);
  transition:opacity .5s var(--ease),transform .8s cubic-bezier(.22,1,.36,1);
}
.why__card:hover{
  translate:0 -6px;
  border-color:rgba(201,169,97,.3);
  background:linear-gradient(160deg,rgba(201,169,97,.05) 0%,rgba(255,255,255,0) 60%),var(--bg-3);
  box-shadow:0 40px 50px -20px rgba(0,0,0,.7);
}
.why__card:hover::before{opacity:1;transform:translateX(0)}
.why__num{
  display:block;font-family:var(--font-display);
  font-size:2.6rem;font-weight:800;
  color:var(--gold);letter-spacing:-.04em;line-height:1;
  margin-bottom:18px;
  background:linear-gradient(180deg,var(--gold),rgba(201,169,97,.4));
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}
.why__card h3{
  font-family:var(--font-display);font-size:1.15rem;font-weight:700;
  margin-bottom:10px;letter-spacing:-.015em;color:var(--text);
}
.why__card p{color:var(--muted);font-size:.95rem;line-height:1.65}

/* CERTIFICATIONS strip */
.certifications{
  display:flex;justify-content:center;flex-wrap:wrap;gap:8px 28px;
  margin:0 auto 36px;
  padding:14px 24px;
  max-width:max-content;
  border:1px solid var(--border);
  border-radius:var(--r-pill);
  background:rgba(255,255,255,.02);
}
.cert{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.78rem;letter-spacing:.06em;color:var(--muted);font-weight:500;
}
.cert svg{color:var(--gold);flex-shrink:0}

/* TESTIMONIALS */
.testimonials{padding:120px 0;position:relative;isolation:isolate}
.testimonials::before{
  content:"";position:absolute;top:30%;left:-200px;
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(201,169,97,.1),transparent 60%);
  filter:blur(60px);pointer-events:none;z-index:-1;
}
.testimonials__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
  margin-bottom:60px;
}
.testimonial{
  position:relative;padding:36px 32px 28px;
  background:linear-gradient(160deg,rgba(255,255,255,.025) 0%,rgba(255,255,255,0) 60%),var(--bg-2);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  display:flex;flex-direction:column;gap:20px;
  transition:transform .5s var(--ease),border-color .5s var(--ease),background .5s var(--ease),box-shadow .5s var(--ease);
}
.testimonial:hover{
  translate:0 -6px;
  border-color:rgba(201,169,97,.35);
  background:linear-gradient(160deg,rgba(201,169,97,.04) 0%,rgba(255,255,255,0) 60%),var(--bg-3);
  box-shadow:0 40px 50px -20px rgba(0,0,0,.7);
}
.testimonial--featured{
  background:linear-gradient(160deg,rgba(201,169,97,.08) 0%,rgba(255,255,255,0) 60%),var(--bg-3);
  border-color:rgba(201,169,97,.25);
}
.testimonial__head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
.testimonial__quote{
  font-family:Georgia,serif;font-size:5rem;line-height:.6;
  color:var(--gold);opacity:.7;
  font-weight:700;letter-spacing:-.04em;
  margin-top:-6px;
}
.testimonial__stars{display:flex;gap:3px;flex-shrink:0}
.testimonial__stars svg{width:16px;height:16px;color:var(--gold)}
.testimonial__text{
  font-family:var(--font-display);
  color:rgba(255,255,255,.9);
  font-size:1.02rem;line-height:1.6;
  flex:1;font-weight:500;
}
.testimonial__author{
  display:flex;align-items:center;gap:14px;
  padding-top:20px;border-top:1px solid var(--border);
}
.testimonial__avatar{
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),#A88744);
  color:var(--black);
  display:grid;place-items:center;
  font-family:var(--font-display);font-weight:700;font-size:.88rem;
  letter-spacing:.02em;flex-shrink:0;
}
.testimonial__author > div{display:flex;flex-direction:column;gap:2px;min-width:0}
.testimonial__author strong{color:var(--text);font-size:.92rem;font-weight:600;font-family:var(--font-sans)}
.testimonial__author span{color:var(--muted);font-size:.78rem;letter-spacing:.02em}

.testimonials__bottom{
  display:flex;flex-direction:column;align-items:center;gap:14px;
  text-align:center;
}
.testimonials__rating{
  display:flex;align-items:center;gap:18px;
  padding:18px 32px;
  background:var(--bg-2);
  border:1px solid var(--border);
  border-radius:var(--r-pill);
}
.testimonials__rating-num{
  font-family:var(--font-display);font-size:2rem;font-weight:800;
  color:#fff;letter-spacing:-.04em;line-height:1;
}
.testimonials__rating-num span{color:var(--muted);font-size:1rem;font-weight:500;margin-left:2px}
.testimonials__rating-stars{display:flex;gap:3px}
.testimonials__rating-stars svg{width:18px;height:18px;color:var(--gold)}
.testimonials__rating-label{font-size:.85rem;color:var(--muted);max-width:480px}

/* PORTFOLIO — Galería con scroll horizontal anclado al scroll vertical */
.portfolio{padding:120px 0 0}
.portfolio__scroll{
  position:relative;
  height:380vh;
  margin-top:40px;
}
.portfolio__sticky{
  position:sticky;top:var(--nav-h);
  height:calc(100vh - var(--nav-h));
  display:flex;align-items:center;
  overflow:hidden;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.portfolio__track{
  display:flex;gap:24px;
  padding:0 clamp(20px,4vw,48px);
  will-change:transform;
  align-items:center;
}
.portfolio__item{
  flex:0 0 auto;
  margin:0;
  overflow:hidden;border-radius:var(--r-md);
  position:relative;
  border:1px solid var(--border);
  cursor:zoom-in;
  background:var(--bg-2);
  height:min(70vh,640px);
  aspect-ratio:3/4;
  transition:transform .6s cubic-bezier(.22,1,.36,1);
}
.portfolio__item:nth-child(3n){aspect-ratio:4/5}
.portfolio__item:nth-child(5n){aspect-ratio:1/1}
.portfolio__item:nth-child(7n){aspect-ratio:4/3}
.portfolio__item img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 1.2s cubic-bezier(.22,1,.36,1),filter .7s var(--ease);
  will-change:transform;
}
.portfolio__item::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,transparent 45%,rgba(0,0,0,.92) 100%);
  opacity:.65;transition:opacity .5s var(--ease);
}
.portfolio__item::before{
  content:"";position:absolute;top:14px;right:14px;
  width:40px;height:40px;border-radius:50%;
  background:rgba(10,10,10,.65);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.15);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23C9A961' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='11' cy='11' r='8'/><path d='M21 21l-4.35-4.35'/><path d='M11 8v6M8 11h6'/></svg>");
  background-position:center;background-repeat:no-repeat;
  opacity:0;transform:translateY(-6px);
  transition:opacity .4s var(--ease),transform .4s var(--ease);
  z-index:3;
}
.portfolio__item:hover{translate:0 -8px}
.portfolio__item:hover img{filter:brightness(.92) saturate(1.1)}
.portfolio__item:hover::after{opacity:.95}
.portfolio__item:hover::before{opacity:1;transform:translateY(0)}

.portfolio__item figcaption{
  position:absolute;left:24px;bottom:24px;right:24px;
  display:flex;flex-direction:column;gap:6px;
  color:#fff;
  z-index:2;
  transform:translateY(6px);
  transition:transform .5s var(--ease);
}
.portfolio__item:hover figcaption{transform:translateY(0)}
.portfolio__cat{
  font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);font-weight:700;
}
.portfolio__item figcaption span:not(.portfolio__cat){
  font-family:var(--font-display);font-size:1.05rem;font-weight:600;
  letter-spacing:-.01em;line-height:1.3;
}

/* Barra de progreso del carrusel */
.portfolio__progress{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  width:200px;height:2px;
  background:rgba(255,255,255,.1);
  border-radius:2px;overflow:hidden;
  z-index:5;pointer-events:none;
}
.portfolio__progress-bar{
  height:100%;width:0;
  background:linear-gradient(90deg,var(--gold),#fff,var(--gold));
  box-shadow:0 0 12px rgba(201,169,97,.6);
  transition:width .15s linear;
}

/* FAQ */
.faq{padding:120px 0;position:relative}
.faq__grid{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:start}
.faq__head{position:sticky;top:100px}
.faq__head .section-title{text-align:left}
.faq__head .section-sub{text-align:left;margin-top:14px}
.faq__list{display:flex;flex-direction:column}
.faq__item{border-bottom:1px solid var(--border);padding:4px 0;transition:padding .4s var(--ease)}
.faq__item:hover{padding:8px 0}
.faq__item summary{
  list-style:none;cursor:pointer;padding:26px 56px 26px 0;position:relative;
  font-weight:600;font-size:1.12rem;letter-spacing:-.01em;
  font-family:var(--font-display);color:var(--text);
  transition:color .3s var(--ease);
}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{
  content:"";position:absolute;right:8px;top:50%;
  width:32px;height:32px;border-radius:50%;
  border:1px solid var(--border);
  background:
    linear-gradient(currentColor,currentColor) center/12px 1px no-repeat,
    linear-gradient(currentColor,currentColor) center/1px 12px no-repeat;
  color:var(--gold);
  transform:translateY(-50%) rotate(0deg);
  transition:transform .4s var(--ease),border-color .4s var(--ease),background-size .4s var(--ease);
}
.faq__item summary:hover::after{border-color:rgba(201,169,97,.4)}
.faq__item[open] summary::after{
  transform:translateY(-50%) rotate(135deg);
  background:
    linear-gradient(currentColor,currentColor) center/12px 1px no-repeat,
    linear-gradient(currentColor,currentColor) center/1px 0 no-repeat;
  border-color:var(--gold);
}
.faq__item[open] summary{color:var(--gold)}
.faq__item p{color:var(--muted);padding:0 0 28px;max-width:90%;font-family:var(--font-sans);line-height:1.7}

/* CTA */
.cta{padding:60px 0 120px}
.cta__block{
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%,rgba(201,169,97,.1),transparent 60%),
    radial-gradient(ellipse 70% 50% at 50% 100%,rgba(37,211,102,.06),transparent 60%),
    linear-gradient(180deg,#181818 0%,#0A0A0A 100%);
  color:#fff;border-radius:var(--r-xl);
  border:1px solid var(--border);
  overflow:hidden;position:relative;
  box-shadow:0 50px 90px -40px rgba(0,0,0,.9);
}
.cta__block::before{
  content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:60%;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  opacity:.5;
}
.cta__center{
  position:relative;z-index:1;
  padding:clamp(56px,7vw,96px) clamp(24px,5vw,64px);
  max-width:680px;margin:0 auto;
  display:flex;flex-direction:column;align-items:center;
  text-align:center;gap:20px;
}
.cta__title{
  font-size:clamp(1.8rem,2.8vw,2.4rem);line-height:1.1;letter-spacing:-.025em;
  max-width:640px;margin:0;text-wrap:balance;font-weight:700;white-space:nowrap;
}
.cta__title em{color:var(--gold);font-style:normal}
.cta__text{color:rgba(255,255,255,.72);max-width:560px;margin:0 0 20px;font-size:1rem;line-height:1.65;text-wrap:balance}

@media (max-width:720px){
  .cta__title{white-space:normal;font-size:clamp(1.7rem,6.5vw,2.2rem)}
}

.cta__big-actions{
  display:flex;flex-direction:column;gap:14px;width:100%;max-width:460px;
  margin-top:6px;
}
.big-action{
  position:relative;overflow:hidden;
  display:flex;align-items:center;gap:18px;
  padding:20px 24px;border-radius:20px;
  background:var(--bg-3);
  border:1px solid var(--border);
  color:#fff;
  transition:transform .5s cubic-bezier(.22,1,.36,1),border-color .4s var(--ease),background .4s var(--ease),box-shadow .5s var(--ease);
}
.big-action__glow{
  position:absolute;inset:-1px;border-radius:inherit;pointer-events:none;
  background:linear-gradient(135deg,rgba(37,211,102,.4),transparent 60%);
  opacity:0;transition:opacity .4s var(--ease);
}
.big-action__icon{
  width:46px;height:46px;flex-shrink:0;
  display:grid;place-items:center;border-radius:14px;
  background:rgba(255,255,255,.05);
  transition:background .4s var(--ease),transform .5s cubic-bezier(.34,1.56,.64,1),color .4s var(--ease);
}
.big-action__content{
  display:flex;flex-direction:column;gap:2px;text-align:left;flex:1;
}
.big-action__label{
  font-family:var(--font-display);font-size:1.1rem;font-weight:700;
  letter-spacing:-.015em;color:#fff;
}
.big-action__sub{
  font-size:.78rem;color:rgba(255,255,255,.55);letter-spacing:.05em;
}
.big-action__arrow{
  width:34px;height:34px;flex-shrink:0;
  display:grid;place-items:center;border-radius:50%;
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.7);
  transition:background .4s var(--ease),color .4s var(--ease),transform .5s cubic-bezier(.22,1,.36,1);
}
.big-action:hover{translate:0 -2px}
.big-action:hover .big-action__arrow{transform:translateX(4px)}

/* WhatsApp — destacado */
.big-action--wa{
  background:linear-gradient(135deg,#25D366 0%,#128C44 100%);
  border-color:rgba(255,255,255,.14);
  box-shadow:0 20px 40px -12px rgba(37,211,102,.4),inset 0 1px 0 rgba(255,255,255,.15);
}
.big-action--wa::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.15) 50%,transparent 70%);
  transform:translateX(-100%);
  transition:transform 1s cubic-bezier(.22,1,.36,1);
}
.big-action--wa:hover{
  box-shadow:0 24px 50px -10px rgba(37,211,102,.6),inset 0 1px 0 rgba(255,255,255,.2);
}
.big-action--wa:hover::after{transform:translateX(100%)}
.big-action--wa:hover .big-action__glow{opacity:1}
.big-action--wa .big-action__icon{background:rgba(255,255,255,.18);color:#fff}
.big-action--wa:hover .big-action__icon{transform:scale(1.1) rotate(-6deg)}
.big-action--wa .big-action__label{color:#fff}
.big-action--wa .big-action__sub{color:rgba(255,255,255,.85)}
.big-action--wa .big-action__arrow{background:rgba(255,255,255,.2);color:#fff}

/* Llamar — secundario gold */
.big-action--call{
  background:rgba(255,255,255,.02);
  border-color:rgba(201,169,97,.2);
}
.big-action--call .big-action__icon{color:var(--gold)}
.big-action--call:hover{
  background:rgba(201,169,97,.06);
  border-color:rgba(201,169,97,.4);
}
.big-action--call:hover .big-action__icon{background:var(--gold);color:var(--black);transform:scale(1.08)}
.big-action--call:hover .big-action__arrow{background:var(--gold);color:var(--black)}

.cta__bullets{
  list-style:none;display:flex;flex-wrap:nowrap;justify-content:center;gap:0;
  margin:24px 0 0;padding:16px 20px;
  border-top:1px solid var(--border);
  width:100%;max-width:520px;
}
.cta__bullets li{
  display:inline-flex;align-items:center;gap:7px;
  font-size:.76rem;color:rgba(255,255,255,.65);letter-spacing:.015em;
  padding:0 clamp(6px,2vw,14px);position:relative;
  flex:0 1 auto;white-space:nowrap;
}
.cta__bullets li:not(:last-child)::after{
  content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);
  width:1px;height:12px;background:var(--border);
}
.cta__bullets svg{color:var(--gold);flex-shrink:0;width:12px;height:12px}

@media (max-width:520px){
  .cta__bullets{flex-wrap:wrap;gap:10px 0;justify-content:center;padding:14px}
  .cta__bullets li{flex:0 0 auto;width:100%;justify-content:center}
  .cta__bullets li:not(:last-child)::after{display:none}
}

.cta__form{
  padding:clamp(40px,5vw,64px);background:var(--black-soft);
  display:grid;grid-template-columns:1fr 1fr;gap:18px;
}
.field{display:flex;flex-direction:column;gap:8px}
.field--full{grid-column:1/-1}
.field--float{position:relative;padding-top:22px}
.field--float label{
  position:absolute;top:34px;left:0;pointer-events:none;
  font-size:1rem;color:rgba(255,255,255,.55);font-weight:500;letter-spacing:0;text-transform:none;
  transition:all .3s cubic-bezier(.22,1,.36,1);
  transform-origin:left top;
}
.field--float:has(input:focus) label,
.field--float:has(input:not(:placeholder-shown)) label,
.field--float:has(select:focus) label,
.field--float:has(textarea:focus) label,
.field--float:has(textarea:not(:placeholder-shown)) label,
.field--float.is-filled label{
  top:0;font-size:.7rem;color:var(--gold);letter-spacing:.16em;text-transform:uppercase;font-weight:600;
}
.field label:not(.check){font-size:.82rem;color:rgba(255,255,255,.6);letter-spacing:.04em;text-transform:uppercase;font-weight:600}
.field input,.field select,.field textarea{
  background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.18);
  padding:10px 0;color:#fff;font-size:1rem;transition:border-color .3s var(--ease);
  outline:none;border-radius:0;font-family:var(--font-sans);width:100%;
}
.field textarea{resize:vertical;min-height:80px}
.field select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--gold) 50%),linear-gradient(135deg,var(--gold) 50%,transparent 50%);background-position:calc(100% - 14px) 50%,calc(100% - 9px) 50%;background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:28px}
.field select option{background:var(--black)}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--gold)}
.cta__form .btn--full{display:inline-flex;align-items:center;justify-content:center;gap:10px}
.check{flex-direction:row;align-items:center;gap:12px;font-size:.88rem;color:rgba(255,255,255,.7)}
.check input{width:18px;height:18px;accent-color:var(--gold)}
.check a{color:var(--gold);text-decoration:underline}
.form__note{grid-column:1/-1;font-size:.88rem;color:var(--gold);min-height:1em}

/* MARQUEE — cinta infinita entre secciones */
.marquee{
  overflow:hidden;
  padding:22px 0;
  background:var(--bg-2);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  position:relative;
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  contain:layout paint;
}
.marquee__track{
  --gap:44px;
  display:inline-flex;gap:var(--gap);align-items:center;
  white-space:nowrap;
  animation:marqueeMove 50s linear infinite;
  will-change:transform;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
}
.marquee__track span{
  font-family:var(--font-display);
  font-size:clamp(1.6rem,2.8vw,2.4rem);
  font-weight:700;letter-spacing:-.02em;
  color:var(--text);
  flex-shrink:0;
}
.marquee__track span:nth-child(4n+1){color:var(--gold)}
.marquee__track i{
  width:8px;height:8px;border-radius:50%;
  background:var(--gold);flex-shrink:0;
  box-shadow:0 0 12px rgba(201,169,97,.4);
}
@keyframes marqueeMove{
  from{transform:translate3d(0,0,0)}
  to{transform:translate3d(calc(-50% - var(--gap) / 2),0,0)}
}

/* PÁGINAS LEGALES — diseño editorial premium */
.legal-body{background:var(--bg);min-height:100vh;display:flex;flex-direction:column}
.legal-body main{flex:1}
.legal{
  padding:calc(var(--nav-h) + 60px) 0 120px;
  position:relative;overflow:hidden;
}
.legal::before{
  content:"";position:absolute;top:0;left:-10%;width:70%;height:700px;
  background:radial-gradient(ellipse at top left,rgba(201,169,97,.1),transparent 60%);
  filter:blur(60px);pointer-events:none;z-index:0;
}
.legal::after{
  content:"";position:absolute;top:200px;right:-15%;width:50%;height:500px;
  background:radial-gradient(ellipse,rgba(212,180,114,.06),transparent 60%);
  filter:blur(70px);pointer-events:none;z-index:0;
}

.legal__inner{
  max-width:780px;margin:0 auto;
  position:relative;z-index:1;
  padding:0 clamp(20px,4vw,40px);
}

.legal__kicker{
  display:inline-flex;align-items:center;gap:12px;
  font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);font-weight:700;margin-bottom:18px;
  padding:8px 16px 8px 10px;
  border:1px solid rgba(201,169,97,.3);border-radius:var(--r-pill);
  background:rgba(201,169,97,.06);
}
.legal__kicker::before{
  content:"";width:8px;height:8px;border-radius:50%;
  background:var(--gold);box-shadow:0 0 10px var(--gold);
  animation:decoPulse 3s ease-in-out infinite;
}

.legal__title{
  font-family:var(--font-display);
  font-size:clamp(2.6rem,5.5vw,4.6rem);
  font-weight:800;letter-spacing:-.035em;line-height:.95;
  color:var(--text);margin:0 0 20px;
  text-wrap:balance;
}

.legal__updated{
  font-size:.86rem;color:var(--muted);letter-spacing:.02em;
  padding-bottom:48px;margin-bottom:56px;
  border-bottom:1px solid var(--border);
  position:relative;
}
.legal__updated::before{
  content:"";position:absolute;bottom:-1px;left:0;
  width:60px;height:1px;background:var(--gold);
}

.legal section{
  margin-bottom:56px;
  position:relative;
  padding-left:clamp(0px,6vw,60px);
  counter-increment:sec;
}
.legal{counter-reset:sec}
.legal section::before{
  content:counter(sec,decimal-leading-zero);
  position:absolute;left:0;top:-2px;
  font-family:var(--font-display);
  font-size:1.4rem;font-weight:800;letter-spacing:-.03em;
  color:var(--gold);opacity:.5;
  background:linear-gradient(180deg,var(--gold),rgba(201,169,97,.3));
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}

.legal h2{
  font-family:var(--font-display);
  font-size:clamp(1.35rem,2.2vw,1.6rem);font-weight:700;
  letter-spacing:-.015em;line-height:1.2;
  margin:0 0 18px;color:var(--text);
}

.legal p{
  color:rgba(255,255,255,.78);
  line-height:1.75;margin:0 0 16px;font-size:1.02rem;
  text-wrap:pretty;
}
.legal p:last-child{margin-bottom:0}

.legal ul{
  list-style:none;padding:0;margin:18px 0;
  display:flex;flex-direction:column;gap:12px;
}
.legal ul li{
  color:rgba(255,255,255,.82);
  line-height:1.65;padding:12px 16px 12px 32px;position:relative;
  font-size:.98rem;
  background:rgba(255,255,255,.02);
  border:1px solid var(--border);
  border-radius:var(--r-sm);
  transition:background .3s var(--ease),border-color .3s var(--ease),transform .3s var(--ease);
}
.legal ul li:hover{
  background:rgba(201,169,97,.04);
  border-color:rgba(201,169,97,.2);
  transform:translateX(3px);
}
.legal ul li::before{
  content:"";position:absolute;left:14px;top:1.3em;
  width:6px;height:6px;border-radius:50%;
  background:var(--gold);box-shadow:0 0 8px rgba(201,169,97,.5);
}

.legal strong{color:#fff;font-weight:600}
.legal a{
  color:var(--gold);text-decoration:none;
  border-bottom:1px solid rgba(201,169,97,.3);
  padding-bottom:1px;
  transition:color .3s,border-color .3s;
}
.legal a:hover{color:var(--gold-2);border-color:var(--gold)}

.legal__back{
  display:inline-flex;align-items:center;gap:10px;margin-top:60px;
  padding:14px 26px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.03);
  border:1px solid var(--border);
  color:var(--text);font-size:.88rem;font-weight:600;
  letter-spacing:.04em;text-transform:uppercase;
  transition:background .3s,border-color .3s,color .3s,transform .4s cubic-bezier(.22,1,.36,1);
}
.legal__back:hover{
  background:var(--gold);color:var(--black);border-color:var(--gold);
  transform:translateX(-6px);
  box-shadow:0 10px 30px -10px rgba(201,169,97,.5);
}

@media (max-width:720px){
  .legal{padding:calc(var(--nav-h) + 40px) 0 80px}
  .legal__title{font-size:clamp(2rem,9.5vw,3.2rem)}
  .legal section{padding-left:0}
  .legal section::before{
    display:block;position:static;margin-bottom:10px;
    font-size:1.1rem;
  }
  .legal h2{font-size:1.2rem}
  .legal p,.legal ul li{font-size:.95rem}
  .legal ul li{padding:10px 14px 10px 28px}
  .legal ul li::before{left:12px;top:1.1em}
}

/* FOOTER premium */
.footer{background:#060606;color:rgba(255,255,255,.7);padding:0 0 30px;border-top:1px solid var(--border);position:relative;overflow:hidden}
.footer__accent{
  position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold) 40%,var(--gold) 60%,transparent);
}
.footer__cta{
  text-align:center;
  padding:100px 0 70px;
  border-bottom:1px solid var(--border);
  position:relative;
}
.footer__cta::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse at center,rgba(201,169,97,.08),transparent 60%);
}
.footer__cta .overline{position:relative;z-index:1;color:var(--gold);margin-bottom:22px}
.footer__cta-title{
  font-family:var(--font-display);
  font-size:clamp(2.4rem,5vw,4.4rem);
  font-weight:800;line-height:1.05;letter-spacing:-.03em;
  margin-bottom:36px;color:#fff;position:relative;z-index:1;
}
.footer__cta-actions{
  display:flex;gap:14px;justify-content:center;flex-wrap:wrap;
  position:relative;z-index:1;
}
.footer__cta-actions .btn{padding:16px 32px;font-size:.95rem}
.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:56px;margin:90px 0 60px}
.footer__brand{display:flex;flex-direction:column;gap:22px}
.footer__brand .nav__logo--footer img{height:80px}
.footer__social{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap}
.footer__chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;border-radius:var(--r-pill);
  border:1px solid var(--border);
  font-size:.82rem;font-weight:600;letter-spacing:.02em;
  transition:color .3s var(--ease),border-color .3s var(--ease),background .3s var(--ease),transform .3s var(--ease),box-shadow .3s var(--ease);
}
.footer__chip svg{flex-shrink:0}
.footer__chip--call{
  color:var(--gold);border-color:rgba(201,169,97,.35);
  background:rgba(201,169,97,.06);
}
.footer__chip--call:hover{
  background:var(--gold);color:var(--black);border-color:var(--gold);
  transform:translateY(-2px);
  box-shadow:0 10px 24px -10px rgba(201,169,97,.5);
}
.footer__chip--wa{
  color:#4BDF7C;border-color:rgba(75,223,124,.35);
  background:rgba(37,211,102,.08);
}
.footer__chip--wa:hover{
  background:#25D366;color:#fff;border-color:#25D366;
  transform:translateY(-2px);
  box-shadow:0 10px 24px -10px rgba(37,211,102,.5);
}
.footer h4{font-family:var(--font-sans);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:#fff;margin-bottom:20px;font-weight:700;position:relative;padding-bottom:10px}
.footer h4::after{content:"";position:absolute;bottom:0;left:0;width:20px;height:2px;background:var(--gold)}
.footer__col-sub{margin-top:28px!important}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.footer ul a{transition:color .3s var(--ease),padding-left .3s var(--ease);font-size:.92rem;display:inline-block}
.footer ul a:hover{color:var(--gold);padding-left:8px}
.footer ul li{font-size:.92rem}
.footer ul li strong{color:rgba(255,255,255,.9);font-weight:600}
.footer__tag{font-size:.95rem;max-width:320px;line-height:1.7}
.footer__bottom{
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;align-items:center;
  padding-top:30px;border-top:1px solid var(--border-light);
  font-size:.85rem;color:rgba(255,255,255,.4);
}
.footer__signature{
  font-family:'Caveat',cursive;font-size:1.35rem;font-weight:400;
  color:rgba(255,255,255,.5);letter-spacing:.01em;
  display:inline-flex;align-items:baseline;gap:6px;
  line-height:1;
}
.footer__signature span{
  color:rgba(255,255,255,.9);font-weight:400;font-size:1.55rem;
  font-style:italic;letter-spacing:.015em;
  -webkit-text-fill-color:rgba(255,255,255,.9);
}

/* WA FLOAT */
.wa-float{
  position:fixed;right:22px;bottom:22px;z-index:40;
  width:58px;height:58px;border-radius:50%;
  background:#25D366;color:#fff;display:grid;place-items:center;
  box-shadow:0 10px 30px -5px rgba(37,211,102,.5);
  transition:transform .3s var(--ease);
}
.wa-float:hover{transform:scale(1.08)}

/* PHOTO PLACEHOLDERS */
.photo{
  background:linear-gradient(135deg,#2a2a2a 0%,#1a1a1a 100%);
  position:relative;overflow:hidden;
}
.photo::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(201,169,97,.08) 1px,transparent 1px),
    linear-gradient(90deg,rgba(201,169,97,.08) 1px,transparent 1px);
  background-size:40px 40px;
}
.photo::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 30% 20%,rgba(201,169,97,.15),transparent 60%);
}
.photo--editorial-1{background:linear-gradient(160deg,#4a4438,#1a1a1a)}
.photo--editorial-2{background:linear-gradient(200deg,#2a2a2a,#4a3f2a)}
.photo--spotlight{background:linear-gradient(225deg,#2a2a2a 0%,#0a0a0a 60%,#3a321f 100%)}
.photo--p1{background:linear-gradient(135deg,#3a3a3a,#1a1a1a)}
.photo--p2{background:linear-gradient(160deg,#2a3a4a,#0a1a2a)}
.photo--p3{background:linear-gradient(200deg,#4a3a2a,#1a1208)}
.photo--p4{background:linear-gradient(225deg,#3a3a3a,#2a2a2a)}
.photo--p5{background:linear-gradient(115deg,#4a4438,#1a1810)}
.photo--p6{background:linear-gradient(145deg,#2a2a2a,#1a1a1a)}

/* SIDE NAV — dots de sección lateral */
.side-nav{
  position:fixed;top:50%;right:24px;transform:translateY(-50%);
  z-index:70;
  display:flex;flex-direction:column;gap:20px;
  padding:18px 10px;
}
.side-nav__dot{
  position:relative;display:block;
  width:9px;height:9px;border-radius:50%;
  background:rgba(255,255,255,.2);
  transition:background .4s cubic-bezier(.22,1,.36,1),transform .4s cubic-bezier(.22,1,.36,1);
}
.side-nav__dot::after{
  content:"";position:absolute;inset:-5px;
  border:1px solid transparent;border-radius:50%;
  transition:border-color .4s,inset .4s;
}
.side-nav__dot span{
  position:absolute;right:24px;top:50%;transform:translate(6px,-50%);
  font-family:var(--font-display);
  font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  color:var(--text);
  background:rgba(10,10,10,.9);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid var(--border);
  padding:7px 14px;border-radius:var(--r-pill);
  opacity:0;pointer-events:none;white-space:nowrap;
  transition:opacity .35s cubic-bezier(.22,1,.36,1),transform .35s cubic-bezier(.22,1,.36,1);
}
.side-nav__dot:hover{background:var(--gold);transform:scale(1.3)}
.side-nav__dot:hover span{opacity:1;transform:translate(0,-50%)}
.side-nav__dot.is-active{background:var(--gold);transform:scale(1.2);box-shadow:0 0 10px rgba(201,169,97,.5)}
.side-nav__dot.is-active::after{border-color:rgba(201,169,97,.5);inset:-7px}
@media (max-width:1024px){.side-nav{display:none}}

/* CURSOR CUSTOM premium (solo desktop) */
.cursor{
  position:fixed;top:0;left:0;
  pointer-events:none;z-index:9998;
  opacity:0;transition:opacity .3s var(--ease);
}
.cursor__dot,.cursor__ring{
  position:absolute;top:0;left:0;
  border-radius:50%;
  transform:translate(-50%,-50%);
  will-change:transform;
}
.cursor__dot{
  width:6px;height:6px;background:var(--gold);
  mix-blend-mode:difference;
  box-shadow:0 0 14px rgba(201,169,97,.6);
}
.cursor__ring{
  width:38px;height:38px;
  border:1px solid rgba(201,169,97,.45);
  transition:width .35s cubic-bezier(.22,1,.36,1),height .35s cubic-bezier(.22,1,.36,1),border-color .35s var(--ease),background .35s var(--ease),opacity .35s var(--ease);
}
@media (hover:hover) and (pointer:fine){
  body.cursor-active:not(.modal-open){cursor:none}
  body.cursor-active:not(.modal-open) a,body.cursor-active:not(.modal-open) button,body.cursor-active:not(.modal-open) .service,body.cursor-active:not(.modal-open) .portfolio__item,body.cursor-active:not(.modal-open) .testimonial,body.cursor-active:not(.modal-open) .why__card,body.cursor-active:not(.modal-open) .ba__slider,body.cursor-active:not(.modal-open) .nav__toggle,body.cursor-active:not(.modal-open) .faq__item summary,body.cursor-active:not(.modal-open) .wa-float,body.cursor-active:not(.modal-open) .ba__knob,body.cursor-active:not(.modal-open) label.check{cursor:none!important}
  body.modal-open .cursor{opacity:0!important}
  .cursor.is-ready{opacity:1}
  .cursor.is-hover .cursor__ring{width:60px;height:60px;background:rgba(201,169,97,.1);border-color:var(--gold)}
  .cursor.is-click .cursor__ring{width:32px;height:32px}
}
@media (pointer:coarse),(hover:none){
  .cursor{display:none}
}

/* 3D TILT para cards */
.tilt-card{
  transform-style:preserve-3d;
  will-change:transform;
}
.tilt-card.is-tilting{transition-property:translate,box-shadow,border-color,background,color,filter,opacity!important;transition-duration:.4s!important}

/* INTRO LOAD — fade overall on first paint (sin transform para no romper position:fixed) */
@keyframes pageIn{from{opacity:0}to{opacity:1}}
body{animation:pageIn .8s ease-out both}

/* Active section dot en nav */
.nav__menu a{position:relative}
.nav__menu a.is-current{color:#fff}
.nav__menu a.is-current::before{
  content:"";position:absolute;left:-10px;top:50%;transform:translateY(-50%);
  width:4px;height:4px;border-radius:50%;
  background:var(--gold);
  box-shadow:0 0 8px var(--gold);
}

/* Focus visible premium */
:focus{outline:none}
:focus-visible{outline:2px solid var(--gold);outline-offset:4px;border-radius:4px}
.btn:focus-visible,a.btn:focus-visible{outline-offset:6px}

/* Reduced motion total support */
@media (prefers-reduced-motion:reduce){
  body{animation:none}
  .marquee__track{animation:none}
  .ambient-lights__orb{animation:none}
  .editorial__deco--ring{animation:none}
  .editorial__deco--mark{animation:none}
  .overline__dot{animation:none}
  .comparison__arrow{animation:none}
  .scroll-hero__hint{animation:none}
  .scroll-text.active{animation:none}
}

/* REVEAL — variantes multidireccionales */
.reveal{opacity:0;transform:translateY(30px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.is-visible{opacity:1;transform:translateY(0)}
.reveal--left{transform:translateX(-40px)}
.reveal--left.is-visible{transform:translateX(0)}
.reveal--right{transform:translateX(40px)}
.reveal--right.is-visible{transform:translateX(0)}
.reveal--scale{transform:scale(.92)}
.reveal--scale.is-visible{transform:scale(1)}
.reveal--tilt{transform:translateY(30px) rotate(-1deg)}
.reveal--tilt.is-visible{transform:translateY(0) rotate(0)}

/* Títulos con reveal tipo máscara (palabras que entran desde abajo) */
.split-reveal{display:block}
.split-reveal > .split-line{
  display:inline-block;overflow:hidden;vertical-align:top;padding:0 .08em;margin:0 -.08em;
}
.split-reveal > .split-line > span{display:inline-block;transform:translateY(110%);transition:transform 1.1s cubic-bezier(.2,1,.3,1)}
.split-reveal.is-visible > .split-line > span{transform:translateY(0)}
.split-reveal > .split-line:nth-child(2){transition-delay:.12s}
.split-reveal > .split-line:nth-child(3){transition-delay:.24s}

/* Barra de progreso de scroll */
.scroll-progress{
  position:fixed;top:0;left:0;right:0;height:2px;z-index:200;
  pointer-events:none;
  background:linear-gradient(90deg,transparent,var(--gold) 50%,transparent);
  transform-origin:left;
  transform:scaleX(var(--progress,0));
  transition:opacity .3s;
  box-shadow:0 0 16px rgba(201,169,97,.6);
}

/* Punto dorado en overlines */
.overline__dot{color:var(--gold);margin-right:8px;font-size:.7em;letter-spacing:0;display:inline-block;vertical-align:middle;transform:translateY(-1px);animation:pulseDot 3s ease-in-out infinite}
@keyframes pulseDot{
  0%,100%{opacity:.6;transform:scale(1)}
  50%{opacity:1;transform:scale(1.2)}
}

/* Parallax */
[data-parallax]{will-change:translate}

/* Smooth scroll — Lenis lo controla; solo padding para anchors */
html{scroll-padding-top:calc(var(--nav-h) + 16px)}
html.lenis{height:auto}
html.lenis-smooth{scroll-behavior:auto!important}
html.lenis-smooth body{overflow:hidden auto}
html.lenis-scrolling iframe{pointer-events:none}

/* Selection */
::selection{background:var(--gold);color:var(--black)}

/* Scrollbar — ocultar en móvil / táctil */
html,body{scrollbar-width:none;-ms-overflow-style:none}
html::-webkit-scrollbar,body::-webkit-scrollbar,*::-webkit-scrollbar{display:none;width:0;height:0}

/* Desktop con pointer fino: scrollbar sutil */
@media (hover:hover) and (pointer:fine){
  html,body{scrollbar-width:thin;scrollbar-color:var(--bg-3) var(--bg)}
  html::-webkit-scrollbar,body::-webkit-scrollbar{display:block;width:10px}
  html::-webkit-scrollbar-track,body::-webkit-scrollbar-track{background:var(--bg)}
  html::-webkit-scrollbar-thumb,body::-webkit-scrollbar-thumb{background:var(--bg-3);border-radius:5px;border:2px solid var(--bg)}
  html::-webkit-scrollbar-thumb:hover,body::-webkit-scrollbar-thumb:hover{background:var(--gold)}
}

/* Optimizaciones de performance */
img[loading="lazy"]{opacity:0;transition:opacity .6s var(--ease)}
img[loading="lazy"].is-loaded,img:not([loading]){opacity:1}

/* content-visibility sobre secciones pesadas — se renderizan solo cerca del viewport */
.services,.comparison,.testimonials,.why,.portfolio,.faq,.cta,.footer{
  content-visibility:auto;
  contain-intrinsic-size:auto 900px;
}

/* GPU hints para elementos animados */
.marquee__track,.ambient-lights__orb{will-change:transform}
.portfolio__item,.ba__slider,.editorial__photo,.spotlight__photo{contain:paint}

/* Shine sweep en botones */
.btn{position:relative;overflow:hidden}
.btn::before{
  content:"";position:absolute;top:0;left:-60%;
  width:40%;height:100%;
  background:linear-gradient(120deg,transparent 20%,rgba(255,255,255,.2) 50%,transparent 80%);
  transform:skewX(-20deg);
  transition:left .8s cubic-bezier(.2,1,.3,1);
  pointer-events:none;
}
.btn:hover::before{left:140%}

/* Section head relative para decoraciones */
.section-head{position:relative}

/* RESPONSIVE */
@media (max-width:1024px){
  .editorial{padding:100px 0 80px}
  .editorial__layout{grid-template-columns:1fr;gap:48px}
  .editorial__text-col{align-items:center;text-align:center}
  .editorial__visual{max-width:540px;margin:0 auto;min-height:480px}
  .editorial__title{font-size:clamp(2.2rem,6vw,3.6rem)}
  .comparison__grid{grid-template-columns:1fr 1fr;gap:28px}
  .portfolio__item{height:min(60vh,540px)}
  .services__grid{grid-template-columns:repeat(2,1fr)}
  .process__list{grid-template-columns:repeat(2,1fr)}
  .why__cards{grid-template-columns:repeat(2,1fr)}
  .testimonials__grid{grid-template-columns:1fr 1fr;gap:18px;margin-bottom:50px}
  .testimonial--featured{grid-column:1/-1}
  .faq__grid,.spotlight__block,.cta__block{grid-template-columns:1fr}
  .faq__head{position:static}
  .spotlight__photo{min-height:360px;aspect-ratio:16/10}
  .footer__grid{grid-template-columns:1fr 1fr;gap:40px}
  .footer__brand{grid-column:1/-1}
  .cta__form{grid-template-columns:1fr}
  .trust__grid{grid-template-columns:repeat(7,auto);gap:0;padding:30px 20px}
  .trust__item{padding:0 clamp(10px,2vw,22px)}
  .trust__sep{height:56px}
}

@media (max-width:720px){
  :root{--nav-h:62px}
  .container{padding:0 18px}

  /* NAV */
  .nav__inner{display:flex;grid-template-columns:none;justify-content:space-between;align-items:center;padding:0 16px;gap:12px}
  .nav__logo{justify-self:auto}
  .nav__logo .nav__logo__img{height:38px}
  .nav__logo--footer img{height:68px}
  .nav__menu{display:none;position:absolute;top:100%;left:0;right:0;background:rgba(12,12,12,.96);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-top:1px solid var(--border);padding:24px;flex-direction:column;gap:18px;box-shadow:0 20px 60px -20px rgba(0,0,0,.6);justify-self:auto}
  .nav__menu.is-open{display:flex}
  .nav__menu a{font-size:.88rem;letter-spacing:.18em;color:rgba(255,255,255,.8)}
  .nav__menu a:hover{color:#fff}
  .nav__toggle{display:flex;justify-self:auto}
  .nav__cta{display:none}

  /* Section heads / títulos — jerarquía reforzada */
  .section-head{margin:0 auto 36px}
  .section-title{font-size:clamp(2.3rem,10vw,3.4rem);line-height:1;letter-spacing:-.035em;font-weight:800}
  .section-sub{font-size:.9rem;line-height:1.55;color:var(--muted)}
  .overline{font-size:.7rem}

  /* HERO scroll video */
  .scroll-video-wrapper{height:240vh}
  .scroll-hero__video{object-fit:cover;object-position:60% center}
  /* Overlay suave en móvil para legibilidad sin apagar el vídeo */
  .scroll-hero__vignette{
    display:block;position:absolute;inset:0;pointer-events:none;z-index:12;
    background:
      linear-gradient(180deg,rgba(0,0,0,.35) 0%,rgba(0,0,0,.12) 35%,rgba(0,0,0,.18) 65%,rgba(0,0,0,.5) 100%),
      radial-gradient(120% 80% at 20% 40%,rgba(0,0,0,.28) 0%,rgba(0,0,0,0) 65%);
  }
  .scroll-text{padding:0 22px}
  .scroll-text--center{align-items:center;text-align:center;justify-content:center;padding-top:4vh}
  .scroll-text--left{align-items:flex-start;text-align:left;justify-content:flex-end;padding-bottom:14vh}
  .scroll-text--right{align-items:flex-start;text-align:left;justify-content:flex-start;padding-top:calc(var(--nav-h) + 3vh)}
  .scroll-text__title{font-size:clamp(2.4rem,10vw,3.6rem);line-height:.95;text-shadow:0 2px 4px rgba(0,0,0,.95),0 6px 24px rgba(0,0,0,.85),0 14px 50px rgba(0,0,0,.7)}
  .scroll-text--center .scroll-text__title{font-size:clamp(1.9rem,7.6vw,2.8rem);white-space:nowrap;letter-spacing:-.04em}
  /* Big-num con acabado metálico como en desktop */
  .scroll-text__title .big-num{
    font-size:1.35em;line-height:.82;letter-spacing:-.065em;
    background:linear-gradient(180deg,#E8C77A 0%,#C9A961 45%,#A98748 100%);
    -webkit-background-clip:text;background-clip:text;
    -webkit-text-fill-color:transparent;color:transparent;
    filter:drop-shadow(0 2px 4px rgba(0,0,0,.95)) drop-shadow(0 6px 16px rgba(0,0,0,.7)) drop-shadow(0 0 22px rgba(201,169,97,.25));
    text-shadow:none;
  }
  .scroll-text__body{font-size:1rem;max-width:100%;line-height:1.5;text-shadow:0 2px 4px rgba(0,0,0,.98),0 4px 18px rgba(0,0,0,.9)}
  .scroll-text__tag{margin-top:14px;font-size:.76rem;letter-spacing:.22em;gap:10px;flex-wrap:wrap;text-shadow:0 2px 4px rgba(0,0,0,.98),0 4px 14px rgba(0,0,0,.9)}
  .scroll-text__tag-line{width:22px}
  .scroll-text__index{margin-bottom:14px}
  .scroll-text__body{margin-top:14px}

  /* TRUST bar + certifications */
  .trust{padding:20px 0 50px}
  .trust__grid{
    grid-template-columns:1fr 1fr;
    gap:0;padding:8px;border-radius:22px;
    align-items:stretch;justify-content:stretch;
  }
  .trust__sep{display:none}
  .trust__item{
    padding:22px 12px;
    border:1px solid transparent;
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
    min-height:110px;
  }
  .trust__item:nth-child(1),.trust__item:nth-child(3){border-right:1px solid var(--border)}
  .trust__item:nth-child(1),.trust__item:nth-child(3),.trust__item:nth-child(5){border-right:1px solid var(--border)}
  .trust__item:nth-child(1),.trust__item:nth-child(3){border-bottom:1px solid var(--border)}
  .trust__num{font-size:clamp(1.7rem,8vw,2.2rem)}
  .trust__label{
    font-size:.58rem;letter-spacing:.2em;line-height:1.3;
    max-width:100px;text-wrap:balance;
  }

  .certifications{
    display:grid;grid-template-columns:1fr 1fr;gap:0;
    border-radius:22px;max-width:none;margin:0 12px 20px;padding:6px;
    background:rgba(255,255,255,.025);
  }
  .cert{
    font-size:.68rem;letter-spacing:.04em;
    padding:14px 10px;justify-content:center;
    border:1px solid transparent;
    min-height:54px;text-align:center;gap:8px;
    line-height:1.2;
  }
  .cert:nth-child(1),.cert:nth-child(3){border-right:1px solid var(--border)}
  .cert:nth-child(1),.cert:nth-child(2){border-bottom:1px solid var(--border)}
  .cert svg{width:14px;height:14px;flex-shrink:0}

  /* EDITORIAL */
  .editorial{padding:70px 0 50px}
  .editorial__layout{gap:36px}
  .editorial__text-col{gap:16px}
  .editorial__title{font-size:clamp(2.4rem,10.5vw,3.4rem);line-height:1;letter-spacing:-.035em;font-weight:800}
  .editorial__text{font-size:.9rem;line-height:1.6;color:var(--muted)}
  .editorial__visual{
    position:relative;aspect-ratio:1/1;min-height:auto;
    max-width:380px;margin:0 auto;width:calc(100% - 48px);
  }
  .editorial__photo--main{
    width:70%;height:72%;
    top:0;left:10%;
    border-radius:160px 18px 18px 18px;
  }
  .editorial__photo--accent{
    width:55%;height:48%;
    bottom:0;right:0;
    border-radius:18px;
  }
  .editorial__badge{
    width:70px;height:70px;
    left:0;top:auto;bottom:14%;
    transform:none;
    z-index:5;
  }
  .editorial__badge-num{font-size:1.2rem}
  .editorial__badge-lbl{font-size:.56rem;letter-spacing:.16em;margin-top:2px}
  .editorial__deco--ring{
    width:66px;height:66px;
    top:6%;right:4%;
  }
  .editorial__deco--mark{display:none}
  .editorial__cta{width:100%;justify-content:center}

  /* COMPARISON */
  .comparison{padding:50px 0 70px}
  .comparison__grid{grid-template-columns:1fr;gap:30px}
  .ba__slider{aspect-ratio:3/4}
  .ba__knob{width:46px;height:46px}
  .ba__knob svg{width:18px;height:18px}
  .ba__label{padding:5px 11px;font-size:.62rem;top:14px}
  .ba__label--before{left:14px}
  .ba__label--after{right:14px}
  .ba__title{font-size:.92rem}

  /* MARQUEE */
  .marquee{padding:14px 0}
  .marquee__track{gap:28px}
  .marquee__track span{font-size:clamp(1.2rem,5.5vw,1.7rem)}
  .marquee__track i{width:6px;height:6px}

  /* TESTIMONIALS */
  .testimonials{padding:60px 0}
  .testimonials__grid{grid-template-columns:1fr;max-width:520px;gap:16px;margin:0 auto 40px}
  .testimonial{padding:26px 22px 20px}
  .testimonial__quote{font-size:3.6rem}
  .testimonial__text{font-size:.92rem;line-height:1.55}
  .testimonial__author strong{font-size:.88rem}
  .testimonial__author span{font-size:.74rem}
  .testimonials__rating{padding:14px 22px;gap:14px}
  .testimonials__rating-num{font-size:1.7rem}

  /* SERVICES */
  .services{margin:0 12px;padding:60px 0;border-radius:22px}
  .services__grid{grid-template-columns:1fr;gap:14px}
  .service{padding:28px 24px 50px}
  .service h3{font-size:1.05rem}
  .service p{font-size:.86rem;line-height:1.55}
  .service__icon{width:48px;height:48px}
  .service__icon img{width:42px;height:42px}

  /* SPOTLIGHT */
  .spotlight{padding:60px 0}
  .spotlight__block{grid-template-columns:1fr;min-height:auto}
  .spotlight__content{padding:36px 28px 30px;gap:16px}
  .spotlight__title{font-size:clamp(2.3rem,10vw,3.2rem);line-height:1;letter-spacing:-.035em;font-weight:800}
  .spotlight__text{font-size:.9rem;line-height:1.6}
  .spotlight__photo{min-height:300px;aspect-ratio:5/4}

  /* PROCESS */
  .process{padding:60px 0}
  .process__list{grid-template-columns:1fr;gap:14px}
  .process__list::before{display:none}
  .process__step{padding:32px 26px 24px}
  .process__num{font-size:3rem;margin-top:-10px;margin-bottom:4px}
  .process__step h3{font-size:1.08rem}

  /* WHY */
  .why{padding:60px 0}
  .why__cards{grid-template-columns:1fr;gap:12px}
  .why__card{padding:28px 24px}
  .why__num{font-size:2.4rem;margin-bottom:12px}
  .why__card h3{font-size:1.1rem}
  .why__card p{font-size:.86rem;line-height:1.55}

  /* PORTFOLIO */
  .portfolio{padding:60px 0 0}
  .portfolio__scroll{height:auto;margin-top:24px}
  .portfolio__sticky{position:static;height:auto;border:none}
  .portfolio__track{flex-direction:column;padding:20px 16px;gap:14px;transform:none!important}
  .portfolio__item{width:100%;height:auto;aspect-ratio:4/5!important}
  .portfolio__item figcaption{left:18px;right:18px;bottom:18px}
  .portfolio__progress{display:none}

  /* FAQ */
  .faq{padding:60px 0}
  .faq__grid{grid-template-columns:1fr;gap:28px}
  .faq__head{position:static;text-align:center}
  .faq__head .overline{text-align:center;display:block}
  .faq__head .section-title{text-align:center}
  .faq__head .section-sub{text-align:center}
  .faq__item summary{font-size:1rem;padding:22px 52px 22px 0}
  .faq__item summary::after{width:28px;height:28px;right:6px}
  .faq__item p{font-size:.95rem}

  /* CTA form */
  .cta{padding:30px 0 70px}
  .cta__block{grid-template-columns:1fr}
  .cta__content{padding:40px 28px 30px;gap:16px}
  .cta__title{font-size:clamp(2.3rem,10vw,3.2rem);line-height:1;letter-spacing:-.035em;font-weight:800}
  .cta__text{font-size:.9rem;line-height:1.6}
  .cta__form{grid-template-columns:1fr;padding:32px 28px;gap:18px}
  .cta__phone{font-size:1.25rem}

  /* FOOTER */
  .footer__cta{padding:110px 24px 60px;position:relative}
  .footer__cta .overline{margin-bottom:26px;margin-top:0;font-size:.68rem;letter-spacing:.3em;display:block}
  .footer__accent{background:linear-gradient(90deg,transparent,rgba(201,169,97,.4) 40%,rgba(201,169,97,.4) 60%,transparent)}
  .footer__cta-title{font-size:clamp(2.3rem,9.5vw,3.2rem);line-height:1;letter-spacing:-.035em;font-weight:800;margin-bottom:32px}
  .footer__cta-actions{flex-direction:column;width:100%;gap:12px;max-width:320px;margin:0 auto}
  .footer__cta-actions .btn{width:100%;padding:18px 24px}
  .footer__grid{grid-template-columns:1fr;gap:36px;margin:40px 0 30px}
  .footer__col-sub{margin-top:24px!important}
  .footer__bottom{justify-content:center;text-align:center;flex-direction:column;gap:8px}

  /* WA float */
  .wa-float{width:52px;height:52px;right:16px;bottom:16px}
  .wa-float svg{width:24px;height:24px}
}

@media (max-width:480px){
  .scroll-video-wrapper{height:210vh}
  .container{padding:0 14px}
  .trust__grid{padding:24px 16px;gap:22px 10px}
  .trust__num{font-size:1.7rem}
  .certifications{padding:12px 14px;gap:8px 14px}
  .cert{font-size:.65rem}
  .cert svg{width:14px;height:14px}
  .editorial__visual{max-width:320px;width:calc(100% - 32px)}
  .editorial__badge{width:60px;height:60px;left:-4px}
  .editorial__badge-num{font-size:1.1rem}
  .editorial__badge-lbl{font-size:.52rem}
  .editorial__deco--ring{width:56px;height:56px}
  .testimonial__quote{font-size:3.4rem}
  .process__num{font-size:2.6rem}
  .why__num{font-size:1.9rem}
  .ba__knob{width:40px;height:40px}
  .ba__label{padding:4px 10px;font-size:.58rem}
  .service{padding:26px 22px 48px}
  .marquee__track span{font-size:clamp(1rem,5vw,1.4rem)}
  .marquee__track{gap:20px}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .reveal{opacity:1;transform:none}
  .scroll-video-wrapper{height:auto}
  .scroll-hero{position:relative;height:auto;aspect-ratio:16/9}
  .scroll-hero__video{position:relative}
  .scroll-hero__hint{display:none}
  .scroll-text{display:none}
  .page-content{opacity:1;transform:none}
  .scroll-video-progress{display:none}
}
