/* =========================================================================
   SHAVE BARBER SHOP — barbershopfl.com
   Brand palette pulled from the real shop: royal-blue awning, scarlet sign,
   warm cream stucco, brick red, deep midnight navy for drama.
   Type: Anton (signage display) · Yellowtail (brand script) · Archivo (UI).
   ========================================================================= */

/* ---------- Tokens ---------- */
:root{
  --cream:      #121214;
  --cream-2:    #1a1a1e;
  --cream-3:    #232328;
  --paper:      #1b1b20;
  --ink:        #f2f2f3;
  --ink-2:      #b7b7bc;
  --ink-soft:   #8a8a90;

  --navy:       #08080a;
  --navy-2:     #000000;
  --navy-3:     #26262c;
  --navy-line:  rgba(255,255,255,.12);

  --red:        #ffffff;
  --red-deep:   #d2d2d4;
  --red-glow:   rgba(255,255,255,.18);

  --blue:       #3a3a40;
  --blue-bright:#d7d7da;
  --blue-deep:  #5a5a61;

  --line:       rgba(255,255,255,.13);
  --line-2:     rgba(255,255,255,.07);

  --ff-disp: "Saira", system-ui, sans-serif;
  --ff-script: "Saira", system-ui, sans-serif;
  --ff-body: "Saira", system-ui, sans-serif;

  --shadow-sm: 0 2px 8px rgba(12,26,43,.08);
  --shadow:    0 14px 40px -16px rgba(12,26,43,.32);
  --shadow-lg: 0 40px 90px -34px rgba(8,19,32,.55);
  --shadow-red:0 18px 40px -14px var(--red-glow);

  --r-sm: 10px;
  --r:    16px;
  --r-lg: 26px;
  --r-pill: 999px;

  --maxw: 1240px;
  --pad: clamp(20px, 5vw, 64px);
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; overflow-x:clip; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  font-family:var(--ff-body);
  background:var(--cream);
  color:var(--ink);
  line-height:1.6;
  font-size:clamp(15px,1.05vw,17px);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:clip;
}
img,video{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; cursor:pointer; background:none; border:none; }
input,select,textarea{ font:inherit; color:inherit; }
ul{ list-style:none; }
::selection{ background:var(--red); color:#0e0e0e; }
:focus-visible{ outline:3px solid var(--blue-bright); outline-offset:2px; border-radius:4px; }

/* custom scrollbar */
::-webkit-scrollbar{ width:12px; height:12px; }
::-webkit-scrollbar-track{ background:var(--cream-2); }
::-webkit-scrollbar-thumb{ background:var(--navy-3); border:3px solid var(--cream-2); border-radius:999px; }

/* ---------- Layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }
.section{ padding-block:clamp(64px,9vw,128px); position:relative; }
.section--tight{ padding-block:clamp(48px,6vw,84px); }
.bg-navy{ background:var(--navy); color:var(--ink); }
.bg-cream2{ background:var(--cream-2); }
.bg-paper{ background:var(--paper); }

/* ---------- Typography helpers ---------- */
.kicker{
  font-family:var(--ff-disp);
  font-weight:700; font-style:italic;
  font-size:clamp(.82rem,1.4vw,1.02rem);
  letter-spacing:.14em; text-transform:uppercase;
  color:var(--red);
  line-height:1;
  display:inline-block;
}
.bg-navy .kicker{ color:var(--blue-bright); }
.eyebrow{
  font-family:var(--ff-body);
  font-weight:700;
  letter-spacing:.32em;
  text-transform:uppercase;
  font-size:.72rem;
  color:var(--ink-soft);
  display:inline-flex; align-items:center; gap:.7em;
}
.eyebrow::before{ content:""; width:34px; height:2px; background:var(--red); display:inline-block; }
.bg-navy .eyebrow{ color:rgba(245,239,227,.66); }
.bg-navy .eyebrow::before{ background:var(--blue-bright); }

h1,h2,h3,.display{ font-family:var(--ff-disp); font-weight:800; font-style:italic; line-height:.95; letter-spacing:.012em; text-transform:uppercase; }
.h-sec{ font-size:clamp(2rem,5vw,4.1rem); color:var(--ink-2); }
.h-sec .accent{ color:#fff; }
.bg-navy .h-sec .accent{ color:#fff; }
.lede{ font-size:clamp(1.05rem,1.5vw,1.28rem); color:var(--ink-2); max-width:60ch; line-height:1.55; }
.bg-navy .lede{ color:rgba(245,239,227,.82); }
.sec-head{ margin-bottom:clamp(34px,5vw,60px); max-width:78ch; }
.sec-head .kicker{ margin-bottom:.35em; }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--red); --fg:#fff; --bd:transparent;
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  font-family:var(--ff-body); font-weight:700; letter-spacing:.04em;
  font-size:.96rem; text-transform:uppercase;
  padding:1.02em 1.7em; border-radius:var(--r-pill);
  background:var(--bg); color:var(--fg); border:2px solid var(--bd);
  position:relative; isolation:isolate; overflow:hidden;
  transition:transform .35s var(--ease-out), box-shadow .35s var(--ease), background .25s;
  will-change:transform;
}
.btn svg{ width:1.05em; height:1.05em; }
.btn::after{ content:""; position:absolute; inset:0; z-index:-1; background:linear-gradient(120deg,transparent,rgba(255,255,255,.28),transparent); transform:translateX(-120%); transition:transform .6s var(--ease); }
.btn:hover{ transform:translateY(-3px); box-shadow:var(--shadow-red); }
.btn:hover::after{ transform:translateX(120%); }
.btn:active{ transform:translateY(-1px) scale(.99); }
.btn--red{ --bg:var(--red); --fg:#0e0e0e; } .btn--red:hover{ background:var(--red-deep); }
.btn--blue{ --bg:var(--blue); --fg:#fff; } .btn--blue:hover{ background:var(--blue-deep); box-shadow:0 18px 40px -14px rgba(22,100,201,.5); }
.btn--ghost{ --bg:transparent; --fg:var(--ink); --bd:rgba(255,255,255,.32); }
.btn--ghost:hover{ --fg:#0e0e0e; background:#fff; border-color:#fff; box-shadow:var(--shadow); }
.bg-navy .btn--ghost{ --fg:#fff; --bd:rgba(255,255,255,.4); }
.bg-navy .btn--ghost:hover{ background:#fff; --fg:var(--navy); border-color:#fff; }
.btn--lg{ padding:1.18em 2.1em; font-size:1.02rem; }
.btn--sm{ padding:.7em 1.15em; font-size:.82rem; }
.btn--block{ width:100%; }

.link-underline{ position:relative; font-weight:600; color:var(--blue-deep); }
.link-underline::after{ content:""; position:absolute; left:0; bottom:-3px; width:100%; height:2px; background:currentColor; transform:scaleX(0); transform-origin:right; transition:transform .35s var(--ease); }
.link-underline:hover::after{ transform:scaleX(1); transform-origin:left; }

/* ===================== TOP BAR ===================== */
.topbar{
  background:var(--navy-2); color:var(--ink);
  font-size:.78rem; letter-spacing:.06em;
}
.topbar .wrap{ display:flex; align-items:center; justify-content:center; gap:1.5em; padding-block:.6em; text-align:center; }
.topbar strong{ color:#fff; }
.topbar .dot{ color:var(--red); }
.topbar a{ color:var(--blue-bright); font-weight:600; }
.topbar .tb-hide{ }
@media (max-width:680px){ .topbar .tb-hide{ display:none; } }

/* ===================== NAV ===================== */
.nav{
  position:sticky; top:0; z-index:60;
  background:rgba(18,18,20,.82);
  backdrop-filter:blur(14px) saturate(1.4); -webkit-backdrop-filter:blur(14px) saturate(1.4);
  border-bottom:1px solid var(--line-2);
  transition:background .3s, box-shadow .3s, padding .3s;
}
.nav.scrolled{ background:rgba(14,14,16,.95); box-shadow:0 10px 30px -18px rgba(12,26,43,.4); }
.nav .wrap{ display:flex; align-items:center; gap:1.4rem; padding-block:.85rem; }
.nav.scrolled .wrap{ padding-block:.6rem; }
.brand{ display:flex; flex-direction:column; line-height:.86; margin-right:auto; }
.brand .b-script{ font-family:var(--ff-disp); font-weight:900; font-style:italic; text-transform:uppercase; letter-spacing:.02em; color:var(--red); font-size:1.5rem; }
.brand .b-sub{ font-family:var(--ff-disp); font-weight:600; font-size:.78rem; letter-spacing:.2em; color:var(--ink); }
.nav-links{ display:flex; align-items:center; gap:1.6rem; }
.nav-links a{ font-weight:600; font-size:.94rem; position:relative; padding:.2em 0; color:var(--ink-2); transition:color .2s; }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:-4px; height:2px; width:100%; background:var(--red); transform:scaleX(0); transform-origin:right; transition:transform .3s var(--ease); }
.nav-links a:hover{ color:var(--ink); } .nav-links a:hover::after{ transform:scaleX(1); transform-origin:left; }
.nav-actions{ display:flex; align-items:center; gap:.85rem; }
.nav-phone{ display:inline-flex; align-items:center; gap:.45em; font-weight:700; font-size:.92rem; }
.nav-phone svg{ width:1em; height:1em; color:var(--red); }

/* language toggle */
.lang{ display:inline-flex; border:1.5px solid var(--line); border-radius:var(--r-pill); overflow:hidden; font-weight:700; font-size:.78rem; background:var(--paper); }
.lang button{ padding:.42em .8em; letter-spacing:.04em; color:var(--ink-soft); transition:.2s; }
.lang button[aria-pressed="true"]{ background:var(--navy); color:#fff; }

/* burger */
.burger{ display:none; width:46px; height:42px; border:1.5px solid var(--line); border-radius:12px; flex-direction:column; gap:5px; align-items:center; justify-content:center; background:var(--paper); }
.burger span{ width:20px; height:2px; background:var(--ink); transition:.3s var(--ease); }
.burger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.burger.open span:nth-child(2){ opacity:0; }
.burger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* mobile drawer */
.drawer{ position:fixed; inset:0 0 0 auto; width:min(86vw,360px); background:var(--navy); color:var(--ink); z-index:80; transform:translateX(100%); transition:transform .45s var(--ease-out); display:flex; flex-direction:column; padding:5.5rem 2rem 2rem; gap:.4rem; box-shadow:var(--shadow-lg); }
.drawer.open{ transform:translateX(0); }
.drawer a{ font-family:var(--ff-disp); font-size:1.6rem; padding:.55rem 0; border-bottom:1px solid var(--navy-line); text-transform:uppercase; }
.drawer .btn{ margin-top:1.2rem; }
.scrim{ position:fixed; inset:0; background:rgba(8,19,32,.55); backdrop-filter:blur(3px); z-index:70; opacity:0; visibility:hidden; transition:.4s; }
.scrim.open{ opacity:1; visibility:visible; }

/* ===================== HERO ===================== */
.hero{ position:relative; min-height:min(88vh,840px); display:flex; align-items:flex-end; overflow:hidden; color:#fff; isolation:isolate; }
.hero__media{ position:absolute; inset:0; z-index:-2; }
.hero__media img{ width:100%; height:100%; object-fit:cover; object-position:center 14%; animation:kenburns 26s var(--ease) infinite alternate; }
@keyframes kenburns{ from{ transform:scale(1.0); } to{ transform:scale(1.06); } }
.hero__scrim{ position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(180deg, rgba(8,19,32,.55) 0%, rgba(8,19,32,.12) 26%, rgba(8,19,32,.05) 46%, rgba(8,19,32,.62) 82%, rgba(8,19,32,.92) 100%),
    linear-gradient(95deg, rgba(8,19,32,.7) 0%, rgba(8,19,32,.18) 52%, transparent 75%);
}
.hero__inner{ padding-block:clamp(40px,8vw,96px); width:100%; }
.hero .kicker{ color:#ffd; text-shadow:0 2px 18px rgba(0,0,0,.4); }
.hero h1{ font-size:clamp(2.8rem,8.6vw,6.6rem); margin:.12em 0 .26em; text-shadow:0 6px 40px rgba(0,0,0,.4); max-width:18ch; }
.hero h1 .accent{ color:var(--red); -webkit-text-stroke:0; }
.hero__sub{ font-size:clamp(1.05rem,1.7vw,1.4rem); max-width:46ch; color:rgba(255,255,255,.92); text-shadow:0 2px 16px rgba(0,0,0,.45); }
.hero__cta{ display:flex; flex-wrap:wrap; gap:.9rem; margin-top:1.8rem; }
.hero__trust{ display:flex; flex-wrap:wrap; gap:1.6rem 2.2rem; margin-top:2.4rem; padding-top:1.6rem; border-top:1px solid rgba(255,255,255,.2); }
.trust-item{ display:flex; align-items:center; gap:.6em; font-size:.92rem; }
.trust-item .stars{ color:#ffd23f; letter-spacing:.06em; font-size:1.05rem; }
.trust-item strong{ font-family:var(--ff-disp); font-size:1.4rem; letter-spacing:.02em; }
.trust-item small{ display:block; opacity:.75; font-size:.74rem; letter-spacing:.08em; text-transform:uppercase; line-height:1.2; }
.scroll-cue{ position:absolute; left:50%; bottom:20px; transform:translateX(-50%); z-index:2; display:flex; flex-direction:column; align-items:center; gap:.4em; font-size:.66rem; letter-spacing:.3em; text-transform:uppercase; opacity:.85; }
.scroll-cue .mouse{ width:22px; height:36px; border:2px solid rgba(255,255,255,.7); border-radius:14px; position:relative; }
.scroll-cue .mouse::after{ content:""; position:absolute; left:50%; top:7px; width:3px; height:7px; background:#fff; border-radius:2px; transform:translateX(-50%); animation:wheel 1.6s var(--ease) infinite; }
@keyframes wheel{ 0%{opacity:0;transform:translate(-50%,0)} 40%{opacity:1} 100%{opacity:0;transform:translate(-50%,12px)} }

/* ===================== MARQUEE ===================== */
.marquee{ background:var(--red); color:#0e0e0e; overflow:hidden; border-block:3px solid var(--navy); }
.marquee__track{ display:flex; gap:0; white-space:nowrap; width:max-content; animation:marq 32s linear infinite; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
.marquee span{ font-family:var(--ff-disp); text-transform:uppercase; font-size:clamp(1.3rem,2.4vw,2rem); letter-spacing:.04em; padding:.5em 1.1em; display:inline-flex; align-items:center; gap:1.1em; }
.marquee span::after{ content:"✦"; color:var(--navy); font-size:.7em; }
@keyframes marq{ to{ transform:translateX(-50%); } }

/* ===================== SERVICES ===================== */
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,30px); }
.svc{
  background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:clamp(26px,3vw,40px); display:flex; flex-direction:column; position:relative; overflow:hidden;
  transition:transform .45s var(--ease-out), box-shadow .45s var(--ease), border-color .3s;
}
.svc::before{ content:""; position:absolute; left:0; top:0; height:5px; width:100%; background:linear-gradient(90deg,var(--red),var(--blue)); transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease); }
.svc:hover{ transform:translateY(-8px); box-shadow:var(--shadow); border-color:transparent; }
.svc:hover::before{ transform:scaleX(1); }
.svc.feat{ background:var(--navy); color:var(--ink); border-color:rgba(255,255,255,.2); box-shadow:var(--shadow); }
.svc.feat .svc__price{ color:#fff; }
.svc__tag{ display:inline-flex; align-self:flex-start; align-items:center; gap:.45em; background:var(--red); color:#0e0e0e; font-weight:700; font-size:.68rem; letter-spacing:.14em; text-transform:uppercase; padding:.45em .85em; border-radius:var(--r-pill); margin-bottom:.9rem; box-shadow:var(--shadow-sm); }
.svc__tag::before{ content:"★"; font-size:.9em; }
.svc__name{ font-family:var(--ff-disp); font-size:clamp(1.5rem,2.4vw,2rem); text-transform:uppercase; line-height:1; }
.svc__price{ font-family:var(--ff-disp); font-size:clamp(2.6rem,5vw,3.6rem); color:var(--red); line-height:1; margin:.2em 0 .1em; }
.svc.feat .svc__price{ color:var(--blue-bright); }
.svc__price small{ font-size:1.1rem; opacity:.6; vertical-align:.5em; }
.svc__dur{ font-size:.8rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); }
.svc.feat .svc__dur{ color:rgba(245,239,227,.6); }
.svc__list{ margin:1.3rem 0 1.6rem; display:flex; flex-direction:column; gap:.6em; font-size:.95rem; }
.svc__list li{ display:flex; gap:.6em; align-items:flex-start; }
.svc__list li::before{ content:""; flex:none; width:18px; height:18px; margin-top:2px; border-radius:50%; background:#3a3a40 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/11px no-repeat; }
.svc.feat .svc__list li::before{ background-color:#5a5a61; }
.svc .btn{ margin-top:auto; }

/* ===================== BOOKING ===================== */
.book-wrap{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(30px,5vw,72px); align-items:center; }
.book-wrap > *, .book-pitch, .booking, #bookForm, .field, .svc-pick, .time-grid, .date-strip, .two, .input{ min-width:0; }
.book-pitch h2{ margin:.2em 0 .5em; }
.book-pitch .lede{ margin-bottom:1.6rem; }
.book-steps{ display:flex; flex-direction:column; gap:1.1rem; margin-top:1.6rem; }
.book-step{ display:flex; gap:1rem; align-items:flex-start; }
.book-step .n{ flex:none; width:40px; height:40px; border-radius:50%; display:grid; place-items:center; font-family:var(--ff-disp); font-size:1.2rem; background:rgba(255,255,255,.08); border:1px solid var(--navy-line); color:var(--blue-bright); }
.book-step h4{ font-size:1.02rem; font-weight:700; }
.book-step p{ font-size:.9rem; color:rgba(245,239,227,.66); }

.booking{ background:var(--paper); color:var(--ink); border-radius:var(--r-lg); padding:clamp(22px,3vw,38px); box-shadow:var(--shadow-lg); position:relative; }
.booking__head{ display:flex; align-items:center; justify-content:space-between; gap:1rem; margin-bottom:1.2rem; }
.booking__head h3{ font-size:1.5rem; }
.booking__head .secure{ font-size:.72rem; letter-spacing:.08em; color:var(--ink-soft); display:inline-flex; gap:.4em; align-items:center; }
.booking__head .secure svg{ width:1em; height:1em; color:var(--blue); }
.field{ margin-bottom:1.05rem; }
.field > label{ display:block; font-weight:700; font-size:.8rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-2); margin-bottom:.55rem; }
.field > label .req{ color:var(--red); }

.svc-pick{ display:grid; grid-template-columns:repeat(3,1fr); gap:.55rem; }
.svc-pick label{ position:relative; cursor:pointer; }
.svc-pick input{ position:absolute; opacity:0; inset:0; }
.svc-pick .card{ border:1.6px solid var(--line); border-radius:var(--r-sm); padding:.7rem .6rem; text-align:center; transition:.25s; height:100%; display:flex; flex-direction:column; gap:.2rem; justify-content:center; }
.svc-pick .card .t{ font-weight:700; font-size:.84rem; line-height:1.1; }
.svc-pick .card .p{ font-family:var(--ff-disp); font-size:1.25rem; color:var(--red); }
.svc-pick input:checked + .card{ border-color:var(--navy); background:var(--navy); color:#fff; box-shadow:var(--shadow-sm); }
.svc-pick input:checked + .card .p{ color:var(--blue-bright); }
.svc-pick input:focus-visible + .card{ outline:3px solid var(--blue-bright); outline-offset:2px; }

.date-strip{ display:flex; gap:.5rem; overflow-x:auto; padding-bottom:.4rem; scroll-snap-type:x mandatory; scrollbar-width:thin; }
.date-strip::-webkit-scrollbar{ height:6px; }
.date-chip{ flex:none; scroll-snap-align:start; min-width:62px; border:1.6px solid var(--line); border-radius:var(--r-sm); padding:.55rem .3rem; text-align:center; transition:.2s; background:var(--paper); }
.date-chip .dow{ font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); }
.date-chip .dnum{ font-family:var(--ff-disp); font-size:1.4rem; line-height:1; margin-top:.1em; }
.date-chip .mon{ font-size:.6rem; text-transform:uppercase; letter-spacing:.08em; color:var(--ink-soft); }
.date-chip[aria-pressed="true"]{ background:var(--red); border-color:var(--red); color:#0e0e0e; box-shadow:var(--shadow-red); }
.date-chip[aria-pressed="true"] .dow,.date-chip[aria-pressed="true"] .mon{ color:rgba(255,255,255,.85); }

.time-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(78px,1fr)); gap:.5rem; }
.time-chip{ border:1.6px solid var(--line); border-radius:var(--r-sm); padding:.7rem .3rem; text-align:center; font-weight:700; font-size:.92rem; transition:.2s; background:var(--paper); }
.time-chip small{ display:block; font-size:.6rem; font-weight:600; letter-spacing:.04em; color:var(--ink-soft); text-transform:uppercase; margin-top:.15em; }
.time-chip:hover:not(:disabled){ border-color:var(--blue); color:var(--blue-deep); transform:translateY(-2px); }
.time-chip[aria-pressed="true"]{ background:var(--navy); border-color:var(--navy); color:#fff; }
.time-chip[aria-pressed="true"] small{ color:rgba(255,255,255,.7); }
.time-chip:disabled{ opacity:.4; cursor:not-allowed; text-decoration:line-through; }
.time-empty{ font-size:.9rem; color:var(--ink-soft); padding:.6rem 0; }

/* ===== Booksy/Square-style calendar + slots ===== */
.cal{ border:1px solid var(--line); border-radius:var(--r); padding:.85rem; background:var(--paper); }
.cal__head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:.7rem; }
.cal__month{ font-family:var(--ff-disp); font-style:italic; font-weight:800; text-transform:uppercase; letter-spacing:.02em; font-size:1.05rem; }
.cal__nav{ width:38px; height:38px; border-radius:10px; border:1.5px solid var(--line); display:grid; place-items:center; font-size:1.15rem; background:var(--paper); transition:.18s; }
.cal__nav:hover:not(:disabled){ background:var(--navy); color:#fff; border-color:var(--navy); }
.cal__nav:disabled{ opacity:.28; cursor:not-allowed; }
.cal__dow{ display:grid; grid-template-columns:repeat(7,1fr); gap:3px; margin-bottom:5px; }
.cal__dow span{ text-align:center; font-size:.64rem; font-weight:800; letter-spacing:.04em; color:var(--ink-soft); text-transform:uppercase; }
.cal__grid{ display:grid; grid-template-columns:repeat(7,1fr); gap:4px; }
.cal__cell{ aspect-ratio:1; border:0; border-radius:11px; background:transparent; font-weight:700; font-size:.95rem; color:var(--ink); display:grid; place-items:center; transition:.15s; }
.cal__cell.empty{ pointer-events:none; }
.cal__cell:not(.dis):not(.sel):hover{ background:var(--cream-2); transform:translateY(-1px); }
.cal__cell.dis{ color:rgba(255,255,255,.25); cursor:not-allowed; }
.cal__cell.today:not(.sel){ box-shadow:inset 0 0 0 1.6px var(--blue); color:var(--blue-deep); }
.cal__cell.sel{ background:var(--red); color:#0e0e0e; box-shadow:var(--shadow-red); }

.slots{ display:flex; flex-direction:column; gap:1rem; }
.slot-group__label{ font-size:.7rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:.5rem; }
.slot-row{ display:grid; grid-template-columns:repeat(auto-fill,minmax(86px,1fr)); gap:.5rem; }
.slot{ border:1.6px solid var(--line); border-radius:11px; padding:.75rem .3rem; text-align:center; font-weight:700; font-size:.92rem; background:var(--paper); transition:.18s; }
.slot:hover{ border-color:var(--blue); color:var(--blue-deep); transform:translateY(-2px); box-shadow:var(--shadow-sm); }
.slot[aria-pressed="true"]{ background:var(--navy); border-color:var(--navy); color:#fff; }

.book-summary{ display:flex; flex-direction:column; gap:.15rem; background:var(--navy); color:#fff; border-radius:var(--r-sm); padding:.85rem 1.05rem; margin:.2rem 0 1rem; box-shadow:var(--shadow-sm); }
.book-summary .bs-when{ font-family:var(--ff-disp); font-style:italic; font-weight:800; font-size:1.1rem; letter-spacing:.01em; }
.book-summary .bs-svc{ font-size:.9rem; color:var(--blue-bright); font-weight:600; }
.book-summary[hidden]{ display:none; }

.input{ width:100%; padding:.95em 1.05em; border:1.6px solid var(--line); border-radius:var(--r-sm); background:var(--paper); transition:.2s; }
.input:focus{ outline:none; border-color:var(--blue); box-shadow:0 0 0 3px rgba(22,100,201,.15); }
.two{ display:grid; grid-template-columns:1fr 1fr; gap:.8rem; }
.hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.consent{ font-size:.78rem; color:var(--ink-soft); display:flex; gap:.5em; align-items:flex-start; margin:.2rem 0 1rem; }
#ts-holder{ margin:.2rem 0 1rem; min-height:0; }
.booking__msg{ border-radius:var(--r-sm); padding:.85rem 1rem; font-size:.9rem; margin-bottom:1rem; display:none; }
.booking__msg.err{ display:block; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.35); color:var(--red-deep); }
.booking__msg.ok{ display:block; background:rgba(22,100,201,.1); border:1px solid rgba(22,100,201,.3); color:var(--blue-deep); }

.booking__success{ display:none; text-align:center; padding:1rem .5rem; }
.booking__success.show{ display:block; animation:pop .5s var(--ease-out); }
@keyframes pop{ from{opacity:0;transform:scale(.92)} to{opacity:1;transform:scale(1)} }
.booking__success .check{ width:74px; height:74px; margin:0 auto 1rem; border-radius:50%; background:var(--blue); display:grid; place-items:center; box-shadow:0 16px 36px -12px rgba(22,100,201,.5); animation:popcheck .6s var(--ease-out) .1s both; }
.booking__success .check svg{ width:38px; height:38px; color:#fff; }
@keyframes popcheck{ from{transform:scale(0) rotate(-30deg)} to{transform:scale(1) rotate(0)} }
.booking__success h3{ font-size:1.9rem; margin-bottom:.4rem; }
.recap{ background:var(--cream-2); border-radius:var(--r-sm); padding:1rem 1.2rem; margin:1.1rem 0; text-align:left; display:grid; gap:.4rem; }
.recap div{ display:flex; justify-content:space-between; gap:1rem; font-size:.95rem; }
.recap div span:first-child{ color:var(--ink-soft); }
.recap div span:last-child{ font-weight:700; text-align:right; }

.spinner{ width:1.1em; height:1.1em; border:2.5px solid rgba(255,255,255,.4); border-top-color:#fff; border-radius:50%; animation:spin .7s linear infinite; display:none; }
.is-loading .spinner{ display:inline-block; }
.is-loading .btn-label{ opacity:.7; }
@keyframes spin{ to{ transform:rotate(360deg); } }

/* ===================== GALLERY ===================== */
.gallery{ display:grid; grid-template-columns:repeat(3,1fr); grid-auto-rows:200px; gap:14px; }
.gal-item{ overflow:hidden; border-radius:var(--r); position:relative; background:var(--navy-3); }
.gal-item img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease); }
.gal-item:hover img{ transform:scale(1.08); }
.gal-item::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%,rgba(8,19,32,.5)); opacity:0; transition:.4s; }
.gal-item:hover::after{ opacity:1; }
.gal-item .cap{ position:absolute; left:16px; bottom:14px; color:#fff; font-family:var(--ff-disp); text-transform:uppercase; font-size:1.05rem; opacity:0; transform:translateY(8px); transition:.4s; z-index:2; }
.gal-item:hover .cap{ opacity:1; transform:none; }
.gal-tall{ grid-row:span 2; }
.gal-wide{ grid-column:span 2; }

/* ===================== ABOUT BAND ===================== */
.band{ position:relative; overflow:hidden; color:#fff; }
.band__bg{ position:absolute; inset:0; z-index:-2; }
.band__bg img{ width:100%; height:100%; object-fit:cover; object-position:center 40%; }
.band__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(100deg,rgba(8,19,32,.94) 0%,rgba(8,19,32,.8) 42%,rgba(8,19,32,.5) 100%); }
.band .wrap{ position:relative; }
.band__inner{ max-width:60ch; }
.band .lede{ color:rgba(245,239,227,.92); text-shadow:0 1px 14px rgba(0,0,0,.45); }
.stats{ display:grid; grid-template-columns:repeat(3,auto); gap:clamp(24px,5vw,64px); margin-top:2.4rem; }
.stat .num{ font-family:var(--ff-disp); font-size:clamp(2.6rem,5vw,4rem); line-height:1; color:var(--blue-bright); }
.stat .lbl{ font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:rgba(245,239,227,.7); margin-top:.3em; }

/* ===================== LOCATION ===================== */
.loc-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(24px,4vw,56px); align-items:stretch; }
.loc-grid > *{ min-width:0; }
.map-card{ border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow); min-height:360px; border:1px solid var(--line); position:relative; }
.map-card iframe{ width:100%; height:100%; min-height:360px; border:0; filter:saturate(1.05); }

/* ===== Visit: connect / socials card ===== */
.connect-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(20px,2.6vw,30px); display:flex; flex-direction:column; gap:.7rem; }
.connect-card h3{ font-size:1.5rem; margin-bottom:.5rem; }
.connect-row{ display:flex; align-items:center; gap:1rem; padding:.95rem 1.1rem; border:1.5px solid var(--line); border-radius:var(--r); background:var(--paper); transition:transform .25s var(--ease-out), box-shadow .25s, background .25s, color .2s, border-color .2s; }
.connect-row:hover{ transform:translateY(-3px); box-shadow:var(--shadow); color:#fff; border-color:transparent; }
.connect-row .ic{ width:46px; height:46px; border-radius:13px; background:var(--cream-2); display:grid; place-items:center; flex:none; transition:.25s; }
.connect-row .ic svg{ width:1.4em; height:1.4em; }
.connect-row .tx{ flex:1; min-width:0; }
.connect-row .tx b{ display:block; font-size:1.04rem; }
.connect-row .tx small{ color:var(--ink-soft); font-size:.85rem; }
.connect-row .arr{ font-weight:800; opacity:.35; transition:.25s; }
.connect-row:hover .arr{ opacity:1; transform:translateX(4px); }
.connect-row:hover .ic{ background:rgba(255,255,255,.22); color:#fff; }
.connect-row:hover .tx small{ color:rgba(255,255,255,.82); }
.connect-row.gmaps:hover{ background:var(--blue); }
.connect-row.star:hover{ background:#f5b301; color:var(--ink); }
.connect-row.star:hover .tx small,.connect-row.star:hover .ic{ color:var(--ink); }
.connect-row.ig:hover{ background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); }
.connect-row.tt:hover{ background:#111; }
.hours-card{ background:var(--navy); color:var(--ink); border-radius:var(--r-lg); padding:clamp(26px,3vw,40px); display:flex; flex-direction:column; }
.hours-card h3{ font-size:1.7rem; margin-bottom:.2em; }
.hours-list{ margin:1.2rem 0; }
.hours-list li{ display:flex; justify-content:space-between; padding:.7em 0; border-bottom:1px solid var(--navy-line); font-size:.98rem; }
.hours-list li.today{ color:#fff; }
.hours-list li.today .d{ position:relative; padding-left:1.1em; }
.hours-list li.today .d::before{ content:""; position:absolute; left:0; top:50%; transform:translateY(-50%); width:8px; height:8px; border-radius:50%; background:#3ad07a; box-shadow:0 0 0 4px rgba(58,208,122,.2); }
.hours-list .h{ color:rgba(245,239,227,.78); }
.addr{ display:flex; flex-direction:column; gap:.8rem; margin:1rem 0 1.4rem; }
.addr a{ display:flex; gap:.7em; align-items:flex-start; font-size:.98rem; }
.addr svg{ width:1.2em; height:1.2em; color:var(--blue-bright); flex:none; margin-top:.15em; }
.pay{ display:flex; gap:.5rem; flex-wrap:wrap; margin-top:auto; padding-top:1.2rem; border-top:1px solid var(--navy-line); }
.pay span{ font-size:.68rem; letter-spacing:.08em; text-transform:uppercase; border:1px solid var(--navy-line); border-radius:6px; padding:.35em .6em; color:rgba(245,239,227,.78); }

/* ===================== TESTIMONIALS + SOCIAL ===================== */
.reviews{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,2.4vw,26px); }
.review{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r); padding:clamp(22px,2.6vw,32px); display:flex; flex-direction:column; gap:1rem; transition:transform .4s var(--ease-out), box-shadow .4s; }
.review:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.review .stars{ color:#f5b301; letter-spacing:.1em; }
.review p{ font-size:1rem; line-height:1.55; }
.review .who{ display:flex; align-items:center; gap:.7rem; margin-top:auto; }
.review .av{ width:42px; height:42px; border-radius:50%; background:var(--navy); color:#fff; font-family:var(--ff-disp); display:grid; place-items:center; font-size:1.1rem; }
.review .who b{ font-size:.92rem; } .review .who small{ display:block; color:var(--ink-soft); font-size:.78rem; }

.social-bar{ display:flex; flex-wrap:wrap; gap:1rem; align-items:center; justify-content:center; margin-top:clamp(34px,5vw,56px); }
.social-btn{ display:inline-flex; align-items:center; gap:.7em; padding:.85em 1.4em; border-radius:var(--r-pill); border:1.6px solid var(--line); font-weight:700; transition:.3s var(--ease-out); background:var(--paper); }
.social-btn svg{ width:1.3em; height:1.3em; }
.social-btn:hover{ transform:translateY(-3px); color:#fff; border-color:transparent; box-shadow:var(--shadow); }
.social-btn.ig:hover{ background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); }
.social-btn.tt:hover{ background:#000; }
.social-btn.gm:hover{ background:var(--blue); }

/* ===================== FAQ ===================== */
.faq{ max-width:880px; margin-inline:auto; }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{ width:100%; display:flex; justify-content:space-between; align-items:center; gap:1rem; text-align:left; padding:1.3rem 0; font-weight:700; font-size:clamp(1.02rem,1.5vw,1.18rem); }
.faq-q .ic{ flex:none; width:30px; height:30px; border-radius:50%; border:2px solid var(--line); display:grid; place-items:center; transition:.3s var(--ease); position:relative; }
.faq-q .ic::before,.faq-q .ic::after{ content:""; position:absolute; background:var(--red); border-radius:2px; }
.faq-q .ic::before{ width:12px; height:2px; } .faq-q .ic::after{ width:2px; height:12px; transition:transform .3s var(--ease); }
.faq-item.open .faq-q .ic{ background:var(--red); border-color:var(--red); }
.faq-item.open .faq-q .ic::before,.faq-item.open .faq-q .ic::after{ background:#111; }
.faq-item.open .faq-q .ic::after{ transform:rotate(90deg) scaleX(0); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .4s var(--ease); }
.faq-a p{ padding-bottom:1.3rem; color:var(--ink-2); max-width:70ch; }

/* ===================== BLOG ===================== */
.blog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.6vw,30px); }
.post-card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; display:flex; flex-direction:column; transition:transform .45s var(--ease-out), box-shadow .45s; }
.post-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow); }
.post-card__img{ aspect-ratio:16/10; overflow:hidden; background:var(--navy-3); }
.post-card__img img{ width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); }
.post-card:hover .post-card__img img{ transform:scale(1.07); }
.post-card__body{ padding:1.5rem 1.5rem 1.7rem; display:flex; flex-direction:column; gap:.7rem; flex:1; }
.post-card__tag{ font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:var(--red); font-weight:700; }
.post-card h3{ font-family:var(--ff-body); font-weight:800; text-transform:none; font-size:1.2rem; line-height:1.25; letter-spacing:0; }
.post-card p{ font-size:.92rem; color:var(--ink-2); }
.post-card .more{ margin-top:auto; font-weight:700; color:var(--blue-deep); display:inline-flex; gap:.4em; align-items:center; }
.post-card:hover .more{ gap:.7em; }

/* ===================== FOOTER ===================== */
.footer{ background:var(--navy-2); color:rgba(245,239,227,.78); padding-block:clamp(48px,6vw,80px) 2rem; }
.footer__top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:clamp(28px,4vw,56px); }
.footer .brand .b-sub{ color:#fff; }
.footer h4{ font-family:var(--ff-body); font-weight:800; text-transform:uppercase; letter-spacing:.08em; font-size:.84rem; color:#fff; margin-bottom:1.1rem; }
.footer a:hover{ color:#fff; }
.footer ul{ display:flex; flex-direction:column; gap:.6rem; font-size:.92rem; }
.footer .fcontact li{ display:flex; gap:.6em; align-items:flex-start; margin-bottom:.6rem; font-size:.92rem; }
.footer .fcontact svg{ width:1.05em; height:1.05em; color:var(--blue-bright); flex:none; margin-top:.2em; }
.footer .fsocial{ display:flex; gap:.6rem; margin-top:1rem; }
.footer .fsocial a{ width:42px; height:42px; border-radius:50%; border:1px solid var(--navy-line); display:grid; place-items:center; transition:.3s; }
.footer .fsocial a:hover{ background:var(--blue); border-color:var(--blue); color:#fff; transform:translateY(-3px); }
.footer .fsocial svg{ width:1.15em; height:1.15em; }
.footer__bottom{ display:flex; flex-wrap:wrap; gap:1rem; justify-content:space-between; align-items:center; margin-top:clamp(34px,4vw,56px); padding-top:1.6rem; border-top:1px solid var(--navy-line); font-size:.8rem; }
.footer__bottom a{ color:var(--blue-bright); }

/* ===================== CHATBOT ===================== */
.cb-fab{ position:fixed; right:20px; bottom:20px; z-index:90; width:62px; height:62px; border-radius:50%; background:var(--red); color:#0e0e0e; display:grid; place-items:center; box-shadow:var(--shadow-red),0 0 0 0 var(--red-glow); transition:transform .35s var(--ease-out), background .25s; animation:fabpulse 3s var(--ease) infinite; }
@keyframes fabpulse{ 0%,100%{ box-shadow:0 14px 30px -10px var(--red-glow),0 0 0 0 rgba(255,255,255,.4);} 50%{ box-shadow:0 14px 30px -10px var(--red-glow),0 0 0 12px rgba(255,255,255,0);} }
.cb-fab:hover{ transform:scale(1.07) rotate(-4deg); background:var(--red-deep); }
.cb-fab svg{ width:28px; height:28px; }
.cb-fab .x{ display:none; }
.cb-fab.open .chat{ display:none; } .cb-fab.open .x{ display:block; }
.cb-badge{ position:absolute; top:-3px; right:-3px; width:20px; height:20px; border-radius:50%; background:var(--blue); color:#fff; font-size:.66rem; font-weight:800; display:grid; place-items:center; border:2px solid var(--cream); }

.cb-panel{ position:fixed; right:20px; bottom:94px; z-index:90; width:min(380px,calc(100vw - 32px)); height:min(560px,calc(100vh - 130px)); background:var(--paper); border-radius:var(--r-lg); box-shadow:var(--shadow-lg); display:flex; flex-direction:column; overflow:hidden; transform:translateY(20px) scale(.96); opacity:0; visibility:hidden; transform-origin:bottom right; transition:.35s var(--ease-out); border:1px solid var(--line); }
.cb-panel.open{ transform:none; opacity:1; visibility:visible; }
.cb-head{ background:var(--navy); color:#fff; padding:1rem 1.2rem; display:flex; align-items:center; gap:.8rem; }
.cb-head .av{ width:40px; height:40px; border-radius:50%; background:var(--red); color:#0e0e0e; display:grid; place-items:center; font-family:var(--ff-script); font-size:1.2rem; flex:none; }
.cb-head .t b{ display:block; font-size:.98rem; } .cb-head .t small{ display:flex; align-items:center; gap:.4em; opacity:.8; font-size:.74rem; }
.cb-head .t small::before{ content:""; width:7px; height:7px; border-radius:50%; background:#3ad07a; }
.cb-body{ flex:1; overflow-y:auto; padding:1.1rem; display:flex; flex-direction:column; gap:.7rem; background:linear-gradient(180deg,var(--cream),var(--paper)); }
.cb-msg{ max-width:84%; padding:.7rem .95rem; border-radius:16px; font-size:.92rem; line-height:1.45; animation:msgin .3s var(--ease-out); }
@keyframes msgin{ from{opacity:0;transform:translateY(8px)} to{opacity:1} }
.cb-msg.bot{ background:var(--navy-3); border:1px solid var(--line); border-bottom-left-radius:5px; align-self:flex-start; }
.cb-msg.user{ background:var(--navy); color:#fff; border-bottom-right-radius:5px; align-self:flex-end; }
.cb-msg a{ color:var(--blue-deep); font-weight:700; text-decoration:underline; }
.cb-msg.user a{ color:#fff; }
.cb-chips{ display:flex; flex-wrap:wrap; gap:.45rem; padding:.3rem 1.1rem .2rem; }
.cb-chip{ font-size:.8rem; font-weight:600; padding:.5em .9em; border-radius:var(--r-pill); border:1.4px solid var(--line); background:var(--paper); transition:.2s; }
.cb-chip:hover{ background:var(--navy); color:#fff; border-color:var(--navy); }
.cb-foot{ display:flex; gap:.5rem; padding:.8rem; border-top:1px solid var(--line); background:var(--paper); }
.cb-foot input{ flex:1; border:1.5px solid var(--line); border-radius:var(--r-pill); padding:.7em 1em; }
.cb-foot input:focus{ outline:none; border-color:var(--blue); }
.cb-foot button{ width:44px; height:44px; border-radius:50%; background:var(--red); color:#0e0e0e; display:grid; place-items:center; flex:none; transition:.2s; }
.cb-foot button:hover{ background:var(--red-deep); transform:scale(1.05); }
.cb-foot button svg{ width:18px; height:18px; }
.typing{ display:inline-flex; gap:4px; padding:.3rem 0; }
.typing i{ width:7px; height:7px; border-radius:50%; background:var(--ink-soft); animation:typing 1.2s infinite; }
.typing i:nth-child(2){ animation-delay:.2s; } .typing i:nth-child(3){ animation-delay:.4s; }
@keyframes typing{ 0%,60%,100%{ transform:translateY(0); opacity:.4 } 30%{ transform:translateY(-5px); opacity:1 } }

/* ===================== STICKY MOBILE BOOK BAR ===================== */
.mbar{ position:fixed; left:0; right:0; bottom:0; z-index:55; display:none; gap:.6rem; padding:.7rem .9rem calc(.7rem + env(safe-area-inset-bottom)); background:rgba(14,14,16,.96); backdrop-filter:blur(12px); border-top:1px solid var(--line); box-shadow:0 -10px 30px -20px rgba(12,26,43,.5); }
.mbar .btn{ flex:1; }
.mbar .btn--ghost{ flex:none; }

/* ===================== REVEAL / MOTION ===================== */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease-out), transform .8s var(--ease-out); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s } .reveal.d2{ transition-delay:.16s } .reveal.d3{ transition-delay:.24s } .reveal.d4{ transition-delay:.32s }
.reveal-x{ opacity:0; transform:translateX(-30px); transition:opacity .8s var(--ease-out), transform .8s var(--ease-out); }
.reveal-x.in{ opacity:1; transform:none; }
.reveal-scale{ opacity:0; transform:scale(.94); transition:opacity .7s var(--ease-out), transform .7s var(--ease-out); }
.reveal-scale.in{ opacity:1; transform:none; }

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
  .reveal,.reveal-x,.reveal-scale{ opacity:1 !important; transform:none !important; }
  .hero__media img{ animation:none !important; transform:scale(1.0); }
  .cb-fab{ animation:none !important; }
}

/* ===================== RESPONSIVE ===================== */
@media (max-width:1040px){
  .book-wrap{ grid-template-columns:1fr; }
  .loc-grid{ grid-template-columns:1fr; }
  .footer__top{ grid-template-columns:1fr 1fr; gap:36px; }
  .gallery{ grid-auto-rows:170px; }
}
@media (max-width:880px){
  .nav-links,.nav-phone{ display:none; }
  .burger{ display:flex; }
  .svc-grid{ grid-template-columns:1fr; max-width:460px; margin-inline:auto; }
  .reviews{ grid-template-columns:1fr; max-width:520px; margin-inline:auto; }
  .blog-grid{ grid-template-columns:1fr; max-width:460px; margin-inline:auto; }
  .stats{ grid-template-columns:repeat(3,1fr); gap:18px; }
  .mbar{ display:flex; }
  body{ padding-bottom:74px; }
  .cb-fab{ bottom:84px; } .cb-panel{ bottom:158px; height:min(520px,calc(100vh - 196px)); }
}
@media (max-width:620px){
  .nav .nav-actions > .btn--red{ display:none; }
  .nav .wrap{ gap:.7rem; }
  .gallery{ grid-template-columns:repeat(2,1fr); grid-auto-rows:150px; }
  .gal-wide{ grid-column:span 2; } .gal-tall{ grid-row:span 1; }
  .svc-pick{ grid-template-columns:1fr; }
  .svc-pick .card{ flex-direction:row; justify-content:space-between; align-items:center; text-align:left; }
  .two{ grid-template-columns:1fr; }
  .hero__trust{ gap:1rem 1.4rem; }
  .footer__top{ grid-template-columns:1fr; gap:30px; }
  .topbar .wrap{ gap:.8em; }
}
@media (max-width:420px){
  .hero h1{ font-size:clamp(2.7rem,13vw,3.4rem); }
  .stats{ grid-template-columns:1fr; text-align:center; }
  .stat{ display:flex; align-items:baseline; gap:.6rem; justify-content:center; }
}

/* large screens / TV */
@media (min-width:1700px){
  :root{ --maxw:1480px; }
  body{ font-size:18px; }
  .gallery{ grid-auto-rows:240px; }
}

/* print-ish / no-js fallback */
.no-js .reveal,.no-js .reveal-x,.no-js .reveal-scale{ opacity:1; transform:none; }

/* ===================== UTILITIES ===================== */
html{ scroll-padding-top:92px; }
.sr-only{ position:absolute!important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* ===================== ARTICLE / BLOG ===================== */
.mini-nav{ position:sticky; top:0; z-index:50; background:rgba(14,14,16,.92); backdrop-filter:blur(14px) saturate(1.3); -webkit-backdrop-filter:blur(14px); border-bottom:1px solid var(--line-2); }
.mini-nav .wrap{ display:flex; align-items:center; gap:1rem; padding-block:.8rem; }
.mini-nav .brand{ margin-right:auto; }
.mini-nav .back{ font-weight:600; color:var(--ink-2); display:inline-flex; align-items:center; gap:.4em; }
.mini-nav .back:hover{ color:var(--red); }

.article{ padding-block:clamp(28px,5vw,56px) clamp(48px,7vw,90px); }
.article__head{ max-width:760px; margin-inline:auto; text-align:center; }
.article__tag{ font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--red); font-weight:700; }
.article__head h1{ font-family:var(--ff-disp); font-size:clamp(2.2rem,5.5vw,4rem); line-height:1; margin:.4em 0 .3em; text-transform:uppercase; }
.article__meta{ color:var(--ink-soft); font-size:.9rem; display:flex; gap:1em; justify-content:center; flex-wrap:wrap; }
.article__hero{ border-radius:var(--r-lg); overflow:hidden; margin:clamp(28px,4vw,48px) auto; max-width:980px; aspect-ratio:16/8; box-shadow:var(--shadow); }
.article__hero img{ width:100%; height:100%; object-fit:cover; }
.prose{ max-width:720px; margin-inline:auto; font-size:1.08rem; line-height:1.78; color:var(--ink-2); }
.prose > p:first-of-type{ font-size:1.2rem; color:var(--ink); }
.prose h2{ font-family:var(--ff-disp); text-transform:uppercase; font-size:clamp(1.5rem,3vw,2rem); line-height:1.05; color:var(--ink); margin:2.2rem 0 .9rem; letter-spacing:.01em; }
.prose h3{ font-weight:800; font-size:1.2rem; margin:1.6rem 0 .6rem; color:var(--ink); }
.prose p,.prose ul,.prose ol{ margin-bottom:1.2rem; }
.prose ul,.prose ol{ padding-left:1.3rem; } .prose li{ margin-bottom:.5rem; } .prose ul{ list-style:disc; } .prose ol{ list-style:decimal; }
.prose a{ color:var(--blue-deep); text-decoration:underline; font-weight:600; }
.prose strong{ color:var(--ink); }
.prose blockquote{ border-left:4px solid var(--red); padding:.4rem 0 .4rem 1.2rem; margin:1.6rem 0; font-style:italic; color:var(--ink); font-size:1.15rem; }
.prose figure{ margin:2rem 0; } .prose figure img{ border-radius:var(--r); box-shadow:var(--shadow-sm); }
.cta-band{ margin-top:clamp(40px,6vw,72px); }
.cta-band .inner{ background:var(--navy); color:#fff; border-radius:var(--r-lg); padding:clamp(30px,5vw,56px); text-align:center; max-width:820px; margin-inline:auto; }
.cta-band h2{ font-family:var(--ff-disp); text-transform:uppercase; font-size:clamp(1.8rem,4vw,2.8rem); line-height:1; margin-bottom:.6rem; }
.cta-band h2 .accent{ color:var(--blue-bright); }
.cta-band p{ color:rgba(245,239,227,.82); margin-bottom:1.4rem; }
.post-nav{ max-width:720px; margin:2.4rem auto 0; display:flex; justify-content:space-between; gap:1rem; font-weight:700; }
.post-nav a{ color:var(--blue-deep); }
@media (max-width:560px){ .article__hero{ aspect-ratio:4/3; } }

/* ===================== BOOKING POPUP (modal) ===================== */
.modal{ position:fixed; inset:0; z-index:120; display:grid; place-items:center; padding:22px; opacity:0; visibility:hidden; transition:opacity .3s var(--ease); }
.modal.open{ opacity:1; visibility:visible; }
.modal__scrim{ position:absolute; inset:0; background:rgba(8,19,32,.72); backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px); }
.modal__dialog{ position:relative; width:100%; max-width:540px; transform:translateY(18px) scale(.97); transition:transform .4s var(--ease-out); }
.modal.open .modal__dialog{ transform:none; }
.modal .booking{ max-height:90vh; overflow:auto; box-shadow:var(--shadow-lg); }
.modal__close{ position:absolute; top:-14px; right:-14px; z-index:3; width:42px; height:42px; border-radius:50%; background:var(--red); color:#0e0e0e; display:grid; place-items:center; box-shadow:var(--shadow); transition:transform .25s var(--ease-out), background .2s; }
.modal__close:hover{ background:var(--red-deep); transform:rotate(90deg) scale(1.05); }
.modal__close svg{ width:18px; height:18px; }
@media (max-width:560px){ .modal{ padding:14px; } .modal__close{ top:-10px; right:-2px; } }
@media (prefers-reduced-motion: reduce){ .modal__dialog{ transform:none; } .modal{ transition:none; } }

/* ===================== COMPACT BOOKING POPUP (fit-on-screen) ===================== */
.modal{ padding:14px; }
.modal__dialog{ max-width:432px; }
.modal .booking{ padding:clamp(15px,3vw,20px); max-height:94vh; }
.modal .booking__head{ margin-bottom:.55rem; }
.modal .booking__head h3{ font-size:1.18rem; }
.modal .field{ margin-bottom:.55rem; }
.modal .field > label{ margin-bottom:.3rem; font-size:.7rem; }
.modal .svc-pick{ gap:.38rem; }
.modal .svc-pick .card{ padding:.42rem .4rem; }
.modal .svc-pick .card .t{ font-size:.74rem; }
.modal .svc-pick .card .p{ font-size:.98rem; }
.modal .cal{ padding:.45rem .5rem; }
.modal .cal__head{ margin-bottom:.35rem; }
.modal .cal__month{ font-size:.9rem; }
.modal .cal__nav{ width:28px; height:28px; font-size:1rem; border-radius:8px; }
.modal .cal__grid{ gap:2px; }
.modal .cal__dow{ margin-bottom:2px; }
.modal .cal__dow span{ font-size:.58rem; }
.modal .cal__cell{ aspect-ratio:auto; min-height:28px; padding:.28rem 0; font-size:.8rem; border-radius:8px; }
.modal .slots{ gap:.5rem; }
.modal .slot-group__label{ margin-bottom:.28rem; font-size:.64rem; }
.modal .slot-row{ gap:.38rem; grid-template-columns:repeat(auto-fill,minmax(70px,1fr)); }
.modal .slot{ padding:.46rem .3rem; font-size:.84rem; border-radius:9px; }
.modal .two{ gap:.5rem; }
.modal .input{ padding:.62em .8em; }
.modal .consent{ margin:.05rem 0 .5rem; font-size:.72rem; }
.modal #ts-holder:empty{ display:none; }
.modal .book-summary{ padding:.55rem .8rem; margin:.05rem 0 .55rem; }
.modal .book-summary .bs-when{ font-size:.98rem; }
.modal #bookBtn{ padding:.85em 1.6em; font-size:.92rem; }
@media (max-width:560px){ .modal{ padding:8px; } .modal .booking{ max-height:96vh; } }

/* ===================== FLOATING BOOK FAB (+ remove mobile book bar) ===================== */
.mbar{ display:none !important; }
@media (max-width:880px){
  body{ padding-bottom:0 !important; }
  .cb-fab{ bottom:20px !important; }
  .cb-panel{ bottom:94px !important; height:min(520px,calc(100vh - 130px)) !important; }
}
.book-fab{ position:fixed; right:20px; bottom:92px; z-index:80; width:62px; height:62px; border-radius:50%; background:var(--red); color:#0e0e0e; display:grid; place-items:center; box-shadow:var(--shadow-red); transition:transform .35s var(--ease-out), background .25s; animation:fabpulse 3s var(--ease) infinite; }
.book-fab:hover{ transform:scale(1.07) rotate(-4deg); }
.book-fab svg{ width:27px; height:27px; }
.book-fab .bk-badge{ position:absolute; top:-6px; left:-6px; background:var(--navy-2); color:#fff; font-size:.56rem; font-weight:800; letter-spacing:.06em; padding:.25em .5em; border-radius:999px; border:1px solid var(--navy-line); text-transform:uppercase; }
.cb-fab{ animation:none !important; }

/* gallery — 3 photos clean stacking on phone */
@media (max-width:620px){
  .gallery{ grid-template-columns:1fr; grid-auto-rows:210px; }
  .gallery .gal-item{ grid-column:auto !important; grid-row:auto !important; }
}
