/* =====================================================================
   PLAZA AVANTI — Sistema de diseño
   Corporativo · Editorial · Premium
   ===================================================================== */

/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  font-weight:400;
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}

/* ---------- TOKENS ---------- */
:root{
  /* Neutrals — warm architectural off-whites & charcoals */
  --ink:        #14130f;
  --ink-soft:   #3c3a33;
  --ink-mute:   #76726a;
  --line:       #e6e3dc;
  --line-soft:  #f0ede7;
  --paper:      #ffffff;
  --paper-2:    #faf8f4;
  --paper-3:    #f3efe8;

  /* Dark surfaces */
  --night:      #15140f;
  --night-2:    #1f1d17;
  --night-soft: #2a2821;

  /* Single restrained accent — warm bronze/gold */
  --gold:       #9a8458;
  --gold-deep:  #7c693f;
  --gold-soft:  #c4b48f;
  --gold-wash:  #f5f0e6;

  /* Type families */
  --serif: 'Cormorant', 'Times New Roman', serif;
  --sans:  'Jost', system-ui, sans-serif;

  /* Rhythm */
  --pad-x: clamp(1.4rem, 5vw, 6rem);
  --sec-y: clamp(4.5rem, 9vw, 9rem);
  --maxw:  1280px;

  /* Motion */
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);

  /* Elevation */
  --shadow-sm: 0 2px 14px rgba(20,19,15,.05);
  --shadow:    0 18px 50px -22px rgba(20,19,15,.28);
  --shadow-lg: 0 40px 90px -40px rgba(20,19,15,.45);
}

/* ---------- TYPE HELPERS ---------- */
.serif{font-family:var(--serif)}
.eyebrow{
  font-family:var(--sans);
  font-size:.7rem;
  font-weight:600;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gold);
  display:inline-flex;
  align-items:center;
  gap:.85rem;
}
.eyebrow::before{
  content:'';
  width:30px;height:1px;
  background:var(--gold);
  display:inline-block;
}
.eyebrow.center{justify-content:center}
.eyebrow.light{color:var(--gold-soft)}
.eyebrow.light::before{background:var(--gold-soft)}

