@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@300;400;500&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
img{max-width:100%;height:auto;display:block}

:root{
  --white:#FFFFFF;
  --chalk:#E5E3DC;
  --beige:#C4BEA8;
  --mid-black:#2B2C2E;
  --black:#0A0A0A;
  --bg:#0A0A0A;
  --bg2:#111112;
  --bg3:#1A1A1B;
  --border:rgba(255,255,255,0.07);
  --font-head:'Space Grotesk',sans-serif;
  --font-body:'Inter',sans-serif;
  --ease:0.3s ease;
}

body{font-family:var(--font-body);background:var(--bg);color:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--font-head);font-weight:700;line-height:1.05;letter-spacing:-0.025em}

.container{max-width:1160px;margin:0 auto;padding:0 24px}
section{padding:96px 0}

/* Reveal animations */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:none}

/* ── Navigation ── */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px 0;transition:background var(--ease),padding var(--ease)}
.nav.scrolled{background:rgba(10,10,10,.97);backdrop-filter:blur(14px);padding:14px 0;border-bottom:1px solid var(--border)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.nav__logo img{height:28px;width:auto}
.nav__logo-text{font-family:var(--font-head);font-size:22px;font-weight:700;letter-spacing:-.03em;color:var(--white);text-decoration:none}
.nav__links{display:flex;gap:32px;list-style:none}
.nav__links a{font-family:var(--font-head);font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--chalk);text-decoration:none;transition:color var(--ease)}
.nav__links a:hover{color:var(--white)}
.nav__mobile-cta{display:none}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 28px;font-family:var(--font-head);font-size:14px;font-weight:600;letter-spacing:.03em;text-decoration:none;border-radius:3px;transition:all var(--ease);cursor:pointer;border:none;white-space:nowrap}
.btn-primary{background:var(--white);color:var(--black)}
.btn-primary:hover{background:var(--chalk);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--white);border:1.5px solid rgba(255,255,255,.3)}
.btn-outline:hover{border-color:var(--white);background:rgba(255,255,255,.05)}
.btn-dark{background:var(--black);color:var(--white)}
.btn-dark:hover{background:var(--mid-black);transform:translateY(-2px)}
.btn-lg{padding:16px 40px;font-size:15px}

/* ── Hero ── */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media video,.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center center}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(105deg,rgba(10,10,10,.88) 40%,rgba(10,10,10,.5));z-index:1}
.hero__content{position:relative;z-index:2;max-width:680px}
.hero__eyebrow{font-family:var(--font-head);font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--beige);margin-bottom:20px}
.hero__title{font-size:clamp(52px,9vw,104px);font-weight:700;line-height:.92;letter-spacing:-.035em;margin-bottom:24px}
.hero__desc{font-size:clamp(16px,2vw,18px);color:var(--chalk);max-width:500px;line-height:1.65;margin-bottom:36px}
.hero__actions{display:flex;gap:12px;flex-wrap:wrap}
.hero__scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--beige);font-size:10px;letter-spacing:.18em;text-transform:uppercase}
.hero__line{width:1px;height:40px;background:var(--beige);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.2}}

/* ── Section labels ── */
.label{font-family:var(--font-head);font-size:11px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--beige);margin-bottom:14px;display:block}
.section-title{font-size:clamp(34px,5vw,62px);margin-bottom:20px}
.section-desc{font-size:clamp(15px,1.8vw,17px);color:var(--chalk);line-height:1.7;max-width:540px}

/* ── Values grid ── */
.values{background:var(--bg2)}
.grid-6{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:56px}
.vcard{background:var(--bg2);padding:40px 32px;position:relative;overflow:hidden;transition:background var(--ease)}
.vcard:hover{background:var(--bg3)}
.vcard__num{font-family:var(--font-head);font-size:72px;font-weight:700;color:rgba(255,255,255,.04);position:absolute;top:16px;right:16px;line-height:1;pointer-events:none}
.vcard h3{font-size:18px;margin-bottom:10px}
.vcard p{font-size:14px;color:var(--chalk);line-height:1.65}

/* ── Photo callout ── */
.photo-callout{position:relative;height:680px;overflow:hidden}
.photo-callout img{width:100%;height:100%;object-fit:cover;object-position:center 30%}
.photo-callout__overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(10,10,10,.82) 35%,rgba(10,10,10,.2))}
.photo-callout__content{position:absolute;inset:0;display:flex;align-items:center}

