/* ===== RESET & BASE ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --primary:#E63946;
  --primary-dark:#b71c2e;
  --accent:#F4A023;
  --accent-dark:#c47e00;
  --bg:#0b0b10;
  --bg-2:#10101a;
  --bg-card:rgba(16,16,26,.88);
  --bg-card-hover:rgba(22,22,38,.92);
  --text:#d6d6d6;
  --text-muted:#999;
  --white:#fff;
  --border:rgba(255,255,255,.07);
  --radius:14px;
  --nav-h:64px;
  --announcement-h:42px;
  --font-body:'Inter',sans-serif;
  --font-head:'Space Grotesk',sans-serif;
  --shadow-card:0 8px 32px rgba(0,0,0,.35);
  --shadow-glow:0 0 40px rgba(230,57,70,.18);
}

html{scroll-behavior:smooth}

body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
}

img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;-webkit-tap-highlight-color:transparent}
ul{list-style:none}
button{font-family:inherit;cursor:pointer}

.container{max-width:1200px;margin:0 auto;padding:0 24px}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
}

/* ===== INTRO OVERLAY ===== */
#intro-overlay{
  position:fixed;inset:0;z-index:10000;background:#000;
  display:flex;align-items:center;justify-content:center;
  transition:opacity 1.2s cubic-bezier(.4,0,.2,1),transform 1.2s cubic-bezier(.4,0,.2,1);
  overflow:hidden;
}
#intro-overlay.fade-out{opacity:0;transform:scale(1.08);pointer-events:none}
#intro-overlay.hidden{display:none}

/* ===== PORTAL VIDEO ===== */
.intro-video{
  position:relative;
  z-index:0;
  pointer-events:none;
  object-fit:contain;
}
/* Desktop: landscape — right-aligned, vertically centred */
.intro-video--desktop{
  top:50%;right:0;left:auto;
  transform:translateY(-50%);
  height:100%;width:auto;
}
/* Mobile: portrait — centred, fill viewport */
.intro-video--mobile{
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:100%;height:100%;
  object-fit:cover;
}
/* Toggle by orientation */
.intro-video--mobile{display:none}
.intro-video--desktop{display:block}
@media (orientation:portrait){
  .intro-video--mobile{display:block}
  .intro-video--desktop{display:none}
}

/* ===== CONTENT INSIDE THE PORTAL ===== */
#intro-content{
  position:absolute;z-index:2;
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;
  text-align:center;
  width:clamp(180px,28vw,360px);
  gap:clamp(.3rem,1vmin,.6rem);
}
/* Desktop/landscape: content on the left side */
@media (orientation:landscape){
  #intro-content{
    top:45%;left:50.5%;
    transform:translate(-50%,-50%);
  }
}
/* Mobile/portrait: center in viewport */
@media (orientation:portrait){
  #intro-content{
    top:50%;left:50.5%;
    transform:translate(-50%,-50%);
    width:clamp(180px,65vw,340px);
  }
}

/* ─── Shared reveal state: content emerges from portal ─── */
.intro-reveal{
  opacity:0;
  transform:scale(.7) translateY(10px);
  filter:blur(8px);
  transition:
    opacity .7s cubic-bezier(.16,1,.3,1),
    transform .7s cubic-bezier(.16,1,.3,1),
    filter .7s cubic-bezier(.16,1,.3,1);
}
.intro-reveal.visible{
  opacity:1;
  transform:scale(1) translateY(0);
  filter:blur(0);
}

/* ─── IIEC Logo ─── */
.intro-college-logo{
  width:clamp(40px,8vmin,90px);height:auto;
  filter:drop-shadow(0 0 12px rgba(255,180,50,.5));
}

/* ─── "Presents" ─── */
.intro-presents{
  font-family:var(--font-body);
  font-size:clamp(.55rem,1.6vmin,.75rem);
  color:rgba(255,255,255,.45);
  letter-spacing:.4em;text-transform:uppercase;
  font-weight:400;
  margin-bottom:clamp(.3rem,1vmin,.6rem);
}

/* ─── Tech Astra Logo ─── */
.intro-logo{
  width:clamp(80px,22vmin,220px);height:auto;
  filter:
    drop-shadow(0 0 24px rgba(255,160,40,.5))
    drop-shadow(0 0 50px rgba(230,57,70,.2));
  animation:introLogoFloat 3.5s ease-in-out 2s infinite;
}

/* ─── Tagline ─── */
.intro-tagline{
  font-family:var(--font-head);
  font-size:clamp(.6rem,2vmin,.95rem);
  font-weight:600;letter-spacing:.25em;text-transform:uppercase;
  background:linear-gradient(135deg,var(--accent),#fff,var(--accent));
  background-size:200% 100%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  animation:introShimmer 3s ease-in-out 2.5s infinite;
  margin-top:clamp(.3rem,1vmin,.6rem);
}

/* ─── Divider ─── */
.intro-divider{
  width:50px;height:1.5px;border-radius:2px;
  background:linear-gradient(90deg,transparent,var(--accent),transparent);
}

/* ─── Skip hint ─── */
.intro-skip{
  font-size:clamp(.55rem,1.2vmin,.68rem);
  color:rgba(255,255,255,.28);
  display:flex;align-items:center;gap:.35rem;
  animation:introBlink 2.5s ease-in-out 3s infinite;
}
.intro-skip i{font-size:.55rem}

/* ─── Portrait adjustments ─── */
@media (orientation:portrait){
  #intro-content{
    width:clamp(180px,65vw,340px);
    gap:clamp(.5rem,2vmin,1rem);
  }
  .intro-college-logo{width:clamp(45px,15vw,100px)}
  .intro-logo{width:clamp(90px,42vw,220px)}
  .intro-tagline{font-size:clamp(.55rem,2.5vw,.85rem)}
}
/* Small phones */
@media (max-height:600px) and (orientation:portrait){
  #intro-content{gap:.3rem}
  .intro-college-logo{width:40px}
  .intro-logo{width:clamp(80px,35vw,160px)}
  .intro-presents{font-size:.5rem}
}

/* ─── Keyframes ─── */
@keyframes introLogoFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-6px)}
}
@keyframes introShimmer{
  0%{background-position:200% center}
  100%{background-position:-200% center}
}
@keyframes introBlink{0%,100%{opacity:.25}50%{opacity:.7}}

#snap-particles{position:absolute;inset:0;z-index:3;pointer-events:none}
.snap-particle{position:absolute;border-radius:2px;opacity:0}

/* ===== LIGHTNING OVERLAY ===== */
.lightning-overlay{
  position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:0;
  background:radial-gradient(ellipse at center,rgba(255,255,255,.12) 0%,transparent 70%);
  transition:opacity .05s;
}
.lightning-overlay.flash{opacity:1}

/* ===== MAIN CONTENT ===== */
#main-content{
  opacity:0;pointer-events:none;
  transition:opacity 1s ease .2s;position:relative;z-index:1;
}
#main-content.visible,.subpage #main-content{opacity:1;pointer-events:auto}

/* ===== NAVBAR ===== */
.navbar{
  position:fixed;top:0;left:0;width:100%;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 5%;height:var(--nav-h);
  background:rgba(11,11,16,.82);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(255,255,255,.06);
  transition:all .3s ease;
}
.navbar.scrolled{
  background:rgba(11,11,16,.97);
  box-shadow:0 2px 30px rgba(0,0,0,.5);
  border-bottom-color:var(--primary);
}

.nav-brand a{display:flex;align-items:center;gap:.5rem}
.nav-logo{height:34px;width:auto;transition:transform .3s}
.nav-brand a:hover .nav-logo{transform:scale(1.06)}

