/* ==========================================================================
   Yogameister Yoga Academy
   Design system + components
   ========================================================================== */

:root{
  /* Palette */
  --cream:      #FAF6EC;
  --cream-2:    #F3ECDB;
  --paper:      #FFFFFF;
  --forest:     #1E2A22;
  --forest-2:   #16201A;
  --ink:        #20281F;
  --text:       #50584C;
  --muted:      #828A7C;
  --gold:       #C6A14C;
  --gold-2:     #B0883A;
  --gold-soft:  #EBDFC2;
  --line:       rgba(30,42,34,.12);
  --line-soft:  rgba(30,42,34,.07);

  /* Type */
  --serif: "Cormorant Garamond", Georgia, serif;
  --display: "Poppins", "Segoe UI", system-ui, sans-serif;
  --body: "Inter", "Segoe UI", system-ui, sans-serif;

  /* Layout */
  --container: 1180px;
  --radius: 18px;
  --radius-lg: 28px;
  --pad-section: clamp(4rem, 8vw, 7rem);
  --shadow-card: 0 24px 60px -34px rgba(30,42,34,.4);
  --shadow-soft: 0 14px 40px -28px rgba(30,42,34,.35);
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--body);
  color:var(--text);
  background:var(--cream);
  line-height:1.7;
  font-size:1rem;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,video{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4{ margin:0; color:var(--ink); font-family:var(--display); font-weight:700; line-height:1.12; letter-spacing:-.01em; }
p{ margin:0; }
ul{ margin:0; padding:0; list-style:none; }

/* ---------- Layout helpers ---------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:clamp(1.25rem,4vw,2.5rem); }
.section{ padding-block:var(--pad-section); }
.section--tight{ padding-block:clamp(3rem,6vw,4.5rem); }
.bg-cream2{ background:var(--cream-2); }
.bg-paper{ background:var(--paper); }
.center{ text-align:center; }

/* ---------- Eyebrow + section heads ---------- */
.eyebrow{
  font-family:var(--body);
  font-weight:600;
  font-size:.74rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold-2);
  margin:0 0 .9rem;
}
.section-head{ max-width:640px; margin-inline:auto; margin-bottom:clamp(2.2rem,4vw,3.2rem); }
.section-head h2{ font-size:clamp(1.85rem,3.6vw,2.8rem); }
.section-head p{ margin-top:1rem; color:var(--text); font-size:1.06rem; }
.center .eyebrow{ margin-inline:auto; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  font-family:var(--display); font-weight:600; font-size:.95rem;
  padding:.95rem 1.9rem; border-radius:999px; border:1.6px solid transparent;
  transition:transform .25s ease, background .25s ease, box-shadow .25s ease, color .25s ease;
  white-space:nowrap;
}
.btn:active{ transform:translateY(1px); }
.btn--gold{ background:var(--gold); color:#23301F; box-shadow:0 14px 30px -16px rgba(176,136,58,.8); }
.btn--gold:hover{ background:var(--gold-2); color:#fff; transform:translateY(-2px); }
.btn--ghost{ border-color:var(--ink); color:var(--ink); background:transparent; }
.btn--ghost:hover{ background:var(--ink); color:var(--cream); transform:translateY(-2px); }
.btn--light{ border-color:rgba(250,246,236,.6); color:var(--cream); background:transparent; }
.btn--light:hover{ background:var(--cream); color:var(--ink); transform:translateY(-2px); }
.btn--block{ width:100%; }

/* ==========================================================================
   Header / Nav
   ========================================================================== */
.site-header{
  position:sticky; top:0; z-index:60;
  background:rgba(250,246,236,.86);
  backdrop-filter:saturate(120%) blur(10px);
  border-bottom:1px solid transparent;
  transition:border-color .3s ease, box-shadow .3s ease, background .3s ease;
}
.site-header.is-scrolled{ border-bottom-color:var(--line); box-shadow:0 10px 30px -26px rgba(30,42,34,.5); }
.nav{ display:flex; align-items:center; gap:2rem; height:78px; }
.nav__links{ display:flex; align-items:center; gap:1.9rem; margin-left:auto; }
.nav__link{
  font-family:var(--display); font-weight:500; font-size:.95rem; color:var(--ink);
  position:relative; padding:.4rem 0; transition:color .2s ease;
}
.nav__link::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px; height:2px;
  background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform .25s ease;
}
.nav__link:hover{ color:var(--gold-2); }
.nav__link:hover::after,
.nav__link[aria-current="page"]::after{ transform:scaleX(1); }
.nav__link[aria-current="page"]{ color:var(--ink); }
.nav__cta{ margin-left:.4rem; }
.nav__toggle{
  display:none; margin-left:auto; width:46px; height:46px; border:1px solid var(--line);
  border-radius:12px; background:var(--paper); align-items:center; justify-content:center;
}
.nav__toggle span, .nav__toggle span::before, .nav__toggle span::after{
  content:""; display:block; width:20px; height:2px; background:var(--ink); border-radius:2px;
  transition:transform .3s ease, opacity .3s ease; position:relative;
}
.nav__toggle span::before{ position:absolute; top:-6px; }
.nav__toggle span::after{ position:absolute; top:6px; }
body.nav-open .nav__toggle span{ background:transparent; }
body.nav-open .nav__toggle span::before{ transform:translateY(6px) rotate(45deg); }
body.nav-open .nav__toggle span::after{ transform:translateY(-6px) rotate(-45deg); }

/* Brand lockup */
.brand{ display:flex; align-items:center; gap:.7rem; }
.brand .emblem{ width:46px; height:46px; flex:none; color:var(--forest); }
.brand .emblem .gold{ fill:var(--gold); }
.wordmark{ display:flex; flex-direction:column; line-height:1; }
.wordmark__name{
  font-family:var(--serif); font-weight:600; font-size:1.42rem; letter-spacing:.13em;
  color:var(--ink);
}
.wordmark__sub{
  font-family:var(--body); font-weight:600; font-size:.56rem; letter-spacing:.34em;
  text-transform:uppercase; color:var(--gold-2); margin-top:.28rem;
}

/* Mobile menu panel */
.mobile-menu{
  display:none; position:fixed; inset:78px 0 auto 0; z-index:55;
  background:var(--cream); border-bottom:1px solid var(--line);
  box-shadow:0 30px 50px -30px rgba(30,42,34,.5);
  padding:1.2rem clamp(1.25rem,4vw,2.5rem) 1.8rem;
}
body.nav-open .mobile-menu{ display:block; animation:menuDrop .3s ease; }
.mobile-menu a{
  display:block; font-family:var(--display); font-weight:500; font-size:1.1rem; color:var(--ink);
  padding:.85rem .25rem; border-bottom:1px solid var(--line-soft);
}
.mobile-menu a[aria-current="page"]{ color:var(--gold-2); }
.mobile-menu .btn{ margin-top:1.2rem; }
@keyframes menuDrop{ from{ opacity:0; transform:translateY(-10px);} to{ opacity:1; transform:none;} }

/* ==========================================================================
   Hero (video)
   ========================================================================== */
.hero{ position:relative; isolation:isolate; overflow:hidden; }
.hero__media{ position:absolute; inset:0; z-index:-2; }
.hero__media video, .hero__media img{
  width:100%; height:100%; object-fit:cover; object-position:center 40%;
}
.hero__overlay{
  position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(180deg, rgba(22,32,26,.62) 0%, rgba(22,32,26,.5) 45%, rgba(22,32,26,.78) 100%);
}
.hero__inner{ position:relative; color:var(--cream); text-align:center; }
.hero--home .hero__inner{ padding-block:clamp(6rem,15vh,10rem); }
.hero--page .hero__inner{ padding-block:clamp(4.5rem,11vh,7rem); }
.hero .eyebrow{ color:var(--gold); }
.hero h1{
  color:#fff; font-size:clamp(2.5rem,6.2vw,4.4rem); line-height:1.04;
  text-shadow:0 2px 30px rgba(0,0,0,.3); max-width:14ch; margin-inline:auto;
}
.hero--page h1{ font-size:clamp(2.2rem,5.2vw,3.6rem); max-width:18ch; }
.hero__lead{
  margin:1.4rem auto 0; max-width:54ch; font-size:clamp(1rem,1.6vw,1.18rem);
  color:rgba(250,246,236,.92);
}
.hero__actions{ margin-top:2.1rem; display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* Gold ticker strip under home hero */
.ticker{ background:var(--forest-2); color:var(--gold); }
.ticker__row{
  display:flex; align-items:center; justify-content:center; gap:1.4rem; flex-wrap:wrap;
  padding:1.05rem 1rem; font-family:var(--display); font-weight:500; font-size:.82rem;
  letter-spacing:.2em; text-transform:uppercase;
}
.ticker__row span.dot{ width:5px; height:5px; border-radius:50%; background:var(--gold); opacity:.7; }

/* ==========================================================================
   Split (image + text)
   ========================================================================== */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.split--reverse .split__media{ order:2; }
.split__media{ position:relative; }
.split__media img{ border-radius:var(--radius-lg); box-shadow:var(--shadow-card); width:100%; }
.split__media--frame::after{
  content:""; position:absolute; inset:18px -18px -18px 18px; border:1.5px solid var(--gold);
  border-radius:var(--radius-lg); z-index:-1;
}
.split__body h2{ font-size:clamp(1.8rem,3.4vw,2.6rem); }
.split__body p{ margin-top:1.1rem; color:var(--text); }
.split__body .btn{ margin-top:1.8rem; }

/* Checklist */
.checklist{ margin-top:1.6rem; display:grid; gap:.9rem; }
.checklist li{ display:flex; align-items:flex-start; gap:.8rem; color:var(--ink); font-weight:500; }
.checklist .tick{
  flex:none; width:26px; height:26px; border-radius:50%; background:var(--forest); color:var(--gold);
  display:grid; place-items:center; font-size:.8rem; margin-top:1px;
}

/* Numbered reasons list */
.reasons{ display:grid; gap:1.4rem; margin-top:1.6rem; }
.reasons li{ display:flex; gap:1.1rem; }
.reasons .num{
  font-family:var(--display); font-weight:700; color:var(--gold); font-size:.95rem;
  border:1.5px solid var(--gold-soft); border-radius:10px; width:40px; height:40px;
  display:grid; place-items:center; flex:none;
}
.reasons h4{ font-size:1.02rem; }
.reasons p{ margin-top:.25rem; font-size:.96rem; }

/* ==========================================================================
   Cards
   ========================================================================== */
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; }
.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.6rem; }

