/* ============================================================
   MICHAEL HAIR STUDIO — luxury black + gold
   Hand-written, framework-free. Mobile-first.
   Palette + type per design spec. WCAG AA gold-on-black.
   ============================================================ */

:root{
  --black-1:#0a0a0b;
  --black-2:#0d0d10;
  --panel:#121216;
  --panel-raised:#16161b;
  --gold-deep:#c9a24a;
  --gold-core:#d4af37;
  --gold-light:#e8c873;
  --gold-pale:#f0dba0;
  --brushed:linear-gradient(120deg,#c9a24a 0%,#e8c873 28%,#d4af37 50%,#b8862f 72%,#e8c873 100%);
  --cream:#f3ece0;
  --cream-dim:#cfc6b6;
  --muted:#8c8576;
  --line:rgba(212,175,55,0.22);
  --line-strong:rgba(212,175,55,0.45);
  --leader:rgba(212,175,55,0.42);
  --vignette:radial-gradient(ellipse 120% 80% at 50% -10%, #16140e 0%, #0d0d10 45%, #0a0a0b 100%);
  --serif:"Cinzel", Georgia, "Times New Roman", serif;
  --script:"Pinyon Script", "Brush Script MT", cursive;
  --sans:"Jost", system-ui, -apple-system, "Segoe UI", sans-serif;
  --maxw:1180px;
  --ease:cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  font-family:var(--sans);
  font-weight:400;
  color:var(--cream);
  background:var(--black-1);
  background-image:var(--vignette);
  background-attachment:fixed;
  line-height:1.7;
  font-size:16px;
  letter-spacing:.01em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
/* film-grain noise overlay on the whole page (very subtle) */
body::before{
  content:"";
  position:fixed; inset:0; z-index:0; pointer-events:none;
  opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
main, header, footer{ position:relative; z-index:1; }

img{ max-width:100%; height:auto; display:block; }
a{ color:var(--gold-light); text-decoration:none; }
a:hover{ color:var(--gold-pale); }

/* focus rings — visible gold */
a:focus-visible, button:focus-visible, [tabindex]:focus-visible, .ba-handle:focus-visible{
  outline:2px solid var(--gold-core);
  outline-offset:3px;
  border-radius:3px;
}

.sr-only{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}
.skip-link{
  position:absolute; left:12px; top:-60px; z-index:200;
  background:var(--gold-core); color:var(--black-1);
  padding:10px 16px; border-radius:6px; font-weight:600;
  transition:top .2s var(--ease);
}
.skip-link:focus{ top:12px; }

/* ---------- layout helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 22px; }
section{ padding:84px 0; }
@media (min-width:768px){ section{ padding:108px 0; } }

.eyebrow{
  font-family:var(--script);
  font-size:1.9rem;
  line-height:1;
  color:var(--gold-light);
  display:block;
  margin-bottom:.35em;
  font-display:block;
}
.section-head{ text-align:center; margin-bottom:54px; }
h2.section-title{
  font-family:var(--serif);
  font-weight:600;
  font-size:clamp(1.7rem,4.4vw,2.7rem);
  letter-spacing:.06em;
  margin:0 0 .2em;
  color:var(--cream);
  text-transform:uppercase;
}
.section-sub{
  color:var(--cream-dim);
  max-width:600px; margin:0 auto;
  font-weight:300;
  font-size:1.02rem;
}
.gold-text{
  background:var(--brushed);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:var(--gold-core);
}
.rule{
  width:74px; height:1px; margin:18px auto 0;
  background:var(--brushed);
  position:relative;
}
.rule::before,.rule::after{
  content:""; position:absolute; top:50%; width:5px; height:5px;
  border-radius:50%; background:var(--gold-core); transform:translateY(-50%) rotate(45deg);
}
.rule::before{ left:-12px; }
.rule::after{ right:-12px; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--sans); font-weight:600; font-size:.92rem;
  letter-spacing:.08em; text-transform:uppercase;
  padding:14px 26px; border-radius:2px; cursor:pointer;
  border:1px solid transparent; transition:all .25s var(--ease);
  line-height:1; white-space:nowrap;
}
.btn-gold{
  background:var(--brushed); color:var(--black-1);
  border-color:var(--gold-light);
  box-shadow:0 6px 22px -8px rgba(212,175,55,.55);
}
.btn-gold:hover{
  color:var(--black-1);
  transform:translateY(-2px);
  box-shadow:0 10px 30px -8px rgba(212,175,55,.7);
}
.btn-ghost{
  background:transparent; color:var(--gold-light);
  border-color:var(--line-strong);
}
.btn-ghost:hover{
  color:var(--gold-pale);
  border-color:var(--gold-core);
  background:rgba(212,175,55,.06);
}
.btn .ico{ width:1.05em; height:1.05em; }

/* ============================================================
   SCROLL PROGRESS + HEADER
   ============================================================ */
#scroll-progress{
  position:fixed; top:0; left:0; height:3px; width:0;
  background:linear-gradient(90deg,#c9a24a,#e8c873);
  z-index:120; transition:width .1s linear;
}
#site-header{
  position:fixed; top:0; left:0; right:0; z-index:110;
  padding:16px 0;
  background:transparent;
  border-bottom:1px solid transparent;
  transition:background .35s var(--ease), border-color .35s var(--ease), padding .35s var(--ease);
}
#site-header.scrolled{
  background:rgba(13,13,16,.94);
  -webkit-backdrop-filter:blur(10px); backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  padding:10px 0;
}
.header-inner{ display:flex; align-items:center; justify-content:space-between; gap:18px; }
.brand-lockup{ display:flex; align-items:center; gap:11px; min-width:0; }
.brand-lockup .mini-mono{ width:34px; height:34px; flex:0 0 auto; }
.brand-lockup .brand-words{ display:flex; flex-direction:column; line-height:1; min-width:0; }
.brand-lockup .b1{
  font-family:var(--serif); font-weight:700; font-size:1.02rem;
  letter-spacing:.14em; color:var(--cream); white-space:nowrap;
}
.brand-lockup .b2{
  font-family:var(--sans); font-weight:400; font-size:.58rem;
  letter-spacing:.34em; color:var(--gold-light); text-transform:uppercase;
  margin-top:3px;
}

.nav-desk{ display:none; align-items:center; gap:30px; }
.nav-desk a{
  font-family:var(--sans); font-weight:400; font-size:.84rem;
  letter-spacing:.14em; text-transform:uppercase; color:var(--cream-dim);
  position:relative; padding:4px 0; transition:color .2s var(--ease);
}
.nav-desk a::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px; height:1px;
  background:var(--brushed); transform:scaleX(0); transform-origin:left;
  transition:transform .3s var(--ease);
}
.nav-desk a:hover{ color:var(--gold-light); }
.nav-desk a:hover::after{ transform:scaleX(1); }

.header-cta{ display:none; align-items:center; gap:12px; }
.header-cta .btn{ padding:11px 18px; font-size:.78rem; }

/* hamburger */
.hamburger{
  display:inline-flex; flex-direction:column; justify-content:center; gap:5px;
  width:44px; height:44px; padding:10px; background:transparent;
  border:1px solid var(--line); border-radius:4px; cursor:pointer;
}
.hamburger span{ display:block; height:2px; width:100%; background:var(--gold-light); transition:transform .3s var(--ease), opacity .3s var(--ease); border-radius:2px; }
.hamburger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2){ opacity:0; }
.hamburger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

