/* =============================================================
   1. Tokens
   ============================================================= */
:root {
  --bg:         #FAFAF8;
  --bg-2:       #F5F0E8;
  --ink:        #111111;
  --ink-soft:   #333333;
  --ink-mute:   #777777;
  --ink-faint:  #AAAAAA;
  --gold:       #C6A96A;
  --gold-dark:  #A08550;
  --gold-light: #D9BF83;
  --gold-fade:  rgba(198,169,106,0.14);
  --dark:       #0D0D0D;
  --dark-2:     #181818;
  --serif:      'Cormorant Garamond',Georgia,serif;
  --sans:       'Inter',system-ui,sans-serif;
  --ease-out:   cubic-bezier(0.16,1,0.3,1);
  --ease-soft:  cubic-bezier(0.25,0.46,0.45,0.94);
  --nav-h:      72px;
  --r:          12px;
  --r-lg:       20px;
  --container:  1200px;
  --gutter:     clamp(1.25rem,5vw,3rem);
}

/* =============================================================
   2. Reset
   ============================================================= */
*,*::before,*::after{box-sizing:border-box;margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;overflow-x:clip}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{font-family:var(--sans);font-size:clamp(15px,1.1vw,17px);line-height:1.65;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:clip;overscroll-behavior-y:none}
img,svg,video{display:block;max-width:100%}
img{height:auto}
button{font:inherit;color:inherit;cursor:pointer;border:0;background:none}
a{color:inherit;text-decoration:none}
p{text-wrap:pretty}
h1,h2,h3,h4{text-wrap:balance;line-height:1.05;letter-spacing:-0.02em;font-family:var(--serif);font-weight:400}
::selection{background:var(--gold);color:var(--dark)}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:4px}

/* =============================================================
   3. Utilities
   ============================================================= */
.skip-link{position:fixed;top:-100px;left:1rem;padding:.6rem 1.2rem;background:var(--gold);color:var(--dark);z-index:9999;border-radius:8px;font-weight:600;font-size:.875rem;transition:top .2s}
.skip-link:focus{top:1rem}
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(4.5rem,10vw,8rem)}
.eyebrow{font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:.8rem}
.eyebrow--gold{color:var(--gold-light)}
.section-header{text-align:center;max-width:640px;margin-inline:auto;margin-bottom:clamp(3rem,7vw,5rem)}
.section-header h2{font-size:clamp(2.4rem,5vw,3.8rem)}
.section-header h2 em,.section-header--light h2 em{font-style:italic;color:var(--gold)}
.section-header--light h2{color:var(--bg)}
.section-sub{margin-top:1.1rem;font-size:clamp(1rem,1.5vw,1.1rem);color:var(--ink-mute);max-width:520px;margin-inline:auto;line-height:1.7}
.section-sub--light{color:rgba(250,250,248,.65)}

/* =============================================================
   4. Buttons
   ============================================================= */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.9rem 2rem;border-radius:100px;font-family:var(--sans);font-size:.875rem;font-weight:500;letter-spacing:.04em;cursor:pointer;transition:transform .3s var(--ease-out),box-shadow .3s var(--ease-out),background .25s,color .25s,border-color .25s;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn-gold{background:var(--gold);color:var(--dark);border:1.5px solid var(--gold)}
.btn-gold:hover{background:var(--gold-dark);border-color:var(--gold-dark);box-shadow:0 8px 32px rgba(198,169,106,.4)}
.btn-ghost{background:transparent;color:rgba(250,250,248,.9);border:1.5px solid rgba(250,250,248,.3)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-dark{background:var(--ink);color:var(--bg);border:1.5px solid var(--ink)}
.btn-dark:hover{background:var(--ink-soft);box-shadow:0 8px 28px rgba(17,17,17,.25)}
.btn-outline{background:transparent;color:var(--ink);border:1.5px solid rgba(17,17,17,.2)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold)}
.btn-gold-outline{background:transparent;color:var(--gold-light);border:1.5px solid var(--gold)}
.btn-gold-outline:hover{background:var(--gold);color:var(--dark)}

/* =============================================================
   5. Reveal animations
   ============================================================= */
[data-reveal]{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
[data-reveal].is-visible{opacity:1;transform:none}
[data-reveal="bento"]{opacity:0;transform:translateY(40px) scale(.98)}
[data-reveal="bento"].is-visible{opacity:1;transform:none}
[data-reveal][data-split]{opacity:1;transform:none}

/* =============================================================
   6. NAV
   ============================================================= */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);background:transparent;transition:background .4s var(--ease-soft),box-shadow .4s}
