/* ══════════════════════════════════════════════
   NEXUS INSTITUTE – Complete Stylesheet
   Font: Syne (headings) + DM Sans (body)
   Theme: Deep Navy + Electric Amber accent
══════════════════════════════════════════════ */

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  --navy:       #080d1a;
  --navy2:      #0d1526;
  --navy3:      #111d35;
  --navy4:      #182040;
  --amber:      #f5a623;
  --amber2:     #fbbf24;
  --amber-glow: rgba(245,166,35,.18);
  --blue:       #3b82f6;
  --blue-dim:   rgba(59,130,246,.12);
  --white:      #ffffff;
  --off-white:  #e8edf5;
  --muted:      rgba(232,237,245,.5);
  --border:     rgba(232,237,245,.08);
  --font-head:  'Syne', sans-serif;
  --font-body:  'DM Sans', sans-serif;
  --radius:     12px;
  --radius-lg:  20px;
}

html { scroll-behavior:smooth; }

body {
  font-family: var(--font-body);
  background: var(--navy);
  color: var(--off-white);
  overflow-x: hidden;
  cursor: none;
}

a { text-decoration:none; color:inherit; }
img { display:block; max-width:100%; }
button { font-family: var(--font-body); cursor:none; }

/* ════════ CUSTOM CURSOR ════════ */
.cursor {
  position: fixed;
  width: 12px; height: 12px;
  background: var(--amber);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9999;
  mix-blend-mode: difference;
  transition: transform .1s;
}
.cursor.cursor-hover { transform: scale(2.5) !important; }

.cursor-trail {
  position: fixed;
  width: 36px; height: 36px;
  border: 1.5px solid rgba(245,166,35,.4);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9998;
}

/* ════════ NAVBAR ════════ */
nav {
  position: sticky; top:0; z-index:1000;
  background: rgba(8,13,26,.85);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
  transition: box-shadow .3s;
}
nav.scrolled {
  box-shadow: 0 4px 32px rgba(0,0,0,.5);
  background: rgba(8,13,26,.96);
}
.nav-inner {
  max-width: 1200px; margin:0 auto;
  display:flex; align-items:center;
  padding: 0 40px; height: 68px; gap: 40px;
}

