/* =========================================================
   Bella Vie Salon & Spa — Cinematic Premium Stylesheet
   ========================================================= */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&family=Inter:wght@300;400;500;600;700&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,400&display=swap');

/* ---------- Tokens ---------- */
:root {
  --cream: #FDFBF7;
  --cream-2: #F6F0E6;
  --gold: #D4AF37;
  --gold-soft: #E8CE7A;
  --gold-deep: #A8862A;
  --rose: #E9C2C9;
  --rose-deep: #C48A94;
  --taupe: #B38F72;
  --charcoal: #2C3E50;
  --charcoal-2: #1A2530;
  --ink: #14161B;
  --white: #ffffff;

  --grad-gold: linear-gradient(120deg, #A8862A 0%, #D4AF37 30%, #F3DE9A 55%, #D4AF37 80%, #A8862A 100%);
  --grad-rose: linear-gradient(135deg, #F7E4E8 0%, #E9C2C9 45%, #C48A94 100%);
  --grad-cream: linear-gradient(180deg, #FDFBF7 0%, #F6F0E6 100%);
  --grad-hero-veil: linear-gradient(180deg, rgba(20,22,27,.55) 0%, rgba(20,22,27,.25) 35%, rgba(20,22,27,.65) 100%);

  --shadow-sm: 0 4px 14px rgba(44,62,80,.08);
  --shadow-md: 0 18px 50px -18px rgba(44,62,80,.28);
  --shadow-lg: 0 40px 90px -30px rgba(44,62,80,.35);
  --shadow-gold: 0 20px 60px -18px rgba(212,175,55,.55);

  --radius-sm: 10px;
  --radius: 18px;
  --radius-lg: 28px;

  --f-display: 'Playfair Display', 'Cormorant Garamond', Georgia, serif;
  --f-serif: 'Cormorant Garamond', 'Playfair Display', Georgia, serif;
  --f-body: 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;

  --nav-h: 82px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--f-body);
  color: var(--charcoal);
  background: var(--cream);
  line-height: 1.65;
  font-weight: 400;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; }

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

/* ---------- Loader ---------- */
.loader{
  position:fixed; inset:0; z-index:9999; background:var(--cream);
  display:flex; align-items:center; justify-content:center; flex-direction:column; gap:1.25rem;
  transition: opacity .8s ease, visibility .8s;
}
.loader.hidden{ opacity:0; visibility:hidden; pointer-events:none; }
.loader-mark{
  font-family:var(--f-display); font-size:2rem; letter-spacing:.4em; text-transform:uppercase;
  background: var(--grad-gold); -webkit-background-clip:text; background-clip:text; color:transparent;
  animation: shimmer 2.4s linear infinite;
  background-size:200% auto;
}
.loader-bar{ width:180px; height:2px; background:rgba(44,62,80,.1); position:relative; overflow:hidden; border-radius:2px; }
.loader-bar::after{ content:''; position:absolute; inset:0; background:var(--grad-gold); background-size:200% auto; animation: loadBar 1.4s ease-in-out infinite; }
@keyframes loadBar { 0%{ transform:translateX(-100%);} 100%{ transform:translateX(100%);} }
@keyframes shimmer { to { background-position: 200% center; } }

/* ---------- Scroll progress ---------- */
.progress{ position:fixed; top:0; left:0; height:3px; width:0%; z-index:200;
  background: var(--grad-gold); background-size:200% auto; box-shadow:0 0 12px rgba(212,175,55,.7); }

/* ---------- Nav ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; height:var(--nav-h); z-index:100;
  display:flex; align-items:center; justify-content:space-between; padding: 0 clamp(1rem, 4vw, 3rem);
  transition: background .5s ease, backdrop-filter .5s, box-shadow .4s, height .4s;
}
.nav.scrolled{
  background: rgba(253,251,247,.82);
  backdrop-filter: blur(18px) saturate(1.2);
  -webkit-backdrop-filter: blur(18px) saturate(1.2);
  box-shadow: 0 8px 30px -18px rgba(44,62,80,.25);
  height: 68px;
}
.brand{ display:flex; align-items:center; gap:.85rem; }
.brand-logo{
  width:46px; height:46px; border-radius:50%; object-fit:cover;
  box-shadow: 0 6px 20px rgba(44,62,80,.25), 0 0 0 2px rgba(212,175,55,.4);
  transition: transform .5s ease;
}
.brand:hover .brand-logo{ transform: rotate(-8deg) scale(1.05); }
.brand-name{
  font-family:var(--f-display); font-weight:700; font-size:1.15rem; letter-spacing:.14em; text-transform:uppercase;
  color: var(--charcoal);
}
.brand-name em{ font-style:italic; font-weight:500; color:var(--gold-deep); letter-spacing:.06em; margin-left:.35em; }

.nav-links{ display:flex; align-items:center; gap: 2.2rem; }
.nav-links a{
  position:relative; font-size:.86rem; letter-spacing:.15em; text-transform:uppercase; font-weight:500;
  color:var(--charcoal); padding:.4rem 0;
}
.nav-links a::after{
  content:''; position:absolute; left:0; bottom:0; width:100%; height:1px; background:var(--gold);
  transform: scaleX(0); transform-origin: right center; transition: transform .45s cubic-bezier(.7,.05,.3,1);
}
.nav-links a:hover::after, .nav-links a.active::after{ transform: scaleX(1); transform-origin:left center; }
.nav-links a.active{ color: var(--gold-deep); }

.nav-cta{ display:inline-flex; align-items:center; gap:.5rem; }
.burger{ display:none; width:44px; height:44px; border-radius:50%; align-items:center; justify-content:center;
  background: rgba(44,62,80,.05); }
.burger span{ display:block; width:20px; height:1.5px; background:var(--charcoal); position:relative; transition:.3s; }
.burger span::before, .burger span::after{ content:''; position:absolute; left:0; width:20px; height:1.5px; background:var(--charcoal); transition:.3s; }
.burger span::before{ top:-6px; } .burger span::after{ top:6px; }
.burger.open span{ background:transparent; }
.burger.open span::before{ top:0; transform: rotate(45deg); }
.burger.open span::after{ top:0; transform: rotate(-45deg); }

.mobile-menu{
  position:fixed; inset: 0; z-index: 90; background: var(--cream);
  padding: calc(var(--nav-h) + 2rem) 2rem 2rem;
  transform: translateY(-101%); transition: transform .6s cubic-bezier(.77,0,.18,1);
  display:flex; flex-direction:column; gap:1rem;
}
.mobile-menu.open{ transform: translateY(0); }
.mobile-menu a{
  font-family: var(--f-display); font-size: 2rem; padding: .5rem 0;
  border-bottom: 1px solid rgba(44,62,80,.08);
  opacity:0; transform: translateY(20px); transition: opacity .5s, transform .5s;
}
.mobile-menu.open a{ opacity:1; transform:translateY(0); }
.mobile-menu.open a:nth-child(1){ transition-delay: .15s;}
.mobile-menu.open a:nth-child(2){ transition-delay: .22s;}
.mobile-menu.open a:nth-child(3){ transition-delay: .29s;}
.mobile-menu.open a:nth-child(4){ transition-delay: .36s;}
.mobile-menu.open a:nth-child(5){ transition-delay: .43s;}
.mobile-menu .btn{ margin-top: 1.5rem; align-self: flex-start; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.7rem;
  padding: 1rem 1.9rem;
  font-size:.8rem; letter-spacing:.24em; text-transform:uppercase; font-weight:600;
  border-radius: 999px;
  transition: transform .4s cubic-bezier(.2,.9,.2,1), box-shadow .4s, background .4s, color .4s;
  position:relative; overflow:hidden; isolation:isolate;
}
.btn svg{ width:16px; height:16px; }
.btn-primary{ background: var(--charcoal); color: var(--cream); box-shadow: var(--shadow-md); }
.btn-primary::before{
  content:''; position:absolute; inset:0; background: var(--grad-gold); background-size:200% auto;
  opacity:0; transition:opacity .5s; z-index:-1;
}
.btn-primary:hover{ transform: translateY(-3px); color:var(--charcoal); box-shadow: var(--shadow-gold); }
.btn-primary:hover::before{ opacity:1; animation: shimmer 3s linear infinite; }

.btn-gold{ background: var(--grad-gold); background-size:200% auto; color:var(--white); box-shadow: var(--shadow-gold); }
.btn-gold:hover{ transform: translateY(-3px); animation: shimmer 2s linear infinite; }

.btn-ghost{ background: transparent; color: var(--cream); border: 1px solid rgba(255,255,255,.6); }
.btn-ghost:hover{ background: rgba(255,255,255,.14); border-color: var(--gold); color:var(--gold-soft); }

.btn-dark-outline{ background: transparent; color: var(--charcoal); border: 1px solid var(--charcoal); }
.btn-dark-outline:hover{ background: var(--charcoal); color: var(--cream); transform:translateY(-3px); }

/* ---------- Layout ---------- */
.section{ padding: clamp(4rem, 9vw, 8rem) clamp(1.25rem, 5vw, 4rem); position:relative; }
.container{ max-width: 1240px; margin: 0 auto; }
.container-narrow{ max-width: 980px; margin: 0 auto; }

.eyebrow{
  display:inline-flex; align-items:center; gap:.7rem;
  font-size:.72rem; letter-spacing:.4em; text-transform:uppercase; font-weight:600;
  color: var(--gold-deep);
}
.eyebrow::before{ content:''; width:34px; height:1px; background: var(--gold); }

h1, h2, h3, h4 { font-family: var(--f-display); font-weight: 500; letter-spacing:-.01em; color: var(--charcoal); line-height:1.1; }
h1{ font-size: clamp(2.6rem, 6.5vw, 5.5rem); font-weight: 500; }
h2{ font-size: clamp(2rem, 4.4vw, 3.6rem); font-weight: 500; }
h3{ font-size: clamp(1.4rem, 2.2vw, 1.9rem); }
h1 em, h2 em{ font-family: var(--f-serif); font-style: italic; font-weight: 400; color: var(--gold-deep); }
.lead{ font-size: clamp(1rem, 1.25vw, 1.15rem); color: rgba(44,62,80,.75); max-width:60ch; }

/* ---------- Hero ---------- */
.hero{
  position:relative; min-height: 100svh; overflow:hidden;
  display:flex; align-items:flex-end;
  color: var(--cream);
  isolation: isolate;
}
.hero-media{ position:absolute; inset:0; z-index:-2; overflow:hidden; }
.hero-media img{
  width:100%; height:100%; object-fit:cover; object-position: center 35%;
  transform: scale(1.15); animation: heroZoom 14s ease-out forwards;
  filter: saturate(1.05) contrast(1.02);
}
@keyframes heroZoom { to { transform: scale(1.02);} }
.hero-veil{ position:absolute; inset:0; z-index:-1; background: var(--grad-hero-veil); }
.hero-veil::after{
  content:''; position:absolute; inset:0;
  background: radial-gradient(ellipse at 20% 100%, rgba(212,175,55,.25), transparent 50%),
              radial-gradient(ellipse at 100% 0%, rgba(228,180,190,.18), transparent 55%);
  mix-blend-mode: screen;
}
.hero-inner{
  padding: 0 clamp(1.25rem, 5vw, 4rem) clamp(3rem, 8vw, 6rem);
  width:100%; max-width: 1240px; margin: 0 auto;
  position:relative;
}
.hero-eyebrow{
  display:inline-flex; align-items:center; gap:.8rem;
  font-size:.75rem; letter-spacing:.42em; text-transform:uppercase; color: var(--gold-soft); font-weight:500;
  margin-bottom: 1.5rem;
}
.hero-eyebrow::before, .hero-eyebrow::after{ content:''; width:40px; height:1px; background: var(--gold-soft); }
.hero-title{
  color: var(--white); font-weight: 500;
  font-size: clamp(2.8rem, 7.5vw, 6.2rem);
  line-height: 1; letter-spacing:-.015em;
  max-width: 14ch;
  text-shadow: 0 4px 40px rgba(0,0,0,.35);
}
.hero-title .line{ display:block; overflow:hidden; }
.hero-title .line span{ display:inline-block; transform: translateY(110%); animation: rise 1.1s cubic-bezier(.2,.8,.2,1) forwards; }
.hero-title .line:nth-child(1) span{ animation-delay: .3s; }
.hero-title .line:nth-child(2) span{ animation-delay: .5s; }
.hero-title .line:nth-child(3) span{ animation-delay: .7s; }
.hero-title em{
  font-family: var(--f-serif); font-style: italic; font-weight:400;
  background: var(--grad-gold); background-size:200% auto;
  -webkit-background-clip:text; background-clip:text; color:transparent;
  animation: shimmer 5s linear infinite;
}
@keyframes rise { to { transform: translateY(0); } }

.hero-sub{
  margin-top: 1.6rem; max-width: 46ch; color: rgba(253,251,247,.85);
  font-size: clamp(.98rem, 1.1vw, 1.1rem);
  opacity:0; transform: translateY(20px); animation: fadeUp 1s ease .95s forwards;
}
.hero-actions{ display:flex; flex-wrap:wrap; gap:.9rem; margin-top: 2.2rem;
  opacity:0; transform: translateY(20px); animation: fadeUp 1s ease 1.1s forwards; }
@keyframes fadeUp{ to { opacity:1; transform: translateY(0);} }

.hero-meta{
  position:absolute; right: clamp(1.25rem, 5vw, 4rem); bottom: clamp(3rem, 8vw, 6rem);
  writing-mode: vertical-rl; transform: rotate(180deg);
  font-size:.7rem; letter-spacing:.5em; text-transform:uppercase; color: rgba(253,251,247,.7);
  display:flex; align-items:center; gap:1rem;
}
.hero-meta::after{ content:''; width:1px; height:60px; background: rgba(253,251,247,.5); }

.scroll-indicator{
  position:absolute; left: 50%; bottom: 1.5rem; transform: translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:.6rem;
  font-size:.65rem; letter-spacing:.35em; text-transform:uppercase; color: rgba(253,251,247,.75);
  z-index:2;
}
.scroll-indicator .line{
  width:1px; height:50px; background: linear-gradient(to bottom, transparent, var(--gold-soft));
  animation: pulseLine 2.2s ease-in-out infinite;
}
@keyframes pulseLine { 0%,100% { transform: scaleY(1); opacity:.9;} 50%{ transform: scaleY(.4); opacity:.5;} }

/* Hero variant for interior pages */
.hero.hero-page{ min-height: 78svh; align-items:center; text-align:center; }
.hero.hero-page .hero-inner{ text-align:center; }
.hero.hero-page .hero-title{ max-width: none; margin: 0 auto; }
.hero.hero-page .hero-sub{ margin-left:auto; margin-right:auto; }

/* ---------- Marquee ---------- */
.marquee{
  overflow:hidden; padding: 1.5rem 0; background: var(--charcoal-2); color: var(--cream);
  border-top: 1px solid rgba(212,175,55,.25); border-bottom: 1px solid rgba(212,175,55,.25);
}
.marquee-track{ display:flex; gap: 3rem; animation: mar 40s linear infinite; white-space:nowrap; }
.marquee-track span{
  font-family: var(--f-display); font-style: italic; font-size: 1.5rem; letter-spacing:.04em;
  display:inline-flex; align-items:center; gap: 3rem;
}
.marquee-track span::after{ content:'✦'; color: var(--gold); font-style: normal; font-size:1rem; }
@keyframes mar { to { transform: translateX(-50%);} }

/* ---------- Intro / About block ---------- */
.split{ display:grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 5rem); align-items:center; }
.split-media{ position:relative; }
.split-media .frame{
  border-radius: var(--radius-lg); overflow:hidden; box-shadow: var(--shadow-lg);
  transform: perspective(1200px) rotateY(-6deg) rotateX(2deg);
  transition: transform .8s cubic-bezier(.2,.8,.2,1);
}
.split-media .frame:hover{ transform: perspective(1200px) rotateY(-2deg) rotateX(1deg) translateY(-6px); }
.split-media .frame img{ width:100%; height:100%; object-fit:cover; aspect-ratio: 4/5; transform: scale(1.02); transition: transform 1.2s ease; }
.split-media .frame:hover img{ transform: scale(1.08); }
.split-media .badge{
  position:absolute; bottom:-30px; right:-24px; z-index:2;
  width:170px; height:170px; border-radius:50%;
  background: var(--grad-gold); color: var(--charcoal);
  display:flex; align-items:center; justify-content:center; text-align:center;
  font-family: var(--f-display); font-size: 1rem; line-height:1.2;
  box-shadow: var(--shadow-gold);
  animation: rotSlow 22s linear infinite;
}
.split-media .badge span{ display:block; font-style: italic; font-size:.75rem; letter-spacing:.15em; text-transform:uppercase; }
@keyframes rotSlow { to { transform: rotate(360deg);} }

.split-body h2{ margin: 1rem 0 1.25rem; }
.split-body .sig{
  font-family: var(--f-serif); font-style: italic; font-size: 1.4rem; color: var(--gold-deep);
  margin-top: 1.5rem; display:inline-block;
}
.split-body .stats{ display:flex; gap: 2.5rem; margin-top: 2rem; }
.stat b{ font-family: var(--f-display); font-size: 2.4rem; color: var(--charcoal); display:block; }
.stat small{ font-size:.72rem; letter-spacing:.28em; text-transform:uppercase; color: rgba(44,62,80,.6); }

/* ---------- Services ---------- */
.section-head{ text-align:center; margin: 0 auto 3.5rem; max-width: 62ch; }
.section-head h2{ margin:.8rem 0 1rem; }
.section-head p{ color: rgba(44,62,80,.7); }

.svc-grid{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 1.4rem; }
.svc-card{
  position:relative; overflow:hidden; border-radius: var(--radius);
  aspect-ratio: 3/4; background: var(--charcoal);
  isolation: isolate; cursor:pointer;
  box-shadow: var(--shadow-md);
  transition: transform .6s cubic-bezier(.2,.8,.2,1);
}
.svc-card img{
  width:100%; height:100%; object-fit:cover; position:absolute; inset:0;
  transition: transform 1.2s cubic-bezier(.2,.8,.2,1), filter .6s;
  filter: saturate(.95);
}
.svc-card::after{
  content:''; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(20,22,27,0) 30%, rgba(20,22,27,.85) 100%);
}
.svc-card .body{
  position:absolute; left:0; right:0; bottom:0; padding: 1.6rem; z-index:2; color: var(--cream);
  transform: translateY(20px); transition: transform .5s;
}
.svc-card .kicker{ font-size:.7rem; letter-spacing:.35em; text-transform:uppercase; color: var(--gold-soft); }
.svc-card h3{ color: var(--cream); font-size: 1.5rem; margin: .4rem 0 .6rem; }
.svc-card p{ color: rgba(253,251,247,.8); font-size:.9rem; opacity:0; max-height:0; transition: opacity .5s, max-height .6s; }
.svc-card:hover{ transform: translateY(-6px); }
.svc-card:hover img{ transform: scale(1.1); filter: saturate(1.1); }
.svc-card:hover .body{ transform: translateY(0); }
.svc-card:hover p{ opacity:1; max-height: 100px; }

