/* ============================================================
   New Style Hair Design — Design System  ("The Chair Since '67")
   Palette: Oxblood & Bone · Type: Anton / DM Serif Display / Inter
   ============================================================ */

:root{
  /* colour */
  --ink:#15120D; --ink-2:#211C14; --ink-3:#2C2519;
  --bone:#F4EEE2; --bone-2:#EAE0CC; --bone-3:#E1D4BC;
  --oxblood:#9E2B25; --oxblood-dk:#7C211C; --ember:#C8432F;
  --brass:#B07D3B; --brass-lt:#C99A57; --walnut:#5A4632;
  --ink-soft:#4A4334;            /* muted text on bone (AA on bone) */
  --line:rgba(21,18,13,.14);     /* hairline on bone */
  --line-d:rgba(244,238,226,.16);/* hairline on ink  */

  /* type */
  --f-display:'Anton',Impact,'Arial Narrow Bold',sans-serif;
  --f-serif:'DM Serif Display',Georgia,'Times New Roman',serif;
  --f-body:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;

  /* scale */
  --step--1:clamp(.82rem,.78rem + .2vw,.92rem);
  --step-0:clamp(1rem,.96rem + .2vw,1.08rem);
  --step-1:clamp(1.2rem,1.1rem + .5vw,1.4rem);
  --step-2:clamp(1.6rem,1.35rem + 1.1vw,2.1rem);
  --step-3:clamp(2.2rem,1.7rem + 2.4vw,3.4rem);
  --step-4:clamp(3rem,2rem + 4.6vw,6rem);
  --step-5:clamp(3.6rem,2rem + 7vw,8.5rem);

  /* space + shape */
  --container:1200px; --gutter:clamp(1.1rem,4vw,2.4rem);
  --r:4px; --r-lg:10px;
  --shadow:0 1px 2px rgba(21,18,13,.06),0 12px 34px -16px rgba(21,18,13,.30);
  --shadow-d:0 18px 50px -20px rgba(0,0,0,.7);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth }
html.lenis,html.lenis body{ scroll-behavior:auto !important } /* Lenis guard */
body{
  font-family:var(--f-body); font-size:var(--step-0); line-height:1.65;
  color:var(--ink); background:var(--bone);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{display:block; max-width:100%; height:auto}
a{color:inherit; text-decoration:none}
button{font:inherit; color:inherit; cursor:pointer; background:none; border:none}
ul{list-style:none; padding:0}
:focus-visible{ outline:3px solid var(--oxblood); outline-offset:3px; border-radius:2px }

/* ---------- type ---------- */
h1,h2,h3{ font-family:var(--f-display); font-weight:400; line-height:.96;
  text-transform:uppercase; letter-spacing:.01em; }
h1{font-size:var(--step-4)} h2{font-size:var(--step-3)} h3{font-size:var(--step-2)}
.serif{font-family:var(--f-serif)}
p{ max-width:66ch }
.lede{ font-size:var(--step-1); line-height:1.5; color:var(--ink-soft) }

.eyebrow{ font-family:var(--f-body); font-weight:700; font-size:.74rem;
  text-transform:uppercase; letter-spacing:.28em; color:var(--brass);
  display:inline-flex; align-items:center; gap:.7rem; }
.eyebrow::before{ content:""; width:30px; height:2px; background:var(--brass); display:inline-block }
.eyebrow.center{ justify-content:center }
.eyebrow.on-dark{ color:var(--brass-lt) }

/* ---------- layout ---------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gutter) }
.container--wide{ max-width:1380px }
section{ padding-block:clamp(3.6rem,8vw,7rem) }
.section-dark{ background:var(--ink); color:var(--bone) }
.section-dark .lede,.section-dark p{ color:rgba(244,238,226,.74) }
.section-cream{ background:var(--bone-2) }
.stack>*+*{ margin-top:1.1rem }
.grid{ display:grid; gap:clamp(1rem,2.5vw,1.6rem) }
.text-center{ text-align:center }
.mx-auto{ margin-inline:auto }

/* ---------- greek-key divider ---------- */
.meander{ height:14px; width:100%;
  background:
   repeating-linear-gradient(90deg, var(--brass) 0 2px, transparent 2px 8px) 0 0/100% 2px no-repeat,
   repeating-linear-gradient(90deg, var(--brass) 0 2px, transparent 2px 8px) 0 100%/100% 2px no-repeat;
  opacity:.5; }
.rule{ height:1px; background:var(--line); border:0 }
.section-dark .rule{ background:var(--line-d) }

/* ---------- buttons ---------- */
.btn{ position:relative; display:inline-flex; align-items:center; gap:.6rem;
  font-weight:700; font-size:.96rem; letter-spacing:.02em; padding:.95rem 1.6rem;
  border-radius:var(--r); overflow:hidden; transition:transform .25s var(--ease), background .25s, color .25s, box-shadow .25s; }
.btn:active{ transform:translateY(1px) }
.btn--primary{ background:var(--oxblood); color:#fff; box-shadow:0 10px 24px -12px rgba(158,43,37,.8) }
.btn--primary:hover{ background:var(--oxblood-dk) }
.btn--primary::after{ /* sheen sweep */
  content:""; position:absolute; top:0; left:-80%; width:55%; height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.35),transparent);
  transform:skewX(-18deg); transition:left .6s var(--ease); }