.nav.is-scrolled{background:rgba(250,250,248,.97);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 1px 0 rgba(17,17,17,.08)}
.nav-inner{display:flex;align-items:center;gap:1.5rem;height:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.nav-logo{display:flex;align-items:center;flex-shrink:0}
.nav-logo-text{font-family:var(--serif);font-size:1.85rem;font-weight:300;letter-spacing:.06em;color:#FAFAF8;line-height:1}
.nav-logo-text em{font-style:italic;font-weight:400;letter-spacing:.02em;color:var(--gold)}
.nav.is-scrolled .nav-logo-text{color:var(--ink)}
.nav.is-scrolled .nav-logo-text em{color:var(--gold)}
.nav-links{display:none;gap:1.75rem;margin-left:auto;align-items:center}
.nav-links a,.nav-dropdown-trigger{font-size:.875rem;font-weight:400;color:rgba(250,250,248,.85);transition:color .2s;position:relative;cursor:pointer}
.nav-links a::after,.nav-dropdown-trigger::after{content:'';position:absolute;bottom:-3px;left:0;right:0;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease-out)}
.nav-links a:hover,.nav-dropdown-trigger:hover{color:var(--gold)}
.nav-links a:hover::after,.nav-dropdown-trigger:hover::after{transform:scaleX(1)}
.nav.is-scrolled .nav-links a,.nav.is-scrolled .nav-dropdown-trigger{color:var(--ink-soft)}
.nav.is-scrolled .nav-links a:hover,.nav.is-scrolled .nav-dropdown-trigger:hover{color:var(--gold-dark)}
.nav-arrow{font-size:.65rem;opacity:.7;margin-left:.2rem}
.nav-dropdown{position:relative}
.nav-dropdown::before{content:'';position:absolute;top:100%;left:-1rem;right:-1rem;height:1.2rem}
.nav-dropdown-menu{position:absolute;top:calc(100% + 1rem);left:50%;transform:translateX(-50%);background:rgba(250,250,248,.98);backdrop-filter:blur(16px);border:1px solid rgba(17,17,17,.08);border-radius:var(--r);padding:.5rem;min-width:220px;box-shadow:0 16px 48px rgba(17,17,17,.14);opacity:0;pointer-events:none;transform:translateX(-50%) translateY(-8px);transition:opacity .25s,transform .3s var(--ease-out)}
.nav-dropdown:hover .nav-dropdown-menu{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.nav-dropdown-menu a{display:block;padding:.55rem 1rem;font-size:.875rem;color:var(--ink-soft);border-radius:8px;transition:background .2s,color .2s;white-space:nowrap}
.nav-dropdown-menu a:hover{background:var(--gold-fade);color:var(--gold-dark)}
.nav-cta{margin-left:.5rem}
.nav-hamburger{display:flex;flex-direction:column;gap:5px;padding:.5rem;margin-left:auto}
.nav-hamburger span{display:block;width:22px;height:1.5px;background:var(--white,#FAFAF8);transition:transform .3s,opacity .3s,background .3s}
.nav.is-scrolled .nav-hamburger span{background:var(--ink)}
.nav-hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.nav-mobile{position:absolute;top:var(--nav-h);left:0;right:0;background:rgba(250,250,248,.98);backdrop-filter:blur(16px);padding:1.5rem var(--gutter) 2rem;display:flex;flex-direction:column;gap:.25rem;transform:translateY(-8px);opacity:0;pointer-events:none;transition:transform .35s var(--ease-out),opacity .3s;border-bottom:1px solid rgba(17,17,17,.08)}
.nav-mobile.is-open{transform:none;opacity:1;pointer-events:auto}
.nav-mobile-link{padding:.7rem 0;font-size:1.1rem;color:var(--ink-soft);border-bottom:1px solid rgba(17,17,17,.08)}
.nav-mobile-cta{margin-top:1rem;align-self:flex-start}

/* =============================================================
   7. WhatsApp Float
   ============================================================= */
.whatsapp-float{position:fixed;bottom:1.75rem;right:1.75rem;z-index:999;display:flex;align-items:center;gap:.6rem;padding:.8rem 1.3rem;background:#25D366;color:#fff;border-radius:100px;font-size:.8rem;font-weight:600;box-shadow:0 4px 24px rgba(37,211,102,.4);transition:transform .3s var(--ease-out),box-shadow .3s;border:2px solid rgba(255,255,255,.2)}
.whatsapp-float svg{width:22px;height:22px;flex-shrink:0}
.whatsapp-float:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 10px 40px rgba(37,211,102,.55)}
.whatsapp-float-label{display:none}

/* =============================================================
   8. HERO
   ============================================================= */
.hero{position:relative;min-height:100vh;min-height:100svh;display:flex;align-items:center;justify-content:center;background:var(--dark);overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center top;transform:scale(1.06);transition:transform 10s ease-out}
.hero.is-loaded .hero-bg img{transform:scale(1)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(13,13,13,.75) 0%,rgba(13,13,13,.55) 50%,rgba(13,13,13,.82) 100%)}
.hero-mesh{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 20% 60%,rgba(198,169,106,.12) 0%,transparent 70%),radial-gradient(ellipse 60% 80% at 80% 30%,rgba(198,169,106,.07) 0%,transparent 70%);animation:meshDrift 14s ease-in-out infinite alternate}
@keyframes meshDrift{from{opacity:.6;transform:scale(1)}to{opacity:1;transform:scale(1.06) rotate(3deg)}}
.hero-grain{position:absolute;inset:0;opacity:.03;mix-blend-mode:overlay;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:180px 180px}
.hero-content{position:relative;z-index:1;text-align:center;padding:calc(var(--nav-h) + 3rem) var(--gutter) 6rem;max-width:860px;width:100%;margin-inline:auto}
.hero-kicker{font-size:.72rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:1.5rem}
.hero-title{font-family:var(--serif);font-size:clamp(3.2rem,8vw,6.5rem);font-weight:400;color:#FAFAF8;line-height:1;margin-bottom:1.5rem}
.hero-title em{font-style:italic;color:var(--gold)}
.hero-sub{font-size:clamp(1rem,2vw,1.2rem);color:rgba(250,250,248,.75);line-height:1.75;max-width:560px;margin-inline:auto;margin-bottom:2.5rem}
.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:3.5rem}
.hero-stats{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;padding:1.5rem 2rem;background:rgba(13,13,13,.55);border:1px solid rgba(198,169,106,.2);border-radius:var(--r-lg);backdrop-filter:blur(8px);max-width:660px;margin-inline:auto}
.hero-stat{display:flex;flex-direction:column;align-items:center;padding:.5rem 1.5rem;flex:1;min-width:90px}
.hero-stat strong{font-family:var(--serif);font-size:clamp(2.4rem,5.5vw,3.4rem);font-weight:600;color:var(--gold);line-height:1}
.hero-stat span{color:var(--gold);font-family:var(--serif);font-size:1.5rem}
.hero-stat small{font-size:clamp(.65rem,.8vw,.72rem);font-weight:500;letter-spacing:.06em;color:rgba(250,250,248,.55);text-transform:uppercase;margin-top:.35rem;text-align:center}
.hero-stat-sep{width:1px;height:44px;background:rgba(198,169,106,.2);flex-shrink:0}
.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.4rem;color:rgba(250,250,248,.45);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase}
.hero-scroll-line{width:1px;height:44px;background:linear-gradient(to bottom,transparent,rgba(198,169,106,.6));animation:scrollLine 2.2s ease-in-out infinite}
@keyframes scrollLine{0%,100%{transform:scaleY(0);transform-origin:top;opacity:0}45%{transform:scaleY(1);transform-origin:top;opacity:1}85%{transform:scaleY(1);transform-origin:bottom;opacity:1}}

/* =============================================================
   9. TRUST TICKER
   ============================================================= */
.trust-ticker{background:var(--dark);overflow:hidden;border-top:1px solid rgba(198,169,106,.1);border-bottom:1px solid rgba(198,169,106,.1);padding-block:.85rem}
.trust-track{display:flex;align-items:center;gap:1.25rem;width:max-content;animation:marqueeScroll 30s linear infinite;font-size:clamp(.72rem,.85vw,.78rem);font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:rgba(250,250,248,.55)}
.trust-track span{white-space:nowrap}
.trust-track .sep{color:var(--gold);opacity:.6}

/* =============================================================
   10. SPECS BENTO
   ============================================================= */
.specs{background:var(--dark);padding-block:clamp(4rem,9vw,7rem)}
.specs .section-header h2{color:#FAFAF8}
.specs .section-header h2 em{color:var(--gold-light)}
.specs .section-sub{color:rgba(250,250,248,.6)}
.specs .eyebrow{color:var(--gold)}

.specs-bento{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto;gap:6px;margin-top:2rem}
.spec-card--featured{grid-column:span 2}
.spec-card--wide{grid-column:span 2}

.spec-card{position:relative;overflow:hidden;border-radius:var(--r);min-height:260px;display:flex;flex-direction:column;justify-content:flex-end;cursor:pointer;text-decoration:none;background:var(--dark-2)}
.spec-card--featured{min-height:360px}
.spec-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.04);transition:transform .9s var(--ease-out)}
.spec-card:hover .spec-bg{transform:scale(1.08)}
.spec-overlay{position:absolute;inset:0;transition:opacity .5s}
.spec-card:hover .spec-overlay{opacity:.8}
.spec-body{position:relative;z-index:1;padding:1.5rem 1.75rem 1.75rem;display:flex;flex-direction:column;gap:.5rem}
.spec-num{font-family:var(--sans);font-size:.7rem;font-weight:700;letter-spacing:.2em;color:var(--gold);opacity:.8}
.spec-card h3{font-family:var(--serif);font-size:clamp(1.4rem,2.5vw,2rem);font-weight:500;color:#FAFAF8;line-height:1.1}
.spec-card p{font-size:clamp(.82rem,.9vw,.9rem);color:rgba(250,250,248,.7);line-height:1.5;max-width:320px}
.spec-cta{display:inline-flex;align-items:center;gap:.4rem;font-size:.8rem;font-weight:600;letter-spacing:.08em;color:var(--gold);margin-top:.35rem;transition:gap .25s var(--ease-out)}
.spec-card:hover .spec-cta{gap:.7rem}
.spec-cta .arrow{transition:transform .25s var(--ease-out)}
.spec-card:hover .spec-cta .arrow{transform:translateX(4px)}
.spec-accent-line{position:absolute;bottom:0;left:1.75rem;right:1.75rem;height:2px;border-radius:2px;opacity:.8}

/* =============================================================
   11. CLINIC SHOWCASE
   ============================================================= */
.clinic-showcase{position:relative;min-height:520px;display:flex;align-items:center;overflow:hidden}
.clinic-showcase-bg{position:absolute;inset:0}
.clinic-showcase-bg img{width:100%;height:100%;object-fit:cover;object-position:center}
.clinic-showcase-overlay{position:absolute;inset:0;background:linear-gradient(110deg,rgba(13,13,13,.82) 0%,rgba(13,13,13,.65) 40%,rgba(13,13,13,.35) 100%)}
.clinic-showcase-content{position:relative;z-index:1;padding:clamp(3rem,7vw,5rem) var(--gutter);max-width:var(--container);margin-inline:auto;width:100%}
.clinic-showcase-content h2{font-size:clamp(2.2rem,5vw,3.5rem);color:#FAFAF8;margin-bottom:1rem}
.clinic-showcase-content h2 em{font-style:italic;color:var(--gold)}
.clinic-showcase-content p{font-size:clamp(1rem,1.5vw,1.1rem);color:rgba(250,250,248,.72);max-width:500px;line-height:1.75;margin-bottom:2rem}

/* =============================================================
   12. WHY
   ============================================================= */
.why{background:var(--bg)}
.why-inner{display:grid;grid-template-columns:1fr;gap:3rem;align-items:center}
.why-text h2{font-size:clamp(2rem,4.5vw,3.2rem);margin-bottom:1.25rem}
.why-text h2 em{font-style:italic;color:var(--gold)}
.why-text>p{color:var(--ink-soft);line-height:1.75;margin-bottom:1.5rem}
.why-list{list-style:none;padding:0;margin:0 0 2rem;display:flex;flex-direction:column;gap:.8rem}
.why-list li{display:flex;align-items:flex-start;gap:.75rem;font-size:.95rem;color:var(--ink-soft);line-height:1.6}
.why-check{color:var(--gold);font-size:.75rem;margin-top:.2rem;flex-shrink:0}
.why-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.stat-card{background:var(--bg-2);border:1px solid rgba(17,17,17,.09);border-radius:var(--r);padding:1.75rem 1.5rem;display:flex;flex-direction:column;gap:.35rem;transition:border-color .3s,box-shadow .3s}
.stat-card:hover{border-color:var(--gold-fade);box-shadow:0 8px 28px rgba(17,17,17,.07)}
.stat-card--gold{border-color:var(--gold-fade)}
.stat-num{font-family:var(--serif);font-size:clamp(3rem,5.5vw,4rem);font-weight:600;color:var(--gold);line-height:1}
.stat-stars{color:var(--gold);font-size:.85rem;letter-spacing:.06em}
.stat-card small{font-size:.82rem;color:var(--ink-mute);line-height:1.4;margin-top:.15rem}

/* =============================================================
   13. TEAM
   ============================================================= */
.team{background:var(--bg-2)}
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}
.team-card{background:var(--bg);border:1px solid rgba(17,17,17,.09);border-radius:var(--r-lg);overflow:hidden;transition:transform .4s var(--ease-out),box-shadow .4s,border-color .4s;will-change:transform}
.team-card:hover{transform:translateY(-7px);box-shadow:0 24px 60px rgba(17,17,17,.12),0 0 0 1px rgba(198,169,106,.2);border-color:rgba(198,169,106,.25)}
.team-photo-wrap{position:relative;overflow:hidden;aspect-ratio:4/5}
.team-photo-wrap img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .7s var(--ease-out)}
.team-card:hover .team-photo-wrap img{transform:scale(1.06)}
.team-photo-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,13,13,.4) 0%,transparent 50%)}
.team-info{padding:1.25rem 1.5rem 1.5rem;border-top:1px solid rgba(17,17,17,.08)}
.team-info h3{font-family:var(--serif);font-size:1.2rem;font-weight:500;color:var(--ink);margin-bottom:.2rem}
.team-title{font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);margin-bottom:.2rem}
.team-specialty{font-size:.85rem;color:var(--ink-mute)}
.team-cta{text-align:center;margin-top:2.5rem;display:flex;flex-direction:column;align-items:center;gap:.75rem}
.team-cta-note{font-size:.9rem;color:var(--ink-mute)}
.team-cta-note strong{color:var(--ink);font-weight:600}

