/* ============================================================
   ROCHELLOS style.css  (revised)
   Fixes: no overlap on load, better contrast, tighter type scale,
   breathing room on booking page, clearer text throughout
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Lora:ital,wght@0,400;0,600;1,400;1,600&family=Outfit:wght@300;400;500;600&display=swap');

:root {
  --sand:        #e8dcc8;
  --sand-dark:   #cfc0a8;
  --sand-deep:   #b8a888;
  --rust:        #c04a1e;
  --rust-light:  #d85a2a;
  --rust-dim:    rgba(192,74,30,.18);
  --charcoal:    #181818;
  --charcoal-2:  #242424;
  --charcoal-3:  #2e2e2e;
  --charcoal-4:  #363636;
  --offwhite:    #f4efe6;
  --muted:       #887868;
  --muted-lt:    #a09080;
  --nav-h:       68px;
  --section:     clamp(64px, 8vw, 108px);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0 }
html { scroll-behavior:smooth; overflow-x:hidden }
body {
  background: var(--charcoal);
  color: var(--sand);
  font-family: 'Outfit', sans-serif;
  font-size: 16px;
  line-height: 1.65;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img  { display:block; max-width:100% }
a    { color:inherit; text-decoration:none }
ul   { list-style:none }
button { cursor:pointer; border:none; background:none; font-family:inherit }
input,select,textarea { font-family:inherit }

.container { width:100%; max-width:1260px; margin:0 auto; padding:0 clamp(20px,4vw,56px) }

/* ── TYPE ───────────────────────────────────────────────── */
h2,h3,h4 { font-family:'Lora',serif; line-height:1.2 }
h2 { font-size:clamp(1.75rem,3vw,2.6rem); font-weight:400 }
h3 { font-size:clamp(1.3rem,2vw,1.9rem); font-weight:400 }
h4 { font-size:1.05rem; font-weight:600 }
p  { color:var(--sand-dark); line-height:1.82; font-size:.95rem }
em { font-style:italic; color:var(--rust-light) }

.label {
  font-size: 10px; font-weight:700; letter-spacing:.24em;
  text-transform:uppercase; color:var(--rust-light);
  display:inline-block;
}

/* ── REVEAL — hero content always visible; only scroll els animate ── */
/* Hero items: visible immediately (no opacity:0 on load) */
.hero .fade-in,
.hero .fade-left,
.hero .fade-right { opacity:1; transform:none }

/* Everything else fades in on scroll */
.fade-in {
  opacity:0; transform:translateY(24px);
  transition: opacity .75s cubic-bezier(.25,.46,.45,.94),
              transform .75s cubic-bezier(.25,.46,.45,.94);
}
.fade-in.visible  { opacity:1; transform:none }

.fade-left {
  opacity:0; transform:translateX(-32px);
  transition: opacity .75s cubic-bezier(.25,.46,.45,.94),
              transform .75s cubic-bezier(.25,.46,.45,.94);
}
.fade-left.visible { opacity:1; transform:none }

.fade-right {
  opacity:0; transform:translateX(32px);
  transition: opacity .75s cubic-bezier(.25,.46,.45,.94),
              transform .75s cubic-bezier(.25,.46,.45,.94);
}
.fade-right.visible { opacity:1; transform:none }

.d1 { transition-delay:.08s }
.d2 { transition-delay:.16s }
.d3 { transition-delay:.24s }
.d4 { transition-delay:.32s }

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:10px;
  padding:13px 30px; font-size:11px; font-weight:600;
  letter-spacing:.2em; text-transform:uppercase;
  transition:all .28s; border:2px solid transparent; cursor:pointer;
}
.btn-rust  { background:var(--rust); color:var(--offwhite); border-color:var(--rust) }
.btn-rust:hover { background:var(--rust-light); border-color:var(--rust-light); transform:translateY(-2px); box-shadow:0 8px 24px rgba(192,74,30,.3) }
.btn-ghost { background:transparent; color:var(--sand); border-color:rgba(232,220,200,.32) }
.btn-ghost:hover { border-color:var(--sand); transform:translateY(-2px) }
.btn-ghost-rust { background:transparent; color:var(--rust-light); border-color:var(--rust) }
.btn-ghost-rust:hover { background:var(--rust); color:var(--offwhite); border-color:var(--rust) }
.btn-dark  { background:var(--charcoal); color:var(--sand); border-color:var(--charcoal-3) }
.btn-dark:hover { background:var(--charcoal-2) }

/* ═══════════════════════════════════════════
   NAV
   ═══════════════════════════════════════════ */
#nav {
  position:fixed; top:0; left:0; right:0; z-index:900;
  height:var(--nav-h); display:flex; align-items:center;
  transition:background .4s, box-shadow .4s;
}
#nav.solid {
  background:rgba(24,24,24,.97);
  box-shadow:0 1px 0 rgba(232,220,200,.08);
  backdrop-filter:blur(12px);
}

.nav-wrap { display:flex; align-items:center; justify-content:space-between; width:100% }

