:root {
  interpolate-size: allow-keywords;
  --bg: #FFFFFF;
  --surface: #EEFAF6;
  --surface-2: #E0F5EE;
  --ink: #2D2D2D;
  --ink-soft: #6B6B6B;
  --accent: #FF6B5A;
  --accent-2: #2EC4A0;
  --line: rgba(45, 45, 45, 0.12);
  --line-strong: rgba(45, 45, 45, 0.25);
  --radius: 16px;
  --radius-sm: 8px;
  --radius-pill: 100px;
  --header-h: 72px;
  --container: 1400px;
  --font-heading: 'Trebuchet MS', 'Segoe UI', sans-serif;
  --font-body: 'Segoe UI', 'Trebuchet MS', sans-serif;
  --font-mono: 'Consolas', 'Courier New', monospace;
  --ease: cubic-bezier(.2,.7,.2,1);
  --ease-out: cubic-bezier(.4,0,.2,1);
  --shadow-sm: 0 2px 8px rgba(45,45,45,.06);
  --shadow-md: 0 8px 24px rgba(45,45,45,.1);
  --shadow-lg: 0 16px 48px rgba(45,45,45,.12);
  --shadow-accent: 0 8px 24px rgba(255,107,90,.18);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

html,body{overflow-x:hidden;max-width:100vw;margin:0}

body{
  font-family:var(--font-body);
  font-weight:400;
  font-size:clamp(15px,1.6vw,17px);
  line-height:1.65;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color 240ms var(--ease-out)}
ul,ol{list-style:none}
button,input,select,textarea{font:inherit;color:inherit;border:none;background:none}
button{cursor:pointer}

.skip-link{
  position:absolute;top:-100%;left:16px;z-index:10000;
  background:var(--ink);color:var(--bg);padding:12px 24px;border-radius:var(--radius-sm);
  font-weight:600;font-size:14px;
}
.skip-link:focus{top:16px}

h1,h2,h3,h4,h5,h6{
  font-family:var(--font-heading);
  font-weight:600;
  line-height:1.15;
  letter-spacing:-0.012em;
  color:var(--ink);
}

h1{font-size:clamp(36px,5vw,72px);font-weight:700}
h2{font-size:clamp(2rem,4vw,3rem)}
h3{font-size:clamp(1.4rem,2.5vw,1.8rem)}
h4{font-size:clamp(1.1rem,1.8vw,1.3rem)}

.eyebrow{
  font-family:var(--font-body);
  font-weight:500;
  font-size:clamp(12px,1.2vw,14px);
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:12px;
  display:block;
}

.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding-left:clamp(16px,4vw,32px);
  padding-right:clamp(16px,4vw,32px);
}

/* ---- HEADER ---- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1080;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  transition:background 240ms ease,box-shadow 240ms ease,padding 240ms ease;
  padding:0;
}
.site-header.scrolled{
  background:rgba(255,255,255,.98);
  box-shadow:0 8px 24px -16px rgba(0,0,0,.18);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:var(--header-h);
  max-width:var(--container);margin:0 auto;
  padding:0 clamp(16px,4vw,32px);
}
.logo{
  font-family:var(--font-heading);
  font-weight:700;font-size:clamp(18px,2vw,22px);
  display:flex;align-items:center;gap:10px;
  z-index:1100;
}
.logo svg{width:36px;height:36px;flex-shrink:0}
.logo span{color:var(--accent)}

.nav-desktop{display:none}
@media(min-width:1024px){
  .nav-desktop{
    display:flex;align-items:center;gap:clamp(20px,2.5vw,36px);
  }
  .nav-desktop a{
    font-family:var(--font-body);
    font-size:14px;font-weight:500;
    color:var(--ink);position:relative;
    padding:4px 0;
    transition:color 240ms var(--ease-out);
  }
  .nav-desktop a::after{
    content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;
    background:var(--accent);border-radius:2px;
    transition:width 280ms var(--ease);
  }
  .nav-desktop a:hover{color:var(--accent)}
  .nav-desktop a:hover::after{width:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2))}
  .nav-desktop a.is-active{color:var(--accent)}
  .nav-desktop a.is-active::after{width:100%}
  .nav-desktop .nav-cta{
    background:var(--ink);color:var(--bg);
    padding:10px 24px;border-radius:var(--radius-pill);
    font-weight:600;font-size:14px;
    transition:background 240ms var(--ease-out),color 240ms var(--ease-out),transform 200ms var(--ease-out);
  }
  .nav-desktop .nav-cta::after{display:none}
  .nav-desktop .nav-cta:hover{background:var(--accent);color:#fff;transform:translateY(-3px);box-shadow:0 6px 20px rgba(255,107,90,.2)}
  .nav-desktop .nav-cta.is-active{background:var(--accent);color:#fff}
}

.nav-toggle{
  display:flex;flex-direction:column;justify-content:center;gap:5px;
  width:44px;height:44px;padding:10px;
  z-index:1100;position:relative;
  background:none;border:none;cursor:pointer;
}
.nav-toggle span{
  display:block;width:26px;height:3px;
  background:var(--ink);border-radius:2px;
  transition:transform 320ms var(--ease),opacity 200ms,background 240ms var(--ease-out);
  transform-origin:center;
}
.nav-toggle:hover span{background:var(--accent)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
@media(min-width:1024px){.nav-toggle{display:none}}

/* ---- DRAWER ---- */
.drawer-backdrop{
  position:fixed;inset:0;z-index:1040;
  background:rgba(0,0,0,.55);
  opacity:0;pointer-events:none;
  transition:opacity 240ms;
}
.drawer-backdrop.is-open{opacity:1;pointer-events:auto}

