
:root{
  --black:#080705;
  --black-soft:#15110c;
  --cream:#f7ead4;
  --cream-2:#fff7ea;
  --gold:#c79a54;
  --muted:#b9a88e;
  --brown:#5c4730;
  --shadow:0 30px 90px rgba(0,0,0,.38);
  --radius:28px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:Inter,Arial,sans-serif;background:var(--black);color:var(--cream);overflow-x:hidden}
a{text-decoration:none;color:inherit}
img,video{display:block;max-width:100%}
.page-wrap{background:radial-gradient(circle at top left,rgba(199,154,84,.17),transparent 32%),var(--black)}
.topbar{background:var(--cream);color:var(--black);padding:10px 7%;display:flex;justify-content:space-between;gap:20px;align-items:center;font-size:13px;font-weight:700}
.topbar-left,.topbar-right,.socials{display:flex;gap:15px;align-items:center;flex-wrap:wrap}
.topbar i{color:var(--gold)}
.socials a{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;background:var(--black);color:var(--cream);transition:.3s}
.socials a:hover{background:var(--gold);color:var(--black);transform:translateY(-2px)}
header{position:sticky;top:0;z-index:20;background:rgba(8,7,5,.88);backdrop-filter:blur(16px);border-bottom:1px solid rgba(247,234,212,.12)}
nav{padding:18px 7%;display:flex;align-items:center;justify-content:space-between;gap:30px}
.logo{font-family:"Cormorant Garamond",serif;font-size:32px;font-weight:700;letter-spacing:1px}
.logo span{color:var(--gold)}
.nav-links{display:flex;list-style:none;gap:27px;align-items:center;font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:1px}
.nav-links a{position:relative}
.nav-links a:after{content:"";position:absolute;left:0;bottom:-8px;width:0;height:2px;background:var(--gold);transition:.3s}
.nav-links a:hover:after,.nav-links .active:after{width:100%}
.book-btn{background:var(--gold);color:var(--black)!important;padding:13px 20px;border-radius:999px;box-shadow:0 12px 30px rgba(199,154,84,.25)}
section{padding:105px 7%}
.hero{min-height:86vh;display:grid;grid-template-columns:1.02fr .98fr;gap:64px;align-items:center;position:relative;overflow:hidden}
.hero:before{content:"";position:absolute;inset:32px;border:1px solid rgba(247,234,212,.12);border-radius:42px;pointer-events:none}
.eyebrow{color:var(--gold);font-size:13px;text-transform:uppercase;letter-spacing:4px;font-weight:900;margin-bottom:18px}
h1,h2,h3{font-family:"Cormorant Garamond",serif;line-height:.98}
h1{font-size:clamp(54px,7vw,104px);max-width:840px}
h2{font-size:clamp(44px,5vw,76px)}
h1 span,h2 span{color:var(--gold)}
.lead{font-size:18px;line-height:1.85;color:var(--muted);max-width:660px;margin:28px 0 38px}
.btns{display:flex;gap:16px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 28px;border-radius:999px;font-weight:900;letter-spacing:.4px;transition:.3s}
.btn.primary{background:var(--cream);color:var(--black)}
.btn.secondary{border:1px solid rgba(247,234,212,.35)}
.btn:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.media-slider{position:relative;min-height:610px;border-radius:48px;overflow:hidden;border:1px solid rgba(247,234,212,.16);box-shadow:var(--shadow);background:var(--black-soft)}
.slide{position:absolute;inset:0;opacity:0;animation:fade 18s infinite}
.slide:nth-child(2){animation-delay:6s}.slide:nth-child(3){animation-delay:12s}
.slide img,.slide video{width:100%;height:100%;object-fit:cover}
.slide:after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.72),transparent 56%)}
@keyframes fade{0%,29%{opacity:1}34%,100%{opacity:0}}
.slider-card{position:absolute;left:26px;right:26px;bottom:26px;z-index:3;background:rgba(247,234,212,.93);color:var(--black);padding:24px;border-radius:24px}
.slider-card h3{font-size:34px;margin-bottom:6px}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:44px}
.stat{background:rgba(247,234,212,.07);border:1px solid rgba(247,234,212,.12);border-radius:22px;padding:23px}
.stat strong{font-family:"Cormorant Garamond",serif;color:var(--gold);font-size:42px;display:block}
.page-hero{padding:95px 7%;background:linear-gradient(rgba(8,7,5,.78),rgba(8,7,5,.92)),url('https://images.unsplash.com/photo-1521590832167-7bcbfaa6381f?auto=format&fit=crop&w=1800&q=80') center/cover;text-align:center}
.page-hero p{margin:22px auto 0;max-width:700px;color:var(--muted);line-height:1.8}
.section-head{display:flex;justify-content:space-between;align-items:end;gap:30px;margin-bottom:54px}
.section-head p{max-width:500px;color:var(--muted);line-height:1.8}
.cream-section{background:var(--cream);color:var(--black)}
.cream-section .eyebrow,.cream-section h2 span{color:#946728}
.cream-section .section-head p,.cream-section .text p{color:#554a39}
.about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:56px;align-items:center}
.round-img{border-radius:42px;overflow:hidden;box-shadow:22px 22px 0 #d8bd91;min-height:520px}
.round-img img{width:100%;height:100%;object-fit:cover}
.text p{line-height:1.9;font-size:17px;margin-bottom:22px}
.features{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:28px}
.feature{background:#fff7ea;border:1px solid #e2c99f;border-radius:24px;padding:23px}
.feature i{font-size:25px;color:#946728;margin-bottom:14px}
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.service-card{position:relative;overflow:hidden;background:linear-gradient(145deg,rgba(247,234,212,.1),rgba(247,234,212,.035));border:1px solid rgba(247,234,212,.14);border-radius:var(--radius);padding:38px;min-height:310px;transition:.35s}
.service-card:hover{transform:translateY(-10px);border-color:rgba(199,154,84,.6)}
.service-card:before{content:"";position:absolute;width:160px;height:160px;right:-60px;top:-60px;border-radius:50%;background:rgba(199,154,84,.15)}
.service-card i{font-size:34px;color:var(--gold);margin-bottom:26px}
.service-card h3{font-size:34px;margin-bottom:15px}
.service-card p{color:var(--muted);line-height:1.75}
.price{display:inline-block;margin-top:24px;background:var(--cream);color:var(--black);padding:10px 16px;border-radius:999px;font-weight:900}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.gallery-item{position:relative;min-height:310px;border-radius:28px;overflow:hidden;background:#111}
.gallery-item.tall{grid-row:span 2;min-height:638px}.gallery-item.wide{grid-column:span 2}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:.5s}
.gallery-item:hover img{transform:scale(1.08);opacity:.72}
.gallery-item span{position:absolute;left:20px;bottom:20px;background:var(--black);color:var(--cream);border-radius:999px;padding:10px 16px;font-size:13px;font-weight:800;opacity:0;transform:translateY(12px);transition:.3s}
.gallery-item:hover span{opacity:1;transform:translateY(0)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.contact-card{background:rgba(247,234,212,.09);border:1px solid rgba(247,234,212,.15);border-radius:var(--radius);padding:42px;backdrop-filter:blur(16px)}
.contact-row{display:grid;grid-template-columns:54px 1fr;gap:18px;padding:22px 0;border-bottom:1px solid rgba(247,234,212,.13)}
.contact-row:last-child{border-bottom:0}
.contact-row i{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;background:var(--cream);color:var(--black);font-size:20px}
.contact-row h3{font-size:28px;margin-bottom:6px}
.contact-row p{color:var(--muted);line-height:1.7}
.map-box{min-height:500px;border-radius:var(--radius);background:var(--cream);color:var(--black);display:grid;place-items:center;text-align:center;padding:38px}
.map-box i{font-size:70px;color:var(--gold);margin-bottom:24px}
.map-box h3{font-size:46px;margin-bottom:14px}
.map-box p{color:#5b513f;line-height:1.8}
footer{background:#050403;border-top:1px solid rgba(247,234,212,.12);padding:50px 7%;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.footer-brand{font-family:"Cormorant Garamond",serif;font-size:30px;font-weight:700}
.footer-brand span,footer a{color:var(--gold)}
.whatsapp{position:fixed;right:24px;bottom:24px;z-index:99;width:62px;height:62px;border-radius:50%;display:grid;place-items:center;background:#25d366;color:#fff;font-size:32px;box-shadow:0 18px 45px rgba(0,0,0,.38);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.45)}70%{box-shadow:0 0 0 18px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
@media(max-width:980px){
  .topbar,nav{align-items:flex-start}.nav-links{gap:16px;flex-wrap:wrap}.hero,.about-grid,.contact-grid{grid-template-columns:1fr}.service-grid,.gallery-grid{grid-template-columns:repeat(2,1fr)}.section-head{display:block}.section-head p{margin-top:20px}.hero:before{display:none}
}
@media(max-width:620px){
  section{padding:75px 6%}.topbar{display:none}nav{padding:16px 6%;display:block}.nav-links{margin-top:18px}.stats,.features,.service-grid,.gallery-grid{grid-template-columns:1fr}.gallery-item.wide{grid-column:span 1}.gallery-item.tall{grid-row:span 1;min-height:310px}.media-slider{min-height:470px}footer{display:block}.footer-brand{margin-bottom:15px}
}


/* ===== Premium stylist homepage upgrades ===== */
.luxury-divider{
  height:1px;
  width:100%;
  background:linear-gradient(90deg,transparent,rgba(199,154,84,.8),transparent);
}
.marquee{
  overflow:hidden;
  background:var(--cream);
  color:var(--black);
  border-block:1px solid rgba(199,154,84,.45);
}
.marquee-track{
  display:flex;
  gap:48px;
  width:max-content;
  padding:17px 0;
  animation:marqueeMove 22s linear infinite;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:2px;
  font-size:13px;
}
.marquee-track span:before{
  content:"✦";
  color:var(--gold);
  margin:0 24px;
}
@keyframes marqueeMove{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
.home-showcase{
  background:
    radial-gradient(circle at 80% 20%,rgba(199,154,84,.18),transparent 34%),
    linear-gradient(180deg,#080705,#120d08);
}
.showcase-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:28px;
  align-items:stretch;
}
.big-editorial{
  min-height:660px;
  border-radius:44px;
  overflow:hidden;
  position:relative;
  border:1px solid rgba(247,234,212,.14);
  box-shadow:var(--shadow);
}
.big-editorial img{width:100%;height:100%;object-fit:cover;filter:saturate(.92) contrast(1.04)}
.big-editorial:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.82),rgba(0,0,0,.08));
}
.editorial-caption{
  position:absolute;
  left:32px;
  right:32px;
  bottom:32px;
  z-index:2;
}
.editorial-caption h2{font-size:64px}
.editorial-caption p{color:var(--muted);line-height:1.8;max-width:580px;margin-top:14px}
.mini-panels{
  display:grid;
  gap:28px;
}
.glass-panel{
  border:1px solid rgba(247,234,212,.15);
  background:linear-gradient(145deg,rgba(247,234,212,.095),rgba(247,234,212,.035));
  border-radius:34px;
  padding:34px;
  position:relative;
  overflow:hidden;
}
.glass-panel:before{
  content:"";
  position:absolute;
  width:180px;
  height:180px;
  border-radius:50%;
  right:-76px;
  top:-76px;
  background:rgba(199,154,84,.18);
}
.glass-panel h3{font-size:39px;margin-bottom:14px;position:relative}
.glass-panel p{color:var(--muted);line-height:1.8;position:relative}
.badge-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px;position:relative}
.badge-row span{
  border:1px solid rgba(247,234,212,.2);
  border-radius:999px;
  padding:10px 14px;
  color:var(--cream);
  font-size:12px;
  font-weight:900;
}
.offer-card{
  background:var(--cream);
  color:var(--black);
  border-radius:34px;
  padding:34px;
  position:relative;
  overflow:hidden;
}
.offer-card:after{
  content:"SAVE";
  position:absolute;
  right:-18px;
  bottom:-24px;
  font-size:92px;
  font-weight:900;
  color:rgba(8,7,5,.06);
}
.offer-card h3{font-size:42px;margin-bottom:12px}
.offer-card p{color:#5b513f;line-height:1.8}
.offer-card .price{background:var(--black);color:var(--cream)}
.process-strip{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  margin-top:42px;
}
.process-step{
  background:rgba(247,234,212,.075);
  border:1px solid rgba(247,234,212,.12);
  border-radius:28px;
  padding:28px;
  transition:.35s;
}
.process-step:hover{transform:translateY(-8px);background:rgba(247,234,212,.12)}
.process-step strong{
  display:block;
  color:var(--gold);
  font-size:44px;
  font-family:"Cormorant Garamond",serif;
  margin-bottom:12px;
}
.process-step h3{font-size:28px;margin-bottom:9px}
.process-step p{color:var(--muted);line-height:1.65;font-size:14px}
.signature-section{
  background:var(--cream);
  color:var(--black);
  position:relative;
  overflow:hidden;
}
.signature-section:before{
  content:"VELVET AURA";
  position:absolute;
  left:-30px;
  top:20px;
  font-size:140px;
  line-height:1;
  font-weight:900;
  letter-spacing:6px;
  color:rgba(8,7,5,.035);
  white-space:nowrap;
}
.signature-grid{
  display:grid;
  grid-template-columns:.85fr 1.15fr;
  gap:48px;
  align-items:center;
  position:relative;
}
.stylist-card{
  border-radius:42px;
  overflow:hidden;
  box-shadow:24px 24px 0 #d8bd91;
  position:relative;
}
.stylist-card img{width:100%;height:620px;object-fit:cover}
.stylist-label{
  position:absolute;
  left:24px;
  right:24px;
  bottom:24px;
  background:rgba(255,247,234,.94);
  border-radius:24px;
  padding:22px;
}
.stylist-label h3{font-size:34px}
.stylist-label p{color:#5b513f;margin-top:5px}
.signature-list{
  display:grid;
  gap:17px;
  margin-top:30px;
}
.signature-item{
  display:grid;
  grid-template-columns:58px 1fr;
  gap:18px;
  align-items:start;
  background:#fff7ea;
  border:1px solid #e2c99f;
  border-radius:25px;
  padding:22px;
}
.signature-item i{
  width:58px;
  height:58px;
  display:grid;
  place-items:center;
  background:var(--black);
  color:var(--gold);
  border-radius:50%;
}
.signature-item h3{font-size:27px;margin-bottom:5px}
.signature-item p{color:#5b513f;line-height:1.7}
.testimonial-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
}
.review-card{
  padding:34px;
  border-radius:30px;
  border:1px solid rgba(247,234,212,.14);
  background:linear-gradient(145deg,rgba(247,234,212,.095),rgba(247,234,212,.03));
}
.stars{color:var(--gold);margin-bottom:18px;letter-spacing:3px}
.review-card p{color:var(--muted);line-height:1.8;font-size:15px}
.review-card h3{font-size:28px;margin-top:22px}
.insta-strip{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:10px;
  margin-top:38px;
}
.insta-strip a{
  min-height:190px;
  border-radius:24px;
  overflow:hidden;
  position:relative;
}
.insta-strip img{width:100%;height:100%;object-fit:cover;transition:.45s}
.insta-strip a:after{
  content:"\f16d";
  font-family:"Font Awesome 6 Brands";
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  background:rgba(0,0,0,.45);
  font-size:32px;
  opacity:0;
  transition:.35s;
}
.insta-strip a:hover img{transform:scale(1.1)}
.insta-strip a:hover:after{opacity:1}
.cta-band{
  margin:0 7% 80px;
  border-radius:42px;
  padding:54px;
  background:
    linear-gradient(90deg,rgba(8,7,5,.92),rgba(8,7,5,.48)),
    url('https://images.unsplash.com/photo-1562322140-8baeececf3df?auto=format&fit=crop&w=1600&q=80') center/cover;
  border:1px solid rgba(247,234,212,.16);
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:30px;
}
.cta-band h2{font-size:58px}
.cta-band p{color:var(--muted);line-height:1.7;margin-top:12px;max-width:660px}
footer{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 15% 20%,rgba(199,154,84,.18),transparent 30%),
    linear-gradient(180deg,#090705,#030302);
  padding:0;
  display:block;
}
.footer-main{
  padding:70px 7% 44px;
  display:grid;
  grid-template-columns:1.1fr .75fr .75fr 1fr;
  gap:38px;
  position:relative;
  z-index:2;
}
footer:before{
  content:"";
  position:absolute;
  inset:20px;
  border:1px solid rgba(247,234,212,.08);
  border-radius:38px;
  pointer-events:none;
}
.footer-brand{font-size:40px;margin-bottom:16px}
.footer-col p,.footer-col li{
  color:var(--muted);
  line-height:1.8;
  font-size:14px;
}
.footer-col h3{
  font-family:Inter,Arial,sans-serif;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:2px;
  color:var(--gold);
  margin-bottom:20px;
}
.footer-col ul{list-style:none;display:grid;gap:11px}
.footer-col li a:hover{color:var(--cream)}
.footer-socials{display:flex;gap:12px;margin-top:24px}
.footer-socials a{
  width:42px;
  height:42px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:rgba(247,234,212,.08);
  border:1px solid rgba(247,234,212,.13);
  color:var(--cream);
  transition:.3s;
}
.footer-socials a:hover{background:var(--gold);color:var(--black);transform:translateY(-4px)}
.footer-hours{
  display:grid;
  gap:10px;
}
.footer-hours div{
  display:flex;
  justify-content:space-between;
  border-bottom:1px dashed rgba(247,234,212,.15);
  padding-bottom:10px;
  color:var(--muted);
  font-size:14px;
}
.footer-bottom{
  position:relative;
  z-index:2;
  border-top:1px solid rgba(247,234,212,.1);
  padding:22px 7%;
  display:flex;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
  color:var(--muted);
  font-size:14px;
}
.footer-bottom a{color:var(--gold);font-weight:900}
@media(max-width:980px){
  .showcase-grid,.signature-grid{grid-template-columns:1fr}
  .process-strip,.testimonial-row{grid-template-columns:repeat(2,1fr)}
  .insta-strip{grid-template-columns:repeat(3,1fr)}
  .footer-main{grid-template-columns:1fr 1fr}
  .cta-band{display:block}
  .cta-band .btn{margin-top:24px}
}
@media(max-width:620px){
  .process-strip,.testimonial-row,.insta-strip,.footer-main{grid-template-columns:1fr}
  .big-editorial{min-height:520px}
  .editorial-caption h2,.cta-band h2{font-size:42px}
  .cta-band{margin:0 6% 60px;padding:34px}
  .signature-section:before{font-size:70px}
}


/* ===== Mobile menu, lightbox, and richer motion effects ===== */
.cursor-glow{
  position:fixed;
  width:360px;
  height:360px;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  pointer-events:none;
  z-index:0;
  background:radial-gradient(circle,rgba(199,154,84,.16),transparent 64%);
  filter:blur(8px);
  transition:left .12s linear,top .12s linear;
}
body > *:not(.cursor-glow):not(.whatsapp):not(.lightbox){position:relative}
.menu-toggle,.menu-close,.mobile-menu-head{display:none}
.reveal-up{
  opacity:0;
  transform:translateY(42px);
  transition:opacity .85s ease,transform .85s cubic-bezier(.22,1,.36,1),filter .85s ease;
  transition-delay:var(--delay,0ms);
  filter:blur(8px);
}
.reveal-up.is-visible{
  opacity:1;
  transform:translateY(0);
  filter:blur(0);
}
.hero h1{
  animation:heroLift .95s cubic-bezier(.22,1,.36,1) both;
}
.hero .lead,.hero .btns,.hero .stats{
  animation:heroLift .95s cubic-bezier(.22,1,.36,1) both;
}
.hero .lead{animation-delay:.12s}.hero .btns{animation-delay:.22s}.hero .stats{animation-delay:.32s}
.media-slider{
  animation:floatFrame 7s ease-in-out infinite;
}
@keyframes heroLift{
  from{opacity:0;transform:translateY(34px);filter:blur(10px)}
  to{opacity:1;transform:translateY(0);filter:blur(0)}
}
@keyframes floatFrame{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-14px)}
}
.service-card,.glass-panel,.review-card,.process-step,.tilt-card{
  will-change:transform;
  transform-style:preserve-3d;
}
.big-editorial:before,.gallery-item:before{
  content:"";
  position:absolute;
  inset:0;
  z-index:2;
  background:linear-gradient(110deg,transparent 20%,rgba(255,255,255,.26) 45%,transparent 70%);
  transform:translateX(-130%);
  transition:.8s;
  pointer-events:none;
}
.big-editorial:hover:before,.gallery-item:hover:before{
  transform:translateX(130%);
}
.glass-panel,.offer-card,.process-step,.signature-item,.review-card{
  box-shadow:0 0 0 rgba(199,154,84,0);
}
.glass-panel:hover,.offer-card:hover,.process-step:hover,.signature-item:hover,.review-card:hover{
  box-shadow:0 28px 80px rgba(199,154,84,.13);
}
.signature-item{
  transition:.35s;
}
.signature-item:hover{
  transform:translateX(10px);
}
.insta-strip a{
  transition:.35s;
}
.insta-strip a:hover{
  transform:translateY(-8px) rotate(-1deg);
}
.cta-band{
  animation:ctaGlow 5s ease-in-out infinite;
}
@keyframes ctaGlow{
  0%,100%{box-shadow:0 0 0 rgba(199,154,84,0)}
  50%{box-shadow:0 28px 95px rgba(199,154,84,.2)}
}
.gallery-item{
  cursor:pointer;
  display:block;
}
.gallery-item em{
  position:absolute;
  top:18px;
  right:18px;
  z-index:4;
  width:46px;
  height:46px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:var(--cream);
  color:var(--black);
  opacity:0;
  transform:scale(.75) rotate(-18deg);
  transition:.35s;
  font-style:normal;
}
.gallery-item:hover em{
  opacity:1;
  transform:scale(1) rotate(0);
}
.lightbox{
  position:fixed;
  inset:0;
  z-index:999;
  background:rgba(3,3,2,.86);
  backdrop-filter:blur(18px);
  display:grid;
  place-items:center;
  opacity:0;
  pointer-events:none;
  transition:.35s;
  padding:34px;
}
.lightbox.is-open{
  opacity:1;
  pointer-events:auto;
}
.lightbox-frame{
  width:min(1080px,84vw);
  max-height:86vh;
  position:relative;
  border-radius:34px;
  overflow:hidden;
  border:1px solid rgba(247,234,212,.18);
  box-shadow:0 36px 120px rgba(0,0,0,.72);
  background:#080705;
}
.lightbox-frame img{
  width:100%;
  max-height:78vh;
  object-fit:contain;
  background:#080705;
}
.image-pop{
  animation:imagePop .45s cubic-bezier(.22,1,.36,1) both;
}
@keyframes imagePop{
  from{opacity:0;transform:scale(.92) rotate(.5deg);filter:blur(8px)}
  to{opacity:1;transform:scale(1) rotate(0);filter:blur(0)}
}
.lightbox-caption{
  position:absolute;
  left:20px;
  right:20px;
  bottom:20px;
  border-radius:20px;
  padding:16px 20px;
  background:rgba(247,234,212,.92);
  color:var(--black);
  font-weight:900;
  letter-spacing:1px;
}
.lightbox-close,.lightbox-nav{
  position:fixed;
  border:0;
  cursor:pointer;
  display:grid;
  place-items:center;
  background:var(--cream);
  color:var(--black);
  transition:.25s;
}
.lightbox-close:hover,.lightbox-nav:hover{
  background:var(--gold);
  transform:scale(1.08);
}
.lightbox-close{
  top:24px;
  right:24px;
  width:54px;
  height:54px;
  border-radius:50%;
  font-size:22px;
}
.lightbox-nav{
  top:50%;
  transform:translateY(-50%);
  width:58px;
  height:58px;
  border-radius:50%;
  font-size:20px;
}
.lightbox-prev{left:24px}
.lightbox-next{right:24px}
body.lightbox-open{overflow:hidden}
@media(max-width:980px){
  .menu-toggle{
    display:grid;
    width:48px;
    height:48px;
    border-radius:50%;
    border:1px solid rgba(247,234,212,.22);
    background:rgba(247,234,212,.08);
    place-items:center;
    padding:11px;
    cursor:pointer;
    margin-left:auto;
  }
  .menu-toggle span{
    width:22px;
    height:2px;
    background:var(--cream);
    display:block;
    margin:3px 0;
    transition:.3s;
  }
  nav{
    display:flex;
    align-items:center;
  }
  .nav-backdrop{
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.58);
    backdrop-filter:blur(4px);
    z-index:80;
    opacity:0;
    pointer-events:none;
    transition:.3s;
  }
  .nav-links{
    position:fixed;
    right:0;
    top:0;
    height:100vh;
    width:min(86vw,390px);
    z-index:90;
    display:flex;
    flex-direction:column;
    align-items:stretch;
    gap:0;
    padding:26px;
    background:
      radial-gradient(circle at top right,rgba(199,154,84,.22),transparent 36%),
      linear-gradient(180deg,#0b0805,#030302);
    border-left:1px solid rgba(247,234,212,.14);
    transform:translateX(105%);
    transition:transform .42s cubic-bezier(.22,1,.36,1);
    box-shadow:-30px 0 80px rgba(0,0,0,.48);
  }
  .mobile-menu-head{
    display:flex;
    justify-content:space-between;
    align-items:center;
    color:var(--gold);
    font-family:"Cormorant Garamond",serif;
    font-size:34px;
    margin-bottom:18px;
  }
  .menu-close{
    display:grid;
    width:42px;
    height:42px;
    border:0;
    border-radius:50%;
    background:var(--cream);
    color:var(--black);
    place-items:center;
    font-size:18px;
    cursor:pointer;
  }
  .nav-links li:not(.mobile-menu-head){
    border-bottom:1px solid rgba(247,234,212,.1);
  }
  .nav-links a{
    display:block;
    padding:19px 0;
    font-size:15px;
  }
  .nav-links .book-btn{
    text-align:center;
    margin-top:22px;
    padding:15px 18px;
  }
  body.menu-open .nav-backdrop{
    opacity:1;
    pointer-events:auto;
  }
  body.menu-open .nav-links{
    transform:translateX(0);
  }
  body.menu-open .menu-toggle span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  body.menu-open .menu-toggle span:nth-child(2){opacity:0}
  body.menu-open .menu-toggle span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
}
@media(max-width:620px){
  .lightbox{padding:14px}
  .lightbox-frame{width:92vw}
  .lightbox-nav{width:46px;height:46px}
  .lightbox-prev{left:10px}
  .lightbox-next{right:10px}
  .lightbox-close{top:12px;right:12px}
  .topbar{display:flex;padding:9px 6%;font-size:12px}
  .topbar-right{display:none}
}


/* ===== v4 bug fixes: gallery viewer + WhatsApp placement ===== */
.whatsapp{
  right:28px !important;
  bottom:28px !important;
  width:64px !important;
  height:64px !important;
  z-index:120 !important;
}
.gallery-grid{
  align-items:stretch;
}
.gallery-item{
  text-decoration:none;
  color:inherit;
}
.gallery-item img{
  pointer-events:none;
}
.lightbox{
  z-index:2000 !important;
}
.lightbox-close,.lightbox-nav{
  z-index:2010 !important;
}
body.lightbox-open .whatsapp{
  opacity:0;
  pointer-events:none;
  transform:scale(.86);
}
@media(max-width:620px){
  .whatsapp{
    right:18px !important;
    bottom:84px !important;
    width:56px !important;
    height:56px !important;
    font-size:28px !important;
  }
}


/* ===== v5 hard fix: fixed WhatsApp + reliable gallery overlay ===== */
.whatsapp,
a.whatsapp{
  position:fixed !important;
  right:26px !important;
  left:auto !important;
  bottom:26px !important;
  top:auto !important;
  width:62px !important;
  height:62px !important;
  z-index:9999 !important;
  border-radius:50% !important;
  display:grid !important;
  place-items:center !important;
  transform:none !important;
}
.lightbox{
  position:fixed !important;
  inset:0 !important;
  z-index:99999 !important;
}
.lightbox-close,
.lightbox-nav{
  z-index:100000 !important;
}
@media(max-width:620px){
  .whatsapp,
  a.whatsapp{
    right:18px !important;
    left:auto !important;
    bottom:18px !important;
    top:auto !important;
    width:56px !important;
    height:56px !important;
  }
}
