/* === Peters Barbershop — editorial old-world ============================ */

:root{
  --ink:#0e0e0c;
  --ink-2:#1c1b18;
  --bone:#f4ede2;
  --bone-2:#ece2d0;
  --cream:#fbf6ec;
  --brass:#b48a4a;
  --brass-2:#8d6630;
  --oxblood:#6b1f1f;
  --line:rgba(14,14,12,.18);
  --line-soft:rgba(14,14,12,.10);
  --shadow: 0 30px 60px -30px rgba(14,14,12,.35);
  --serif:'Fraunces', 'Cormorant Garamond', Georgia, serif;
  --sans:'Inter', system-ui, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--bone);
  color:var(--ink);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;background:none;border:0;color:inherit}

/* paper grain */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.06;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode:multiply;
}

/* ---------- typography ---------- */
.eyebrow{
  font-family:var(--sans);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.72rem;
  color:var(--brass-2);
  font-weight:500;
}
.display{
  font-family:var(--serif);
  font-weight:340;
  font-size:clamp(3.4rem, 8.5vw, 7.6rem);
  line-height:.92;
  letter-spacing:-.02em;
  font-variation-settings:"opsz" 144, "SOFT" 30;
}
.display em{font-style:italic;color:var(--oxblood);font-weight:340}
.h-display{
  font-family:var(--serif);
  font-weight:380;
  font-size:clamp(2rem, 4.6vw, 3.8rem);
  line-height:1.02;
  letter-spacing:-.015em;
  font-variation-settings:"opsz" 100;
  max-width:24ch;
}
.lede{
  font-family:var(--serif);
  font-style:italic;
  font-weight:340;
  font-size:clamp(1.05rem, 1.4vw, 1.3rem);
  line-height:1.55;
  max-width:46ch;
  color:var(--ink-2);
}

/* ---------- util bar ---------- */
.util{
  background:var(--ink);
  color:var(--bone);
  font-size:.74rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  position:relative;
  z-index:5;
}
.util__inner{
  max-width:1400px;margin:0 auto;
  padding:.7rem 2rem;
  display:flex;justify-content:center;align-items:center;gap:1rem;
  flex-wrap:wrap;
}
.util__dot{color:var(--brass)}
.util__phone{color:var(--brass);font-weight:500}

/* ---------- nav ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  display:grid;
  grid-template-columns: 1fr 1fr 1fr auto 1fr 1fr 1fr;
  align-items:center;gap:1.4rem;
  padding:1.1rem 2.2rem;
  background:rgba(244,237,226,.86);
  backdrop-filter: blur(14px) saturate(1.05);
  -webkit-backdrop-filter: blur(14px) saturate(1.05);
  border-bottom:1px solid var(--line-soft);
}
.nav__link{
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-2);
  text-align:center;
  padding:.4rem 0;
  position:relative;
}
.nav__link::after{
  content:"";position:absolute;left:50%;bottom:0;
  width:0;height:1px;background:var(--brass);
  transition:width .35s ease, left .35s ease;
}
.nav__link:hover::after{width:100%;left:0}
.nav__cta{color:var(--oxblood);font-weight:600}

.brand{
  display:flex;flex-direction:column;align-items:center;gap:.1rem;
  text-align:center;padding:0 1.2rem;
}
.brand__crest{
  font-family:var(--serif);
  font-weight:600;
  font-size:1.7rem;
  width:2.4rem;height:2.4rem;
  border:1.5px solid var(--ink);
  border-radius:50%;
  display:grid;place-items:center;
  font-style:italic;
  background:var(--bone);
  color:var(--ink);
}
.brand__crest--lg{width:3rem;height:3rem;font-size:2rem}
.brand__name{
  font-family:var(--serif);font-weight:500;
  font-size:1.05rem;letter-spacing:.04em;margin-top:.2rem;
}
.brand__est{
  font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--brass-2);
}
.nav__toggle{display:none}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:1.05rem 1.6rem;
  font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  border-radius:999px;
  transition:transform .25s ease, background .25s ease, color .25s ease, box-shadow .25s ease;
  font-weight:500;
  white-space:nowrap;
}
.btn--primary{
  background:var(--ink);color:var(--bone);
  box-shadow:0 12px 32px -16px rgba(14,14,12,.6);
}
.btn--primary:hover{background:var(--oxblood);transform:translateY(-2px)}
.btn--ghost{
  border:1px solid var(--ink);color:var(--ink);
}
.btn--ghost:hover{background:var(--ink);color:var(--bone)}

/* ---------- hero ---------- */
.hero{
  padding:6vh 2.2rem 4vh;
  max-width:1500px;margin:0 auto;
  position:relative;
}
.hero__grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:5rem;align-items:center;
}
.hero__copy{display:flex;flex-direction:column;gap:1.6rem}
.hero__cta{display:flex;gap:.8rem;margin-top:.6rem;flex-wrap:wrap}
.hero__meta{
  list-style:none;display:flex;gap:2.2rem;margin-top:1.6rem;
  border-top:1px solid var(--line);padding-top:1.6rem;
}
.hero__meta li{display:flex;flex-direction:column}
.hero__meta strong{
  font-family:var(--serif);font-weight:400;font-size:1.9rem;line-height:1;
}
.hero__meta span{
  font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--brass-2);margin-top:.4rem;
}