.drawer{
  position:fixed;top:0;right:0;bottom:0;
  width:min(360px,92vw);z-index:1050;
  background:var(--bg);
  transform:translateX(100%);
  transition:transform 320ms cubic-bezier(.2,.7,.2,1);
  padding:calc(var(--header-h) + 24px) 32px 32px;
  display:flex;flex-direction:column;gap:8px;
  overflow-y:auto;
}
.drawer.is-open{transform:translateX(0)}
.drawer a{
  font-family:var(--font-heading);
  font-size:18px;font-weight:600;
  padding:14px 0;
  border-bottom:1px solid var(--line);
  display:block;
  transition:color 240ms var(--ease-out),transform 240ms var(--ease-out);
}
.drawer a:hover{color:var(--accent);transform:translateX(6px)}
.drawer a.is-active{color:var(--accent)}
.drawer .drawer-cta{
  margin-top:16px;
  background:var(--accent);color:#fff;
  padding:16px 32px;border-radius:var(--radius-pill);
  text-align:center;font-weight:600;font-size:16px;
  border-bottom:none;
  transition:background 240ms var(--ease-out),transform 200ms var(--ease-out);
}
.drawer .drawer-cta:hover{background:var(--ink);color:#fff;transform:translateX(0) translateY(-2px)}

/* ---- MAIN ---- */
main{padding-top:var(--header-h)}

/* ---- SECTION SPACING ---- */
.section{
  padding:clamp(60px,10vw,120px) 0;
  position:relative;
}
.section--surface{background:var(--surface)}
.section--ink{background:var(--ink);color:var(--bg)}
.section--ink h2,.section--ink h3,.section--ink h4,.section--ink .eyebrow{color:var(--bg)}
.section--ink .eyebrow{color:var(--accent)}
.section--ink p{color:rgba(255,255,255,.8)}

.section-header{
  max-width:640px;margin-bottom:clamp(32px,5vw,56px);
}
.section-header.centered{text-align:center;margin-left:auto;margin-right:auto}

/* ---- BUTTONS ---- */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-heading);
  font-weight:600;font-size:15px;
  padding:14px 32px;border-radius:var(--radius-pill);
  transition:all 240ms var(--ease-out);
  cursor:pointer;border:2px solid transparent;
  position:relative;overflow:hidden;
}
.btn-primary{
  background:var(--ink);color:var(--bg);
  border-color:var(--ink);
}
.btn-primary:hover,.btn-primary:focus-visible{
  background:var(--accent);color:#fff;
  border-color:var(--accent);
  transform:translateY(-3px);
  box-shadow:0 8px 28px rgba(255,107,90,.25);
}
.btn-accent{
  background:var(--accent);color:#fff;
  border-color:var(--accent);
}
.btn-accent:hover,.btn-accent:focus-visible{
  background:var(--ink);color:var(--bg);
  border-color:var(--ink);
  transform:translateY(-3px);
  box-shadow:0 8px 24px rgba(45,45,45,.18);
}
.btn-ghost{
  background:transparent;color:var(--ink);
  border-color:var(--line-strong);
}
.btn-ghost:hover,.btn-ghost:focus-visible{
  background:var(--surface);color:var(--ink);
  border-color:var(--accent-2);
  transform:translateY(-3px);
  box-shadow:0 6px 20px rgba(46,196,160,.12);
}
.btn-white{
  background:#fff;color:var(--ink);
  border-color:#fff;
}
.btn-white:hover,.btn-white:focus-visible{
  background:var(--accent);color:#fff;
  border-color:var(--accent);
  transform:translateY(-3px);
  box-shadow:0 8px 24px rgba(255,107,90,.3);
}

.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:2px solid var(--accent);outline-offset:2px;
}

