/* ==========================================================
   СТИХ. — Massage practice. Ultra-minimal Japandi.
   Stone gray + warm tan + sage. EB Garamond + Plus Jakarta Sans + JetBrains Mono
   ========================================================== */

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
html,body{margin:0;padding:0;overflow-x:clip}

:root{
  --bg:#EDE7DC;
  --bg-2:#E2DAC9;
  --paper:#F8F4EB;
  --ink:#2A2826;
  --ink-2:#4A4640;
  --ink-3:#7C766A;
  --ink-4:#A8A294;
  --sage:#7B8569;
  --line:rgba(42,40,38,.12);

  --f-d:"EB Garamond","Times New Roman",serif;
  --f-b:"Plus Jakarta Sans",system-ui,sans-serif;
  --f-m:"JetBrains Mono",ui-monospace,monospace;

  --pad-x:clamp(20px,4vw,80px);
  --sec-y:clamp(96px,11vw,160px);

  --ease:cubic-bezier(.22,.9,.3,1);
}

body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--f-b);font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;font-weight:400;
}
img,svg,video,iframe{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;background:none;border:0;padding:0;color:inherit;cursor:pointer}
ul,ol{margin:0;padding:0;list-style:none}
h1,h2,h3,h4,p,dl,dt,dd,figure,blockquote{margin:0;padding:0;border:0}
address{font-style:normal}

::selection{background:var(--sage);color:var(--paper)}
:focus-visible{outline:1px solid var(--ink);outline-offset:4px}

/* ============ HEADER ============ */
.hdr{
  position:fixed;top:0;left:0;right:0;z-index:30;
  padding:18px var(--pad-x);
  display:flex;align-items:center;justify-content:space-between;gap:22px;
  background:rgba(237,231,220,.0);transition:background .35s var(--ease);
}
.hdr.is-solid{background:rgba(237,231,220,.94);backdrop-filter:blur(10px)}
.lg{display:inline-flex;align-items:center;gap:10px;color:var(--ink)}
.lg-mark{color:var(--sage)}
.lg-w{font-family:var(--f-d);font-size:24px;font-weight:500;letter-spacing:-.01em;line-height:1}
.lg-w i{color:var(--sage)}
.nv{display:flex;gap:32px;font-family:var(--f-b);font-size:14px;color:var(--ink-2);font-weight:500}
.nv a{transition:color .25s var(--ease)}
.nv a:hover{color:var(--sage)}

.mb{
  position:fixed;top:14px;right:var(--pad-x);z-index:31;
  display:none;width:44px;height:44px;
  align-items:center;justify-content:center;color:var(--ink);background:var(--paper);border:1px solid var(--line);border-radius:50%;
}

.drawer{
  position:fixed;inset:0;z-index:80;
  background:var(--paper);
  padding:24px var(--pad-x);
  display:flex;flex-direction:column;gap:36px;
  opacity:0;pointer-events:none;
  transition:opacity .45s var(--ease);
}
body.dr-open .drawer{opacity:1;pointer-events:auto}
.dr-x{align-self:flex-end;width:44px;height:44px;color:var(--ink);border:1px solid var(--line);border-radius:50%;display:inline-flex;align-items:center;justify-content:center}
.drawer nav{flex:1;display:flex;flex-direction:column;justify-content:center;gap:6px}
.drawer nav a{
  padding:14px 0;border-bottom:1px solid var(--line);
  font-family:var(--f-d);font-size:clamp(36px,8vw,64px);font-weight:500;
  letter-spacing:-.015em;color:var(--ink);
  opacity:0;transform:translateY(20px);
  transition:opacity .55s var(--ease) calc(var(--i,0)*.07s + .15s),transform .55s var(--ease) calc(var(--i,0)*.07s + .15s);
}
body.dr-open .drawer nav a{opacity:1;transform:none}

/* ============ HERO ============ */
.hero{
  display:grid;grid-template-columns:1.1fr 1fr;
  gap:clamp(40px,5vw,96px);
  padding:clamp(140px,18vh,200px) var(--pad-x) clamp(60px,7vw,100px);
  max-width:1500px;margin:0 auto;
  align-items:center;
}
.hero-l{display:flex;flex-direction:column;gap:28px}