/* ── Programs ── */
.programs{background:var(--bg)}
.grid-progs{display:grid;grid-template-columns:repeat(2,1fr);gap:40px;margin-top:56px}
.pcard--full{background:var(--bg);transition:background var(--ease);overflow:hidden}
.pcard--full:hover{background:var(--bg3)}
.pcard__img-wrap{position:relative;overflow:hidden}
.pcard__img-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(10,10,10,.6))}
.pcard__body{padding:28px}
.pcard__tag{display:inline-block;font-family:var(--font-head);font-size:10px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--beige);border:1px solid rgba(196,190,168,.3);padding:4px 10px;border-radius:2px;margin-bottom:18px}
.pcard__days{font-size:11px;color:rgba(196,190,168,.6);letter-spacing:.08em;margin-top:16px;font-family:var(--font-head);text-transform:uppercase}
.pcard--full h3{font-size:21px;margin-bottom:10px}
.pcard--full p{font-size:14px;color:var(--chalk);line-height:1.65}
.pcard__img-wrap img{transition:transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);will-change:transform}
.pcard--full:hover .pcard__img-wrap img{transform:scale(1.06)}

/* ── Video section ── */
.video-section{background:var(--bg2);border-top:1px solid var(--border);padding:96px 0}
.video-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.video-embed{position:relative;border-radius:8px;overflow:hidden;border:1px solid var(--border)}
.video-embed iframe{display:block;width:100%;aspect-ratio:9/16;border:none}

/* ── Steps ── */
.steps{background:var(--bg2);border-top:1px solid var(--border)}
.grid-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;margin-top:56px}
.step__num{font-family:var(--font-head);font-size:12px;font-weight:600;letter-spacing:.12em;color:var(--beige);margin-bottom:16px}
.step h3{font-size:18px;margin-bottom:10px}
.step p{font-size:14px;color:var(--chalk);line-height:1.65}

/* ── Timetable List ── */
.timetable-list{display:flex;flex-direction:column;max-width:800px;margin:0 auto}
.tt-item{display:flex;align-items:flex-start;padding:32px 0;border-bottom:1px solid var(--border)}
.tt-item:first-child{border-top:1px solid var(--border)}
.tt-day{width:110px;font-family:var(--font-head);font-size:24px;font-weight:700;letter-spacing:.05em}
.tt-details{flex:1;display:flex;flex-direction:column;gap:10px}
.tt-times{font-size:14px;color:var(--chalk);font-family:var(--font-head);letter-spacing:.05em;line-height:1.6;font-weight:500;}
.tt-programs{font-family:var(--font-head);font-size:15px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--white)}

/* ── For you ── */
.for-you{background:var(--bg)}
.fy-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.fy-photo{border-radius:6px;overflow:hidden;height:480px}
.fy-photo img{width:100%;height:100%;object-fit:cover;object-position:center 20%}
.fylist{list-style:none;display:flex;flex-direction:column;gap:16px;margin-top:36px}
.fylist li{display:flex;align-items:flex-start;gap:14px;font-size:16px;color:var(--chalk);line-height:1.5}
.fylist li::before{content:'';width:8px;height:8px;min-width:8px;border-radius:50%;background:var(--beige);margin-top:7px;flex-shrink:0}

/* ── Social Proof Marquee ── */
.social-proof{background:var(--bg3);padding:64px 0;overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.marquee{display:flex;gap:40px;width:max-content;animation:scroll 30s linear infinite}
.marquee:hover{animation-play-state:paused}
.review-item{display:flex;flex-direction:column;gap:12px;width:340px;background:var(--bg);padding:28px;border-radius:4px;border:1px solid var(--border)}
.stars{color:#FFD700;font-size:14px;letter-spacing:3px}
.review-item p{font-size:14px;color:var(--chalk);line-height:1.6;font-style:italic}
.review-author{font-family:var(--font-head);font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--beige)}
@keyframes scroll{to{transform:translateX(calc(-50% - 20px))}}

/* ── Location ── */
.location{background:var(--bg2);border-top:1px solid var(--border)}
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.loc-row{display:flex;gap:18px;margin-bottom:20px}
.loc-label{font-family:var(--font-head);font-size:11px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--beige);min-width:84px;padding-top:2px}
.loc-val{font-size:16px;color:var(--white);text-decoration:none;transition:color var(--ease)}
.loc-val:hover{color:var(--beige)}
.map-wrap{border-radius:4px;overflow:hidden;height:340px;border:1px solid var(--border)}
.map-wrap iframe{width:100%;height:100%;border:none;filter:grayscale(100%) invert(88%)}

