/* ================ Tokens ================ */
:root{
  --cream:#0A0A0A;
  --white:#141414;
  --rose:#C99B2A;
  --rose-soft:#1A1410;
  --gold:#C99B2A;
  --gold-soft:#EFC85E;
  --gold-deep:#8B6411;
  --ink:#F5EFE2;
  --ink-bg:#0A0A0A;
  --muted:#A39888;
  --surface:#171411;
  --surface-2:#1F1B16;
  --line:rgba(239,200,94,0.10);
  --line-gold:rgba(201,155,42,0.35);
  --shadow-sm:0 1px 2px rgba(0,0,0,0.4), 0 2px 8px rgba(0,0,0,0.35);
  --shadow-md:0 12px 40px rgba(0,0,0,0.45);
  --shadow-lg:0 20px 60px rgba(26,26,26,0.12);
  --r-sm:8px;
  --r-md:12px;
  --r-lg:18px;
  --serif:"Cormorant Garamond", Georgia, serif;
  --serif-display:"Tenor Sans", "Inter", sans-serif;
  --display-tracking:0.12em;
  --display-weight:400;
  --display-case:uppercase;
  --display-italic:"Cormorant Garamond", serif;
  --display-italic-style:italic;
  --script:"Dancing Script", cursive;
  --sans:"Inter", system-ui, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  font-weight:300;
  color:var(--ink);
  background:var(--cream);
  font-size:16px;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}

/* ================ Scrollbar a tono con la marca ================ */
html{
  scrollbar-width:thin;
  scrollbar-color:var(--gold) #0E0E0E;
}
::-webkit-scrollbar{width:12px;height:12px}
::-webkit-scrollbar-track{
  background:#0E0E0E;
  border-left:1px solid rgba(201,155,42,0.10);
}
::-webkit-scrollbar-thumb{
  border-radius:999px;
  border:3px solid #0E0E0E;
  background:linear-gradient(180deg, var(--gold-soft) 0%, var(--gold) 55%, var(--gold-deep) 100%);
}
::-webkit-scrollbar-thumb:hover{
  background:linear-gradient(180deg, #F6DA86 0%, var(--gold-soft) 55%, var(--gold) 100%);
}
::-webkit-scrollbar-corner{background:#0E0E0E}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}

.container{max-width:1240px;margin:0 auto;padding:0 32px}

/* ================ Type ================ */
h1,h2{font-family:var(--serif-display);font-weight:var(--display-weight);letter-spacing:var(--display-tracking);text-transform:var(--display-case);line-height:1.1;color:var(--ink)}
h3,h4{font-family:var(--serif);font-weight:500;letter-spacing:-0.01em;line-height:1.15;color:var(--ink)}
h1{font-size:clamp(2.4rem,5vw,4.4rem)}
h2{font-size:clamp(1.9rem,3.6vw,2.9rem)}
h3{font-size:clamp(1.3rem,2vw,1.6rem)}
.script{font-family:var(--script);font-weight:600;color:var(--gold);font-size:1.4em;font-style:normal}
.italic{font-style:normal;font-family:inherit;text-transform:inherit;font-weight:inherit;color:var(--gold)}
.gold{color:var(--gold)}
.muted{color:var(--muted)}

/* ================ Buttons ================ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;
  font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:0.12em;
  border-radius:999px;
  transition:all .35s cubic-bezier(.2,.7,.2,1);
  cursor:pointer;
  white-space:nowrap;
  text-transform:uppercase;
}
.btn--rose{background:var(--gold);color:#0A0A0A;font-weight:700;box-shadow:0 6px 24px rgba(201,155,42,0.28)}
.btn--rose svg{color:#0A0A0A}
.btn--rose:hover{background:var(--gold-soft);color:#0A0A0A;transform:translateY(-2px);box-shadow:0 12px 32px rgba(201,155,42,0.45)}
.btn--ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn--ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn--outline{background:transparent;color:var(--ink);border:1px solid var(--gold);padding:18px 36px;font-size:12px}
.btn--outline:hover{background:var(--gold);color:#0A0A0A;letter-spacing:0.16em}
.btn--mini{padding:8px 16px;font-size:11px;background:var(--gold);color:#0A0A0A;font-weight:700;letter-spacing:0.1em;border-radius:999px}
.btn--mini:hover{background:var(--gold-soft);color:#0A0A0A}
.btn--big{padding:18px 32px;font-size:14px;justify-content:center;text-align:center;line-height:1}
.btn--big svg{flex:none}
.btn--big > span{display:inline-block;vertical-align:middle}
.btn--full{width:100%;justify-content:center;text-align:center}
.btn--small{padding:11px 20px;font-size:11px}

/* ================ Gold thread ================ */
.gold-thread{
  position:fixed;top:0;right:24px;
  width:60px;height:100vh;
  pointer-events:none;z-index:5;
  opacity:0.65;
}
@media (max-width:900px){.gold-thread{display:none}}

/* ================ Section indicator ================ */
.section-indicator{
  position:fixed;right:28px;top:50%;transform:translateY(-50%);
  z-index:90;
  display:flex;flex-direction:column;gap:14px;
  padding:18px 10px;
  pointer-events:auto;
}
.section-indicator::before{
  /* hairline rail behind dots */
  content:"";position:absolute;left:50%;top:24px;bottom:24px;
  width:1px;background:linear-gradient(180deg, transparent, var(--line-gold), transparent);
  transform:translateX(-50%);
  opacity:0.5;
}
.section-indicator__item{
  position:relative;
  display:flex;align-items:center;justify-content:flex-end;gap:14px;
  height:18px;
  text-decoration:none;
  color:var(--muted);
  -webkit-tap-highlight-color:transparent;
}
.section-indicator__dot{
  width:6px;height:6px;border-radius:50%;
  background:rgba(255,255,255,0.15);
  position:relative;z-index:1;
  transition:all .35s cubic-bezier(.2,.7,.2,1);
  flex:none;
}
.section-indicator__dot::after{
  /* expanding gold ring on active */
  content:"";position:absolute;inset:-6px;
  border-radius:50%;
  border:1px solid var(--gold);
  opacity:0;
  transition:opacity .4s, transform .4s;
}
.section-indicator__label{
  font-family:"DM Sans","Inter",system-ui,sans-serif;
  font-size:10px;font-weight:600;
  letter-spacing:0.22em;text-transform:uppercase;
  color:var(--gold-soft);
  opacity:0;transform:translateX(8px);
  pointer-events:none;
  transition:opacity .35s, transform .35s;
  white-space:nowrap;
}

/* Hover state */
.section-indicator__item:hover .section-indicator__dot{
  background:var(--gold);
  transform:scale(1.3);
}
.section-indicator__item:hover .section-indicator__label{
  opacity:0.85;transform:translateX(0);
}

/* Active state */
.section-indicator__item.is-active .section-indicator__dot{
  background:var(--gold);
  width:10px;height:10px;
  box-shadow:0 0 12px rgba(201,155,42,0.6);
}
.section-indicator__item.is-active .section-indicator__dot::after{
  opacity:0.6;
  inset:-5px;
}
.section-indicator__item.is-active .section-indicator__label{
  opacity:1;transform:translateX(0);
  color:var(--gold);
}

@media (max-width:980px){
  .section-indicator{display:none}
}

/* ================ Nav ================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(10,10,10,0.78);backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  transition:box-shadow .3s, padding .3s;
}
.nav.scrolled{box-shadow:0 1px 0 var(--line), 0 4px 24px rgba(0,0,0,0.5)}
.nav__inner{
  max-width:1320px;margin:0 auto;padding:11px 32px;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:32px;
}
.nav__logo{justify-self:start}
.nav__cta{justify-self:end}
.nav__logo img{height:46px;width:auto;transition:opacity .3s}
.nav__menu{display:flex;justify-content:center;gap:32px}
.nav__menu a{
  font-size:11px;font-weight:500;letter-spacing:0.18em;color:var(--ink);
  position:relative;padding:6px 0;
}
.nav__menu a::after{
  content:"";position:absolute;left:0;bottom:0;
  width:0;height:1px;background:var(--gold);
  transition:width .35s cubic-bezier(.2,.7,.2,1);
}
.nav__menu a:hover{color:var(--gold)}
.nav__menu a:hover::after{width:100%}
.nav__cta{font-size:11px;padding:12px 22px}
.nav__burger{display:none;flex-direction:column;gap:5px;width:30px;height:30px;justify-content:center;align-items:center}
.nav__burger span{width:22px;height:1.5px;background:var(--ink);transition:.3s}

@media (max-width:980px){
  .nav__menu{display:none;position:absolute;top:100%;left:0;right:0;background:var(--cream);flex-direction:column;padding:24px;border-top:1px solid var(--line)}
  .nav__menu.open{display:flex}
  .nav__cta{display:none}
  .nav__burger{display:flex}
  .nav__inner{grid-template-columns:auto 1fr auto}
}

/* ================ Hero ================ */
.hero{
  padding:100px 0 0;
  min-height:100vh;
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(1100px 700px at 85% 12%, rgba(201,155,42,0.22), transparent 65%),
    radial-gradient(900px 600px at 8% 88%, rgba(201,155,42,0.14), transparent 60%),
    linear-gradient(180deg, #0E0B07 0%, var(--cream) 60%, #050505 100%);
}
.hero::before{
  content:"";position:absolute;
  top:20%;left:-200px;width:500px;height:500px;
  background:radial-gradient(circle, rgba(201,155,42,0.25), transparent 70%);
  pointer-events:none;
}

/* ----- ambient atmosphere ----- */
.hero__atmos{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:0}
.hero__grid{position:relative;z-index:2}
.hero__orb{
  position:absolute;border-radius:50%;
  filter:blur(70px);opacity:0.7;
  will-change:transform;
}
.hero__orb--rose{
  width:520px;height:520px;top:-120px;right:-140px;
  background:radial-gradient(circle, rgba(201,155,42,0.42), rgba(201,155,42,0) 70%);
  animation:floatA 14s ease-in-out infinite;
}
.hero__orb--gold{
  width:420px;height:420px;bottom:-100px;left:8%;
  background:radial-gradient(circle, rgba(239,200,94,0.55), rgba(201,155,42,0) 70%);
  animation:floatB 18s ease-in-out infinite;
}
.hero__orb--cream{
  width:360px;height:360px;top:40%;left:42%;
  background:radial-gradient(circle, rgba(255,243,224,0.7), rgba(255,243,224,0) 70%);
  animation:floatC 22s ease-in-out infinite;
}
@keyframes floatA{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(-30px,40px) scale(1.06)}
}
@keyframes floatB{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(40px,-30px) scale(1.08)}
}
@keyframes floatC{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(-20px,-30px) scale(1.04)}
}