.hero__art{
  position:relative;aspect-ratio:4/5;
  border-radius:200px 200px 12px 12px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.hero__photo{
  position:absolute;inset:0;
  background-image:var(--bg);background-size:cover;background-position:center;
  filter:contrast(1.05) saturate(.85) sepia(.18);
}
.hero__photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(14,14,12,0) 50%, rgba(14,14,12,.45) 100%);
}
.hero__sticker{
  position:absolute;left:-1.4rem;bottom:14%;
  width:130px;height:130px;border-radius:50%;
  background:var(--brass);color:var(--ink);
  display:grid;place-items:center;text-align:center;
  font-family:var(--serif);font-style:italic;
  transform:rotate(-12deg);
  box-shadow:0 12px 30px -10px rgba(14,14,12,.4);
  border:1.5px solid var(--ink);
}
.hero__sticker span{font-size:1.15rem;font-weight:500;display:block}
.hero__sticker em{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;font-style:normal;display:block;margin-top:.2rem}

.hero__plate{
  position:absolute;right:1.2rem;top:1.2rem;
  background:var(--bone);border:1px solid var(--ink);
  padding:.7rem 1rem;border-radius:6px;
  display:flex;flex-direction:column;align-items:center;
  font-family:var(--serif);
}
.hero__plate strong{font-size:1.6rem;line-height:1;font-weight:500}
.hero__plate span{font-size:.6rem;letter-spacing:.22em;text-transform:uppercase}

/* ---------- marquee ---------- */
.marquee{
  background:var(--ink);color:var(--bone);
  border-top:1px solid var(--brass);border-bottom:1px solid var(--brass);
  overflow:hidden;padding:1.4rem 0;
  font-family:var(--serif);
}
.marquee__track{
  display:flex;gap:2.4rem;align-items:center;
  white-space:nowrap;
  animation: scroll 38s linear infinite;
}
.marquee__track span{font-size:1.7rem;letter-spacing:.02em;font-style:italic;font-weight:340}
.marquee__track i{color:var(--brass);font-style:normal;font-size:1rem}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- house ---------- */
.house{padding:10vh 2.2rem;background:var(--cream);border-top:1px solid var(--line-soft)}
.house__inner{max-width:1300px;margin:0 auto;display:flex;flex-direction:column;gap:2rem}
.house__grid{display:grid;grid-template-columns:1.4fr 1fr;gap:4rem;margin-top:2rem;align-items:start}
.house__col p{margin-bottom:1.2rem;font-size:1.05rem;line-height:1.7;color:var(--ink-2);max-width:48ch}
.house__col em{font-style:italic;color:var(--oxblood)}

.house__card{
  background:var(--ink);color:var(--bone);
  border-radius:14px;padding:2.2rem 2rem;
  box-shadow:var(--shadow);
}
.house__card__eyebrow{
  font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--brass);margin-bottom:1.2rem;
}
.house__card ul{list-style:none;display:flex;flex-direction:column;gap:1rem}
.house__card li{
  padding-bottom:1rem;border-bottom:1px solid rgba(244,237,226,.14);
  font-size:.92rem;line-height:1.55;
}
.house__card li:last-child{border:0;padding-bottom:0}
.house__card strong{font-family:var(--serif);font-weight:500;font-size:1.05rem;display:inline-block;margin-right:.4rem;color:var(--brass)}