.logo-block { display:flex; flex-direction:column; gap:0 }
.logo-r { font-family:'Bebas Neue',sans-serif; font-size:1.75rem; letter-spacing:.08em; color:var(--sand); line-height:1 }
.logo-r span { color:var(--rust-light) }
.logo-sub { font-size:9px; font-weight:600; letter-spacing:.26em; text-transform:uppercase; color:var(--muted); margin-top:2px }

.nav-links { display:flex; gap:28px; align-items:center }
.nav-links a {
  font-size:11px; font-weight:600; letter-spacing:.16em; text-transform:uppercase;
  color:rgba(232,220,200,.6); transition:color .2s; padding-bottom:2px;
  border-bottom:1px solid transparent;
}
.nav-links a:hover { color:var(--sand); border-bottom-color:var(--rust) }

.nav-cta {
  font-size:11px; font-weight:600; letter-spacing:.18em; text-transform:uppercase;
  padding:9px 22px; border:1.5px solid var(--rust); color:var(--rust); transition:all .28s;
}
.nav-cta:hover { background:var(--rust); color:var(--offwhite) }

.burger { display:none; flex-direction:column; gap:5px; padding:4px }
.burger span { display:block; width:22px; height:1.5px; background:var(--sand); transition:all .3s }
.burger.open span:nth-child(1) { transform:rotate(45deg) translate(4.5px,4.5px) }
.burger.open span:nth-child(2) { opacity:0 }
.burger.open span:nth-child(3) { transform:rotate(-45deg) translate(4.5px,-4.5px) }

.mob-nav {
  position:fixed; inset:0; background:var(--charcoal-2); z-index:899;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:20px; opacity:0; pointer-events:none; transition:opacity .35s;
}
.mob-nav.open { opacity:1; pointer-events:all }
.mob-nav a { font-family:'Bebas Neue',sans-serif; font-size:2.6rem; letter-spacing:.06em; color:var(--sand); transition:color .2s; line-height:1 }
.mob-nav a:hover { color:var(--rust-light) }
.mob-nav .mob-cta { margin-top:10px; padding:12px 32px; border:1.5px solid var(--rust); color:var(--rust-light); font-family:'Outfit',sans-serif; font-size:11px; font-weight:600; letter-spacing:.2em; text-transform:uppercase }

/* ═══════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════ */
.hero {
  min-height: 100svh;
  display:flex; align-items:flex-end;
  position:relative; overflow:hidden;
  padding-top: var(--nav-h);
  padding-bottom: clamp(52px, 6vw, 88px);
}
.hero-img { position:absolute; top:0; right:0; width:58%; height:100%; z-index:0 }
.hero-img img { width:100%; height:100%; object-fit:cover; object-position:center top }
.hero-img::after {
  content:''; position:absolute; inset:0;
  background: linear-gradient(100deg, var(--charcoal) 38%, rgba(24,24,24,.82) 65%, transparent 100%);
}

.hero-content { position:relative; z-index:2; max-width:640px }

.hero-eyebrow {
  font-size:10px; font-weight:700; letter-spacing:.32em; text-transform:uppercase;
  color:var(--rust-light); display:flex; align-items:center; gap:14px; margin-bottom:22px;
}
.hero-eyebrow::before { content:''; width:32px; height:1px; background:var(--rust) }

/* Tighter title — was 5rem–13rem, now 3.8rem–7rem */
.hero-big {
  font-family:'Bebas Neue',sans-serif;
  font-size: clamp(3.8rem, 8.5vw, 7.5rem);
  letter-spacing:.03em; text-transform:uppercase;
  line-height:.92; color:var(--sand);
}
.hero-big span { display:block }
.hero-big .outline { -webkit-text-stroke:1.5px var(--sand); color:transparent }

.hero-lead {
  font-family:'Lora',serif; font-size:clamp(.95rem,1.3vw,1.15rem);
  font-style:italic; color:rgba(232,220,200,.8);
  max-width:460px; margin:26px 0 34px; line-height:1.75;
}
.hero-actions { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:52px }

.hero-ticker {
  display:flex; gap:36px; flex-wrap:wrap;
  border-top:1px solid rgba(232,220,200,.12); padding-top:28px;
}
.ticker-item .num {
  font-family:'Bebas Neue',sans-serif; font-size:2.2rem;
  letter-spacing:.04em; color:var(--sand); line-height:1;
}
.ticker-item .lbl {
  font-size:10px; font-weight:500; letter-spacing:.16em; text-transform:uppercase;
  color:var(--muted); margin-top:4px;
}

/* ═══════════════════════════════════════════
   SCROLL BAND
   ═══════════════════════════════════════════ */
