/* ============================================================
   FADE TITE — Premium Barbershop
   Palette: charcoal black, bone white, barber gold
   ============================================================ */

:root {
  --black: #0c0b0a;
  --charcoal: #141210;
  --charcoal-2: #1b1815;
  --bone: #f4efe6;
  --bone-dim: #b8b1a4;
  --gold: #c79a3b;
  --gold-bright: #e7c46a;
  --red: #b13b35;
  --blue: #2f5d8c;
  --ease: cubic-bezier(0.65, 0.05, 0.2, 1);
  --gut: clamp(1.25rem, 5vw, 6rem);
}

* { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  background: var(--black);
  color: var(--bone);
  font-family: 'Inter', sans-serif;
  font-weight: 400;
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

::selection { background: var(--gold); color: var(--black); }

h1, h2, h3, h4 { font-family: 'Oswald', sans-serif; font-weight: 600; line-height: 1.02; }

.display { font-family: 'Bebas Neue', sans-serif; }

/* ============================================================
   CUSTOM CURSOR
   ============================================================ */
.cursor, .cursor-dot {
  position: fixed; top: 0; left: 0;
  border-radius: 50%;
  pointer-events: none; z-index: 9999;
  transform: translate(-50%, -50%);
  mix-blend-mode: difference;
}
.cursor {
  width: 38px; height: 38px;
  border: 1.5px solid var(--bone);
  transition: width .3s var(--ease), height .3s var(--ease), background .3s;
}
.cursor-dot { width: 5px; height: 5px; background: var(--bone); }
.cursor.is-hover { width: 70px; height: 70px; background: var(--bone); }
@media (hover: none) { .cursor, .cursor-dot { display: none; } }

/* ============================================================
   PRELOADER
   ============================================================ */
.preloader {
  position: fixed; inset: 0; z-index: 10000;
  background: var(--black);
  display: grid; place-items: center;
}
.preloader__inner { text-align: center; }
.preloader__pole {
  width: 16px; height: 90px; margin: 0 auto 1.5rem;
  border-radius: 20px; overflow: hidden;
  border: 2px solid var(--bone);
  background: repeating-linear-gradient(45deg, var(--red) 0 10px, var(--bone) 10px 20px, var(--blue) 20px 30px, var(--bone) 30px 40px);
  background-size: 100% 56px;
  animation: poleSpin 1s linear infinite;
}
@keyframes poleSpin { to { background-position: 0 -56px; } }
.preloader__count {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 3rem; color: var(--gold); letter-spacing: 2px;
}
.preloader__brand {
  font-family: 'Bebas Neue', sans-serif;
  letter-spacing: 8px; color: var(--bone-dim); font-size: .9rem; margin-top: .5rem;
}

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 900;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.5rem var(--gut);
  transition: padding .4s var(--ease), background .4s var(--ease);
  mix-blend-mode: difference;
}
.nav.scrolled {
  padding: .9rem var(--gut);
  background: rgba(12,11,10,.0);
}
.nav__logo {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.6rem; letter-spacing: 3px; color: var(--bone);
}
.nav__logo span { color: var(--gold); }
.nav__links { display: flex; gap: 2.2rem; }
.nav__links a {
  font-family: 'Oswald', sans-serif; font-weight: 400;
  font-size: .82rem; text-transform: uppercase; letter-spacing: 2px;
  color: var(--bone); position: relative; padding: .3rem 0;
}
.nav__links a::after {
  content: ''; position: absolute; left: 0; bottom: 0;
  width: 0; height: 1px; background: var(--gold); transition: width .35s var(--ease);
}
.nav__links a:hover::after { width: 100%; }
.nav__burger { display: none; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  font-family: 'Oswald', sans-serif; font-weight: 500;
  text-transform: uppercase; letter-spacing: 2px; font-size: .8rem;
  padding: 1rem 2rem; border-radius: 2px;
  transition: transform .35s var(--ease), background .35s, color .35s, box-shadow .35s;
  cursor: pointer; border: 1px solid transparent; position: relative; overflow: hidden;
}
.btn--gold { background: var(--gold); color: var(--black); }
.btn--gold:hover { background: var(--gold-bright); transform: translateY(-3px); box-shadow: 0 18px 40px -18px var(--gold); }
.btn--ghost { background: transparent; border-color: rgba(244,239,230,.3); color: var(--bone); }
.btn--ghost:hover { border-color: var(--gold); color: var(--gold); transform: translateY(-3px); }
.btn:focus-visible,
.nav a:focus-visible,
.nav__burger:focus-visible,
.visit__row:focus-visible {
  outline: 2px solid var(--gold-bright);
  outline-offset: 4px;
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position: relative; min-height: 100svh;
  display: flex; flex-direction: column; justify-content: center;
  padding: 8rem var(--gut) 3rem;
  overflow: hidden;
}
.hero__bg {
  position: absolute; inset: 0; z-index: 0;
  background:
    linear-gradient(90deg, rgba(12,11,10,.94) 0%, rgba(12,11,10,.82) 40%, rgba(12,11,10,.42) 100%),
    linear-gradient(180deg, rgba(12,11,10,.18), rgba(12,11,10,.88)),
    url("https://images.unsplash.com/photo-1585747860715-2ba37e788b70?q=80&w=1800&auto=format&fit=crop") right center/cover,
    radial-gradient(120% 80% at 80% 0%, rgba(199,154,59,.14), transparent 55%),
    linear-gradient(180deg, #100e0c 0%, #0c0b0a 100%);
}
.hero__bg::before {
  content: ''; position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(244,239,230,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(244,239,230,.035) 1px, transparent 1px);
  background-size: 70px 70px;
  mask-image: radial-gradient(80% 80% at 70% 40%, #000, transparent);
}
.hero__grain {
  position: absolute; inset: 0; z-index: 1; opacity: .05; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.hero__pole {
  position: absolute; right: var(--gut); top: 50%; transform: translateY(-50%);
  z-index: 2;
}
.pole {
  width: 34px; height: 320px; border-radius: 30px; overflow: hidden;
  border: 3px solid var(--bone);
  box-shadow: 0 0 50px -10px rgba(199,154,59,.5);
  background: repeating-linear-gradient(45deg, var(--red) 0 14px, var(--bone) 14px 28px, var(--blue) 28px 42px, var(--bone) 42px 56px);
  background-size: 100% 56px;
  animation: poleSpin 1.4s linear infinite;
}
.hero__content { position: relative; z-index: 3; max-width: 880px; }
.hero__eyebrow {
  display: flex; align-items: center; gap: 1rem;
  font-family: 'Oswald', sans-serif; text-transform: uppercase;
  letter-spacing: 4px; font-size: .8rem; color: var(--gold);
  margin-bottom: 1.5rem;
}
.hero__eyebrow .line { width: 50px; height: 1px; background: var(--gold); display: inline-block; }
.hero__title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(4rem, 16vw, 13rem);
  line-height: .85; letter-spacing: 2px;
  margin-bottom: 1.8rem;
}
.reveal-line { display: block; overflow: hidden; }
.reveal-line > span { display: block; }
.reveal-line.outline > span {
  -webkit-text-stroke: 2px var(--gold);
  color: transparent;
}
.hero__sub {
  max-width: 520px; color: var(--bone-dim); font-size: 1.05rem;
  margin-bottom: 2.5rem;
}
.hero__actions { display: flex; gap: 1rem; flex-wrap: wrap; }
.hero__meta {
  position: relative; z-index: 3;
  display: flex; align-items: flex-end; justify-content: space-between;
  margin-top: 4rem;
}
.hero__rating { display: flex; flex-direction: column; gap: .3rem; }
.stars, .review__stars { color: var(--gold); letter-spacing: 3px; }
.hero__rating span { font-size: .8rem; color: var(--bone-dim); letter-spacing: 1px; }
.hero__scroll {
  display: flex; flex-direction: column; align-items: center; gap: .6rem;
  font-family: 'Oswald', sans-serif; text-transform: uppercase;
  letter-spacing: 3px; font-size: .7rem; color: var(--bone-dim);
}
.hero__scroll-line { width: 1px; height: 50px; background: linear-gradient(var(--gold), transparent); }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee {
  border-top: 1px solid rgba(244,239,230,.1);
  border-bottom: 1px solid rgba(244,239,230,.1);
  overflow: hidden; padding: 1.4rem 0;
  background: var(--charcoal);
}
.marquee__track {
  display: flex; align-items: center; gap: 2.5rem; width: max-content;
  will-change: transform;
}
.marquee__track span {
  font-family: 'Bebas Neue', sans-serif; font-size: 2.2rem;
  letter-spacing: 3px; color: var(--bone); white-space: nowrap;
}
.marquee__track .dot { color: var(--gold); }

/* ============================================================
   STATS
   ============================================================ */
.stats {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1px; background: rgba(244,239,230,.08);
  border-bottom: 1px solid rgba(244,239,230,.08);
}
.stat {
  background: var(--black); padding: 3.5rem var(--gut);
  text-align: center;
}
.stat__num {
  display: block; font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(3rem, 6vw, 5rem); color: var(--gold); line-height: 1;
}
.stat__label {
  font-family: 'Oswald', sans-serif; text-transform: uppercase;
  letter-spacing: 2px; font-size: .75rem; color: var(--bone-dim);
}

/* ============================================================
   SECTION HEAD
   ============================================================ */
.section-head { max-width: 760px; margin: 0 auto 4rem; text-align: center; padding: 0 var(--gut); }
.section-head__eyebrow {
  font-family: 'Oswald', sans-serif; text-transform: uppercase;
  letter-spacing: 4px; font-size: .78rem; color: var(--gold); margin-bottom: 1rem;
}
.section-head__title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(2.8rem, 8vw, 6rem); letter-spacing: 2px; line-height: .9;
}
.section-head__title em { color: var(--gold); font-style: normal; }
.section-head__lead { color: var(--bone-dim); margin-top: 1.2rem; }

/* ============================================================
   SERVICES
   ============================================================ */
.services { padding: 7rem 0 5rem; }
.services__list { max-width: 1100px; margin: 0 auto; padding: 0 var(--gut); }
.service {
  display: grid; grid-template-columns: 70px 1fr auto;
  align-items: center; gap: 1.5rem;
  padding: 2rem 1rem; border-top: 1px solid rgba(244,239,230,.1);
  position: relative; transition: padding-left .4s var(--ease);
}
.service:last-of-type { border-bottom: 1px solid rgba(244,239,230,.1); }
.service::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 0;
  background: linear-gradient(90deg, rgba(199,154,59,.12), transparent);
  transition: width .4s var(--ease); z-index: -1;
}
.service:hover::before { width: 100%; }
.service:hover { padding-left: 1.5rem; }
.service__index { font-family: 'Bebas Neue', sans-serif; font-size: 1.4rem; color: var(--gold); }
.service__body h3 { font-size: 1.7rem; font-family: 'Oswald', sans-serif; font-weight: 600; }
.service__body p { color: var(--bone-dim); font-size: .92rem; margin-top: .2rem; max-width: 480px; }
.service__price {
  font-family: 'Bebas Neue', sans-serif; font-size: 2.4rem; color: var(--bone);
  transition: color .35s;
}
.service:hover .service__price { color: var(--gold); }
.services__note { text-align: center; color: var(--bone-dim); font-size: .82rem; margin-top: 2.5rem; padding: 0 var(--gut); }

