/* ============ TEXTURED BARBER LOUNGE — luxury dark system ============ */
:root{
  --black:#050505;
  --graphite:#121212;
  --graphite-2:#1a1a1a;
  --silver:#C7C7C7;
  --platinum:#E8E8E8;
  --white:#FFFFFF;
  --muted:#8d8d8d;
  --line:rgba(199,199,199,.14);
  --font-display:'Marcellus',serif;
  --font-body:'Jost',sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
  --shadow:0 30px 60px rgba(0,0,0,.55);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--black);color:var(--platinum);font-family:var(--font-body);font-weight:300;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--silver);color:var(--black)}

h1,h2,h3{font-family:var(--font-display);font-weight:400;color:var(--white);line-height:1.12}
h1{font-size:clamp(2.6rem,6vw,4.8rem);letter-spacing:.01em}
h2{font-size:clamp(2rem,4.2vw,3.2rem)}
h2 em,h1 em{font-style:normal;color:transparent;-webkit-text-stroke:1px var(--silver)}
.kicker{display:inline-block;font-size:.72rem;letter-spacing:.42em;text-transform:uppercase;color:var(--silver);margin-bottom:1rem}
.stars{color:var(--silver);letter-spacing:.18em}

.container{width:min(1180px,92%);margin:0 auto}
.container.narrow{width:min(820px,92%)}
.section{padding:clamp(5rem,9vw,8.5rem) 0;position:relative}
.section-head{text-align:center;max-width:640px;margin:0 auto clamp(2.5rem,5vw,4.5rem)}
.section-head p{color:var(--muted);margin-top:1rem}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;padding:1rem 2.4rem;font-family:var(--font-body);font-size:.8rem;font-weight:500;letter-spacing:.28em;text-transform:uppercase;border:1px solid var(--silver);cursor:pointer;position:relative;overflow:hidden;transition:color .45s var(--ease),border-color .45s var(--ease);z-index:1}
.btn::before{content:"";position:absolute;inset:0;background:var(--platinum);transform:scaleX(0);transform-origin:right;transition:transform .45s var(--ease);z-index:-1}
.btn:hover::before{transform:scaleX(1);transform-origin:left}
.btn-solid{background:var(--platinum);color:var(--black);border-color:var(--platinum)}
.btn-solid::before{background:var(--black)}
.btn-solid:hover{color:var(--platinum)}
.btn-ghost{color:var(--platinum);background:transparent}
.btn-ghost:hover{color:var(--black)}
.btn-full{width:100%}

/* ---------- header ---------- */
.header{position:fixed;inset:0 0 auto;z-index:100;transition:border-color .4s,padding .4s;border-bottom:1px solid transparent}
/* blur lives on a pseudo-element so the header never becomes the
   containing block for the fixed-position mobile nav */
