.elementor-103 .elementor-element.elementor-element-90c64d7{--display:grid;--e-con-grid-template-columns:repeat(1, 1fr);--e-con-grid-template-rows:repeat(1, 1fr);--grid-auto-flow:row;}@media(max-width:1024px){.elementor-103 .elementor-element.elementor-element-90c64d7{--grid-auto-flow:row;}}@media(max-width:767px){.elementor-103 .elementor-element.elementor-element-90c64d7{--e-con-grid-template-columns:repeat(1, 1fr);--e-con-grid-template-rows:repeat(1, 1fr);--grid-auto-flow:row;}}/* Start custom CSS for html, class: .elementor-element-0d5f3bb */:root {
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-ui:      'Montserrat', sans-serif;
  --black:   #080808;
  --white:   #fdf8f3;
  --cream:   #fafaf8;
  --cream-dk:#f3f0eb;
  --gold:    #a98435;
  --gold-lt:#75695b;
  --pink:    #e8b4c4;
  --pink-lt: #fce8ef;
  --pink-dk: #c47a96;
  --taupe:   #75695b;
  --dark:    #0a0a0a;
}
 
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  background:var(--cream);
  color:var(--black);
  font-family:var(--font-display);
  font-size:18px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
 
/* ── ANIMATIONS ── */
@keyframes fadeUp    { from { opacity:0; transform:translateY(36px); } to { opacity:1; transform:translateY(0); } }
@keyframes fadeIn    { from { opacity:0; } to { opacity:1; } }
@keyframes lineGrow  { from { transform:scaleX(0); } to { transform:scaleX(1); } }
@keyframes floatY    { 0%,100%{transform:translateY(0);} 50%{transform:translateY(-14px);} }
@keyframes floatYR   { 0%,100%{transform:translateY(0) scaleX(-1);} 50%{transform:translateY(-14px) scaleX(-1);} }
@keyframes rotate    { from{transform:rotate(0deg);} to{transform:rotate(360deg);} }
 
.reveal {
  opacity:0; transform:translateY(30px);
  transition:opacity 1s cubic-bezier(.16,.7,.3,1), transform 1s cubic-bezier(.16,.7,.3,1);
}
.reveal.visible { opacity:1; transform:translateY(0); }
.d1{transition-delay:.1s;} .d2{transition-delay:.2s;} .d3{transition-delay:.3s;} .d4{transition-delay:.4s;} .d5{transition-delay:.5s;}
 
/* ── LABEL ── */
.label {
  display:inline-flex; align-items:center; gap:.75rem;
  font-family:var(--font-ui);
  font-size:clamp(.75rem,3.5rem,.84rem);
  font-weight:500; letter-spacing:.26em; text-transform:uppercase;
  color:var(--gold); margin-bottom:1.2rem;
}
.label::before,.label::after { content:''; height:1px; background:currentColor; flex-shrink:0; }
.label::before { width:2rem; transform-origin:left; animation:lineGrow .8s ease forwards; }
.label::after  { width:.5rem; opacity:.35; }
.label-lt { color:var(--gold-lt); }
.label-lt::before,.label-lt::after { background:var(--gold-lt); }
 