.hero__beam{display:none}
@keyframes beam{
  0%{transform:rotate(18deg) translateX(-200px);opacity:0}
  20%{opacity:0.55}
  80%{opacity:0.4}
  100%{transform:rotate(18deg) translateX(900px);opacity:0}
}

/* falling gold sparkles */
.hero__stars{
  position:absolute;inset:0;pointer-events:none;overflow:hidden;
}
.hero__star{
  position:absolute;top:-20px;
  left:var(--x, 50%);
  width:var(--s, 6px);height:var(--s, 6px);
  opacity:0;
  background:
    radial-gradient(circle, rgba(255,245,200,0.95) 0%, rgba(239,200,94,0.6) 30%, transparent 60%);
  border-radius:50%;
  box-shadow:0 0 8px 1px rgba(239,200,94,0.55);
  animation:starFall var(--dur, 12s) linear infinite;
  animation-delay:var(--d, 0s);
  will-change:transform, opacity;
}
.hero__star::before,
.hero__star::after{
  content:"";position:absolute;left:50%;top:50%;
  width:1px;height:calc(var(--s, 6px) * 3);
  background:linear-gradient(180deg, transparent, rgba(239,200,94,0.85), transparent);
  transform:translate(-50%,-50%);
}
.hero__star::after{
  transform:translate(-50%,-50%) rotate(90deg);
}
@keyframes starFall{
  0%{transform:translate3d(0,-40px,0) rotate(0deg);opacity:0}
  10%{opacity:0.9}
  50%{opacity:0.7}
  90%{opacity:0.4}
  100%{transform:translate3d(-30px, calc(100vh + 60px), 0) rotate(180deg);opacity:0}
}
@media (prefers-reduced-motion: reduce){
  .hero__star{animation:none;display:none}
}