.header::before{content:"";position:absolute;inset:0;z-index:-1;background:rgba(5,5,5,.72);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);opacity:0;transition:opacity .4s}
.header.scrolled::before{opacity:1}
.header.scrolled{border-bottom-color:var(--line)}
.header-inner{width:min(1320px,94%);margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:1.1rem 0;transition:padding .4s}
.header.scrolled .header-inner{padding:.7rem 0}
.logo{display:flex;align-items:center;gap:.8rem}
.logo-mark{display:grid;place-items:center;width:46px;height:46px;border:1px solid var(--silver);font-family:var(--font-display);font-size:1.15rem;color:var(--white);letter-spacing:.05em;background:linear-gradient(145deg,rgba(199,199,199,.12),transparent)}
.logo-text{font-family:var(--font-display);font-size:1.05rem;color:var(--white);letter-spacing:.14em;text-transform:uppercase;line-height:1.15}
.logo-text em{display:block;font-style:normal;font-family:var(--font-body);font-size:.58rem;font-weight:400;letter-spacing:.5em;color:var(--silver)}
.nav{display:flex;align-items:center;gap:2rem}
.nav>a{font-size:.78rem;letter-spacing:.24em;text-transform:uppercase;color:var(--platinum);position:relative;padding:.3rem 0}
.nav>a::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--silver);transform:scaleX(0);transform-origin:right;transition:transform .35s var(--ease)}
.nav>a:hover::after{transform:scaleX(1);transform-origin:left}
.nav-socials{display:flex;gap:.5rem;margin-left:.4rem}
.icon-btn{display:grid;place-items:center;width:38px;height:38px;border:1px solid var(--line);transition:border-color .3s,background .3s}
.icon-btn svg{width:16px;height:16px;fill:var(--silver);transition:fill .3s}
.icon-btn:hover{border-color:var(--silver);background:rgba(199,199,199,.08)}
.icon-btn:hover svg{fill:var(--white)}
.nav-cta{padding:.8rem 1.6rem}
.burger{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:6px;padding:8px;z-index:110}
.burger span{display:block;width:26px;height:1.5px;background:var(--platinum);transition:.35s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ---------- hero ---------- */
.hero{min-height:100svh;display:grid;place-items:center;position:relative;text-align:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;animation:heroZoom 14s var(--ease) forwards}
@keyframes heroZoom{from{transform:scale(1.12)}to{transform:scale(1)}}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,5,5,.64) 0%,rgba(5,5,5,.5) 45%,var(--black) 100%)}
.hero-content{width:min(880px,92%);padding:9rem 0 6rem;position:relative;z-index:2}
.hero-eyebrow{display:flex;align-items:center;justify-content:center;gap:1.2rem;font-size:.7rem;letter-spacing:.45em;text-transform:uppercase;color:var(--silver);margin-bottom:1.8rem}
.hero-eyebrow .line{width:54px;height:1px;background:linear-gradient(90deg,transparent,var(--silver))}
.hero-eyebrow .line:last-child{background:linear-gradient(90deg,var(--silver),transparent)}
.hero-sub{max-width:560px;margin:1.6rem auto 0;color:#cfcfcf;font-size:1.05rem}
.hero-cta{display:flex;gap:1rem;justify-content:center;margin-top:2.6rem;flex-wrap:wrap}
.hero-badges{display:flex;align-items:center;justify-content:center;gap:1.4rem;margin-top:2.8rem;flex-wrap:wrap}
.badge{font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--platinum);display:flex;align-items:center;gap:.6rem}
.badge-sep{width:5px;height:5px;background:var(--silver);transform:rotate(45deg)}
.scroll-hint{position:absolute;bottom:2.2rem;left:50%;transform:translateX(-50%);width:26px;height:44px;border:1px solid var(--line);border-radius:13px;display:flex;justify-content:center;padding-top:8px;z-index:2}
.scroll-hint span{width:2px;height:8px;background:var(--silver);border-radius:2px;animation:drop 1.8s infinite}
@keyframes drop{0%{transform:translateY(0);opacity:1}70%{transform:translateY(14px);opacity:0}100%{opacity:0}}

/* ---------- marquee ---------- */
.marquee{border-block:1px solid var(--line);padding:1.1rem 0;overflow:hidden;background:var(--graphite)}
.marquee-track{display:flex;gap:2.6rem;width:max-content;animation:scroll 30s linear infinite;align-items:center}
.marquee span{font-family:var(--font-display);font-size:1rem;letter-spacing:.3em;text-transform:uppercase;color:var(--silver);white-space:nowrap}
.marquee i{color:var(--muted);font-style:normal;font-size:.7rem}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- services ---------- */
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1px;background:var(--line);border:1px solid var(--line)}
.service-card{background:var(--black);padding:2.2rem 1.9rem 2rem;position:relative;overflow:hidden;transition:background .45s var(--ease)}
.service-card::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:2px;background:linear-gradient(90deg,var(--silver),transparent);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.service-card:hover{background:var(--graphite)}
.service-card:hover::after{transform:scaleX(1)}
.service-card .num{font-family:var(--font-display);font-size:.78rem;color:var(--muted);letter-spacing:.3em}
.service-card h3{font-size:1.35rem;margin:.9rem 0 .5rem}
.service-card p{font-size:.92rem;color:var(--muted)}
.service-card .price{margin-top:1.3rem;font-family:var(--font-display);font-size:1.15rem;color:var(--silver);letter-spacing:.08em}
.service-card .price small{color:var(--muted)}
.price-note{text-align:center;color:var(--muted);font-size:.8rem;margin-top:1.6rem;letter-spacing:.05em}

