/* =========================================================
   dafna. — design system (faithful continuation)
   Pure monochrome: bone + cream + charcoal + photography.
   No accent color. Hebrew headings = bold sans, centered.
   Serif used ONLY for the Latin "Let's Do It."
   Slim translucent-dark header · cream pills · hairlines ·
   minimal bone footer · underline-input closer.
   ========================================================= */

:root{
  --bone:   #f2f1ec;   /* page background (sampled) */
  --cream:  #fbfaf6;   /* cards & the "בואו נדבר" pill */
  --sand:   #eae8e1;   /* subtle alternate section */
  --dark:   #2b2926;   /* charcoal panel / hero overlay / gift card */
  --dark-2: #211f1c;

  --ink:    #33312d;   /* primary text (from the dafna. logo) */
  --ink-2:  #56544e;   /* secondary text */
  --muted:  #8a877f;   /* captions, labels */
  --muted-2:#a6a299;

  --line:   rgba(47,46,43,.16);
  --line-2: rgba(47,46,43,.09);
  --on-dark:rgba(255,255,255,.20);

  --sans: 'Assistant','Heebo',system-ui,sans-serif;
  --serif:'Lora','Cormorant Garamond',serif;   /* Latin only */
  --round:'Comfortaa','Assistant',sans-serif;   /* the dafna. wordmark */

  --container:1240px;
  --wide:1440px;
  --gutter:clamp(20px,5vw,70px);
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-2:cubic-bezier(.16,1,.3,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);background:var(--bone);color:var(--ink);
  line-height:1.75;font-weight:400;letter-spacing:.005em;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden;
}
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(--dark);color:var(--bone)}

/* ---------- layout ---------- */
.wrap{max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.wide{max-width:var(--wide);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(66px,9.5vw,148px)}
.section-sm{padding-block:clamp(44px,6vw,80px)}
.bg-sand{background:var(--sand)}

/* ---------- type ---------- */
h1,h2,h3,h4{font-weight:600;line-height:1.2;color:var(--ink);letter-spacing:-.02em}
.kicker{
  display:block;font-size:.7rem;letter-spacing:.4em;text-transform:uppercase;
  color:var(--muted);font-weight:600;margin-bottom:1.3rem;
}
.h1{font-size:clamp(2.2rem,4.9vw,3.9rem);line-height:1.1;font-weight:600}
.h2{font-size:clamp(1.8rem,3.4vw,2.9rem);line-height:1.14;font-weight:600}
.h3{font-size:1.3rem;font-weight:600}
.lead{font-size:clamp(1.02rem,1.45vw,1.2rem);color:var(--ink-2);font-weight:300;line-height:1.85}
.muted{color:var(--muted)}
.lets{font-family:var(--serif);font-weight:500;letter-spacing:.005em}

/* centered section header with hairline (homepage pattern) */
.sec-head{max-width:60ch;margin-inline:auto;text-align:center}
.sec-head .h2{margin-bottom:1rem}
.sec-head p{color:var(--ink-2);font-weight:300}
.sec-head.left{margin-inline:0;text-align:start}
.hairline{width:46px;height:1px;background:var(--ink);margin:1.3rem auto 0;opacity:.5}
.sec-head.left .hairline{margin-inline:0}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  font-size:.92rem;font-weight:600;letter-spacing:.01em;transition:.4s var(--ease);
  white-space:nowrap;
}
.btn svg{width:1em;height:1em;transition:transform .4s var(--ease)}
.btn-cream{background:var(--cream);color:var(--ink);border:1px solid var(--line);
  padding:.86em 2em;border-radius:100px}
.btn-cream:hover{background:var(--dark);color:var(--bone);border-color:var(--dark)}
.btn-cream:hover svg{transform:translateX(-4px)}
.btn-dark{background:var(--dark);color:var(--bone);border:1px solid var(--dark);
  padding:.86em 2em;border-radius:100px}
.btn-dark:hover{background:transparent;color:var(--ink)}
.btn-dark:hover svg{transform:translateX(-4px)}
.btn-outline{background:transparent;color:var(--ink);border:1px solid var(--line);
  padding:.62em 1.4em;border-radius:3px;font-size:.82rem;letter-spacing:.04em;font-weight:500}
.btn-outline:hover{border-color:var(--ink);background:var(--ink);color:var(--bone)}
.btn-link{font-weight:600;font-size:.9rem;border-bottom:1px solid var(--ink);padding-bottom:3px;gap:.5em}
.btn-link svg{width:.82em}
.btn-link:hover{opacity:.6}
.btn-link:hover svg{transform:translateX(-4px)}