/* =============================================================
   14. BRANDS
   ============================================================= */
.brands{padding-block:0}
.brands-strip{overflow:hidden;padding-block:2.25rem;border-top:1px solid rgba(17,17,17,.08)}
.brands-strip--dark{background:var(--dark);border-top:none;border-bottom:1px solid rgba(255,255,255,.05)}
.brands-strip--dark .brands-strip-label{color:rgba(250,250,248,.35)}
.brands-strip--dark .brand-logo-item{color:rgba(250,250,248,.65)}
.brands-strip--dark .brand-sep-dot{color:var(--gold);opacity:.5}
.brands-strip-label{font-size:.68rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);text-align:center;margin-bottom:1.1rem}
.marquee-wrap{overflow:hidden;mask-image:linear-gradient(to right,transparent,black 7%,black 93%,transparent);-webkit-mask-image:linear-gradient(to right,transparent,black 7%,black 93%,transparent)}
.marquee-track{display:flex;align-items:center;gap:1.5rem;width:max-content;animation:marqueeScroll 30s linear infinite}
.marquee-track--slow{animation-duration:44s}
.marquee-track--reverse{animation-direction:reverse}
@keyframes marqueeScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.brand-logo-item{display:inline-flex;align-items:center;height:36px;opacity:.7;transition:opacity .25s}
.brand-logo-item:hover{opacity:1}
.brand-logo-item svg{height:36px;width:auto}
.brand-client{height:40px}
.brand-client svg{height:40px}
.brand-sep-dot{color:var(--gold);font-size:1rem;opacity:.5;flex-shrink:0}
.brands .section-header h2{font-size:clamp(1.8rem,4vw,2.8rem)}

