/* ============================================================
   BARBERSHOP OTTAWA — moody luxury, near-black with real depth
   ============================================================ */

/* ---- Fonts: Big Shoulders (Leo's brand family) ---- */
@font-face{font-family:'BigShoulders';src:url('fonts/BigShoulders-Thin.ttf') format('truetype');font-weight:100;font-style:normal;font-display:swap;}
@font-face{font-family:'BigShoulders';src:url('fonts/BigShoulders-ExtraLight.ttf') format('truetype');font-weight:200;font-style:normal;font-display:swap;}
@font-face{font-family:'BigShoulders';src:url('fonts/BigShoulders-Light.ttf') format('truetype');font-weight:300;font-style:normal;font-display:swap;}
@font-face{font-family:'BigShoulders';src:url('fonts/BigShoulders-Regular.ttf') format('truetype');font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:'BigShoulders';src:url('fonts/BigShoulders-Medium.ttf') format('truetype');font-weight:500;font-style:normal;font-display:swap;}
@font-face{font-family:'BigShoulders';src:url('fonts/BigShoulders-Bold.ttf') format('truetype');font-weight:700;font-style:normal;font-display:swap;}
@font-face{font-family:'BigShoulders';src:url('fonts/BigShoulders-Black.ttf') format('truetype');font-weight:900;font-style:normal;font-display:swap;}

:root{
  --ink:#0A0A0A;
  --ink-2:#0d0d0d;
  --char:#151515;
  --char-2:#1b1b1b;
  --char-3:#232323;
  --line:rgba(255,255,255,.09);
  --line-strong:rgba(255,255,255,.16);
  --gold:#C9A24B;
  --gold-dim:rgba(201,162,75,.5);
  --white:#F4F2EC;
  --grey:#A8A6A0;
  --grey-dim:#777570;
  --grey-faint:#4a4845;
  --maxw:1240px;
  --pad:clamp(20px,5vw,64px);
  --sec-y:clamp(84px,13vw,170px);
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  font-family:'BigShoulders',system-ui,sans-serif;
  background:var(--ink);
  color:var(--white);
  font-weight:300;
  line-height:1.5;
  letter-spacing:.01em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
::selection{background:var(--gold);color:#0a0a0a;}

/* ---- Global grain + vignette overlays (depth, never flat black) ---- */
.grain{
  position:fixed;inset:0;z-index:9000;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.55'/%3E%3C/svg%3E");
  opacity:.07;mix-blend-mode:overlay;
}
.vignette{
  position:fixed;inset:0;z-index:8999;pointer-events:none;
  background:radial-gradient(120% 90% at 50% 8%,transparent 38%,rgba(0,0,0,.6) 100%);
}
.backdrop{position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(95% 60% at 50% 0%,rgba(255,255,255,.06),transparent 55%),
    radial-gradient(70% 55% at 85% 88%,rgba(201,162,75,.045),transparent 60%),
    #0a0a0a;}
.backdrop::after{content:"";position:absolute;inset:0;background:url('assets/silk.png') center/cover no-repeat;opacity:.16;mix-blend-mode:screen;}
.hero,.section,.footer{position:relative;z-index:1;}

/* ---- Layout helpers ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad);}
.section{position:relative;padding-top:var(--sec-y);padding-bottom:var(--sec-y);}
.hairline{height:1px;border:0;background:linear-gradient(90deg,transparent,var(--line-strong) 18%,var(--line-strong) 82%,transparent);}
.gold-rule{height:1px;border:0;background:linear-gradient(90deg,transparent,var(--gold-dim) 30%,var(--gold) 50%,var(--gold-dim) 70%,transparent);}

/* eyebrow = bilingual paired label (echoes the brand banner: LOCATION/UBICACION) */
.eyebrow{
  font-weight:500;font-size:clamp(11px,1.3vw,13px);
  letter-spacing:.42em;text-transform:uppercase;color:var(--grey);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold);display:inline-block;}
.eyebrow .sl{color:var(--gold);font-weight:400;}

.kicker-num{
  font-weight:200;font-variant-numeric:tabular-nums;
  color:transparent;-webkit-text-stroke:1px var(--grey-faint);
  font-size:clamp(70px,16vw,180px);line-height:.8;letter-spacing:-.02em;
}

h1,h2,h3{font-weight:900;text-transform:uppercase;line-height:.92;letter-spacing:-.005em;}
.display{font-size:clamp(54px,12vw,150px);}
.h2{font-size:clamp(40px,7.5vw,92px);}
.h3{font-size:clamp(26px,3.6vw,40px);}
.lead{font-weight:300;font-size:clamp(18px,2.3vw,25px);line-height:1.55;color:var(--grey);max-width:60ch;}
.lead strong{color:var(--white);font-weight:500;}
p.body{font-weight:300;color:var(--grey);font-size:clamp(16px,1.7vw,18.5px);line-height:1.6;}

/* ============================================================
   TOP BAR  (transparent over hero → solid sticky on scroll)
   ============================================================ */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:7000;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--pad);
  transition:background .4s ease,backdrop-filter .4s ease,padding .4s ease,border-color .4s ease;
  border-bottom:1px solid transparent;
}
.topbar.solid{
  background:rgba(10,10,10,.82);backdrop-filter:blur(14px) saturate(120%);
  border-bottom:1px solid var(--line);padding-top:13px;padding-bottom:13px;
}
.topbar .tb-logo{height:26px;opacity:0;transform:translateY(-6px);transition:opacity .4s,transform .4s;pointer-events:none;}
.topbar.solid .tb-logo{opacity:1;transform:none;pointer-events:auto;}
.topbar-right{display:flex;align-items:center;gap:14px;}