.btn--primary:hover::after{ left:130% }
.btn--ghost{ border:1.5px solid currentColor; color:var(--ink) }
.btn--ghost:hover{ background:var(--ink); color:var(--bone) }
.section-dark .btn--ghost{ color:var(--bone) }
.section-dark .btn--ghost:hover{ background:var(--bone); color:var(--ink) }
.btn--brass{ background:var(--brass); color:var(--ink) }
.btn--brass:hover{ background:var(--brass-lt) }
.btn--lg{ padding:1.1rem 2rem; font-size:1.02rem }
.btn .ico{ width:18px; height:18px; flex:none }

/* ---------- header ---------- */
.site-header{ position:sticky; top:0; z-index:120;
  background:color-mix(in srgb, var(--bone) 86%, transparent); backdrop-filter:blur(10px) saturate(1.1);
  border-bottom:1px solid var(--line); transition:padding .3s var(--ease), background .3s; }
.site-header.scrolled{ background:color-mix(in srgb, var(--bone) 95%, transparent) }
.nav{ display:flex; align-items:center; justify-content:space-between; gap:1.4rem;
  padding-block:.85rem; transition:padding .3s var(--ease) }
.scrolled .nav{ padding-block:.55rem }
.brand{ display:flex; align-items:center; gap:.7rem; flex:none }
.brand img{ width:46px; height:46px; transition:width .3s var(--ease),height .3s }
.scrolled .brand img{ width:40px; height:40px }
.brand b{ font-family:var(--f-display); font-size:1.18rem; letter-spacing:.03em; line-height:1; text-transform:uppercase }
.brand span{ display:block; font-size:.6rem; letter-spacing:.34em; color:var(--brass); font-weight:700; margin-top:2px }
.nav-links{ display:flex; align-items:center; gap:1.6rem }
.nav-links a{ font-weight:600; font-size:.92rem; position:relative; padding:.25rem 0; letter-spacing:.01em }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:-2px; width:0; height:2px;
  background:var(--oxblood); transition:width .3s var(--ease) }
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{ width:100% }
.nav-cta{ display:flex; align-items:center; gap:.8rem }
.nav-toggle{ display:none; width:46px; height:46px; align-items:center; justify-content:center }
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{
  content:""; display:block; width:24px; height:2px; background:var(--ink); transition:.3s var(--ease) }
.nav-toggle span::before{ transform:translateY(-7px) } .nav-toggle span::after{ transform:translateY(5px) }
.nav-open .nav-toggle span{ background:transparent }
.nav-open .nav-toggle span::before{ transform:rotate(45deg) }
.nav-open .nav-toggle span::after{ transform:rotate(-45deg) }

/* mobile drawer */
.drawer{ position:fixed; inset:0 0 0 auto; width:min(86vw,340px); background:var(--ink); color:var(--bone);
  z-index:115; transform:translateX(100%); transition:transform .4s var(--ease);
  padding:5.5rem 2rem 2rem; display:flex; flex-direction:column; gap:.4rem; box-shadow:var(--shadow-d) }
.nav-open .drawer{ transform:translateX(0) }
.drawer a{ font-family:var(--f-display); font-size:1.5rem; text-transform:uppercase; padding:.6rem 0;
  border-bottom:1px solid var(--line-d) }