/* ---- PILL BADGES ---- */
.pill{
  display:inline-flex;align-items:center;
  padding:4px 14px;border-radius:var(--radius-pill);
  font-size:12px;font-weight:600;
  font-family:var(--font-body);
  letter-spacing:.04em;
}
.pill--beginner{background:#E8F9F0;color:#1A8A52}
.pill--intermediate{background:#FFF3E6;color:#D97706}
.pill--advanced{background:#FFE8E6;color:#DC2626}
.pill--all{background:var(--surface-2);color:var(--accent-2)}
.pill--tag{background:var(--surface);color:var(--ink-soft);font-weight:500}

/* ---- HERO ---- */
.hero{
  min-height:min(calc(100vh - var(--header-h)),860px);
  display:flex;align-items:center;
  position:relative;overflow:hidden;
  background:var(--bg);
  padding:clamp(40px,8vw,80px) 0;
}
.hero-container{
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(32px,5vw,48px);
  align-items:center;
}
@media(min-width:1024px){
  .hero-container{grid-template-columns:1fr 1fr;gap:clamp(40px,5vw,80px)}
}
.hero-content{position:relative;z-index:2}
.hero-pills{
  display:flex;flex-wrap:wrap;gap:8px;margin-bottom:clamp(20px,3vw,32px);
}
.hero-pills .pill{
  font-size:13px;padding:6px 16px;
  transition:transform 240ms var(--ease),background 240ms var(--ease-out);
  cursor:default;
}
.hero-pills .pill:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 4px 12px rgba(46,196,160,.15)}
.hero h1{margin-bottom:clamp(16px,2vw,24px)}
.hero h1 .char{
  display:inline-block;
  opacity:0;transform:translateY(20px);
  animation:charReveal 500ms var(--ease) forwards;
}
.hero h1.chars-done .char{opacity:1!important;transform:none!important}
@keyframes charReveal{to{opacity:1;transform:none}}
.hero-sub{
  font-size:clamp(16px,1.8vw,20px);
  color:var(--ink-soft);
  max-width:520px;
  margin-bottom:clamp(24px,4vw,40px);
  line-height:1.6;
}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.hero-trust{
  display:flex;flex-wrap:wrap;gap:10px;margin-top:clamp(24px,3vw,36px);
}
.hero-trust-item{
  display:flex;align-items:center;gap:6px;
  font-size:13px;color:var(--ink-soft);font-weight:500;
}
.hero-trust-item svg{width:16px;height:16px;color:var(--accent-2);flex-shrink:0}

.hero-visual{
  position:relative;
  display:flex;align-items:center;justify-content:center;
}
.hero-visual-img{
  width:100%;max-width:560px;
  border-radius:var(--radius);
  overflow:hidden;
  position:relative;
  aspect-ratio:4/5;
}
.hero-visual-img img{
  width:100%;height:100%;object-fit:cover;
}
.hero-breathe{
  position:absolute;
  width:clamp(200px,30vw,380px);height:clamp(200px,30vw,380px);
  border-radius:50%;
  background:radial-gradient(circle,rgba(46,196,160,.15) 0%,rgba(46,196,160,.02) 70%,transparent 100%);
  animation:breathe 8s ease-in-out infinite;
  pointer-events:none;
  top:50%;left:50%;transform:translate(-50%,-50%);
  z-index:0;
}
@keyframes breathe{
  0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.4}
  50%{transform:translate(-50%,-50%) scale(1.18);opacity:.7}
}
@media(prefers-reduced-motion:reduce){
  .hero-breathe{animation:none;opacity:.4}
  .hero h1 .char{opacity:1;transform:none;animation:none}
}

.hero-deco{
  position:absolute;pointer-events:none;z-index:0;
}
.hero-deco--lotus{
  right:-5%;top:10%;width:clamp(120px,18vw,240px);height:auto;opacity:.06;
  animation:lotusFloat 12s ease-in-out infinite;
}
@keyframes lotusFloat{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-12px) rotate(4deg)}
}
@media(prefers-reduced-motion:reduce){.hero-deco--lotus{animation:none}}

/* ---- CLASSES / DERSLER ---- */
.filter-bar{
  display:flex;flex-wrap:wrap;gap:8px;
  margin-bottom:clamp(24px,4vw,40px);
  padding:16px 0;
  border-bottom:1px solid var(--line);
}
.filter-group{
  display:flex;flex-wrap:wrap;gap:6px;align-items:center;
}
.filter-group-label{
  font-size:13px;font-weight:600;color:var(--ink-soft);
  margin-right:4px;
  font-family:var(--font-heading);
}
.filter-btn{
  padding:6px 16px;border-radius:var(--radius-pill);
  font-size:13px;font-weight:500;
  background:var(--surface);color:var(--ink-soft);
  border:1px solid transparent;
  transition:all 200ms var(--ease-out);
  cursor:pointer;
}
.filter-btn:hover{background:var(--surface-2);color:var(--ink)}
.filter-btn.is-active{
  background:var(--ink);color:var(--bg);
  border-color:var(--ink);
}

.class-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:clamp(16px,2vw,24px);
}
@media(min-width:1024px){
  .class-grid{grid-template-columns:repeat(4,1fr)}
}

.class-card{
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  transition:transform 360ms var(--ease),box-shadow 360ms var(--ease),opacity 320ms var(--ease);
  position:relative;
}
.class-card:hover{
  transform:translateY(-7px);
  box-shadow:0 16px 40px rgba(46,196,160,.16),0 0 0 1px rgba(46,196,160,.12),0 0 60px -12px rgba(255,107,90,.06);
  border-color:rgba(46,196,160,.28);
}
.class-card.is-flipping{
  animation:cardFlip 400ms var(--ease-out);
}
@keyframes cardFlip{
  0%{transform:perspective(600px) rotateY(0) scale(1);opacity:1}
  50%{transform:perspective(600px) rotateY(90deg) scale(.95);opacity:0}
  100%{transform:perspective(600px) rotateY(0) scale(1);opacity:1}
}
.class-card.is-hidden{
  display:none;
}
.class-card-img{
  aspect-ratio:16/10;overflow:hidden;position:relative;
}
.class-card-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 600ms var(--ease);
}
.class-card:hover .class-card-img img{transform:scale(1.04)}
.class-card-body{padding:clamp(16px,2vw,20px)}
.class-card-top{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:8px;
}
.class-card h4{font-size:16px;margin-bottom:4px}
.class-card-meta{
  font-size:13px;color:var(--ink-soft);
  display:flex;gap:12px;align-items:center;
  margin-top:8px;
}
.class-card-meta svg{width:14px;height:14px;flex-shrink:0}