.nav-links{display:flex;gap:2rem;align-items:center}
.nav-links a{
  font-size:.82rem;font-weight:500;text-transform:uppercase;
  letter-spacing:.1em;color:var(--text);position:relative;
  padding:.3rem 0;transition:color .3s;
}
.nav-links a::after{
  content:'';position:absolute;bottom:-3px;left:0;width:0;height:2px;
  background:linear-gradient(90deg,var(--primary),var(--accent));
  border-radius:2px;transition:width .3s;
}
.nav-links a:hover,.nav-links a.active{color:var(--white)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}

.hamburger{
  display:none;flex-direction:column;gap:5px;
  cursor:pointer;padding:.5rem;z-index:1001;
}
.hamburger span{
  width:24px;height:2px;background:var(--white);
  transition:.3s;display:block;border-radius:2px;
}

/* ===== HERO ===== */
.hero{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
  padding:calc(var(--nav-h) + 2rem) 5% 4rem;
}
.hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 20% 30%,rgba(230,57,70,.12) 0%,transparent 50%),
    radial-gradient(circle at 80% 70%,rgba(244,160,35,.08) 0%,transparent 50%),
    linear-gradient(180deg,rgba(11,11,16,.85),var(--bg));
  z-index:0;
}
.hero-particles{position:absolute;inset:0;overflow:hidden;z-index:1}
.particle{
  position:absolute;border-radius:50%;opacity:.12;
  animation:float linear infinite;
}
.particle.red{background:var(--primary)}
.particle.gold{background:var(--accent)}

@keyframes float{
  0%{transform:translateY(100vh) rotate(0);opacity:0}
  10%{opacity:.12}90%{opacity:.12}
  100%{transform:translateY(-10vh) rotate(720deg);opacity:0}
}

.hero-content{
  text-align:center;z-index:2;position:relative;
  max-width:860px;width:100%;
}

.hero-college{
  font-size:clamp(.65rem,1.5vw,.85rem);color:rgba(255,255,255,.45);
  letter-spacing:.5em;text-transform:uppercase;margin-bottom:.8rem;
  opacity:0;animation:slideUp .8s ease .2s forwards;
}

.hero-logo{
  width:clamp(200px,45vw,480px);height:auto;margin:0 auto 1rem;
  filter:drop-shadow(0 0 40px rgba(244,160,35,.35));
  opacity:0;animation:slideUp .8s ease .4s forwards;
}

.hero-tagline{
  font-family:var(--font-head);font-weight:600;
  font-size:clamp(.8rem,2.2vw,1.15rem);
  color:var(--accent);letter-spacing:.2em;text-transform:uppercase;
  margin-bottom:1.5rem;
  opacity:0;animation:slideUp .8s ease .6s forwards;
}

.hero-headline{
  font-family:var(--font-head);font-weight:800;
  font-size:clamp(1.6rem,4.5vw,3rem);color:var(--white);
  line-height:1.25;margin-bottom:1rem;
  opacity:0;animation:slideUp .8s ease .7s forwards;
}
.hero-headline .hl{
  background:linear-gradient(135deg,var(--primary),var(--accent));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}

.hero-desc{
  font-size:clamp(.88rem,1.8vw,1.02rem);color:#bbb;
  max-width:640px;margin:0 auto 2rem;line-height:1.8;
  opacity:0;animation:slideUp .8s ease .9s forwards;
}

.hero-stats{
  display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;
  margin-bottom:2rem;
  opacity:0;animation:slideUp .8s ease 1s forwards;
}
.hero-stat{
  display:flex;flex-direction:column;align-items:center;
  padding:.8rem 1.4rem;border-radius:var(--radius);
  background:var(--bg-card);border:1px solid var(--border);
  backdrop-filter:blur(8px);min-width:110px;
}
.hero-stat strong{
  font-family:var(--font-head);font-size:clamp(1.2rem,3vw,1.8rem);
  font-weight:800;
  background:linear-gradient(135deg,var(--accent),var(--primary));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.hero-stat span{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-top:.2rem}

.hero-buttons{
  display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;
  opacity:0;animation:slideUp .8s ease 1.1s forwards;
}

@keyframes slideUp{
  from{opacity:0;transform:translateY(24px)}
  to{opacity:1;transform:translateY(0)}
}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.85rem 2rem;border-radius:var(--radius);
  font-size:.88rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.05em;transition:all .3s;border:none;
  position:relative;overflow:hidden;white-space:nowrap;
}
.btn::after{
  content:'';position:absolute;top:50%;left:-100%;
  width:40px;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);
  transform:translateY(-50%) skewX(-15deg);transition:left .5s;
}
.btn:hover::after{left:120%}

.btn-primary{
  background:linear-gradient(135deg,var(--primary),var(--primary-dark));
  color:var(--white);box-shadow:0 6px 24px rgba(230,57,70,.3);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 36px rgba(230,57,70,.45)}

.btn-outline{
  background:transparent;color:var(--accent);
  border:1.5px solid var(--accent);
}
.btn-outline:hover{
  background:rgba(244,160,35,.08);transform:translateY(-2px);
  box-shadow:0 6px 24px rgba(244,160,35,.2);
}

.btn-sm{padding:.55rem 1.3rem;font-size:.78rem;border-radius:10px}

.btn-white{
  background:var(--white);color:var(--bg);
}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(255,255,255,.15)}

/* ===== SECTION COMMON ===== */
.section{padding:5rem 0;position:relative}
.section-dark{background:var(--bg-2)}
.section-title{
  font-family:var(--font-head);font-size:clamp(1.6rem,4vw,2.6rem);
  font-weight:800;text-align:center;color:var(--white);
  margin-bottom:.5rem;letter-spacing:.02em;
}
.section-title .hl{
  background:linear-gradient(135deg,var(--primary),var(--accent));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.section-subtitle{
  text-align:center;color:var(--text-muted);
  font-size:clamp(.85rem,1.8vw,.98rem);
  margin-bottom:3rem;max-width:650px;margin-left:auto;margin-right:auto;
}

/* Decorative line under titles */
.section-title::after{
  content:'';display:block;width:50px;height:3px;
  background:linear-gradient(90deg,var(--primary),var(--accent));
  border-radius:3px;margin:1rem auto 0;
}

/* ===== PRIZE BANNER ===== */
.prize-banner{
  background:linear-gradient(135deg,var(--primary),#c0392b 40%,var(--accent));
  padding:2.5rem 1rem;text-align:center;position:relative;overflow:hidden;
}
.prize-banner::before{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(45deg,transparent,transparent 20px,rgba(255,255,255,.03) 20px,rgba(255,255,255,.03) 40px);
}
.prize-banner .prize-amount{
  font-family:var(--font-head);font-size:clamp(2.5rem,8vw,5rem);
  font-weight:900;color:var(--white);position:relative;
  text-shadow:0 4px 30px rgba(0,0,0,.3);line-height:1;
}
.prize-banner .prize-label{
  font-size:clamp(.85rem,2vw,1.1rem);color:rgba(255,255,255,.85);
  letter-spacing:.15em;text-transform:uppercase;margin-top:.5rem;
  position:relative;
}

/* ===== EVENT CATEGORY HEADERS ===== */
.event-category{margin-bottom:3rem}
.event-category:last-child{margin-bottom:0}
.category-header{
  display:flex;align-items:center;gap:1rem;
  margin-bottom:1.5rem;padding-bottom:.75rem;
  border-bottom:2px solid var(--border);
}
.category-icon{
  width:48px;height:48px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;flex-shrink:0;
}
.category-header h3{
  font-family:var(--font-head);font-size:1.4rem;font-weight:700;
  color:var(--white);margin:0;
}
.category-header h3 span{color:var(--text-muted);font-weight:400;font-size:.85rem;margin-left:.5rem}

/* ===== EVENT CARDS (overview) ===== */
.events-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:1.5rem;
}

.event-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden;
  transition:all .35s ease;display:flex;flex-direction:column;
  backdrop-filter:blur(6px);
}
.event-card:hover{
  transform:translateY(-6px);
  border-color:rgba(230,57,70,.3);
  box-shadow:var(--shadow-card);
}

