/* ============================================================
   BROWS BY HANNAH — COMPLETE STYLESHEET
   brows-by-hannah.com | Fort Worth, TX
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;0,700;1,300;1,400&family=Jost:wght@200;300;400;500;600&display=swap');

/* ---- VARIABLES ---- */
:root {
  --black:    #faf7f4;
  --black2:   #f4f0eb;
  --black3:   #ede8e2;
  --black4:   #e5dfd8;
  --white:    #2a2118;
  --white2:   #5c4f42;
  --white3:   #8a7a6e;
  --gold:     #9a6e48;
  --gold2:    #b8966e;
  --gold3:    #c4a898;
  --rose:     #c4a898;
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body:    'Jost', sans-serif;
  --max-w: 1280px;
  --pad-x: 6%;
  --t: 0.38s cubic-bezier(0.4,0,0.2,1);
}

/* ---- RESET ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--black);color:var(--white);font-family:var(--font-body);font-weight:300;line-height:1.75;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:var(--font-body)}
input,textarea,select{font-family:var(--font-body)}

/* ---- UTILITIES ---- */
.container{max-width:var(--max-w);margin:0 auto;padding:0 var(--pad-x)}
.gold{color:var(--gold)} .text-center{text-align:center}

/* ---- TYPOGRAPHY ---- */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.08;letter-spacing:-0.01em}
h1{font-size:clamp(3.2rem,8vw,7.5rem)}
h2{font-size:clamp(2.4rem,5vw,4.2rem)}
h3{font-size:clamp(1.5rem,3vw,2.4rem)}
h4{font-size:clamp(1.1rem,2vw,1.5rem)}
p{font-size:clamp(0.88rem,1.4vw,1rem);color:var(--white2);line-height:1.8}

.section-tag{display:inline-flex;align-items:center;gap:14px;font-size:0.65rem;font-weight:500;letter-spacing:0.32em;text-transform:uppercase;color:var(--gold);margin-bottom:22px}
.section-tag::before{content:'';width:32px;height:1px;background:var(--gold)}

/* ---- BUTTONS ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:15px 40px;font-family:var(--font-body);font-size:0.7rem;font-weight:500;letter-spacing:0.22em;text-transform:uppercase;transition:all var(--t);white-space:nowrap}
.btn-gold{background:var(--gold);color:var(--black)}
.btn-gold:hover{background:var(--gold2);transform:translateY(-2px);box-shadow:0 12px 32px rgba(184,150,110,0.3)}
.btn-outline{border:1px solid rgba(184,150,110,0.6);color:var(--gold)}
.btn-outline:hover{background:var(--gold);color:var(--black)}
.btn-white{border:1px solid rgba(42,33,24,0.3);color:var(--white)}
.btn-white:hover{background:var(--white);color:var(--black)}
.btn-lg{padding:18px 52px;font-size:0.75rem}

.divider{width:60px;height:1px;background:var(--gold);margin:24px 0}
.divider-center{margin:24px auto}

/* ============================================================
   NAVIGATION
   ============================================================ */
#site-nav{position:fixed;top:0;left:0;right:0;z-index:999;height:196px;display:flex;align-items:center;justify-content:space-between;padding:0 var(--pad-x);transition:background .5s ease,box-shadow .5s ease}
#site-nav.scrolled{background:rgba(250,247,244,.97);box-shadow:0 1px 0 rgba(154,110,72,.15);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.nav-logo{display:flex;align-items:center;gap:14px}
.nav-logo img{height:180px;width:auto;filter:contrast(1.1) saturate(1.2)}
.nav-logo-text{font-family:var(--font-display);font-size:1.15rem;font-weight:600;color:var(--white);letter-spacing:.04em;line-height:1.2}
.nav-logo-text small{display:block;font-family:var(--font-body);font-size:.58rem;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-top:2px}
.nav-center{display:flex;align-items:center;gap:32px}
.nav-center a{font-size:.68rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--white2);transition:color var(--t)}
.nav-center a:hover,.nav-center a.active{color:var(--gold)}
.nav-right{display:flex;align-items:center;gap:18px}
.nav-phone{font-size:.78rem;letter-spacing:.06em;color:var(--gold);display:flex;align-items:center;gap:6px;transition:color var(--t)}
.nav-phone:hover{color:var(--gold2)}
.nav-phone svg{width:13px;height:13px;flex-shrink:0}
.nav-book{font-size:.63rem;letter-spacing:.2em;padding:10px 22px;background:var(--gold);color:var(--black);font-weight:500;text-transform:uppercase;transition:all var(--t)}
.nav-book:hover{background:var(--gold2)}
.nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:32px;height:32px;cursor:pointer;padding:4px}
.nav-burger span{display:block;width:22px;height:1px;background:var(--white);transition:var(--t)}