/* ---------- header (slim translucent dark, consistent) ---------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:120;
  background:rgba(35,33,29,.55);
  transition:background .45s var(--ease);
}
.site-header.solid{background:rgba(31,29,26,.97)}
.bar{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;height:60px}
.header-start{display:flex;align-items:center;gap:1.1rem}
.pill-cta{background:var(--cream);color:var(--ink);border-radius:100px;
  padding:.52em 1.35em;font-size:.85rem;font-weight:600;transition:.35s var(--ease)}
.pill-cta:hover{background:#fff;transform:translateY(-1px)}
.socials{display:flex;align-items:center;gap:.85rem}
.socials a{color:rgba(255,255,255,.78);transition:.3s;display:grid;place-items:center}
.socials a:hover{color:#fff}
.socials svg{width:16px;height:16px}
.nav{display:flex;align-items:center;gap:1.9rem}
.nav a{font-size:.92rem;font-weight:500;color:rgba(255,255,255,.82);position:relative;padding:3px 0;transition:color .3s}
.nav a::after{content:"";position:absolute;inset:auto 0 -2px 0;height:1px;background:#fff;
  transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease)}
.nav a:hover,.nav a[aria-current]{color:#fff}
.nav a:hover::after,.nav a[aria-current]::after{transform:scaleX(1)}
.header-end{display:flex;align-items:center;gap:1.1rem}
.cart{color:rgba(255,255,255,.82);display:grid;place-items:center;transition:.3s}
.cart:hover{color:#fff}.cart svg{width:19px;height:19px}
.menu-toggle{display:none;color:#fff}

/* mobile nav */
.mobile-nav{position:fixed;inset:0;z-index:115;background:var(--bone);
  padding:90px var(--gutter) 40px;display:flex;flex-direction:column;gap:.2rem;
  transform:translateY(-100%);transition:transform .55s var(--ease-2);visibility:hidden}
.mobile-nav.open{transform:translateY(0);visibility:visible}
.mobile-nav a{font-size:1.7rem;font-weight:600;padding:.55rem 0;border-bottom:1px solid var(--line-2)}
.mobile-nav .m-foot{margin-top:auto;color:var(--muted);font-size:.85rem;display:flex;gap:1rem}

/* ---------- reveal ---------- */
[data-reveal]{opacity:0;transform:translateY(22px);transition:opacity .9s var(--ease-2),transform .9s var(--ease-2)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal][data-delay="1"]{transition-delay:.08s}
[data-reveal][data-delay="2"]{transition-delay:.16s}
[data-reveal][data-delay="3"]{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){[data-reveal]{opacity:1;transform:none;transition:none}}

/* =========================================================
   HERO — dark full-bleed photo + overlaid text (archive)
   matches the existing treatments hero exactly
   ========================================================= */
.hero-dark{position:relative;min-height:clamp(600px,92vh,920px);display:flex;align-items:flex-end;
  color:#fff;isolation:isolate;overflow:hidden}
.hero-dark img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;
  transform-origin:60% 40%;animation:kenburns 22s ease-in-out infinite alternate}