/* =============================================================
   15. TESTIMONIALS
   ============================================================= */
.testimonials{background:var(--dark);color:#FAFAF8;overflow:hidden}
.testimonials-carousel{position:relative;overflow:hidden}
.testimonials-track{display:flex;gap:1.25rem;transition:transform .6s var(--ease-out)}
.testimonial-card{flex:0 0 min(420px,85vw);background:rgba(255,255,255,.05);border:1px solid rgba(198,169,106,.15);border-radius:var(--r-lg);padding:2rem;display:flex;flex-direction:column;gap:1.25rem;transition:border-color .3s,background .3s}
.testimonial-card:hover{background:rgba(255,255,255,.08);border-color:rgba(198,169,106,.3)}
.testimonial-stars{color:var(--gold);font-size:1rem;letter-spacing:.1em}
.testimonial-card blockquote{font-family:var(--serif);font-size:1.1rem;font-style:italic;color:rgba(250,250,248,.88);line-height:1.65;flex:1}
.testimonial-card footer{display:flex;align-items:center;gap:.9rem;border-top:1px solid rgba(198,169,106,.1);padding-top:1rem}
.testimonial-avatar{width:40px;height:40px;border-radius:50%;background:var(--gold-fade);border:1px solid var(--gold);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1.1rem;color:var(--gold);flex-shrink:0;overflow:hidden;position:relative}
.testimonial-card cite{font-family:var(--sans);font-size:.875rem;font-style:normal;font-weight:500;color:#FAFAF8;display:block}
.testimonial-card time{font-size:.76rem;color:rgba(250,250,248,.4);display:block;margin-top:.15rem}
.testimonials-controls{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:2rem}
.testimonial-btn{width:44px;height:44px;border-radius:50%;border:1px solid rgba(198,169,106,.3);color:var(--gold);font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:background .25s,border-color .25s,transform .25s}
.testimonial-btn:hover{background:var(--gold-fade);border-color:var(--gold);transform:scale(1.08)}
.testimonial-dots{display:flex;gap:.5rem}
.testimonial-dot{width:7px;height:7px;border-radius:50%;background:rgba(198,169,106,.3);transition:background .25s,transform .25s;cursor:pointer;border:none}
.testimonial-dot.is-active{background:var(--gold);transform:scale(1.3)}
.testimonials-cta{text-align:center;margin-top:2.5rem}

/* =============================================================
   16. CONTACT
   ============================================================= */
.contact{background:var(--bg-2)}
.contact-grid{display:grid;grid-template-columns:1fr;gap:3rem}
.contact-form{display:flex;flex-direction:column;gap:1.25rem}
.form-row{display:flex;flex-direction:column;gap:.4rem}
.form-row label{font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mute)}
.form-row input,.form-row select,.form-row textarea{width:100%;padding:.9rem 1.1rem;background:var(--bg);border:1.5px solid rgba(17,17,17,.12);border-radius:var(--r);font:400 1rem/1.5 var(--sans);color:var(--ink);transition:border-color .25s,box-shadow .25s;-webkit-appearance:none}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(198,169,106,.15)}
.form-row textarea{resize:vertical;min-height:120px}
.form-row select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23777' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.75rem;cursor:pointer}
.form-submit{position:relative;width:100%;justify-content:center}
.btn-sending,.btn-sent{display:none}
.form-submit.is-sending .btn-text{display:none}
.form-submit.is-sending .btn-sending{display:block}
.form-submit.is-sent .btn-text{display:none}
.form-submit.is-sent .btn-sent{display:block}
.form-note{font-size:.8rem;color:var(--ink-mute);text-align:center}
.form-note a{color:var(--gold-dark);font-weight:500}
.contact-details{display:flex;flex-direction:column;gap:1.25rem;margin-bottom:1.75rem}
.contact-detail{display:flex;align-items:flex-start;gap:1rem}
.contact-detail-icon{font-size:1.1rem;flex-shrink:0;margin-top:.1rem}
.contact-detail strong{display:block;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:.25rem}
.contact-detail p{font-size:.95rem;color:var(--ink-soft)}
.contact-ref{font-size:.8rem;color:var(--ink-mute);margin-top:.15rem}
.contact-detail a{color:var(--ink-soft)}
.contact-detail a:hover{color:var(--gold-dark)}
.contact-map{border-radius:var(--r);overflow:hidden;border:1px solid rgba(17,17,17,.1)}
.contact-map iframe{display:block}
.contact-facade{margin-top:1rem;border-radius:var(--r);overflow:hidden;aspect-ratio:16/9}
.contact-facade img{width:100%;height:100%;object-fit:cover;display:block}

