/* ============================================================
   Bro's Barbershop — Modern Luxe / Editorial
   Black + gold, oversized condensed display type, full-bleed
   photography, asymmetric magazine grid. Bespoke layout — not
   the agency house template.
   ============================================================ */
:root{
  --ink:#0c0b0a;          /* warm near-black */
  --ink-2:#121110;        /* raised panel */
  --ink-3:#1a1815;        /* card */
  --paper:#f4f1ea;        /* warm white text */
  --muted:#a39c8f;        /* warm grey */
  --muted-2:#6f685d;
  --gold:#c9a227;
  --gold-lite:#e8ce7a;
  --gold-deep:#8a6d22;
  --hair:rgba(233,206,122,.22);     /* gold hairline */
  --hair-soft:rgba(255,255,255,.08);
  --display:'Bebas Neue', 'Arial Narrow', sans-serif;
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
  --maxw:1240px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--ink);
  color:var(--paper);
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img,svg,iframe{max-width:100%;display:block}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 28px}
::selection{background:var(--gold);color:var(--ink)}

/* ---------- Type primitives ---------- */
.kicker{
  font-family:var(--serif);font-style:italic;font-weight:600;
  font-size:1.05rem;letter-spacing:.3px;color:var(--gold-lite);
  display:inline-flex;align-items:center;gap:12px;
}
.kicker::before{content:"";width:34px;height:1px;background:var(--gold);display:inline-block}
.display{font-family:var(--display);font-weight:400;line-height:.92;letter-spacing:.5px;text-transform:uppercase}
.gold{color:var(--gold)}
.outline{color:transparent;-webkit-text-stroke:1.2px var(--gold)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  font-family:var(--display);font-size:1.18rem;letter-spacing:1.2px;text-transform:uppercase;
  padding:.62em 1.5em;border:1px solid transparent;border-radius:2px;cursor:pointer;
  transition:transform .4s var(--ease),background .3s,color .3s,border-color .3s,box-shadow .3s;
}
.btn svg{width:1em;height:1em;fill:none;stroke:currentColor;stroke-width:2;flex:none}
.btn--gold{background:var(--gold);color:var(--ink);box-shadow:0 0 0 0 rgba(201,162,39,.5)}
.btn--gold:hover{background:var(--gold-lite);transform:translateY(-2px);box-shadow:0 16px 34px -14px rgba(201,162,39,.8)}
.btn--line{background:transparent;color:var(--paper);border-color:var(--hair)}
.btn--line:hover{border-color:var(--gold);color:var(--gold-lite);transform:translateY(-2px)}
.btn--lg{font-size:1.34rem;padding:.66em 1.7em}

/* ---------- Scroll progress ---------- */
.progress{position:fixed;top:0;left:0;height:2px;width:0;z-index:300;background:linear-gradient(90deg,var(--gold-deep),var(--gold-lite))}

/* ---------- Header ---------- */
.header{position:sticky;top:0;z-index:140;border-bottom:1px solid transparent;transition:background .4s,border-color .4s,backdrop-filter .4s}
.header.scrolled{background:rgba(12,11,10,.86);backdrop-filter:blur(12px);border-bottom-color:var(--hair)}
.header__in{display:flex;align-items:center;gap:28px;height:84px}
.brand{display:inline-flex;align-items:center;gap:14px}
.brand img{height:50px;width:auto}
.brand__name{font-family:var(--display);font-size:1.5rem;letter-spacing:2px;line-height:.9}
.brand__name small{display:block;font-family:var(--serif);font-style:italic;font-size:.72rem;letter-spacing:.5px;color:var(--gold-lite);text-transform:none}
.nav{display:flex;gap:30px;margin-left:auto}
.nav a{font-family:var(--display);font-size:1.06rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);position:relative;padding:4px 0;transition:color .25s}
.nav a:hover{color:var(--paper)}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1px;background:var(--gold);transition:right .35s var(--ease)}
.nav a:hover::after{right:0}
.header__cta{display:flex;align-items:center;gap:14px}
.header__cta .call{font-family:var(--display);font-size:1.1rem;letter-spacing:1px;color:var(--paper);display:inline-flex;align-items:center;gap:8px}
.header__cta .call svg{width:16px;height:16px;fill:var(--gold);stroke:none}
.header__cta .call:hover{color:var(--gold-lite)}
.burger{display:none;flex-direction:column;gap:5px;width:46px;height:46px;align-items:center;justify-content:center;background:transparent;border:1px solid var(--hair);border-radius:2px;cursor:pointer;margin-left:auto}
.burger span{width:22px;height:1.5px;background:var(--paper);transition:.3s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.mobile-menu{position:fixed;inset:0 0 0 auto;width:min(88vw,380px);background:var(--ink-2);border-left:1px solid var(--hair);z-index:135;padding:108px 34px 40px;display:flex;flex-direction:column;gap:4px;transform:translateX(105%);transition:transform .5s var(--ease)}
.mobile-menu.open{transform:none}
.mobile-menu a{font-family:var(--display);font-size:1.6rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);padding:13px 0;border-bottom:1px solid var(--hair-soft)}
.mobile-menu a:hover{color:var(--gold-lite)}
.mobile-menu .btn{margin-top:18px;border-bottom:none}
@media(max-width:960px){.nav,.header__cta .call,.header__cta .btn{display:none}.burger{display:flex}}