@keyframes kenburns{from{transform:scale(1.02)}to{transform:scale(1.12)}}
@media (prefers-reduced-motion:reduce){.hero-dark img{animation:none}}
/* cinematic heading entrance */
.hero-box .h1{overflow:hidden}
.hero-box .h1>span{display:inline-block;transform:translateY(110%);transition:transform 1.1s var(--ease-2) .15s}
.hero-dark.reveal-on .hero-box .h1>span{transform:translateY(0)}
.hero-box .kicker,.hero-box>p,.hero-box .btn,.hero-box .hairline{opacity:0;transform:translateY(20px);transition:opacity .9s var(--ease-2),transform .9s var(--ease-2)}
.hero-dark.reveal-on .hero-box .kicker{transition-delay:.1s}
.hero-dark.reveal-on .hero-box>p{transition-delay:.45s}
.hero-dark.reveal-on .hero-box .btn{transition-delay:.6s}
.hero-dark.reveal-on .hero-box .hairline{transition-delay:.72s}
.hero-dark.reveal-on .hero-box .kicker,.hero-dark.reveal-on .hero-box>p,
.hero-dark.reveal-on .hero-box .btn,.hero-dark.reveal-on .hero-box .hairline{opacity:1;transform:none}
/* scroll cue */
.hero-cue{position:absolute;bottom:26px;inset-inline-start:50%;transform:translateX(50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:.6rem;color:rgba(255,255,255,.7);
  font-size:.66rem;letter-spacing:.3em;text-transform:uppercase}
.hero-cue .line{width:1px;height:46px;background:linear-gradient(rgba(255,255,255,.7),transparent);position:relative;overflow:hidden}
.hero-cue .line::after{content:"";position:absolute;inset:0;background:#fff;animation:cue 2.2s var(--ease) infinite}
@keyframes cue{0%{transform:translateY(-100%)}60%,100%{transform:translateY(100%)}}
.hero-dark::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(20,18,15,.5) 0%,rgba(20,18,15,.15) 35%,rgba(18,16,13,.72) 100%)}
.hero-dark .hero-inner{padding-block:clamp(48px,8vw,110px);width:100%}
.hero-dark .hero-box{max-width:52ch;text-align:center;margin-inline:auto}
.hero-dark .kicker{color:rgba(255,255,255,.72)}
.hero-dark h1{color:#fff;margin-bottom:1.2rem}
.hero-dark p{color:rgba(255,255,255,.88);font-weight:300;font-size:clamp(1rem,1.4vw,1.16rem);
  max-width:50ch;margin:0 auto 2rem}
.hero-dark .hairline{background:#fff;opacity:.5}

/* HERO — light split (single treatment / gift), about-page composition */
.hero-split{padding-top:60px}
.hero-split .grid{display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(30px,5vw,72px);align-items:center;
  padding-block:clamp(48px,7vw,96px)}
.hero-split .copy{max-width:48ch}
.hero-split h1{margin:.3rem 0 1.3rem}
.hero-split .lead{margin-bottom:2rem}
.hero-figure{position:relative;border-radius:6px;overflow:hidden;aspect-ratio:4/4.5;
  box-shadow:0 40px 80px -46px rgba(38,36,31,.5)}
.hero-figure img{width:100%;height:100%;object-fit:cover}
.crumbs{font-size:.82rem;color:var(--muted);display:flex;gap:.5em;align-items:center;margin-bottom:1.4rem}
.crumbs a:hover{color:var(--ink)}.crumbs i{opacity:.45;font-style:normal}
.cta-row{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}

/* =========================================================
   3-column bullet section (the "טיפולים מכניים" pattern)
   ========================================================= */
.bullets{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(28px,5vw,64px);text-align:center}
.bullet{display:flex;flex-direction:column;align-items:center;padding-inline:.5rem;position:relative}
.bullet+.bullet::before{content:"";position:absolute;inset-block:6px;inset-inline-start:calc(-1*clamp(14px,2.5vw,32px));
  width:1px;background:var(--line-2)}
.bullet .dot{width:7px;height:7px;border-radius:50%;background:var(--ink);margin-bottom:1.3rem}
.bullet h3{font-size:1.18rem;margin-bottom:.7rem}
.bullet p{color:var(--ink-2);font-weight:300;font-size:.98rem;max-width:34ch}

/* =========================================================
   FILTER TABS (minimal text + hairline underline)
   ========================================================= */
.filters{display:flex;justify-content:center;flex-wrap:wrap;gap:.5rem 2.3rem;
  padding-bottom:clamp(34px,4.5vw,60px);border-bottom:1px solid var(--line-2)}
.filter-tab{font-size:.92rem;font-weight:500;letter-spacing:.01em;color:var(--muted);padding:.4em 0;position:relative;transition:color .3s}
.filter-tab:hover{color:var(--ink)}
.filter-tab.active{color:var(--ink)}
.filter-tab.active::after{content:"";position:absolute;inset:auto 0 -1px 0;height:1.5px;background:var(--ink)}

/* =========================================================
   TREATMENT CARDS (cream, minimal — testimonial-card DNA)
   ========================================================= */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.6vw,36px)}
.card{
  background:var(--cream);border:1px solid var(--line-2);border-radius:3px;
  padding:clamp(1.8rem,2.8vw,2.5rem);display:flex;flex-direction:column;position:relative;
  transition:transform .55s var(--ease),box-shadow .55s var(--ease),border-color .55s;
}
.card:hover{transform:translateY(-6px);box-shadow:0 36px 64px -42px rgba(38,36,31,.34);border-color:var(--line)}
.card.is-hidden{display:none}
.card .cat{font-size:.68rem;letter-spacing:.32em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:1.3rem}
.card h3{font-size:1.42rem;font-weight:600;letter-spacing:-.02em;margin-bottom:.75rem;line-height:1.25}
.card .desc{color:var(--ink-2);font-weight:300;font-size:.98rem;line-height:1.72;margin-bottom:1.5rem}
.card .tags{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:1.7rem}
.tag{font-size:.72rem;letter-spacing:.02em;color:var(--muted);border:1px solid var(--line);border-radius:100px;
  padding:.3em .95em;font-weight:500}
.card .meta{display:flex;align-items:flex-end;gap:.9rem;font-size:.84rem;color:var(--muted);
  padding-block:1.3rem;border-top:1px solid var(--line-2);margin-top:auto;margin-bottom:1.4rem}
.card .meta .sep{align-self:center;width:3px;height:3px;border-radius:50%;background:var(--muted-2)}
.card .meta .price{display:inline-flex;flex-direction:column;line-height:1.25}
.card .meta .price .lbl{font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;color:var(--muted-2)}
.card .meta .price .v{color:var(--ink);font-weight:600;font-size:1.18rem;letter-spacing:-.01em}
.card .meta .dur{align-self:flex-end;padding-bottom:1px}
.card .btn-outline{align-self:flex-start}
.card .stretch{position:absolute;inset:0;z-index:1}
.card .btn-outline{position:relative;z-index:2}

/* featured wide card (photo) — restrained, monochrome */
.card-feature{grid-column:span 2;display:grid;grid-template-columns:1fr 1fr;background:var(--cream);
  border:1px solid var(--line-2);border-radius:4px;overflow:hidden}