/* ---------- Menu (services page) ---------- */
.menu-block{ background: var(--white); border-radius: var(--radius-lg); padding: clamp(2rem, 4vw, 3.5rem); box-shadow: var(--shadow-md); margin-bottom: 2rem; }
.menu-head{ display:flex; align-items:baseline; gap: 1rem; margin-bottom: 2rem; padding-bottom: 1.25rem; border-bottom: 1px solid rgba(44,62,80,.08); }
.menu-head h3{ font-size: clamp(1.6rem, 2.8vw, 2.4rem); color: var(--charcoal); }
.menu-head .num{ font-family: var(--f-serif); font-style:italic; color: var(--gold-deep); font-size: 1.5rem; }
.menu-list{ display:grid; grid-template-columns: 1fr; gap: 1.1rem; }
.menu-item{
  display:flex; align-items:baseline; gap:1rem; padding: 1rem 0;
  border-bottom: 1px dashed rgba(44,62,80,.15);
  transition: padding .3s;
}
.menu-item:hover{ padding-left: .8rem; }
.menu-item:last-child{ border-bottom:0; }
.menu-item .name{ font-family: var(--f-display); font-size: 1.15rem; color: var(--charcoal); flex-shrink:0; }
.menu-item .dots{ flex:1; border-bottom: 1px dotted rgba(44,62,80,.25); position: relative; top:-.35em; margin: 0 .3rem; }
.menu-item .price{
  font-family: var(--f-serif); font-style:italic; font-size: 1.3rem; color: var(--gold-deep); font-weight:500;
}