/* ============================================================
   ABOUT
   ============================================================ */
.about {
  display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 6vw, 6rem);
  align-items: center; padding: 7rem var(--gut);
}
.about__img-wrap { position: relative; }
.about__img {
  aspect-ratio: 4/5; border-radius: 4px; overflow: hidden;
  background:
    linear-gradient(180deg, rgba(12,11,10,.1), rgba(12,11,10,.85)),
    url("https://images.unsplash.com/photo-1503951914875-452162b0f3f1?q=80&w=1200&auto=format&fit=crop") center/cover;
  filter: grayscale(.3) contrast(1.05);
}
.about__badge {
  position: absolute; bottom: -28px; right: -10px;
  width: 130px; height: 130px; border-radius: 50%;
  background: var(--gold); color: var(--black);
  display: grid; place-content: center; text-align: center;
  font-family: 'Bebas Neue', sans-serif; transform: rotate(-8deg);
  box-shadow: 0 20px 40px -15px rgba(199,154,59,.6);
}
.about__badge span { font-size: .8rem; letter-spacing: 2px; }
.about__badge strong { font-size: 1.5rem; letter-spacing: 1px; display: block; }
.about__title { font-family: 'Bebas Neue', sans-serif; font-size: clamp(2.5rem, 6vw, 4.5rem); letter-spacing: 1px; margin: 1rem 0 1.5rem; }
.about__title em { color: var(--gold); font-style: normal; }
.about__content > p { color: var(--bone-dim); margin-bottom: 1rem; }
.about__points { list-style: none; margin: 1.8rem 0; display: grid; grid-template-columns: 1fr 1fr; gap: .8rem; }
.about__points li { display: flex; align-items: center; gap: .6rem; font-size: .92rem; }
.about__points span { color: var(--gold); }

