/* ============================================================
   DESIGN TOKENS
============================================================ */
:root {
  --bg:        #ffffff;
  --surface:   #f8fafc;
  --glass:     rgba(255,255,255,0.7);
  --border:    rgba(0,0,0,0.08);
  --text:      #0f172a;
  --muted:     #64748b;
  --purple:    #008190;
  --cyan:      #f38e3e;
  --amber:     #f38e3e;
  --gold:      #f38e3e;
  --red:       #ef4444;
  --green:     #10b981;
  --teal:      #008190;
  --grad:      linear-gradient(135deg,#008190 0%,#00a8b5 100%);
  --grad-warm: linear-gradient(135deg,#f38e3e 0%,#ff6b3d 100%);
  --grad-card: linear-gradient(145deg,rgba(255,255,255,0.9) 0%,rgba(241,245,249,0.5) 100%);
  --r-sm: 8px; --r-md: 16px; --r-lg: 24px; --r-xl: 36px;
  --shadow-card: 0 10px 30px rgba(0,0,0,0.05);
  --shadow-glow: 0 0 50px rgba(0,129,144,0.1),0 0 100px rgba(243,142,62,0.05);
  --ease-spring: cubic-bezier(0.34,1.56,0.64,1);
  --ease-smooth: cubic-bezier(0.4,0,0.2,1);
  --font-h: 'Syne', sans-serif;
  --font-b: 'DM Sans', sans-serif;
}

/* ============================================================
   RESET & BASE
============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-b);background:var(--bg);color:var(--text);overflow-x:hidden;line-height:1.6}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{cursor:pointer;font-family:var(--font-b);border:none;outline:none;background:none}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--purple);border-radius:3px}

/* ============================================================
   UTILITIES
============================================================ */
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.section{padding:100px 0}

.tag{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(0,129,144,0.1);border:1px solid rgba(0,129,144,0.25);
  color:var(--teal);font-size:.72rem;font-weight:700;letter-spacing:.09em;
  text-transform:uppercase;padding:5px 14px;border-radius:100px;margin-bottom:18px;
}
.tag-dot{width:6px;height:6px;border-radius:50%;background:var(--teal);animation:pdot 2s infinite}
@keyframes pdot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.5)}}

.grad-text{
  background:var(--grad);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
}

.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-h);font-weight:700;font-size:.95rem;
  padding:14px 32px;border-radius:100px;transition:all .3s var(--ease-spring);
  position:relative;overflow:hidden;
}
.btn::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.2),transparent);
  opacity:0;transition:opacity .3s;
}
.btn:hover::after{opacity:1}
.btn-primary{
  background:var(--grad);color:#fff;
  box-shadow:0 8px 30px rgba(0,129,144,.3);
}
.btn-primary:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 16px 50px rgba(0,129,144,.45)}
.btn-primary:active{transform:translateY(0) scale(.98)}
.btn-ghost{
  border:1px solid var(--border);color:var(--text);
  background:var(--glass);backdrop-filter:blur(12px);
}
.btn-ghost:hover{border-color:rgba(124,58,237,.45);background:rgba(124,58,237,.1)}

.glass-card{
  background:var(--grad-card);border:1px solid var(--border);
  border-radius:var(--r-lg);backdrop-filter:blur(20px);
}

.sec-title{
  font-family:var(--font-h);font-size:clamp(1.9rem,4vw,3rem);
  font-weight:800;line-height:1.12;letter-spacing:-.025em;margin-bottom:14px;
}
.sec-sub{color:var(--muted);font-size:1.05rem;max-width:560px;line-height:1.75}

/* Noise texture overlay */
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:9000;opacity:.022;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* Reveal animations */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s var(--ease-smooth)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* ============================================================
   NAVBAR
============================================================ */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:800;padding:16px 0;
  transition:background .4s,backdrop-filter .4s,box-shadow .4s;
}
.navbar.scrolled{
  background:rgba(255,255,255,0.88);backdrop-filter:blur(22px);
  border-bottom:1px solid var(--border);box-shadow:0 4px 32px rgba(0,0,0,0.05);
}
.nav-in{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;padding:0 24px}
.nav-logo{font-family:var(--font-h);font-size:1.45rem;font-weight:800;display:flex;align-items:center;text-decoration:none}
.nav-logo img{max-height:42px;width:auto;object-fit:contain}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{color:var(--muted);font-size:.88rem;font-weight:500;transition:color .2s;position:relative;padding-bottom:2px}
.nav-links a::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--grad);border-radius:2px;transform:scaleX(0);transition:transform .3s}
.nav-links a:hover{color:var(--text)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-cta{background:var(--grad);color:#fff;font-family:var(--font-h);font-weight:700;font-size:.85rem;padding:9px 20px;border-radius:100px;box-shadow:0 4px 20px rgba(124,58,237,.35);transition:all .25s}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(124,58,237,.55)}
.nav-ham{display:none;flex-direction:column;gap:5px;padding:4px;background:none;transition:transform .3s;z-index:900}
.nav-ham[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-ham[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-ham[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-ham span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all .3s}
.mob-nav{
  display:none;position:fixed;inset:0;background:rgba(255,255,255,0.98);
  backdrop-filter:blur(20px);z-index:799;
  flex-direction:column;align-items:center;justify-content:center;gap:28px;
}
.mob-nav.open{display:flex;animation:fadeIn .3s}
.mob-nav a{font-family:var(--font-h);font-size:1.5rem;color:var(--text)}
.mob-close{display:none;position:absolute;top:18px;right:20px;color:var(--text);font-size:1.8rem;background:none;border:none;cursor:pointer;padding:8px}
@media(max-width:768px){.nav-links,.nav-cta{display:none}.nav-ham{display:flex}}

/* ============================================================
   HERO
============================================================ */
.hero{
  min-height:100vh;display:flex;align-items:center;
  position:relative;overflow:hidden;padding-top:80px;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse 80% 70% at 15% 50%,rgba(0,129,144,0.08) 0%,transparent 60%),
    radial-gradient(ellipse 60% 60% at 85% 30%,rgba(243,142,62,0.06) 0%,transparent 60%),
    radial-gradient(ellipse 50% 50% at 60% 85%,rgba(0,129,144,0.04) 0%,transparent 60%);
}
.hero-grid{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(0,129,144,0.03) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(0,129,144,0.03) 1px,transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse at 50% 50%,black 30%,transparent 75%);
}
.orb{position:absolute;border-radius:50%;filter:blur(55px);pointer-events:none;animation:forb 8s ease-in-out infinite}
.o1{width:280px;height:280px;background:rgba(124,58,237,.2);top:8%;left:3%;animation-delay:0s}
.o2{width:200px;height:200px;background:rgba(6,182,212,.15);bottom:15%;right:8%;animation-delay:-3s}
.o3{width:140px;height:140px;background:rgba(245,158,11,.12);bottom:30%;left:42%;animation-delay:-5s}
@keyframes forb{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-26px) scale(1.06)}}