.card-feature .ph{position:relative;min-height:300px;overflow:hidden}
.card-feature .ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform 1s var(--ease)}
.card-feature:hover .ph img{transform:scale(1.05)}
.card-feature .cf-body{padding:clamp(1.6rem,2.6vw,2.4rem);display:flex;flex-direction:column;justify-content:center}
.card-feature h3{font-size:clamp(1.5rem,2.4vw,2rem);margin-bottom:.7rem}

/* =========================================================
   EDITORIAL FEATURE + INDEX (luxury catalog)
   ========================================================= */
.feature{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(30px,5vw,76px);align-items:center;
  margin-bottom:clamp(46px,6vw,84px)}
.feature.is-hidden{display:none}
.feature .ph{position:relative;aspect-ratio:5/4;border-radius:3px;overflow:hidden;
  box-shadow:0 44px 80px -50px rgba(38,36,31,.5)}
.feature .ph img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.feature:hover .ph img{transform:scale(1.04)}
.feature .ph .ribbon{position:absolute;top:1.1rem;inset-inline-start:1.1rem;background:var(--bone);
  font-size:.64rem;letter-spacing:.28em;text-transform:uppercase;font-weight:600;color:var(--ink);
  padding:.5em 1em;border-radius:100px}
.feature .fbody{max-width:46ch}
.feature .cat{font-size:.68rem;letter-spacing:.34em;text-transform:uppercase;color:var(--muted);font-weight:600;display:block;margin-bottom:1rem}
.feature h3{font-size:clamp(1.9rem,3.2vw,2.8rem);font-weight:600;letter-spacing:-.025em;line-height:1.1;margin-bottom:1rem}
.feature .desc{color:var(--ink-2);font-weight:300;font-size:1.08rem;line-height:1.8;margin-bottom:1.5rem}
.feature .tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}
.feature .fmeta{display:flex;align-items:flex-end;gap:1.4rem;margin-bottom:2rem}
.feature .price{display:flex;flex-direction:column;line-height:1.2}
.feature .price .lbl{font-size:.62rem;letter-spacing:.26em;text-transform:uppercase;color:var(--muted-2)}
.feature .price .v{font-size:1.7rem;font-weight:600;letter-spacing:-.01em}
.feature .dur{color:var(--muted);font-size:.9rem;padding-bottom:4px}

/* marquee strip (faithful to the existing brand band) */
.marquee{overflow:hidden;border-block:1px solid var(--line-2);background:var(--bone);padding-block:1.1rem}
.marquee-track{display:flex;width:max-content;animation:marquee 38s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{font-size:.82rem;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);
  font-weight:600;padding-inline:1.6rem;display:inline-flex;align-items:center;gap:1.6rem;white-space:nowrap}
.marquee-track span::after{content:"";width:5px;height:5px;border-radius:50%;background:var(--muted-2)}
@keyframes marquee{to{transform:translateX(50%)}}
@media (prefers-reduced-motion:reduce){.marquee-track{animation:none}}

/* ---------- catalog toolbar (search · sort · count) ---------- */
.toolbar{display:flex;justify-content:space-between;align-items:center;gap:1rem 1.4rem;flex-wrap:wrap;
  margin-top:clamp(20px,3vw,30px)}
.search{display:flex;align-items:center;gap:.6rem;background:var(--cream);border:1px solid var(--line);
  border-radius:100px;padding:.62em 1.3em;flex:1;min-width:220px;max-width:380px;transition:border-color .3s}
.search:focus-within{border-color:var(--ink)}
.search svg{width:16px;height:16px;color:var(--muted);flex:0 0 auto}
.search input{border:none;background:none;font-family:inherit;font-size:.95rem;color:var(--ink);width:100%;outline:none}
.search input::placeholder{color:var(--muted)}
.tb-right{display:flex;align-items:center;gap:1.3rem;flex-wrap:wrap}
.count{font-size:.82rem;color:var(--muted);letter-spacing:.02em;white-space:nowrap}
.count b{color:var(--ink);font-weight:600}
.sort-wrap{position:relative;display:flex;align-items:center}
.sort-wrap svg{position:absolute;inset-inline-start:1.1em;pointer-events:none;width:13px;color:var(--muted)}
.sort-wrap select{appearance:none;background:var(--cream);border:1px solid var(--line);border-radius:100px;
  padding:.62em 2.6em .62em 1.3em;font-family:inherit;font-size:.9rem;color:var(--ink);cursor:pointer;transition:border-color .3s}
.sort-wrap select:hover{border-color:var(--ink)}
.load-more-wrap{text-align:center;margin-top:clamp(30px,4vw,52px)}
.load-more-wrap .btn[hidden]{display:none}
.no-results{display:none;text-align:center;padding:clamp(44px,7vw,90px) 0;color:var(--muted)}
.no-results.show{display:block}
.no-results b{display:block;color:var(--ink);font-size:1.2rem;font-weight:600;margin-bottom:.4rem}