.drawer .btn{ margin-top:1.2rem }
.scrim{ position:fixed; inset:0; background:rgba(0,0,0,.5); opacity:0; visibility:hidden; z-index:114;
  transition:opacity .4s } .nav-open .scrim{ opacity:1; visibility:visible }

/* ---------- cards ---------- */
.card{ position:relative; background:var(--bone); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:1.5rem; overflow:hidden; transition:transform .3s var(--ease),box-shadow .3s; }
.card::before{ content:""; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--brass) 40%,var(--brass-lt) 50%,var(--brass) 60%,transparent); opacity:.7 }
.card:hover{ transform:translateY(-5px); box-shadow:var(--shadow) }
.section-dark .card,.card--dark{ background:var(--ink-2); border-color:var(--line-d); color:var(--bone) }

/* service card */
.svc{ display:flex; flex-direction:column; gap:.5rem }
.svc h3{ font-size:1.55rem }
.svc .price{ font-family:var(--f-serif); font-size:2rem; color:var(--oxblood); line-height:1 }
.section-dark .svc .price{ color:var(--ember) }
.svc .who{ font-size:.8rem; text-transform:uppercase; letter-spacing:.16em; color:var(--brass); font-weight:700 }
.svc p{ color:var(--ink-soft); font-size:.95rem }
.section-dark .svc p{ color:rgba(244,238,226,.7) }

/* ---------- price list (rates table) ---------- */
.rates{ width:100%; border-collapse:collapse; font-size:1.05rem }
.rates th,.rates td{ padding:1rem .4rem; text-align:left; border-bottom:1px solid var(--line-d) }
.rates td:last-child{ text-align:right; font-family:var(--f-serif); font-size:1.5rem; color:var(--ember); white-space:nowrap }
.rates .who2{ color:var(--brass-lt); font-size:.82rem; text-transform:uppercase; letter-spacing:.14em; display:block }
.rates tr:hover td{ background:rgba(176,125,59,.07) }

/* ---------- location card ---------- */
.loc{ display:grid; gap:1rem }
.loc h3{ font-size:1.7rem }
.loc .addr{ font-style:normal; color:var(--ink-soft); line-height:1.5 }
.section-dark .loc .addr{ color:rgba(244,238,226,.74) }
.loc .hours{ font-size:.92rem; display:grid; grid-template-columns:auto 1fr; gap:.15rem 1rem }
.loc .hours dt{ color:var(--brass); font-weight:600 }
.loc .hours dd{ text-align:right; font-variant-numeric:tabular-nums }
.loc .closed{ color:var(--oxblood); font-weight:600 }
.section-dark .loc .closed{ color:var(--ember) }

/* ---------- marquee ---------- */
.marquee{ overflow:hidden; background:var(--ink); color:var(--bone); padding-block:1.1rem;
  border-block:1px solid var(--line-d) }
.marquee__track{ display:flex; gap:2.5rem; width:max-content; will-change:transform; animation:marq 28s linear infinite }
.marquee__track span{ font-family:var(--f-display); font-size:clamp(1.3rem,3vw,2.2rem); text-transform:uppercase;
  letter-spacing:.04em; display:inline-flex; align-items:center; gap:2.5rem }
.marquee__track span::after{ content:"✦"; color:var(--brass); font-size:.7em }
.marquee__track .outline{ color:transparent; -webkit-text-stroke:1px var(--brass-lt) }
.marquee:hover .marquee__track{ animation-play-state:paused }
@keyframes marq{ to{ transform:translateX(-50%) } }

/* ---------- barber pole accent ---------- */
.pole{ --pw:18px; width:var(--pw); border-radius:calc(var(--pw)/2); overflow:hidden;
  background:repeating-linear-gradient(45deg,#fff 0 10px,var(--oxblood) 10px 20px,#fff 20px 30px,var(--ink) 30px 40px);
  background-size:100% 56px; animation:pole 1.6s linear infinite; border:1px solid rgba(0,0,0,.2) }
@keyframes pole{ to{ background-position:0 -56px } }

/* ---------- stats ---------- */
.stats{ display:grid; grid-template-columns:repeat(3,1fr) }
.stat{ text-align:center; padding:1.2rem .5rem; position:relative }
.stat+.stat::before{ content:""; position:absolute; left:0; top:18%; height:64%; width:1px;
  background:linear-gradient(var(--line-d),transparent) }
.stat .n{ font-family:var(--f-serif); font-size:clamp(2.4rem,6vw,3.6rem); line-height:1; color:var(--brass-lt) }
.stat .l{ font-size:.74rem; text-transform:uppercase; letter-spacing:.2em; color:rgba(244,238,226,.7); margin-top:.5rem }

/* ---------- gallery ---------- */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); gap:.7rem }
.gallery figure{ position:relative; overflow:hidden; border-radius:var(--r); aspect-ratio:1; background:var(--ink-2) }
.gallery img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.55) contrast(1.04);
  transition:filter .5s var(--ease),transform .7s var(--ease) }