/* Language toggle */
.lang{
  display:inline-flex;align-items:center;border:1px solid var(--line-strong);
  border-radius:999px;overflow:hidden;font-weight:600;font-size:13px;letter-spacing:.12em;
  background:rgba(0,0,0,.25);backdrop-filter:blur(6px);
}
.lang button{padding:8px 15px;color:var(--grey-dim);transition:color .25s,background .25s;letter-spacing:.12em;}
.lang button.active{color:#0a0a0a;background:var(--white);}
.lang .sep{width:1px;align-self:stretch;background:var(--line);}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.7em;
  font-weight:700;text-transform:uppercase;letter-spacing:.14em;
  font-size:clamp(14px,1.5vw,15px);line-height:1;
  padding:18px 34px;border-radius:2px;transition:transform .25s,box-shadow .35s,background .3s,color .3s;
  white-space:nowrap;
}
.btn .arr{transition:transform .3s;}
.btn:hover .arr{transform:translateX(5px);}
.btn-gold{
  background:var(--gold);color:#0a0a0a;
  box-shadow:0 0 0 1px rgba(201,162,75,.4),0 18px 50px -20px rgba(201,162,75,.65);
}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 0 0 1px rgba(201,162,75,.6),0 26px 70px -22px rgba(201,162,75,.85);}
.btn-ghost{border:1px solid var(--line-strong);color:var(--white);}
.btn-ghost:hover{border-color:var(--white);background:rgba(255,255,255,.04);}
.btn-sm{padding:13px 22px;font-size:13px;}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;overflow:hidden;}
.hero-media{position:absolute;inset:0;z-index:0;}
.hero-slides{position:absolute;inset:0;z-index:0;transition:opacity 1s ease;}
.hero-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 28%;opacity:0;animation:heroCycle 24s infinite;filter:contrast(1.07) brightness(.8) grayscale(.12);}
.hero-slide:nth-child(1){animation-delay:0s;}
.hero-slide:nth-child(2){animation-delay:8s;}
.hero-slide:nth-child(3){animation-delay:16s;}
@keyframes heroCycle{0%{opacity:0;transform:scale(1.05);}4%{opacity:1;}40%{opacity:1;}46%{opacity:0;}100%{opacity:0;transform:scale(1.17);}}
@media (prefers-reduced-motion:reduce){.hero-slide{animation:none;}.hero-slide:nth-child(1){opacity:1;}}
/* Drop a real <video> inside .hero-media to replace the silk poster. */
.hero-media .poster{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  animation:kenburns 26s ease-in-out infinite alternate;
  filter:contrast(1.05) brightness(.92);
}
.hero-media video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 42%;filter:contrast(1.06) brightness(.82) saturate(1);animation:kenburns 26s ease-in-out infinite alternate;z-index:1;opacity:0;transition:opacity .9s ease;}
.hero-video.playing{opacity:1;}
@keyframes kenburns{from{transform:scale(1.01) translate(0,0);}to{transform:scale(1.06) translate(-1%,-1%);}}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(90deg,rgba(10,10,10,.92) 0%,rgba(10,10,10,.6) 38%,rgba(10,10,10,.22) 66%,rgba(10,10,10,.5) 100%),
    linear-gradient(180deg,rgba(10,10,10,.5) 0%,rgba(10,10,10,.1) 36%,rgba(10,10,10,.62) 74%,var(--ink) 100%);
}
.hero-overlay::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 50% 50%,transparent 45%,rgba(0,0,0,.6));}
.hero-inner{position:relative;z-index:2;width:100%;flex:1;display:flex;flex-direction:column;justify-content:center;padding-top:clamp(96px,14vh,150px);padding-bottom:22px;}
.hero-enter{opacity:0;transform:translateY(22px);animation:heroUp 1s cubic-bezier(.2,.7,.2,1) forwards;}
.hero-enter.d1{animation-delay:.12s;}
.hero-enter.d2{animation-delay:.24s;}
.hero-enter.d3{animation-delay:.36s;}
@keyframes heroUp{to{opacity:1;transform:none;}}
@media (prefers-reduced-motion:reduce){.hero-enter{opacity:1;transform:none;animation:none;}}
.hero-logo{width:min(560px,74vw);margin-bottom:clamp(26px,5vw,46px);filter:drop-shadow(0 8px 30px rgba(0,0,0,.6));}
.hero h1{margin:0;}
.hero h1 .alt{display:block;font-weight:300;color:var(--grey);-webkit-text-stroke:0;font-size:.42em;letter-spacing:.005em;margin-top:.28em;}
.hero-sub{margin-top:clamp(22px,3vw,30px);max-width:46ch;}
.hero-cta{margin-top:clamp(30px,4vw,42px);display:flex;flex-wrap:wrap;gap:16px;align-items:center;}
.hero-meta{
  position:relative;z-index:2;padding:0 var(--pad) 26px;
  display:flex;justify-content:space-between;align-items:flex-end;gap:20px;
  font-weight:500;font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--grey-dim);
}
.hero-meta .gold{color:var(--gold);}
.scrollcue{display:inline-flex;align-items:center;gap:10px;}
.scrollcue .ln{width:46px;height:1px;background:var(--grey-dim);position:relative;overflow:hidden;}
.scrollcue .ln::after{content:"";position:absolute;inset:0;background:var(--gold);transform:translateX(-100%);animation:cue 2.6s ease-in-out infinite;}
@keyframes cue{0%{transform:translateX(-100%);}55%{transform:translateX(0);}100%{transform:translateX(100%);}}