.rb{
  font-family:var(--f-m);font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--sage);font-weight:500;
}

.hh{
  font-family:var(--f-d);
  font-size:clamp(48px,7vw,128px);
  font-weight:500;line-height:.98;letter-spacing:-.025em;
  color:var(--ink);
}
.hh span{display:block}
.hh-1 em{font-style:italic;color:var(--sage);font-weight:400}
.hh-2{}
.hh-3{}
.hh-4{font-style:italic;font-weight:400;color:var(--ink-3);font-size:.55em;padding-top:.2em;letter-spacing:-.01em}
.hh-4 em{font-style:italic}

.hp{font-family:var(--f-b);font-size:16px;line-height:1.7;color:var(--ink-2);max-width:54ch}

.cta-r{display:flex;gap:14px;flex-wrap:wrap;margin-top:6px}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 26px;
  font-family:var(--f-b);font-size:14px;font-weight:500;
  letter-spacing:.01em;
  cursor:pointer;
  border:1px solid transparent;
  transition:background .35s var(--ease),color .35s var(--ease),transform .25s var(--ease),border-color .25s var(--ease);
}
.btn-d{background:var(--ink);color:var(--paper)}
.btn-d:hover{background:var(--sage);transform:translateY(-1px)}
.btn-l{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-l:hover{background:var(--ink);color:var(--paper)}
.btn-big{padding:18px 32px;font-size:15px}

.hero-fig{margin:0;overflow:hidden}
.hero-fig img{
  width:100%;aspect-ratio:4/5;object-fit:cover;
  filter:saturate(.85) contrast(1.02) brightness(.98);
  transition:transform 1.4s var(--ease);
}
.hero-fig:hover img{transform:scale(1.02)}

/* ============ SECTION HEAD ============ */
.sh{display:flex;flex-direction:column;gap:18px;padding:0 var(--pad-x) clamp(40px,5vw,72px);max-width:1500px;margin:0 auto}
.sh-h{
  font-family:var(--f-d);font-size:clamp(40px,5.8vw,96px);
  font-weight:500;line-height:1;letter-spacing:-.02em;
  color:var(--ink);max-width:18ch;
}
.sh-h em{font-style:italic;color:var(--sage);font-weight:400}
.sh-p{font-family:var(--f-b);font-size:16px;line-height:1.65;color:var(--ink-2);max-width:60ch}

/* ============ PRACTICE ============ */
.prac{padding:var(--sec-y) 0;max-width:1500px;margin:0 auto}
.pr-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:clamp(28px,4vw,72px);padding:0 var(--pad-x);align-items:start}
.pr-body p{font-family:var(--f-b);font-size:16.5px;line-height:1.75;color:var(--ink-2);margin-bottom:18px;max-width:60ch}
.pr-body p:last-child{margin-bottom:0}
.pr-fig{margin:0;overflow:hidden}
.pr-fig img{width:100%;aspect-ratio:4/5;object-fit:cover;filter:saturate(.9)}
.pr-fig figcaption{font-family:var(--f-m);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);margin-top:10px}

/* ============ METHODS ============ */
.methods{padding:var(--sec-y) 0;background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.m-list{display:flex;flex-direction:column;gap:0;margin:0 var(--pad-x);max-width:1200px;border-top:1px solid var(--line)}
.m-list li{
  display:grid;grid-template-columns:80px 1fr;gap:36px;
  padding:32px 0;border-bottom:1px solid var(--line);
}
.m-no{font-family:var(--f-m);font-size:13px;letter-spacing:.04em;color:var(--sage);padding-top:6px}
.m-list h3{
  font-family:var(--f-d);font-size:clamp(26px,3.2vw,40px);font-weight:500;
  line-height:1.05;letter-spacing:-.015em;color:var(--ink);
}
.m-list h3 em{font-style:italic;color:var(--sage);font-weight:400}
.m-list p{font-family:var(--f-b);font-size:15.5px;line-height:1.7;color:var(--ink-2);margin-top:8px;max-width:62ch}

/* ============ ROOM ============ */
.room{padding:var(--sec-y) 0;max-width:1500px;margin:0 auto}
.rm-gallery{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
  margin:0 var(--pad-x);
}
.rm-gallery figure{margin:0;overflow:hidden}
.rm-gallery img{width:100%;aspect-ratio:4/5;object-fit:cover;filter:saturate(.9)}

.rm-list{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px 48px;
  margin:48px var(--pad-x) 0;
  padding-top:32px;border-top:1px solid var(--line);
}
.rm-list div{display:flex;flex-direction:column;gap:4px}
.rm-list dt{font-family:var(--f-m);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3)}
.rm-list dd{font-family:var(--f-d);font-size:18px;color:var(--ink);font-weight:500;letter-spacing:-.005em}

