/* The Barber Chop — Detroit
   Editorial monochrome. Photography leads. Typography whispers.
   Palette: warm ink + bone newsprint + a single muted brass accent (used sparingly).
   Type: Fraunces (display serif) + Inter (body sans).
*/

/* ---------- TOKENS ---------- */
:root{
  --ink:        #14140f;       /* warm near-black */
  --ink-2:      #2a2a25;
  --ink-3:      #4a4a43;
  --mute:       #7a756a;       /* caption gray */
  --rule:       #14140f;
  --bone:       #f4f0e8;       /* warm off-white */
  --bone-2:     #ebe6da;
  --paper:      #faf7f0;
  --brass:      #8a6f3a;       /* used VERY rarely */

  --hair:       1px;           /* hairline */
  --rule-w:     1px;

  --f-display:  "Fraunces", "Times New Roman", Georgia, serif;
  --f-body:     "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
}

/* ---------- RESET ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--f-body);
  font-size:17px;
  line-height:1.55;
  color:var(--ink);
  background:var(--bone);
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  font-feature-settings: "ss01", "kern";
}
img,svg{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; background:none; border:none; padding:0; }
input,select,textarea,button{ font:inherit; color:inherit; }
ul,ol,dl{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4,h5,h6,p{ margin:0; }

.wrap{ width:min(1200px, 100% - 48px); margin-inline:auto; }

.skip{
  position:absolute; left:-9999px; top:0;
  background:var(--ink); color:var(--bone);
  padding:10px 14px; z-index:100;
  font-size:13px;
}
.skip:focus{ left:8px; top:8px; }

:focus-visible{ outline:2px solid var(--ink); outline-offset:3px; }

::selection{ background:var(--ink); color:var(--bone); }

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:.6em;
  font-family:var(--f-body);
  font-size:14px;
  font-weight:500;
  letter-spacing:.06em;
  text-transform:uppercase;
  padding:14px 22px;
  border:1px solid var(--ink);
  background:transparent;
  color:var(--ink);
  transition: background .25s ease, color .25s ease;
}
.btn:hover{ background:var(--ink); color:var(--bone); }
.btn--solid{ background:var(--ink); color:var(--bone); }
.btn--solid:hover{ background:var(--ink-2); color:var(--bone); }
.btn--inv{ border-color:var(--bone); color:var(--bone); }
.btn--inv:hover{ background:var(--bone); color:var(--ink); }
.btn--lg{ padding:16px 26px; font-size:14px; }
.btn--xl{ padding:20px 32px; font-size:15px; }

/* ---------- TOPBAR ---------- */
.topbar{
  background:var(--bone);
  border-bottom:var(--hair) solid var(--ink);
  font-size:12px; letter-spacing:.04em;
  color:var(--ink-3);
}
.topbar__row{
  display:flex; align-items:center; gap:18px;
  padding:9px 0; flex-wrap:wrap;
  justify-content:center;
}
.topbar b{ color:var(--ink); font-weight:500; }
.topbar__sep{ color:var(--mute); }
@media (max-width:560px){
  .topbar__sep--mobile-hide,
  .topbar__phone{ display:none; }
}

/* ---------- NAV ---------- */
.nav{
  position:sticky; top:0; z-index:50;
  background:var(--bone);
  border-bottom:var(--hair) solid var(--ink);
  transition: background .2s;
}
.nav.is-scrolled{ background: rgba(244,240,232,.96); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); }
.nav__row{
  display:flex; align-items:center; justify-content:space-between;
  gap:18px; padding:18px 0;
}
.brand{
  display:inline-flex; flex-direction:column; align-items:flex-start;
  color:var(--ink); line-height:1;
}
.brand__type{
  font-family:var(--f-display); font-weight:500;
  font-size:22px; letter-spacing:-.005em;
  font-feature-settings: "ss01";
}
.brand__sub{
  font-size:10px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--mute); margin-top:6px;
}

.nav__links{ display:flex; gap:30px; }
.nav__links a{
  font-size:13px;
  letter-spacing:.04em;
  color:var(--ink);
  position:relative;
  padding:6px 0;
}
.nav__links a::after{
  content:""; position:absolute; left:0; right:0; bottom:0;
  height:1px; background:var(--ink);
  transform: scaleX(0); transform-origin: left;
  transition: transform .25s ease;
}
.nav__links a:hover::after{ transform: scaleX(1); }
.nav__cta{ padding:11px 18px; font-size:12px; }