.hero-inner{
  position:relative;z-index:1;display:grid;
  grid-template-columns:1fr 1fr;gap:64px;align-items:center;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:linear-gradient(135deg,rgba(245,158,11,.14),rgba(239,68,68,.1));
  border:1px solid rgba(245,158,11,.3);color:var(--gold);
  font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:5px 14px;border-radius:100px;margin-bottom:18px;
}
.hero-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:pdot 2s infinite}
.hero-title{
  font-family:var(--font-h);font-size:clamp(2.4rem,5.5vw,4rem);
  font-weight:800;line-height:1.08;letter-spacing:-.03em;margin-bottom:18px;
}
.hero-sub{color:var(--muted);font-size:1.05rem;line-height:1.8;margin-bottom:32px;max-width:460px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:44px}
.hero-stats{display:flex;gap:28px;flex-wrap:wrap}
.stat-num{font-family:var(--font-h);font-size:1.7rem;font-weight:800;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.stat-label{color:var(--muted);font-size:.78rem;font-weight:500}

.hero-visual{display:flex;align-items:center;justify-content:center;position:relative}
.wheel-float{position:relative;width:340px;height:340px;animation:fwheel 4s ease-in-out infinite}
@keyframes fwheel{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-14px) rotate(2deg)}}
.wheel-glow{
  position:absolute;inset:-16px;border-radius:50%;
  background:conic-gradient(from 0deg,var(--teal),var(--cyan),var(--amber),var(--teal));
  opacity:.28;filter:blur(18px);animation:spinGlow 6s linear infinite;
}
@keyframes spinGlow{to{transform:rotate(360deg)}}
@media(max-width:1024px){.hero-inner{grid-template-columns:1fr;text-align:center}.hero-sub,.hero-ctas{margin-left:auto;margin-right:auto}.hero-ctas{justify-content:center}.hero-stats{justify-content:center}}
@media(max-width:768px){.hero-visual{display:none}}
@media(max-width:480px){
  .nav-in{padding:0 16px}
  .hero-title{font-size:2.1rem}
  .hero-sub{font-size:.95rem}
  .section{padding:70px 0}
  .sec-title{font-size:1.8rem}
}

/* ============================================================
   COUNTDOWN BAR
============================================================ */
.cd-bar{
  background:linear-gradient(90deg,rgba(0,129,144,0.04),rgba(243,142,62,0.04));
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:16px 0;
}
.cd-in{display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap}
.cd-label{font-family:var(--font-h);font-weight:700;font-size:.88rem;color:var(--amber)}
.cd-units{display:flex;gap:10px;align-items:center}
.cd-unit{display:flex;flex-direction:column;align-items:center;gap:3px}
.cd-num{
  font-family:var(--font-h);font-size:1.6rem;font-weight:800;color:var(--text);
  background:var(--glass);border:1px solid var(--border);border-radius:var(--r-sm);
  padding:6px 14px;min-width:58px;text-align:center;line-height:1;
}
.cd-sep{font-family:var(--font-h);font-size:1.4rem;font-weight:800;color:var(--purple);align-self:flex-start;padding-top:6px}
.cd-ulabel{font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}

/* ============================================================
   SPIN WHEEL SECTION
============================================================ */
.spin-sec{padding:100px 0;position:relative;overflow:hidden}
.spin-sec-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 50%,rgba(124,58,237,.1) 0%,transparent 70%)}
.spin-hdr{text-align:center;margin-bottom:56px}
.spin-layout{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:36px}