.event-card-icon{
  height:180px;display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
  background-size:contain;background-position:center;background-repeat:no-repeat;
  background-color:#0a0a0a;
}
.event-card-icon::before{
  content:none;
}
.event-card-icon i{display:none}

.ec-gaming{color:#e94560}
.ec-coding{color:#58a6ff}
.ec-web{color:#b794f6}
.ec-project{color:#64dfdf}
.ec-mun{color:#f0b323}
.ec-inova{color:#69db7c}
.ec-vibe{color:#c084fc}
.ec-freefire{color:#ff6b35}
.ec-valorant{color:#fd4556}
.ec-chess{color:#f5c542}
.ec-hunt{color:#a855f7}
.ec-expo{color:#38bdf8}
.ec-quiz{color:#2dd4bf}
.ec-reel{color:#f472b6}

.event-card-body{padding:1.2rem 1.4rem;flex:1;display:flex;flex-direction:column}
.event-card-body h3{
  font-family:var(--font-head);font-size:1.05rem;font-weight:700;
  color:var(--white);margin-bottom:.4rem;
}
.event-card-body .event-meta{
  display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.8rem;
}
.event-meta-tag{
  display:inline-flex;align-items:center;gap:.3rem;
  padding:.2rem .6rem;border-radius:999px;font-size:.68rem;
  font-weight:600;text-transform:uppercase;letter-spacing:.04em;
}
.meta-date{background:rgba(244,160,35,.12);color:var(--accent);border:1px solid rgba(244,160,35,.25)}
.meta-fee{background:rgba(230,57,70,.1);color:var(--primary);border:1px solid rgba(230,57,70,.25)}
.meta-mode{background:rgba(255,255,255,.06);color:var(--text-muted);border:1px solid var(--border)}

.event-card-body p{font-size:.85rem;color:var(--text-muted);line-height:1.7;flex:1;margin-bottom:1rem}

.event-card-footer{
  padding:.8rem 1.4rem;border-top:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;
  background:rgba(0,0,0,.15);
}
.event-card-footer .prize-tag{
  font-family:var(--font-head);font-size:.82rem;font-weight:700;color:var(--accent);
  display:flex;align-items:center;gap:.4rem;
}

/* ===== PAGE HERO (Subpages) ===== */
.page-hero{
  position:relative;min-height:45vh;
  display:flex;align-items:center;justify-content:center;text-align:center;
  padding:calc(var(--nav-h) + 2rem) 2rem 3rem;overflow:hidden;
}
.page-hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 30% 40%,rgba(230,57,70,.15) 0%,transparent 50%),
    radial-gradient(circle at 70% 60%,rgba(244,160,35,.1) 0%,transparent 50%),
    linear-gradient(180deg,rgba(11,11,16,.5),var(--bg));
  z-index:1;
}
.page-hero-content{position:relative;z-index:2;max-width:800px}
.page-hero-content .section-title{margin-bottom:.5rem}
.page-hero-content .section-subtitle{margin-bottom:0}

/* ===== ABOUT SECTION (Home) ===== */
.about-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;
}
.about-text h3{
  font-family:var(--font-head);font-size:clamp(1.3rem,3vw,1.8rem);
  font-weight:700;color:var(--white);margin-bottom:1rem;
}
.about-text p{color:var(--text-muted);line-height:1.8;margin-bottom:1rem}
.about-features{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin-top:1.5rem}
.about-feature{
  display:flex;align-items:flex-start;gap:.7rem;
  padding:.8rem;background:var(--bg-card);border:1px solid var(--border);
  border-radius:10px;transition:border-color .3s;
}
.about-feature:hover{border-color:rgba(244,160,35,.25)}
.about-feature i{color:var(--accent);font-size:1.1rem;margin-top:.15rem;flex-shrink:0}
.about-feature span{font-size:.82rem;color:var(--text);line-height:1.5}

.about-image{
  position:relative;display:flex;align-items:center;justify-content:center;
}
.about-image .logo-showcase{
  width:clamp(200px,80%,360px);height:auto;
  filter:drop-shadow(0 0 50px rgba(244,160,35,.25));
  animation:logoFloat 4s ease-in-out infinite;
}

/* ===== SCHEDULE / TIMELINE ===== */
.timeline{
  position:relative;max-width:700px;margin:0 auto;padding-left:2.5rem;
}
.timeline::before{
  content:'';position:absolute;left:14px;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,var(--primary),var(--accent),var(--primary));
  border-radius:3px;
}
.timeline-item{position:relative;padding:1rem 0 1.5rem}
.timeline-dot{
  position:absolute;left:-2.15rem;top:1.3rem;
  width:14px;height:14px;border-radius:50%;
  background:var(--bg-card);border:3px solid var(--accent);z-index:2;
  box-shadow:0 0 10px rgba(244,160,35,.4);
}
.timeline-content{
  background:var(--bg-card);padding:1.2rem 1.5rem;
  border-radius:var(--radius);border:1px solid var(--border);
  transition:all .3s;backdrop-filter:blur(6px);
}
.timeline-item:hover .timeline-content{border-color:rgba(244,160,35,.3);transform:translateX(4px)}
.timeline-content h4{
  font-family:var(--font-head);color:var(--accent);font-size:.88rem;
  font-weight:600;margin-bottom:.3rem;display:flex;align-items:center;gap:.5rem;
}
.timeline-content h4 i{color:var(--primary);font-size:.85rem}
.timeline-content p{font-size:.84rem;color:var(--text-muted);line-height:1.7}
.timeline-update-notice{
  margin-top:1.5rem;padding:1rem 1.2rem;border-radius:var(--radius);
  background:rgba(244,160,35,.08);border:1px dashed rgba(244,160,35,.35);
  color:var(--text-muted);font-size:.88rem;text-align:center;
  display:flex;align-items:center;justify-content:center;gap:.5rem;
}
.timeline-update-notice i{color:var(--primary);font-size:1rem}

/* Coming Soon Notice — used across timeline, coordinators, prizes, scoring */
.coming-soon-notice{
  margin:2rem auto;padding:1.5rem 2rem;border-radius:var(--radius);
  background:linear-gradient(135deg,rgba(244,160,35,.06),rgba(244,160,35,.12));
  border:1.5px dashed rgba(244,160,35,.45);
  color:#e0e0e0;font-size:1rem;text-align:center;max-width:600px;
  display:flex;flex-direction:column;align-items:center;gap:.6rem;
  animation:comingSoonPulse 3s ease-in-out infinite;
}
.coming-soon-notice i{color:var(--primary);font-size:1.4rem}
.coming-soon-notice strong{color:var(--primary);font-weight:700}
@keyframes comingSoonPulse{
  0%,100%{border-color:rgba(244,160,35,.3);box-shadow:0 0 0 transparent}
  50%{border-color:rgba(244,160,35,.6);box-shadow:0 0 20px rgba(244,160,35,.08)}
}

/* ===== MARQUEE ===== */
.marquee-section{
  overflow:hidden;padding:1.2rem 0;
  background:rgba(16,16,26,.9);
  border-top:1px solid rgba(230,57,70,.1);
  border-bottom:1px solid rgba(230,57,70,.1);
}
.marquee-track{
  display:flex;gap:2rem;
  animation:marquee 35s linear infinite;width:max-content;
}
.marquee-item{
  display:flex;align-items:center;gap:.5rem;
  font-family:var(--font-head);font-size:.78rem;font-weight:600;
  color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;
  white-space:nowrap;
}
.marquee-item i{color:var(--primary);font-size:.85rem}

@keyframes marquee{
  0%{transform:translateX(0)}100%{transform:translateX(-50%)}
}

/* ===== CONTACT SECTION ===== */
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start;
}
.contact-info h3{
  font-family:var(--font-head);font-size:1.3rem;font-weight:700;
  color:var(--white);margin-bottom:1rem;
}
.contact-info p{color:var(--text-muted);margin-bottom:1.5rem;line-height:1.8}
.contact-detail{
  display:flex;align-items:center;gap:.8rem;
  margin-bottom:1rem;color:var(--text);font-size:.9rem;
}
.contact-detail i{
  color:var(--accent);font-size:1rem;width:20px;text-align:center;flex-shrink:0;
}

.contact-form{
  display:flex;flex-direction:column;gap:1rem;
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius);padding:2rem;backdrop-filter:blur(6px);
}
.contact-form label{color:var(--white);font-size:.82rem;font-weight:600;letter-spacing:.02em}
.contact-form input,.contact-form textarea,.contact-form select{
  padding:.85rem 1rem;background:rgba(5,5,8,.8);
  border:1px solid rgba(255,255,255,.1);border-radius:10px;
  color:var(--white);font-family:var(--font-body);font-size:.88rem;
  transition:border-color .3s,box-shadow .3s;outline:none;width:100%;
}
.contact-form select{
  appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23E63946' stroke-width='2'%3e%3cpolyline points='6 9 12 15 18 9'/%3e%3c/svg%3e");
  background-repeat:no-repeat;background-position:right 1rem center;background-size:1rem;
  padding-right:2.5rem;
}
.contact-form select option{background:var(--bg);color:var(--white)}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{
  border-color:var(--accent);box-shadow:0 0 0 3px rgba(244,160,35,.12);
}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--text-muted)}
.contact-form textarea{resize:vertical;min-height:100px}
.contact-form .btn{width:100%;justify-content:center;margin-top:.5rem}

/* ===== EVENT DETAIL PAGE ===== */
.event-detail-header{
  display:grid;grid-template-columns:1fr 1fr;gap:3rem;
  align-items:center;margin-bottom:3rem;
}
.event-detail-header .event-icon-big{
  width:100%;aspect-ratio:4/3;border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  font-size:5rem;position:relative;overflow:hidden;
}
.event-detail-header .event-icon-big::before{
  content:'';position:absolute;inset:0;opacity:.1;
  background:repeating-linear-gradient(45deg,transparent,transparent 15px,rgba(255,255,255,.04) 15px,rgba(255,255,255,.04) 30px);
}
.event-detail-header .event-icon-big i{position:relative;z-index:1;filter:drop-shadow(0 0 30px currentColor)}

/* Event detail page — image replaces icon */
.event-detail-img{
  width:100%;height:auto;
  border-radius:var(--radius);
  object-fit:contain;
  background:#0a0a0a;
}

.event-detail-info h1{
  font-family:var(--font-head);font-size:clamp(1.6rem,4vw,2.4rem);
  font-weight:800;color:var(--white);margin-bottom:.8rem;
}
.event-detail-info .event-meta{margin-bottom:1rem}
.event-detail-info p{color:var(--text-muted);line-height:1.8;margin-bottom:1.5rem}

.detail-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}
.detail-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius);padding:1.5rem;
  backdrop-filter:blur(6px);transition:border-color .3s;
}
.detail-card:hover{border-color:rgba(244,160,35,.25)}
.detail-card h3{
  font-family:var(--font-head);font-size:.95rem;font-weight:700;
  color:var(--white);margin-bottom:.8rem;
  display:flex;align-items:center;gap:.5rem;
}
.detail-card h3 i{color:var(--accent)}
.detail-card ul{padding:0}
.detail-card li{
  padding:.3rem 0;font-size:.84rem;color:var(--text-muted);
  display:flex;align-items:flex-start;gap:.5rem;line-height:1.6;
}
.detail-card li i{color:var(--primary);margin-top:.25rem;flex-shrink:0;width:14px;text-align:center}
.detail-card p{font-size:.84rem;color:var(--text-muted);line-height:1.7}

/* Highlight Certificate of Participation */
.detail-card ul li.highlight-cert{
  background:linear-gradient(135deg,rgba(244,160,35,.12),rgba(244,160,35,.08));
  border-left:3px solid var(--accent);
  padding:.8rem .8rem .8rem 1rem !important;
  margin:.8rem 0 !important;
  border-radius:8px;
  font-weight:600;
  color:var(--white) !important;
  box-shadow:0 4px 12px rgba(244,160,35,.15);
  animation:certGlow 2s ease-in-out infinite;
}
.detail-card ul li.highlight-cert i{color:var(--accent) !important;font-size:1rem;margin-right:.3rem}
@keyframes certGlow{
  0%,100%{box-shadow:0 4px 12px rgba(244,160,35,.15)}
  50%{box-shadow:0 6px 20px rgba(244,160,35,.3)}
}

/* Coordinators */
.coordinators-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.5rem}
.coordinator-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius);padding:1.5rem;text-align:center;
  backdrop-filter:blur(6px);transition:all .3s;
}
.coordinator-card:hover{border-color:rgba(244,160,35,.25);transform:translateY(-4px)}
.coordinator-avatar{
  width:70px;height:70px;border-radius:50%;margin:0 auto .8rem;
  background:linear-gradient(135deg,var(--primary),var(--accent));
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;color:var(--white);font-weight:700;
}
.coordinator-card h4{font-family:var(--font-head);font-size:.9rem;color:var(--white);font-weight:600;margin-bottom:.2rem}
.coordinator-card .role{font-size:.72rem;color:var(--accent);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem}
.coordinator-card a{font-size:.8rem;color:var(--text-muted);display:flex;align-items:center;justify-content:center;gap:.3rem;transition:color .3s}
.coordinator-card a:hover{color:var(--primary)}