/* ---------- treatment finder (quiz) ---------- */
.finder-box{max-width:780px;margin:clamp(34px,5vw,54px) auto 0;background:var(--cream);
  border:1px solid var(--line-2);border-radius:6px;padding:clamp(1.8rem,4vw,3.2rem);
  box-shadow:0 40px 80px -56px rgba(38,36,31,.4)}
.finder-step{margin-bottom:2rem;transition:opacity .5s var(--ease)}
.finder-step[hidden],.finder-result[hidden]{display:none}
.q-label{display:block;font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:1.1rem}
.q-label .n{color:var(--ink)}
.q-options{display:flex;flex-wrap:wrap;gap:.7rem}
.chip{border:1px solid var(--line);border-radius:100px;padding:.72em 1.5em;font-size:.95rem;font-weight:500;
  color:var(--ink-2);background:var(--bone);transition:.3s var(--ease)}
.chip:hover{border-color:var(--ink);color:var(--ink)}
.chip.sel{background:var(--ink);color:var(--bone);border-color:var(--ink)}
.finder-result{border-top:1px solid var(--line);padding-top:1.8rem;margin-top:.4rem;
  animation:fadeUp .6s var(--ease-2)}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.fr-label{font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:1rem;display:block}
.fr-card{display:flex;justify-content:space-between;align-items:flex-end;gap:1.5rem;flex-wrap:wrap}
.fr-card .fc-name{font-size:clamp(1.4rem,2.4vw,1.9rem);font-weight:600;letter-spacing:-.02em;margin-bottom:.4rem}
.fr-card .fc-desc{color:var(--ink-2);font-weight:300;font-size:.96rem;max-width:42ch}
.fr-card .fc-price{font-size:.85rem;color:var(--muted);margin-top:.5rem}
.fr-card .fc-price b{color:var(--ink);font-weight:600;font-size:1.1rem}
.fr-actions{display:flex;gap:.8rem;flex-wrap:wrap}

/* ---------- floating whatsapp ---------- */
.wa-float{position:fixed;bottom:22px;inset-inline-start:22px;z-index:95;display:flex;align-items:center;gap:0;
  background:var(--dark);color:#fff;border-radius:100px;height:54px;padding:0;overflow:hidden;
  box-shadow:0 18px 38px -16px rgba(38,36,31,.55);transition:.45s var(--ease)}
.wa-float .ico{width:54px;height:54px;display:grid;place-items:center;flex:0 0 auto}
.wa-float .ico svg{width:25px;height:25px}
.wa-float .lbl{max-width:0;white-space:nowrap;font-size:.9rem;font-weight:600;opacity:0;transition:.45s var(--ease)}
.wa-float:hover{padding-inline-end:1.3rem}
.wa-float:hover .lbl{max-width:200px;opacity:1;padding-inline-start:.2rem}
@media (max-width:680px){.wa-float .lbl{display:none}}

/* index list */
.index{border-top:1px solid var(--line);position:relative}
/* floating hover image preview — the signature moment */
.idx-preview{position:fixed;top:0;left:0;width:clamp(220px,22vw,310px);aspect-ratio:4/5;
  border-radius:4px;overflow:hidden;pointer-events:none;opacity:0;z-index:70;
  transform:translate(-50%,-50%) scale(.92) rotate(-2deg);
  transition:opacity .4s var(--ease),transform .22s var(--ease);
  box-shadow:0 40px 80px -36px rgba(38,36,31,.6)}
.idx-preview.show{opacity:1}
.idx-preview img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.idx-preview::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(20,18,15,.25))}
@media (hover:none){.idx-preview{display:none}}
.index-row{display:grid;grid-template-columns:auto 1fr auto auto;gap:clamp(1.2rem,3.5vw,3.2rem);
  align-items:center;padding:clamp(1.5rem,2.8vw,2.3rem) clamp(.6rem,1.5vw,1.4rem);
  border-bottom:1px solid var(--line);position:relative;transition:padding .5s var(--ease)}
.index-row::before{content:"";position:absolute;inset:0;background:var(--cream);opacity:0;
  transition:opacity .5s var(--ease);z-index:0}
.index-row:hover::before{opacity:1}
.index-row:hover{padding-inline:clamp(1rem,2vw,1.9rem)}
.index-row.is-hidden{display:none}
.index-row>*{position:relative;z-index:1}
.idx-num{font-size:clamp(1.1rem,1.8vw,1.5rem);font-weight:300;color:var(--muted-2);
  font-feature-settings:"lnum";letter-spacing:.02em;min-width:2.4ch}
