/* ═══════════════════════════════════════════
   SERENOVA MASSAGE — main.css
   Warm Obsidian design system
   Deep charcoal + warm gold + sage + dusty rose
   ═══════════════════════════════════════════ */

:root {
  /* Base — warm dark obsidian */
  --bg-900:#0E0D0B; --bg-800:#131210; --bg-700:#1A1815; --bg-600:#221F1B;
  /* Warm tones */
  --warm-1:#1A1612; --warm-2:#2A2318; --warm-3:#3A3020; --warm-4:#4A3D28;
  /* Accent — warm gold */
  --accent:#C8A96B; --accent-bright:#E2C88A; --accent-dim:rgba(200,169,107,.14);
  /* Sage — Hanna */
  --sage:#A8BFA0; --sage-dim:rgba(168,191,160,.12);
  /* Rose — Mikael */
  --rose:#B08D8D; --rose-dim:rgba(176,141,141,.12);
  /* Text */
  --text-100:#F0EDE8; --text-300:#B8AFA0; --text-500:#7A6E60;
  /* Borders */
  --border:rgba(200,169,107,.12); --border-strong:rgba(200,169,107,.24);
  /* Type */
  --font-display:'Cormorant Garamond','Georgia',serif;
  --font-sans:'Inter',sans-serif;
  --font-body:'Inter',sans-serif;
  /* Motion */
  --ease-out:cubic-bezier(0.16,1,0.3,1);
  --nav-h:74px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--bg-900);
  color:var(--text-100);
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--accent);color:var(--bg-900)}

h1,h2{font-family:var(--font-display);font-weight:300}
h1{font-size:clamp(3.6rem,8.5vw,8rem);letter-spacing:-.01em;line-height:.88}
h2{font-size:clamp(2.4rem,5vw,4.2rem);letter-spacing:-.005em;line-height:1.05}
h3{font-family:var(--font-body);font-weight:600}
html[lang="ru"] h1{font-size:clamp(2.8rem,6vw,5.6rem);letter-spacing:0;font-weight:400}
html[lang="ru"] h2{font-size:clamp(2rem,4vw,3.4rem);letter-spacing:0;font-weight:400}

.container{width:min(1240px,92vw);margin:0 auto}
.eyebrow{
  font-family:var(--font-body);
  font-size:.72rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;
  color:var(--accent);display:inline-flex;align-items:center;gap:.8rem;
}
.eyebrow::before{content:'';width:24px;height:1px;background:var(--accent)}

::-webkit-scrollbar{width:8px}
::-webkit-scrollbar-track{background:var(--bg-900)}
::-webkit-scrollbar-thumb{background:var(--warm-3);border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:var(--accent)}

/* ═══ DEMO BANNER ═══ */
.demo-banner{
  position:fixed;top:0;left:0;right:0;z-index:1100;
  background:linear-gradient(90deg,var(--warm-2),var(--warm-1));
  border-bottom:1px solid var(--border-strong);
  display:flex;align-items:center;justify-content:center;gap:18px;
  padding:7px 16px;font-size:.78rem;flex-wrap:wrap;
}
.demo-banner .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent)}
.demo-banner b{color:var(--accent);font-weight:600}
.demo-banner a{
  color:var(--accent-bright);font-weight:600;border-bottom:1px solid transparent;
  display:inline-flex;align-items:center;gap:5px;transition:.2s;
}
.demo-banner a:hover{border-color:var(--accent-bright)}
.demo-banner .bn-sep{color:var(--text-500);opacity:.5;font-weight:700}
.demo-banner .bn-home{color:var(--text-300)}
.demo-banner .bn-home:hover{color:var(--accent);border-color:var(--accent)}

/* ═══ NAVBAR ═══ */
.navbar{
  position:fixed;top:35px;left:0;right:0;z-index:1000;
  transition:background .4s,backdrop-filter .4s,border-color .4s,padding .4s;
  border-bottom:1px solid transparent;
}
.navbar.scrolled{
  background:rgba(14,13,11,.94);backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);top:0;
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:var(--nav-h)}
.logo{
  font-family:var(--font-display);font-size:2rem;letter-spacing:.12em;
  display:flex;align-items:center;gap:.7rem;font-weight:300;text-transform:uppercase;
}
.logo .mark{
  width:36px;height:36px;border-radius:50%;display:grid;place-items:center;
  border:1.5px solid var(--accent);color:var(--accent);font-size:.9rem;
  background:var(--accent-dim);flex-shrink:0;letter-spacing:0;font-weight:500;
  font-family:var(--font-body);font-size:.7rem;text-transform:uppercase;
}
.logo b{color:var(--accent);font-weight:400}
.logo-sub{color:var(--text-500);font-family:var(--font-body);font-size:.58rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;display:block;line-height:1}