/* ---------- Experience / Steps ---------- */
.steps{ display:grid; grid-template-columns: repeat(4, 1fr); gap: 1.25rem; margin-top: 3rem; }
.step{
  position:relative; padding: 2.2rem 1.6rem; border-radius: var(--radius);
  background: var(--white); box-shadow: var(--shadow-sm);
  transition: transform .5s, box-shadow .5s;
}
.step:hover{ transform: translateY(-6px); box-shadow: var(--shadow-md); }
.step .num{
  font-family: var(--f-display); font-style:italic; font-size: 3rem;
  background: var(--grad-gold); -webkit-background-clip:text; background-clip:text; color:transparent;
  line-height:1;
}
.step h4{ font-size: 1.2rem; margin: .8rem 0 .5rem; }
.step p{ font-size: .92rem; color: rgba(44,62,80,.7); }

/* ---------- Gallery ---------- */
.gal-grid{ display:grid; grid-template-columns: repeat(6, 1fr); grid-auto-rows: 160px; gap: 1rem; }
.gal-item{ overflow:hidden; border-radius: var(--radius); position:relative; box-shadow: var(--shadow-sm); }
.gal-item img{ width:100%; height:100%; object-fit:cover; transition: transform 1.2s ease, filter .6s; }
.gal-item::after{
  content:''; position:absolute; inset:0; background: linear-gradient(180deg, transparent 60%, rgba(20,22,27,.6));
  opacity:0; transition: opacity .5s;
}
.gal-item:hover img{ transform: scale(1.08); }
.gal-item:hover::after{ opacity:1; }
.gal-item .cap{
  position:absolute; left:1rem; bottom:1rem; z-index:2; color: var(--cream);
  font-family: var(--f-display); font-style: italic; opacity:0; transform: translateY(10px); transition: .4s;
}
.gal-item:hover .cap{ opacity:1; transform: translateY(0); }
.gal-item.span-2{ grid-column: span 2; }
.gal-item.row-2{ grid-row: span 2; }
.gal-item.span-3{ grid-column: span 3; }