.burger{
  display:none;
  width:36px; height:36px;
  position:relative;
}
.burger span{
  position:absolute; left:6px; right:6px; height:1px; background:var(--ink);
  transition: transform .25s, top .25s, opacity .15s;
}
.burger span:nth-child(1){ top:12px; }
.burger span:nth-child(2){ top:50%; transform:translateY(-50%); }
.burger span:nth-child(3){ bottom:12px; }
.nav.is-open .burger span:nth-child(1){ top:50%; transform:translateY(-50%) rotate(45deg); }
.nav.is-open .burger span:nth-child(2){ opacity:0; }
.nav.is-open .burger span:nth-child(3){ bottom:auto; top:50%; transform:translateY(-50%) rotate(-45deg); }

.drawer{
  display:none; flex-direction:column;
  padding:22px 24px 30px; background:var(--bone);
  border-top:var(--hair) solid var(--ink);
}
.drawer a{
  font-family:var(--f-display);
  font-size:28px; font-weight:400;
  padding:12px 0;
  border-bottom:var(--hair) solid var(--ink);
}
.drawer a:last-child{ border-bottom:none; margin-top:18px; }
.drawer a.btn{
  font-family:var(--f-body); font-size:14px;
  border:1px solid var(--ink); padding:14px 20px;
  text-align:center; justify-content:center;
}

@media (max-width: 920px){
  .nav__links, .nav__cta{ display:none; }
  .burger{ display:block; }
  .nav.is-open .drawer{ display:flex; }
}

/* ---------- TYPE SYSTEM ---------- */
.overline{
  display:inline-block;
  font-size:11px; letter-spacing:.24em;
  text-transform:uppercase; color:var(--mute);
  margin-bottom:24px;
}
.overline::before{
  content:""; display:inline-block; width:24px; height:1px;
  background:currentColor; vertical-align:middle; margin-right:12px;
  position:relative; top:-1px;
}

.sec-h2{
  font-family:var(--f-display);
  font-weight:400;
  font-size: clamp(36px, 5.5vw, 64px);
  line-height: 1.02;
  letter-spacing:-.012em;
  margin-bottom:18px;
  font-feature-settings: "ss01", "kern";
}
.sec-h2 em{ font-style:italic; font-weight:300; color:var(--ink-2); }

.sec-lede{
  font-size: clamp(16px, 1.6vw, 19px);
  line-height:1.55;
  max-width:560px;
  color:var(--ink-3);
}