.band { background:var(--rust); padding:14px 0; overflow:hidden; white-space:nowrap }
.band-track { display:inline-flex; animation:slide 24s linear infinite }
.band-item { font-family:'Bebas Neue',sans-serif; font-size:1.2rem; letter-spacing:.1em; color:var(--offwhite); padding:0 26px; opacity:.92 }
.band-sep { color:rgba(244,239,230,.35); padding:0 4px }
@keyframes slide { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ═══════════════════════════════════════════
   ABOUT STRIP
   ═══════════════════════════════════════════ */
.about-strip { display:grid; grid-template-columns:1fr 1fr; min-height:560px }
.about-strip-img { position:relative; overflow:hidden }
.about-strip-img img { width:100%; height:100%; object-fit:cover; transition:transform 8s ease }
.about-strip-img:hover img { transform:scale(1.04) }
.about-strip-text {
  padding: clamp(48px,6vw,88px) clamp(36px,5vw,72px);
  display:flex; flex-direction:column; justify-content:center;
  background:var(--offwhite);
}
.big-year {
  font-family:'Bebas Neue',sans-serif; font-size:clamp(4rem,7vw,8rem);
  letter-spacing:.04em; color:var(--sand-deep); line-height:1; margin-bottom:12px;
}
.about-strip-text h2 { color:var(--charcoal); margin-bottom:18px }
.about-strip-text p  { color:#584f42; max-width:420px; margin-bottom:12px }
.about-strip-text .btn { margin-top:20px; width:fit-content }

/* ═══════════════════════════════════════════
   SERVICES — dark
   ═══════════════════════════════════════════ */
.services-dark { background:var(--charcoal-2); padding:var(--section) 0 }

.sec-head { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:52px; gap:24px; flex-wrap:wrap }
.sec-head h2 { color:var(--sand) }
.sec-head p  { max-width:320px; color:var(--muted-lt) }

.svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:3px }
.svc-card { background:var(--charcoal-3); overflow:hidden; display:flex; flex-direction:column }
.svc-img  { aspect-ratio:4/3; overflow:hidden; position:relative }
.svc-img img { width:100%; height:100%; object-fit:cover; transition:transform .7s cubic-bezier(.25,.46,.45,.94) }
.svc-card:hover .svc-img img { transform:scale(1.07) }
.svc-num {
  position:absolute; top:14px; left:14px;
  font-family:'Bebas Neue',sans-serif; font-size:.88rem; letter-spacing:.12em;
  background:var(--rust); color:var(--offwhite); padding:3px 10px;
}
.svc-body  { padding:26px 26px 34px; flex:1; display:flex; flex-direction:column }
.svc-body h4 {
  font-family:'Lora',serif; font-size:1.25rem; font-weight:400;
  color:var(--sand); margin-bottom:10px;
}
.svc-body p  { font-size:.88rem; flex:1; margin-bottom:18px; color:var(--muted-lt) }
.svc-price   { display:flex; align-items:baseline; gap:6px; margin-top:auto }
.price-tag   { font-family:'Bebas Neue',sans-serif; font-size:2rem; letter-spacing:.04em; color:var(--rust-light) }
.price-from  { font-size:10px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--muted) }

/* ═══════════════════════════════════════════
   TEAM
   ═══════════════════════════════════════════ */
.team-section { background:var(--sand); padding:var(--section) 0 }
.team-section .sec-head h2 { color:var(--charcoal) }
.team-section .sec-head p  { color:var(--muted) }
.team-row { display:grid; grid-template-columns:repeat(4,1fr); gap:3px }
.team-card { position:relative; overflow:hidden; aspect-ratio:3/4; cursor:pointer; display:block }
.team-card img { width:100%; height:100%; object-fit:cover; object-position:center top; transition:transform .8s cubic-bezier(.25,.46,.45,.94) }
.team-card:hover img { transform:scale(1.07) }
.team-overlay { position:absolute; bottom:0; left:0; right:0; padding:56px 18px 20px; background:linear-gradient(to top,rgba(24,24,24,.9) 0%,transparent 100%); transform:translateY(4px); transition:transform .32s }
.team-card:hover .team-overlay { transform:none }
.team-name { font-family:'Bebas Neue',sans-serif; font-size:1.35rem; letter-spacing:.05em; color:var(--sand) }
.team-role { font-size:10px; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:rgba(232,220,200,.5); margin-top:4px }

/* ═══════════════════════════════════════════
   GALLERY MOSAIC
   ═══════════════════════════════════════════ */
.gallery-sec { background:var(--charcoal); padding:var(--section) 0 }
.gallery-sec h2 { color:var(--sand); margin-bottom:36px }
.mosaic { display:grid; grid-template-columns:repeat(12,1fr); grid-template-rows:240px 240px; gap:3px }
.m-item { overflow:hidden }
.m-item img { width:100%; height:100%; object-fit:cover; transition:transform .7s cubic-bezier(.25,.46,.45,.94) }
.m-item:hover img { transform:scale(1.06) }
.m1{grid-column:1/5;grid-row:1/3}
.m2{grid-column:5/8;grid-row:1/2}
.m3{grid-column:8/13;grid-row:1/2}
.m4{grid-column:5/9;grid-row:2/3}
.m5{grid-column:9/13;grid-row:2/3}
.gallery-cta { text-align:center; margin-top:36px }