@media (min-width:980px){
  .nav-desk{ display:flex; }
  .header-cta{ display:flex; }
  .hamburger{ display:none; }
}

/* mobile nav overlay */
#mobile-nav{
  position:fixed; inset:0; z-index:115;
  background:rgba(8,8,9,.98);
  -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px;
  opacity:0; visibility:hidden; transform:translateY(-12px);
  /* visibility intentionally NOT transitioned: it must flip to 'visible'
     synchronously so focus() into the dialog on open is not a no-op. */
  transition:opacity .3s var(--ease), transform .3s var(--ease);
}
#mobile-nav.open{ opacity:1; visibility:visible; transform:translateY(0); }
#mobile-nav a{
  font-family:var(--serif); font-weight:600; font-size:1.5rem;
  letter-spacing:.1em; text-transform:uppercase; color:var(--cream);
  padding:14px 8px;
}
#mobile-nav a:hover{ color:var(--gold-light); }
#mobile-nav .mn-cta{ margin-top:22px; display:flex; flex-direction:column; gap:14px; width:min(320px,82vw); }
#mobile-nav .mn-cta .btn{ width:100%; }
.mn-close{
  position:absolute; top:20px; right:20px; width:46px; height:46px;
  background:transparent; border:1px solid var(--line); border-radius:6px;
  color:var(--gold-light); font-size:1.5rem; cursor:pointer; line-height:1;
}