/* ---------- services / menu ---------- */
.services{padding:10vh 2.2rem;border-top:1px solid var(--line-soft)}
.services__head{max-width:1300px;margin:0 auto 3rem;display:flex;flex-direction:column;gap:1rem;align-items:flex-start}
.services__note{font-size:.85rem;color:var(--ink-2);opacity:.7;font-style:italic}

.menu{list-style:none;max-width:1300px;margin:0 auto;display:flex;flex-direction:column}
.menu__item{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:2.4rem;align-items:start;
  padding:2.4rem 0;
  border-top:1px solid var(--line);
  position:relative;
  transition:padding-left .4s ease;
}
.menu__item:last-child{border-bottom:1px solid var(--line)}
.menu__item::before{
  content:"";position:absolute;left:0;top:0;height:100%;
  width:0;background:var(--ink);transition:width .4s ease;
  z-index:-1;
}
.menu__item:hover{padding-left:1.4rem}
.menu__num{
  font-family:var(--serif);font-size:1.8rem;font-style:italic;
  font-weight:380;color:var(--brass-2);min-width:3rem;
}
.menu__body h3{
  font-family:var(--serif);font-weight:400;font-size:clamp(1.6rem,2.6vw,2.4rem);
  letter-spacing:-.01em;line-height:1.05;margin-bottom:.6rem;
}
.menu__body p{max-width:60ch;color:var(--ink-2);font-size:1rem;line-height:1.6}
.menu__meta{
  display:flex;gap:1.2rem;margin-top:.9rem;
  font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-2);
}
.menu__meta span{position:relative;padding-right:1.2rem}
.menu__meta span:not(:last-child)::after{
  content:"·";position:absolute;right:.4rem;top:0;color:var(--ink);
}
.menu__price{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:.3rem}
.menu__price span{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-2)}
.menu__price strong{font-family:var(--serif);font-weight:400;font-size:2.4rem;line-height:1;color:var(--ink)}

/* ---------- booker ---------- */
.book{padding:10vh 2.2rem;background:var(--ink);color:var(--bone);position:relative;overflow:hidden}
.book::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 80% 0%, rgba(180,138,74,.15), transparent 50%);
  pointer-events:none;
}
.book .eyebrow{color:var(--brass)}
.book__head{max-width:1300px;margin:0 auto 3rem;display:flex;flex-direction:column;gap:1rem;position:relative;z-index:1}
.book__head .h-display{color:var(--bone)}
.book__head .services__note{color:rgba(244,237,226,.65)}
.book__head a{color:var(--brass);border-bottom:1px solid var(--brass)}

.booker{
  max-width:1300px;margin:0 auto;
  background:var(--bone);color:var(--ink);
  border-radius:18px;
  display:grid;grid-template-columns:240px 1fr;
  overflow:hidden;
  box-shadow:0 40px 80px -30px rgba(0,0,0,.6);
  position:relative;z-index:1;
  min-height:560px;
}
.booker__rail{
  background:var(--cream);
  padding:2.4rem 1.6rem;
  border-right:1px solid var(--line-soft);
  display:flex;flex-direction:column;gap:.4rem;
}
.step{
  display:flex;align-items:center;gap:.9rem;
  padding:1rem .9rem;border-radius:10px;
  font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-2);opacity:.45;transition:all .3s ease;
  border:1px solid transparent;
}
.step span{
  font-family:var(--serif);font-style:italic;font-size:1.1rem;
  width:1.9rem;height:1.9rem;border-radius:50%;
  border:1px solid var(--line);display:grid;place-items:center;
  background:var(--bone);
}
.step.active{opacity:1;background:var(--bone);border-color:var(--line)}
.step.active span{background:var(--ink);color:var(--bone);border-color:var(--ink)}
.step.done{opacity:.85}
.step.done span{background:var(--brass);color:var(--ink);border-color:var(--brass)}