/* ============ BOOK ============ */
.book{
  padding:var(--sec-y) 0;
  background:var(--ink);color:var(--paper);
}
.bk-inner{max-width:900px;margin:0 auto;padding:0 var(--pad-x)}
.book .sh{padding-left:0;padding-right:0;max-width:none}
.book .sh-h{color:var(--paper)}
.book .sh-h em{color:var(--bg-2)}
.book .rb{color:var(--bg-2)}

.bk-steps{
  display:flex;flex-direction:column;gap:0;
  border-top:1px solid rgba(248,244,235,.18);
  margin-bottom:36px;
}
.bk-steps li{
  display:grid;grid-template-columns:80px 1fr;gap:32px;
  padding:24px 0;border-bottom:1px solid rgba(248,244,235,.18);
}
.bk-no{font-family:var(--f-d);font-style:italic;font-size:24px;color:var(--bg-2);font-weight:400}
.bk-steps p{font-family:var(--f-b);font-size:16px;line-height:1.65;color:rgba(248,244,235,.85);max-width:58ch}

.bk-prices{
  display:flex;flex-direction:column;gap:0;
  padding:24px 0;
  border-top:1px solid rgba(248,244,235,.18);
  border-bottom:1px solid rgba(248,244,235,.18);
  margin-bottom:36px;
}
.bk-prices div{
  display:grid;grid-template-columns:1fr auto;gap:18px;
  padding:11px 0;border-bottom:1px dashed rgba(248,244,235,.18);
  font-family:var(--f-b);
}
.bk-prices div:last-child{border-bottom:0}
.bk-prices dt{font-family:var(--f-d);font-size:18px;color:var(--paper);font-weight:500;letter-spacing:-.005em}
.bk-prices dd{font-family:var(--f-m);font-size:14px;color:rgba(248,244,235,.7);text-align:right}
.bk-prices dd b{font-family:var(--f-d);font-style:normal;font-size:22px;color:var(--bg-2);font-weight:500;letter-spacing:-.005em;margin-right:8px}

.book .btn-d{background:var(--paper);color:var(--ink)}
.book .btn-d:hover{background:var(--sage);color:var(--paper)}

/* ============ VISIT ============ */
.visit{padding:var(--sec-y) 0;max-width:1500px;margin:0 auto}
.vs-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(28px,3vw,72px);padding:0 var(--pad-x);align-items:start}
.vs-l{display:flex;flex-direction:column;gap:0}
.vs-l div{display:grid;grid-template-columns:120px 1fr;gap:14px;align-items:baseline;padding:14px 0;border-bottom:1px solid var(--line)}
.vs-l dt{display:inline-flex;align-items:center;gap:6px;font-family:var(--f-m);font-size:11px;color:var(--ink-3);letter-spacing:.06em;text-transform:uppercase}
.vs-l dt svg{color:var(--sage)}
.vs-l dd{font-family:var(--f-d);font-size:20px;color:var(--ink);letter-spacing:-.01em;font-weight:500}
.vs-l dd a{color:var(--sage);border-bottom:1px solid var(--sage)}
.vs-map{position:relative;min-height:clamp(400px,55vh,560px);overflow:hidden}
.vs-map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:saturate(.5) sepia(.16)}