/* ============================================================
   HERO
   ============================================================ */
#hero{
  position:relative; min-height:100svh;
  display:flex; align-items:center; justify-content:center;
  text-align:center; overflow:hidden;
  padding:120px 18px 90px;
  background:var(--vignette);
}
/* faint salon image, deeply darkened, sits under the gold dust */
.hero-photo{
  position:absolute; inset:0; z-index:0;
  background:#0a0a0b center/cover no-repeat;
  opacity:.16; filter:grayscale(.3) brightness(.7);
}
#hero-canvas{
  position:absolute; inset:0; z-index:1;
  width:100%; height:100%; display:none; opacity:0;
  transition:opacity 1.2s ease; pointer-events:none;
}
/* static fallback glow (always present, lives behind canvas) */
.hero-glow{
  position:absolute; left:50%; top:34%; z-index:0;
  width:760px; height:760px; max-width:120vw; transform:translate(-50%,-50%);
  background:radial-gradient(circle, rgba(201,162,74,.16) 0%, rgba(201,162,74,.05) 38%, transparent 68%);
  pointer-events:none;
}
.hero-content{ position:relative; z-index:3; max-width:780px; }
.hero-logo{ width:min(560px,90vw); height:auto; margin:0 auto 14px; display:block; }
.hero-tagline{
  font-family:var(--serif); font-weight:600;
  font-size:clamp(1.5rem,5vw,2.6rem); letter-spacing:.07em;
  margin:10px 0 6px; line-height:1.15;
}
.hero-loc{
  font-family:var(--sans); font-weight:300; letter-spacing:.22em;
  text-transform:uppercase; font-size:.82rem; color:var(--cream-dim);
  margin:0 0 30px;
}
.hero-ctas{ display:flex; flex-wrap:wrap; gap:14px; justify-content:center; }
.scroll-cue{
  position:absolute; bottom:26px; left:50%; transform:translateX(-50%);
  z-index:3; color:var(--gold-light); opacity:.8;
  animation:bob 2.2s var(--ease) infinite;
}
.scroll-cue svg{ width:26px; height:26px; }
@keyframes bob{ 0%,100%{ transform:translate(-50%,0); } 50%{ transform:translate(-50%,8px); } }

/* ============================================================
   ANIMATED LOGO SVG
   ============================================================ */
