/* =====================================================================
   KRISTIE'S VISUAL — Sitio definitivo
   Paleta tomada del logo oficial
   ===================================================================== */
:root{
  --purple:        #8c5f9b;
  --purple-deep:   #5d3c6a;
  --purple-ink:    #3e2a47;
  --gold:          #eec756;
  --gold-deep:     #d8ab33;
  --teal:          #548a8c;
  --lilac:         #bc9dca;
  --cream:         #fbeed6;
  --paper:         #fdf8ef;
  --paper-2:       #f6ecdc;
  --white:         #fffffd;
  --ink:           #3a2c40;
  --muted:         #7c6a82;

  --shadow-sm: 0 4px 18px rgba(93,60,106,.10);
  --shadow-md: 0 18px 50px rgba(93,60,106,.16);
  --shadow-lg: 0 40px 90px rgba(93,60,106,.22);

  --r-sm: 14px;
  --r-md: 22px;
  --r-lg: 34px;

  --serif: 'Playfair Display', Georgia, serif;
  --sans:  'Poppins', system-ui, -apple-system, sans-serif;

  --ease: cubic-bezier(.22,1,.36,1);
  --container: 1240px;
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul,ol{ list-style:none; }

::selection{ background:var(--gold); color:var(--purple-ink); }

/* ---------- Layout helpers ---------- */
.section{
  max-width:var(--container);
  margin-inline:auto;
  padding:clamp(70px,9vw,130px) clamp(20px,5vw,40px);
}
.section__head{ max-width:760px; margin:0 auto clamp(40px,6vw,68px); text-align:center; }
.kicker{
  display:inline-flex; align-items:center; gap:.55em;
  font-weight:600; font-size:.82rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--teal); margin-bottom:18px;
}
.kicker__star{ color:var(--gold); font-size:1.1em; }
.section__title{
  font-family:var(--serif); font-weight:800;
  font-size:clamp(2rem,4.6vw,3.5rem); line-height:1.08; letter-spacing:-.02em;
  color:var(--purple-ink);
}
.section__title em{ font-style:italic; color:var(--purple); }
.section__sub{ margin-top:18px; color:var(--muted); font-size:clamp(1rem,1.5vw,1.12rem); }

/* =====================================================================
   BUTTONS
   ===================================================================== */
.btn{
  --bg:var(--purple); --fg:#fff;
  position:relative; display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--sans); font-weight:600; font-size:.97rem;
  padding:15px 28px; border-radius:100px; border:none; cursor:pointer;
  background:var(--bg); color:var(--fg);
  transition:transform .4s var(--ease), box-shadow .4s var(--ease), background .3s;
  will-change:transform; isolation:isolate; white-space:nowrap;
}
.btn svg{ flex:none; }
.btn::before{
  content:""; position:absolute; inset:0; border-radius:inherit; z-index:-1;
  background:linear-gradient(120deg, rgba(255,255,255,.35), rgba(255,255,255,0) 60%);
  opacity:0; transition:opacity .4s;
}
.btn:hover{ transform:translateY(-3px); box-shadow:var(--shadow-md); }
.btn:hover::before{ opacity:1; }
.btn:active{ transform:translateY(-1px) scale(.98); }

