/* ─── RESET & BASE ─────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;color:#1a2b4a;background:#fff;font-size:15px;line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{font-family:'DM Sans',sans-serif;cursor:pointer}
input,select,textarea{font-family:'DM Sans',sans-serif}

/* ─── TOKENS ────────────────────────────────────── */
:root{
  --navy:#1a2b4a;
  --navy-light:#243557;
  --blue:#2563a8;
  --orange:#8b2635;
  --orange-light:#b03347;
  --cream:#f7f5f0;
  --cream2:#f0ede6;
  --text:#1a2b4a;
  --muted:#5a6a82;
  --border:rgba(26,43,74,.12);
  --serif:'DM Serif Display',serif;
  --sans:'DM Sans',sans-serif;
  --radius:8px;
  --radius-lg:12px;
  --shadow:0 2px 16px rgba(26,43,74,.08);
  --shadow-lg:0 8px 40px rgba(26,43,74,.14);
  --accent: #8b2635;
  --accent-light: #b03347;
  --accent-hover: #6e1e29;
  --fka-radius: 8px;
  --fka-radius-lg: 12px;
  --fka-navy: #1a2b4a;
  --fka-muted: #5a6a82;
  --fka-border: rgba(26,43,74,.12);
  --fka-cream: #f7f5f0;
  --fka-blue: #2563a8;
  --fka-shadow: 0 2px 16px rgba(26,43,74,.08);
  --fka-shadow-lg: 0 8px 40px rgba(26,43,74,.14);
}
/* ─── LAYOUT ────────────────────────────────────── */
.container{max-width:1100px;margin:0 auto;padding:0 32px width: 100%}
section{padding:72px 0}