.wheel-wrap{position:relative;width:380px;height:380px;display:flex;align-items:center;justify-content:center}
.wheel-ptr{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  width:0;height:0;z-index:10;
  border-left:13px solid transparent;border-right:13px solid transparent;
  border-top:26px solid var(--gold);
  filter:drop-shadow(0 4px 10px rgba(251,191,36,.65));
}
.canvas-wrap{position:relative;width:360px;height:360px}
#spinCanvas{
  border-radius:50%;
  box-shadow:0 0 60px rgba(0,129,144,0.1),0 0 120px rgba(243,142,62,0.05),0 20px 60px rgba(0,0,0,0.1);
}
.spin-center-btn{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:76px;height:76px;border-radius:50%;z-index:10;
  background:var(--grad);
  box-shadow:0 0 0 4px rgba(255,255,255,.14),0 8px 28px rgba(124,58,237,.5);
  font-family:var(--font-h);font-weight:800;font-size:.72rem;color:#fff;
  letter-spacing:.06em;text-transform:uppercase;
  transition:transform .3s var(--ease-spring),box-shadow .3s;
}
.spin-center-btn:hover{transform:translate(-50%,-50%) scale(1.12);box-shadow:0 0 0 6px rgba(255,255,255,.2),0 12px 40px rgba(124,58,237,.7)}
.spin-center-btn:disabled{opacity:.45;cursor:not-allowed;transform:translate(-50%,-50%) scale(1)}
.spin-info{text-align:center;max-width:480px}
.spin-info p{color:var(--muted);font-size:.92rem;line-height:1.75}
.prize-chips{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:14px}
.chip{padding:5px 14px;border-radius:100px;font-size:.78rem;font-weight:700;border:1px solid;transition:transform .2s}
.chip:hover{transform:translateY(-2px)}
@media(max-width:768px){.wheel-wrap{width:300px;height:300px}.canvas-wrap,.canvas-wrap canvas{width:280px;height:280px}}