/* ============================================================
   PITCH  /  PICK YOUR OWN ADVENTURE
   ============================================================ */
.pitch{background:transparent;}
.pitch-head{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,64px);align-items:end;}
.pitch-head .h2{max-width:14ch;}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:clamp(46px,6vw,72px);}
.card{
  position:relative;background:linear-gradient(170deg,var(--char-2),var(--char));
  border:1px solid var(--line);border-radius:4px;overflow:hidden;
  padding:clamp(26px,3vw,38px) clamp(24px,3vw,34px) clamp(30px,3.4vw,40px);
  min-height:330px;display:flex;flex-direction:column;
  transition:transform .4s cubic-bezier(.2,.7,.2,1),border-color .4s,box-shadow .4s;
}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,var(--gold),transparent 60%);opacity:.7;}
.card::after{content:"";position:absolute;inset:0;background:radial-gradient(80% 50% at 50% -10%,rgba(201,162,75,.10),transparent 60%);opacity:0;transition:opacity .4s;pointer-events:none;}
.card:hover{transform:translateY(-6px);border-color:var(--line-strong);box-shadow:0 40px 80px -50px rgba(0,0,0,.9);}
.card:hover::after{opacity:1;}
.card .num{font-weight:200;font-size:clamp(40px,4.4vw,56px);color:var(--grey-faint);line-height:1;letter-spacing:-.02em;}
.card .glyph{margin:6px 0 auto;width:40px;height:40px;}
.card h3{margin-top:22px;font-size:clamp(24px,2.6vw,31px);}
.card p{margin-top:13px;color:var(--grey);font-weight:300;font-size:16.5px;line-height:1.55;}