/* Logo */
.nav-logo {
  display:flex; align-items:center; gap:10px;
  flex-shrink:0;
}
.logo-mark {
  width: 38px; height: 38px;
  border-radius: 9px;
  background: linear-gradient(135deg, var(--amber), #e08e0b);
  display:flex; align-items:center; justify-content:center;
  font-family: var(--font-head);
  font-size: 1.2rem; font-weight:800;
  color: var(--navy);
  box-shadow: 0 0 18px var(--amber-glow);
}
.logo-mark.sm { width:28px; height:28px; font-size:.9rem; border-radius:6px; }
.logo-text {
  font-family: var(--font-head);
  font-size: 1.1rem; font-weight:700;
  color: var(--white); line-height:1;
  letter-spacing:-.02em;
}
.logo-text span { color: var(--amber); }

.nav-links {
  display:flex; gap:28px; list-style:none;
  margin-left: auto;
}
.nav-links a {
  font-size: .88rem; font-weight:500;
  color: var(--muted);
  position: relative; padding-bottom:2px;
  transition: color .2s;
}
.nav-links a::after {
  content:''; position:absolute;
  bottom:-2px; left:0; right:0; height:1.5px;
  background: var(--amber);
  transform: scaleX(0); transform-origin:left;
  transition: transform .25s;
}
.nav-links a:hover { color:var(--white); }
.nav-links a:hover::after { transform:scaleX(1); }

.nav-cta {
  display:inline-flex; align-items:center; gap:6px;
  padding: 9px 20px;
  background: var(--amber);
  border: none; border-radius: 8px;
  font-size: .85rem; font-weight:700;
  color: var(--navy);
  white-space: nowrap; flex-shrink:0;
  transition: background .2s, box-shadow .2s, transform .15s;
}
.nav-cta:hover {
  background: var(--amber2);
  box-shadow: 0 6px 24px var(--amber-glow);
  transform: translateY(-1px);
}

.hamburger {
  display:none; background:none; border:none;
  color: var(--white); font-size:1.5rem;
  margin-left: auto; cursor:pointer;
}

/* Mobile menu */
.mobile-menu {
  display:none; flex-direction:column;
  background: var(--navy2);
  position:fixed; top:68px; left:0; right:0;
  z-index:999; padding:8px 0;
  border-bottom:1px solid var(--border);
}
.mobile-menu.open { display:flex; }
.mobile-menu a {
  padding:14px 24px; font-size:.95rem;
  color: var(--muted);
  border-bottom: 1px solid var(--border);
  transition: background .2s, color .2s;
}
.mobile-menu a:hover { background:rgba(255,255,255,.04); color:var(--white); }
.mobile-menu .mob-appt {
  margin: 12px 24px;
  background: var(--amber);
  color: var(--navy);
  border-radius: 8px;
  text-align:center;
  font-weight:700; border:none;
}

/* ════════ ANNOUNCE BAR ════════ */
.announce-bar {
  background: linear-gradient(90deg, #1a2744 0%, #0f1a38 50%, #1a2744 100%);
  text-align:center;
  padding: 10px 24px;
  font-size: .82rem; font-weight:500;
  color: var(--amber2);
  letter-spacing: .02em;
  border-bottom: 1px solid var(--border);
  display:flex; align-items:center; justify-content:center; gap:8px;
}
.announce-bar i { font-size:.9rem; }

/* ════════ HERO ════════ */
.hero {
  position: relative;
  min-height: 92vh;
  display:flex; align-items:center;
  overflow:hidden;
  padding: 0 40px;
}

/* Animated grid background */
.hero-grid {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(245,166,35,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(245,166,35,.04) 1px, transparent 1px);
  background-size: 60px 60px;
  mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, black 30%, transparent 100%);
  pointer-events:none;
}

/* Orbs */
.orb {
  position:absolute; border-radius:50%;
  pointer-events:none; filter:blur(80px);
}
.orb1 {
  width:600px; height:600px;
  background: radial-gradient(circle, rgba(59,130,246,.2) 0%, transparent 70%);
  top:-200px; right:-100px;
  animation: orbFloat 8s ease-in-out infinite;
}
.orb2 {
  width:400px; height:400px;
  background: radial-gradient(circle, rgba(245,166,35,.12) 0%, transparent 70%);
  bottom:0; left:-100px;
  animation: orbFloat 10s ease-in-out infinite reverse;
}
.orb3 {
  width:300px; height:300px;
  background: radial-gradient(circle, rgba(139,92,246,.1) 0%, transparent 70%);
  top:50%; left:40%;
  animation: orbFloat 12s ease-in-out infinite 2s;
}
@keyframes orbFloat {
  0%,100% { transform:translateY(0) scale(1); }
  50%      { transform:translateY(-30px) scale(1.05); }
}

.hero-inner {
  max-width:1200px; margin:0 auto; width:100%;
  display:grid; grid-template-columns:1fr 1fr;
  align-items:center; gap:60px;
  position:relative; z-index:2;
  padding: 80px 0 80px;
}

.hero-badge {
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 14px;
  background: rgba(245,166,35,.1);
  border:1px solid rgba(245,166,35,.25);
  border-radius:30px;
  font-size:.78rem; font-weight:700;
  color:var(--amber2);
  letter-spacing:.04em;
  margin-bottom:20px;
}

.hero-content h1 {
  font-family: var(--font-head);
  font-size: clamp(2.2rem, 4vw, 3.8rem);
  font-weight:800; line-height:1.12;
  color:var(--white); margin-bottom:20px;
  letter-spacing:-.02em;
}
.text-accent { color:var(--amber); }

.hero-sub {
  font-size:1rem; line-height:1.75;
  color:var(--muted); max-width:480px;
  margin-bottom:32px;
}

.hero-actions { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:40px; }

.btn-primary {
  display:inline-flex; align-items:center; gap:8px;
  padding:12px 26px;
  background: var(--amber);
  border:none; border-radius:9px;
  font-family:var(--font-body); font-size:.9rem; font-weight:700;
  color:var(--navy);
  transition:background .2s, box-shadow .2s, transform .15s;
}
.btn-primary:hover {
  background:var(--amber2);
  box-shadow:0 8px 28px var(--amber-glow);
  transform:translateY(-2px);
}

.btn-ghost {
  display:inline-flex; align-items:center; gap:6px;
  padding:12px 22px;
  border:1.5px solid var(--border);
  border-radius:9px;
  font-size:.9rem; font-weight:600;
  color:var(--off-white);
  transition:border-color .2s, background .2s;
}
.btn-ghost:hover { border-color:rgba(255,255,255,.3); background:rgba(255,255,255,.05); }

/* Hero stats */
.hero-stats { display:flex; align-items:center; gap:20px; }
.hstat { display:flex; flex-direction:column; gap:2px; }
.hstat strong {
  font-family:var(--font-head); font-size:1.5rem; font-weight:800;
  color:var(--white);
}
.hstat span { font-size:.78rem; color:var(--muted); }
.hstat-divider { width:1px; height:36px; background:var(--border); }

/* Hero visual */
.hero-visual {
  position:relative; display:flex;
  align-items:center; justify-content:center;
  height:520px;
}
.visual-glow {
  position:absolute;
  width:480px; height:480px; border-radius:50%;
  background: radial-gradient(circle, rgba(59,130,246,.25) 0%, transparent 70%);
  pointer-events:none;
}
.visual-glow2 {
  position:absolute;
  width:360px; height:360px; border-radius:50%;
  background: radial-gradient(circle, rgba(245,166,35,.12) 0%, transparent 70%);
  pointer-events:none;
  animation:orbFloat 6s ease-in-out infinite;
}
.hero-img {
  width:100%; height:100%;
  object-fit:cover; object-position:top;
  border-radius:var(--radius-lg);
  position:relative; z-index:2;
  box-shadow: 0 32px 80px rgba(0,0,0,.5),
              0 0 0 1px rgba(255,255,255,.06);
}

/* Floating cards */
.float-card {
  position:absolute; z-index:4;
  display:flex; align-items:center; gap:10px;
  background: rgba(13,21,38,.9);
  border:1px solid var(--border);
  backdrop-filter:blur(12px);
  border-radius:12px;
  padding:12px 16px;
  box-shadow:0 16px 48px rgba(0,0,0,.4);
  white-space:nowrap;
  animation:floatCard 4s ease-in-out infinite;
}
.float-card i { font-size:1.3rem; color:var(--amber); }
.float-card strong { display:block; font-size:.85rem; color:var(--white); font-weight:700; }
.float-card span { font-size:.72rem; color:var(--muted); }
.fc1 { bottom:80px; left:-30px; animation-delay:0s; }
.fc2 { top:60px;   right:-20px; animation-delay:2s; }
@keyframes floatCard {
  0%,100%{ transform:translateY(0); }
  50%    { transform:translateY(-8px); }
}

/* Scroll indicator */
.scroll-indicator {
  position:absolute; bottom:32px; left:50%;
  transform:translateX(-50%);
  width:24px; height:38px;
  border:2px solid rgba(255,255,255,.2);
  border-radius:12px;
  display:flex; justify-content:center; padding:5px 0;
}
.scroll-dot {
  width:4px; height:8px;
  background:var(--amber); border-radius:2px;
  animation:scrollDot 2s ease-in-out infinite;
}
@keyframes scrollDot {
  0%   { transform:translateY(0); opacity:1; }
  80%  { transform:translateY(12px); opacity:0; }
  100% { transform:translateY(0); opacity:0; }
}

/* ════════ REVEAL ANIMATIONS ════════ */
.reveal            { animation:fadeUp .7s .1s both; }
.reveal-delay-1    { animation:fadeUp .7s .25s both; }
.reveal-delay-2    { animation:fadeUp .7s .4s both; }
.reveal-delay-3    { animation:fadeUp .7s .55s both; }
.reveal-delay-4    { animation:fadeUp .7s .7s both; }
@keyframes fadeUp {
  from { opacity:0; transform:translateY(30px); }
  to   { opacity:1; transform:none; }
}
.will-reveal {
  opacity:0; transform:translateY(28px);
  transition:opacity .6s ease, transform .6s ease;
}
.will-reveal.visible { opacity:1; transform:none; }

/* ════════ PARTNERS BAR ════════ */
.partners-bar {
  background:var(--navy2);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:20px 0;
  display:flex; align-items:center; gap:32px;
  overflow:hidden;
}
.partners-label {
  flex-shrink:0; padding-left:40px;
  font-size:.75rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.1em;
  color:rgba(255,255,255,.25); white-space:nowrap;
}
.partners-track {
  display:flex; align-items:center; gap:40px;
  animation:scrollTrack 20s linear infinite;
}
.partner-item {
  display:flex; align-items:center; justify-content:center;
  opacity:.4; filter:grayscale(1) brightness(2);
  transition:opacity .3s, filter .3s;
}
.partner-item:hover { opacity:.85; filter:grayscale(0) brightness(1); }
.partner-img { height:32px; width:auto; max-width:110px; object-fit:contain; }
@keyframes scrollTrack {
  from { transform:translateX(0); }
  to   { transform:translateX(-50%); }
}

/* ════════ COMMON SECTION STYLES ════════ */
.section-inner {
  max-width:1200px; margin:0 auto;
  padding:0 40px;
}
.section-header { margin-bottom:52px; }
.section-eyebrow {
  font-size:.78rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.12em;
  color:var(--amber); margin-bottom:10px;
  display:flex; align-items:center; gap:8px;
}
.section-eyebrow::before {
  content:''; display:inline-block;
  width:24px; height:2px;
  background:var(--amber); border-radius:1px;
}
.section-heading {
  font-family:var(--font-head);
  font-size:clamp(2rem, 4vw, 3rem);
  font-weight:800; line-height:1.15;
  color:var(--white); letter-spacing:-.02em;
}
.section-heading em { font-style:normal; color:var(--amber); }
.section-desc {
  font-size:.97rem; color:var(--muted);
  line-height:1.75; max-width:520px;
  margin-top:14px;
}
.body-text {
  font-size:.95rem; color:var(--muted);
  line-height:1.8; margin-bottom:16px;
}

/* ════════ ABOUT ════════ */
.about-section { padding:100px 0; }
.about-section .section-inner {
  display:grid; grid-template-columns:1fr 1fr;
  gap:80px; align-items:center;
}

.about-img-stack { position:relative; height:500px; }
.about-img-main {
  position:absolute; top:0; left:0;
  width:75%; height:80%;
  object-fit:cover; border-radius:var(--radius-lg);
  box-shadow:0 24px 60px rgba(0,0,0,.4);
}
.about-img-secondary {
  position:absolute; bottom:0; right:0;
  width:55%; height:55%;
  object-fit:cover; border-radius:var(--radius-lg);
  border:4px solid var(--navy);
  box-shadow:0 16px 40px rgba(0,0,0,.5);
}
.about-badge-exp {
  position:absolute; top:50%; left:65%;
  transform:translate(-50%,-50%);
  background:var(--amber);
  border-radius:var(--radius);
  padding:16px 20px; text-align:center;
  box-shadow:0 8px 32px var(--amber-glow);
  z-index:3;
}
.about-badge-exp strong {
  display:block; font-family:var(--font-head);
  font-size:2.2rem; font-weight:800; color:var(--navy); line-height:1;
}
.about-badge-exp span { font-size:.75rem; font-weight:700; color:var(--navy); opacity:.7; }

.about-features {
  display:grid; grid-template-columns:1fr 1fr;
  gap:16px; margin:24px 0 32px;
}
.af-item {
  display:flex; gap:12px; align-items:flex-start;
  padding:14px; border-radius:var(--radius);
  background:var(--navy2);
  border:1px solid var(--border);
  transition:border-color .2s;
}
.af-item:hover { border-color:rgba(245,166,35,.25); }
.af-icon {
  width:36px; height:36px; flex-shrink:0;
  border-radius:8px; background:rgba(245,166,35,.1);
  display:flex; align-items:center; justify-content:center;
  font-size:1rem; color:var(--amber);
}
.af-item strong { display:block; font-size:.85rem; font-weight:700; color:var(--white); margin-bottom:2px; }
.af-item span { font-size:.78rem; color:var(--muted); }

/* ════════ PROGRAMS ════════ */
.programs-section {
  padding:100px 0;
  background:var(--navy2);
}
.programs-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.prog-card {
  position:relative;
  background:var(--navy3);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:28px;
  overflow:hidden;
  transition:border-color .3s, transform .3s, box-shadow .3s;
  --mx:50%; --my:50%;
}
.prog-card::before {
  content:'';
  position:absolute;
  width:200px; height:200px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(245,166,35,.15) 0%, transparent 70%);
  left:calc(var(--mx) - 100px);
  top:calc(var(--my) - 100px);
  pointer-events:none; opacity:0;
  transition:opacity .3s;
}
.prog-card:hover::before { opacity:1; }
.prog-card:hover {
  transform:translateY(-6px);
  border-color:rgba(245,166,35,.25);
  box-shadow:0 24px 60px rgba(0,0,0,.3);
}