/* Registration form on event page */
.register-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius);padding:2rem;
  backdrop-filter:blur(6px);max-width:600px;margin:0 auto;
}
.register-card h3{
  font-family:var(--font-head);font-size:1.1rem;font-weight:700;
  color:var(--white);margin-bottom:1.5rem;text-align:center;
}

/* ===== PAYMENT MODAL ===== */
.payment-overlay{
  position:fixed;inset:0;z-index:10000;
  background:rgba(0,0,0,.82);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:all .4s ease;
  padding:1rem;
}
.payment-overlay.active{opacity:1;visibility:visible}
.payment-modal{
  background:var(--bg-2);border:1px solid rgba(244,160,35,.2);
  border-radius:var(--radius);max-width:460px;width:100%;
  padding:2rem;position:relative;
  max-height:90vh;overflow-y:auto;
  transform:translateY(30px) scale(.96);
  transition:transform .4s ease;
  scrollbar-width:thin;scrollbar-color:rgba(244,160,35,.3) transparent;
}
.payment-overlay.active .payment-modal{transform:translateY(0) scale(1)}
.payment-modal::-webkit-scrollbar{width:6px}
.payment-modal::-webkit-scrollbar-thumb{background:rgba(244,160,35,.3);border-radius:4px}
.payment-close{
  position:absolute;top:1rem;right:1rem;
  background:none;border:1px solid var(--border);
  color:var(--text-muted);font-size:1rem;
  width:32px;height:32px;border-radius:50%;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .3s;
}
.payment-close:hover{color:var(--primary);border-color:var(--primary)}
.payment-header{text-align:center;margin-bottom:1.5rem}
.payment-header h3{
  font-family:var(--font-head);font-size:1.2rem;font-weight:700;
  color:var(--white);margin-bottom:.4rem;
}
.payment-header p{color:var(--text-muted);font-size:.88rem}
.payment-amount{
  display:inline-block;
  background:linear-gradient(135deg,rgba(244,160,35,.12),rgba(244,160,35,.22));
  border:1px dashed rgba(244,160,35,.45);
  padding:.5rem 1.5rem;border-radius:10px;
  font-family:var(--font-head);font-size:1.6rem;font-weight:800;
  color:var(--accent);margin:.8rem 0 .4rem;
  letter-spacing:.5px;
}
.payment-qr-wrap{
  text-align:center;margin:1.2rem 0;
}
.payment-qr-wrap img{
  width:220px;height:220px;border-radius:12px;
  border:2px solid rgba(244,160,35,.25);
  background:#fff;padding:6px;
}
.payment-qr-wrap p{
  font-size:.82rem;color:var(--text-muted);margin-top:.6rem;
}
.payment-upi-row{
  display:flex;align-items:center;justify-content:center;gap:.6rem;
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);border-radius:10px;
  padding:.7rem 1rem;margin:1rem 0;
  flex-wrap:wrap;
}
.payment-upi-row span{
  font-family:var(--font-head);font-size:.9rem;
  color:var(--white);font-weight:600;letter-spacing:.3px;
}
.payment-upi-row .upi-label{
  color:var(--text-muted);font-weight:400;font-family:var(--font-body);font-size:.82rem;
}
.payment-upi-row button{
  background:rgba(244,160,35,.15);border:1px solid rgba(244,160,35,.35);
  color:var(--accent);font-size:.78rem;font-weight:600;
  padding:.35rem .8rem;border-radius:8px;cursor:pointer;
  display:flex;align-items:center;gap:.3rem;transition:all .3s;
  font-family:var(--font-body);
}
.payment-upi-row button:hover{background:rgba(244,160,35,.25)}
.payment-upi-row button.copied{background:rgba(39,174,96,.2);border-color:rgba(39,174,96,.4);color:#27ae60}
.payment-actions{
  display:flex;gap:.8rem;justify-content:center;margin:1rem 0;
}
.payment-actions button{
  background:rgba(255,255,255,.05);border:1px solid var(--border);
  color:var(--text);font-size:.82rem;padding:.5rem 1rem;
  border-radius:10px;cursor:pointer;display:flex;align-items:center;gap:.4rem;
  transition:all .3s;font-family:var(--font-body);
}
.payment-actions button:hover{border-color:rgba(244,160,35,.3);color:var(--accent)}
.payment-utr-section{margin-top:1.2rem}
.payment-utr-section label{
  display:block;font-size:.85rem;color:var(--white);
  font-weight:600;margin-bottom:.5rem;
  font-family:var(--font-head);
}
.payment-utr-section label i{color:var(--primary);margin-right:.3rem}
.payment-utr-section input{
  width:100%;padding:.7rem 1rem;border-radius:10px;
  border:1px solid var(--border);background:rgba(255,255,255,.04);
  color:var(--white);font-size:.9rem;font-family:var(--font-body);
  transition:border-color .3s;
}
.payment-utr-section input:focus{
  outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(244,160,35,.1);
}
.payment-utr-section input::placeholder{color:var(--text-muted);font-size:.82rem}
.payment-utr-section .utr-hint{
  font-size:.75rem;color:var(--text-muted);
  margin-top:.4rem;display:block;
}
.payment-submit{
  width:100%;margin-top:1.2rem;
  padding:.85rem;border:none;border-radius:12px;
  background:linear-gradient(135deg,var(--primary),var(--primary-dark));
  color:#fff;font-family:var(--font-head);font-size:.95rem;
  font-weight:700;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:.5rem;
  transition:all .3s;
}
.payment-submit:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(230,57,70,.3)}
.payment-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* Payment success state */
.payment-success{
  text-align:center;padding:2rem 1rem;
}
.payment-success .success-icon{
  font-size:3rem;color:#27ae60;margin-bottom:1rem;
  animation:successPop .5s ease-out;
}
@keyframes successPop{
  0%{transform:scale(0);opacity:0}
  60%{transform:scale(1.2)}
  100%{transform:scale(1);opacity:1}
}
.payment-success h3{
  font-family:var(--font-head);font-size:1.15rem;font-weight:700;
  color:var(--white);margin-bottom:.8rem;
}
.payment-success p{
  color:var(--text-muted);font-size:.88rem;line-height:1.7;
  max-width:380px;margin:0 auto;
}
.payment-success .email-notice{
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(244,160,35,.1);
  border:1px solid rgba(244,160,35,.25);
  padding:.6rem 1.2rem;border-radius:10px;
  color:var(--accent);font-size:.82rem;font-weight:600;
  margin-top:1.2rem;
}
.payment-success .close-btn{
  margin-top:1.5rem;
  padding:.6rem 1.5rem;border:1px solid var(--border);border-radius:10px;
  background:none;color:var(--text);font-size:.85rem;
  cursor:pointer;transition:all .3s;font-family:var(--font-body);
}
.payment-success .close-btn:hover{border-color:var(--accent);color:var(--accent)}