/* ---------- about ---------- */
.about{background:var(--graphite)}
.about-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(2.5rem,5vw,5rem);align-items:center}
.about-media{position:relative}
.about-media>img:first-child{width:100%;height:520px;object-fit:cover;filter:grayscale(.25) contrast(1.05);box-shadow:var(--shadow)}
.about-inset{position:absolute;right:-2.2rem;bottom:-2.6rem;width:46%;height:240px;object-fit:cover;border:6px solid var(--graphite);box-shadow:var(--shadow)}
.about-copy h2{margin-bottom:1.2rem}
.about-copy>p{color:#bdbdbd}
.about-points{list-style:none;margin:1.6rem 0 0}
.about-points li{padding:.55rem 0 .55rem 1.6rem;position:relative;color:var(--platinum);font-size:.95rem}
.about-points li::before{content:"";position:absolute;left:0;top:1.05rem;width:8px;height:8px;border:1px solid var(--silver);transform:rotate(45deg)}
.stats{display:flex;gap:2.8rem;margin:2.2rem 0 2.4rem;flex-wrap:wrap}
.stat-num{font-family:var(--font-display);font-size:2.6rem;color:var(--white);display:block;line-height:1}
.stat-label{font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}

/* ---------- gallery ---------- */
.masonry{columns:3 280px;column-gap:1.1rem}
.m-item{display:block;position:relative;margin-bottom:1.1rem;overflow:hidden;break-inside:avoid;border:1px solid var(--line)}
.m-item img{width:100%;height:auto;display:block;transition:transform .8s var(--ease),filter .8s var(--ease);filter:grayscale(.35)}
.m-item:hover img{transform:scale(1.06);filter:grayscale(0)}
.m-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(5,5,5,.85));opacity:0;transition:opacity .5s}
.m-item:hover::after{opacity:1}
.m-tag{position:absolute;left:1.1rem;bottom:1rem;z-index:2;font-size:.68rem;letter-spacing:.34em;text-transform:uppercase;color:var(--platinum);opacity:0;transform:translateY(8px);transition:.45s var(--ease)}
.m-item:hover .m-tag{opacity:1;transform:translateY(0)}
.gallery-cta{text-align:center;margin-top:2.6rem}

/* ---------- reviews ---------- */
.reviews{background:var(--graphite)}
.review-rating{margin-top:1.2rem;font-size:.85rem;letter-spacing:.24em;text-transform:uppercase;color:var(--platinum)}
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.4rem}
.review-card{background:rgba(255,255,255,.025);border:1px solid var(--line);padding:2.6rem 2.2rem 2.2rem;position:relative;backdrop-filter:blur(8px);transition:transform .5s var(--ease),border-color .5s}
.review-card:hover{transform:translateY(-8px);border-color:rgba(199,199,199,.4)}
.quote-mark{font-family:var(--font-display);font-size:4.4rem;color:rgba(199,199,199,.18);position:absolute;top:.6rem;left:1.4rem;line-height:1}
.review-card p{font-family:var(--font-display);font-size:1.25rem;color:var(--white);line-height:1.5;position:relative}
.review-card footer{margin-top:1.6rem;display:flex;justify-content:space-between;align-items:center}
.review-card cite{font-style:normal;font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--muted)}