/* ═══════════════════════════════════════════
   WHY — rust bg
   ═══════════════════════════════════════════ */
.why-sec { background:var(--rust); padding:var(--section) 0 }
.why-sec h2 { color:var(--offwhite); margin-bottom:48px }
.why-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:0; border:1px solid rgba(244,239,230,.18) }
.why-item { padding:32px 24px; border-right:1px solid rgba(244,239,230,.18) }
.why-item:last-child { border-right:none }
.why-num { font-family:'Bebas Neue',sans-serif; font-size:3.5rem; letter-spacing:.04em; color:rgba(244,239,230,.14); line-height:1; margin-bottom:14px }
.why-item h4 { font-family:'Lora',serif; font-weight:600; font-size:1rem; color:var(--offwhite); margin-bottom:10px }
.why-item p  { font-size:.86rem; color:rgba(244,239,230,.7); line-height:1.78 }

/* ═══════════════════════════════════════════
   TESTIMONIALS
   ═══════════════════════════════════════════ */
.test-sec { background:var(--offwhite); padding:var(--section) 0 }
.test-sec h2 { color:var(--charcoal); margin-bottom:44px }
.test-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px }
.test-card { background:var(--cream,#faf8f4); border:1px solid var(--sand-deep); padding:32px 28px; display:flex; flex-direction:column }
.test-stars { color:var(--rust); font-size:.82rem; letter-spacing:3px; margin-bottom:16px }
.test-quote { font-family:'Lora',serif; font-size:1rem; font-style:italic; color:var(--charcoal); line-height:1.72; flex:1; margin-bottom:22px }
.test-author { display:flex; align-items:center; gap:12px }
.test-av { width:38px; height:38px; background:var(--rust); display:flex; align-items:center; justify-content:center; font-family:'Bebas Neue',sans-serif; font-size:1.25rem; color:var(--offwhite); flex-shrink:0 }
.test-name { font-size:.88rem; font-weight:600; color:var(--charcoal) }
.test-since { font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-top:2px }

/* ═══════════════════════════════════════════
   CTA FULL
   ═══════════════════════════════════════════ */
.cta-full { position:relative; overflow:hidden; background:var(--charcoal-2); min-height:400px; display:flex; align-items:center }
.cta-bg { position:absolute; inset:0 }
.cta-bg img { width:100%; height:100%; object-fit:cover; opacity:.18; filter:saturate(.3) }
.cta-content { position:relative; z-index:1; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:40px; width:100%; padding:var(--section) 0 }
.cta-text .label { margin-bottom:14px }
.cta-big { font-family:'Bebas Neue',sans-serif; font-size:clamp(2.6rem,5.5vw,5.5rem); letter-spacing:.03em; color:var(--sand); line-height:.92; margin-bottom:14px }
.cta-text p { max-width:400px; color:var(--muted-lt) }
.cta-btns { display:flex; gap:12px; flex-shrink:0; flex-wrap:wrap }

/* ═══════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════ */
footer { background:#111; padding:clamp(48px,6vw,80px) 0 0 }
.foot-grid { display:grid; grid-template-columns:2.2fr 1fr 1fr 1.5fr; gap:48px; margin-bottom:48px }
.foot-logo .logo-r { font-size:1.9rem }
.foot-desc { font-size:.86rem; color:rgba(232,220,200,.38); line-height:1.82; margin-top:12px; max-width:260px }
.foot-soc { display:flex; gap:8px; margin-top:20px }
.soc-btn { width:36px; height:36px; border:1px solid rgba(232,220,200,.14); display:flex; align-items:center; justify-content:center; font-size:10px; font-weight:700; color:rgba(232,220,200,.38); transition:all .25s }
.soc-btn:hover { border-color:var(--sand); color:var(--sand) }
.foot-head { font-size:10px; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:rgba(232,220,200,.25); margin-bottom:16px }
.foot-links { display:flex; flex-direction:column; gap:10px }
.foot-links a { font-size:.87rem; color:rgba(232,220,200,.5); transition:color .2s }
.foot-links a:hover { color:var(--sand) }
.foot-row { display:flex; gap:12px; align-items:flex-start; margin-bottom:12px }
.foot-row .ic { color:var(--rust); font-size:.9rem; flex-shrink:0; margin-top:2px }
.foot-row span { font-size:.84rem; color:rgba(232,220,200,.5); line-height:1.65 }
.foot-bottom { border-top:1px solid rgba(232,220,200,.07); padding:22px 0; display:flex; justify-content:space-between; align-items:center }
.foot-bottom span { font-size:.78rem; color:rgba(232,220,200,.25) }

/* BTT */
#btt { position:fixed; bottom:26px; right:26px; width:42px; height:42px; background:var(--rust); color:var(--offwhite); display:flex; align-items:center; justify-content:center; font-size:.9rem; opacity:0; pointer-events:none; transition:all .3s; z-index:500; border:none; cursor:pointer }
#btt.show { opacity:1; pointer-events:all }
#btt:hover { background:var(--rust-light); transform:translateY(-3px) }

/* ═══════════════════════════════════════════
   INNER PAGE BANNER
   ═══════════════════════════════════════════ */
.page-banner {
  padding: calc(var(--nav-h) + 64px) 0 64px;
  background:var(--charcoal-2);
  position:relative; overflow:hidden;
}
.page-banner::after { content:''; position:absolute; bottom:0; left:0; right:0; height:2px; background:var(--rust) }
.page-banner .label { display:block; margin-bottom:16px }
.page-banner h1 {
  font-family:'Bebas Neue',sans-serif;
  font-size: clamp(3rem, 7vw, 6rem);
  letter-spacing:.04em; color:var(--sand); line-height:.94;
}
.page-banner p { max-width:500px; margin-top:16px; color:var(--muted-lt) }

/* ═══════════════════════════════════════════
   SERVICES PAGE
   ═══════════════════════════════════════════ */
.svc-full-section { background:var(--charcoal); padding:var(--section) 0 }
.svc-big-card { background:var(--charcoal-2); margin-bottom:3px; overflow:hidden }
.svc-big-inner { display:grid; grid-template-columns:1fr 1fr; min-height:400px }
.svc-big-img { overflow:hidden }
.svc-big-img img { width:100%; height:100%; object-fit:cover; transition:transform .8s }
.svc-big-card:hover .svc-big-img img { transform:scale(1.04) }
.svc-big-body { padding:clamp(36px,5vw,56px); display:flex; flex-direction:column; justify-content:center }
.svc-big-body .num-badge {
  font-family:'Bebas Neue',sans-serif; font-size:.85rem; letter-spacing:.14em;
  background:var(--rust); color:var(--offwhite); padding:3px 12px; width:fit-content; margin-bottom:18px;
}
.svc-big-body h3 { color:var(--sand); margin-bottom:14px }
.svc-big-body p  { color:var(--muted-lt); margin-bottom:14px; max-width:400px }
.svc-meta { display:flex; gap:28px; margin-top:24px; padding-top:22px; border-top:1px solid rgba(232,220,200,.1); flex-wrap:wrap }
.svc-meta-item .ml { font-size:10px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-bottom:4px }
.svc-meta-item .mv { font-family:'Bebas Neue',sans-serif; font-size:1.7rem; letter-spacing:.04em; color:var(--rust-light) }

.extras-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:3px; margin-top:clamp(40px,5vw,64px) }
.extra-card { background:var(--charcoal-2); padding:30px 26px }
.extra-card h4 { font-family:'Lora',serif; font-weight:400; font-size:1.2rem; color:var(--sand); margin-bottom:10px }
.extra-card p  { font-size:.86rem; color:var(--muted-lt); margin-bottom:16px }
.extra-price { font-family:'Bebas Neue',sans-serif; font-size:1.8rem; letter-spacing:.04em; color:var(--rust-light) }

/* ═══════════════════════════════════════════
   BARBERS PAGE
   ═══════════════════════════════════════════ */
.barbers-section { background:var(--charcoal); padding:var(--section) 0 }
.barber-card-full { display:grid; grid-template-columns:5fr 7fr; background:var(--charcoal-2); margin-bottom:3px; overflow:hidden; min-height:380px }
.barber-card-full:nth-child(even) { grid-template-columns:7fr 5fr }
.barber-card-full:nth-child(even) .bc-img  { order:2 }
.barber-card-full:nth-child(even) .bc-body { order:1 }
.bc-img { position:relative; overflow:hidden; min-height:340px }
.bc-img img { width:100%; height:100%; object-fit:cover; object-position:center top; transition:transform .8s }
.barber-card-full:hover .bc-img img { transform:scale(1.04) }
.bc-body { padding:clamp(32px,4vw,52px); display:flex; flex-direction:column; justify-content:center }
.bc-name { font-family:'Bebas Neue',sans-serif; font-size:clamp(1.8rem,3vw,2.8rem); letter-spacing:.04em; color:var(--sand); line-height:1; margin-bottom:4px }
.bc-role { font-size:10px; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--rust-light); margin-bottom:18px; display:block }
.bc-body p  { font-size:.9rem; color:var(--muted-lt); max-width:360px; margin-bottom:12px }
.tags { display:flex; flex-wrap:wrap; gap:8px; margin-top:14px }
.tag { font-size:10px; font-weight:600; letter-spacing:.13em; text-transform:uppercase; padding:5px 13px; border:1px solid rgba(232,220,200,.18); color:rgba(232,220,200,.5) }
.tag.rust { border-color:var(--rust); color:var(--rust-light) }
.bc-body .btn { margin-top:20px; width:fit-content }

/* ═══════════════════════════════════════════
   GALLERY PAGE
   ═══════════════════════════════════════════ */
.gallery-page { background:var(--charcoal); padding:var(--section) 0 }
.g-feature { overflow:hidden; margin-bottom:3px }
.g-feature img { width:100%; height:520px; object-fit:cover; object-position:center 35%; display:block; transition:transform 8s ease }
.g-feature:hover img { transform:scale(1.03) }
.g-grid3 { display:grid; grid-template-columns:repeat(3,1fr); gap:3px; margin-bottom:3px }
.g-grid2 { display:grid; grid-template-columns:repeat(2,1fr); gap:3px; margin-bottom:3px }
.g-item { overflow:hidden }
.g-item img { width:100%; height:270px; object-fit:cover; display:block; transition:transform .7s cubic-bezier(.25,.46,.45,.94) }
.g-item:hover img { transform:scale(1.06) }

/* ═══════════════════════════════════════════
   ABOUT PAGE
   ═══════════════════════════════════════════ */
.about-hero-split { display:grid; grid-template-columns:1fr 1fr; min-height:560px }
.ahs-img { overflow:hidden }
.ahs-img img { width:100%; height:100%; object-fit:cover; transition:transform 8s ease }
.ahs-img:hover img { transform:scale(1.04) }
.ahs-text { background:var(--offwhite); padding:clamp(48px,6vw,88px) clamp(36px,5vw,68px); display:flex; flex-direction:column; justify-content:center }
.ahs-text h2 { color:var(--charcoal); margin-bottom:18px }
.ahs-text p  { color:#584f42; margin-bottom:12px; max-width:440px }

.stats-band { background:var(--rust); padding:56px 0 }
.stats-row { display:grid; grid-template-columns:repeat(4,1fr); text-align:center; gap:0 }
.stat-it .sn { font-family:'Bebas Neue',sans-serif; font-size:clamp(2.8rem,5.5vw,4.8rem); letter-spacing:.04em; color:var(--offwhite); line-height:1 }
.stat-it .sl { font-size:10px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:rgba(244,239,230,.55); margin-top:8px }

.values-section { background:var(--charcoal); padding:var(--section) 0 }
.values-section h2 { color:var(--sand); margin-bottom:44px }
.vals-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:3px }
.val-card { background:var(--charcoal-2); padding:32px 28px }
.val-card h4 { font-family:'Lora',serif; font-weight:400; font-size:1.15rem; color:var(--sand); border-bottom:1px solid var(--rust); padding-bottom:12px; margin-bottom:14px }
.val-card p  { font-size:.88rem; color:var(--muted-lt) }

/* ═══════════════════════════════════════════
   CONTACT PAGE
   ═══════════════════════════════════════════ */
.contact-split { display:grid; grid-template-columns:1fr 1fr; min-height:540px }
.contact-img { overflow:hidden }
.contact-img img { width:100%; height:100%; object-fit:cover }
.contact-info { background:var(--offwhite); padding:clamp(48px,6vw,86px) clamp(36px,5vw,68px); display:flex; flex-direction:column; justify-content:center }
.contact-info h2 { color:var(--charcoal); margin-bottom:32px }
.ci-row { display:flex; gap:16px; align-items:flex-start; margin-bottom:24px }
.ci-row .ic { color:var(--rust); font-size:1.1rem; flex-shrink:0; margin-top:2px }
.ci-label { font-size:10px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin-bottom:4px }
.ci-val { font-size:.93rem; color:var(--charcoal); line-height:1.65 }
.hrs { display:grid; grid-template-columns:auto 1fr; gap:3px 14px; margin-top:6px }
.hrs .day  { font-size:.86rem; font-weight:600; color:var(--charcoal) }
.hrs .time { font-size:.86rem; color:var(--muted) }
.contact-extras { background:var(--charcoal-2); padding:clamp(40px,5vw,64px) 0 }
.ce-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:3px }
.ce-card { background:var(--charcoal-3); padding:28px 26px }
.ce-card h4 { font-family:'Outfit',sans-serif; font-weight:600; color:var(--sand); margin-bottom:10px; font-size:.95rem }
.ce-card p  { font-size:.85rem; color:var(--muted-lt) }

