/* ==========================================================================
   VESTA &mdash; Hair & Colour Atelier
   Hand-built stylesheet. ASCII-only. CSS unicode escapes used in content.
   ========================================================================== */

/* ---------- Design tokens ---------- */
:root{
  /* palette */
  --cream:      #f4efe7;
  --bone:       #ece4d8;
  --sand:       #e2d6c6;
  --ink:        #1a1512;
  --ink-2:      #241d18;
  --ink-soft:   #4f463e;
  --ink-mute:   rgba(26,21,18,.62);
  --clay:       #b0593b;
  --clay-deep:  #8e442c;
  --clay-soft:  #c98263;

  /* on-dark tokens */
  --dark-text:   #f4efe7;
  --dark-mute:   rgba(244,239,231,.66);
  --dark-line:   rgba(244,239,231,.16);
  --dark-card:   #211a15;

  /* type */
  --serif: "Playfair Display", Georgia, "Times New Roman", serif;
  --sans:  "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --mono:  "Space Mono", ui-monospace, "SFMono-Regular", Menlo, Consolas, monospace;

  /* layout */
  --shell: 1240px;
  --gut: clamp(20px, 5vw, 56px);
  --section-y: clamp(72px, 10vw, 150px);

  /* motion */
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
  --dur: .9s;
  --radius: 4px;

  --line: rgba(26,21,18,.14);
  --shadow: 0 30px 60px -28px rgba(26,21,18,.45);
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{ box-sizing:border-box; }
*{ margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto; }
}
body{
  font-family:var(--sans);
  background:var(--cream);
  color:var(--ink);
  line-height:1.6;
  font-weight:400;
  font-size:clamp(16px,1vw + 12px,17px);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:0; cursor:pointer; }
ul,ol{ list-style:none; }
input,select,textarea,button{ font-family:inherit; }
::selection{ background:var(--clay); color:var(--cream); }

/* film grain / paper texture overlay */
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:9000;
  pointer-events:none;
  opacity:.5;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");
}

/* ---------- Layout helpers ---------- */
.shell{
  width:100%;
  max-width:var(--shell);
  margin-inline:auto;
  padding-inline:var(--gut);
}
.section{ padding-block:var(--section-y); position:relative; }
.section--bone{ background:var(--bone); }
.section--dark{ background:var(--ink); color:var(--dark-text); }
.no-js .reveal{ opacity:1 !important; transform:none !important; }

/* ---------- Typography ---------- */
h1,h2,h3{ font-family:var(--serif); font-weight:500; line-height:1.06; letter-spacing:-.01em; }
em{ font-style:italic; }

.eyebrow{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--clay-deep);
  display:inline-flex;
  align-items:center;
  gap:12px;
  margin-bottom:22px;
}
.eyebrow__rule{ width:30px; height:1px; background:var(--clay-deep); display:inline-block; }
.section--dark .eyebrow{ color:var(--clay-soft); }
.section--dark .eyebrow__rule{ background:var(--clay-soft); }

.section-title{
  font-size:clamp(30px,4.6vw,58px);
  font-weight:500;
  max-width:16ch;
}
.section-lede{
  margin-top:20px;
  max-width:52ch;
  color:var(--ink-soft);
  font-size:clamp(16px,1.1vw,18px);
}
.section--dark .section-lede{ color:var(--dark-mute); }

.section-head{ margin-bottom:clamp(48px,6vw,84px); }
.section-head--split{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:48px; flex-wrap:wrap;
}
.section-head--split .section-title{ max-width:14ch; }
.section-head--split .section-lede{ margin-top:0; max-width:34ch; }

.link-arrow{
  font-family:var(--mono);
  font-size:13px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--ink);
  border-bottom:1px solid var(--ink);
  padding-bottom:4px;
  display:inline-flex; gap:8px; align-items:center;
  transition:color .4s var(--ease), border-color .4s var(--ease);
}
.link-arrow span{ transition:transform .4s var(--ease); }
.link-arrow:hover{ color:var(--clay-deep); border-color:var(--clay-deep); }
.link-arrow:hover span{ transform:translateX(5px); }