/* ---------- booking ---------- */
.booking-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2.5rem,5vw,5rem);align-items:start}
.booking-copy h2{margin-bottom:1.2rem}
.booking-copy>p{color:#bdbdbd}
.booking-points{list-style:none;margin:1.8rem 0}
.booking-points li{padding:.85rem 0;border-bottom:1px solid var(--line);color:var(--muted);font-size:.95rem}
.booking-points strong{color:var(--platinum);font-weight:500}
.booking-alt{margin-top:1.6rem}
.booking-alt span{display:block;font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin-bottom:.3rem}
.phone-link{font-family:var(--font-display);font-size:1.7rem;color:var(--white);letter-spacing:.06em;transition:color .3s}
.phone-link:hover{color:var(--silver)}
.phone-link.big{font-size:2.1rem;display:inline-block;margin:1.2rem 0}
.booking-form{background:rgba(255,255,255,.03);border:1px solid var(--line);padding:clamp(1.6rem,3vw,2.6rem);backdrop-filter:blur(12px)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field{margin-bottom:1.1rem}
.field label{display:block;font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:var(--silver);margin-bottom:.45rem}
.field .optional{color:var(--muted);letter-spacing:.1em;text-transform:none}
.field input,.field select,.field textarea{width:100%;background:var(--black);border:1px solid var(--line);color:var(--white);font-family:var(--font-body);font-weight:300;font-size:.95rem;padding:.85rem 1rem;transition:border-color .3s;border-radius:0;-webkit-appearance:none;appearance:none}
.field select{background-image:linear-gradient(45deg,transparent 50%,var(--silver) 50%),linear-gradient(135deg,var(--silver) 50%,transparent 50%);background-position:calc(100% - 18px) 50%,calc(100% - 13px) 50%;background-size:5px 5px;background-repeat:no-repeat}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--silver)}
.field input::placeholder,.field textarea::placeholder{color:#5d5d5d}
.field input[type=date]{color-scheme:dark}
#bf-gotcha{position:absolute;left:-9999px;height:0;width:0;opacity:0}
.form-fine{font-size:.74rem;color:var(--muted);text-align:center;margin-top:1rem}
.booking-form.sending #bookingSubmit{opacity:.55;pointer-events:none}

/* ---------- faq ---------- */
.faq{background:var(--graphite)}
.faq-item{border:1px solid var(--line);background:rgba(255,255,255,.02);margin-bottom:.8rem}
.faq-item summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.2rem 1.5rem;font-family:var(--font-display);font-size:1.08rem;color:var(--white);transition:color .3s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--silver)}
.faq-x{position:relative;width:14px;height:14px;flex:none}
.faq-x::before,.faq-x::after{content:"";position:absolute;background:var(--silver);transition:transform .35s var(--ease)}
.faq-x::before{inset:6px 0;height:1.5px;top:50%}
.faq-x::after{inset:0 6px;width:1.5px;left:50%}
.faq-item[open] .faq-x::after{transform:rotate(90deg)}
.faq-item p{padding:0 1.5rem 1.3rem;color:var(--muted);font-size:.95rem}
.faq-item a{color:var(--silver);text-decoration:underline}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(2.5rem,5vw,4.5rem);align-items:start}
.contact-info address{font-style:normal;font-size:1.1rem;color:#cfcfcf;line-height:1.9;margin:1.4rem 0 .4rem}
.contact-info address strong{font-family:var(--font-display);font-weight:400;font-size:1.25rem;color:var(--white)}
.areas{margin-top:1.8rem}
.areas ul{list-style:none;display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1rem}
.areas li{border:1px solid var(--line);padding:.4rem 1rem;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--silver);transition:border-color .3s,color .3s}
.areas li:hover{border-color:var(--silver);color:var(--white)}
.map-wrap{border:1px solid var(--line);box-shadow:var(--shadow)}
.map-wrap iframe{display:block;width:100%;height:480px;border:0;filter:grayscale(1) invert(.92) contrast(.9)}

