/* Олена Остапко — травмафокусована терапія. Дизайн-система v2 (immersive). */

:root{
  --paper:#F3EEE6;        /* тепла кістка */
  --paper-2:#EAE2D5;
  --ink:#23201B;          /* глибокий теплий графіт */
  --ink-soft:#5B5345;
  --cream:#FBF8F2;
  --thread:#B0814A;       /* тепла нитка / золото-глина — єдиний акцент */
  --thread-deep:#8C6231;
  --gold-light:#EBC88F;
  --line:rgba(35,32,27,.14);
  --serif:"Playfair Display", Georgia, serif;
  --serif-soft:"Cormorant Garamond", Georgia, serif;
  --sans:"Manrope", -apple-system, BlinkMacSystemFont, sans-serif;
  --maxw:1180px;
  --ease:cubic-bezier(.2,.6,.3,1);
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:18px;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.1;letter-spacing:-.015em;margin:0}
p{margin:0 0 1.1em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.col{max-width:760px}
.muted{color:var(--ink-soft)}
.center{text-align:center}
.eyebrow{font-family:var(--sans);font-size:.74rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;display:inline-flex;align-items:center;gap:.8em}
.eyebrow::before{content:"";width:30px;height:1px;background:currentColor;opacity:.6}
.lead{font-size:1.18rem;color:var(--ink-soft);line-height:1.7}

/* кнопки */
.btn{display:inline-flex;align-items:center;gap:.7em;font-family:var(--sans);font-weight:600;font-size:.92rem;letter-spacing:.02em;padding:1em 1.8em;border-radius:2px;border:1px solid transparent;cursor:pointer;transition:.3s var(--ease)}
.btn--solid{background:var(--thread);color:#FBF6EC}
.btn--solid:hover{background:var(--thread-deep);transform:translateY(-2px)}
.btn--out{border-color:rgba(255,255,255,.5);color:#fff}
.btn--out:hover{background:rgba(255,255,255,.12)}
.btn--ink{border-color:var(--line);color:var(--ink)}
.btn--ink:hover{border-color:var(--thread);color:var(--thread-deep)}
.link-thread{color:var(--thread-deep);font-weight:600;border-bottom:1px solid rgba(176,129,74,.4);transition:border-color .25s}
.link-thread:hover{border-color:var(--thread)}

/* фірмова нитка-розділювач */
.thread-mark{height:1px;border:0;background:linear-gradient(90deg,transparent,var(--line) 18%,var(--line) 82%,transparent);position:relative;margin:0}
.thread-mark::after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:7px;height:7px;border-radius:50%;background:var(--thread);box-shadow:0 0 0 5px var(--paper)}

/* HEADER */
.hdr{position:fixed;top:0;left:0;right:0;z-index:50;transition:background .4s,backdrop-filter .4s,border-color .4s;border-bottom:1px solid transparent}
.hdr.scrolled{background:rgba(243,238,230,.88);backdrop-filter:blur(10px);border-color:var(--line)}
.hdr__in{display:flex;align-items:center;justify-content:space-between;padding:22px 32px;max-width:var(--maxw);margin:0 auto}
.brand{font-family:var(--serif);font-size:1.2rem;font-weight:500;color:#fff;transition:color .4s}
.brand small{display:block;font-family:var(--sans);font-size:.58rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;opacity:.8;margin-top:3px}
.hdr.scrolled .brand{color:var(--ink)}
.nav{display:flex;align-items:center;gap:30px}
.nav a{font-size:.86rem;font-weight:500;color:rgba(255,255,255,.9);transition:color .3s}
.hdr.scrolled .nav a{color:var(--ink-soft)}
.nav a:hover,.nav a[aria-current="page"]{color:var(--gold-light)}
.hdr.scrolled .nav a:hover,.hdr.scrolled .nav a[aria-current="page"]{color:var(--thread-deep)}
.nav-cta{background:var(--thread);padding:.62em 1.3em;border-radius:2px;font-weight:600;transition:background .25s,transform .25s}
.nav-cta:hover{background:var(--thread-deep);transform:translateY(-1px)}
.nav a.nav-cta,.nav a.nav-cta:hover,.hdr.scrolled .nav a.nav-cta,.hdr.scrolled .nav a.nav-cta:hover{color:#FBF6EC}
.nav-toggle{display:none;background:none;border:0;color:#fff;font-family:var(--sans);font-weight:600;font-size:.86rem;cursor:pointer}
.hdr.scrolled .nav-toggle{color:var(--ink)}
@media(max-width:820px){
  .nav{position:fixed;inset:64px 0 auto 0;flex-direction:column;align-items:flex-start;gap:0;background:var(--paper);border-bottom:1px solid var(--line);padding:8px 32px 22px;transform:translateY(-130%);transition:transform .35s var(--ease)}
  .nav.open{transform:none}
  .nav a{color:var(--ink);padding:13px 0;width:100%;border-bottom:1px solid var(--line)}
  .nav .nav-cta{border-bottom:1px solid var(--line)}
  .nav-toggle{display:block}
}

/* HERO (головна, повний екран) + PAGE-HERO (внутрішні) */
.hero,.page-hero{position:relative;color:#fff;overflow:hidden;display:flex;align-items:flex-end}
.hero{min-height:100svh}
.page-hero{min-height:62vh}
.hero__bg,.page-hero__bg{position:absolute;inset:0;z-index:-2;background-size:cover;background-position:center 38%}
.hero__bg::after,.page-hero__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,17,13,.5) 0%,rgba(20,17,13,.1) 32%,rgba(20,17,13,.28) 60%,rgba(20,17,13,.74) 100%)}
.hero__in{position:relative;z-index:1;width:100%;padding-bottom:104px;padding-top:140px}
.page-hero__in{position:relative;z-index:1;width:100%;padding-bottom:60px;padding-top:150px}
.hero .eyebrow{color:rgba(255,255,255,.86);margin-bottom:30px;animation:fade .9s .1s both}
.hero h1{font-size:clamp(2.7rem,6.4vw,5.6rem);max-width:16ch;margin-bottom:.5em;text-shadow:0 2px 40px rgba(0,0,0,.25);animation:fade 1s .22s both}
.hero h1 em,.page-hero h1 em{font-family:var(--serif-soft);font-style:italic;color:var(--gold-light)}
.hero__lead{font-size:clamp(1.05rem,1.6vw,1.3rem);max-width:46ch;color:rgba(255,255,255,.9);margin-bottom:2.2em;animation:fade 1s .36s both}
.hero__cta{display:flex;gap:16px;flex-wrap:wrap;animation:fade 1s .5s both}
.page-hero .eyebrow{color:rgba(255,255,255,.86);margin-bottom:24px}
.page-hero h1{font-size:clamp(2.4rem,5vw,4.2rem);max-width:18ch;margin-bottom:.35em;text-shadow:0 2px 40px rgba(0,0,0,.25)}
.page-hero__lead{font-size:1.2rem;max-width:50ch;color:rgba(255,255,255,.9)}
.scrollcue{position:absolute;right:36px;bottom:40px;z-index:1;writing-mode:vertical-rl;font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.7);animation:fade 1s 1s both}
.scrollcue::after{content:"";display:block;width:1px;height:46px;background:rgba(255,255,255,.6);margin:14px auto 0;animation:grow 2s ease-in-out infinite}
@keyframes fade{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
@keyframes grow{0%,100%{transform:scaleY(.4);transform-origin:top;opacity:.4}50%{transform:scaleY(1);opacity:.9}}

/* секції */
.section{padding:clamp(80px,10vw,130px) 0}
.section--cream{background:var(--cream)}
.section--paper{background:var(--paper)}
.section-head{max-width:54ch;margin:0 auto clamp(40px,5vw,64px)}
.section-head.center{text-align:center}
.section-head .eyebrow{color:var(--thread-deep);margin-bottom:18px}
.section-head.center .eyebrow{justify-content:center}
.section-title{font-size:clamp(2rem,3.6vw,3rem)}

/* INTRO — наїзд на hero (головна) */
.intro{position:relative;background:var(--paper);padding:0 0 120px}
.intro__grid{display:grid;grid-template-columns:1.25fr .75fr;gap:64px;align-items:end}
.intro__lead{margin-top:-46px;position:relative;z-index:2;background:var(--cream);border:1px solid var(--line);padding:54px 56px;box-shadow:0 40px 80px -50px rgba(35,32,27,.4)}
.intro__lead .eyebrow{color:var(--thread-deep);margin-bottom:24px}
.intro__lead p{font-family:var(--serif-soft);font-size:clamp(1.5rem,2.5vw,2.05rem);line-height:1.4;margin:0}
.intro__lead p em{font-style:italic;color:var(--thread-deep)}
.intro__fig{position:relative;aspect-ratio:3/4;margin-top:-150px;z-index:3}
.intro__fig img{width:100%;height:100%;object-fit:cover;filter:saturate(.92)}
.intro__fig figcaption{position:absolute;left:14px;bottom:14px;right:14px;font-family:var(--sans);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:#fff;text-shadow:0 1px 12px rgba(0,0,0,.7)}
.intro__who{margin-top:50px;max-width:62ch;color:var(--ink-soft);font-size:1.08rem}
.intro__who strong{color:var(--ink);font-weight:600}

/* IMMERSIVE BAND (образ із фразою) — фон через inline style на .band__bg */
.band{position:relative;min-height:74vh;display:grid;place-items:center;text-align:center;color:#fff;padding:120px 32px;overflow:hidden}
.band__bg{position:absolute;inset:0;z-index:-1;background-size:cover;background-position:center}
.band__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,32,33,.34),rgba(28,32,33,.52))}
.band__eyebrow{color:rgba(255,255,255,.8);margin-bottom:28px}
.band__line{font-family:var(--serif-soft);font-style:italic;font-size:clamp(1.8rem,4vw,3.4rem);max-width:18ch;line-height:1.25;text-shadow:0 2px 40px rgba(0,0,0,.3);margin:0 auto}

/* WORK — bleed image + editorial index */
.work{position:relative;background:var(--paper);padding:clamp(80px,10vw,130px) 0}
.work__grid{display:grid;grid-template-columns:minmax(0,42%) minmax(0,58%);gap:0;align-items:stretch}
.work__media{position:relative;min-height:560px}
.work__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.work__media .tag{position:absolute;left:0;bottom:0;background:var(--thread);color:#FBF6EC;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;padding:12px 20px}
.work__body{padding:8px 0 8px 70px}
.work__body .eyebrow{color:var(--thread-deep);margin-bottom:18px}
.work__body h2{font-size:clamp(2rem,3.4vw,3rem);margin-bottom:14px}
.work__body>.muted{max-width:46ch;margin-bottom:18px}
.idx{border-top:1px solid var(--line)}
.idx__row{display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:baseline;padding:22px 0;border-bottom:1px solid var(--line);transition:padding-left .3s}
.idx__row:hover{padding-left:10px}
.idx__n{font-family:var(--serif);font-size:1.05rem;color:var(--thread-deep)}
.idx__t{font-family:var(--serif-soft);font-size:1.5rem;color:var(--ink)}
.idx__t small{display:block;font-family:var(--sans);font-size:.92rem;color:var(--ink-soft);margin-top:3px;letter-spacing:0}

/* MANIFESTO — образ + велика цитата (фон inline на .manifesto__bg) */
.manifesto{position:relative;min-height:92vh;display:flex;align-items:center;color:#F2ECE1;overflow:hidden}
.manifesto__bg{position:absolute;inset:0;z-index:-1;background-size:cover;background-position:center}
.manifesto__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(16,18,17,.85) 0%,rgba(16,18,17,.6) 50%,rgba(16,18,17,.4) 100%)}
.manifesto__in{max-width:760px}
.manifesto .eyebrow{color:rgba(242,236,225,.7);margin-bottom:30px}
.manifesto h2{font-size:clamp(2.1rem,4.4vw,3.7rem);line-height:1.18;margin-bottom:30px}
.manifesto h2 em{font-family:var(--serif-soft);font-style:italic;color:var(--gold-light)}
.manifesto p{max-width:48ch;color:rgba(242,236,225,.8)}
.manifesto cite{display:block;margin-top:26px;font-style:normal;font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(242,236,225,.6)}

/* PATH — принципи + кроки на нитці */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-bottom:96px}
.value{background:var(--paper);padding:40px 34px}
.value .vn{font-family:var(--serif-soft);font-style:italic;font-size:1.05rem;color:var(--thread-deep)}
.value h3{font-family:var(--serif);font-size:1.5rem;margin:8px 0 12px}
.value p{margin:0;color:var(--ink-soft);font-size:.98rem}
.steps{max-width:640px;margin:0 auto;position:relative}
.steps::before{content:"";position:absolute;left:26px;top:20px;bottom:20px;width:1px;background:linear-gradient(var(--thread),rgba(176,129,74,.2))}
.step{position:relative;display:grid;grid-template-columns:54px 1fr;gap:30px;padding:22px 0}
.step__n{position:relative;z-index:1;width:54px;height:54px;border-radius:50%;background:var(--paper);border:1px solid var(--thread);color:var(--thread-deep);display:grid;place-items:center;font-family:var(--serif);font-size:1.15rem}
.step h3{font-family:var(--serif-soft);font-size:1.55rem;margin:0 0 4px}
.step p{margin:0;color:var(--ink-soft);font-size:1rem}

/* PROSE — читабельний текст (про мене, юр.) */
.prose{max-width:62ch}
.prose p{font-size:1.08rem;color:var(--ink)}
.prose p.drop:first-letter{} /* без бахв */
.prose h3{font-family:var(--serif-soft);font-size:1.7rem;margin:1.6em 0 .5em;color:var(--ink)}
.prose .lead-serif{font-family:var(--serif-soft);font-size:clamp(1.4rem,2.4vw,1.9rem);line-height:1.4;color:var(--ink);margin-bottom:1em}

/* SPLIT — текст + образ, з шаром */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center}
.split--media-first .split__media{order:-1}
.split__media{position:relative;aspect-ratio:4/5}
.split__media img{width:100%;height:100%;object-fit:cover}
.split__media figcaption{position:absolute;left:14px;bottom:14px;font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:#fff;text-shadow:0 1px 12px rgba(0,0,0,.7)}

/* списки */
.creds{list-style:none;padding:0;margin:0}
.creds li{padding:16px 0 16px 34px;position:relative;border-bottom:1px solid var(--line);font-size:1.05rem}
.creds li::before{content:"";position:absolute;left:4px;top:24px;width:9px;height:9px;border-radius:50%;background:var(--thread)}
.checklist{list-style:none;padding:0;margin:0}
.checklist li{padding:12px 0 12px 30px;position:relative;border-bottom:1px dashed var(--line);color:var(--ink)}
.checklist li::before{content:"";position:absolute;left:3px;top:21px;width:8px;height:8px;border-radius:50%;background:var(--thread)}
.pills{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:12px}
.pills li{background:var(--cream);border:1px solid var(--line);border-radius:100px;padding:9px 18px;font-size:.92rem}

/* QA акордеон */
.qa{border-bottom:1px solid var(--line)}
.qa:first-of-type{border-top:1px solid var(--line)}
.qa>summary{cursor:pointer;list-style:none;padding:26px 0;font-family:var(--serif-soft);font-size:1.4rem;color:var(--ink);display:flex;justify-content:space-between;gap:18px;align-items:baseline}
.qa>summary::-webkit-details-marker{display:none}
.qa>summary::after{content:"+";color:var(--thread);font-family:var(--sans);font-weight:400;font-size:1.5rem;line-height:1}
.qa[open]>summary::after{content:"–"}
.qa__a{padding:0 0 26px;margin:0;color:var(--ink-soft);max-width:70ch}

/* форма + контакти */
.field{display:block;margin-bottom:20px}
.field label{display:block;font-size:.74rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:9px}
.field input,.field textarea{width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:2px;background:var(--cream);font-family:var(--sans);font-size:1rem;color:var(--ink);transition:border-color .2s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--thread)}
.field textarea{min-height:150px;resize:vertical}
.contact-method{display:flex;align-items:center;gap:16px;padding:20px 0;border-bottom:1px solid var(--line);transition:padding-left .25s}
.contact-method:hover{padding-left:8px;color:var(--thread-deep)}
.contact-method__ic{width:46px;height:46px;flex:none;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:.78rem;color:var(--thread-deep)}
.contact-method__v{font-weight:700}
.contact-method__l{display:block;font-size:.84rem;color:var(--ink-soft)}
.social{display:flex;gap:14px;margin-top:22px}
.social a{width:42px;height:42px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;font-size:.72rem;font-weight:700;color:var(--thread-deep);transition:.25s}
.social a:hover{border-color:var(--thread);transform:translateY(-2px)}

