@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;500;600;700;800;900&family=Poppins:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=Montserrat:wght@400;500;600;700;800&display=swap');

:root {
  --bg-dark: #050714;
  --bg-secondary: #0a0f2e;
  --bg-card: rgba(255,255,255,0.04);
  --bg-card-hover: rgba(255,255,255,0.07);
  --purple: #7c3aed;
  --purple-light: #a78bfa;
  --purple-dim: rgba(124,58,237,0.15);
  --gold: #f59e0b;
  --gold-light: #fcd34d;
  --gold-dim: rgba(245,158,11,0.15);
  --teal: #06b6d4;
  --teal-light: #67e8f9;
  --teal-dim: rgba(6,182,212,0.15);
  --coral: #f43f5e;
  --coral-dim: rgba(244,63,94,0.15);
  --green: #10b981;
  --green-dim: rgba(16,185,129,0.15);
  --text: #f8fafc;
  --text-soft: #94a3b8;
  --text-muted: #475569;
  --border: rgba(255,255,255,0.08);
  --border-glow: rgba(255,255,255,0.18);
  --glow-purple: 0 0 40px rgba(124,58,237,0.4);
  --glow-gold: 0 0 40px rgba(245,158,11,0.4);
  --glow-teal: 0 0 40px rgba(6,182,212,0.4);
  --radius: 16px;
  --radius-sm: 8px;
  --radius-lg: 24px;
  --ease: all 0.35s cubic-bezier(0.4,0,0.2,1);
}

*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; overflow-x:hidden; }
body { background:var(--bg-dark); color:var(--text); font-family:'Poppins',sans-serif; overflow-x:hidden; cursor:none; line-height:1.6; }

/* ===== CUSTOM CURSOR ===== */
.cursor { width:10px; height:10px; background:var(--gold); border-radius:50%; position:fixed; pointer-events:none; z-index:99999; transform:translate(-50%,-50%); transition:width .2s,height .2s,background .2s; }
.cursor-ring { width:36px; height:36px; border:1.5px solid rgba(245,158,11,0.6); border-radius:50%; position:fixed; pointer-events:none; z-index:99998; transform:translate(-50%,-50%); transition:all 0.12s ease; }
body:has(a:hover) .cursor, body:has(button:hover) .cursor { width:18px; height:18px; background:var(--purple-light); }
body:has(a:hover) .cursor-ring, body:has(button:hover) .cursor-ring { width:54px; height:54px; border-color:rgba(124,58,237,0.5); }

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-track { background:var(--bg-dark); }
::-webkit-scrollbar-thumb { background:var(--purple); border-radius:4px; }

/* ===== SCROLL PROGRESS ===== */
.scroll-progress { position:fixed; top:0; left:0; height:3px; background:linear-gradient(90deg,var(--purple),var(--gold),var(--teal)); z-index:9999; width:0%; transition:width .1s; }