/* ---- INSTRUCTORS ---- */
.instructors-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:clamp(24px,3vw,40px);
}
@media(min-width:768px){
  .instructors-grid{grid-template-columns:repeat(4,1fr)}
}
.instructor-card{
  text-align:center;
  transition:transform 360ms var(--ease);
}
.instructor-card:hover{transform:translateY(-6px)}
.instructor-avatar{
  width:clamp(120px,14vw,160px);height:clamp(120px,14vw,160px);
  border-radius:50%;
  margin:0 auto clamp(12px,2vw,20px);
  overflow:hidden;
  border:3px solid var(--surface-2);
  transition:border-color 360ms var(--ease);
  position:relative;
}
.instructor-card:hover .instructor-avatar{border-color:var(--accent);box-shadow:0 0 28px rgba(46,196,160,.25),0 0 56px -12px rgba(255,107,90,.08)}
.instructor-avatar img{width:100%;height:100%;object-fit:cover}
.instructor-avatar::after{
  content:'';position:absolute;inset:0;
  border-radius:50%;
  background:radial-gradient(circle at 30% 30%,rgba(255,107,90,.1),transparent 60%);
  opacity:0;transition:opacity 360ms var(--ease);
}
.instructor-card:hover .instructor-avatar::after{opacity:1}
.instructor-card h4{font-size:16px;margin-bottom:4px}
.instructor-card p{font-size:13px;color:var(--ink-soft)}

/* ---- MEMBERSHIP TABLE ---- */
.membership-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(16px,2vw,24px);
}
@media(min-width:768px){
  .membership-grid{grid-template-columns:repeat(3,1fr)}
}
@media(min-width:1024px){
  .membership-grid{grid-template-columns:repeat(4,1fr)}
}

.plan-card{
  background:var(--bg);
  border:2px solid var(--line);
  border-radius:var(--radius);
  padding:clamp(24px,3vw,36px);
  transition:transform 360ms var(--ease),box-shadow 360ms var(--ease),border-color 360ms var(--ease);
  display:flex;flex-direction:column;
  position:relative;
}
.plan-card:hover{
  transform:translateY(-8px);
  box-shadow:0 20px 48px rgba(46,196,160,.15),0 0 0 1px rgba(46,196,160,.1),0 0 64px -16px rgba(255,107,90,.06);
  border-color:rgba(46,196,160,.35);
}
.plan-card--featured{
  border-color:var(--accent);
  background:linear-gradient(180deg,rgba(255,107,90,.04) 0%,var(--bg) 100%);
}
.plan-card--featured::before{
  content:'Popüler';
  position:absolute;top:-1px;right:24px;
  background:var(--accent);color:#fff;
  padding:4px 14px;border-radius:0 0 var(--radius-sm) var(--radius-sm);
  font-size:12px;font-weight:700;
  font-family:var(--font-heading);
}
.plan-card h4{font-size:18px;margin-bottom:8px}
.plan-price{
  font-family:var(--font-mono);
  font-size:clamp(28px,3.5vw,36px);
  font-weight:700;
  color:var(--ink);
  margin-bottom:4px;
}
.plan-price small{font-size:14px;font-weight:400;color:var(--ink-soft)}
.plan-period{font-size:13px;color:var(--ink-soft);margin-bottom:20px}
.plan-features{
  flex:1;
  margin-bottom:24px;
}
.plan-features li{
  font-size:14px;
  padding:6px 0;
  display:flex;align-items:flex-start;gap:8px;
}
.plan-features li svg{
  width:16px;height:16px;flex-shrink:0;margin-top:2px;
}
.plan-features .included svg{color:var(--accent-2)}
.plan-features .excluded{color:var(--ink-soft);text-decoration:line-through;opacity:.6}
.plan-features .excluded svg{color:var(--ink-soft);opacity:.4}
.plan-disclaimer{
  font-size:12px;color:var(--ink-soft);
  padding-top:12px;border-top:1px solid var(--line);
  margin-top:auto;
}

/* ---- TESTIMONIALS ---- */
.testimonials-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(16px,2vw,24px);
}
@media(min-width:640px){
  .testimonials-grid{grid-template-columns:repeat(2,1fr)}
}
@media(min-width:1024px){
  .testimonials-grid{grid-template-columns:repeat(3,1fr)}
}
.testimonial-card{
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:clamp(24px,3vw,32px);
  transition:transform 360ms var(--ease),box-shadow 360ms var(--ease);
  position:relative;
}
.testimonial-card:hover{
  transform:translateY(-5px);
  box-shadow:0 16px 40px rgba(46,196,160,.14),0 0 0 1px rgba(46,196,160,.1),0 0 48px -10px rgba(255,107,90,.05);
  border-color:rgba(46,196,160,.25);
}
.testimonial-card::before{
  content:'"';
  font-family:var(--font-heading);
  font-size:48px;font-weight:700;
  color:var(--accent);opacity:.2;
  position:absolute;top:16px;left:20px;
  line-height:1;
}
.testimonial-text{
  font-size:15px;line-height:1.7;
  margin-bottom:16px;
  color:var(--ink);
}
.testimonial-author{
  display:flex;align-items:center;gap:12px;
  padding-top:16px;
  border-top:1px solid var(--line);
}
.testimonial-author-avatar{
  width:40px;height:40px;border-radius:50%;
  background:var(--surface);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-heading);
  font-weight:700;font-size:15px;
  color:var(--accent-2);
  flex-shrink:0;
}
.testimonial-author-info strong{
  display:block;font-size:14px;font-weight:600;
}
.testimonial-author-info span{
  font-size:12px;color:var(--ink-soft);
}

