@import url("https://fonts.googleapis.com/css2?family=Anton&family=Inter:wght@400;500;600;700;800&display=swap");

:root {
  --background: oklch(0.14 0.02 260);
  --foreground: oklch(0.98 0.005 260);
  --surface: oklch(0.18 0.025 260);
  --surface-elevated: oklch(0.22 0.03 260);
  --muted: oklch(0.7 0.02 260);
  --border: oklch(0.28 0.03 260);
  --brand: oklch(0.55 0.24 260);
  --flame: oklch(0.62 0.24 25);
  --gradient-flame: linear-gradient(135deg, oklch(0.62 0.24 25), oklch(0.7 0.22 35));
  --gradient-hero: linear-gradient(180deg, oklch(0.1 0.02 260 / 0.65), oklch(0.1 0.02 260 / 0.88) 62%, oklch(0.1 0.02 260));
  --gradient-glow: radial-gradient(circle at 50% 0%, oklch(0.55 0.24 260 / 0.25), transparent 60%);
  --shadow-flame: 0 14px 40px -10px oklch(0.62 0.24 25 / 0.55);
  --shadow-elevated: 0 30px 80px -30px oklch(0 0 0 / 0.6);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--background); color: var(--foreground); font-family: Inter, system-ui, sans-serif; -webkit-font-smoothing: antialiased; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
p { color: var(--muted); line-height: 1.7; }
h1, h2, h3 { margin: 0; font-family: Anton, Impact, sans-serif; font-weight: 400; letter-spacing: 0.01em; line-height: 0.95; }
h1 { font-size: clamp(4rem, 11vw, 7.5rem); }
h2 { font-size: clamp(2.6rem, 6vw, 5.5rem); }
h3 { font-size: 2rem; }
h1 span, h2 span, h3 span { color: var(--brand); }

.container { width: min(1200px, calc(100% - 2.5rem)); margin-inline: auto; }
.section { padding-block: clamp(4rem, 10vw, 7rem); }
.surface { background: var(--surface); }
.hidden { display: none !important; }
.eyebrow { margin: 0 0 1rem; color: var(--brand); font-size: 0.75rem; font-weight: 800; letter-spacing: 0.4em; text-transform: uppercase; }
.line { display: flex; align-items: center; gap: 0.75rem; color: var(--muted); }
.line::before { content: ""; width: 2.5rem; height: 1px; background: var(--brand); }

.site-header { position: sticky; top: 0; z-index: 50; border-bottom: 1px solid color-mix(in oklch, var(--border), transparent 35%); background: oklch(0.14 0.02 260 / 0.8); backdrop-filter: blur(18px); }
.nav-wrap { min-height: 5rem; display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; }
.brand-mark { display: inline-flex; align-items: center; gap: 0.75rem; }
.brand-mark img { width: 3rem; height: 3rem; object-fit: contain; }
.brand-mark strong { display: block; font-family: Anton, Impact, sans-serif; font-size: 1.25rem; letter-spacing: 0.05em; }
.brand-mark small { display: block; color: var(--muted); font-size: 0.7rem; letter-spacing: 0.25em; text-transform: uppercase; }
.desktop-nav { display: flex; align-items: center; gap: 2rem; font-size: 0.9rem; font-weight: 700; }
.desktop-nav a { color: color-mix(in oklch, var(--foreground), transparent 20%); }
.desktop-nav a:hover, .desktop-nav .active { color: var(--brand); }
.nav-cta, .mobile-cta, .btn-flame { background: var(--gradient-flame); box-shadow: var(--shadow-flame); color: white; }
.nav-cta, .mobile-cta { border-radius: 0.5rem; padding: 0.8rem 1.25rem; font-size: 0.8rem; font-weight: 900; letter-spacing: 0.12em; text-transform: uppercase; }
.menu-toggle { display: none; width: 2.75rem; height: 2.75rem; border: 0; background: transparent; padding: 0.65rem; }
.menu-toggle span { display: block; height: 2px; margin: 0.35rem 0; background: var(--foreground); }
.mobile-nav { display: none; padding: 0 1.25rem 1.25rem; border-top: 1px solid var(--border); background: var(--background); }
.mobile-nav a { display: block; padding: 0.75rem 0; font-weight: 700; }
.mobile-nav.open { display: block; }