.nav-links{display:flex;align-items:center;gap:2.2rem}
.nav-links a{font-size:.82rem;font-weight:400;letter-spacing:.06em;color:var(--text-300);transition:.2s;position:relative}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-5px;height:1px;width:0;background:var(--accent);transition:width .3s}
.nav-links a:hover{color:var(--text-100)}
.nav-links a:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:1rem}
.lang-switch{display:flex;gap:2px;background:var(--bg-700);border:1px solid var(--border);border-radius:8px;padding:3px}
.lang-btn{font-size:.72rem;font-weight:600;padding:5px 9px;border-radius:6px;color:var(--text-500);transition:.2s;letter-spacing:.06em}
.lang-btn.active{background:var(--accent);color:var(--bg-900)}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-weight:500;font-size:.86rem;padding:.85rem 1.8rem;border-radius:4px;
  transition:transform .25s var(--ease-out),box-shadow .25s,background .25s,color .25s,border-color .25s;
  position:relative;overflow:hidden;white-space:nowrap;letter-spacing:.04em;
}
.btn i{font-size:1rem}
.btn-primary{background:var(--accent);color:var(--bg-900);box-shadow:0 8px 28px var(--accent-dim);font-weight:600}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(200,169,107,.35)}
.btn-primary::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.22) 50%,transparent 70%);
  transform:translateX(-130%);transition:transform .55s;
}
.btn-primary:hover::after{transform:translateX(130%)}
.btn-ghost{background:transparent;border:1px solid var(--border-strong);color:var(--text-100)}
.btn-ghost:hover{background:rgba(200,169,107,.08);border-color:var(--accent);transform:translateY(-2px)}
.btn-sm{padding:.6rem 1.2rem;font-size:.8rem}
.nav-cta{
  background:transparent;border:1px solid var(--accent);color:var(--accent);
  padding:.6rem 1.3rem;border-radius:4px;font-weight:500;font-size:.82rem;
  letter-spacing:.06em;transition:.25s;
}
.nav-cta:hover{background:var(--accent);color:var(--bg-900)}

.burger{display:none;flex-direction:column;justify-content:center;gap:5px;padding:10px;width:40px;height:40px}
.burger span{width:22px;height:1.5px;background:var(--text-100);transition:.3s;display:block}
.burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* Mobile menu — redesigned */
.mob-menu{
  position:fixed;inset:0;z-index:1050;
  background:rgba(14,13,11,.97);backdrop-filter:blur(16px);
  display:flex;flex-direction:column;
  opacity:0;pointer-events:none;
  transition:opacity .32s var(--ease-out);
  overflow-y:auto;
  padding-top:max(env(safe-area-inset-top),0px);
}
.mob-menu.open{opacity:1;pointer-events:auto}

/* top bar inside mobile menu */
.mob-menu-top{
  display:flex;align-items:center;justify-content:space-between;
  padding:.8rem 1.2rem;
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.mob-logo{
  font-family:var(--font-display);font-size:1.5rem;letter-spacing:.1em;
  text-transform:uppercase;display:flex;align-items:center;gap:.5rem;font-weight:300;
}
.mob-logo .mark{
  width:28px;height:28px;border-radius:50%;border:1px solid var(--accent);
  display:grid;place-items:center;font-family:var(--font-body);
  font-size:.58rem;font-weight:600;color:var(--accent);letter-spacing:.04em;
}
.mob-close{
  width:38px;height:38px;border-radius:50%;
  border:1px solid var(--border-strong);
  display:grid;place-items:center;
  font-size:1.1rem;color:var(--text-300);transition:.2s;
}
.mob-close:hover{border-color:var(--accent);color:var(--accent)}

/* nav links */
.mob-nav{
  display:flex;flex-direction:column;
  padding:.7rem 1.2rem;gap:0;
  flex:1;overflow-y:auto;
}
.mob-nav a{
  font-family:var(--font-display);
  font-size:clamp(1.25rem,5vw,1.7rem);
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--text-300);font-weight:300;
  padding:.5rem 0;
  border-bottom:1px solid var(--border);
  transition:color .2s,padding-left .2s;
  display:flex;align-items:center;justify-content:space-between;
}
.mob-nav a:last-child{border-bottom:none}
.mob-nav a::after{
  content:'→';font-family:var(--font-body);font-size:.8rem;
  color:var(--border-strong);transition:.2s;font-weight:300;
}
.mob-nav a:hover{color:var(--accent);padding-left:.4rem}
.mob-nav a:hover::after{color:var(--accent)}

