/* ============================================================
   DB Barber Shop — דן ביתן
   Luxury · Editorial · Black & White · RTL
   v2 — full redesign
   ============================================================ */

/* ----- Reset & base ----- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Heebo',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  font-weight:400;
  color:#0a0a0a;
  background:#fff;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
a{color:inherit;text-decoration:none;transition:opacity .25s ease}
a:hover{opacity:.7}
ul,ol{list-style:none}
input,textarea,select{font-family:inherit;font-size:1rem;color:inherit}

::selection{background:#0a0a0a;color:#fff}

/* Accessibility — focus-visible */
*:focus{outline:none}
*:focus-visible{outline:2px solid #0a0a0a;outline-offset:3px;border-radius:2px}
.btn:focus-visible{outline:2px solid #0a0a0a;outline-offset:4px}
.nav.is-on-dark *:focus-visible{outline-color:#fff}

/* Skip link for keyboard / screen-reader users */
.skip-link{position:absolute;top:-100px;right:16px;background:#0a0a0a;color:#fff;padding:12px 24px;font-size:14px;font-weight:600;z-index:10000;transition:top .25s ease}
.skip-link:focus{top:16px;opacity:1}

/* Toast / inline error */
.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%,120%);background:#0a0a0a;color:#fff;padding:14px 26px;border-radius:0;font-size:14px;font-weight:500;z-index:10000;box-shadow:0 20px 60px -20px rgba(0,0,0,.5);transition:transform .35s cubic-bezier(.2,.8,.2,1);max-width:90vw;text-align:center;letter-spacing:.05em}
.toast.is-visible{transform:translate(-50%,0)}
.toast--error{background:#c00}
.toast--success{background:#15803d}

/* Custom scrollbar */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:#f5f5f5}
::-webkit-scrollbar-thumb{background:#0a0a0a;border:2px solid #f5f5f5}
::-webkit-scrollbar-thumb:hover{background:#333}

/* ----- Layout ----- */
.container{max-width:1320px;margin:0 auto;padding:0 clamp(20px,4vw,56px)}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.hide-mobile{display:inline}
@media(max-width:700px){.hide-mobile{display:none}}

/* ============================================================
   Scroll Progress Bar
============================================================ */
.scroll-progress{position:fixed;top:0;right:0;height:2px;width:0;background:linear-gradient(90deg,#0a0a0a,#444);z-index:101;transition:width .1s linear;pointer-events:none}

/* ============================================================
   Custom Cursor
============================================================ */
.cursor{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;mix-blend-mode:difference;display:none}
.cursor__dot{position:fixed;width:6px;height:6px;background:#fff;border-radius:50%;transform:translate(-50%,-50%);transition:transform .15s ease,opacity .2s ease}
.cursor__ring{position:fixed;width:36px;height:36px;border:1px solid rgba(255,255,255,.5);border-radius:50%;transform:translate(-50%,-50%);transition:width .35s cubic-bezier(.2,.8,.2,1),height .35s cubic-bezier(.2,.8,.2,1),background .25s ease,border-color .25s ease}
.cursor.is-hover .cursor__ring{width:60px;height:60px;background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.8)}
.cursor.is-view .cursor__ring{width:80px;height:80px;background:rgba(255,255,255,.95);border-color:transparent;mix-blend-mode:normal}
.cursor.is-view::after{content:'הגדל';position:fixed;font-size:11px;letter-spacing:.15em;color:#0a0a0a;transform:translate(-50%,-50%);font-weight:600;text-transform:uppercase;mix-blend-mode:normal}
.cursor.is-hidden{opacity:0}
@media(hover:hover) and (pointer:fine){
  .cursor{display:block}
  body.has-cursor,body.has-cursor *{cursor:none!important}
  body.has-cursor input,body.has-cursor textarea{cursor:text!important}
  body.has-cursor select{cursor:pointer!important}
}

/* ============================================================
   Reveal Animations
============================================================ */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 1s cubic-bezier(.2,.8,.2,1),transform 1s cubic-bezier(.2,.8,.2,1)}
.reveal.is-visible{opacity:1;transform:none}

.reveal-up{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.2,.8,.2,1),transform .9s cubic-bezier(.2,.8,.2,1)}
.reveal-up.is-visible{opacity:1;transform:none}

/* Letter reveal — for hero title */
.reveal-letter{display:inline-block;overflow:hidden;vertical-align:bottom}
.reveal-letter .letter{display:inline-block;transform:translateY(110%);transition:transform 1.1s cubic-bezier(.2,.8,.2,1)}
.reveal-letter.is-visible .letter{transform:translateY(0)}

/* ============================================================
   Loader
============================================================ */
.loader{position:fixed;inset:0;background:#0a0a0a;z-index:9998;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:32px;transition:opacity .8s ease,visibility .8s ease}
.loader.is-hidden{opacity:0;visibility:hidden}
.loader__brand-svg{width:140px;height:auto}
.loader__text{font-family:'Cormorant Garamond',serif;font-size:80px;font-weight:500;letter-spacing:.04em;fill:transparent;stroke:#fff;stroke-width:.6;stroke-dasharray:300;stroke-dashoffset:300;animation:drawText 1.6s cubic-bezier(.6,.05,.4,.95) forwards}
@keyframes drawText{to{stroke-dashoffset:0;fill:#fff}}
.loader__bar{width:160px;height:1px;background:rgba(255,255,255,.2);overflow:hidden;position:relative}
.loader__bar span{position:absolute;inset:0;background:#fff;transform:scaleX(0);transform-origin:right;animation:loadBar 1.6s cubic-bezier(.7,.05,.2,1) forwards}
@keyframes loadBar{to{transform:scaleX(1)}}

/* ============================================================
   Buttons
============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:16px 32px;
  font-size:13px;font-weight:600;letter-spacing:.12em;
  border:1px solid transparent;border-radius:0;
  cursor:pointer;transition:all .35s cubic-bezier(.2,.8,.2,1);
  position:relative;overflow:hidden;
  white-space:nowrap;
  text-transform:uppercase;
  font-family:'Heebo',sans-serif;
}
.btn--sm{padding:11px 22px;font-size:12px}
.btn--lg{padding:20px 42px;font-size:13px}
.btn--solid{background:#0a0a0a;color:#fff;border-color:#0a0a0a}
.btn--solid::before{content:'';position:absolute;inset:0;background:#fff;transform:translateY(101%);transition:transform .4s cubic-bezier(.2,.8,.2,1);z-index:0}
.btn--solid:hover{color:#0a0a0a;opacity:1;border-color:#0a0a0a}
.btn--solid:hover::before{transform:translateY(0)}
.btn--solid > *{position:relative;z-index:1}
.btn__arrow{transition:transform .35s cubic-bezier(.2,.8,.2,1)}
.btn:hover .btn__arrow{transform:translateX(-6px)}
.btn--ghost{background:transparent;color:#0a0a0a;border-color:#0a0a0a}
.btn--ghost:hover{background:#0a0a0a;color:#fff;opacity:1}
.btn--outline{background:transparent;color:#fff;border-color:#fff}
.btn--outline:hover{background:#fff;color:#0a0a0a;opacity:1}

/* Magnetic effect (JS-driven) */
.magnetic{transition:transform .25s cubic-bezier(.2,.8,.2,1)}

/* ============================================================
   Nav
============================================================ */
.nav{position:fixed;top:0;right:0;left:0;z-index:100;background:rgba(255,255,255,0);backdrop-filter:blur(0);transition:all .4s ease;border-bottom:1px solid transparent}
.nav.is-scrolled{background:rgba(255,255,255,.92);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom-color:rgba(10,10,10,.06)}
.nav.is-on-dark{color:#fff}
.nav.is-on-dark .nav__logo{filter:brightness(0) invert(1)}
.nav.is-on-dark .nav__burger span{background:#fff}
.nav__inner{display:flex;align-items:center;justify-content:space-between;padding:18px 0;gap:24px}
.nav__brand{display:flex;align-items:center}
.nav__logo{height:54px;width:auto;transition:transform .35s ease,filter .4s ease}
.nav__brand:hover .nav__logo{transform:scale(1.05);opacity:1}
.nav__links{display:flex;gap:36px}
.nav__links a{font-size:13px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;position:relative;padding:8px 0}
.nav__links a::after{content:'';position:absolute;bottom:0;right:0;width:0;height:1px;background:currentColor;transition:width .35s cubic-bezier(.2,.8,.2,1)}
.nav__links a:hover{opacity:1}
.nav__links a:hover::after{width:100%}
.nav__cta{display:flex;align-items:center;gap:14px}
.nav.is-on-dark .btn--solid{background:#fff;color:#0a0a0a;border-color:#fff}
.nav.is-on-dark .btn--solid::before{background:#0a0a0a}
.nav.is-on-dark .btn--solid:hover{color:#fff}
.nav__burger{display:none;flex-direction:column;gap:5px;padding:8px;width:36px;height:36px;justify-content:center;align-items:center}
.nav__burger span{display:block;width:22px;height:1.5px;background:#0a0a0a;transition:all .3s ease}
.nav__burger.is-open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav__burger.is-open span:nth-child(2){opacity:0}
.nav__burger.is-open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.nav__mobile{display:none;flex-direction:column;gap:0;padding:0 24px;background:#fff;border-top:1px solid rgba(10,10,10,.08);max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.2,.8,.2,1),padding .4s ease}
.nav__mobile.is-open{max-height:600px;padding:16px 24px 32px}
.nav__mobile a{padding:14px 0;font-size:18px;font-weight:500;border-bottom:1px solid rgba(10,10,10,.06)}
.nav__mobile a.btn{margin-top:16px;border:1px solid #0a0a0a;justify-content:center}

@media (max-width:1000px){
  .nav__links{display:none}
  .nav__burger{display:flex}
  .nav__cta .btn:not(.btn--icon){display:none}
}

/* ============================================================
   Hero — split image + dramatic typography
============================================================ */
.hero{
  position:relative;
  min-height:100vh;min-height:100svh;
  display:flex;align-items:center;
  overflow:hidden;
  padding-top:120px;padding-bottom:80px;
  color:#fff;
  background:#0a0a0a;
}
.hero__image{position:absolute;inset:0;z-index:0}
.hero__image img{width:100%;height:100%;object-fit:cover;animation:heroZoom 12s ease-out forwards;will-change:transform}
@keyframes heroZoom{from{transform:scale(1.15)}to{transform:scale(1)}}
.hero__image-overlay{position:absolute;inset:0;background:
  linear-gradient(120deg,rgba(10,10,10,.7) 0%,rgba(10,10,10,.35) 50%,rgba(10,10,10,.7) 100%),
  linear-gradient(0deg,#0a0a0a 0%,transparent 25%,transparent 75%,rgba(10,10,10,.5) 100%);
}
.hero__grain{position:absolute;inset:0;z-index:1;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9'/%3E%3CfeColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 .12 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");pointer-events:none;mix-blend-mode:overlay}

.hero__vertical{
  position:absolute;
  left:32px;
  top:50%;
  transform:translateY(-50%) rotate(-180deg);
  writing-mode:vertical-rl;
  font-size:11px;letter-spacing:.4em;text-transform:uppercase;
  color:rgba(255,255,255,.5);
  z-index:2;
  font-weight:400;
}
@media(max-width:900px){.hero__vertical{display:none}}

.hero__inner{position:relative;z-index:2;width:100%;display:flex;flex-direction:column;align-items:center;text-align:center}

.hero__eyebrow{display:flex;align-items:center;justify-content:center;gap:18px;margin-bottom:48px;font-size:11px;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.hero__eyebrow-line{display:block;width:60px;height:1px;background:rgba(255,255,255,.4)}

.hero__title{
  font-family:'Bodoni Moda','Cormorant Garamond',serif;
  font-weight:400;
  line-height:.92;
  letter-spacing:-.02em;
  margin-bottom:64px;
  text-align:center;
  direction:ltr;
  unicode-bidi:embed;
}
.hero__title-line{display:block;font-size:clamp(48px,10vw,140px);overflow:hidden}
.hero__title-line--italic{font-style:italic;font-weight:400;color:rgba(255,255,255,.85)}
.hero__title-line:nth-child(2){padding-right:.15em}
.hero__title-line:nth-child(3){font-size:clamp(40px,8vw,110px);font-weight:300;color:rgba(255,255,255,.7);letter-spacing:.02em}

.hero__meta{display:flex;gap:48px;margin-bottom:48px;flex-wrap:wrap;justify-content:center}
.hero__meta-block{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}
.hero__meta-label{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.4)}
.hero__meta-value{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:500;color:rgba(255,255,255,.95)}

.hero__ctas{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.hero__ctas .btn--solid{background:#fff;color:#0a0a0a;border-color:#fff;padding:22px 48px;font-size:13px}
.hero__ctas .btn--solid::before{background:#0a0a0a}
.hero__ctas .btn--solid:hover{color:#fff}

.hero__scroll{position:absolute;bottom:30px;right:50%;transform:translateX(50%);display:flex;flex-direction:column;align-items:center;gap:12px;font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.hero__scroll-line{display:block;width:1px;height:50px;background:linear-gradient(to bottom,rgba(255,255,255,.6),transparent);position:relative;overflow:hidden}
.hero__scroll-line::after{content:'';position:absolute;top:-30px;left:0;right:0;height:30px;background:linear-gradient(to bottom,transparent,#fff);animation:scrollDot 2.4s ease-in-out infinite}
@keyframes scrollDot{0%{top:-30px}100%{top:50px}}

@media(max-width:700px){
  .hero{padding-top:90px;padding-bottom:60px;min-height:90vh;min-height:90svh}
  .hero__eyebrow{margin-bottom:24px;gap:10px;font-size:9px;letter-spacing:.25em}
  .hero__eyebrow-line{width:30px}
  .hero__title{margin-bottom:36px}
  .hero__title-line{font-size:clamp(54px,18vw,84px)}
  .hero__title-line:nth-child(3){font-size:clamp(42px,14vw,68px)}
  .hero__meta{gap:18px;margin-bottom:28px}
  .hero__meta-block{min-width:80px}
  .hero__meta-label{font-size:9px;letter-spacing:.2em}
  .hero__meta-value{font-size:15px}
  .hero__ctas .btn--solid{padding:18px 32px;font-size:12px}
  .hero__scroll{display:none}
  .marquee{padding:20px 0}
  .marquee__track{font-size:30px;gap:32px}
}

/* ============================================================
   Marquee
============================================================ */
.marquee{overflow:hidden;border-top:1px solid rgba(10,10,10,.1);border-bottom:1px solid rgba(10,10,10,.1);padding:28px 0;background:#0a0a0a;color:#fff;position:relative;z-index:1}
.marquee__track{display:flex;gap:48px;animation:marquee 30s linear infinite;white-space:nowrap;font-family:'Bodoni Moda','Cormorant Garamond',serif;font-size:38px;font-style:italic;color:rgba(255,255,255,.85);font-weight:400;letter-spacing:.05em;direction:ltr}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__star{font-style:normal;font-size:24px;color:rgba(255,255,255,.4);align-self:center}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   Section Heads
============================================================ */
.section-head{margin-bottom:72px;max-width:780px}
.section-head--center{text-align:center;margin-inline:auto}
.section-eyebrow{display:inline-block;font-size:11px;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:rgba(10,10,10,.5);margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid rgba(10,10,10,.2)}
.section-title{font-family:'Bodoni Moda','Cormorant Garamond',serif;font-size:clamp(36px,6.5vw,88px);font-weight:400;line-height:.95;letter-spacing:-.015em}
.section-title em{font-style:italic;font-weight:300}
.section-lead{margin-top:24px;color:rgba(10,10,10,.6);font-weight:300;font-size:17px;line-height:1.7}
@media(max-width:700px){
  .section-head{margin-bottom:40px}
  .section-eyebrow{font-size:10px;letter-spacing:.25em;margin-bottom:14px}
  .section-lead{font-size:15px;margin-top:18px}
}

/* ============================================================
   Services
============================================================ */
.services{padding:140px 0;background:#f7f5f2;position:relative}
.services::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:rgba(10,10,10,.08)}
.services__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:72px}
.service{position:relative;background:#fff;padding:48px 40px;transition:all .5s cubic-bezier(.2,.8,.2,1);overflow:hidden;cursor:pointer;border:1px solid rgba(10,10,10,.06)}
.service::before{content:'';position:absolute;inset:0;background:#0a0a0a;transform:translateY(101%);transition:transform .5s cubic-bezier(.2,.8,.2,1);z-index:0}
.service > *{position:relative;z-index:1;transition:color .4s ease}
.service:hover{transform:translateY(-4px);border-color:#0a0a0a}
.service:hover::before{transform:translateY(0)}
.service:hover *{color:#fff}
.service:hover .service__num,.service:hover .service__desc,.service:hover .service__meta span{color:rgba(255,255,255,.65)}
.service__top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px}
.service__num{font-family:'Cormorant Garamond',serif;font-size:13px;letter-spacing:.2em;color:rgba(10,10,10,.4)}
.service__name{font-family:'Bodoni Moda','Cormorant Garamond',serif;font-size:38px;font-weight:500;line-height:1;margin-bottom:14px;letter-spacing:-.01em}
.service__desc{font-size:14px;font-weight:300;line-height:1.7;color:rgba(10,10,10,.65);margin-bottom:32px;min-height:50px}
.service__price{font-family:'Bodoni Moda','Cormorant Garamond',serif;font-size:48px;font-weight:500;letter-spacing:-.02em;line-height:1}
.service__meta{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid rgba(10,10,10,.08);font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:500}
.service__meta span:first-child{color:rgba(10,10,10,.5)}
.service__cta{font-weight:600;color:#0a0a0a;transition:transform .35s cubic-bezier(.2,.8,.2,1);display:inline-block}
.service:hover .service__cta{transform:translateX(-4px)}
.service__badge{position:absolute;top:0;right:0;font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;background:#0a0a0a;color:#fff;padding:10px 18px;z-index:3}
.service--featured{border-color:#0a0a0a;box-shadow:0 20px 50px -25px rgba(0,0,0,.25)}
.service--featured .service__num{visibility:hidden}
.service--featured:hover .service__badge{background:#fff;color:#0a0a0a}
.services__cta{text-align:center}

@media (max-width:700px){
  .services{padding:70px 0}
  .services__grid{grid-template-columns:1fr;gap:14px;margin-bottom:48px}
  .service{padding:32px 24px}
  .service__name{font-size:26px}
  .service__price{font-size:34px}
  .service__desc{font-size:13.5px;margin-bottom:24px;min-height:0}
  .service__top{margin-bottom:24px}
  .service__badge{font-size:9px;padding:8px 14px}
  .service__meta{font-size:11px;padding-top:18px}
}

/* ============================================================
   Gallery
============================================================ */
.gallery{padding:140px 0;background:#fff}
.gallery__head{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:64px}
.gallery__head .section-head{margin-bottom:0}
.gallery__lead{font-size:17px;font-weight:300;line-height:1.7;color:rgba(10,10,10,.65);max-width:420px;justify-self:start}

.gallery__grid{display:flex;gap:16px;direction:rtl;align-items:stretch}
.gallery__item{position:relative;aspect-ratio:4/5;overflow:hidden;cursor:pointer;border:none;background:#0a0a0a;flex:1 1 0;min-width:0}
.gallery__item--lg{flex:1 1 0}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s cubic-bezier(.2,.8,.2,1),filter .5s ease;filter:grayscale(.15)}
.gallery__item:hover img{transform:scale(1.08);filter:grayscale(0)}
.gallery__overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(10,10,10,.2);opacity:0;transition:opacity .4s ease}
.gallery__plus{width:64px;height:64px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.6);color:#fff;font-size:32px;font-weight:300;border-radius:50%;transform:scale(.5);transition:transform .5s cubic-bezier(.2,.8,.2,1);background:rgba(10,10,10,.3);backdrop-filter:blur(4px)}
.gallery__item:hover .gallery__overlay{opacity:1}
.gallery__item:hover .gallery__plus{transform:scale(1)}
.gallery__num{position:absolute;top:16px;right:16px;font-family:'Cormorant Garamond',serif;font-size:13px;letter-spacing:.2em;color:#fff;background:rgba(10,10,10,.4);padding:6px 12px;backdrop-filter:blur(4px)}

/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(10,10,10,.96);z-index:1000;display:none;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .4s ease}
.lightbox.is-open{display:flex;opacity:1}
.lightbox img{max-width:90vw;max-height:85vh;object-fit:contain;box-shadow:0 30px 80px rgba(0,0,0,.5);animation:lightboxIn .5s cubic-bezier(.2,.8,.2,1)}
@keyframes lightboxIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
.lightbox__close{position:absolute;top:24px;left:24px;width:48px;height:48px;color:#fff;font-size:32px;border:1px solid rgba(255,255,255,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .25s ease}
.lightbox__close:hover{background:#fff;color:#0a0a0a}
.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);width:56px;height:56px;color:#fff;font-size:36px;border:1px solid rgba(255,255,255,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .25s ease;line-height:1;padding-bottom:4px}
.lightbox__nav:hover{background:#fff;color:#0a0a0a}
.lightbox__nav--prev{right:24px}
.lightbox__nav--next{left:24px}
.lightbox__counter{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);font-family:'Cormorant Garamond',serif;font-size:14px;letter-spacing:.2em;color:rgba(255,255,255,.6)}

@media (max-width:900px){
  .gallery{padding:80px 0}
  .gallery__head{grid-template-columns:1fr;gap:20px;align-items:start;margin-bottom:40px}
  .gallery__grid{flex-direction:column;gap:12px}
  .gallery__item,.gallery__item--lg{flex:1;width:100%;aspect-ratio:4/3}
  .gallery__item--lg{aspect-ratio:16/10}
  .gallery__num{font-size:11px;padding:5px 10px}
  .lightbox__nav{width:44px;height:44px;font-size:28px}
  .lightbox__nav--prev{right:12px}
  .lightbox__nav--next{left:12px}
}

/* ============================================================
   Testimonials
============================================================ */
.testimonials{padding:140px 0;background:#0a0a0a;color:#fff;position:relative;overflow:hidden}
.testimonials::before{content:'"';position:absolute;top:-60px;right:5%;font-family:'Bodoni Moda',serif;font-size:480px;color:rgba(255,255,255,.04);font-weight:500;line-height:.6;pointer-events:none}
.testimonials .section-eyebrow{color:rgba(255,255,255,.5);border-bottom-color:rgba(255,255,255,.2)}
.testimonials .section-title{color:#fff}
.testimonials__track{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative;z-index:1}
.testimonial{padding:48px 36px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.02);transition:all .4s ease;position:relative}
.testimonial:hover{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.25);transform:translateY(-4px)}
.testimonial__stars{color:#d4af37;font-size:18px;letter-spacing:.1em;margin-bottom:24px}
.testimonial__quote{font-family:'Cormorant Garamond',serif;font-size:21px;line-height:1.55;font-style:italic;font-weight:400;color:rgba(255,255,255,.92);margin-bottom:32px}
.testimonial__author{display:flex;flex-direction:column;gap:4px;padding-top:24px;border-top:1px solid rgba(255,255,255,.15)}
.testimonial__author strong{font-size:15px;font-weight:600;color:#fff;font-family:'Heebo',sans-serif;letter-spacing:.05em}
.testimonial__author span{font-size:12px;color:rgba(255,255,255,.5);letter-spacing:.05em}

@media(max-width:900px){
  .testimonials{padding:70px 0}
  .testimonials::before{font-size:280px;top:-30px;right:0%}
  .testimonials__track{grid-template-columns:1fr;gap:14px}
  .testimonial{padding:32px 24px}
  .testimonial__quote{font-size:18px}
}

/* ============================================================
   Booking
============================================================ */
.booking{padding:140px 0;background:#f7f5f2;position:relative}
.booking::before,.booking::after{content:'';position:absolute;left:0;right:0;height:1px;background:rgba(10,10,10,.08)}
.booking::before{top:0}.booking::after{bottom:0}
.booking__form{max-width:1080px;margin:0 auto;background:#fff;border:1px solid rgba(10,10,10,.06);padding:48px;box-shadow:0 30px 80px -40px rgba(0,0,0,.15)}
.booking__form .booking__step[data-step="1"],
.booking__form .booking__step[data-step="3"]{max-width:780px;margin:0 auto}
.booking__steps{display:flex;justify-content:space-between;margin:0 auto 48px;position:relative;counter-reset:step;max-width:780px}
.booking__steps::before{content:'';position:absolute;top:18px;right:18px;left:18px;height:1px;background:rgba(10,10,10,.15);z-index:0}
.booking__steps li{display:flex;flex-direction:column;align-items:center;gap:10px;font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(10,10,10,.4);position:relative;z-index:1;flex:1;transition:color .35s ease}
.booking__steps li span{width:36px;height:36px;background:#fff;border:1px solid rgba(10,10,10,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:16px;transition:all .35s cubic-bezier(.2,.8,.2,1)}
.booking__steps li.active{color:#0a0a0a}
.booking__steps li.active span{background:#0a0a0a;color:#fff;border-color:#0a0a0a;transform:scale(1.05)}
.booking__steps li.done span{background:#0a0a0a;color:#fff;border-color:#0a0a0a}
.booking__steps li.done{color:#0a0a0a}

.booking__step{display:none;border:none;padding:0}
.booking__step.active{display:block;animation:fadeUp .5s cubic-bezier(.2,.8,.2,1)}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

.booking__services{display:flex;flex-direction:column;gap:10px;margin-bottom:32px}
.booking__service{display:block;cursor:pointer;position:relative}
.booking__service input{position:absolute;opacity:0;pointer-events:none}
.booking__service div{display:flex;justify-content:space-between;align-items:center;padding:22px 26px;border:1px solid rgba(10,10,10,.12);transition:all .3s ease}
.booking__service strong{font-family:'Cormorant Garamond',serif;font-size:23px;font-weight:500;letter-spacing:.01em}
.booking__service .muted{font-size:13px;color:rgba(10,10,10,.55)}
.booking__service:hover div{border-color:rgba(10,10,10,.5);transform:translateX(-4px)}
.booking__service input:checked + div{background:#0a0a0a;color:#fff;border-color:#0a0a0a}
.booking__service input:checked + div .muted{color:rgba(255,255,255,.7)}

/* ===== Schedule (Calendly-style: info | calendar | times) ===== */
.schedule{display:grid;grid-template-columns:260px 1fr 280px;border:1px solid rgba(10,10,10,.1);background:#fff;margin-bottom:24px;min-height:480px}
.schedule > *{padding:28px 24px}
.schedule__info{background:#fafaf8;border-inline-start:1px solid rgba(10,10,10,.08);display:flex;flex-direction:column;gap:24px}
.schedule__brand{padding-bottom:20px;border-bottom:1px solid rgba(10,10,10,.08)}
.schedule__brand img{height:44px;display:block;margin-bottom:14px}
.schedule__brand strong{display:block;font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:500;line-height:1.2}
.schedule__brand span{font-size:12px;color:rgba(10,10,10,.55);letter-spacing:.05em}
.schedule__service{display:flex;flex-direction:column;gap:6px}
.schedule__service strong{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:500;color:#0a0a0a;line-height:1.2}
.schedule__service .schedule__price{font-size:14px;color:rgba(10,10,10,.6);font-weight:500;letter-spacing:.05em}
.schedule__meta{display:flex;flex-direction:column;gap:14px;margin-top:auto;padding-top:20px;border-top:1px solid rgba(10,10,10,.08)}
.schedule__meta li{display:flex;align-items:center;gap:10px;font-size:13px;color:rgba(10,10,10,.7);line-height:1.4}
.schedule__meta svg{flex-shrink:0;color:rgba(10,10,10,.5)}

.schedule__cal{border-inline-start:1px solid rgba(10,10,10,.08)}
.schedule__cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px}
.schedule__cal-head h3{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:500;flex:1;text-align:center}
.cal__weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:6px}
.cal__weekdays span{text-align:center;font-size:11px;letter-spacing:.1em;color:rgba(10,10,10,.5);padding:6px 0;text-transform:uppercase;font-weight:600}
.cal__days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.cal__day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:14px;border:1px solid transparent;cursor:pointer;transition:all .18s ease;background:transparent;font-weight:500;border-radius:50%;color:rgba(10,10,10,.85)}
.cal__day.is-available{background:#f0ede7;color:#0a0a0a;font-weight:600}
.cal__day:not(:disabled):hover{background:#0a0a0a;color:#fff;transform:scale(1.05)}
.cal__day.is-today{outline:1px solid rgba(10,10,10,.45);outline-offset:-3px}
.cal__day.is-selected{background:#0a0a0a;color:#fff;border-color:#0a0a0a}
.cal__day.is-selected.is-available{background:#0a0a0a;color:#fff}
.cal__day:disabled{color:rgba(10,10,10,.25);cursor:not-allowed;background:transparent;font-weight:400}
.cal__day.empty{background:transparent;cursor:default;border:none}
.cal-nav{width:36px;height:36px;border:1px solid rgba(10,10,10,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;line-height:1;flex-shrink:0;transition:all .2s ease;background:#fff;cursor:pointer}
.cal-nav:hover:not(:disabled){background:#0a0a0a;color:#fff;border-color:#0a0a0a}
.cal-nav:disabled{opacity:.3;cursor:not-allowed}

.schedule__times{display:flex;flex-direction:column;background:#fff;max-height:560px}
.schedule__times-head{margin-bottom:14px}
.schedule__times-head h4{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:500;margin-bottom:2px}
.schedule__times-tz{font-size:11px;color:rgba(10,10,10,.5);letter-spacing:.05em}

.booking__times{display:grid;grid-template-columns:1fr 1fr;gap:8px;overflow-y:auto;padding-inline-end:4px;flex:1}
.booking__times::-webkit-scrollbar{width:6px}
.booking__times::-webkit-scrollbar-track{background:transparent}
.booking__times::-webkit-scrollbar-thumb{background:rgba(10,10,10,.15);border-radius:4px}
.booking__time{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:13px 10px;border:1px solid rgba(10,10,10,.15);border-radius:14px;font-size:14px;font-weight:600;text-align:center;transition:all .2s ease;background:#fff;letter-spacing:.03em;color:#0a0a0a;cursor:pointer;font-family:inherit}
.booking__time svg{flex-shrink:0;color:rgba(10,10,10,.55);transition:color .2s}
.booking__time:hover:not(:disabled){border-color:#0a0a0a;background:#fafaf8;transform:translateY(-1px);box-shadow:0 4px 12px -6px rgba(0,0,0,.18)}
.booking__time:hover svg{color:#0a0a0a}
.booking__time.is-selected{background:#0a0a0a;color:#fff;border-color:#0a0a0a}
.booking__time.is-selected svg{color:#fff}
.booking__time:disabled{color:rgba(10,10,10,.25);cursor:not-allowed;text-decoration:line-through}
.booking__times-empty{grid-column:1/-1;text-align:center;padding:32px 8px;color:rgba(10,10,10,.5);font-size:13px;line-height:1.6}

.booking__fields{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:32px}
.field{display:flex;flex-direction:column;gap:8px}
.field--full{grid-column:1/-1}
.field span{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:rgba(10,10,10,.6);font-weight:600}
.field input,.field textarea{padding:16px 20px;border:1px solid rgba(10,10,10,.12);background:#fff;border-radius:0;transition:border-color .25s ease;font-size:16px}
.field input:focus,.field textarea:focus{outline:none;border-color:#0a0a0a}
.field textarea{resize:vertical;min-height:90px;font-family:inherit}
.field input:invalid:not(:placeholder-shown){border-color:#c00}

.booking__summary{background:#f7f5f2;padding:24px 28px;margin-bottom:24px;border:1px solid rgba(10,10,10,.06);font-size:14px}
.booking__summary strong{font-family:'Cormorant Garamond',serif;font-size:20px;display:block;margin-bottom:12px;font-weight:500}
.booking__summary div{display:flex;justify-content:space-between;padding:5px 0;color:rgba(10,10,10,.7)}

.booking__nav{display:flex;justify-content:space-between;gap:12px;margin-top:24px}

.booking__success{text-align:center;padding:32px 0}
.booking__success-icon{width:80px;height:80px;border:1px solid #0a0a0a;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;animation:bounceIn .6s cubic-bezier(.2,.8,.2,1)}
@keyframes bounceIn{0%{transform:scale(0)}60%{transform:scale(1.1)}100%{transform:scale(1)}}
.booking__success h3{font-family:'Cormorant Garamond',serif;font-size:38px;font-weight:500;margin-bottom:12px}
.booking__success p{color:rgba(10,10,10,.7);margin-bottom:16px}
.booking__code{font-family:'Bodoni Moda','Cormorant Garamond',serif;font-size:36px;letter-spacing:.25em;background:#0a0a0a;color:#fff;padding:18px 28px;display:inline-block;margin:8px 0 24px;font-weight:500}
.booking__success-buttons{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:24px}
.booking__wa-btn,.booking__ics-btn{display:inline-flex;align-items:center;gap:10px;padding:13px 22px;font-size:13px;font-weight:600;letter-spacing:.05em;text-decoration:none;transition:all .3s ease;border-radius:0;cursor:pointer}
.booking__wa-btn{background:#25D366;color:#fff;border:1px solid #25D366}
.booking__wa-btn:hover{background:#1ea952;border-color:#1ea952;opacity:1;transform:translateY(-2px);box-shadow:0 10px 30px -10px rgba(37,211,102,.5)}
.booking__ics-btn{background:#fff;color:#0a0a0a;border:1px solid #0a0a0a}
.booking__ics-btn:hover{background:#0a0a0a;color:#fff;opacity:1;transform:translateY(-2px);box-shadow:0 10px 30px -10px rgba(0,0,0,.3)}
.booking__wa-btn svg,.booking__ics-btn svg{flex-shrink:0}
.booking__success-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:24px}
.small{font-size:13px}
.muted{color:rgba(10,10,10,.55)}

.booking__cancel-link{text-align:center;margin-top:32px;font-size:14px;color:rgba(10,10,10,.6)}
.booking__cancel-link a{font-weight:600;text-decoration:underline;text-underline-offset:4px}

@media (max-width:960px){
  .schedule{grid-template-columns:1fr;min-height:0}
  .schedule__info{border-inline-start:none;border-bottom:1px solid rgba(10,10,10,.08);flex-direction:row;flex-wrap:wrap;gap:16px;padding:20px 24px}
  .schedule__brand{padding-bottom:0;border-bottom:none;display:flex;align-items:center;gap:12px;flex:1 1 auto}
  .schedule__brand img{height:36px;margin-bottom:0}
  .schedule__service{flex:1 1 auto;text-align:end}
  .schedule__service strong{font-size:18px}
  .schedule__meta{flex-direction:row;flex-wrap:wrap;gap:14px;margin-top:0;padding-top:14px;border-top:1px solid rgba(10,10,10,.08);width:100%}
  .schedule__meta li{font-size:12px}
  .schedule__cal{border-inline-start:none;border-bottom:1px solid rgba(10,10,10,.08)}
  .schedule__times{max-height:none;padding-bottom:24px}
  .booking__times{max-height:340px}
}
@media (max-width:700px){
  .booking{padding:90px 0}
  .booking__form{padding:24px 18px}
  .booking__steps li{font-size:9px}
  .booking__steps li span{width:32px;height:32px;font-size:14px}
  .booking__fields{grid-template-columns:1fr}
  .schedule > *{padding:18px 16px}
  .schedule__info{flex-direction:column;align-items:stretch}
  .schedule__brand{justify-content:flex-start}
  .schedule__service{text-align:start}
  .schedule__meta{flex-direction:column;gap:10px}
  .schedule__cal-head h3{font-size:18px}
  .booking__times{grid-template-columns:repeat(3,1fr);gap:6px}
  .booking__time{padding:11px 4px;font-size:13px;border-radius:12px;gap:4px}
  .booking__time svg{width:12px;height:12px}
  .cal-nav{width:32px;height:32px;font-size:16px}
  .cal__day{font-size:13px}
}
@media (max-width:380px){
  .booking__times{grid-template-columns:repeat(2,1fr)}
}

/* ============================================================
   Location
============================================================ */
.location{padding:140px 0;background:#fff}
.location__grid{display:grid;grid-template-columns:1fr 1.2fr;gap:72px;align-items:start}
.info-block{padding-bottom:32px;margin-bottom:32px;border-bottom:1px solid rgba(10,10,10,.08)}
.info-block:last-child{border-bottom:none;margin-bottom:0}
.info-block h3{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:500;margin-bottom:12px}
.info-block p,.info-block a{font-size:16px;font-weight:300;color:rgba(10,10,10,.75);display:block;margin-bottom:6px}
.info-block a:hover{color:#0a0a0a;opacity:1}
.link-arrow{display:inline-block!important;margin-top:8px;font-size:12px!important;font-weight:600!important;letter-spacing:.1em;text-transform:uppercase;color:#0a0a0a!important;border-bottom:1px solid #0a0a0a;padding-bottom:2px}
.hours{display:flex;flex-direction:column;gap:10px}
.hours li{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid rgba(10,10,10,.06);font-size:15px;font-weight:300}
.hours li:last-child{border-bottom:none}
.hours .closed{color:rgba(10,10,10,.4);font-style:italic}
.location__map{aspect-ratio:1;border:1px solid rgba(10,10,10,.08);overflow:hidden;filter:grayscale(.5) contrast(1.05);transition:filter .5s ease}
.location__map:hover{filter:grayscale(0) contrast(1)}
.location__map iframe{display:block;width:100%;height:100%}

@media (max-width:900px){
  .location{padding:70px 0}
  .location__grid{grid-template-columns:1fr;gap:36px}
  .location__map{aspect-ratio:4/3}
  .info-block h3{font-size:22px}
  .info-block p,.info-block a{font-size:15px}
  .hours li{font-size:14px}
}

/* ============================================================
   CTA Band
============================================================ */
.cta-band{background:#0a0a0a;color:#fff;padding:120px 0;position:relative;overflow:hidden}
@media(max-width:700px){.cta-band{padding:80px 0}.cta-band p{font-size:16px;margin-bottom:32px}}
.cta-band__bg{position:absolute;inset:0;opacity:.1;background-image:
  radial-gradient(circle at 20% 50%,rgba(255,255,255,.5) 0,transparent 50%),
  radial-gradient(circle at 80% 50%,rgba(255,255,255,.3) 0,transparent 50%);
}
.cta-band::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:60px 60px;pointer-events:none}
.cta-band__inner{text-align:center;position:relative;max-width:780px;margin:0 auto}
.cta-band__eyebrow{display:block;font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:24px}
.cta-band h2{font-family:'Bodoni Moda','Cormorant Garamond',serif;font-size:clamp(40px,7vw,84px);font-weight:400;margin-bottom:20px;line-height:.95;letter-spacing:-.015em}
.cta-band h2 em{font-style:italic;font-weight:300}
.cta-band p{color:rgba(255,255,255,.7);font-weight:300;margin-bottom:40px;font-size:18px;max-width:480px;margin-inline:auto}
.cta-band__btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.cta-band .btn--solid{background:#fff;color:#0a0a0a;border-color:#fff;padding:22px 48px}
.cta-band .btn--solid::before{background:#0a0a0a}
.cta-band .btn--solid:hover{color:#fff;border-color:#fff}

/* ============================================================
   Footer
============================================================ */
.footer{background:#0a0a0a;color:rgba(255,255,255,.7);padding:90px 0 28px}
.footer__inner{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:56px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer__brand img{height:90px;margin-bottom:24px;filter:brightness(0) invert(1)}
.footer__brand p{font-size:14px;line-height:1.7;font-weight:300;max-width:280px}
.footer__col h4{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:500;color:#fff;margin-bottom:20px}
.footer__col a,.footer__col span{display:block;font-size:14px;font-weight:300;margin-bottom:10px;transition:color .25s ease}
.footer__col a:hover{color:#fff;opacity:1;padding-right:6px}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;padding-top:28px;font-size:11px;letter-spacing:.1em;color:rgba(255,255,255,.4);flex-wrap:wrap;gap:8px;text-transform:uppercase}
.footer__admin{font-size:10px;letter-spacing:.2em;text-transform:uppercase;opacity:.4;transition:opacity .25s ease}
.footer__admin:hover{opacity:1;color:#fff}

@media (max-width:1000px){
  .footer__inner{grid-template-columns:1fr 1fr;gap:36px}
}
@media (max-width:540px){
  .footer{padding:60px 0 24px}
  .footer__inner{grid-template-columns:1fr;gap:28px;padding-bottom:32px}
  .footer__brand img{height:70px;margin-bottom:18px}
  .footer__col h4{font-size:20px;margin-bottom:14px}
  .footer__bottom{font-size:10px}
}

/* ============================================================
   Sticky CTA (mobile)
============================================================ */
.sticky-cta{
  position:fixed;bottom:16px;right:16px;left:16px;z-index:90;
  background:#0a0a0a;color:#fff;padding:18px;
  text-align:center;font-size:14px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;
  box-shadow:0 10px 40px rgba(0,0,0,.25);
  display:none;
  opacity:0;transform:translateY(20px);transition:all .35s ease
}
.sticky-cta.is-visible{opacity:1;transform:none}
@media (max-width:700px){
  .sticky-cta{display:block}
  body{padding-bottom:80px}
}

/* ============================================================
   Reduced motion
============================================================ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .reveal,.reveal-up{opacity:1;transform:none}
  .reveal-letter .letter{transform:none}
}