/* ═══════════════════════════════════════════
   BOOKING PAGE — completely reworked clarity
   ═══════════════════════════════════════════ */
.book-page { background:var(--charcoal); min-height:100vh; padding-top:var(--nav-h) }
.book-layout { display:grid; grid-template-columns:380px 1fr }

/* Sidebar */
.book-side {
  background:var(--charcoal-2);
  border-right:1px solid rgba(232,220,200,.08);
  padding:clamp(36px,4vw,56px) clamp(28px,3vw,44px);
  position:sticky; top:var(--nav-h);
  height:calc(100vh - var(--nav-h));
  overflow-y:auto;
  display:flex; flex-direction:column; gap:0;
}
.book-side h2 {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2.2rem,3.5vw,3.2rem);
  letter-spacing:.04em; color:var(--sand);
  line-height:.94; margin-bottom:12px;
}
.book-side > p { font-size:.88rem; color:var(--muted-lt); line-height:1.78; padding-bottom:28px }

.book-info { display:flex; flex-direction:column; gap:16px; border-top:1px solid rgba(232,220,200,.1); padding-top:24px; margin-top:auto }
.bi-row { display:flex; gap:12px; align-items:flex-start }
.bi-ic  { color:var(--rust-light); font-size:.9rem; flex-shrink:0; margin-top:1px }
.bi-lbl { font-size:9px; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:rgba(232,220,200,.38); margin-bottom:3px }
.bi-val { font-size:.84rem; color:rgba(232,220,200,.62); line-height:1.6 }