/* bottom CTA + lang */
.mob-bottom{
  padding:.9rem 1.2rem;
  border-top:1px solid var(--border);
  display:flex;flex-direction:column;gap:.6rem;
  flex-shrink:0;
  padding-bottom:max(calc(env(safe-area-inset-bottom) + .9rem), 1rem);
}
.mob-book-btn{
  width:100%;padding:1rem;border-radius:4px;
  background:var(--accent);color:var(--bg-900);
  font-weight:600;font-size:.92rem;letter-spacing:.06em;
  display:flex;align-items:center;justify-content:center;gap:.6rem;transition:.2s;
}
.mob-book-btn:hover{background:var(--accent-bright)}
.mob-lang{
  display:flex;gap:.5rem;
}
.mob-lang .lang-btn{
  flex:1;padding:.55rem;border-radius:4px;
  font-size:.78rem;font-weight:600;letter-spacing:.06em;
  border:1px solid var(--border);color:var(--text-500);transition:.2s;
}
.mob-lang .lang-btn.active{background:var(--accent);color:var(--bg-900);border-color:var(--accent)}

/* ═══ HERO SLIDER ═══ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.hero-slides{position:absolute;inset:0}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.1s ease;pointer-events:none}
.hero-slide.active{opacity:1;pointer-events:auto}
.hero-slide-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.06);transition:transform 7s ease}
.hero-slide.active .hero-slide-bg{transform:scale(1)}
.hero-slide-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(to right,rgba(14,13,11,.95) 0%,rgba(14,13,11,.5) 55%,rgba(14,13,11,.1) 100%),
    linear-gradient(to top,rgba(14,13,11,.8) 0%,transparent 50%);
}
/* subtle warm grain texture */
.grain-overlay{
  position:absolute;inset:0;opacity:.04;mix-blend-mode:overlay;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
  background-size:200px;
}

.hero-content{position:relative;z-index:5;width:100%;padding:var(--nav-h) 0 0}
.hero-grid{display:grid;grid-template-columns:1.35fr .85fr;align-items:center;gap:3rem;min-height:90vh}

.hero-badge{
  display:inline-flex;align-items:center;gap:.6rem;margin-bottom:2rem;
  padding:.45rem 1rem;border-radius:2px;
  border:1px solid var(--border-strong);font-size:.7rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent);
}
.hero h1{margin-bottom:1.4rem;line-height:.9}
.hero-title-line{display:block;overflow:hidden;padding-top:.12em;padding-bottom:.08em}
html[lang="ru"] .hero h1{line-height:.98}
.hero-title-word{display:inline-block;transform:translateY(130%);transition:transform .8s var(--ease-out)}
.hero-content.in .hero-title-word{transform:translateY(0)}
.hero-title-word.tw2{transition-delay:.12s;color:var(--slide-accent,var(--accent));font-style:italic}
.hero-sub{
  font-size:clamp(.95rem,1.5vw,1.1rem);color:var(--text-300);max-width:36ch;margin-bottom:2.4rem;
  font-weight:300;line-height:1.75;
  opacity:0;transform:translateY(20px);transition:.6s .38s var(--ease-out);
}
.hero-content.in .hero-sub{opacity:1;transform:translateY(0)}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;
  opacity:0;transform:translateY(20px);transition:.6s .54s var(--ease-out)}
.hero-content.in .hero-actions{opacity:1;transform:translateY(0)}

/* floating therapist card */
.hero-card{
  position:relative;background:rgba(26,24,21,.75);border:1px solid var(--border-strong);
  border-radius:2px;padding:1.6rem;backdrop-filter:blur(20px);
  box-shadow:0 40px 100px rgba(0,0,0,.55);
  opacity:0;transform:translateY(30px) scale(.97);transition:.8s .42s var(--ease-out);
}
.hero-content.in .hero-card{opacity:1;transform:none}
.hero-card-photo{height:240px;border-radius:2px;background-size:cover;background-position:center top;margin-bottom:1.2rem;position:relative;overflow:hidden}
.hero-card-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(14,13,11,.65),transparent 60%)}
.hero-card-name{font-family:var(--font-display);font-size:1.9rem;letter-spacing:.04em;line-height:1;font-weight:300}
.hero-card-spec{font-size:.68rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--slide-accent,var(--accent));margin:.35rem 0 .8rem}
.hero-card-rating{display:flex;align-items:center;gap:.4rem;font-size:.82rem;color:var(--text-300)}
.hero-card-rating .ti{color:var(--accent)}
.hero-card-tag{position:absolute;top:1.1rem;right:1.1rem;background:rgba(14,13,11,.8);border:1px solid var(--border-strong);padding:.3rem .7rem;border-radius:2px;font-size:.64rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;z-index:2;color:var(--slide-accent,var(--accent))}