/* ── CTA Banner ── */
.cta-banner{background:var(--white);padding:96px 0;text-align:center}
.cta-banner .label{color:var(--mid-black)}
.cta-banner .section-title{color:var(--black)}
.cta-banner .section-desc{color:var(--mid-black);margin:16px auto 36px}

/* ── Footer ── */
footer{background:var(--black);border-top:1px solid var(--border);padding:44px 0}
.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px}
.footer-links{display:flex;gap:24px;list-style:none;flex-wrap:wrap}
.footer-links a{font-size:13px;color:var(--chalk);text-decoration:none;transition:color var(--ease)}
.footer-links a:hover{color:var(--white)}
.footer-copy{font-size:12px;color:rgba(255,255,255,.28)}

/* ── Offer page ── */
.nav-minimal{position:fixed;top:0;left:0;right:0;z-index:100;padding:22px 0;background:linear-gradient(to bottom,rgba(10,10,10,.95),transparent)}
.nav-minimal.scrolled{background:rgba(10,10,10,.97);backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}
.offer-wrap{background:var(--bg);min-height:100vh;padding:120px 0 80px}
.offer-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.price-wrap{display:flex;align-items:flex-start;gap:4px;margin-bottom:24px}
.price-sign{font-family:var(--font-head);font-size:28px;font-weight:600;color:var(--beige);margin-top:14px}
.price-amount{font-family:var(--font-head);font-size:clamp(80px,11vw,124px);font-weight:700;line-height:.9;letter-spacing:-.04em}
.price-label{display:flex;flex-direction:column;justify-content:flex-end;padding-bottom:8px}
.price-label span{font-size:15px;color:var(--beige);font-family:var(--font-head)}
.offer-feats{display:flex;flex-wrap:wrap;gap:20px;margin:28px 0 36px}
.offer-feat{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--chalk)}
.offer-feat::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--beige);flex-shrink:0}

/* ── Form ── */
.form-wrap{background:var(--bg3);border:1px solid var(--border);border-radius:6px;padding:44px 40px}
.form-wrap h2{font-size:28px;margin-bottom:6px}
.form-sub{color:var(--chalk);margin-bottom:32px;font-size:14px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.fgroup{display:flex;flex-direction:column;gap:7px}
.fgroup label{font-family:var(--font-head);font-size:10px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--beige)}
.fgroup input,.fgroup select{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:3px;color:var(--white);font-family:var(--font-body);font-size:15px;padding:13px 14px;outline:none;transition:border-color var(--ease);width:100%;-webkit-appearance:none;appearance:none}
.fgroup input:focus,.fgroup select:focus{border-color:var(--beige)}
.fgroup input::placeholder{color:rgba(255,255,255,.22)}
.fgroup select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7' viewBox='0 0 12 7'%3E%3Cpath d='M1 1l5 4.5L11 1' stroke='%23C4BEA8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center;padding-right:38px}
.fgroup select option{background:var(--mid-black)}
.span-2{grid-column:1/-1}
.submit-btn{width:100%;padding:16px;font-size:15px;text-align:center;margin-top:4px;border-radius:3px;cursor:pointer}
.form-note{text-align:center;font-size:12px;color:rgba(255,255,255,.38);margin-top:12px}
.typeform-wrap{border-radius:4px;overflow:hidden;margin:16px 0;border:1px solid var(--border)}

/* ── Support section (offer page) ── */
.support-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px}

/* ── Mobile hamburger ── */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}
.hamburger span{width:24px;height:2px;background:var(--white);transition:all var(--ease);display:block}

/* ── Mobile nav drawer ── */
.mobile-nav{display:none;position:fixed;inset:0;background:rgba(10,10,10,.98);z-index:99;flex-direction:column;align-items:center;justify-content:center;gap:32px}
.mobile-nav.open{display:flex}
.mobile-nav a{font-family:var(--font-head);font-size:28px;font-weight:700;color:var(--white);text-decoration:none;letter-spacing:-.02em}

