/* ============================================================
   САРАТОВСКИЙ ЛЕТНИЙ ЙОГА-РЕТРИТ · Ананда Марга 2026
   Метафора: лотос растёт из Волги (синий) к солнцу (оранжевый)
   ============================================================ */

:root{
  /* — небо и Волга — */
  --blue-950:#061a36;
  --blue-900:#08234a;
  --blue-800:#0a2c5e;
  --blue-700:#0e3a7c;
  --blue-600:#134f9f;
  --blue-500:#1f6fcf;
  --blue-400:#3f8fe6;
  --blue-300:#79b6f2;
  --blue-200:#aed4f8;
  --blue-100:#d8ebfc;

  /* — солнце Ананда Марги — */
  --orange-700:#c5430a;
  --orange-600:#e8590c;
  --orange-500:#ff7a18;
  --orange-400:#ff9a3c;
  --orange-300:#ffb866;
  --orange-200:#ffd29a;

  /* — тёплый свет / песок — */
  --cream:#fff5e6;
  --sand:#f7ead2;
  --ink:#0c1f3c;

  --bg:var(--blue-800);
  --maxw:1180px;
  --radius:22px;
  --radius-sm:14px;
  --shadow:0 24px 60px -20px rgba(3,16,38,.55);
  --shadow-orange:0 18px 40px -12px rgba(232,89,12,.5);

  --font-display:"Unbounded",system-ui,sans-serif;
  --font-body:"Manrope",system-ui,-apple-system,sans-serif;
}

/* ---------- reset ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  color:var(--cream);
  background:var(--blue-900);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
::selection{background:var(--orange-500);color:#fff}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}

/* ---------- типографика ---------- */
.h2{font-family:var(--font-display);font-weight:700;line-height:1.08;
  font-size:clamp(1.9rem,4.5vw,3.2rem);letter-spacing:-.02em}
.h3{font-family:var(--font-display);font-weight:600;font-size:clamp(1.3rem,2.6vw,1.7rem);line-height:1.15}
.lead{font-size:clamp(1rem,1.6vw,1.18rem);color:var(--blue-100);opacity:.95}
.eyebrow{font-family:var(--font-display);font-weight:600;text-transform:uppercase;
  letter-spacing:.18em;font-size:.74rem;color:var(--orange-400);margin-bottom:.7rem}
.eyebrow--light{color:var(--orange-300)}

.section{position:relative;padding:clamp(64px,9vw,120px) 0}
.section-head{text-align:center;max-width:760px;margin:0 auto clamp(40px,5vw,64px)}
.section-head__sub{margin-top:.8rem;color:var(--blue-200)}

/* ============================================================
   КНОПКИ
   ============================================================ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--font-display);font-weight:600;font-size:.95rem;
  padding:.85em 1.5em;border-radius:100px;transition:.3s cubic-bezier(.2,.7,.3,1);
  white-space:nowrap;position:relative;overflow:hidden}
.btn svg{flex:none}
.btn--big{padding:1.05em 2em;font-size:1.05rem}
.btn--full{width:100%}
.btn--join{background:linear-gradient(135deg,var(--orange-500),var(--orange-600));
  color:#fff;box-shadow:var(--shadow-orange)}
.btn--join:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 24px 50px -12px rgba(232,89,12,.65)}
.btn--join:active{transform:translateY(-1px) scale(.99)}
.btn--ghost{background:rgba(255,255,255,.1);color:#fff;backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.22)}
.btn--ghost:hover{background:rgba(255,255,255,.18);transform:translateY(-3px)}
.btn--outline{border:1.5px solid var(--orange-400);color:var(--orange-300);padding:.75em 1.4em}
.btn--outline:hover{background:var(--orange-500);color:#fff;border-color:var(--orange-500)}
.btn--glow{animation:btnGlow 2.6s ease-in-out infinite}
@keyframes btnGlow{0%,100%{box-shadow:0 10px 30px -8px rgba(255,122,24,.5)}
  50%{box-shadow:0 16px 50px -6px rgba(255,154,60,.85)}}
/* блик по кнопке */
.btn--join::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.45),transparent);
  transform:skewX(-18deg);transition:left .6s}
.btn--join:hover::after{left:130%}

/* ============================================================
   ПРЕЛОАДЕР
   ============================================================ */
.preloader{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;
  background:radial-gradient(circle at 50% 40%,var(--blue-700),var(--blue-950));
  transition:opacity .7s ease,visibility .7s}