/* ---------- Ticker ---------- */
.ticker{border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);background:var(--ink-2);overflow:hidden}
.ticker__row{display:flex;gap:46px;white-space:nowrap;width:max-content;padding:13px 0;animation:slide 38s linear infinite}
.ticker span{font-family:var(--display);font-size:1.04rem;letter-spacing:3px;text-transform:uppercase;color:var(--muted)}
.ticker b{color:var(--gold);font-weight:400}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Hero ---------- */
.hero{position:relative;display:grid;grid-template-columns:1.08fr .92fr;min-height:92vh;border-bottom:1px solid var(--hair)}
.hero__text{display:flex;flex-direction:column;justify-content:center;padding:80px 0 80px clamp(28px,7vw,110px);padding-right:48px}
.hero__title{font-family:var(--display);font-weight:400;text-transform:uppercase;line-height:.86;letter-spacing:1px;font-size:clamp(3.6rem,9vw,8.2rem);margin:24px 0 26px}
.hero__title .ln{display:block;overflow:hidden}
.hero__sub{font-family:var(--serif);font-size:clamp(1.15rem,2vw,1.5rem);color:#d8d2c6;max-width:30ch;margin-bottom:34px;line-height:1.5}
.hero__cta{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:40px}
.hero__meta{display:flex;flex-wrap:wrap;gap:26px;padding-top:26px;border-top:1px solid var(--hair)}
.hero__meta div{display:flex;flex-direction:column}
.hero__meta b{font-family:var(--display);font-size:1.5rem;letter-spacing:1px;color:var(--paper);line-height:1}
.hero__meta span{font-size:.78rem;letter-spacing:.5px;color:var(--muted);margin-top:6px;text-transform:uppercase}
.hero__media{position:relative;overflow:hidden;border-left:1px solid var(--hair)}
.hero__media img{width:100%;height:100%;object-fit:cover;filter:grayscale(.15) contrast(1.06)}
.hero__media::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,var(--ink) 0%,transparent 38%),linear-gradient(0deg,rgba(12,11,10,.5),transparent 40%)}
.hero__stamp{position:absolute;right:26px;top:50%;transform:translateY(-50%) rotate(90deg);transform-origin:right center;font-family:var(--display);letter-spacing:6px;font-size:.9rem;color:var(--gold-lite);z-index:2;text-transform:uppercase}
@media(max-width:860px){
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero__media{order:-1;height:54vh;border-left:none;border-bottom:1px solid var(--hair)}
  .hero__text{padding:54px 28px 64px}
  .hero__stamp{display:none}
}

/* ---------- Section frame ---------- */
.section{padding:clamp(72px,10vw,128px) 0;position:relative}
.section--alt{background:var(--ink-2)}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:clamp(40px,5vw,64px);flex-wrap:wrap}
.sec-head h2{font-family:var(--display);font-weight:400;text-transform:uppercase;line-height:.9;letter-spacing:1px;font-size:clamp(2.6rem,6vw,5rem)}
.sec-head p{font-family:var(--serif);font-style:italic;font-size:1.2rem;color:var(--muted);max-width:34ch}