.mobile-nav{display:none;position:fixed;inset:0;z-index:1002;background:rgba(250,247,244,1);flex-direction:column;align-items:center;justify-content:center;gap:26px}
.mobile-nav.open{display:flex}
.mobile-nav a{font-family:var(--font-display);font-size:clamp(1.8rem,5vw,2.4rem);font-weight:300;color:var(--white);transition:color var(--t)}
.mobile-nav a:hover{color:var(--gold)}
.mobile-nav .m-phone{margin-top:18px;font-size:.95rem;letter-spacing:.08em;color:var(--gold)}
.mobile-nav .m-book{margin-top:6px;padding:13px 38px;background:var(--gold);color:var(--black);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;font-weight:500}
.mobile-close{position:absolute;top:28px;right:var(--pad-x);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--white3);cursor:pointer;font-family:var(--font-body)}

/* ============================================================
   FOOTER
   ============================================================ */
#site-footer{background:#2a2118;border-top:1px solid rgba(154,110,72,.2);padding:80px var(--pad-x) 32px}
.footer-inner{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:2.2fr 1fr 1fr 1.3fr;gap:52px;padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand .f-logo{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.footer-brand .f-logo img{height:80px;width:auto}
.footer-brand .f-logo-text{font-family:var(--font-display);font-size:1.15rem;font-weight:600;line-height:1.2}
.footer-brand .f-logo-text small{display:block;font-family:var(--font-body);font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}
.footer-brand p{font-size:.88rem;max-width:260px;line-height:1.7;margin-bottom:22px}
.footer-social{display:flex;gap:10px}
.footer-social a{width:36px;height:36px;border:1px solid rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;color:var(--white3);transition:all var(--t)}
.footer-social a:hover{border-color:var(--gold);color:var(--gold)}
.footer-social svg{width:16px;height:16px}
.footer-col h5{font-family:var(--font-body);font-size:.62rem;font-weight:500;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:20px}
.footer-col li{margin-bottom:9px}
.footer-col li a{font-size:.88rem;color:var(--white2);transition:color var(--t)}
.footer-col li a:hover{color:var(--gold)}
.f-phone{display:flex;align-items:center;gap:8px;font-size:1.05rem;color:var(--gold);letter-spacing:.04em;margin-bottom:12px}
.f-phone svg{width:16px;height:16px;flex-shrink:0}
.f-addr{font-size:.88rem;color:var(--white2);line-height:1.7}
.f-hours{margin-top:14px}
.f-hours p{font-size:.82rem;margin-bottom:3px}
.footer-bottom{max-width:var(--max-w);margin:26px auto 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-bottom p{font-size:.75rem;color:rgba(255,255,255,.45)}
.footer-bottom .f-links{display:flex;gap:22px}
.footer-bottom .f-links a{font-size:.72rem;color:rgba(255,255,255,.45);transition:color var(--t)}
.footer-bottom .f-links a:hover{color:var(--gold)}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:var(--black)}
.hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,#faf7f4 0%,#f5ede4 40%,#faf7f4 100%)}
.hero-bg-img{position:absolute;inset:0;background:url('assets/brow-portrait-beauty-grand-prairie-tx.jpg') center/cover no-repeat;opacity:.22;mix-blend-mode:multiply}
.hero-grad{position:absolute;inset:0;background:linear-gradient(90deg,rgba(250,247,244,.95) 0%,rgba(250,247,244,.7) 55%,rgba(250,247,244,.3) 100%)}
.hero-grain{position:absolute;inset:0;opacity:.032;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px}
.hero-glow{position:absolute;right:-10%;top:-20%;width:80vh;height:80vh;background:radial-gradient(ellipse,rgba(154,110,72,.06) 0%,transparent 70%);pointer-events:none}

.hero-content{position:relative;z-index:2;padding:130px var(--pad-x) 100px;max-width:var(--max-w);margin:0 auto;width:100%}
.hero-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:22px;animation:fadeUp .9s ease both}
.hero-eyebrow::before{content:'';width:40px;height:1px;background:var(--gold)}
.hero-eyebrow span{font-size:.65rem;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:var(--gold)}
.hero h1{font-weight:300;color:var(--white);animation:fadeUp .9s .15s ease both}
.hero h1 strong{font-weight:700;display:block;font-style:italic}
.hero-line{width:80px;height:1px;background:rgba(184,150,110,.4);margin:26px 0;animation:fadeUp .9s .28s ease both}

.hero-rotate-row{display:flex;align-items:center;gap:18px;margin:0 0 42px;animation:fadeUp .9s .35s ease both;flex-wrap:wrap}
.hero-rotate-label{font-size:.63rem;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:var(--white3);white-space:nowrap}
.hero-ticker{font-family:var(--font-display);font-size:clamp(1.1rem,2.2vw,1.6rem);font-weight:600;font-style:italic;color:var(--gold);height:2em;overflow:hidden;position:relative;min-width:200px}
.hero-ticker-inner{display:flex;flex-direction:column;animation:ticker 10s cubic-bezier(.4,0,.2,1) infinite}
.hero-ticker-inner span{height:2em;display:flex;align-items:center;white-space:nowrap}
@keyframes ticker{0%,18%{transform:translateY(0)}25%,43%{transform:translateY(-2em)}50%,68%{transform:translateY(-4em)}75%,93%{transform:translateY(-6em)}100%{transform:translateY(0)}}

.hero-ctas{display:flex;align-items:center;gap:18px;flex-wrap:wrap;animation:fadeUp .9s .45s ease both}
.hero-trust{margin-top:50px;display:flex;align-items:center;gap:30px;animation:fadeUp .9s .6s ease both;flex-wrap:wrap}
.hero-trust-item{display:flex;align-items:center;gap:10px}
.hero-trust-num{font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--white);line-height:1}
.hero-trust-num span{font-size:.9rem;color:var(--gold)}
.hero-trust-label{font-size:.7rem;color:var(--white3);letter-spacing:.06em;line-height:1.4}
.hero-trust-divider{width:1px;height:38px;background:rgba(255,255,255,.1)}
.hero-scroll{position:absolute;bottom:36px;left:var(--pad-x);display:flex;align-items:center;gap:10px;opacity:.32}
.hero-scroll-line{width:1px;height:48px;background:var(--gold);animation:scroll-anim 2s ease-in-out infinite;transform-origin:top}
@keyframes scroll-anim{0%,100%{transform:scaleY(1);opacity:.5}50%{transform:scaleY(.4);opacity:1}}
.hero-scroll span{font-size:.56rem;letter-spacing:.28em;text-transform:uppercase;writing-mode:vertical-lr;color:var(--white2)}