.gallery figure:hover img{ filter:grayscale(0) contrast(1); transform:scale(1.06) }
.gallery .tall{ grid-row:span 2; aspect-ratio:auto }

/* ---------- forms ---------- */
.field{ display:grid; gap:.4rem; margin-bottom:1.1rem }
.field label{ font-weight:600; font-size:.86rem; letter-spacing:.02em }
.field .req{ color:var(--oxblood) }
.field input,.field select,.field textarea{ font:inherit; padding:.85rem 1rem; border:1.5px solid var(--line);
  border-radius:var(--r); background:var(--bone); color:var(--ink); transition:border-color .2s,box-shadow .2s }
.section-dark .field input,.section-dark .field select,.section-dark .field textarea{
  background:var(--ink-2); border-color:var(--line-d); color:var(--bone) }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--oxblood);
  box-shadow:0 0 0 3px rgba(158,43,37,.18) }
.field .help{ font-size:.78rem; color:var(--ink-soft) }
.form-note{ font-size:.82rem; color:var(--ink-soft) }

/* ---------- footer ---------- */
.site-footer{ background:var(--ink); color:var(--bone); position:relative; overflow:hidden; padding-top:clamp(3rem,7vw,5rem) }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:2rem; position:relative; z-index:2 }
.site-footer h4{ font-family:var(--f-body); font-weight:700; text-transform:uppercase; letter-spacing:.18em;
  font-size:.76rem; color:var(--brass); margin-bottom:1rem }
.site-footer a{ color:rgba(244,238,226,.78); font-size:.94rem; display:inline-block; padding:.18rem 0; transition:color .2s }
.site-footer a:hover{ color:var(--bone) }
.foot-brand img{ width:62px; margin-bottom:1rem }
.foot-brand p{ color:rgba(244,238,226,.6); font-size:.9rem }
.foot-social{ display:flex; gap:.8rem; margin-top:1rem }
.foot-social a{ width:40px; height:40px; border:1px solid var(--line-d); border-radius:50%;
  display:grid; place-items:center } .foot-social a:hover{ border-color:var(--brass); background:var(--ink-2) }
.foot-social svg{ width:18px; height:18px }
.foot-bottom{ border-top:1px solid var(--line-d); margin-top:2.5rem; padding-block:1.4rem; position:relative; z-index:2;
  display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-size:.82rem; color:rgba(244,238,226,.55) }
.foot-watermark{ position:absolute; left:50%; bottom:-2.5vw; transform:translateX(-50%); z-index:1;
  font-family:var(--f-display); font-size:18vw; line-height:.8; color:transparent;
  -webkit-text-stroke:1px rgba(244,238,226,.07); white-space:nowrap; pointer-events:none; text-transform:uppercase }

/* ---------- custom cursor ---------- */
.cur-dot,.cur-ring{ position:fixed; top:0; left:0; border-radius:50%; pointer-events:none; z-index:9999;
  transform:translate(-50%,-50%); opacity:0; transition:opacity .3s }
.cur-dot{ width:7px; height:7px; background:var(--oxblood) }
.cur-ring{ width:34px; height:34px; border:1.5px solid var(--brass); transition:width .25s,height .25s,background .25s,opacity .3s }
html.has-cursor.cursor-ready .cur-dot,html.has-cursor.cursor-ready .cur-ring{ opacity:1 }
html.has-cursor.cursor-ready *{ cursor:none }
html.has-cursor.cursor-ready input,html.has-cursor.cursor-ready textarea,html.has-cursor.cursor-ready select{ cursor:auto }
.cur-ring.hover{ width:54px; height:54px; background:rgba(176,125,59,.12) }
.cur-ring.press{ width:26px; height:26px }

/* ---------- reveals ---------- */
[data-reveal]{ opacity:0 }
@media (prefers-reduced-motion:reduce){ [data-reveal]{ opacity:1 !important; transform:none !important } }