/* ── BUTTONS ── */
.btn {
  display:inline-block;
  font-family:var(--font-ui); font-size:.63rem; font-weight:500;
  letter-spacing:.2em; text-transform:uppercase; text-decoration:none;
  padding:1rem 2.4rem; border:1px solid currentColor;
  transition:background .3s,color .3s,border-color .3s,transform .2s;
  cursor:pointer;
}
.btn:hover { transform:translateY(-2px); }
.btn-dark  { background:var(--dark);  color:var(--white); border-color:var(--dark); }
.btn-dark:hover  { background:var(--gold); border-color:var(--gold); }
.btn-gold  { background:var(--gold);  color:var(--white); border-color:var(--gold); }
.btn-gold:hover  { background:  #fce8ef!important; border-color:var(--dark); color: black!important;}
.btn-ghost { background:transparent; color:var(--white); border-color:rgba(253,248,243,.38); }
.btn-ghost:hover { border-color:#fce8ef; 
    color: #fce8ef;
}
 
/* ── DIAMOND DIVIDER ── */
.gem-divider {
  display:flex; align-items:center; gap:1rem;
  width:140px; margin:1.8rem auto 0;
}
.gem-divider::before,.gem-divider::after {
  content:''; flex:1; height:1px; background:var(--gold); opacity:.28;
}
.gem { width:6px; height:6px; background:var(--gold); transform:rotate(45deg); opacity:.55; flex-shrink:0; }
 

 
/* ════════════════
   HERO
════════════════ */
.hero {
  min-height:65vh;
  background:var(--dark);
  display:flex; align-items:flex-end;
  position:relative; overflow:hidden;
}
.hero-bg {
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover; object-position:center 30%;
  opacity:.1; animation:fadeIn 1.8s ease forwards;
  margin-top:-5%;
  
}
.hero-overlay {
  position:absolute; inset:0;
  background: linear-gradient(155deg,rgba(8,8,8,.85) 0%,rgba(26,20,16,.78) 45%,rgba(8,8,8,.95) 100%);
  z-index:1;
}
.hero-overlay::after {
  content:''; position:absolute; bottom:0; left:0; right:0;
  height:52%; background:linear-gradient(to top, rgba(8,8,8,1) 0%, transparent 100%);
}
.hero-floral-tr {
  position:absolute; top:-60px; right:-50px;
  width:clamp(280px,32vw,440px); opacity:.11; z-index:2; pointer-events:none;
  animation:floatY 9s ease-in-out infinite;
}
.hero-floral-bl {
  position:absolute; bottom:-50px; left:-30px;
  width:clamp(180px,20vw,280px); opacity:.07; z-index:2; pointer-events:none;
  animation:floatY 13s ease-in-out infinite reverse;
}
.hero-content {
  position:relative; z-index:3;
  width:100%; max-width:1200px; margin:0 auto;
  padding:0 3rem 6rem;
}
.hero-content h1 {
  font-family:var(--font-display);
  font-size:clamp(4.5rem,10vw,9rem);
  font-weight:300; color:var(--white);
  line-height:.95; letter-spacing:-.02em;
  margin-bottom:1.6rem;
  animation:fadeUp 1.2s .15s ease both;
}
.hero-content h1 em { font-style:italic; color:var(--pink); }
.hero-tagline {
  font-family:var(--font-ui); font-size:clamp(.57rem,.95vw,.67rem);
  letter-spacing:.28em; text-transform:uppercase;
  color:rgba(253,248,243,.38); margin-bottom:3rem;
  animation:fadeUp 1.2s .3s ease both;
}
.hero-pills {
  display:flex; flex-wrap:wrap; gap:.6rem;
  animation:fadeUp 1.2s .45s ease both;
}
.hero-pill {
  font-family:var(--font-ui); font-size:.55rem; font-weight:500;
  letter-spacing:.16em; text-transform:uppercase;
  color:rgba(253,248,243,.55); border:1px solid rgba(253,248,243,.15);
  padding:.48rem 1rem; text-decoration:none;
  transition:color .25s, border-color .25s;
}
.hero-pill:hover { color:var(--gold-lt); border-color:rgba(184,150,78,.4); }
 
/* ════════════════
   SECTION SHELL
════════════════ */
.section {
  padding:9rem 4rem;
  position:relative; overflow:hidden;
}
.section--cream  { background:var(--cream); }
.section--creamdk{ background:var(--cream-dk); }
.section--white  { background:var(--white); }
.section--dark   { background:var(--dark); }
 
.section--dark::before,
.section--rule::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(to right, transparent, var(--gold), transparent);
}
.section--rule::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:1px;
  background:linear-gradient(to right, transparent, rgba(184,150,78,.2), transparent);
}
 
/* ambient florals */
.f-tr { position:absolute; top:-70px; right:-55px; width:clamp(200px,23vw,340px); opacity:.055; pointer-events:none; animation:floatY 11s ease-in-out infinite; }
.f-tl { position:absolute; top:-70px; left:-55px;  width:clamp(160px,18vw,260px); opacity:.045; pointer-events:none; animation:floatY 13s ease-in-out infinite reverse; }
.f-br { position:absolute; bottom:-70px; right:-55px; width:clamp(180px,20vw,280px); opacity:.045; pointer-events:none; animation:floatY 10s ease-in-out infinite; }
.f-bl { position:absolute; bottom:-70px; left:-55px;  width:clamp(160px,18vw,260px); opacity:.055; pointer-events:none; animation:floatY 12s ease-in-out infinite reverse; }
.f-c  { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:clamp(420px,58vw,740px); opacity:.025; pointer-events:none; animation:rotate 110s linear infinite; }
 