.card{
  background:var(--paper); border-radius:var(--radius); box-shadow:var(--shadow-soft);
  overflow:hidden; transition:transform .3s ease, box-shadow .3s ease;
}
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-card); }

.class-card .class-card__img{ aspect-ratio:16/11; overflow:hidden; }
.class-card .class-card__img img{ width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.class-card:hover .class-card__img img{ transform:scale(1.06); }
.class-card__body{ padding:1.6rem 1.5rem 1.8rem; }
.class-card__body h3{ font-size:1.2rem; }
.class-card__body p{ margin-top:.7rem; color:var(--text); font-size:.96rem; }

/* Feature card (icon) */
.feature-card{ background:var(--paper); border-radius:var(--radius); padding:1.7rem 1.5rem; box-shadow:var(--shadow-soft); transition:transform .3s ease, box-shadow .3s ease; }
.feature-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow-card); }
.feature-card .chip{
  width:48px; height:48px; border-radius:14px; background:var(--gold-soft); color:var(--gold-2);
  display:grid; place-items:center; margin-bottom:1.1rem;
}
.feature-card .chip svg{ width:22px; height:22px; }
.feature-card h3{ font-size:1.1rem; }
.feature-card p{ margin-top:.55rem; font-size:.95rem; color:var(--text); }