.featured-card {
  background:linear-gradient(145deg, #1c1f35 0%, #141830 100%);
  border-color:rgba(245,166,35,.3);
  box-shadow:0 0 0 1px rgba(245,166,35,.1), 0 16px 40px rgba(0,0,0,.3);
}
.prog-badge-feat {
  display:inline-flex; align-items:center;
  padding:4px 12px;
  background:var(--amber); border-radius:20px;
  font-size:.7rem; font-weight:800;
  color:var(--navy); text-transform:uppercase;
  letter-spacing:.06em; margin-bottom:14px;
}
.prog-icon {
  width:48px; height:48px;
  border-radius:12px;
  background:rgba(245,166,35,.1);
  border:1px solid rgba(245,166,35,.2);
  display:flex; align-items:center; justify-content:center;
  font-size:1.4rem; color:var(--amber);
  margin-bottom:16px;
}
.prog-card h3 {
  font-family:var(--font-head);
  font-size:1.05rem; font-weight:700;
  color:var(--white); margin-bottom:10px;
}
.prog-card p {
  font-size:.85rem; color:var(--muted);
  line-height:1.7; margin-bottom:18px;
}
.prog-meta { display:flex; gap:14px; margin-bottom:20px; }
.prog-meta span {
  display:flex; align-items:center; gap:5px;
  font-size:.76rem; color:var(--muted);
  background:rgba(255,255,255,.05);
  padding:4px 10px; border-radius:20px;
}
.prog-meta i { color:var(--amber); }
.prog-btn {
  display:inline-flex; align-items:center; gap:6px;
  padding:9px 18px;
  background:transparent;
  border:1.5px solid rgba(245,166,35,.35);
  border-radius:8px;
  font-size:.82rem; font-weight:700;
  color:var(--amber);
  transition:background .2s, border-color .2s;
}
.prog-btn:hover { background:rgba(245,166,35,.1); border-color:var(--amber); }

/* ════════ WHY US ════════ */
.why-section {
  padding:100px 0;
  position:relative; overflow:hidden;
}
.why-bg-text {
  position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%);
  font-family:var(--font-head);
  font-size:clamp(100px, 18vw, 240px);
  font-weight:900; letter-spacing:-.05em;
  color:rgba(255,255,255,.025);
  pointer-events:none; white-space:nowrap;
  user-select:none;
}
.why-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:20px; position:relative; z-index:2;
}
.why-card {
  background:var(--navy2);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:28px;
  transition:border-color .3s, transform .3s;
  position:relative; overflow:hidden;
}
.why-card::after {
  content:'';
  position:absolute; bottom:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, var(--amber), transparent);
  transform:scaleX(0); transform-origin:left;
  transition:transform .3s;
}
.why-card:hover { transform:translateY(-4px); border-color:rgba(245,166,35,.2); }
.why-card:hover::after { transform:scaleX(1); }
.why-num {
  font-family:var(--font-head); font-size:.72rem; font-weight:800;
  color:rgba(245,166,35,.4); letter-spacing:.08em;
  margin-bottom:14px;
}
.why-icon {
  width:44px; height:44px; border-radius:10px;
  background:rgba(245,166,35,.08); border:1px solid rgba(245,166,35,.15);
  display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; color:var(--amber); margin-bottom:16px;
}
.why-card h4 {
  font-family:var(--font-head); font-size:.95rem; font-weight:700;
  color:var(--white); margin-bottom:10px;
}
.why-card p { font-size:.83rem; color:var(--muted); line-height:1.7; }