.hero { position: relative; isolation: isolate; overflow: hidden; }
.hero-bg, .hero-shade { position: absolute; inset: 0; width: 100%; height: 100%; }
.hero-bg { z-index: -3; object-fit: cover; transform: scale(1.1); }
.hero-shade { z-index: -2; background: var(--gradient-hero), var(--gradient-glow); }
.hero-content { position: relative; padding-block: clamp(5rem, 12vw, 10rem); }
.hero h1 { max-width: 62rem; }
.hero-copy { max-width: 36rem; margin-top: 2rem; font-size: 1.125rem; color: color-mix(in oklch, var(--foreground), transparent 20%); }
.hero-logo { position: absolute; right: 2rem; bottom: 2rem; width: 12rem; filter: drop-shadow(0 24px 35px oklch(0 0 0 / 0.45)); }
.grain::before { content: ""; position: absolute; inset: 0; pointer-events: none; background-image: radial-gradient(oklch(1 0 0 / 0.04) 1px, transparent 1px); background-size: 4px 4px; mix-blend-mode: overlay; }
.trust-strip { border-block: 1px solid color-mix(in oklch, var(--border), transparent 35%); background: oklch(0.14 0.02 260 / 0.6); backdrop-filter: blur(14px); }
.trust-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; padding-block: 1.25rem; font-size: 0.9rem; }
.trust-grid p { margin: 0; color: var(--muted); }
.trust-grid span { color: var(--flame); }

.button-row { display: flex; flex-wrap: wrap; align-items: center; gap: 1rem; margin-top: 2.25rem; }
.button-row.center { justify-content: center; }
.btn { display: inline-flex; align-items: center; justify-content: center; border-radius: 0.5rem; padding: 1rem 1.75rem; border: 1px solid transparent; font-size: 0.85rem; font-weight: 900; letter-spacing: 0.18em; text-transform: uppercase; }
.btn-ghost { border-color: var(--border); background: oklch(0.14 0.02 260 / 0.35); backdrop-filter: blur(10px); }
.btn-ghost:hover { border-color: var(--brand); }

.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(3rem, 7vw, 5rem); align-items: center; }
.image-stack { position: relative; }
.image-stack img:first-child { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; border-radius: 1rem; border: 1px solid var(--border); box-shadow: var(--shadow-elevated); }
.image-stack img:last-child { position: absolute; width: 60%; right: -1.5rem; bottom: -3rem; aspect-ratio: 4 / 3; object-fit: cover; border-radius: 1rem; border: 4px solid var(--background); box-shadow: var(--shadow-elevated); }
.mini-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; margin-top: 2rem; }
.mini-grid article, .reason-grid article, .review-grid figure, .schedule-grid article, .stats-grid article { border: 1px solid var(--border); border-radius: 1rem; background: var(--surface); }
.mini-grid article { padding: 1rem; }
.mini-grid strong { display: block; color: var(--brand); font-family: Anton, Impact, sans-serif; font-size: 1.3rem; font-weight: 400; }
.mini-grid small, figcaption small { display: block; color: var(--muted); }