/* ==========================================================================
   Timetable
   ========================================================================== */
.timetable{ max-width:860px; margin-inline:auto; background:var(--paper); border-radius:var(--radius); box-shadow:var(--shadow-soft); overflow:hidden; }
.timetable__row{
  display:grid; grid-template-columns:1fr 2fr auto; gap:1rem; align-items:center;
  padding:1.15rem clamp(1.2rem,3vw,2rem); border-bottom:1px solid var(--line-soft);
}
.timetable__row:last-child{ border-bottom:0; }
.timetable__row:nth-child(odd){ background:rgba(243,236,219,.4); }
.timetable__day{ font-family:var(--display); font-weight:600; color:var(--ink); }
.timetable__class{ color:var(--text); }
.timetable__time{ font-family:var(--display); font-weight:600; color:var(--gold-2); white-space:nowrap; }

/* ==========================================================================
   Steps (journey to the mat)
   ========================================================================== */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; position:relative; }
.step{ text-align:center; padding:0 .5rem; }
.step__num{
  width:58px; height:58px; border-radius:50%; margin:0 auto 1.1rem;
  display:grid; place-items:center; font-family:var(--display); font-weight:700; font-size:1.25rem;
  color:var(--forest); background:var(--gold-soft); border:1.5px solid var(--gold);
}
.step h3{ font-size:1.12rem; }
.step p{ margin-top:.5rem; color:var(--text); font-size:.95rem; }