/* ціни */
.price-list{border-top:1px solid var(--line)}
.price-row{display:flex;justify-content:space-between;align-items:baseline;gap:20px;padding:24px 0;border-bottom:1px solid var(--line)}
.price-row__name{font-family:var(--serif-soft);font-size:1.45rem}
.price-row__meta{display:block;font-family:var(--sans);font-size:.82rem;color:var(--ink-soft);margin-top:3px;letter-spacing:.02em}
.price-row__value{font-family:var(--serif);font-size:1.4rem;color:var(--thread-deep);white-space:nowrap}
.price-note{font-size:.88rem;color:var(--ink-soft);margin-top:20px}
.req{background:var(--cream);border:1px solid var(--line);padding:34px 36px;font-size:.98rem;line-height:1.9}
.req b{font-family:var(--serif-soft);font-size:1.2rem}

/* ВІДГУК */
.testi{position:relative;background:var(--cream);padding:clamp(80px,10vw,120px) 0}
.testi__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:center}
.testi__fig{aspect-ratio:4/5}
.testi__fig img{width:100%;height:100%;object-fit:cover}
.testi blockquote{margin:0}
.testi q{font-family:var(--serif-soft);font-style:italic;font-size:clamp(1.5rem,2.8vw,2.3rem);line-height:1.4;color:var(--ink);quotes:none}
.testi q::before{content:"";display:block;width:46px;height:1px;background:var(--thread);margin-bottom:28px}
.testi cite{display:block;margin-top:26px;font-style:normal;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--thread-deep)}