.btn--purple{ --bg:var(--purple); box-shadow:0 10px 30px rgba(140,95,155,.35); }
.btn--gold{ --bg:var(--gold); --fg:var(--purple-ink); box-shadow:0 10px 30px rgba(238,199,86,.4); }
.btn--ghost{ --bg:transparent; --fg:var(--purple-deep); border:1.6px solid rgba(140,95,155,.35); }
.btn--ghost:hover{ background:var(--purple); color:#fff; border-color:var(--purple); }
.btn--ghost-light{ --bg:transparent; --fg:#fff; border:1.6px solid rgba(255,255,255,.5); }
.btn--ghost-light:hover{ background:#fff; color:var(--purple-deep); border-color:#fff; }
.btn--lg{ padding:18px 36px; font-size:1.05rem; }

/* =====================================================================
   PRELOADER
   ===================================================================== */
.preloader{
  position:fixed; inset:0; z-index:9999;
  display:grid; place-content:center; gap:26px; justify-items:center;
  background:var(--paper);
  transition:opacity .7s var(--ease), visibility .7s;
}
.preloader.is-done{ opacity:0; visibility:hidden; }
.preloader__awning{ display:flex; }
.preloader__awning span{
  width:42px; height:30px; border-radius:0 0 42% 42%/0 0 100% 100%;
  transform:scaleY(0); transform-origin:top;
  animation:scallop .6s var(--ease) forwards;
}
.preloader__awning span:nth-child(odd){ background:var(--lilac); }
.preloader__awning span:nth-child(even){ background:var(--cream); }
.preloader__awning span:nth-child(1){ animation-delay:.05s; }
.preloader__awning span:nth-child(2){ animation-delay:.13s; }
.preloader__awning span:nth-child(3){ animation-delay:.21s; }
.preloader__awning span:nth-child(4){ animation-delay:.29s; }
.preloader__awning span:nth-child(5){ animation-delay:.37s; }
@keyframes scallop{ to{ transform:scaleY(1); } }
.preloader__mark{
  font-family:var(--serif); font-size:1.5rem; color:var(--purple-deep);
  opacity:0; animation:fadeUp .6s .4s var(--ease) forwards;
}
.preloader__mark em{ font-style:italic; color:var(--gold-deep); }
@keyframes fadeUp{ from{opacity:0; transform:translateY(12px);} to{opacity:1; transform:none;} }

/* =====================================================================
   CUSTOM CURSOR
   ===================================================================== */
.cursor-dot,.cursor-ring{
  position:fixed; top:0; left:0; z-index:9000; pointer-events:none;
  border-radius:50%; mix-blend-mode:normal;
  transform:translate(-50%,-50%);
}
.cursor-dot{ width:7px; height:7px; background:var(--purple); transition:opacity .3s; }
.cursor-ring{
  width:38px; height:38px; border:1.6px solid rgba(140,95,155,.5);
  transition:width .3s var(--ease), height .3s var(--ease), background .3s, border-color .3s, opacity .3s;
}
.cursor-ring.is-hover{ width:64px; height:64px; background:rgba(238,199,86,.16); border-color:var(--gold); }
.cursor-ring.is-cta{ width:74px; height:74px; background:rgba(140,95,155,.18); border-color:var(--purple); }
.cursor-ring.is-view::after{ content:"Ver"; font-family:var(--sans); font-size:.62rem; font-weight:600; color:var(--purple-deep); letter-spacing:.05em; }
.cursor-ring{ display:grid; place-content:center; }
@media (hover:none), (pointer:coarse){ .cursor-dot,.cursor-ring{ display:none; } }

/* =====================================================================
   SCROLL PROGRESS
   ===================================================================== */
.scroll-progress{
  position:fixed; top:0; left:0; height:3px; width:0%; z-index:8000;
  background:linear-gradient(90deg,var(--purple),var(--gold));
}

/* =====================================================================
   NAVBAR
   ===================================================================== */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  transition:transform .45s var(--ease), background .4s, box-shadow .4s, backdrop-filter .4s;
}
.nav.is-hidden{ transform:translateY(-110%); }
.nav.is-scrolled{
  background:rgba(253,248,239,.82); backdrop-filter:blur(14px) saturate(1.2);
  box-shadow:0 6px 30px rgba(93,60,106,.08);
}
.nav__inner{
  max-width:var(--container); margin-inline:auto;
  display:flex; align-items:center; gap:22px;
  padding:30px clamp(20px,5vw,40px) 16px; transition:padding .4s;
}
.nav.is-scrolled .nav__inner{ padding-block:12px; }
.nav__logo img{ height:46px; width:auto; transition:height .4s; }
.nav.is-scrolled .nav__logo img{ height:40px; }
.nav__links{ display:flex; gap:6px; margin-left:auto; }
.nav__link{
  position:relative; padding:8px 14px; font-weight:500; font-size:.95rem; color:var(--purple-ink);
  border-radius:100px; transition:color .3s;
}
.nav__link::after{
  content:""; position:absolute; left:14px; right:14px; bottom:4px; height:2px;
  background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform .35s var(--ease);
}
.nav__link:hover{ color:var(--purple); }
.nav__link:hover::after{ transform:scaleX(1); }
.nav__cta{ padding:11px 22px; }
.nav__burger{ display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:6px; }
.nav__burger span{ width:24px; height:2px; background:var(--purple-deep); border-radius:2px; transition:.3s var(--ease); }
.nav__burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav__burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav__burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* =====================================================================
   AWNING (toldo) MOTIF — firma de marca
   ===================================================================== */
.awning{
  --scallop:46px;
  height:30px; width:100%;
  background:
    radial-gradient(circle at 50% 0, var(--lilac) 0 49%, transparent 51%) 0 0/var(--scallop) 100% repeat-x;
}
.awning--top{ position:absolute; top:0; left:0; }
.awning--light{ filter:none; opacity:.9; }
.awning::after{
  /* franjas alternas crema sobre lila para el efecto rayado del toldo */
  content:""; display:block; height:100%; width:100%;
  background:
    radial-gradient(circle at 50% 0, var(--cream) 0 49%, transparent 51%) calc(var(--scallop)/2) 0/var(--scallop) 100% repeat-x;
}

/* =====================================================================
   HERO
   ===================================================================== */
.hero{
  position:relative; overflow:hidden;
  padding:clamp(120px,16vh,180px) clamp(20px,5vw,40px) clamp(70px,9vw,110px);
  background:linear-gradient(180deg,#fdf8ef 0%, #f7edde 100%);
}
.hero__mesh{ position:absolute; inset:0; z-index:0; filter:blur(60px); opacity:.85; }
.blob{ position:absolute; border-radius:50%; }
.hero__mesh .blob--1{ width:540px; height:540px; top:-140px; right:-80px; background:radial-gradient(circle,var(--lilac),transparent 70%); animation:float1 14s ease-in-out infinite; }
.hero__mesh .blob--2{ width:460px; height:460px; bottom:-160px; left:-120px; background:radial-gradient(circle,rgba(84,138,140,.5),transparent 70%); animation:float2 17s ease-in-out infinite; }
.hero__mesh .blob--3{ width:380px; height:380px; top:30%; left:38%; background:radial-gradient(circle,rgba(238,199,86,.45),transparent 70%); animation:float3 12s ease-in-out infinite; }
@keyframes float1{ 50%{ transform:translate(-40px,40px) scale(1.1);} }
@keyframes float2{ 50%{ transform:translate(50px,-30px) scale(1.08);} }
@keyframes float3{ 50%{ transform:translate(-30px,-40px) scale(1.12);} }

.hero .awning--top{ z-index:3; }

.hero__inner{
  position:relative; z-index:2;
  max-width:var(--container); margin-inline:auto;
  display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(30px,5vw,60px); align-items:center;
}

.eyebrow{
  display:inline-flex; align-items:center; gap:.6em;
  background:rgba(255,255,255,.7); border:1px solid rgba(140,95,155,.18);
  padding:8px 16px; border-radius:100px;
  font-size:.8rem; font-weight:600; letter-spacing:.06em; color:var(--purple-deep);
  box-shadow:var(--shadow-sm);
}
.eyebrow__dot{ width:8px; height:8px; border-radius:50%; background:var(--teal); box-shadow:0 0 0 4px rgba(84,138,140,.18); animation:pulseDot 2s infinite; }
@keyframes pulseDot{ 50%{ box-shadow:0 0 0 7px rgba(84,138,140,0);} }

.hero__title{
  font-family:var(--serif); font-weight:800;
  font-size:clamp(2.6rem,6.4vw,5.1rem); line-height:1.02; letter-spacing:-.025em;
  color:var(--purple-ink); margin:24px 0 22px;
}
.hero__title .line{ display:block; overflow:hidden; }
.hero__title .w{
  display:inline-block;
  transition:transform .9s var(--ease);
}
.js .hero__title .w{ transform:translateY(110%); }
.hero__title .w.accent{ color:var(--purple-deep); font-style:italic; position:relative; z-index:1; }
.hero__title .w.accent::after{
  content:""; position:absolute; left:-.05em; right:-.05em; bottom:.04em; height:.26em; z-index:-1;
  background:rgba(238,199,86,.55); border-radius:6px; transform:scaleX(0); transform-origin:left;
  transition:transform .8s 1s var(--ease);
}
.is-loaded .hero__title .w{ transform:translateY(0); }
.is-loaded .hero__title .w.accent::after{ transform:scaleX(1); }
.hero__title .line:nth-child(1) .w{ transition-delay:.15s; }
.hero__title .line:nth-child(2) .w{ transition-delay:.28s; }
.hero__title .line:nth-child(3) .w{ transition-delay:.4s; }

.hero__lead{ max-width:520px; color:var(--muted); font-size:clamp(1.02rem,1.6vw,1.18rem); }
.hero__actions{ display:flex; flex-wrap:wrap; gap:14px; margin:30px 0 36px; }

.hero__stats{ display:flex; gap:clamp(20px,4vw,46px); flex-wrap:wrap; }
.hero__stats li{ display:flex; flex-direction:column; }
.hero__stats strong{ font-family:var(--serif); font-weight:800; font-size:clamp(1.7rem,3vw,2.3rem); color:var(--purple); line-height:1; }
.hero__stats span{ font-size:.82rem; color:var(--muted); margin-top:4px; }

/* Hero visual */
.hero__visual{ position:relative; min-height:440px; display:grid; place-items:center; }
.hero__glow{
  position:absolute; width:115%; aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.9), rgba(255,255,255,0) 65%);
  z-index:0;
}
.hero__product{ position:relative; z-index:1; filter:drop-shadow(0 30px 50px rgba(93,60,106,.3)); }
.hero__product--main{ width:min(100%,560px); animation:floaty 6s ease-in-out infinite; }
.hero__product--float{
  position:absolute; bottom:-6%; right:-2%; width:46%; z-index:2;
  filter:drop-shadow(0 24px 34px rgba(93,60,106,.34)); animation:floaty 5s ease-in-out infinite reverse;
}
@keyframes floaty{ 50%{ transform:translateY(-16px);} }

.hero__badge{
  position:absolute; z-index:4;
  display:flex; align-items:center; gap:9px;
  background:rgba(255,255,255,.9); backdrop-filter:blur(8px);
  padding:11px 16px; border-radius:100px; box-shadow:var(--shadow-md);
  font-weight:600; font-size:.84rem; color:var(--purple-deep);
  border:1px solid rgba(255,255,255,.8);
}
.hero__badge svg{ color:var(--teal); }
.hero__badge--uv{ top:8%; left:-4%; animation:floaty 7s ease-in-out infinite; }
.hero__badge--canvas{ bottom:14%; left:-6%; animation:floaty 6.5s 1s ease-in-out infinite reverse; }
.hero__badge--canvas svg{ color:var(--gold-deep); }

.hero__scroll{
  position:relative; z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  width:max-content; margin:50px auto 0;
  font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted);
}
.hero__scroll-line{ width:1.5px; height:46px; background:linear-gradient(var(--purple),transparent); position:relative; overflow:hidden; }
.hero__scroll-line::after{ content:""; position:absolute; top:-50%; left:0; width:100%; height:50%; background:var(--gold); animation:scrolldown 1.8s var(--ease) infinite; }
@keyframes scrolldown{ to{ top:100%; } }