/* ---------- footer ---------- */
.footer{border-top:1px solid var(--line);padding:3.5rem 0 2rem;background:var(--graphite)}
.footer-top{display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap;padding-bottom:2.4rem;border-bottom:1px solid var(--line)}
.footer-ctas{display:flex;gap:.8rem;flex-wrap:wrap}
.footer-ctas .btn{padding:.75rem 1.5rem;font-size:.7rem}
.footer-bottom{padding-top:1.6rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.8rem;color:var(--muted)}
.footer-bottom a{color:var(--silver)}
.disclaimer{font-size:.72rem;color:#5d5d5d}

/* ---------- floating actions ---------- */
.fab-stack{position:fixed;right:1.3rem;bottom:1.3rem;display:flex;flex-direction:column;gap:.7rem;z-index:90;opacity:0;transform:translateY(16px);pointer-events:none;transition:.5s var(--ease)}
.fab-stack.show{opacity:1;transform:none;pointer-events:auto}
.fab{display:grid;place-items:center;width:52px;height:52px;border-radius:50%;border:1px solid var(--line);background:rgba(18,18,18,.85);backdrop-filter:blur(10px);box-shadow:0 10px 28px rgba(0,0,0,.5);transition:transform .3s var(--ease),border-color .3s}
.fab:hover{transform:translateY(-4px);border-color:var(--silver)}
.fab svg{width:22px;height:22px;fill:var(--platinum)}
.fab-book{width:auto;height:52px;border-radius:26px;padding:0 1.5rem;background:var(--platinum);color:var(--black);font-size:.74rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase}

/* ---------- lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(5,5,5,.94);backdrop-filter:blur(12px);display:grid;place-items:center;opacity:0;pointer-events:none;transition:opacity .4s}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox img{max-width:88vw;max-height:84vh;border:1px solid var(--line);box-shadow:var(--shadow)}
.lb-close,.lb-prev,.lb-next{position:absolute;background:none;border:1px solid var(--line);color:var(--platinum);width:48px;height:48px;font-size:1.5rem;cursor:pointer;transition:border-color .3s,background .3s;display:grid;place-items:center}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{border-color:var(--silver);background:rgba(199,199,199,.1)}
.lb-close{top:1.4rem;right:1.4rem}
.lb-prev{left:1.4rem;top:50%;transform:translateY(-50%)}
.lb-next{right:1.4rem;top:50%;transform:translateY(-50%)}

/* ---------- toast ---------- */
.toast{position:fixed;left:50%;bottom:2rem;transform:translate(-50%,140%);background:var(--platinum);color:var(--black);font-size:.85rem;font-weight:500;letter-spacing:.06em;padding:1rem 1.8rem;z-index:300;box-shadow:var(--shadow);transition:transform .5s var(--ease);max-width:90vw;text-align:center}
.toast.show{transform:translate(-50%,0)}
.toast.error{background:#2a1212;color:#f3c2c2;border:1px solid #6b2b2b}

/* ---------- reveal animations ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.12s}.d2{transition-delay:.24s}.d3{transition-delay:.36s}.d4{transition-delay:.48s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero-bg img{animation:none}
  .marquee-track{animation-duration:90s}
}

/* ---------- responsive ---------- */
@media (max-width:1020px){
  .about-grid,.booking-grid,.contact-grid{grid-template-columns:1fr}
  .about-inset{right:0;bottom:-2rem}
  .about-media{margin-bottom:2rem}
}
@media (max-width:840px){
  .burger{display:flex}
  .nav{position:fixed;inset:0;background:rgba(5,5,5,.96);backdrop-filter:blur(20px);flex-direction:column;justify-content:center;gap:1.6rem;transform:translateY(-100%);visibility:hidden;transition:transform .5s var(--ease),visibility .5s;z-index:105}
  .nav.open{transform:none;visibility:visible}
  .nav>a{font-size:1.05rem}
  .nav-cta{margin-top:.6rem}
  .form-row{grid-template-columns:1fr}
  .about-media>img:first-child{height:380px}
  .about-inset{width:52%;height:180px;border-color:var(--graphite)}
  .map-wrap iframe{height:360px}
  .footer-top{flex-direction:column;align-items:flex-start}
}

/* ============ V2 COMPONENTS ============ */
/* hero tagline */
.hero-tag{font-family:var(--font-display);font-size:clamp(1.05rem,2.2vw,1.45rem);letter-spacing:.24em;text-transform:uppercase;color:var(--silver);margin-top:1.4rem}

/* why choose us */
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.2rem}
.why-card{border:1px solid var(--line);background:rgba(255,255,255,.02);padding:2rem 1.8rem;transition:transform .5s var(--ease),border-color .5s,background .5s}
.why-card:hover{transform:translateY(-6px);border-color:rgba(199,199,199,.45);background:var(--graphite)}
.why-ico{display:grid;place-items:center;width:42px;height:42px;border:1px solid var(--silver);color:var(--silver);font-size:.9rem;margin-bottom:1.2rem;background:linear-gradient(145deg,rgba(199,199,199,.12),transparent)}
.why-card h3{font-size:1.2rem;margin-bottom:.4rem}
.why-card p{font-size:.92rem;color:var(--muted)}

/* service card v2 */
.svc-meta{display:flex;justify-content:space-between;align-items:baseline;margin-top:1.3rem;padding-top:1rem;border-top:1px solid var(--line)}
.svc-meta .dur{font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--muted)}
.svc-meta .price{font-family:var(--font-display);font-size:1.3rem;color:var(--silver);letter-spacing:.06em}
.svc-meta .price small{color:var(--muted);font-size:.8rem}
.svc-book{display:inline-block;margin-top:1rem;font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--platinum);transition:color .3s,letter-spacing .3s}
.svc-book:hover{color:var(--silver);letter-spacing:.34em}