/* ===== LOADING SCREEN ===== */
.loader { position:fixed; inset:0; background:var(--bg-dark); z-index:999999; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:24px; transition:opacity .6s, visibility .6s; }
.loader.done { opacity:0; visibility:hidden; }
.loader-logo { font-family:'Orbitron',sans-serif; font-size:1.4rem; font-weight:900; background:linear-gradient(135deg,var(--gold),var(--teal)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.loader-bar { width:200px; height:3px; background:rgba(255,255,255,0.1); border-radius:3px; overflow:hidden; }
.loader-fill { height:100%; background:linear-gradient(90deg,var(--purple),var(--teal)); border-radius:3px; animation:loader-anim 1.4s ease forwards; }
@keyframes loader-anim { from{width:0} to{width:100%} }

/* ===== PAGE TRANSITION ===== */
.page-transition { position:fixed; inset:0; background:linear-gradient(135deg,var(--purple),var(--bg-dark)); z-index:999998; transform:scaleY(0); transform-origin:bottom; transition:transform .5s cubic-bezier(0.76,0,0.24,1); }
.page-transition.active { transform:scaleY(1); transform-origin:top; }

/* ===== NAVBAR ===== */
.navbar { position:fixed; top:0; left:0; right:0; z-index:1000; padding:22px 48px; display:flex; align-items:center; justify-content:space-between; transition:var(--ease); }
.navbar.scrolled { background:rgba(5,7,20,0.85); backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px); border-bottom:1px solid var(--border); padding:14px 48px; }
.nav-logo { display:flex; align-items:center; gap:12px; text-decoration:none; }
.logo-mark { width:44px; height:44px; background:linear-gradient(135deg,var(--purple),var(--teal)); border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:20px; animation:logo-breathe 2.5s ease-in-out infinite; flex-shrink:0; }
@keyframes logo-breathe { 0%,100%{box-shadow:0 0 0 0 rgba(124,58,237,.5)} 50%{box-shadow:0 0 0 12px rgba(124,58,237,0)} }
.logo-text { font-family:'Orbitron',sans-serif; font-size:14px; font-weight:800; background:linear-gradient(135deg,var(--gold),var(--teal)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; line-height:1.3; }
.logo-year { display:block; font-size:10px; color:var(--text-muted); font-family:'Poppins',sans-serif; -webkit-text-fill-color:var(--text-muted); }
.nav-links { display:flex; align-items:center; gap:4px; list-style:none; }
.nav-links a { color:var(--text-soft); text-decoration:none; font-size:13.5px; font-weight:500; padding:8px 14px; border-radius:8px; transition:var(--ease); position:relative; }
.nav-links a:hover { color:var(--text); background:var(--bg-card); }
.nav-links a.active { color:var(--text); background:var(--bg-card); }
.nav-links a.active::after { content:''; position:absolute; bottom:5px; left:50%; transform:translateX(-50%); width:4px; height:4px; background:var(--gold); border-radius:50%; }
.nav-cta { background:linear-gradient(135deg,var(--purple),var(--teal)) !important; color:#fff !important; padding:10px 22px !important; border-radius:50px !important; -webkit-text-fill-color:#fff !important; }
.nav-cta:hover { box-shadow:var(--glow-purple) !important; transform:translateY(-2px); }
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:8px; background:none; border:none; }
.hamburger span { width:24px; height:2px; background:var(--text); border-radius:2px; transition:var(--ease); display:block; }

/* ===== MOBILE NAV ===== */
.mobile-nav { display:none; position:fixed; inset:0; background:rgba(5,7,20,0.98); z-index:9999; align-items:center; justify-content:center; flex-direction:column; gap:24px; }
.mobile-nav.open { display:flex; }
.mobile-nav a { color:var(--text); text-decoration:none; font-family:'Orbitron',sans-serif; font-size:1.4rem; font-weight:700; transition:var(--ease); letter-spacing:.05em; }
.mobile-nav a:hover { color:var(--gold); }
.mob-close { position:absolute; top:24px; right:24px; background:none; border:none; color:var(--text); font-size:28px; cursor:pointer; }

/* ===== HERO ===== */
.hero { min-height:100vh; position:relative; display:flex; align-items:center; justify-content:center; overflow:hidden; }
#particles-canvas { position:absolute; inset:0; z-index:0; }
.hero-bg { position:absolute; inset:0; background:radial-gradient(ellipse 80% 70% at 15% 20%, rgba(124,58,237,.14) 0%, transparent 60%), radial-gradient(ellipse 60% 60% at 85% 80%, rgba(6,182,212,.1) 0%, transparent 60%), linear-gradient(180deg,#050714 0%,#0d0523 50%,#050714 100%); z-index:1; }
.hero-content { position:relative; z-index:2; text-align:center; max-width:1020px; padding:0 24px; }
.hero-badge { display:inline-flex; align-items:center; gap:8px; background:rgba(124,58,237,.12); border:1px solid rgba(124,58,237,.3); border-radius:50px; padding:8px 20px; margin-bottom:28px; font-size:12px; color:var(--purple-light); text-transform:uppercase; letter-spacing:.15em; animation:float 3.5s ease-in-out infinite; }
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
.hero-badge i { animation:spin-slow 4s linear infinite; }
@keyframes spin-slow { from{transform:rotate(0)} to{transform:rotate(360deg)} }
.hero-title { font-family:'Orbitron',sans-serif; font-size:clamp(2.2rem,6vw,5.2rem); font-weight:900; line-height:1.05; margin-bottom:18px; }
.hero-title .line1 { display:block; background:linear-gradient(135deg,#fff,#cbd5e1); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.hero-title .line2 { display:block; background:linear-gradient(135deg,var(--gold),var(--coral)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; position:relative; }
.glitch { position:relative; }
.glitch::before,.glitch::after { content:attr(data-text); position:absolute; inset:0; background:inherit; -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.glitch::before { background:linear-gradient(135deg,#ff0080,#ff6b6b); clip-path:polygon(0 0,100% 0,100% 45%,0 45%); animation:g1 4s steps(1) infinite; }
.glitch::after { background:linear-gradient(135deg,#00f5ff,#0080ff); clip-path:polygon(0 55%,100% 55%,100% 100%,0 100%); animation:g2 4s steps(1) infinite; }
@keyframes g1 { 0%,89%,100%{transform:translate(0);opacity:0} 90%{transform:translate(-4px,-2px);opacity:.8} 92%{transform:translate(4px,2px);opacity:0} 94%{transform:translate(-4px,2px);opacity:.8} 96%{transform:translate(0);opacity:0} }
@keyframes g2 { 0%,87%,100%{transform:translate(0);opacity:0} 88%{transform:translate(4px,2px);opacity:.8} 90%{transform:translate(-4px,-2px);opacity:0} 92%{transform:translate(4px,-2px);opacity:.8} 94%{transform:translate(0);opacity:0} }
.hero-tagline { font-family:'Orbitron',sans-serif; font-size:clamp(.85rem,1.8vw,1.1rem); color:var(--teal-light); letter-spacing:.12em; text-transform:uppercase; margin-bottom:20px; }
.hero-desc { font-size:clamp(.95rem,1.4vw,1.08rem); color:var(--text-soft); max-width:720px; margin:0 auto 28px; line-height:1.85; }
.hero-date { display:inline-flex; align-items:center; gap:8px; background:rgba(245,158,11,.1); border:1px solid rgba(245,158,11,.3); border-radius:50px; padding:10px 24px; margin-bottom:40px; color:var(--gold-light); font-weight:600; font-size:.9rem; }
.hero-btns { display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap; margin-bottom:56px; }
.scroll-hint { position:absolute; bottom:36px; left:50%; transform:translateX(-50%); z-index:2; display:flex; flex-direction:column; align-items:center; gap:8px; color:var(--text-muted); font-size:11px; letter-spacing:.15em; text-transform:uppercase; }
.scroll-hint-line { width:1px; height:48px; background:linear-gradient(180deg,transparent,var(--teal)); animation:scroll-line 2s ease-in-out infinite; }
@keyframes scroll-line { 0%{height:0;opacity:0} 50%{height:48px;opacity:1} 100%{height:0;opacity:0;transform:translateY(48px)} }

/* ===== BUTTONS ===== */
.btn { display:inline-flex; align-items:center; gap:10px; padding:15px 34px; border-radius:50px; font-weight:600; font-size:14.5px; text-decoration:none; transition:var(--ease); position:relative; overflow:hidden; border:none; cursor:pointer; font-family:'Poppins',sans-serif; }
.btn-primary { background:linear-gradient(135deg,var(--purple),var(--teal)); color:#fff; }
.btn-primary::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,var(--teal),var(--purple)); opacity:0; transition:opacity .3s; }
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 20px 50px rgba(124,58,237,.4); }
.btn-primary:hover::before { opacity:1; }
.btn-primary span, .btn-primary i { position:relative; z-index:1; }
.btn-secondary { background:transparent; color:var(--text); border:1.5px solid var(--border-glow); }
.btn-secondary:hover { background:var(--bg-card); border-color:var(--gold); color:var(--gold); transform:translateY(-3px); }
.btn-ghost { background:transparent; color:var(--purple-light); border:1px solid rgba(124,58,237,.3); }
.btn-ghost:hover { background:var(--purple-dim); border-color:var(--purple); transform:translateY(-2px); }
.btn-sm { padding:10px 22px; font-size:13px; }

/* ===== SECTIONS ===== */
section { padding:100px 48px; }
.container { max-width:1200px; margin:0 auto; }
.sec-tag { display:inline-flex; align-items:center; gap:8px; background:var(--purple-dim); border:1px solid rgba(124,58,237,.25); border-radius:50px; padding:6px 16px; font-size:11px; color:var(--purple-light); text-transform:uppercase; letter-spacing:.15em; margin-bottom:14px; }
.sec-title { font-family:'Orbitron',sans-serif; font-size:clamp(1.7rem,3.8vw,2.9rem); font-weight:800; margin-bottom:16px; background:linear-gradient(135deg,var(--text),var(--text-soft)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.sec-title .accent { background:linear-gradient(135deg,var(--gold),var(--coral)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.sec-sub { color:var(--text-soft); font-size:1.02rem; max-width:600px; line-height:1.85; }
.sec-header { margin-bottom:56px; }
.sec-header.centered { text-align:center; }
.sec-header.centered .sec-sub { margin:0 auto; }
.divider { width:56px; height:3px; background:linear-gradient(90deg,var(--purple),var(--teal)); border-radius:3px; margin:16px 0; }
.divider.center { margin:16px auto; }

/* ===== STATS BAND ===== */
.stats-band { padding:56px 48px; background:linear-gradient(135deg,rgba(124,58,237,.05),rgba(6,182,212,.05)); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.stats-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:32px; }
.stat-item { text-align:center; }
.stat-num { font-family:'Orbitron',sans-serif; font-size:2.8rem; font-weight:900; background:linear-gradient(135deg,var(--gold),var(--coral)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; line-height:1; margin-bottom:8px; }
.stat-label { color:var(--text-soft); font-size:.8rem; text-transform:uppercase; letter-spacing:.12em; }

/* ===== CARDS ===== */
.card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:28px; transition:var(--ease); position:relative; overflow:hidden; }
.card::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(124,58,237,.05),transparent); opacity:0; transition:opacity .3s; }
.card:hover { border-color:rgba(124,58,237,.3); transform:translateY(-5px); box-shadow:0 24px 60px rgba(0,0,0,.35), var(--glow-purple); }
.card:hover::before { opacity:1; }
.card-icon { width:56px; height:56px; border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:22px; margin-bottom:18px; }
.ci-purple { background:var(--purple-dim); color:var(--purple-light); }
.ci-gold { background:var(--gold-dim); color:var(--gold-light); }
.ci-teal { background:var(--teal-dim); color:var(--teal-light); }
.ci-coral { background:var(--coral-dim); color:#fb7185; }
.ci-green { background:var(--green-dim); color:#34d399; }
.card h3 { font-family:'Montserrat',sans-serif; font-size:1.05rem; font-weight:700; margin-bottom:10px; }
.card p { color:var(--text-soft); font-size:.88rem; line-height:1.78; }

/* ===== GRIDS ===== */
.grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:22px; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.grid-auto { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:22px; }

/* ===== WELCOME SECTION ===== */
.welcome-wrap { display:grid; grid-template-columns:1fr 1fr; gap:70px; align-items:center; }
.welcome-img { position:relative; border-radius:var(--radius-lg); overflow:hidden; }
.welcome-img img { width:100%; height:520px; object-fit:cover; transition:transform .7s ease; display:block; }
.welcome-img:hover img { transform:scale(1.06); }
.welcome-img::after { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(124,58,237,.18),transparent); pointer-events:none; border-radius:var(--radius-lg); }
.img-badge { position:absolute; bottom:20px; left:20px; background:rgba(5,7,20,.85); backdrop-filter:blur(12px); border:1px solid var(--border); border-radius:var(--radius); padding:14px 18px; z-index:1; }
.img-badge-title { font-weight:700; font-size:1rem; color:var(--gold); }
.img-badge-sub { font-size:.75rem; color:var(--text-soft); margin-top:3px; }
.welcome-text p { color:var(--text-soft); line-height:1.85; margin-bottom:14px; font-size:.95rem; }
.check-list { list-style:none; display:flex; flex-direction:column; gap:10px; margin:20px 0 28px; }
.check-list li { display:flex; align-items:center; gap:12px; color:var(--text-soft); font-size:.92rem; }
.check-list li i { color:var(--teal); flex-shrink:0; }

/* ===== HIGHLIGHTS SECTION ===== */
.hl-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:28px; text-align:center; transition:var(--ease); position:relative; overflow:hidden; }
.hl-card::after { content:''; position:absolute; top:0; inset-inline:0; height:3px; background:linear-gradient(90deg,var(--purple),var(--teal)); transform:scaleX(0); transition:transform .35s; }
.hl-card:hover::after { transform:scaleX(1); }
.hl-card:hover { transform:translateY(-6px); box-shadow:0 24px 60px rgba(0,0,0,.3); border-color:rgba(124,58,237,.2); }
.hl-icon { font-size:2.6rem; margin-bottom:14px; display:block; }
.hl-value { font-family:'Orbitron',sans-serif; font-size:1.6rem; font-weight:700; color:var(--gold); margin-bottom:6px; line-height:1.2; }
.hl-label { color:var(--text-soft); font-size:.78rem; text-transform:uppercase; letter-spacing:.12em; }

/* ===== PAGE HERO (inner pages) ===== */
.page-hero { min-height:46vh; display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; padding:120px 48px 80px; text-align:center; }
.page-hero-bg { position:absolute; inset:0; background:radial-gradient(ellipse 80% 60% at 50% 50%, rgba(124,58,237,.12) 0%, transparent 70%), linear-gradient(180deg,#050714 0%,#0d0523 100%); z-index:0; }
.page-hero-content { position:relative; z-index:1; }
.page-hero h1 { font-family:'Orbitron',sans-serif; font-size:clamp(1.9rem,4.5vw,3.4rem); font-weight:900; background:linear-gradient(135deg,#fff,var(--text-soft)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; margin-bottom:14px; }
.page-hero h1 .accent { background:linear-gradient(135deg,var(--gold),var(--coral)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.page-hero p { color:var(--text-soft); font-size:1.05rem; max-width:600px; margin:0 auto; line-height:1.85; }
.page-hero .hero-badge { margin-bottom:16px; }

/* ===== PARTNERS ===== */
.partner-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:36px 28px; text-align:center; transition:var(--ease); }
.partner-card:hover { border-color:rgba(124,58,237,.35); transform:translateY(-5px); box-shadow:0 24px 60px rgba(0,0,0,.3); }
.partner-logo-wrap { width:76px; height:76px; border-radius:20px; display:flex; align-items:center; justify-content:center; font-size:1.9rem; margin:0 auto 18px; }
.pl-purple { background:linear-gradient(135deg,var(--purple),var(--teal)); }
.pl-gold { background:linear-gradient(135deg,var(--gold),var(--coral)); }
.pl-green { background:linear-gradient(135deg,var(--green),var(--teal)); }
.partner-name { font-family:'Montserrat',sans-serif; font-size:1rem; font-weight:700; margin-bottom:6px; }
.partner-role { color:var(--teal); font-size:.72rem; text-transform:uppercase; letter-spacing:.12em; margin-bottom:14px; }
.partner-desc { color:var(--text-soft); font-size:.85rem; line-height:1.75; }

/* ===== CONTACT ===== */
.contact-form { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-lg); padding:40px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.form-group { margin-bottom:20px; }
.form-group label { display:block; color:var(--text-soft); font-size:.78rem; font-weight:600; text-transform:uppercase; letter-spacing:.12em; margin-bottom:8px; }
.form-group input, .form-group textarea, .form-group select { width:100%; background:rgba(255,255,255,.03); border:1px solid var(--border); border-radius:var(--radius-sm); padding:13px 16px; color:var(--text); font-family:'Poppins',sans-serif; font-size:.92rem; outline:none; transition:var(--ease); }
.form-group input:focus, .form-group textarea:focus, .form-group select:focus { border-color:var(--purple); box-shadow:0 0 0 3px rgba(124,58,237,.1); background:rgba(124,58,237,.03); }
.form-group textarea { height:130px; resize:vertical; }
.form-group select option { background:#0a0f2e; }
.contact-info-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:28px; display:flex; align-items:flex-start; gap:16px; margin-bottom:16px; }
.cic-icon { width:46px; height:46px; background:var(--purple-dim); border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:18px; color:var(--purple-light); flex-shrink:0; }
.cic-label { font-size:.75rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:.1em; margin-bottom:4px; }
.cic-value { font-weight:600; font-size:.95rem; }
.cic-value a { color:var(--text); text-decoration:none; transition:var(--ease); }
.cic-value a:hover { color:var(--gold); }
.social-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-top:8px; }
.social-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-sm); padding:16px 12px; text-align:center; text-decoration:none; color:var(--text-soft); transition:var(--ease); font-size:.78rem; }
.social-card i { display:block; font-size:1.3rem; margin-bottom:6px; }
.social-card:hover { background:var(--purple-dim); border-color:var(--purple); color:var(--purple-light); transform:translateY(-3px); }

/* ===== RESOURCES ===== */
.resource-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:22px; display:flex; align-items:flex-start; gap:14px; transition:var(--ease); text-decoration:none; color:inherit; }
.resource-card:hover { border-color:rgba(124,58,237,.3); transform:translateX(5px); background:var(--bg-card-hover); }
.rc-icon { width:46px; height:46px; border-radius:12px; background:var(--purple-dim); display:flex; align-items:center; justify-content:center; font-size:19px; color:var(--purple-light); flex-shrink:0; }
.rc-title { font-weight:600; font-size:.92rem; margin-bottom:4px; }
.rc-sub { color:var(--text-soft); font-size:.8rem; }
.resource-cat { margin-bottom:40px; }
.resource-cat-title { font-family:'Montserrat',sans-serif; font-size:.8rem; font-weight:700; text-transform:uppercase; letter-spacing:.15em; color:var(--teal); margin-bottom:14px; display:flex; align-items:center; gap:8px; }
.resource-cat-title::after { content:''; flex:1; height:1px; background:var(--border); }

/* ===== MEDIA ===== */
.media-filter { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:32px; }
.filter-btn { padding:8px 18px; border-radius:50px; border:1px solid var(--border); background:transparent; color:var(--text-soft); font-size:.8rem; font-weight:500; cursor:pointer; transition:var(--ease); font-family:'Poppins',sans-serif; }
.filter-btn.active, .filter-btn:hover { background:var(--purple-dim); border-color:rgba(124,58,237,.4); color:var(--purple-light); }
.media-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; transition:var(--ease); }
.media-card:hover { transform:translateY(-5px); box-shadow:0 24px 60px rgba(0,0,0,.3); }
.media-thumb { aspect-ratio:16/9; position:relative; overflow:hidden; background:linear-gradient(135deg,rgba(124,58,237,.2),rgba(6,182,212,.2)); display:flex; align-items:center; justify-content:center; }
.media-thumb img { width:100%; height:100%; object-fit:cover; transition:transform .6s; }
.media-card:hover .media-thumb img { transform:scale(1.07); }
.media-play { position:absolute; width:52px; height:52px; background:rgba(255,255,255,.92); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:16px; color:var(--purple); opacity:0; transform:scale(.7); transition:var(--ease); }
.media-card:hover .media-play { opacity:1; transform:scale(1); }
.media-type-tag { position:absolute; top:12px; left:12px; background:rgba(5,7,20,.8); backdrop-filter:blur(8px); border-radius:6px; padding:4px 10px; font-size:.7rem; color:var(--teal-light); text-transform:uppercase; letter-spacing:.1em; }
.media-info { padding:18px; }
.media-title { font-weight:600; font-size:.88rem; line-height:1.5; }

/* ===== LEADERBOARD ===== */
.award-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:22px; text-align:center; transition:var(--ease); position:relative; overflow:hidden; }
.award-card::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(245,158,11,.06),transparent); opacity:0; transition:opacity .3s; }
.award-card:hover { transform:translateY(-5px); border-color:rgba(245,158,11,.3); }
.award-card:hover::before { opacity:1; }
.award-icon { font-size:2.3rem; margin-bottom:10px; display:block; }
.award-name { font-family:'Montserrat',sans-serif; font-weight:700; font-size:.88rem; margin-bottom:6px; }
.award-desc { color:var(--text-soft); font-size:.78rem; }
.lb-table { width:100%; border-collapse:collapse; }
.lb-table th { background:rgba(124,58,237,.1); color:var(--purple-light); font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.12em; padding:14px 18px; text-align:left; border-bottom:1px solid var(--border); }
.lb-table td { padding:14px 18px; border-bottom:1px solid var(--border); color:var(--text-soft); transition:var(--ease); font-size:.9rem; }
.lb-table tr:hover td { background:var(--bg-card-hover); color:var(--text); }
.rank-badge { width:30px; height:30px; border-radius:8px; display:inline-flex; align-items:center; justify-content:center; font-weight:700; font-size:.8rem; }
.r1 { background:rgba(255,215,0,.15); color:var(--gold); }
.r2 { background:rgba(192,192,192,.15); color:#c0c0c0; }
.r3 { background:rgba(205,127,50,.15); color:#cd7f32; }
.r-n { background:var(--bg-card); color:var(--text-muted); }

/* ===== TIMELINE ===== */
.timeline { position:relative; padding:20px 0; }
.timeline::before { content:''; position:absolute; left:50%; top:0; bottom:0; width:2px; background:linear-gradient(180deg,var(--purple),var(--teal)); transform:translateX(-50%); }
.tl-item { display:flex; justify-content:flex-end; padding-right:calc(50% + 36px); margin-bottom:36px; position:relative; }
.tl-item:nth-child(even) { justify-content:flex-start; padding-right:0; padding-left:calc(50% + 36px); }
.tl-dot { position:absolute; left:50%; transform:translateX(-50%); width:14px; height:14px; background:var(--gold); border-radius:50%; box-shadow:var(--glow-gold); top:20px; }
.tl-box { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:22px; max-width:380px; }
.tl-date { color:var(--teal); font-size:.8rem; font-weight:600; margin-bottom:6px; }
.tl-title { font-weight:700; margin-bottom:6px; font-size:.95rem; }
.tl-desc { color:var(--text-soft); font-size:.85rem; }

/* ===== ABOUT FEATURE ===== */
.about-feature { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; margin-bottom:100px; }
.about-feature:nth-child(even) .about-feature-img { order:-1; }
.about-feature-img { border-radius:var(--radius-lg); overflow:hidden; }
.about-feature-img img { width:100%; height:400px; object-fit:cover; transition:transform .7s; display:block; }
.about-feature-img:hover img { transform:scale(1.05); }
.about-feature-text p { color:var(--text-soft); line-height:1.85; margin-bottom:14px; font-size:.95rem; }
.about-feature-text ul { list-style:none; display:flex; flex-direction:column; gap:10px; margin:18px 0; }
.about-feature-text ul li { display:flex; align-items:flex-start; gap:10px; color:var(--text-soft); font-size:.9rem; }
.about-feature-text ul li i { color:var(--gold); margin-top:2px; flex-shrink:0; }

/* ===== VISION MISSION ===== */
.vm-card { background:linear-gradient(135deg,rgba(124,58,237,.08),rgba(6,182,212,.05)); border:1px solid rgba(124,58,237,.2); border-radius:var(--radius-lg); padding:40px; }
.vm-card h3 { font-family:'Orbitron',sans-serif; font-size:1.3rem; font-weight:700; margin-bottom:16px; background:linear-gradient(135deg,var(--gold),var(--coral)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.vm-card p { color:var(--text-soft); line-height:1.85; font-size:.95rem; }

/* ===== TAG CHIPS ===== */
.tag { display:inline-flex; align-items:center; gap:5px; padding:4px 12px; border-radius:50px; font-size:.72rem; font-weight:600; }
.tag-purple { background:var(--purple-dim); color:var(--purple-light); border:1px solid rgba(124,58,237,.2); }
.tag-teal { background:var(--teal-dim); color:var(--teal-light); border:1px solid rgba(6,182,212,.2); }
.tag-gold { background:var(--gold-dim); color:var(--gold-light); border:1px solid rgba(245,158,11,.2); }
.tag-green { background:var(--green-dim); color:#34d399; border:1px solid rgba(16,185,129,.2); }

/* ===== FOOTER ===== */
footer { background:#050714; border-top:1px solid var(--border); padding:80px 48px 36px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:56px; margin-bottom:56px; }
.footer-brand p { color:var(--text-soft); font-size:.85rem; line-height:1.8; margin:16px 0 22px; }
.footer-socials { display:flex; gap:10px; flex-wrap:wrap; }
.soc-btn { width:38px; height:38px; border-radius:10px; background:var(--bg-card); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--text-soft); font-size:15px; text-decoration:none; transition:var(--ease); }
.soc-btn:hover { background:var(--purple); border-color:var(--purple); color:#fff; transform:translateY(-3px); }
.footer-col h4 { font-family:'Montserrat',sans-serif; font-weight:700; font-size:.9rem; margin-bottom:18px; letter-spacing:.05em; }
.footer-links { list-style:none; display:flex; flex-direction:column; gap:9px; }
.footer-links a { color:var(--text-soft); text-decoration:none; font-size:.85rem; transition:var(--ease); }
.footer-links a:hover { color:var(--gold); padding-left:5px; }
.footer-bottom { border-top:1px solid var(--border); padding-top:32px; display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.footer-tagline { font-family:'Orbitron',sans-serif; font-size:.72rem; color:var(--text-muted); text-align:center; flex:1; }

/* ===== BACK TO TOP ===== */
.btt { position:fixed; bottom:28px; right:28px; width:46px; height:46px; background:linear-gradient(135deg,var(--purple),var(--teal)); border-radius:12px; display:flex; align-items:center; justify-content:center; color:#fff; font-size:17px; cursor:pointer; border:none; opacity:0; transform:translateY(16px); transition:var(--ease); z-index:500; text-decoration:none; }
.btt.show { opacity:1; transform:translateY(0); }
.btt:hover { transform:translateY(-4px); box-shadow:var(--glow-purple); }

/* ===== REVEAL ANIMATIONS ===== */
.reveal { opacity:0; transform:translateY(28px); transition:opacity .65s ease, transform .65s ease; }
.reveal.vis { opacity:1; transform:translateY(0); }
.reveal-l { opacity:0; transform:translateX(-28px); transition:opacity .65s ease, transform .65s ease; }
.reveal-l.vis { opacity:1; transform:translateX(0); }
.reveal-r { opacity:0; transform:translateX(28px); transition:opacity .65s ease, transform .65s ease; }
.reveal-r.vis { opacity:1; transform:translateX(0); }
.reveal-scale { opacity:0; transform:scale(.9); transition:opacity .65s ease, transform .65s ease; }
.reveal-scale.vis { opacity:1; transform:scale(1); }

/* ===== ANIMATED BG ===== */
.animated-bg { background:linear-gradient(300deg,#050714,#0d0523,#060e2a,#050714); background-size:300% 300%; animation:bg-shift 18s ease infinite; }
@keyframes bg-shift { 0%{background-position:0% 50%} 50%{background-position:100% 50%} 100%{background-position:0% 50%} }

/* ===== FLOATING SHAPES ===== */
.float-shapes { position:absolute; inset:0; pointer-events:none; overflow:hidden; z-index:1; }
.fshape { position:absolute; border-radius:50%; animation:fshape-rise linear infinite; }
@keyframes fshape-rise { 0%{transform:translateY(110vh) rotate(0deg);opacity:0} 5%{opacity:1} 95%{opacity:.7} 100%{transform:translateY(-120px) rotate(720deg);opacity:0} }

/* ===== SECTION SPECIFIC ===== */
.zebra-section { background:linear-gradient(180deg,transparent,rgba(124,58,237,.03),transparent); }
.dark-section { background:var(--bg-secondary); }
.judging-item { display:flex; align-items:flex-start; gap:14px; padding:18px; background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-sm); transition:var(--ease); }
.judging-item:hover { border-color:rgba(124,58,237,.25); }
.judging-num { width:32px; height:32px; background:linear-gradient(135deg,var(--purple),var(--teal)); border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:.78rem; font-weight:700; flex-shrink:0; }
.judging-text h4 { font-size:.9rem; font-weight:600; margin-bottom:4px; }
.judging-text p { font-size:.82rem; color:var(--text-soft); }

/* ===== RESPONSIVE ===== */
@media(max-width:1100px) {
  .grid-4 { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; gap:36px; }
  .welcome-wrap { grid-template-columns:1fr; gap:40px; }
  .about-feature { grid-template-columns:1fr; gap:40px; }
  .about-feature:nth-child(even) .about-feature-img { order:0; }
}
@media(max-width:860px) {
  section { padding:64px 24px; }
  .navbar { padding:16px 22px; }
  .navbar.scrolled { padding:12px 22px; }
  .nav-links { display:none; }
  .hamburger { display:flex; }
  .grid-3, .grid-2 { grid-template-columns:1fr; }
  .grid-4 { grid-template-columns:repeat(2,1fr); }
  .form-row { grid-template-columns:1fr; }
  .timeline::before { left:18px; }
  .tl-item { padding-right:0; padding-left:50px; justify-content:flex-start; }
  .tl-item:nth-child(even) { padding-left:50px; }
  .tl-dot { left:18px; }
  .footer-grid { grid-template-columns:1fr; gap:28px; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .stats-band { padding:40px 24px; }
  .vm-card { padding:28px; }
  .social-grid { grid-template-columns:repeat(4,1fr); }
}
@media(max-width:580px) {
  .grid-4 { grid-template-columns:1fr; }
  .hero-btns { flex-direction:column; align-items:center; }
  .social-grid { grid-template-columns:repeat(2,1fr); }
  .media-filter { gap:6px; }
}