.inner { max-width:1140px; margin:0 auto; position:relative; z-index:1; }
 
/* ── Section header ── */
.sec-hd { text-align:center; margin-bottom:6rem; }
.sec-hd h2 {
  font-family:var(--font-display);
  font-size:clamp(2.8rem,5.5vw,4.4rem);
  font-weight:300; line-height:1.05; margin-bottom:.6rem;
}
.sec-hd h2 em { font-style:italic; color:var(--gold); }
.sec-hd--lt h2 { color:var(--white); }
.sec-hd--lt h2 em { color:var(--pink); }
.sec-hd .sub {
  font-family:var(--font-ui); font-size:.62rem;
  letter-spacing:.22em; text-transform:uppercase; color:var(--taupe);
  margin-top:.5rem;
}
.sec-hd--lt .sub { color:rgba(253,248,243,.35); }
 
/* ════════════════════════════
   HAIR — editorial split
════════════════════════════ */
.hair-split {
  display:grid;
  grid-template-columns:1fr 1px 1fr;
  gap:0 4rem;
  align-items:start;
}
.hair-divider-line {
  background:rgba(184,150,78,.2);
  align-self:stretch;
}
.hair-col-label {
  font-family:var(--font-ui); font-size:.78rem; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--taupe); margin-bottom:2.5rem;
  padding-bottom:1.2rem; border-bottom:1px solid rgba(0,0,0,.07);
}
.hair-item {
  display:flex; align-items:baseline; justify-content:space-between;
  gap:1.5rem; padding:1.1rem 0;
  border-bottom:1px solid rgba(0,0,0,.05);
}
.hair-item:last-child { border-bottom:none; }
.hair-item-name {
  font-family:var(--font-display);
  font-size:clamp(1rem,1.6vw,1.18rem);
  color:var(--dark); line-height:1.4;
}
.hair-item-desc {
  font-size:.9rem; font-style:italic; color:var(--taupe);
  margin-top:.2rem; display:block;
}
.hair-item-price {
  font-family:var(--font-ui); font-size:.72rem; font-weight:600;
  letter-spacing:.08em; color:var(--gold);
  white-space:nowrap; flex-shrink:0;
}
 
/* ════════════════════════════
   FACIAL — large hero cards
════════════════════════════ */
.facial-intro {
  display:grid; grid-template-columns:1fr 2fr; gap:5rem;
  align-items:center; margin-bottom:6rem;
}
.facial-intro-text h3 {
  font-family:var(--font-display);
  font-size:clamp(1.8rem,3vw,2.6rem);
  font-weight:300; line-height:1.15; margin-bottom:1.2rem;
}
.facial-intro-text h3 em { font-style:italic; color:var(--gold); }
.facial-intro-text p {
  font-size:clamp(.95rem,1.5vw,1.08rem);
  color:#555; line-height:1.9; margin-bottom:1rem;
}
.facial-intro-stat {
  margin-top:2rem; display:flex; gap:2.5rem;
}
.facial-stat-num {
  font-family:var(--font-display);
  font-size:clamp(2.4rem,4vw,3.2rem);
  font-weight:300; color:var(--gold); line-height:1;
}
.facial-stat-label {
  font-family:var(--font-ui); font-size:.58rem;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--taupe); margin-top:.3rem;
}
 