/* ---------- page hero (inner pages) ---------- */
.page-hero{ background:var(--ink); color:var(--bone); position:relative; overflow:hidden;
  padding-block:clamp(4.5rem,11vw,8rem) }
.page-hero::after{ content:""; position:absolute; inset:0; opacity:.16; mix-blend-mode:luminosity;
  background-size:cover; background-position:center }
.page-hero[data-img="brand"]::after{ background-image:url(../img/brand-flatlay.webp) }
.page-hero[data-img="chairs"]::after{ background-image:url(../img/barber-chairs.webp) }
.page-hero[data-img="shave"]::after{ background-image:url(../img/straight-razor-shave.webp) }
.page-hero[data-img="clippers"]::after{ background-image:url(../img/wahl-clippers.webp) }
.page-hero[data-img="tools"]::after{ background-image:url(../img/tools-flatlay.webp) }
.page-hero .container{ position:relative; z-index:2 }
.page-hero h1{ font-size:var(--step-5); max-width:18ch }
.page-hero .lede{ color:rgba(244,238,226,.78); max-width:60ch; margin-top:1rem }
.breadcrumb{ font-size:.8rem; letter-spacing:.04em; color:var(--brass-lt); margin-bottom:1.4rem }
.breadcrumb a:hover{ color:var(--bone) }

/* ---------- quick-answer + key-facts (AEO) ---------- */
.quick-answer{ border-left:3px solid var(--brass); background:rgba(176,125,59,.08); padding:1.1rem 1.3rem;
  border-radius:0 var(--r) var(--r) 0; margin-block:1.4rem; max-width:70ch }
.quick-answer .qa-label{ font-size:.72rem; text-transform:uppercase; letter-spacing:.2em; color:var(--brass); font-weight:700; margin-bottom:.3rem }
.key-facts{ width:100%; border-collapse:collapse; margin-block:1.4rem }
.key-facts th,.key-facts td{ text-align:left; padding:.7rem .8rem; border-bottom:1px solid var(--line); font-size:.95rem }
.key-facts th{ width:38%; color:var(--ink-soft); font-weight:600 }
.section-dark .key-facts th,.section-dark .key-facts td{ border-color:var(--line-d) }
.section-dark .key-facts th{ color:var(--brass-lt) }

/* ---------- FAQ ---------- */
.faqs details{ border-bottom:1px solid var(--line); padding:1.1rem 0 }
.section-dark .faqs details{ border-color:var(--line-d) }
.faqs summary{ font-weight:600; font-size:1.1rem; cursor:pointer; list-style:none; display:flex; justify-content:space-between; gap:1rem; align-items:center }
.faqs summary::-webkit-details-marker{ display:none }
.faqs summary::after{ content:"+"; font-family:var(--f-serif); font-size:1.6rem; color:var(--brass); transition:transform .3s }
.faqs details[open] summary::after{ transform:rotate(45deg) }
.faqs details p{ margin-top:.8rem; color:var(--ink-soft) }
.section-dark .faqs details p{ color:rgba(244,238,226,.72) }

/* ---------- misc ---------- */
.updated{ font-size:.8rem; color:var(--ink-soft) }
.tag-pill{ display:inline-block; font-size:.72rem; text-transform:uppercase; letter-spacing:.16em; font-weight:700;
  color:var(--brass); border:1px solid var(--brass); border-radius:100px; padding:.3rem .8rem }
.skip-link{ position:absolute; left:-999px; top:0; background:var(--oxblood); color:#fff; padding:.7rem 1.2rem; z-index:200 }
.skip-link:focus{ left:8px; top:8px }

/* ---------- responsive ---------- */
@media (max-width:900px){
  .footer-grid{ grid-template-columns:1fr 1fr }
  .gallery{ grid-template-columns:repeat(3,1fr) }
}
@media (max-width:760px){
  .nav-links,.nav-cta .btn{ display:none }
  .nav-toggle{ display:flex }
  .stats{ grid-template-columns:1fr; }
  .stat+.stat::before{ display:none }
  .stat+.stat{ border-top:1px solid var(--line-d) }
  .gallery{ grid-template-columns:repeat(2,1fr) }
  .gallery .tall{ grid-row:span 1; aspect-ratio:1 }
  .footer-grid{ grid-template-columns:1fr }
}