/* ---------- Buttons ---------- */
.btn{
  --btn-bg:var(--clay-deep);
  --btn-fg:var(--cream);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  font-family:var(--mono);
  font-size:13px;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:15px 24px;
  border-radius:100px;
  background:var(--btn-bg);
  color:var(--btn-fg);
  border:1px solid transparent;
  position:relative;
  overflow:hidden;
  transition:transform .5s var(--ease), background-color .4s var(--ease), color .4s var(--ease), border-color .4s var(--ease);
  isolation:isolate;
  white-space:nowrap;
}
.btn::after{
  content:"";
  position:absolute; inset:0;
  background:var(--ink);
  transform:translateY(101%);
  z-index:-1;
  transition:transform .5s var(--ease-out);
}
.btn:hover{ transform:translateY(-2px); }
.btn:hover::after{ transform:translateY(0); }
.btn:focus-visible{ outline:2px solid var(--clay); outline-offset:3px; }
.btn__arrow{ width:14px; height:1.5px; background:currentColor; position:relative; transition:width .4s var(--ease); }
.btn__arrow::after{
  content:""; position:absolute; right:0; top:50%;
  width:7px; height:7px;
  border-top:1.5px solid currentColor; border-right:1.5px solid currentColor;
  transform:translateY(-50%) rotate(45deg);
}
.btn:hover .btn__arrow{ width:20px; }

.btn--solid{ background:var(--clay-deep); color:var(--cream); }
.btn--solid:hover{ color:var(--cream); }
.btn--ghost{
  background:transparent; color:inherit;
  border:1px solid rgba(244,239,231,.5);
}
.btn--ghost::after{ background:var(--cream); }
.btn--ghost{ color:var(--cream); }
.btn--ghost:hover{ color:var(--ink); }
.btn--line{
  background:transparent; color:var(--ink);
  border:1px solid var(--ink);
}
.btn--line::after{ background:var(--ink); }
.btn--line:hover{ color:var(--cream); }
.btn--lg{ padding:18px 30px; font-size:13px; }
.btn--sm{ padding:11px 18px; font-size:11px; }
.btn--block{ width:100%; }

/* ---------- Skip link ---------- */
.skip-link{
  position:absolute; left:16px; top:-60px;
  z-index:10000;
  background:var(--ink); color:var(--cream);
  padding:12px 18px; border-radius:0 0 6px 6px;
  font-family:var(--mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase;
  transition:top .3s var(--ease);
}
.skip-link:focus{ top:0; }

/* ---------- Header / nav ---------- */
.site-header{
  position:fixed; inset:0 0 auto 0;
  z-index:1000;
  transition:background-color .5s var(--ease), box-shadow .5s var(--ease), color .5s var(--ease);
  color:var(--cream);
}
.site-header__inner{
  display:flex; align-items:center; justify-content:space-between;
  height:78px;
  gap:24px;
}
.site-header.is-scrolled{
  background:rgba(244,239,231,.86);
  -webkit-backdrop-filter:blur(14px) saturate(1.2);
  backdrop-filter:blur(14px) saturate(1.2);
  color:var(--ink);
  box-shadow:0 1px 0 var(--line);
}
.brand{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--serif); font-size:24px; font-weight:600;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.brand__mark{ color:var(--clay-deep); display:inline-flex; }
.brand--light{ color:var(--cream); }
.brand--light .brand__mark{ color:var(--clay-soft); }

.nav{ display:none; }
.nav__list{ display:flex; gap:34px; }
.nav__list a{
  font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase;
  position:relative; padding:6px 0;
  color:inherit; opacity:.82;
  transition:opacity .3s var(--ease);
}
.nav__list a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0;
  background:var(--clay-deep); transition:width .4s var(--ease);
}
.site-header.is-scrolled .nav__list a::after{ background:var(--clay-deep); }
.nav__list a:hover{ opacity:1; }
.nav__list a:hover::after,
.nav__list a[aria-current="true"]::after{ width:100%; }
.nav__list a[aria-current="true"]{ opacity:1; }

.site-header__actions{ display:flex; align-items:center; gap:14px; }
.site-header .btn--solid{ background:var(--clay-deep); color:var(--cream); }
.site-header .btn--solid::after{ background:var(--ink); }
.site-header.is-scrolled .btn--solid{ background:var(--ink); color:var(--cream); }
.site-header.is-scrolled .btn--solid::after{ background:var(--clay-deep); }