.hero__sparkle{
  position:absolute;
  left:var(--x);top:var(--y);
  width:var(--s);height:var(--s);
  background:radial-gradient(circle, #fff 0%, #EFC85E 35%, transparent 70%);
  border-radius:50%;
  box-shadow:0 0 12px 2px rgba(239,200,94,0.7);
  animation:twinkle 4.5s ease-in-out infinite;
  animation-delay:var(--d);
}
.hero__sparkle::before, .hero__sparkle::after{
  content:"";position:absolute;left:50%;top:50%;
  background:linear-gradient(180deg, transparent, #fff, transparent);
  transform-origin:center;
}
.hero__sparkle::before{
  width:1px;height:calc(var(--s) * 4);
  transform:translate(-50%,-50%);
}
.hero__sparkle::after{
  width:calc(var(--s) * 4);height:1px;
  transform:translate(-50%,-50%);
}
@keyframes twinkle{
  0%,100%{opacity:0;transform:scale(0.6)}
  50%{opacity:1;transform:scale(1)}
}

.hero__grain{
  position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.4 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity:0.06;
  mix-blend-mode:multiply;
}

/* shimmer on gold text */
.hero__title .shimmer{
  background:linear-gradient(100deg,
    #C99B2A 0%, #C99B2A 35%,
    #F8DA86 48%, #FFEFB8 52%, #F8DA86 56%,
    #C99B2A 70%, #C99B2A 100%);
  background-size:300% 100%;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  animation:shimmer 5.5s ease-in-out infinite;
}
@keyframes shimmer{
  0%{background-position:120% 0}
  100%{background-position:-120% 0}
}
.hero__grid{
  max-width:1440px;margin:0 auto;padding:0 0 0 32px;
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:stretch;
  min-height:calc(100vh - 100px);
}
.hero__copy{display:flex;flex-direction:column;justify-content:center;padding:40px 0 60px}
.hero__eyebrow{margin-bottom:22px}
.hero__eyebrow .line{width:40px;height:2px;background:#A8801F}
.hero__eyebrow .label{
  font-family:"Inter",sans-serif;
  font-size:11px;
  font-weight:600;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:#A8801F;
}
.eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:24px}
.eyebrow .line{width:42px;height:1px;background:var(--gold)}
.hero__title{
  display:flex;flex-direction:column;gap:6px;
  font-family:"Archivo Black","Anton",Impact,sans-serif;
  font-weight:900;
  letter-spacing:-0.01em;
  text-transform:uppercase;
  line-height:0.98;
  font-size:clamp(2.4rem,4.1vw,3.6rem);
  color:var(--ink);
  margin:0 0 14px;
}
.hero__title .gold{
  color:#A8801F;font-style:normal;
  background:linear-gradient(100deg, #A8801F 0%, #A8801F 35%, #EFC85E 50%, #A8801F 65%, #A8801F 100%);
  background-size:220% 100%;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  animation:goldShimmer 7s ease-in-out infinite;
}
@keyframes goldShimmer{
  0%,100%{background-position:120% 0}
  50%{background-position:-20% 0}
}
.hero__title span{display:block}
.hero__sub{
  font-size:clamp(1.02rem,1.3vw,1.18rem);
  color:var(--muted);
  max-width:460px;
  margin:24px 0 36px;
  line-height:1.7;
  position:relative;
}
.hero__sub::before{
  content:none;
}
.hero__sub--lead{
  font-family:var(--serif);
  font-size:clamp(1.5rem,2.2vw,2rem);
  font-weight:400;
  color:var(--ink);
  max-width:560px;
  margin:8px 0 38px;
  line-height:1.35;
  letter-spacing:-0.005em;
}
.hero__sub--lead::first-line{font-style:italic;color:var(--gold)}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:36px}

/* Hero mini-stats row */
.hero__stats{
  display:flex;align-items:center;gap:22px;
  list-style:none;margin:0;padding:18px 0 0;
  border-top:1px solid rgba(168,128,31,0.18);
  max-width:580px;
  flex-wrap:wrap;
}
.hero__stats li{display:flex;align-items:center;gap:10px}
.hero__stats li.divider{
  width:1px;height:32px;
  background:linear-gradient(180deg, transparent, rgba(168,128,31,0.45), transparent);
  flex:none;
}
.hero__stats strong{
  display:block;
  font-family:"Inter",sans-serif;
  font-size:13px;font-weight:600;
  color:var(--ink);
  letter-spacing:0.02em;
  line-height:1.2;
}
.hero__stats span{
  display:block;
  font-size:11px;
  color:var(--muted);
  letter-spacing:0.05em;
  line-height:1.3;
}

.hero__bullets{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:560px}
.hero__bullets li{display:flex;align-items:flex-start;gap:12px;font-size:11px;letter-spacing:0.04em;line-height:1.4}
.hero__bullets strong{display:block;font-weight:600;color:var(--ink);letter-spacing:0.12em;font-size:11px;margin-bottom:2px}
.hero__bullets span{color:var(--muted);font-size:11px}

.hero__visual{position:relative;width:100%;height:100%;align-self:stretch}
.hero__frame{position:relative;width:100%;height:100%;display:flex;align-items:flex-end;justify-content:center;overflow:hidden}
.hero__halo{display:none}
.hero__img{
  position:relative;z-index:1;
  display:block;
  height:100%;
  width:auto;
  max-width:none;
  max-height:calc(100vh - 100px);
  object-fit:contain;
  object-position:right bottom;
  transform:translateX(20px);
  pointer-events:none;
  animation:heroFloat 7s ease-in-out infinite;
}
@keyframes heroFloat{
  0%,100%{transform:translateX(20px) translateY(0)}
  50%{transform:translateX(20px) translateY(-10px)}
}
@keyframes haloFloat{
  0%,100%{transform:translate(-50%,-50%) scale(1)}
  50%{transform:translate(-48%,-52%) scale(1.05)}
}
.hero__fade{
  position:absolute;
  bottom:0;left:0;right:0;
  height:14%;
  background:linear-gradient(to bottom, transparent 0%, var(--cream) 90%);
  z-index:2;
  pointer-events:none;
}
.hero__img--legacy-removed{display:none}
.hero__badge{
  position:absolute;bottom:30px;left:0;
  background:var(--surface);
  padding:16px 22px;
  border-radius:var(--r-md);
  box-shadow:0 18px 40px rgba(60,40,20,0.14), 0 2px 6px rgba(60,40,20,0.06);
  display:flex;gap:12px;align-items:center;
  border:1px solid rgba(201,155,42,0.18);
}
.hero__badge .num{font-family:var(--serif);font-size:2.2rem;color:var(--gold);line-height:1}
.hero__badge .lbl{font-size:10px;letter-spacing:0.12em;color:var(--muted);text-transform:uppercase;line-height:1.3}

.hero__stamp{
  position:absolute;top:-20px;right:-20px;
  width:110px;height:110px;
  background:var(--cream);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  animation:spin 30s linear infinite;
  border:1px solid var(--line-gold);
}
@keyframes spin{to{transform:rotate(360deg)}}

.hero__scroll{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:12px;
  font-size:9px;letter-spacing:0.3em;color:var(--muted);
}
.hero__scroll .line{width:1px;height:40px;background:var(--gold);position:relative;overflow:hidden}
.hero__scroll .line::after{content:"";position:absolute;top:0;left:0;width:100%;height:50%;background:var(--cream);animation:slideDown 1.8s ease-in-out infinite}
@keyframes slideDown{0%{transform:translateY(-100%)}100%{transform:translateY(200%)}}

@media (max-width:980px){
  .hero{padding:90px 0 40px;min-height:0}
  .hero__grid{
    grid-template-columns:1fr;
    grid-template-areas: "visual" "copy";
    gap:24px;
    min-height:0;
    padding:0 24px;
    text-align:center;
  }
  .hero__copy{
    grid-area:copy;
    padding:0;
    align-items:center;
  }
  .hero__visual{
    grid-area:visual;
    max-width:none;
    margin:0;
    height:auto;
    display:flex;justify-content:center;
  }
  .hero__frame{
    width:100%;
    max-width:380px;
    margin:0 auto;
    height:auto;
    aspect-ratio:4/5;
    justify-content:center;
    align-items:flex-end;
  }
  .hero__img{
    height:100%;
    width:auto;
    max-height:none;
    transform:none !important;
    animation:none;
    object-position:center bottom;
  }
  .hero__title{
    align-items:center;
    text-align:center;
    font-size:clamp(1.9rem,7vw,2.6rem);
    margin-bottom:6px;
  }
  .hero__sub{
    margin:18px auto 28px;
    max-width:420px;
    font-size:1rem;
    text-align:center;
  }
  .hero__sub::before{margin-left:auto;margin-right:auto;margin-bottom:16px}
  .hero__cta{justify-content:center}
  .hero__bullets{grid-template-columns:1fr}
  .hero__scroll{display:none}
  /* Calm the ambient effects on mobile */
  .hero__orb--rose{width:300px;height:300px}
  .hero__orb--gold{width:260px;height:260px}
  .hero__orb--cream{display:none}
  .hero__beam{display:none}
  .hero__sparkle{display:none}
}

@media (max-width:520px){
  .hero{padding:80px 0 32px}
  .hero__frame{max-width:300px;aspect-ratio:3/4}
  .hero__title{font-size:clamp(1.7rem,8vw,2.2rem)}
  .hero__sub{font-size:0.95rem;margin:14px auto 24px}
  .hero__cta .btn{padding:13px 22px;font-size:11px}
}

/* ================ Sections base ================ */
.section{padding:120px 0;position:relative}
.section--cream{background:var(--cream)}
.section--white{background:var(--cream)}
.section__head{text-align:center;max-width:680px;margin:0 auto 72px}
.section__head--left{text-align:left;margin-left:0}
.section__head .script{display:block;margin-bottom:12px}
.section__head p{color:var(--muted);margin-top:16px;font-size:1.05rem}
.section__cta{text-align:center;margin-top:60px}

@media (max-width:768px){.section{padding:80px 0}.section__head{margin-bottom:48px}}

/* ================ Services ================ */
.services{
  display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
}
@media (max-width:980px){.services{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.services{grid-template-columns:1fr}}

.card{
  background:var(--white);
  border-radius:var(--r-md);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .4s;
  display:flex;flex-direction:column;
  border:1px solid var(--line);
  position:relative;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.card__img{
  aspect-ratio:5/3;background-size:cover;background-position:center;
  transition:transform .8s cubic-bezier(.2,.7,.2,1);
}
.card:hover .card__img{transform:scale(1.06)}
.card__img--collage{
  display:grid;
  grid-template-columns:1fr 1fr;
  grid-template-rows:1fr 1fr;
  gap:2px;
  background:#0E0B07;
}
.card__img--collage span{
  display:block;
  background-size:cover;
  background-position:center;
  transition:transform .8s cubic-bezier(.2,.7,.2,1), filter .6s ease;
}
.card__img--collage span:nth-child(1){filter:grayscale(0.1)}
.card__img--collage span:nth-child(4){filter:grayscale(0.1)}
.card:hover .card__img--collage span{transform:scale(1.04);filter:grayscale(0)}
.card__body{padding:24px 24px 22px;display:flex;flex-direction:column;flex:1;gap:8px}
.card__icon{
  width:54px;height:54px;
  border:1px solid rgba(168,128,31,0.35);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:10px;
  background:
    radial-gradient(circle at 30% 30%, rgba(201,155,42,0.45), transparent 70%),
    radial-gradient(circle at 70% 70%, rgba(239,200,94,0.22), transparent 70%);
  box-shadow:inset 0 0 0 1px rgba(239,200,94,0.18), 0 4px 14px rgba(0,0,0,0.4);
  transition:transform .5s cubic-bezier(.2,.7,.2,1), box-shadow .4s;
}
.card:hover .card__icon{
  transform:translateY(-2px) rotate(-3deg);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,0.7), 0 8px 22px rgba(168,128,31,0.18);
}
.card h3{margin-bottom:2px;font-size:clamp(1.1rem,1.4vw,1.3rem)}
.card p{color:var(--muted);font-size:0.9rem;flex:1;line-height:1.55}
.card__foot{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-top:18px;padding-top:18px;
  border-top:1px solid var(--line);
  gap:12px;
}
.card__foot .price{
  display:flex;flex-direction:column;align-items:flex-start;
  line-height:1;
  gap:4px;
}
.card__foot .price__from{
  font-family:"Inter",sans-serif;
  font-size:9.5px;
  font-weight:600;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:#A8801F;
}
.card__foot .price__value{
  display:inline-flex;align-items:baseline;gap:5px;
  font-family:"DM Sans","Inter",system-ui,sans-serif;
  font-weight:600;
  font-size:1.7rem;
  color:var(--ink);
  letter-spacing:-0.015em;
  line-height:1;
  font-variant-numeric:lining-nums tabular-nums;
  font-feature-settings:"lnum" 1, "tnum" 1;
}
.card__foot .price__cur{
  font-family:"DM Sans","Inter",system-ui,sans-serif;
  font-size:0.7em;
  font-weight:500;
  color:var(--gold);
  letter-spacing:0.02em;
  font-style:normal;
  transform:translateY(-1px);
}
.card__foot .price__num{
  font-variant-numeric:lining-nums tabular-nums;
  font-feature-settings:"lnum" 1, "tnum" 1;
}
.card__foot .price__cur{
  font-size:0.7rem;
  font-weight:500;
  color:#A8801F;
  letter-spacing:0.04em;
  font-style:italic;
  align-self:flex-start;
  margin-top:6px;
}

/* Wide card — Barbería */
.card--wide{
  grid-column:1 / -1;
  flex-direction:row;
  align-items:stretch;
  background:linear-gradient(135deg, #1A1A1A 0%, #2A2520 100%);
  color:#F5EFE7;
  border-color:transparent;
  box-shadow:var(--shadow-md);
}
.card--wide .card__img{
  flex:1 1 45%;
  aspect-ratio:auto;
  align-self:stretch;
  min-height:320px;
  filter:grayscale(0.15) brightness(0.95);
}
.card--wide:hover .card__img{transform:scale(1.04)}
.card--wide .card__body{
  flex:1 1 55%;
  padding:48px 56px;
  gap:14px;
  justify-content:center;
}
.card--wide__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.card--wide .card__icon{margin-bottom:0;border-color:var(--gold);background:rgba(201,155,42,0.08)}
.card--wide__tag{
  font-size:10px;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--gold);font-weight:500;
  padding:6px 14px;border:1px solid var(--gold);border-radius:999px;
}
.card__monogram{
  width:60px;height:60px;flex:none;
  display:flex;align-items:center;justify-content:center;
}
.card__monogram svg{width:100%;height:100%;display:block}
.card--wide h3{color:#F5EFE7;font-size:1.9rem;font-weight:500}
.card--wide h3 .gold{color:var(--gold-soft)}
.card--wide__title{
  font-family:var(--serif-display);
  font-weight:var(--display-weight);
  letter-spacing:var(--display-tracking);
  text-transform:var(--display-case);
  font-size:clamp(2rem,3.4vw,3rem);
  line-height:1.05;
  margin:6px 0 14px;
}
.card--wide__title .italic, .card--wide__title .gold{
  font-family:inherit;
  font-style:inherit;
  font-weight:inherit;
  text-transform:inherit;
  letter-spacing:inherit;
  color:var(--gold-soft);
}
.card--wide p{color:#B8AFA6;font-size:1rem;line-height:1.65;max-width:520px}
.card--wide__list{
  display:grid;grid-template-columns:repeat(2,1fr);gap:10px 28px;
  margin:14px 0 18px;
  list-style:none;
}
.card--wide__list li{
  font-size:0.92rem;color:#E2DAD0;
  display:flex;align-items:center;gap:12px;
  letter-spacing:0.02em;
}
.card--wide__list li::before{
  content:"";width:8px;height:8px;flex:none;
  background:linear-gradient(135deg,var(--gold-soft) 0%,var(--gold) 100%);
  transform:rotate(45deg);
  box-shadow:0 0 0 1px rgba(239,200,94,0.25), 0 0 8px rgba(201,155,42,0.45);
  border-radius:1px;
}
.card--wide .card__foot{border-top-color:rgba(255,255,255,0.08);margin-top:8px}
.card--wide .card__foot--feature{
  padding-top:22px;margin-top:16px;
  align-items:center;
}
.card--wide .price--feature{
  display:inline-flex;align-items:baseline;gap:8px;
  font-family:var(--serif);
  color:#F5EFE7;
}
.card--wide .price--feature .price__from{
  font-family:var(--sans);
  font-size:10px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--gold);font-weight:500;
  align-self:center;
  padding-right:10px;margin-right:2px;
  border-right:1px solid rgba(201,155,42,0.4);
}
.card--wide .price--feature .price__currency{
  font-family:var(--serif);font-style:italic;
  font-size:1.05rem;color:var(--gold-soft);
  font-weight:400;
}
.card--wide .price--feature strong{
  font-family:var(--serif-display);
  font-weight:var(--display-weight);
  letter-spacing:-0.01em;
  font-size:2.6rem;line-height:1;
  color:var(--gold-soft);
  text-shadow:0 1px 0 rgba(0,0,0,0.15);
}
.card--wide .card__foot .price{color:#9C918A}
.card--wide .card__foot .price strong{color:#F5EFE7}
.card--wide .btn--mini{background:var(--gold);color:#1A1A1A}
.card--wide .btn--mini:hover{background:var(--gold-soft)}

@media (max-width:768px){
  .card--wide{flex-direction:column}
  .card--wide .card__img{min-height:240px;aspect-ratio:5/3}
  .card--wide .card__body{padding:32px 28px}
  .card--wide__list{grid-template-columns:1fr}
}

/* ================ Feature section ================ */
.feature{
  background:linear-gradient(135deg, #0E0B07 0%, #1A1410 100%);
  padding:120px 0;
  position:relative;overflow:hidden;
}
.feature__deco{
  position:absolute;top:-100px;right:-100px;
  width:400px;height:400px;
  border:1px solid var(--line-gold);border-radius:50%;
  pointer-events:none;
}
.feature__deco::after{
  content:"";position:absolute;inset:30px;
  border:1px solid var(--line-gold);border-radius:50%;
  opacity:0.5;
}
.feature__grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative;z-index:1}
.feature__copy h2{margin:16px 0 24px}
.feature__copy p{color:var(--muted);font-size:1.05rem;max-width:480px;line-height:1.7}
.pills{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin:40px 0}
.pills li{
  display:flex;align-items:center;gap:12px;
  padding:16px 20px;background:rgba(255,255,255,0.6);
  border-radius:var(--r-sm);border:1px solid rgba(255,255,255,0.8);
  font-size:11px;font-weight:500;letter-spacing:0.12em;
}
.feature__visual{position:relative;aspect-ratio:1/1;max-height:560px}
.feature__img{position:absolute;background-size:cover;background-position:center;border-radius:var(--r-md);box-shadow:var(--shadow-md)}
.feature__img--a{top:0;left:0;width:75%;height:75%}
.feature__img--b{bottom:0;right:0;width:55%;height:55%;border:8px solid var(--surface)}
.feature__tag{
  position:absolute;top:20%;right:-10px;
  background:var(--white);padding:18px 22px;
  border-radius:var(--r-sm);box-shadow:var(--shadow-md);
  display:flex;flex-direction:column;gap:2px;z-index:2;
  border:1px solid var(--line-gold);
}
.feature__tag em{font-family:var(--script);color:var(--gold);font-size:1.2rem;font-style:normal}
.feature__tag strong{font-family:var(--serif);font-weight:500;font-size:0.95rem;letter-spacing:0.04em}

@media (max-width:980px){
  .feature__grid{grid-template-columns:1fr;gap:60px}
  .feature__visual{max-width:480px;margin:0 auto}
  .pills{grid-template-columns:1fr}
}

/* ================ About — editorial centered layout ================ */
.about-editorial{position:relative;overflow:hidden;padding:140px 0 0}
.about-editorial + .section{padding-top:70px}

/* ----- ambient atmosphere ----- */
.about-edi__atmos{
  position:absolute;inset:0;
  pointer-events:none;overflow:hidden;
  z-index:0;
}
.about-edi__orb{
  position:absolute;border-radius:50%;
  filter:blur(80px);opacity:0.55;
  will-change:transform;
}
.about-edi__orb--gold{
  width:520px;height:520px;top:-160px;left:-120px;
  background:radial-gradient(circle, rgba(201,155,42,0.40), rgba(201,155,42,0) 70%);
  animation:floatA 16s ease-in-out infinite;
}
.about-edi__orb--amber{
  width:460px;height:460px;bottom:-180px;right:-120px;
  background:radial-gradient(circle, rgba(239,200,94,0.42), rgba(201,155,42,0) 70%);
  animation:floatB 20s ease-in-out infinite;
}
.about-edi__orb--cream{
  width:380px;height:380px;top:45%;left:50%;transform:translate(-50%,-50%);
  background:radial-gradient(circle, rgba(255,235,180,0.30), rgba(255,235,180,0) 70%);
  animation:floatC 22s ease-in-out infinite;
}
.about-edi__stars{
  position:absolute;inset:0;pointer-events:none;overflow:hidden;
}
.about-edi__star{
  position:absolute;top:-20px;
  left:var(--x, 50%);
  width:var(--s, 6px);height:var(--s, 6px);
  opacity:0;
  background:
    radial-gradient(circle, rgba(255,245,200,0.95) 0%, rgba(239,200,94,0.6) 30%, transparent 60%);
  border-radius:50%;
  box-shadow:0 0 8px 1px rgba(239,200,94,0.55);
  animation:starFall var(--dur, 12s) linear infinite;
  animation-delay:var(--d, 0s);
  will-change:transform, opacity;
}
.about-edi__star::before,
.about-edi__star::after{
  content:"";position:absolute;left:50%;top:50%;
  width:1px;height:calc(var(--s, 6px) * 3);
  background:linear-gradient(180deg, transparent, rgba(239,200,94,0.85), transparent);
  transform:translate(-50%,-50%);
}
.about-edi__star::after{
  transform:translate(-50%,-50%) rotate(90deg);
}
@media (prefers-reduced-motion: reduce){
  .about-edi__star{animation:none;display:none}
  .about-edi__orb{animation:none}
}
.about-edi{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;
  text-align:center;
  max-width:760px;
}
.about-edi__eyebrow{
  display:block;
  font-size:1.5rem;
  color:var(--gold);
  margin-bottom:32px;
}

.about-edi__crest{
  display:flex;align-items:center;justify-content:center;
  width:100%;
  margin-bottom:40px;
}
.about-edi__logo{
  width:clamp(200px, 26vw, 300px);
  height:auto;
  filter:drop-shadow(0 8px 26px rgba(201,155,42,0.22));
  flex:none;
}

.about-edi__title{
  font-size:clamp(2rem, 3.5vw, 2.8rem);
  line-height:1.15;
  margin-bottom:36px;
  text-wrap:balance;
}

.about-edi__copy{max-width:620px;margin-bottom:28px}
.about-edi__copy p{
  font-size:1.05rem;
  line-height:1.85;
  color:var(--ink);
  margin-bottom:18px;
}
.about-edi__copy p.muted{
  color:var(--muted);
  font-style:italic;
  font-family:var(--serif);
  font-size:1.15rem;
}

.about-edi__milestone{
  position:relative;
  display:inline-flex;align-items:center;gap:32px;
  padding:28px 8px;
  background:transparent;
  border:none;
}
.about-edi__num{
  font-family:var(--serif-display, var(--serif));
  font-weight:600;
  font-size:clamp(4rem, 6.4vw, 5.8rem);
  line-height:1;
  color:var(--gold-soft);
  letter-spacing:-0.035em;
  font-variant-numeric:lining-nums;
  text-shadow:0 2px 28px rgba(201,155,42,0.30);
  display:inline-flex;align-items:baseline;
}
.about-edi__plus{
  font-size:0.5em;
  font-weight:500;
  line-height:1;
  margin-right:0.04em;
  align-self:center;
  position:relative;
  top:-0.12em;
}
.about-edi__label{
  display:flex;flex-direction:column;gap:8px;
  text-align:left;
}
.about-edi__lead{
  font-family:var(--serif);
  font-style:italic;
  font-weight:400;
  font-size:1.35rem;
  color:var(--ink);
  line-height:1.1;
  letter-spacing:0.005em;
}
.about-edi__sub{
  font-size:10.5px;
  letter-spacing:0.24em;
  text-transform:uppercase;
  color:#9C927F;
  line-height:1.4;
  font-weight:400;
}

@media (max-width:680px){
  .about-editorial{padding:100px 0 0}
  .about-editorial + .section{padding-top:60px}
  .about-edi__crest{margin-bottom:32px}
  .about-edi__milestone{gap:22px;padding:20px 4px}
  .about-edi__lead{font-size:1.15rem}
  .about-edi__sub{font-size:10px;letter-spacing:0.2em}
}

/* ================ About v2 (deprecated) ================ */
.about-v2{position:relative;overflow:hidden}
.about-v2__watermark{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:min(120%, 1400px);
  max-width:none;
  opacity:0.04;
  pointer-events:none;
  user-select:none;
  z-index:0;
}
.about-v2__inner{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;
  text-align:center;
  max-width:780px;
}
.about-v2__crest{
  display:flex;align-items:center;justify-content:center;
  gap:28px;
  width:100%;
  margin-bottom:40px;
}
.about-v2__crest img{
  width:clamp(180px, 22vw, 260px);
  height:auto;
  filter:drop-shadow(0 6px 22px rgba(201,155,42,0.25));
}
.about-v2__rule{
  flex:1;height:1px;max-width:160px;
  background:linear-gradient(90deg, transparent, var(--line-gold) 50%, transparent);
}
.about-v2__head .script{display:block;margin-bottom:14px;font-size:1.5rem}
.about-v2__head h2{margin-bottom:32px}
.about-v2__body{max-width:620px}
.about-v2__body p{
  font-size:1.05rem;
  line-height:1.85;
  color:var(--ink);
  margin-bottom:18px;
}
.about-v2__body p.muted{color:var(--muted);font-style:italic}
.about-v2__milestone{
  display:inline-flex;align-items:center;gap:28px;
  margin-top:48px;padding:28px 44px;
  border:1px solid var(--line-gold);
  border-radius:var(--r-sm);
  background:rgba(255,255,255,0.5);
  backdrop-filter:blur(2px);
}
.about-v2__milestone .milestone__label{text-align:left}

@media (max-width:680px){
  .about-v2__crest{gap:16px;margin-bottom:32px}
  .about-v2__rule{max-width:60px}
  .about-v2__milestone{flex-direction:row;gap:20px;padding:22px 28px}
}

/* ================ About (legacy, kept for safety) ================ */
.about{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about__visual{position:relative;aspect-ratio:4/5;max-height:520px}
.about__img{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  border-radius:var(--r-md);box-shadow:var(--shadow-md);
}
.about__logo{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
}
.about__logo img{
  width:100%;
  max-width:480px;
  height:auto;
  object-fit:contain;
  filter:drop-shadow(0 8px 28px rgba(201,155,42,0.22));
}
.about__chip{
  position:absolute;bottom:-20px;right:-20px;
  background:var(--cream);padding:18px 28px;
  border:1px solid var(--line-gold);border-radius:var(--r-sm);
  box-shadow:var(--shadow-sm);
}
.about__chip .script{font-size:1.5rem}
.about__copy .script{display:block;margin-bottom:12px;font-size:1.5rem}
.about__copy h2{margin-bottom:24px}
.about__copy p{margin-bottom:16px;font-size:1.02rem;color:var(--ink);line-height:1.75}
.about__copy p.muted{color:var(--muted)}

.milestone{
  display:flex;align-items:center;gap:28px;
  margin-top:44px;padding-top:36px;
  border-top:1px solid var(--line);
}
.milestone__num{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(3.6rem,5.5vw,5rem);
  line-height:1;
  color:var(--ink);
  letter-spacing:-0.02em;
}
.milestone__rule{
  width:1px;height:64px;
  background:linear-gradient(180deg, transparent, var(--line-gold) 30%, var(--line-gold) 70%, transparent);
  flex:none;
}
.milestone__label{display:flex;flex-direction:column;gap:6px}
.milestone__lead{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.5rem;
  color:var(--gold);
  line-height:1.1;
}
.milestone__sub{
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--muted);
  line-height:1.4;
}

@media (max-width:520px){
  .milestone{gap:20px}
  .milestone__rule{height:54px}
  .milestone__lead{font-size:1.25rem}
}

@media (max-width:980px){
  .about{grid-template-columns:1fr;gap:60px}
  .about__visual{max-width:480px;margin:0 auto}
}

/* ================ Gallery ================ */
.gallery{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:180px;
  gap:14px;
  margin-bottom:96px;
}
.g{
  background-size:cover;background-position:center;
  border-radius:var(--r-sm);
  overflow:hidden;
  cursor:pointer;
  transition:transform .6s cubic-bezier(.2,.7,.2,1), box-shadow .4s;
  position:relative;
}
.g::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.2));
  opacity:0;transition:opacity .35s;
}
.g:hover{transform:scale(1.02);box-shadow:var(--shadow-md);z-index:2}
.g:hover::after{opacity:1}
.g1{grid-column:span 2;grid-row:span 2}
.g2{grid-column:span 1;grid-row:span 1}
.g3{grid-column:span 1;grid-row:span 2}
.g4{grid-column:span 1;grid-row:span 1}
.g5{grid-column:span 1;grid-row:span 2}
.g6{grid-column:span 1;grid-row:span 1}
.g7{grid-column:span 2;grid-row:span 1}
.g8{grid-column:span 1;grid-row:span 1}
.g9{grid-column:span 1;grid-row:span 2}

@media (max-width:768px){
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .g1,.g3,.g5,.g7,.g9{grid-column:span 1;grid-row:span 1}
}

.ba-head{text-align:center;margin-bottom:40px}
.ba-head .script{font-size:1.6rem;display:block;margin-bottom:8px}
.ba-head h3{font-size:1.6rem;font-weight:400}

.ba-row{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:900px){.ba-row{grid-template-columns:1fr;max-width:500px;margin:0 auto}}

.ba{
  position:relative;aspect-ratio:4/5;
  border-radius:var(--r-md);overflow:hidden;
  box-shadow:var(--shadow-md);
  cursor:ew-resize;
  user-select:none;
  background:var(--gold);
}
.ba__before,.ba__after{position:absolute;inset:0;background-size:cover;background-position:center}
.ba__after{clip-path:inset(0 0 0 50%)}
.ba__handle{
  position:absolute;top:0;bottom:0;left:50%;
  width:2px;background:white;
  box-shadow:0 0 12px rgba(0,0,0,0.4);
  transform:translateX(-50%);
  pointer-events:none;
}
.ba__handle span{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:40px;height:40px;border-radius:50%;background:white;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 14px rgba(0,0,0,0.3);
}
.ba__handle span::before,.ba__handle span::after{
  content:"";position:absolute;width:0;height:0;
  border-top:5px solid transparent;border-bottom:5px solid transparent;
}
.ba__handle span::before{border-right:7px solid var(--ink);left:11px}
.ba__handle span::after{border-left:7px solid var(--ink);right:11px}
.ba__label{
  position:absolute;top:14px;
  padding:7px 14px;border-radius:999px;
  font-family:"DM Sans","Inter",system-ui,sans-serif;
  font-size:10px;font-weight:600;
  letter-spacing:0.16em;text-transform:uppercase;
  backdrop-filter:saturate(180%) blur(8px);
  -webkit-backdrop-filter:saturate(180%) blur(8px);
  box-shadow:0 4px 14px rgba(0,0,0,0.35);
}
.ba__label--l{
  left:14px;
  background:rgba(10,10,10,0.78);
  color:var(--gold-soft);
  border:1px solid var(--line-gold);
}
.ba__label--r{
  right:14px;
  background:var(--gold);
  color:#0A0A0A;
  border:1px solid var(--gold);
}

/* ================ Brands marquee ================ */
.brands{
  padding:96px 0 80px;
  background:var(--cream);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  overflow:hidden;
}
.brands__head{text-align:center;max-width:680px;margin:0 auto 56px}
.brands__head .script{display:block;margin-bottom:12px}
.brands__head h2{font-size:clamp(1.8rem,3.4vw,2.6rem)}
.brands__sub{color:var(--muted);margin-top:14px;font-size:1rem;line-height:1.65}

.marquee{overflow:hidden;mask:linear-gradient(90deg,transparent,black 8%,black 92%,transparent);-webkit-mask:linear-gradient(90deg,transparent,black 8%,black 92%,transparent)}
.marquee__track{
  display:flex;gap:56px;width:max-content;
  animation:marquee 42s linear infinite;
  align-items:center;
}
.marquee__track span{
  font-family:var(--serif);font-size:1.9rem;letter-spacing:0.16em;
  color:var(--ink);font-weight:500;
  text-transform:uppercase;
  white-space:nowrap;
}
.marquee__track span.alt{
  font-family:var(--serif);font-style:italic;font-weight:500;
  color:var(--gold);letter-spacing:0.04em;
  text-transform:none;font-size:2.1rem;
}
.marquee__track .sep{
  color:var(--gold);font-size:1rem;letter-spacing:0;
  font-family:var(--sans);font-weight:300;
  opacity:0.6;
}
@keyframes marquee{to{transform:translateX(-50%)}}

@media (max-width:640px){
  .marquee__track{gap:40px}
  .marquee__track span{font-size:1.5rem}
  .marquee__track span.alt{font-size:1.7rem}
}

/* ================ Testimonios ================ */
.testis{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media (max-width:1100px){.testis{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.testis{grid-template-columns:1fr}}
.testi{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--r-md);
  padding:32px;
  box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;gap:18px;
  position:relative;
  transition:transform .4s;
}
.testi::before{
  content:"";position:absolute;top:0;left:32px;right:32px;height:2px;
  background:linear-gradient(90deg,var(--gold),var(--gold-soft));
  border-radius:0 0 2px 2px;
}
.testi:hover{transform:translateY(-4px)}
.stars{color:var(--gold);letter-spacing:4px;font-size:1.1rem}
.testi p{font-size:0.95rem;color:var(--ink);line-height:1.65;flex:1;font-style:italic}
.testi footer{display:flex;align-items:center;gap:12px;padding-top:12px;border-top:1px solid var(--line)}
.avatar{width:44px;height:44px;border-radius:50%;background-size:cover;background-position:center;border:2px solid var(--gold-soft)}
.testi footer strong{display:block;font-family:var(--serif);font-size:1.05rem;font-weight:500}
.testi footer span{font-size:0.8rem;color:var(--muted)}

/* ================ Promos ================ */
.promos{
  display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
  align-items:stretch;
  padding-top:8px;
}
@media (max-width:900px){.promos{grid-template-columns:1fr;max-width:500px;margin:0 auto}}

.promo{
  background:linear-gradient(180deg, #15110D 0%, #0E0B07 100%);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:36px 32px 32px;
  display:flex;flex-direction:column;
  position:relative;
  isolation:isolate;
  overflow:hidden;
  transition:transform .45s cubic-bezier(.2,.7,.2,1), border-color .4s, box-shadow .4s;
}
.promo::before{
  /* Soft top-left gold sheen */
  content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(180px 130px at 12% 0%, rgba(201,155,42,0.10), transparent 70%);
  opacity:0.85;
  transition:opacity .4s;
}
.promo:hover{
  transform:translateY(-6px);
  border-color:var(--line-gold);
  box-shadow:0 24px 50px -20px rgba(0,0,0,0.55), 0 0 0 1px rgba(201,155,42,0.18) inset;
}
.promo:hover::before{opacity:1}

/* Tag */
.promo__tag{
  align-self:flex-start;
  background:transparent;
  color:var(--gold-soft);
  border:1px solid var(--line-gold);
  padding:6px 12px;border-radius:999px;
  font-size:9.5px;letter-spacing:0.22em;
  text-transform:uppercase;font-weight:600;
}
.promo__tag--gold{
  background:var(--gold);color:#0A0A0A;border-color:var(--gold);
}

/* Title + decorative rule */
.promo h3{
  font-family:var(--serif);font-weight:500;
  font-size:1.5rem;line-height:1.18;
  text-wrap:balance;
  text-align:center;
  letter-spacing:-0.005em;
  margin:18px 0 18px;
  color:var(--ink);
}
.promo__plus{
  font-family:var(--serif);font-style:italic;font-weight:400;
  color:var(--gold);font-size:1.15em;
  margin:0 2px;
  vertical-align:-1px;
}
.promo p{
  color:var(--muted);font-size:0.93rem;
  line-height:1.65;
  margin:0 0 32px;flex:1;
  max-width:38ch;
}

/* Foot block: price + CTA */
.promo__foot{
  display:flex;flex-direction:column;gap:18px;
}

.promo__price{
  display:flex;align-items:baseline;gap:10px;
  font-family:var(--serif);
}
.promo__price-from{
  font-size:11px;letter-spacing:0.2em;
  color:var(--muted);text-transform:uppercase;font-weight:500;
  font-family:var(--sans);
}
.promo__price-amt{
  display:inline-flex;align-items:baseline;gap:5px;
  font-variant-numeric:lining-nums tabular-nums;
  font-feature-settings:"lnum" 1, "tnum" 1;
}
.promo__price-amt .cur{
  font-family:"DM Sans","Inter",system-ui,sans-serif;
  font-size:1.05rem;font-weight:500;
  color:var(--gold);font-style:normal;
  letter-spacing:0.02em;
  transform:translateY(-2px);
}
.promo__price-amt strong{
  font-family:"DM Sans","Inter",system-ui,sans-serif;
  font-weight:600;
  font-size:2.4rem;line-height:1;
  color:var(--ink);
  letter-spacing:-0.015em;
  font-variant-numeric:lining-nums tabular-nums;
  font-feature-settings:"lnum" 1, "tnum" 1;
}

/* CTA inside promo: arrow icon */
.promo .btn--full{
  gap:8px;
}
.promo .btn--full svg{
  transition:transform .3s;
}
.promo .btn--full:hover svg{
  transform:translateX(3px);
}

/* Featured variant — animated gold conic frame */
.promo--featured{
  border-color:transparent;
  background:
    linear-gradient(180deg, #1A1410 0%, #100C08 100%) padding-box,
    conic-gradient(from 0deg, var(--gold-deep), var(--gold), var(--gold-soft), var(--gold), var(--gold-deep)) border-box;
  border:1px solid transparent;
  transform:translateY(-6px);
  z-index:1;
  box-shadow:
    0 30px 60px -24px rgba(0,0,0,0.7),
    0 0 0 1px rgba(201,155,42,0.18) inset,
    0 0 60px -10px rgba(201,155,42,0.12);
}
.promo--featured::before{
  background:
    radial-gradient(280px 200px at 12% 0%, rgba(201,155,42,0.18), transparent 70%),
    radial-gradient(220px 160px at 88% 100%, rgba(201,155,42,0.12), transparent 70%);
  opacity:1;
}
.promo--featured:hover{
  transform:translateY(-12px);
  box-shadow:
    0 36px 70px -22px rgba(0,0,0,0.75),
    0 0 0 1px rgba(201,155,42,0.28) inset,
    0 0 80px -10px rgba(201,155,42,0.22);
}
.promo--featured h3{font-size:1.78rem}

@media (max-width:900px){
  .promo--featured{transform:none}
  .promo--featured:hover{transform:translateY(-6px)}
}
@media (max-width:520px){
  .promo{padding:30px 24px 26px}
  .promo h3{font-size:1.45rem}
  .promo--featured h3{font-size:1.55rem}
  .promo__price-amt strong{font-size:2.2rem}
}

/* ================ FAQ ================ */
.faq-wrap{
  display:grid;grid-template-columns:0.85fr 1.6fr;
  gap:96px;align-items:start;
}
@media (max-width:980px){.faq-wrap{grid-template-columns:1fr;gap:48px}}

.faq-aside{position:sticky;top:120px;align-self:center}
@media (max-width:980px){.faq-aside{position:static}}
.faq-aside .script{display:block;margin-bottom:14px;font-size:1.5rem}
.faq-aside h2{margin-bottom:22px;line-height:1.05}
.faq-aside__lead{
  color:var(--muted);
  font-size:1rem;line-height:1.7;
  max-width:360px;margin-bottom:36px;
}

.faq-filters{
  display:flex;flex-wrap:wrap;gap:8px;
  margin-bottom:36px;
}
.faq-filter{
  appearance:none;background:transparent;
  border:1px solid var(--line);
  color:var(--ink);
  font-family:inherit;font-size:11px;font-weight:500;
  letter-spacing:0.16em;text-transform:uppercase;
  padding:9px 16px;border-radius:999px;
  cursor:pointer;
  display:inline-flex;align-items:center;gap:8px;
  transition:all .25s ease;
}
.faq-filter em{
  font-style:normal;font-size:9px;
  color:var(--muted);letter-spacing:0.08em;
}
.faq-filter:hover{border-color:var(--gold);color:var(--gold)}
.faq-filter:hover em{color:var(--gold)}
.faq-filter.is-active{
  background:var(--gold);color:#0A0A0A;border-color:var(--gold);
}
.faq-filter.is-active em{color:#0A0A0A;opacity:0.7}

.faq-help{
  display:flex;align-items:center;gap:14px;
  padding:18px 18px 18px 16px;
  border:1px solid var(--line);
  border-radius:var(--r-md);
  background:linear-gradient(180deg, var(--surface) 0%, var(--surface-2) 100%);
  position:relative;overflow:hidden;
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s, border-color .35s;
}
.faq-help::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(140px 80px at 80% 0%, rgba(201,155,42,0.18), transparent 70%);
  opacity:0;transition:opacity .35s;
}
.faq-help:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 36px -22px rgba(26,26,26,0.25);
  border-color:var(--line-gold);
}
.faq-help:hover::before{opacity:1}
.faq-help__ic{
  flex:none;width:44px;height:44px;border-radius:50%;
  background:var(--gold);color:#0A0A0A;
  display:flex;align-items:center;justify-content:center;
  position:relative;z-index:1;
}
.faq-help__body{flex:1;display:flex;flex-direction:column;gap:2px;position:relative;z-index:1;min-width:0}
.faq-help__body strong{
  font-family:var(--serif);font-weight:500;
  font-size:1.15rem;color:var(--ink);line-height:1.2;
}
.faq-help__body small{
  font-size:11px;letter-spacing:0.06em;color:var(--muted);
}
.faq-help__arrow{
  flex:none;width:28px;height:28px;border-radius:50%;
  border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  color:var(--ink);transition:all .3s;position:relative;z-index:1;
}
.faq-help:hover .faq-help__arrow{
  background:var(--gold);color:#fff;border-color:var(--gold);
  transform:translateX(4px);
}

/* FAQ list */
.faqs{display:flex;flex-direction:column;gap:0}
.faqs .faq{
  border-top:1px solid var(--line);
  transition:opacity .3s, transform .3s;
}
.faqs .faq:last-child{border-bottom:1px solid var(--line)}
.faqs .faq[hidden]{display:none}
.faqs summary{
  list-style:none;cursor:pointer;
  display:grid;grid-template-columns:auto 1fr auto;
  align-items:center;gap:24px;
  padding:26px 4px 26px 0;
  position:relative;
  transition:color .3s;
}
.faqs summary::-webkit-details-marker{display:none}
.faqs summary::before{
  content:"";position:absolute;left:0;right:0;top:0;bottom:0;
  background:linear-gradient(90deg, rgba(201,155,42,0.06), transparent 60%);
  opacity:0;transition:opacity .3s;
  pointer-events:none;
}
.faqs summary:hover::before{opacity:1}

.faq__num{
  font-family:var(--serif);font-style:italic;
  font-size:1.4rem;color:var(--gold);
  letter-spacing:0.02em;line-height:1;
  min-width:34px;
  transition:transform .35s cubic-bezier(.2,.7,.2,1), color .3s;
}
.faq__body{display:flex;flex-direction:column;gap:4px;min-width:0}
.faq__tag{
  font-size:10px;letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--muted);font-weight:500;
  transition:color .3s;
}
.faq__q{
  font-family:"DM Sans","Inter",system-ui,sans-serif;
  font-weight:500;
  font-size:clamp(1rem, 1.2vw, 1.12rem);
  color:var(--ink);line-height:1.4;
  letter-spacing:-0.005em;
  letter-spacing:-0.005em;
}

.faq__toggle{
  flex:none;width:36px;height:36px;border-radius:50%;
  border:1px solid var(--line);
  position:relative;
  transition:all .35s cubic-bezier(.2,.7,.2,1);
}
.faq__toggle i{
  position:absolute;top:50%;left:50%;
  background:var(--ink);
  transition:transform .35s cubic-bezier(.2,.7,.2,1), background .3s;
}
.faq__toggle i:nth-child(1){width:12px;height:1px;transform:translate(-50%,-50%)}
.faq__toggle i:nth-child(2){width:1px;height:12px;transform:translate(-50%,-50%)}
.faqs summary:hover .faq__toggle{border-color:var(--gold)}
.faqs summary:hover .faq__num{transform:translateX(3px)}

/* Open state */
.faq[open] .faq__num{color:var(--gold-soft)}
.faq[open] .faq__tag{color:var(--gold)}
.faq[open] .faq__toggle{
  background:var(--gold);border-color:var(--gold);
  transform:rotate(180deg);
}
.faq[open] .faq__toggle i{background:#0A0A0A}
.faq[open] .faq__toggle i:nth-child(2){transform:translate(-50%,-50%) rotate(90deg)}

/* Answer */
.faq__a{
  padding:0 0 28px 58px;
  animation:faqIn .45s cubic-bezier(.2,.7,.2,1);
}
.faq__a p{
  margin:0;color:var(--muted);
  font-family:"DM Sans","Inter",system-ui,sans-serif;
  font-weight:400;
  font-size:0.96rem;line-height:1.7;
  max-width:62ch;
  position:relative;padding-left:18px;
}
.faq__a p::before{
  content:"";position:absolute;left:0;top:6px;bottom:6px;width:1px;
  background:linear-gradient(180deg, var(--gold) 0%, transparent 100%);
}
@keyframes faqIn{
  from{opacity:0;transform:translateY(-4px)}
  to{opacity:1;transform:translateY(0)}
}

@media (max-width:600px){
  .faqs summary{gap:14px;padding:22px 0}
  .faq__num{font-size:1.2rem;min-width:28px}
  .faq__a{padding-left:42px}
  .faq__toggle{width:32px;height:32px}
}

/* ================ Contact ================ */
.contact{display:grid;grid-template-columns:1fr 1.2fr;gap:48px;align-items:stretch}
@media (max-width:900px){.contact{grid-template-columns:1fr}}
.contact__info{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:48px;
  display:flex;flex-direction:column;gap:32px;
}
.contact__info ul{display:flex;flex-direction:column;gap:24px;flex:1}
.contact__info li{display:flex;gap:18px;align-items:flex-start}
.contact__info .ic{
  flex:none;width:46px;height:46px;border-radius:50%;
  border:1px solid var(--line-gold);
  display:flex;align-items:center;justify-content:center;
  background:var(--surface-2);
}
.contact__info strong{
  display:block;
  font-family:"DM Sans","Inter",system-ui,sans-serif;
  font-size:0.92rem;font-weight:600;
  letter-spacing:0.04em;
  color:var(--ink);
  margin-bottom:4px;
}
.contact__info li > div > span,
.contact__info li > div span{
  font-family:"DM Sans","Inter",system-ui,sans-serif;
  font-weight:400;
  color:var(--muted);font-size:0.92rem;line-height:1.55;
  letter-spacing:0.005em;
}

/* Clickable contact links (WhatsApp / Instagram / TikTok) */
.contact__li--link{position:relative}
.contact__link{
  display:flex;gap:18px;align-items:center;
  text-decoration:none;
  padding:6px 8px;margin:-6px -8px;
  border-radius:var(--r-md);
  transition:background .25s ease;
}
.contact__link > div{flex:1;min-width:0}
.contact__link:hover{background:rgba(201,155,42,0.06)}
.contact__link:hover strong{color:var(--gold-soft)}
.contact__link-arrow{
  color:var(--muted);flex:none;
  opacity:0;transform:translate(-4px,4px);
  transition:opacity .25s, transform .25s, color .25s;
}
.contact__link:hover .contact__link-arrow{
  opacity:1;transform:translate(0,0);color:var(--gold);
}

/* Branded icon wells */
.contact__info .ic.ic--wa,
.contact__info .ic.ic--ig,
.contact__info .ic.ic--tt{
  background:var(--surface-2);
  border:1px solid var(--line-gold);
  transition:all .3s ease;
  overflow:hidden;
  position:relative;
}
.contact__info .ic.ic--wa svg,
.contact__info .ic.ic--ig svg,
.contact__info .ic.ic--tt svg{
  display:block;
  margin:0 auto;
}
.contact__info .ic.ic--wa svg{color:#25D366;transform:translate(1px,0)}
.contact__info .ic.ic--ig{
  position:relative;
}
.contact__info .ic.ic--ig svg{
  color:#E4405F;
  position:relative;z-index:1;
}
.contact__info .ic.ic--tt svg{color:var(--ink);transform:translate(2px,1px)}
.contact__info .ic.ic--tt{position:relative}

.contact__link:hover .ic--wa{background:#25D366;border-color:#25D366}
.contact__link:hover .ic--wa svg{color:#fff}
.contact__link:hover .ic--ig{
  background:linear-gradient(45deg, #F58529 0%, #DD2A7B 50%, #8134AF 100%);
  border-color:transparent;
}
.contact__link:hover .ic--ig svg{color:#fff}
.contact__link:hover .ic--tt{background:var(--ink);border-color:var(--ink)}
.contact__link:hover .ic--tt svg{color:#0A0A0A}

/* Cómo llegar — nav buttons inside the info card */
.contact__nav{
  display:flex;flex-direction:column;gap:10px;
  padding-top:24px;
  border-top:1px solid var(--line);
}
.contact__nav-label{
  font-family:"DM Sans","Inter",system-ui,sans-serif;
  font-size:10px;letter-spacing:0.24em;text-transform:uppercase;
  color:var(--gold);font-weight:600;
}
.contact__nav-btns{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
}
.contact__nav-btn{
  display:flex;align-items:center;gap:12px;
  padding:14px 16px;
  background:var(--surface-2);
  border:1px solid var(--line);
  border-radius:var(--r-md);
  color:var(--ink);
  font-family:"DM Sans","Inter",system-ui,sans-serif;
  font-size:0.95rem;font-weight:600;
  letter-spacing:0.01em;
  text-decoration:none;
  transition:all .25s ease;
  position:relative;
}
.contact__nav-btn:hover{
  border-color:var(--gold);
  background:rgba(201,155,42,0.06);
  transform:translateY(-1px);
}
.contact__nav-ic{
  width:30px;height:30px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;flex:none;
}
.contact__nav-ic--waze{background:linear-gradient(135deg, #33CCFF 0%, #00A0E5 100%)}
.contact__nav-ic--gmaps{background:linear-gradient(135deg, #EA4335 0%, #C5221F 100%)}
.contact__nav-text{flex:1}
.contact__nav-arrow{color:var(--muted);transition:color .25s, transform .25s}
.contact__nav-btn:hover .contact__nav-arrow{color:var(--gold);transform:translate(2px,-2px)}

@media (max-width:480px){
  .contact__nav-btns{grid-template-columns:1fr}
  .contact__nav-btn{padding:12px 14px;font-size:0.9rem}
}
.contact__map{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:480px;box-shadow:var(--shadow-md)}
.contact__map iframe{position:absolute;inset:0;width:100%;height:100%;border:0}


/* ================ Footer ================ */
.footer{
  background:#050505;color:#D8CFC6;border-top:1px solid var(--line);
  padding:80px 0 0;
  position:relative;
}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:48px;padding-bottom:60px}
@media (max-width:900px){.footer__grid{grid-template-columns:1fr 1fr;gap:36px}}
@media (max-width:540px){.footer__grid{grid-template-columns:1fr}}
.footer__logo{display:block;height:80px;width:auto;margin:0 auto 18px;opacity:0.98}
.footer__grid > div:first-child{text-align:center;display:flex;flex-direction:column;align-items:center}
.footer__grid > div:first-child p{max-width:300px;text-align:center}
@media (max-width:900px){.footer__grid > div:first-child{align-items:flex-start;text-align:left}
  .footer__grid > div:first-child p{text-align:left}
  .footer__logo{margin-left:0;margin-right:auto}
}
.footer p{font-size:0.9rem;color:#9C918A;line-height:1.6;max-width:280px}
.footer h4{
  color:var(--gold-soft);font-family:var(--sans);font-size:11px;
  letter-spacing:0.2em;text-transform:uppercase;font-weight:500;
  margin-bottom:18px;
}
.footer ul{display:flex;flex-direction:column;gap:10px}
.footer ul a{color:#9C918A;font-size:0.92rem;transition:color .25s}
.footer ul a:hover{color:var(--gold-soft)}
.socials a{display:flex;align-items:center;gap:10px}
.footer__contact{font-size:0.92rem;color:#9C918A;line-height:1.8;margin-bottom:18px}
.footer__bar{
  border-top:1px solid rgba(255,255,255,0.06);
  padding:24px 0;text-align:center;
  font-size:0.82rem;color:#6E6660;letter-spacing:0.04em;
}

/* ================ Floating WA ================ */
.wa-float{
  position:fixed;bottom:24px;right:24px;z-index:90;
  width:60px;height:60px;border-radius:50%;
  background:#25D366;display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(37,211,102,0.35);
  transition:transform .3s;
}
.wa-float:hover{transform:scale(1.08)}
.wa-float__pulse{
  position:absolute;inset:0;border-radius:50%;
  background:#25D366;
  animation:pulse 2s ease-out infinite;
  z-index:-1;
}
@keyframes pulse{
  0%{transform:scale(1);opacity:0.6}
  100%{transform:scale(1.8);opacity:0}
}

/* ================ Reveal animations ================ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.is-visible{opacity:1;transform:translateY(0)}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.01ms !important;transition-duration:0.01ms !important}
  .reveal{opacity:1;transform:none}
}


/* ================ Mobile polish ================ */
@media (max-width:768px){
  .container{padding:0 20px}
  .nav__inner{padding:14px 20px;gap:16px}
  .nav__logo img{height:44px;width:auto}

  /* Section rhythm */
  .section{padding:72px 0}
  .section__head{margin-bottom:40px;padding:0 4px}
  .section__head h2,.section__head--left h2{font-size:clamp(1.6rem,6vw,2.2rem)}

  /* Hero — keep portrait + tighter copy */
  .hero__cta{flex-direction:column;align-items:center;width:100%;gap:10px}
  .hero__cta .btn{width:100%;max-width:320px;justify-content:center}
  .hero__stamp{display:none}
  .hero__badge{display:none}
  .hero__atmos{opacity:0.6}

  /* Service cards */
  .card__body{padding:22px 20px 20px}
  .card__foot{flex-wrap:wrap;gap:14px}
  .card__foot .price{flex:1 1 auto}

  /* Feature section */
  .feature{padding:80px 0}
  .feature__visual{aspect-ratio:4/5;max-width:360px}
  .feature__tag{
    top:auto;bottom:-18px;right:14px;
    padding:12px 16px;font-size:13px;
  }
  .feature__tag em{font-size:1rem}
  .feature__tag strong{font-size:0.85rem}

  /* About */
  .about__visual{aspect-ratio:4/5;max-height:420px}
  .about__copy h2{font-size:clamp(1.7rem,6.5vw,2.2rem)}

  /* Gallery — tighter rows */
  .gallery{gap:6px;grid-auto-rows:130px}

  /* Before & after */
  .ba__label{font-size:9px;padding:5px 10px;letter-spacing:0.16em}
  .ba__handle span{width:34px;height:34px}

  /* Brands marquee */
  .brands{padding:64px 0 56px}
  .brands__head{margin:0 auto 36px}

  /* Promo cards */
  .promos{gap:18px}
  .promo--featured{transform:none}
  .promo--featured:hover{transform:translateY(-6px)}
  .promo h3{font-size:1.45rem}

  /* FAQ */
  .faq-aside .faq-aside__lead{margin-bottom:24px}
  .faq-filters{margin-bottom:24px}
  .faq-filter{padding:8px 14px;font-size:10px}
  .faq-help{padding:14px}
  .faq-help__body strong{font-size:1.02rem}
  .faq-help__body small{font-size:10.5px}
  .faqs summary{padding:22px 0;gap:14px}
  .faq__q{font-size:1.02rem}
  .faq__a{padding:0 0 24px 50px}
  .faq__tag{font-size:9.5px;letter-spacing:0.18em}

  /* Contact */
  .contact{gap:32px}
  .contact__info{padding:32px 24px;gap:24px}
  .contact__info li{gap:14px}
  .contact__info .ic{width:42px;height:42px}
  .contact__map{min-height:320px}

  /* Footer */
  .footer{padding:60px 0 0}
  .footer__grid{gap:32px;padding-bottom:48px}
  .footer__logo{height:64px}

  /* Floating WA — out of the way of bottom CTAs */
  .wa-float{width:54px;height:54px;bottom:18px;right:18px}
}

@media (max-width:480px){
  .container{padding:0 18px}
  .nav__inner{padding:12px 16px;gap:12px}
  .nav__logo img{height:38px}
  .nav__burger{width:26px;height:26px}

  .section{padding:64px 0}
  .section__head{margin-bottom:32px}

  /* Hero phone tuning */
  .hero{padding:72px 0 24px}
  .hero__grid{padding:0 16px;gap:20px}
  .hero__frame{max-width:260px;aspect-ratio:3/4}
  .hero__title{font-size:clamp(1.6rem,9vw,2rem);gap:2px}
  .hero__sub--lead{font-size:1.1rem;margin:6px 0 24px}
  .hero__eyebrow .label{font-size:10px;letter-spacing:0.24em}

  /* Milestone (about) */
  .milestone{flex-wrap:wrap;gap:14px}
  .milestone__num{font-size:3rem}
  .milestone__rule{display:none}
  .milestone__lead{font-size:1.1rem}
  .milestone__sub{font-size:10px;letter-spacing:0.14em}

  /* Gallery — denser rows */
  .gallery{grid-auto-rows:110px}

  /* Promo */
  .promo{padding:24px 22px}
  .promo h3{font-size:1.3rem}

  /* FAQ — collapse numbering size & tags */
  .faqs summary{gap:12px;padding:20px 0;grid-template-columns:auto 1fr auto}
  .faq__num{font-size:1.05rem;min-width:24px}
  .faq__toggle{width:30px;height:30px}
  .faq__toggle i:nth-child(1){width:10px}
  .faq__toggle i:nth-child(2){height:10px}
  .faq__a{padding:0 0 22px 38px}
  .faq__a p{font-size:0.93rem;padding-left:14px}

  /* Contact info card */
  .contact__info{padding:26px 20px}
  .contact__info strong{font-size:1rem}
  .contact__info span{font-size:0.88rem}
  .contact__map{min-height:280px}

  /* Footer typography */
  .footer h4{font-size:10.5px}
  .footer p,.footer ul a,.footer__contact{font-size:0.88rem}
  .footer__logo{height:56px}

  /* Buttons */
  .btn{padding:14px 22px;font-size:11px}
  .btn--big{padding:16px 24px;font-size:12px}

  /* Marquee gentler */
  .marquee__track{gap:32px}
  .marquee__track span{font-size:1.25rem}
  .marquee__track span.alt{font-size:1.4rem}

  /* Wa float */
  .wa-float{width:50px;height:50px;bottom:16px;right:16px}
  .wa-float svg{width:22px;height:22px}
}

@media (max-width:380px){
  .hero__frame{max-width:230px}
  .hero__title{font-size:clamp(1.45rem,9vw,1.85rem)}
  .hero__sub--lead{font-size:1rem}
  .promo h3{font-size:1.2rem}
}

/* Prevent horizontal scroll on any viewport */
html, body{overflow-x:hidden}
img{max-width:100%}