.demo-note {
  background:rgba(192,74,30,.1);
  border:1px solid rgba(192,74,30,.28);
  padding:12px 14px; margin-top:18px;
  border-radius:0;
}
.demo-note p { font-size:.77rem; color:rgba(232,220,200,.5); line-height:1.65 }

/* Main booking area */
.book-main { padding:clamp(36px,4vw,56px) clamp(28px,4vw,52px) }

.step-block { margin-bottom:44px }
.step-hd { display:flex; align-items:center; gap:12px; margin-bottom:22px }
.step-badge {
  width:30px; height:30px; background:var(--rust);
  display:flex; align-items:center; justify-content:center;
  font-size:11px; font-weight:700; color:var(--offwhite); flex-shrink:0;
  font-family:'Outfit',sans-serif;
}
.step-title { font-size:11px; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--sand) }
.step-rule  { height:1px; background:rgba(232,220,200,.1); margin-bottom:44px }

/* Calendar — bigger, more readable */
.cal-nav { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px }
.cal-month { font-family:'Bebas Neue',sans-serif; font-size:1.5rem; letter-spacing:.05em; color:var(--sand) }
.cal-arr { width:32px; height:32px; border:1px solid rgba(232,220,200,.2); display:flex; align-items:center; justify-content:center; color:var(--muted-lt); font-size:.9rem; transition:all .22s; cursor:pointer; background:none }
.cal-arr:hover { border-color:var(--rust); color:var(--rust-light) }
.cal-wk  { display:grid; grid-template-columns:repeat(7,1fr); text-align:center; margin-bottom:6px }
.cal-wk span { font-size:9px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); padding:8px 0 }
.cal-days { display:grid; grid-template-columns:repeat(7,1fr); gap:4px }
.cd {
  aspect-ratio:1; display:flex; align-items:center; justify-content:center;
  font-size:.86rem; font-weight:500; cursor:pointer;
  border:1.5px solid transparent; transition:all .18s;
  color:var(--sand); background:var(--charcoal-3);
}
.cd:hover:not(.past):not(.empty) { border-color:var(--rust-light); color:var(--rust-light) }
.cd.past  { color:rgba(232,220,200,.2); background:transparent; cursor:not-allowed }
.cd.empty { background:transparent; cursor:default }
.cd.selected { background:var(--rust); color:var(--offwhite) !important; border-color:var(--rust) }
.cd.today { border-color:rgba(192,74,30,.5); color:var(--rust-light) }

