/* ============================================================
   International Yoga Day 2026 — Soul Vibe Space
   ============================================================ */
:root{
  --purple-deep:#5E3FA3;
  --purple:#7B5FB8;
  --purple-brand:#9B7BD9;
  --magenta:#9176C7;
  --teal:#4FA98E;
  --lavender:#EFE4FB;
  --lavender-2:#E3D3F5;
  --ink:#3A2A5E;
  --ink-soft:#5b4783;
  --white:#ffffff;
  --paper:#FBF8FF;

  /* Soft pastel identity: lavender → lilac → mint, matching the brand identity reference */
  --grad: linear-gradient(120deg, #A892D6 0%, #B59CE0 35%, #C9B8DC 60%, #9DD4C0 85%, #7FC9B0 100%);
  --grad-band: linear-gradient(115deg, #A892D6 0%, #B59CE0 45%, #9DD4C0 80%, #7FC9B0 100%);
  --grad-ring: linear-gradient(135deg, #9B7BD9, #B59CE0 55%, #7FC9B0);

  --radius:18px;
  --radius-sm:12px;
  --radius-pill:999px;
  --shadow-sm:0 2px 10px rgba(74,43,122,.08);
  --shadow:0 14px 40px rgba(74,43,122,.14);
  --shadow-lg:0 24px 70px rgba(74,43,122,.22);

  --space-4:1rem; --space-6:1.5rem; --space-8:2rem; --space-10:2.75rem; --space-12:3.5rem; --space-16:5rem;
  --maxw:1160px;

  --sans:'Plus Jakarta Sans', system-ui, -apple-system, "Segoe UI", sans-serif;
  --script:'Caveat', cursive;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:84px;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
:focus-visible{outline:3px solid var(--magenta);outline-offset:3px;border-radius:6px}

.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2.5rem)}
.container.narrow{max-width:820px}

/* ---------------- Buttons ---------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
  font-weight:700;font-size:1rem;letter-spacing:.2px;
  padding:.9rem 1.6rem;border-radius:var(--radius-pill);
  border:2px solid transparent;cursor:pointer;
  transition:transform .18s ease, box-shadow .25s ease, background .25s ease;
  min-height:48px;line-height:1.1;
}
.btn-sm{padding:.55rem 1.1rem;font-size:.92rem;min-height:40px}
.btn-primary{background:var(--grad-ring);color:#fff;box-shadow:0 8px 22px rgba(192,38,211,.32)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(192,38,211,.42)}
.btn-light{background:#fff;color:var(--purple)}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-ghost-light{background:rgba(255,255,255,.10);color:#fff;border-color:rgba(255,255,255,.55);backdrop-filter:blur(4px)}
.btn-ghost-light:hover{background:rgba(255,255,255,.20);transform:translateY(-2px)}

/* ---------------- Header ---------------- */
.site-header{
  position:sticky;top:0;z-index:100;
  /* Bright brand gradient matching poster: deep purple → magenta → teal */
  background:linear-gradient(95deg, #4F2D8E 0%, #6D40B0 28%, #8A3FB8 50%, #6B47B5 72%, #2E8C7E 100%);
  box-shadow:0 1px 0 rgba(0,0,0,.10), 0 6px 18px rgba(60,30,120,.20);
  transition:box-shadow .3s ease;
}
.site-header.scrolled{
  box-shadow:0 1px 0 rgba(0,0,0,.15), 0 10px 28px rgba(60,30,120,.35);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:72px}
.brand{display:flex;align-items:center;gap:.85rem;text-decoration:none}
.brand-logo{display:block;height:46px;width:auto;object-fit:contain}
.brand-event{display:flex;flex-direction:column;justify-content:center;line-height:1;padding-left:.4rem}
.brand-event__kicker{font-family:'Plus Jakarta Sans',sans-serif;font-size:.62rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.78);margin-bottom:.25rem}
.brand-event__title{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.05rem;font-weight:800;letter-spacing:.06em;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.22)}
.brand-footer .brand-logo{height:56px;filter:none}
@media (max-width:720px){
  .brand-event{display:none}
}

.primary-nav{display:flex;gap:1.7rem;align-items:center}
.primary-nav a{font-weight:600;font-size:.95rem;color:rgba(255,255,255,.85);position:relative;padding:.3rem 0;letter-spacing:.2px}
.primary-nav a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:linear-gradient(90deg,#fff,#9DD4C0);transition:width .25s ease}
.primary-nav a:hover{color:#fff}
.primary-nav a:hover::after{width:100%}

.header-actions{display:flex;align-items:center;gap:.7rem}
.lang-toggle{display:inline-flex;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.20);border-radius:var(--radius-pill);padding:3px;backdrop-filter:blur(6px)}
.lang-btn{
  border:none;background:transparent;cursor:pointer;font-family:var(--sans);
  font-weight:700;font-size:.85rem;color:rgba(255,255,255,.85);
  padding:.34rem .7rem;border-radius:var(--radius-pill);transition:.2s;min-height:32px;
}
.lang-btn.active{background:#fff;color:var(--purple);box-shadow:0 2px 8px rgba(0,0,0,.18)}

/* Register button in header stays vivid */
.site-header .btn-primary{background:linear-gradient(135deg,#fff,#F3E9FF);color:var(--purple-deep);box-shadow:0 4px 14px rgba(0,0,0,.2)}
.site-header .btn-primary:hover{box-shadow:0 8px 22px rgba(0,0,0,.28)}

.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:24px;height:2.5px;background:#fff;border-radius:2px;transition:.3s}

/* ---------------- Hero ---------------- */
.hero{position:relative;overflow:hidden;color:#fff;isolation:isolate;
  min-height:84vh;display:flex;align-items:center;padding:7rem 0 5rem}
.hero-bg{position:absolute;inset:0;
  background:url('assets/hero/hero-main.jpg') center/cover no-repeat;
  z-index:-3}
.hero-orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.4;z-index:-2}
.hero-orb-1{width:520px;height:520px;background:radial-gradient(circle,#C9B0E8,transparent 70%);top:-160px;left:-140px}
.hero-orb-2{width:560px;height:560px;background:radial-gradient(circle,#9DD4C0,transparent 70%);bottom:-220px;right:-160px}
/* Soft left-side overlay to keep white text readable over the photo */
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(40,20,90,.35) 0%,rgba(40,20,90,.18) 45%,rgba(40,20,90,0) 70%);z-index:-1;pointer-events:none}

.hero-content{position:relative;max-width:880px}
.hero-eyebrow{font-weight:700;letter-spacing:.42em;font-size:clamp(.85rem,2.4vw,1.3rem);opacity:.92;margin-bottom:.2rem;text-transform:uppercase}
.hero-title{font-weight:800;letter-spacing:.01em;font-size:clamp(3.4rem,14vw,8.5rem);line-height:.92;text-shadow:0 4px 30px rgba(58,42,94,.35),0 2px 10px rgba(0,0,0,.18)}
.hero-script{font-family:var(--script);font-size:clamp(2.2rem,7vw,4rem);color:#FFF4FB;font-weight:600;margin:.1rem 0 1rem;line-height:1;text-shadow:0 2px 14px rgba(58,42,94,.3)}
.hero-tagline{font-weight:700;letter-spacing:.04em;font-size:clamp(1rem,2.6vw,1.5rem);max-width:30ch;opacity:.96;text-transform:uppercase;line-height:1.35}

.hero-stats{display:flex;flex-wrap:wrap;gap:1.1rem;margin:2.2rem 0 2.4rem}
.stat{display:flex;align-items:center;gap:.8rem;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);
  border-radius:var(--radius);padding:.85rem 1.15rem;backdrop-filter:blur(6px);flex:1 1 240px;min-width:230px}
.stat-ic{flex:none;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;
  background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.35)}
.stat-ic svg{width:24px;height:24px;color:#fff}
.stat-txt{display:flex;flex-direction:column;line-height:1.25}
.stat-txt strong{font-weight:800;font-size:.9rem;letter-spacing:.3px}
.stat-txt em{font-style:normal;font-size:.82rem;opacity:.85;font-weight:500}

.hero-ctas{display:flex;flex-wrap:wrap;gap:.9rem}

/* floating badge */
.hero-badge{position:absolute;top:5rem;right:clamp(1rem,4vw,3rem);z-index:2;width:170px;height:170px;
  animation:float 6s ease-in-out infinite;filter:drop-shadow(0 18px 38px rgba(0,0,0,.30))}
.hero-badge img{width:100%;height:100%;display:block;object-fit:contain}
@keyframes float{0%,100%{transform:translateY(0) rotate(-4deg)}50%{transform:translateY(-14px) rotate(4deg)}}

/* ---------------- Info strip ---------------- */
.info-strip{margin-top:-2.4rem;position:relative;z-index:5;padding-bottom:1rem}
.info-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.info-card{display:flex;align-items:center;gap:.85rem;background:#fff;border-radius:var(--radius);
  padding:1.15rem 1.2rem;box-shadow:var(--shadow);border:1px solid rgba(107,79,160,.08);transition:transform .2s,box-shadow .2s}
a.info-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.info-ic{flex:none;width:44px;height:44px;border-radius:13px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--lavender),#fff);color:var(--purple-brand)}
.info-ic svg{width:23px;height:23px}
.info-l{display:block;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--magenta);font-weight:700}
.info-v{display:block;font-weight:700;font-size:.98rem;color:var(--ink);line-height:1.3}

/* ---------------- Section ---------------- */
.section{padding:var(--space-16) 0}
.section-soft{background:linear-gradient(180deg,#F7F1FF,#FBF8FF)}
.section-head{text-align:center;max-width:680px;margin:0 auto var(--space-12)}
.section-title{font-weight:800;letter-spacing:.16em;text-transform:uppercase;
  font-size:clamp(1.7rem,4.5vw,2.6rem);color:var(--purple);position:relative;display:inline-block}
.section-title::after{content:"";display:block;width:64px;height:4px;border-radius:4px;
  background:var(--grad-ring);margin:.7rem auto 0}
.section-intro{margin-top:1rem;color:var(--ink-soft);font-size:1.05rem}

/* ---------------- Schedule table ---------------- */
.table-wrap{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid rgba(107,79,160,.10)}
.schedule-table{width:100%;border-collapse:collapse;background:#fff}
.schedule-table thead th{
  background:var(--grad-band);color:#fff;text-align:left;font-weight:800;letter-spacing:.08em;
  font-size:.82rem;padding:1rem 1.2rem;text-transform:uppercase}
.schedule-table tbody tr{cursor:pointer;transition:background .18s,transform .18s}
.schedule-table tbody tr:nth-child(odd){background:#fff}
.schedule-table tbody tr:nth-child(even){background:var(--lavender)}
.schedule-table tbody tr:hover{background:var(--lavender-2)}
.schedule-table td{padding:.92rem 1.2rem;border-bottom:1px solid rgba(107,79,160,.08);vertical-align:middle;font-size:.98rem}
.td-time{font-weight:700;color:var(--purple);white-space:nowrap;display:flex;align-items:center;gap:.5rem}
.td-time .clock{color:var(--magenta);display:inline-flex}
.td-class{font-weight:700;color:var(--ink)}
.td-teacher{color:var(--ink-soft);font-weight:600}
.tr.flash,tr.flash,.flash{animation:flash 1.1s ease}
@keyframes flash{0%,100%{box-shadow:none}30%{box-shadow:0 0 0 3px var(--magenta) inset}}

/* language pills */
.pill{display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:.72rem;letter-spacing:.05em;
  padding:.26rem .6rem;border-radius:var(--radius-pill);line-height:1;min-width:42px}
.lang-ru{background:#FDE2E4;color:#C0263A}
.lang-en{background:#DCE7FF;color:#2348B8}
.lang-bi{padding:0;overflow:hidden;gap:0}
.lang-bi .pill-en{background:#DCE7FF;color:#2348B8;padding:.26rem .5rem}
.lang-bi .pill-ru{background:#FDE2E4;color:#C0263A;padding:.26rem .5rem}

/* mobile schedule cards */
.sched-cards{display:none;flex-direction:column;gap:.8rem}
.sched-card{text-align:left;width:100%;background:#fff;border:1px solid rgba(107,79,160,.12);
  border-left:4px solid var(--magenta);border-radius:var(--radius-sm);padding:1rem 1.1rem;cursor:pointer;
  box-shadow:var(--shadow-sm);transition:transform .18s,box-shadow .18s;font-family:var(--sans)}
.sched-card:active{transform:scale(.99)}
.sched-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}
.sched-card-time{font-weight:800;color:var(--purple);font-size:.95rem}
.sched-card-title{font-weight:700;color:var(--ink);font-size:1.02rem;line-height:1.3}
.sched-card-teacher{color:var(--ink-soft);font-size:.9rem;margin-top:.2rem;font-weight:600}

/* ---------------- Avatars ---------------- */
.avatar{flex:none;width:52px;height:52px;border-radius:50%;padding:3px;background:var(--grad-ring);display:grid;place-items:center}
.avatar-inner{width:100%;height:100%;border-radius:50%;background:#fff;display:grid;place-items:center;
  font-weight:800;font-size:1.25rem}
.avatar-inner span,.avatar-inner{line-height:1}
.avatar-inner{overflow:hidden}
.avatar-photo{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block;transform-origin:center}
.avatar-letter{background-image:var(--grad-ring);background-clip:text;-webkit-background-clip:text;color:transparent;-webkit-text-fill-color:transparent}
.avatar-lg{width:74px;height:74px}
.avatar-lg .avatar-inner{font-size:1.8rem}

/* ---------------- Class cards ---------------- */
.class-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.class-card{background:#fff;border-radius:var(--radius);padding:clamp(1.5rem,3vw,2.2rem);
  box-shadow:var(--shadow-sm);border:1px solid rgba(107,79,160,.08);
  transition:transform .25s,box-shadow .25s;scroll-margin-top:90px}
.class-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.class-card-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}
.class-card-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:flex-end}
.time-pill{background:var(--lavender);color:var(--purple);font-weight:800;font-size:.82rem;
  padding:.3rem .7rem;border-radius:var(--radius-pill);white-space:nowrap}
.class-card-title{font-size:1.25rem;font-weight:800;color:var(--purple);line-height:1.25}
.class-card-teacher{color:var(--magenta);font-weight:700;font-size:.92rem;margin:.25rem 0 .75rem}
.class-card-desc{color:var(--ink-soft);font-size:.97rem;line-height:1.65}

/* ---------------- Teachers ---------------- */
.teacher-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.teacher-card{background:#fff;border-radius:var(--radius);padding:1.8rem 1.2rem;text-align:center;
  box-shadow:var(--shadow-sm);border:1px solid rgba(107,79,160,.08);transition:transform .25s,box-shadow .25s}
.teacher-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.teacher-card .avatar{margin:0 auto .9rem}
.teacher-name{font-size:1.12rem;font-weight:800;color:var(--purple)}
.teacher-leads{margin-top:.4rem;color:var(--ink-soft);font-size:.86rem;line-height:1.45}

/* ---------------- FAQ ---------------- */
.faq-list{display:flex;flex-direction:column;gap:.85rem}
.faq-item{background:#fff;border-radius:var(--radius);border:1px solid rgba(107,79,160,.10);
  box-shadow:var(--shadow-sm);overflow:hidden}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:1.1rem 1.4rem;font-weight:700;color:var(--purple);font-size:1.05rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-chevron{color:var(--magenta);display:inline-flex;transition:transform .25s}
.faq-item[open] .faq-chevron{transform:rotate(180deg)}
.faq-a{padding:0 1.4rem 1.2rem;color:var(--ink-soft);line-height:1.65}

/* ---------------- CTA band ---------------- */
.cta-band{position:relative;color:#fff;text-align:center;padding:var(--space-16) 0;overflow:hidden;isolation:isolate}
.cta-bg{position:absolute;inset:0;background:var(--grad-band);z-index:-1}
.cta-inner{max-width:760px}
.cta-title{font-size:clamp(1.8rem,4.5vw,2.9rem);font-weight:800;line-height:1.15;text-shadow:0 4px 24px rgba(0,0,0,.18)}
.cta-sub{margin:1rem 0 2rem;font-size:1.1rem;opacity:.94}
.cta-band .hero-ctas{justify-content:center}

/* ---------------- Footer ---------------- */
.site-footer{background:var(--purple-deep);color:#E8DBFB;padding:var(--space-16) 0 2rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem}
.footer-slogan{font-family:var(--script);font-size:1.55rem;color:#FFD9F6;margin-top:1rem}
.footer-col h3{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:#C9B4EC;margin-bottom:.9rem;font-weight:700}
.footer-col a{display:block;color:#E8DBFB;margin-bottom:.55rem;font-size:.97rem;transition:color .2s}
.footer-col a:hover{color:#fff}
.foot-wa{display:inline-flex;align-items:center;gap:.5rem;background:#25D366;color:#fff;padding:.55rem .95rem;border-radius:var(--radius-pill);font-weight:700;margin-bottom:.7rem;transition:transform .2s, box-shadow .2s}
.foot-wa:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(37,211,102,.45);color:#fff}
.foot-wa svg{flex:none}
.footer-bottom{margin-top:3rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.12);
  font-size:.85rem;color:#B79DDC}

/* ---------------- Reveal ---------------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ---------------- Map section ---------------- */
.map-section{padding:3rem 0 1rem}
.map-section .section-head{margin-bottom:1.4rem}
.map-address-link{color:var(--purple-dark,#4F2D8E);font-weight:600;text-decoration:none;border-bottom:1px solid rgba(79,45,142,.25);transition:border-color .2s ease}
.map-address-link:hover{border-color:rgba(79,45,142,.7)}
.map-frame{border-radius:18px;overflow:hidden;box-shadow:0 14px 40px -18px rgba(40,20,90,.45);background:#eee}
.map-frame iframe{display:block;width:100%;height:420px;border:0}
@media (max-width:780px){.map-frame iframe{height:340px}}

/* Section CTA — small register prompt after each block */
.section-cta{display:flex;align-items:center;justify-content:center;gap:1.2rem;flex-wrap:wrap;margin-top:2.5rem;padding:1.4rem 1.6rem;border-radius:18px;background:linear-gradient(135deg,rgba(125,80,200,.08),rgba(125,200,170,.08));border:1px solid rgba(125,80,200,.18)}
.section-cta__text{font-weight:600;font-size:1.02rem;color:#3a2660;letter-spacing:.2px}
.section-cta .btn{flex-shrink:0}
@media (max-width:560px){
  .section-cta{flex-direction:column;gap:.9rem;text-align:center;padding:1.2rem}
  .section-cta .btn{width:100%}
}

/* Booking note under Register CTAs */
.booking-note{margin:.9rem 0 0;font-size:.82rem;letter-spacing:.2px;opacity:.78;line-height:1.5}
.booking-note-light{color:rgba(255,255,255,.85)}

/* Mobile-only Register inside the burger menu */
.nav-register-mobile{display:none}

/* ---------------- Responsive ---------------- */
@media (max-width:960px){
  .info-grid{grid-template-columns:repeat(2,1fr)}
  .teacher-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:780px){
  .primary-nav{position:fixed;inset:72px 0 auto 0;flex-direction:column;gap:0;
    background:linear-gradient(160deg, #4F2D8E, #6D40B0 50%, #2E8C7E);
    padding:1rem clamp(1.1rem,4vw,2.5rem) 1.5rem;box-shadow:var(--shadow);
    transform:translateY(-130%);transition:transform .3s ease;align-items:stretch}
  .primary-nav.open{transform:translateY(0)}
  .primary-nav a{padding:.85rem 0;border-bottom:1px solid rgba(255,255,255,.14);font-size:1.05rem;color:#fff}
  .primary-nav a::after{display:none}
  .primary-nav .nav-register-mobile{display:block;margin-top:.9rem;padding:.85rem 1rem;background:#fff;color:#4F2D8E;font-weight:700;border-radius:999px;text-align:center;border-bottom:none;letter-spacing:.4px}
  .burger{display:flex}
  .header-actions .btn-primary{display:none}
  .class-grid{grid-template-columns:1fr}
  .teacher-grid{grid-template-columns:repeat(2,1fr)}
  .schedule-table{display:none}
  .table-wrap{border:none;box-shadow:none;overflow:visible}
  .sched-cards{display:flex}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .hero{min-height:74vh;padding:6rem 0 4rem}
  .hero-badge{width:84px;height:84px;top:5.6rem;right:.6rem}
  .hero-badge img{width:84px;height:84px}
  .hero-content{padding-top:5.2rem}
}
@media (max-width:560px){
  .info-grid{grid-template-columns:1fr}
  .stat{min-width:100%}
  .hero-stats{gap:.7rem}
  .btn{width:100%}
  .header-actions .lang-toggle{order:2}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none;transition:none}
}