/* ============================================================
   TEAM
   ============================================================ */
.team { padding: 5rem 0 7rem; }
.team__grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1.2rem; max-width: 1200px; margin: 0 auto; padding: 0 var(--gut);
}
.barber { position: relative; overflow: hidden; border-radius: 4px; }
.barber__photo {
  aspect-ratio: 3/4; background-size: cover; background-position: center;
  filter: grayscale(1) contrast(1.05);
  transition: filter .5s var(--ease), transform .8s var(--ease);
}
.barber__photo--1 { background-image: linear-gradient(180deg, transparent 40%, rgba(12,11,10,.9)), url("https://images.unsplash.com/photo-1599351431202-1e0f0137899a?q=80&w=900&auto=format&fit=crop"); }
.barber__photo--2 { background-image: linear-gradient(180deg, transparent 40%, rgba(12,11,10,.9)), url("https://images.unsplash.com/photo-1622286342621-4bd786c2447c?q=80&w=900&auto=format&fit=crop"); }
.barber__photo--3 { background-image: linear-gradient(180deg, transparent 40%, rgba(12,11,10,.9)), url("https://images.unsplash.com/photo-1605497788044-5a32c7078486?q=80&w=900&auto=format&fit=crop"); }
.barber__photo--4 { background-image: linear-gradient(180deg, transparent 40%, rgba(12,11,10,.9)), url("https://images.unsplash.com/photo-1521590832167-7bcbfaa6381f?q=80&w=900&auto=format&fit=crop"); }
.barber:hover .barber__photo { filter: grayscale(0) contrast(1.05); transform: scale(1.05); }
.barber__info { position: absolute; bottom: 0; left: 0; padding: 1.5rem; }
.barber__info h3 { font-family: 'Bebas Neue', sans-serif; font-size: 2rem; letter-spacing: 1px; }
.barber__info span { font-family: 'Oswald', sans-serif; text-transform: uppercase; letter-spacing: 2px; font-size: .72rem; color: var(--gold); }