@media(max-width:600px){
  .payment-modal{padding:1.5rem 1rem}
  .payment-amount{font-size:1.3rem}
  .payment-qr-wrap img{width:180px;height:180px}
  .payment-upi-row{flex-direction:column;gap:.4rem}
}

/* ===== FAQ ===== */
.faq-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;
  max-width:900px;margin:0 auto;
}
.faq-item{
  background:var(--bg-card);padding:1.5rem;border-radius:var(--radius);
  border:1px solid var(--border);transition:all .3s;backdrop-filter:blur(6px);
}
.faq-item:hover{border-color:rgba(244,160,35,.25);transform:translateY(-3px)}
.faq-question{display:flex;align-items:center;gap:.7rem;margin-bottom:.5rem}
.faq-question i{color:var(--accent);font-size:1rem;flex-shrink:0}
.faq-question h4{font-family:var(--font-head);color:var(--white);font-size:.82rem;font-weight:600}
.faq-item p{font-size:.84rem;color:var(--text-muted);line-height:1.7}

/* ===== FOOTER ===== */
.footer{
  padding:3rem 2rem;border-top:1px solid rgba(255,255,255,.06);
  background:var(--bg-2);
}
.footer-content{
  display:flex;flex-direction:column;align-items:center;gap:1.2rem;text-align:center;
}
.footer-logo{height:36px;width:auto;opacity:.85;transition:opacity .3s}
.footer-logo:hover{opacity:1}
.footer-links{display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:center}
.footer-links a{color:var(--text-muted);font-size:.85rem;transition:color .3s;padding:.2rem 0}
.footer-links a:hover{color:var(--primary)}
.footer-social{display:flex;gap:.8rem}
.footer-social a{
  width:38px;height:38px;border-radius:50%;border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);font-size:.95rem;transition:all .3s;
}
.footer-social a:hover{color:var(--primary);border-color:var(--primary);transform:translateY(-2px)}
.footer-contact-info{display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:center;margin-top:.2rem}
.footer-contact-info p{color:var(--text-muted);font-size:.82rem;display:flex;align-items:center;gap:.4rem;margin:0}
.footer-contact-info a{color:var(--text-muted);transition:color .3s}
.footer-contact-info a:hover{color:var(--primary)}
.footer-contact-info i{color:var(--accent);font-size:.8rem}
.footer-tagline{color:var(--accent);font-style:italic;font-size:.85rem}
.footer p{color:var(--text-muted);font-size:.72rem}