.section-head { max-width: 42rem; margin-bottom: 3.5rem; }
.center-head { max-width: 48rem; margin-inline: auto; text-align: center; }
.program-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.program-card { position: relative; overflow: hidden; border: 1px solid var(--border); border-radius: 1rem; background: var(--surface); box-shadow: var(--shadow-elevated); transition: 0.4s ease; }
.program-card:hover { transform: translateY(-0.25rem); border-color: var(--brand); }
.program-card img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; transition: 0.6s ease; }
.program-card:hover img { transform: scale(1.06); }
.program-card span { position: absolute; top: 1rem; left: 1rem; border: 1px solid var(--border); border-radius: 999px; background: oklch(0.14 0.02 260 / 0.82); padding: 0.35rem 0.65rem; font-size: 0.62rem; font-weight: 900; letter-spacing: 0.2em; text-transform: uppercase; }
.program-card h3, .program-card p, .program-card ul, .program-card a { margin-inline: 1.5rem; }
.program-card h3 { margin-top: 1.5rem; }
.program-card ul { padding: 0; list-style: none; color: var(--foreground); line-height: 1.8; }
.program-card li::before { content: "▸"; color: var(--brand); margin-right: 0.5rem; }
.program-card a { display: inline-block; margin-bottom: 1.5rem; color: var(--brand); font-size: 0.8rem; font-weight: 900; letter-spacing: 0.12em; text-transform: uppercase; }

.gallery-section { overflow: hidden; }
.marquee { position: relative; overflow: hidden; }
.marquee::before, .marquee::after { content: ""; position: absolute; top: 0; bottom: 0; z-index: 2; width: 8rem; pointer-events: none; }
.marquee::before { left: 0; background: linear-gradient(90deg, var(--background), transparent); }
.marquee::after { right: 0; background: linear-gradient(270deg, var(--background), transparent); }
.marquee-track { display: flex; gap: 1rem; width: max-content; animation: marquee 40s linear infinite; }
.marquee img { width: 24rem; height: 18rem; object-fit: cover; border-radius: 1rem; border: 1px solid var(--border); }
@keyframes marquee { to { transform: translateX(-50%); } }

.reason-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.reason-grid article { background: var(--background); padding: 1.75rem; }
.reason-grid b { display: block; font-family: Anton, Impact, sans-serif; font-size: 1.6rem; font-weight: 400; }
.reason-grid article::before { content: ""; display: block; width: 3rem; height: 3rem; margin-bottom: 1.25rem; border: 1px solid var(--border); border-radius: 0.75rem; background: var(--surface); }
.review-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.25rem; margin-top: 3rem; }
.review-grid figure { margin: 0; padding: 1.75rem; background: var(--background); }
.review-grid figure > div { color: var(--flame); letter-spacing: 0.1em; }
blockquote { margin: 1rem 0; font-size: 1.1rem; line-height: 1.7; }

.schedule-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 0.75rem; }
.schedule-grid article { padding: 1rem; }
.schedule-grid h3 { color: var(--brand); text-align: center; font-size: 1.65rem; }
.tag { margin: 0.65rem 0 0; border: 1px solid var(--border); border-radius: 0.65rem; padding: 0.75rem; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 0.75rem; color: color-mix(in oklch, var(--foreground), transparent 20%); }
.tag b { font-family: Inter, system-ui, sans-serif; font-size: 0.9rem; color: var(--foreground); }
.tag.brand { border-color: color-mix(in oklch, var(--brand), transparent 55%); background: color-mix(in oklch, var(--brand), transparent 86%); }
.tag.flame { border-color: color-mix(in oklch, var(--flame), transparent 55%); background: color-mix(in oklch, var(--flame), transparent 86%); }
.tag.muted { background: var(--surface-elevated); }

.faq-layout { display: grid; grid-template-columns: 1fr 2fr; gap: 4rem; }
.faq-list { border: 1px solid var(--border); border-radius: 1rem; overflow: hidden; background: var(--surface); }
details + details { border-top: 1px solid var(--border); }
summary { cursor: pointer; padding: 1.35rem; font-weight: 800; list-style: none; }
summary::-webkit-details-marker { display: none; }
details p { margin: 0; padding: 0 1.35rem 1.35rem; }