/* ---------- Service menu (numbered editorial rows) ---------- */
.menu{border-top:1px solid var(--hair)}
.menu__row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:clamp(18px,4vw,52px);
  padding:clamp(22px,3.4vw,40px) 6px;border-bottom:1px solid var(--hair);position:relative;transition:padding-left .4s var(--ease)}
.menu__row::before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(90deg,rgba(201,162,39,.10),transparent);transition:width .45s var(--ease)}
.menu__row:hover{padding-left:24px}
.menu__row:hover::before{width:100%}
.menu__num{font-family:var(--display);font-size:clamp(1.6rem,3vw,2.4rem);color:transparent;-webkit-text-stroke:1px var(--gold-deep);letter-spacing:1px;position:relative;z-index:1}
.menu__name{font-family:var(--display);font-size:clamp(1.9rem,4vw,3.1rem);letter-spacing:1px;text-transform:uppercase;line-height:1;position:relative;z-index:1;transition:color .3s}
.menu__row:hover .menu__name{color:var(--gold-lite)}
.menu__desc{font-size:.96rem;color:var(--muted);max-width:34ch;text-align:right;position:relative;z-index:1}
@media(max-width:720px){
  .menu__row{grid-template-columns:auto 1fr;gap:16px 18px}
  .menu__desc{grid-column:1/-1;text-align:left;max-width:none;padding-left:0}
}

/* ---------- Cinematic band ---------- */
.band{position:relative;min-height:64vh;display:grid;place-items:center;text-align:center;overflow:hidden;border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.band img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(.4) brightness(.4) contrast(1.05)}
.band__in{position:relative;z-index:1;padding:60px 28px;max-width:900px}
.band__in q{font-family:var(--serif);font-style:italic;font-size:clamp(1.7rem,4.4vw,3.4rem);line-height:1.25;color:var(--paper);quotes:none}
.band__in cite{display:block;margin-top:24px;font-family:var(--display);letter-spacing:3px;font-style:normal;font-size:1rem;color:var(--gold-lite);text-transform:uppercase}

/* ---------- Gallery (asymmetric mosaic) ---------- */
.mosaic{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:clamp(150px,22vw,260px);gap:14px}
.shot{position:relative;overflow:hidden;border:1px solid var(--hair);cursor:pointer;border-radius:2px}
.shot img{width:100%;height:100%;object-fit:cover;filter:grayscale(.1) contrast(1.05);transition:transform .7s var(--ease),filter .5s}
.shot:hover img{transform:scale(1.06);filter:none}
.shot figcaption{position:absolute;left:0;right:0;bottom:0;padding:30px 16px 14px;font-family:var(--display);letter-spacing:1.5px;text-transform:uppercase;font-size:1rem;color:var(--paper);background:linear-gradient(transparent,rgba(12,11,10,.85));opacity:0;transform:translateY(10px);transition:.4s var(--ease)}
.shot:hover figcaption{opacity:1;transform:none}
.shot::after{content:"+";position:absolute;top:10px;right:14px;font-family:var(--display);font-size:1.6rem;color:var(--gold);opacity:0;transition:.3s var(--ease)}
.shot:hover::after{opacity:1}
.shot--a{grid-column:span 2;grid-row:span 2}
.shot--b{grid-column:span 2;grid-row:span 1}
.shot--c{grid-column:span 2;grid-row:span 1}
.shot--d{grid-column:span 2;grid-row:span 1}
.shot--e{grid-column:span 2;grid-row:span 1}
.mosaic__cta{margin-top:34px;display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:center}
@media(max-width:760px){
  .mosaic{grid-template-columns:1fr 1fr;grid-auto-rows:42vw}
  .shot--a,.shot--b,.shot--c,.shot--d,.shot--e{grid-column:span 1;grid-row:span 1}
  .shot--a{grid-column:span 2}
}