/* Facial service rows — generous breathing room */
.facial-services { display:flex; flex-direction:column; gap:0; }
.facial-service-row {
  display:grid; grid-template-columns:1fr auto;
  gap:2rem; align-items:start;
  padding:3.2rem 0;
  border-bottom:1px solid rgba(0,0,0,.07);
  position:relative;
}
.facial-service-row:first-child { border-top:1px solid rgba(0,0,0,.07); }
.facial-service-row::before {
  content:'';
  position:absolute; left:0; bottom:-1px;
  width:0; height:1px; background:var(--gold);
  transition:width .5s ease;
}
.facial-service-row:hover::before { width:100%; }
.facial-service-name {
  font-family:var(--font-display);
  font-size:clamp(1.3rem,2.2vw,1.7rem);
  font-weight:400; color:var(--dark);
  margin-bottom:.6rem;
}
.facial-service-desc {
  font-size:clamp(.95rem,1.5vw,1.08rem);
  color:#666; line-height:1.85;
  max-width:640px;
}
.facial-service-price {
  font-family:var(--font-display);
  font-size:clamp(1.8rem,2.8vw,2.4rem);
  font-weight:300; color:var(--gold);
  white-space:nowrap; padding-top:.4rem;
}
 
/* ════════════════════════════
   NAILS — dark, grid
════════════════════════════ */
.nails-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:2px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(184,150,78,.12);
}
.nails-panel {
  padding:4rem 3.5rem;
  background:rgba(253,248,243,.03);
}
.nails-panel-label {
  font-family:var(--font-ui); font-size:.58rem; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold-lt); margin-bottom:2.5rem;
  padding-bottom:1.2rem;
  border-bottom:1px solid rgba(184,150,78,.18);
}
.nail-item {
  display:flex; align-items:baseline; justify-content:space-between;
  gap:1.5rem; padding:1rem 0;
  border-bottom:1px solid rgba(255,255,255,.04);
}
.nail-item:last-child { border-bottom:none; }
.nail-item-name {
  font-family:var(--font-display);
  font-size:clamp(1rem,1.6vw,1.15rem);
  color:rgba(253,248,243,.78);
}
.nail-item-price {
  font-family:var(--font-ui); font-size:.7rem; font-weight:600;
  letter-spacing:.08em; color:var(--gold); white-space:nowrap;
}
 
/* ════════════════════════════
   BEAUTY — waxing, lashes, perm
   Generous editorial layout
════════════════════════════ */
.beauty-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:3rem;
}
.beauty-col {
  padding:4rem 3rem;
  border:1px solid rgba(0,0,0,.07);
  background:var(--white);
  position:relative;
  transition:box-shadow .3s, border-color .3s;
}
.beauty-col:hover {
  box-shadow:0 16px 48px rgba(0,0,0,.06);
  border-color:rgba(184,150,78,.25);
}
/* corner marks */
.beauty-col::before {
  content:''; position:absolute; top:0; left:0;
  width:24px; height:24px;
  border-top:1px solid rgba(184,150,78,.4);
  border-left:1px solid rgba(184,150,78,.4);
}
.beauty-col::after {
  content:''; position:absolute; bottom:0; right:0;
  width:24px; height:24px;
  border-bottom:1px solid rgba(184,150,78,.4);
  border-right:1px solid rgba(184,150,78,.4);
}
.beauty-col-icon {
  width:52px; height:52px;
  border:1px solid rgba(184,150,78,.32);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:2rem;
  transition:border-color .3s;
}
.beauty-col:hover .beauty-col-icon { border-color:var(--gold); }
.beauty-col-icon svg { width:22px; height:22px; stroke:var(--gold); fill:none; stroke-width:1.35; stroke-linecap:round; stroke-linejoin:round; }
.beauty-col-title {
  font-family:var(--font-display);
  font-size:clamp(1.5rem,2.2vw,2rem);
  font-weight:300; color:var(--dark);
  margin-bottom:2.5rem; line-height:1.1;
}
.beauty-col-title em { font-style:italic; color:var(--gold); }
.beauty-item {
  display:flex; align-items:baseline; justify-content:space-between;
  gap:1.5rem; padding:1.4rem 0;
  border-bottom:1px solid rgba(0,0,0,.06);
}
.beauty-item:first-of-type { border-top:1px solid rgba(0,0,0,.06); }
.beauty-item:last-of-type { border-bottom:none; }
.beauty-item-name {
  font-family:var(--font-display);
  font-size:clamp(1.05rem,1.7vw,1.25rem);
  color:var(--dark); line-height:1.4;
}
.beauty-item-price {
  font-family:var(--font-ui); font-size:.72rem; font-weight:600;
  letter-spacing:.08em; color:var(--gold); white-space:nowrap; flex-shrink:0;
}
.beauty-col-note {
  margin-top:2rem; padding-top:1.5rem;
  border-top:1px solid rgba(0,0,0,.06);
  font-size:clamp(.88rem,1.3vw,.98rem);
  font-style:italic; color:var(--taupe); line-height:1.8;
}
.beauty-col-note strong {
  display:block; font-family:var(--font-ui);
  font-size:.58rem; font-style:normal;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--gold); margin-bottom:.5rem; font-weight:600;
}
 