/* hamburger */
.nav-toggle{ display:inline-flex; width:44px; height:44px; align-items:center; justify-content:center; }
.nav-toggle__bars, .nav-toggle__bars::before, .nav-toggle__bars::after{
  content:""; display:block; width:22px; height:1.5px; background:currentColor; position:relative;
  transition:transform .4s var(--ease), opacity .3s var(--ease);
}
.nav-toggle__bars::before{ position:absolute; top:-7px; }
.nav-toggle__bars::after{ position:absolute; top:7px; width:14px; left:8px; }
body.menu-open .nav-toggle__bars{ background:transparent; }
body.menu-open .nav-toggle__bars::before{ transform:translateY(7px) rotate(45deg); top:0; }
body.menu-open .nav-toggle__bars::after{ transform:translateY(-7px) rotate(-45deg); top:0; width:22px; left:0; }

/* mobile menu */
.mobile-menu{
  position:fixed; inset:0; z-index:990;
  background:var(--ink); color:var(--cream);
  display:flex; flex-direction:column; justify-content:center;
  padding:var(--gut);
  opacity:0; visibility:hidden;
  transition:opacity .5s var(--ease), visibility .5s var(--ease);
}
body.menu-open .mobile-menu{ opacity:1; visibility:visible; }
.mobile-menu__list{ display:flex; flex-direction:column; gap:4px; }
.mobile-menu__list a{
  font-family:var(--serif); font-size:clamp(36px,9vw,64px); font-weight:500;
  line-height:1.15; padding:6px 0; display:inline-block;
  opacity:.92; transition:color .3s var(--ease), padding-left .4s var(--ease);
}
.mobile-menu__list a:hover{ color:var(--clay-soft); padding-left:14px; }
.mobile-menu__list .btn{
  font-family:var(--mono); font-size:13px; align-self:flex-start; margin-top:18px;
}
.mobile-menu__meta{
  margin-top:48px; font-family:var(--mono); font-size:13px; color:var(--dark-mute);
  letter-spacing:.04em; line-height:1.8;
}
.mobile-menu__meta a{ border-bottom:1px solid var(--dark-line); }

/* ---------- Hero ---------- */
.hero{
  position:relative; min-height:100vh; min-height:100svh;
  display:flex; align-items:flex-end;
  color:var(--cream);
  overflow:hidden;
  padding-block:130px 70px;
}
.hero__media{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:center 30%;
  transform:scale(1.04);
  animation:kenburns 22s ease-in-out infinite alternate;
  z-index:0;
}
@keyframes kenburns{
  from{ transform:scale(1.04) translate3d(0,0,0); }
  to  { transform:scale(1.16) translate3d(-1.5%,-2%,0); }
}
.hero__scrim{
  position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(180deg, rgba(26,21,18,.55) 0%, rgba(26,21,18,.15) 30%, rgba(26,21,18,.12) 55%, rgba(26,21,18,.78) 100%),
    radial-gradient(120% 80% at 75% 25%, rgba(26,21,18,.25), transparent 60%);
}
.hero__veil{
  position:absolute; inset:0; z-index:3;
  background:var(--ink);
  transform-origin:bottom;
  animation:veilUp 1.2s var(--ease-out) .2s forwards;
}
@keyframes veilUp{ to{ transform:scaleY(0); } }

.hero__inner{ position:relative; z-index:2; width:100%; max-width:1000px; }
.hero__eyebrow{
  font-family:var(--mono); font-size:12px; letter-spacing:.2em; text-transform:uppercase;
  display:inline-flex; align-items:center; gap:12px;
  color:rgba(244,239,231,.9); margin-bottom:26px;
}
.hero__eyebrow .dot{ width:7px; height:7px; border-radius:50%; background:var(--clay-soft); display:inline-block; }
.hero__title{
  font-size:clamp(52px,12.5vw,168px);
  font-weight:500; line-height:.96; letter-spacing:-.02em;
  margin-bottom:30px;
}
.hero__title em{ font-style:italic; color:var(--clay-soft); font-weight:400; }
.hero__title .line{ display:block; overflow:hidden; padding-bottom:.04em; }
.hero__title .line > span{ display:block; transform:translateY(112%); will-change:transform; }
.is-entered .hero__title .line > span{ animation:lineRise 1.1s var(--ease-out) forwards; }
.is-entered .hero__title .line:nth-child(2) > span{ animation-delay:.14s; }
@keyframes lineRise{ to{ transform:translateY(0); } }
.hero__lede{
  font-size:clamp(17px,1.6vw,21px); max-width:46ch; line-height:1.5;
  color:rgba(244,239,231,.92); font-weight:300;
  margin-bottom:38px;
}
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; }
.site-header:not(.is-scrolled) .hero__cta .btn--solid{ }