/* ---------- Testimonials ---------- */
.testi{
  background: var(--charcoal); color: var(--cream);
  position:relative; overflow:hidden;
}
.testi::before{
  content:''; position:absolute; inset:0;
  background: radial-gradient(ellipse at 20% 10%, rgba(212,175,55,.18), transparent 55%),
              radial-gradient(ellipse at 90% 90%, rgba(228,180,190,.14), transparent 55%);
}
.testi .section-head h2, .testi .eyebrow, .testi h3{ color: var(--cream);}
.testi .eyebrow{ color: var(--gold-soft); }
.testi .section-head p{ color: rgba(253,251,247,.7); }
.testi-grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; position:relative; }
.testi-card{
  padding: 2.4rem 2rem; border-radius: var(--radius);
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(10px);
  transition: transform .6s, border-color .5s, background .5s;
}
.testi-card:hover{ transform: translateY(-6px); border-color: rgba(212,175,55,.5); background: rgba(255,255,255,.06); }
.testi-card .quote{
  font-family: var(--f-serif); font-style: italic; font-size: 1.15rem; line-height:1.6; color: var(--cream); margin-bottom: 1.6rem;
}
.testi-card .stars{ color: var(--gold-soft); letter-spacing:.15em; margin-bottom: 1rem; }
.testi-card .who{ display:flex; align-items:center; gap:.9rem; }
.testi-card .who .avatar{
  width:44px; height:44px; border-radius:50%; background: var(--grad-rose); display:flex; align-items:center; justify-content:center;
  font-family: var(--f-display); color: var(--charcoal-2); font-size:1.1rem;
}
.testi-card .who small{ display:block; color: rgba(253,251,247,.6); font-size:.75rem; letter-spacing:.2em; text-transform:uppercase; }

