/* ============================================================
   SNEASHVI COMPUTER INSTITUTE — Main Stylesheet
   File: css/style.css
   ============================================================ */

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

:root {
  --navy:   #0d0f2b;
  --deep:   #12163a;
  --purple: #4a2d8f;
  --violet: #7b3fbf;
  --gold:   #e8a422;
  --amber:  #f5c842;
  --blue:   #1e3a8a;
  --cyan:   #38bdf8;
  --light:  #eef2ff;
  --white:  #ffffff;
  --muted:  #94a3b8;
}

/* ── Reset & Base ─────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family:'Outfit',sans-serif;
  background:var(--navy);
  color:var(--white);
  overflow-x:hidden;
}

/* ── Canvas Background ───────────────────────────────────── */
#bg-canvas { position:fixed; inset:0; z-index:0; pointer-events:none; }

/* ── Navigation ──────────────────────────────────────────── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 48px;
  background:rgba(13,15,43,0.85);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(123,63,191,0.2);
}
.nav-logo { display:flex; align-items:center; gap:12px; }
.nav-logo img { height:44px; filter:drop-shadow(0 0 8px rgba(232,164,34,.5)); }
.nav-brand {
  font-family:'Bebas Neue',sans-serif; font-size:1.3rem; letter-spacing:2px;
  background:linear-gradient(135deg,#a78bfa,var(--gold));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.nav-links { display:flex; gap:32px; list-style:none; }
.nav-links a {
  text-decoration:none; color:#cbd5e1; font-size:.88rem;
  font-weight:500; letter-spacing:1px; text-transform:uppercase;
  transition:color .3s; position:relative;
}
.nav-links a::after {
  content:''; position:absolute; bottom:-4px; left:0;
  width:0; height:2px; background:var(--gold); transition:width .3s;
}
.nav-links a:hover { color:var(--gold); }
.nav-links a:hover::after { width:100%; }
.nav-cta {
  background:linear-gradient(135deg,var(--violet),var(--blue));
  color:#fff !important; padding:10px 24px; border-radius:30px;
  font-weight:600 !important;
  box-shadow:0 0 20px rgba(123,63,191,.4);
  transition:transform .2s,box-shadow .2s !important;
}
.nav-cta:hover { transform:translateY(-2px); box-shadow:0 0 32px rgba(123,63,191,.7) !important; }
.nav-cta::after { display:none !important; }

/* ── Hero ────────────────────────────────────────────────── */
.hero {
  position:relative; z-index:1; min-height:100vh;
  display:flex; align-items:center;
  padding:120px 48px 80px; overflow:hidden;
}
.hero-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:60px; align-items:center;
  max-width:1200px; margin:0 auto; width:100%;
}
.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(232,164,34,.12); border:1px solid rgba(232,164,34,.35);
  padding:6px 18px; border-radius:30px;
  font-size:.75rem; letter-spacing:2px; text-transform:uppercase;
  color:var(--amber); font-weight:600; margin-bottom:24px;
  animation:fadeUp .8s ease both;
}
.badge-dot {
  width:7px; height:7px; border-radius:50%;
  background:var(--gold); animation:pulse 1.5s infinite;
}
@keyframes pulse {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:.5; transform:scale(1.4); }
}
.hero h1 {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(3rem,6vw,5.5rem);
  line-height:.95; letter-spacing:3px; margin-bottom:10px;
  animation:fadeUp .8s .1s ease both;
}
.hero h1 span {
  display:block;
  background:linear-gradient(135deg,#a78bfa 0%,var(--gold) 60%,var(--amber) 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.hero-sub {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(1.2rem,2.5vw,2rem);
  color:#64748b; letter-spacing:6px; margin-bottom:24px;
  animation:fadeUp .8s .2s ease both;
}
.hero-desc {
  font-size:1.05rem; color:var(--muted); line-height:1.75;
  max-width:480px; margin-bottom:40px;
  animation:fadeUp .8s .3s ease both;
}
.hero-desc strong { color:var(--cyan); }
.hero-actions { display:flex; gap:16px; flex-wrap:wrap; animation:fadeUp .8s .4s ease both; }
.hero-stats { display:flex; gap:32px; margin-top:48px; animation:fadeUp .8s .5s ease both; }
.stat { text-align:left; }
.stat-num { font-family:'Bebas Neue',sans-serif; font-size:2.2rem; color:var(--gold); line-height:1; }
.stat-label { font-size:.75rem; color:#64748b; letter-spacing:1px; text-transform:uppercase; margin-top:2px; }

/* ── Hero Visual ─────────────────────────────────────────── */
.hero-visual {
  position:relative; display:flex; align-items:center; justify-content:center;
  animation:fadeUp .8s .3s ease both;
}
.hero-logo-wrap {
  position:relative; width:380px; height:380px;
  display:flex; align-items:center; justify-content:center;
}
.orbit-ring {
  position:absolute; border-radius:50%;
  border:1px solid transparent; animation:spin linear infinite;
}
.ring1 { width:340px; height:340px; border-color:rgba(123,63,191,.3); animation-duration:12s; }
.ring2 { width:280px; height:280px; border-color:rgba(232,164,34,.2); animation-duration:8s; animation-direction:reverse; }
.ring3 { width:220px; height:220px; border-color:rgba(56,189,248,.15); animation-duration:15s; }
.orbit-dot {
  position:absolute; width:10px; height:10px; border-radius:50%;
  background:var(--gold); box-shadow:0 0 12px var(--gold);
  top:-5px; left:calc(50% - 5px);
}
@keyframes spin { to { transform:rotate(360deg); } }
.hero-logo-img {
  width:200px;
  filter:drop-shadow(0 0 30px rgba(123,63,191,.6)) drop-shadow(0 0 60px rgba(232,164,34,.3));
  animation:float 4s ease-in-out infinite; z-index:2;
}
@keyframes float { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-12px); } }
.tech-pills { position:absolute; width:100%; height:100%; }
.tech-pill {
  position:absolute; background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.12); border-radius:20px;
  padding:6px 14px; font-size:.7rem; letter-spacing:1px;
  font-family:'Space Mono',monospace; color:var(--muted);
  white-space:nowrap; animation:float ease-in-out infinite;
}
.tech-pill:nth-child(1) { top:8%; left:-10%; animation-duration:3.5s; color:var(--cyan); border-color:rgba(56,189,248,.3); }
.tech-pill:nth-child(2) { top:20%; right:-12%; animation-duration:4s; animation-delay:.5s; color:#f472b6; border-color:rgba(244,114,182,.3); }
.tech-pill:nth-child(3) { bottom:22%; left:-14%; animation-duration:4.5s; animation-delay:1s; color:var(--amber); border-color:rgba(232,164,34,.3); }
.tech-pill:nth-child(4) { bottom:8%; right:-8%; animation-duration:3.8s; animation-delay:1.5s; color:#86efac; border-color:rgba(134,239,172,.3); }
.tech-pill:nth-child(5) { top:50%; left:-16%; animation-duration:4.2s; animation-delay:.8s; color:#a78bfa; border-color:rgba(167,139,250,.3); }

/* ── Buttons ─────────────────────────────────────────────── */
.btn-primary {
  display:inline-flex; align-items:center; gap:10px;
  background:linear-gradient(135deg,var(--violet),#1e40af);
  color:#fff; text-decoration:none; padding:16px 36px;
  border-radius:50px; font-weight:700; font-size:.95rem;
  letter-spacing:1px; box-shadow:0 8px 32px rgba(123,63,191,.5);
  transition:transform .2s,box-shadow .2s; border:none; cursor:pointer;
}
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 16px 48px rgba(123,63,191,.7); }
.btn-outline {
  display:inline-flex; align-items:center; gap:10px;
  background:transparent; color:#fff; text-decoration:none;
  padding:16px 36px; border-radius:50px; font-weight:600; font-size:.95rem;
  letter-spacing:1px; border:1px solid rgba(255,255,255,.2); transition:all .2s; cursor:pointer;
}
.btn-outline:hover { background:rgba(255,255,255,.06); border-color:var(--gold); color:var(--gold); }

/* ── Marquee ─────────────────────────────────────────────── */
.marquee-section {
  position:relative; z-index:1;
  border-top:1px solid rgba(123,63,191,.2);
  border-bottom:1px solid rgba(123,63,191,.2);
  background:rgba(74,45,143,.1); padding:18px 0; overflow:hidden;
}
.marquee-track {
  display:flex; gap:48px;
  animation:marquee 25s linear infinite; width:max-content;
}
.marquee-item {
  display:flex; align-items:center; gap:12px;
  font-family:'Space Mono',monospace; font-size:.78rem;
  letter-spacing:2px; color:#64748b; text-transform:uppercase; white-space:nowrap;
}
.marquee-item .dot { color:var(--gold); font-size:1.2rem; }
@keyframes marquee { from { transform:translateX(0); } to { transform:translateX(-50%); } }

/* ── Section Base ────────────────────────────────────────── */
section { position:relative; z-index:1; padding:100px 48px; }
.container { max-width:1200px; margin:0 auto; width:100%; }
.section-tag {
  font-family:'Space Mono',monospace; font-size:.72rem;
  letter-spacing:4px; text-transform:uppercase; color:var(--gold);
  margin-bottom:16px; display:flex; align-items:center; gap:10px;
}
.section-tag::before { content:''; display:block; width:30px; height:2px; background:var(--gold); }
.section-title {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2.5rem,5vw,4rem);
  letter-spacing:2px; line-height:1; margin-bottom:16px;
}
.section-title em {
  font-style:normal;
  background:linear-gradient(135deg,#a78bfa,var(--gold));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}

/* ── Courses ─────────────────────────────────────────────── */
.courses-section { background:linear-gradient(to bottom,var(--navy),#0a0c24); }
.courses-intro {
  display:grid; grid-template-columns:1fr 1fr;
  gap:60px; align-items:end; margin-bottom:64px;
}
.courses-desc { font-size:1rem; color:#64748b; line-height:1.8; }
.courses-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.course-card {
  position:relative; background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08); border-radius:16px;
  padding:28px 22px; overflow:hidden; cursor:pointer;
  transition:transform .35s,border-color .35s,box-shadow .35s;
}
.course-card::before {
  content:''; position:absolute; inset:0;
  background:var(--card-glow,linear-gradient(135deg,rgba(74,45,143,.2),rgba(30,58,138,.2)));
  opacity:0; transition:opacity .35s; border-radius:16px;
}
.course-card:hover { transform:translateY(-8px); border-color:var(--card-accent,rgba(123,63,191,.5)); box-shadow:0 20px 60px var(--card-shadow,rgba(74,45,143,.3)); }
.course-card:hover::before { opacity:1; }
.course-card:nth-child(1)  { --card-accent:rgba(56,189,248,.5);  --card-shadow:rgba(56,189,248,.2);  --card-glow:linear-gradient(135deg,rgba(56,189,248,.1),rgba(30,58,138,.15));  --icon-color:#38bdf8; }
.course-card:nth-child(2)  { --card-accent:rgba(167,139,250,.5); --card-shadow:rgba(167,139,250,.2); --card-glow:linear-gradient(135deg,rgba(123,63,191,.15),rgba(74,45,143,.1)); --icon-color:#a78bfa; }
.course-card:nth-child(3)  { --card-accent:rgba(232,164,34,.5);  --card-shadow:rgba(232,164,34,.2);  --card-glow:linear-gradient(135deg,rgba(232,164,34,.12),rgba(30,58,138,.1)); --icon-color:#e8a422; }
.course-card:nth-child(4)  { --card-accent:rgba(244,114,182,.5); --card-shadow:rgba(244,114,182,.2); --card-glow:linear-gradient(135deg,rgba(244,114,182,.1),rgba(74,45,143,.15)); --icon-color:#f472b6; }
.course-card:nth-child(5)  { --card-accent:rgba(134,239,172,.5); --card-shadow:rgba(134,239,172,.2); --card-glow:linear-gradient(135deg,rgba(134,239,172,.1),rgba(30,58,138,.1)); --icon-color:#86efac; }
.course-card:nth-child(6)  { --card-accent:rgba(251,191,36,.5);  --card-shadow:rgba(251,191,36,.2);  --card-glow:linear-gradient(135deg,rgba(251,191,36,.1),rgba(74,45,143,.1));  --icon-color:#fbbf24; }
.course-card:nth-child(7)  { --card-accent:rgba(248,113,113,.5); --card-shadow:rgba(248,113,113,.2); --card-glow:linear-gradient(135deg,rgba(248,113,113,.1),rgba(30,58,138,.1)); --icon-color:#f87171; }
.course-card:nth-child(8)  { --card-accent:rgba(56,189,248,.5);  --card-shadow:rgba(56,189,248,.2);  --card-glow:linear-gradient(135deg,rgba(56,189,248,.08),rgba(74,45,143,.1)); --icon-color:#22d3ee; }
.course-card:nth-child(9)  { --card-accent:rgba(167,139,250,.5); --card-shadow:rgba(167,139,250,.2); --card-glow:linear-gradient(135deg,rgba(167,139,250,.1),rgba(30,58,138,.12)); --icon-color:#c084fc; }
.course-card:nth-child(10) { --card-accent:rgba(232,164,34,.5);  --card-shadow:rgba(232,164,34,.2);  --card-glow:linear-gradient(135deg,rgba(232,164,34,.1),rgba(74,45,143,.1));  --icon-color:#fb923c; }
.course-card:nth-child(11) { --card-accent:rgba(52,211,153,.5);  --card-shadow:rgba(52,211,153,.2);  --card-glow:linear-gradient(135deg,rgba(52,211,153,.1),rgba(30,58,138,.1));  --icon-color:#34d399; }
.course-card:nth-child(12) { --card-accent:rgba(244,114,182,.5); --card-shadow:rgba(244,114,182,.2); --card-glow:linear-gradient(135deg,rgba(244,114,182,.1),rgba(74,45,143,.12)); --icon-color:#e879f9; }
.course-icon { font-size:2.2rem; margin-bottom:16px; display:block; filter:drop-shadow(0 0 8px currentColor); color:var(--icon-color,var(--violet)); }
.course-name { font-weight:700; font-size:.95rem; letter-spacing:.5px; margin-bottom:8px; color:#e2e8f0; }
.course-desc { font-size:.78rem; color:#475569; line-height:1.6; }
.course-tag { display:inline-block; margin-top:14px; font-size:.65rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--icon-color,var(--violet)); font-family:'Space Mono',monospace; font-weight:700; }
.course-arrow { position:absolute; top:22px; right:22px; font-size:1rem; opacity:0; color:var(--icon-color,var(--violet)); transition:opacity .3s,transform .3s; }
.course-card:hover .course-arrow { opacity:1; transform:translate(2px,-2px); }
.course-card.featured { grid-column:span 2; display:grid; grid-template-columns:1fr 1fr; gap:20px; align-items:center; padding:36px; --card-accent:rgba(232,164,34,.6); --card-shadow:rgba(232,164,34,.3); --card-glow:linear-gradient(135deg,rgba(232,164,34,.12),rgba(74,45,143,.2)); --icon-color:#f5c842; }
.featured-left .course-icon { font-size:3.5rem; }
.featured-left .course-name { font-size:1.2rem; }
.featured-desc { font-size:.85rem; color:#64748b; line-height:1.7; }

/* ── Why Section ─────────────────────────────────────────── */
.why-section { background:linear-gradient(135deg,rgba(74,45,143,.08),rgba(30,58,138,.08)); border-top:1px solid rgba(123,63,191,.15); border-bottom:1px solid rgba(123,63,191,.15); }
.why-layout { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.why-hex-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.feature-box { background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.07); border-radius:14px; padding:22px 18px; transition:all .3s; }
.feature-box:hover { background:rgba(123,63,191,.12); border-color:rgba(123,63,191,.3); transform:translateY(-4px); }
.feature-box .f-icon { font-size:1.6rem; margin-bottom:10px; display:block; }
.feature-box .f-title { font-size:.82rem; font-weight:700; color:#e2e8f0; margin-bottom:4px; }
.feature-box .f-text { font-size:.72rem; color:#475569; line-height:1.5; }
.why-list { list-style:none; }
.why-list li { display:flex; gap:16px; align-items:flex-start; padding:20px 0; border-bottom:1px solid rgba(255,255,255,.05); }
.why-list li:last-child { border-bottom:none; }
.why-check { width:36px; height:36px; border-radius:50%; background:linear-gradient(135deg,var(--violet),var(--blue)); display:flex; align-items:center; justify-content:center; font-size:.9rem; flex-shrink:0; box-shadow:0 4px 16px rgba(123,63,191,.4); }
.why-text strong { display:block; font-size:.95rem; font-weight:700; color:#e2e8f0; margin-bottom:4px; }
.why-text span { font-size:.82rem; color:#475569; line-height:1.6; }

/* ── About ───────────────────────────────────────────────── */
.about-section { background:var(--navy); }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.about-card { background:linear-gradient(135deg,rgba(74,45,143,.15),rgba(30,58,138,.15)); border:1px solid rgba(123,63,191,.2); border-radius:24px; padding:48px; position:relative; overflow:hidden; }
.about-card::before { content:''; position:absolute; top:-50%; right:-30%; width:300px; height:300px; border-radius:50%; background:radial-gradient(circle,rgba(74,45,143,.3),transparent 70%); pointer-events:none; }
.about-card p { font-size:1rem; color:var(--muted); line-height:1.85; margin-bottom:20px; }
.address-box { background:rgba(232,164,34,.08); border:1px solid rgba(232,164,34,.2); border-radius:12px; padding:20px 22px; display:flex; gap:14px; align-items:flex-start; margin-top:28px; }
.addr-icon { font-size:1.3rem; flex-shrink:0; margin-top:2px; }
.addr-text { font-size:.88rem; color:var(--muted); line-height:1.6; }
.addr-text strong { color:var(--gold); display:block; margin-bottom:4px; font-size:.82rem; letter-spacing:1px; text-transform:uppercase; }
.about-logo-display { display:flex; align-items:center; justify-content:center; padding:60px 40px; background:linear-gradient(135deg,rgba(74,45,143,.12),rgba(30,58,138,.12)); border:1px solid rgba(123,63,191,.15); border-radius:24px; position:relative; overflow:hidden; }
.about-logo-display::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at center,rgba(74,45,143,.2),transparent 70%); }
.about-logo-display img { width:260px; filter:drop-shadow(0 0 40px rgba(123,63,191,.5)) drop-shadow(0 0 80px rgba(232,164,34,.2)); animation:float 4s ease-in-out infinite; position:relative; z-index:1; }

/* ── Contact ─────────────────────────────────────────────── */
.contact-section { background:linear-gradient(135deg,#0a0c24,var(--navy)); }
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start; }
.contact-info-cards { display:flex; flex-direction:column; gap:16px; }
.contact-card { display:flex; gap:18px; align-items:center; background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.07); border-radius:14px; padding:22px 24px; transition:all .3s; }
.contact-card:hover { background:rgba(74,45,143,.12); border-color:rgba(123,63,191,.3); transform:translateX(4px); }
.contact-card-icon { width:48px; height:48px; border-radius:12px; background:linear-gradient(135deg,var(--violet),var(--blue)); display:flex; align-items:center; justify-content:center; font-size:1.2rem; flex-shrink:0; box-shadow:0 4px 16px rgba(123,63,191,.3); }
.contact-card-title { font-size:.72rem; letter-spacing:2px; text-transform:uppercase; color:#475569; font-family:'Space Mono',monospace; margin-bottom:4px; }
.contact-card-text { font-size:.92rem; color:#e2e8f0; font-weight:500; }
.enroll-form { background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08); border-radius:20px; padding:40px; position:relative; overflow:hidden; }
.enroll-form::before { content:''; position:absolute; top:-30%; right:-20%; width:250px; height:250px; border-radius:50%; background:radial-gradient(circle,rgba(74,45,143,.2),transparent 70%); pointer-events:none; }
.form-title { font-family:'Bebas Neue',sans-serif; font-size:1.8rem; letter-spacing:2px; margin-bottom:8px; }
.form-subtitle { font-size:.85rem; color:#475569; margin-bottom:28px; }
.form-group { margin-bottom:16px; }
.form-group label { display:block; font-size:.75rem; letter-spacing:1.5px; text-transform:uppercase; color:#64748b; font-family:'Space Mono',monospace; margin-bottom:8px; }
.form-group input, .form-group select, .form-group textarea { width:100%; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1); border-radius:10px; padding:12px 16px; color:#fff; font-family:'Outfit',sans-serif; font-size:.92rem; outline:none; transition:border-color .3s,background .3s; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:rgba(123,63,191,.5); background:rgba(74,45,143,.1); }
.form-group select option { background:var(--navy); color:#fff; }
.form-group textarea { resize:none; height:90px; }
.form-submit { width:100%; padding:16px; background:linear-gradient(135deg,var(--violet),#1e40af); color:#fff; border:none; border-radius:50px; font-family:'Outfit',sans-serif; font-size:1rem; font-weight:700; letter-spacing:2px; text-transform:uppercase; cursor:pointer; margin-top:8px; box-shadow:0 8px 32px rgba(123,63,191,.4); transition:transform .2s,box-shadow .2s; }
.form-submit:hover { transform:translateY(-2px); box-shadow:0 16px 48px rgba(123,63,191,.6); }
.form-submit:disabled { opacity:.6; cursor:not-allowed; }
.form-msg { padding:10px 14px; border-radius:8px; font-size:.85rem; margin-top:12px; display:none; }
.form-msg.success { background:rgba(52,211,153,.12); border:1px solid rgba(52,211,153,.3); color:#34d399; }
.form-msg.error   { background:rgba(248,113,113,.12); border:1px solid rgba(248,113,113,.3); color:#f87171; }

/* ── Footer ──────────────────────────────────────────────── */
footer { position:relative; z-index:1; background:#07091c; border-top:1px solid rgba(123,63,191,.2); padding:48px; }
.footer-inner { max-width:1200px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.footer-brand { display:flex; align-items:center; gap:14px; }
.footer-brand img { height:40px; filter:drop-shadow(0 0 6px rgba(123,63,191,.5)); }
.footer-brand-text { font-family:'Bebas Neue',sans-serif; font-size:1.1rem; letter-spacing:2px; background:linear-gradient(135deg,#a78bfa,var(--gold)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.footer-copy { font-size:.78rem; color:#334155; letter-spacing:1px; text-align:center; }
.footer-links { display:flex; gap:24px; }
.footer-links a { text-decoration:none; font-size:.78rem; color:#334155; letter-spacing:1px; transition:color .2s; }
.footer-links a:hover { color:var(--gold); }

/* ── Utilities ───────────────────────────────────────────── */
.glow-divider { height:1px; background:linear-gradient(to right,transparent,rgba(123,63,191,.5),rgba(232,164,34,.5),transparent); }
.reveal { opacity:0; transform:translateY(40px); transition:opacity .7s ease,transform .7s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-delay-1 { transition-delay:.1s; }
.reveal-delay-2 { transition-delay:.2s; }
.reveal-delay-3 { transition-delay:.3s; }
.reveal-delay-4 { transition-delay:.4s; }
@keyframes fadeUp { from { opacity:0; transform:translateY(30px); } to { opacity:1; transform:translateY(0); } }

/* ── Responsive ──────────────────────────────────────────── */
/* ── Hamburger Button ────────────────────────────────────── */
.nav-hamburger {
  display:none; flex-direction:column; justify-content:space-between;
  width:26px; height:20px; background:none; border:none; cursor:pointer;
  padding:0; z-index:200;
}
.nav-hamburger span {
  display:block; height:2px; width:100%; background:var(--gold);
  border-radius:2px; transition:transform .3s, opacity .3s;
}
.nav-hamburger.open span:nth-child(1) { transform:translateY(9px) rotate(45deg); }
.nav-hamburger.open span:nth-child(2) { opacity:0; }
.nav-hamburger.open span:nth-child(3) { transform:translateY(-9px) rotate(-45deg); }

@media(max-width:900px) {
  nav { padding:12px 24px; }
  .nav-hamburger { display:flex; }
  .nav-links {
    display:none; position:fixed; top:0; left:0; right:0; bottom:0;
    background:rgba(13,15,43,0.98); flex-direction:column; align-items:center;
    justify-content:center; gap:32px; z-index:150;
  }
  .nav-links.open { display:flex; }
  .nav-links a { font-size:1.3rem; }
  section { padding:70px 24px; }
  .hero { padding:100px 24px 60px; }
  .hero-grid,.courses-intro,.why-layout,.about-grid,.contact-grid { grid-template-columns:1fr; gap:40px; }
  .hero-visual { order:-1; }
  .hero-logo-wrap { width:260px; height:260px; }
  .ring1 { width:240px; height:240px; }
  .ring2 { width:190px; height:190px; }
  .ring3 { width:150px; height:150px; }
  .hero-logo-img { width:140px; }
  .courses-grid { grid-template-columns:repeat(2,1fr); }
  .course-card.featured { grid-column:span 2; grid-template-columns:1fr; }
  .why-hex-grid { grid-template-columns:repeat(2,1fr); }
  footer { padding:32px 24px; }
  .footer-inner { flex-direction:column; align-items:center; text-align:center; }
}
@media(max-width:560px) {
  .courses-grid { grid-template-columns:1fr; }
  .course-card.featured { grid-column:span 1; }
  .hero-stats { gap:20px; }
}