.booker__stage{padding:2.6rem;position:relative;display:flex;flex-direction:column}
.pane{display:none;animation:fade .4s ease}
.pane.active{display:flex;flex-direction:column;gap:1.6rem;flex:1}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.pane__title{
  font-family:var(--serif);font-weight:400;font-size:1.7rem;letter-spacing:-.01em;
}

.opts{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.opt{
  text-align:left;padding:1.2rem 1.3rem;
  border:1px solid var(--line);border-radius:12px;
  background:var(--cream);
  display:flex;flex-direction:column;gap:.4rem;
  transition:all .25s ease;
  position:relative;
}
.opt em{
  font-family:var(--serif);font-style:italic;font-size:.85rem;color:var(--brass-2);
}
.opt strong{font-family:var(--serif);font-weight:400;font-size:1.4rem}
.opt span{font-size:.78rem;color:var(--ink-2);opacity:.7;letter-spacing:.04em}
.opt:hover{border-color:var(--ink);transform:translateY(-2px)}
.opt.selected{
  background:var(--ink);color:var(--bone);border-color:var(--ink);
}
.opt.selected em,.opt.selected span{color:var(--brass)}

.opts--barbers .opt{flex-direction:row;align-items:center;gap:1rem}
.opt__avatar{
  width:54px;height:54px;border-radius:50%;
  background-image:var(--img);background-size:cover;background-position:center;
  border:1.5px solid var(--line);flex-shrink:0;
  filter:sepia(.15) saturate(.9);
}
.opt__avatar--any{
  background:var(--brass);color:var(--ink);
  display:grid;place-items:center;font-family:var(--serif);font-size:1.5rem;
}
.opts--barbers .opt > strong,.opts--barbers .opt > span{display:block}
.opts--barbers .opt{display:grid;grid-template-columns:auto 1fr;align-items:center}
.opts--barbers .opt strong{grid-column:2;align-self:end}
.opts--barbers .opt span{grid-column:2;align-self:start}
.opts--barbers .opt__avatar{grid-row:span 2}

.dates{display:flex;gap:.6rem;overflow-x:auto;padding-bottom:.4rem}
.date{
  flex-shrink:0;min-width:78px;
  padding:.9rem .8rem;border-radius:10px;border:1px solid var(--line);
  background:var(--cream);text-align:center;display:flex;flex-direction:column;gap:.2rem;
  transition:all .25s;
}
.date:hover{border-color:var(--ink)}
.date.selected{background:var(--ink);color:var(--bone);border-color:var(--ink)}
.date.selected .date__dow{color:var(--brass)}
.date.closed{opacity:.35;pointer-events:none}
.date__dow{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brass-2)}
.date__num{font-family:var(--serif);font-size:1.6rem;font-weight:400;line-height:1}
.date__mo{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;opacity:.7}

.times{display:grid;grid-template-columns:repeat(auto-fill,minmax(94px,1fr));gap:.5rem;margin-top:.6rem}
.time{
  padding:.7rem;border-radius:8px;border:1px solid var(--line);background:var(--cream);
  font-family:var(--serif);font-size:1rem;text-align:center;transition:all .2s;
}
.time:hover{border-color:var(--ink)}
.time.selected{background:var(--ink);color:var(--bone);border-color:var(--ink)}
.time.taken{opacity:.3;pointer-events:none;text-decoration:line-through}

.confirm{
  background:var(--cream);border:1px solid var(--line);border-radius:12px;
  padding:1.6rem;display:grid;grid-template-columns:1fr 1fr;gap:1rem 2rem;
}
.confirm dt{
  font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-2);margin-bottom:.3rem;
}
.confirm dd{font-family:var(--serif);font-size:1.25rem;font-weight:400}
.confirm__total{
  grid-column:1/-1;display:flex;justify-content:space-between;align-items:baseline;
  border-top:1px dashed var(--line);padding-top:1rem;margin-top:.4rem;
}
.confirm__total strong{font-family:var(--serif);font-size:1.8rem;font-weight:400}

.form{display:grid;grid-template-columns:1fr 1fr;gap:.9rem;margin-top:.4rem}
.form label{display:flex;flex-direction:column;gap:.4rem}
.form__full{grid-column:1/-1}
.form span{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-2)}
.form input,.form textarea{
  font-family:var(--sans);font-size:1rem;
  padding:.8rem 1rem;border-radius:8px;border:1px solid var(--line);
  background:var(--cream);color:var(--ink);
  transition:border-color .2s;
}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--ink)}