h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1.04;letter-spacing:-.01em;color:var(--ink)}
h1{font-size:clamp(2.7rem,6.4vw,5.6rem)}
h2{font-size:clamp(2.1rem,4.4vw,3.6rem)}
h3{font-size:clamp(1.5rem,2.4vw,2rem)}
em{font-style:italic;color:var(--gold-deep)}
.on-dark h1,.on-dark h2,.on-dark h3,.on-dark h4{color:#fff}
.on-dark em{color:var(--gold-soft)}

.lead{font-size:clamp(1.02rem,1.5vw,1.18rem);color:var(--ink-soft);font-weight:300;line-height:1.75}
.muted{color:var(--ink-mute)}

/* ---------- LAYOUT ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad-x)}
.section{padding-block:var(--sec-y)}
.section-head{max-width:680px;margin-bottom:clamp(2.5rem,5vw,4rem)}
.section-head.center{margin-inline:auto;text-align:center}
.section-head h2{margin:1.2rem 0 1.1rem}

/* =====================================================================
   BUTTONS
   ===================================================================== */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--sans);font-size:.74rem;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;
  padding:1.05rem 2rem;border-radius:999px;
  transition:transform .4s var(--ease-out),background .3s,color .3s,box-shadow .4s var(--ease-out),border-color .3s;
  will-change:transform;
}
.btn svg{width:15px;height:15px}
.btn-primary{background:var(--ink);color:#fff}
.btn-primary:hover{background:var(--gold-deep);transform:translateY(-3px);box-shadow:var(--shadow)}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{background:var(--gold-deep);transform:translateY(-3px);box-shadow:0 18px 44px -18px rgba(124,105,63,.7)}
.btn-wa{background:#1f9d57;color:#fff}
.btn-wa:hover{background:#178347;transform:translateY(-3px);box-shadow:0 18px 44px -18px rgba(31,157,87,.7)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-3px)}
.on-dark .btn-ghost{color:#fff;border-color:rgba(255,255,255,.28)}
.on-dark .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.06)}
.btn-outline-gold{background:transparent;color:var(--gold-deep);border:1px solid var(--gold-soft)}
.btn-outline-gold:hover{background:var(--gold);color:#fff;border-color:var(--gold);transform:translateY(-3px)}
.btn-lg{padding:1.2rem 2.6rem;font-size:.78rem}

.txtlink{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.74rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink);
}
.txtlink .arrow{transition:transform .35s var(--ease-out);display:inline-block}
.txtlink:hover .arrow{transform:translateX(6px)}
.txtlink.gold{color:var(--gold-deep)}

/* =====================================================================
   NAV
   ===================================================================== */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:120;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.4rem var(--pad-x);
  transition:background .45s var(--ease),padding .4s var(--ease),box-shadow .45s,border-color .45s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(160%) blur(16px);
  -webkit-backdrop-filter:saturate(160%) blur(16px);
  border-bottom-color:var(--line);
  padding-block:.95rem;
  box-shadow:0 8px 30px -24px rgba(20,19,15,.5);
}
.nav-logo{display:flex;flex-direction:column;line-height:1;gap:.18rem}
.nav-logo .lg-name{
  font-family:var(--serif);font-size:1.55rem;letter-spacing:.26em;text-transform:uppercase;color:#fff;
  transition:color .45s var(--ease);
}
.nav-logo .lg-sub{
  font-family:var(--sans);font-size:.52rem;font-weight:500;letter-spacing:.42em;
  text-transform:uppercase;color:rgba(255,255,255,.55);transition:color .45s var(--ease);
}
.nav.scrolled .lg-name{color:var(--ink)}
.nav.scrolled .lg-sub{color:var(--gold)}

.nav-links{display:flex;align-items:center;gap:2.4rem}
.nav-links a{
  font-size:.7rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.72);transition:color .25s;position:relative;
}
.nav-links a::after{
  content:'';position:absolute;left:0;bottom:-6px;height:1px;width:0;background:var(--gold);
  transition:width .35s var(--ease-out);
}
.nav-links a:hover{color:#fff}
.nav-links a:hover::after{width:100%}
.nav.scrolled .nav-links a{color:var(--ink-soft)}
.nav.scrolled .nav-links a:hover{color:var(--ink)}
.nav-links .nav-cta{
  padding:.7rem 1.4rem;border:1px solid rgba(255,255,255,.32);border-radius:999px;
  color:#fff;transition:background .3s,border-color .3s,color .3s;
}
.nav-links .nav-cta::after{display:none}
.nav-links .nav-cta:hover{background:#fff;color:var(--ink);border-color:#fff}
.nav.scrolled .nav-cta{border-color:var(--line);color:var(--ink)}
.nav.scrolled .nav-cta:hover{background:var(--ink);color:#fff;border-color:var(--ink)}

.nav-burger{display:none;width:30px;height:22px;position:relative}
.nav-burger span{position:absolute;left:0;height:2px;width:100%;background:#fff;border-radius:2px;transition:transform .4s var(--ease),top .3s,background .45s}
.nav-burger span:nth-child(1){top:0}
.nav-burger span:nth-child(2){top:10px}
.nav-burger span:nth-child(3){top:20px}
.nav.scrolled .nav-burger span{background:var(--ink)}

/* drawer */
.drawer{
  position:fixed;inset:0 0 0 auto;width:min(86vw,380px);z-index:140;
  background:var(--night);color:#fff;
  transform:translateX(100%);transition:transform .55s var(--ease);
  padding:6rem 2.4rem 2.4rem;display:flex;flex-direction:column;
}
.drawer.open{transform:translateX(0)}
.drawer-close{position:absolute;top:1.8rem;right:1.8rem;font-size:1.6rem;color:rgba(255,255,255,.7)}
.drawer a{font-family:var(--serif);font-size:1.5rem;color:rgba(255,255,255,.82);padding:.7rem 0;border-bottom:1px solid rgba(255,255,255,.08);transition:color .25s,padding-left .3s}
.drawer a:hover{color:#fff;padding-left:.5rem}
.drawer .drawer-wa{margin-top:1.6rem;font-family:var(--sans);font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:#1f9d57;border-radius:999px;text-align:center;padding:1rem;border:none}
.backdrop{position:fixed;inset:0;background:rgba(10,9,7,.5);backdrop-filter:blur(3px);z-index:130;opacity:0;visibility:hidden;transition:.4s}
.backdrop.open{opacity:1;visibility:visible}

/* =====================================================================
   WHATSAPP FLOAT
   ===================================================================== */
.wa-float{
  position:fixed;right:1.5rem;bottom:1.5rem;z-index:115;
  width:58px;height:58px;border-radius:50%;background:#1f9d57;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 12px 30px -8px rgba(31,157,87,.6);
  transition:transform .35s var(--ease-out),box-shadow .35s;
}
.wa-float::after{
  content:'';position:absolute;inset:0;border-radius:50%;
  border:2px solid #1f9d57;animation:waPulse 2.4s ease-out infinite;
}
@keyframes waPulse{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.7);opacity:0}}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:30px;height:30px;fill:#fff;position:relative;z-index:1}

/* =====================================================================
   HERO
   ===================================================================== */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;background:var(--night)}
.hero-inner{flex:1;display:flex;flex-direction:column;justify-content:flex-end}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:center 42%;transform:scale(1.08);animation:heroZoom 14s var(--ease-out) forwards}
@keyframes heroZoom{to{transform:scale(1)}}
.hero-veil{position:absolute;inset:0;z-index:1;background:
  linear-gradient(180deg,rgba(12,11,8,.55) 0%,rgba(12,11,8,.22) 28%,rgba(12,11,8,.5) 58%,rgba(12,11,8,.82) 78%,rgba(12,11,8,.96) 100%),
  linear-gradient(90deg,rgba(12,11,8,.5) 0%,rgba(12,11,8,.12) 45%,transparent 70%);}
.hero-grain{position:absolute;inset:0;z-index:2;opacity:.5;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.045'/%3E%3C/svg%3E");}
.hero-inner{position:relative;z-index:3;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x) clamp(3rem,7vw,6rem)}
.hero-copy{max-width:760px}
.hero-copy .eyebrow{margin-bottom:1.6rem}
.hero h1{color:#fff;margin-bottom:1.5rem}
.hero h1 .ln{display:block;overflow:hidden}
.hero h1 .ln span{display:block;transform:translateY(108%);animation:rise 1s var(--ease-out) forwards}
.hero h1 .ln:nth-child(2) span{animation-delay:.12s}
.hero h1 .ln:nth-child(3) span{animation-delay:.24s}
@keyframes rise{to{transform:translateY(0)}}
.hero-sub{color:rgba(255,255,255,.78);font-size:clamp(1rem,1.5vw,1.18rem);font-weight:300;max-width:520px;margin-bottom:2.6rem;opacity:0;animation:fadeUp .9s var(--ease-out) .5s forwards}
.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;opacity:0;animation:fadeUp .9s var(--ease-out) .66s forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}

/* hero meta bar */
.hero-meta{
  position:relative;z-index:3;
  border-top:1px solid rgba(255,255,255,.14);
  background:linear-gradient(180deg,rgba(12,11,8,.0),rgba(12,11,8,.4));
}
.hero-meta-inner{max-width:var(--maxw);margin:0 auto;padding:1.6rem var(--pad-x);
  display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.hmeta .hmeta-n{font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.4rem);color:#fff;line-height:1}
.hmeta .hmeta-l{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-top:.4rem}

/* =====================================================================
   REVEAL ANIMATIONS
   ===================================================================== */
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease-out),transform 1s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}.reveal.d4{transition-delay:.4s}.reveal.d5{transition-delay:.5s}
.reveal-img{clip-path:inset(0 0 100% 0);transition:clip-path 1.2s var(--ease-out)}
.reveal-img.in{clip-path:inset(0 0 0 0)}
@media(prefers-reduced-motion:reduce){
  .reveal,.reveal-img{opacity:1!important;transform:none!important;clip-path:none!important}
  .hero h1 .ln span{animation:none;transform:none}
  .hero-sub,.hero-actions{animation:none;opacity:1}
  .hero-media img{animation:none;transform:none}
}

/* =====================================================================
   INTRO / SPLIT
   ===================================================================== */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(2.5rem,5vw,5.5rem);align-items:center}