/* slider chrome */
.hero-bottom{position:absolute;bottom:36px;left:0;right:0;z-index:6}
.hero-bottom-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.slide-nav{display:flex;align-items:center;gap:1.4rem}
.slide-arrow{width:48px;height:48px;border-radius:50%;border:1px solid var(--border-strong);display:grid;place-items:center;font-size:1.1rem;color:var(--text-100);transition:.25s;background:rgba(255,255,255,.02)}
.slide-arrow:hover{background:var(--accent);color:var(--bg-900);border-color:var(--accent)}
.slide-dots{display:flex;gap:10px}
.slide-dot{width:36px;height:1px;border-radius:1px;background:rgba(255,255,255,.15);overflow:hidden;position:relative;transition:.3s}
.slide-dot.active{background:rgba(255,255,255,.2)}
.slide-dot .fill{position:absolute;inset:0;background:var(--accent);transform-origin:left;transform:scaleX(0)}
.slide-dot.active .fill{animation:slideProgress 5s linear forwards}
@keyframes slideProgress{from{transform:scaleX(0)}to{transform:scaleX(1)}}
.slide-counter{font-family:var(--font-display);font-size:1.6rem;letter-spacing:.1em;color:var(--text-500);font-weight:300}
.slide-counter b{color:var(--accent)}
.scroll-hint{display:flex;flex-direction:column;align-items:center;gap:.5rem;font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;color:var(--text-500)}
.scroll-hint .line{width:1px;height:36px;background:linear-gradient(to bottom,var(--accent),transparent);animation:scrollPulse 1.8s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* ═══ SECTION SHELL ═══ */
section{position:relative}
.section-pad{padding:clamp(5rem,10vw,9rem) 0}
.section-head{text-align:center;max-width:580px;margin:0 auto 3.5rem}
.section-head .eyebrow{margin-bottom:1.2rem}
.section-head .eyebrow::before{display:none}
.section-head h2{margin-bottom:1rem}
.section-head p{color:var(--text-300);font-size:.95rem;font-weight:300}

/* ═══ TRUST BAR ═══ */
.trust{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg-800)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.trust-item{padding:2.6rem 1rem;text-align:center;position:relative}
.trust-item:not(:last-child)::after{content:'';position:absolute;right:0;top:30%;height:40%;width:1px;background:linear-gradient(to bottom,transparent,var(--border-strong),transparent)}
.trust-num{font-family:var(--font-display);font-size:clamp(2.8rem,5vw,4rem);line-height:1;font-weight:300;color:var(--text-100)}
.trust-num .sfx{color:var(--accent)}
.trust-label{font-size:.72rem;color:var(--text-500);letter-spacing:.1em;margin-top:.6rem;text-transform:uppercase;font-weight:400}

/* ═══ SERVICES ═══ */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;border:1px solid var(--border);border-radius:4px;overflow:hidden;background:var(--border)}
.svc-card{
  background:var(--bg-700);padding:2rem;
  position:relative;overflow:hidden;
  transition:background .4s var(--ease-out);
}
.svc-card:hover{background:var(--bg-600)}
.svc-accent-line{position:absolute;top:0;left:0;right:0;height:2px;background:var(--tr-color,var(--accent));opacity:0;transition:opacity .4s}
.svc-card:hover .svc-accent-line{opacity:1}
.svc-top{display:flex;align-items:center;gap:.9rem;margin-bottom:1.4rem}
.svc-therapist-photo{width:42px;height:42px;border-radius:50%;background-size:cover;background-position:center;border:1.5px solid var(--tr-color,var(--accent));flex-shrink:0}
.svc-therapist-name{font-size:.76rem;font-weight:600;color:var(--text-100);letter-spacing:.04em}
.svc-therapist-role{font-size:.68rem;color:var(--text-500)}
.svc-badge{margin-left:auto;font-size:.62rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:.24rem .6rem;border-radius:2px;background:var(--accent-dim);color:var(--accent);border:1px solid var(--border-strong)}
.svc-name{font-family:var(--font-display);font-size:1.4rem;font-weight:300;margin-bottom:.5rem;color:var(--text-100);letter-spacing:.02em}
.svc-desc{font-size:.84rem;color:var(--text-300);margin-bottom:1.4rem;min-height:3.2em;line-height:1.6;font-weight:300}
.svc-meta{display:flex;align-items:flex-end;justify-content:space-between;gap:.5rem}
.svc-price{font-family:var(--font-display);font-size:2.6rem;line-height:.9;color:var(--text-100);font-weight:300}
.svc-price small{font-size:.78rem;color:var(--text-500);font-family:var(--font-body)}
.svc-dur{font-size:.75rem;color:var(--text-500);display:flex;align-items:center;gap:.3rem}
.svc-book-btn{
  width:100%;margin-top:1.4rem;padding:.75rem;border-radius:3px;font-weight:500;font-size:.82rem;
  background:transparent;border:1px solid var(--tr-color,var(--accent));color:var(--tr-color,var(--accent));
  transition:.3s;display:flex;align-items:center;justify-content:center;gap:.5rem;letter-spacing:.06em;
}
.svc-book-btn:hover{background:var(--tr-color,var(--accent));color:var(--bg-900)}