@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ============================================================
   MARQUEE STRIP
   ============================================================ */
.marquee-strip{background:var(--gold);padding:14px 0;overflow:hidden}
.marquee-track{display:flex;width:max-content;animation:marquee 22s linear infinite}
.marquee-track:hover{animation-play-state:paused}
.marquee-item{display:flex;align-items:center;gap:20px;padding:0 32px;font-size:.63rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:#fff;white-space:nowrap}
.marquee-dot{width:4px;height:4px;background:#fff;border-radius:50%;opacity:.5}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   BEFORE / AFTER SLIDER
   ============================================================ */
.ba-section{padding:100px 0;background:var(--black2)}
.ba-head{padding:0 var(--pad-x);margin-bottom:56px;text-align:center}
.ba-head h2{margin-bottom:14px}
.ba-track{display:flex;padding:0 var(--pad-x);gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;justify-content:center}
.ba-track::-webkit-scrollbar{display:none}
.ba-slide{flex:0 0 calc(33.333% - 14px);scroll-snap-align:start;min-width:280px}
.ba-slider{position:relative;overflow:hidden;cursor:ew-resize;user-select:none;background:#111}
.ba-slider-inner{position:relative;width:100%;aspect-ratio:3/4}
.ba-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ba-after{clip-path:inset(0 0 0 50%)}
.ba-handle{position:absolute;top:0;bottom:0;left:50%;width:2px;background:rgba(255,255,255,.9);pointer-events:none;z-index:5}
.ba-knob{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:var(--white);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.4)}
.ba-knob svg{width:18px;height:18px;color:var(--black)}
.ba-lbl{position:absolute;bottom:16px;font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;font-weight:500;background:rgba(0,0,0,.75);padding:5px 11px}
.ba-lbl.before-lbl{left:14px;color:var(--white2)}
.ba-lbl.after-lbl{right:14px;color:var(--gold)}
.ba-cta-row{text-align:center;margin-top:48px;padding:0 var(--pad-x)}

/* ============================================================
   SERVICES CARDS (HOME)
   ============================================================ */
.home-services{padding:100px var(--pad-x);max-width:var(--max-w);margin:0 auto}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:54px}
.svc-card{background:#fff;padding:52px 36px;transition:var(--t);position:relative;overflow:hidden;cursor:default;box-shadow:0 2px 16px rgba(42,33,24,.06)}
.svc-card::before{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .5s ease}
.svc-card:hover::before{transform:scaleX(1)}
.svc-card:hover{background:var(--black3)}
.svc-num{font-family:var(--font-display);font-size:3.5rem;font-weight:300;color:rgba(184,150,110,.1);line-height:1;margin-bottom:18px}
.svc-card h3{font-size:1.7rem;margin-bottom:12px;color:var(--white)}
.svc-card p{font-size:.9rem;margin-bottom:26px;line-height:1.8}
.svc-badge{display:inline-block;font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;padding:5px 12px;border:1px solid rgba(184,150,110,.3);color:var(--gold);margin-bottom:22px}
.svc-link{display:inline-flex;align-items:center;gap:8px;font-size:.67rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);transition:gap var(--t)}
.svc-link:hover{gap:14px}
.svc-link svg{width:14px;height:14px}

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews-section{background:var(--black2);padding:100px var(--pad-x);border-top:1px solid rgba(154,110,72,.12);border-bottom:1px solid rgba(154,110,72,.12)}
.reviews-head{text-align:center;margin-bottom:58px}
.reviews-stars{display:flex;justify-content:center;gap:4px;margin-bottom:18px}
.reviews-stars svg{width:18px;height:18px;fill:var(--gold);color:var(--gold)}
.reviews-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;max-width:var(--max-w);margin:0 auto}
.review-card{background:#fff;padding:40px 34px;border:1px solid rgba(154,110,72,.1);transition:border-color var(--t);box-shadow:0 2px 20px rgba(42,33,24,.06)}
.review-card:hover{border-color:rgba(154,110,72,.3)}
.review-card .quote-mark{font-family:var(--font-display);font-size:5rem;font-weight:700;color:rgba(184,150,110,.12);line-height:.8;margin-bottom:6px}
.review-card blockquote{font-family:var(--font-display);font-size:clamp(1rem,1.4vw,1.2rem);font-weight:400;font-style:italic;color:var(--white);line-height:1.65;margin-bottom:22px}
.review-meta{display:flex;align-items:center;gap:12px}
.review-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--gold3),var(--gold));display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:.95rem;font-weight:600;color:var(--white);flex-shrink:0}
.review-author{font-size:.82rem;font-weight:500;color:var(--white);margin-bottom:3px}
.review-stars-sm{display:flex;gap:2px}
.review-stars-sm svg{width:11px;height:11px;fill:var(--gold)}