.split.flip{direction:rtl}.split.flip>*{direction:ltr}
.split-figure{position:relative}
.split-figure img{width:100%;border-radius:6px;box-shadow:var(--shadow)}
.split-figure .fig-badge{
  position:absolute;left:-1.5rem;bottom:-1.5rem;background:var(--ink);color:#fff;
  padding:1.4rem 1.7rem;border-radius:4px;box-shadow:var(--shadow-lg);max-width:230px}
.fig-badge .fb-n{font-family:var(--serif);font-size:2.3rem;line-height:1;color:#fff}
.fig-badge .fb-l{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-top:.4rem}
.split-body h2{margin:1.2rem 0 1.3rem}
.checks{margin:1.8rem 0 2.2rem;display:grid;gap:.9rem}
.checks li{display:flex;gap:.85rem;align-items:flex-start;font-size:.96rem;color:var(--ink-soft)}
.checks li .ck{flex:none;width:22px;height:22px;border-radius:50%;background:var(--gold-wash);color:var(--gold-deep);display:flex;align-items:center;justify-content:center;font-size:.7rem;margin-top:.15rem}

/* =====================================================================
   STAT BAND (dark)
   ===================================================================== */
.statband{background:var(--night);color:#fff;position:relative;overflow:hidden}
.statband::before{content:'';position:absolute;inset:0;opacity:.06;pointer-events:none;
  background:radial-gradient(circle at 20% 20%,var(--gold) 0,transparent 45%),radial-gradient(circle at 85% 80%,var(--gold) 0,transparent 40%)}
.statband .wrap{position:relative;z-index:1}
.stat-intro{max-width:620px;margin-bottom:clamp(2.5rem,5vw,3.8rem)}
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.4rem,3vw,2.4rem)}
.stat{padding:2.2rem 0;border-top:1px solid rgba(255,255,255,.14)}
.stat .stat-n{font-family:var(--serif);font-size:clamp(3rem,6vw,4.6rem);line-height:1;color:#fff;display:flex;align-items:baseline}
.stat .stat-n .plus{color:var(--gold-soft);font-size:.55em;margin-left:.1em}
.stat .stat-l{margin-top:.9rem;color:rgba(255,255,255,.62);font-size:.92rem;font-weight:300;max-width:230px;line-height:1.55}

/* =====================================================================
   FEATURES GRID
   ===================================================================== */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.feat{
  background:var(--paper);border:1px solid var(--line);border-radius:6px;
  padding:2.2rem 2rem;transition:transform .5s var(--ease-out),box-shadow .5s var(--ease-out),border-color .4s;
  position:relative;overflow:hidden}
.feat::after{content:'';position:absolute;left:0;top:0;height:3px;width:0;background:var(--gold);transition:width .5s var(--ease-out)}
.feat:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.feat:hover::after{width:100%}
.feat .f-ic{width:46px;height:46px;border-radius:10px;background:var(--gold-wash);display:flex;align-items:center;justify-content:center;margin-bottom:1.3rem;color:var(--gold-deep)}
.feat .f-ic svg{width:22px;height:22px;stroke:var(--gold-deep);fill:none;stroke-width:1.5}
.feat h3{font-size:1.32rem;margin-bottom:.6rem}
.feat p{font-size:.94rem;color:var(--ink-mute);line-height:1.6}

/* =====================================================================
   OFFICE CARDS
   ===================================================================== */
.cards-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:clamp(2.2rem,4vw,3.2rem)}
.office-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1.2rem,2.5vw,1.8rem)}
.ocard{
  display:block;background:var(--paper);border:1px solid var(--line);border-radius:8px;overflow:hidden;
  transition:transform .55s var(--ease-out),box-shadow .55s var(--ease-out),border-color .4s}