/* ─── TYPOGRAPHY ────────────────────────────────── */
.eyebrow{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;font-weight:500;color:var(--orange)}
h1,h2,h3,.serif{font-family:var(--serif)}
h1{font-size:clamp(36px,5vw,56px);line-height:1.08;color:#fff}
h2{font-size:clamp(26px,3vw,36px);line-height:1.15;color:var(--navy)}
h3{font-size:20px;line-height:1.3;color:var(--navy)}
.lead{font-size:17px;color:var(--muted);line-height:1.7}

/* ─── BUTTONS ───────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:11px 24px;border-radius:var(--radius);font-size:14px;font-weight:500;border:none;transition:all .18s}
.btn-primary{background:var(--orange);color:#fff}
.btn-primary:hover{background:#6e1e29;transform:translateY(-1px);box-shadow:0 4px 14px rgba(139,38,53,.35)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:#243557;transform:translateY(-1px)}
.btn-outline-white{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.35)}
.btn-outline-white:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.6)}
.btn-outline{background:transparent;color:var(--navy);border:1.5px solid var(--border)}
.btn-outline:hover{border-color:var(--navy);background:var(--cream)}
.btn-sm{padding:8px 18px;font-size:13px}

/* ─── THEME TOGGLE ──────────────────────────────── */
.theme-toggle{display:inline-flex;align-items:center;gap:6px;padding:5px 10px 5px 5px;border:1px solid var(--border);border-radius:20px;background:var(--cream);cursor:pointer;font-size:12px;font-weight:500;color:var(--muted);transition:all .18s;white-space:nowrap}
.theme-toggle:hover{border-color:var(--navy);color:var(--navy)}
.theme-toggle-dot{width:20px;height:20px;border-radius:50%;background:var(--navy);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .18s}
.theme-toggle-dot svg{width:11px;height:11px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* Dark hero override */
body.theme-dark .hero{background:var(--navy);border-bottom:none}
body.theme-dark .hero-bg-pattern{opacity:.04;background-image:repeating-linear-gradient(45deg,#fff 0,#fff 1px,transparent 0,transparent 50%)}
body.theme-dark .hero-eyebrow{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.12);color:rgba(255,255,255,.8)}
body.theme-dark .hero h1{color:#fff}
body.theme-dark .hero h1 em{color:var(--orange-light)}
body.theme-dark .hero-lead{color:rgba(255,255,255,.72)}
body.theme-dark .hero-stats{border-top-color:rgba(255,255,255,.1)}
body.theme-dark .hero-stat{border-left-color:rgba(255,255,255,.1)}
body.theme-dark .hero-stat-num{color:#fff}
body.theme-dark .hero-stat-label{color:rgba(255,255,255,.5)}
body.theme-dark .hero-feature-card{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.12);box-shadow:none}
body.theme-dark .hero-card-title{color:#fff}
body.theme-dark .hero-card-detail{color:rgba(255,255,255,.5)}
body.theme-dark .hero-card-cta{color:var(--orange-light)}
body.theme-dark .tag-orange{background:rgba(224,123,46,.25);color:var(--orange-light)}
body.theme-dark .tag-blue{background:rgba(37,99,168,.3);color:#7eb6f0}
body.theme-dark .hero-eyebrow-dot{background:var(--orange)}
body.theme-dark .hero-stat-strip{border-top-color:rgba(255,255,255,.1)!important}

/* ─── NAVIGATION ────────────────────────────────── */
.nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:110px;gap:24px}
.nav-logo{display:flex;align-items:center;flex-shrink:0}
.nav-logo img{height:96px;width:auto;display:block}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none}
.nav-links a{padding:6px 14px;font-size:14px;color:var(--muted);border-radius:6px;font-weight:500;transition:all .15s}
.nav-links a:hover,.nav-links a.active{color:var(--navy);background:var(--cream)}
.nav-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav-phone{font-size:13px;color:var(--muted);font-weight:500}
.nav-phone span{color:var(--navy)}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:4px}
.hamburger span{width:22px;height:2px;background:var(--navy);border-radius:2px;transition:.2s}
.mobile-menu{display:none;position:fixed;top:65px;left:0;right:0;background:#fff;border-bottom:1px solid var(--border);padding:16px 24px 24px;z-index:99}
.mobile-menu.open{display:block}
.mobile-menu a{display:block;padding:12px 0;font-size:16px;color:var(--navy);font-weight:500;border-bottom:1px solid var(--border)}

/* ─── HERO ──────────────────────────────────────── */
.hero{background:var(--cream);position:relative;overflow:hidden;padding:0;border-bottom:1px solid var(--border)}
.hero-bg-pattern{position:absolute;inset:0;opacity:.035;background-image:repeating-linear-gradient(45deg,var(--navy) 0,var(--navy) 1px,transparent 0,transparent 50%);background-size:24px 24px}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;padding-top:80px;padding-bottom:0;position:relative;z-index:1}
.hero-content{padding-bottom:80px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(26,43,74,.06);border:1px solid rgba(26,43,74,.12);border-radius:20px;padding:5px 14px;font-size:12px;color:var(--muted);font-weight:500;margin-bottom:24px}
.hero-eyebrow-dot{width:6px;height:6px;background:var(--orange);border-radius:50%}
.hero h1{margin-bottom:20px;color:var(--navy)}
.hero h1 em{color:var(--orange);font-style:italic}
.hero-lead{color:var(--muted);font-size:16px;max-width:480px;margin-bottom:32px;line-height:1.7}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:40px}
.hero-stats{display:flex;gap:0;border-top:1px solid var(--border)}
.hero-stat{padding:28px 32px 28px 0;flex:1}
.hero-stat+.hero-stat{border-left:1px solid var(--border);padding-left:32px}
.hero-stat-num{font-family:var(--serif);font-size:36px;color:var(--navy);line-height:1}
.hero-stat-label{font-size:12px;color:var(--muted);margin-top:4px;letter-spacing:.3px}
.hero-card-stack{padding-bottom:0;display:flex;flex-direction:column;justify-content:flex-end}
.hero-feature-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow);margin-bottom:12px}
.hero-feature-card:last-child{margin-bottom:0}
.hero-card-tag{display:inline-block;font-size:11px;padding:2px 10px;border-radius:20px;font-weight:500;margin-bottom:8px}
.tag-orange{background:rgba(224,123,46,.12);color:var(--orange)}
.tag-blue{background:rgba(37,99,168,.1);color:var(--blue)}
.hero-card-title{font-size:14px;font-weight:500;color:var(--navy);margin-bottom:2px}
.hero-card-detail{font-size:12px;color:var(--muted)}
.hero-card-cta{font-size:12px;color:var(--orange);font-weight:500;margin-top:10px;display:inline-flex;align-items:center;gap:4px}
.hero-card-cta:hover{color:var(--navy)}