/* ============================================================
   ABOUT TEASER
   ============================================================ */
.about-teaser{padding:100px var(--pad-x);display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;max-width:var(--max-w);margin:0 auto}
.about-img-wrap{position:relative}
.about-img-wrap img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:top;filter:grayscale(10%)}
.about-img-badge{position:absolute;bottom:-22px;right:-22px;background:var(--gold);padding:24px;text-align:center}
.about-img-badge .badge-num{font-family:var(--font-display);font-size:2.6rem;font-weight:700;color:var(--black);line-height:1}
.about-img-badge .badge-lbl{font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(8,8,8,.7);font-weight:500}
.about-text h2{margin-bottom:18px}
.about-text p{margin-bottom:18px}

/* ============================================================
   CTA STRIP
   ============================================================ */
.cta-strip{padding:90px var(--pad-x);background:linear-gradient(135deg,#2a2118 0%,#3d2e22 50%,#2a2118 100%);position:relative;overflow:hidden;text-align:center;border-top:1px solid rgba(184,150,110,.1)}
.cta-strip::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:600px;border-radius:50%;background:radial-gradient(ellipse,rgba(184,150,110,.06) 0%,transparent 70%);pointer-events:none}
.cta-strip h2{color:#faf7f4;margin-bottom:14px}
.cta-strip p{color:rgba(255,255,255,.7);margin-bottom:0;max-width:500px;margin-left:auto;margin-right:auto}
.cta-strip .phone-big{display:block;font-family:var(--font-display);font-size:clamp(1.8rem,4vw,3rem);font-weight:600;color:var(--gold);margin:22px 0 34px;transition:color var(--t);letter-spacing:.04em}
.cta-strip .phone-big:hover{color:var(--gold2)}
.cta-row{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}.cta-strip .btn-white{border:1px solid rgba(255,255,255,.4);color:#faf7f4}.cta-strip .btn-white:hover{background:#faf7f4;color:#2a2118}

/* ============================================================
   INSTAGRAM
   ============================================================ */
.ig-section{padding:80px var(--pad-x);border-top:1px solid rgba(255,255,255,.04)}
.ig-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:34px;flex-wrap:wrap;gap:14px}
.ig-handle{display:flex;align-items:center;gap:10px;font-size:.88rem;color:var(--gold);transition:color var(--t)}
.ig-handle:hover{color:var(--gold2)}
.ig-handle svg{width:20px;height:20px}
.ig-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:4px}
.ig-item{aspect-ratio:1;overflow:hidden;background:var(--black3);position:relative;cursor:pointer}
.ig-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease,filter .6s ease;filter:grayscale(10%)}
.ig-item:hover img{transform:scale(1.08);filter:grayscale(0)}
.ig-overlay{position:absolute;inset:0;background:rgba(184,150,110,.38);opacity:0;transition:opacity var(--t);display:flex;align-items:center;justify-content:center}
.ig-item:hover .ig-overlay{opacity:1}
.ig-overlay svg{width:26px;height:26px;color:#fff}

/* ============================================================
   PAGE HERO (INNER PAGES)
   ============================================================ */
.page-hero{padding:160px var(--pad-x) 80px;background:linear-gradient(135deg,#f5ede4 0%,#faf7f4 60%,#f5ede4 100%);position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;right:0;top:0;bottom:0;width:38%;background:none;opacity:.07;mask-image:linear-gradient(90deg,transparent,rgba(0,0,0,.6));-webkit-mask-image:linear-gradient(90deg,transparent,rgba(0,0,0,.6))}
.page-hero-inner{max-width:var(--max-w);margin:0 auto;position:relative;z-index:1}
.breadcrumb{display:flex;align-items:center;gap:10px;margin-bottom:22px;font-size:.67rem;letter-spacing:.14em;text-transform:uppercase}
.breadcrumb a{color:var(--white3);transition:color var(--t)}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb .sep{color:var(--white3);opacity:.4}
.breadcrumb .current{color:var(--gold)}
.page-hero h1{color:var(--white);margin-bottom:18px}
.page-hero p{max-width:540px;font-size:1.02rem}

/* ============================================================
   SERVICES PAGE
   ============================================================ */
.service-block{padding:80px var(--pad-x);max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.service-block.alt{direction:rtl}
.service-block.alt>*{direction:ltr}
.service-img-col{position:sticky;top:100px}
.service-img{width:100%;aspect-ratio:2/3;object-fit:cover;display:block}
.price-badge{background:var(--gold);padding:18px 26px;display:inline-flex;flex-direction:column;margin-top:22px}
.price-badge .from{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(8,8,8,.65);font-weight:500}
.price-badge .price{font-family:var(--font-display);font-size:2.2rem;font-weight:700;color:var(--black);line-height:1.1}
.service-content h2{margin-bottom:14px}
.service-desc{font-size:1rem;margin-bottom:28px;line-height:1.85}
.service-meta{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:28px 0}
.meta-item{background:var(--black2);padding:18px;border-left:2px solid var(--gold)}
.meta-item .meta-label{font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:5px;font-weight:500}
.meta-item .meta-val{font-family:var(--font-display);font-size:1.2rem;font-weight:600;color:var(--white)}
.best-for{margin-bottom:28px}
.best-for h4{font-family:var(--font-body);font-size:.8rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--white);margin-bottom:12px}
.best-for li{display:flex;align-items:flex-start;gap:10px;font-size:.9rem;color:var(--white2);margin-bottom:9px}
.best-for li::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--gold);flex-shrink:0;margin-top:8px}
.svc-divider{height:1px;background:rgba(255,255,255,.05);margin:0 var(--pad-x)}

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.about-split{padding:100px var(--pad-x);display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;max-width:var(--max-w);margin:0 auto}
.about-photo-wrap{position:relative}
.about-photo-wrap img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:top;filter:grayscale(12%)}
.about-photo-frame{position:absolute;bottom:-18px;left:-18px;width:100%;height:100%;border:1px solid rgba(184,150,110,.22);pointer-events:none}
.about-cred{margin:36px 0}
.cred-item{display:flex;align-items:flex-start;gap:14px;padding:18px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.cred-icon{width:42px;height:42px;border:1px solid rgba(184,150,110,.28);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--gold)}
.cred-icon svg{width:18px;height:18px}
.cred-text h5{font-family:var(--font-body);font-size:.82rem;font-weight:500;color:var(--white);margin-bottom:3px}
.cred-text p{font-size:.82rem;margin:0}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:0}
.value-card{background:#fff;padding:40px 28px;box-shadow:0 2px 16px rgba(42,33,24,.05)}
.value-card h4{font-size:1.3rem;margin-bottom:10px;color:var(--white)}
.value-card p{font-size:.88rem;line-height:1.7}
.value-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--gold);margin-bottom:18px}
.value-icon svg{width:28px;height:28px}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;padding:60px var(--pad-x) 100px;max-width:1600px;margin:0 auto}
.gallery-item{position:relative;overflow:hidden;cursor:pointer}
.gallery-item img{width:100%;aspect-ratio:3/4;object-fit:cover;transition:transform .7s ease;filter:grayscale(12%)}
.gallery-item:nth-child(5n) img,.gallery-item:nth-child(7n) img{aspect-ratio:4/3}
.gallery-item:hover img{transform:scale(1.05);filter:grayscale(0)}
.gallery-overlay{position:absolute;inset:0;background:rgba(42,33,24,.45);opacity:0;transition:opacity var(--t);display:flex;align-items:flex-end;padding:20px}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-overlay-label{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.gallery-sliders-sect{padding:80px var(--pad-x);background:var(--black2)}
.gallery-sliders-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-width:var(--max-w);margin:48px auto 0}
/* ============================================================
   CONTACT / BOOKING
   ============================================================ */
