/* ============ Reset & Base ============ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Open Sans',sans-serif;color:#1a2238;line-height:1.6;background:#fff}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Montserrat',sans-serif;font-weight:800;line-height:1.2;margin:0 0 .6em;color:#0d1b3d}
h1{font-size:clamp(1.7rem,3.5vw,2.8rem);letter-spacing:.5px}
h2{font-size:clamp(1.5rem,2.6vw,2.2rem);text-transform:uppercase}
h3{font-size:1.15rem}
p{margin:0 0 1em}
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 20px}

/* ============ Colors ============ */
:root{
  --navy:#0d1b3d;
  --navy-2:#102352;
  --red:#e2231a;
  --red-d:#c41c14;
  --gray:#f5f6f8;
  --border:#e3e6ee;
}

/* ============ Buttons ============ */
.btn{display:inline-block;padding:14px 26px;border-radius:6px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:.9rem;letter-spacing:1px;text-transform:uppercase;cursor:pointer;border:2px solid transparent;transition:.2s;text-align:center}
.btn-red{background:var(--red);color:#fff;border-color:var(--red)}
.btn-red:hover{background:var(--red-d);border-color:var(--red-d)}
.btn-outline{background:transparent;color:#fff;border-color:#fff}
.btn-outline:hover{background:#fff;color:var(--navy)}
.btn-navy{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-navy:hover{background:var(--navy-2)}
.btn-block{display:block;width:100%}

/* ============ Top Bar ============ */
.topbar{background:#2e7ad1;color:#fff;font-size:.82rem;padding:8px 0}
.topbar-inner{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.topbar-right{display:flex;gap:18px;flex-wrap:wrap}
.topbar i{margin-right:6px}

/* ============ Header ============ */
.header{background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.05);position:sticky;top:0;z-index:100}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;gap:20px}
.logo{display:flex;align-items:center;gap:10px}
.logo-img{height:56px;width:auto;display:block}
.footer .logo-img{height:64px;filter:brightness(0) invert(1)}
.logo-mark{width:42px;height:48px;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);font-size:1.2rem}
.logo-title{display:block;font-family:'Montserrat',sans-serif;font-weight:900;font-size:1.2rem;color:var(--navy);line-height:1}
.logo-sub{display:block;font-family:'Montserrat',sans-serif;font-weight:600;font-size:.65rem;letter-spacing:2px;color:var(--navy)}
.nav{display:flex;gap:28px}
.nav a{font-weight:600;font-size:.95rem;color:var(--navy);padding:6px 0;border-bottom:2px solid transparent;transition:.2s}
.nav a:hover,.nav a.active{color:var(--red);border-bottom-color:var(--red)}
.nav-drop{position:relative;display:flex;align-items:center}
.nav-drop > a{cursor:pointer;padding:6px 0;border-bottom:2px solid transparent;font-weight:600;font-size:.95rem;color:var(--navy);line-height:1.4;transition:.2s}
.nav-drop:hover > a{color:var(--red);border-bottom-color:var(--red)}
.nav-drop > a::after{content:'\f078';font-family:'Font Awesome 6 Free';font-weight:900;font-size:.6rem;margin-left:6px;opacity:.7}
.nav-drop-menu{position:absolute;top:100%;left:0;min-width:220px;background:#fff;box-shadow:0 12px 30px rgba(0,0,0,.12);border-radius:8px;padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s;z-index:50;list-style:none;margin:0}
.nav-drop:hover .nav-drop-menu,.nav-drop:focus-within .nav-drop-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav-drop-menu li a{display:block;padding:10px 14px;border-radius:6px;font-size:.88rem;border:none}
.nav-drop-menu li a:hover{background:var(--gray);color:var(--red);border:none}
.header-cta{padding:12px 20px;font-size:.8rem}
.nav-toggle{display:none;background:none;border:none;font-size:1.5rem;color:var(--navy);cursor:pointer}

/* ============ Hero ============ */
.hero{position:relative;background:linear-gradient(135deg,#0d1b3d 0%,#1a2d5f 100%);color:#fff;overflow:hidden;padding:60px 0}
.hero-bg-pattern{position:absolute;inset:0;background-image:
  radial-gradient(circle at 10% 20%,rgba(255,255,255,.08) 0,transparent 2px),
  radial-gradient(circle at 80% 30%,rgba(255,255,255,.06) 0,transparent 3px),
  radial-gradient(circle at 30% 70%,rgba(255,255,255,.05) 0,transparent 2px),
  radial-gradient(circle at 60% 80%,rgba(255,255,255,.07) 0,transparent 2px);
  background-size:120px 120px,200px 200px,180px 180px,150px 150px;pointer-events:none}
.hero::before,.hero::after{content:'';position:absolute;top:0;width:80px;height:100%;background:linear-gradient(180deg,var(--red) 0%,#fff 50%,#2e7ad1 100%);opacity:.15;transform:skewX(-15deg)}
.hero::before{left:-40px}
.hero::after{right:-40px}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:center}
.hero-content h1{color:#fff;margin-bottom:.5em}
.hero-content p{font-size:1.05rem;opacity:.92;max-width:520px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin:24px 0 32px}
.hero-features{display:flex;flex-wrap:wrap;gap:18px;color:#fff;align-items:flex-start}
.hf{display:flex;flex-direction:column;align-items:center;gap:8px;font-size:.78rem;text-align:center;width:118px}
.hf i{background:transparent;width:auto;height:auto;border-radius:0;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;line-height:1}
.hero-image img{border-radius:12px;box-shadow:0 20px 50px rgba(0,0,0,.4)}

/* ============ Hero Slider ============ */
.hero-slider{position:relative;height:480px;border-radius:14px;overflow:hidden;box-shadow:0 25px 60px rgba(0,0,0,.45);background:#06112a}
.hs-track{position:absolute;inset:0;display:flex;transition:transform .7s cubic-bezier(.65,.05,.36,1)}
.hs-slide{flex:0 0 100%;position:relative;height:100%;overflow:hidden}
.hs-slide::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(13,27,61,.95) 100%);z-index:2}
.hs-slide img{width:100%;height:100%;object-fit:cover;transform:scale(1.08);transition:transform 8s linear}
.hs-slide.active img{transform:scale(1)}
.hs-caption{position:absolute;left:24px;right:24px;bottom:24px;z-index:3;color:#fff}
.hs-caption h3{color:#fff;font-size:1.4rem;margin:0 0 6px;text-shadow:0 2px 12px rgba(0,0,0,.5)}
.hs-caption p{font-size:.92rem;opacity:.95;margin:0;max-width:80%}
.hs-caption .chip{display:inline-block;background:var(--red);color:#fff;font-family:'Montserrat',sans-serif;font-weight:700;font-size:.7rem;letter-spacing:2px;padding:5px 12px;border-radius:999px;margin-bottom:10px;text-transform:uppercase}

/* Decorative stripes */
.hs-stripes{position:absolute;top:-30px;right:-30px;width:160px;height:120%;z-index:4;pointer-events:none;transform:rotate(18deg)}
.hs-stripes .stripe{display:block;width:14px;height:100%;position:absolute;top:0;border-radius:2px;opacity:.95}
.hs-stripes .red{background:var(--red);right:0}
.hs-stripes .white{background:#fff;right:24px}
.hs-stripes .blue{background:#2e7ad1;right:48px}

/* Stars */
.hs-stars{position:absolute;inset:0;z-index:4;pointer-events:none;color:#fff}
.hs-stars i{position:absolute;opacity:.85;filter:drop-shadow(0 0 6px rgba(255,255,255,.5));animation:twinkle 2.4s ease-in-out infinite}
.hs-stars .s1{top:14px;left:18px;font-size:.7rem;animation-delay:0s}
.hs-stars .s2{top:38px;left:60px;font-size:1rem;color:var(--red);animation-delay:.4s}
.hs-stars .s3{top:78px;right:90px;font-size:.65rem;animation-delay:.8s}
.hs-stars .s4{top:120px;left:30px;font-size:.55rem;color:#2e7ad1;animation-delay:1.2s}
.hs-stars .s5{bottom:140px;right:50px;font-size:.85rem;animation-delay:1.6s}
@keyframes twinkle{0%,100%{opacity:.4;transform:scale(.85)}50%{opacity:1;transform:scale(1.15)}}

/* Badge */
.hs-badge{position:absolute;top:18px;left:18px;z-index:5;background:rgba(13,27,61,.85);backdrop-filter:blur(6px);color:#fff;display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.15)}
.hs-badge i{color:var(--red);font-size:1.2rem}
.hs-badge span{font-family:'Montserrat',sans-serif;font-weight:800;font-size:.72rem;line-height:1.1;letter-spacing:1px}

/* Nav arrows */
.hs-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:42px;height:42px;border-radius:50%;border:none;background:rgba(255,255,255,.18);backdrop-filter:blur(6px);color:#fff;cursor:pointer;font-size:.9rem;transition:.2s;display:flex;align-items:center;justify-content:center}
.hs-nav:hover{background:var(--red)}
.hs-prev{left:14px}
.hs-next{right:14px}

/* Dots */
.hs-dots{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);z-index:5;display:flex;gap:8px}
.hs-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.4);border:none;cursor:pointer;transition:.2s;padding:0}
.hs-dot.active{background:var(--red);width:24px;border-radius:4px}

/* ============ Programs ============ */
.programs{padding:60px 0;background:#fff;margin-top:-40px;position:relative;z-index:3}
.program-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.program-card{background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 6px 20px rgba(0,0,0,.08);transition:.3s;display:flex;flex-direction:column}
.program-card:hover{transform:translateY(-6px);box-shadow:0 14px 30px rgba(0,0,0,.12)}
.pc-img{height:180px;background-size:cover;background-position:center}
.pc-body{padding:20px;display:flex;flex-direction:column;flex:1}
.pc-icons{display:flex;gap:8px;color:var(--red);margin-bottom:8px;font-size:1rem}
.pc-body h3{font-size:1rem;color:var(--navy)}
.pc-body p{font-size:.85rem;color:#555;flex:1}
.pc-body .btn{margin-top:14px;font-size:.78rem;padding:11px}

/* ============ About ============ */
.about{padding:60px 0;background:#fff}
.about-inner{display:grid;grid-template-columns:1fr 1.1fr;gap:40px;align-items:center}
.about-images{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.about-images img{border-radius:8px;height:170px;object-fit:cover;width:100%}
.about-text h2{color:var(--navy)}
.about-text p{color:#444;font-size:.95rem}
.about-text .btn{margin-top:14px}

/* ============ Transform / Trial ============ */
.transform{position:relative;background:linear-gradient(135deg,#0d1b3d 0%,#1a2d5f 100%);color:#fff;padding:60px 0;overflow:hidden}
.transform .hero-bg-pattern{opacity:.7}
.transform-inner{position:relative;z-index:2}
.transform-header{text-align:center;margin-bottom:40px}
.eyebrow{color:#fff;letter-spacing:3px;font-size:.78rem;font-weight:700;text-transform:uppercase;opacity:.85}
.transform-header h2{color:#fff}
.transform-body{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:30px 24px;text-align:center}
.benefit-icon{width:60px;height:60px;background:var(--red);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 10px;font-size:1.3rem;color:#fff}
.benefit h4{color:#fff;margin:0 0 4px;font-size:1rem}
.benefit span{font-size:.78rem;opacity:.85}
.trial-form{background:#fff;color:var(--navy);padding:28px;border-radius:10px;box-shadow:0 20px 50px rgba(0,0,0,.3)}
.trial-form h3{text-align:center;color:var(--navy)}
.trial-form > p{text-align:center;font-size:.85rem;color:#555}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.trial-form input,.trial-form select{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:6px;font-size:.9rem;font-family:inherit;background:var(--gray);margin-bottom:10px}
.trial-form input:focus,.trial-form select:focus{outline:none;border-color:var(--red);background:#fff}
.form-note{text-align:center;font-size:.78rem;color:#666;margin:10px 0 0}

/* ============ Small Wins ============ */
.smallwins{padding:60px 0;text-align:center;background:#fff}
.smallwins h2{color:var(--navy)}
.sw-lead{max-width:720px;margin:0 auto 36px;color:#555}
.sw-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;text-align:left;max-width:920px;margin:0 auto}
.sw-grid h3{color:var(--navy);font-size:1.05rem}
.sw-grid p{color:#555;font-size:.92rem}

/* ============ Tabbed Section ============ */
.tabsec{position:relative;padding:60px 0;background:url('assets/about.jpg') center/cover}
.tabsec-overlay{position:absolute;inset:0;background:rgba(13,27,61,.75)}
.tabsec .container{position:relative;z-index:2}
.tabs-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 20px 50px rgba(0,0,0,.3)}
.tabs-nav{display:flex;border-bottom:1px solid var(--border);overflow-x:auto}
.tab{flex:1;background:none;border:none;padding:18px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:.9rem;cursor:pointer;color:#555;border-bottom:3px solid transparent;white-space:nowrap}
.tab.active{color:var(--red);border-bottom-color:var(--red)}
.tab-panels{padding:28px}
.tab-panel{display:none}
.tab-panel.active{display:block}
.tp-grid{display:grid;grid-template-columns:200px 1fr 240px;gap:28px;align-items:center}
.tp-grid > img{width:100%;height:160px;object-fit:cover;border-radius:8px}
.tp-grid h3{color:var(--navy)}
.tp-grid p{font-size:.9rem;color:#555}
.testimonial{background:var(--gray);padding:18px;border-radius:8px;text-align:center}
.testimonial img{width:50px;height:50px;border-radius:50%;margin:0 auto 8px}
.testimonial p{font-size:.82rem;color:#444;font-style:italic;margin-bottom:6px}
.testimonial a{color:var(--red);font-weight:700;font-size:.82rem}

/* ============ FAQ ============ */
.faqsec{position:relative;padding:60px 0;background:url('assets/prog3.jpg') center/cover}
.faqsec-overlay{position:absolute;inset:0;background:rgba(13,27,61,.82)}
.faqsec .container{position:relative;z-index:2;text-align:center}
.faqsec h2{color:#fff}
.faq-list{max-width:680px;margin:30px auto}
.faq-list details{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:6px;margin-bottom:10px;color:#fff}
.faq-list summary{padding:14px 20px;cursor:pointer;font-weight:600;font-size:.92rem;display:flex;justify-content:space-between;align-items:center;list-style:none}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary i{background:var(--red);width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;transition:.2s}
.faq-list details[open] summary i{transform:rotate(180deg)}
.faq-list p{padding:0 20px 16px;margin:0;font-size:.88rem;opacity:.9;text-align:left}
.faq-cta{margin-top:20px}

/* ============ Why ============ */
.why{padding:60px 0;text-align:center;background:var(--gray)}
.why h2{color:var(--navy)}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:30px}
.why-icon{width:60px;height:60px;background:var(--red);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin:0 auto 14px}
.why-card h3{color:var(--navy);font-size:1.05rem}
.why-card p{color:#555;font-size:.9rem}

/* ============ Footer ============ */
.footer{background:var(--navy);color:#fff;padding:50px 0 0}
.footer-inner{display:grid;grid-template-columns:1fr 1fr 1.4fr 1.4fr;gap:30px}
.f-col h4{color:var(--red);margin-bottom:14px;font-size:.95rem;text-transform:uppercase;letter-spacing:1px}
.f-col a{display:block;padding:4px 0;color:#cfd5e6;font-size:.88rem}
.f-col a:hover{color:#fff}
.f-col p{color:#cfd5e6;font-size:.88rem;margin:6px 0;display:flex;gap:8px;align-items:flex-start}
.f-col p i{color:var(--red);margin-top:4px}
.social{display:flex;gap:10px;margin:12px 0}
.social a{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;padding:0}
.social a:hover{background:var(--red)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:40px;padding:18px 0;font-size:.8rem;color:#aab2c8;text-align:center}
.footer-bottom .container{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap}
.footer-bottom p{margin:0}

/* ============ Inner Page: Hero ============ */
.page-hero{position:relative;padding:60px 0 80px;overflow:hidden;background:#fff}
.page-hero-bg{position:absolute;inset:0;background:url('assets/about.jpg') center/cover;opacity:.25;filter:saturate(.6) hue-rotate(-10deg)}
.page-hero::after{content:'';position:absolute;left:0;right:0;bottom:-1px;height:80px;background:#fff;clip-path:polygon(0 60%,100% 0,100% 100%,0 100%)}
.page-hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:center}
.ph-eyebrow{color:var(--red);font-weight:700;font-family:'Montserrat',sans-serif;font-size:.8rem;letter-spacing:2px;text-transform:uppercase;margin-bottom:10px}
.ph-content h1{color:var(--navy);font-size:clamp(1.6rem,2.6vw,2.4rem)}
.ph-lead{color:#333;font-size:1rem;max-width:520px}
.ph-image{position:relative;display:flex;justify-content:center}
.ph-image img{width:100%;max-width:420px;height:380px;object-fit:cover;border-radius:14px;box-shadow:0 18px 45px rgba(0,0,0,.18)}
.ph-tag{position:absolute;top:0;right:0;background:var(--red);color:#fff;padding:8px 14px;border-radius:6px;font-family:'Montserrat',sans-serif;font-weight:800;font-size:.78rem;text-align:center;line-height:1.2}
.ph-tag small{display:block;font-weight:600;font-size:.62rem;opacity:.9}
.ph-arrow{position:absolute;top:42px;right:-6px;color:var(--red);font-size:1.2rem;animation:bounce 1.6s ease-in-out infinite}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}
.ph-form{grid-column:3;background:#fff;border-radius:12px;padding:24px;box-shadow:0 20px 50px rgba(0,0,0,.15);border-top:4px solid var(--red);max-width:340px;justify-self:end}
.ph-form h3{color:var(--red);text-align:center;font-size:1.05rem;margin-bottom:6px}
.ph-form > p{font-size:.82rem;text-align:center;color:#444;margin-bottom:6px}
.ph-form-hint{display:block;text-align:center;color:#888;font-size:.72rem;margin-bottom:14px}
.ph-form input{width:100%;padding:11px 14px;border:1px solid var(--border);border-radius:6px;margin-bottom:10px;background:var(--gray);font-family:inherit;font-size:.88rem}
.ph-form input:focus{outline:none;border-color:var(--red);background:#fff}
.ph-form-foot{display:block;text-align:center;color:#888;font-size:.68rem;margin-top:10px}
@media(max-width:1024px){
  .page-hero-inner{grid-template-columns:1fr 1fr}
  .ph-form{grid-column:1/-1;justify-self:center;margin-top:20px}
}
@media(max-width:680px){
  .page-hero-inner{grid-template-columns:1fr;text-align:center}
  .ph-form{max-width:100%}
}

/* ============ Benefits Grid (4 col) ============ */
.benefits-grid{padding:50px 0;background:#fff}
.bg-row{display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.bg-item{padding:10px}
.bg-icon{width:54px;height:54px;background:var(--red);color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:12px}
.bg-item h4{color:var(--navy);font-size:1rem;margin-bottom:8px}
.bg-item p{font-size:.88rem;color:#555;margin:0}
@media(max-width:900px){.bg-row{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.bg-row{grid-template-columns:1fr}}

/* ============ Unleash ============ */
.unleash{padding:60px 0;background:#fff}
.unleash-inner{display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:center}
.un-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.un-gallery img{width:100%;height:130px;object-fit:cover;border-radius:6px}
.un-gallery img:first-child{grid-column:1/3;height:160px}
.un-text h2{color:var(--navy)}
.un-text p{color:#444;font-size:.95rem}
.un-text .btn{margin-top:10px}
@media(max-width:900px){.unleash-inner{grid-template-columns:1fr}}

/* ============ Big Banner ============ */
.big-banner{position:relative;padding:80px 0;background-size:cover;background-position:center;text-align:center;color:#fff}
.bb-overlay{position:absolute;inset:0;background:rgba(13,27,61,.7)}
.big-banner .container{position:relative;z-index:2}
.big-banner h2{color:#fff;margin:0;font-size:clamp(1.3rem,2.4vw,2rem)}

/* ============ Challenges ============ */
.challenges{padding:60px 0;background:#fff}
.ch-row{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;margin-bottom:60px;position:relative}
.ch-row:last-child{margin-bottom:0}
.ch-row.reverse .ch-text{order:2}
.ch-row.reverse .ch-img{order:1}
.ch-num{color:var(--red);font-weight:900;font-size:1.4rem;margin-right:6px}
.ch-text h3{color:var(--navy);font-size:1.25rem;display:flex;align-items:center}
.ch-text p{color:#555;font-size:.95rem;margin-bottom:16px}
.ch-img{position:relative;border-radius:10px;overflow:hidden}
.ch-img img{width:100%;height:280px;object-fit:cover;border-radius:10px}
.ch-img::before{content:'';position:absolute;top:0;bottom:0;width:30px;background:linear-gradient(180deg,var(--red),#fff,#2e7ad1);left:-15px;transform:skewX(-12deg);z-index:2;opacity:.85;border-radius:4px}
.ch-row.reverse .ch-img::before{left:auto;right:-15px}
@media(max-width:820px){.ch-row{grid-template-columns:1fr;gap:24px;margin-bottom:40px}.ch-row.reverse .ch-text{order:0}.ch-row.reverse .ch-img{order:0}}

/* ============ Solution Heading ============ */
.solution-head{padding:50px 0;text-align:center;background:#fff}
.solution-head h2{color:var(--navy);max-width:780px;margin:0 auto 12px}
.solution-head .alt{color:var(--red)}
.solution-head p{max-width:680px;margin:0 auto;color:#555}

/* ============ Solution CTA ============ */
.solution-cta{background:linear-gradient(135deg,#0d1b3d 0%,#1a2d5f 100%);color:#fff;padding:50px 0}
.sc-inner{display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:center}
.sc-text h2{color:#fff;margin-bottom:8px}
.sc-text p{opacity:.9}
.sc-form{background:#fff;color:var(--navy);padding:22px;border-radius:10px;box-shadow:0 14px 36px rgba(0,0,0,.25)}
.sc-form input{width:100%;padding:11px 14px;border:1px solid var(--border);border-radius:6px;margin-bottom:10px;background:var(--gray);font-family:inherit;font-size:.88rem}
@media(max-width:820px){.sc-inner{grid-template-columns:1fr}}

/* ============ Testimonials ============ */
.testimonials{padding:60px 0;background:#fff;text-align:center}
.testimonials h2{color:var(--navy)}
.t-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin:30px 0;text-align:left}
.t-card{background:var(--gray);padding:24px;border-radius:10px;border-left:4px solid var(--red);position:relative}
.t-card i{color:var(--red);font-size:1.3rem;margin-bottom:10px}
.t-card p{color:#444;font-style:italic;margin-bottom:14px;font-size:.92rem}
.t-card strong{display:block;color:var(--navy);font-family:'Montserrat',sans-serif}
.t-card small{color:#777;font-size:.78rem}
.t-cta{margin-top:20px}
@media(max-width:720px){.t-grid{grid-template-columns:1fr}}

/* ============ Closer Look ============ */
.closer{padding:60px 0;background:var(--gray);text-align:center}
.closer h3{color:var(--red);font-size:1.4rem}
.closer-sub{color:#555;margin-bottom:30px}
.closer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:left}
.closer-card{background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 6px 18px rgba(0,0,0,.08)}
.closer-card img{width:100%;height:150px;object-fit:cover}
.cc-body{padding:18px}
.cc-num{display:inline-block;background:var(--red);color:#fff;font-family:'Montserrat',sans-serif;font-weight:800;padding:3px 10px;border-radius:4px;font-size:.78rem;margin-bottom:8px}
.cc-body h4{color:var(--navy);margin-bottom:6px;font-size:1rem}
.cc-body p{color:#555;font-size:.85rem;margin:0}
.closer-cta{margin-top:30px}
@media(max-width:900px){.closer-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.closer-grid{grid-template-columns:1fr}}

/* ============ Page FAQ Spacing ============ */
.page-faq{padding:70px 0}

/* ============ Final CTA Banner ============ */
.final-cta{position:relative;padding:80px 0;background-size:cover;background-position:center;color:#fff}
.fc-overlay{position:absolute;inset:0;background:rgba(13,27,61,.85)}
.fc-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:center}
.fc-text h2{color:#fff}
.fc-text p{opacity:.9}
.fc-form{background:#fff;color:var(--navy);padding:24px;border-radius:10px;box-shadow:0 20px 50px rgba(0,0,0,.4)}
.fc-form h3{color:var(--navy);text-align:center;margin-bottom:14px}
.fc-form input{width:100%;padding:11px 14px;border:1px solid var(--border);border-radius:6px;margin-bottom:10px;background:var(--gray);font-family:inherit;font-size:.88rem}
@media(max-width:820px){.fc-inner{grid-template-columns:1fr}}

/* ============ Lead Capture Modal ============ */
.lead-modal{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;padding:20px}
.lead-modal.open{display:flex;animation:fadeIn .25s ease-out}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.lm-backdrop{position:absolute;inset:0;background:rgba(13,27,61,.55);backdrop-filter:blur(4px)}
.lm-card{position:relative;background:#cfe5f5;border-radius:14px;max-width:780px;width:100%;max-height:92vh;overflow-y:auto;display:grid;grid-template-columns:1fr 1.1fr;box-shadow:0 30px 70px rgba(0,0,0,.4);animation:lmSlide .35s cubic-bezier(.2,.8,.3,1.1)}
@keyframes lmSlide{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.lm-close{position:absolute;top:10px;right:10px;z-index:3;width:32px;height:32px;border-radius:50%;border:none;background:rgba(255,255,255,.85);color:var(--navy);cursor:pointer;font-size:.95rem;display:flex;align-items:center;justify-content:center}
.lm-close:hover{background:var(--red);color:#fff}
.lm-image{background-size:cover;background-position:center;min-height:280px;border-radius:14px 0 0 14px}
.lm-body{padding:24px 28px;background:#fff;border-radius:0 14px 14px 0}
.lm-logo{height:38px;width:auto;margin-bottom:10px}
.lm-body h2{color:var(--navy);font-size:1.4rem;margin-bottom:6px;line-height:1.2}
.lm-body h2 .alt{color:var(--red)}
.lm-sub{color:var(--navy);margin-bottom:4px}
.lm-hint{color:#666;font-size:.85rem;margin-bottom:14px}
.lm-form input{width:100%;padding:11px 14px;border:1px solid var(--border);border-radius:6px;margin-bottom:10px;background:var(--gray);font-family:inherit;font-size:.9rem}
.lm-form input:focus{outline:none;border-color:var(--red);background:#fff}
.lm-countdown{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:14px 0 10px}
.lm-countdown div{background:var(--gray);text-align:center;padding:8px 4px;border-radius:6px;border:1px solid var(--border)}
.lm-countdown strong{display:block;font-family:'Montserrat',sans-serif;font-weight:800;color:var(--red);font-size:1.1rem;line-height:1}
.lm-countdown span{font-size:.65rem;color:#666;text-transform:uppercase;letter-spacing:1px}
.lm-bullets{padding-left:18px;margin:8px 0;color:#444;font-size:.85rem}
.lm-bullets li{margin-bottom:3px}
.lm-tos{display:block;color:#888;font-size:.7rem;margin-top:10px;line-height:1.4}
@media(max-width:680px){
  .lm-card{grid-template-columns:1fr;max-height:96vh}
  .lm-image{min-height:140px;border-radius:14px 14px 0 0}
  .lm-body{border-radius:0 0 14px 14px;padding:20px}
}

/* ============ Page Banner (About/Contact/FAQ) ============ */
.page-banner{position:relative;padding:80px 0 60px;background:url('assets/about.jpg') center/cover;color:#fff}
.pb-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(46,122,209,.85),rgba(13,27,61,.7))}
.page-banner .container{position:relative;z-index:2}
.page-banner h1{color:#fff;font-size:clamp(1.8rem,3vw,2.6rem);margin-bottom:10px}
.page-banner p{color:#fff;max-width:680px;opacity:.95}

/* ============ Quick Links (4 program cards) ============ */
.quick-links{padding:30px 0;background:#fff;margin-top:-40px;position:relative;z-index:3}
.ql-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.ql-card{position:relative;height:160px;border-radius:12px;background-size:cover;background-position:center;overflow:hidden;display:flex;align-items:flex-end;padding:18px;color:#fff;box-shadow:0 8px 22px rgba(0,0,0,.12);transition:.25s}
.ql-card:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(0,0,0,.18)}
.ql-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(13,27,61,.85) 100%)}
.ql-card span{position:relative;z-index:2;font-family:'Montserrat',sans-serif;font-weight:800;font-size:1.05rem;color:#fff}
@media(max-width:900px){.ql-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.ql-grid{grid-template-columns:1fr}}

/* ============ Meet section (About) ============ */
.meet{padding:60px 0;background:#fff}
.meet.alt{background:var(--gray)}
.meet-inner{display:grid;grid-template-columns:1fr 1.4fr;gap:50px;align-items:center}
.meet-inner.reverse{grid-template-columns:1.4fr 1fr}
.meet-inner.reverse .meet-img{order:2}
.meet-inner.reverse .meet-text{order:1}
.meet-img img{width:100%;height:440px;object-fit:cover;border-radius:14px;box-shadow:0 18px 40px rgba(0,0,0,.18)}
.meet-text h2{color:var(--navy);margin-bottom:12px}
.meet-text p{color:#444}
.meet-text .btn{margin-top:10px}
@media(max-width:900px){.meet-inner,.meet-inner.reverse{grid-template-columns:1fr}.meet-inner.reverse .meet-img{order:0}.meet-inner.reverse .meet-text{order:0}.meet-img img{height:340px}}

/* ============ Contact block ============ */
.contact-block{padding:60px 0;background:#fff}
.contact-inner{display:grid;grid-template-columns:1fr 1fr 1fr;gap:30px;align-items:start}
.ci-info h2{color:var(--red);margin-bottom:8px}
.ci-list{list-style:none;padding:0;margin:18px 0}
.ci-list li{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--border);align-items:flex-start}
.ci-list li i{color:var(--red);margin-top:5px;width:18px}
.ci-list a{color:var(--navy);font-weight:500}
.ci-list a:hover{color:var(--red)}
.ci-hours{display:grid;grid-template-columns:1fr auto;gap:4px 18px;font-size:.92rem;color:#444}
.ci-social{display:flex;gap:10px;margin-top:14px}
.ci-social a{width:38px;height:38px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center}
.ci-image img{width:100%;height:420px;object-fit:cover;border-radius:12px}
.ci-map iframe{width:100%;height:280px;border-radius:12px;border:0;margin-bottom:12px}
@media(max-width:900px){.contact-inner{grid-template-columns:1fr}.ci-image img{height:320px}}

/* ============ Message block ============ */
.message-block{padding:60px 0;background:var(--gray)}
.mb-card{background:#fff;border-radius:14px;padding:40px;max-width:780px;margin:0 auto;box-shadow:0 12px 30px rgba(0,0,0,.06)}
.mb-card h2{color:var(--navy);text-align:center;margin-bottom:20px}
.mb-form label{display:block;font-size:.85rem;font-weight:600;color:#444;margin-bottom:14px}
.mb-form input,.mb-form textarea{width:100%;padding:11px 14px;border:1px solid var(--border);border-radius:6px;font-family:inherit;font-size:.92rem;background:var(--gray);margin-top:4px}
.mb-form textarea{resize:vertical}
.mb-form button{display:block;margin:14px auto 0;padding:14px 40px}

/* ============ FAQ page ============ */
.faq-page{padding:60px 0;background:#fff}
.faq-page-inner{display:grid;grid-template-columns:2fr 1fr;gap:40px;align-items:start}
.faq-col details{background:var(--gray);border-radius:8px;margin-bottom:10px;padding:0}
.faq-col summary{padding:16px 20px;cursor:pointer;font-weight:600;font-size:.95rem;color:var(--navy);display:flex;justify-content:space-between;align-items:center;list-style:none}
.faq-col summary::-webkit-details-marker{display:none}
.faq-col summary i{background:#2e7ad1;color:#fff;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;transition:.2s}
.faq-col details[open] summary i{transform:rotate(180deg);background:var(--red)}
.faq-col details p{padding:0 20px 18px;margin:0;color:#444;font-size:.92rem}
.faq-aside{background:#2e7ad1;color:#fff;padding:26px;border-radius:14px;position:sticky;top:90px}
.faq-aside h3{color:#fff;text-align:center;font-size:1.05rem}
.faq-aside > p{font-size:.85rem;text-align:center;opacity:.95;margin-bottom:16px}
.faq-aside input{width:100%;padding:11px 14px;border:none;border-radius:6px;margin-bottom:10px;background:#fff;color:var(--navy);font-family:inherit;font-size:.88rem}
.faq-aside small{display:block;color:rgba(255,255,255,.85);font-size:.72rem;margin-top:12px}
@media(max-width:900px){.faq-page-inner{grid-template-columns:1fr}.faq-aside{position:static}}

/* ============ Hero's Journey ============ */
.journey-hero{position:relative;padding:100px 0 80px;background:url('assets/about.jpg') center/cover;color:#fff;text-align:center}
.jh-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(226,35,26,.6),rgba(13,27,61,.85))}
.journey-hero .container{position:relative;z-index:2}
.jh-logo{height:80px;width:auto;margin:0 auto 18px;display:block;filter:brightness(0) invert(1)}
.jh-kicker{color:#fff;opacity:.9;font-size:1rem;margin-bottom:6px;font-family:'Montserrat',sans-serif;font-weight:600}
.journey-hero h1{color:#fff;font-size:clamp(2rem,4vw,3rem);margin-bottom:14px}
.journey-hero > .container > p{max-width:620px;margin:0 auto;color:#fff;opacity:.95}

.values{padding:60px 0;background:#fff}
.values h2{color:var(--red);text-align:center;margin-bottom:30px}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.value-card{background:#fff;border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:0 6px 18px rgba(0,0,0,.06);transition:.25s}
.value-card:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(0,0,0,.1)}
.value-card img{width:100%;height:200px;object-fit:cover}
.value-card h3{color:var(--red);padding:18px 22px 0;font-size:1.15rem;margin-bottom:6px}
.value-card p{padding:0 22px 22px;color:#444;margin:0;font-size:.92rem}
@media(max-width:820px){.values-grid{grid-template-columns:1fr}}

.stand{padding:60px 0;background:var(--gray)}
.stand-inner{display:grid;grid-template-columns:1fr 1.4fr;gap:50px;align-items:start}
.stand-img img{width:100%;height:520px;object-fit:cover;border-radius:14px}
.stand-text h2{color:var(--navy);text-align:left;margin-bottom:24px}
.stand-item{display:grid;grid-template-columns:auto 1fr;gap:16px;margin-bottom:22px}
.si-icon{width:48px;height:48px;background:var(--red);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.05rem}
.stand-item h4{color:var(--red);margin-bottom:4px;font-size:1rem}
.stand-item p{color:#444;margin:0;font-size:.92rem}
@media(max-width:820px){.stand-inner{grid-template-columns:1fr}.stand-img img{height:340px}}

.journey-cta{background:#2e7ad1;color:#fff;padding:60px 0;text-align:center}
.jc-eyebrow{font-family:'Montserrat',sans-serif;font-weight:600;letter-spacing:1px;text-transform:uppercase;font-size:.85rem;opacity:.9}
.journey-cta h2{color:#fff;max-width:640px;margin:8px auto 22px}

/* ============ Responsive ============ */
@media(max-width:1024px){
  .nav{gap:18px}
  .program-grid{grid-template-columns:repeat(2,1fr)}
  .tp-grid{grid-template-columns:1fr;text-align:center}
  .tp-grid > img{height:200px}
  .footer-inner{grid-template-columns:1fr 1fr}
}
@media(max-width:820px){
  .hero-inner{grid-template-columns:1fr;text-align:center}
  .hero-image{order:-1;max-width:380px;margin:0 auto}
  .hero-slider{order:-1;height:320px;margin-bottom:20px}
  .hero-content{order:0}
  .hero-ctas{justify-content:center}
  .hero-features{justify-content:center}
  .about-inner{grid-template-columns:1fr}
  .transform-body{grid-template-columns:1fr}
  .sw-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr;gap:24px}
  .nav{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;padding:16px;box-shadow:0 6px 18px rgba(0,0,0,.1);gap:0}
  .nav.open{display:flex}
  .nav a{padding:12px 0;border-bottom:1px solid var(--border)}
  .nav-toggle{display:block}
  .header-cta{display:none}
  .header-inner{position:relative}
}
@media(max-width:560px){
  .program-grid{grid-template-columns:1fr}
  .topbar-inner{flex-direction:column;text-align:center;gap:4px}
  .topbar-right{justify-content:center}
  .benefits{grid-template-columns:repeat(2,1fr)}
  .form-row{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr;text-align:center}
  .f-col p{justify-content:center}
  .social{justify-content:center}
  .about-images img{height:130px}
}

/* ============ Reference-Match: sharp hero stripes + sparkles ============ */
.hero{padding:54px 0 70px}
.hero::before,.hero::after{display:none!important}
.hero-inner{grid-template-columns:1.15fr .85fr;gap:30px}
.hero-content h1{font-size:clamp(1.6rem,2.7vw,2.35rem);line-height:1.14;letter-spacing:.4px;max-width:560px;margin-bottom:.45em}
.hero-content p{font-size:1rem;max-width:480px}
.hero-image{position:relative;z-index:2}
.hero-image img{border-radius:10px;box-shadow:0 22px 48px rgba(0,0,0,.45);width:100%;height:440px;object-fit:cover;object-position:center top}

/* sparkles */
.hero-sparkles{position:absolute;inset:0;z-index:1;pointer-events:none}
.hero-sparkles .sp{position:absolute;color:rgba(255,255,255,.55);line-height:1;filter:drop-shadow(0 0 4px rgba(255,255,255,.3));animation:twk 3s ease-in-out infinite}
.hero-sparkles .sp.red{color:rgba(226,35,26,.8)}
.hero-sparkles .sp.blue{color:rgba(46,122,209,.85)}
@keyframes twk{0%,100%{opacity:.35;transform:scale(.8)}50%{opacity:1;transform:scale(1.1)}}

/* slim diagonal accent stripes in top corners (a few thin lines, like the reference) */
.hero-stripes-tl,.hero-stripes-tr{position:absolute;top:0;z-index:1;pointer-events:none;width:170px;height:150px;background-repeat:no-repeat;
  background-image:linear-gradient(135deg,
    transparent 0 30px,
    #e2231a 30px 35px,
    transparent 35px 45px,
    #2e7ad1 45px 50px,
    transparent 50px 60px,
    #e2231a 60px 65px,
    transparent 65px 100%);
  clip-path:polygon(100% 0,100% 100%,0 0)}
.hero-stripes-tr{right:0}
.hero-stripes-tl{left:0;transform:scaleX(-1)}

/* programs overlap the hero like the reference */
.programs{margin-top:-46px}
@media(max-width:820px){
  .hero-stripes-tl,.hero-stripes-tr{width:160px;height:130px}
  .hero-image img{height:320px}
}

/* ============ Full-width banner hero (background = kid + stripes + stars; live text overlaid left) ============ */
.hero.has-banner{position:relative;padding:0;background-color:#0d1b3d;background-size:cover;background-position:right 22%;background-repeat:no-repeat;overflow:hidden;display:flex;align-items:center;height:clamp(440px,37vw,490px)}
.hero.has-banner::before,.hero.has-banner::after{display:none!important}
.hero-banner-scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(13,27,61,.96) 0%,rgba(13,27,61,.85) 30%,rgba(13,27,61,.4) 48%,transparent 62%)}
.hero-banner-mobile{display:none}
.hero.has-banner .hero-inner{position:relative;z-index:2;width:100%;max-width:100%;padding:0;display:grid;grid-template-columns:1fr 1fr;align-items:center}
.hero.has-banner .hero-content{max-width:560px;justify-self:center;padding:0 18px;text-align:left}
.hero.has-banner .hero-content h1{color:#fff;font-size:clamp(1.1rem,1.8vw,1.85rem);line-height:1.14;margin-bottom:.32em}
.hero.has-banner .hero-content p{font-size:clamp(.78rem,.95vw,.95rem);line-height:1.45;margin-bottom:0;max-width:430px}
.hero.has-banner .hero-ctas{margin:18px 0 18px;gap:12px;justify-content:flex-start}
.hero.has-banner .btn{padding:12px 22px;font-size:.78rem}
.hero.has-banner .hero-features{display:flex;gap:16px;align-items:flex-start;flex-wrap:wrap;justify-content:flex-start}
.hero.has-banner .hf{width:104px;display:flex;flex-direction:column;align-items:center;gap:9px;text-align:center}
.hero.has-banner .hf i{font-size:1.5rem;color:#fff;line-height:1;background:transparent;width:auto;height:auto}
.hero.has-banner .hf span{font-size:.72rem;line-height:1.25;color:#fff}
/* mobile/tablet: show the banner image ABOVE the text, on navy */
@media(max-width:900px){
  .hero.has-banner{background:linear-gradient(135deg,#0d1b3d 0%,#1a2d5f 100%)!important;height:auto;display:flex;flex-direction:column;padding:0;align-items:stretch;overflow:visible}
  .hero-banner-scrim{display:none}
  .hero-banner-mobile{display:block;width:100%;height:auto;order:0}
  .hero.has-banner .hero-inner{order:1;padding:32px 20px 68px;display:block;max-width:100%}
  .hero.has-banner .hero-content{max-width:100%;justify-self:stretch;padding:0;text-align:center}
  .hero.has-banner .hero-content h1{font-size:clamp(1.35rem,5.4vw,1.7rem);text-align:center}
  .hero.has-banner .hero-content p{max-width:520px;margin-left:auto;margin-right:auto;font-size:.92rem}
  .hero.has-banner .hero-ctas{justify-content:center;flex-wrap:wrap;gap:10px}
  .hero.has-banner .hero-features{justify-content:center;gap:14px;flex-wrap:wrap;margin-top:6px}
  .hero.has-banner .hf{width:96px;flex:0 0 auto;min-width:0}
  .hero.has-banner .hf i{font-size:1.55rem}
  .hero.has-banner .hf span{font-size:.68rem;line-height:1.2}
}

/* ---- Lead forms ---- */
html{scroll-behavior:smooth}
.hp-field{position:absolute!important;left:-9999px!important;top:-9999px!important;width:1px;height:1px;opacity:0;pointer-events:none}
.lead-success{background:#0d7a3f;color:#fff;padding:18px 20px;border-radius:10px;font-weight:600;text-align:center;line-height:1.45;font-size:1.02rem}
.lead-success[hidden]{display:none!important}
.lead-toast{position:fixed;top:18px;left:50%;transform:translateX(-50%);background:#0d7a3f;color:#fff;padding:14px 24px;border-radius:10px;font-weight:600;z-index:2000;box-shadow:0 12px 34px rgba(0,0,0,.28);max-width:92%;text-align:center;font-size:1rem}
.trial-form .lead-success,.ph-form .lead-success,.fc-form .lead-success,.mb-form .lead-success,.lm-form .lead-success{margin-top:6px}

/* ---- Conversion funnel: class-selector + checkout + thank you ---- */
.funnel-classes{padding:50px 0 70px;background:var(--gray,#f4f6fa)}
.cs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.cs-card{background:#fff;border:1px solid #e6e9f0;border-top:4px solid var(--red);border-radius:14px;padding:26px;box-shadow:0 10px 30px rgba(13,27,61,.06);display:flex;flex-direction:column}
.cs-card h3{color:var(--navy);font-size:1.25rem;margin-bottom:4px}
.cs-age{display:inline-block;align-self:flex-start;background:var(--navy);color:#fff;font-size:.72rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:3px 10px;border-radius:999px;margin-bottom:12px}
.cs-card p{color:#475067;line-height:1.6;margin-bottom:20px;flex:1}

.checkout-wrap{padding:46px 0 70px;background:var(--gray,#f4f6fa)}
.checkout-wrap .container{max-width:680px}
.checkout-steps{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:8px 22px;margin-bottom:26px;padding:0}
.checkout-steps li{font-size:.85rem;font-weight:600;color:#8a93a6}
.checkout-steps li.done{color:#0d7a3f}
.checkout-steps li.active{color:var(--red)}
.checkout-offer{text-align:center;background:#fff;border:1px solid #e6e9f0;border-radius:14px;padding:22px;margin-bottom:22px}
.co-label{text-transform:uppercase;letter-spacing:2px;font-size:.72rem;font-weight:700;color:var(--red);margin-bottom:4px}
.co-amount{color:var(--navy);font-weight:700;font-size:1.05rem}
.co-big{color:var(--red);font-family:'Montserrat',sans-serif;font-weight:900;font-size:3rem;line-height:1}
.checkout-form{background:#fff;border:1px solid #e6e9f0;border-radius:14px;padding:26px}
.checkout-form h3{color:var(--red);text-align:center;margin-bottom:18px}
.checkout-form input,.checkout-form textarea{width:100%;padding:13px 14px;border:1px solid #d6dbe6;border-radius:9px;margin-bottom:12px;font-size:.95rem;font-family:inherit}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.cf-pick{font-weight:700;color:var(--navy);margin:8px 0 12px}
.cf-programs{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.cf-program{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;border:2px solid #e0e5ef;border-radius:10px;padding:12px 14px;cursor:pointer;transition:.15s}
.cf-program.checked{border-color:var(--red);background:#fff5f5}
.cf-program input{width:auto;margin:0}
.cf-program-name{font-weight:700;color:var(--navy)}
.cf-program-note{grid-column:2;font-size:.8rem;color:#8a93a6}
.cf-program-price{font-weight:900;color:var(--red);font-size:1.15rem}
.btn-pay{font-size:1.05rem;padding:15px}
.cf-secure{text-align:center;color:#0d7a3f;font-weight:600;font-size:.85rem;margin:10px 0 6px}
.cf-terms{display:block;color:#8a93a6;font-size:.72rem;line-height:1.5;text-align:center}

.thankyou{padding:70px 0;background:var(--gray,#f4f6fa);text-align:center}
.thankyou-inner{max-width:560px}
.ty-check{font-size:4rem;color:#0d7a3f;display:block;margin-bottom:10px}
.thankyou h1{color:var(--red);font-size:2.4rem;margin-bottom:8px}
.ty-lead{color:var(--navy);font-size:1.1rem;margin-bottom:28px}
.ty-follow h3{color:var(--red);margin-bottom:4px}
.ty-follow p{color:#475067;margin-bottom:12px}
.ty-social{display:flex;justify-content:center;gap:14px;margin-bottom:28px}
.ty-social a{width:42px;height:42px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;transition:.2s}
.ty-social a:hover{background:var(--red)}
.ty-contact{display:flex;flex-direction:column;gap:3px;color:#475067;margin-bottom:26px;font-size:.95rem}
.ty-contact strong{color:var(--navy)}
@media(max-width:640px){.cs-grid{grid-template-columns:1fr}.cf-row{grid-template-columns:1fr}}

.co-time{text-align:center;background:#eef3ff;color:var(--navy);border-radius:8px;padding:8px 12px;margin-bottom:14px;font-size:.92rem}

/* ---- Old-site pages: Our Classes, Schedule, Locations, Terms, Scheduler ---- */
.sec-title{text-align:center;color:var(--navy);font-size:clamp(1.4rem,2.4vw,2rem);margin-bottom:26px}
/* Our Classes */
.classlist-sec{padding:60px 0}
.cl-row{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center;margin-bottom:48px}
.cl-row:last-child{margin-bottom:0}
.cl-reverse .cl-media{order:2}
.cl-media img{width:100%;border-radius:14px;box-shadow:0 14px 36px rgba(13,27,61,.14);object-fit:cover;aspect-ratio:4/3}
.cl-text h2{color:var(--navy);font-size:1.6rem;margin-bottom:12px}
.cl-text p{color:#475067;line-height:1.7;margin-bottom:20px}
@media(max-width:780px){.cl-row{grid-template-columns:1fr;gap:18px}.cl-reverse .cl-media{order:0}}
/* Schedule */
.schedule-sec{padding:54px 0 70px;background:var(--gray,#f4f6fa)}
.sched-tables{display:flex;flex-direction:column;gap:22px}
.sched-table-wrap{overflow-x:auto;border-radius:12px;box-shadow:0 8px 26px rgba(13,27,61,.07)}
.sched-table{width:100%;border-collapse:collapse;background:#fff;min-width:680px}
.sched-table th{background:var(--navy);color:#fff;font-size:.82rem;font-weight:700;padding:12px 10px;text-align:center;text-transform:uppercase;letter-spacing:.5px}
.sched-table th.st-name,.sched-table td.st-name{text-align:left;min-width:180px}
.sched-table td{padding:12px 10px;text-align:center;border-bottom:1px solid #eef0f5;color:var(--red);font-weight:600;font-size:.9rem}
.sched-table td.st-name{color:var(--navy)}
.sched-table tr:nth-child(even) td{background:#fafbfe}
.st-dash{color:#c2c8d4}
.sched-cta{text-align:center;margin-top:28px}
/* Locations */
.locations-sec{padding:54px 0 70px}
.loc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.loc-card{background:#fff;border:1px solid #e6e9f0;border-radius:14px;overflow:hidden;box-shadow:0 10px 30px rgba(13,27,61,.06);display:flex;flex-direction:column}
.loc-current{border:2px solid var(--red)}
.loc-map iframe{display:block}
.loc-body{padding:20px;display:flex;flex-direction:column;gap:8px;flex:1}
.loc-body h3{color:var(--navy);font-size:1.2rem}
.loc-web{color:var(--red);font-weight:700;font-size:.9rem}
.loc-addr{color:#475067;line-height:1.5;flex:1}
.loc-phone{color:var(--navy);font-weight:700}
.loc-body .btn{margin-top:6px}
@media(max-width:860px){.loc-grid{grid-template-columns:1fr}}
/* Scheduler step */
.scheduler-sec{padding:46px 0 70px;background:var(--gray,#f4f6fa)}
.scheduler-sec .container{max-width:760px}
.sched-pick{background:#fff;border:1px solid #e6e9f0;border-radius:14px;padding:30px;text-align:center}
.sched-pick h3{color:var(--navy);font-size:1.4rem;margin-bottom:6px}
.sched-pick-sub{color:#7a849a;margin-bottom:22px}
.slot-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.slot-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px 12px;border:2px solid #e0e5ef;border-radius:10px;color:var(--navy);font-weight:700;transition:.15s;cursor:pointer}
.slot-btn:hover{border-color:var(--red);background:#fff5f5;color:var(--red)}
.sched-skip{margin-top:20px}
.sched-skip a{color:#8a93a6;font-size:.9rem;text-decoration:underline}
@media(max-width:640px){.slot-grid{grid-template-columns:1fr 1fr}}
/* Terms / legal */
.legal-sec{padding:50px 0 70px}
.legal-body{max-width:860px}
.legal-body h3{color:var(--navy);font-size:1.15rem;margin:22px 0 6px}
.legal-body p{color:#475067;line-height:1.7;margin-bottom:8px}
.legal-body em{color:#8a93a6}

/* ---- Funnel redesign: photos, scheduler card, checkout layout + Stripe ---- */
.cs-card{background:#fff;border:1px solid #e6e9f0;border-radius:16px;overflow:hidden;box-shadow:0 12px 32px rgba(13,27,61,.08);display:flex;flex-direction:column;padding:0}
.cs-photo{aspect-ratio:16/10;background-size:cover;background-position:center top;position:relative}
.cs-age{position:absolute;top:12px;left:12px;background:var(--red);color:#fff;font-size:.72rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:4px 11px;border-radius:999px}
.cs-card-body{padding:22px 24px 24px;display:flex;flex-direction:column;flex:1}
.cs-card-body h3{color:var(--navy);font-size:1.25rem;margin-bottom:10px}
.cs-card-body p{color:#475067;line-height:1.6;margin-bottom:20px;flex:1}
/* Scheduler card */
.sched-card{display:grid;grid-template-columns:300px 1fr;background:#fff;border:1px solid #e6e9f0;border-radius:16px;overflow:hidden;box-shadow:0 12px 32px rgba(13,27,61,.08)}
.sched-card-photo{background-size:cover;background-position:center;min-height:300px}
.sched-card .sched-pick{border:0;padding:30px;text-align:left}
.sched-card .slot-grid{grid-template-columns:repeat(2,1fr)}
@media(max-width:780px){.sched-card{grid-template-columns:1fr}.sched-card-photo{min-height:180px}}
/* Checkout layout */
.checkout-wrap .container.checkout-grid{max-width:1080px;display:grid;grid-template-columns:340px 1fr;gap:28px;align-items:start}
.checkout-offer{position:relative}
.co-img{width:128px;height:auto;margin:0 auto 10px;display:block;border-radius:10px}
.co-prog{margin-top:8px;color:var(--navy);font-weight:700}
.co-prog i,.co-time i{color:var(--red);margin-right:6px}
.co-benefits{display:flex;flex-direction:column;gap:12px;margin-top:18px}
.co-benefit{display:flex;gap:12px;align-items:flex-start;background:#fff;border:1px solid #e6e9f0;border-radius:12px;padding:14px}
.co-benefit-ic{flex:0 0 auto;width:40px;height:40px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1rem}
.co-benefit strong{display:block;color:var(--navy);font-size:.95rem;margin-bottom:2px}
.co-benefit span{font-size:.82rem;color:#6b7488;line-height:1.45}
/* Card field */
.cf-card-label{display:block;font-weight:700;color:var(--navy);margin:8px 0 8px}
.cf-card{border:1px solid #d6dbe6;border-radius:9px;padding:14px;background:#fff}
.cf-card-err{color:var(--red);font-size:.85rem;min-height:18px;margin:6px 0}
.cf-card-pending{background:#fff7e6;border:1px dashed #e0c378;color:#8a6d1f;border-radius:9px;padding:14px;margin:8px 0 4px;font-size:.9rem}
@media(max-width:860px){.checkout-wrap .container.checkout-grid{grid-template-columns:1fr}.checkout-aside{order:2}}

/* ---- Round5: schedule notes + thank-you photo ---- */
.sched-notes{text-align:center;margin-top:30px}
.sched-notes p{color:#475067;margin-bottom:6px;font-size:.95rem}
.sched-notes .sn-big{color:var(--navy);font-weight:800;font-size:1.25rem;font-family:'Montserrat',sans-serif;margin-bottom:10px}
.ty-photo{width:280px;max-width:80%;border-radius:14px;box-shadow:0 14px 36px rgba(13,27,61,.18);margin:0 auto 26px;display:block}

/* ---- Round6: funnel galleries + checkout program photo ---- */
.fgal{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:28px}
.fgal img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:12px;box-shadow:0 10px 26px rgba(13,27,61,.10)}
@media(max-width:680px){.fgal{grid-template-columns:repeat(2,1fr)}}
.co-photo{width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:12px;margin-bottom:14px;display:block}
