/*
Theme Name: Пуща — Оздоровчий центр
Theme URI: https://puscha.kyiv.ua/
Author: Оздоровчий центр Пуща
Description: Сучасна тема для оздоровчого центру «Пуща». Стаціонар детоксу та відновлення в Пуща-Водиці.
Version: 4.1.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: Private
Text Domain: puscha
*/


/* ── Локальні шрифти (@font-face) ───────────────────────────────────────────
   Файли шрифтів мають лежати у /assets/fonts/ папці теми.
   Завантажте .woff2 файли з https://fontsource.org/fonts/manrope
   та https://fontsource.org/fonts/lora і покладіть у assets/fonts/
   ─────────────────────────────────────────────────────────────────────────── */
@font-face {
  font-family: 'Manrope';
  src: url('assets/fonts/manrope-400.woff2') format('woff2');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Manrope';
  src: url('assets/fonts/manrope-500.woff2') format('woff2');
  font-weight: 500; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Manrope';
  src: url('assets/fonts/manrope-600.woff2') format('woff2');
  font-weight: 600; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Manrope';
  src: url('assets/fonts/manrope-700.woff2') format('woff2');
  font-weight: 700; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Lora';
  src: url('assets/fonts/lora-500.woff2') format('woff2');
  font-weight: 500; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Lora';
  src: url('assets/fonts/lora-400italic.woff2') format('woff2');
  font-weight: 400; font-style: italic; font-display: swap;
}
@font-face {
  font-family: 'Lora';
  src: url('assets/fonts/lora-500italic.woff2') format('woff2');
  font-weight: 500; font-style: italic; font-display: swap;
}

/* ── Hero pretitle (SEO + дизайн) ───────────────────────────────────────────*/
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