.idx-main{min-width:0}
.idx-main .cat{font-size:.64rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);font-weight:600;display:block;margin-bottom:.5rem}
.idx-main h3{font-size:clamp(1.3rem,2.3vw,1.85rem);font-weight:600;letter-spacing:-.025em;line-height:1.15;margin-bottom:.45rem;transition:color .4s}
.idx-main .desc{color:var(--ink-2);font-weight:300;font-size:.96rem;line-height:1.6;max-width:52ch}
.idx-main .tags{display:flex;gap:.45rem;margin-top:.7rem;flex-wrap:wrap}
.idx-price{text-align:end;white-space:nowrap}
.idx-price .lbl{display:block;font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted-2);margin-bottom:.2rem}
.idx-price .v{font-size:1.3rem;font-weight:600;letter-spacing:-.01em;color:var(--ink)}
.idx-price .dur{display:block;font-size:.8rem;color:var(--muted);margin-top:.25rem}
.idx-arrow{width:46px;height:46px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;
  color:var(--ink);transition:.45s var(--ease);flex:0 0 auto}
.index-row:hover .idx-arrow{background:var(--ink);color:var(--bone);border-color:var(--ink)}
.index-row:hover .idx-arrow svg{transform:translateX(-3px)}
.idx-arrow svg{width:18px;height:18px;transition:transform .45s var(--ease)}
.index-row .stretch{position:absolute;inset:0;z-index:2}

/* =========================================================
   STATS / QUICK-INFO row (the 12 / 8 / 7 pattern)
   ========================================================= */
.stats{display:grid;grid-template-columns:repeat(var(--n,3),1fr);border-block:1px solid var(--line)}
.stat{padding:clamp(1.6rem,3vw,2.4rem) 1.2rem;text-align:center;position:relative}
.stat+.stat::before{content:"";position:absolute;inset-block:1.4rem auto;inset-inline-start:0;top:1.4rem;bottom:1.4rem;width:1px;background:var(--line)}
.stat .n{font-size:clamp(1.5rem,2.4vw,2rem);font-weight:700;color:var(--ink);line-height:1.1}
.stat .l{font-size:.82rem;color:var(--muted);margin-top:.5rem;letter-spacing:.02em}
.intensity{display:inline-flex;gap:4px;margin-top:.5rem}
.intensity i{width:20px;height:3px;border-radius:2px;background:var(--line)}
.intensity i.on{background:var(--ink)}

/* =========================================================
   TWO-COLUMN: photo + content / list  (about + treatments DNA)
   ========================================================= */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,84px);align-items:center}
.duo.narrow{grid-template-columns:.9fr 1.1fr}
.duo-figure{border-radius:6px;overflow:hidden;aspect-ratio:4/4.3;box-shadow:0 40px 74px -48px rgba(38,36,31,.5)}
.duo-figure img{width:100%;height:100%;object-fit:cover}
.benefit{list-style:none;display:grid;gap:1rem;margin-top:1.6rem}
.benefit li{display:flex;gap:.9rem;align-items:flex-start;color:var(--ink-2);font-weight:300}
.benefit .dot{width:6px;height:6px;border-radius:50%;background:var(--ink);margin-top:.6rem;flex:0 0 auto}
.benefit b{color:var(--ink);font-weight:600}

/* aside booking card */
.aside{position:sticky;top:90px}
.aside-card{background:var(--cream);border:1px solid var(--line-2);border-radius:4px;padding:1.9rem}
.aside-card h3{font-size:1.25rem;margin-bottom:.4rem}
.aside-card p{font-size:.92rem;color:var(--muted);font-weight:300;margin-bottom:1.4rem}
.aside-price{display:flex;align-items:baseline;gap:.5rem;padding-block:1.1rem;border-block:1px solid var(--line-2);margin-bottom:1.4rem}
.aside-price .v{font-size:1.7rem;font-weight:700}
.aside-price small{color:var(--muted)}
.aside-card .btn{width:100%}
.aside-note{font-size:.8rem;color:var(--muted);text-align:center;margin-top:1rem}

/* =========================================================
   NUMBERED STEPS (process) — hairline rows, sans numbers
   ========================================================= */
.steps{display:grid;border-top:1px solid var(--line)}
.step{display:grid;grid-template-columns:auto 1fr;gap:clamp(1.4rem,3vw,2.6rem);align-items:start;
  padding-block:clamp(1.5rem,2.6vw,2.2rem);border-bottom:1px solid var(--line)}
.step .num{font-size:clamp(1.5rem,2.6vw,2rem);font-weight:700;color:var(--muted-2);min-width:1.8ch;line-height:1.1}
.step h3{font-size:1.2rem;margin-bottom:.4rem}
.step p{color:var(--ink-2);font-weight:300;max-width:58ch}
.step .t{font-size:.8rem;color:var(--muted);margin-top:.5rem}

/* mini step (gift "how it works") */
.steps-row{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,4vw,48px);text-align:center}
.step-mini .n{width:50px;height:50px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;
  margin:0 auto 1.2rem;font-size:1.15rem;font-weight:700}
.step-mini h3{font-size:1.15rem;margin-bottom:.5rem}
.step-mini p{font-size:.94rem;color:var(--ink-2);font-weight:300;max-width:32ch;margin-inline:auto}