/* instagram bar */
.ig-bar{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;border:1px solid var(--line);background:rgba(255,255,255,.02);backdrop-filter:blur(8px);padding:1rem 1.6rem;margin-bottom:1.4rem;font-size:.85rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.ig-bar strong{color:var(--silver);font-weight:500}
.ig-link{color:var(--silver);text-decoration:underline}

/* booking steps + slots */
.bstep{display:flex;align-items:center;gap:.8rem;margin:1.4rem 0 1rem;font-size:.78rem;letter-spacing:.3em;text-transform:uppercase;color:var(--platinum)}
.bstep:first-child{margin-top:0}
.bstep-num{display:grid;place-items:center;width:28px;height:28px;border:1px solid var(--silver);color:var(--silver);font-family:var(--font-display);font-size:.85rem;flex:none}
.slot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(86px,1fr));gap:.5rem;min-height:52px}
.slot-hint{grid-column:1/-1;color:#5d5d5d;font-size:.85rem;align-self:center}
.slot{padding:.6rem .2rem;text-align:center;font-size:.82rem;letter-spacing:.08em;border:1px solid var(--line);background:var(--black);color:var(--platinum);cursor:pointer;transition:border-color .25s,background .25s,color .25s;user-select:none}
.slot:hover{border-color:var(--silver)}
.slot.selected{background:var(--silver);border-color:var(--silver);color:var(--black);font-weight:500}
.slot.taken{border-color:rgba(255,255,255,.05);color:#4a4a4a;background:transparent;cursor:not-allowed;text-decoration:line-through}

/* seo content */
.seo-content{background:var(--graphite)}
.seo-body h3{font-size:1.45rem;margin:2.2rem 0 .8rem;color:var(--white)}
.seo-body h3:first-child{margin-top:0}
.seo-body p{color:#b5b0a4;font-size:.98rem;margin-bottom:.6rem}
.seo-body a{color:var(--silver);text-decoration:underline}

/* faq categories */
.faq-cat{font-size:1.1rem;letter-spacing:.22em;text-transform:uppercase;color:var(--silver);margin:2.4rem 0 1rem}
.faq-list+.faq-cat{margin-top:2.8rem}

/* hours table */
.hours{margin:1.4rem 0;border-collapse:collapse;width:100%;max-width:340px}
.hours td{padding:.55rem 0;border-bottom:1px solid var(--line);font-size:.95rem;color:#cfcfcf}
.hours td:last-child{text-align:right;color:var(--platinum)}
.hours .closed{color:var(--muted);letter-spacing:.2em;text-transform:uppercase;font-size:.78rem}
.areas a{display:block}

/* subpages (suburb + blog) */
.page-hero{padding:11rem 0 4.5rem;text-align:center;background:linear-gradient(180deg,var(--graphite),var(--black))}
.page-hero h1{font-size:clamp(2.2rem,4.5vw,3.4rem)}
.page-hero .crumbs{font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-bottom:1.2rem}
.page-hero .crumbs a{color:var(--silver)}
.page-body{padding:4rem 0}
.page-body h2{font-size:1.6rem;margin:2.2rem 0 .8rem}
.page-body p{color:#b5b0a4;margin-bottom:.8rem}
.page-body a{color:var(--silver);text-decoration:underline}
.page-body ul{margin:.6rem 0 1rem 1.2rem;color:#b5b0a4}
.page-cta{margin:2.6rem 0;display:flex;gap:1rem;flex-wrap:wrap}
.page-cta a{text-decoration:none}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.4rem;margin-top:2rem}
.blog-card{border:1px solid var(--line);background:rgba(255,255,255,.02);transition:transform .5s var(--ease),border-color .5s;display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-6px);border-color:rgba(199,199,199,.45)}
.blog-card img{width:100%;height:210px;object-fit:cover;filter:grayscale(.3)}
.blog-card-body{padding:1.6rem;display:flex;flex-direction:column;gap:.6rem;flex:1}
.blog-card h3{font-size:1.25rem}
.blog-card p{font-size:.9rem;color:var(--muted);flex:1}
.blog-card .read{font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--silver)}
.post-meta{font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted)}
.page-body a.blog-card{text-decoration:none}
.blog-card h3,.blog-card p{text-decoration:none}

/* ---------- textured silver (brushed-metal accents) ---------- */
h1 em,h2 em{-webkit-text-stroke:0;color:transparent;background:linear-gradient(110deg,#7d7d7d 0%,#e9e9e9 22%,#9b9b9b 45%,#ffffff 60%,#8a8a8a 80%,#d6d6d6 100%);-webkit-background-clip:text;background-clip:text}
.logo-mark{background:linear-gradient(145deg,rgba(232,232,232,.18),rgba(120,120,120,.06) 60%,transparent)}
.svc-meta .price,.phone-link{color:transparent;background:linear-gradient(110deg,#8d8d8d,#efefef 40%,#a8a8a8 70%,#e2e2e2);-webkit-background-clip:text;background-clip:text}
.fab-book{background:linear-gradient(120deg,#e9e9e9,#c2c2c2 55%,#f2f2f2)}
.btn-solid{background:linear-gradient(120deg,#ececec,#c6c6c6 55%,#f4f4f4);border-color:#dcdcdc}
.ig-id{display:flex;align-items:center;gap:.7rem}
.ig-id img{border-radius:50%;border:1px solid var(--line)}
.nav>a.nav-cta{color:var(--black)}
.nav>a.nav-cta::after{display:none}
.nav>a.nav-cta:hover{color:var(--platinum)}

/* ---------- Square booking panel ---------- */
.square-panel{background:rgba(255,255,255,.03);border:1px solid var(--line);padding:clamp(1.6rem,3vw,2.6rem);backdrop-filter:blur(12px)}
.square-lead{color:#bdbdbd;font-size:.98rem;margin:1.1rem 0 1.3rem}
.square-points{list-style:none;margin:0 0 1.6rem}
.square-points li{padding:.6rem 0 .6rem 1.7rem;position:relative;color:var(--platinum);font-size:.95rem;border-bottom:1px solid var(--line)}
.square-points li::before{content:"";position:absolute;left:0;top:1.05rem;width:8px;height:8px;border:1px solid var(--silver);transform:rotate(45deg)}
.square-panel .bstep-num{border-radius:50%}

/* ---------- Square inline embed ---------- */
.square-topbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.1rem;flex-wrap:wrap}
.square-newtab{font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--silver);border-bottom:1px solid var(--line);padding-bottom:.2rem;transition:color .3s,border-color .3s}
.square-newtab:hover{color:var(--white);border-color:var(--silver)}
.square-embed{position:relative;min-height:560px;border:1px solid var(--line);background:#fff;overflow:hidden}
.square-embed iframe{display:block;width:100%;height:680px;border:0}
.square-embed:empty::after{content:"Loading booking…";position:absolute;inset:0;display:grid;place-items:center;color:var(--muted);background:var(--graphite);font-size:.85rem;letter-spacing:.2em;text-transform:uppercase}
#squareBook{margin-top:1.2rem}
@media (max-width:840px){.square-embed iframe{height:600px}}

/* ---------- WhatsApp submit button ---------- */
.btn-wa svg{width:18px;height:18px;fill:currentColor;flex:none}

/* ===== forward-port overrides: new logo, add-ons, fixes ===== */
.logo-mark{height:46px;width:46px;display:block;border:0;background:none;border-radius:0;transition:transform .5s var(--ease)}
.logo:hover .logo-mark{transform:rotate(-6deg)}
.logo-word{display:flex;flex-direction:column;line-height:1}
.logo-word b{font-family:var(--font-display);font-weight:400;font-size:1.5rem;letter-spacing:.18em;color:#fff}
.logo-word small{font-family:var(--font-body);font-weight:600;font-size:.5rem;letter-spacing:.46em;text-transform:uppercase;color:var(--silver);margin-top:4px;border-top:1px solid var(--line);padding-top:4px}
.header.scrolled .logo-mark{height:40px;width:40px}
@media (max-width:840px){.logo-word b{font-size:1.3rem}.logo-mark{height:40px;width:40px}}
.m-item img{height:auto}
.svc-extras{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:.8rem 1.4rem;margin-top:2rem}
.svc-extras .extras-label{font-family:var(--font-display);font-size:1.15rem;letter-spacing:.08em;color:var(--silver)}
.svc-extras .extra{font-size:.92rem;color:#cfcdc8;border:1px solid var(--line);border-radius:40px;padding:.5rem 1.1rem}
.svc-extras .extra b{color:#fff;font-weight:700}
/* hero stacking safety (bg behind, content above) */
.hero-bg{z-index:0}
.hero-content{position:relative;z-index:2}
.scroll-hint{z-index:2}