:root{
  --pushcha-blue:#6fa8c8;
  --blue-accent:#4d8cb0;
  --blue-deep:#2d5872;
  --blue-ink:#1a3d52;
  --blue-soft:#b5d2e3;
  --blue-mist:#e3eef5;

  --pushcha-olive:#8fa441;
  --olive-deep:#6c7d2f;
  --olive-soft:#d8dea8;
  --olive-tint:#eef0d8;

  --cream:#f2efe7;
  --cream-deep:#ece8e0;
  --paper:#f8f5ed;
  --ink:#1a1f24;
  --white:#ffffff;
  --hairline:#dcd6c8;
  --hairline-dark:rgba(255,255,255,.12);

  --text-ink:#1a1f24;
  --text-soft:rgba(26,31,36,.66);
  --text-faint:rgba(26,31,36,.42);

  --serif:"Lora",Georgia,serif;
  --sans:"Manrope","Helvetica Neue",Arial,sans-serif;

  --ease:cubic-bezier(.25,.46,.45,.94);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:62.5%;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  font-size:1.6rem;line-height:1.6;
  color:var(--text-ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  letter-spacing:-.01em;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none;transition:color .25s var(--ease)}
button{font-family:inherit;cursor:pointer;border:none;background:none}
::selection{background:var(--blue-soft);color:var(--blue-ink)}

/* Subtle paper grain overlay */
body::before{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .045 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity:.7;
  mix-blend-mode:multiply;
}

.container{max-width:1320px;margin:0 auto;padding:0 2.4rem}
@media(min-width:768px){.container{padding:0 4rem}}
@media(min-width:1200px){.container{padding:0 6rem}}

/* ───────── EDITORIAL TYPE ───────── */
.eyebrow{
  display:inline-flex;align-items:center;gap:1rem;
  font-family:var(--sans);font-size:1.15rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.24em;
  color:var(--olive-deep);
}
.eyebrow::before{content:"";width:2.8rem;height:1px;background:currentColor;opacity:.6}
.eyebrow--dark{color:var(--olive-soft)}

.display{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(4.6rem,9vw,11rem);
  line-height:.95;letter-spacing:-.03em;
  color:var(--blue-ink);
}
.display em{font-style:italic;font-weight:400;color:var(--blue-deep)}

h2.section-title{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(2.8rem,4vw,4.8rem);
  line-height:1.02;letter-spacing:-.025em;
  color:var(--blue-ink);
}
h2.section-title em{font-style:italic;font-weight:400;color:var(--pushcha-olive)}

.lead{font-size:1.85rem;line-height:1.6;color:var(--text-soft);max-width:54ch;font-weight:400}

/* ───────── Buttons ───────── */
.btn{
  display:inline-flex;align-items:center;gap:1rem;justify-content:center;
  padding:1.5rem 2.8rem;border-radius:50px;
  font-family:var(--sans);font-weight:600;font-size:1.5rem;
  letter-spacing:.01em;
  transition:all .25s var(--ease);
  white-space:nowrap;
}
.btn:active{transform:scale(.96)}
.btn--primary{background:var(--blue-ink);color:#fff;box-shadow:0 12px 30px -12px rgba(26,61,82,.5)}
.btn--primary:hover{background:#0e2a3c;box-shadow:0 18px 40px -12px rgba(14,42,60,.55);transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--blue-ink);border:1.5px solid currentColor;opacity:.8}
.btn--ghost:hover{opacity:1;background:rgba(26,61,82,.05)}
.btn--light{background:#fff;color:var(--blue-ink)}
.btn--light:hover{background:var(--blue-mist)}
.btn svg{width:1.6rem;height:1.6rem;stroke-width:2}

/* ───────── NAV ───────── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:1.6rem 0;
  transition:all .3s var(--ease);
}
.nav.scrolled{
  background:rgba(242,239,231,.85);
  backdrop-filter:saturate(150%) blur(16px);
  -webkit-backdrop-filter:saturate(150%) blur(16px);
  box-shadow:0 1px 0 rgba(0,0,0,.06);
}
.nav__inner{
  display:flex;align-items:center;justify-content:space-between;gap:1.2rem;
  height:5.6rem;
}
@media(max-width:600px){
  .nav__inner{height:auto;padding:.8rem 0}
  .brand__name-2{display:none}
}
.brand{display:flex;align-items:center;gap:1.2rem}
/* Approach card — 5 vs 10 day variant rows */
.app-step__variant{
  margin-top:auto;display:flex;flex-direction:column;gap:1rem;
  padding-top:1.8rem;border-top:1px solid var(--hairline);
}
.app-step__variant-row{display:flex;gap:1.2rem;align-items:flex-start}
.app-step__variant-label{
  font-family:var(--sans);font-size:1.05rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:var(--pushcha-olive);
  flex-shrink:0;min-width:5.4rem;padding-top:.3rem;
}
.app-step__variant-text{flex:1;font-size:1.4rem;line-height:1.55;color:var(--text-soft)}
.app-step__both{
  margin-top:auto;padding-top:1.8rem;
  border-top:1px solid var(--hairline);
  font-family:var(--serif);font-style:italic;
  font-size:1.4rem;color:var(--text-soft);
}

.brand__mark{
  width:4.4rem;height:4.4rem;display:grid;place-items:center;
  flex-shrink:0;
}

/* Phone messenger pills */
.phone-line{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem 1.4rem}
.msg-badges{display:inline-flex;gap:.5rem;align-items:center}
.msg-badges a{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.45rem 1rem;border-radius:50px;
  background:var(--blue-mist);color:var(--blue-ink);
  font-size:1.15rem;font-weight:600;letter-spacing:.02em;
  transition:all .2s var(--ease);
}
.msg-badges a:hover{background:var(--blue-ink);color:#fff}
.msg-badges svg{width:1.3rem;height:1.3rem}
.brand__mark img{width:3.8rem;height:3.8rem;object-fit:contain}
.brand__name{display:flex;flex-direction:column;line-height:1}
.brand__name-1{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:2.2rem;color:var(--blue-ink);letter-spacing:-.01em;
}
.brand__name-2{
  font-family:var(--sans);font-size:1rem;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;color:var(--pushcha-olive);
  margin-top:.4rem;
}
.nav__links{display:none;gap:.2rem;align-items:center}
@media(min-width:1024px){.nav__links{display:flex}}
.nav__links a{
  padding:.8rem 1.4rem;font-size:1.35rem;font-weight:500;color:var(--text-ink);
  position:relative;
}
.nav__links a::after{
  content:"";position:absolute;left:1.4rem;right:1.4rem;bottom:.4rem;
  height:1px;background:var(--blue-ink);
  transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease-out);
}
.nav__links a:hover::after{transform:scaleX(1)}
.nav__right{display:flex;align-items:center;gap:1.4rem;flex-shrink:0}
.nav__phone{
  display:none;font-size:1.35rem;font-weight:600;color:var(--blue-ink);
  font-variant-numeric:tabular-nums;
}
@media(min-width:768px){.nav__phone{display:inline-flex;align-items:center;gap:.6rem}}
.nav__phone svg{width:1.4rem;height:1.4rem;color:var(--pushcha-blue)}
.nav__cta{padding:1.1rem 2rem;font-size:1.3rem}
/* ───────── HERO ───────── */
.hero{
  position:relative;
  padding:8rem 0 4rem;
  z-index:2;
}
@media(min-width:1024px){.hero{padding:11rem 0 6rem}}

.hero__inner{
  display:grid;grid-template-columns:1fr;gap:5rem;
  align-items:end;position:relative;
}
@media(min-width:1024px){
  .hero__inner{grid-template-columns:1.15fr .85fr;gap:6rem;align-items:end}
}

.hero__meta{
  display:flex;align-items:center;gap:1.6rem;margin-bottom:3rem;
  font-family:var(--sans);font-size:1.2rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.2em;color:var(--text-soft);
}
.hero__meta-dot{width:.6rem;height:.6rem;border-radius:50%;background:#4ade80;box-shadow:0 0 0 4px rgba(74,222,128,.18)}
.hero__meta-divider{flex:1;max-width:8rem;height:1px;background:rgba(0,0,0,.18)}

.hero__title{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(4.2rem,6vw,7rem);
  line-height:.92;letter-spacing:-.035em;
  color:var(--blue-ink);
}
.hero__title-row{display:block;position:relative}
.hero__title em{
  font-style:italic;font-weight:400;
  color:var(--pushcha-olive);
  position:relative;
}
.hero__title em::after{
  content:"";position:absolute;left:0;right:0;bottom:.15em;
  height:.08em;background:rgba(143,164,65,.25);z-index:-1;
}

.hero__lead{
  margin-top:2.4rem;font-size:1.7rem;line-height:1.55;color:var(--text-soft);
  max-width:48ch;
}
.hero__lead strong{color:var(--blue-ink);font-weight:600}

.hero__cta{display:flex;gap:1.2rem;flex-wrap:wrap;align-items:center;margin-top:2.4rem}

.hero__stats{
  display:flex;flex-wrap:wrap;gap:3.2rem 5rem;
  margin-top:3rem;padding-top:2rem;
  border-top:1px solid rgba(0,0,0,.1);
}
.hero__stat-num{
  font-family:var(--serif);font-weight:500;
  font-size:4rem;line-height:1;color:var(--blue-ink);letter-spacing:-.03em;
}
.hero__stat-num sup{font-size:1.8rem;color:var(--pushcha-olive);font-weight:500;top:-2rem;position:relative}
.hero__stat-label{font-size:1.3rem;color:var(--text-soft);margin-top:.6rem;text-transform:uppercase;letter-spacing:.16em;font-weight:500}

/* Hero visual: layered photo + frame */
.hero__visual{position:relative;height:60rem}
@media(max-width:1023px){.hero__visual{height:48rem;margin-top:2rem}}
.hero__photo-main{
  position:absolute;inset:0;border-radius:0;
  overflow:hidden;
  box-shadow:0 40px 80px -30px rgba(26,61,82,.4);
}
.hero__photo-main img{width:100%;height:100%;object-fit:cover;object-position:center 30%;filter:sepia(.12) saturate(1.15) contrast(1.03)}

.hero__photo-frame{
  position:absolute;inset:-2rem -2rem auto auto;width:60%;height:35%;
  border:1px solid rgba(255,255,255,.6);
  border-radius:0;pointer-events:none;z-index:-1;
}
.hero__photo-frame::before{
  content:"";position:absolute;top:-2rem;right:-2rem;width:8rem;height:8rem;
  border-top:1px solid var(--blue-ink);border-right:1px solid var(--blue-ink);
  opacity:.3;
}

/* badge/chip */
.hero__chip{
  position:absolute;top:2rem;left:-2rem;
  background:rgba(255,255,255,.92);backdrop-filter:blur(8px);
  padding:1.2rem 1.6rem;border-radius:50px;
  display:flex;align-items:center;gap:1rem;
  box-shadow:0 20px 40px -20px rgba(0,0,0,.25);
  z-index:3;
}
.hero__chip-dot{width:.7rem;height:.7rem;border-radius:50%;background:#4ade80;box-shadow:0 0 0 4px rgba(74,222,128,.2)}
.hero__chip-text{font-size:1.25rem;color:var(--blue-ink);font-weight:600;letter-spacing:.02em}

.hero__capsule{
  position:absolute;left:-3rem;bottom:-3rem;
  background:var(--blue-ink);color:#fff;
  padding:2.4rem 2.8rem;border-radius:0;
  display:flex;flex-direction:column;gap:.6rem;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.35);
  z-index:3;max-width:30rem;
}
.hero__capsule small{
  font-size:1.05rem;text-transform:uppercase;letter-spacing:.2em;
  color:var(--olive-soft);font-weight:600;
}
.hero__capsule-text{font-family:var(--serif);font-style:italic;font-size:1.7rem;line-height:1.35;color:#fff}
@media(max-width:1023px){
  .hero__capsule{left:1rem;bottom:1rem;max-width:26rem;padding:2rem}
  .hero__chip{left:1rem;top:1rem}
}

/* corner label */
.side-label{
  position:absolute;left:-1rem;top:0;
  writing-mode:vertical-rl;transform:rotate(180deg);
  font-family:var(--sans);font-size:1.05rem;font-weight:600;
  letter-spacing:.3em;text-transform:uppercase;color:var(--text-faint);
}
@media(max-width:1199px){.side-label{display:none}}

/* ───────── MARQUEE ───────── */
.marquee{
  background:var(--cream-deep);
  padding:2rem 0;margin-top:3rem;
  border-top:1px solid var(--hairline);
  border-bottom:1px solid var(--hairline);
  overflow:hidden;position:relative;z-index:2;
}
.marquee__track{
  display:flex;gap:5rem;
  animation:marquee 40s linear infinite;
  width:max-content;
}
.marquee__item{
  display:flex;align-items:center;gap:2rem;
  font-family:var(--serif);font-style:italic;
  font-size:2.4rem;font-weight:400;color:var(--blue-ink);
  white-space:nowrap;
}
.marquee__item::after{
  content:"✦";color:var(--pushcha-olive);font-style:normal;font-size:1.6rem;margin-left:3rem;
}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ───────── Section base ───────── */
section{position:relative;z-index:2}
.section-pad{padding:6rem 0}
@media(max-width:768px){.section-pad{padding:8rem 0}}

.sec-head{margin-bottom:3.5rem;display:grid;grid-template-columns:1fr;gap:2rem;align-items:end}
@media(min-width:900px){.sec-head{grid-template-columns:1fr 1fr;gap:6rem}}
.sec-head h2{margin-top:2rem}
.sec-head__lead{font-size:1.65rem;line-height:1.6;color:var(--text-soft);max-width:50ch}

/* ───────── PROGRAMS — editorial ───────── */
#programs{background:var(--cream);padding:7rem 0}

.prog-list{display:flex;flex-direction:column;gap:4rem}

.prog{
  display:grid;grid-template-columns:1fr;gap:4rem;align-items:center;
  position:relative;
}
@media(min-width:900px){
  .prog{grid-template-columns:1fr 1fr;gap:6rem}
  .prog--reverse .prog__media{order:2}
}

.prog__media{
  position:relative;aspect-ratio:4/5;overflow:hidden;
}
.prog__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease-out)}
.prog:hover .prog__media img{transform:scale(1.05)}
.prog__media-num{
  position:absolute;top:-3rem;right:2rem;
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:9rem;line-height:1;color:var(--blue-ink);
  letter-spacing:-.04em;z-index:2;
  pointer-events:none;
}
@media(max-width:899px){.prog__media-num{font-size:9rem;top:-2rem;right:1rem}}

.prog__media-tag{
  position:absolute;bottom:2rem;left:2rem;
  background:rgba(255,255,255,.94);backdrop-filter:blur(8px);
  padding:.8rem 1.6rem;border-radius:50px;
  font-size:1.15rem;font-weight:600;color:var(--blue-ink);
  letter-spacing:.16em;text-transform:uppercase;
}

.prog__body{padding:0}
.prog__duration{
  display:flex;align-items:baseline;gap:1.6rem;margin-bottom:2rem;
}
.prog__duration-big{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:5rem;line-height:1;color:var(--blue-ink);letter-spacing:-.03em;
}
.prog__duration-small{font-size:1.4rem;color:var(--text-soft);text-transform:uppercase;letter-spacing:.18em;font-weight:600}

.prog__title{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(2.6rem,3.5vw,3.8rem);
  line-height:1.05;letter-spacing:-.02em;color:var(--blue-ink);
  margin-bottom:1.6rem;
}
.prog__title em{font-style:italic;font-weight:400;color:var(--pushcha-olive)}

.prog__copy{font-size:1.65rem;line-height:1.6;color:var(--text-soft);margin-bottom:3.2rem;max-width:48ch}

.prog__list{
  list-style:none;display:flex;flex-direction:column;gap:0;
  border-top:1px solid var(--hairline);
}
.prog__list li{
  display:flex;align-items:center;gap:1.4rem;
  padding:1.4rem 0;
  border-bottom:1px solid var(--hairline);
  font-size:1.55rem;color:var(--text-ink);
  font-weight:500;
}
.prog__list svg{width:1.6rem;height:1.6rem;color:var(--olive-deep);flex-shrink:0}

.prog__foot{
  display:flex;align-items:center;justify-content:space-between;gap:2rem;
  margin-top:2.8rem;flex-wrap:wrap;
}
.prog__price-tag{
  font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--text-soft);
}
.prog__price-tag b{font-style:normal;font-family:var(--sans);font-weight:700;font-size:2rem;color:var(--blue-ink);margin-left:.6rem}

/* ───────── SYMPTOMS — cinematic dark ───────── */
#symptoms{
  background:var(--blue-ink);color:#fff;
  position:relative;overflow:hidden;
  padding:7rem 0;
}
#symptoms::before{
  content:"";position:absolute;inset:0;
  background:url("assets/symptoms-bg.webp") center/cover;
  opacity:.18;filter:saturate(.6) contrast(1.05);
}
#symptoms::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse 100% 80% at 50% 50%, transparent, rgba(26,61,82,.85));
}
#symptoms .container{position:relative;z-index:2}
#symptoms h2{color:#fff}
#symptoms h2 em{color:var(--olive-soft)}
#symptoms .sec-head__lead{color:rgba(255,255,255,.7);font-size:1.85rem}