/* ===== SCROLL REVEAL ===== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.reveal.active{opacity:1;transform:translateY(0)}

/* ===== BACK TO TOP ===== */
.back-to-top{
  position:fixed;bottom:1.5rem;right:1.5rem;
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--primary-dark));
  color:var(--white);display:flex;align-items:center;justify-content:center;
  font-size:1rem;border:none;z-index:900;
  opacity:0;visibility:hidden;transform:translateY(16px);
  transition:all .3s;box-shadow:0 4px 20px rgba(230,57,70,.35);
}
.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(230,57,70,.5)}

/* ===== GLOBAL EVENT HIGHLIGHT (Enhanced) ===== */
.global-event-highlight{
  position:fixed;
  left:1.5rem;
  bottom:1.5rem;
  z-index:901;
  animation:gehSlideIn 0.6s ease 1s both;
}
@keyframes gehSlideIn{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}
.global-event-highlight .global-event-link{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  border-radius:999px;
  padding:.65rem 1.2rem;
  font-size:.82rem;
  letter-spacing:.02em;
  font-weight:700;
  color:#fff;
  border:1.5px solid rgba(212,167,58,.6);
  background:linear-gradient(135deg,rgba(123,104,238,.92),rgba(212,167,58,.88));
  box-shadow:0 8px 30px rgba(123,104,238,.3),0 0 15px rgba(212,167,58,.15);
  transition:transform .25s ease,box-shadow .25s ease;
  position:relative;
  overflow:hidden;
}
.global-event-highlight .global-event-link:hover{
  transform:translateY(-3px) scale(1.03);
  box-shadow:0 12px 40px rgba(123,104,238,.4),0 0 20px rgba(212,167,58,.25);
}
.global-event-pulse{
  width:8px;height:8px;border-radius:50%;
  background:#69db7c;
  box-shadow:0 0 6px rgba(105,219,124,.6);
  animation:gePulse 2s ease-in-out infinite;
  flex-shrink:0;
}
@keyframes gePulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.5;transform:scale(1.4)}
}

/* Mobile backdrop */
.nav-backdrop{
  display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);
  z-index:998;opacity:0;transition:opacity .3s;backdrop-filter:blur(4px);
}
.nav-backdrop.visible{display:block;opacity:1}

/* ===== RESPONSIVE: TABLET ===== */
@media(max-width:1024px){
  .events-grid{grid-template-columns:repeat(2,1fr)}
  .about-grid,.contact-grid,.event-detail-header{grid-template-columns:1fr;gap:2rem}
  .about-image{order:-1}
  .detail-cards{grid-template-columns:1fr 1fr}
}

/* ===== RESPONSIVE: MOBILE ===== */
@media(max-width:768px){
  :root{--nav-h:58px}

  .navbar{padding:0 4%}
  .nav-links{
    position:fixed;top:0;right:-100%;width:75%;max-width:300px;
    height:100vh;height:100dvh;flex-direction:column;
    background:rgba(11,11,16,.98);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);
    padding:5rem 2rem 2rem;gap:0;transition:right .4s;
    border-left:1px solid rgba(230,57,70,.2);z-index:999;overflow-y:auto;
  }
  .nav-links.open{right:0}
  .nav-links li{border-bottom:1px solid rgba(255,255,255,.04)}
  .nav-links a{display:block;padding:1rem 0;font-size:.95rem}
  .hamburger{display:flex}
  .hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
  .hamburger.active span:nth-child(2){opacity:0}
  .hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

  .hero{padding:calc(var(--nav-h) + 1rem) 1.2rem 3rem;min-height:100dvh}
  .hero-buttons{flex-direction:column;align-items:stretch}

  .global-event-highlight{left:1rem;bottom:1rem}
  .global-event-highlight .global-event-link{font-size:.72rem;padding:.48rem .8rem}
  .hero-buttons .btn{justify-content:center}

  .section{padding:3.5rem 0}
  .container{padding:0 16px}

  .events-grid{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .about-features{grid-template-columns:1fr}
  .detail-cards{grid-template-columns:1fr}
  .coordinators-grid{grid-template-columns:1fr 1fr}

  .event-detail-header{grid-template-columns:1fr}
  .event-detail-header .event-icon-big{height:180px;aspect-ratio:auto}
  .event-detail-img{max-height:300px;object-fit:contain}

  .page-hero{min-height:35vh;padding-top:calc(var(--nav-h) + 1.5rem)}

  .timeline{padding-left:2rem}
  .timeline::before{left:10px}
  .timeline-dot{left:-1.85rem;width:12px;height:12px}

  .orb{filter:blur(60px)}
  .orb-1{width:200px;height:200px}
  .orb-2{width:180px;height:180px}
  .orb-3{width:150px;height:150px}
  .intro-bg-grid{background-size:40px 40px}

  .contact-grid{grid-template-columns:1fr}
  .footer{padding:2rem 1rem}
}

@media(max-width:400px){
  .hero-stats{flex-direction:column;align-items:center}
  .hero-stat{width:100%}
  .coordinators-grid{grid-template-columns:1fr}
  .navbar{padding:0 3%}
}

/* Stats grid used on home */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.stat-card{
  text-align:center;padding:2rem 1rem;
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius);backdrop-filter:blur(6px);transition:all .35s;
}
.stat-card:hover{transform:translateY(-4px);border-color:rgba(244,160,35,.25)}
.stat-number{
  font-family:var(--font-head);font-size:clamp(1.8rem,4vw,2.6rem);font-weight:900;
  background:linear-gradient(135deg,var(--accent),var(--primary));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  line-height:1.2;
}
.stat-label{font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-top:.4rem}

@media(max-width:768px){
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:1rem}
}

/* ===== EVENT SCHEDULE ===== */
.schedule-tabs{
  display:flex;justify-content:center;gap:.8rem;margin-bottom:3rem;flex-wrap:wrap;
}
.schedule-tab{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.75rem 2rem;border-radius:999px;
  font-family:var(--font-head);font-size:.9rem;font-weight:700;
  color:var(--text-muted);background:var(--bg-card);
  border:1.5px solid var(--border);cursor:pointer;transition:all .3s;
}
.schedule-tab:hover{border-color:var(--primary);color:var(--text)}
.schedule-tab.active{
  background:linear-gradient(135deg,var(--primary),var(--primary-dark));
  color:#fff;border-color:var(--primary);
  box-shadow:0 4px 18px rgba(230,57,70,.35);
}
.schedule-day{display:none}
.schedule-day.active{display:block}

/* ── Vertical Timeline ── */
.stl{
  max-width:860px;margin:0 auto;
  display:flex;flex-direction:column;gap:0;
}
.stl-block{
  display:grid;
  grid-template-columns:80px 32px 1fr;
  align-items:stretch;
  gap:0 1.2rem;
}

/* Time label */
.stl-time{
  display:flex;align-items:flex-start;justify-content:flex-end;
  padding-top:.55rem;
}
.stl-time span{
  font-family:var(--font-head);font-size:.82rem;font-weight:800;
  color:var(--accent);white-space:nowrap;letter-spacing:.02em;
}