/* Time slots — 5 per row, clear contrast */
.ts-hint { font-size:.82rem; color:var(--muted-lt); margin-bottom:14px; line-height:1.6 }
.time-wrap { display:grid; grid-template-columns:repeat(5,1fr); gap:6px }
.ts {
  padding:11px 6px; border:1.5px solid rgba(232,220,200,.18);
  background:var(--charcoal-3); text-align:center;
  font-size:.82rem; font-weight:600; cursor:pointer;
  color:var(--sand); transition:all .18s; letter-spacing:.02em;
}
.ts:hover:not(.full) { border-color:var(--rust-light); color:var(--rust-light); background:var(--charcoal-4) }
.ts.selected { background:var(--rust); color:var(--offwhite); border-color:var(--rust) }
.ts.full { color:rgba(232,220,200,.22); text-decoration:line-through; cursor:not-allowed; background:transparent; border-color:rgba(232,220,200,.08) }

/* Barber select — clear photos */
.bsel-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:10px }
.bsel {
  display:flex; align-items:center; gap:14px;
  padding:14px 16px; border:1.5px solid rgba(232,220,200,.15);
  background:var(--charcoal-3); cursor:pointer; transition:all .2s;
  width:100%;
}
.bsel:hover { border-color:var(--rust); background:var(--charcoal-4) }
.bsel.selected { border-color:var(--rust); background:var(--rust-dim) }
.bsel-img { width:52px; height:52px; overflow:hidden; flex-shrink:0 }
.bsel-img img { width:100%; height:100%; object-fit:cover; object-position:center top }
.bsel-name { font-size:.9rem; font-weight:600; color:var(--sand) }
.bsel-role { font-size:9.5px; font-weight:600; letter-spacing:.13em; text-transform:uppercase; color:var(--muted-lt); margin-top:3px }
.bsel.selected .bsel-name { color:var(--offwhite) }
.bsel.selected .bsel-role { color:rgba(244,239,230,.6) }