/* ============ FOOTER ============ */
.ft{padding:clamp(56px,6vw,96px) var(--pad-x) clamp(22px,2vw,30px);display:flex;flex-direction:column;gap:clamp(40px,5vw,72px);background:var(--bg-2)}
.ft-mark{text-align:center;font-family:var(--f-d);font-size:clamp(100px,24vw,320px);font-weight:500;line-height:.88;letter-spacing:-.04em;color:var(--ink)}
.ft-mark i{color:var(--sage);font-style:italic;font-weight:400}
.ft-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,48px);max-width:1200px;margin:0 auto;width:100%}
.ft-grid > div{display:flex;flex-direction:column;gap:8px}
.ft-l{font-family:var(--f-m);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--sage);margin-bottom:6px}
.ft-grid a,.ft-grid address{font-family:var(--f-d);font-size:18px;color:var(--ink);letter-spacing:-.005em;font-weight:500}
.ft-grid a:hover{color:var(--sage)}
.ft-base{text-align:center;padding-top:20px;border-top:1px solid var(--line);font-family:var(--f-m);font-size:11px;color:var(--ink-3);letter-spacing:.04em;max-width:1200px;margin:0 auto;width:100%}

/* RESPONSIVE */
@media (max-width:1023px){
  :root{--pad-x:24px;--sec-y:clamp(64px,8vw,100px)}
  .nv{display:none}
  .mb{display:inline-flex}
  .hero{grid-template-columns:1fr;gap:32px;padding-top:100px}
  .pr-grid{grid-template-columns:1fr;gap:32px}
  .rm-gallery{grid-template-columns:1fr 1fr}
  .rm-gallery figure:nth-child(3){grid-column:1 / -1}
  .rm-list{grid-template-columns:1fr 1fr}
  .vs-grid{grid-template-columns:1fr;gap:24px}
}

@media (max-width:767px){
  :root{--pad-x:18px;--sec-y:64px}
  body{font-size:15.5px}
  .hdr{padding:14px 18px}
  .lg-w{font-size:21px}

  .hero{padding-top:80px;padding-bottom:48px}
  .hh{font-size:clamp(40px,12vw,64px)}
  .hh-4{font-size:.5em}
  .hp{font-size:15.5px}
  .cta-r{flex-direction:column;align-items:stretch}
  .cta-r .btn{justify-content:center;min-height:48px}

  .sh-h{font-size:36px}

  .pr-body p{font-size:15.5px}

  .m-list{margin:0 18px}
  .m-list li{grid-template-columns:60px 1fr;gap:18px;padding:22px 0}
  .m-no{font-size:12px;padding-top:4px}
  .m-list h3{font-size:22px}
  .m-list p{font-size:14.5px}

  .rm-gallery{grid-template-columns:1fr 1fr;gap:8px}
  .rm-gallery figure:nth-child(3){grid-column:1 / -1}
  .rm-list{grid-template-columns:1fr 1fr;gap:12px 24px;margin-top:24px;padding-top:20px}
  .rm-list dd{font-size:15.5px}

  .bk-steps li{grid-template-columns:60px 1fr;gap:18px;padding:18px 0}
  .bk-no{font-size:20px}
  .bk-steps p{font-size:14.5px}
  .bk-prices dt{font-size:15.5px}
  .bk-prices dd b{font-size:18px}
  .btn-big{padding:14px 22px;font-size:14px;width:100%;justify-content:center;min-height:48px}

  .vs-l div{grid-template-columns:90px 1fr;padding:11px 0}
  .vs-l dd{font-size:17px}
  .vs-map{min-height:320px}

  .ft-grid{grid-template-columns:1fr 1fr;gap:18px}
  .ft-grid a,.ft-grid address{font-size:15.5px}
  .ft-mark{font-size:clamp(72px,22vw,140px)}
}

@media (max-width:479px){.ft-grid{grid-template-columns:1fr}.rm-list{grid-template-columns:1fr}.rm-gallery{grid-template-columns:1fr}.rm-gallery figure:nth-child(3){grid-column:1}}
@media (hover:none) and (pointer:coarse){.btn,.mb,.dr-x{min-height:44px}}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}}