/* results */
.results{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,30px)}
.result{background:var(--cream);border:1px solid var(--line-2);border-radius:4px;padding:1.8rem}
.result .n{font-size:1.9rem;font-weight:700;line-height:1.1}
.result h4{margin:.6rem 0 .3rem;font-size:1.05rem}
.result p{font-size:.92rem;color:var(--muted);font-weight:300}
.disclaimer{font-size:.84rem;color:var(--muted);margin-top:1.8rem;max-width:74ch;line-height:1.6}

/* =========================================================
   FAQ ( + accordion, hairlines ) — exact existing pattern
   ========================================================= */
.faq{max-width:820px;margin-inline:auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
  padding:1.5rem 0;text-align:start;font-size:1.1rem;font-weight:600;color:var(--ink)}
.faq-ico{flex:0 0 auto;width:24px;height:24px;position:relative}
.faq-ico::before,.faq-ico::after{content:"";position:absolute;inset:50% 0 auto 0;height:1.5px;background:var(--ink);transition:.4s var(--ease)}
.faq-ico::after{transform:rotate(90deg)}
.faq-item.open .faq-ico::after{transform:rotate(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.faq-a p{padding:0 0 1.5rem;color:var(--ink-2);font-weight:300;max-width:66ch}

/* =========================================================
   LET'S DO IT.  closer (serif + underline inputs)
   ========================================================= */
.lets-do{text-align:center}
.lets-do h2{font-family:var(--serif);font-weight:500;font-size:clamp(2.2rem,4.4vw,3.4rem);letter-spacing:.01em;margin-bottom:1rem}
.lets-do p{color:var(--ink-2);font-weight:300;max-width:46ch;margin:0 auto 2.8rem}
.inline-form{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,3vw,2.6rem);max-width:820px;margin-inline:auto}
.uline{display:flex;flex-direction:column}
.uline input{background:transparent;border:none;border-bottom:1px solid var(--line);
  padding:.7em .2em;font-family:inherit;font-size:1rem;color:var(--ink);text-align:start;transition:.3s}
.uline input::placeholder{color:var(--muted)}
.uline input:focus{outline:none;border-bottom-color:var(--ink)}
.lets-do .submit-row{margin-top:2.4rem}

/* =========================================================
   GIFT CARD MOCKUP (charcoal, monochrome)
   ========================================================= */
.giftcard{position:relative;aspect-ratio:1.6/1;border-radius:10px;overflow:hidden;color:#fff;
  background:var(--dark);box-shadow:0 46px 84px -42px rgba(38,36,31,.6);
  padding:clamp(1.4rem,3vw,2.1rem);display:flex;flex-direction:column;justify-content:space-between}
.giftcard::after{content:"";position:absolute;inset:0;border:1px solid rgba(255,255,255,.1);border-radius:10px;pointer-events:none}
.giftcard .gc-top{display:flex;justify-content:space-between;align-items:flex-start}
.giftcard .gc-brand{font-family:var(--round);font-weight:700;font-size:1.5rem;letter-spacing:-.04em}
.giftcard .gc-chip{font-size:.64rem;letter-spacing:.28em;text-transform:uppercase;opacity:.6;text-align:end;line-height:1.5}
.giftcard .gc-l{font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;opacity:.6;margin-bottom:.4rem}
.giftcard .gc-amount{font-size:clamp(1.7rem,4vw,2.4rem);font-weight:700;line-height:1.1}
.giftcard .gc-bottom{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem}
.giftcard .gc-ded{font-family:var(--serif);font-style:italic;font-weight:400;opacity:.85;max-width:62%;font-size:.95rem;line-height:1.45}
.giftcard .gc-to{font-size:.74rem;letter-spacing:.06em;opacity:.6}
.gift-figure{position:relative}
.gift-stamp{position:absolute;top:-16px;inset-inline-end:-10px;width:88px;height:88px;border-radius:50%;
  background:var(--cream);color:var(--ink);display:grid;place-items:center;text-align:center;
  font-size:.64rem;font-weight:600;letter-spacing:.08em;line-height:1.45;
  box-shadow:0 20px 40px -24px rgba(38,36,31,.5);transform:rotate(-7deg);border:1px solid var(--line)}

/* gift options (cream cards, charcoal selected) */
.gift-options{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px)}
.gift-opt{background:var(--cream);border:1px solid var(--line-2);border-radius:4px;padding:1.6rem;
  cursor:pointer;text-align:start;display:flex;flex-direction:column;gap:.5rem;position:relative;
  transition:.4s var(--ease)}
.gift-opt:hover{transform:translateY(-4px);box-shadow:0 26px 48px -36px rgba(38,36,31,.4)}
.gift-opt.sel{border-color:var(--ink);box-shadow:0 0 0 1px var(--ink)}
.gift-opt .cat{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:600}
.gift-opt h3{font-size:1.12rem}
.gift-opt p{font-size:.9rem;color:var(--ink-2);font-weight:300;flex:1;line-height:1.55}
.gift-opt .price{font-size:1.2rem;font-weight:700;margin-top:.3rem}
.gift-opt .check{position:absolute;top:1.1rem;inset-inline-end:1.1rem;width:20px;height:20px;border-radius:50%;
  border:1.5px solid var(--line);display:grid;place-items:center;transition:.3s}