/* ---- PROCESS / TIMELINE ---- */
.process-timeline{
  position:relative;
  max-width:680px;
  margin:0 auto;
}
.process-timeline::before{
  content:'';position:absolute;
  left:24px;top:0;bottom:0;width:2px;
  background:linear-gradient(180deg,var(--accent),var(--accent-2));
  border-radius:2px;
}
@media(min-width:640px){
  .process-timeline::before{left:32px}
}
.process-step{
  position:relative;
  padding-left:clamp(56px,8vw,80px);
  padding-bottom:clamp(32px,5vw,48px);
}
.process-step:last-child{padding-bottom:0}
.process-step-num{
  position:absolute;left:0;top:0;
  width:48px;height:48px;
  border-radius:50%;
  background:var(--accent);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-heading);
  font-weight:700;font-size:16px;
  z-index:1;
}
@media(min-width:640px){
  .process-step-num{width:64px;height:64px;font-size:18px;left:0}
  .process-step{padding-left:96px}
  .process-timeline::before{left:31px}
}
.process-step-time{
  font-size:12px;font-weight:600;color:var(--accent);
  text-transform:uppercase;letter-spacing:.08em;
  margin-bottom:4px;
}
.process-step h4{margin-bottom:6px}
.process-step p{font-size:15px;color:var(--ink-soft);line-height:1.6}

/* ---- FAQ ---- */
.faq-list{max-width:760px;margin:0 auto}
.faq-item{
  border-bottom:1px solid var(--line);
}
.faq-item summary{
  display:flex;align-items:center;justify-content:space-between;
  padding:clamp(16px,2.5vw,22px) 0;
  font-family:var(--font-heading);
  font-weight:600;
  font-size:clamp(15px,1.6vw,17px);
  cursor:pointer;
  list-style:none;
  transition:color 240ms var(--ease-out);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::marker{display:none}
.faq-item summary:hover{color:var(--accent)}
.faq-item summary .faq-icon{
  width:24px;height:24px;flex-shrink:0;
  transition:transform 320ms var(--ease);
  color:var(--ink-soft);
}
.faq-item[open] summary .faq-icon{transform:rotate(45deg);color:var(--accent)}
.faq-item .faq-body{
  height:0;
  padding:0 clamp(18px,3vw,28px);
  overflow:hidden;
  transition:height 360ms cubic-bezier(.4,0,.2,1),
             padding-block-end 360ms cubic-bezier(.4,0,.2,1);
}
.faq-item[open] .faq-body{
  height:auto;
  padding-block-end:26px;
}
@media(prefers-reduced-motion:reduce){
  .faq-item .faq-body{transition:none}
}
.faq-body p{
  font-size:15px;color:var(--ink-soft);line-height:1.7;
}

/* ---- STATS ---- */
.stats-row{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:clamp(16px,3vw,32px);
}
@media(min-width:640px){
  .stats-row{grid-template-columns:repeat(4,1fr)}
}
.stat-item{text-align:center}
.stat-num{
  font-family:var(--font-mono);
  font-size:clamp(2rem,4vw,3rem);
  font-weight:700;
  color:var(--accent);
  line-height:1.1;
}
.stat-label{
  font-size:13px;color:var(--ink-soft);
  margin-top:4px;font-weight:500;
}

/* ---- CONTACT CHANNELS ---- */
.contact-channels{
  display:grid;gap:0;
}
.contact-row{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:14px;
  align-items:start;
  padding:clamp(14px,2vw,20px) 0;
  border-bottom:1px solid var(--line);
  transition:transform 240ms var(--ease-out),background 240ms var(--ease-out);
  border-radius:var(--radius-sm);
  padding-left:8px;padding-right:8px;
}
.contact-row:hover{transform:translateX(4px);background:var(--surface)}
.contact-row svg{
  width:20px;height:20px;
  color:var(--ink-soft);
  margin-top:2px;
  transition:color 240ms var(--ease-out),transform 240ms var(--ease-out);
  flex-shrink:0;
}
.contact-row:hover svg{color:var(--accent);transform:scale(1.08)}
.contact-row strong{
  display:block;font-family:var(--font-heading);
  font-weight:600;font-size:14px;color:var(--ink);
  margin-bottom:2px;
}
.contact-row span,.contact-row a{
  font-size:15px;color:var(--ink-soft);
  word-break:break-word;overflow-wrap:anywhere;
}
.contact-row a:hover{color:var(--accent)}

/* ---- CONTACT LAYOUT ---- */
.contact-layout{
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(32px,5vw,64px);
  align-items:start;
}
@media(min-width:768px){
  .contact-layout{grid-template-columns:1fr 1fr}
}

/* ---- FORMS ---- */
.form-grid{
  display:grid;gap:clamp(16px,2vw,20px);
}
@media(min-width:640px){
  .form-grid--2col{grid-template-columns:repeat(2,1fr)}
}
.form-grid .field--full{grid-column:1/-1}
.field{display:flex;flex-direction:column;gap:6px}
.field label{
  font-family:var(--font-heading);
  font-weight:600;font-size:14px;
  color:var(--ink);
}
.field input[type="text"],
.field input[type="email"],
.field input[type="tel"],
.field select,
.field textarea{
  width:100%;
  padding:12px 16px;
  border:1px solid var(--line-strong);
  border-radius:var(--radius-sm);
  font-size:15px;
  background:var(--bg);
  transition:border-color 240ms var(--ease-out),box-shadow 240ms var(--ease-out);
}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--accent-2);
  box-shadow:0 0 0 3px rgba(46,196,160,.15);
  outline:none;
}
.field textarea{min-height:120px;resize:vertical}
.field select{cursor:pointer}