/* ═══ THERAPISTS ═══ */
.therapists-list{display:flex;flex-direction:column;gap:1px;border:1px solid var(--border);border-radius:4px;overflow:hidden}
.therapist-card{
  display:grid;grid-template-columns:38% 62%;background:var(--bg-700);
  transition:background .4s var(--ease-out);
}
.therapist-card:nth-child(even){grid-template-columns:62% 38%}
.therapist-card:nth-child(even) .therapist-photo-wrap{order:2}
.therapist-card:hover{background:var(--bg-600)}
.therapist-photo-wrap{position:relative;height:360px;overflow:hidden}
.therapist-photo{position:absolute;inset:0;background-size:cover;background-position:center 20%;transition:transform .8s var(--ease-out)}
.therapist-card:hover .therapist-photo{transform:scale(1.04)}
.therapist-photo-wrap::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(14,13,11,.55),transparent 55%)}
.therapist-quote{
  position:absolute;left:1.6rem;right:1.6rem;bottom:1.6rem;z-index:2;
  font-family:var(--font-display);font-style:italic;font-size:1.05rem;color:rgba(255,255,255,.9);
  opacity:0;transform:translateY(14px);transition:.5s var(--ease-out);
  line-height:1.4;font-weight:300;
}
.therapist-card:hover .therapist-quote{opacity:1;transform:translateY(0)}
.therapist-body{padding:2.4rem;display:flex;flex-direction:column;justify-content:center}
.therapist-name{font-family:var(--font-display);font-size:clamp(2.2rem,3.5vw,3rem);line-height:1;letter-spacing:.02em;font-weight:300;margin-bottom:.4rem}
.therapist-role{font-size:.7rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--tr-color,var(--accent));margin-bottom:1.2rem}
.therapist-bio{font-size:.86rem;color:var(--text-300);margin-bottom:1.4rem;line-height:1.75;font-weight:300}
.therapist-stats{display:flex;gap:.7rem;flex-wrap:wrap;margin-bottom:1.3rem}
.stat-pill{display:flex;align-items:center;gap:.4rem;padding:.42rem .85rem;border-radius:2px;background:var(--bg-900);border:1px solid var(--border);font-size:.78rem;font-weight:500;letter-spacing:.04em}
.stat-pill .ti{font-size:.9rem;color:var(--accent)}
.therapist-certs{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.6rem}
.cert-tag{font-size:.68rem;padding:.26rem .62rem;border-radius:2px;background:var(--accent-dim);color:var(--accent-bright);font-weight:400;letter-spacing:.04em}
.therapist-actions{display:flex}

/* ═══ GALLERY ═══ */
.gallery-grid{columns:4;column-gap:1px;background:var(--border);border:1px solid var(--border);border-radius:4px;overflow:hidden}
.gallery-item{position:relative;break-inside:avoid;margin-bottom:1px;overflow:hidden;cursor:pointer}
.gallery-item img{width:100%;transition:transform .7s var(--ease-out)}
.gallery-item::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(14,13,11,.7),transparent);opacity:0;transition:.4s}
.gallery-item .zoom-ic{position:absolute;inset:0;display:grid;place-items:center;font-size:1.6rem;color:#fff;opacity:0;transition:.4s;z-index:2}
.gallery-item:hover img{transform:scale(1.05)}
.gallery-item:hover::after{opacity:.5}
.gallery-item:hover .zoom-ic{opacity:1}

/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:1200;background:rgba(10,9,7,.97);display:none;align-items:center;justify-content:center}
.lightbox.open{display:flex}
.lightbox img{max-width:88vw;max-height:84vh;border-radius:2px;box-shadow:0 40px 100px rgba(0,0,0,.7)}
.lb-close{position:absolute;top:24px;right:28px;font-size:2rem;color:var(--text-300)}
.lb-arrow{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;border:1px solid var(--border-strong);display:grid;place-items:center;font-size:1.3rem;background:rgba(255,255,255,.03);color:#fff;transition:.25s}
.lb-arrow:hover{background:var(--accent);color:var(--bg-900);border-color:var(--accent)}
.lb-prev{left:28px}.lb-next{right:28px}

/* ═══ REVIEWS ═══ */
.reviews-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;border:1px solid var(--border);border-radius:4px;overflow:hidden;background:var(--border)}
.review-card{background:var(--bg-700);padding:2rem;position:relative;transition:background .4s}
.review-card:hover{background:var(--bg-600)}
.review-card::before{content:'\\201C';position:absolute;top:.2rem;right:1.6rem;font-family:var(--font-display);font-size:6rem;color:var(--accent-dim);line-height:1;font-weight:300}
.review-stars{display:flex;gap:3px;margin-bottom:1.1rem;color:var(--accent)}
.review-text{font-size:.92rem;color:var(--text-100);margin-bottom:1.4rem;position:relative;z-index:1;font-weight:300;line-height:1.7}
.review-author{display:flex;align-items:center;gap:.8rem}
.review-avatar{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-weight:600;font-size:.86rem;color:var(--bg-900)}
.review-name{font-weight:500;font-size:.9rem}
.review-role{font-size:.74rem;color:var(--text-500)}