/* =====================================================================
   MARQUEE
   ===================================================================== */
.marquee-sec{ padding:clamp(40px,6vw,64px) 0; background:var(--white); border-block:1px solid rgba(140,95,155,.1); overflow:hidden; }
.marquee-sec__label{ text-align:center; color:var(--muted); font-size:.8rem; letter-spacing:.18em; text-transform:uppercase; margin-bottom:30px; }
.marquee{ position:relative; -webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); }
.marquee__track{ display:flex; gap:54px; align-items:center; width:max-content; animation:scrollx 38s linear infinite; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
.marquee__track img{
  height:88px; width:auto; object-fit:contain;
  filter:grayscale(1) opacity(.55); transition:filter .4s, transform .4s;
}
.marquee__track img:hover{ filter:none; transform:scale(1.08); }
@keyframes scrollx{ to{ transform:translateX(-50%); } }

/* =====================================================================
   PRODUCTOS
   ===================================================================== */
.prod-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.prod-card{
  background:var(--white); border-radius:var(--r-md); overflow:hidden;
  box-shadow:var(--shadow-sm); border:1px solid rgba(140,95,155,.08);
  display:flex; flex-direction:column; transition:box-shadow .5s var(--ease);
  transform-style:preserve-3d;
}
.prod-card:hover{ box-shadow:var(--shadow-lg); }
.prod-card__media{
  aspect-ratio:4/3.2; display:grid; place-items:center; overflow:hidden; position:relative;
  background:linear-gradient(160deg,var(--cream),#fff);
}
.prod-card__media::before{
  content:""; position:absolute; inset:0; opacity:.5;
  background:radial-gradient(circle at 50% 120%, rgba(140,95,155,.16), transparent 60%);
}
.prod-card__media img{ width:84%; object-fit:contain; transition:transform .6s var(--ease); position:relative; z-index:1; }
.prod-card:hover .prod-card__media img{ transform:scale(1.07) translateY(-4px); }
.prod-card__media--arana img{ width:100%; height:100%; object-fit:cover; object-position:center 42%; }
.prod-card__media--photo{
  background-image:var(--bg); background-size:cover; background-position:center;
  transition:transform .6s var(--ease);
}
.prod-card:hover .prod-card__media--photo{ transform:scale(1.05); }
.prod-card__body{ padding:22px 22px 26px; display:flex; flex-direction:column; gap:10px; flex:1; }
.prod-card__tag{
  align-self:flex-start; font-size:.68rem; font-weight:600; letter-spacing:.07em; text-transform:uppercase;
  color:var(--teal); background:rgba(84,138,140,.12); padding:5px 11px; border-radius:100px;
}
.prod-card__tag--gold{ color:var(--gold-deep); background:rgba(238,199,86,.18); }
.prod-card__body h3{ font-family:var(--serif); font-size:1.4rem; font-weight:700; color:var(--purple-ink); }
.prod-card__body > p{ font-size:.9rem; color:var(--muted); }
.prod-card__feats{ display:flex; flex-wrap:wrap; gap:7px; margin-top:2px; }
.prod-card__feats li{ font-size:.72rem; color:var(--purple-deep); background:var(--paper-2); padding:5px 10px; border-radius:8px; }
.prod-card__link{
  margin-top:auto; padding-top:8px; display:inline-flex; align-items:center; gap:6px;
  font-weight:600; font-size:.9rem; color:var(--purple);
}
.prod-card__link span{ transition:transform .35s var(--ease); }
.prod-card__link:hover span{ transform:translateX(5px); }

/* =====================================================================
   FEATURES STRIP
   ===================================================================== */
.features{ background:linear-gradient(150deg,var(--purple),var(--purple-deep)); color:#fff; position:relative; overflow:hidden; }
.features::before{ content:""; position:absolute; inset:0; background:radial-gradient(circle at 80% -10%, rgba(238,199,86,.22), transparent 50%); }
.features__inner{
  position:relative; max-width:var(--container); margin-inline:auto;
  padding:clamp(50px,7vw,80px) clamp(20px,5vw,40px);
  display:grid; grid-template-columns:repeat(5,1fr); gap:30px;
}
.feat{ text-align:center; }
.feat svg{ width:42px; height:42px; color:var(--gold); margin:0 auto 14px; }
.feat h4{ font-size:1rem; font-weight:600; margin-bottom:7px; }
.feat p{ font-size:.84rem; color:rgba(255,255,255,.74); line-height:1.55; }

/* =====================================================================
   PROYECTOS / GALLERY
   ===================================================================== */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:230px; gap:18px; }
.gal{
  position:relative; overflow:hidden; border-radius:var(--r-md);
  box-shadow:var(--shadow-sm); background:var(--paper-2);
  clip-path:inset(0 0 0 0 round var(--r-md));
}
.gal--tall{ grid-row:span 2; }
.gal--wide{ grid-column:span 2; }
.gal img{
  width:100%; height:100%; object-fit:cover;
  transition:transform .8s var(--ease), filter .5s;
}
.gal:hover img{ transform:scale(1.08); }
.gal figcaption{
  position:absolute; inset:auto 0 0 0; padding:36px 18px 16px;
  background:linear-gradient(transparent, rgba(62,42,71,.86));
  color:#fff; transform:translateY(8px); opacity:0; transition:.45s var(--ease);
  display:flex; flex-direction:column;
}
.gal:hover figcaption{ transform:none; opacity:1; }
.gal figcaption strong{ font-family:var(--serif); font-size:1.15rem; font-weight:600; }
.gal figcaption span{ font-size:.8rem; color:var(--gold); }
.proyectos__cta{ text-align:center; margin-top:44px; }

/* =====================================================================
   PROCESO (sticky storytelling)
   ===================================================================== */
.proceso{ position:relative; }
.proceso__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,70px); align-items:start; }
.proceso__sticky{ position:sticky; top:120px; }
.proceso__visual{
  position:relative; margin-top:34px; aspect-ratio:1/.82; border-radius:var(--r-lg);
  background:linear-gradient(160deg,var(--cream),var(--lilac));
  display:grid; place-items:center; overflow:hidden; box-shadow:var(--shadow-md);
}
.proceso__num{
  position:absolute; font-family:var(--serif); font-weight:800;
  font-size:clamp(7rem,18vw,13rem); color:#fff; line-height:1;
  opacity:0; transform:scale(.8) translateY(20px); transition:.6s var(--ease);
  text-shadow:0 14px 40px rgba(93,60,106,.3);
}
.proceso__num.is-active{ opacity:1; transform:none; }
.proceso .awning--mini{ position:absolute; top:0; left:0; --scallop:38px; height:24px; opacity:.85; }