/* ─── TRUST STRIP ───────────────────────────────── */
.trust-strip{background:var(--cream);border-bottom:1px solid var(--border);padding:16px 0;overflow:hidden}
.trust-strip-inner{display:flex;align-items:center;gap:28px}
.trust-label{font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--muted);font-weight:500;white-space:nowrap;flex-shrink:0}
.trust-divider{width:1px;height:20px;background:var(--border);flex-shrink:0}
.trust-logos{display:flex;gap:32px;align-items:center;overflow:hidden}
.trust-logo{font-size:13px;font-weight:500;color:var(--navy);opacity:.45;white-space:nowrap;transition:opacity .2s}
.trust-logo:hover{opacity:.85}

/* ─── TESTIMONIAL BAR ───────────────────────────── */
.tbar{background:var(--orange);padding:16px 0}
.tbar-inner{display:flex;align-items:center;gap:20px}
.tbar-icon{font-family:var(--serif);font-size:36px;color:rgba(255,255,255,.3);line-height:1;flex-shrink:0}
.tbar-quote{font-family:var(--serif);font-size:17px;font-style:italic;color:#fff;flex:1}
.tbar-attr{flex-shrink:0;text-align:right}
.tbar-name{font-size:13px;font-weight:500;color:#fff}
.tbar-company{font-size:12px;color:rgba(255,255,255,.7)}
.tbar-stars{color:rgba(255,255,255,.85);font-size:13px;margin-bottom:2px}

/* ─── SECTION HEADER ────────────────────────────── */
.section-header{margin-bottom:40px}
.section-header .eyebrow{display:block;margin-bottom:10px}
.section-header h2{margin-bottom:10px}
.section-header .lead{max-width:560px}
.section-header.centered{text-align:center}
.section-header.centered .lead{margin:0 auto}

/* ─── PROGRAM CARDS ─────────────────────────────── */
.programs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.prog-card{border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}
.prog-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--radius-lg) var(--radius-lg) 0 0;transition:opacity .2s;opacity:0}
.prog-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.prog-card:hover::before{opacity:1}
.prog-card.delivery::before{background:var(--blue)}
.prog-card.design::before{background:var(--orange)}
.prog-card.performance::before{background:#1a6b45}
.prog-card.evaluation::before{background:#5a2a9a}
.prog-tag{display:inline-block;font-size:13px;padding:6px 16px;border-radius:20px;font-weight:500;margin-bottom:14px}
.tag-delivery{background:#e3edf8;color:#1a5ca8}
.tag-design{background:#fdeede;color:#a0500a}
.tag-performance{background:#e3f2ec;color:#1a6b45}
.tag-evaluation{background:#f0e8f8;color:#5a2a9a}
.prog-name{font-family:var(--serif);font-size:19px;color:var(--navy);margin-bottom:8px;line-height:1.25}
.prog-desc{font-size:14px;color:var(--muted);margin-bottom:18px;line-height:1.6}
.prog-footer{display:flex;justify-content:space-between;align-items:center;padding-top:14px;border-top:1px solid var(--border)}
.prog-meta{font-size:12px;color:var(--muted)}
.prog-meta strong{color:var(--navy);font-weight:500}
.prog-link{font-size:13px;color:var(--blue);font-weight:500;display:flex;align-items:center;gap:4px}
.prog-link:hover{color:var(--navy)}

/* ─── SCHEDULE ──────────────────────────────────── */
.schedule-section{background:var(--cream);scroll-margin-top:120px}
.schedule-list{display:flex;flex-direction:column;gap:12px}
.session-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 24px;display:flex;align-items:center;gap:20px;transition:all .2s}
.session-card:hover{box-shadow:var(--shadow);border-color:rgba(26,43,74,.2)}
.session-date{width:52px;text-align:center;flex-shrink:0}
.session-month{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--orange);font-weight:500}
.session-day{font-family:var(--serif);font-size:28px;color:var(--navy);line-height:1.1}
.session-divider{width:1px;height:44px;background:var(--border);flex-shrink:0}
.session-info{flex:1;min-width:0}
.session-detail{font-size:13px;color:var(--muted);margin-top:2px}
.session-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:2px 9px;border-radius:10px;background:#e3edf8;color:#1a5ca8;font-weight:500;margin-left:8px}
.session-badge.online::before{content:'';width:5px;height:5px;background:#1a9a6a;border-radius:50%;flex-shrink:0}
.session-right{display:flex;align-items:center;gap:16px;flex-shrink:0}
.session-price{text-align:right}
.session-price-amount{font-family:var(--serif);font-size:20px;color:var(--navy)}
.session-price-note{font-size:11px;color:var(--muted)}
.session-btn {
  background: var(--accent);
  color: #fff;
  border: none;
  padding: 10px 20px;
  border-radius: var(--fka-radius);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  white-space: nowrap;
  transition: all .18s;
  text-decoration: none;
  display: inline-block;
}
.session-btn:hover {
  background: var(--accent-hover);
  transform: translateY(-1px);
}.session-guide-link{font-size:12px;color:var(--blue);font-weight:500;white-space:nowrap;background:none;border:1px solid var(--border);padding:10px 14px;border-radius:var(--radius);cursor:pointer;transition:all .18s}
.session-guide-link:hover{border-color:var(--blue);background:var(--cream)}
.schedule-cta{margin-top:28px;text-align:center}

/* ─── WHY FKA ────────────────────────────────────── */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:0}
.why-card{padding:28px;border-radius:var(--radius-lg);background:var(--cream)}
.why-icon{width:44px;height:44px;border-radius:10px;background:var(--navy);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.why-icon svg{width:22px;height:22px;color:#fff;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.why-card h3{font-size:16px;margin-bottom:8px}
.why-card p{font-size:14px;color:var(--muted);line-height:1.6}

/* ─── TESTIMONIALS ──────────────────────────────── */
.testimonials-section{background:var(--navy);color:#fff}
.testimonials-section h2{color:#fff}
.testimonials-section .lead{color:rgba(255,255,255,.6)}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.testimonial-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:24px}
.testimonial-stars{color:var(--orange-light);font-size:14px;margin-bottom:12px;letter-spacing:2px}
.testimonial-quote{font-family:var(--serif);font-size:16px;font-style:italic;color:rgba(255,255,255,.9);line-height:1.5;margin-bottom:16px}
.testimonial-attr{display:flex;align-items:center;gap:10px;border-top:1px solid rgba(255,255,255,.1);padding-top:14px}
.testimonial-avatar{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;color:rgba(255,255,255,.7);flex-shrink:0}
.testimonial-name{font-size:13px;font-weight:500;color:#fff}
.testimonial-company{font-size:12px;color:rgba(255,255,255,.45)}

/* ─── REGISTRATION ──────────────────────────────── */
.reg-section{background:#fff}
.reg-layout{display:grid;grid-template-columns:1fr 1.5fr;gap:56px;align-items:start}
.reg-left h2{margin-bottom:14px}
.reg-left p{color:var(--muted);margin-bottom:28px;line-height:1.7}
.reg-trust-list{display:flex;flex-direction:column;gap:12px;margin-bottom:32px}
.reg-trust-item{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--muted);line-height:1.5}
.reg-trust-dot{width:20px;height:20px;border-radius:50%;background:var(--cream2);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.reg-trust-dot svg{width:10px;height:10px;stroke:var(--orange);stroke-width:2.5;fill:none;stroke-linecap:round;stroke-linejoin:round}
.reg-form-card{background:#fff;border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-lg)}
.reg-form-header{background:var(--navy);padding:20px 24px}
.reg-form-header-name{font-family:var(--serif);font-size:17px;color:#fff}
.reg-form-header-dates{font-size:13px;color:rgba(255,255,255,.6);margin-top:4px}
.reg-form-header-price{font-family:var(--serif);font-size:24px;color:#fff;margin-top:12px}
.reg-form-header-price span{font-family:var(--sans);font-size:12px;color:rgba(255,255,255,.5);font-weight:400}
.reg-form-body{padding:24px}
.form-row{margin-bottom:16px}
.form-row label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:1.2px;color:var(--muted);margin-bottom:5px;font-weight:500}
.form-row input,.form-row select{width:100%;padding:10px 13px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;color:var(--text);background:#fff;transition:border .15s;outline:none}
.form-row input:focus,.form-row select:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,168,.1)}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-section-label{font-size:12px;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:1px;padding:4px 0 12px;border-bottom:1px solid var(--border);margin-bottom:16px}
.voucher-row{display:flex;gap:8px}
.voucher-row input{flex:1}
.voucher-btn{padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--cream);font-size:13px;color:var(--muted);white-space:nowrap}
.stripe-badge{display:flex;align-items:center;gap:8px;background:var(--cream);border-radius:var(--radius);padding:10px 14px;font-size:12px;color:var(--muted);margin-bottom:14px}
.stripe-logo{font-size:13px;font-weight:700;color:#635bff}
.stripe-lock{font-size:13px}
.submit-btn{width:100%;background:var(--orange);color:#fff;border:none;padding:14px;border-radius:var(--radius);font-size:15px;font-weight:500;cursor:pointer;transition:all .18s;display:flex;align-items:center;justify-content:center;gap:8px}
.submit-btn:hover{background:#c96a1e;transform:translateY(-1px);box-shadow:0 4px 14px rgba(224,123,46,.35)}
.form-footer-note{font-size:12px;color:var(--muted);text-align:center;margin-top:10px}

/* ─── ABOUT STRIP ───────────────────────────────── */
.about-strip{background:var(--cream2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:56px 0}
.about-layout{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.about-content .eyebrow{display:block;margin-bottom:12px}
.about-content h2{margin-bottom:16px}
.about-content p{color:var(--muted);font-size:15px;line-height:1.75;margin-bottom:20px}
.about-pillars{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.about-pillar{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--navy)}
.about-pillar::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--orange);flex-shrink:0}
.about-image-placeholder{background:var(--navy);border-radius:16px;height:320px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.about-image-pattern{position:absolute;inset:0;opacity:.05;background-image:repeating-linear-gradient(45deg,#fff 0,#fff 1px,transparent 0,transparent 20px);background-size:20px 20px}
.about-image-text{position:relative;z-index:1;text-align:center}
.about-image-number{font-family:var(--serif);font-size:72px;color:#fff;line-height:1;opacity:.9}
.about-image-label{font-size:14px;color:rgba(255,255,255,.6);margin-top:4px}

/* ─── BLOG STRIP ────────────────────────────────── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-card{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);transition:all .2s}
.blog-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.blog-card-img{height:180px;background:var(--navy);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.blog-card-img-bg{position:absolute;inset:0;opacity:.05;background-image:repeating-linear-gradient(45deg,#fff 0,#fff 1px,transparent 0,transparent 20px);background-size:20px 20px}
.blog-card-img-label{position:relative;z-index:1;font-family:var(--serif);font-size:14px;color:rgba(255,255,255,.5);font-style:italic}
.blog-card-body{padding:20px}
.blog-cat{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--orange);font-weight:500;margin-bottom:8px}
.blog-title{font-family:var(--serif);font-size:17px;color:var(--navy);line-height:1.3;margin-bottom:8px}
.blog-excerpt{font-size:13px;color:var(--muted);line-height:1.6;margin-bottom:14px}
.blog-meta{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:8px}
.blog-meta-dot{width:3px;height:3px;border-radius:50%;background:var(--border)}

/* ─── VOICE AI WIDGET ───────────────────────────── */
.voice-widget{position:fixed;bottom:28px;right:28px;z-index:200}
.voice-btn{width:56px;height:56px;border-radius:50%;background:var(--orange);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(224,123,46,.5);transition:all .2s}
.voice-btn:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(224,123,46,.6)}
.voice-btn svg{width:24px;height:24px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.voice-tooltip{position:absolute;bottom:68px;right:0;background:var(--navy);color:#fff;font-size:12px;white-space:nowrap;padding:6px 12px;border-radius:6px;pointer-events:none;opacity:0;transition:opacity .2s}
.voice-tooltip::after{content:'';position:absolute;top:100%;right:18px;border:5px solid transparent;border-top-color:var(--navy)}
.voice-widget:hover .voice-tooltip{opacity:1}

/* ─── FOOTER ────────────────────────────────────── */
footer{background:var(--navy);color:rgba(255,255,255,.6)}
.footer-top{padding:56px 0 40px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px}
.footer-brand{font-family:var(--serif);font-size:20px;color:#fff;margin-bottom:10px}
.footer-tagline{font-size:13px;color:rgba(255,255,255,.5);line-height:1.6;max-width:240px;margin-bottom:16px}
.footer-contact{font-size:13px;line-height:2}
.footer-contact a{color:rgba(255,255,255,.6);transition:color .15s}
.footer-contact a:hover{color:#fff}
.footer-col-title{font-size:12px;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.4);font-weight:500;margin-bottom:14px}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-links a{font-size:13px;color:rgba(255,255,255,.6);transition:color .15s}
.footer-links a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:20px 0;display:flex;justify-content:space-between;align-items:center}
.footer-legal{font-size:12px}
.footer-legal a{color:rgba(255,255,255,.45);margin-left:16px;transition:color .15s}
.footer-legal a:hover{color:#fff}

/* ─── PAGE SECTIONS (SPA routing) ──────────────── */
.page{display:none}
.page.active{display:block}

/* ─── PAGE: PROGRAMS ────────────────────────────── */
.page-hero{background:var(--navy);padding:64px 0 56px;text-align:center}
.page-hero h1{font-size:clamp(28px,4vw,44px);margin-bottom:12px}
.page-hero p{color:rgba(255,255,255,.65);font-size:16px;max-width:560px;margin:0 auto}
.programs-full-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.prog-full-card{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:all .2s;cursor:pointer}
.prog-full-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.prog-full-card-header{padding:20px;border-bottom:1px solid var(--border)}
.prog-full-card-body{padding:20px}
.prog-upcoming-count{display:inline-flex;align-items:center;gap:4px;font-size:11px;padding:3px 9px;border-radius:10px;background:var(--cream);color:var(--muted);font-weight:500}
.prog-upcoming-count.has-dates{background:#e3f2ec;color:#1a6b45}

/* ─── PAGE: ABOUT ───────────────────────────────── */
.about-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:48px}
.about-stat-card{text-align:center;padding:32px 20px;background:var(--cream);border-radius:var(--radius-lg)}
.about-stat-card .num{font-family:var(--serif);font-size:40px;color:var(--navy)}
.about-stat-card .lbl{font-size:13px;color:var(--muted);margin-top:4px}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
.team-card{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.team-avatar{height:160px;background:var(--navy);display:flex;align-items:center;justify-content:center}
.team-initials{font-family:var(--serif);font-size:40px;color:rgba(255,255,255,.35)}
.team-info{padding:18px}
.team-name{font-family:var(--serif);font-size:17px;color:var(--navy)}
.team-role{font-size:13px;color:var(--muted);margin-top:2px}

/* ─── PAGE: CONTACT ─────────────────────────────── */
.contact-layout{display:grid;grid-template-columns:1fr 1.4fr;gap:56px}
.contact-info h3{font-size:18px;margin-bottom:6px}
.contact-info p{color:var(--muted);font-size:14px;margin-bottom:24px}
.contact-item{display:flex;gap:12px;align-items:flex-start;margin-bottom:20px}
.contact-item-icon{width:40px;height:40px;border-radius:10px;background:var(--cream);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-item-icon svg{width:18px;height:18px;stroke:var(--navy);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.contact-item-text{font-size:14px;color:var(--navy)}
.contact-item-label{font-size:12px;color:var(--muted)}
.contact-form-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow)}
.contact-form-card textarea{width:100%;padding:10px 13px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;color:var(--text);background:#fff;resize:vertical;min-height:120px;outline:none;transition:border .15s}
.contact-form-card textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,168,.1)}

/* ─── RESPONSIVE ────────────────────────────────── */
@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr}
  .hero-card-stack{display:none}
  .reg-layout{grid-template-columns:1fr}
  .about-layout{grid-template-columns:1fr}
  .about-image-placeholder{display:none}
  .footer-top{grid-template-columns:1fr 1fr}
  .testimonials-grid{grid-template-columns:1fr}
  .programs-full-grid{grid-template-columns:1fr 1fr}
  .about-stats-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav-links,.nav-phone{display:none}
  .hamburger{display:flex}
  .programs-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .programs-full-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .session-card{flex-wrap:wrap}
  .session-right{width:100%;justify-content:flex-end}
  .tbar-inner{flex-direction:column;text-align:center}
  .footer-top{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .about-stats-grid{grid-template-columns:1fr 1fr}
  .contact-layout{grid-template-columns:1fr}
  .container{padding:0 20px}
}

/* ─── UTILITIES ─────────────────────────────────── */
.mt-8{margin-top:8px}
.mt-16{margin-top:16px}
.mt-24{margin-top:24px}
.mt-32{margin-top:32px}
.text-center{text-align:center}
.text-orange{color:var(--orange)}
.divider{height:1px;background:var(--border);margin:0}

.fka-footer-bottom {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  flex-direction: row !important;
  width: 100%;
}

.fka-footer-legal a {
  margin-left: 16px;
}

.fka-footer-bottom span {
  flex: 1;
}

.fka-footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
}

.fka-footer-links a {
  color: rgba(255,255,255,0.6);
  text-decoration: none;
}
.fka-footer-links a:hover {
  color: #ffffff;
}
.fka-footer-col-title {
  color: rgba(255,255,255,0.4);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  font-weight: 500;
  margin-bottom: 14px;
}

/* ─── TRUST STRIP SCROLL ─────────────────────── */
.trust-strip {
  background: var(--fka-cream);
  border-bottom: 1px solid var(--fka-border);
  padding: 14px 0;
  overflow: hidden;
}
.trust-strip-inner {
  display: flex;
  align-items: center;
  gap: 20px;
}
.trust-label-wrap {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-shrink: 0;
  padding-left: 32px;
}
.trust-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--fka-muted);
  font-weight: 500;
  white-space: nowrap;
}
.trust-divider {
  width: 1px;
  height: 20px;
  background: var(--fka-border);
  flex-shrink: 0;
}
.trust-scroll-outer {
  overflow: hidden;
  flex: 1;
  /* Fade edges */
  -webkit-mask-image: linear-gradient(to right, transparent, black 5%, black 95%, transparent);
  mask-image: linear-gradient(to right, transparent, black 5%, black 95%, transparent);
}
.trust-scroll-track {
  display: flex;
  align-items: center;
  gap: 48px;
  width: max-content;
  animation: trust-scroll 30s linear infinite;
}
.trust-scroll-track:hover {
  animation-play-state: paused;
}
.trust-logo-img {
  height: 40px;
  width: auto;
  opacity: 0.65;
  transition: opacity 0.2s;
}
.trust-logo-img:hover {
  opacity: 1;
  }

@keyframes trust-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

.trust-strip {
  padding: 24px 0;
}

.section-header h2,
.section-header.centered h2 {
  font-size: clamp(28px, 3.5vw, 42px);
}

.eyebrow {
  font-size: 20px;
  letter-spacing: 2px;
}

.testimonial-stars {
  color: #c9a227;
}

.nav-links a {
  font-size: 16px;
}

.nav-phone {
  font-size: 15px;
}
.nav-btn {
  font-size: 15px;
}

.session-card {
  display: flex;
  align-items: center;
  gap: 20px;
  background: #fff;
  border: 1px solid var(--fka-border);
  border-radius: var(--fka-radius-lg);
  padding: 18px 24px;
  transition: all 0.2s;
}
.session-card:hover {
  box-shadow: var(--fka-shadow);
  border-color: rgba(26,43,74,0.2);
}
.session-info {
  flex: 1;
  min-width: 0;
}
.session-right {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-shrink: 0;
}
.session-date {
  width: 52px;
  text-align: center;
  flex-shrink: 0;
}
.session-divider {
  width: 1px;
  height: 44px;
  background: var(--fka-border);
  flex-shrink: 0;
}
.session-month {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--accent);
  font-weight: 500;
}
.session-day {
  font-family: 'DM Serif Display', serif;
  font-size: 28px;
  color: var(--fka-navy);
  line-height: 1.1;
}
.session-name {
  font-size: 15px;
  font-weight: 500;
  color: var(--fka-navy);
}
.session-detail {
  font-size: 13px;
  color: var(--fka-muted);
  margin-top: 2px;
}
.session-price-amount {
  font-family: 'DM Serif Display', serif;
  font-size: 20px;
  color: var(--fka-navy);
  text-align: right;
}
.session-price-note {
  font-size: 11px;
  color: var(--fka-muted);
  text-align: right;
}
.session-btn {
  background: var(--fka-navy);
  color: #fff;
  border: none;
  padding: 10px 20px;
  border-radius: var(--fka-radius);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  white-space: nowrap;
  text-decoration: none;
  transition: all 0.18s;
  display: inline-block;
}
.session-btn:hover {
  background: var(--accent);
  transform: translateY(-1px);
}
.session-guide-link {
  font-size: 12px;
  color: var(--fka-blue);
  font-weight: 500;
  white-space: nowrap;
  background: none;
  border: 1px solid var(--fka-border);
  padding: 10px 14px;
  border-radius: var(--fka-radius);
  cursor: pointer;
  text-decoration: none;
  transition: all 0.18s;
  display: inline-block;
}
.session-guide-link:hover {
  border-color: var(--fka-blue);
  background: var(--fka-cream);
}

.schedule-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}