.sym-quote{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:clamp(2rem,3vw,3rem);line-height:1.3;
  color:var(--olive-soft);max-width:36ch;
  margin:0 0 2.4rem;
  position:relative;padding-left:3rem;
}
.sym-quote::before{
  content:"";position:absolute;left:0;top:.2em;bottom:.2em;width:2px;background:var(--pushcha-olive);
}

.sym-list{
  list-style:none;display:grid;grid-template-columns:1fr;gap:0;
  border-top:1px solid var(--hairline-dark);
}
@media(min-width:768px){.sym-list{grid-template-columns:1fr 1fr;border-top:1px solid var(--hairline-dark)}}

.sym-item{
  padding:2rem 0;
  border-bottom:1px solid var(--hairline-dark);
  display:flex;gap:2.4rem;align-items:flex-start;
  transition:padding .3s var(--ease);
}
@media(min-width:768px){
  .sym-item:nth-child(2n-1){padding-right:3rem;border-right:1px solid var(--hairline-dark)}
  .sym-item:nth-child(2n){padding-left:3rem}
}
.sym-item:hover{padding-left:1rem}
@media(min-width:768px){.sym-item:nth-child(2n):hover{padding-left:4rem}}

.sym-num{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:3.6rem;line-height:1;color:var(--olive-soft);
  letter-spacing:-.02em;flex-shrink:0;min-width:4rem;
}
.sym-item h4{
  font-family:var(--sans);font-size:1.7rem;font-weight:600;color:#fff;
  letter-spacing:-.01em;margin-bottom:.5rem;
}
.sym-item p{font-size:1.4rem;color:rgba(255,255,255,.65);line-height:1.5}

.sym-foot{
  margin-top:3rem;display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap;
  padding-top:2.4rem;border-top:1px solid var(--hairline-dark);
}
.sym-foot p{font-family:var(--serif);font-style:italic;font-size:1.85rem;color:rgba(255,255,255,.85);max-width:46ch}

/* ───────── APPROACH — sticky number ───────── */
#approach{background:var(--paper);padding:7rem 0}
.app-grid{
  display:grid;grid-template-columns:1fr;gap:2rem;
}
@media(min-width:768px){.app-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.app-grid{grid-template-columns:repeat(4,1fr);gap:0}}

.app-step{
  padding:4rem 3rem;
  border-top:2px solid var(--blue-ink);
  display:flex;flex-direction:column;gap:1.6rem;
  position:relative;
  transition:background .3s var(--ease);
}
@media(min-width:1024px){
  .app-step{border-right:1px solid var(--hairline)}
  .app-step:last-child{border-right:none}
}
.app-step:hover{background:rgba(255,255,255,.5)}
.app-step__num{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:2rem;color:var(--pushcha-olive);
}
.app-step h4{
  font-family:var(--serif);font-weight:500;font-size:2.6rem;line-height:1.1;
  color:var(--blue-ink);letter-spacing:-.02em;
}
.app-step h4 em{font-style:italic;font-weight:400;color:var(--pushcha-olive)}
.app-step p{font-size:1.45rem;color:var(--text-soft);line-height:1.6;margin-top:auto}

/* ───────── BENEFITS — editorial grid ───────── */
#benefits{background:var(--cream);padding:7rem 0;position:relative;overflow:hidden}

.ben-grid{
  display:grid;grid-template-columns:1fr;gap:4rem 3rem;
}
@media(max-width:639px){.ben-grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media(min-width:640px){.ben-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.ben-grid{grid-template-columns:repeat(4,1fr);gap:5rem 2.4rem}}

.ben{display:flex;flex-direction:column}
.ben__media{
  position:relative;aspect-ratio:2/1;overflow:hidden;
  margin-bottom:2.4rem;
}
@media(max-width:639px){.ben__media{aspect-ratio:2/1!important;margin-bottom:1.2rem}}
.ben__media img{width:100%;height:100%;object-fit:cover;object-position:center center}
.ben__media-num{
  position:absolute;top:1rem;left:1rem;
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:1.4rem;color:#fff;letter-spacing:.1em;
  text-shadow:0 1px 4px rgba(0,0,0,.3);
}
.ben h4{
  font-family:var(--serif);font-weight:500;font-size:2.6rem;line-height:1.1;
  color:var(--blue-ink);letter-spacing:-.02em;margin-bottom:1rem;
}
.ben h4 em{font-style:italic;font-weight:400;color:var(--pushcha-olive)}
.ben p{font-size:1.5rem;color:var(--text-soft);line-height:1.55}

/* ───────── EDITORIAL QUOTE ───────── */
#essay{
  background:var(--cream-deep);padding:7rem 0;
  position:relative;overflow:hidden;
}
.essay-inner{
  display:grid;grid-template-columns:1fr;gap:4rem;align-items:center;
  max-width:1100px;margin:0 auto;
}
@media(min-width:900px){.essay-inner{grid-template-columns:auto 1fr;gap:6rem}}
.essay__sig{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:6rem;line-height:1;color:var(--pushcha-olive);
  opacity:.65;
}
.essay__text{
  font-family:var(--serif);font-weight:500;font-style:italic;
  font-size:clamp(2rem,2.6vw,2.8rem);line-height:1.4;
  color:var(--blue-ink);letter-spacing:-.01em;
}
.essay__sign{
  margin-top:3rem;font-family:var(--sans);font-style:normal;
  font-size:1.3rem;color:var(--text-soft);letter-spacing:.18em;
  text-transform:uppercase;font-weight:600;
}

/* ───────── PRICING ───────── */
#pricing{background:var(--cream);padding:7rem 0}

.pricing-wrap{
  display:grid;grid-template-columns:1fr;gap:5rem;align-items:start;
}
@media(min-width:1024px){.pricing-wrap{grid-template-columns:1.2fr .8fr;gap:6rem}}

.tabs{
  display:inline-flex;background:transparent;padding:0;border:none;margin-bottom:3.6rem;
  border-bottom:1px solid var(--hairline);width:100%;
}
.tab{
  padding:1.6rem 0;margin-right:4rem;
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:2.4rem;color:var(--text-faint);
  transition:color .25s var(--ease);
  border-bottom:2px solid transparent;margin-bottom:-1px;
  letter-spacing:-.01em;
}
.tab span{font-size:1.5rem;font-style:normal;font-family:var(--sans);font-weight:600;margin-left:.6rem;text-transform:uppercase;letter-spacing:.16em;color:inherit}
.tab.is-active{color:var(--blue-ink);border-bottom-color:var(--blue-ink)}
.tab:hover:not(.is-active){color:var(--text-soft)}