.proceso__steps{ display:flex; flex-direction:column; gap:18px; }
.pstep{
  padding:30px 32px; border-radius:var(--r-md); background:var(--white);
  border:1px solid rgba(140,95,155,.1); box-shadow:var(--shadow-sm);
  opacity:.5; transition:opacity .5s var(--ease), transform .5s var(--ease), box-shadow .5s;
  transform:scale(.98);
}
.pstep.is-active{ opacity:1; transform:scale(1); box-shadow:var(--shadow-md); border-color:rgba(238,199,86,.5); }
.pstep__index{ font-family:var(--serif); font-size:1rem; font-weight:700; color:var(--gold-deep); }
.pstep h3{ font-family:var(--serif); font-size:1.5rem; font-weight:700; color:var(--purple-ink); margin:6px 0 10px; }
.pstep p{ color:var(--muted); font-size:.96rem; }

/* =====================================================================
   STATS BAND
   ===================================================================== */
.stats-band{ position:relative; background:linear-gradient(120deg,var(--teal),#3f6e70); color:#fff; overflow:hidden; }
.stats-band::before{ content:""; position:absolute; inset:0; background:radial-gradient(circle at 15% 120%, rgba(238,199,86,.25), transparent 45%); }
.stats-band__inner{
  position:relative; max-width:var(--container); margin-inline:auto;
  padding:clamp(54px,7vw,86px) clamp(20px,5vw,40px);
  display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center;
}
.stat strong{ display:block; font-family:var(--serif); font-weight:800; font-size:clamp(2.4rem,5vw,3.6rem); line-height:1; }
.stat span{ font-size:.88rem; color:rgba(255,255,255,.8); margin-top:8px; display:block; }

/* =====================================================================
   NOSOTROS
   ===================================================================== */
.nosotros__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,6vw,80px); align-items:center; }
.nosotros__intro .section__title{ text-align:left; }
.nosotros__intro .kicker{ justify-content:flex-start; }
.nosotros__intro .btn{ margin-top:30px; }
.nosotros__list{ display:flex; flex-direction:column; gap:14px; }
.nosotros__list li{
  display:flex; gap:18px; align-items:flex-start;
  padding:24px 26px; border-radius:var(--r-md); background:var(--white);
  box-shadow:var(--shadow-sm); border:1px solid rgba(140,95,155,.08);
  transition:transform .4s var(--ease), box-shadow .4s;
}
.nosotros__list li:hover{ transform:translateX(8px); box-shadow:var(--shadow-md); }
.nosotros__ico{
  flex:none; width:42px; height:42px; border-radius:12px; display:grid; place-content:center;
  background:linear-gradient(150deg,var(--gold),var(--gold-deep)); color:var(--purple-ink); font-size:1.1rem;
}
.nosotros__list h4{ font-size:1.08rem; font-weight:600; color:var(--purple-ink); margin-bottom:4px; }
.nosotros__list p{ font-size:.9rem; color:var(--muted); }