.field-checkbox{
  display:flex;align-items:flex-start;gap:10px;
}
.field input[type="checkbox"]{
  appearance:auto;
  -webkit-appearance:auto;
  width:18px;height:18px;
  min-width:18px;min-height:18px;
  padding:0;border:0;margin:2px 0 0;
  accent-color:var(--accent);
}
.field-checkbox span{font-size:14px;line-height:1.5;color:var(--ink-soft)}
.field-checkbox a{color:var(--accent);text-decoration:underline}

/* ---- TABLE SCROLL ---- */
.table-scroll{
  display:block;width:100%;max-width:100%;min-width:0;
  overflow-x:auto;-webkit-overflow-scrolling:touch;
  margin:18px 0;
  border:1px solid var(--line);
  border-radius:6px;
}
.table-scroll>table{margin:0!important;min-width:480px;width:100%}
:where(*:has(>.table-scroll),*:has(>*>.table-scroll),*:has(>*>*>.table-scroll)){min-width:0}

table{border-collapse:collapse;width:100%}
th,td{
  padding:12px 16px;
  text-align:left;
  border-bottom:1px solid var(--line);
  font-size:14px;
}
th{
  font-family:var(--font-heading);
  font-weight:600;
  background:var(--surface);
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.04em;
}

/* ---- FOOTER ---- */
.site-footer{
  background:var(--ink);
  color:rgba(255,255,255,.7);
  padding:clamp(48px,8vw,80px) 0 0;
}
.footer-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(32px,4vw,48px);
  padding-bottom:clamp(32px,5vw,48px);
}
@media(min-width:640px){
  .footer-grid{grid-template-columns:repeat(2,1fr)}
}
@media(min-width:1024px){
  .footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}
}
.footer-col h5{
  color:#fff;font-family:var(--font-heading);
  font-weight:600;font-size:15px;
  margin-bottom:16px;
}
.footer-about{max-width:320px}
.footer-about .logo{
  margin-bottom:16px;color:#fff;
}
.footer-about p{font-size:14px;line-height:1.6}
.footer-col a{
  display:block;font-size:14px;
  padding:4px 0;
  transition:color 240ms var(--ease-out),transform 240ms var(--ease-out);
}
.footer-col a:hover{color:var(--accent);transform:translateX(4px)}
.footer-contact-item{
  display:flex;align-items:flex-start;gap:8px;
  font-size:14px;margin-bottom:8px;
}
.footer-contact-item svg{
  width:16px;height:16px;flex-shrink:0;margin-top:2px;
  color:var(--accent-2);
}
.footer-contact-item a{display:inline;padding:0}
.footer-bar{
  border-top:1px solid rgba(255,255,255,.1);
  padding:20px 0;
  display:flex;flex-wrap:wrap;
  justify-content:space-between;align-items:center;
  gap:12px;
  font-size:12px;
}
.footer-legal{display:flex;flex-wrap:wrap;gap:16px}
.footer-legal a{padding:0;font-size:12px;display:inline}
.footer-legal a:hover{color:var(--accent)}

/* ---- COOKIE BANNER ---- */
.cookie-banner{
  position:fixed;
  bottom:16px;left:16px;right:16px;
  max-width:520px;margin:0 auto;
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:clamp(20px,3vw,28px);
  box-shadow:var(--shadow-lg);
  transform:translateY(140%);
  opacity:0;
  transition:transform 280ms cubic-bezier(.2,.7,.2,1),opacity 240ms;
  z-index:9999;
}
@media(min-width:768px){
  .cookie-banner{left:24px;right:auto;max-width:420px}
}
.cookie-banner.is-visible{transform:translateY(0);opacity:1}
.cookie-banner h5{
  font-family:var(--font-heading);
  font-weight:700;font-size:15px;
  margin-bottom:8px;
  color:var(--ink);
}
.cookie-banner p{font-size:13px;color:var(--ink-soft);line-height:1.5;margin-bottom:16px}
.cookie-banner p a{color:var(--accent);text-decoration:underline}
.cookie-actions{display:flex;gap:8px;flex-wrap:wrap}
.cookie-actions button{
  padding:10px 20px;border-radius:var(--radius-pill);
  font-size:13px;font-weight:600;
  font-family:var(--font-heading);
  min-height:44px;
  cursor:pointer;
  transition:all 200ms var(--ease-out);
  flex:1;min-width:100px;
  text-align:center;
}
.cookie-actions .cookie-accept{
  background:var(--accent-2);color:#fff;border:2px solid var(--accent-2);
}
.cookie-actions .cookie-accept:hover{background:#26a88a;border-color:#26a88a;color:#fff}
.cookie-actions .cookie-reject{
  background:transparent;color:var(--ink);border:2px solid var(--ink);font-weight:700;
}
.cookie-actions .cookie-reject:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.cookie-actions .cookie-settings{
  background:transparent;color:var(--ink-soft);border:2px solid var(--line);
}
.cookie-actions .cookie-settings:hover{color:var(--ink);background:var(--surface);border-color:var(--line-strong)}

/* ---- REVEAL ---- */
.reveal{
  opacity:0;transform:translateY(24px);
  transition:opacity 700ms cubic-bezier(.16,.8,.24,1),transform 700ms cubic-bezier(.16,.8,.24,1);
}
.reveal.is-in{opacity:1;transform:none}
.reveal[style*="--i"]{
  transition-delay:calc(var(--i,0) * 80ms);
}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none!important}
}
html.no-js .reveal{opacity:1;transform:none}
html.js .reveal:not(.is-in){
  animation:_revealSafety 700ms cubic-bezier(.16,.8,.24,1) both;
  animation-delay:calc(var(--i,0) * 80ms + 600ms);
}
@keyframes _revealSafety{to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){html.js .reveal:not(.is-in){animation:none}}