/* ============================================================
   SERVICES
   ============================================================ */
.services{background:transparent;}
.svc-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(30px,5vw,70px);align-items:start;}
.svc-list{margin-top:6px;}
.svc-row{display:flex;align-items:baseline;gap:14px;padding:22px 0;border-bottom:1px solid var(--line);}
.svc-row:first-child{border-top:1px solid var(--line);}
.svc-name{font-weight:700;text-transform:uppercase;letter-spacing:.02em;font-size:clamp(20px,2.4vw,27px);color:var(--white);white-space:nowrap;}
.svc-sub{display:block;font-weight:300;text-transform:none;letter-spacing:.01em;font-size:14.5px;color:var(--grey-dim);margin-top:2px;}
.svc-leader{flex:1;align-self:flex-end;margin-bottom:7px;border-bottom:1px dotted var(--grey-faint);height:1px;min-width:24px;}
.svc-price{font-weight:500;font-size:clamp(22px,2.6vw,30px);font-variant-numeric:tabular-nums;color:var(--white);white-space:nowrap;}
.svc-price .cur{color:var(--gold);font-weight:400;font-size:.7em;vertical-align:top;margin-right:1px;}
.specialty{
  margin-top:26px;border:1px solid var(--gold-dim);border-radius:4px;
  padding:22px 24px;background:radial-gradient(120% 100% at 0% 0%,rgba(201,162,75,.10),transparent 55%);
  display:flex;gap:18px;align-items:flex-start;
}
.specialty .tag{font-weight:700;font-size:11px;letter-spacing:.28em;color:var(--gold);text-transform:uppercase;border:1px solid var(--gold-dim);padding:6px 10px;border-radius:2px;white-space:nowrap;margin-top:3px;}
.specialty h4{font-weight:900;text-transform:uppercase;font-size:22px;letter-spacing:0;}
.specialty p{color:var(--grey);font-weight:300;font-size:15.5px;margin-top:5px;}
.svc-aside .body{margin-top:18px;}
.svc-consult{margin-top:22px;padding-top:22px;border-top:1px solid var(--line);}
.svc-consult .sc-tag{display:inline-flex;align-items:center;gap:.6em;font-weight:600;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:12px;}
.svc-consult .sc-tag .sl{color:var(--grey-dim);font-weight:400;}
.svc-consult p{font-weight:300;color:var(--grey);font-size:16px;line-height:1.55;max-width:60ch;}
.svc-consult p strong{color:var(--white);font-weight:500;}
.svc-note{margin-top:26px;font-weight:300;font-size:14.5px;color:var(--grey-dim);letter-spacing:.02em;}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{background:transparent;}
.gal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:clamp(40px,5vw,60px);}
.shot{position:relative;overflow:hidden;border-radius:3px;border:1px solid var(--line);background:var(--char);aspect-ratio:3/4;}
.shot .ph{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:16px;
  background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.022) 0 12px,transparent 12px 24px);
  transition:transform .6s cubic-bezier(.2,.7,.2,1);}
.shot:hover .ph{transform:scale(1.07);}
.shot .ph::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 50% 30%,rgba(40,40,40,.4),transparent 70%);}
.shot .lbl{position:relative;font-family:ui-monospace,'SF Mono',Menlo,monospace;font-size:11px;letter-spacing:.12em;color:var(--grey-dim);text-transform:uppercase;}
.shot .lbl b{display:block;color:var(--grey);font-weight:600;margin-bottom:2px;}
.shot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 26%;transition:transform .6s cubic-bezier(.2,.7,.2,1);}
.shot:hover img{transform:scale(1.07);}
/* uniform portrait tiles — photos stay centered */
.gal-cap{margin-top:18px;font-family:ui-monospace,monospace;font-size:12px;color:var(--grey-faint);letter-spacing:.06em;}

/* ============================================================
   BOOKING
   ============================================================ */