/* ═══ CONTACT ═══ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;border:1px solid var(--border);border-radius:4px;overflow:hidden;background:var(--border)}
.contact-card{background:var(--bg-700);padding:2.4rem}
.contact-row{display:flex;align-items:flex-start;gap:1rem;padding:1.1rem 0;border-bottom:1px solid var(--border)}
.contact-row:last-child{border-bottom:none}
.contact-ic{width:42px;height:42px;border-radius:2px;display:grid;place-items:center;background:var(--accent-dim);color:var(--accent);font-size:1.2rem;flex-shrink:0}
.contact-label{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-500);margin-bottom:.2rem}
.contact-val{font-size:.92rem;color:var(--text-100);font-weight:400}
.contact-side{background:var(--bg-700);padding:2.4rem;display:flex;flex-direction:column;position:relative;overflow:hidden}
.contact-side h3{font-family:var(--font-display);font-size:2.2rem;letter-spacing:.02em;margin-bottom:.6rem;font-weight:300}
.contact-side p{color:var(--text-300);font-size:.88rem;margin-bottom:1.8rem;font-weight:300;line-height:1.7}
.hours-table{margin-bottom:1.8rem}
.hours-table .row{display:flex;justify-content:space-between;padding:.7rem 0;border-bottom:1px solid var(--border);font-size:.88rem}
.hours-table .row span:first-child{color:var(--text-300)}
.hours-table .row span:last-child{color:var(--accent-bright);font-weight:500}
.social-row{display:flex;gap:.8rem;margin-top:auto}
.social-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.85rem;border-radius:3px;font-weight:500;font-size:.84rem;transition:.25s;border:1px solid var(--border-strong)}
.social-btn.ig{background:linear-gradient(135deg,#833ab4,#fd1d1d,#fcb045);color:#fff;border:none}
.social-btn.wa{background:rgba(37,211,102,.06);color:#25D366;border-color:rgba(37,211,102,.3)}
.social-btn:hover{transform:translateY(-2px)}

/* ═══ FOOTER ═══ */
footer{border-top:1px solid var(--border);background:var(--bg-800);padding:3.5rem 0 2rem}
.footer-grid{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;margin-bottom:2.2rem}
.footer-tag{color:var(--text-500);font-size:.86rem;max-width:38ch;font-weight:300;margin-top:.4rem}
.footer-bottom{padding-top:1.6rem;border-top:1px solid var(--border);display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.76rem;color:var(--text-500)}