.contact-wrap{padding:60px var(--pad-x) 100px;max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:1fr 1.4fr;gap:80px}
.contact-info .info-block{margin-bottom:36px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.06)}
.contact-info .info-block:last-child{border-bottom:none}
.contact-info h4{font-family:var(--font-body);font-size:.6rem;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.contact-phone-big{font-family:var(--font-display);font-size:2rem;font-weight:600;color:var(--white);letter-spacing:.04em;transition:color var(--t);display:block;margin-bottom:6px}
.contact-phone-big:hover{color:var(--gold)}

.booking-form{background:#fff;padding:50px 42px;border:1px solid rgba(154,110,72,.12);box-shadow:0 4px 30px rgba(42,33,24,.08)}
.form-title{font-family:var(--font-display);font-size:1.8rem;font-weight:600;color:var(--white);margin-bottom:6px}
.form-subtitle{font-size:.82rem;color:var(--white3);margin-bottom:34px}
.form-group{margin-bottom:20px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
.form-group label,.form-row .fg label{display:block;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:7px;font-weight:500}
.form-group input:not([type="checkbox"]),.form-group select,.form-group textarea,.form-row .fg input:not([type="checkbox"]),.form-row .fg select{width:100%;background:#fff;border:1px solid rgba(154,110,72,.2);padding:13px 16px;color:var(--white);font-size:.9rem;font-family:var(--font-body);transition:border-color var(--t);outline:none;appearance:none;-webkit-appearance:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus,.form-row .fg input:focus,.form-row .fg select:focus{border-color:var(--gold);background:rgba(154,110,72,.04)}
.form-group textarea{resize:vertical;min-height:110px}
.form-group select,.form-row .fg select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='7'%3E%3Cpath fill='%239a6e48' d='M5 7L0 0h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;background-color:#fff}
.form-group select option,.form-row .fg select option{background:#fff;color:var(--white)}
.form-submit{width:100%;padding:16px;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;font-weight:500;background:var(--gold);color:var(--black);transition:all var(--t);border:none;cursor:pointer;font-family:var(--font-body)}
.form-submit:hover{background:var(--gold2);transform:translateY(-1px);box-shadow:0 8px 24px rgba(184,150,110,.25)}
.form-note{font-size:.7rem;color:var(--white3);text-align:center;margin-top:14px;line-height:1.6}
.form-success{display:none;text-align:center;padding:40px 20px}
.form-success.show{display:block}
.success-icon{width:58px;height:58px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.success-icon svg{width:26px;height:26px;color:var(--black)}
.form-success h3{margin-bottom:10px;font-size:1.7rem}

.faq-section{padding:80px var(--pad-x) 100px;background:var(--black2)}
.faq-inner{max-width:800px;margin:0 auto}
.faq-head{text-align:center;margin-bottom:50px}
.faq-item{border-bottom:1px solid rgba(255,255,255,.07)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;padding:22px 0;cursor:pointer;background:none;border:none;text-align:left;font-family:var(--font-display);font-size:1.15rem;font-weight:400;color:var(--white);gap:18px;transition:color var(--t)}
.faq-q:hover{color:var(--gold)}
.faq-icon{width:27px;height:27px;border:1px solid rgba(184,150,110,.3);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--t)}
.faq-icon svg{width:11px;height:11px;color:var(--gold);transition:transform var(--t)}
.faq-item.open .faq-icon{background:var(--gold)}
.faq-item.open .faq-icon svg{transform:rotate(45deg);color:var(--black)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s ease}
.faq-item.open .faq-a{max-height:500px;padding-bottom:22px}
.faq-a p{font-size:.9rem;line-height:1.85}

/* ============================================================
   LEGAL PAGES
   ============================================================ */
.legal-wrap{padding:60px var(--pad-x) 100px;max-width:860px;margin:0 auto}
.legal-card{background:#fff;border:1px solid rgba(154,110,72,.1);padding:52px 60px}
.legal-card h2{font-size:clamp(1.8rem,3vw,2.6rem);margin-bottom:26px;padding-bottom:26px;border-bottom:1px solid rgba(184,150,110,.2)}
.legal-intro{font-size:1rem;color:var(--white);margin-bottom:34px;font-style:italic;font-family:var(--font-display)}
.legal-section-label{font-family:var(--font-body);font-size:.6rem;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin:38px 0 18px;display:flex;align-items:center;gap:12px}
.legal-section-label::after{content:'';flex:1;height:1px;background:rgba(184,150,110,.2)}
.legal-item{display:flex;align-items:flex-start;gap:14px;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.legal-item:last-child{border-bottom:none}
.legal-bullet{width:7px;height:7px;border-radius:50%;background:var(--gold);flex-shrink:0;margin-top:9px}
.legal-item p{font-size:.92rem;color:var(--white2);line-height:1.85;margin:0}
.legal-item p strong{color:var(--white);font-weight:500}
.legal-warning{background:rgba(184,150,110,.07);border-left:3px solid var(--gold);padding:18px 22px;margin:28px 0}
.legal-warning p{color:var(--white);font-size:.9rem;margin:0;font-weight:400}
.aftercare-phase{margin:28px 0}
.aftercare-phase-title{font-family:var(--font-body);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:16px;font-weight:500}
.aftercare-step{display:flex;align-items:flex-start;gap:18px;padding:18px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.aftercare-step:last-child{border-bottom:none}
.step-num{width:40px;height:40px;border:1px solid rgba(184,150,110,.28);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--gold)}
.step-text p{font-size:.92rem;color:var(--white2);line-height:1.85;margin:0}
.warn-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:22px 0}
.warn-item{background:rgba(255,255,255,.03);border-left:2px solid rgba(184,150,110,.35);padding:12px 16px}
.warn-item p{font-size:.84rem;color:var(--white2);margin:0;line-height:1.6}
.warn-item strong{color:var(--white);font-weight:500}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1100px){
  .footer-inner{grid-template-columns:1fr 1fr;gap:36px}
  .service-block{grid-template-columns:1fr;gap:40px}
  .service-img-col{position:relative;top:0}
  .about-split{grid-template-columns:1fr;gap:48px}
  .contact-wrap{grid-template-columns:1fr;gap:48px}
  .gallery-sliders-grid{grid-template-columns:1fr}
}
@media(max-width:900px){
  :root{--pad-x:5%}
  .services-grid{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:1fr}
  .about-teaser{grid-template-columns:1fr;gap:50px}
  .about-img-badge{right:0;bottom:-14px}
  .ig-grid{grid-template-columns:repeat(3,1fr)}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .legal-card{padding:36px 26px}
  .warn-grid{grid-template-columns:1fr}
  .values-grid{grid-template-columns:1fr}
  .service-meta{grid-template-columns:1fr}
  .gallery-sliders-grid{grid-template-columns:1fr}
}

@media(max-width:768px){
  /* Nav */
  .nav-center,.nav-phone,.nav-book{display:none}
  .nav-burger{display:flex}
  #site-nav{height:120px}
  .nav-logo img{height:108px;filter:contrast(1.1) saturate(1.2)}

  /* Typography */
  h1{font-size:clamp(2.4rem,9vw,3.8rem)}
  h2{font-size:clamp(1.8rem,6vw,2.6rem)}
  p{font-size:.92rem}

  /* Hero */
  .hero-content{padding:100px var(--pad-x) 80px}
  .hero-rotate-row{flex-direction:column;align-items:flex-start;gap:8px}
  .hero-trust{flex-wrap:wrap;gap:16px}
  .hero-trust-divider{display:none}
  .hero-ctas{flex-direction:column;align-items:flex-start}
  .hero-ctas .btn{width:100%;justify-content:center}

  /* Before/After — single column stacked */
  .ba-track{flex-direction:column;overflow-x:visible;padding:0 var(--pad-x);gap:32px;scroll-snap-type:none}
  .ba-slide{flex:0 0 auto;width:100%;min-width:unset}
  .ba-slider-inner{aspect-ratio:4/5}

  /* Gallery sliders — single column */
  .gallery-sliders-grid{grid-template-columns:1fr;gap:28px}

  /* Gallery grid */
  .gallery-grid{grid-template-columns:1fr;gap:3px}

  /* Services */
  .svc-card{padding:36px 24px}

  /* Reviews */
  .reviews-grid{grid-template-columns:1fr}
  .review-card{padding:28px 22px}

  /* About teaser */
  .about-teaser{grid-template-columns:1fr;gap:40px}
  .about-img-badge{right:0;bottom:-14px}

  /* Footer */
  .footer-inner{grid-template-columns:1fr;gap:28px}
  .footer-brand p{max-width:100%}

  /* Booking form */
  .booking-form{padding:28px 20px}
  .contact-wrap{padding:40px var(--pad-x) 60px;gap:36px}

  /* Legal pages */
  .legal-card{padding:28px 20px}

  /* CTA strip */
  .cta-strip{padding:60px var(--pad-x)}
  .cta-row{flex-direction:column;align-items:center}
  .cta-row .btn{width:100%;max-width:320px;justify-content:center}

  /* Instagram */
  .ig-grid{grid-template-columns:repeat(3,1fr)}

  /* Page hero */
  .page-hero{padding:120px var(--pad-x) 60px}
}

@media(max-width:480px){
  :root{--pad-x:4%}

  /* Form */
  .form-row{grid-template-columns:1fr}
  .booking-form{padding:24px 16px}

  /* Instagram - 2 cols on very small screens */
  .ig-grid{grid-template-columns:repeat(2,1fr)}

  /* Gallery */
  .gallery-grid{grid-template-columns:1fr}

  /* Nav logo text hide on tiny screens */
  .nav-logo-text small{display:none}

  /* Hero */
  .hero-content{padding:90px var(--pad-x) 60px}

  /* Footer bottom links wrap */
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:8px}
  .footer-bottom .f-links{flex-wrap:wrap;gap:12px}

  /* Marquee slightly smaller */
  .marquee-item{font-size:.58rem;padding:0 20px}
}