.preloader.hide{opacity:0;visibility:hidden}
.preloader__lotus img{width:90px;animation:lotusPulse 1.8s ease-in-out infinite}
@keyframes lotusPulse{0%,100%{transform:scale(.9);opacity:.7}50%{transform:scale(1.08);opacity:1}}
.preloader__ring{position:absolute;width:150px;height:150px;border-radius:50%;
  border:2px solid transparent;border-top-color:var(--orange-400);animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ============================================================
   ПРОГРЕСС-ВОСХОД
   ============================================================ */
.scroll-progress{position:fixed;top:0;left:0;right:0;height:4px;z-index:1000;
  background:rgba(255,255,255,.08)}
.scroll-progress__bar{height:100%;width:0;
  background:linear-gradient(90deg,var(--orange-600),var(--orange-400),var(--orange-300))}
.scroll-progress__sun{position:absolute;top:-4px;left:0;width:12px;height:12px;border-radius:50%;
  background:var(--orange-400);box-shadow:0 0 16px 4px rgba(255,154,60,.9);transform:translateX(-50%)}

/* ============================================================
   ШАПКА
   ============================================================ */
.header{position:fixed;top:0;left:0;right:0;z-index:900;
  display:flex;align-items:center;gap:18px;color:var(--ink);
  padding:14px clamp(16px,4vw,40px);transition:.4s;
  background:rgba(255,255,255,.9);backdrop-filter:blur(14px);
  box-shadow:0 6px 22px -16px rgba(8,35,74,.4)}
.header.scrolled{background:rgba(255,255,255,.97);
  box-shadow:0 10px 34px -16px rgba(8,35,74,.34);padding-top:10px;padding-bottom:10px}
.brand{display:flex;align-items:center;gap:11px;margin-right:auto}
.brand__logo{width:42px;height:42px;transition:transform .4s;filter:drop-shadow(0 4px 12px rgba(255,122,24,.45))}
.brand:hover .brand__logo{transform:rotate(-8deg) scale(1.05)}
.brand__text{display:flex;flex-direction:column;line-height:1.1}
.brand__title{font-family:var(--font-display);font-weight:700;font-size:1rem;color:var(--ink)}
.brand__sub{font-size:.7rem;color:var(--orange-600);letter-spacing:.05em}
.nav{display:flex;gap:6px}
.nav a{font-size:.9rem;font-weight:600;padding:.5em .85em;border-radius:100px;
  color:#33506f;transition:.25s;position:relative}
.nav a:hover{color:var(--orange-700);background:rgba(255,122,24,.1)}
.header__cta{display:inline-flex}
.burger{display:none;width:44px;height:44px;flex-direction:column;justify-content:center;
  align-items:center;gap:5px;border-radius:12px}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-menu{position:fixed;inset:0;z-index:850;background:linear-gradient(160deg,var(--blue-800),var(--blue-950));
  display:flex;flex-direction:column;justify-content:center;gap:8px;padding:40px;
  transform:translateY(-100%);transition:transform .5s cubic-bezier(.7,0,.2,1);visibility:hidden}
.mobile-menu.open{transform:translateY(0);visibility:visible}
.mobile-menu nav{display:flex;flex-direction:column;gap:6px;margin-bottom:28px}
.mobile-menu nav a{font-family:var(--font-display);font-weight:600;font-size:1.35rem;
  padding:.5em 0;border-bottom:1px solid rgba(255,255,255,.08)}
.mobile-menu nav a:hover{color:var(--orange-300);padding-left:.5em}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;
  justify-content:center;align-items:center;text-align:center;overflow:hidden;
  padding:120px 20px 160px}
.sky{position:absolute;inset:0;z-index:0}
.sky__gradient{position:absolute;inset:0;
  background:
   radial-gradient(120% 80% at 70% -10%,rgba(255,154,60,.35),transparent 55%),
   linear-gradient(180deg,#0a2c5e 0%,#134f9f 45%,#3f8fe6 78%,#79b6f2 100%)}
/* TEMP: скрыть солнце на главном экране */
.hero #heroSun{display:none}

.sun{position:absolute;top:14%;left:50%;transform:translateX(-50%);
  width:170px;height:170px;will-change:transform}
.sun__core{position:absolute;inset:0;border-radius:50%;
  background:radial-gradient(circle at 38% 35%,#fff3d6,var(--orange-400) 55%,var(--orange-600));
  box-shadow:0 0 70px 18px rgba(255,154,60,.6)}
.sun__glow{position:absolute;inset:-40%;border-radius:50%;
  background:radial-gradient(circle,rgba(255,184,102,.5),transparent 62%);
  animation:sunPulse 6s ease-in-out infinite}
@keyframes sunPulse{0%,100%{transform:scale(1);opacity:.8}50%{transform:scale(1.15);opacity:1}}
.sun--mini{position:absolute;width:120px;height:120px;top:18%;left:78%}

.cloud{position:absolute;height:40px;border-radius:100px;background:rgba(255,255,255,.55);
  filter:blur(6px);opacity:.7}
.cloud::before,.cloud::after{content:"";position:absolute;border-radius:50%;background:inherit}
.cloud--1{width:160px;top:24%;left:-180px;animation:drift 38s linear infinite}
.cloud--1::before{width:70px;height:70px;top:-28px;left:30px}
.cloud--1::after{width:50px;height:50px;top:-18px;left:90px}
.cloud--2{width:120px;top:40%;left:-160px;animation:drift 52s linear infinite 6s;opacity:.5}
.cloud--2::before{width:54px;height:54px;top:-22px;left:24px}
.cloud--3{width:200px;top:14%;left:-240px;animation:drift 64s linear infinite 12s;opacity:.4}
.cloud--3::before{width:80px;height:80px;top:-32px;left:40px}
.cloud--3::after{width:60px;height:60px;top:-20px;left:120px}
@keyframes drift{to{transform:translateX(calc(100vw + 280px))}}

.stars{position:absolute;inset:0;opacity:0;transition:opacity 1.2s;pointer-events:none}
.stars span{position:absolute;width:2px;height:2px;border-radius:50%;background:#fff;
  animation:twinkle 3s ease-in-out infinite}
@keyframes twinkle{0%,100%{opacity:.2}50%{opacity:1}}

/* частицы-лепестки */
.petals{position:absolute;inset:0;z-index:1;pointer-events:none}
.petals--over-text{z-index:6}

/* вода + волны */
.hero__water{position:absolute;left:-4%;right:-4%;bottom:0;height:30vh;min-height:170px;z-index:1}
.waves{position:absolute;bottom:0;left:0;width:100%;height:100%}
.wave{fill:var(--blue-600)}
.wave--back{fill:#1b62bd;opacity:.6;animation:waveMove 14s ease-in-out infinite alternate}
.wave--mid{fill:#134f9f;opacity:.8;animation:waveMove 10s ease-in-out infinite alternate-reverse}
.wave--front{fill:#0e3a7c;animation:waveMove 8s ease-in-out infinite alternate}
@keyframes waveMove{from{transform:translateX(-2%)}to{transform:translateX(2%)}}
.hero__inner{position:relative;z-index:3;max-width:880px}
.hero__kicker{display:inline-block;font-family:var(--font-display);font-weight:600;
  font-size:.82rem;letter-spacing:.12em;color:#fff;
  background:rgba(255,122,24,.22);border:1px solid rgba(255,154,60,.5);
  padding:.5em 1.2em;border-radius:100px;margin-bottom:1.4rem;backdrop-filter:blur(6px)}
.hero__title{font-family:var(--font-display);font-weight:800;
  font-size:clamp(2.6rem,8.5vw,6rem);line-height:.98;letter-spacing:-.03em;
  text-shadow:0 8px 40px rgba(3,16,38,.4)}
.hero__title .line{display:block}
.hero__accent{
  background:linear-gradient(135deg,#ffae58 0%,var(--orange-400) 50%,var(--orange-500) 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:var(--orange-400);
  text-shadow:none}
.hero__lead{max-width:580px;margin:1.6rem auto 0;font-size:clamp(1.05rem,2vw,1.3rem);color:#eaf3ff}
.hero__date{display:inline-flex;align-items:center;gap:.6em;margin-top:1.8rem;
  font-weight:600;font-size:.98rem;color:#fff;
  background:rgba(8,35,74,.4);border:1px solid rgba(255,255,255,.2);
  padding:.7em 1.3em;border-radius:100px;backdrop-filter:blur(8px)}
.hero__date svg{color:var(--orange-300)}
.hero__actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:2rem}

.scroll-cue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.scroll-cue__mouse{width:24px;height:38px;border:2px solid rgba(255,255,255,.6);border-radius:14px;
  display:flex;justify-content:center;padding-top:6px}
.scroll-cue__mouse span{width:4px;height:8px;border-radius:4px;background:#fff;animation:scrollDot 1.6s infinite}
@keyframes scrollDot{0%{opacity:0;transform:translateY(-4px)}40%{opacity:1}80%,100%{opacity:0;transform:translateY(10px)}}

/* ============================================================
   БЕГУЩАЯ СТРОКА
   ============================================================ */
.marquee{background:linear-gradient(90deg,var(--orange-600),var(--orange-500));
  padding:14px 0;overflow:hidden;white-space:nowrap;position:relative;z-index:5}
.marquee__track{display:inline-flex;align-items:center;gap:26px;
  animation:marquee 26s linear infinite;will-change:transform}
.marquee__track span{font-family:var(--font-display);font-weight:600;font-size:1rem;
  color:#fff;text-transform:uppercase;letter-spacing:.05em}
.marquee__track .dot{font-size:.85rem}
@keyframes marquee{to{transform:translateX(-50%)}}
.marquee:hover .marquee__track{animation-play-state:paused}

/* ============================================================
   О РЕТРИТЕ
   ============================================================ */
.about{background:linear-gradient(180deg,var(--blue-300),var(--blue-100));color:var(--ink)}
.about__text .h2{margin-bottom:1.5rem}
.about .lead{color:#1a3a63}
.about__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(30px,5vw,70px);align-items:center}
.about .eyebrow{color:var(--orange-600)}
.about__stats{display:flex;gap:30px;margin-top:2rem;flex-wrap:wrap}
.stat__num{font-family:var(--font-display);font-weight:800;font-size:2.6rem;color:var(--orange-600);display:block;line-height:1}
.stat__label{font-size:.85rem;color:#3a5577;font-weight:600}
.about__chips{display:flex;flex-wrap:wrap;gap:12px;align-content:center}
.chip{background:#fff;color:var(--ink);font-weight:600;font-size:.92rem;
  padding:.7em 1.15em;border-radius:100px;box-shadow:0 8px 22px -12px rgba(19,79,159,.4);
  border:1px solid rgba(19,79,159,.1);transition:.3s}
.chip:hover{transform:translateY(-4px) rotate(-1.5deg);box-shadow:0 16px 30px -14px rgba(232,89,12,.5);
  border-color:var(--orange-300)}

/* ============================================================
   КАРТОЧКИ «ЧТО ВАС ЖДЁТ»
   ============================================================ */
.highlights{background:linear-gradient(180deg,var(--blue-100),#eaf4ff);color:var(--ink);padding-bottom:0}
.highlights .eyebrow{color:var(--orange-600)}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;padding-bottom:clamp(80px,10vw,130px)}
.card{background:#fff;border-radius:var(--radius);padding:32px 28px;
  box-shadow:0 20px 50px -28px rgba(19,79,159,.5);border:1px solid rgba(19,79,159,.08);
  transition:.4s cubic-bezier(.2,.7,.3,1);position:relative;overflow:hidden}
.card::before{content:"";position:absolute;top:-40px;right:-40px;width:120px;height:120px;
  border-radius:50%;background:radial-gradient(circle,rgba(255,154,60,.16),transparent 70%);transition:.4s}
.card:hover{transform:translateY(-8px);box-shadow:0 30px 60px -24px rgba(232,89,12,.4)}
.card:hover::before{transform:scale(1.6)}
.card__icon{width:64px;height:64px;border-radius:18px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--orange-400),var(--orange-600));margin-bottom:18px;
  box-shadow:var(--shadow-orange)}
.card__icon svg{width:34px;height:34px;color:#fff}
.card h3{font-family:var(--font-display);font-weight:600;font-size:1.25rem;margin-bottom:.5rem;color:var(--ink)}
.card p{color:#48607e;font-size:.96rem}

/* волна-разделитель */
.wave-divider{line-height:0}
.wave-divider svg{width:100%;height:clamp(50px,7vw,100px)}
.wave-divider path{fill:var(--blue-900)}
.wave-divider--up{transform:rotate(180deg)}
.wave-divider--light path{fill:#cfe3fa}

/* ============================================================
   АЧАРЬЯ
   ============================================================ */
.acharya{background:var(--blue-900);overflow:hidden}
.mandala{position:absolute;top:50%;right:-200px;width:600px;height:600px;transform:translateY(-50%);
  background:conic-gradient(from 0deg,transparent,rgba(255,154,60,.12),transparent 30%,rgba(63,143,230,.12),transparent 60%);
  border-radius:50%;animation:spin 60s linear infinite;pointer-events:none;opacity:.6;
  -webkit-mask:radial-gradient(circle,#000 30%,transparent 71%);mask:radial-gradient(circle,#000 30%,transparent 71%)}
.acharya__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(30px,5vw,64px);align-items:center;position:relative;z-index:2}
.acharya__photo{position:relative}
.acharya__frame{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);
  border:3px solid rgba(255,154,60,.3);aspect-ratio:1/1.05}
.acharya__frame img{width:100%;height:100%;object-fit:cover;transition:transform .8s}
.acharya__photo:hover .acharya__frame img{transform:scale(1.05)}
.acharya__petal{position:absolute;width:90px;height:90px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cpath d='M50 5C60 35 60 55 50 95C40 55 40 35 50 5Z' fill='%23ff9a3c'/%3E%3C/svg%3E") center/contain no-repeat;opacity:.8}
.acharya__petal--1{top:-30px;right:-20px;animation:float1 7s ease-in-out infinite}
.acharya__petal--2{bottom:-26px;left:-26px;width:60px;height:60px;animation:float1 9s ease-in-out infinite reverse}
@keyframes float1{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-16px) rotate(12deg)}}
.acharya__text .quote{border-left:3px solid var(--orange-500);padding:.4em 0 .4em 1.2em;
  margin:1.6rem 0;font-style:italic;color:var(--orange-200);font-size:1.08rem}

/* ============================================================
   ГАЛЕРЕЯ
   ============================================================ */
.gallery{background:var(--blue-900)}
.gallery__carousel{position:relative;margin-top:8px;width:100vw;margin-left:calc(50% - 50vw)}
.gallery__viewport{overflow-x:auto;overflow-y:hidden;
  -webkit-overflow-scrolling:touch;scrollbar-width:none;cursor:grab}
.gallery__viewport.dragging{cursor:grabbing;scroll-behavior:auto}
.gallery__viewport::-webkit-scrollbar{display:none}
.gallery__track{display:grid;grid-auto-flow:column dense;
  grid-template-rows:repeat(2,clamp(120px,17vw,190px));
  grid-auto-columns:clamp(150px,21vw,240px);gap:14px;padding:6px;width:max-content}
.ph{position:relative;overflow:hidden;border-radius:var(--radius-sm);cursor:pointer;
  box-shadow:0 14px 30px -18px rgba(0,0,0,.6)}
.ph img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.2,.7,.3,1);
  pointer-events:none;-webkit-user-drag:none;user-select:none}
.ph::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(8,35,74,.6));
  opacity:0;transition:.4s}
.ph::before{content:"⤢";position:absolute;top:12px;right:14px;z-index:2;color:#fff;font-size:1.1rem;
  opacity:0;transform:scale(.6);transition:.35s}
.ph:hover img{transform:scale(1.1)}
.ph:hover::after,.ph:hover::before{opacity:1}
.ph:hover::before{transform:scale(1)}
.ph--big{grid-column:span 2;grid-row:span 2}
.ph--tall{grid-row:span 2}
.gallery__arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:6;
  width:48px;height:48px;border-radius:50%;background:#fff;color:var(--blue-800);
  font-size:1.9rem;line-height:1;display:grid;place-items:center;
  box-shadow:0 12px 28px -10px rgba(0,0,0,.55);transition:.25s}
.gallery__arrow:hover{background:var(--orange-500);color:#fff;transform:translateY(-50%) scale(1.08)}
.gallery__arrow:active{transform:translateY(-50%) scale(.96)}
.gallery__arrow--prev{left:24px}
.gallery__arrow--next{right:24px}
.gallery__hint{text-align:center;color:var(--blue-300);font-size:.82rem;margin-top:16px;letter-spacing:.04em}

/* видео */
.video{margin-top:clamp(40px,6vw,64px);display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,56px);align-items:center}
.video__intro .h3{margin:.4rem 0 .8rem}
.video__intro p{color:var(--blue-200)}
.video__player{position:relative;border-radius:var(--radius);overflow:hidden;
  background:#000;box-shadow:var(--shadow);max-width:380px;margin:0 auto;width:100%;
  aspect-ratio:9/16;border:1px solid rgba(255,255,255,.1)}
.video__player video{width:100%;height:100%;object-fit:cover;display:block}
.video__play{position:absolute;inset:0;margin:auto;width:84px;height:84px;border-radius:50%;
  background:rgba(255,122,24,.92);display:grid;place-items:center;color:#fff;
  box-shadow:0 0 0 0 rgba(255,122,24,.6);animation:pulseRing 2.2s infinite}
.video__play.hide{display:none}
@keyframes pulseRing{0%{box-shadow:0 0 0 0 rgba(255,122,24,.6)}70%{box-shadow:0 0 0 26px rgba(255,122,24,0)}100%{box-shadow:0 0 0 0 rgba(255,122,24,0)}}

/* ============================================================
   ОТЗЫВЫ
   ============================================================ */
.testimonials{background:linear-gradient(180deg,var(--blue-950),var(--blue-900));padding-bottom:0}
.testimonials .community{margin-bottom:clamp(40px,6vw,72px)}
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.review{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius);padding:34px 28px 30px;position:relative;transition:.4s}
.review:hover{transform:translateY(-6px);border-color:rgba(255,154,60,.4);background:rgba(255,255,255,.08)}
.review__mark{position:absolute;top:6px;left:20px;font-family:var(--font-display);
  font-size:4rem;color:var(--orange-500);opacity:.5;line-height:1}
.review p{position:relative;z-index:1;color:#eaf3ff;font-size:1.02rem}
.community{margin-top:clamp(34px,5vw,56px)}
.community__video{position:relative;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);aspect-ratio:16/9;background:#06183a;border:1px solid rgba(255,255,255,.1)}
.community__video iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
.community figcaption{margin-top:16px;text-align:center;
  font-family:var(--font-display);font-weight:600;color:var(--blue-100)}

/* ============================================================
   РАСПИСАНИЕ
   ============================================================ */
.schedule{background:linear-gradient(180deg,#dfeefc,#f2f8ff);padding-bottom:0}
.schedule .timeline-wrap{margin-bottom:clamp(40px,6vw,72px)}
.schedule .eyebrow{color:var(--orange-600)}
.schedule .h2{color:var(--ink)}
.schedule .section-head__sub{color:#3a5577}
.tabs{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:36px}
.tab{display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:.8em 1.5em;border-radius:16px;background:#fff;color:var(--ink);
  border:1px solid rgba(19,79,159,.14);box-shadow:0 8px 22px -16px rgba(19,79,159,.5);transition:.3s}
.tab__d{font-family:var(--font-display);font-weight:600;font-size:1.05rem;white-space:nowrap}
.tab__w{font-size:.78rem;color:#6c83a0}
.tab:hover{transform:translateY(-2px);border-color:var(--orange-300)}
.tab.is-active{background:linear-gradient(135deg,var(--orange-500),var(--orange-600));
  border-color:transparent;color:#fff;box-shadow:var(--shadow-orange)}
.tab.is-active .tab__w{color:rgba(255,255,255,.85)}
.timeline-wrap{max-width:720px;margin:0 auto;background:#fff;border-radius:var(--radius);
  padding:clamp(14px,3vw,24px);box-shadow:0 26px 60px -34px rgba(19,79,159,.55);
  border:1px solid rgba(19,79,159,.08)}
.timeline{display:none}
.timeline.is-active{display:flex;flex-direction:column;gap:8px;animation:fadeUp .5s ease}
.timeline li{display:flex;align-items:center;gap:16px;padding:11px 14px;border-radius:14px;transition:.25s}
.timeline li:hover{background:rgba(19,79,159,.05)}
.timeline .t{font-family:var(--font-display);font-weight:600;font-size:.9rem;
  color:var(--blue-700);background:var(--blue-100);
  padding:.42em .7em;border-radius:100px;flex:none;min-width:62px;text-align:center}
.timeline .e{font-weight:500;color:#33506f}
.timeline .key{background:linear-gradient(100deg,rgba(255,122,24,.12),rgba(255,122,24,.03))}
.timeline .key .t{background:linear-gradient(135deg,var(--orange-500),var(--orange-600));color:#fff}
.timeline .key .e{font-weight:700;color:var(--ink)}

/* ============================================================
   МЕСТО
   ============================================================ */
.place{background:linear-gradient(180deg,#cfe3fa,#dfeefc)}
.place .eyebrow{color:var(--orange-600)}
.place .h2{color:var(--ink)}
.place .section-head__sub{color:#3a5577}
.place__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.place__card{background:#fff;border-radius:var(--radius);overflow:hidden;
  box-shadow:0 24px 60px -34px rgba(19,79,159,.55);border:1px solid rgba(19,79,159,.08);
  display:flex;flex-direction:column;transition:.4s cubic-bezier(.2,.7,.3,1)}
.place__card:hover{transform:translateY(-6px);box-shadow:0 34px 70px -30px rgba(232,89,12,.4)}
.place__card--wide{grid-column:span 2;flex-direction:row}
.place__card--wide .place__media{flex:1.1;aspect-ratio:auto}
.place__card--wide .place__body{flex:1;display:flex;flex-direction:column;justify-content:center}
.place__media{position:relative;overflow:hidden;aspect-ratio:4/3}
.place__media img{width:100%;height:100%;object-fit:cover;transition:transform .9s}
.place__card:hover .place__media img{transform:scale(1.06)}
.place__no{position:absolute;top:14px;left:16px;z-index:2;
  font-family:var(--font-display);font-weight:800;font-size:1.05rem;color:#fff;
  width:42px;height:42px;display:grid;place-items:center;border-radius:12px;
  background:linear-gradient(135deg,var(--orange-500),var(--orange-600));box-shadow:var(--shadow-orange)}
.place__body{padding:24px 26px 28px}
.place__body h3{margin-bottom:.6rem;color:var(--ink)}
.place__body p{color:#48607e}
.frog{position:absolute;bottom:12px;left:16px;font-size:1.6rem;background:none;
  filter:drop-shadow(0 4px 6px rgba(0,0,0,.4));transition:transform .25s;z-index:3;
  opacity:.85}
.frog:hover{opacity:1}
.frog.hop{animation:hop .6s ease}
@keyframes hop{0%,100%{transform:translateY(0)}30%{transform:translateY(-34px) rotate(-12deg)}60%{transform:translateY(0) scale(1.1,.9)}}

/* ============================================================
   СТОИМОСТЬ
   ============================================================ */
.price{background:linear-gradient(180deg,var(--blue-900),var(--blue-950))}
.price__card{display:grid;grid-template-columns:1.2fr .8fr;gap:0;border-radius:calc(var(--radius) + 6px);
  overflow:hidden;box-shadow:var(--shadow)}
.price__left{background:#fff;color:var(--ink);padding:clamp(32px,5vw,52px)}
.price__left .eyebrow{color:var(--orange-600)}
.price__left .h2{color:var(--ink)}
.price__list{margin:1.6rem 0}
.price__list li{padding:.55em 0 .55em 2em;position:relative;border-bottom:1px solid rgba(19,79,159,.1);color:#33506f;font-weight:500}
.price__list li::before{content:"🪷";position:absolute;left:0;top:.5em;font-size:.95em}
.price__note{font-size:.86rem;color:#7187a3}
.price__right{background:linear-gradient(160deg,var(--orange-500),var(--orange-700));
  padding:clamp(32px,5vw,52px);display:flex;flex-direction:column;justify-content:center;text-align:center;color:#fff}
.price__tag{display:flex;align-items:flex-start;justify-content:center;gap:6px;line-height:1}
.price__amount{font-family:var(--font-display);font-weight:800;font-size:clamp(3rem,8vw,4.6rem)}
.price__cur{font-family:var(--font-display);font-weight:700;font-size:1.6rem;margin-top:.4em}
.price__sub{opacity:.9;margin-bottom:1.6rem;font-weight:600}
.price__right .btn--join{background:#fff;color:var(--orange-700)}
.price__right .btn--join:hover{background:var(--cream)}
.price__after{font-size:.82rem;opacity:.92;margin-top:1.2rem}

/* ============================================================
   ВАЖНО / АККОРДЕОН
   ============================================================ */
.important{background:var(--blue-900)}
.accordion{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.acc{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);
  overflow:hidden;transition:.3s}
.acc[open]{border-color:rgba(255,154,60,.4);background:rgba(255,255,255,.07)}
.acc summary{display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:20px 24px;font-family:var(--font-display);font-weight:600;font-size:1.05rem;
  cursor:pointer;list-style:none}
.acc summary::-webkit-details-marker{display:none}
.acc__plus{position:relative;width:18px;height:18px;flex:none}
.acc__plus::before,.acc__plus::after{content:"";position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);background:var(--orange-400);border-radius:2px}
.acc__plus::before{width:16px;height:2px}
.acc__plus::after{width:2px;height:16px;transition:transform .3s}
.acc[open] .acc__plus::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.acc__body{padding:0 24px 22px;color:var(--blue-100)}
.acc__body p{margin-bottom:.6em}
.acc__body ul{margin:.4em 0}
.acc__body li{padding-left:1.4em;position:relative;margin-bottom:.4em}
.acc__body li::before{content:"•";position:absolute;left:.3em;color:var(--orange-400)}
.acc__body b{color:#fff}

/* ============================================================
   КАК ДОБРАТЬСЯ
   ============================================================ */
.how{background:linear-gradient(180deg,var(--blue-900),var(--blue-950))}
.how__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,60px);align-items:center}
.how__addr{font-family:var(--font-display);font-weight:600;font-size:1.2rem;margin:.4rem 0 1.4rem;color:#fff}
.how__list{margin-bottom:1.8rem}
.how__list li{padding:.7em 0;border-bottom:1px solid rgba(255,255,255,.08);color:var(--blue-100);font-size:.96rem}
.how__list li:last-child{border-bottom:none}
.how__list b{color:#fff}
.how__map{position:relative;aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;
  background:#08234a;box-shadow:var(--shadow);border:1px solid rgba(121,182,242,.18)}
.how__map-frame{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
.map-grid{position:absolute;inset:0;
  background-image:linear-gradient(rgba(121,182,242,.1) 1px,transparent 1px),
    linear-gradient(90deg,rgba(121,182,242,.1) 1px,transparent 1px);
  background-size:38px 38px;
  -webkit-mask:radial-gradient(120% 120% at 50% 45%,#000 55%,transparent);
          mask:radial-gradient(120% 120% at 50% 45%,#000 55%,transparent)}
.map-grid::after{content:"";position:absolute;top:52%;left:-10%;right:-10%;height:30px;
  background:linear-gradient(90deg,transparent,var(--blue-500),var(--blue-400),transparent);
  transform:rotate(-7deg);opacity:.55;filter:blur(2px)}
.map-pin{position:relative;z-index:2;display:grid;place-items:center;margin-bottom:18px}
.map-pin__dot{width:22px;height:22px;border-radius:50%;background:var(--orange-500);
  border:3px solid #fff;box-shadow:0 6px 16px rgba(0,0,0,.45);z-index:2}
.map-pin__pulse{position:absolute;width:22px;height:22px;border-radius:50%;background:var(--orange-500);animation:pinPulse 2s ease-out infinite}
@keyframes pinPulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(4);opacity:0}}
.map-label{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);
  display:inline-flex;align-items:center;gap:.5em;background:rgba(6,26,54,.9);
  padding:.6em 1.1em;border-radius:100px;font-size:.84rem;font-weight:600;z-index:2;
  border:1px solid rgba(255,255,255,.18);white-space:nowrap;
  box-shadow:0 10px 24px -12px rgba(0,0,0,.6)}
.map-label::before{content:"📍";font-size:.95em}

/* ============================================================
   ФИНАЛЬНЫЙ CTA
   ============================================================ */
.cta-final{position:relative;text-align:center;overflow:hidden;
  background:linear-gradient(180deg,var(--blue-950),var(--blue-800) 60%,var(--blue-600));
  padding:clamp(80px,12vw,150px) 20px}
.cta-final .sky--mini{position:absolute;inset:0;z-index:0;opacity:.9}
.cta-final__inner{position:relative;z-index:3;max-width:680px}
.cta-final__logo{width:84px;margin:0 auto 24px;animation:lotusPulse 4s ease-in-out infinite;
  filter:drop-shadow(0 8px 24px rgba(255,122,24,.5))}
.cta-final__title{font-family:var(--font-display);font-weight:800;
  font-size:clamp(2.2rem,6vw,4rem);line-height:1.02;letter-spacing:-.02em;margin-bottom:1.2rem}
.cta-final__lead{color:#eaf3ff;font-size:clamp(1rem,1.8vw,1.2rem);margin-bottom:2rem;max-width:540px;margin-inline:auto}

/* ============================================================
   ПОДВАЛ
   ============================================================ */
.footer{background:var(--blue-950);padding:clamp(50px,7vw,80px) 0 30px;border-top:1px solid rgba(255,255,255,.08)}
.footer__inner{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:36px}
.footer__logo{width:54px;margin-bottom:14px}
.footer__title{font-family:var(--font-display);font-weight:700;font-size:1.2rem;line-height:1.1}
.footer__sub{color:var(--blue-200);font-size:.86rem;margin-top:.5rem}
.footer__col h4{font-family:var(--font-display);font-weight:600;font-size:.95rem;margin-bottom:1rem;color:var(--orange-300)}
.footer__col a{display:block;color:var(--blue-100);font-size:.92rem;padding:.35em 0;transition:.25s}
.footer__col a:hover{color:#fff;padding-left:.4em}
.footer__cta{display:flex;flex-direction:column;gap:14px}
.footer__domain{font-family:var(--font-display);font-weight:600;color:var(--orange-300);text-align:center;letter-spacing:.05em}
.footer__made{text-align:center;color:var(--blue-300);font-size:.85rem;margin-top:40px;
  padding-top:24px;border-top:1px solid rgba(255,255,255,.06)}

/* ============================================================
   ЛАЙТБОКС
   ============================================================ */
.lightbox{position:fixed;inset:0;z-index:2000;background:rgba(4,14,30,.94);
  display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;
  transition:.3s;backdrop-filter:blur(6px)}
.lightbox.open{opacity:1;visibility:visible}
.lightbox img{max-width:90vw;max-height:86vh;border-radius:12px;box-shadow:0 30px 80px rgba(0,0,0,.6);
  animation:lbIn .4s cubic-bezier(.2,.7,.3,1)}
@keyframes lbIn{from{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}
.lightbox__close{position:absolute;top:20px;right:26px;font-size:2.6rem;color:#fff;line-height:1;width:50px;height:50px}
.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);font-size:3rem;color:#fff;
  width:60px;height:80px;opacity:.7;transition:.25s}
.lightbox__nav:hover{opacity:1}
.lightbox__nav--prev{left:14px}
.lightbox__nav--next{right:14px}

/* ============================================================
   REVEAL-АНИМАЦИИ
   ============================================================ */
.reveal{opacity:0;transform:translateY(38px);transition:opacity .8s,transform .8s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}
.reveal-word{opacity:0;transform:translateY(60%);display:inline-block}
.reveal-word.in{animation:wordUp .9s cubic-bezier(.2,.8,.2,1) forwards}
@keyframes wordUp{to{opacity:1;transform:none}}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.cards .card.in:nth-child(2){transition-delay:.08s}
.cards .card.in:nth-child(3){transition-delay:.16s}
.cards .card.in:nth-child(4){transition-delay:.24s}
.cards .card.in:nth-child(5){transition-delay:.32s}
.cards .card.in:nth-child(6){transition-delay:.4s}

/* ============================================================
   АДАПТИВ
   ============================================================ */
@media (max-width:1024px){
  .nav{display:none}
  .burger{display:flex}
  .header__cta{display:none}
  .cards{grid-template-columns:repeat(2,1fr)}
  .price__card{grid-template-columns:1fr}
}
@media (max-width:768px){
  .about__grid,.acharya__grid,.video,.how__grid{grid-template-columns:1fr}
  .acharya__photo{max-width:420px;margin:0 auto}
  .reviews{grid-template-columns:1fr}
  .place__grid{grid-template-columns:1fr}
  .place__card--wide{grid-column:auto;flex-direction:column}
  .place__card--wide .place__media{aspect-ratio:4/3}
  .footer__inner{grid-template-columns:1fr 1fr}
  .footer__brand{grid-column:1/-1}
  .footer__cta{grid-column:1/-1}
  .mandala{display:none}
}
@media (max-width:560px){
  .cards{grid-template-columns:1fr}
  .about__stats{gap:18px}
  .stat__num{font-size:2rem}
  .gallery__track{grid-template-rows:repeat(2,clamp(110px,33vw,150px));grid-auto-columns:clamp(140px,42vw,190px)}
  .gallery__arrow{display:none}
  .footer__inner{grid-template-columns:1fr}
  .hero__actions .btn{width:100%}
  .tabs .tab{flex:1;min-width:0;padding:.7em .5em}
  .tabs .tab__d{font-size:.92rem}
  .video__player{max-width:300px}
  .lightbox__nav{width:44px;font-size:2.2rem}
}

/* ============================================================
   PREFERS REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.01ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