/* ── Custom Form Styles ── */
.form-step{animation:fadeIn 0.4s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
form label{display:block;font-family:var(--font-head);font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--beige);margin-bottom:8px;margin-top:20px}
form input, form select{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:0;color:var(--white);padding:16px 20px;font-size:16px;font-family:var(--font-body);transition:border 0.3s ease}
form input:focus, form select:focus{outline:none;border-color:var(--beige);background:rgba(255,255,255,.05)}
.custom-select-wrapper{position:relative}
form select{appearance:none;cursor:pointer}
.custom-select-wrapper::after{content:'▼';position:absolute;right:20px;top:50%;transform:translateY(-50%);color:var(--beige);font-size:12px;pointer-events:none}

/* ══════════════════════════════
   MOBILE RESPONSIVE — 768px
══════════════════════════════ */
@media(max-width:768px){
  section{padding:72px 0}
  .container{padding:0 20px}

  /* Nav */
  .nav__links{display:none}
  .hamburger{display:flex}
  .nav__mobile-cta{display:none}

  /* Hero */
  .hero{min-height:100svh}
  .hero__content{max-width:100%}
  .hero__title{font-size:clamp(52px,14vw,76px);line-height:.92}
  .hero__desc{font-size:16px}
  .hero__actions{flex-direction:column;gap:10px}
  .hero__actions .btn{width:100%;text-align:center;justify-content:center}
  .hero__overlay{background:linear-gradient(180deg,rgba(10,10,10,.65) 0%,rgba(10,10,10,.88) 100%)}

  /* Section headings */
  .section-title{font-size:clamp(38px,10vw,58px)}

  /* Values — 2 columns keeps desktop feel */
  .grid-6{grid-template-columns:1fr 1fr}
  .vcard{padding:28px 20px}
  .vcard__num{font-size:52px}

  /* Photo callout */
  .photo-callout{height:540px}
  .photo-callout__overlay{background:linear-gradient(to right,rgba(10,10,10,.88) 0%,rgba(10,10,10,.6) 100%)}

  /* Programs */
  .grid-progs{grid-template-columns:1fr;gap:40px}
  .pcard--full:not(:last-child){border-bottom:none}
  .pcard__img-wrap img{height:260px}
  .pcard__body{padding:28px 24px}
  .pcard--full h3{font-size:24px}

  /* Video */
  .video-grid{grid-template-columns:1fr;gap:40px}
  .video-embed iframe{aspect-ratio:9/16;max-height:480px}

  /* Timetable format mobile */
  .tt-item{flex-direction:column;gap:12px;padding:24px 0}
  .tt-day{font-size:20px;width:100%}

  /* Steps */
  .grid-steps{grid-template-columns:1fr 1fr;gap:28px}
  .step h3{font-size:17px}

  /* For you */
  .fy-grid{grid-template-columns:1fr;gap:40px}
  .fy-photo{height:360px;order:-1}
  .fylist li{font-size:16px}

  /* Location */
  .loc-grid{grid-template-columns:1fr;gap:40px}
  .map-wrap{height:300px}

  /* CTA banner */
  .cta-banner{padding:80px 0}
  .cta-banner .section-desc{max-width:100%}

  /* Footer */
  .footer-inner{flex-direction:column;align-items:flex-start;gap:24px}
  .footer-links{gap:16px}

  /* Offer page */
  .offer-wrap{padding:100px 0 60px}
  .offer-grid{grid-template-columns:1fr;gap:48px}
  .support-grid{grid-template-columns:1fr;gap:48px}
  /* Mobile Sticky CTA */
  .mobile-sticky{display:block;position:fixed;bottom:0;left:0;right:0;background:rgba(10,10,10,.95);backdrop-filter:blur(10px);padding:16px 20px;border-top:1px solid var(--border);z-index:90;transform:translateY(100%);transition:transform 0.4s ease}
  .mobile-sticky.visible{transform:translateY(0)}
  .mobile-sticky .btn{width:100%;font-size:15px;padding:16px}
  body{padding-bottom:80px}
}

.mobile-sticky{display:none}

@media(max-width:480px){
  .grid-6{grid-template-columns:1fr 1fr}
  .grid-steps{grid-template-columns:1fr 1fr}
  .hero__title{font-size:clamp(46px,14vw,62px)}
  .section-title{font-size:clamp(34px,11vw,48px)}
}