/* ════════════════════════════
   TEETH WHITENING
════════════════════════════ */
.teeth-wrap {
  display:grid; grid-template-columns:1fr 1fr;
  gap:6rem; align-items:center;
}
.teeth-text h2 {
  font-family:var(--font-display);
  font-size:clamp(2.8rem,5vw,4rem);
  font-weight:300; line-height:1; margin-bottom:1.5rem;
}
.teeth-text h2 em { font-style:italic; color:var(--gold); }
.teeth-text p {
  font-size:clamp(1rem,1.6vw,1.15rem);
  color:#555; line-height:1.9; margin-bottom:2.5rem;
}
.teeth-price-block {
  display:flex; align-items:baseline; gap:1rem; margin-bottom:2.5rem;
}
.teeth-price {
  font-family:var(--font-display);
  font-size:clamp(3rem,5vw,4.5rem);
  font-weight:300; color:var(--gold); line-height:1;
}
.teeth-price-label {
  font-family:var(--font-ui); font-size:.62rem;
  letter-spacing:.18em; text-transform:uppercase; color:var(--taupe);
}
.teeth-features {
  border:1px solid rgba(0,0,0,.07);
  padding:3rem;
  position:relative; background:var(--white);
}
.teeth-features::before {
  content:''; position:absolute; top:0; left:0;
  width:22px; height:22px;
  border-top:1px solid rgba(184,150,78,.4);
  border-left:1px solid rgba(184,150,78,.4);
}
.teeth-features::after {
  content:''; position:absolute; bottom:0; right:0;
  width:22px; height:22px;
  border-bottom:1px solid rgba(184,150,78,.4);
  border-right:1px solid rgba(184,150,78,.4);
}
.teeth-feature {
  display:flex; gap:1.2rem; align-items:flex-start;
  padding:1.1rem 0; border-bottom:1px solid rgba(0,0,0,.05);
}
.teeth-feature:last-child { border-bottom:none; }
.teeth-feature-gem {
  color:var(--gold); font-size:.7rem; flex-shrink:0; margin-top:.25rem;
}
.teeth-feature-text {
  font-size:clamp(.95rem,1.5vw,1.08rem); color:var(--dark); line-height:1.6;
}
 
/* ════════════════════════════
   MASSAGE
════════════════════════════ */
.massage-grid {
  display:grid; grid-template-columns:repeat(2,1fr); gap:1.8rem;
}
.massage-card {
  padding:3rem 2.8rem;
  border:1px solid rgba(184,150,78,.12);
  background:rgba(253,248,243,.03);
  position:relative; overflow:hidden;
  transition:background .35s, border-color .35s, transform .3s;
}
.massage-card:hover {
  background:rgba(253,248,243,.07);
  border-color:rgba(184,150,78,.35);
  transform:translateY(-4px);
}
.massage-card::before {
  content:''; position:absolute; top:0; left:0;
  width:22px; height:22px;
  border-top:1px solid rgba(184,150,78,.4);
  border-left:1px solid rgba(184,150,78,.4);
}
.massage-card-name {
  font-family:var(--font-display);
  font-size:clamp(1.2rem,2vw,1.5rem);
  font-weight:400; color:var(--white); margin-bottom:.4rem;
}
.massage-card-duration {
  font-family:var(--font-ui); font-size:.57rem;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--gold-lt); margin-bottom:1.1rem;
}
.massage-card-desc {
  font-size:clamp(.9rem,1.4vw,1.02rem);
  color:rgba(253,248,243,.5); line-height:1.8; margin-bottom:1.4rem;
}
.massage-card-price {
  font-family:var(--font-display);
  font-size:clamp(1.6rem,2.5vw,2rem);
  font-weight:300; color:var(--gold); line-height:1;
}
 