/* Exam Tabs */
.exam-tabs-wrap{
  width:100%;max-width:800px;margin:0 auto 20px;
  overflow:hidden;position:relative;
  -webkit-mask-image: linear-gradient(to right, transparent, black 8%, black 92%, transparent);
  mask-image: linear-gradient(to right, transparent, black 8%, black 92%, transparent);
}
.exam-tabs{
  display:flex;gap:12px;overflow-x:auto;padding:10px 40px 20px;
  scrollbar-width:none;-ms-overflow-style:none;
  justify-content:center;
}
.exam-tabs::-webkit-scrollbar{display:none}
.exam-tab{
  padding:10px 24px;border-radius:100px;background:var(--surface);border:1px solid var(--border);
  color:var(--muted);font-family:var(--font-h);font-weight:700;font-size:.88rem;
  cursor:pointer;transition:all .3s var(--ease-spring);white-space:nowrap;flex-shrink:0;
}
.exam-tab:hover{border-color:var(--teal);color:var(--teal);transform:translateY(-2px);background:rgba(0,129,144,.03)}
.exam-tab.active{background:var(--teal);color:#fff;border-color:var(--teal);box-shadow:0 8px 24px rgba(0,129,144,0.3)}
@media(max-width:800px){
  .exam-tabs{justify-content:flex-start;padding-left:10%;padding-right:10%;}
}

/* ============================================================
   WIN MODAL
============================================================ */
.overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.82);z-index:2000;
  display:none;align-items:center;justify-content:center;
  backdrop-filter:blur(12px);padding:20px;
}
.overlay.open{display:flex;animation:fadeIn .3s}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{
  background:linear-gradient(145deg,#ffffff,#f8fafc);
  border:1px solid rgba(0,129,144,0.2);border-radius:var(--r-xl);
  padding:44px 38px;max-width:460px;width:100%;text-align:center;
  position:relative;box-shadow:var(--shadow-glow),var(--shadow-card);
  animation:mIn .5s var(--ease-spring);
}
@keyframes mIn{from{transform:scale(.7) translateY(36px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
.modal-x{
  position:absolute;top:14px;right:14px;
  background:var(--glass);border:1px solid var(--border);color:var(--muted);
  width:30px;height:30px;border-radius:50%;font-size:.9rem;
  display:flex;align-items:center;justify-content:center;transition:all .2s;
}
.modal-x:hover{color:var(--text);background:rgba(255,255,255,.1)}
.modal-trophy{font-size:3.8rem;margin-bottom:14px;animation:bIn .6s var(--ease-spring) .3s both}
@keyframes bIn{from{transform:scale(0) rotate(-20deg)}to{transform:scale(1) rotate(0)}}
.modal-title{font-family:var(--font-h);font-size:1.55rem;font-weight:800;margin-bottom:6px}
.modal-sub{color:var(--muted);font-size:.9rem;margin-bottom:22px}
.modal-reward{
  font-family:var(--font-h);font-size:3.2rem;font-weight:800;
  background:var(--grad-warm);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:6px;animation:gPulse 2s ease-in-out infinite;
}
@keyframes gPulse{0%,100%{filter:drop-shadow(0 0 8px rgba(245,158,11,.5))}50%{filter:drop-shadow(0 0 28px rgba(245,158,11,.9))}}
.modal-code-label{color:var(--muted);font-size:.82rem;margin-bottom:8px}
.modal-code{
  background:rgba(124,58,237,.1);border:1px dashed rgba(124,58,237,.4);
  border-radius:var(--r-sm);padding:11px 18px;font-family:monospace;
  font-size:1.15rem;letter-spacing:.15em;color:#a78bfa;margin-bottom:22px;
}
.modal-btn{width:100%;justify-content:center;font-size:1rem;padding:15px}

/* ============================================================
   FORM SECTION
============================================================ */
.form-sec{padding:100px 0}
.form-layout{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.form-perks{display:flex;flex-direction:column;gap:14px;margin-top:30px}
.perk{
  display:flex;align-items:flex-start;gap:14px;
  padding:14px 18px;border-radius:var(--r-md);
  background:var(--grad-card);border:1px solid var(--border);transition:border-color .3s;
}
.perk:hover{border-color:rgba(124,58,237,.3)}
.perk-icon{
  width:38px;height:38px;border-radius:var(--r-sm);
  background:var(--grad);display:flex;align-items:center;justify-content:center;
  font-size:1rem;flex-shrink:0;
}
.perk-t h4{font-family:var(--font-h);font-size:.9rem;font-weight:700;margin-bottom:3px}
.perk-t p{color:var(--muted);font-size:.82rem}

.form-card{
  background:linear-gradient(145deg,rgba(255,255,255,.05),rgba(255,255,255,.02));
  border:1px solid var(--border);border-radius:var(--r-xl);
  padding:36px;backdrop-filter:blur(20px);
}
.disc-banner{
  background:linear-gradient(135deg,rgba(245,158,11,.14),rgba(239,68,68,.1));
  border:1px solid rgba(245,158,11,.3);border-radius:var(--r-md);
  padding:12px 18px;margin-bottom:26px;display:flex;align-items:center;gap:12px;
}
.disc-banner strong{color:var(--gold);font-family:var(--font-h);display:block;font-size:.88rem}
.disc-banner span{color:var(--muted);font-size:.78rem}
#appliedDiscount{color:var(--gold);font-weight:700}
.fg{margin-bottom:18px}
.fg label{display:block;margin-bottom:7px;font-size:.82rem;font-weight:600;color:var(--muted);letter-spacing:.02em}
.fg input,.fg select{
  width:100%;background:rgba(255,255,255,.04);border:1px solid var(--border);
  border-radius:var(--r-md);padding:13px 15px;color:var(--text);
  font-family:var(--font-b);font-size:.92rem;transition:border-color .3s,box-shadow .3s;
}
.fg select{
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238892b0' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;
}
.fg select option{background:#ffffff}
.fg input:focus,.fg select:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(0,129,144,.14)}
.fg input.err,.fg select.err{border-color:var(--red)}
.err-msg{color:var(--red);font-size:.78rem;margin-top:4px;display:none}
.has-err .err-msg{display:block}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.sub-btn{width:100%;justify-content:center;padding:15px;margin-top:6px;font-size:1rem}
.form-success{display:none;text-align:center;padding:28px 16px}
.succ-icon{font-size:2.8rem;margin-bottom:10px;animation:bIn .5s var(--ease-spring)}
.form-success h3{font-family:var(--font-h);font-size:1.35rem;margin-bottom:8px}
.form-success p{color:var(--muted);font-size:.88rem}
@media(max-width:1024px){.form-layout{grid-template-columns:1fr;gap:40px}}
@media(max-width:480px){.fg-row{grid-template-columns:1fr}}

/* ============================================================
   HOW IT WORKS
============================================================ */
.how-sec{padding:100px 0;position:relative}
.how-sec::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 50% 50%,rgba(0,168,181,.07) 0%,transparent 70%)}
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:56px;position:relative;z-index:1}
.steps-grid::before{
  content:'';position:absolute;top:56px;left:calc(16.6% + 44px);right:calc(16.6% + 44px);
  height:2px;background:linear-gradient(90deg,var(--teal),var(--cyan));z-index:-1;
}
.step-card{
  background:var(--grad-card);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:32px 24px;text-align:center;
  transition:transform .3s var(--ease-spring),border-color .3s,box-shadow .3s;
}
.step-card:hover{transform:translateY(-8px);border-color:rgba(0,129,144,.38);box-shadow:var(--shadow-card)}
.step-num{
  width:60px;height:60px;border-radius:50%;margin:0 auto 16px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-h);font-size:1.35rem;font-weight:800;position:relative;
}
.step-num::before{content:'';position:absolute;inset:0;border-radius:50%;background:var(--grad);opacity:.14}
.step-icon{font-size:1.9rem;margin-bottom:10px}
.step-card h3{font-family:var(--font-h);font-size:1.1rem;font-weight:700;margin-bottom:8px}
.step-card p{color:var(--muted);font-size:.88rem;line-height:1.75}
@media(max-width:1024px){.steps-grid{grid-template-columns:1fr}.steps-grid::before{display:none}}

/* ============================================================
   3D ORBIT CAROUSEL
============================================================ */
.col-sec{padding:100px 0;overflow:hidden;position:relative}
.col-sec::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 60% 55% at 50% 45%,rgba(0,129,144,.13) 0%,transparent 70%),
    radial-gradient(ellipse 30% 30% at 50% 50%,rgba(0,168,181,.09) 0%,transparent 60%);
}
.orbit-header{text-align:center;margin-bottom:14px;position:relative;z-index:1}
.orbit-sub{
  text-align:center;color:var(--muted);font-size:.95rem;
  margin-bottom:52px;max-width:540px;margin-left:auto;margin-right:auto;
  position:relative;z-index:1;line-height:1.8;
}
.orbit-scene-wrap{
  position:relative;height:580px;
  display:flex;align-items:center;justify-content:center;
  perspective:1000px;perspective-origin:50% 42%;overflow:visible;
}
.orbit-path-ring{
  position:absolute;border-radius:50%;
  border:1px solid rgba(0,129,144,.18);
  box-shadow:0 0 0 1px rgba(0,168,181,.06) inset,0 0 60px 4px rgba(0,129,144,.08);
  pointer-events:none;transform:rotateX(80deg);transition:box-shadow .6s;
}
.orbit-path-ring.active-spin{
  box-shadow:0 0 0 1px rgba(245,158,11,.15) inset,0 0 90px 10px rgba(245,158,11,.12);
  border-color:rgba(245,158,11,.25);
}
.orbit-spotlight{
  position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:260px;height:100%;pointer-events:none;z-index:0;
  background:linear-gradient(to bottom,rgba(245,158,11,.0) 0%,rgba(245,158,11,.04) 30%,rgba(245,158,11,.10) 50%,rgba(245,158,11,.04) 70%,rgba(245,158,11,.0) 100%);
  clip-path:polygon(30% 0%,70% 0%,100% 100%,0% 100%);opacity:0;transition:opacity .8s ease;
}
.orbit-spotlight.lit{opacity:1}
.orbit-front-indicator{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:248px;border:2px dashed rgba(245,158,11,.0);border-radius:22px;
  pointer-events:none;z-index:20;transition:border-color .5s, box-shadow .5s;
}
.orbit-front-indicator.active{
  border-color:rgba(245,158,11,.55);
  box-shadow:0 0 30px rgba(245,158,11,.2), inset 0 0 20px rgba(245,158,11,.06);
  animation:indicatorPulse 1.6s ease-in-out infinite;
}
@keyframes indicatorPulse{
  0%,100%{box-shadow:0 0 20px rgba(245,158,11,.15), inset 0 0 10px rgba(245,158,11,.04)}
  50%{box-shadow:0 0 50px rgba(245,158,11,.35), inset 0 0 24px rgba(245,158,11,.12)}
}
.orbit-ring{position:relative;width:240px;height:340px;transform-style:preserve-3d;will-change:transform;}
.o-card{
  position:absolute;top:0;left:0;width:240px;height:340px;
  transform-style:preserve-3d;cursor:default;will-change:transform,opacity;
  transition:opacity .08s linear, filter .08s linear;
}
.o-card-inner{
  width:100%;height:100%;background:rgba(255,255,255,0.92);
  border:1px solid rgba(0,129,144,.08);border-radius:22px;overflow:hidden;
  backdrop-filter:blur(18px) saturate(1.4);-webkit-backdrop-filter:blur(18px) saturate(1.4);
  transition:border-color .5s, box-shadow .5s, transform .5s var(--ease-spring);position:relative;
}
.o-card.is-winner .o-card-inner{
  border-color:rgba(245,158,11,.8);
  box-shadow:0 0 0 2px rgba(245,158,11,.3),0 0 40px rgba(245,158,11,.4),0 0 100px rgba(0,129,144,.3),inset 0 0 30px rgba(245,158,11,.06);
  transform:scale(1.04);
}
.o-img{height:160px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;font-size:3.8rem;}
.o-img-mesh{
  position:absolute;inset:0;
  background:conic-gradient(from 180deg at 50% 50%, var(--c1) 0deg, var(--c2) 120deg, var(--c1) 240deg, var(--c2) 360deg);
  opacity:.18;animation:meshSpin 12s linear infinite;
}
@keyframes meshSpin{to{transform:rotate(360deg)}}
.o-img-icon{position:relative;z-index:2;font-size:3.6rem;line-height:1;filter:drop-shadow(0 4px 16px rgba(0,0,0,.5))}
.o-logo-img{
  position:relative;z-index:2;width:80px;height:80px;object-fit:contain;
  filter:drop-shadow(0 4px 12px rgba(0,0,0,.3));
  background:rgba(255,255,255,0.9);padding:10px;border-radius:50%;
}
.o-dummy-icon{font-size:3.5rem;color:rgba(255,255,255,0.8);text-shadow:0 4px 12px rgba(0,0,0,0.3);}
.om-logo-img{width:100px;height:100px;object-fit:contain;margin:0 auto 12px;display:block;background:white;padding:12px;border-radius:50%;box-shadow:0 8px 24px rgba(0,0,0,0.1);}
.om-dummy-icon{width:100px;height:100px;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.1);border-radius:50%;color:white;font-size:3.5rem;}
.o-img::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(to bottom,transparent 35%,rgba(255,255,255,.9));}
.o-tag{
  position:absolute;top:12px;left:12px;z-index:3;
  font-size:.62rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  padding:3px 10px;border-radius:100px;
  background:rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.14);
  color:var(--gold);backdrop-filter:blur(8px);
}
.o-rating{
  position:absolute;top:12px;right:12px;z-index:3;
  display:flex;align-items:center;gap:3px;font-size:.7rem;font-weight:700;color:#fff;
  background:rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.1);
  padding:3px 9px;border-radius:100px;backdrop-filter:blur(8px);
}
.o-rating i{color:var(--gold);font-size:.66rem}
.o-body{padding:16px 18px 20px;position:relative;z-index:1}
.o-name{font-family:var(--font-h);font-size:1rem;font-weight:800;margin-bottom:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em;}
.o-loc{color:var(--muted);font-size:.75rem;margin-bottom:14px;display:flex;align-items:center;gap:4px}
.o-discount{
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(0,129,144,.14);border:1px solid rgba(0,129,144,.28);border-radius:12px;padding:10px 14px;
}
.o-disc-label{font-size:.7rem;color:var(--muted);font-weight:500}
.o-disc-value{
  font-family:var(--font-h);font-size:1.1rem;font-weight:900;
  background:linear-gradient(135deg,#fbbf24,#f59e0b);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.o-apply-btn{
  display:block;width:100%;margin-top:12px;padding:9px;border-radius:100px;text-align:center;
  background:linear-gradient(135deg,rgba(0,129,144,.25),rgba(0,168,181,.2));
  border:1px solid rgba(0,129,144,.3);color:var(--text);font-family:var(--font-h);font-size:.78rem;font-weight:700;
  letter-spacing:.03em;transition:background .2s,border-color .2s,transform .2s;cursor:pointer;
}
.o-card.is-winner .o-apply-btn{background:linear-gradient(135deg,var(--teal),var(--cyan));border-color:transparent;box-shadow:0 4px 20px rgba(0,129,144,.4);}
.o-apply-btn:hover{transform:scale(1.02)}
.o-winner-badge{
  position:absolute;top:-32px;left:50%;transform:translateX(-50%);
  font-size:1.8rem;display:none;pointer-events:none;z-index:30;
  filter:drop-shadow(0 0 16px rgba(245,158,11,.9));
  animation:crownBounce .6s var(--ease-spring) forwards;
}
.o-card.is-winner .o-winner-badge{display:block}
@keyframes crownBounce{
  0%{transform:translateX(-50%) scale(0) rotate(-25deg);opacity:0}
  65%{transform:translateX(-50%) scale(1.25) rotate(6deg);opacity:1}
  100%{transform:translateX(-50%) scale(1) rotate(0deg);opacity:1}
}
.o-scan{position:absolute;inset:0;z-index:5;pointer-events:none;background:linear-gradient(115deg,transparent 25%,rgba(255,255,255,.07) 50%,transparent 75%);background-size:200% 200%;opacity:0;}
.o-card.is-winner .o-scan{opacity:1;animation:scanSweep 2s ease-in-out infinite;}
@keyframes scanSweep{0%{background-position:200% 0%}100%{background-position:-200% 0%}}
.orbit-particle{position:absolute;border-radius:50%;pointer-events:none;animation:orbitParticleFloat linear infinite;}
@keyframes orbitParticleFloat{0%{opacity:0;transform:scale(0)}10%{opacity:1;transform:scale(1)}90%{opacity:.7;transform:scale(1)}100%{opacity:0;transform:scale(0)}}
.orbit-speed-bar{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);width:160px;height:4px;border-radius:4px;background:rgba(255,255,255,.06);overflow:hidden;pointer-events:none;}
.orbit-speed-fill{height:100%;width:0%;border-radius:4px;background:linear-gradient(90deg,var(--teal),var(--cyan),var(--gold));transition:width .1s linear;}
.orbit-controls{display:flex;flex-direction:column;align-items:center;gap:16px;margin-top:52px;position:relative;z-index:10;}
.orbit-dots{display:flex;gap:7px;align-items:center}
.orbit-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.18);transition:all .3s var(--ease-spring);cursor:pointer;}
.orbit-dot:hover{background:rgba(255,255,255,.35);transform:scale(1.3)}
.orbit-dot.active{width:20px;height:7px;border-radius:4px;background:linear-gradient(90deg,var(--teal),var(--cyan));box-shadow:0 0 10px rgba(0,129,144,.5);}
.orbit-start-btn{
  position:relative;overflow:hidden;padding:18px 60px;border-radius:100px;
  background: linear-gradient(135deg, #06bacf 0%, #008190 40%, var(--cyan) 100%);
  color:#fff;font-family:var(--font-h);font-size:1.05rem;font-weight:800;letter-spacing:.04em;
  box-shadow:0 0 0 0 rgba(0,129,144,.4),0 8px 32px rgba(0,129,144,.3);
  transition:transform .25s var(--ease-spring),box-shadow .3s,opacity .2s;
}
.orbit-start-btn::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(115deg,transparent 30%,rgba(255,255,255,.22) 50%,transparent 70%);
  background-size:200% 100%;background-position:200% 0;transition:background-position .5s;
}
.orbit-start-btn:hover:not(:disabled)::before{background-position:-200% 0}
.orbit-start-btn:hover:not(:disabled){transform:scale(1.06) translateY(-2px);box-shadow:0 0 0 10px rgba(0,129,144,.15),0 16px 50px rgba(0,129,144,.45);}
.orbit-start-btn:active:not(:disabled){transform:scale(.98)}
.orbit-start-btn:disabled{opacity:.45;cursor:not-allowed}
.orbit-start-btn.spinning{animation:btnRipple 1s ease-in-out infinite}
@keyframes btnRipple{0%,100%{box-shadow:0 0 0 0 rgba(0,129,144,.5),0 8px 32px rgba(0,129,144,.3)}50%{box-shadow:0 0 0 18px rgba(0,129,144,0),0 8px 32px rgba(0,129,144,.3)}}
.orbit-btn-icon{display:inline-block;margin-right:9px;font-size:1.1rem;vertical-align:middle}
.orbit-btn-icon.spin-anim{animation:iconSpin .5s linear infinite}
@keyframes iconSpin{to{transform:rotate(360deg)}}
.orbit-hint{font-size:.82rem;color:var(--muted);text-align:center;max-width:340px;line-height:1.6;transition:color .3s;}
.orbit-hint.win{color:var(--gold)}