/* ---------- Reviews ---------- */
.feature-quote{max-width:1000px;margin:0 auto 56px;text-align:center}
.feature-quote .mark{font-family:var(--serif);font-size:5rem;line-height:.3;color:var(--gold);display:block;margin-bottom:18px}
.feature-quote q{font-family:var(--serif);font-style:italic;font-size:clamp(1.5rem,3.6vw,2.6rem);line-height:1.3;quotes:none}
.feature-quote cite{display:block;margin-top:26px;font-style:normal}
.feature-quote cite b{font-family:var(--display);letter-spacing:2px;text-transform:uppercase;color:var(--paper);font-size:1.15rem}
.feature-quote cite span{display:block;font-size:.8rem;letter-spacing:1px;color:var(--gold-lite);text-transform:uppercase;margin-top:4px}
.quotes{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--hair)}
.quotes .q{padding:34px clamp(20px,3vw,40px);border-bottom:1px solid var(--hair)}
.quotes .q:nth-child(odd){border-right:1px solid var(--hair)}
.q__stars{color:var(--gold);letter-spacing:3px;font-size:.95rem;margin-bottom:14px}
.q p{font-size:1.02rem;color:#ddd6c9;margin-bottom:16px}
.q__by{font-family:var(--display);letter-spacing:1.5px;text-transform:uppercase;color:var(--paper);font-size:1.05rem}
.q__by span{font-family:var(--sans);display:block;font-size:.72rem;letter-spacing:.5px;color:var(--muted-2);text-transform:none;margin-top:2px}
.reviews-foot{text-align:center;margin-top:44px;display:flex;flex-direction:column;align-items:center;gap:18px}
.gbadge{display:inline-flex;align-items:center;gap:10px;font-family:var(--display);letter-spacing:1.5px;text-transform:uppercase;color:var(--muted)}
.gbadge b{color:var(--paper);font-size:1.4rem}
.gbadge .stars{color:var(--gold);letter-spacing:2px}
@media(max-width:680px){.quotes{grid-template-columns:1fr}.quotes .q:nth-child(odd){border-right:none}}

/* ---------- Barbers ---------- */
.barbers{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:1px solid var(--hair)}
.barber{padding:clamp(28px,3.4vw,44px);border-right:1px solid var(--hair)}
.barber:last-child{border-right:none}
.barber__name{font-family:var(--display);font-size:clamp(2rem,4vw,2.8rem);letter-spacing:1.5px;text-transform:uppercase;line-height:1}
.barber__role{font-family:var(--serif);font-style:italic;color:var(--gold-lite);font-size:1.1rem;margin:6px 0 14px}
.barber p{color:var(--muted);font-size:.95rem}
@media(max-width:760px){.barbers{grid-template-columns:1fr}.barber{border-right:none;border-bottom:1px solid var(--hair)}.barber:last-child{border-bottom:none}}

/* ---------- Visit + book ---------- */
.visit{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--hair)}
.visit__info{padding:clamp(30px,4vw,56px);border-right:1px solid var(--hair)}
.visit__info h3{font-family:var(--display);font-size:clamp(2rem,4vw,3rem);letter-spacing:1px;text-transform:uppercase;margin-bottom:26px}
.vlist{list-style:none;display:grid;gap:22px;margin-bottom:30px}
.vlist li{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:start}
.vlist .ic{width:42px;height:42px;border:1px solid var(--hair);border-radius:2px;display:grid;place-items:center;flex:none}
.vlist .ic svg{width:18px;height:18px;fill:none;stroke:var(--gold);stroke-width:1.6}
.vlist .lab{font-family:var(--display);letter-spacing:1.5px;text-transform:uppercase;font-size:.86rem;color:var(--muted)}
.vlist a,.vlist .val{color:var(--paper);font-size:1.05rem}
.vlist a:hover{color:var(--gold-lite)}
.openrow{display:inline-flex;align-items:center;gap:9px}
.dot{width:8px;height:8px;border-radius:50%;background:var(--muted-2)}
.dot.open{background:#3ec07a;box-shadow:0 0 0 4px rgba(62,192,122,.18)}
.dot.closed{background:var(--gold-deep)}
.socials{display:flex;gap:12px;flex-wrap:wrap}
.socials a{font-family:var(--display);letter-spacing:1.5px;text-transform:uppercase;font-size:.92rem;color:var(--muted);border:1px solid var(--hair);border-radius:2px;padding:7px 14px;transition:.3s}
.socials a:hover{color:var(--gold-lite);border-color:var(--gold)}
.visit__map{min-height:340px}
.visit__map iframe{width:100%;height:100%;border:0;filter:grayscale(.5) contrast(1.1) brightness(.85)}
@media(max-width:820px){.visit{grid-template-columns:1fr}.visit__info{border-right:none;border-bottom:1px solid var(--hair)}.visit__map{min-height:300px}}

.final-cta{text-align:center;max-width:680px;margin:0 auto}
.final-cta h2{font-family:var(--display);font-size:clamp(2.8rem,7vw,5rem);letter-spacing:1px;text-transform:uppercase;line-height:.9;margin:18px 0}
.final-cta p{font-family:var(--serif);font-style:italic;font-size:1.3rem;color:var(--muted);margin-bottom:34px}
.final-cta__btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ---------- Footer ---------- */
.footer{border-top:1px solid var(--hair);padding:70px 0 30px;background:var(--ink-2)}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:50px}
.footer__brand img{height:78px;width:auto;margin-bottom:16px}
.footer__brand p{color:var(--muted);max-width:32ch;font-family:var(--serif);font-style:italic;font-size:1.1rem}
.footer__col h4{font-family:var(--display);letter-spacing:2px;text-transform:uppercase;color:var(--gold-lite);font-size:.95rem;margin-bottom:16px}
.footer__col a,.footer__col span{display:block;color:var(--muted);padding:5px 0;font-size:.96rem}
.footer__col a:hover{color:var(--paper)}
.footer__bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;border-top:1px solid var(--hair-soft);padding-top:24px;color:var(--muted-2);font-size:.82rem;letter-spacing:.5px}
@media(max-width:760px){.footer__top{grid-template-columns:1fr 1fr}.footer__brand{grid-column:1/-1}}