/* ════════ STATS BAND ════════ */
.stats-band {
  background:linear-gradient(90deg, var(--navy4), #1a2a50, var(--navy4));
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:36px 40px;
}
.stats-band-inner {
  max-width:1100px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  gap:20px; flex-wrap:wrap;
}
.sb-stat { text-align:center; }
.sb-stat strong {
  display:block;
  font-family:var(--font-head); font-size:2.4rem; font-weight:800;
  color:var(--amber); line-height:1;
}
.sb-stat span { font-size:.8rem; color:var(--muted); margin-top:4px; display:block; }
.sb-divider { width:1px; height:50px; background:var(--border); }

/* ════════ TESTIMONIALS ════════ */
.testimonials-section {
  padding:100px 0;
  background:var(--navy2);
}
.testi-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.testi-card {
  background:var(--navy3);
  border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:28px;
  transition:border-color .3s, transform .3s;
}
.testi-card:hover { transform:translateY(-4px); border-color:rgba(255,255,255,.12); }
.testi-featured {
  background:linear-gradient(145deg, #1b2040, #111730);
  border-color:rgba(245,166,35,.25);
  box-shadow:0 12px 40px rgba(0,0,0,.3);
}
.testi-stars { display:flex; gap:3px; margin-bottom:16px; color:var(--amber); font-size:.9rem; }
.testi-card p {
  font-size:.9rem; color:var(--muted); line-height:1.75;
  margin-bottom:20px; font-style:italic;
}
.testi-author { display:flex; align-items:center; gap:12px; }
.testi-author img {
  width:44px; height:44px; border-radius:50%;
  object-fit:cover; border:2px solid var(--border);
}
.testi-author strong { display:block; font-size:.85rem; font-weight:700; color:var(--white); }
.testi-author span { font-size:.75rem; color:var(--muted); }

/* ════════ CONTACT ════════ */
.contact-section { padding:100px 0; }
.contact-section .section-inner {
  display:grid; grid-template-columns:1fr 1.2fr;
  gap:80px; align-items:start;
}
.contact-info-list { display:flex; flex-direction:column; gap:16px; margin:28px 0 32px; }
.ci-item {
  display:flex; gap:14px; align-items:flex-start;
  padding:14px; border-radius:var(--radius);
  background:var(--navy2); border:1px solid var(--border);
  transition:border-color .2s;
}
.ci-item:hover { border-color:rgba(245,166,35,.2); }
.ci-icon {
  width:38px; height:38px; flex-shrink:0;
  border-radius:9px; background:rgba(245,166,35,.08);
  border:1px solid rgba(245,166,35,.15);
  display:flex; align-items:center; justify-content:center;
  font-size:1rem; color:var(--amber);
}
.ci-item strong { display:block; font-size:.82rem; font-weight:700; color:var(--white); margin-bottom:2px; }
.ci-item span { font-size:.82rem; color:var(--muted); }

/* Contact form card */
.contact-form-card {
  background:var(--navy2);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:36px 32px;
}
.contact-form-card h3 {
  font-family:var(--font-head); font-size:1.3rem; font-weight:700;
  color:var(--white); margin-bottom:4px;
}
.contact-form-card p { font-size:.83rem; color:var(--muted); margin-bottom:24px; }

.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-group { margin-bottom:14px; }
.form-group label {
  display:block; font-size:.75rem; font-weight:700;
  color:rgba(255,255,255,.5); text-transform:uppercase;
  letter-spacing:.06em; margin-bottom:6px;
}
.form-group input,
.form-group textarea {
  width:100%; padding:11px 14px;
  background:#0d1526;
  border:1.5px solid var(--border);
  border-radius:8px;
  font-family:var(--font-body); font-size:.9rem;
  color:var(--white); outline:none;
  transition:border-color .2s, box-shadow .2s;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color:rgba(255,255,255,.2); }
.form-group input:focus,
.form-group textarea:focus {
  border-color:rgba(245,166,35,.5);
  box-shadow:0 0 0 3px rgba(245,166,35,.08);
}
.form-group textarea { resize:vertical; }

.select-wrap { position:relative; }
.select-wrap select {
  width:100%; padding:11px 38px 11px 14px;
  background:#0d1526;
  border:1.5px solid var(--border);
  border-radius:8px;
  font-family:var(--font-body); font-size:.9rem;
  color:var(--white); outline:none;
  -webkit-appearance:none; appearance:none; cursor:pointer;
  transition:border-color .2s;
}
.select-wrap select:focus { border-color:rgba(245,166,35,.5); }
.select-wrap select option { background:#0d1526; }
.select-arrow {
  position:absolute; right:12px; top:50%;
  transform:translateY(-50%);
  color:rgba(255,255,255,.3); pointer-events:none;
}

.btn-submit-form {
  width:100%; padding:13px;
  background:var(--amber);
  border:none; border-radius:9px;
  font-family:var(--font-body); font-size:.95rem; font-weight:700;
  color:var(--navy); display:flex; align-items:center;
  justify-content:center; gap:8px;
  transition:background .2s, box-shadow .2s, transform .15s;
}
.btn-submit-form:hover {
  background:var(--amber2);
  box-shadow:0 8px 28px var(--amber-glow);
  transform:translateY(-1px);
}

/* ════════ MAP ════════ */
.map-section { background:var(--navy2); padding:0; }
.map-label {
  padding:24px 40px 16px;
  font-family:var(--font-head); font-size:1.1rem; font-weight:700;
  color:var(--white); display:flex; align-items:center; gap:8px;
}
.map-label i { color:var(--amber); }
.map-embed { width:100%; height:320px; border:none; display:block; filter:saturate(.7) brightness(.9); }

/* ════════ FOOTER ════════ */
footer { background:#050a14; padding:72px 40px 0; }
.footer-top {
  max-width:1200px; margin:0 auto;
  display:grid; grid-template-columns:2fr 1fr 1fr 1.2fr;
  gap:48px; padding-bottom:48px;
  border-bottom:1px solid var(--border);
}
.footer-brand-col .footer-logo { margin-bottom:16px; }
.footer-brand-col p {
  font-size:.85rem; color:rgba(255,255,255,.4);
  line-height:1.8; max-width:290px; margin-bottom:20px;
}
.footer-socials { display:flex; gap:10px; }
.footer-socials a {
  width:36px; height:36px; border-radius:9px;
  background:rgba(255,255,255,.06); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.5); font-size:.95rem;
  transition:background .2s, color .2s, border-color .2s;
}
.footer-socials a:hover { background:var(--amber); color:var(--navy); border-color:var(--amber); }

.footer-col h4 {
  font-family:var(--font-head); font-size:.78rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.1em;
  color:rgba(255,255,255,.4); margin-bottom:18px;
}
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-col ul a {
  font-size:.85rem; color:rgba(255,255,255,.4);
  transition:color .2s;
}
.footer-col ul a:hover { color:var(--amber); }
.footer-contact-list { list-style:none; display:flex; flex-direction:column; gap:12px; }
.footer-contact-list li {
  display:flex; align-items:flex-start; gap:8px;
  font-size:.83rem; color:rgba(255,255,255,.4); line-height:1.5;
}
.footer-contact-list i { color:var(--amber); flex-shrink:0; margin-top:2px; }

.footer-bottom {
  max-width:1200px; margin:0 auto;
  display:flex; justify-content:space-between; align-items:center;
  padding:20px 0;
  font-size:.78rem; color:rgba(255,255,255,.2);
}

/* ════════ POPUP ════════ */
.overlay {
  position:fixed; inset:0; z-index:2000;
  background:rgba(0,0,0,.75);
  backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center;
  opacity:0; pointer-events:none;
  transition:opacity .35s;
}
.overlay.show { opacity:1; pointer-events:all; }

.popup {
  background:var(--navy2);
  border:1px solid rgba(245,166,35,.15);
  border-radius:var(--radius-lg);
  width:90%; max-width:520px;
  max-height:92vh; overflow-y:auto;
  padding:36px 32px;
  position:relative;
  box-shadow:0 40px 100px rgba(0,0,0,.6),
             0 0 0 1px rgba(255,255,255,.04);
  transform:translateY(28px) scale(.96);
  transition:transform .4s cubic-bezier(.16,1,.3,1);
}
.overlay.show .popup { transform:translateY(0) scale(1); }

.popup-close {
  position:absolute; top:16px; right:16px;
  width:32px; height:32px; border-radius:8px;
  background:rgba(255,255,255,.07); border:none;
  display:flex; align-items:center; justify-content:center;
  font-size:1.1rem; color:var(--white);
  transition:background .2s;
}
.popup-close:hover { background:rgba(255,255,255,.14); }

.popup-header { margin-bottom:24px; }
.popup-logo {
  display:flex; align-items:center; gap:8px;
  font-family:var(--font-head); font-size:.88rem; font-weight:700;
  color:var(--amber); margin-bottom:12px;
}
.popup-header h3 {
  font-family:var(--font-head); font-size:1.5rem; font-weight:800;
  color:var(--white); margin-bottom:4px; letter-spacing:-.02em;
}
.popup-header p { font-size:.83rem; color:var(--muted); }

.popup-form { display:flex; flex-direction:column; gap:0; }
.popup-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media(max-width:500px) { .popup-row { grid-template-columns:1fr; } }

.popup .form-group { margin-bottom:12px; }
.popup .form-group label {
  display:block; font-size:.73rem; font-weight:700;
  color:rgba(255,255,255,.45); text-transform:uppercase;
  letter-spacing:.07em; margin-bottom:5px;
}
.req { color:var(--amber); }
.popup .form-group input,
.popup .form-group textarea {
  width:100%; padding:11px 14px;
  background:#0a1220;
  border:1.5px solid rgba(255,255,255,.08);
  border-radius:8px;
  font-family:var(--font-body); font-size:.9rem;
  color:var(--white); outline:none;
  transition:border-color .2s, box-shadow .2s;
  -webkit-appearance:none; appearance:none;
}
.popup .form-group input::placeholder,
.popup .form-group textarea::placeholder { color:rgba(255,255,255,.2); }
.popup .form-group input:focus,
.popup .form-group textarea:focus {
  border-color:rgba(245,166,35,.5);
  box-shadow:0 0 0 3px rgba(245,166,35,.06);
}
.popup .form-group textarea { resize:vertical; }
.popup .select-wrap select {
  background:#0a1220;
  border-color:rgba(255,255,255,.08);
  color:var(--white);
}
.popup .select-wrap select option { background:#0a1220; }
.popup .select-wrap select:focus { border-color:rgba(245,166,35,.5); }

/* Picker */
.picker-group { position:relative; }
.picker-face {
  width:100%; height:44px;
  padding:0 38px 0 14px;
  background:#0a1220;
  border:1.5px solid rgba(255,255,255,.08);
  border-radius:8px;
  font-family:var(--font-body); font-size:.9rem; color:#fff;
  outline:none; box-sizing:border-box;
  cursor:pointer; caret-color:transparent;
  -webkit-appearance:none; appearance:none;
  transition:border-color .2s;
  position:relative; z-index:1;
  pointer-events:none;
}
.picker-face::placeholder { color:rgba(255,255,255,.2); }
.picker-icon {
  position:absolute; right:12px; top:50%;
  transform:translateY(-50%);
  color:rgba(255,255,255,.3); font-size:1rem;
  pointer-events:none; z-index:2;
}
.picker-group input[type="date"],
.picker-group input[type="time"] {
  position:absolute; inset:0;
  width:100%; height:100%;
  opacity:0; cursor:pointer; z-index:4;
  -webkit-appearance:none; appearance:none;
  border:none; background:transparent;
  color:transparent; font-size:16px;
}
.picker-group input[type="date"]::-webkit-datetime-edit,
.picker-group input[type="date"]::-webkit-inner-spin-button,
.picker-group input[type="date"]::-webkit-calendar-picker-indicator,
.picker-group input[type="time"]::-webkit-datetime-edit,
.picker-group input[type="time"]::-webkit-inner-spin-button,
.picker-group input[type="time"]::-webkit-calendar-picker-indicator {
  display:none !important; opacity:0 !important;
}

.btn-popup-submit {
  width:100%; padding:14px;
  background:var(--amber); border:none;
  border-radius:9px;
  font-family:var(--font-body); font-size:.97rem; font-weight:800;
  color:var(--navy);
  display:flex; align-items:center; justify-content:center; gap:8px;
  margin-top:8px;
  transition:background .2s, box-shadow .2s, transform .15s;
}
.btn-popup-submit:hover {
  background:var(--amber2);
  box-shadow:0 10px 32px var(--amber-glow);
  transform:translateY(-1px);
}

.popup-note {
  display:flex; align-items:center; gap:6px;
  font-size:.75rem; color:rgba(255,255,255,.28);
  margin-top:12px; text-align:center;
  justify-content:center;
}
.popup-note i { color:rgba(245,166,35,.5); }

/* ════════ RESPONSIVE ════════ */
@media(max-width:1024px) {
  .hero-inner { grid-template-columns:1fr; gap:40px; padding:60px 0; }
  .hero-visual { height:380px; }
  .hero-img { height:100%; }
  .about-section .section-inner { grid-template-columns:1fr; }
  .about-img-stack { height:360px; }
  .programs-grid { grid-template-columns:1fr 1fr; }
  .why-grid { grid-template-columns:1fr 1fr; }
  .testi-grid { grid-template-columns:1fr; }
  .contact-section .section-inner { grid-template-columns:1fr; }
  .footer-top { grid-template-columns:1fr 1fr; }
  .stats-band-inner { justify-content:center; gap:28px; }
}
@media(max-width:768px) {
  .nav-inner { padding:0 20px; }
  .nav-links, .nav-cta { display:none; }
  .hamburger { display:block; margin-left: auto;  }
  .hero { padding:0 20px; }
  .hero-inner { padding:60px 0 40px; }
  .float-card { display:none; }
  .partners-bar { gap:16px; }
  .section-inner { padding:0 20px; }
  .about-section, .programs-section, .why-section,
  .testimonials-section, .contact-section { padding:64px 0; }
  .programs-grid, .why-grid { grid-template-columns:1fr; }
  .footer-top { grid-template-columns:1fr; gap:32px; }
  .footer-bottom { flex-direction:column; gap:8px; text-align:center; }
  .map-label { padding:24px 20px 12px; }
  .stats-band { padding:28px 20px; }
  .sb-divider { display:none; }
  footer { padding:52px 20px 0; }
  .form-row { grid-template-columns:1fr; }
}
@media(max-width:480px) {
  .hero-stats { gap:8px; }
  .about-features { grid-template-columns:1fr; }
  .popup { padding:28px 20px; }
}