/* ═══ BOOKING DRAWER ═══ */
.drawer-bg{position:fixed;inset:0;z-index:1300;background:rgba(8,7,5,.72);backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:.3s}
.drawer-bg.open{opacity:1;pointer-events:auto}
.drawer{
  position:fixed;top:0;right:0;bottom:0;width:min(460px,100vw);z-index:1310;
  background:var(--bg-800);border-left:1px solid var(--border-strong);
  transform:translateX(100%);transition:transform .4s var(--ease-out);
  display:flex;flex-direction:column;
}
.drawer.open{transform:none}
.drawer-head{padding:1.4rem 1.6rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.drawer-head h3{font-family:var(--font-display);font-size:1.7rem;letter-spacing:.04em;font-weight:300}
.drawer-close{font-size:1.4rem;color:var(--text-300)}
.drawer-body{flex:1;overflow-y:auto;padding:1.6rem}
.bk-step{margin-bottom:1.8rem}
.bk-step-label{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-500);margin-bottom:.8rem;display:flex;align-items:center;gap:.6rem}
.bk-step-label .n{width:20px;height:20px;border-radius:50%;background:var(--accent-dim);color:var(--accent);display:grid;place-items:center;font-size:.68rem;font-weight:700}
.bk-options{display:flex;flex-wrap:wrap;gap:.6rem}
.bk-opt{padding:.6rem 1rem;border-radius:3px;border:1px solid var(--border);background:var(--bg-700);font-size:.82rem;font-weight:400;transition:.2s;display:flex;align-items:center;gap:.5rem}
.bk-opt:hover{border-color:var(--border-strong)}
.bk-opt.sel{background:var(--accent);color:var(--bg-900);border-color:var(--accent)}
.bk-opt .av{width:22px;height:22px;border-radius:50%;background-size:cover}
.bk-svc-opt{width:100%;display:flex;justify-content:space-between;align-items:center}
.bk-svc-opt .pr{font-weight:600;font-family:var(--font-display);font-size:1.15rem}
.bk-slots{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}
.bk-slot{padding:.55rem;border-radius:3px;border:1px solid var(--border);background:var(--bg-700);font-size:.78rem;font-weight:500;transition:.2s;text-align:center}
.bk-slot:hover{border-color:var(--accent)}
.bk-slot.sel{background:var(--accent);color:var(--bg-900);border-color:var(--accent)}
.bk-field{margin-bottom:1rem}
.bk-field label{display:block;font-size:.78rem;color:var(--text-300);margin-bottom:.4rem;font-weight:500;letter-spacing:.04em}
.bk-input{width:100%;padding:.8rem 1rem;border-radius:3px;background:var(--bg-700);border:1px solid var(--border);color:var(--text-100);font-family:inherit;font-size:.88rem;transition:.2s}
.bk-input:focus{outline:none;border-color:var(--accent)}
.bk-input::placeholder{color:var(--text-500)}
textarea.bk-input{resize:vertical;min-height:70px}
.bk-date{margin-bottom:.9rem}
.bk-days{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.6rem;margin-bottom:1rem;scrollbar-width:thin}
.bk-days::-webkit-scrollbar{height:4px}
.bk-day{flex:0 0 auto;width:60px;padding:.6rem .3rem;border-radius:3px;border:1px solid var(--border);background:var(--bg-700);display:flex;flex-direction:column;align-items:center;gap:.15rem;transition:.2s}
.bk-day:hover:not(.full){border-color:var(--accent);transform:translateY(-2px)}
.bk-day .dow{font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-500)}
.bk-day .dnum{font-family:var(--font-display);font-size:1.5rem;line-height:1;color:var(--text-100);font-weight:300}
.bk-day .dfree{font-size:.56rem;color:var(--accent);font-weight:500}
.bk-day.sel{background:var(--accent);border-color:var(--accent)}
.bk-day.sel .dow,.bk-day.sel .dnum,.bk-day.sel .dfree{color:var(--bg-900)}
.bk-day.full{opacity:.35;cursor:not-allowed}
.bk-day.full .dfree{color:var(--text-500)}
.bk-slots-wrap{min-height:44px}
.bk-slots-empty{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;border:1px dashed var(--border);border-radius:3px;color:var(--text-500);font-size:.82rem}
.bk-slots-empty .ti{color:var(--accent)}
.drawer-foot{padding:1.3rem 1.6rem;border-top:1px solid var(--border)}
.bk-summary{font-size:.82rem;color:var(--text-300);margin-bottom:.9rem;display:flex;justify-content:space-between}
.bk-summary b{color:var(--accent)}
.bk-success{text-align:center;padding:3rem 1.5rem}
.bk-success .ic{width:72px;height:72px;border-radius:50%;background:var(--accent-dim);color:var(--accent);display:grid;place-items:center;font-size:2.2rem;margin:0 auto 1.4rem}
.bk-success h3{font-family:var(--font-display);font-size:2.2rem;letter-spacing:.04em;margin-bottom:.6rem;font-weight:300}
.bk-success p{color:var(--text-300);margin-bottom:1.8rem;font-weight:300}

/* Toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%,120%);z-index:1400;background:var(--bg-600);border:1px solid var(--border-strong);color:var(--text-100);padding:.85rem 1.4rem;border-radius:3px;font-size:.86rem;font-weight:400;box-shadow:0 20px 50px rgba(0,0,0,.5);transition:transform .4s var(--ease-out);display:flex;align-items:center;gap:.6rem}
.toast.show{transform:translate(-50%,0)}
.toast .ti{color:var(--accent)}

/* ═══ SCROLL ANIMATIONS ═══ */
.anim-up,.anim-left,.anim-scale{opacity:0;transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.anim-up{transform:translateY(36px)}
.anim-left{transform:translateX(-36px)}
.anim-scale{transform:scale(.94)}
.anim-up.visible,.anim-left.visible,.anim-scale.visible{opacity:1;transform:none}
.anim-delay-1{transition-delay:.1s}.anim-delay-2{transition-delay:.2s}.anim-delay-3{transition-delay:.3s}
.anim-delay-4{transition-delay:.4s}.anim-delay-5{transition-delay:.5s}.anim-delay-6{transition-delay:.6s}

/* ═══ RESPONSIVE ═══ */

/* ── Tablet wide ── */
@media(max-width:1100px){
  .hero-grid{gap:2rem}
  .hero-card-photo{height:200px}
  .services-grid{grid-template-columns:repeat(2,1fr)}
}

/* ── Tablet ── */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr}
  .hero-card{display:none}
  .hero-sub{max-width:52ch}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{columns:3}
  .reviews-grid,.contact-grid{grid-template-columns:1fr}
  .therapist-card,.therapist-card:nth-child(even){grid-template-columns:1fr}
  .therapist-card:nth-child(even) .therapist-photo-wrap{order:0}
  .therapist-photo-wrap{height:300px}
  .therapist-quote{opacity:1;transform:none}
  .contact-side{min-height:300px}
}