.hero__cue{
  position:absolute; z-index:2; right:var(--gut); bottom:42px;
  display:flex; flex-direction:column; align-items:center; gap:12px;
  font-family:var(--mono); font-size:10px; letter-spacing:.24em; text-transform:uppercase;
  color:rgba(244,239,231,.7);
}
.hero__cue-line{
  width:1px; height:54px; background:linear-gradient(var(--clay-soft), transparent);
  position:relative; overflow:hidden;
}
.hero__cue-line::after{
  content:""; position:absolute; top:-100%; left:0; width:100%; height:100%;
  background:var(--cream); animation:cueSlide 2.4s var(--ease) infinite;
}
@keyframes cueSlide{ 0%{ top:-100%; } 60%,100%{ top:100%; } }

/* ---------- Marquee ---------- */
.marquee{
  background:var(--ink); color:var(--cream);
  padding:18px 0; overflow:hidden;
  border-block:1px solid var(--dark-line);
}
.marquee__track{ display:flex; width:max-content; animation:marquee 38s linear infinite; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
.marquee__group{
  display:inline-flex; align-items:center;
  font-family:var(--serif); font-style:italic; font-size:clamp(20px,2.4vw,30px); font-weight:400;
  white-space:nowrap;
}
.marquee__group > span{ padding:0 26px; opacity:.92; }
.marquee__sep{
  width:8px; height:8px; background:var(--clay-soft);
  transform:rotate(45deg); display:inline-block;
}
@keyframes marquee{ to{ transform:translateX(-50%); } }

/* ---------- Story ---------- */
.story__grid{
  display:grid; grid-template-columns:1fr; gap:clamp(40px,6vw,90px);
  align-items:center;
}
.story__media{ position:relative; }
.story__figure{ position:relative; overflow:hidden; border-radius:var(--radius); }
.story__figure img{ width:100%; height:100%; object-fit:cover; transition:transform 1.4s var(--ease); }
.story__figure{ aspect-ratio:4/5; box-shadow:var(--shadow); }
.story__figure--small{
  position:absolute; right:-4%; bottom:-8%;
  width:42%; aspect-ratio:1/1; border:6px solid var(--cream);
  z-index:2;
}
.story__figure:hover img{ transform:scale(1.04); }
.story__stamp{
  position:absolute; left:-6%; top:-6%;
  width:108px; height:108px; border-radius:50%;
  background:var(--clay-deep); color:var(--cream);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; z-index:3;
  font-family:var(--mono); font-size:9px; letter-spacing:.12em; text-transform:uppercase; line-height:1.4;
}
.story__stamp strong{ font-family:var(--serif); font-style:italic; font-size:34px; font-weight:600; line-height:1; }
.story__body .section-title{ max-width:14ch; }
.story__text{ margin-top:30px; max-width:54ch; }
.story__text p{ margin-bottom:18px; color:var(--ink-soft); font-size:clamp(16px,1.1vw,18px); }
.story__quote{
  margin-top:38px; padding-left:26px; border-left:2px solid var(--clay);
}
.story__quote p{
  font-family:var(--serif); font-style:italic; font-size:clamp(22px,2.4vw,30px);
  line-height:1.35; color:var(--ink);
}
.story__quote cite{
  display:block; margin-top:14px; font-style:normal;
  font-family:var(--mono); font-size:12px; letter-spacing:.1em; color:var(--clay-deep);
}
.story__sign{ margin-top:34px; }

/* ---------- Services ---------- */
.services__grid{
  display:grid; grid-template-columns:1fr; gap:clamp(28px,3vw,40px);
}
.price-card{
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:clamp(26px,3vw,42px);
  display:flex; flex-direction:column;
  transition:transform .6s var(--ease), box-shadow .6s var(--ease), border-color .6s var(--ease);
}
.price-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:transparent; }
.price-card__head{
  display:flex; align-items:baseline; gap:14px;
  padding-bottom:22px; margin-bottom:8px;
  border-bottom:1px solid var(--line);
}
.price-card__num{
  font-family:var(--mono); font-size:13px; color:var(--clay-deep); letter-spacing:.1em;
}
.price-card__head h3{ font-size:clamp(24px,2.6vw,32px); font-weight:500; }
.menu{ display:flex; flex-direction:column; }
.menu__row{
  display:grid; grid-template-columns:1fr auto; gap:8px 18px;
  align-items:baseline;
  padding:18px 0;
  border-bottom:1px dashed var(--line);
  position:relative;
  transition:padding-left .4s var(--ease);
}
.menu__row::before{
  content:""; position:absolute; left:0; top:0; bottom:0; width:2px;
  background:var(--clay); transform:scaleY(0); transform-origin:bottom;
  transition:transform .4s var(--ease);
}
.menu__row:hover{ padding-left:14px; }
.menu__row:hover::before{ transform:scaleY(1); transform-origin:top; }
.menu__name strong{ font-weight:500; font-size:17px; display:block; color:var(--ink); }
.menu__name span{ font-size:13.5px; color:var(--ink-mute); display:block; margin-top:2px; }
.menu__price{
  font-family:var(--mono); font-size:15px; font-weight:700;
  color:var(--ink); white-space:nowrap;
  transform:translateX(8px); opacity:.7;
  transition:transform .4s var(--ease), opacity .4s var(--ease), color .4s var(--ease);
}
.menu__row:hover .menu__price{ transform:translateX(0); opacity:1; color:var(--clay-deep); }
.price-card .btn{ margin-top:26px; }