/* ============================================================
   GALLERY
   ============================================================ */
.gallery { padding: 5rem 0 7rem; }
.gallery__grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 220px; gap: 1rem;
  max-width: 1300px; margin: 0 auto; padding: 0 var(--gut);
}
.gallery__item { background-size: cover; background-position: center; border-radius: 4px; filter: grayscale(.5) brightness(.85); transition: filter .5s, transform .6s var(--ease); }
.gallery__item:hover { filter: grayscale(0) brightness(1); transform: scale(.98); }
.g1 { grid-column: span 2; grid-row: span 2; background-image: url("https://images.unsplash.com/photo-1585747860715-2ba37e788b70?q=80&w=1200&auto=format&fit=crop"); }
.g2 { background-image: url("https://images.unsplash.com/photo-1503951914875-452162b0f3f1?q=80&w=800&auto=format&fit=crop"); }
.g3 { background-image: url("https://images.unsplash.com/photo-1622286342621-4bd786c2447c?q=80&w=800&auto=format&fit=crop"); }
.g4 { grid-column: span 2; background-image: url("https://images.unsplash.com/photo-1635273051937-a0d3bca6c5e9?q=80&w=1000&auto=format&fit=crop"); }
.g5 { background-image: url("https://images.unsplash.com/photo-1599351431202-1e0f0137899a?q=80&w=800&auto=format&fit=crop"); }
.g6 { background-image: url("https://images.unsplash.com/photo-1605497788044-5a32c7078486?q=80&w=800&auto=format&fit=crop"); }

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews { padding: 5rem 0 7rem; overflow: hidden; }
.reviews__track { display: flex; gap: 1.5rem; padding: 0 var(--gut); width: max-content; }
.review {
  width: 380px; flex-shrink: 0;
  background: var(--charcoal); border: 1px solid rgba(244,239,230,.08);
  border-radius: 4px; padding: 2.2rem;
}
.review__stars { margin-bottom: 1rem; letter-spacing: 3px; }
.review p { font-size: 1.1rem; line-height: 1.5; margin-bottom: 1.2rem; font-family: 'Oswald', sans-serif; font-weight: 300; }
.review cite { color: var(--gold); font-style: normal; font-size: .85rem; letter-spacing: 1px; }