/* ---------- Mobile sticky bar ---------- */
.mbar{position:fixed;left:0;right:0;bottom:0;z-index:120;display:none;gap:10px;padding:11px 14px calc(11px + env(safe-area-inset-bottom));background:rgba(12,11,10,.92);backdrop-filter:blur(12px);border-top:1px solid var(--hair)}
.mbar .btn{flex:1;font-size:1.1rem;padding:.7em 1em}
@media(max-width:960px){.mbar{display:flex}body{padding-bottom:76px}}

/* ---------- Lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:300;display:none;align-items:center;justify-content:center;background:rgba(8,7,6,.96);backdrop-filter:blur(6px);padding:30px}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:84vh;border:1px solid var(--hair)}
.lightbox button{position:absolute;background:transparent;border:1px solid var(--hair);color:var(--paper);width:50px;height:50px;border-radius:2px;cursor:pointer;font-size:1.5rem;display:grid;place-items:center;transition:.25s}
.lightbox button:hover{border-color:var(--gold);color:var(--gold-lite)}
.lb-close{top:24px;right:24px}
.lb-prev{top:50%;left:20px;transform:translateY(-50%)}
.lb-next{top:50%;right:20px;transform:translateY(-50%)}
.lb-cap{position:absolute;bottom:26px;left:0;right:0;text-align:center;font-family:var(--display);letter-spacing:2px;text-transform:uppercase;color:var(--gold-lite)}

/* ---------- Toast ---------- */
.toast{position:fixed;bottom:26px;left:50%;transform:translate(-50%,160%);z-index:320;display:flex;align-items:center;gap:13px;background:var(--ink-3);border:1px solid var(--gold);border-radius:3px;padding:16px 22px;transition:transform .5s var(--ease);max-width:90vw}
.toast.show{transform:translate(-50%,0)}
.toast svg{width:24px;height:24px;stroke:var(--gold);fill:none;flex:none}
.toast strong{font-family:var(--display);letter-spacing:1.5px;text-transform:uppercase}
@media(max-width:960px){.toast{bottom:90px}}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