/* ---- YOGA-SPECIFIC ANIMATIONS ---- */
@keyframes matRoll{
  from{clip-path:inset(0 100% 0 0)}
  to{clip-path:inset(0 0 0 0)}
}
.mat-reveal{
  clip-path:inset(0 100% 0 0);
  transition:clip-path 800ms cubic-bezier(.2,.7,.2,1);
}
.mat-reveal.is-in{clip-path:inset(0 0 0 0)}

@keyframes energyFlow{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}
.energy-border{
  background:linear-gradient(90deg,var(--accent),var(--accent-2),var(--accent));
  background-size:200% 100%;
  animation:energyFlow 6s ease-in-out infinite;
  padding:2px;border-radius:var(--radius);
}
@media(prefers-reduced-motion:reduce){.energy-border{animation:none;background-size:100% 100%}}
.energy-border>*{background:var(--bg);border-radius:calc(var(--radius) - 2px)}

@keyframes mandalaRotate{
  from{transform:rotate(0deg)}
  to{transform:rotate(360deg)}
}
.mandala-deco{
  position:absolute;pointer-events:none;
  width:clamp(80px,12vw,160px);height:clamp(80px,12vw,160px);
  opacity:.04;
  animation:mandalaRotate 30s linear infinite;
}
@media(prefers-reduced-motion:reduce){.mandala-deco{animation:none}}

@keyframes chakraGlow{
  0%,100%{box-shadow:0 0 0 0 rgba(46,196,160,0)}
  50%{box-shadow:0 0 20px 4px rgba(46,196,160,.2)}
}
.chakra-glow:hover{animation:chakraGlow 2s ease-in-out infinite}
@media(prefers-reduced-motion:reduce){.chakra-glow:hover{animation:none}}

@keyframes balanceSway{
  0%,100%{transform:rotate(0deg)}
  25%{transform:rotate(1.5deg)}
  75%{transform:rotate(-1.5deg)}
}

@keyframes btnBreathe{
  0%,100%{box-shadow:0 4px 16px rgba(255,107,90,0)}
  50%{box-shadow:0 4px 28px rgba(255,107,90,.18)}
}
.hero-actions .btn-primary{animation:btnBreathe 4s ease-in-out infinite}
@media(prefers-reduced-motion:reduce){.hero-actions .btn-primary{animation:none}}

.hero-visual-img::after{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:radial-gradient(ellipse at 40% 60%,rgba(46,196,160,.08),transparent 70%);
  pointer-events:none;opacity:0;
  transition:opacity 600ms var(--ease);
}
.hero-visual:hover .hero-visual-img::after{opacity:1}

/* ---- COUNTER UP ---- */
.counter{font-variant-numeric:tabular-nums}

/* ---- PAGE HERO (inner pages) ---- */
.page-hero{
  padding:clamp(48px,8vw,80px) 0 clamp(32px,5vw,48px);
  background:var(--surface);
  text-align:center;
}
.page-hero h1{font-size:clamp(2rem,4vw,3rem);margin-bottom:12px}
.page-hero p{font-size:16px;color:var(--ink-soft);max-width:560px;margin:0 auto}
.breadcrumb{
  display:flex;justify-content:center;gap:8px;
  font-size:13px;color:var(--ink-soft);
  margin-bottom:16px;
}
.breadcrumb a{color:var(--accent)}
.breadcrumb span{color:var(--ink-soft)}

/* ---- CONTENT PAGES ---- */
.content-page{
  padding:clamp(40px,6vw,80px) 0;
  max-width:820px;
  margin:0 auto;
}
.content-page h2{font-size:clamp(1.4rem,2.5vw,1.8rem);margin:clamp(28px,4vw,40px) 0 12px}
.content-page h3{font-size:clamp(1.1rem,1.8vw,1.3rem);margin:24px 0 8px}
.content-page p{margin-bottom:16px;color:var(--ink-soft);line-height:1.7}
.content-page ul{margin-bottom:16px;padding-left:20px}
.content-page ul li{
  position:relative;padding-left:16px;margin-bottom:8px;
  font-size:15px;color:var(--ink-soft);line-height:1.6;
}
.content-page ul li::before{
  content:'';position:absolute;left:0;top:10px;
  width:6px;height:6px;border-radius:50%;
  background:var(--accent-2);
}