.ocard:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:transparent}
.ocard-media{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--paper-3)}
.ocard-media img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease-out)}
.ocard:hover .ocard-media img{transform:scale(1.06)}
.ocard-tag{position:absolute;top:1rem;left:1rem;display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(255,255,255,.92);backdrop-filter:blur(6px);padding:.45rem .85rem;border-radius:999px;
  font-size:.62rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink)}
.ocard-tag .dot{width:7px;height:7px;border-radius:50%;background:#1f9d57;box-shadow:0 0 0 0 rgba(31,157,87,.5);animation:dotPulse 2s infinite}
@keyframes dotPulse{0%{box-shadow:0 0 0 0 rgba(31,157,87,.5)}70%{box-shadow:0 0 0 7px rgba(31,157,87,0)}100%{box-shadow:0 0 0 0 rgba(31,157,87,0)}}
.ocard-m2{position:absolute;bottom:1rem;right:1rem;background:var(--ink);color:#fff;padding:.4rem .9rem;border-radius:999px;font-size:.72rem;font-weight:500;letter-spacing:.04em}
.ocard-body{padding:1.7rem 1.7rem 1.9rem}
.ocard-name{font-family:var(--serif);font-size:1.65rem;line-height:1.05}
.ocard-loc{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin:.5rem 0 .9rem}
.ocard-desc{font-size:.93rem;color:var(--ink-mute);line-height:1.6;margin-bottom:1.4rem;min-height:2.9em}
.ocard-foot{display:flex;justify-content:space-between;align-items:center;padding-top:1.2rem;border-top:1px solid var(--line-soft)}
.ocard .ocard-foot .txtlink{font-size:.7rem}

/* salon wide card */
.salon-card{grid-column:1/-1;display:grid;grid-template-columns:1.1fr 1fr}
.salon-card .ocard-media{aspect-ratio:auto;height:100%;min-height:280px}
.salon-card .ocard-body{display:flex;flex-direction:column;justify-content:center;padding:clamp(2rem,4vw,3rem)}

/* =====================================================================
   SALON FEATURE (dark split)
   ===================================================================== */
.salonsec{background:var(--night-2);color:#fff;position:relative;overflow:hidden}
.salonsec .split{align-items:stretch}
.salonsec .split-figure img{box-shadow:var(--shadow-lg);height:100%;object-fit:cover}
.salonsec .split-body{display:flex;flex-direction:column;justify-content:center;padding-block:clamp(1rem,3vw,2rem)}
.salon-feats{display:grid;gap:1.4rem;margin:1.8rem 0 2.4rem}
.sfeat{display:flex;gap:1.1rem;align-items:flex-start}
.sfeat .sf-ic{flex:none;width:42px;height:42px;border-radius:10px;background:rgba(196,180,143,.14);display:flex;align-items:center;justify-content:center}
.sfeat .sf-ic svg{width:20px;height:20px;stroke:var(--gold-soft);fill:none;stroke-width:1.5}
.sfeat h4{font-family:var(--sans);font-size:1rem;font-weight:600;color:#fff;letter-spacing:.01em;margin-bottom:.25rem}
.sfeat p{font-size:.9rem;color:rgba(255,255,255,.62);line-height:1.55}

/* =====================================================================
   AMENITIES / BANO ZIGZAG (reuse split)
   ===================================================================== */
.zig .split{margin-bottom:0}

/* =====================================================================
   TESTIMONIALS
   ===================================================================== */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.testi{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:2.2rem 2rem;display:flex;flex-direction:column;transition:transform .5s var(--ease-out),box-shadow .5s var(--ease-out)}
.testi:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.testi .quote{font-family:var(--serif);font-size:3rem;line-height:.6;color:var(--gold-soft);height:1.2rem}
.testi p{font-size:.98rem;color:var(--ink-soft);line-height:1.7;margin:1.2rem 0 1.6rem;flex:1}
.testi .who{display:flex;align-items:center;gap:.85rem;padding-top:1.2rem;border-top:1px solid var(--line-soft)}
.testi .who .av{width:42px;height:42px;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1.1rem}
.testi .who .nm{font-weight:600;font-size:.92rem;color:var(--ink)}
.testi .who .rl{font-size:.78rem;color:var(--ink-mute)}

/* logos row */
.logos{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(2rem,5vw,4rem);align-items:center;opacity:.78}
.logos .lg{font-family:var(--serif);font-size:1.5rem;letter-spacing:.04em;color:var(--ink-mute);font-style:italic}

/* =====================================================================
   LOCATION
   ===================================================================== */
.loc-grid{display:grid;grid-template-columns:1.25fr 1fr;gap:clamp(1.5rem,3vw,2.6rem);align-items:stretch}
.loc-map{border-radius:8px;overflow:hidden;min-height:420px;box-shadow:var(--shadow);border:1px solid var(--line)}
.loc-map iframe{width:100%;height:100%;min-height:420px;border:none;display:block;filter:grayscale(.2) contrast(1.02)}
.loc-facts{display:grid;gap:1.5rem;align-content:start}
.lfact{padding-bottom:1.4rem;border-bottom:1px solid var(--line-soft)}
.lfact h4{font-family:var(--sans);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem;font-weight:600}
.lfact p{font-size:.98rem;color:var(--ink-soft);line-height:1.6}

/* =====================================================================
   CTA SECTION (dark)
   ===================================================================== */
.cta{position:relative;background:var(--night);color:#fff;overflow:hidden;text-align:center}
.cta-bg{position:absolute;inset:0;font-family:var(--serif);font-size:clamp(14rem,40vw,32rem);line-height:1;
  color:rgba(255,255,255,.03);display:flex;align-items:center;justify-content:center;pointer-events:none;font-style:italic;white-space:nowrap}
.cta .wrap{position:relative;z-index:1}
.cta h2{color:#fff;margin:1.3rem auto 1.3rem;max-width:14ch}
.cta .lead{color:rgba(255,255,255,.72);max-width:540px;margin:0 auto 2.6rem}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:3.2rem}
.cta-contacts{display:flex;justify-content:center;gap:clamp(2rem,6vw,4.5rem);flex-wrap:wrap;padding-top:2.4rem;border-top:1px solid rgba(255,255,255,.12)}
.ccontact .cc-l{font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:.45rem}
.ccontact .cc-v{font-family:var(--serif);font-size:1.3rem;color:#fff}
.ccontact .cc-v a:hover{color:var(--gold-soft)}

/* =====================================================================
   FOOTER
   ===================================================================== */
.footer{background:var(--night-2);color:rgba(255,255,255,.6);padding-block:clamp(3rem,6vw,4.5rem)}
.footer .wrap{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2.5rem}
.foot-brand .fb-name{font-family:var(--serif);font-size:1.8rem;letter-spacing:.2em;text-transform:uppercase;color:#fff;margin-bottom:.4rem}
.foot-brand .fb-sub{font-size:.6rem;letter-spacing:.36em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:1.2rem}
.foot-brand p{font-size:.9rem;line-height:1.6;max-width:30ch}
.foot-col h5{font-family:var(--sans);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:#fff;margin-bottom:1.1rem;font-weight:600}
.foot-col a,.foot-col p{display:block;font-size:.92rem;color:rgba(255,255,255,.6);padding:.32rem 0;transition:color .25s}
.foot-col a:hover{color:#fff}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:clamp(2.5rem,5vw,3.5rem);padding-top:1.8rem}
.foot-bottom .wrap{display:flex;justify-content:space-between;align-items:center;gap:1rem;grid-template-columns:none}
.foot-bottom span{font-size:.8rem;color:rgba(255,255,255,.45)}

/* =====================================================================
   OFFICE DETAIL PAGE
   ===================================================================== */
.op-hero{position:relative;min-height:62vh;display:flex;align-items:flex-end;overflow:hidden;background:var(--night)}
.op-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0;transform:scale(1.06);animation:heroZoom 12s var(--ease-out) forwards}
.op-hero .hero-veil{z-index:1}
.op-hero-inner{position:relative;z-index:3;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x) clamp(2.5rem,5vw,4rem)}
.op-back{display:inline-flex;align-items:center;gap:.5rem;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-bottom:1.4rem;transition:color .25s,gap .3s}
.op-back:hover{color:#fff;gap:.85rem}
.op-hero h1{color:#fff;margin-bottom:.6rem}
.op-hero .op-meta{display:flex;gap:1.6rem;flex-wrap:wrap;color:rgba(255,255,255,.72);font-size:.82rem;letter-spacing:.06em;margin-top:1rem}
.op-hero .op-meta span{display:inline-flex;align-items:center;gap:.5rem}
.op-hero .op-meta b{color:#fff;font-weight:500}

.op-layout{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(2.5rem,5vw,4.5rem);align-items:start}
.op-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.op-gallery .g-main{grid-column:1/-1;aspect-ratio:16/10;overflow:hidden;border-radius:8px;cursor:zoom-in;background:var(--paper-3)}
.op-gallery .g-thumb{aspect-ratio:1;overflow:hidden;border-radius:8px;cursor:zoom-in;background:var(--paper-3)}
.op-gallery img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease-out)}
.op-gallery .g-main:hover img,.op-gallery .g-thumb:hover img{transform:scale(1.05)}

.op-aside{position:sticky;top:7rem;background:var(--paper-2);border:1px solid var(--line);border-radius:10px;padding:clamp(1.8rem,3vw,2.4rem)}
.op-aside .oa-tag{display:inline-flex;align-items:center;gap:.5rem;font-size:.62rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:#1f9d57;margin-bottom:1.1rem}
.op-aside .oa-tag .dot{width:7px;height:7px;border-radius:50%;background:#1f9d57}
.op-aside h2{font-size:2rem;margin-bottom:.4rem}
.op-aside .oa-sub{color:var(--gold);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:1.4rem}
.op-aside .oa-p{font-size:.95rem;color:var(--ink-soft);line-height:1.7;margin-bottom:1.6rem}
.op-specs{display:grid;gap:.85rem;margin-bottom:1.8rem}
.op-specs li{display:flex;gap:.75rem;align-items:flex-start;font-size:.92rem;color:var(--ink-soft)}
.op-specs li .ck{flex:none;width:20px;height:20px;border-radius:50%;background:var(--gold-wash);color:var(--gold-deep);display:flex;align-items:center;justify-content:center;font-size:.62rem;margin-top:.2rem}
.op-aside .btn{width:100%;justify-content:center}
.op-aside .oa-or{text-align:center;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute);margin:.9rem 0}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(12,11,8,.94);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:.35s;padding:2rem}
.lightbox.open{opacity:1;visibility:visible}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:6px;box-shadow:var(--shadow-lg);transform:scale(.96);transition:transform .4s var(--ease-out)}
.lightbox.open img{transform:scale(1)}
.lightbox-close{position:absolute;top:1.5rem;right:1.8rem;color:#fff;font-size:2rem;opacity:.8}
.lightbox-close:hover{opacity:1}

/* other offices strip */
.more-offices{background:var(--paper-2);border-top:1px solid var(--line)}

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media(max-width:1024px){
  .nav-links{display:none}
  .nav-burger{display:block}
  .loc-grid{grid-template-columns:1fr}
  .op-layout{grid-template-columns:1fr}
  .op-aside{position:static}
  .footer .wrap{grid-template-columns:1fr 1fr}
}
@media(max-width:860px){
  .split,.salonsec .split{grid-template-columns:1fr;gap:2.4rem}
  .split.flip{direction:ltr}
  .split-figure .fig-badge{left:1rem;bottom:1rem}
  .feat-grid,.testi-grid,.stat-grid{grid-template-columns:1fr 1fr}
  .office-grid{grid-template-columns:1fr}
  .salon-card{grid-template-columns:1fr}
  .salon-card .ocard-media{min-height:240px}
  .hero-meta-inner{grid-template-columns:1fr 1fr;gap:1.4rem 1rem}
}
@media(max-width:560px){
  .feat-grid,.testi-grid,.stat-grid{grid-template-columns:1fr}
  .footer .wrap{grid-template-columns:1fr}
  .foot-bottom .wrap{flex-direction:column;text-align:center}
  .op-gallery{grid-template-columns:1fr 1fr}
  .cards-head{flex-direction:column;align-items:flex-start}
  .hero{min-height:88vh}
  .hero-inner{padding-top:6rem}
  /* hero actions full-width stacked */
  .hero-actions{flex-direction:column;align-items:stretch;gap:.75rem}
  .hero-actions .btn{width:100%;justify-content:center}
  /* meta bar: 2x2 grid */
  .hero-meta-inner{grid-template-columns:1fr 1fr;gap:1.3rem 1rem;padding-block:1.6rem}
  .hmeta .hmeta-n{font-size:1.7rem}
  .hmeta .hmeta-l{font-size:.6rem}
  .hero-copy .eyebrow{margin-bottom:1.2rem;font-size:.62rem;letter-spacing:.2em}
  .op-hero .op-meta{gap:1rem}
  .fig-badge .fb-n{font-size:1.9rem}
}
@media(max-width:380px){
  .nav{padding-inline:1.1rem}
  .nav-logo .lg-name{font-size:1.35rem;letter-spacing:.2em}
}