.booking{background:transparent;}
.book-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(34px,5vw,72px);align-items:start;}
.book-left .lead{margin-top:20px;}
.policy{margin-top:34px;border:1px solid var(--line);border-radius:4px;background:linear-gradient(170deg,var(--char),var(--ink-2));padding:24px 26px;}
.policy h4{font-weight:700;text-transform:uppercase;letter-spacing:.16em;font-size:13px;color:var(--gold);margin-bottom:14px;display:flex;align-items:center;gap:9px;}
.policy h4::before{content:"";width:16px;height:1px;background:var(--gold);}
.policy-now{margin:0 0 16px;padding:12px 15px;border:1px solid var(--gold-dim);border-radius:3px;background:radial-gradient(130% 100% at 0% 0%,rgba(201,162,75,.13),transparent 60%);color:var(--white);font-weight:300;font-size:15px;line-height:1.4;letter-spacing:.01em;}
.policy-now b{color:var(--gold);font-weight:600;}
.policy li.dim{opacity:.42;}
.policy li.active b{color:var(--gold);}
.policy li.active::before{background:var(--gold);}
.policy ul{list-style:none;display:flex;flex-direction:column;gap:11px;}
.policy li{display:flex;gap:12px;font-weight:300;font-size:14.5px;color:var(--grey);line-height:1.45;}
.policy li::before{content:"";flex:none;width:5px;height:5px;margin-top:8px;background:var(--grey-faint);transform:rotate(45deg);}
.policy li b{color:var(--white);font-weight:600;}

/* form */
.form{background:linear-gradient(170deg,var(--char-2),var(--char));border:1px solid var(--line);border-radius:5px;padding:clamp(24px,3.2vw,40px);position:relative;overflow:hidden;}
.form::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold-dim),transparent);}
.field{margin-bottom:18px;}
.field.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:18px;}
.field.row2 .field{margin-bottom:0;}
label{display:block;font-weight:600;text-transform:uppercase;letter-spacing:.16em;font-size:11px;color:var(--grey);margin-bottom:9px;}
label .opt{color:var(--grey-faint);font-weight:400;letter-spacing:.08em;}
.inp{
  width:100%;background:var(--ink);border:1px solid var(--line-strong);border-radius:3px;
  color:var(--white);font-family:inherit;font-weight:300;font-size:16px;letter-spacing:.01em;
  padding:14px 15px;min-height:54px;transition:border-color .25s,box-shadow .25s,background .25s;
}
/* Date & time fields: bigger, clearly tappable targets */
.inp-date,select.time-select{min-height:58px;font-size:17px;cursor:pointer;}
.inp-date{padding-right:14px;}
.inp-date::-webkit-calendar-picker-indicator{width:26px;height:26px;cursor:pointer;opacity:.65;filter:invert(.8);margin-left:4px;}
.inp-date::-webkit-calendar-picker-indicator:hover{opacity:1;}
textarea.inp{resize:vertical;min-height:92px;line-height:1.5;}
.inp::placeholder{color:var(--grey-faint);}
.inp:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,75,.12);background:#0c0c0c;}
select.inp{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath d='M3 5l4 4 4-4' stroke='%23A8A6A0' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 15px center;padding-right:38px;}
select.time-select{background-size:16px;background-position:right 16px center;}
.inp.invalid{border-color:#a8453b;box-shadow:0 0 0 3px rgba(168,69,59,.14);}
.form-note{display:flex;gap:11px;align-items:flex-start;margin:6px 0 20px;color:var(--grey);font-weight:300;font-size:14.5px;line-height:1.45;}
.form-note .dot{flex:none;width:7px;height:7px;margin-top:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(201,162,75,.14);}
.form-actions{display:flex;flex-direction:column;gap:12px;}
.form-actions .btn{width:100%;}
.or{text-align:center;font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:var(--grey-faint);font-weight:500;}
.btn-wa{border:1px solid var(--line-strong);color:var(--white);}
.btn-wa:hover{border-color:#25D366;color:#25D366;background:rgba(37,211,102,.05);}
.btn-wa svg{width:18px;height:18px;}

/* confirmation state */
.confirm{display:none;text-align:center;padding:clamp(30px,5vw,60px) 10px;}
.confirm.show{display:block;animation:fade .6s ease both;}
.form.sent .form-body{display:none;}
@keyframes fade{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:none;}}
.confirm .mark{width:64px;height:64px;margin:0 auto 22px;border:1px solid var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle,rgba(201,162,75,.12),transparent);}
.confirm .mark svg{width:30px;height:30px;}
.confirm h3{font-size:clamp(28px,4vw,40px);}
.confirm p{color:var(--grey);font-weight:300;margin-top:14px;font-size:17px;max-width:40ch;margin-left:auto;margin-right:auto;}

