/* ==========================================================================
   Berkem Brows — Shared site styles
   Used by: index/home + about + services + cosmetic-tattoo + brows +
   lashes + hair-growth-repair + waxing + faq + contact
   ========================================================================== */

:root{
  --blush:#F4EBE4; --blush-light:#FAF6F3; --blush-dark:#EAD9CF;
  --charcoal:#2A2220; --near-black:#1A1412;
  --stone:#8B7D77; --caramel:#C4956A; --caramel-light:#E8D0BC;
  --cream:#FDFAF8; --line:#E2D5CE;
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'DM Sans', system-ui, -apple-system, sans-serif;
  --ease:cubic-bezier(0.22,1,0.36,1);
}
*{box-sizing:border-box; margin:0; padding:0}
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%}
body{
  background:var(--blush); color:var(--charcoal);
  font-family:var(--sans); font-weight:400; line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
::selection{background:var(--charcoal); color:var(--cream)}
h1,h2,h3,h4{font-family:var(--serif); font-weight:400; color:var(--charcoal)}
a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
button{cursor:pointer; background:transparent; border:none; font:inherit; color:inherit}

.container{max-width:1240px; margin:0 auto; padding:0 24px}
@media(min-width:640px){.container{padding:0 32px}}
@media(min-width:1024px){.container{padding:0 48px}}

.eyebrow{font-family:var(--sans); font-size:11px; text-transform:uppercase; letter-spacing:0.22em; color:var(--stone); display:inline-flex; align-items:center; gap:12px}
.eyebrow::before{content:''; display:inline-block; width:32px; height:1px; background:rgba(42,34,32,0.4)}
.eyebrow.center::before, .eyebrow.center::after{content:''; display:inline-block; width:32px; height:1px; background:rgba(42,34,32,0.4)}

/* ----- Buttons ----- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:var(--sans); font-size:12px; text-transform:uppercase;
  letter-spacing:0.16em; font-weight:500;
  padding:14px 32px; border-radius:2px;
  transition:all 500ms var(--ease); cursor:pointer; border:1px solid transparent;
}
.btn-primary{background:var(--near-black); color:var(--cream); border-color:var(--near-black)}
.btn-primary:hover{background:var(--caramel); border-color:var(--caramel); transform:translateY(-2px); box-shadow:0 24px 60px -20px rgba(42,34,32,0.25)}
.btn-secondary{background:transparent; color:var(--charcoal); border-color:var(--charcoal)}
.btn-secondary:hover{background:var(--charcoal); color:var(--cream)}
.btn-ghost{display:inline-flex; align-items:center; gap:8px; font-family:var(--sans); font-size:12px; text-transform:uppercase; letter-spacing:0.16em; font-weight:500; color:var(--charcoal); position:relative}
.btn-ghost::after{content:''; display:block; width:24px; height:1px; background:currentColor; transition:width 300ms var(--ease)}
.btn-ghost:hover{color:var(--caramel)}
.btn-ghost:hover::after{width:40px}
.magnetic{transition:transform 600ms var(--ease)}

/* ----- Reveal animation ----- */
.reveal{opacity:0; transform:translateY(24px); transition:opacity 900ms var(--ease), transform 900ms var(--ease)}
.reveal.in{opacity:1; transform:translateY(0)}
.reveal.delay-1{transition-delay:120ms}
.reveal.delay-2{transition-delay:240ms}
.reveal.delay-3{transition-delay:360ms}
.reveal.delay-4{transition-delay:480ms}

/* ----- Navigation ----- */
.nav{position:fixed; top:0; left:0; right:0; z-index:50; transition:all 500ms var(--ease)}
.nav.scrolled{background:rgba(244,235,228,0.85); backdrop-filter:blur(12px); border-bottom:1px solid rgba(42,34,32,0.08)}
.nav-inner{display:flex; align-items:center; justify-content:space-between; padding:18px 0}
.wordmark{display:flex; align-items:center; gap:8px}
.wordmark img.logo{height:44px; width:auto; display:block; transition:opacity 400ms var(--ease)}
.wordmark:hover img.logo{opacity:0.75}
@media(min-width:768px){.wordmark img.logo{height:56px}}
/* Legacy text wordmark (kept for footer where the logo is on dark bg) */
.wordmark .pt1{font-family:var(--serif); font-size:24px; line-height:1; color:var(--charcoal)}
.wordmark .pt2{font-family:var(--serif); font-style:italic; font-size:24px; line-height:1; color:rgba(42,34,32,0.6); transition:color 500ms var(--ease)}
.wordmark:hover .pt2{color:var(--caramel)}
.nav-links{display:none; gap:32px; align-items:center}
@media(min-width:1024px){.nav-links{display:flex}}
.nav-link{font-family:var(--sans); font-size:12px; text-transform:uppercase; letter-spacing:0.16em; color:rgba(42,34,32,0.75); transition:color 300ms}
.nav-link:hover, .nav-link.active{color:var(--caramel)}
.nav-cta{display:flex; align-items:center; gap:12px}
.nav-phone{display:none; font-family:var(--sans); font-size:12px; text-transform:uppercase; letter-spacing:0.16em; color:rgba(42,34,32,0.75)}
@media(min-width:768px){.nav-phone{display:inline}}
.nav-phone:hover{color:var(--caramel)}
.nav-book{display:none}
@media(min-width:640px){.nav-book{display:inline-flex; background:var(--near-black); color:var(--cream); font-family:var(--sans); font-size:11px; text-transform:uppercase; letter-spacing:0.16em; font-weight:500; padding:12px 20px; border-radius:2px; transition:background 500ms}}
.nav-book:hover{background:var(--caramel)}

/* ----- Mobile hamburger + drawer ----- */
.nav-burger{
  display:flex; align-items:center; justify-content:center;
  width:44px; height:44px; padding:0; margin-left:4px;
  background:transparent; border:1px solid rgba(42,34,32,0.15);
  border-radius:50%; transition:all 300ms var(--ease);
  flex-shrink:0;
}
@media(min-width:1024px){.nav-burger{display:none}}
.nav-burger svg{width:18px; height:18px}
.nav-burger:hover{border-color:var(--charcoal)}
.nav-burger:focus-visible{outline:2px solid var(--caramel); outline-offset:2px}

.mobile-drawer{
  position:fixed; inset:0; z-index:200; pointer-events:none;
  visibility:hidden; transition:visibility 0s 500ms;
}
.mobile-drawer.open{pointer-events:auto; visibility:visible; transition:visibility 0s 0s}
.drawer-overlay{
  position:absolute; inset:0; background:rgba(26,20,18,0);
  transition:background 400ms var(--ease);
}
.mobile-drawer.open .drawer-overlay{background:rgba(26,20,18,0.45); backdrop-filter:blur(2px)}
.drawer-panel{
  position:absolute; top:0; right:0; height:100%; width:88%; max-width:380px;
  background:var(--blush); padding:24px 28px 32px;
  display:flex; flex-direction:column;
  transform:translateX(100%); transition:transform 500ms var(--ease);
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  box-shadow:-24px 0 60px -20px rgba(42,34,32,0.25);
}
.mobile-drawer.open .drawer-panel{transform:translateX(0)}
.drawer-head{display:flex; align-items:center; justify-content:space-between; margin-bottom:24px}
.drawer-head .logo{height:40px; width:auto; display:block}
.drawer-close{
  width:44px; height:44px; display:flex; align-items:center; justify-content:center;
  border:1px solid rgba(42,34,32,0.15); border-radius:50%; transition:all 300ms;
  background:transparent;
}
.drawer-close svg{width:14px; height:14px}
.drawer-close:hover{border-color:var(--charcoal); background:var(--charcoal); color:var(--cream)}
.drawer-nav{display:flex; flex-direction:column; border-top:1px solid rgba(42,34,32,0.1)}
.drawer-nav a{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 0; border-bottom:1px solid rgba(42,34,32,0.1);
  font-family:var(--serif); font-size:22px; line-height:1.2; color:var(--charcoal);
  transition:color 300ms; min-height:44px;
}
.drawer-nav a:hover, .drawer-nav a.active{color:var(--caramel)}
.drawer-nav a .arrow{font-family:var(--sans); font-size:14px; opacity:0.45; transition:transform 300ms, opacity 300ms}
.drawer-nav a:hover .arrow, .drawer-nav a.active .arrow{opacity:1; transform:translateX(4px)}
.drawer-foot{margin-top:auto; padding-top:32px}
.drawer-cta{
  display:flex; align-items:center; justify-content:center; gap:8px;
  width:100%; background:var(--near-black); color:var(--cream);
  padding:16px 24px; border-radius:2px;
  font-family:var(--sans); font-size:12px; text-transform:uppercase; letter-spacing:0.16em; font-weight:500;
  min-height:52px;
  transition:background 300ms;
}
.drawer-cta:hover{background:var(--caramel)}
.drawer-contact{margin-top:24px; padding-top:24px; border-top:1px solid rgba(42,34,32,0.1)}
.drawer-contact p.lbl{font-family:var(--sans); font-size:10px; text-transform:uppercase; letter-spacing:0.22em; color:var(--stone); margin-bottom:8px}
.drawer-contact a, .drawer-contact span.line{display:block; font-family:var(--sans); font-size:14px; color:var(--charcoal); padding:4px 0; min-height:32px; transition:color 300ms}
.drawer-contact a:hover{color:var(--caramel)}
.drawer-socials{display:flex; gap:12px; margin-top:16px}
.drawer-socials a{
  width:40px; height:40px; display:flex; align-items:center; justify-content:center;
  border:1px solid rgba(42,34,32,0.15); border-radius:50%; transition:all 300ms;
}
.drawer-socials a:hover{border-color:var(--caramel); color:var(--caramel)}
body.drawer-open{overflow:hidden}

/* ----- Image placeholder ----- */
.img-ph{position:relative; overflow:hidden; border:1px solid rgba(42,34,32,0.1); background:var(--blush-dark); color:rgba(42,34,32,0.65)}
.img-ph.charcoal{background:var(--charcoal); color:rgba(253,250,248,0.7); border-color:rgba(253,250,248,0.1)}
.img-ph.cream{background:var(--cream); color:rgba(42,34,32,0.65)}
.img-ph::before{
  content:''; position:absolute; inset:0; opacity:0.4;
  background-image:repeating-linear-gradient(135deg, currentColor 0 1px, transparent 1px 22px);
}
/* Real image overlays the placeholder when present */
.img-ph > img.real{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; z-index:2;
  display:block;
}
.img-ph-inner{display:none} /* legacy placeholder text — hidden so internal paths never leak if an image stalls */
.img-ph-rule{display:flex; align-items:center; gap:8px; margin-bottom:16px; opacity:0.7}
.img-ph-rule .line{width:24px; height:1px; background:currentColor}
.img-ph-label{font-family:var(--sans); font-size:10px; text-transform:uppercase; letter-spacing:0.22em; opacity:0.8}
.img-ph-name{font-family:var(--serif); font-style:italic; font-size:18px; margin-top:12px; max-width:24ch; line-height:1.3}
.img-ph-file{font-family:var(--sans); font-size:10px; margin-top:12px; opacity:0.6; letter-spacing:0.04em}
.aspect-portrait{aspect-ratio:4/5}
.aspect-square{aspect-ratio:1/1}
.aspect-landscape{aspect-ratio:3/2}
.aspect-wide{aspect-ratio:16/9}
.aspect-21-9{aspect-ratio:21/9}

/* ----- Page hero (inner pages) ----- */
.page-hero{
  padding:160px 0 80px; position:relative; overflow:hidden;
  background:
    linear-gradient(90deg, rgba(226, 213, 206, 0.5) 1px, transparent 1px) 0 0 / 72px 72px,
    linear-gradient(180deg, var(--blush), var(--cream) 68%, var(--blush-light));
}
@media(min-width:1024px){.page-hero{padding:200px 0 120px}}
.page-hero-grid{display:grid; grid-template-columns:1fr; gap:48px; align-items:center}
@media(min-width:1024px){.page-hero-grid{grid-template-columns:6fr 6fr; gap:80px}}
.page-hero h1{font-size:clamp(2.25rem, 5.5vw, 3.5rem); line-height:1.05; letter-spacing:-0.015em; margin-top:32px; max-width:16ch}
.page-hero h1 .italic{font-style:italic; color:rgba(42,34,32,0.85)}
.page-hero-sub{margin-top:32px; max-width:52ch; font-size:18px; line-height:1.7; color:rgba(42,34,32,0.75)}
.page-hero-ctas{margin-top:40px; display:flex; flex-wrap:wrap; gap:16px}

/* ----- Sections ----- */
.section{padding:96px 0}
@media(min-width:1024px){.section{padding:144px 0}}
.section-alt{background:var(--blush-light)}
.section-dark{background:var(--charcoal); color:var(--cream)}
.section-dark h1, .section-dark h2, .section-dark h3{color:var(--cream)}
.section-dark .eyebrow{color:rgba(253,250,248,0.55)}
.section-dark .eyebrow::before, .section-dark .eyebrow.center::before, .section-dark .eyebrow.center::after{background:rgba(253,250,248,0.4)}

.section-head{display:grid; grid-template-columns:1fr; gap:32px; margin-bottom:64px}
@media(min-width:1024px){.section-head{grid-template-columns:5fr 7fr; gap:32px; margin-bottom:96px}}
.section-head h2{font-size:clamp(2rem, 4.5vw, 2.75rem); line-height:1.1; letter-spacing:-0.01em}
.section-head h2 .italic{font-style:italic; color:rgba(42,34,32,0.85)}
.section-dark .section-head h2 .italic{color:rgba(253,250,248,0.85)}
.section-head .lead{font-size:18px; line-height:1.7; color:rgba(42,34,32,0.75); max-width:52ch; align-self:end}
.section-dark .section-head .lead{color:rgba(253,250,248,0.75)}

/* ----- Service detail blocks (on inner pages) ----- */
.svc-grid{display:grid; grid-template-columns:1fr; gap:48px}
@media(min-width:1024px){.svc-grid{gap:64px}}
.svc-row{display:grid; grid-template-columns:1fr; gap:32px; align-items:start; padding:48px 0; border-top:1px solid rgba(42,34,32,0.1)}
@media(min-width:768px){.svc-row{grid-template-columns:1fr 2fr; gap:48px}}
.svc-row:first-child{border-top:0; padding-top:0}
.svc-row .num{font-family:var(--serif); font-size:14px; color:var(--caramel); text-transform:uppercase; letter-spacing:0.22em}
.svc-row h3{font-family:var(--serif); font-size:28px; line-height:1.15; margin-top:8px}
.svc-row .duration{font-family:var(--sans); font-size:13px; color:var(--stone); margin-top:4px; font-style:italic}
.svc-row .body p{font-size:16px; line-height:1.7; color:rgba(42,34,32,0.8)}
.svc-row .body p + p{margin-top:12px}
.svc-row .body .cta-row{margin-top:24px}

/* Compact service list (Brows, Lashes, Waxing) */
.svc-list{display:grid; grid-template-columns:1fr; gap:0; border-top:1px solid rgba(42,34,32,0.1)}
.svc-list-item{padding:32px 0; border-bottom:1px solid rgba(42,34,32,0.1); display:grid; grid-template-columns:1fr; gap:16px}
@media(min-width:768px){.svc-list-item{grid-template-columns:1fr 2fr 200px; gap:32px; align-items:start}}
.svc-list-item h3{font-family:var(--serif); font-size:22px; line-height:1.2}
.svc-list-item p{font-size:15px; line-height:1.65; color:rgba(42,34,32,0.75)}
.svc-list-item .cta{font-family:var(--sans); font-size:11px; text-transform:uppercase; letter-spacing:0.16em; color:var(--charcoal); transition:color 300ms; align-self:start}
.svc-list-item .cta:hover{color:var(--caramel)}

/* ----- Process timeline ----- */
.process{display:grid; grid-template-columns:1fr; gap:48px}
@media(min-width:768px){.process{grid-template-columns:repeat(4,1fr); gap:32px}}
.process-step{position:relative}
.process-step .step-num{font-family:var(--serif); font-style:italic; font-size:48px; line-height:1; color:var(--caramel); margin-bottom:16px}
.process-step h3{font-family:var(--serif); font-size:22px; line-height:1.2; margin-bottom:12px}
.process-step p{font-size:15px; line-height:1.65; color:rgba(42,34,32,0.75)}

/* ----- FAQ accordion ----- */
.faq-list{max-width:820px; margin:0 auto}
.faq-item{border-bottom:1px solid rgba(42,34,32,0.15)}
.faq-trigger{
  display:flex; align-items:flex-start; justify-content:space-between; gap:24px;
  width:100%; padding:28px 0; text-align:left;
  font-family:var(--serif); font-size:22px; line-height:1.3; color:var(--charcoal);
  transition:color 300ms;
}
.faq-trigger:hover{color:var(--caramel)}
.faq-trigger .plus{
  flex-shrink:0; width:32px; height:32px; border:1px solid rgba(42,34,32,0.25); border-radius:50%;
  display:flex; align-items:center; justify-content:center; position:relative;
  margin-top:4px; transition:all 400ms var(--ease);
}
.faq-trigger .plus::before, .faq-trigger .plus::after{
  content:''; position:absolute; background:var(--charcoal); transition:transform 400ms var(--ease);
}
.faq-trigger .plus::before{width:12px; height:1px}
.faq-trigger .plus::after{width:1px; height:12px}
.faq-item.open .faq-trigger{color:var(--caramel)}
.faq-item.open .faq-trigger .plus{border-color:var(--caramel); background:var(--caramel)}
.faq-item.open .faq-trigger .plus::before, .faq-item.open .faq-trigger .plus::after{background:var(--cream)}
.faq-item.open .faq-trigger .plus::after{transform:rotate(90deg)}
.faq-body{
  max-height:0; overflow:hidden; transition:max-height 500ms var(--ease), padding 500ms var(--ease);
}
.faq-item.open .faq-body{padding-bottom:28px}
.faq-body p{font-size:16px; line-height:1.7; color:rgba(42,34,32,0.8); max-width:68ch}
.faq-body p + p{margin-top:12px}

/* FAQ category heading (master FAQ page) */
.faq-cat{padding-top:48px; margin-top:48px; border-top:1px solid rgba(42,34,32,0.1)}
.faq-cat:first-child{padding-top:0; margin-top:0; border-top:0}
.faq-cat-title{font-family:var(--sans); font-size:11px; text-transform:uppercase; letter-spacing:0.22em; color:var(--caramel); margin-bottom:8px; text-align:center}
.faq-cat-h{font-family:var(--serif); font-size:32px; text-align:center; margin-bottom:24px}

/* ----- Contact details ----- */
.contact-grid{display:grid; grid-template-columns:1fr; gap:48px; align-items:start}
@media(min-width:768px){.contact-grid{grid-template-columns:1fr 1fr; gap:64px}}
.contact-card{padding:32px; border:1px solid rgba(42,34,32,0.12); background:var(--blush-light)}
.contact-list{display:flex; flex-direction:column; gap:20px}
.contact-row{display:flex; gap:16px; align-items:start; padding-bottom:20px; border-bottom:1px solid rgba(42,34,32,0.08)}
.contact-row:last-child{border-bottom:0; padding-bottom:0}
.contact-row .dot{width:6px; height:6px; border-radius:50%; background:var(--caramel); margin-top:10px; flex-shrink:0}
.contact-row dt{font-family:var(--sans); font-size:11px; text-transform:uppercase; letter-spacing:0.22em; color:var(--stone); margin-bottom:4px}
.contact-row dd{font-family:var(--serif); font-size:18px; line-height:1.4; color:var(--charcoal)}
.contact-row dd a{color:var(--charcoal); transition:color 300ms}
.contact-row dd a:hover{color:var(--caramel)}

/* Map embed */
.map-slot{margin-top:64px; background:var(--blush-dark); border:1px solid rgba(42,34,32,0.1); aspect-ratio:21/9; position:relative; overflow:hidden; box-shadow:0 4px 24px rgba(42,34,32,0.08)}
.map-slot iframe{position:absolute; inset:0; width:100%; height:100%; border:0; display:block}
@media(max-width:640px){.map-slot{aspect-ratio:4/3}}
.map-slot-inner{position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; color:rgba(42,34,32,0.6); text-align:center; padding:24px}
.map-pin{width:28px; height:28px; border-radius:50%; border:2px solid var(--caramel); position:relative; margin-bottom:12px}
.map-pin::after{content:''; position:absolute; bottom:-12px; left:50%; width:2px; height:12px; background:var(--caramel); transform:translateX(-50%)}

/* ----- Final CTA ----- */
.final{position:relative; overflow:hidden; text-align:center}
.final-inner{position:relative; max-width:768px; margin:0 auto}
.final h2{font-size:clamp(2.5rem, 6vw, 3.75rem); line-height:1.05; margin-top:32px}
.final h2 .italic{font-style:italic}
.final p.lead{margin:32px auto 0; max-width:52ch; font-size:18px; line-height:1.7; color:rgba(42,34,32,0.75)}
.final-ctas{margin-top:48px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:16px}
@media(min-width:640px){.final-ctas{flex-direction:row}}
.final-tag{margin-top:64px; font-family:var(--serif); font-style:italic; font-size:24px; color:rgba(42,34,32,0.55)}

/* ----- Footer ----- */
footer{background:var(--near-black); color:var(--cream); position:relative; overflow:hidden}
.footer-line{height:1px; background:rgba(253,250,248,0.1)}
.footer-inner{padding:80px 0 60px}
@media(min-width:1024px){.footer-inner{padding:112px 0 80px}}
.footer-grid{display:grid; grid-template-columns:1fr; gap:48px}
@media(min-width:768px){.footer-grid{grid-template-columns:5fr 3fr 4fr; gap:32px}}
.footer-brand .wordmark{margin-bottom:20px}
.footer-brand .wordmark img.logo{height:40px; filter:brightness(0) invert(1); opacity:0.95}
.footer-brand .wordmark .pt1, .footer-brand .wordmark .pt2{font-size:28px; color:var(--cream)}
.footer-brand .wordmark .pt2{color:rgba(253,250,248,0.6)}
.footer-tag{font-family:var(--serif); font-style:italic; font-size:24px; line-height:1.3; color:rgba(253,250,248,0.85); max-width:52ch}
.footer-blurb{font-family:var(--sans); font-size:14px; color:rgba(253,250,248,0.55); margin-top:24px; max-width:52ch; line-height:1.6}
.footer-col .lbl{font-family:var(--sans); font-size:11px; text-transform:uppercase; letter-spacing:0.22em; color:rgba(253,250,248,0.5); margin-bottom:20px}
.footer-row{display:flex; align-items:start; gap:12px; font-family:var(--sans); font-size:14px; line-height:1.6; color:rgba(253,250,248,0.75); margin-bottom:16px; transition:color 300ms}
a.footer-row:hover{color:var(--caramel)}
.footer-row .dot{width:6px; height:6px; border-radius:50%; background:var(--caramel); margin-top:8px; flex-shrink:0}
.footer-cta{display:inline-flex; width:100%; align-items:center; justify-content:space-between; background:var(--cream); color:var(--near-black); padding:16px 24px; font-family:var(--sans); font-size:12px; text-transform:uppercase; letter-spacing:0.16em; font-weight:500; border-radius:2px; transition:all 500ms}
.footer-cta:hover{background:var(--caramel); color:var(--cream)}
.footer-social{margin-top:16px; display:flex; align-items:center; gap:16px}
.footer-social a{display:inline-flex; align-items:center; justify-content:center; width:40px; height:40px; border:1px solid rgba(253,250,248,0.2); border-radius:2px; transition:all 300ms}
.footer-social a:hover{border-color:var(--caramel); color:var(--caramel)}
.footer-handle{font-family:var(--sans); font-size:12px; text-transform:uppercase; letter-spacing:0.16em; color:rgba(253,250,248,0.6); transition:color 300ms}
.footer-handle:hover{color:var(--caramel)}
.footer-bottom{border-top:1px solid rgba(253,250,248,0.1); margin-top:64px; padding-top:32px; display:flex; flex-direction:column; gap:12px; justify-content:space-between}
@media(min-width:768px){.footer-bottom{flex-direction:row; align-items:center}}
.footer-bottom p{font-family:var(--sans); font-size:11px; color:rgba(253,250,248,0.45)}
.footer-bottom p.right{font-size:10px; text-transform:uppercase; letter-spacing:0.22em; color:rgba(253,250,248,0.35)}

/* ----- Loader ----- */
.loader{
  position:fixed; inset:0; z-index:10000; background:var(--blush);
  display:flex; align-items:center; justify-content:center;
  transition:opacity 800ms var(--ease) 1800ms, visibility 0s 2600ms;
}
.loader.done{opacity:0; visibility:hidden; pointer-events:none}
.loader-mark{position:relative; display:flex; align-items:baseline; gap:14px; overflow:hidden}
.loader-mark .lm-part{
  font-family:var(--serif); font-size:clamp(48px, 9vw, 92px); line-height:1; color:var(--charcoal);
  transform:translateY(110%); display:inline-block;
  animation:lm-rise 900ms var(--ease) forwards;
}
.loader-mark .lm-part.italic{font-style:italic; color:rgba(42,34,32,0.55); animation-delay:200ms}
@keyframes lm-rise{from{transform:translateY(110%)} to{transform:translateY(0)}}
.loader-rule{
  position:absolute; left:50%; bottom:-32px; transform:translateX(-50%);
  width:0; height:1px; background:var(--caramel);
  animation:lm-rule 800ms var(--ease) 800ms forwards;
}
@keyframes lm-rule{from{width:0} to{width:120px}}
.loader-tag{
  position:absolute; left:50%; bottom:-72px; transform:translateX(-50%);
  font-family:var(--sans); font-size:10px; text-transform:uppercase; letter-spacing:0.32em;
  color:rgba(42,34,32,0.5); white-space:nowrap; opacity:0;
  animation:lm-tag 600ms var(--ease) 1100ms forwards;
}
@keyframes lm-tag{from{opacity:0; transform:translateX(-50%) translateY(4px)} to{opacity:1; transform:translateX(-50%) translateY(0)}}
body.loading{overflow:hidden}

/* ----- Floating sticky CTA ----- */
.float-cta{
  position:fixed; bottom:24px; right:24px; z-index:90;
  background:var(--near-black); color:var(--cream);
  padding:14px 22px 14px 20px; border-radius:100px;
  display:flex; align-items:center; gap:10px;
  font-family:var(--sans); font-size:12px; text-transform:uppercase; letter-spacing:0.16em; font-weight:500;
  box-shadow:0 16px 40px -12px rgba(42,34,32,0.4);
  transform:translateY(120%) scale(0.95); opacity:0;
  transition:all 600ms var(--ease);
}
.float-cta.show{transform:translateY(0) scale(1); opacity:1}
.float-cta:hover{background:var(--caramel); transform:translateY(-2px); box-shadow:0 24px 48px -12px rgba(196,149,106,0.5)}
.float-cta .dot-pulse{
  width:8px; height:8px; border-radius:50%; background:var(--caramel);
  position:relative; flex-shrink:0; animation:dot-pulse 2.4s ease-in-out infinite;
}
.float-cta:hover .dot-pulse{background:var(--cream)}
.float-cta .dot-pulse::before{
  content:''; position:absolute; inset:-4px; border-radius:50%;
  background:currentColor; opacity:0.35;
  animation:dot-ring 2.4s ease-in-out infinite;
}
@keyframes dot-pulse{0%,100%{transform:scale(1)} 50%{transform:scale(1.2)}}
@keyframes dot-ring{0%{transform:scale(1); opacity:0.45} 100%{transform:scale(2.2); opacity:0}}
@media(max-width:640px){.float-cta{bottom:16px; right:16px; padding:12px 18px; font-size:11px}}

/* ----- Lead body type ----- */
.lead-body p{font-size:17px; line-height:1.75; color:rgba(42,34,32,0.85); max-width:64ch}
.lead-body p + p{margin-top:20px}
.lead-body.center p{margin-left:auto; margin-right:auto; text-align:center}

/* ----- Two-up content (image + text) ----- */
.two-up{display:grid; grid-template-columns:1fr; gap:48px; align-items:center}
@media(min-width:768px){.two-up{grid-template-columns:1fr 1fr; gap:80px}}
.two-up.reverse > :first-child{order:2}
@media(min-width:768px){.two-up.reverse > :first-child{order:0}}

/* ----- Product list ----- */
.product-list{list-style:none; display:flex; flex-direction:column; gap:20px; margin-top:24px}
.product-list li{display:flex; gap:16px; padding-bottom:20px; border-bottom:1px solid rgba(42,34,32,0.08)}
.product-list li:last-child{border-bottom:0}
.product-list strong, .product-list h3{font-family:var(--serif); font-weight:400; font-size:20px; min-width:140px; color:var(--charcoal); display:block; margin-bottom:6px; line-height:1.2}
.product-list p{font-size:15px; line-height:1.65; color:rgba(42,34,32,0.75)}

/* ----- Reduced motion ----- */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{animation-duration:0.01ms !important; transition-duration:0.01ms !important}
  .loader{display:none}
}