/* ════════════════════════════
   WELLNESS
════════════════════════════ */
.wellness-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:2rem;
}
.wellness-card {
  padding:3.5rem 2.8rem;
  border:1px solid rgba(0,0,0,.07);
  background:var(--white);
  position:relative;
  transition:transform .3s, box-shadow .3s, border-color .3s;
}
.wellness-card:hover {
  transform:translateY(-4px);
  box-shadow:0 14px 40px rgba(0,0,0,.06);
  border-color:rgba(184,150,78,.28);
}
.wellness-card::before {
  content:''; position:absolute; top:0; left:0;
  width:20px; height:20px;
  border-top:1px solid rgba(184,150,78,.38); border-left:1px solid rgba(184,150,78,.38);
}
.wellness-card-label {
  font-family:var(--font-ui); font-size:.57rem; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--taupe); margin-bottom:.8rem;
}
.wellness-card-title {
  font-family:var(--font-display);
  font-size:clamp(1.3rem,2vw,1.65rem);
  font-weight:300; color:var(--dark); margin-bottom:2rem; line-height:1.1;
}
.wellness-item {
  display:flex; align-items:baseline; justify-content:space-between;
  gap:1rem; padding:.85rem 0; border-bottom:1px solid rgba(0,0,0,.05);
}
.wellness-item:last-child { border-bottom:none; }
.wellness-item-name { font-family:var(--font-display); font-size:clamp(.95rem,1.5vw,1.08rem); color:var(--dark); }
.wellness-item-price { font-family:var(--font-ui); font-size:.68rem; font-weight:600; letter-spacing:.06em; color:var(--gold); white-space:nowrap; flex-shrink:0; }
.wellness-note { font-size:.88rem; font-style:italic; color:var(--taupe); margin-top:.8rem; }
 
/* ════════════════════════════
   POLICIES
════════════════════════════ */
.policies-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:2rem;
  max-width:1100px; margin:0 auto;
}
.policy-card {
  padding:3.5rem 2.8rem;
  border:1px solid rgba(184,150,78,.13);
  background:rgba(253,248,243,.03);
  position:relative;
  transition:border-color .3s;
}
.policy-card:hover { border-color:rgba(184,150,78,.35); }
.policy-card::before {
  content:''; position:absolute; top:0; left:0;
  width:18px; height:18px;
  border-top:1px solid rgba(184,150,78,.42); border-left:1px solid rgba(184,150,78,.42);
}
.policy-title {
  font-family:var(--font-ui); font-size:.62rem; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold-lt); margin-bottom:1.2rem;
}
.policy-body {
  font-family:var(--font-display);
  font-size:clamp(.95rem,1.5vw,1.08rem);
  color:rgba(253,248,243,.58); line-height:1.85;
}
 
/* ════════════════════════════
   TEAM
════════════════════════════ */
.team-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(185px,1fr));
  gap:1.6rem;
}
.team-card {
  text-align:center; padding:2.8rem 1.6rem;
  border:1px solid rgba(0,0,0,.06);
  background:var(--white); position:relative;
  transition:border-color .3s, transform .3s;
}
.team-card:hover { border-color:rgba(184,150,78,.28); transform:translateY(-3px); }
.team-card::before {
  content:''; position:absolute; top:0; left:0;
  width:14px; height:14px;
  border-top:1px solid rgba(184,150,78,.3); border-left:1px solid rgba(184,150,78,.3);
}
.team-card::after {
  content:''; position:absolute; bottom:0; right:0;
  width:14px; height:14px;
  border-bottom:1px solid rgba(184,150,78,.3); border-right:1px solid rgba(184,150,78,.3);
}
.team-initial {
  width:54px; height:54px; border-radius:50%;
  background:var(--pink-lt); border:1px solid rgba(196,122,150,.2);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-style:italic;
  font-size:1.4rem; color:var(--pink-dk);
  margin:0 auto 1.2rem;
}
.team-name { font-family:var(--font-display); font-size:1.1rem; color:var(--dark); margin-bottom:.3rem; }
.team-role { font-family:var(--font-ui); font-size:.57rem; letter-spacing:.14em; text-transform:uppercase; color:var(--taupe); }
.team-note { font-family:var(--font-display); font-size:.92rem; font-style:italic; color:var(--pink-dk); margin-top:.5rem; line-height:1.5; }
 