/* Summary box */
.summary-box { background:var(--charcoal-2); border:1px solid rgba(232,220,200,.1); padding:28px }
.summary-box .sh { font-size:10px; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--muted-lt); margin-bottom:20px }
.sum-row { display:flex; justify-content:space-between; align-items:center; padding:12px 0; border-bottom:1px solid rgba(232,220,200,.08) }
.sum-row:last-of-type { border-bottom:none }
.sum-lbl { font-size:10px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:rgba(232,220,200,.35) }
.sum-val { font-family:'Lora',serif; font-size:1.05rem; color:var(--sand) }
.sum-val.empty { font-family:'Outfit',sans-serif; font-size:.82rem; color:rgba(232,220,200,.25); font-style:italic }

.book-btn {
  width:100%; padding:16px; margin-top:16px;
  background:var(--rust); color:var(--offwhite);
  font-size:11px; font-weight:700; letter-spacing:.22em; text-transform:uppercase;
  border:none; cursor:pointer; transition:background .28s; font-family:'Outfit',sans-serif;
}
.book-btn:hover:not(:disabled) { background:var(--rust-light) }
.book-btn:disabled { background:rgba(232,220,200,.1); color:rgba(232,220,200,.25); cursor:not-allowed }
.book-legal { font-size:.74rem; color:rgba(232,220,200,.22); margin-top:10px; text-align:center; line-height:1.6 }

/* Confirm overlay */
.confirm-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.88); z-index:9999; align-items:center; justify-content:center }
.confirm-overlay.show { display:flex }
.confirm-box { background:var(--offwhite); max-width:440px; width:90%; padding:48px 40px; text-align:center }
.confirm-icon { font-size:2.2rem; color:var(--rust); margin-bottom:18px }
.confirm-box h3 { font-family:'Bebas Neue',sans-serif; font-size:2.2rem; letter-spacing:.04em; color:var(--charcoal); margin-bottom:8px }
.confirm-box p { font-size:.88rem; color:var(--muted); margin-bottom:16px; line-height:1.75 }
.confirm-detail { display:inline-block; background:var(--sand); padding:8px 18px; font-size:.84rem; font-weight:600; color:var(--charcoal); margin-bottom:18px }
.demo-warn { background:var(--sand-deep); padding:12px 16px; font-size:.76rem; color:var(--charcoal); margin-bottom:22px; line-height:1.65 }
.confirm-close { background:var(--rust); color:var(--offwhite); padding:12px 34px; font-size:11px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; border:none; cursor:pointer; transition:background .25s; font-family:'Outfit',sans-serif }
.confirm-close:hover { background:var(--rust-light) }

/* ═══════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════ */
@media(max-width:1100px){
  .book-layout{grid-template-columns:1fr}
  .book-side{position:static;height:auto}
  .about-hero-split,.contact-split,.about-strip{grid-template-columns:1fr}
  .about-strip-img,.ahs-img,.contact-img{min-height:360px}
  .why-grid{grid-template-columns:1fr 1fr}
  .why-item{border-bottom:1px solid rgba(244,239,230,.18)}
  .barber-card-full,.barber-card-full:nth-child(even){grid-template-columns:1fr}
  .barber-card-full:nth-child(even) .bc-img,.barber-card-full:nth-child(even) .bc-body{order:unset}
  .svc-big-inner{grid-template-columns:1fr}
  .svc-big-img{min-height:300px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:36px}
}
@media(max-width:768px){
  .nav-links,.nav-cta{display:none}
  .burger{display:flex}
  .hero-img{width:100%;opacity:.3}
  .hero-big{font-size:clamp(3.2rem,10vw,5.5rem)}
  .svc-grid{grid-template-columns:1fr}
  .team-row{grid-template-columns:1fr 1fr}
  .test-grid{grid-template-columns:1fr}
  .mosaic{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .m1,.m2,.m3,.m4,.m5{grid-column:auto;grid-row:auto}
  .m-item img{aspect-ratio:1/1;height:auto}
  .why-grid{grid-template-columns:1fr}
  .stats-row{grid-template-columns:1fr 1fr;gap:24px}
  .vals-grid,.extras-grid,.ce-grid{grid-template-columns:1fr}
  .g-grid3{grid-template-columns:1fr 1fr}
  .g-grid2{grid-template-columns:1fr}
  .g-feature img{height:300px}
  .foot-grid{grid-template-columns:1fr}
  .cta-content{flex-direction:column;text-align:center}
  .cta-btns{flex-direction:column}
  .hero-actions,.cta-btns{flex-direction:column}
  .hero-ticker{gap:20px;flex-wrap:wrap}
  .time-wrap{grid-template-columns:repeat(4,1fr)}
  .bsel-grid{grid-template-columns:1fr}
  .book-main{padding:28px 18px}
  .book-side{padding:28px 18px}
  .sec-head{flex-direction:column;align-items:flex-start}
}