/* ---------- Team ---------- */
.team__grid{
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(22px,3vw,34px);
}
.stylist__card{
  position:relative; overflow:hidden; border-radius:var(--radius);
  background:var(--ink);
}
.stylist__media{ aspect-ratio:4/5; overflow:hidden; }
.stylist__media img{
  width:100%; height:100%; object-fit:cover;
  filter:grayscale(1) contrast(1.02);
  transform:scale(1.01);
  transition:filter 1s var(--ease), transform 1.2s var(--ease);
}
.stylist__card:hover .stylist__media img{ filter:grayscale(0) contrast(1); transform:scale(1.06); }
.stylist__meta{
  position:absolute; left:0; right:0; bottom:0;
  padding:24px 24px 24px;
  color:var(--cream);
  background:linear-gradient(180deg, transparent, rgba(26,21,18,.92) 60%);
}
.stylist__name{ font-size:24px; font-weight:500; }
.stylist__role{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--clay-soft); margin-top:6px; }
.stylist__special{
  font-size:14px; color:rgba(244,239,231,.85); margin-top:12px;
  max-height:0; opacity:0; overflow:hidden;
  transition:max-height .5s var(--ease), opacity .5s var(--ease), margin-top .5s var(--ease);
}
.stylist__card:hover .stylist__special{ max-height:60px; opacity:1; }
.stylist__handle{
  font-family:var(--mono); font-size:12px; color:rgba(244,239,231,.6);
  margin-top:8px;
}

/* ---------- CTA band ---------- */
.cta-band{
  position:relative; overflow:hidden;
  color:var(--cream); text-align:center;
  padding-block:clamp(90px,12vw,170px);
}
.cta-band__bg{
  position:absolute; inset:0; z-index:0;
  background:
    linear-gradient(rgba(26,21,18,.74), rgba(26,21,18,.82)),
    url("https://images.unsplash.com/photo-1522335789203-aabd1fc54bc9?auto=format&fit=crop&w=1800&q=80") center/cover;
  transform:scale(1.05);
  animation:kenburns 26s ease-in-out infinite alternate;
}
.cta-band__inner{ position:relative; z-index:1; max-width:760px; }
.cta-band__kicker{ font-family:var(--mono); font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--clay-soft); margin-bottom:18px; }
.cta-band__title{ font-size:clamp(38px,7vw,84px); font-weight:500; line-height:1.02; letter-spacing:-.02em; }
.cta-band__lede{ font-size:clamp(16px,1.4vw,19px); color:rgba(244,239,231,.88); margin:20px auto 34px; max-width:44ch; font-weight:300; }