/* Orbit Win Modal */
.orbit-modal{
  position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px;
  background:rgba(4,4,16,.82);backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px);
  opacity:0;pointer-events:none;transition:opacity .35s;
}
.orbit-modal.open{opacity:1;pointer-events:all}
.orbit-modal-card{
  background:linear-gradient(150deg,rgba(255,255,255,.98) 0%,rgba(248,250,252,.99) 100%);
  border:1px solid rgba(0,129,144,0.1);border-radius:30px;padding:52px 44px;
  text-align:center;max-width:460px;width:100%;position:relative;
  box-shadow:0 30px 60px rgba(0,0,0,0.1),0 0 0 1px rgba(0,129,144,.05);
  transform:scale(.84) translateY(28px);transition:transform .5s var(--ease-spring);
}
.orbit-modal.open .orbit-modal-card{transform:scale(1) translateY(0)}
.orbit-modal-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;border-radius:30px 30px 0 0;
  background:linear-gradient(90deg,var(--purple),var(--cyan),var(--gold),var(--cyan));
  background-size:200% 100%;animation:shimmerBar 3s linear infinite;
}
@keyframes shimmerBar{0%{background-position:0% 0}100%{background-position:200% 0}}
.om-close{
  position:absolute;top:16px;right:16px;width:34px;height:34px;border-radius:50%;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);
  color:var(--muted);font-size:1rem;display:flex;align-items:center;justify-content:center;transition:.2s;cursor:pointer;
}
.om-close:hover{background:rgba(255,255,255,.14);color:var(--text);transform:rotate(90deg)}
.om-college-icon{font-size:4rem;margin-bottom:10px;display:block;animation:iconPop .55s var(--ease-spring);}
@keyframes iconPop{0%{transform:scale(0) rotate(-15deg)}70%{transform:scale(1.18) rotate(4deg)}100%{transform:scale(1) rotate(0)}}
.om-eyebrow{font-size:.78rem;font-weight:700;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px}
.om-college-name{font-family:var(--font-h);font-size:1.5rem;font-weight:900;margin-bottom:8px;line-height:1.2}
.om-loc{font-size:.82rem;color:var(--muted);margin-bottom:22px}
.om-prize-box{
  background:linear-gradient(135deg,rgba(250,204,21,.07),rgba(245,158,11,.05));
  border:1.5px dashed rgba(250,204,21,.4);border-radius:18px;padding:20px 28px;margin-bottom:20px;
  position:relative;overflow:hidden;
}
.om-prize-box::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(115deg,transparent 25%,rgba(255,255,255,.04) 50%,transparent 75%);
  background-size:200% 100%;animation:scanSweep 2.5s ease-in-out infinite;
}
.om-prize-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:8px}
.om-prize-val{font-family:var(--font-h);font-size:3.2rem;font-weight:900;line-height:1;background:linear-gradient(135deg,#fbbf24 0%,#f97316 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.om-code-row{background:rgba(6,182,212,.06);border:1px solid rgba(6,182,212,.22);border-radius:12px;padding:11px 18px;display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;gap:10px;}
.om-code-val{font-family:var(--font-h);font-weight:800;font-size:1.05rem;color:var(--cyan);letter-spacing:.08em;word-break:break-all;}
.om-copy-btn{flex-shrink:0;background:rgba(6,182,212,.12);border:1px solid rgba(6,182,212,.3);color:var(--cyan);font-size:.73rem;font-weight:700;padding:5px 13px;border-radius:100px;cursor:pointer;transition:.2s;white-space:nowrap;}
.om-copy-btn:hover{background:rgba(6,182,212,.28)}
.om-cta{
  width:100%;padding:16px;border-radius:16px;background:linear-gradient(135deg,var(--purple),var(--cyan));
  color:#fff;font-family:var(--font-h);font-size:1rem;font-weight:800;
  box-shadow:0 8px 32px rgba(124,58,237,.35);transition:transform .2s,box-shadow .2s;
  display:flex;align-items:center;justify-content:center;gap:9px;cursor:pointer;
}
.om-cta:hover{transform:translateY(-3px);box-shadow:0 16px 48px rgba(124,58,237,.5)}

/* Card gradient themes */
.o-bg-c1{--c1:#008190;--c2:#00a8b5;background:linear-gradient(135deg,rgba(0,129,144,.3),rgba(0,168,181,.18))}
.o-bg-c2{--c1:#f38e3e;--c2:#ff6b3d;background:linear-gradient(135deg,rgba(243,142,62,.26),rgba(255,107,61,.18))}
.o-bg-c3{--c1:#10b981;--c2:#008190;background:linear-gradient(135deg,rgba(16,185,129,.26),rgba(0,129,144,.18))}
.o-bg-c4{--c1:#f38e3e;--c2:#008190;background:linear-gradient(135deg,rgba(243,142,62,.26),rgba(0,129,144,.18))}
.o-bg-c5{--c1:#008190;--c2:#f38e3e;background:linear-gradient(135deg,rgba(0,129,144,.26),rgba(243,142,62,.18))}
.o-bg-c6{--c1:#00a8b5;--c2:#10b981;background:linear-gradient(135deg,rgba(0,168,181,.26),rgba(16,185,129,.18))}
.o-bg-c7{--c1:#008190;--c2:#f38e3e;background:linear-gradient(135deg,rgba(0,129,144,.26),rgba(243,142,62,.18))}
.o-bg-c8{--c1:#14b8a6;--c2:#008190;background:linear-gradient(135deg,rgba(20,184,166,.26),rgba(0,129,144,.18))}

@media(max-width:768px){
  .orbit-scene-wrap{height:480px;perspective:820px;perspective-origin:50% 44%}
  .orbit-ring,.o-card{width:200px;height:290px}
  .o-img{height:130px}
  .orbit-start-btn{padding:16px 46px;font-size:.95rem}
  .orbit-front-indicator{width:208px}
}
@media(max-width:480px){
  .orbit-scene-wrap{height:410px;perspective:680px}
  .orbit-ring,.o-card{width:174px;height:256px}
  .o-img{height:112px;font-size:2.8rem}
  .o-name{font-size:.88rem}
  .orbit-modal-card{padding:36px 24px}
  .om-prize-val{font-size:2.4rem}
  .orbit-front-indicator{width:182px}
}

/* ============================================================
   TESTIMONIALS
============================================================ */
.test-sec{padding:100px 0;position:relative}
.test-sec::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 50% 50%,rgba(124,58,237,.07) 0%,transparent 70%)}
.test-card{background:var(--grad-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px;margin:6px 0 28px;}
.test-stars{color:var(--gold);font-size:.95rem;margin-bottom:12px;letter-spacing:2px}
.test-text{color:var(--muted);font-size:.9rem;line-height:1.82;margin-bottom:18px;font-style:italic}
.test-author{display:flex;align-items:center;gap:12px}
.test-av{width:44px;height:44px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-family:var(--font-h);font-size:1rem;font-weight:800;color:#fff;flex-shrink:0;}
.test-name{font-family:var(--font-h);font-weight:700;font-size:.9rem;margin-bottom:2px}
.test-course{color:var(--muted);font-size:.78rem}

/* ============================================================
   FAQ
============================================================ */
.faq-sec{padding:100px 0}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.faq-list{display:flex;flex-direction:column;gap:10px}
.faq-item{background:var(--grad-card);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;transition:border-color .3s;}
.faq-item.open{border-color:rgba(124,58,237,.4)}
.faq-q{width:100%;padding:18px 22px;display:flex;align-items:center;justify-content:space-between;background:none;color:var(--text);font-family:var(--font-h);font-weight:600;font-size:.9rem;text-align:left;}
.faq-ico{width:22px;height:22px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.95rem;font-weight:300;transition:all .3s;color:var(--purple);}
.faq-item.open .faq-ico{transform:rotate(45deg);background:rgba(124,58,237,.15)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease-smooth)}
.faq-a-in{padding:0 22px 18px;color:var(--muted);font-size:.88rem;line-height:1.8}
.faq-item.open .faq-a{max-height:220px}
@media(max-width:1024px){.faq-grid{grid-template-columns:1fr;gap:40px}}

/* ============================================================
   STICKY BAR
============================================================ */
.sticky{position:fixed;bottom:0;left:0;right:0;z-index:700;transform:translateY(100%);transition:transform .4s var(--ease-smooth);}
.sticky.show{transform:translateY(0)}
.sticky-in{
  background:rgba(255,255,255,0.9);backdrop-filter:blur(20px);border-top:1px solid var(--border);
  padding:12px 24px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
  box-shadow: 0 -10px 40px rgba(0,0,0,0.05);
}
.sticky-txt strong{font-family:var(--font-h);font-size:.9rem}
.sticky-txt span{color:var(--muted);font-size:.78rem;display:block}
.sticky-btn{padding:11px 26px;white-space:nowrap}

/* ============================================================
   FOOTER
============================================================ */
.footer{padding:56px 0 28px;border-top:1px solid var(--border)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:44px;margin-bottom:44px}
.foot-logo{font-family:var(--font-h);font-size:1.6rem;font-weight:800;margin-bottom:10px;display:flex;align-items:center}
.foot-logo img{max-height:48px;width:auto;object-fit:contain}
.foot-desc{color:var(--muted);font-size:.85rem;line-height:1.75;max-width:270px;margin-bottom:18px}
.foot-socials{display:flex;gap:10px}
.soc-btn{width:34px;height:34px;border-radius:var(--r-sm);background:var(--glass);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.95rem;transition:all .2s;color:var(--muted);}
.soc-btn:hover{border-color:rgba(124,58,237,.5);color:var(--text);background:rgba(124,58,237,.1);transform:translateY(-2px)}
.foot-col h4{font-family:var(--font-h);font-size:.8rem;font-weight:700;margin-bottom:14px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.foot-col ul li a{color:var(--muted);font-size:.85rem;transition:color .2s}
.foot-col ul li a:hover{color:var(--text)}
.foot-btm{border-top:1px solid var(--border);padding-top:22px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;}
.foot-btm p,.foot-legal a{color:var(--muted);font-size:.78rem}
.foot-legal{display:flex;gap:18px}
.foot-legal a:hover{color:var(--text)}
@media(max-width:1024px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:640px){.footer-grid{grid-template-columns:1fr;gap:24px}}

/* College bg placeholders */
.c1{background:linear-gradient(135deg,#1e1b4b,#312e81)}
.c2{background:linear-gradient(135deg,#1e3a5f,#0e7490)}
.c3{background:linear-gradient(135deg,#1f2937,#374151)}
.c4{background:linear-gradient(135deg,#1a1a2e,#16213e)}
.c5{background:linear-gradient(135deg,#1c1917,#292524)}
.c6{background:linear-gradient(135deg,#0f2027,#203a43)}