.tab-panel{display:none}
.tab-panel.is-active{display:block;animation:fadeIn .4s var(--ease-out)}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.price-row{
  display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:center;
  padding:2rem 1.6rem;
  border-bottom:1px solid var(--hairline);
  background:#fff;
  border-radius:.6rem;
  box-shadow:0 1px 4px rgba(0,0,0,.06);
  margin-bottom:1rem;
  transition:box-shadow .25s var(--ease);
}
.price-row:hover{box-shadow:0 4px 16px rgba(0,0,0,.1)}
.price-row:hover{padding-left:1rem}
.price-row__name{font-family:var(--serif);font-size:2.2rem;font-weight:500;color:var(--blue-ink);letter-spacing:-.01em}
.price-row__extra{font-size:1.25rem;color:var(--text-faint);margin-top:.6rem;text-transform:uppercase;letter-spacing:.14em;font-weight:500}
.price-row__amt{
  font-family:var(--serif);font-style:italic;font-size:2.6rem;font-weight:500;
  color:var(--blue-ink);white-space:nowrap;letter-spacing:-.02em;
}
.price-row__amt b{font-style:normal;font-family:var(--sans);font-weight:700}

.price-foot{margin-top:3.2rem;display:flex;gap:1.6rem;align-items:center;flex-wrap:wrap}
.price-foot__note{font-size:1.3rem;color:var(--text-soft);font-style:italic;font-family:var(--serif)}

.inc-card{
  background:var(--blue-ink);color:#fff;
  padding:4rem;
  position:relative;overflow:hidden;
}
.inc-card::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:3px;
  background:linear-gradient(90deg, var(--pushcha-olive), var(--olive-soft));
}
.inc-card h4{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:2.6rem;color:#fff;margin-bottom:2.4rem;letter-spacing:-.01em;
}
.inc-list{list-style:none;display:flex;flex-direction:column;gap:0;border-top:1px solid var(--hairline-dark)}
.inc-list li{
  display:flex;gap:1.4rem;align-items:center;
  padding:1.4rem 0;border-bottom:1px solid var(--hairline-dark);
  font-size:1.45rem;color:rgba(255,255,255,.92);
}
.inc-list svg{width:1.4rem;height:1.4rem;color:var(--olive-soft);flex-shrink:0}
.inc-list__note{font-size:1.1rem!important;color:rgba(255,255,255,.4)!important;font-style:italic;border-bottom:none!important;padding-top:.6rem!important;padding-bottom:.8rem!important;display:block}

.add-card{
  background:var(--paper);padding:3rem;margin-top:2rem;
  border:1px solid var(--hairline);
}
.add-card h4{
  font-size:1.15rem;letter-spacing:.22em;text-transform:uppercase;
  font-weight:700;color:var(--olive-deep);margin-bottom:1.8rem;
}
.add-card p{font-size:1.4rem;color:var(--text-soft);margin-bottom:.8rem;line-height:1.6;font-family:var(--serif)}
.add-card strong{color:var(--blue-ink);font-weight:600;font-family:var(--sans);font-style:normal}
.add-card h5{
  font-size:1.05rem;letter-spacing:.22em;text-transform:uppercase;
  font-weight:700;color:var(--olive-deep);
  margin:2.4rem 0 1.4rem;
}
.add-card__list{list-style:none;display:flex;flex-direction:column;gap:.4rem;margin:0;padding:0}
.add-card__list li{
  font-family:var(--serif);font-style:italic;font-size:1.5rem;
  color:var(--blue-ink);line-height:1.4;
  position:relative;padding-left:1.8rem;
}
.add-card__list li::before{
  content:"";position:absolute;left:0;top:.7em;
  width:1rem;height:1px;background:var(--pushcha-olive);
}