/* ---------- Lookbook / gallery ---------- */
.gallery{
  display:grid; grid-template-columns:repeat(2,1fr);
  grid-auto-rows:minmax(180px,auto);
  gap:clamp(12px,1.6vw,20px);
}
.gallery__item{ overflow:hidden; border-radius:var(--radius); position:relative; }
.gallery__item--tall{ grid-row:span 2; }
.gallery__item--wide{ grid-column:span 2; }
.gallery__btn{
  display:block; width:100%; height:100%; position:relative;
  background:none; padding:0;
}
.gallery__btn img{
  width:100%; height:100%; object-fit:cover;
  transition:transform 1.3s var(--ease), filter .8s var(--ease);
}
.gallery__btn{ aspect-ratio:1/1; }
.gallery__item--tall .gallery__btn{ aspect-ratio:3/4; }
.gallery__item--wide .gallery__btn{ aspect-ratio:16/10; }
.gallery__btn::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 45%, rgba(26,21,18,.7));
  opacity:0; transition:opacity .5s var(--ease);
}
.gallery__cap{
  position:absolute; left:18px; bottom:16px; z-index:2;
  font-family:var(--serif); font-style:italic; font-size:clamp(16px,1.6vw,21px);
  color:var(--cream);
  transform:translateY(10px); opacity:0;
  transition:transform .5s var(--ease), opacity .5s var(--ease);
}
.gallery__btn:hover img,
.gallery__btn:focus-visible img{ transform:scale(1.07); }
.gallery__btn:hover::after,
.gallery__btn:focus-visible::after{ opacity:1; }
.gallery__btn:hover .gallery__cap,
.gallery__btn:focus-visible .gallery__cap{ transform:translateY(0); opacity:1; }
.gallery__btn:focus-visible{ outline:2px solid var(--clay-soft); outline-offset:2px; }

/* ---------- Visit & book ---------- */
.visit__grid{
  display:grid; grid-template-columns:1fr; gap:clamp(40px,6vw,80px);
  align-items:start;
}
.visit__details{ margin-top:36px; display:grid; gap:28px; }
.visit__block{ }
.visit__label{ font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--clay-deep); margin-bottom:10px; }
.visit__value{ font-size:16px; color:var(--ink-soft); line-height:1.8; }
.visit__value a{ border-bottom:1px solid var(--line); transition:border-color .3s var(--ease), color .3s var(--ease); }
.visit__value a:hover{ color:var(--clay-deep); border-color:var(--clay-deep); }
.hours{ display:grid; gap:0; }
.hours > div{ display:flex; justify-content:space-between; gap:18px; padding:8px 0; border-bottom:1px dashed var(--line); font-size:15px; }
.hours dt{ font-family:var(--mono); font-size:12px; letter-spacing:.1em; color:var(--ink-mute); text-transform:uppercase; }
.hours dd{ color:var(--ink); }
.visit__map{ margin-top:40px; }
.visit__map-frame{
  display:block; width:100%; aspect-ratio:16/9; height:auto;
  border:1px solid var(--line);
  border-radius:var(--radius);
  filter:grayscale(.35) contrast(1.02) sepia(.12);
  transition:filter .8s var(--ease);
  background:var(--bone);
}
.visit__map:hover .visit__map-frame{ filter:grayscale(0) contrast(1) sepia(0); }
.visit__map figcaption{ margin-top:14px; font-family:var(--mono); font-size:12px; color:var(--ink-mute); letter-spacing:.04em; }