.gift-opt.sel .check{background:var(--ink);border-color:var(--ink)}
.gift-opt .check svg{width:11px;height:11px;color:var(--bone);opacity:0;transition:.3s}
.gift-opt.sel .check svg{opacity:1}

/* form */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,6vw,72px);align-items:start}
.form-card{background:var(--cream);border:1px solid var(--line-2);border-radius:6px;padding:clamp(1.6rem,3vw,2.4rem)}
.field{margin-bottom:1.3rem}
.field label{display:block;font-size:.82rem;font-weight:600;color:var(--ink-2);margin-bottom:.5rem}
.field input,.field select,.field textarea{width:100%;background:var(--bone);border:1px solid var(--line);
  border-radius:3px;padding:.82em 1em;font-family:inherit;font-size:1rem;color:var(--ink);transition:.3s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--ink);background:#fff}
.field textarea{resize:vertical;min-height:88px;line-height:1.6}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-card .btn{width:100%;margin-top:.4rem}
.form-aside{position:sticky;top:90px}
.reassure{display:grid;gap:1rem;margin-top:1.8rem}
.reassure .ri{display:flex;gap:.9rem;align-items:flex-start}
.reassure .ri .dot{width:6px;height:6px;border-radius:50%;background:var(--ink);margin-top:.65rem;flex:0 0 auto}
.reassure .ri b{display:block;color:var(--ink)}
.reassure .ri span{font-size:.9rem;color:var(--muted);font-weight:300}

/* =========================================================
   FOOTER (bone, minimal single row)
   ========================================================= */
.site-footer{border-top:1px solid var(--line-2);padding-block:30px;margin-top:0}
.foot{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1.5rem}
.foot .credit{font-size:.78rem;color:var(--muted);grid-column:3;text-align:end}
.foot-menu{display:flex;justify-content:center;gap:1.6rem;flex-wrap:wrap;grid-column:2}
.foot-menu a{font-size:.82rem;color:var(--ink-2);transition:.3s}
.foot-menu a:hover{color:var(--ink)}
.foot-social{display:flex;justify-content:flex-start;gap:.8rem;grid-column:1}
.foot-social a{width:34px;height:34px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;color:var(--ink);transition:.3s}
.foot-social a:hover{background:var(--ink);color:var(--bone);border-color:var(--ink)}
.foot-social svg{width:15px;height:15px}

/* toast */
.toast{position:fixed;bottom:28px;inset-inline:0;margin-inline:auto;width:max-content;max-width:90vw;
  background:var(--dark);color:#fff;padding:.95rem 1.6rem;border-radius:100px;font-size:.94rem;
  box-shadow:0 24px 50px -22px rgba(38,36,31,.6);z-index:200;transform:translateY(150%);
  transition:transform .55s var(--ease-2);display:flex;gap:.6rem;align-items:center}
.toast.show{transform:translateY(0)}
.toast svg{width:17px;height:17px}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1024px){
  .cards,.gift-options,.results{grid-template-columns:repeat(2,1fr)}
  .card-feature{grid-column:span 2}
}
@media (max-width:900px){
  .nav,.socials,.pill-cta{display:none}
  .menu-toggle{display:grid;place-items:center}
  .feature{grid-template-columns:1fr;gap:1.8rem}
  .feature .ph{order:-1}
  .hero-split .grid,.duo,.duo.narrow,.form-grid{grid-template-columns:1fr}
  .hero-figure{order:-1;max-width:460px;margin-inline:auto;width:100%}
  .aside,.form-aside{position:static}
  .card-feature{grid-template-columns:1fr}
  .card-feature .ph{min-height:240px}
  .bullets{grid-template-columns:1fr;gap:2.2rem}
  .bullet+.bullet::before{display:none}
  .steps-row{grid-template-columns:1fr;max-width:400px;margin-inline:auto;gap:2rem}
  .duo-figure{display:none}
}
@media (max-width:760px){
  .index-row{grid-template-columns:auto 1fr auto;gap:1rem 1.3rem;padding-inline:.2rem}
  .index-row .idx-main .desc,.index-row .idx-arrow{display:none}
  .index-row .idx-main .tags{margin-top:.5rem}
  .idx-price .v{font-size:1.1rem}
}
@media (max-width:680px){
  .cards,.gift-options,.results{grid-template-columns:1fr}
  .card-feature{grid-column:span 1}
  .inline-form{grid-template-columns:1fr;max-width:360px}
  .stats{grid-template-columns:1fr}
  .stat+.stat::before{display:none}
  .stat{border-top:1px solid var(--line-2)}
  .stat:first-child{border-top:none}
  .step{grid-template-columns:1fr;gap:.6rem}
  .foot{grid-template-columns:1fr;text-align:center;gap:1.4rem}
  .foot-social{justify-content:center}
  .foot .credit{order:3}
}
