:root{
  --red:#e63329;
  --red-dark:#b8231b;
  --red-deep:#7a1610;
  --ink:#0e0e10;
  --ink-2:#1a1a1d;
  --paper:#fafafa;
  --muted:#6b6b70;
  --line:#ececec;
  --radius:14px;
  --shadow:0 12px 40px -18px rgba(0,0,0,.35);
  --max:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* NAV */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 40px;
  background:rgba(14,14,16,.6);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  color:#fff;
  transition:background .3s, padding .3s;
}
.nav.scrolled{background:rgba(14,14,16,.92);padding:12px 40px}
.brand{display:flex;flex-direction:column;line-height:1}
.brand-mark{font-family:'Anton',sans-serif;font-size:24px;letter-spacing:1.5px}
.brand-sub{font-size:9px;letter-spacing:3px;opacity:.7;margin-top:2px}
.nav-links{display:flex;gap:32px;align-items:center;font-size:14px;font-weight:500}
.nav-links a{opacity:.85;transition:opacity .2s}
.nav-links a:hover{opacity:1}
.cta-mini{
  background:var(--red);padding:9px 18px;border-radius:50px;opacity:1!important;
  font-weight:600;transition:transform .2s, background .2s;
}
.cta-mini:hover{background:var(--red-dark);transform:translateY(-2px)}
.hamburger{display:none;background:none;border:0;flex-direction:column;gap:5px;cursor:pointer}
.hamburger span{width:24px;height:2px;background:#fff;display:block}

/* HERO */
.hero{
  position:relative;min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  color:#fff;text-align:center;overflow:hidden;
  padding:120px 24px 80px;
}
.hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:brightness(.7) saturate(1.1);
  animation:slowZoom 20s ease-in-out infinite alternate;
}
@keyframes slowZoom{from{transform:scale(1)}to{transform:scale(1.08)}}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(14,14,16,.4) 0%,rgba(230,51,41,.25) 60%,rgba(14,14,16,.85) 100%);
}
.hero-content{position:relative;z-index:2;max-width:900px}
.rating-pill{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.12);backdrop-filter:blur(10px);
  padding:8px 18px;border-radius:50px;font-size:13px;
  border:1px solid rgba(255,255,255,.2);margin-bottom:30px;
}
.rating-pill .g{
  background:#fff;color:#4285F4;font-weight:700;
  width:22px;height:22px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;font-size:13px;
}
.hero h1{
  font-family:'Anton',sans-serif;
  font-size:clamp(48px,9vw,120px);
  line-height:.95;letter-spacing:-1px;
  text-transform:uppercase;
  margin-bottom:24px;
  text-shadow:0 4px 30px rgba(0,0,0,.4);
}
.tagline{
  font-family:'Caveat',cursive;
  font-size:clamp(22px,3vw,32px);
  margin-bottom:40px;opacity:.95;
}
.hero-ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:50px}
.btn{
  display:inline-block;padding:15px 32px;border-radius:50px;
  font-weight:600;font-size:15px;cursor:pointer;border:0;
  transition:transform .2s, box-shadow .2s, background .2s;
}
.btn-primary{background:var(--red);color:#fff;box-shadow:0 10px 30px -10px rgba(230,51,41,.6)}
.btn-primary:hover{background:var(--red-dark);transform:translateY(-2px);box-shadow:0 15px 35px -10px rgba(230,51,41,.8)}
.btn-ghost{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.3)}
.btn-ghost:hover{background:rgba(255,255,255,.2)}
.btn-outline{border:2px solid var(--red);color:var(--red);background:transparent}
.btn-outline:hover{background:var(--red);color:#fff}
.btn-block{width:100%;display:block;margin-top:10px}
.location{font-size:11px;letter-spacing:6px;opacity:.7}
.scroll-indicator{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:2;
  width:24px;height:40px;border:2px solid rgba(255,255,255,.4);border-radius:12px;
}
.scroll-indicator span{
  display:block;width:3px;height:8px;background:#fff;
  margin:6px auto;border-radius:3px;animation:scroll 1.8s infinite;
}
@keyframes scroll{0%{transform:translateY(0);opacity:1}100%{transform:translateY(14px);opacity:0}}

/* STATS */
.stats{
  background:var(--ink);color:#fff;
  display:grid;grid-template-columns:repeat(4,1fr);
  padding:60px 40px;gap:20px;text-align:center;
}
.stat .num{font-family:'Anton',sans-serif;font-size:clamp(40px,5vw,64px);color:var(--red);line-height:1}
.stat .lbl{font-size:12px;letter-spacing:2px;text-transform:uppercase;opacity:.7;margin-top:8px}

/* SECTIONS */
.section{padding:100px 40px;max-width:var(--max);margin:0 auto}
.section.dark{
  max-width:none;background:var(--ink);color:#fff;
  padding:100px 40px;
}
.section.dark > *{max-width:var(--max);margin-left:auto;margin-right:auto}
.section-head{text-align:center;margin-bottom:60px;max-width:700px;margin-left:auto;margin-right:auto}
.kicker{
  display:inline-block;font-size:11px;letter-spacing:4px;
  color:var(--red);font-weight:700;text-transform:uppercase;margin-bottom:14px;
}
.kicker.light{color:#ff6b62}
.section-head h2{
  font-family:'Anton',sans-serif;
  font-size:clamp(36px,5vw,60px);
  line-height:1;text-transform:uppercase;letter-spacing:-.5px;margin-bottom:18px;
}
.section-head p{color:var(--muted);font-size:17px}
.section.dark .section-head p{color:rgba(255,255,255,.7)}

/* PROGRAMS */
.programs{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.program{
  position:relative;padding:36px 28px;border-radius:var(--radius);
  background:#fff;border:1px solid var(--line);
  transition:transform .3s, box-shadow .3s, border-color .3s;
}
.program:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--red)}
.program.featured{background:var(--red);color:#fff;border-color:var(--red)}
.program.featured .program-tag{color:#fff}
.program-tag{font-size:11px;letter-spacing:2px;font-weight:700;color:var(--red);text-transform:uppercase;margin-bottom:18px;display:flex;align-items:center;gap:8px}
.program-age{font-family:'Anton',sans-serif;font-size:80px;line-height:.9;margin-bottom:14px}
.program p{font-size:14px;opacity:.85}
.new-pill{background:#fff;color:var(--red);font-size:9px;padding:3px 7px;border-radius:50px;letter-spacing:1px}
.program.new .new-pill{background:var(--red);color:#fff}
.note{margin-top:32px;text-align:center;color:var(--muted);font-size:14px}

/* OFFERS */
.offers{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.offer{
  padding:32px 26px;border-radius:var(--radius);
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  transition:transform .3s, background .3s, border-color .3s;
}
.offer:hover{transform:translateY(-4px);background:rgba(230,51,41,.1);border-color:var(--red)}
.offer .ico{font-size:32px;margin-bottom:16px}
.offer h3{font-size:17px;margin-bottom:8px;font-weight:700}
.offer p{font-size:14px;opacity:.7}

/* PILLARS */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.pillar{
  padding:40px 30px;border-radius:var(--radius);
  background:linear-gradient(135deg,#fff 0%,#fafafa 100%);
  border:1px solid var(--line);position:relative;overflow:hidden;
  transition:transform .3s;
}
.pillar:hover{transform:translateY(-6px)}
.pillar::before{
  content:'';position:absolute;top:0;left:0;width:4px;height:100%;background:var(--red);
}
.pillar-num{font-family:'Anton',sans-serif;font-size:48px;color:var(--red);opacity:.25;line-height:1;margin-bottom:14px}
.pillar h3{font-size:20px;margin-bottom:10px}
.pillar p{color:var(--muted);font-size:14px}

/* SCHEDULE */
.schedule-table{
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
}
.schedule-table .row{
  display:grid;grid-template-columns:80px 1.2fr 1.5fr 1.2fr 2.5fr;
  padding:18px 24px;border-bottom:1px solid var(--line);font-size:14px;align-items:center;
}
.schedule-table .row:last-child{border-bottom:0}
.schedule-table .row.head{background:var(--ink);color:#fff;font-size:11px;letter-spacing:2px;text-transform:uppercase;font-weight:700}
.schedule-table .row:not(.head):hover{background:#fff5f4}

/* PRICING */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.price-card{
  background:#fff;color:var(--ink);
  border-radius:var(--radius);padding:40px 30px;text-align:center;
  position:relative;transition:transform .3s, box-shadow .3s;
}
.price-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.price-card.highlight{
  background:linear-gradient(160deg,var(--red) 0%,var(--red-deep) 100%);
  color:#fff;transform:scale(1.04);
}
.price-card.highlight:hover{transform:scale(1.04) translateY(-6px)}
.badge{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--ink);color:#fff;font-size:10px;letter-spacing:2px;
  padding:6px 14px;border-radius:50px;font-weight:700;
}
.new-badge{background:#22c55e}
.price-card .age{font-size:13px;letter-spacing:3px;text-transform:uppercase;font-weight:700;margin-bottom:18px;opacity:.7}
.price-card.highlight .age{opacity:.9}
.price{font-family:'Anton',sans-serif;font-size:56px;line-height:1}
.price span{font-size:16px;font-family:'Inter',sans-serif;opacity:.7}
.meta{font-size:13px;margin:14px 0 28px;opacity:.7}
.price-card.highlight .btn-primary{background:#fff;color:var(--red)}
.price-card.highlight .btn-primary:hover{background:#fff;transform:translateY(-2px)}

/* EXTRAS */
.extras{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.extra{
  padding:30px;border-radius:var(--radius);background:#fff;
  border-left:3px solid var(--red);
  transition:transform .3s, box-shadow .3s;
}
.extra:hover{transform:translateX(6px);box-shadow:var(--shadow)}
.extra h3{font-size:18px;margin-bottom:8px}
.extra p{color:var(--muted);font-size:14px}

/* GALLERY */
.gallery-masonry {
  column-count: 3;
  column-gap: 20px;
}
.gallery-item {
  break-inside: avoid;
  margin-bottom: 20px;
  border-radius: var(--radius);
  overflow: hidden;
  transition: transform .3s;
  border: 1px solid var(--line);
  background: #eee;
}
.gallery-item:hover {
  transform: scale(1.02);
  box-shadow: var(--shadow);
}
.gallery-item img {
  width: 100%;
  height: auto;
  display: block;
}
@media (max-width: 900px) {
  .gallery-masonry {
    column-count: 2;
  }
}
@media (max-width: 600px) {
  .gallery-masonry {
    column-count: 1;
  }
}

.footnote{text-align:center;font-size:12px;color:var(--muted);margin-top:30px;opacity:.7}
.section.dark .footnote{color:rgba(255,255,255,.5)}

/* CTA */
.cta-section{
  background:linear-gradient(160deg,var(--red) 0%,var(--red-deep) 100%);
  color:#fff;padding:100px 40px;
  position:relative;overflow:hidden;
}
.cta-section::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle at 20% 30%,rgba(255,255,255,.1) 0%,transparent 40%),radial-gradient(circle at 80% 70%,rgba(0,0,0,.2) 0%,transparent 40%);
}
.cta-inner{max-width:560px;margin:0 auto;position:relative;z-index:2;text-align:center}
.cta-inner h2{
  font-family:'Anton',sans-serif;
  font-size:clamp(40px,6vw,72px);line-height:1;
  text-transform:uppercase;margin-bottom:18px;
}
.lead{font-size:17px;margin-bottom:40px;opacity:.95}

.demo-form{
  background:#fff;color:var(--ink);
  padding:40px;border-radius:var(--radius);
  text-align:left;box-shadow:0 30px 80px -20px rgba(0,0,0,.4);
}
.field{margin-bottom:18px}
.field label{display:block;font-size:11px;letter-spacing:2px;text-transform:uppercase;font-weight:700;margin-bottom:8px;color:var(--muted)}
.field input,.field select{
  width:100%;padding:14px 16px;border:1px solid var(--line);
  border-radius:10px;font-size:15px;font-family:inherit;
  transition:border-color .2s, box-shadow .2s;background:#fafafa;
}
.field input:focus,.field select:focus{
  outline:0;border-color:var(--red);box-shadow:0 0 0 3px rgba(230,51,41,.12);background:#fff;
}
.form-status{margin-top:14px;text-align:center;font-size:14px;font-weight:600;color:#16a34a;min-height:20px}
.see-you{margin-top:40px;font-family:'Caveat',cursive;font-size:26px;opacity:.95}
.ig-link{
  display:inline-block;margin-top:14px;
  background:rgba(0,0,0,.2);padding:10px 22px;border-radius:50px;
  font-size:14px;font-weight:600;transition:background .2s;
}
.ig-link:hover{background:rgba(0,0,0,.4)}

/* FOOTER */
footer{
  background:var(--ink);color:#fff;
  padding:40px;display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:14px;
}
.foot-brand{font-family:'Anton',sans-serif;font-size:22px;letter-spacing:2px}
.foot-brand span{font-family:'Inter',sans-serif;font-size:11px;letter-spacing:3px;opacity:.6;margin-left:6px}
.foot-meta{font-size:12px;letter-spacing:2px;opacity:.6;text-transform:uppercase}

/* Reveal animation */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s, transform .8s}
.reveal.in{opacity:1;transform:none}

/* RESPONSIVE */
@media (max-width:900px){
  .nav{padding:14px 20px}
  .nav-links{
    position:fixed;top:0;right:-100%;width:80%;height:100vh;
    background:var(--ink);flex-direction:column;justify-content:center;
    transition:right .3s;gap:24px;
  }
  .nav-links.open{right:0}
  .hamburger{display:flex}
  .stats{grid-template-columns:repeat(2,1fr);gap:30px}
  .programs,.offers,.pillars,.pricing,.extras{grid-template-columns:1fr}
  .price-card.highlight{transform:none}
  .price-card.highlight:hover{transform:translateY(-6px)}
  .schedule-table .row{grid-template-columns:1fr 1fr;gap:6px 14px;font-size:13px}
  .schedule-table .row.head{display:none}
  .schedule-table .row > div::before{
    content:attr(data-l);display:block;font-size:10px;letter-spacing:1.5px;
    text-transform:uppercase;color:var(--muted);font-weight:700;
  }
  .section{padding:70px 20px}
  .section.dark,.cta-section{padding:70px 20px}
  .demo-form{padding:28px}
}