/* Booking card */
.card{
  background:var(--ink); color:var(--cream);
  border-radius:var(--radius);
  padding:clamp(28px,4vw,52px);
  box-shadow:var(--shadow);
}
.book .eyebrow{ color:var(--clay-soft); }
.book .eyebrow__rule{ background:var(--clay-soft); }
.book__title{ font-size:clamp(28px,3.4vw,40px); font-weight:500; }
.book__lede{ margin-top:12px; color:var(--dark-mute); font-size:15px; max-width:42ch; }
.book__head{ margin-bottom:30px; }

.book__form{ display:grid; gap:18px; }
.field{ display:flex; flex-direction:column; gap:8px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.field label{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--dark-mute); }
.field__opt{ text-transform:none; opacity:.6; }
.field input, .field select, .field textarea{
  width:100%;
  background:transparent;
  color:var(--cream);
  border:0; border-bottom:1px solid var(--dark-line);
  padding:11px 0;
  font-size:16px;
  border-radius:0;
  transition:border-color .3s var(--ease);
}
.field textarea{ resize:vertical; min-height:80px; }
.field input::placeholder, .field textarea::placeholder{ color:rgba(244,239,231,.35); }
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--clay-soft);
}
.field input:placeholder-shown,
.field input:not(:placeholder-shown){ }
.field input[type="date"]{ color-scheme:dark; }
.select{ position:relative; }
.select::after{
  content:""; position:absolute; right:4px; top:50%;
  width:8px; height:8px; border-right:1.5px solid var(--dark-mute); border-bottom:1.5px solid var(--dark-mute);
  transform:translateY(-65%) rotate(45deg); pointer-events:none;
}
.field select{ appearance:none; -webkit-appearance:none; padding-right:24px; cursor:pointer; }
.field select option{ background:var(--ink); color:var(--cream); }
.book__form .btn--solid{ background:var(--clay-deep); color:var(--cream); margin-top:8px; }
.book__form .btn--solid::after{ background:var(--cream); }
.book__form .btn--solid:hover{ color:var(--ink); }
.book__small{ font-size:12px; color:var(--dark-mute); text-align:center; margin-top:6px; line-height:1.6; }

/* invalid state (after attempted submit) */
.book__form .field input:user-invalid,
.book__form .field select:user-invalid,
.book__form.attempted .field input:invalid,
.book__form.attempted .field select:invalid{
  border-color:var(--clay-soft);
}

.book__success{ text-align:center; padding-block:24px; }
.book__success-mark{
  width:62px; height:62px; margin:0 auto 22px; border-radius:50%;
  background:var(--clay-deep); color:var(--cream);
  display:flex; align-items:center; justify-content:center;
}
.book__success .book__title{ }
.book__success .book__lede{ margin-inline:auto; }
.book__success .btn{ margin-top:24px; }
.book__success .btn--line{ color:var(--cream); border-color:var(--dark-line); }
.book__success .btn--line::after{ background:var(--cream); }
.book__success .btn--line:hover{ color:var(--ink); }

/* ---------- Footer ---------- */
.site-footer{ background:var(--ink); color:var(--dark-text); padding-top:clamp(64px,8vw,110px); }
.site-footer__top{
  display:grid; grid-template-columns:1fr; gap:40px;
  padding-bottom:60px;
  border-bottom:1px solid var(--dark-line);
}
.site-footer__brand{ max-width:34ch; }
.site-footer__tag{ margin-top:18px; color:var(--dark-mute); font-size:15px; line-height:1.7; }
.site-footer__label{ font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--clay-soft); margin-bottom:16px; }
.site-footer__col ul{ display:grid; gap:10px; }
.site-footer__col a, .site-footer__col p{ color:var(--dark-mute); font-size:15px; line-height:1.8; transition:color .3s var(--ease); }
.site-footer__col a:hover{ color:var(--cream); }
.site-footer__cta{ margin-top:18px; }
.site-footer__bottom{
  display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap;
  padding-block:30px;
  font-family:var(--mono); font-size:11px; letter-spacing:.08em; color:var(--dark-mute);
}
.site-footer__credit{ opacity:.7; }