/* Rail & dot */
.stl-rail{
  display:flex;flex-direction:column;align-items:center;
  position:relative;
}
.stl-rail::before{
  content:'';position:absolute;top:0;bottom:0;left:50%;
  transform:translateX(-50%);width:2px;
  background:linear-gradient(180deg,rgba(230,57,70,.5),rgba(230,57,70,.08));
}
.stl-block:last-child .stl-rail::before{bottom:50%}
.stl-dot{
  width:14px;height:14px;border-radius:50%;flex-shrink:0;
  margin-top:.5rem;position:relative;z-index:1;
  background:var(--primary);
  border:2.5px solid var(--bg);
  box-shadow:0 0 0 3px rgba(230,57,70,.25);
}
.stl-dot--glow{
  background:linear-gradient(135deg,#7b68ee,#d4a73a);
  box-shadow:0 0 0 3px rgba(123,104,238,.3),0 0 14px rgba(212,167,58,.4);
  animation:dotPulse 2s ease-in-out infinite;
}
@keyframes dotPulse{
  0%,100%{box-shadow:0 0 0 3px rgba(123,104,238,.3),0 0 14px rgba(212,167,58,.3)}
  50%{box-shadow:0 0 0 6px rgba(123,104,238,.15),0 0 22px rgba(212,167,58,.55)}
}

/* Cards area */
.stl-cards{
  display:flex;flex-direction:column;gap:.55rem;
  padding:.3rem 0 1.6rem;
}
.stl-card{
  display:flex;align-items:center;gap:.9rem;
  padding:.7rem 1.1rem;border-radius:10px;
  background:var(--bg-card);border:1px solid var(--border);
  text-decoration:none;transition:all .28s;position:relative;overflow:hidden;
}
.stl-card::after{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,var(--primary),var(--accent));
  transform:scaleY(0);transform-origin:top;transition:transform .28s;
}
.stl-card:hover{
  border-color:rgba(230,57,70,.35);
  transform:translateX(5px);
  box-shadow:0 4px 18px rgba(0,0,0,.25);
}
.stl-card:hover::after{transform:scaleY(1)}