/* ============================================================
   HOURS + LOCATION
   ============================================================ */
.visit{background:transparent;}
.visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,64px);align-items:stretch;}
.panel{border:1px solid var(--line);border-radius:4px;background:linear-gradient(170deg,var(--char),var(--ink-2));padding:clamp(28px,3.4vw,42px);display:flex;flex-direction:column;}
.panel .eyebrow{margin-bottom:22px;}
.hours-row{display:flex;justify-content:space-between;align-items:baseline;padding:15px 0;border-bottom:1px solid var(--line);}
.hours-row:last-child{border-bottom:0;}
.hours-row .d{font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:17px;}
.hours-row .t{font-weight:300;color:var(--grey);font-size:16px;letter-spacing:.02em;}
.byappt{margin-top:auto;padding-top:24px;}
.byappt .big{font-weight:900;text-transform:uppercase;font-size:clamp(26px,3.4vw,38px);line-height:.95;}
.byappt .big .gold{color:var(--gold);}
.byappt p{margin-top:12px;}
.map{position:relative;border:1px solid var(--line);border-radius:4px;overflow:hidden;min-height:300px;flex:1;background:
  radial-gradient(60% 60% at 30% 30%,rgba(40,40,40,.5),transparent 60%),var(--char);
  display:flex;align-items:flex-end;}