/* ───────── TESTIMONIALS — single editorial quote ───────── */
#testimonials{background:var(--cream-deep);padding:7rem 0;position:relative;overflow:hidden}
.test-track{
  display:flex;gap:3.2rem;overflow-x:auto;scroll-snap-type:x mandatory;
  padding-bottom:2rem;-webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.test-track::-webkit-scrollbar{display:none}
.test{
  flex:0 0 80%;max-width:48rem;scroll-snap-align:start;
  display:flex;flex-direction:column;gap:3rem;
  padding:0;
}
@media(min-width:768px){.test{flex:0 0 32rem}}
@media(min-width:1024px){.test{flex:0 0 36rem}}

.test__stars{display:flex;gap:.2rem;color:var(--pushcha-olive);font-size:1.6rem}
.test__quote{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:2.4rem;line-height:1.35;color:var(--blue-ink);letter-spacing:-.01em;
}
.test__author{display:flex;align-items:center;gap:1.4rem;margin-top:auto;padding-top:2rem;border-top:1px solid var(--hairline)}
.test__avatar{
  width:5rem;height:5rem;border-radius:50%;
  background:var(--blue-ink);color:#fff;
  display:grid;place-items:center;
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:1.7rem;flex-shrink:0;
}
.test__name{font-size:1.55rem;font-weight:600;color:var(--blue-ink);letter-spacing:-.01em}
.test__meta{font-size:1.25rem;color:var(--text-faint);margin-top:.2rem;letter-spacing:.06em}

.test-meta-row{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:5rem;padding-top:3rem;border-top:1px solid var(--hairline);
  font-size:1.3rem;color:var(--text-soft);letter-spacing:.16em;text-transform:uppercase;font-weight:600;
}

/* ───────── CONTACT ───────── */
#contact{background:var(--cream);padding:7rem 0 5rem}

.contact-wrap{
  display:grid;grid-template-columns:1fr;gap:5rem;
}
@media(min-width:1024px){.contact-wrap{grid-template-columns:1fr 1fr;gap:8rem}}

.contact__left h2{margin-top:2rem;margin-bottom:3rem}
.contact__left .lead{margin-bottom:4rem}

.contact-meta{display:flex;flex-direction:column;gap:0;margin-top:2rem;border-top:1px solid var(--hairline)}
.ci{
  display:grid;grid-template-columns:auto 1fr;gap:2rem;align-items:center;
  padding:2.4rem 0;border-bottom:1px solid var(--hairline);
}
.ci__icon{
  width:4.8rem;height:4.8rem;border-radius:50%;
  background:transparent;border:1px solid var(--hairline);
  color:var(--blue-ink);
  display:grid;place-items:center;flex-shrink:0;
  transition:all .25s var(--ease);
}
.ci:hover .ci__icon{background:var(--blue-ink);color:#fff;border-color:var(--blue-ink)}
.ci__icon svg{width:1.9rem;height:1.9rem}
.ci__label{font-size:1.1rem;color:var(--text-faint);text-transform:uppercase;letter-spacing:.2em;font-weight:600;margin-bottom:.4rem}
.ci__val{font-size:1.8rem;color:var(--blue-ink);font-weight:500;display:block;font-family:var(--serif)}
.ci__val + .ci__val{margin-top:.3rem}

.socials{display:flex;gap:1.2rem;margin-top:3rem}
.social{
  width:4.8rem;height:4.8rem;border-radius:50%;
  background:transparent;border:1px solid var(--hairline);
  color:var(--blue-ink);
  display:grid;place-items:center;
  transition:all .25s var(--ease);
}
.social:hover{background:var(--blue-ink);color:#fff;border-color:var(--blue-ink);transform:translateY(-2px)}
.social svg{width:1.9rem;height:1.9rem}

.contact__visual{
  position:relative;min-height:60rem;
  overflow:hidden;
  background:linear-gradient(180deg, rgba(26,61,82,.15), rgba(26,61,82,.65)),
    url("assets/program-10day.webp") center/cover;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:4rem;color:#fff;
}
.contact__visual::before{
  content:"";position:absolute;top:2.4rem;left:2.4rem;right:2.4rem;bottom:2.4rem;
  border:1px solid rgba(255,255,255,.3);pointer-events:none;
}
.contact__visual-eyebrow{
  font-size:1.1rem;text-transform:uppercase;letter-spacing:.24em;
  color:var(--olive-soft);font-weight:600;margin-bottom:1.6rem;
}
.contact__visual-addr{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:clamp(2.4rem,3vw,3.4rem);line-height:1.1;letter-spacing:-.02em;
}
.contact__visual-sub{font-size:1.5rem;color:rgba(255,255,255,.8);margin-top:2rem;max-width:32ch;line-height:1.55}
.contact__visual-link{
  margin-top:3rem;display:inline-flex;align-items:center;gap:1rem;
  padding:1.4rem 2.4rem;background:rgba(255,255,255,.12);
  backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.25);
  border-radius:50px;
  font-size:1.4rem;font-weight:600;color:#fff;align-self:flex-start;
  transition:all .2s var(--ease);
}
.contact__visual-link:hover{background:#fff;color:var(--blue-ink);border-color:#fff}

/* ───────── Footer ───────── */
footer{
  background:var(--blue-ink);color:#fff;padding:3rem 0;
  position:relative;overflow:hidden;z-index:2;
}
.foot-top{
  display:grid;grid-template-columns:1fr;gap:5rem;
  padding-bottom:5rem;border-bottom:1px solid var(--hairline-dark);
}
@media(min-width:768px){.foot-top{grid-template-columns:1.4fr 1fr 1fr 1fr}}

.foot__brand .brand__name-1{color:#fff}
.foot__brand .brand__name-2{color:var(--olive-soft)}
.foot__brand p{font-size:1.45rem;color:rgba(255,255,255,.6);line-height:1.6;margin-top:2rem;max-width:30rem}

.foot__col h5{font-size:1.05rem;letter-spacing:.24em;text-transform:uppercase;font-weight:700;color:var(--olive-soft);margin-bottom:2rem}
.foot__col a, .foot__col p{display:block;font-size:1.5rem;color:rgba(255,255,255,.7);padding:.45rem 0;transition:color .2s var(--ease);font-family:var(--serif);font-style:italic;font-weight:400}
.foot__col a:hover{color:#fff}

/* ───────── FAB ───────── */
.fab{
  position:fixed;bottom:2.4rem;right:2.4rem;z-index:90;
  width:5.6rem;height:5.6rem;border-radius:50%;
  background:var(--blue-ink);color:#fff;
  display:grid;place-items:center;
  box-shadow:0 0 6px rgba(0,0,0,.24), 0 8px 18px rgba(0,0,0,.2);
  transition:all .25s var(--ease);
}
.fab:hover{background:var(--pushcha-olive);transform:scale(1.06)}
.fab:active{transform:scale(.95)}
.fab svg{width:2.4rem;height:2.4rem}

/* ───────── Fade-in ───────── */
.fade-in{opacity:0;transform:translateY(24px);transition:opacity 1s var(--ease-out), transform 1s var(--ease-out)}
.fade-in.in{opacity:1;transform:none}
.fade-in.delay-1{transition-delay:.1s}
.fade-in.delay-2{transition-delay:.2s}
.fade-in.delay-3{transition-delay:.3s}
@media (prefers-reduced-motion:reduce){.fade-in{opacity:1;transform:none;transition:none}}

/* ════════════════════════════════════════════
   JOURNAL — list/single page styles
   ════════════════════════════════════════════ */

/* ─── PAGE HEAD ─── */
.page-head{
  padding:13rem 0 5rem;
  position:relative;z-index:2;
}
.page-head__inner{
  display:grid;grid-template-columns:1fr;gap:5rem;align-items:end;
}
@media(min-width:1024px){.page-head__inner{grid-template-columns:1.2fr .8fr;gap:8rem}}

.page-head__crumb{
  display:flex;align-items:center;gap:1rem;
  font-size:1.2rem;color:var(--text-soft);
  letter-spacing:.16em;text-transform:uppercase;font-weight:600;
  margin-bottom:3rem;
}
.page-head__crumb a:hover{color:var(--blue-ink)}
.page-head__crumb svg{width:1.2rem!important;height:1.2rem!important;max-width:1.2rem!important;max-height:1.2rem!important;flex-shrink:0;opacity:.5}

.page-head h1{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(4.2rem,6vw,7rem);
  line-height:.95;letter-spacing:-.035em;color:var(--blue-ink);
}
.page-head h1 em{font-style:italic;font-weight:400;color:var(--pushcha-olive)}

.page-head__lead{
  font-size:1.85rem;line-height:1.55;color:var(--text-soft);
  max-width:46ch;
}

/* ─── FILTERS ─── */
.filters{
  display:flex;flex-wrap:wrap;gap:1rem;
  margin:6rem 0 5rem;padding:2rem 0;
  border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);
  align-items:center;
}
.filters__label{font-size:1.15rem;text-transform:uppercase;letter-spacing:.2em;color:var(--text-faint);font-weight:600;margin-right:1rem}
.chip{
  padding:.8rem 1.6rem;border-radius:50px;
  font-family:var(--sans);font-size:1.35rem;font-weight:500;
  color:var(--text-soft);
  border:1px solid var(--hairline);background:transparent;
  transition:all .2s var(--ease);
}
.chip:hover{border-color:var(--blue-ink);color:var(--blue-ink)}
.chip.is-active{background:var(--blue-ink);color:#fff;border-color:var(--blue-ink)}
.filters__count{margin-left:auto;font-family:var(--serif);font-style:italic;font-size:1.55rem;color:var(--text-soft)}
.filters__count b{font-style:normal;font-family:var(--sans);font-weight:700;color:var(--blue-ink)}

/* ─── FEATURED ARTICLE ─── */
.feature{
  display:grid;grid-template-columns:1fr;gap:4rem;
  padding-bottom:8rem;border-bottom:1px solid var(--hairline);
  align-items:center;
}
@media(min-width:900px){.feature{grid-template-columns:1.1fr .9fr;gap:6rem}}

.feature__media{
  position:relative;aspect-ratio:4/3;overflow:hidden;
}
.feature__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease-out)}
.feature:hover .feature__media img{transform:scale(1.04)}
.feature__media-tag{
  position:absolute;top:2rem;left:2rem;
  background:#fff;padding:.7rem 1.4rem;border-radius:50px;
  font-size:1.05rem;font-weight:700;color:var(--blue-ink);
  letter-spacing:.2em;text-transform:uppercase;
}

.feature__cat{
  display:inline-block;
  font-family:var(--sans);font-size:1.1rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;color:var(--pushcha-olive);
  margin-bottom:2rem;
}
.feature__title{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(2.6rem,3.5vw,4rem);
  line-height:1.02;letter-spacing:-.025em;color:var(--blue-ink);
  margin-bottom:2.4rem;
}
.feature__title em{font-style:italic;font-weight:400;color:var(--blue-deep)}
.feature__excerpt{font-size:1.75rem;line-height:1.5;color:var(--text-soft);margin-bottom:3rem;max-width:50ch}
.feature__meta{
  display:flex;gap:2.4rem;align-items:center;flex-wrap:wrap;
  font-size:1.25rem;color:var(--text-faint);
  letter-spacing:.14em;text-transform:uppercase;font-weight:600;
  padding-bottom:2.4rem;border-bottom:1px solid var(--hairline);
  margin-bottom:2.4rem;
}
.feature__meta-dot{width:.4rem;height:.4rem;border-radius:50%;background:var(--pushcha-olive)}

/* ─── JOURNAL GRID ─── */
.journal{padding:4rem 0 6rem;position:relative;z-index:2}

.journal__head{
  display:flex;justify-content:space-between;align-items:end;
  margin-bottom:5rem;gap:2rem;flex-wrap:wrap;
}
.journal__head h2{font-family:var(--serif);font-weight:500;font-size:clamp(2.4rem,3vw,3.6rem);line-height:1.05;color:var(--blue-ink);letter-spacing:-.02em}
.journal__head h2 em{font-style:italic;font-weight:400;color:var(--pushcha-olive)}

.grid{
  display:grid;grid-template-columns:1fr;gap:5rem 3rem;
}
@media(min-width:640px){.grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.grid{grid-template-columns:repeat(3,1fr);gap:6rem 3rem}}

.card{display:flex;flex-direction:column;cursor:pointer;transition:transform .35s var(--ease-out)}
.card:hover{transform:translateY(-4px)}
.card__media{
  position:relative;aspect-ratio:4/5;overflow:hidden;margin-bottom:2.4rem;
}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease-out)}
.card:hover .card__media img{transform:scale(1.06)}
.card__num{
  position:absolute;top:1.4rem;left:1.6rem;
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:1.4rem;color:#fff;letter-spacing:.06em;
  text-shadow:0 1px 4px rgba(0,0,0,.4);
}
.card__cat{
  display:inline-block;font-size:1.05rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;color:var(--pushcha-olive);
  margin-bottom:1.2rem;
}
.card__title{
  font-family:var(--serif);font-weight:500;
  font-size:2.6rem;line-height:1.1;color:var(--blue-ink);
  letter-spacing:-.02em;margin-bottom:1.4rem;
  transition:color .2s var(--ease);
}
.card__title em{font-style:italic;font-weight:400;color:var(--pushcha-olive)}
.card:hover .card__title{color:var(--blue-deep)}
.card__excerpt{font-size:1.5rem;color:var(--text-soft);line-height:1.55;margin-bottom:2rem}
.card__meta{
  display:flex;gap:1.4rem;align-items:center;
  font-size:1.2rem;color:var(--text-faint);letter-spacing:.14em;
  text-transform:uppercase;font-weight:600;margin-top:auto;
  padding-top:2rem;border-top:1px solid var(--hairline);
}
.card__meta-dot{width:.4rem;height:.4rem;border-radius:50%;background:var(--text-faint)}
.card__readmore{
  margin-left:auto;color:var(--blue-ink);font-weight:700;letter-spacing:.04em;
  display:inline-flex;align-items:center;gap:.4rem;
}
.card__readmore::after{content:"→";transition:transform .25s var(--ease)}
.card:hover .card__readmore::after{transform:translateX(4px)}

/* ─── NEWSLETTER ─── */
.newsletter{
  background:var(--blue-ink);color:#fff;
  padding:8rem 0;position:relative;overflow:hidden;z-index:2;
}
.newsletter::before{
  content:"";position:absolute;inset:0;
  background:url("assets/program-10day.webp") center/cover;
  opacity:.12;filter:saturate(.5);
}
.newsletter::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse 80% 60% at 50% 50%, transparent, rgba(26,61,82,.85));
}
.newsletter__inner{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr;gap:4rem;align-items:center;
}
@media(min-width:900px){.newsletter__inner{grid-template-columns:1fr 1fr;gap:8rem}}