.sec{ padding: clamp(80px, 11vw, 140px) 0; position:relative; }
.sec-head{ margin-bottom: clamp(48px, 6vw, 72px); max-width:720px; }
.sec--inv{ background:var(--ink); color:var(--bone); }
.sec--inv .sec-h2{ color:var(--bone); }
.sec--inv .sec-h2 em{ color:#bdb6a4; }
.sec--inv .overline{ color:#9b9587; }
.sec--inv .sec-lede{ color:#bdb6a4; }

/* ---------- HERO ---------- */
.hero{
  padding-top: clamp(48px, 7vw, 90px);
  padding-bottom: clamp(72px, 9vw, 120px);
  background:var(--paper);
  border-bottom:var(--hair) solid var(--ink);
}
.hero__grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: clamp(32px, 5vw, 80px);
  align-items:center;
}
.hero__h1{
  font-family:var(--f-display);
  font-weight:400;
  font-size: clamp(48px, 7.4vw, 104px);
  line-height: .98;
  letter-spacing:-.02em;
  margin: 8px 0 28px;
  font-feature-settings: "ss01", "kern";
}
.hero__h1 em{
  font-style:italic;
  font-weight:300;
  color:var(--ink-2);
}
.hero__sub{
  font-size: 18px;
  line-height:1.55;
  color:var(--ink-3);
  max-width:480px;
  margin-bottom:36px;
}
.hero__ctas{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:48px; }

.hero__meta{
  display:grid;
  grid-template-columns: repeat(3, max-content);
  gap: 28px 40px;
  border-top:var(--hair) solid var(--ink);
  padding-top:24px;
  font-size:13px; letter-spacing:.02em;
}
.hero__meta dt{
  font-size:10px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--mute); margin-bottom:6px;
}
.hero__meta dd{ margin:0; color:var(--ink); font-weight:500; }

.hero__media{ position:relative; }
.hero__frame{
  margin:0;
  background:var(--ink);
  overflow:hidden;
  aspect-ratio: 4 / 5;
  border:var(--hair) solid var(--ink);
}
.hero__frame img{ width:100%; height:100%; object-fit:cover; }
.hero__cap{
  font-style:italic; font-family:var(--f-display); font-weight:300;
  font-size:13px; color:var(--mute);
  margin-top:14px;
  display:flex; justify-content:space-between; gap:18px;
}
.hero__cap span:last-child{
  font-family:var(--f-body); font-style:normal; font-size:11px;
  letter-spacing:.18em; text-transform:uppercase;
}

@media (max-width: 880px){
  .hero__grid{ grid-template-columns: 1fr; }
  .hero__media{ order:-1; max-width:560px; margin-inline:auto; width:100%; }
  .hero__meta{ grid-template-columns: repeat(3, 1fr); gap:20px 16px; }
}
@media (max-width: 480px){
  .hero__meta{ grid-template-columns: repeat(2, 1fr); }
}

/* ---------- SERVICES ---------- */
.sec--services{ background:var(--bone); }
.svc-list{
  border-top: var(--hair) solid var(--ink);
}
.svc{
  display:grid;
  grid-template-columns: 56px 1fr 110px 70px;
  gap: clamp(16px, 3vw, 36px);
  align-items:baseline;
  padding: clamp(26px, 3vw, 38px) 0;
  border-bottom: var(--hair) solid var(--ink);
}
.svc__num{
  font-family:var(--f-display);
  font-style:italic; font-weight:300;
  font-size:18px; color:var(--mute);
  letter-spacing:.02em;
}
.svc__name{
  font-family:var(--f-display);
  font-weight:400;
  font-size: clamp(22px, 2.4vw, 30px);
  line-height:1.1;
  letter-spacing:-.01em;
  margin-bottom:8px;
}
.svc__name small{
  font-size:.55em; font-style:italic; font-weight:300;
  color:var(--mute); margin-left:6px;
}
.svc__copy{
  color:var(--ink-3);
  max-width:520px;
  font-size:15px; line-height:1.55;
}
.svc__time{
  font-size:12px; letter-spacing:.04em;
  color:var(--mute);
  text-align:left;
  font-variant-numeric: tabular-nums;
}
.svc__price{
  font-family:var(--f-display);
  font-weight:400;
  font-size: clamp(22px, 2.4vw, 30px);
  text-align:right;
  font-variant-numeric: tabular-nums;
}
.svc__tag{
  display:block;
  margin-top:6px;
  font-style:italic; font-family:var(--f-display); font-weight:300;
  font-size:13px; color:var(--mute);
}

@media (max-width: 720px){
  .svc{ grid-template-columns: 32px 1fr auto; row-gap:6px; }
  .svc__time{ grid-column: 2; font-size:12px; }
  .svc__price{ grid-column: 3; align-self:start; font-size:24px; }
}

.svc-note{
  margin-top:36px;
  font-style:italic; font-family:var(--f-display); font-weight:300;
  font-size:15px; color:var(--mute);
  max-width:520px;
}

/* ---------- CREW ---------- */
.sec--crew{ background:var(--paper); border-top:var(--hair) solid var(--ink); }
.crew{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(28px, 4vw, 56px) clamp(20px, 3vw, 40px);
}
.crew__card{ }
.crew__photo{
  aspect-ratio: 4 / 5;
  background:var(--ink);
  margin-bottom:18px;
  overflow:hidden;
  filter: grayscale(100%);
}
.crew__photo img{ width:100%; height:100%; object-fit:cover; }
.crew__name{
  font-family:var(--f-display);
  font-weight:400;
  font-size:22px;
  letter-spacing:-.005em;
  margin-bottom:4px;
}
.crew__role{
  font-size:13px;
  color:var(--mute);
  margin-bottom:10px;
}
.crew__role em{ font-style:italic; }
.crew__tags{
  display:flex; flex-wrap:wrap; gap:6px 14px;
  font-size:12px; color:var(--ink-3);
  letter-spacing:.02em;
}
.crew__tags li{ position:relative; }
.crew__tags li + li::before{
  content:"·"; position:absolute; left:-9px; color:var(--mute);
}

@media (max-width: 880px){ .crew{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px){ .crew{ grid-template-columns: 1fr; max-width:380px; margin-inline:auto; } }

/* ---------- GALLERY ---------- */
.sec--gallery{ background:var(--bone); }
.gallery{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: 240px;
  gap: clamp(12px, 1.6vw, 20px);
}
.gallery__item{
  margin:0; position:relative;
  background:var(--ink);
  overflow:hidden;
}
.gallery__item--tall{ grid-row: span 2; }
.gallery__item img{
  width:100%; height:100%; object-fit:cover;
  filter:grayscale(100%);
  transition: transform .8s ease;
}
.gallery__item:hover img{ transform: scale(1.04); }
.gallery__item figcaption{
  position:absolute; left:14px; bottom:12px;
  font-family:var(--f-display); font-style:italic; font-weight:300;
  font-size:14px;
  color:var(--bone);
}

@media (max-width: 720px){
  .gallery{ grid-template-columns: repeat(2, 1fr); grid-auto-rows: 180px; }
}

/* ---------- REVIEWS ---------- */
.sec--reviews{ background:var(--paper); border-top:var(--hair) solid var(--ink); }
.reviews{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(36px, 5vw, 64px) clamp(28px, 4vw, 56px);
}
.rv{
  margin:0;
  border-top: var(--hair) solid var(--ink);
  padding-top: 22px;
}
.rv p{
  font-family:var(--f-display);
  font-weight:400;
  font-size: clamp(18px, 1.7vw, 22px);
  line-height: 1.35;
  letter-spacing:-.005em;
  margin-bottom:18px;
  color:var(--ink);
}
.rv p::before{ content:"“"; margin-right:.05em; }
.rv p::after{  content:"”"; margin-left:.02em; }
.rv footer{
  font-size:12px;
  color:var(--mute);
  letter-spacing:.04em;
}
.rv footer b{
  color:var(--ink); font-weight:500;
}

@media (max-width: 880px){ .reviews{ grid-template-columns: 1fr; max-width:560px; } }

/* ---------- BOOK ---------- */
.sec--book{ background:var(--ink); color:var(--bone); }
.book__grid{
  display:grid;
  grid-template-columns: 1fr 1.05fr;
  gap: clamp(36px, 6vw, 80px);
  align-items:start;
}
.book__copy .overline{ color:#9b9587; }
.book__copy .sec-h2{ color:var(--bone); }
.book__copy .sec-h2 em{ color:#bdb6a4; }
.book__lede{ color:#bdb6a4; max-width:460px; margin-bottom:30px; font-size:17px; line-height:1.55; }
.book__perks{ display:flex; flex-direction:column; gap:14px; margin-bottom:36px; }
.book__perks li{
  display:flex; gap:14px; align-items:baseline;
  color:var(--bone); font-size:15px;
  border-top:1px solid #2f2e29; padding-top:14px;
}
.book__perks li::before{
  content:""; width:18px; height:1px; background:#bdb6a4;
  position:relative; top:-4px; flex-shrink:0;
}
.book__phone{
  font-family:var(--f-display); font-style:italic; font-weight:300;
  font-size:18px; color:#bdb6a4;
}
.book__phone b{ font-style:normal; font-weight:400; color:var(--bone); margin-left:4px; }

.book__form{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:20px;
  background:transparent;
  padding: 0;
  color:var(--bone);
}
.ff{ display:flex; flex-direction:column; gap:10px; }
.ff--full{ grid-column: 1 / -1; }
.ff label{
  font-size:11px; letter-spacing:.18em;
  text-transform:uppercase; color:#9b9587;
}
.ff label small{ color:#7c7669; text-transform:none; letter-spacing:0; font-size:12px; margin-left:6px; font-style:italic; }
.ff input,
.ff select,
.ff textarea{
  background:transparent;
  border:none;
  border-bottom:1px solid #4a4942;
  padding:10px 0 12px;
  font-size:16px;
  color:var(--bone);
  width:100%;
  border-radius:0;
}
.ff input::placeholder{ color:#5f5d56; }
.ff input:focus,
.ff select:focus,
.ff textarea:focus{
  outline:none;
  border-bottom-color:var(--bone);
}
.ff select{
  -webkit-appearance:none; appearance:none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 6 5-6' fill='none' stroke='%23bdb6a4' stroke-width='1'/></svg>");
  background-repeat:no-repeat; background-position: right 4px center;
  padding-right:28px;
}
.ff select option{ background:var(--ink); color:var(--bone); }
.ff textarea{ resize:vertical; min-height:48px; font-family:var(--f-body); }

.book__submit{
  margin-top:6px;
  background:transparent; color:var(--bone); border:1px solid var(--bone);
  padding:18px 28px;
  font-size:13px; letter-spacing:.06em; text-transform:uppercase;
  font-family:var(--f-body); font-weight:500;
  transition: background .25s, color .25s;
}
.book__submit:hover{ background:var(--bone); color:var(--ink); }
.ff__fine{
  font-size:12px; color:#7c7669; margin-top:6px;
  font-style:italic; font-family:var(--f-display); font-weight:300;
}
@media (max-width: 880px){
  .book__grid{ grid-template-columns: 1fr; }
  .book__form{ grid-template-columns: 1fr; }
}

/* ---------- VISIT ---------- */
.sec--visit{ background:var(--bone); border-top:var(--hair) solid var(--ink); }
.visit__grid{
  display:grid;
  grid-template-columns: 1fr 1.1fr;
  gap: clamp(32px, 5vw, 64px);
  align-items:start;
}
.visit__lede{ color:var(--ink-3); margin-bottom:32px; max-width:420px; font-size:17px; line-height:1.55; }
.visit__hours{
  display:grid;
  grid-template-columns: max-content 1fr;
  gap:14px 32px;
  border-top:var(--hair) solid var(--ink);
  padding-top:20px; margin-bottom:30px;
  font-size:14px;
}
.visit__hours dt{ color:var(--mute); }
.visit__hours dd{ margin:0; color:var(--ink); font-variant-numeric: tabular-nums; }
.visit__meta{ display:flex; flex-direction:column; gap:14px; font-size:14px; padding-top:20px; border-top:var(--hair) solid var(--ink); }
.visit__meta b{ color:var(--mute); margin-right:14px; font-weight:400; font-size:11px; letter-spacing:.18em; text-transform:uppercase; }

.visit__map{
  background:var(--paper);
  border:var(--hair) solid var(--ink);
}
.map{
  position:relative;
  aspect-ratio: 5 / 4;
  background:var(--paper); color:var(--ink);
  overflow:hidden;
}
.map__grid{
  position:absolute; inset:0;
  background:
    linear-gradient(var(--ink) 1px, transparent 1px) 0 0/48px 48px,
    linear-gradient(90deg, var(--ink) 1px, transparent 1px) 0 0/48px 48px;
  opacity:.06;
}
.map__pin{
  position:absolute; left:54%; top:50%;
  transform:translate(-50%,-50%);
  text-align:center;
}
.map__pin-mark{
  display:block;
  width:10px; height:10px; background:var(--ink); border-radius:50%;
  margin:0 auto;
}
.map__pin-lbl{
  display:inline-block; margin-top:10px;
  font-family:var(--f-display); font-style:italic; font-weight:300;
  font-size:13px; color:var(--ink);
}
.map__label{
  position:absolute;
  font-size:10px; letter-spacing:.22em;
  text-transform:uppercase; color:var(--mute);
}
.map__label--street{ left:14px; bottom:14px; }
.map__label--cross{ right:14px; top:14px; }
.map__label--park{ left:14px; top:14px; font-style:italic; text-transform:none; letter-spacing:.04em; font-family:var(--f-display); font-weight:300; font-size:13px; color:var(--ink); }

@media (max-width: 880px){ .visit__grid{ grid-template-columns: 1fr; } }

/* ---------- FAQ ---------- */
.sec--faq{ background:var(--paper); border-top:var(--hair) solid var(--ink); }
.faq__grid{
  display:grid;
  grid-template-columns: .8fr 1.4fr;
  gap: clamp(32px, 5vw, 80px);
  align-items:start;
}
.faq{ display:flex; flex-direction:column; border-top:var(--hair) solid var(--ink); }
.qa{
  border-bottom: var(--hair) solid var(--ink);
  padding: 22px 0;
}
.qa summary{
  font-family:var(--f-display); font-weight:400;
  font-size: clamp(18px, 1.8vw, 22px);
  letter-spacing:-.005em;
  cursor:pointer; list-style:none;
  display:flex; align-items:baseline; justify-content:space-between;
  gap:18px;
}
.qa summary::-webkit-details-marker{ display:none; }
.qa summary::after{
  content:"+"; font-family:var(--f-display); font-weight:300;
  font-size:24px; line-height:1; color:var(--mute);
  transition: transform .2s;
  flex-shrink:0;
}
.qa[open] summary::after{ content:"–"; }
.qa p{
  margin-top:14px; color:var(--ink-3); max-width:640px;
  line-height:1.6; font-size:16px;
}

@media (max-width: 880px){ .faq__grid{ grid-template-columns: 1fr; } }

/* ---------- FINAL ---------- */
.sec--final{
  background: var(--bone);
  border-top: var(--hair) solid var(--ink);
  text-align:center;
  padding: clamp(100px, 14vw, 180px) 0;
}
.final__h{
  font-family:var(--f-display); font-weight:400;
  font-size: clamp(44px, 7vw, 96px);
  line-height: 1.0;
  letter-spacing:-.02em;
  margin-bottom:36px;
}
.final__h em{ font-style:italic; font-weight:300; color:var(--ink-2); }
.final__sub{
  margin-top:28px;
  font-family:var(--f-display); font-style:italic; font-weight:300;
  font-size:15px; color:var(--mute);
}

/* ---------- FOOTER ---------- */
.footer{
  background:var(--ink); color:var(--bone);
  padding: 80px 0 28px;
}
.footer__row{
  display:grid;
  grid-template-columns: 1.4fr repeat(3, 1fr);
  gap: 40px;
}
.footer__col h4{
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:#9b9587; margin-bottom:16px; font-weight:500;
}
.footer__col p{ font-size:14px; line-height:1.7; color:#cfc9bc; }
.footer__addr{ font-size:14px; line-height:1.7; color:#cfc9bc; margin-top:16px; }
.brand--footer .brand__type{ color:var(--bone); }
.brand--footer .brand__sub{ color:#7c7669; }

.footer__bottom{
  display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap;
  margin-top:60px; padding-top:22px;
  border-top:1px solid #2f2e29;
  font-size:11px; letter-spacing:.04em;
  color:#7c7669;
}
.footer__credit a{ color:#cfc9bc; border-bottom:1px solid #4a4942; padding-bottom:1px; }
.footer__credit a:hover{ color:var(--bone); border-color:var(--bone); }

@media (max-width: 720px){
  .footer__row{ grid-template-columns: 1fr 1fr; }
}

/* ---------- MOBILE STICKY CTA ---------- */
.mobile-cta{
  display:none;
  position:fixed; left:0; right:0; bottom:0; z-index:60;
  background:var(--ink); color:var(--bone);
  padding:12px 18px;
  align-items:center; justify-content:space-between; gap:14px;
}
.mobile-cta__phone{
  font-size:14px;
}
.mobile-cta__phone b{ color:var(--bone); font-weight:500; }
.mobile-cta__phone span{ color:#9b9587; font-size:11px; letter-spacing:.18em; text-transform:uppercase; display:block; }
.btn--mcta{
  border-color:var(--bone); color:var(--bone);
  padding:11px 18px; font-size:12px;
}
.btn--mcta:hover{ background:var(--bone); color:var(--ink); }
@media (max-width: 720px){
  .mobile-cta{ display:flex; }
  body{ padding-bottom:62px; }
}

/* ---------- IMAGE FALLBACKS (quiet, monochrome) ---------- */
.fb{
  width:100%; height:100%;
  display:grid; place-items:center;
  background: var(--ink);
  color:var(--bone);
  position:relative;
  overflow:hidden;
}
.fb::after{
  content:""; position:absolute; inset:0;
  background:
    repeating-linear-gradient(45deg, transparent 0 18px, rgba(255,255,255,.025) 18px 19px);
  pointer-events:none;
}
.fb--hero{ background:#1a1a16; }
.fb--hero .fb__sign{
  position:relative;
  font-family:var(--f-display); font-weight:300; font-style:italic;
  font-size: clamp(22px, 3vw, 30px);
  color:#bdb6a4; text-align:center;
  letter-spacing:.04em;
  z-index:2;
}
.fb--portrait{ background:#1a1a16; }
.fb--portrait span{
  font-family:var(--f-display); font-weight:300; font-style:italic;
  font-size:48px; color:#9b9587;
  z-index:2;
}
.fb--gallery{ background:#1a1a16; }
.fb--gallery span{
  font-family:var(--f-display); font-weight:300; font-style:italic;
  font-size:18px; color:#bdb6a4;
  letter-spacing:.04em;
  z-index:2;
}

/* ---------- REVEAL ---------- */
.reveal{
  opacity:0; transform: translateY(12px);
  transition: opacity .6s ease, transform .6s ease;
}
.reveal.is-in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
}