/* ---------- Lightbox ---------- */
.lightbox{
  position:fixed; inset:0; z-index:2000;
  background:rgba(15,12,10,.94);
  -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
  display:flex; align-items:center; justify-content:center;
  padding:clamp(20px,5vw,70px);
  opacity:0; visibility:hidden;
  transition:opacity .4s var(--ease), visibility .4s var(--ease);
}
html.lb-open{ overflow:hidden; }
.lightbox.is-open{ opacity:1; visibility:visible; }
.lightbox__figure{
  max-width:min(1100px,92vw); max-height:86vh;
  display:flex; flex-direction:column; gap:14px; align-items:center;
}
.lightbox__figure img{
  max-width:100%; max-height:78vh; width:auto; height:auto;
  object-fit:contain; border-radius:var(--radius);
  box-shadow:0 40px 90px -30px rgba(0,0,0,.8);
  transform:scale(.96); opacity:0;
  transition:transform .5s var(--ease-out), opacity .4s var(--ease);
}
.lightbox.is-open .lightbox__figure img{ transform:scale(1); opacity:1; }
.lightbox__figure figcaption{
  font-family:var(--serif); font-style:italic; font-size:clamp(15px,1.6vw,19px);
  color:rgba(244,239,231,.8); text-align:center;
}
.lightbox__close, .lightbox__nav{
  position:absolute; z-index:2;
  width:54px; height:54px; border-radius:50%;
  border:1px solid var(--dark-line);
  color:var(--cream); background:rgba(244,239,231,.05);
  font-size:28px; line-height:1;
  display:flex; align-items:center; justify-content:center;
  transition:background .3s var(--ease), transform .3s var(--ease), border-color .3s var(--ease);
}
.lightbox__close:hover, .lightbox__nav:hover{ background:var(--clay-deep); border-color:var(--clay-deep); transform:scale(1.05); }
.lightbox__close:focus-visible, .lightbox__nav:focus-visible{ outline:2px solid var(--clay-soft); outline-offset:3px; }
.lightbox__close{ top:24px; right:24px; }
.lightbox__nav--prev{ left:18px; top:50%; transform:translateY(-50%); }
.lightbox__nav--next{ right:18px; top:50%; transform:translateY(-50%); }
.lightbox__nav--prev:hover{ transform:translateY(-50%) scale(1.05); }
.lightbox__nav--next:hover{ transform:translateY(-50%) scale(1.05); }

/* ---------- Reveal animations ---------- */
.reveal{ transition:opacity 1s var(--ease), transform 1s var(--ease); will-change:opacity, transform; }
.reveal[data-reveal="up"]{ opacity:0; transform:translateY(36px); }
.reveal[data-reveal="fade"]{ opacity:0; }
.reveal.is-in{ opacity:1; transform:none; }

/* ---------- Responsive ---------- */
@media (min-width:640px){
  .services__grid{ grid-template-columns:1fr 1fr; }
  .price-card:last-child{ grid-column:1 / -1; }
}
@media (min-width:760px){
  .gallery{ grid-template-columns:repeat(3,1fr); }
}
@media (min-width:880px){
  .nav{ display:block; }
  .nav-toggle{ display:none; }
  .site-header__actions .btn{ display:inline-flex; }
}
@media (min-width:980px){
  .story__grid{ grid-template-columns:0.92fr 1fr; }
  .services__grid{ grid-template-columns:repeat(3,1fr); }
  .price-card:last-child{ grid-column:auto; }
  .team__grid{ grid-template-columns:repeat(4,1fr); }
  .visit__grid{ grid-template-columns:1fr 1fr; }
  .site-footer__top{ grid-template-columns:1.6fr 1fr 1fr 1fr; }
}
@media (max-width:879px){
  .site-header__actions .btn--solid{ display:none; }
}
@media (max-width:560px){
  .field-row{ grid-template-columns:1fr; }
  .gallery{ grid-template-columns:repeat(2,1fr); }
  .gallery__item--wide{ grid-column:span 2; }
  .section-head--split{ flex-direction:column; align-items:flex-start; }
  .hero__cue{ display:none; }
  .lightbox__nav{ width:44px; height:44px; }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
  .hero__media{ animation:none; transform:none; }
  .hero__veil{ display:none; }
  .hero__title .line > span{ transform:none; }
  .marquee__track{ animation:none; }
  .cta-band__bg{ animation:none; transform:none; }
  .hero__cue-line::after{ animation:none; }
  .reveal{ opacity:1 !important; transform:none !important; }
}