.booker__foot{
  grid-column:1/-1;display:flex;justify-content:space-between;align-items:center;
  padding:1.4rem 2rem;border-top:1px solid var(--line);
  background:var(--cream);
  gap:1rem;
}
.booker__summary{font-family:var(--serif);font-style:italic;color:var(--ink-2);flex:1;text-align:center}

/* ---------- barbers ---------- */
.barbers{padding:10vh 2.2rem;background:var(--cream);border-top:1px solid var(--line-soft)}
.barbers__head{max-width:1300px;margin:0 auto 3rem;display:flex;flex-direction:column;gap:1rem}
.barbers__grid{
  max-width:1300px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;
}
.barber{display:flex;flex-direction:column}
.barber__photo{
  aspect-ratio:4/5;
  background-image:var(--bg);background-size:cover;background-position:center top;
  filter:sepia(.18) contrast(1.05);
  border-radius:8px;
  margin-bottom:1.4rem;
  position:relative;
}
.barber__photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(14,14,12,.3));
  border-radius:8px;
}
.barber__role{
  font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--brass-2);
}
.barber h3{
  font-family:var(--serif);font-weight:400;font-size:2.2rem;line-height:1;
  margin:.4rem 0 .8rem;
}
.barber p{font-size:.95rem;color:var(--ink-2);line-height:1.6;margin-bottom:1rem}
.barber__skills{
  list-style:none;display:flex;flex-wrap:wrap;gap:.4rem;
}
.barber__skills li{
  font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;
  padding:.4rem .8rem;border:1px solid var(--line);border-radius:999px;
  color:var(--ink-2);
}

/* ---------- gallery ---------- */
.gallery{padding:10vh 2.2rem;border-top:1px solid var(--line-soft)}
.gallery__head{max-width:1300px;margin:0 auto 3rem;display:flex;flex-direction:column;gap:1rem}
.gallery__grid{
  max-width:1300px;margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:.8rem;
}
.g{
  background-image:var(--bg);background-size:cover;background-position:center;
  filter:sepia(.15) contrast(1.05);border-radius:6px;
  transition:transform .5s ease, filter .5s ease;
}
.g:hover{transform:scale(1.02);filter:sepia(0) contrast(1.05)}
.g--tall{grid-row:span 2}
.g--wide{grid-column:span 2}

/* ---------- words / testimonials ---------- */
.words{padding:10vh 2.2rem;background:var(--ink);color:var(--bone);border-top:1px solid var(--brass)}
.words .eyebrow{color:var(--brass)}
.words__head{max-width:1300px;margin:0 auto 3rem;display:flex;flex-direction:column;gap:1rem}
.words__head .h-display{color:var(--bone);font-style:italic}
.words__head .services__note{color:rgba(244,237,226,.6)}
.words__grid{
  max-width:1300px;margin:0 auto;
  display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;
}
.words blockquote{
  border-left:2px solid var(--brass);
  padding:1.5rem 0 1.5rem 1.8rem;
  display:flex;flex-direction:column;gap:1rem;
}
.words blockquote p{
  font-family:var(--serif);font-style:italic;font-size:1.3rem;line-height:1.5;font-weight:340;
  color:var(--bone);
}
.words cite{
  font-style:normal;font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--brass);
}

/* ---------- visit ---------- */
.visit{padding:10vh 2.2rem;background:var(--cream);border-top:1px solid var(--line-soft)}
.visit__grid{max-width:1300px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.visit__copy{display:flex;flex-direction:column;gap:1.4rem}
.visit__list{display:grid;grid-template-columns:120px 1fr;gap:1rem 1.6rem;margin:1rem 0;border-top:1px solid var(--line);padding-top:1.4rem}
.visit__list dt{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass-2);padding-top:.3rem}
.visit__list dd{font-family:var(--serif);font-size:1.2rem;font-weight:400;line-height:1.5}
.visit__list a{border-bottom:1px solid var(--brass)}
.visit__map{
  aspect-ratio:1/1;border-radius:14px;overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow);
}
.visit__map iframe{width:100%;height:100%;border:0;filter:grayscale(.4) contrast(1.05)}