/* ── Mobile landscape / small tablet ── */
@media(max-width:760px){
  :root{--nav-h:58px}

  /* NAV */
  .nav-links{display:none}
  .burger{display:flex}
  .nav-right .lang-switch{display:none}
  .nav-cta{padding:.48rem .85rem;font-size:.76rem;letter-spacing:.03em}
  .logo{font-size:1.5rem;gap:.5rem}
  .logo-sub{display:none}

  /* DEMO BANNER */
  .demo-banner{padding:5px 12px;gap:10px;font-size:.72rem}
  .demo-banner .bn-sep{display:none}

  /* HERO */
  .hero{min-height:90vh}
  .hero-content{padding-top:0}
  .hero-grid{min-height:85vh;padding-top:calc(var(--nav-h) + 32px);padding-bottom:80px;align-content:center}
  .hero-badge{margin-bottom:1rem;font-size:.65rem;padding:.38rem .8rem}
  .hero h1{margin-bottom:1.1rem}
  .hero-sub{max-width:100%;margin-bottom:1.6rem}
  .hero-actions{flex-wrap:nowrap;gap:.7rem}
  .hero-bottom{bottom:16px}
  .hero-bottom-inner .scroll-hint{display:none}
  .slide-nav{gap:.8rem}
  .slide-arrow{width:38px;height:38px;font-size:1rem}
  .slide-counter{font-size:1.2rem}
  .slide-dot{width:28px}

  /* TRUST */
  .trust-grid{grid-template-columns:repeat(2,1fr)}
  .trust-item{padding:1.6rem .8rem}
  .trust-item:nth-child(2)::after{display:none}
  .trust-num{font-size:clamp(2.2rem,7vw,3rem)}

  /* SERVICES */
  .services-grid{grid-template-columns:1fr;border-radius:3px}
  .svc-card{padding:1.5rem}

  /* THERAPISTS */
  .therapist-photo-wrap{height:240px}
  .therapist-body{padding:1.4rem}
  .therapist-name{font-size:clamp(1.8rem,6vw,2.4rem)}
  .therapist-stats{gap:.4rem}
  .stat-pill{font-size:.72rem;padding:.36rem .7rem}

  /* GALLERY */
  .gallery-grid{columns:2;gap:.6px}

  /* REVIEWS */
  .reviews-grid{grid-template-columns:1fr;gap:.6px}
  .review-card{padding:1.5rem}

  /* CONTACT */
  .contact-grid{gap:.6px}
  .contact-card,.contact-side{padding:1.4rem}
  .social-row{flex-direction:column;gap:.5rem}
  .social-btn{width:100%}

  /* SECTION HEADS */
  .section-head{margin-bottom:2rem}
  .section-pad{padding:clamp(3rem,7vw,5rem) 0}

  /* FOOTER */
  .footer-grid{flex-direction:column;align-items:flex-start;gap:1rem}

  /* BOOKING DRAWER */
  .drawer{width:100vw;border-left:none;border-top:1px solid var(--border-strong);border-radius:16px 16px 0 0;top:auto;height:92dvh}
  .drawer-head{padding:1rem 1.4rem}
  .drawer-body{padding:1.2rem 1.4rem}
  .drawer-foot{padding:1rem 1.4rem}
  .bk-slots{grid-template-columns:repeat(3,1fr)}
}

/* ── Mobile portrait ── */
@media(max-width:480px){
  /* HERO */
  .hero-actions{flex-direction:column;width:100%}
  .hero-actions .btn{width:100%;justify-content:center}

  /* GALLERY */
  .gallery-grid{columns:1}

  /* TRUST */
  .trust-item{padding:1.4rem .6rem}

  /* THERAPIST STATS */
  .therapist-stats{flex-direction:column;gap:.4rem}

  /* SERVICES */
  .svc-price{font-size:2rem}

  /* BOOKING */
  .bk-day{width:50px}
  .bk-slots{grid-template-columns:repeat(3,1fr)}
  .bk-opt{font-size:.78rem;padding:.5rem .8rem}

  /* CONTACT */
  .hours-table .row{font-size:.82rem}
}

/* ── Small mobile ── */
@media(max-width:380px){
  :root{--nav-h:54px}
  .demo-banner{font-size:.64rem;gap:6px}
  .demo-banner .dot{display:none}
  .logo{font-size:1.3rem}
  .nav-cta{padding:.42rem .7rem;font-size:.72rem}
  .trust-grid{grid-template-columns:repeat(2,1fr)}
  .trust-num{font-size:2rem}
  .slide-dot{width:22px}
  .slide-counter{font-size:1rem}
  .bk-day{width:44px}
  .bk-day .dnum{font-size:1.2rem}
  .bk-slots{grid-template-columns:repeat(2,1fr)}
  .hero h1{font-size:clamp(2.6rem,10vw,3.6rem)}
}

/* ── Safe area for notched phones ── */
@supports(padding-top: env(safe-area-inset-top)){
  .navbar.scrolled{top:0}
  .demo-banner{padding-top:max(7px, env(safe-area-inset-top))}
}