.cta-band, .page-hero, .page-glow { position: relative; overflow: hidden; background: var(--gradient-glow); }
.page-hero { padding-block: clamp(5rem, 11vw, 8rem); }
.cta-band { text-align: center; }
.cta-band > img { position: absolute; inset: 0; z-index: -2; width: 100%; height: 100%; object-fit: cover; }
.cta-band::before { content: ""; position: absolute; inset: 0; z-index: -1; background: oklch(0.14 0.02 260 / 0.88); }
.cta-content { padding-block: clamp(4rem, 10vw, 7rem); }
.cta-content p { max-width: 38rem; margin-inline: auto; }
.stats-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.stats-grid article { padding: 2.5rem; text-align: center; background: var(--background); }
.stats-grid strong { display: block; color: var(--brand); font-family: Anton, Impact, sans-serif; font-size: 4rem; font-weight: 400; }
.stats-grid span { color: var(--muted); font-size: 0.8rem; font-weight: 800; letter-spacing: 0.25em; text-transform: uppercase; }

.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: start; }
.contact-list { padding: 0; margin-top: 2rem; list-style: none; line-height: 2.4; }
.trial-form { border: 1px solid var(--border); border-radius: 1rem; background: var(--surface); padding: clamp(1.5rem, 4vw, 2rem); box-shadow: var(--shadow-elevated); }
.trial-form label, .trial-form legend { display: block; margin-top: 1rem; color: var(--muted); font-size: 0.75rem; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; }
.trial-form input:not([type="radio"]) { width: 100%; margin-top: 0.5rem; border: 1px solid var(--border); border-radius: 0.65rem; background: var(--background); color: var(--foreground); padding: 0.9rem 1rem; }
.trial-form fieldset { margin: 1rem 0 0; padding: 0; border: 0; }
.choice-row { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.5rem; }
.choice-row label { display: flex; align-items: center; justify-content: center; gap: 0.5rem; border: 1px solid var(--border); border-radius: 0.65rem; background: var(--background); padding: 0.8rem; color: var(--foreground); letter-spacing: 0; text-transform: capitalize; }
.trial-form small { display: block; margin-block: 1rem; color: var(--muted); line-height: 1.5; }
.trial-form button { width: 100%; border: 0; cursor: pointer; }
.form-success { padding-block: 3rem; text-align: center; }
.form-success h2 { color: var(--brand); }

.site-footer { border-top: 1px solid var(--border); background: var(--surface); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 3rem; padding-block: 4rem; }
.footer-grid a:not(.brand-mark) { display: block; margin: 0.65rem 0; color: var(--muted); }
.footer-grid a:hover { color: var(--brand); }
.footer-grid h4 { color: var(--muted); font-size: 0.8rem; letter-spacing: 0.25em; text-transform: uppercase; }
.socials { display: flex; gap: 0.75rem; margin-top: 1.5rem; }
.socials a { border: 1px solid var(--border); border-radius: 999px; padding: 0.65rem 0.9rem; }
.footer-bottom { border-top: 1px solid var(--border); }
.footer-bottom .container { display: flex; justify-content: space-between; gap: 1rem; padding-block: 1.25rem; font-size: 0.75rem; }
.footer-bottom p { margin: 0; }

@media (max-width: 950px) {
  .desktop-nav, .nav-cta, .hero-logo { display: none; }
  .menu-toggle { display: block; }
  .split, .contact-grid, .faq-layout, .footer-grid { grid-template-columns: 1fr; }
  .program-grid, .reason-grid, .stats-grid { grid-template-columns: 1fr; }
  .schedule-grid { grid-template-columns: repeat(2, 1fr); }
  .trust-grid, .review-grid { grid-template-columns: 1fr; text-align: center; }
  .image-stack img:last-child { display: none; }
}

@media (max-width: 560px) {
  .container { width: min(100% - 1.5rem, 1200px); }
  h1 { font-size: clamp(3.4rem, 17vw, 5rem); }
  .mini-grid, .schedule-grid { grid-template-columns: 1fr; }
  .marquee img { width: 18rem; height: 13rem; }
  .footer-bottom .container { flex-direction: column; text-align: center; }
}