/* =============================================================
   17. FOOTER
   ============================================================= */
.footer{background:var(--dark-2);color:rgba(250,250,248,.7);padding-block:clamp(3rem,7vw,5rem) 2rem}
.footer-top{display:flex;flex-direction:column;gap:3rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:2rem}
.footer-brand{display:flex;flex-direction:column;gap:.75rem;max-width:260px}
.footer-logo .nav-logo-text{color:#FAFAF8}
.footer-tagline{font-family:var(--serif);font-style:italic;font-size:1rem;color:rgba(250,250,248,.45);line-height:1.5}
.footer-rating{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .9rem;background:rgba(198,169,106,.07);border:1px solid rgba(198,169,106,.18);border-radius:100px;font-size:.75rem;font-weight:500;color:rgba(250,250,248,.7);width:fit-content;transition:background .25s,border-color .25s}
.footer-rating:hover{background:rgba(198,169,106,.14);border-color:var(--gold)}
.footer-rating-stars{color:var(--gold);letter-spacing:.08em}
.footer-nav{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}
.footer-nav-col{display:flex;flex-direction:column;gap:.6rem}
.footer-nav-title{font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(250,250,248,.3);margin-bottom:.35rem}
.footer-nav a,.footer-nav p{font-size:.88rem;color:rgba(250,250,248,.55);transition:color .2s}
.footer-nav a:hover{color:var(--gold)}
.footer-bottom{display:flex;flex-wrap:wrap;gap:.35rem;align-items:flex-start}
.footer-bottom p{font-size:.78rem;color:rgba(250,250,248,.28)}

/* =============================================================
   LOGOS — soporte para <img> en empresas clientes
   ============================================================= */
.brand-client img{height:36px;max-width:160px;object-fit:contain;filter:grayscale(1) brightness(2);opacity:.7;transition:filter .35s,opacity .35s}
.brand-client:hover img{filter:grayscale(0) brightness(1.1);opacity:1}
.brand-logo-item.brand-client{height:auto;padding:.25rem 0}

/* =============================================================
   TESTIMONIAL AVATAR — soporte para foto real
   ============================================================= */
.testimonial-avatar{position:relative}
.testimonial-avatar::after{content:attr(data-initial);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--serif);font-size:1.1rem;color:var(--gold);z-index:0;pointer-events:none;line-height:1}
.testimonial-avatar img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:1}