/* ---- THANK YOU PAGE ---- */
.thank-you{
  min-height:calc(100vh - var(--header-h) - 200px);
  display:flex;align-items:center;justify-content:center;
  text-align:center;
  padding:80px 16px;
}
.thank-you-content{max-width:480px}
.thank-you svg{
  width:80px;height:80px;
  color:var(--accent-2);
  margin-bottom:24px;
}
.thank-you h1{font-size:clamp(1.8rem,3vw,2.4rem);margin-bottom:12px}
.thank-you p{font-size:16px;color:var(--ink-soft);margin-bottom:32px;line-height:1.6}

/* ---- 404 PAGE ---- */
.error-page{
  min-height:calc(100vh - var(--header-h) - 200px);
  display:flex;align-items:center;justify-content:center;
  text-align:center;
  padding:80px 16px;
}
.error-page h1{
  font-size:clamp(6rem,15vw,10rem);
  font-weight:700;color:var(--accent);
  line-height:1;margin-bottom:16px;
}
.error-page p{font-size:18px;color:var(--ink-soft);margin-bottom:32px}

/* ---- TEAM PAGE ---- */
.team-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(32px,5vw,48px);
}
.team-member{
  display:grid;
  grid-template-columns:1fr;
  gap:clamp(24px,3vw,40px);
  align-items:start;
}
@media(min-width:768px){
  .team-member{grid-template-columns:240px 1fr}
  .team-member:nth-child(even){direction:rtl}
  .team-member:nth-child(even)>*{direction:ltr}
}
.team-photo{
  aspect-ratio:3/4;border-radius:var(--radius);
  overflow:hidden;
}
.team-photo img{width:100%;height:100%;object-fit:cover}
.team-info h3{margin-bottom:4px}
.team-info .team-role{
  font-size:14px;color:var(--accent);font-weight:600;
  margin-bottom:12px;display:block;
}
.team-info p{font-size:15px;color:var(--ink-soft);line-height:1.7}

/* ---- DIVIDER ---- */
.section-divider{
  height:2px;
  background:linear-gradient(90deg,transparent,var(--accent-2),var(--accent),var(--accent-2),transparent);
  background-size:200% 100%;
  border:none;
  margin:0;
  animation:energyFlow 8s ease-in-out infinite;
}
@media(prefers-reduced-motion:reduce){.section-divider{animation:none;background-size:100% 100%}}

/* ---- MANIFESTO QUOTE ---- */
.manifesto{
  text-align:center;
  padding:clamp(60px,10vw,100px) 0;
}
.manifesto blockquote{
  font-family:var(--font-heading);
  font-size:clamp(1.6rem,3.5vw,2.8rem);
  font-weight:600;
  font-style:italic;
  line-height:1.3;
  color:var(--ink);
  max-width:800px;
  margin:0 auto;
}
.manifesto cite{
  display:block;margin-top:16px;
  font-size:14px;color:var(--ink-soft);
  font-style:normal;font-weight:400;
  font-family:var(--font-body);
}

/* ---- RESPONSIVE ---- */
@media(max-width:1024px){
  .hero-container{grid-template-columns:1fr}
  .hero-visual{order:-1}
}
@media(max-width:768px){
  :root{--header-h:64px}
  .instructors-grid{grid-template-columns:repeat(2,1fr)}
  .membership-grid{grid-template-columns:1fr}
  .class-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  .class-grid{grid-template-columns:1fr}
  .instructors-grid{grid-template-columns:repeat(2,1fr)}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .filter-bar{gap:6px}
  .filter-btn{font-size:12px;padding:5px 12px}
}
@media(max-width:430px){
  h1{font-size:clamp(28px,8vw,42px)}
  .hero-pills .pill{font-size:11px;padding:4px 10px}
  .plan-card{padding:20px}
  .testimonial-card{padding:20px}
  .process-step{padding-left:56px}
}

/* ---- YOGA HOVER MICRO-EFFECTS ---- */
.process-step-num{
  transition:transform 360ms var(--ease),box-shadow 360ms var(--ease);
}
.process-step:hover .process-step-num{
  transform:scale(1.1);
  box-shadow:0 0 20px rgba(255,107,90,.3),0 0 40px -8px rgba(46,196,160,.15);
}
.faq-item summary:hover .faq-icon{color:var(--accent);transform:scale(1.1)}

@keyframes subtlePulse{
  0%,100%{box-shadow:0 0 0 0 rgba(46,196,160,0)}
  50%{box-shadow:0 0 12px 2px rgba(46,196,160,.12)}
}
.plan-card--featured{animation:subtlePulse 4s ease-in-out infinite}
@media(prefers-reduced-motion:reduce){.plan-card--featured{animation:none}}

@media(max-width:640px){
  .cookie-banner{bottom:0;left:0;right:0;max-width:100%;padding:clamp(16px,3vw,20px);border-radius:var(--radius) var(--radius) 0 0}
  .cookie-actions{flex-wrap:nowrap}
  .cookie-actions button{min-width:0;padding:10px 14px}
}

/* ---- SCROLL PROGRESS ---- */
.scroll-progress{
  position:absolute;bottom:0;left:0;height:2px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  width:0;z-index:1;
  transition:none;
  pointer-events:none;
}

/* ---- DRAWER CLOSE ---- */

/* ---- PRINT ---- */
@media print{
  .site-header,.drawer,.drawer-backdrop,.cookie-banner,.nav-toggle,.skip-link{display:none!important}
  main{padding-top:0}
  .reveal{opacity:1!important;transform:none!important}
  body{font-size:12pt;color:#000}
  a{text-decoration:underline}
  .section{padding:24pt 0}
}