.align-start { align-items: start; }
.content-card { border: 1px solid var(--border); border-radius: 1rem; background: var(--background); padding: clamp(1.5rem, 4vw, 2rem); }
.content-card.elevated { background: var(--surface); box-shadow: var(--shadow-elevated); }
.content-card h3 { color: var(--brand); font-size: 2rem; }
.check-list { margin: 1.25rem 0 0; padding: 0; list-style: none; color: var(--foreground); line-height: 1.9; }
.check-list li { position: relative; padding-left: 1.5rem; }
.check-list li::before { content: ""; position: absolute; left: 0; top: 0.72rem; width: 0.5rem; height: 0.5rem; border-radius: 999px; background: var(--brand); box-shadow: 0 0 24px color-mix(in oklch, var(--brand), transparent 20%); }
.benefit-grid article::before { background: linear-gradient(135deg, var(--surface), color-mix(in oklch, var(--brand), transparent 80%)); }
.section-note { max-width: 42rem; margin: 2rem auto 0; color: var(--foreground); font-size: 1.2rem; text-align: center; }
.reviews-layout { display: grid; grid-template-columns: minmax(0, 1fr) minmax(18rem, 0.85fr); gap: clamp(2rem, 6vw, 5rem); align-items: center; }
.feature-quote { margin: 2rem 0 0; border-left: 4px solid var(--flame); padding-left: 1.25rem; color: var(--foreground); font-size: clamp(1.5rem, 3vw, 2.5rem); font-family: Anton, Impact, sans-serif; line-height: 1.1; }
.review-embed-placeholder { min-height: 20rem; display: grid; place-items: center; align-content: center; gap: 0.75rem; border: 1px dashed color-mix(in oklch, var(--brand), transparent 35%); border-radius: 1.25rem; background: linear-gradient(135deg, var(--background), color-mix(in oklch, var(--brand), transparent 90%)); box-shadow: var(--shadow-elevated); text-align: center; }
.review-embed-placeholder .stars { color: var(--flame); letter-spacing: 0.15em; }
.review-embed-placeholder h3 { color: var(--foreground); }
.review-embed-placeholder p { margin: 0; }

@media (max-width: 950px) {
  .reviews-layout { grid-template-columns: 1fr; }
}

@media (min-width: 951px) {
  .four-up { grid-template-columns: repeat(4, 1fr); }
}

.nav-dropdown { position: relative; display: inline-flex; align-items: center; }
.nav-dropdown > .nav-link { color: color-mix(in oklch, var(--foreground), transparent 20%); }
.nav-dropdown > .nav-link::after { content: ""; display: inline-block; width: 0.35rem; height: 0.35rem; margin-left: 0.45rem; border-right: 2px solid currentColor; border-bottom: 2px solid currentColor; transform: translateY(-0.15rem) rotate(45deg); }
.nav-dropdown:hover > .nav-link, .nav-dropdown:focus-within > .nav-link { color: var(--brand); }
.nav-dropdown-menu { position: absolute; top: calc(100% + 0.9rem); left: 50%; z-index: 80; min-width: 14rem; padding: 0.6rem; border: 1px solid var(--border); border-radius: 0.9rem; background: color-mix(in oklch, var(--surface), black 6%); box-shadow: var(--shadow-elevated); opacity: 0; pointer-events: none; transform: translate(-50%, -0.4rem); transition: opacity 180ms ease, transform 180ms ease; }
.nav-dropdown-menu::before { content: ""; position: absolute; left: 0; right: 0; top: -1rem; height: 1rem; }
.nav-dropdown:hover .nav-dropdown-menu, .nav-dropdown:focus-within .nav-dropdown-menu { opacity: 1; pointer-events: auto; transform: translate(-50%, 0); }
.nav-dropdown-menu a { display: block; border-radius: 0.6rem; padding: 0.75rem 0.85rem; color: color-mix(in oklch, var(--foreground), transparent 18%); white-space: nowrap; }
.nav-dropdown-menu a:hover, .nav-dropdown-menu a:focus { background: color-mix(in oklch, var(--brand), transparent 88%); color: var(--foreground); }
.programs-home-grid { margin-top: clamp(2rem, 6vw, 4rem); }

@media (max-width: 950px) {
  .nav-dropdown { display: none; }
}