.newsletter h2{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(2.4rem,3.5vw,4rem);line-height:1.05;color:#fff;
  letter-spacing:-.025em;
}
.newsletter h2 em{font-style:italic;font-weight:400;color:var(--olive-soft)}
.newsletter p{font-size:1.65rem;color:rgba(255,255,255,.7);line-height:1.55;margin-top:1.6rem;max-width:46ch}

.nl-form{display:flex;flex-direction:column;gap:1.2rem}
.nl-input-row{
  display:flex;gap:0;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);border-radius:50px;
  padding:.6rem;backdrop-filter:blur(8px);
}
.nl-input{
  flex:1;background:transparent;border:none;outline:none;color:#fff;
  font-family:var(--sans);font-size:1.5rem;padding:1.2rem 2rem;
}
.nl-input::placeholder{color:rgba(255,255,255,.5)}
.nl-submit{
  background:#fff;color:var(--blue-ink);border:none;border-radius:50px;
  padding:1.2rem 2.4rem;font-family:var(--sans);font-weight:700;font-size:1.4rem;
  letter-spacing:.02em;cursor:pointer;transition:all .2s var(--ease);
}
.nl-submit:hover{background:var(--olive-soft)}
.nl-small{font-size:1.2rem;color:rgba(255,255,255,.45);letter-spacing:.04em}