/* Icon */
.stl-ic{
  width:34px;height:34px;border-radius:8px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:rgba(230,57,70,.12);color:var(--primary);font-size:.9rem;
}
.stl-ic--gold{background:rgba(212,167,58,.15);color:#d4a73a}

/* Card text */
.stl-card h4{
  font-family:var(--font-head);font-size:.9rem;font-weight:700;
  color:var(--white);margin-bottom:.18rem;line-height:1.2;
}
.stl-card p{
  font-size:.73rem;color:var(--text-muted);margin:0;
  display:flex;align-items:center;gap:.3rem;flex-wrap:wrap;
}
.stl-card p i{color:var(--accent);font-size:.68rem}
.stl-sep{color:rgba(255,255,255,.2);margin:0 .15rem}

/* Featured card */
.stl-card--feat{
  border-color:rgba(123,104,238,.35);
  background:linear-gradient(135deg,rgba(123,104,238,.1),rgba(212,167,58,.06));
}
.stl-card--feat::after{
  background:linear-gradient(180deg,#7b68ee,#d4a73a);
}
.stl-card--feat:hover{
  border-color:rgba(212,167,58,.5);
  box-shadow:0 6px 24px rgba(123,104,238,.2);
}
.stl-card--feat h4{color:#e8dfff}
.stl-free{
  position:absolute;top:.5rem;right:.6rem;
  font-size:.58rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;
  padding:.15rem .5rem;border-radius:999px;
  background:linear-gradient(135deg,#7b68ee,#d4a73a);color:#fff;
}

@media(max-width:768px){
  .schedule-tab{padding:.6rem 1.2rem;font-size:.8rem}
  .stl-block{grid-template-columns:62px 24px 1fr;gap:0 .8rem}
  .stl-time span{font-size:.73rem}
  .stl-dot{width:11px;height:11px}
  .stl-card{padding:.6rem .85rem;gap:.7rem}
  .stl-ic{width:28px;height:28px;font-size:.78rem}
  .stl-card h4{font-size:.82rem}
  .stl-card p{font-size:.67rem}
}
@media(max-width:480px){
  .stl-block{grid-template-columns:52px 20px 1fr;gap:0 .55rem}
  .stl-time span{font-size:.68rem}
  .stl-cards{gap:.4rem;padding-bottom:1.2rem}
}

/* ===== ANNOUNCEMENT BAR =====*/
.announcement-bar{
  position:fixed;
  top:0;left:0;width:100%;
  height:var(--announcement-h);
  z-index:1001;
  background:linear-gradient(135deg,#7b68ee,#d4a73a);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.announcement-bar__inner{
  display:flex;align-items:center;gap:1rem;
  padding:0 1rem;width:100%;max-width:1200px;justify-content:center;
}
.announcement-bar__text{
  font-family:var(--font-body);font-size:.82rem;font-weight:500;
  color:#fff;white-space:nowrap;
}
.announcement-bar__text i{margin-right:.3rem}
.announcement-bar__cta{
  display:inline-flex;align-items:center;gap:.3rem;
  padding:.25rem .8rem;border-radius:999px;
  background:rgba(255,255,255,.2);color:#fff;
  font-size:.75rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.04em;transition:background .3s;
  white-space:nowrap;text-decoration:none;
}
.announcement-bar__cta:hover{background:rgba(255,255,255,.35)}
.announcement-bar__close{
  position:absolute;right:1rem;background:none;border:none;
  color:rgba(255,255,255,.7);font-size:.9rem;cursor:pointer;
  padding:.3rem;transition:color .3s;
}
.announcement-bar__close:hover{color:#fff}
body.has-announcement-bar .navbar{top:var(--announcement-h)}
body.has-announcement-bar .hero{padding-top:calc(var(--nav-h) + var(--announcement-h) + 2rem)}
body.has-announcement-bar .page-hero{padding-top:calc(var(--nav-h) + var(--announcement-h) + 2rem)}

@media(max-width:768px){
  :root{--announcement-h:38px}
  .announcement-bar__text{font-size:.72rem}
  .announcement-bar__cta{font-size:.68rem;padding:.2rem .6rem}
  .announcement-bar__inner{gap:.5rem}
}
@media(max-width:480px){
  .announcement-bar__text{font-size:.65rem}
  .announcement-bar__cta{display:none}
}

/* ===== NAV CEOs TALK LINK ===== */
.nav-ceo-link{
  display:inline-flex !important;align-items:center;gap:.35rem;
  padding:.35rem .85rem !important;border-radius:999px !important;
  background:linear-gradient(135deg,rgba(123,104,238,.2),rgba(212,167,58,.2));
  border:1.5px solid rgba(212,167,58,.45) !important;
  color:#d4a73a !important;font-size:.78rem !important;font-weight:700 !important;
  letter-spacing:.04em;text-transform:uppercase;
  transition:all .3s !important;animation:navCeoGlow 3s ease-in-out infinite;
}
.nav-ceo-link:hover{
  background:linear-gradient(135deg,rgba(123,104,238,.35),rgba(212,167,58,.35)) !important;
  color:#f0c85a !important;transform:translateY(-1px);
  box-shadow:0 4px 16px rgba(212,167,58,.25);
}
.nav-links .nav-ceo-link::after{display:none !important}
@keyframes navCeoGlow{
  0%,100%{border-color:rgba(212,167,58,.45);box-shadow:none}
  50%{border-color:rgba(212,167,58,.8);box-shadow:0 0 12px rgba(212,167,58,.15)}
}
@media(max-width:768px){
  .nav-ceo-link{
    border-radius:10px !important;padding:.8rem 1rem !important;
    font-size:.88rem !important;justify-content:center;text-align:center;width:100%;
  }
}

/* ===== CEO SPOTLIGHT SECTION ===== */
.ceo-spotlight{
  background:linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%);
  position:relative;overflow:hidden;padding:4rem 0;
}
.ceo-spotlight::before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:80%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(123,104,238,.4),rgba(212,167,58,.4),transparent);
}
.ceo-spotlight__grid{
  display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;
}
.ceo-spotlight__poster{position:relative}
.ceo-spotlight__img{
  width:100%;border-radius:var(--radius);
  border:2px solid rgba(123,104,238,.3);
  box-shadow:0 12px 40px rgba(123,104,238,.15),0 0 60px rgba(212,167,58,.08);
  transition:transform .4s ease,box-shadow .4s ease;
}
.ceo-spotlight__img:hover{
  transform:scale(1.02);
  box-shadow:0 16px 50px rgba(123,104,238,.25),0 0 80px rgba(212,167,58,.12);
}
.ceo-spotlight__badge{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.35rem .9rem;border-radius:999px;
  background:linear-gradient(135deg,rgba(212,167,58,.2),rgba(123,104,238,.2));
  border:1px solid rgba(212,167,58,.4);color:#d4a73a;
  font-size:.75rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;margin-bottom:1rem;
}
.ceo-spotlight__title{
  font-family:var(--font-head);font-size:clamp(1.8rem,4vw,2.8rem);
  font-weight:800;color:var(--white);margin-bottom:.5rem;
  background:linear-gradient(135deg,#fff 60%,#d4a73a);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.ceo-spotlight__subtitle{
  font-size:clamp(.9rem,2vw,1.05rem);color:var(--text-muted);margin-bottom:1.5rem;
}
.ceo-spotlight__speakers{display:flex;flex-direction:column;gap:.8rem;margin-bottom:1.5rem}
.ceo-spotlight__speaker{
  padding:.8rem 1rem;background:var(--bg-card);
  border:1px solid var(--border);border-left:3px solid #7b68ee;border-radius:10px;
}
.ceo-spotlight__speaker strong{
  display:block;font-family:var(--font-head);font-size:.95rem;
  color:var(--white);font-weight:700;
}
.ceo-spotlight__speaker span{font-size:.82rem;color:var(--text-muted)}
.ceo-spotlight__meta{display:flex;flex-wrap:wrap;gap:.8rem;margin-bottom:1.5rem}
.ceo-spotlight__meta span{
  display:inline-flex;align-items:center;gap:.35rem;
  padding:.3rem .7rem;border-radius:999px;
  background:rgba(255,255,255,.05);border:1px solid var(--border);
  font-size:.78rem;color:var(--text);
}
.ceo-spotlight__meta span i{color:#d4a73a;font-size:.75rem}
.ceo-spotlight__actions{display:flex;gap:1rem}
@media(max-width:1024px){
  .ceo-spotlight__grid{grid-template-columns:1fr;gap:2rem}
  .ceo-spotlight__poster{order:-1;max-width:500px;margin:0 auto}
}
@media(max-width:768px){
  .ceo-spotlight{padding:3rem 0}
  .ceo-spotlight__meta{gap:.5rem}
  .ceo-spotlight__speaker{padding:.6rem .8rem}
}

/* ===== FEATURED EVENT CARD ===== */
.event-card--featured{
  position:relative;
  border:1.5px solid rgba(123,104,238,.4) !important;
  box-shadow:0 0 20px rgba(123,104,238,.1),0 8px 32px rgba(0,0,0,.35);
  animation:featuredCardGlow 4s ease-in-out infinite;
}
.event-card--featured:hover{
  border-color:rgba(212,167,58,.6) !important;
  box-shadow:0 0 30px rgba(123,104,238,.2),0 12px 40px rgba(0,0,0,.4);
  transform:translateY(-8px) scale(1.01);
}
.event-card--featured::before{
  content:'\f005  FEATURED';font-family:'Font Awesome 6 Free',var(--font-head);
  font-weight:900;position:absolute;top:12px;right:12px;z-index:5;
  padding:.3rem .7rem;border-radius:999px;
  background:linear-gradient(135deg,#7b68ee,#d4a73a);
  color:#fff;font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;
  box-shadow:0 4px 12px rgba(123,104,238,.3);
  animation:featuredBadgePulse 2.5s ease-in-out infinite;
}
@keyframes featuredCardGlow{
  0%,100%{border-color:rgba(123,104,238,.4)}
  50%{border-color:rgba(212,167,58,.5)}
}
@keyframes featuredBadgePulse{
  0%,100%{transform:scale(1);box-shadow:0 4px 12px rgba(123,104,238,.3)}
  50%{transform:scale(1.05);box-shadow:0 6px 18px rgba(212,167,58,.4)}
}

/* ===== CEO FEATURED HERO (events.html) ===== */
.ceo-events-hero{
  padding:3rem 0;
  background:linear-gradient(135deg,rgba(123,104,238,.06) 0%,rgba(212,167,58,.04) 100%);
  border-bottom:1px solid rgba(123,104,238,.15);position:relative;overflow:hidden;
}
.ceo-events-hero::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(212,167,58,.3),rgba(123,104,238,.3),transparent);
}
.ceo-events-hero__grid{
  display:grid;grid-template-columns:300px 1fr;gap:2.5rem;align-items:center;
}
.ceo-events-hero__img{
  width:100%;border-radius:var(--radius);
  border:1.5px solid rgba(123,104,238,.3);box-shadow:0 8px 30px rgba(0,0,0,.3);
}
.ceo-events-hero__title{
  font-family:var(--font-head);font-size:clamp(1.5rem,3.5vw,2.2rem);
  font-weight:800;color:var(--white);margin-bottom:.5rem;
}
.ceo-events-hero__desc{
  font-size:.9rem;color:var(--text-muted);line-height:1.7;margin-bottom:1rem;
}
.ceo-events-hero__desc strong{color:var(--white)}
@media(max-width:768px){
  .ceo-events-hero__grid{grid-template-columns:1fr;gap:1.5rem;text-align:center}
  .ceo-events-hero__poster{max-width:280px;margin:0 auto}
  .ceo-events-hero .ceo-spotlight__meta{justify-content:center}
}

/* ===== CEO CROSS-PROMO BANNER ===== */
.ceo-cross-promo{
  padding:3rem 0;background:var(--bg-2);
  border-top:1px solid rgba(123,104,238,.12);
}
.ceo-cross-promo__card{
  display:grid;grid-template-columns:180px 1fr;gap:1.5rem;align-items:center;
  background:linear-gradient(135deg,rgba(123,104,238,.08),rgba(212,167,58,.05));
  border:1.5px solid rgba(123,104,238,.25);border-radius:var(--radius);
  padding:1.5rem;max-width:800px;margin:0 auto;
  transition:border-color .3s,box-shadow .3s;
}
.ceo-cross-promo__card:hover{
  border-color:rgba(212,167,58,.4);box-shadow:0 8px 30px rgba(123,104,238,.1);
}
.ceo-cross-promo__poster img{
  width:100%;border-radius:10px;border:1px solid rgba(123,104,238,.2);
}
.ceo-cross-promo__badge{
  display:inline-flex;align-items:center;gap:.3rem;
  padding:.25rem .65rem;border-radius:999px;
  background:linear-gradient(135deg,rgba(212,167,58,.2),rgba(123,104,238,.2));
  border:1px solid rgba(212,167,58,.35);color:#d4a73a;
  font-size:.7rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.06em;margin-bottom:.6rem;
}
.ceo-cross-promo__title{
  font-family:var(--font-head);font-size:1.15rem;font-weight:700;
  color:var(--white);margin-bottom:.4rem;
}
.ceo-cross-promo__desc{
  font-size:.84rem;color:var(--text-muted);line-height:1.7;margin-bottom:1rem;
}
@media(max-width:768px){
  .ceo-cross-promo__card{
    grid-template-columns:1fr;text-align:center;padding:1.2rem;
  }
  .ceo-cross-promo__poster{max-width:200px;margin:0 auto}
  .ceo-cross-promo__body .btn{width:100%;justify-content:center}
}