/* ============================================================
   VISIT
   ============================================================ */
.visit { padding: 5rem var(--gut) 7rem; }
.visit__inner {
  display: grid; grid-template-columns: 1.3fr 1fr; gap: clamp(2rem, 5vw, 5rem);
  max-width: 1200px; margin: 0 auto;
  background:
    radial-gradient(100% 100% at 0% 0%, rgba(199,154,59,.08), transparent 60%),
    var(--charcoal);
  border: 1px solid rgba(244,239,230,.08); border-radius: 6px;
  padding: clamp(2rem, 5vw, 4.5rem);
}
.visit__title { font-family: 'Bebas Neue', sans-serif; font-size: clamp(2.8rem, 7vw, 5rem); letter-spacing: 1px; margin: 1rem 0; }
.visit__title em { color: var(--gold); font-style: normal; }
.visit__lead { color: var(--bone-dim); max-width: 460px; margin-bottom: 2.5rem; }
.visit__rows { display: flex; flex-direction: column; }
.visit__row {
  display: grid; grid-template-columns: 110px 1fr; gap: 1rem; align-items: center;
  padding: 1.3rem 0; border-top: 1px solid rgba(244,239,230,.1);
}
.visit__rows .visit__row:last-child { border-bottom: 1px solid rgba(244,239,230,.1); }
.visit__row-label { font-family: 'Oswald', sans-serif; text-transform: uppercase; letter-spacing: 2px; font-size: .72rem; color: var(--gold); }
.visit__row-val { font-size: 1rem; }
.visit__row-val em { color: var(--bone-dim); font-style: normal; }
a.visit__row:hover .visit__row-val { color: var(--gold-bright); }
.visit__actions { display: flex; gap: 1rem; margin-top: 2.5rem; flex-wrap: wrap; }

