/* ============================================================
   UNACADEMY COIMBATORE - STYLES
   Consolidated, no duplicates, fully responsive
   ============================================================ */

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:root {
  --green: #00B375;
  --green-dark: #06A36E;
  --blue: #2678BE;
  --navy: #0A0F2E;
  --white: #ffffff;
  --off: #F5F6FF;
  --text: #1A1D3D;
  --muted: #6B7280;
  --border: #E5E7EB;
  --gold: #FFD768;
  --black: #3c4a54;
  --gray: #E7F0FA;
}

html { scroll-behavior: smooth; }

body {
  font-family: 'Inter', sans-serif;
  background: var(--white);
  color: var(--text);
  line-height: 1.6;
  overflow-x: hidden;
}

img { max-width: 100%; height: auto; }

/* ============ NAVBAR ============ */
.navbar {
  width: 100%;
  background: #ffffff;
  border-bottom: 1px solid #e5e7eb;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 10px 20px;
}
.navbar img { height: 65px; width: auto; display: block; }


.pill{
  display:inline-block;
  padding:12px 24px;
  background:#00B375;
  color:#fff;
  border-radius:50px;
  text-decoration:none; /* removes underline */
  font-weight:600;
}
/* ============ HERO ============ */
.hero {
  background-color: #2678BE;
  padding: 70px 40px 60px;
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 60px;
  align-items: center;
  min-height: 500px;
  position: relative;
  overflow: hidden;
}
.hero::before {
  content: '';
  position: absolute;
  top: -80px; right: -80px;
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(8,189,128,.15) 0%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}
.hero-content { min-width: 0; }
.hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(8,189,128,.15); border: 1px solid rgba(8,189,128,.4);
  border-radius: 100px; padding: 6px 16px;
  font-size: 13px; font-weight: 600; color: var(--gold); margin-bottom: 20px;
}
.hero-badge::before {
  content: ''; width: 8px; height: 8px;
  background: var(--gold); border-radius: 50%;
  animation: pulse 1.8s infinite;
}
@keyframes pulse {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:.5; transform:scale(1.3); }
}
.hero h1 {
  font-family: 'Sora', sans-serif; font-size: 44px; font-weight: 800;
  color: white; line-height: 1.15; margin-bottom: 16px;
}
.hero h1 span { color: var(--gold); }
.hero p { color: rgba(255,255,255,.85); font-size: 17px; line-height: 1.7; max-width: 520px; margin-bottom: 32px; }
.hero-pills { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 32px; }
.hero-pills .pill {
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15);
  border-radius: 100px; padding: 7px 18px; color: white; font-size: 13px; font-weight: 500;
}
.stats-row { display: flex; flex-wrap: wrap; gap: 32px; }
.stat { color: white; }
.stat-num { font-family:'Sora',sans-serif; font-size:26px; font-weight:800; color:var(--gold); display:block; }
.stat-label { font-size:12px; color:rgba(255,255,255,.7); }