/* ==========================================================================
   Stats band
   ========================================================================== */
.stats{ background:var(--forest); color:var(--cream); }
.stats__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; text-align:center; padding-block:clamp(2.4rem,5vw,3.4rem); }
.stats__num{ font-family:var(--display); font-weight:700; font-size:clamp(2.4rem,5vw,3.4rem); color:#fff; line-height:1; }
.stats__label{ margin-top:.6rem; font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); }
.stats__divider{ width:1px; }

/* ==========================================================================
   Pricing
   ========================================================================== */
.pricing{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; align-items:stretch; }
.price{
  background:var(--paper); border-radius:var(--radius); padding:2rem 1.7rem 2rem; box-shadow:var(--shadow-soft);
  border:1.5px solid var(--line-soft); display:flex; flex-direction:column;
}
.price--feature{ background:var(--forest); color:var(--cream); border-color:var(--forest); transform:scale(1.03); box-shadow:var(--shadow-card); }
.price__tag{ font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); font-weight:700; margin-bottom:.9rem; }
.price__name{ font-family:var(--display); font-weight:600; font-size:1.15rem; color:var(--ink); }
.price--feature .price__name{ color:#fff; }
.price__cost{ display:flex; align-items:baseline; gap:.4rem; margin:.4rem 0 1.3rem; }
.price__cost .amount{ font-family:var(--display); font-weight:700; font-size:2.7rem; color:var(--ink); line-height:1; }
.price--feature .price__cost .amount{ color:#fff; }
.price__cost .per{ color:var(--muted); font-size:.92rem; }
.price--feature .price__cost .per{ color:rgba(250,246,236,.7); }
.price__list{ display:grid; gap:.7rem; margin-bottom:1.7rem; }
.price__list li{ display:flex; gap:.6rem; align-items:flex-start; font-size:.94rem; color:var(--text); }
.price--feature .price__list li{ color:rgba(250,246,236,.9); }
.price__list .tick{ color:var(--gold-2); flex:none; margin-top:.15rem; }
.price--feature .price__list .tick{ color:var(--gold); }
.price .btn{ margin-top:auto; }
.pricing__note{ text-align:center; margin-top:1.6rem; color:var(--muted); font-size:.9rem; }
.pricing__note a{ color:var(--gold-2); text-decoration:underline; text-underline-offset:3px; }

/* ==========================================================================
   Testimonials
   ========================================================================== */
.quotes{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; }
.quote{ background:var(--paper); border-radius:var(--radius); padding:1.8rem 1.6rem; box-shadow:var(--shadow-soft); }
.quote__stars{ color:var(--gold); letter-spacing:.15em; font-size:.95rem; margin-bottom:.9rem; }
.quote__text{ color:var(--text); font-size:.98rem; }
.quote__who{ margin-top:1.2rem; }
.quote__who strong{ color:var(--ink); font-family:var(--display); font-weight:600; display:block; font-size:.95rem; }
.quote__who span{ color:var(--muted); font-size:.82rem; }

/* Big single testimonial (about) */
.testimonial{ max-width:760px; margin-inline:auto; text-align:center; }
.testimonial__mark{ font-family:var(--serif); font-size:4rem; color:var(--gold); line-height:.4; }
.testimonial__text{ font-family:var(--display); font-weight:500; font-size:clamp(1.15rem,2.4vw,1.5rem); color:var(--ink); line-height:1.5; margin-top:1rem; }
.testimonial__stars{ color:var(--gold); letter-spacing:.2em; margin-top:1.4rem; }
.testimonial__who{ margin-top:.8rem; }
.testimonial__who strong{ display:block; font-family:var(--display); font-weight:600; color:var(--ink); }
.testimonial__who span{ color:var(--muted); font-size:.85rem; }

/* ==========================================================================
   FAQ accordion
   ========================================================================== */
.faq{ max-width:780px; margin-inline:auto; display:grid; gap:.9rem; }
.faq__item{ background:var(--paper); border-radius:14px; box-shadow:var(--shadow-soft); overflow:hidden; }
.faq__q{
  width:100%; text-align:left; background:none; border:0; padding:1.25rem 1.4rem;
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
  font-family:var(--display); font-weight:600; font-size:1.02rem; color:var(--ink);
}
.faq__icon{ flex:none; width:24px; height:24px; position:relative; transition:transform .3s ease; }
.faq__icon::before,.faq__icon::after{ content:""; position:absolute; background:var(--gold-2); border-radius:2px; }
.faq__icon::before{ top:11px; left:4px; right:4px; height:2px; }
.faq__icon::after{ left:11px; top:4px; bottom:4px; width:2px; transition:transform .3s ease; }
.faq__item.is-open .faq__icon::after{ transform:rotate(90deg); opacity:0; }
.faq__a{ padding:0 1.4rem; max-height:0; overflow:hidden; transition:max-height .35s ease, padding .35s ease; }
.faq__a p{ color:var(--text); padding-bottom:1.3rem; }
.faq__item.is-open .faq__a{ max-height:320px; }

/* ==========================================================================
   Dark CTA band
   ========================================================================== */
.cta-band{ position:relative; isolation:isolate; overflow:hidden; color:var(--cream); text-align:center; }
.cta-band__bg{ position:absolute; inset:0; z-index:-2; }
.cta-band__bg img{ width:100%; height:100%; object-fit:cover; }
.cta-band::after{ content:""; position:absolute; inset:0; z-index:-1; background:linear-gradient(180deg, rgba(22,32,26,.86), rgba(22,32,26,.92)); }
.cta-band .eyebrow{ color:var(--gold); }
.cta-band h2{ color:#fff; font-size:clamp(1.9rem,4vw,2.9rem); max-width:18ch; margin-inline:auto; }
.cta-band p{ margin:1.1rem auto 0; max-width:54ch; color:rgba(250,246,236,.86); }
.cta-band .btn{ margin-top:1.9rem; }

/* ==========================================================================
   Newsletter
   ========================================================================== */
.newsletter{ text-align:center; }
.newsletter h2{ font-size:clamp(1.7rem,3.4vw,2.5rem); }
.newsletter p{ margin:1rem auto 0; max-width:46ch; color:var(--text); }
.newsletter__form{ margin:1.8rem auto 0; max-width:480px; display:flex; gap:.7rem; }
.newsletter__form input{
  flex:1; padding:.95rem 1.2rem; border-radius:999px; border:1.5px solid var(--line);
  background:var(--paper); font-family:var(--body); font-size:.95rem; color:var(--ink);
}
.newsletter__form input:focus{ outline:2px solid var(--gold); outline-offset:1px; border-color:var(--gold); }

/* ==========================================================================
   Contact
   ========================================================================== */
.contact-grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(2rem,5vw,4rem); align-items:start; }
.contact-info h2{ font-size:clamp(1.9rem,3.6vw,2.6rem); }
.contact-info > p{ margin-top:1rem; color:var(--text); max-width:42ch; }
.contact-list{ margin-top:2rem; display:grid; gap:1.4rem; }
.contact-list li{ display:flex; gap:1rem; align-items:flex-start; }
.contact-list .ic{
  flex:none; width:48px; height:48px; border-radius:14px; background:var(--gold-soft); color:var(--gold-2);
  display:grid; place-items:center;
}
.contact-list .ic svg{ width:21px; height:21px; }
.contact-list .lbl{ font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); font-weight:600; }
.contact-list .val{ color:var(--ink); font-weight:500; font-size:1.02rem; margin-top:.2rem; }
.contact-list a.val:hover{ color:var(--gold-2); }

.form-card{ background:var(--paper); border-radius:var(--radius-lg); padding:clamp(1.8rem,3vw,2.6rem); box-shadow:var(--shadow-card); }
.form-card h3{ font-size:1.4rem; }
.form-card > p{ color:var(--muted); margin-top:.4rem; font-size:.95rem; }
.field{ margin-top:1.3rem; }
.field label{ display:block; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); font-weight:600; margin-bottom:.5rem; }
.field input, .field textarea{
  width:100%; padding:.95rem 1.1rem; border-radius:12px; border:1.5px solid var(--line);
  background:var(--cream); font-family:var(--body); font-size:.98rem; color:var(--ink); resize:vertical;
}
.field input:focus, .field textarea:focus{ outline:2px solid var(--gold); outline-offset:1px; border-color:var(--gold); background:#fff; }
.form-card .btn{ margin-top:1.6rem; }
.form-note{ margin-top:1rem; font-size:.82rem; color:var(--muted); text-align:center; }
.hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer{ background:var(--forest-2); color:rgba(250,246,236,.78); padding-top:clamp(3.2rem,6vw,4.5rem); }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:2.5rem; }
.site-footer .brand .emblem{ color:var(--cream); }
.site-footer .brand .wordmark__name{ color:#fff; }
.site-footer .brand .wordmark__sub{ color:var(--gold); }
.footer-about{ margin-top:1.2rem; max-width:34ch; font-size:.95rem; line-height:1.7; }
.footer-col h4{ font-family:var(--body); font-weight:600; font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-bottom:1.1rem; }
.footer-col ul{ display:grid; gap:.7rem; }
.footer-col a, .footer-col li{ color:rgba(250,246,236,.78); font-size:.95rem; }
.footer-col a:hover{ color:#fff; }
.footer-bottom{ margin-top:clamp(2.5rem,5vw,3.5rem); border-top:1px solid rgba(250,246,236,.12); padding-block:1.6rem; display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.footer-bottom small{ color:rgba(250,246,236,.55); font-size:.82rem; }
.footer-social{ width:38px; height:38px; border-radius:50%; border:1px solid rgba(250,246,236,.25); display:grid; place-items:center; color:var(--cream); transition:background .25s ease, color .25s ease; }
.footer-social:hover{ background:var(--gold); color:var(--forest-2); border-color:var(--gold); }

/* ==========================================================================
   Gallery (Mark's journey)
   ========================================================================== */
.gallery{ display:grid; grid-template-columns:repeat(3,1fr); grid-auto-rows:clamp(150px,21vw,235px); gap:1rem; max-width:1000px; margin-inline:auto; }
.gallery__item{ border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-soft); }
.gallery__item img{ width:100%; height:100%; object-fit:cover; transition:transform .7s ease; }
.gallery__item:hover img{ transform:scale(1.06); }
.gallery__item--wide{ grid-column:span 2; }
@media (max-width:760px){
  .gallery{ grid-template-columns:repeat(2,1fr); }
  .gallery__item--wide{ grid-column:span 2; }
}
@media (max-width:460px){
  .gallery{ grid-template-columns:1fr; grid-auto-rows:200px; }
  .gallery__item--wide{ grid-column:span 1; }
}

/* ==========================================================================
   Floating WhatsApp
   ========================================================================== */
.wa-float{
  position:fixed; right:clamp(1rem,3vw,1.7rem); bottom:clamp(1rem,3vw,1.7rem); z-index:80;
  width:60px; height:60px; border-radius:50%; background:#25D366; color:#fff;
  display:grid; place-items:center; box-shadow:0 16px 34px -10px rgba(37,211,102,.6);
  transition:transform .25s ease, box-shadow .25s ease;
}
.wa-float svg{ width:32px; height:32px; }
.wa-float:hover{ transform:scale(1.08); box-shadow:0 20px 40px -10px rgba(37,211,102,.7); }
.wa-float::after{
  content:""; position:absolute; inset:0; border-radius:50%; background:#25D366; z-index:-1;
  animation:waPulse 2.4s ease-out infinite;
}
@keyframes waPulse{ 0%{ transform:scale(1); opacity:.55;} 70%{ transform:scale(1.7); opacity:0;} 100%{ opacity:0;} }
.wa-tip{
  position:absolute; right:72px; top:50%; transform:translateY(-50%); white-space:nowrap;
  background:var(--forest); color:var(--cream); font-size:.82rem; font-weight:500;
  padding:.5rem .85rem; border-radius:10px; opacity:0; pointer-events:none; transition:opacity .25s ease;
  font-family:var(--display);
}
.wa-float:hover .wa-tip{ opacity:1; }

/* ==========================================================================
   Reveal on scroll
   ========================================================================== */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s ease; }
.reveal.is-visible{ opacity:1; transform:none; }
.reveal[data-delay="1"]{ transition-delay:.08s; }
.reveal[data-delay="2"]{ transition-delay:.16s; }
.reveal[data-delay="3"]{ transition-delay:.24s; }

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width:980px){
  .grid-3, .quotes, .pricing, .steps{ grid-template-columns:1fr 1fr; }
  .reasons{ grid-template-columns:1fr; }
}
@media (max-width:860px){
  .nav__links, .nav__cta.desktop-only{ display:none; }
  .nav__toggle{ display:flex; }
  .split{ grid-template-columns:1fr; }
  .split--reverse .split__media{ order:0; }
  .split__media--frame::after{ inset:14px -10px -10px 10px; }
  .contact-grid{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .footer-about{ grid-column:1 / -1; }
  .price--feature{ transform:none; }
}
@media (max-width:620px){
  .grid-3, .grid-2, .quotes, .pricing, .steps{ grid-template-columns:1fr; }
  .stats__grid{ grid-template-columns:1fr; gap:1.8rem; }
  .timetable__row{ grid-template-columns:1fr auto; }
  .timetable__class{ grid-column:1 / -1; order:3; font-size:.92rem; }
  .newsletter__form{ flex-direction:column; }
  .newsletter__form .btn{ width:100%; }
  .footer-grid{ grid-template-columns:1fr; }
  .hero__actions{ flex-direction:column; }
  .hero__actions .btn{ width:100%; }
  .wa-float{ width:54px; height:54px; }
  .wa-float svg{ width:28px; height:28px; }
}

/* ==========================================================================
   Accessibility
   ========================================================================== */
:focus-visible{ outline:2.5px solid var(--gold-2); outline-offset:3px; border-radius:4px; }
.skip-link{ position:absolute; left:-999px; top:0; background:var(--forest); color:var(--cream); padding:.7rem 1.1rem; z-index:200; border-radius:0 0 10px 0; }
.skip-link:focus{ left:0; }

@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
  .wa-float::after{ display:none; }
}