.logo-svg{ display:block; width:100%; height:auto; overflow:visible; }
.logo-svg .stroke-draw{
  fill:none; stroke:url(#goldGrad); stroke-width:6;
  stroke-linecap:round; stroke-linejoin:round;
}
.logo-svg .mono-fill{ fill:url(#goldGrad); opacity:1; }
.logo-svg .wordmark{ fill:url(#goldGrad); }
.logo-svg .word-sub{ fill:var(--cream); }
.logo-svg .script-line{ fill:url(#goldGrad); }
.logo-svg .est{ fill:var(--gold-light); }
.logo-svg .shine-rect{ opacity:0; }

/* Hero instance gets .animate — everything starts hidden and animates in.
   Static instances (header/footer) show the final state by default. */
.logo-svg.animate .stroke-draw{
  stroke-dasharray:var(--len); stroke-dashoffset:var(--len);
  animation:mono-draw 1.5s var(--ease) forwards;
}
.logo-svg.animate .stroke-draw.s2{ animation-delay:.15s; }
.logo-svg.animate .stroke-draw.s3{ animation-delay:.3s; }
.logo-svg.animate .mono-fill{ opacity:0; animation:fill-in .8s ease 1.25s forwards; }
.logo-svg.animate .wordmark,
.logo-svg.animate .word-sub,
.logo-svg.animate .script-line,
.logo-svg.animate .est{
  opacity:0; transform:translateY(8px); transform-box:fill-box; transform-origin:center;
  animation:rise-in .8s var(--ease) forwards;
}
.logo-svg.animate .wordmark{ animation-delay:1.0s; }
.logo-svg.animate .word-sub{ animation-delay:1.15s; }
.logo-svg.animate .script-line{ animation-delay:1.3s; }
.logo-svg.animate .est{ animation-delay:1.45s; }
.logo-svg.animate .shine-rect{ animation:shine-sweep 6s ease-in-out 2.2s infinite; }

@keyframes mono-draw{ to{ stroke-dashoffset:0; } }
@keyframes fill-in{ to{ opacity:1; } }
@keyframes rise-in{ to{ opacity:1; transform:translateY(0); } }
@keyframes shine-sweep{
  0%{ opacity:0; transform:translateX(-260px) skewX(-18deg); }
  8%{ opacity:.9; }
  22%{ opacity:.9; }
  36%{ opacity:0; transform:translateX(640px) skewX(-18deg); }
  100%{ opacity:0; transform:translateX(640px) skewX(-18deg); }
}

/* ============================================================
   SERVICES — luxury price menus
   ============================================================ */
.menus{ display:grid; grid-template-columns:1fr; gap:26px; }
@media (min-width:880px){ .menus{ grid-template-columns:1fr 1fr; gap:30px; align-items:start; } }

.menu-card{
  background:var(--panel-raised);
  border:1px solid var(--line);
  border-radius:4px; padding:34px 28px 30px;
  position:relative; overflow:hidden;
}
.menu-card::before{
  content:""; position:absolute; inset:0; opacity:.05; pointer-events:none;
  background:var(--tex,none) center/cover; mix-blend-mode:overlay;
}
.menu-cat{ text-align:center; margin:0 0 6px; }
.menu-cat .kicker{
  font-family:var(--serif); font-weight:700; font-size:1.4rem;
  letter-spacing:.1em; text-transform:uppercase; color:var(--cream); margin:0;
}
.menu-cat .kicker-sub{
  font-family:var(--script); font-size:1.6rem; color:var(--gold-light);
  line-height:1; display:block; margin-top:2px; font-display:block;
}
.menu-divider{ height:1px; background:var(--line); margin:18px 0 22px; position:relative; }
.menu-divider::after{ content:""; position:absolute; left:50%; top:50%; transform:translate(-50%,-50%) rotate(45deg); width:7px; height:7px; background:var(--gold-core); }

.menu-list{ list-style:none; margin:0; padding:0; }
.menu-row{ display:flex; align-items:flex-end; gap:8px; padding:11px 0; }
.menu-row + .menu-row{ border-top:1px solid rgba(212,175,55,.10); }
.menu-row .name{
  font-family:var(--sans); font-weight:400; font-size:1rem; color:var(--cream);
  flex:0 1 auto; letter-spacing:.01em;
}
.menu-row .leader{
  flex:1 1 auto; height:1px; margin-bottom:6px;
  background-image:radial-gradient(circle, var(--leader) 1px, transparent 1.4px);
  background-size:7px 2px; background-repeat:repeat-x; background-position:0 100%;
  min-width:18px;
}
.menu-row .price{
  font-family:var(--sans); font-weight:600; font-size:1rem;
  color:var(--gold-light); flex:0 0 auto; letter-spacing:.02em; white-space:nowrap;
}
.menu-fineprint{
  margin:18px 2px 0; font-size:.8rem; color:var(--muted);
  font-style:italic; font-weight:300; letter-spacing:.01em;
}
.menu-cta{ margin-top:24px; text-align:center; }
.menu-cta .btn{ width:100%; }

/* ============================================================
   GALLERY + BEFORE/AFTER
   ============================================================ */
.gallery-grid{
  display:grid; grid-template-columns:repeat(2,1fr); gap:14px;
  grid-auto-rows:160px;
}
@media (min-width:640px){ .gallery-grid{ grid-template-columns:repeat(3,1fr); gap:16px; grid-auto-rows:200px; } }
@media (min-width:980px){ .gallery-grid{ grid-auto-rows:230px; } }
.gal-item{
  position:relative; overflow:hidden; border-radius:4px;
  border:1px solid var(--line);
}
.gal-item.span2{ grid-row:span 2; }
.gal-item img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease), filter .5s var(--ease); filter:saturate(.92); }
.gal-item:hover img{ transform:scale(1.07); filter:saturate(1.05); }
.gal-item::after{
  content:attr(data-cap); position:absolute; left:0; right:0; bottom:0;
  padding:14px 14px 12px; font-family:var(--sans); font-weight:500;
  font-size:.78rem; letter-spacing:.14em; text-transform:uppercase;
  color:var(--gold-light);
  background:linear-gradient(0deg, rgba(8,8,9,.86) 0%, transparent 100%);
  transform:translateY(8px); opacity:0; transition:all .4s var(--ease);
}
.gal-item:hover::after,.gal-item:focus-within::after{ transform:translateY(0); opacity:1; }

/* before / after */
.ba-wrap{ margin-top:44px; }
.ba-head{ text-align:center; margin-bottom:18px; }
.ba-head h3{
  font-family:var(--serif); font-weight:600; font-size:1.25rem; letter-spacing:.08em;
  text-transform:uppercase; margin:0 0 4px; color:var(--cream);
}
.ba-slider{
  position:relative; width:100%; max-width:760px; margin:0 auto;
  aspect-ratio:16/10; border:1px solid var(--line-strong); border-radius:6px;
  overflow:hidden; cursor:ew-resize; user-select:none; touch-action:none;
  background:#0a0a0b;
}
.ba-layer{ position:absolute; inset:0; }
.ba-layer img{ width:100%; height:100%; object-fit:cover; pointer-events:none; }
.ba-after img{ filter:none; }
.ba-before{ z-index:2; }
.ba-before img{ filter:grayscale(.55) saturate(.4) brightness(.86) contrast(.96) hue-rotate(-12deg); }
.ba-tag{
  position:absolute; top:12px; z-index:4; font-family:var(--sans); font-weight:600;
  font-size:.68rem; letter-spacing:.18em; text-transform:uppercase;
  padding:5px 12px; border-radius:2px; background:rgba(8,8,9,.7);
  border:1px solid var(--line); color:var(--gold-light);
}
.ba-tag.before-tag{ left:12px; }
.ba-tag.after-tag{ right:12px; }
.ba-divider{ position:absolute; top:0; bottom:0; left:50%; width:2px; z-index:5; background:var(--brushed); transform:translateX(-1px); pointer-events:none; }
.ba-handle{
  position:absolute; top:50%; left:50%; z-index:6;
  width:46px; height:46px; transform:translate(-50%,-50%); border-radius:50%;
  background:var(--brushed); border:2px solid var(--black-1);
  box-shadow:0 4px 16px rgba(0,0,0,.5); cursor:ew-resize;
  display:flex; align-items:center; justify-content:center;
}
.ba-handle svg{ width:22px; height:22px; fill:var(--black-1); }
.ba-note{ text-align:center; margin:14px auto 0; max-width:640px; font-size:.82rem; color:var(--muted); font-weight:300; font-style:italic; }

.repr-note{ text-align:center; margin:18px auto 0; max-width:640px; font-size:.8rem; color:var(--muted); font-weight:300; }

/* ============================================================
   WHY / TRUST BADGES
   ============================================================ */
.why-grid{ display:grid; grid-template-columns:1fr; gap:18px; }
@media (min-width:560px){ .why-grid{ grid-template-columns:1fr 1fr; } }
@media (min-width:1000px){ .why-grid{ grid-template-columns:repeat(4,1fr); } }
.why-card{
  background:var(--panel); border:1px solid var(--line); border-radius:4px;
  padding:32px 22px; text-align:center;
}
.why-icon{
  width:58px; height:58px; margin:0 auto 16px;
  display:flex; align-items:center; justify-content:center; border-radius:50%;
  border:1px solid var(--line-strong);
  background:radial-gradient(circle, rgba(201,162,74,.1), transparent 70%);
}
.why-icon svg{ width:30px; height:30px; stroke:url(#goldGrad2); fill:none; stroke-width:1.6; }
.why-card h3{
  font-family:var(--serif); font-weight:600; font-size:1.02rem; letter-spacing:.04em;
  margin:0 0 6px; color:var(--cream); line-height:1.3;
}
.why-card p{ margin:0; font-size:.86rem; color:var(--cream-dim); font-weight:300; }

/* ============================================================
   INSTAGRAM
   ============================================================ */
#instagram{ background:linear-gradient(180deg, var(--black-2), var(--black-1)); }
.ig-panel{
  background:var(--panel-raised);
  border:1px solid var(--line); border-radius:6px;
  padding:48px 28px; text-align:center; position:relative; overflow:hidden;
}
.ig-panel::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(135deg, rgba(201,162,74,.14), rgba(10,10,11,0) 60%);
  pointer-events:none;
}
.ig-inner{ position:relative; z-index:1; max-width:620px; margin:0 auto; }
.ig-glyph{ width:54px; height:54px; margin:0 auto 14px; }
.ig-glyph svg{ width:100%; height:100%; }
.ig-script{ font-family:var(--script); font-size:2.3rem; color:var(--gold-light); line-height:1; display:block; margin-bottom:4px; font-display:block; }
.ig-line{ font-family:var(--serif); font-weight:600; font-size:clamp(1.3rem,3.5vw,1.9rem); letter-spacing:.05em; text-transform:uppercase; margin:0 0 12px; }
.ig-copy{ color:var(--cream-dim); font-weight:300; margin:0 0 26px; }
.ig-handle-btn{ font-size:1.05rem; padding:16px 34px; }
.ig-feed{
  display:grid; grid-template-columns:repeat(2,1fr); gap:10px;
  margin-top:34px;
}
@media (min-width:560px){ .ig-feed{ grid-template-columns:repeat(4,1fr); } }
.ig-tile{ position:relative; aspect-ratio:1; overflow:hidden; border-radius:4px; border:1px solid var(--line); display:block; }
.ig-tile img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease), filter .4s var(--ease); filter:saturate(.9) brightness(.9); }
.ig-tile:hover img{ transform:scale(1.08); filter:saturate(1) brightness(1); }
.ig-tile::after{
  content:""; position:absolute; inset:0;
  background:radial-gradient(circle at 50% 50%, transparent 55%, rgba(8,8,9,.35));
  opacity:0; transition:opacity .4s;
}
.ig-tile:hover::after{ opacity:1; }
.ig-tile .tile-ig{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:26px; height:26px; opacity:0; transition:opacity .4s; z-index:2; }
.ig-tile:hover .tile-ig{ opacity:1; }
.ig-tile .tile-ig svg{ width:100%; height:100%; fill:var(--cream); }

/* ============================================================
   VISIT / INFO
   ============================================================ */
.visit-grid{ display:grid; grid-template-columns:1fr; gap:26px; }
@media (min-width:880px){ .visit-grid{ grid-template-columns:1fr 1fr; gap:32px; align-items:stretch; } }
.info-card{
  background:var(--panel-raised); border:1px solid var(--line); border-radius:6px;
  padding:34px 30px; display:flex; flex-direction:column;
}
.info-card h3{
  font-family:var(--serif); font-weight:600; font-size:1.2rem; letter-spacing:.06em;
  text-transform:uppercase; margin:0 0 4px; color:var(--cream);
}
.info-block + .info-block{ margin-top:26px; padding-top:26px; border-top:1px solid var(--line); }
.hours-table{ width:100%; border-collapse:collapse; }
.hours-table th, .hours-table td{ text-align:left; padding:8px 0; font-size:.96rem; }
.hours-table th{ font-family:var(--sans); font-weight:400; color:var(--cream-dim); letter-spacing:.04em; }
.hours-table td{ font-weight:500; color:var(--cream); text-align:right; white-space:nowrap; }
.hours-table .appt th, .hours-table .appt td{ color:var(--muted); font-weight:300; font-size:.86rem; font-style:italic; }
.info-line{ display:flex; align-items:flex-start; gap:12px; margin:0 0 12px; }
.info-line .ic{ flex:0 0 auto; width:20px; height:20px; margin-top:3px; stroke:url(#goldGrad2); fill:none; stroke-width:1.6; }
.info-line a{ color:var(--cream); }
.info-line a:hover{ color:var(--gold-light); }
.info-line .lbl{ display:block; font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-light); margin-bottom:2px; }
.visit-tag{ font-family:var(--script); font-size:1.9rem; color:var(--gold-light); line-height:1; margin:22px 0 18px; display:block; font-display:block; }
.info-card .btn{ width:100%; margin-top:auto; }

.map-card{ border:1px solid var(--line); border-radius:6px; overflow:hidden; min-height:340px; position:relative; background:var(--panel); }
#map-frame{ position:absolute; inset:0; min-height:340px; background:var(--panel); }
.leaflet-container{ background:#0d0d10; font-family:'Jost', sans-serif; }
.gold-pin svg{ width:36px; height:48px; filter:drop-shadow(0 4px 6px rgba(0,0,0,.55)); }
.gold-pin svg path{ fill:#d4af37; stroke:#0a0a0b; stroke-width:.6; }
.gold-pin svg circle{ fill:#0a0a0b; }
.leaflet-popup-content-wrapper, .leaflet-popup-tip{ background:#16161b; color:var(--cream-dim); border:1px solid var(--line); box-shadow:0 12px 32px rgba(0,0,0,.55); }
.leaflet-popup-content{ font-size:13px; line-height:1.55; margin:12px 14px; }
.leaflet-popup-content strong{ font-family:'Cinzel', serif; color:var(--gold-light); font-size:14px; }
.leaflet-popup-content a{ color:var(--gold-light); text-decoration:none; }
.leaflet-popup-content a:hover{ text-decoration:underline; }
.leaflet-container a.leaflet-popup-close-button{ color:var(--gold-light); }
.leaflet-control-zoom a{ background:#16161b !important; color:var(--gold-light) !important; border-color:var(--line) !important; }
.leaflet-control-zoom a:hover{ background:#1d1d24 !important; }
.leaflet-bar{ border:1px solid var(--line); }
.leaflet-control-attribution{ background:rgba(13,13,16,.72) !important; color:#8c8576 !important; font-size:10px; }
.leaflet-control-attribution a{ color:#c9a24a !important; }
.map-fallback{
  position:absolute; inset:0; display:none; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:30px; gap:10px; color:var(--cream-dim);
  background:radial-gradient(circle at 50% 40%, rgba(201,162,74,.08), transparent 70%), var(--panel);
}
.map-fallback svg{ width:46px; height:46px; stroke:url(#goldGrad2); fill:none; stroke-width:1.4; }

/* ============================================================
   FOOTER
   ============================================================ */
#site-footer{
  border-top:1px solid var(--line-strong);
  background:var(--black-2);
  padding:56px 0 110px;
}
@media (min-width:980px){ #site-footer{ padding:60px 0 40px; } }
.footer-grid{ display:grid; grid-template-columns:1fr; gap:34px; }
@media (min-width:760px){ .footer-grid{ grid-template-columns:1.4fr 1fr 1fr; gap:40px; } }
.foot-brand .mini-mono{ width:42px; height:42px; margin-bottom:12px; }
.foot-brand .fb-name{ font-family:var(--serif); font-weight:700; font-size:1.1rem; letter-spacing:.14em; color:var(--cream); }
.foot-brand .fb-script{ font-family:var(--script); font-size:1.5rem; color:var(--gold-light); display:block; line-height:1; margin:2px 0 4px; font-display:block; }
.foot-brand .fb-est{ font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }
.foot-col h4{ font-family:var(--serif); font-weight:600; font-size:.92rem; letter-spacing:.1em; text-transform:uppercase; color:var(--gold-light); margin:0 0 16px; }
.foot-col ul{ list-style:none; margin:0; padding:0; }
.foot-col li{ margin-bottom:10px; }
.foot-col a, .foot-col span{ color:var(--cream-dim); font-size:.92rem; font-weight:300; }
.foot-col a:hover{ color:var(--gold-light); }
.foot-bottom{
  margin-top:42px; padding-top:24px; border-top:1px solid var(--line);
  text-align:center; font-size:.8rem; color:var(--muted); letter-spacing:.04em;
}

/* ============================================================
   STICKY MOBILE ACTION BAR
   ============================================================ */
#mobile-bar{
  position:fixed; left:0; right:0; bottom:0; z-index:108;
  display:flex; gap:10px; padding:10px 12px;
  background:rgba(13,13,16,.96); -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
  border-top:1px solid var(--line);
}
#mobile-bar .btn{ flex:1; padding:13px 8px; font-size:.8rem; }
@media (min-width:980px){ #mobile-bar{ display:none; } }

/* ============================================================
   SCROLL REVEALS — graceful: default visible, JS hides then reveals
   ============================================================ */
.js .reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.js .reveal.in{ opacity:1; transform:translateY(0); }
.js .reveal.d1{ transition-delay:.08s; }
.js .reveal.d2{ transition-delay:.16s; }
.js .reveal.d3{ transition-delay:.24s; }
.js .reveal.d4{ transition-delay:.32s; }

@media (prefers-reduced-motion: reduce){
  .js .reveal{ opacity:1 !important; transform:none !important; transition:none !important; }
  .logo-svg.animate .stroke-draw{ stroke-dashoffset:0 !important; animation:none !important; }
  .logo-svg.animate .mono-fill{ opacity:1 !important; animation:none !important; }
  .logo-svg.animate .wordmark,
  .logo-svg.animate .word-sub,
  .logo-svg.animate .script-line,
  .logo-svg.animate .est{ opacity:1 !important; transform:none !important; animation:none !important; }
  .logo-svg.animate .shine-rect{ animation:none !important; opacity:0 !important; }
  .scroll-cue{ animation:none !important; }
}