/* ==========================================================================
   Mobile polish — tap targets, sizing, overflow guards
   ========================================================================== */
html, body{overflow-x:hidden}
@media (max-width:768px){
  /* Tighter base spacing so content breathes on small screens */
  .section{padding:72px 0}
  .page-hero{padding:128px 0 56px}
  .nav-inner{padding:14px 0}
  .wordmark img.logo{height:40px}

  /* Buttons: keep tappable but trim padding so two CTAs fit side-by-side */
  .btn{padding:14px 22px; min-height:48px}
  .btn-ghost{min-height:44px; padding:6px 0}
  .nav-book{padding:11px 16px; font-size:10.5px; min-height:40px}

  /* Headings: tighten line-height a touch */
  .page-hero h1{margin-top:24px}
  .page-hero-sub{margin-top:24px; font-size:16px}
  .page-hero-ctas{margin-top:28px; gap:12px}
  .section-head{margin-bottom:40px; gap:20px}
  .section-head .lead{font-size:16px}

  /* Service / process / two-up */
  .svc-row{padding:32px 0; gap:24px}
  .svc-row h3{font-size:24px}
  .process-step .step-num{font-size:40px; margin-bottom:12px}
  .two-up{gap:32px}

  /* FAQ — denser */
  .faq-trigger{padding:22px 0; font-size:18px; gap:16px}
  .faq-trigger .plus{width:28px; height:28px}
  .faq-cat{padding-top:32px; margin-top:32px}
  .faq-cat-h{font-size:24px}

  /* Contact card */
  .contact-card{padding:24px}
  .contact-row dd{font-size:16px}
  .map-slot{margin-top:40px}

  /* Final CTA */
  .final h2{margin-top:24px}
  .final-ctas{margin-top:36px; gap:14px}
  .final-tag{margin-top:48px; font-size:20px}

  /* Footer */
  .footer-inner{padding:64px 0 48px}
  .footer-tag{font-size:20px}
  .footer-bottom{margin-top:48px; padding-top:24px}

  /* Product list — fix overflow risk */
  .product-list li{flex-direction:column; gap:6px}
  .product-list strong, .product-list h3{min-width:0}
}
@media (max-width:480px){
  .container{padding:0 20px}
  .page-hero{padding:120px 0 48px}
  .page-hero h1{font-size:clamp(2rem, 8vw, 2.5rem)}
  .section{padding:64px 0}
  .section-head h2{font-size:clamp(1.75rem, 8vw, 2.25rem)}
  .nav-book{display:none} /* Drawer CTA replaces it on tiny screens */
  .nav-phone{display:none}
  .btn{font-size:11px; padding:14px 18px; letter-spacing:0.14em}
}
@media (hover:none) and (pointer:coarse){
  /* Disable hover-driven transforms on touch — they linger and feel buggy */
  .btn-primary:hover, .service-card:hover, .tile:hover, .pillar:hover .img-wrap .img-ph{transform:none}
  .magnetic{transition:none}
}