/* =============================================================
   18. ANTES / DESPUÉS
   ============================================================= */
.ba-section{background:var(--bg-2)}
.ba-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-top:3rem}
.ba-item{position:relative;overflow:hidden;border-radius:var(--r-lg);aspect-ratio:4/3;cursor:col-resize;user-select:none;touch-action:pan-y;background:var(--dark-2)}
.ba-layer{position:absolute;inset:0;background:var(--dark-2)}
.ba-layer img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 72%;z-index:1;display:block}
.ba-after{z-index:0}
.ba-before{z-index:1;clip-path:inset(0 50% 0 0)}
.ba-ph{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;z-index:0;padding:1rem}
.ba-ph-icon{font-size:2.5rem;color:rgba(198,169,106,.25);line-height:1}
.ba-ph p{font-size:.72rem;color:rgba(250,250,248,.2);font-family:var(--sans);text-align:center;max-width:180px;line-height:1.4}
.ba-handle-line{position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);width:2px;background:#fff;z-index:4;box-shadow:0 0 10px rgba(0,0,0,.4);pointer-events:none}
.ba-handle-knob{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:42px;height:42px;border-radius:50%;background:#fff;color:var(--ink);display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:700;letter-spacing:.03em;z-index:5;box-shadow:0 3px 18px rgba(0,0,0,.3);pointer-events:none;white-space:nowrap}
.ba-tag{position:absolute;top:.75rem;z-index:3;background:rgba(0,0,0,.52);backdrop-filter:blur(8px);color:#fff;font-family:var(--sans);font-size:.67rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:.28rem .7rem;border-radius:100px}
.ba-tag--left{left:.75rem}
.ba-tag--right{right:.75rem}
.ba-case-label{position:absolute;bottom:0;left:0;right:0;padding:.65rem 1rem;background:linear-gradient(0deg,rgba(0,0,0,.75) 0%,transparent 100%);font-family:var(--serif);font-style:italic;font-size:.95rem;color:rgba(250,250,248,.9);z-index:3;pointer-events:none}
.ba-disclaimer{text-align:center;font-size:.76rem;color:var(--ink-mute);margin-top:2rem;max-width:580px;margin-inline:auto;line-height:1.6}

/* =============================================================
   19. FAQ
   ============================================================= */
.faq-section{background:var(--bg)}
.faq-list{max-width:780px;margin:3rem auto 0;display:flex;flex-direction:column;gap:.6rem}
.faq-item{border:1.5px solid rgba(17,17,17,.09);border-radius:var(--r);overflow:hidden;background:var(--bg);transition:border-color .25s,box-shadow .25s}
.faq-item:hover{border-color:rgba(198,169,106,.2);box-shadow:0 4px 20px rgba(17,17,17,.06)}
.faq-item[open]{border-color:rgba(198,169,106,.3);box-shadow:0 4px 24px rgba(17,17,17,.07);background:var(--bg-2)}
.faq-q{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.25rem 1.5rem;cursor:pointer;font-family:var(--sans);font-size:1rem;font-weight:500;color:var(--ink);transition:color .2s}
.faq-q::-webkit-details-marker{display:none}
.faq-q:focus-visible{outline:2px solid var(--gold);outline-offset:-2px}
.faq-item[open] .faq-q{color:var(--gold-dark)}
.faq-icon{flex-shrink:0;width:28px;height:28px;border-radius:50%;border:1.5px solid rgba(17,17,17,.15);position:relative;transition:border-color .25s,background .25s,transform .35s var(--ease-out)}
.faq-icon::before,.faq-icon::after{content:'';position:absolute;top:50%;left:50%;background:var(--ink-soft);border-radius:2px;transition:background .2s,transform .3s var(--ease-out)}
.faq-icon::before{width:10px;height:1.5px;transform:translate(-50%,-50%)}
.faq-icon::after{width:1.5px;height:10px;transform:translate(-50%,-50%)}
.faq-item[open] .faq-icon{background:var(--gold-fade);border-color:var(--gold);transform:rotate(45deg)}
.faq-item[open] .faq-icon::before,.faq-item[open] .faq-icon::after{background:var(--gold-dark)}
.faq-a{padding:0 1.5rem 1.5rem}
.faq-a p{font-size:.97rem;color:var(--ink-soft);line-height:1.78}

/* =============================================================
   18. Responsive
   ============================================================= */
@media(min-width:540px){
  .whatsapp-float-label{display:block}
  .specs-bento{grid-template-columns:repeat(2,1fr)}
  .spec-card--featured{grid-column:span 2;min-height:400px}
  .spec-card--wide{grid-column:span 2}
}
@media(min-width:720px){
  .why-inner{grid-template-columns:1fr 1fr;gap:5rem}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr 1fr}
  .footer-top{flex-direction:row;justify-content:space-between;align-items:flex-start}
  .footer-nav{grid-template-columns:repeat(3,auto)}
  .specs-bento{grid-template-columns:2fr 1fr 1fr}
  .spec-card--featured{grid-column:span 2;grid-row:span 1}
  .spec-card--wide{grid-column:span 2}
  .ba-grid{grid-template-columns:1fr 1fr}
}
@media(min-width:960px){
  .nav-links{display:flex}
  .nav-hamburger{display:none}
  .nav-mobile{display:none!important}
  .team-grid{grid-template-columns:repeat(4,1fr)}
  .specs-bento{grid-template-columns:2fr 1fr 1fr}
  .spec-card{min-height:300px}
  .spec-card--featured{min-height:440px}
  .ba-grid{grid-template-columns:repeat(3,1fr)}
}
@media(min-width:1280px){
  .hero-stat small{white-space:nowrap}
  .specs-bento{gap:8px}
}

/* =============================================================
   LANGUAGE SWITCHER — dual flag buttons
   ============================================================= */
.lang-switcher{display:flex;align-items:center;gap:.18rem;flex-shrink:0;margin-left:.3rem}
.lang-btn{display:flex;align-items:center;gap:.28rem;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:100px;padding:.28rem .55rem;font-size:.7rem;font-weight:600;letter-spacing:.06em;color:rgba(250,250,248,.65);cursor:pointer;transition:background .22s,border-color .22s,color .22s;line-height:1}
.lang-btn span:first-child{font-size:.88rem;line-height:1}
.lang-btn:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.32);color:#FAFAF8}
.lang-btn.lang-active{background:var(--gold-fade,rgba(198,169,106,.15));border-color:var(--gold,#C6A96A);color:var(--gold-dark,#a8892c)}
.nav.is-scrolled .lang-btn{background:rgba(17,17,17,.05);border-color:rgba(17,17,17,.12);color:var(--ink-soft)}
.nav.is-scrolled .lang-btn:hover{background:rgba(17,17,17,.1);border-color:rgba(17,17,17,.22);color:var(--ink)}
.nav.is-scrolled .lang-btn.lang-active{background:var(--gold-fade,rgba(198,169,106,.12));border-color:var(--gold,#C6A96A);color:var(--gold-dark,#a8892c)}

/* Mobile — hide CTA button from nav bar (it lives in the dropdown already) */
@media(max-width:959px){
  .nav-cta{display:none}
}

/* Mobile lang switcher inside dropdown */
.nav-mobile-lang{display:flex;gap:.5rem;padding:.75rem 0 .25rem;border-top:1px solid rgba(17,17,17,.08);margin-top:.5rem}
.nav-mobile-lang .lang-btn{background:rgba(17,17,17,.05);border-color:rgba(17,17,17,.12);color:var(--ink-soft);font-size:.8rem;padding:.35rem .7rem}
.nav-mobile-lang .lang-btn:hover{background:rgba(17,17,17,.1);border-color:rgba(17,17,17,.22);color:var(--ink)}
.nav-mobile-lang .lang-btn.lang-active{background:var(--gold-fade,rgba(198,169,106,.12));border-color:var(--gold,#C6A96A);color:var(--gold-dark,#a8892c)}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){
  .hero-scroll-line,.hero-mesh,.trust-track,.marquee-track{animation:none}
}