/* ════════════════════════════
   PAGE CTA
════════════════════════════ */
.page-cta {
  background:var(--dark);
  padding:7rem 3rem;
  text-align:center; position:relative; overflow:hidden;
}
.page-cta::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(to right, transparent, var(--gold), transparent);
}
.cta-fl { position:absolute; top:50%; transform:translateY(-50%); width:clamp(130px,15vw,210px); opacity:.065; pointer-events:none; }
.cta-fl-l { left:-35px; animation:floatY 9s ease-in-out infinite; }
.cta-fl-r { right:-35px; animation:floatY 11s ease-in-out infinite reverse; transform:translateY(-50%) scaleX(-1); }
.page-cta-inner { position:relative; z-index:1; }
.page-cta h2 {
  font-family:var(--font-display);
  font-size:clamp(2.8rem,6vw,5rem);
  font-weight:300; color:var(--white); line-height:1.0; margin-bottom:1.2rem;
}
.page-cta h2 em { font-style:italic; color:var(--pink); }
.page-cta p { color:rgba(253,248,243,.48); font-size:clamp(.95rem,1.5vw,1.1rem); margin-bottom:3rem; }
.cta-actions { display:flex; justify-content:center; gap:1.2rem; flex-wrap:wrap; }
 
/* ════════════════════════════
   FOOTER
════════════════════════════ */
.footer { background:var(--black); padding:5rem 3rem 2.5rem; text-align:center; }
.footer-logo { font-family:var(--font-display); font-size:2.4rem; font-style:italic; color:var(--white); margin-bottom:.4rem; }
.footer-logo em { color:var(--gold); font-style:normal; }
.footer-tagline { font-family:var(--font-ui); font-size:.58rem; letter-spacing:.3em; text-transform:uppercase; color:var(--taupe); margin-bottom:3rem; }
.footer-nav { display:flex; justify-content:center; gap:2.5rem; flex-wrap:wrap; margin-bottom:3rem; }
.footer-nav a { font-family:var(--font-ui); font-size:.6rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(253,248,243,.42); text-decoration:none; transition:color .2s; }
.footer-nav a:hover { color:var(--gold); }
.footer-rule { display:flex; align-items:center; gap:1rem; max-width:160px; margin:0 auto 2.5rem; }
.footer-rule::before,.footer-rule::after { content:''; flex:1; height:1px; background:rgba(255,255,255,.07); }
.footer-dot { width:4px; height:4px; border-radius:50%; background:rgba(184,150,78,.4); flex-shrink:0; }
.footer-copy { font-family:var(--font-ui); font-size:.57rem; letter-spacing:.1em; color:rgba(253,248,243,.22); }
 
/* ════════════════════════════
   RESPONSIVE
════════════════════════════ */
@media(max-width:1060px){
  .hair-split { grid-template-columns:1fr; gap:3rem; }
  .hair-divider-line { display:none; }
  .facial-intro { grid-template-columns:1fr; gap:2.5rem; }
  .beauty-grid { grid-template-columns:1fr; gap:2rem; }
  .nails-grid { grid-template-columns:1fr; }
  .waxing-lashes-grid { grid-template-columns:1fr !important; }
  .perm-makeup-grid { grid-template-columns:1fr !important; gap:3rem !important; }
  .wellness-grid { grid-template-columns:1fr 1fr; }
  .massage-grid { grid-template-columns:1fr; }
  .teeth-wrap { grid-template-columns:1fr; gap:3rem; }
  .policies-grid { grid-template-columns:1fr 1fr; }
}
@media(max-width:700px){

  .hero { min-height:82vh; }
  .hero-content { padding:0 1.5rem 4rem; }
  .section { padding:6rem 1.5rem; }
  .nails-panel { padding:2.5rem 1.8rem; }
  .wellness-grid,.policies-grid { grid-template-columns:1fr; }
  .team-grid { grid-template-columns:1fr 1fr; }
  .massage-grid { grid-template-columns:1fr; }
}

</style>/* End custom CSS */