.visit__hours-card {
  background: var(--black); border: 1px solid rgba(244,239,230,.08);
  border-radius: 4px; padding: 2rem; align-self: start;
}
.visit__hours-card h3 { font-family: 'Bebas Neue', sans-serif; font-size: 1.8rem; letter-spacing: 1px; margin-bottom: 1.2rem; color: var(--gold); }
.visit__hours-card ul { list-style: none; }
.visit__hours-card li {
  display: flex; justify-content: space-between;
  padding: .7rem 0; border-bottom: 1px dashed rgba(244,239,230,.1);
  font-size: .92rem;
}
.visit__hours-card li span:first-child { color: var(--bone-dim); }
.visit__hours-card li.closed span:last-child { color: var(--red); }
.visit__status {
  margin-top: 1.2rem; font-family: 'Oswald', sans-serif; text-transform: uppercase;
  letter-spacing: 2px; font-size: .78rem; padding: .6rem 1rem; border-radius: 30px;
  display: inline-block; border: 1px solid rgba(244,239,230,.15);
}
.visit__status.open { color: #6cc070; border-color: rgba(108,192,112,.4); }
.visit__status.closed { color: var(--red); border-color: rgba(177,59,53,.4); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { padding: 5rem var(--gut) 2rem; border-top: 1px solid rgba(244,239,230,.08); }
.footer__big {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(4rem, 20vw, 18rem); line-height: .8; letter-spacing: 2px;
  text-align: center; color: transparent; -webkit-text-stroke: 1.5px rgba(244,239,230,.18);
  transition: -webkit-text-stroke .4s;
}
.footer__big:hover { -webkit-text-stroke: 1.5px var(--gold); }
.footer__cols {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem;
  max-width: 1000px; margin: 3rem auto; padding-top: 3rem;
  border-top: 1px solid rgba(244,239,230,.08);
}
.footer__cols h4 { font-family: 'Oswald', sans-serif; text-transform: uppercase; letter-spacing: 2px; font-size: .8rem; color: var(--gold); margin-bottom: .8rem; }
.footer__cols p { color: var(--bone-dim); font-size: .92rem; margin-bottom: .3rem; }
.footer__cols a:hover { color: var(--gold); }
.footer__bottom {
  display: flex; justify-content: space-between; max-width: 1000px; margin: 0 auto;
  padding-top: 1.5rem; border-top: 1px solid rgba(244,239,230,.08);
  font-size: .78rem; color: var(--bone-dim); letter-spacing: 1px;
}

/* ============================================================
   REVEAL ANIMATION DEFAULTS
   ============================================================ */
.fade-up { opacity: 0; transform: translateY(40px); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 980px) {
  .stats { grid-template-columns: repeat(2, 1fr); }
  .about { grid-template-columns: 1fr; }
  .about__media { max-width: 420px; }
  .team__grid { grid-template-columns: repeat(2, 1fr); }
  .gallery__grid { grid-template-columns: repeat(2, 1fr); }
  .g1, .g4 { grid-column: span 2; }
  .g1 { grid-row: span 1; }
  .visit__inner { grid-template-columns: 1fr; }
  .hero__pole { display: none; }
}

@media (max-width: 720px) {
  .nav__links, .nav__cta { display: none; }
  .nav__links {
    position: fixed; inset: 0; background: var(--charcoal);
    flex-direction: column; align-items: center; justify-content: center;
    gap: 2.5rem; mix-blend-mode: normal;
    transform: translateY(-100%); transition: transform .5s var(--ease);
    display: flex;
  }
  .nav__links.open { transform: translateY(0); }
  .nav__links a { font-size: 1.5rem; }
  .nav { mix-blend-mode: normal; background: rgba(12,11,10,.6); backdrop-filter: blur(10px); }
  .nav__burger {
    display: flex; flex-direction: column; gap: 6px; background: none; border: none;
    cursor: pointer; z-index: 950; width: 30px;
  }
  .nav__burger span { width: 28px; height: 2px; background: var(--bone); transition: transform .4s, opacity .3s; }
  .nav__burger.open span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
  .nav__burger.open span:nth-child(2) { transform: translateY(-0px) rotate(-45deg); }
  .service { grid-template-columns: 40px 1fr auto; gap: .8rem; }
  .service__index { display: none; }
  .service__price { font-size: 1.9rem; }
  .about__points { grid-template-columns: 1fr; }
  .reviews { overflow-x: auto; }
  .reviews__track { width: auto; padding-right: var(--gut); scroll-snap-type: x mandatory; overflow-x: auto; }
  .review { width: min(84vw, 360px); scroll-snap-align: start; }
  .footer__cols { grid-template-columns: 1fr; text-align: center; }
  .footer__bottom { flex-direction: column; gap: .5rem; text-align: center; align-items: center; }
}

@media (max-width: 520px) {
  .hero { min-height: 92svh; padding-top: 7rem; }
  .hero__actions, .visit__actions { flex-direction: column; align-items: stretch; }
  .btn { width: 100%; padding-inline: 1rem; }
  .stats { grid-template-columns: 1fr; }
  .service { grid-template-columns: 1fr; align-items: start; }
  .service__price { justify-self: start; }
  .team__grid, .gallery__grid { grid-template-columns: 1fr; }
  .g1, .g4 { grid-column: span 1; }
  .gallery__grid { grid-auto-rows: 260px; }
  .visit__row { grid-template-columns: 1fr; gap: .35rem; }
  .visit__hours-card li { gap: 1rem; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}