/* ─── FOOTER ─── */
footer{background:var(--blue-ink);color:#fff;padding:5rem 0 2.5rem;position:relative;overflow:hidden;z-index:2}
.foot-top{display:grid;grid-template-columns:1fr;gap:5rem;padding-bottom:5rem;border-bottom:1px solid var(--hairline-dark)}
@media(min-width:768px){.foot-top{grid-template-columns:1.4fr 1fr 1fr 1fr}}
.foot__brand .brand__name-1{color:#fff}
.foot__brand .brand__name-2{color:var(--olive-soft)}
.foot__brand p{font-size:1.45rem;color:rgba(255,255,255,.6);line-height:1.6;margin-top:2rem;max-width:30rem}
.foot__col h5{font-size:1.05rem;letter-spacing:.24em;text-transform:uppercase;font-weight:700;color:var(--olive-soft);margin-bottom:2rem}
.foot__col a,.foot__col p{display:block;font-size:1.5rem;color:rgba(255,255,255,.7);padding:.45rem 0;transition:color .2s var(--ease);font-family:var(--serif);font-style:italic;font-weight:400}
.foot__col a:hover{color:#fff}
.foot__bottom{padding-top:3rem;display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;font-size:1.25rem;color:rgba(255,255,255,.45);letter-spacing:.02em}
.foot__license{font-family:var(--serif);font-style:italic}
.foot__privacy{color:rgba(255,255,255,.4);font-size:1.25rem;text-decoration:none;letter-spacing:.02em;transition:color .2s}
.foot__privacy:hover{color:rgba(255,255,255,.75)}
.foot__disclaimer{font-size:1.1rem;color:rgba(255,255,255,.3);line-height:1.6;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.08);max-width:720px}

/* ─── FAB ─── */

/* ─── fade-in ─── */
.fade-in{opacity:0;transform:translateY(24px);transition:opacity 1s var(--ease-out), transform 1s var(--ease-out)}
.fade-in.in{opacity:1;transform:none}
.fade-in.delay-1{transition-delay:.08s}
.fade-in.delay-2{transition-delay:.16s}
.fade-in.delay-3{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){.fade-in{opacity:1;transform:none;transition:none}}

/* ═══════════════════════════════════════════════════
   ЖУРНАЛ — СТОРІНКА ОКРЕМОЇ СТАТТІ (single.php)
   ═══════════════════════════════════════════════════ */

.journal-single{background:var(--paper);min-height:100vh}

.journal-article{max-width:780px;margin:0 auto}

/* Заголовок */
.article-header{margin-bottom:3rem}

.article-header .section-title,
h1.section-title{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(2.8rem,4vw,4.8rem);
  line-height:1.05;letter-spacing:-.03em;color:var(--blue-ink);
  margin-top:1.6rem;
}

/* Мета-рядок: дата · час читання · автор */
.article-meta{
  display:flex;gap:1.6rem;align-items:center;flex-wrap:wrap;
  margin-top:2rem;
  font-size:1.3rem;color:var(--text-faint);
  letter-spacing:.14em;text-transform:uppercase;font-weight:600;
}

/* Тіло статті — типографіка WordPress-контенту */
.article-body{
  font-size:1.7rem;line-height:1.75;color:var(--text-ink);
}
.article-body p{margin-bottom:2rem}
.article-body h2{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(2.8rem,4vw,4rem);
  line-height:1.1;letter-spacing:-.02em;color:var(--blue-ink);
  margin:4rem 0 1.6rem;
}
.article-body h3{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(2.2rem,3vw,3rem);
  line-height:1.15;color:var(--blue-ink);
  margin:3rem 0 1.2rem;
}
.article-body h4{
  font-family:var(--sans);font-weight:700;
  font-size:1.6rem;letter-spacing:.06em;text-transform:uppercase;
  color:var(--text-ink);margin:2.4rem 0 .8rem;
}
.article-body ul,.article-body ol{
  padding-left:2.4rem;margin-bottom:2rem;
}
.article-body li{margin-bottom:.8rem;line-height:1.65}
.article-body blockquote{
  border-left:3px solid var(--pushcha-olive);
  padding:1.6rem 2.4rem;margin:3rem 0;
  font-family:var(--serif);font-style:italic;
  font-size:2rem;line-height:1.5;color:var(--text-soft);
}
.article-body strong{font-weight:700;color:var(--blue-ink)}
.article-body em{font-style:italic}
.article-body a:not(.btn){
  color:var(--blue-deep);
  text-decoration:underline;text-underline-offset:.3em;
  text-decoration-color:var(--pushcha-blue);
}
.article-body a:not(.btn):hover{color:var(--pushcha-olive)}
.article-body a:hover{color:var(--pushcha-olive)}
.article-body img{
  width:100%;height:auto;
  margin:3rem 0;
  border-radius:2px;
}
.article-body hr{
  border:none;border-top:1px solid var(--hairline);
  margin:4rem 0;
}

/* ═══════════════════════════════════════════════════
   ЖУРНАЛ — СПИСОК (home.php) — ВИПРАВЛЕННЯ
   ═══════════════════════════════════════════════════ */

/* Фікс: SVG у будь-якому breadcrumb не розтягується */
svg{max-width:100%}
.page-head__crumb svg,
.journal-article nav svg{
  width:1.2rem!important;height:1.2rem!important;
  max-width:1.2rem!important;flex-shrink:0;
}

/* Фікс featured: мінімальна висота медіа на мобільному */
.feature__media{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  min-height:28rem;
}

/* Фікс: page-head відступ коли є адмін-бар WordPress */
.admin-bar .page-head{padding-top:13rem}
.admin-bar .journal-single{padding-top:12rem!important}
.admin-bar .hero{padding-top:13rem}


/* ═══════════════════════════════════════════════════
   МОБІЛЬНА ВЕРСІЯ — компактний вигляд (max 600px)
   ═══════════════════════════════════════════════════ */
@media(max-width:600px){

  /* Контейнер */
  .container{padding:0 1.8rem}

  /* ── Бігуча строка ── */
  .marquee{padding:1.6rem 0;margin-top:3rem}
  .marquee__item{font-size:1.6rem;gap:1.2rem}
  .marquee__item::after{font-size:1.2rem;margin-left:1.6rem}

  /* ── Ліцензія (capsule) — не перекриває фото ── */
  .hero__capsule{
    position:static!important;
    margin-top:1.2rem;
    max-width:100%!important;
    padding:1.4rem 1.6rem!important;
    border-radius:.4rem;
  }
  .hero__inner{gap:2.4rem}
  .hero__title{font-size:clamp(3.8rem,11vw,6rem);line-height:1}
  .hero__lead{font-size:1.5rem;line-height:1.55;margin-bottom:2rem}
  .hero__stats{gap:2rem;margin-top:2rem}
  .hero__stat-num{font-size:3.6rem}
  .hero__stat-num sup{font-size:1.4rem;top:-1.2rem}
  .hero__stat-label{font-size:1.1rem}
  .hero__visual{height:28rem;margin-top:0}
  .hero__capsule{padding:.8rem 1.4rem;gap:.8rem}
  .hero__capsule-text{font-size:1.4rem}
  .hero__meta{font-size:1.1rem;gap:1rem;margin-bottom:2rem}
  .hero__badges{gap:.5rem;flex-wrap:wrap}

  /* ── СЕКЦІЇ — загальний відступ ── */
  .section-pad{padding:5rem 0}
  .sec-head{margin-bottom:4rem}
  .sec-head h2{font-size:clamp(3rem,9vw,5rem);margin-top:1rem}
  .sec-head__lead{font-size:1.45rem}

  /* ── ПРОГРАМИ ── */
  #programs{padding:5rem 0}
  .prog-list{gap:4rem}
  .prog{gap:2rem}
  .prog__media{aspect-ratio:4/3}
  .prog__media-num{font-size:7rem;top:-1.5rem}
  .prog__title{font-size:clamp(2.8rem,8vw,4.2rem);margin-bottom:1.2rem}
  .prog__copy{font-size:1.45rem;margin-bottom:2rem}
  .prog__duration-big{font-size:3.2rem}
  .prog__list{gap:.6rem}
  .prog__list li{font-size:1.4rem}

  /* ── СИМПТОМИ ── */
  #symptoms{padding:5rem 0}
  .sym-quote{font-size:1.7rem;margin:0 0 1.6rem;padding-left:2rem}
  .sym-item{padding:1.4rem 0}
  .sym-item h4{font-size:1.5rem;margin-bottom:.4rem}
  .sym-item p{font-size:1.3rem}
  .sym-foot{margin-top:2rem;padding-top:1.6rem;flex-direction:column;align-items:flex-start;gap:1.6rem}
  .sym-foot p{font-size:1.5rem}

  /* ── ПІДХІД ── */
  #approach{padding:5rem 0}
  .app-grid{gap:1.6rem}

  /* ── ПЕРЕВАГИ ── */
  #benefits{padding:5rem 0}

  /* ── ESSAY / ЦИТАТА ── */
  #essay{padding:4rem 0}
  .essay-inner{gap:1.6rem}
  .essay__sig{font-size:5rem}
  .essay__text{font-size:2rem;line-height:1.4}
  .essay__sign{font-size:1.1rem;margin-top:1.6rem}

  /* ── ЦІНИ ── */
  #pricing{padding:5rem 0}
  .pricing-wrap{gap:2rem}
  .price-row{padding:1.4rem 1.4rem;gap:1rem;margin-bottom:.8rem}
  .price-row__name{font-size:1.6rem}
  .price-row__extra{font-size:1.05rem}
  .price-row__amt{font-size:1.9rem}
  .inc-card{padding:2.4rem 2rem}
  .inc-card h4{font-size:2rem;margin-bottom:1.6rem}
  .inc-list li{font-size:1.35rem;padding:1.1rem 0}

  /* ── ВІДГУКИ ── */
  #testimonials{padding:5rem 0}

  /* ── КОНТАКТИ ── */
  #contact{padding:5rem 0 4rem}
  .contact-wrap{gap:2rem}
  .ci__text{font-size:1.4rem}

  /* ── ЖУРНАЛ — список ── */
  .page-head{padding:10rem 0 3.5rem}
  .page-head h1{font-size:clamp(3.8rem,12vw,7rem);line-height:.95}
  .page-head__lead{font-size:1.45rem;line-height:1.5}
  .page-head__inner{gap:2rem}
  .feature{gap:2rem;padding-bottom:3.5rem}
  .feature__media{aspect-ratio:16/9;min-height:0}
  .feature__title{font-size:clamp(2.6rem,8vw,4rem);margin-bottom:1.4rem}
  .feature__excerpt{font-size:1.45rem;margin-bottom:1.8rem}
  .feature__meta{font-size:1.1rem;gap:1rem;padding-bottom:1.4rem;margin-bottom:1.4rem}
  .journal{padding:3.5rem 0 5rem}
  .grid{gap:2.8rem}
  .card__title{font-size:1.9rem}
  .card__excerpt{font-size:1.35rem}
  .card__media{aspect-ratio:16/9}
  .card__meta{font-size:1.15rem}

  /* ── СТАТТЯ single ── */
  .journal-single{padding:10rem 0 4rem!important}
  .article-header .section-title,h1.section-title{font-size:clamp(2.8rem,9vw,4.8rem)}
  .article-meta{font-size:1.1rem;gap:1.2rem}
  .article-body{font-size:1.5rem;line-height:1.7}
  .article-body h2{font-size:clamp(2.2rem,7vw,3rem);margin:2.4rem 0 1rem}
  .article-body h3{font-size:clamp(1.9rem,6vw,2.4rem)}
  .article-body blockquote{font-size:1.7rem;padding:1.2rem 1.8rem}
  .journal-article aside{padding:2.4rem 1.8rem}

  /* ── FOOTER ── */
  footer{padding:5rem 0 2.5rem}
  .foot-top{gap:3rem}
  .foot__bottom{flex-direction:column;gap:.8rem;font-size:1.1rem}

  /* ── FAB ── */
  .fab{width:4.6rem;height:4.6rem;bottom:1.4rem;right:1.4rem}
  .fab svg{width:1.9rem;height:1.9rem}

  /* ── Кнопки ── */
  .btn{font-size:1.05rem;padding:1.2rem 2.2rem}
  .btn--primary{min-height:4.8rem}

  /* ── Картинки — компактні пропорції ── */
  .hero__visual{height:22rem;margin-top:0}
  .hero__photo-main{border-radius:1rem}
  .prog__media{aspect-ratio:16/9}
  .prog__media-num{font-size:6rem;top:-1rem;right:.8rem}
  .card__media{aspect-ratio:16/9!important;margin-bottom:1.6rem}
  .feature__media{aspect-ratio:16/9!important;min-height:0}
}

/* ═══════════════════════════════════════════════════
   МОБІЛЬНЕ МЕНЮ — гамбургер
   ═══════════════════════════════════════════════════ */

/* Кнопка гамбургер */
.nav__burger{
  display:none;
  flex-direction:column;justify-content:center;align-items:center;
  gap:.5rem;width:4rem;height:4rem;padding:.6rem;
  background:none;border:none;cursor:pointer;
  flex-shrink:0;position:relative;z-index:110;
}
.nav__burger span{
  display:block;width:2.2rem;height:2px;
  background:var(--blue-ink);border-radius:2px;
  transition:all .3s var(--ease);
  transform-origin:center;
}
@media(max-width:1023px){.nav__burger{display:flex}}

/* Стан відкрито */
.nav__burger.is-open span:nth-child(1){transform:translateY(.7rem) rotate(45deg)}
.nav__burger.is-open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav__burger.is-open span:nth-child(3){transform:translateY(-.7rem) rotate(-45deg)}

/* Мобільне меню — дропдаун */
.nav__mobile{
  display:none!important;
  flex-direction:column;
  background:rgba(242,239,231,.97);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-top:1px solid var(--hairline);
  padding:1.6rem 0 2.4rem;
}
.nav__mobile.is-open{display:flex!important}
.nav__mobile a{
  padding:1.2rem 2.4rem;
  font-family:var(--sans);font-size:1.7rem;font-weight:500;
  color:var(--text-ink);
  border-bottom:1px solid var(--hairline);
  transition:color .2s var(--ease), background .2s var(--ease);
}
.nav__mobile a:last-child{border-bottom:none}
.nav__mobile a:hover,.nav__mobile a.is-active{color:var(--blue-ink);background:rgba(111,168,200,.08)}
.nav__mobile a.is-active{font-weight:600}
.nav__mobile-phone{
  font-family:var(--sans)!important;font-size:1.5rem!important;
  color:var(--blue-ink)!important;font-weight:600!important;
  margin-top:.8rem;
}
.nav__mobile-cta{
  margin:1.6rem 2.4rem 0!important;
  background:var(--blue-ink)!important;color:#fff!important;
  border-radius:50px!important;text-align:center!important;
  font-weight:600!important;font-size:1.5rem!important;
  padding:1.4rem!important;border-bottom:none!important;
}

@media(min-width:1024px){
  .nav__mobile{display:none!important}
  .nav__burger{display:none!important}
}

/* ═══════════════════════════════════════════════════
   TRUST BADGES — три плашки статистики
   ═══════════════════════════════════════════════════ */
.trust-badges{
  background:var(--paper);
  padding:6rem 0 5rem;
  position:relative;z-index:2;
}

.trust-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2.4rem;
}
@media(max-width:768px){.trust-grid{grid-template-columns:1fr;gap:1.6rem}}

.trust-card{
  background:#fff;
  border:1px solid var(--hairline);
  border-radius:.4rem;
  padding:3.2rem 2.8rem;
  display:flex;flex-direction:column;gap:.8rem;
  position:relative;overflow:hidden;
  transition:transform .3s var(--ease-out), box-shadow .3s var(--ease-out);
}
.trust-card::before{
  content:"";
  position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg, var(--blue-ink), var(--pushcha-blue));
}
.trust-card:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 40px rgba(0,0,0,.08);
}