/* =====================================================================
   TESTIMONIOS
   ===================================================================== */
.testi-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.testi{
  background:var(--white); border-radius:var(--r-md); padding:32px 30px;
  box-shadow:var(--shadow-sm); border:1px solid rgba(140,95,155,.08);
  position:relative; transition:transform .4s var(--ease), box-shadow .4s;
}
.testi:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); }
.testi::before{ content:"\201C"; font-family:var(--serif); font-size:4.5rem; color:var(--lilac); line-height:.6; position:absolute; top:24px; right:24px; opacity:.5; }
.testi p{ color:var(--purple-ink); font-size:1rem; position:relative; z-index:1; }
.testi footer{ display:flex; align-items:center; gap:12px; margin-top:22px; }
.testi__avatar{ width:42px; height:42px; border-radius:50%; display:grid; place-content:center; font-weight:700; color:#fff; background:linear-gradient(150deg,var(--purple),var(--lilac)); }
.testi footer strong{ display:block; font-size:.92rem; color:var(--purple-ink); }
.testi footer small{ color:var(--muted); font-size:.8rem; }

/* =====================================================================
   FAQ
   ===================================================================== */
.faq__list{ max-width:820px; margin-inline:auto; display:flex; flex-direction:column; gap:12px; }
.faq__item{
  background:var(--white); border-radius:var(--r-sm); border:1px solid rgba(140,95,155,.12);
  overflow:hidden; transition:box-shadow .4s, border-color .4s;
}
.faq__item[open]{ box-shadow:var(--shadow-md); border-color:rgba(238,199,86,.5); }
.faq__item summary{
  cursor:pointer; list-style:none; padding:22px 26px;
  font-weight:600; font-size:1.05rem; color:var(--purple-ink);
  display:flex; align-items:center; justify-content:space-between; gap:16px;
}
.faq__item summary::-webkit-details-marker{ display:none; }
.faq__item summary::after{
  content:"+"; font-family:var(--serif); font-size:1.6rem; color:var(--purple); line-height:1;
  transition:transform .4s var(--ease); flex:none;
}
.faq__item[open] summary::after{ transform:rotate(45deg); }
.faq__answer{ padding:0 26px; max-height:0; overflow:hidden; transition:max-height .5s var(--ease), padding .5s; }
.faq__item[open] .faq__answer{ max-height:260px; padding:0 26px 24px; }
.faq__answer p{ color:var(--muted); font-size:.96rem; }

/* =====================================================================
   CTA FINAL
   ===================================================================== */
.cta-final{ position:relative; overflow:hidden; background:linear-gradient(140deg,var(--purple-deep),var(--purple)); color:#fff; }
.cta-final__mesh{ position:absolute; inset:0; filter:blur(70px); opacity:.6; }
.cta-final__mesh .blob--1{ width:480px; height:480px; top:-160px; left:-80px; background:radial-gradient(circle,var(--lilac),transparent 70%); }
.cta-final__mesh .blob--2{ width:420px; height:420px; bottom:-180px; right:-60px; background:radial-gradient(circle,rgba(238,199,86,.6),transparent 70%); }
.cta-final__inner{
  position:relative; z-index:2; max-width:760px; margin-inline:auto; text-align:center;
  padding:clamp(70px,10vw,130px) clamp(20px,5vw,40px);
}
.cta-final__mark{ width:78px; height:78px; margin:0 auto 24px; filter:drop-shadow(0 14px 30px rgba(0,0,0,.25)); }
.cta-final h2{ font-family:var(--serif); font-weight:800; font-size:clamp(2.1rem,5vw,3.6rem); line-height:1.08; letter-spacing:-.02em; }
.cta-final h2 em{ font-style:italic; color:var(--gold); }
.cta-final p{ margin:18px auto 34px; max-width:480px; color:rgba(255,255,255,.82); font-size:1.1rem; }
.cta-final__actions{ display:flex; flex-wrap:wrap; gap:14px; justify-content:center; }

/* =====================================================================
   FOOTER
   ===================================================================== */
.footer{ background:var(--purple-ink); color:rgba(255,255,255,.72); }
.footer__inner{
  max-width:var(--container); margin-inline:auto;
  padding:clamp(54px,7vw,80px) clamp(20px,5vw,40px) 40px;
  display:grid; grid-template-columns:2fr 1fr 1fr 1.4fr; gap:40px;
}
.footer__logo-wrap{ display:flex; align-items:center; gap:14px; margin-bottom:20px; }
.footer__mark{ width:58px; height:58px; flex:none; border-radius:50%; box-shadow:0 6px 18px rgba(0,0,0,.25); }
.footer__wordmark{ font-family:var(--serif); font-size:1.7rem; font-weight:600; color:#fff; line-height:1; }
.footer__wordmark em{ font-style:italic; color:var(--gold); }
.footer__brand p{ font-size:.9rem; max-width:300px; line-height:1.65; }
.footer__social{ display:flex; gap:12px; margin-top:20px; }
.footer__social a{
  width:42px; height:42px; border-radius:12px; display:grid; place-content:center;
  background:rgba(255,255,255,.08); color:#fff; transition:.35s var(--ease);
}
.footer__social a:hover{ background:var(--gold); color:var(--purple-ink); transform:translateY(-3px); }
.footer__col h5{ color:#fff; font-size:.95rem; font-weight:600; margin-bottom:16px; }
.footer__col a{ display:block; font-size:.88rem; padding:5px 0; transition:color .3s, padding-left .3s; }
.footer__col a:hover{ color:var(--gold); padding-left:5px; }
.footer__bottom{
  border-top:1px solid rgba(255,255,255,.1);
  max-width:var(--container); margin-inline:auto;
  padding:22px clamp(20px,5vw,40px); display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap;
  font-size:.8rem; color:rgba(255,255,255,.55);
}
.footer__made{ color:var(--gold); }

/* =====================================================================
   FLOATING WHATSAPP
   ===================================================================== */
.float-wa{
  position:fixed; bottom:26px; right:26px; z-index:900;
  width:62px; height:62px; border-radius:50%;
  display:grid; place-content:center; color:#fff;
  background:linear-gradient(150deg,#42c956,#1faa44);
  box-shadow:0 12px 30px rgba(31,170,68,.45);
  transform:scale(0); transition:transform .5s var(--ease);
}
.float-wa.is-visible{ transform:scale(1); }
.float-wa:hover{ transform:scale(1.08); }
.float-wa__pulse{ position:absolute; inset:0; border-radius:50%; border:2px solid #42c956; animation:waPulse 2s ease-out infinite; }
@keyframes waPulse{ 0%{ transform:scale(1); opacity:.7;} 100%{ transform:scale(1.6); opacity:0;} }

/* =====================================================================
   REVEAL ANIMATIONS
   ===================================================================== */
.js .reveal{ opacity:0; transform:translateY(34px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.is-in{ opacity:1; transform:none; }

/* =====================================================================
   LIGHTBOX (galería de proyectos)
   ===================================================================== */
.gal{ cursor:pointer; }
.lightbox{
  position:fixed; inset:0; z-index:9500;
  display:flex; align-items:center; justify-content:center;
  padding:clamp(16px,4vw,48px);
  background:rgba(46,30,52,.86); backdrop-filter:blur(10px);
  opacity:0; visibility:hidden; transition:opacity .4s var(--ease), visibility .4s;
}
.lightbox.is-open{ opacity:1; visibility:visible; }
.lightbox__stage{
  position:relative; max-width:1100px; width:100%;
  display:flex; flex-direction:column; align-items:center; gap:16px;
  transform:scale(.94); transition:transform .45s var(--ease);
}
.lightbox.is-open .lightbox__stage{ transform:scale(1); }
.lightbox__img{
  max-width:100%; max-height:78vh; width:auto; border-radius:var(--r-md);
  box-shadow:0 40px 100px rgba(0,0,0,.5); background:#fff;
}
.lightbox__cap{ text-align:center; color:#fff; }
.lightbox__cap strong{ font-family:var(--serif); font-size:1.3rem; font-weight:600; display:block; }
.lightbox__cap span{ color:var(--gold); font-size:.9rem; }
.lightbox__close{
  position:absolute; top:-14px; right:-14px; z-index:2;
  width:46px; height:46px; border-radius:50%; border:none; cursor:pointer;
  background:#fff; color:var(--purple-deep); font-size:1.3rem; line-height:1;
  display:grid; place-content:center; box-shadow:var(--shadow-md);
  transition:transform .3s var(--ease), background .3s, color .3s;
}
.lightbox__close:hover{ transform:rotate(90deg); background:var(--gold); }
.lightbox__nav{
  position:absolute; top:50%; transform:translateY(-50%); z-index:2;
  width:52px; height:52px; border-radius:50%; border:none; cursor:pointer;
  background:rgba(255,255,255,.16); color:#fff; font-size:1.5rem;
  display:grid; place-content:center; transition:background .3s, transform .3s var(--ease);
}
.lightbox__nav:hover{ background:var(--gold); color:var(--purple-deep); }
.lightbox__nav--prev{ left:-8px; }
.lightbox__nav--next{ right:-8px; }
.lightbox__nav--prev:hover{ transform:translateY(-50%) translateX(-3px); }
.lightbox__nav--next:hover{ transform:translateY(-50%) translateX(3px); }
.lightbox__count{ color:rgba(255,255,255,.6); font-size:.82rem; letter-spacing:.05em; }
body.no-scroll{ overflow:hidden; }
@media (max-width:640px){
  .lightbox__close{ top:-50px; right:0; }
  .lightbox__nav{ top:auto; bottom:-58px; transform:none; }
  .lightbox__nav--prev{ left:30%; }
  .lightbox__nav--next{ right:30%; }
  .lightbox__img{ max-height:64vh; }
}

/* ---------- Snapshot/debug mode (?snap) ---------- */
.snap .preloader{ display:none !important; }
.snap .reveal{ opacity:1 !important; transform:none !important; }
.snap .hero__title .w{ transform:none !important; }
.snap .hero__title .w.accent::after{ transform:scaleX(1) !important; }
.snap *,.snap *::before,.snap *::after{ animation:none !important; }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width:1080px){
  .prod-grid{ grid-template-columns:repeat(2,1fr); }
  .features__inner{ grid-template-columns:repeat(3,1fr); row-gap:40px; }
  .testi-grid{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:repeat(2,1fr); grid-auto-rows:200px; }
  .gal--wide{ grid-column:span 2; }
  .gal--tall{ grid-row:span 1; }
}
@media (max-width:880px){
  .nav__links{ display:none; }
  .nav__cta{ margin-left:auto; }
  .nav__burger{ display:flex; }
  .nav__links.is-open{
    display:flex; flex-direction:column; gap:4px;
    position:absolute; top:100%; left:16px; right:16px;
    background:rgba(253,248,239,.97); backdrop-filter:blur(14px);
    padding:16px; border-radius:var(--r-md); box-shadow:var(--shadow-lg);
  }
  .nav__links.is-open .nav__link{ padding:12px 14px; font-size:1.05rem; }
  .hero__inner{ grid-template-columns:1fr; text-align:center; }
  .hero__content{ order:2; }
  .hero__visual{ order:1; min-height:340px; }
  .eyebrow,.hero__actions,.hero__stats{ justify-content:center; }
  .hero__lead{ margin-inline:auto; }
  .proceso__grid{ grid-template-columns:1fr; }
  .proceso__sticky{ position:relative; top:0; }
  .proceso__visual{ display:none; }
  .nosotros__grid{ grid-template-columns:1fr; }
  .nosotros__intro .section__title,.nosotros__intro .kicker{ text-align:center; justify-content:center; }
  .nosotros__intro{ text-align:center; }
  .nosotros__intro .btn{ margin-inline:auto; }
  .stats-band__inner{ grid-template-columns:repeat(2,1fr); gap:34px; }
  .footer__inner{ grid-template-columns:1fr 1fr; }
}
@media (max-width:540px){
  .prod-grid{ grid-template-columns:1fr; }
  .features__inner{ grid-template-columns:1fr 1fr; }
  .gallery{ grid-template-columns:1fr; grid-auto-rows:240px; }
  .gal--wide{ grid-column:span 1; }
  .footer__inner{ grid-template-columns:1fr; }
  .hero__badge{ display:none; }
  .btn{ width:100%; justify-content:center; }
  .hero__actions,.cta-final__actions{ width:100%; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
  .reveal{ opacity:1; transform:none; }
  .hero__title .w{ transform:none; }
}