/* CTA / FOOTER (спільний образ) */
.foot{position:relative;color:#F2ECE1;overflow:hidden}
.foot__bg{position:absolute;inset:0;z-index:-1;background:url("https://images.unsplash.com/photo-1777605455295-1a47d25ad6ae?w=2000&q=80&auto=format&fit=crop") center 30%/cover}
.foot__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,16,13,.72),rgba(18,16,13,.93))}
.foot__cta{text-align:center;padding:130px 32px 90px;max-width:760px;margin:0 auto}
.foot__cta .eyebrow{color:rgba(242,236,225,.7);justify-content:center;margin-bottom:24px}
.foot__cta h2{font-size:clamp(2.1rem,4.2vw,3.6rem);margin-bottom:14px}
.foot__cta h2 em{font-family:var(--serif-soft);font-style:italic;color:var(--gold-light)}
.foot__cta p{color:rgba(242,236,225,.82);max-width:42ch;margin:0 auto 34px}
.foot__grid{border-top:1px solid rgba(242,236,225,.16);padding:50px 0 0;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:34px}
.foot__grid h4{font-family:var(--sans);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(242,236,225,.6);margin:0 0 14px}
.foot a.fl{display:block;color:rgba(242,236,225,.86);font-size:.95rem;margin-bottom:9px}
.foot a.fl:hover{color:var(--gold-light)}
.foot__brand{font-family:var(--serif);font-size:1.5rem}
.foot__slogan{font-family:var(--serif-soft);font-style:italic;font-size:1.15rem;color:var(--gold-light);margin-top:10px}
.safety{font-size:.82rem;color:rgba(242,236,225,.6);padding:34px 0;border-top:1px solid rgba(242,236,225,.16);margin-top:46px}
.safety strong{color:#F2ECE1}
.foot__bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px;padding-bottom:36px;font-size:.78rem;color:rgba(242,236,225,.5)}

/* адаптив */
@media(max-width:900px){
  .intro__grid{grid-template-columns:1fr;gap:0}
  .intro__lead{margin-top:-40px;padding:38px 30px}
  .intro__fig{margin-top:34px;aspect-ratio:16/10}
  .work__grid{grid-template-columns:1fr}
  .work__media{min-height:320px}
  .work__body{padding:46px 0 0}
  .testi__grid{grid-template-columns:1fr;gap:34px}
  .testi__fig{aspect-ratio:16/10;order:2}
  .values{grid-template-columns:1fr}
  .split{grid-template-columns:1fr;gap:30px}
  .split--media-first .split__media{order:0}
  .foot__grid{grid-template-columns:1fr 1fr;gap:26px}
}
@media(max-width:560px){
  body{font-size:17px}
  .price-row{flex-direction:column;gap:4px}
  .foot__grid{grid-template-columns:1fr}
}