.trust-card__icon{
  width:4rem;height:4rem;
  display:grid;place-items:center;
  background:var(--blue-mist);border-radius:50%;
  margin-bottom:.8rem;flex-shrink:0;
}
.trust-card__icon svg{width:2rem;height:2rem;color:var(--blue-ink)}

.trust-card__num{
  font-family:var(--serif);font-weight:500;
  font-size:clamp(3.6rem,5vw,5.2rem);
  line-height:1;letter-spacing:-.03em;
  color:var(--blue-ink);
}
.trust-card__num span{
  font-size:.55em;color:var(--pushcha-olive);
  font-weight:500;vertical-align:super;
  font-style:normal;
}

.trust-card__title{
  font-family:var(--sans);font-weight:700;
  font-size:1.5rem;letter-spacing:.06em;
  text-transform:uppercase;color:var(--text-ink);
  margin-top:.4rem;
}

.trust-card__desc{
  font-size:1.45rem;line-height:1.55;
  color:var(--text-soft);
  font-family:var(--serif);font-style:italic;
}

@media(max-width:600px){
  .trust-badges{padding:3.5rem 0}
  .trust-grid{gap:1.2rem}
  .trust-card{padding:2rem 1.8rem;gap:.6rem}
  .trust-card__num{font-size:3.2rem}
  .trust-card__icon{width:3.2rem;height:3.2rem}
  .trust-card__icon svg{width:1.6rem;height:1.6rem}
  .trust-card__title{font-size:1.3rem}
  .trust-card__desc{font-size:1.3rem}
}

/* ═══════════════════════════════════════════════════
   ПЛАНШЕТ — проміжний розмір (601px – 1023px)
   ═══════════════════════════════════════════════════ */
@media(min-width:601px) and (max-width:1023px){

  .container{padding:0 3rem}

  /* Hero */
  .hero{padding:11rem 0 5rem}
  .hero__title{font-size:clamp(4rem,7vw,6rem)}
  .hero__lead{font-size:1.65rem}
  .hero__stats{gap:2.4rem 4rem;margin-top:4rem}
  .hero__stat-num{font-size:4rem}
  .hero__visual{height:38rem}

  /* Секції */
  .section-pad{padding:6rem 0}
  .sec-head{margin-bottom:4rem}
  .sec-head h2{font-size:clamp(2.8rem,5vw,4.2rem)}

  /* Програми */
  #programs{padding:7rem 0}
  .prog-list{gap:6rem}
  .prog__media{aspect-ratio:16/9}
  .prog__duration-big{font-size:4rem}
  .prog__title{font-size:clamp(2.6rem,4vw,3.6rem)}
  .prog__media-num{font-size:8rem}

  /* Симптоми */
  #symptoms{padding:7rem 0}
  .sym-quote{font-size:clamp(1.8rem,2.5vw,2.4rem);margin:0 0 2rem}
  .sym-item{padding:1.8rem 0}
  .sym-foot p{font-size:1.65rem}

  /* Підхід, переваги */
  #approach{padding:7rem 0}
  #benefits{padding:7rem 0}

  /* Цитата */
  #essay{padding:7rem 0}
  .essay__sig{font-size:7rem}
  .essay__text{font-size:clamp(2rem,3vw,2.6rem)}

  /* Ціни */
  #pricing{padding:7rem 0}
  .price-row{padding:1.6rem 1.8rem;margin-bottom:.8rem}
  .price-row__name{font-size:1.9rem}
  .price-row__amt{font-size:2.2rem}

  /* Відгуки, контакти */
  #testimonials{padding:7rem 0}
  #contact{padding:7rem 0 5rem}

  /* Журнал */
  .page-head{padding:12rem 0 5rem}
  .page-head h1{font-size:clamp(4rem,8vw,6rem)}
  .journal{padding:5rem 0 7rem}
  .feature__title{font-size:clamp(2.8rem,4vw,4rem)}

  /* Footer */
  footer{padding:6rem 0 3rem}
}

/* ═══════════════════════════════════════════════════
   PERFORMANCE — CLS та LCP виправлення
   ═══════════════════════════════════════════════════ */

/* Запобігаємо CLS від шрифтів */
@font-face{font-display:swap}

/* Hero — резервуємо місце щоб не було CLS */
.hero__visual{contain:layout size}
.hero__photo-main img{
  will-change:auto;
  content-visibility:auto;
}

/* Fade-in не має впливати на CLS — початкова висота резервується */
.fade-in{
  contain:layout;
}

/* Hero inner — фіксуємо min-height щоб не стрибав */
.hero__inner{min-height:40rem}
@media(min-width:1024px){.hero__inner{min-height:50rem}}

/* ===================== MODAL ===================== */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:9999;align-items:center;justify-content:center;padding:20px}
.modal-overlay.is-open{display:flex}
.modal-box{background:#F5F1E8;border-radius:16px;padding:40px 36px;max-width:480px;width:100%;position:relative;box-shadow:0 20px 60px rgba(0,0,0,.2);animation:modalIn .25s ease}
@keyframes modalIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.modal-close{position:absolute;top:16px;right:20px;background:none;border:none;font-size:28px;cursor:pointer;color:#666;line-height:1}
.modal-close:hover{color:#1e5a50}
.modal-title{font-size:1.5rem;color:#1e5a50;margin-bottom:6px}
.modal-sub{color:#888;font-size:.9rem;margin-bottom:24px}
.modal-box .wpcf7-form label{display:block;font-size:15px !important;color:#555;margin-bottom:4px;margin-top:14px}
.modal-box .wpcf7-form input,.modal-box .wpcf7-form select,.modal-box .wpcf7-form textarea{width:100%;padding:11px 14px;border:1.5px solid #ddd;border-radius:8px;background:#fff;font-size:16px !important;font-family:inherit;transition:border-color .2s;box-sizing:border-box}
.modal-box label{font-size:15px !important;color:#555}
.modal-box input[type="text"],.modal-box input[type="tel"],.modal-box input[type="email"],.modal-box select,.modal-box textarea{font-size:16px !important;font-family:inherit}
.modal-box .wpcf7-form input:focus,.modal-box .wpcf7-form select:focus,.modal-box .wpcf7-form textarea:focus{outline:none;border-color:#1e5a50}
.modal-box .wpcf7-form textarea{min-height:80px;resize:vertical}
.modal-box .wpcf7-form input[type="submit"]{background:#1e5a50;color:#fff;border:none;border-radius:50px;padding:13px 32px;font-size:1rem;font-weight:600;cursor:pointer;margin-top:20px;width:100%;transition:background .2s}
.modal-box .wpcf7-form input[type="submit"]:hover{background:#174840}
@media(max-width:500px){.modal-box{padding:30px 20px}.modal-box .wpcf7-form textarea{min-height:80px;max-height:120px}}
#inner-page .pricing-wrap{display:grid;grid-template-columns:1.2fr .8fr;gap:6rem;align-items:start}
.contact__visual-link { text-decoration: none; }
.prog__list--detailed { gap: 2rem; }
.prog__list--detailed li {
  display: grid;
  grid-template-columns: 20px 1fr;
  gap: 0 1rem;
  align-items: start;
}
.prog__list--detailed li svg { margin-top: .4rem; }
.prog__list-item {
  display: flex;
  flex-direction: column;
  gap: .5rem;
}
.prog__list-title {
  font-weight: 600;
  color: var(--blue-ink, #1a3a4a);
  font-size: 1.6rem;
  line-height: 1.3;
  display: block;
}
.prog__list-desc {
  font-size: 1.45rem;
  color: var(--text-soft, #6b7c85);
  line-height: 1.65;
  display: block;
}
.prog__price-link {
  font-style: italic;
  font-size: 1.6rem;
  color: var(--blue-ink, #1a3a4a);
  text-decoration: none;
  transition: color .2s;
}
.prog__price-link b { font-size: 2.4rem; font-style: normal; }
.prog__price-link:hover { color: var(--pushcha-olive, #7a9e7e); text-decoration: underline; }