/* ============ LEAD FORM ============ */
.lead-form {
  background: white; border-radius: 16px; padding: 32px 28px;
  box-shadow: 0 24px 60px rgba(0,0,0,.25); width: 100%; max-width: 420px;
}
.lead-form h2 { font-family:'Sora',sans-serif; font-size:22px; font-weight:700; color:var(--text); margin-bottom:4px; }
.lead-form .sub { font-size:13px; color:var(--muted); margin-bottom:22px; }
.form-group { margin-bottom: 14px; }
.form-group label { display:block; font-size:12px; font-weight:600; color:var(--text); margin-bottom:6px; text-transform:uppercase; letter-spacing:.05em; }
.form-group input,
.form-group select {
  width:100%; padding:11px 14px; border:1.5px solid var(--border); border-radius:9px;
  font-size:14px; font-family:'Inter',sans-serif; color:var(--text); background:white; outline:none; transition:border-color .2s;
}
.form-group input:focus,
.form-group select:focus { border-color: var(--green); }
.form-group input::placeholder { color:#9CA3AF; }
.cta-btn {
  width:100%; background:var(--green); color:white; font-size:16px; font-weight:700;
  font-family:'Sora',sans-serif; padding:14px; border-radius:10px; border:none; cursor:pointer; margin-top:6px; transition:background .2s,transform .1s;
}
.cta-btn:hover:not(:disabled) { background:var(--green-dark); transform:translateY(-1px); }
.cta-btn:active:not(:disabled) { transform:translateY(0); }
.cta-btn:disabled { opacity:.7; cursor:not-allowed; }
.form-status { text-align:center; font-size:13px; margin-top:12px; min-height:18px; font-weight:500; line-height:1.5; padding:0 8px; }
.form-status.success { color:var(--green-dark); }
.form-status.error { color:#d33; }
.form-note { text-align:center; font-size:13px; color:var(--black); margin-top:0; }
.honeypot { position:absolute; left:-9999px; width:1px; height:1px; opacity:0; overflow:hidden; pointer-events:none; }

/* ============ TRUST BAR ============ */
.trust-bar {
  background:var(--off); padding:18px 40px;
  display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:48px;
  border-bottom:1px solid var(--border);
}
.trust-item { display:flex; align-items:center; gap:10px; font-size:13px; font-weight:600; color:var(--text); }
.trust-icon {
  width:28px; height:28px; border-radius:50%; background:var(--green);
  display:flex; align-items:center; justify-content:center; color:white; font-size:14px; flex-shrink:0;
}

/* ============ WORKSHOP / VIDEO SECTION ============ */
.container { max-width:1200px; margin:0 auto; padding:80px 20px 50px; }
.eyebrow-green { text-align:center; color:#2bb673; font-size:18px; font-weight:500; margin-bottom:14px; }
.headline { text-align:center; font-size:40px; font-weight:800; color:#0f1c2e; line-height:1.25; max-width:900px; margin:0 auto 50px; }
.content { display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:center; }
.video-wrapper { position:relative; width:100%; padding-bottom:56.25%; border-radius:8px; overflow:hidden; box-shadow:0 4px 20px rgba(0,0,0,.08); }
.video-wrapper iframe { position:absolute; top:0; left:0; width:100%; height:100%; border:none; }
.info { display:flex; flex-direction:column; gap:16px; }
.info .pill { background:#E7F0FA; border-radius:10px; padding:18px 22px; color:#0f1c2e; }
.date-pill { display:flex; align-items:center; gap:16px; }
.date-pill .icon { width:44px; height:44px; flex-shrink:0; }
.date-pill .date-text .day { font-size:18px; font-weight:600; }
.date-pill .date-text .time { font-size:14px; margin-top:4px; color:#1a2a3d; }
.meta-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.meta-pill { text-align:center; }
.meta-pill .label { font-size:16px; margin-bottom:6px; }
.meta-pill .value { font-size:16px; font-weight:700; }
.register-btn {
  display:block; width:100%; padding:18px;
  background:linear-gradient(180deg,#1f7a44 0%,#0a3d1f 100%);
  color:#fff; border:none; border-radius:10px; font-size:18px; font-weight:700;
  cursor:pointer; text-align:center; transition:transform .15s,box-shadow .15s;
}
.register-btn:hover { transform:translateY(-2px); box-shadow:0 8px 20px rgba(10,61,31,.25); }
#offer-timer { text-align:center; font-size:14px; margin-top:10px; color:#000; }

/* ============ TRACK RECORD TABLE ============ */
.track-record { max-width:1200px; margin:40px auto; padding:0 20px; }
.track-title { font-size:22px; font-weight:700; color:#0a1f2c; margin-bottom:16px; }
.record-table { width:100%; border-collapse:collapse; background:#fff; }
.record-table th,
.record-table td { border:1px solid #333; padding:16px 20px; font-size:16px; color:#0a1f2c; }
.record-table th { font-weight:700; text-align:center; font-size:18px; }
.record-table td { text-align:center; }
.record-table .exam-name { font-weight:700; text-align:left; white-space:nowrap; }

/* ============ TAGLINE QUOTE ============ */
.tagline-quote { padding-top:20px; font-size:15px; max-width:900px; margin:0 auto; line-height:1.6; color:var(--green); }

/* ============ ACCORDION ============ */
.main-wrapper { max-width:1200px; margin:40px auto; padding:0 20px; display:grid; grid-template-columns:420px 1fr; gap:60px; align-items:flex-start; }
.left-image img { width:100%; display:block; border-radius:4px; }
.accordion { background:#2f80c7; overflow:hidden; border-radius:4px; }
.accordion-item { border-bottom:1px solid rgba(255,255,255,.15); }
.accordion-header {
  width:100%; border:none; outline:none; background:#2f80c7; color:#ffe76a;
  font-size:16px; font-weight:700; padding:22px 24px; text-align:left; cursor:pointer;
  display:flex; align-items:center; gap:12px; transition:background .3s; font-family:inherit;
}
.accordion-header:hover { background:#2b74b5; }
.accordion-header .icon { color:#000; font-size:18px; font-weight:bold; line-height:1; flex-shrink:0; }
.accordion-content { background:#fff; color:#6d6d6d; font-size:15px; line-height:1.9; padding:24px; display:none; }
.accordion-item.active .accordion-content { display:block; }

/* ============ SECTIONS ============ */
.section { padding:60px 20px; }
.section-off { background:var(--off); }
.section-header { text-align:center; margin-bottom:40px; padding:0 20px; }
.section-tag { font-size:12px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--green); margin-bottom:10px; }
.spaced-tag { padding-top:50px; }
.section-header h2 { font-family:'Sora',sans-serif; font-size:32px; font-weight:800; color:var(--text); }
.features-bg .section-header h2 { color:white; }
.features-bg .section-tag { color:#FFD768; }

/* ============ COURSES ============ */
.courses-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; max-width:960px; margin:0 auto; }
.course-card { border-radius:14px; padding:28px 24px; border:1.5px solid var(--border); background:white; transition:box-shadow .2s,transform .2s; cursor:pointer; }
.course-card:hover { box-shadow:0 8px 32px rgba(0,0,0,.1); transform:translateY(-3px); }
.course-card.featured { background:#2678BE; border-color:var(--navy); color:white; }
.course-icon { width:50px; height:50px; border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:22px; margin-bottom:16px; }
.course-card:not(.featured) .course-icon { background:var(--off); }
.course-card.featured .course-icon { background:rgba(255,255,255,.1); }
.course-card h3 { font-family:'Sora',sans-serif; font-size:18px; font-weight:700; margin-bottom:8px; }
.course-card p { font-size:13px; color:var(--muted); line-height:1.6; margin-bottom:16px; }
.course-card.featured p { color:rgba(255,255,255,.85); }
.course-tags { display:flex; flex-wrap:wrap; gap:6px; }
.tag { font-size:11px; font-weight:600; padding:4px 10px; border-radius:100px; background:var(--off); color:var(--text); }
.course-card.featured .tag { background:rgba(255,255,255,.15); color:white; }

/* ============ FEATURES ============ */
.features-bg { background:#2678BE; padding:60px 20px; }
.features-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; max-width:1200px; margin:0 auto; }
.feature-card { background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); border-radius:14px; padding:24px 20px; text-align:center; }
.feature-num { font-family:'Sora',sans-serif; font-size:18px; font-weight:800; color:#FFD768; margin-bottom:6px; }
.feature-label { font-size:14px; color:rgba(255,255,255,.75); font-weight:500; line-height:1.5; }

/* ============ FACILITIES PAGE ============ */
.page { max-width:1200px; margin:0 auto; padding:64px 32px 96px; }
.eyebrow { font-size:12px; font-weight:500; letter-spacing:.1em; color:#6b6b66; text-transform:uppercase; margin:0 0 8px; }
.facilities-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-bottom:64px; }
.facility-card { background:#fff; border:1px solid rgba(0,0,0,.08); border-radius:12px; padding:24px; transition:border-color .2s,transform .2s; }
.facility-card:hover { border-color:rgba(0,0,0,.16); transform:translateY(-2px); }
.facility-head { display:flex; align-items:center; gap:14px; margin-bottom:14px; }
.icon-wrap { width:40px; height:40px; border-radius:10px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.icon-wrap i { font-size:22px; }
.icon-teal { background:#E1F5EE; }
.icon-teal i { color:#0F6E56; }
.icon-amber { background:#FAEEDA; }
.icon-amber i { color:#854F0B; }
.facility-title { font-size:16px; font-weight:500; margin:0; color:#1a1a1a; }
.facility-desc { font-size:14px; color:#5f5e5a; margin:0; line-height:1.6; }

/* ============ TESTIMONIAL (single) ============ */
.testimonial { background:#f1efe8; border-radius:16px; padding:40px 48px; position:relative; }
.testimonial .quote-mark { position:absolute; top:24px; left:32px; font-size:40px; color:#1D9E75; opacity:.35; }
.testimonial-text { font-family:'Source Serif 4',Georgia,serif; font-style:italic; font-size:20px; line-height:1.6; color:#1a1a1a; margin:0 0 20px; padding-left:56px; max-width:800px; }
.testimonial-attr { display:flex; align-items:center; gap:12px; padding-left:56px; }
.avatar-sm { width:36px; height:36px; border-radius:50%; background:#E1F5EE; color:#0F6E56; display:flex; align-items:center; justify-content:center; font-weight:500; font-size:13px; }
.attr-name { font-size:14px; font-weight:500; margin:0; color:#1a1a1a; }
.attr-meta { font-size:13px; color:#6b6b66; margin:0; }

/* ============ MARQUEE ============ */
.marquee {
  width:100%; overflow:hidden; padding:20px 0; background:#f8f8f8;
  -webkit-mask-image:linear-gradient(to right,transparent,#000 10%,#000 90%,transparent);
  mask-image:linear-gradient(to right,transparent,#000 10%,#000 90%,transparent);
}
.marquee-track { display:flex; gap:20px; width:max-content; animation:scroll 30s linear infinite; }
.marquee-track img { width:320px; height:400px; object-fit:cover; border-radius:12px; flex-shrink:0; }
.marquee:hover .marquee-track { animation-play-state:paused; }
@keyframes scroll {
  from { transform:translateX(0); }
  to   { transform:translateX(-50%); }
}

/* ============ IMAGE PAIR ============ */
.image-pair { display:grid; grid-template-columns:1fr 1fr; gap:20px; max-width:1000px; margin:40px auto; padding:0 20px; }
.image-card { border-radius:12px; overflow:hidden; box-shadow:0 4px 16px rgba(0,0,0,.1); }
.image-card img { width:100%; height:100%; object-fit:cover; display:block; }

/* ============ FAQ ============ */
.faq-header { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:end; margin-bottom:48px; }
.faq-title { font-family:'Sora',sans-serif; font-size:36px; font-weight:700; margin:0; color:#1a1a1a; letter-spacing:-.02em; line-height:1.15; }
.header-note { font-size:15px; color:#5f5e5a; margin:0; line-height:1.6; }
.faq-list { display:flex; flex-direction:column; gap:14px; }
.faq-item { background:#fff; border:1px solid rgba(0,0,0,.08); border-radius:14px; overflow:hidden; transition:border-color .2s,box-shadow .2s; }
.faq-item:hover { border-color:rgba(0,0,0,.16); }
.faq-item.open { border-color:#0F6E56; box-shadow:0 4px 16px rgba(15,110,86,.08); }
.faq-question { width:100%; background:transparent; border:none; cursor:pointer; padding:22px 28px; display:flex; align-items:center; gap:18px; text-align:left; font-family:inherit; color:#1a1a1a; }
.faq-number { font-size:13px; font-weight:500; color:#0F6E56; background:#E1F5EE; min-width:32px; height:32px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; flex-shrink:0; }
.faq-question-text { flex:1; font-size:16px; font-weight:500; color:#1a1a1a; }
.faq-toggle { width:32px; height:32px; border-radius:50%; background:#f1efe8; display:inline-flex; align-items:center; justify-content:center; flex-shrink:0; transition:background .2s,transform .3s; }
.faq-toggle i { font-size:18px; color:#5f5e5a; transition:transform .3s; }
.faq-item.open .faq-toggle { background:#0F6E56; }
.faq-item.open .faq-toggle i { color:#fff; transform:rotate(180deg); }
.faq-answer { max-height:0; overflow:hidden; transition:max-height .35s ease; }
.faq-answer-inner { padding:0 28px 22px 78px; font-size:15px; color:#5f5e5a; line-height:1.7; }
.faq-footer { margin-top:40px; padding:28px 32px; background:#bdf5e1; border-radius:14px; display:flex; align-items:center; justify-content:space-between; gap:24px; }
.faq-footer-text { margin:0; font-size:15px; color:#1a1a1a; }
.faq-footer-text strong { font-weight:500; }
.faq-footer-text span { color:#5f5e5a; display:block; font-size:13px; margin-top:4px; }
.faq-cta { background:#1a1a1a; color:#fff; border:none; padding:12px 22px; border-radius:999px; font-family:inherit; font-size:14px; font-weight:500; cursor:pointer; display:inline-flex; align-items:center; gap:8px; transition:background .2s; white-space:nowrap; }
.faq-cta:hover { background:#333; }
.faq-cta i { font-size:16px; }

/* ============ TESTIMONIAL CARDS ============ */
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; max-width:960px; margin:0 auto; }
.tcard { background:white; border:1.5px solid var(--border); border-radius:14px; padding:24px; }
.stars { color:var(--gold); font-size:14px; margin-bottom:12px; }
.tcard p { font-size:14px; color:var(--text); line-height:1.7; margin-bottom:16px; font-style:italic; }
.student { display:flex; align-items:center; gap:10px; }
.avatar { width:38px; height:38px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:14px; font-weight:700; color:white; }
.student-name { font-size:13px; font-weight:600; }
.student-course { font-size:12px; color:var(--muted); }

/* ============ CTA BOTTOM ============ */
.cta-bottom { background:linear-gradient(135deg,#06A36E,#08BD80); padding:60px 20px; text-align:center; }
.cta-bottom h2 { font-family:'Sora',sans-serif; font-size:32px; font-weight:800; color:white; margin-bottom:12px; }
.cta-bottom p { font-size:16px; color:rgba(255,255,255,.95); margin-bottom:30px; }
.cta-white { display:inline-block; background:white; color:var(--green-dark); font-family:'Sora',sans-serif; font-size:16px; font-weight:700; padding:15px 40px; border-radius:10px; text-decoration:none; border:none; cursor:pointer; transition:transform .2s; }
.cta-white:hover { transform:translateY(-2px); }

/* ============ FOOTER ============ */
footer { background:var(--blue); padding:20px; text-align:center; font-size:14px; color:rgba(255,255,255,.7); }


/* ============================================================
   FEATURED STORIES CAROUSEL  ← NEW
   ============================================================ */

.featured-stories-section {
  background: #f9f8f6;
  padding: 60px 48px 70px;
}

.fs-header {
  margin-bottom: 36px;
}

.fs-eyebrow {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 8px;
}

.fs-title {
  font-family: 'Sora', sans-serif;
  font-size: 2rem;
  font-weight: 800;
  color: #111;
  line-height: 1.1;
  letter-spacing: -.5px;
  margin-bottom: 6px;
}

.fs-title em {
  font-family: 'Playfair Display', serif;
  font-style: italic;
  font-weight: 400;
}

.fs-sub {
  font-size: .875rem;
  color: #888;
  font-weight: 400;
}

/* Wrapper with arrows */
.fs-carousel-wrapper {
  position: relative;
  display: flex;
  align-items: center;
}

.fs-track-outer {
  overflow: hidden;
  width: 100%;
}

.fs-track {
  display: flex;
  gap: 16px;
  transition: transform .45s cubic-bezier(.4,0,.2,1);
  will-change: transform;
}

/* Card */
.fs-card {
  flex: 0 0 calc((100% - 3 * 16px) / 4.6);
  min-width: 200px;
  border-radius: 16px;
  overflow: hidden;
  position: relative;
  aspect-ratio: 9 / 14;
  cursor: pointer;
  background: #1a1a2e;
  box-shadow: 0 4px 20px rgba(0,0,0,.14);
  transition: transform .3s ease, box-shadow .3s ease;
}

.fs-card:hover {
  transform: translateY(-6px) scale(1.02);
  box-shadow: 0 14px 40px rgba(0,0,0,.24);
}

.fs-thumb {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  transition: transform .5s ease;
}

.fs-card:hover .fs-thumb { transform: scale(1.05); }

.fs-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(0,0,0,0) 40%, rgba(0,0,0,.72) 100%);
  opacity: .85;
  transition: opacity .3s;
}

.fs-card:hover .fs-overlay { opacity: 1; }

/* Play button */
.fs-play-btn {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: rgba(255,255,255,.88);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 10px rgba(0,0,0,.2);
  transition: transform .25s, background .25s;
}

.fs-play-btn svg {
  width: 13px;
  height: 13px;
  margin-left: 2px;
}

.fs-card:hover .fs-play-btn {
  transform: scale(1.12);
  background: #fff;
}

/* Card info */
.fs-info {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 16px 14px;
  z-index: 2;
}

.fs-card-title {
  font-size: .95rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: -.1px;
  margin-bottom: 3px;
}

.fs-card-cta {
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: rgba(255,255,255,.75);
}

/* Nav arrows */
.fs-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #fff;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 12px rgba(0,0,0,.15);
  color: #333;
  transition: background .2s, color .2s, box-shadow .2s, transform .2s;
}

.fs-nav svg { width: 18px; height: 18px; }

.fs-nav:hover {
  background: #111;
  color: #fff;
  box-shadow: 0 4px 20px rgba(0,0,0,.28);
}

.fs-prev { left: -20px; }
.fs-next { right: -20px; }

.fs-nav:disabled { opacity: .3; pointer-events: none; }

/* Modal */
.fs-modal {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.82);
  backdrop-filter: blur(6px);
  z-index: 9999;
  align-items: center;
  justify-content: center;
}

.fs-modal.open { display: flex; }

.fs-modal-box {
  position: relative;
  width: min(860px, 92vw);
  aspect-ratio: 16/9;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 24px 80px rgba(0,0,0,.5);
  animation: fsModalIn .3s cubic-bezier(.34,1.3,.64,1) forwards;
}

@keyframes fsModalIn {
  from { opacity:0; transform:scale(.88); }
  to   { opacity:1; transform:scale(1); }
}

.fs-modal-box iframe { width:100%; height:100%; border:none; display:block; }

.fs-modal-close {
  position: absolute;
  top: -46px;
  right: 0;
  background: none;
  border: none;
  color: #fff;
  font-size: 2rem;
  cursor: pointer;
  line-height: 1;
  transition: transform .2s;
}

.fs-modal-close:hover { transform: rotate(90deg); }


/* ============================================================
   RESPONSIVE BREAKPOINTS
   ============================================================ */

@media (max-width: 1024px) {
  .hero { grid-template-columns:1fr 380px; gap:40px; padding:60px 24px; }
  .hero h1 { font-size:36px; }
  .features-grid { grid-template-columns:repeat(3,1fr); }
  .main-wrapper { grid-template-columns:1fr; gap:40px; }
  .left-image { max-width:500px; margin:0 auto; }
  .headline { font-size:32px; }
  .courses-grid, .testimonials-grid { grid-template-columns:repeat(2,1fr); }
  .facilities-grid { grid-template-columns:repeat(2,1fr); }
  .featured-stories-section { padding:50px 28px 60px; }
}

@media (max-width: 768px) {
  .hero { grid-template-columns:1fr; gap:30px; padding:40px 20px; text-align:center; }
  .hero h1 { font-size:30px; }
  .hero p { font-size:15px; margin-left:auto; margin-right:auto; }
  .hero-pills { justify-content:center; }
  .stats-row { justify-content:center; gap:24px; }
  .lead-form { max-width:100%; margin:0 auto; padding:28px 24px; }
  .lead-form h2 { font-size:20px; }
  .trust-bar { gap:16px; padding:16px 20px; }
  .trust-item { font-size:12px; }
  .container { padding:50px 20px 30px; }
  .headline { font-size:24px; margin-bottom:30px; }
  .eyebrow-green { font-size:15px; }
  .content { grid-template-columns:1fr; gap:30px; }
  .record-table th,.record-table td { padding:10px 8px; font-size:13px; }
  .record-table th { font-size:14px; }
  .track-title { font-size:18px; }
  .section { padding:40px 20px; }
  .features-bg { padding:40px 20px; }
  .section-header h2 { font-size:24px; }
  .courses-grid, .testimonials-grid { grid-template-columns:1fr; max-width:480px; margin:0 auto; }
  .features-grid { grid-template-columns:repeat(2,1fr); }
  .facilities-grid { grid-template-columns:1fr; }
  .accordion-header { padding:18px 20px; font-size:14px; }
  .accordion-content { padding:20px; font-size:14px; }
  .page { padding:40px 20px 60px; }
  .testimonial { padding:28px 24px; }
  .testimonial .quote-mark { left:20px; top:16px; font-size:28px; }
  .testimonial-text { font-size:16px; padding-left:0; padding-top:20px; }
  .testimonial-attr { padding-left:0; }
  .marquee-track img { width:220px; height:280px; }
  .image-pair { grid-template-columns:1fr; gap:16px; }
  .faq-header { grid-template-columns:1fr; gap:16px; margin-bottom:32px; }
  .faq-title { font-size:24px; }
  .faq-question { padding:18px 20px; gap:14px; }
  .faq-question-text { font-size:14px; }
  .faq-answer-inner { padding:0 20px 18px 66px; font-size:14px; }
  .faq-footer { flex-direction:column; align-items:flex-start; padding:22px; }
  .cta-bottom { padding:40px 20px; }
  .cta-bottom h2 { font-size:24px; }
  .cta-bottom p { font-size:14px; }
  /* Carousel responsive */
  .featured-stories-section { padding:40px 20px 50px; }
  .fs-title { font-size:1.6rem; }
  .fs-prev { left:-14px; }
  .fs-next { right:-14px; }
}

@media (max-width: 480px) {
  .navbar img { height:50px; }
  .hero { padding:30px 16px; }
  .hero h1 { font-size:26px; }
  .hero-badge { font-size:11px; padding:5px 12px; }
  .stat-num { font-size:22px; }
  .lead-form { padding:24px 20px; }
  .lead-form h2 { font-size:18px; }
  .form-group label { font-size:11px; }
  .form-group input,.form-group select { font-size:14px; padding:10px 12px; }
  .cta-btn { font-size:14px; padding:13px; }
  .trust-bar { flex-direction:column; gap:10px; }
  .headline { font-size:22px; }
  .features-grid { grid-template-columns:1fr; }
  .record-table th,.record-table td { padding:8px 6px; font-size:12px; }
  .marquee-track img { width:180px; height:220px; }
  .section-header h2 { font-size:22px; }
  .accordion-header { padding:16px; font-size:13px; }
  /* Carousel mobile */
  .featured-stories-section { padding:30px 14px 44px; }
  .fs-title { font-size:1.4rem; }
  .fs-nav { width:34px; height:34px; }
  .fs-prev { left:-10px; }
  .fs-next { right:-10px; }
}