/* ---------- CTA ---------- */
.cta{
  position:relative; overflow:hidden; border-radius: var(--radius-lg);
  padding: clamp(3rem, 6vw, 5rem);
  background: var(--grad-rose);
  text-align:center;
  box-shadow: var(--shadow-lg);
}
.cta::before{
  content:''; position:absolute; inset:0;
  background: radial-gradient(circle at 20% 30%, rgba(255,255,255,.5), transparent 40%),
              radial-gradient(circle at 80% 80%, rgba(212,175,55,.25), transparent 45%);
  pointer-events:none;
}
.cta h2{ position:relative; }
.cta .lead{ margin: 1.2rem auto 2rem; color: rgba(44,62,80,.75); position:relative; }
.cta .btns{ display:flex; gap:.9rem; justify-content:center; flex-wrap:wrap; position:relative; }

/* ---------- Contact ---------- */
.contact-grid{ display:grid; grid-template-columns: 1.1fr 1fr; gap: 2rem; }
.contact-card{
  padding: clamp(2rem, 4vw, 3rem); border-radius: var(--radius-lg);
  background: var(--white); box-shadow: var(--shadow-md);
}
.contact-info{
  padding: clamp(2rem, 4vw, 3rem); border-radius: var(--radius-lg);
  background: var(--charcoal); color: var(--cream); position:relative; overflow:hidden;
}
.contact-info::before{
  content:''; position:absolute; inset:0;
  background: radial-gradient(circle at 100% 0%, rgba(212,175,55,.2), transparent 45%);
}
.contact-info h3{ color: var(--cream); }
.info-row{ display:flex; gap: 1rem; margin: 1.4rem 0; align-items:flex-start; position:relative; }
.info-row .ic{ width: 42px; height: 42px; border-radius:50%; background: rgba(212,175,55,.15); color: var(--gold-soft); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.info-row .ic svg{ width:18px; height:18px;}
.info-row small{ display:block; color: rgba(253,251,247,.6); font-size:.7rem; letter-spacing:.3em; text-transform:uppercase; margin-bottom:.25rem;}
.info-row a, .info-row p{ color: var(--cream); font-size:1.02rem; }

.field{ display:flex; flex-direction:column; gap:.4rem; margin-bottom: 1.2rem; }
.field label{ font-size:.72rem; letter-spacing:.28em; text-transform:uppercase; color: rgba(44,62,80,.7); font-weight:600; }
.field input, .field select, .field textarea{
  padding: .95rem 1.1rem; border:1px solid rgba(44,62,80,.15); background: var(--cream);
  border-radius: 12px; font: inherit; color: var(--charcoal); transition: border .3s, box-shadow .3s;
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color: var(--gold); box-shadow: 0 0 0 4px rgba(212,175,55,.15);
}
.field textarea{ resize:vertical; min-height: 130px; }
.field-row{ display:grid; grid-template-columns: 1fr 1fr; gap: 1rem; }

.socials{ display:flex; gap:.6rem; margin-top: 1.5rem; }
.socials a{
  width:42px; height:42px; border-radius:50%; background: rgba(212,175,55,.15); color: var(--gold-soft);
  display:flex; align-items:center; justify-content:center; transition: transform .4s, background .4s, color .4s;
}
.socials a:hover{ transform: translateY(-3px) rotate(-6deg); background: var(--gold); color: var(--charcoal); }
.socials svg{ width:18px; height:18px;}

/* ---------- Footer ---------- */
.footer{ background: var(--charcoal-2); color: rgba(253,251,247,.75); padding: 4.5rem clamp(1.25rem, 5vw, 4rem) 2rem; position:relative; }
.footer::before{
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
}
.footer-grid{ display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 2.5rem; max-width: 1240px; margin: 0 auto; }
.footer h4{ color: var(--gold-soft); font-family: var(--f-body); font-size:.8rem; letter-spacing:.3em; text-transform:uppercase; margin-bottom: 1.2rem; font-weight:600; }
.footer p, .footer a{ font-size:.92rem; line-height:1.9; }
.footer a{ color: rgba(253,251,247,.75); transition: color .3s; }
.footer a:hover{ color: var(--gold-soft); }
.footer ul{ list-style:none; }
.footer .brand-name{ color: var(--cream); }
.footer-bottom{
  max-width: 1240px; margin: 3rem auto 0; padding-top: 1.5rem;
  border-top: 1px solid rgba(255,255,255,.08);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem;
  font-size:.8rem; color: rgba(253,251,247,.5); letter-spacing:.05em;
}

/* ---------- Floating WA ---------- */
.wa-float{
  position:fixed; right: 1.25rem; bottom: 1.25rem; z-index: 80;
  width: 58px; height: 58px; border-radius:50%;
  background: #25D366; color:#fff;
  display:flex; align-items:center; justify-content:center;
  box-shadow: 0 12px 30px -8px rgba(37,211,102,.6);
  animation: waPulse 2.2s ease-in-out infinite;
  transition: transform .3s;
}
.wa-float:hover{ transform: scale(1.08) rotate(-8deg); }
.wa-float svg{ width:28px; height:28px; }
@keyframes waPulse {
  0%,100% { box-shadow: 0 12px 30px -8px rgba(37,211,102,.6), 0 0 0 0 rgba(37,211,102,.5);}
  50% { box-shadow: 0 12px 30px -8px rgba(37,211,102,.6), 0 0 0 18px rgba(37,211,102,0);}
}

/* ---------- Reveal on scroll ---------- */
.reveal{ opacity:0; transform: translateY(40px); transition: opacity 1s ease, transform 1s cubic-bezier(.2,.8,.2,1); }
.reveal.in{ opacity:1; transform: translateY(0); }
.reveal.delay-1{ transition-delay: .1s; }
.reveal.delay-2{ transition-delay: .2s; }
.reveal.delay-3{ transition-delay: .3s; }
.reveal.delay-4{ transition-delay: .4s; }

/* ---------- Ornaments ---------- */
.ornament{
  display:flex; align-items:center; justify-content:center; gap:1rem; margin: 1rem auto;
  color: var(--gold); font-size:1.2rem;
}
.ornament::before, .ornament::after{ content:''; width:60px; height:1px; background: linear-gradient(90deg, transparent, var(--gold), transparent); }

/* ---------- Responsive ---------- */
@media (max-width: 1080px){
  .svc-grid{ grid-template-columns: repeat(2, 1fr); }
  .steps{ grid-template-columns: repeat(2, 1fr); }
  .testi-grid{ grid-template-columns: 1fr; }
  .split{ grid-template-columns: 1fr; }
  .contact-grid{ grid-template-columns: 1fr; }
  .footer-grid{ grid-template-columns: 1fr 1fr; }
  .gal-grid{ grid-template-columns: repeat(3, 1fr); }
  .gal-item.span-3{ grid-column: span 3; }
  .gal-item.span-2{ grid-column: span 2; }
}
@media (max-width: 720px){
  .nav-links, .nav > .btn { display:none; }
  .burger{ display:flex; }
  h1{ font-size: 2.7rem; }
  .split-media .badge{ width: 130px; height: 130px; font-size:.85rem; right: -10px; bottom: -20px;}
  .split-body .stats{ gap: 1.5rem; flex-wrap:wrap;}
  .stat b{ font-size:1.8rem;}
  .gal-grid{ grid-template-columns: repeat(2, 1fr); grid-auto-rows: 140px; }
  .gal-item.span-2, .gal-item.span-3{ grid-column: span 2; }
  .footer-grid{ grid-template-columns: 1fr; gap: 2rem; }
  .field-row{ grid-template-columns: 1fr; }
  .hero-meta{ display:none; }
  .menu-item{ flex-wrap:wrap; gap:.4rem; }
  .menu-item .dots{ display:none; }
  .menu-item .price{ margin-left:auto; }
}

@media (prefers-reduced-motion: reduce){
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
  .hero-media img{ transform: none; }
}

/* mobile refinements */
@media (max-width: 720px){
  .brand-name{ font-size: .95rem; letter-spacing: .12em; white-space: nowrap; }
  .brand-name em{ display:none; }
  .brand-logo{ width: 42px; height: 42px; }
  .scroll-indicator{ display:none; }
  .hero-actions .btn{ width:100%; justify-content:center; }
  .hero{ min-height: 92svh; }
}