.map-embed{position:absolute;inset:0;width:100%;height:100%;border:0;filter:invert(.92) hue-rotate(180deg) saturate(.7) brightness(.92) contrast(1.04);}
.map .streets{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:44px 44px;opacity:.5;mask-image:radial-gradient(78% 78% at 50% 44%,#000,transparent);-webkit-mask-image:radial-gradient(78% 78% at 50% 44%,#000,transparent);}
.map .road{position:absolute;background:rgba(255,255,255,.05);box-shadow:inset 0 0 0 1px rgba(255,255,255,.04);}
.map .road.h{left:-10%;right:-10%;top:44%;height:20px;}
.map .road.v{top:-10%;bottom:-10%;left:50%;width:20px;transform:translateX(-50%);}
.map .road.d{top:-20%;bottom:-20%;left:22%;width:13px;transform:rotate(28deg);transform-origin:center;background:rgba(255,255,255,.04);}
.map .map-chip{position:absolute;top:calc(44% - 46px);left:50%;transform:translateX(-50%);font-weight:600;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--white);background:rgba(10,10,10,.7);border:1px solid var(--line-strong);padding:6px 11px;border-radius:2px;white-space:nowrap;backdrop-filter:blur(4px);pointer-events:none;}
.map .pin{position:absolute;top:44%;left:50%;transform:translate(-50%,-50%);pointer-events:none;}
.map .pin .dot{position:absolute;top:50%;left:50%;width:9px;height:9px;border-radius:50%;background:var(--gold);transform:translate(-50%,-50%);box-shadow:0 0 12px 2px rgba(201,162,75,.6);}
.map .pin .ring{width:18px;height:18px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 0 rgba(201,162,75,.5);animation:pulse 2.6s ease-out infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(201,162,75,.5);}100%{box-shadow:0 0 0 34px rgba(201,162,75,0);}}
.map .grid-lines{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:46px 46px;opacity:.5;mask-image:radial-gradient(70% 70% at 50% 50%,#000,transparent);}
.map .addr{position:relative;padding:18px 20px;background:linear-gradient(0deg,rgba(10,10,10,.95),rgba(10,10,10,.78) 55%,transparent);width:100%;pointer-events:none;}
.map .addr .dir{pointer-events:auto;display:inline-flex;align-items:center;gap:.6em;margin-top:12px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:12px;color:var(--gold);border:1px solid var(--gold-dim);padding:10px 16px;border-radius:2px;transition:background .25s,color .25s;}
.map .addr .dir:hover{background:var(--gold);color:#0a0a0a;}
.map .addr b{display:block;font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:18px;}
.map .addr span{font-weight:300;color:var(--grey);font-size:14px;}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{position:relative;background:transparent;overflow:hidden;}
.footer .silkbg{position:absolute;inset:0;object-fit:cover;width:100%;height:100%;opacity:.10;filter:contrast(1.1);mask-image:linear-gradient(180deg,transparent,#000 30%);-webkit-mask-image:linear-gradient(180deg,transparent,#000 30%);}
.footer::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent,transparent 55%,rgba(0,0,0,.35));}
.footer-inner{position:relative;z-index:2;padding-top:clamp(80px,11vw,140px);padding-bottom:46px;text-align:center;}
.footer .cta-h{font-weight:900;text-transform:uppercase;font-size:clamp(40px,8vw,104px);line-height:.9;}
.footer .cta-h .gold{color:var(--gold);-webkit-text-stroke:0;}
.footer .cta-sub{color:var(--grey);font-weight:300;margin:18px auto 34px;max-width:40ch;font-size:18px;}
.footer .btn{margin:0 auto;}
.foot-logo{width:min(420px,72vw);margin:clamp(54px,7vw,84px) auto 0;opacity:.92;}
.foot-links{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 30px;margin-top:34px;}
.foot-links a{display:inline-flex;align-items:center;gap:9px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;font-size:13px;color:var(--grey);transition:color .25s;}
.foot-links a:hover{color:var(--white);}
.foot-links svg{width:17px;height:17px;}
.foot-meta{margin-top:30px;color:var(--grey-faint);font-weight:300;font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;display:flex;flex-wrap:wrap;gap:6px 18px;justify-content:center;}
.foot-meta .gold{color:var(--gold-dim);}

/* ============================================================
   LOCATION CARD
   ============================================================ */
.loc .eyebrow{margin-bottom:4px;}
.loc-head{display:flex;align-items:center;gap:16px;margin:22px 0 26px;}
.loc-mark{flex:none;width:46px;height:46px;border-radius:50%;border:1px solid var(--gold-dim);position:relative;background:radial-gradient(circle,rgba(201,162,75,.12),transparent);}
.loc-mark::after{content:"";position:absolute;top:50%;left:50%;width:10px;height:10px;border-radius:50%;background:var(--gold);transform:translate(-50%,-50%);box-shadow:0 0 12px 2px rgba(201,162,75,.55);}
.loc-title{font-weight:900;text-transform:uppercase;font-size:clamp(28px,3.6vw,42px);line-height:.95;}
.loc-city{font-weight:300;color:var(--grey);font-size:14px;letter-spacing:.08em;text-transform:uppercase;}
.loc-facts{list-style:none;display:flex;flex-direction:column;margin-bottom:28px;border-top:1px solid var(--line);}
.loc-facts li{padding:15px 0;border-bottom:1px solid var(--line);font-weight:300;color:var(--grey);font-size:16px;line-height:1.45;display:flex;gap:12px;align-items:flex-start;}
.loc-facts li::before{content:"";flex:none;width:6px;height:6px;margin-top:8px;background:var(--gold);transform:rotate(45deg);}
.loc-actions{margin-top:auto;display:flex;flex-wrap:wrap;gap:10px;}
.loc-actions .btn{flex:0 0 auto;}
.loc-reviews{letter-spacing:.1em;}
.loc-reviews:hover{border-color:var(--gold);color:var(--gold);}

/* Instagram buttons */
.tb-ig{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid var(--line-strong);border-radius:999px;color:var(--white);transition:border-color .25s,color .25s,background .25s;}
.tb-ig:hover{border-color:var(--gold);color:var(--gold);background:rgba(255,255,255,.03);}
.tb-ig svg{width:17px;height:17px;}
.gal-foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;margin-top:22px;}
.gal-foot .gal-cap{margin-top:0;}
.ig-follow{display:inline-flex;align-items:center;gap:10px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:13px;color:var(--white);border:1px solid var(--line-strong);border-radius:2px;padding:12px 20px;transition:border-color .25s,color .25s,background .25s;}
.ig-follow:hover{border-color:var(--gold);color:var(--gold);background:rgba(201,162,75,.05);}
.ig-follow svg{width:18px;height:18px;}
.fb-follow:hover{border-color:#2A6FDB;color:#5B8DEF;background:rgba(42,111,219,.08);}
.gal-social{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}

/* ============================================================
   FLOATING WHATSAPP
   ============================================================ */
.fab-stack{position:fixed;right:22px;bottom:24px;z-index:7600;display:flex;flex-direction:column;align-items:center;gap:12px;}
.fab-stack a{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 16px 44px -14px rgba(0,0,0,.85);transition:transform .25s,box-shadow .35s,border-color .25s,color .25s;}
.fab-stack a:hover{transform:translateY(-3px) scale(1.05);}
.fab-stack svg{width:28px;height:28px;}
.ig-fab{color:#F4F2EC;background:linear-gradient(160deg,#221c1a,#151110);border:1px solid rgba(255,255,255,.18);}
.ig-fab:hover{border-color:var(--gold);color:var(--gold);}
.fb-fab{color:#5B8DEF;background:linear-gradient(160deg,#16203a,#0f1626);border:1px solid rgba(42,111,219,.5);}
.fb-fab:hover{border-color:#2A6FDB;color:#7AA5F5;}
.wa-fab{color:#25D366;background:linear-gradient(160deg,#1c2620,#141a17);border:1px solid rgba(37,211,102,.45);box-shadow:0 16px 44px -14px rgba(0,0,0,.85),0 0 0 0 rgba(37,211,102,.4);animation:waPulse 3s ease-out infinite;}
.wa-fab:hover{box-shadow:0 0 0 4px rgba(37,211,102,.14),0 20px 54px -16px rgba(0,0,0,.9);animation:none;}
@keyframes waPulse{0%{box-shadow:0 16px 44px -14px rgba(0,0,0,.85),0 0 0 0 rgba(37,211,102,.4);}70%{box-shadow:0 16px 44px -14px rgba(0,0,0,.85),0 0 0 14px rgba(37,211,102,0);}100%{box-shadow:0 16px 44px -14px rgba(0,0,0,.85),0 0 0 0 rgba(37,211,102,0);}}
@media (prefers-reduced-motion:reduce){.wa-fab{animation:none;}}

/* ============================================================
   STICKY MOBILE BOOK BAR
   ============================================================ */
.mobile-book{
  position:fixed;left:0;right:0;bottom:0;z-index:7500;
  padding:12px 16px calc(12px + env(safe-area-inset-bottom));
  background:linear-gradient(0deg,var(--ink) 60%,transparent);
  display:none;transform:translateY(120%);transition:transform .45s cubic-bezier(.2,.7,.2,1);
}
.mobile-book.show{transform:none;}
.mobile-book .btn{width:100%;padding:17px;}

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(26px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1);}
  .reveal.in{opacity:1;transform:none;}
  .reveal.d1{transition-delay:.08s;}
  .reveal.d2{transition-delay:.16s;}
  .reveal.d3{transition-delay:.24s;}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:900px){
  .pitch-head{grid-template-columns:1fr;gap:20px;align-items:start;}
  .cards{grid-template-columns:1fr;gap:14px;}
  .card{min-height:auto;}
  .svc-grid,.book-grid,.visit-grid{grid-template-columns:1fr;}
  .svc-aside{order:-1;}
  .gal-grid{grid-template-columns:repeat(2,1fr);}
  .map{min-height:260px;}
}
@media (max-width:560px){
  .hero-meta{font-size:10px;letter-spacing:.2em;}
  .hero-meta .left-meta{display:none;}
  .field.row2{grid-template-columns:1fr;}
  .specialty{flex-direction:column;gap:12px;}
  .mobile-book{display:block;}
  .fab-stack{bottom:86px;right:16px;}
  .fab-stack a{width:50px;height:50px;}
  .topbar .btn-ghost.desk{display:none;}
  .foot-logo{width:84vw;}
}
@media (min-width:561px){
  .mobile-book{display:none !important;}
}