/* ---------- footer ---------- */
.foot{background:var(--ink);color:var(--bone);padding:5rem 2.2rem 1.4rem}
.foot__inner{max-width:1300px;margin:0 auto;display:grid;grid-template-columns:1fr 1.4fr;gap:4rem;padding-bottom:3rem;border-bottom:1px solid rgba(244,237,226,.12)}
.foot__brand{display:flex;flex-direction:column;gap:1.2rem;align-items:flex-start}
.foot__brand .brand__crest{background:var(--bone);border-color:var(--bone)}
.foot__brand p{font-family:var(--serif);font-style:italic;font-size:1.05rem;max-width:34ch;line-height:1.55}
.foot__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.foot__cols h4{
  font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--brass);margin-bottom:1rem;font-weight:500;
}
.foot__cols p{font-family:var(--serif);font-size:1rem;line-height:1.7;color:rgba(244,237,226,.85)}
.foot__cols a:hover{color:var(--brass)}
.foot__rule{
  max-width:1300px;margin:1.2rem auto 0;
  display:flex;justify-content:space-between;
  font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(244,237,226,.5);
}

/* ---------- responsive ---------- */
@media (max-width: 1100px){
  .booker{grid-template-columns:1fr}
  .booker__rail{flex-direction:row;border-right:0;border-bottom:1px solid var(--line-soft);overflow-x:auto;padding:1.2rem}
  .step{white-space:nowrap}
  .barbers__grid{grid-template-columns:repeat(2,1fr)}
  .gallery__grid{grid-template-columns:repeat(2,1fr)}
  .hero__grid{gap:3rem}
}
@media (max-width: 820px){
  .util__inner{font-size:.65rem;gap:.6rem;padding:.6rem 1.2rem}
  .util__dot{display:none}
  .nav{
    grid-template-columns: auto 1fr auto;
    padding:.9rem 1.2rem;
  }
  .nav__link{display:none}
  .nav__cta{display:none}
  .nav__toggle{
    display:flex;flex-direction:column;gap:5px;
    width:36px;height:36px;justify-content:center;align-items:center;
  }
  .nav__toggle span{display:block;width:22px;height:1.5px;background:var(--ink)}
  .brand{align-items:flex-start;text-align:left}
  .hero{padding:3rem 1.2rem}
  .hero__grid{grid-template-columns:1fr;gap:2.5rem}
  .hero__art{aspect-ratio:3/4;border-radius:120px 120px 12px 12px}
  .hero__sticker{width:100px;height:100px}
  .marquee__track span{font-size:1.2rem}
  .house,.services,.book,.barbers,.gallery,.words,.visit{padding:6rem 1.2rem}
  .house__grid{grid-template-columns:1fr;gap:2rem}
  .menu__item{grid-template-columns:auto 1fr;gap:1rem;padding:1.8rem 0}
  .menu__price{grid-column:1/-1;text-align:left;flex-direction:row;align-items:baseline;gap:.6rem}
  .menu__price strong{font-size:1.8rem}
  .barbers__grid{grid-template-columns:1fr}
  .gallery__grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:140px}
  .words__grid{grid-template-columns:1fr}
  .visit__grid{grid-template-columns:1fr;gap:2rem}
  .opts{grid-template-columns:1fr}
  .form{grid-template-columns:1fr}
  .confirm{grid-template-columns:1fr}
  .booker__stage{padding:1.6rem}
  .foot__inner{grid-template-columns:1fr;gap:2rem}
  .foot__cols{grid-template-columns:repeat(2,1fr)}
  .foot__rule{flex-direction:column;gap:.4rem;text-align:center}
  .booker__foot{flex-wrap:wrap}
  .booker__summary{order:3;width:100%;text-align:center}
}

/* mobile menu open state */
.nav.is-open{grid-template-columns:1fr;gap:.4rem}
.nav.is-open .nav__link{display:block;text-align:center;padding:.8rem 0;border-top:1px solid var(--line-soft)}
.nav.is-open .nav__cta{display:block;color:var(--oxblood)}
.nav.is-open .brand{display:none}
