:root {
  --bg: #070a12;
  --bg2: #0d1220;
  --bg3: #111827;
  --glass: rgba(255,255,255,0.03);
  --glass2: rgba(255,255,255,0.06);
  --glass3: rgba(255,255,255,0.09);
  --border: rgba(255,255,255,0.08);
  --border2: rgba(255,255,255,0.14);
  --border3: rgba(255,255,255,0.22);
  --text: #f0f2f8;
  --text2: #9aa3b8;
  --text3: #5a6380;
  --accent: #4f7eff;
  --accent2: #7c5cff;
  --accent3: #00d4aa;
  --gold: #f59e0b;
  --coral: #ff6b6b;
  --radius: 12px;
  --radius2: 18px;
  --radius3: 24px;
  --font: 'DM Sans', sans-serif;
  --font2: 'Syne', sans-serif;
  --glow: 0 0 40px rgba(79,126,255,0.15);
  --glow2: 0 0 60px rgba(79,126,255,0.08);
  --shadow: 0 8px 32px rgba(0,0,0,0.4);
  --shadow2: 0 20px 60px rgba(0,0,0,0.5);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:15px;line-height:1.6;overflow-x:hidden;min-height:100vh}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--border3);border-radius:2px}

/* ── UTILITY ── */
.hidden{display:none!important}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}
.flex{display:flex}
.flex-col{flex-direction:column}
.items-center{align-items:center}
.justify-between{justify-content:space-between}
.gap-4{gap:1rem}
.gap-2{gap:.5rem}
.gap-3{gap:.75rem}
.w-full{width:100%}
.text-sm{font-size:.8125rem}
.text-xs{font-size:.75rem}
.font-bold{font-weight:700}
.font-syne{font-family:var(--font2)}
.text-accent{color:var(--accent)}
.text-muted{color:var(--text2)}
.text-gold{color:var(--gold)}
.text-coral{color:var(--coral)}
.text-green{color:var(--accent3)}
.text-center{text-align:center}
.mt-1{margin-top:.25rem}
.mt-2{margin-top:.5rem}
.mt-3{margin-top:.75rem}
.mt-4{margin-top:1rem}
.mb-2{margin-bottom:.5rem}
.mb-4{margin-bottom:1rem}
.p-4{padding:1rem}
.p-3{padding:.75rem}
.relative{position:relative}
.overflow-hidden{overflow:hidden}
.rounded{border-radius:var(--radius)}
.rounded-lg{border-radius:var(--radius2)}
.grid{display:grid}
.grid-2{grid-template-columns:repeat(2,1fr);gap:1rem}
.grid-3{grid-template-columns:repeat(3,1fr);gap:1rem}
.grid-4{grid-template-columns:repeat(4,1fr);gap:1rem}

/* ── GLASS CARD ── */
.card{background:var(--glass);border:1px solid var(--border);border-radius:var(--radius2);padding:1.5rem;backdrop-filter:blur(20px);transition:all .3s ease}
.card:hover{border-color:var(--border2);background:var(--glass2);transform:translateY(-2px);box-shadow:var(--shadow)}
.card-sm{padding:1rem}
.card-flat{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;border-radius:50px;font-size:.7rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.badge-blue{background:rgba(79,126,255,.15);color:#6f9fff;border:1px solid rgba(79,126,255,.25)}
.badge-green{background:rgba(0,212,170,.12);color:#00d4aa;border:1px solid rgba(0,212,170,.2)}
.badge-gold{background:rgba(245,158,11,.12);color:#f59e0b;border:1px solid rgba(245,158,11,.2)}
.badge-coral{background:rgba(255,107,107,.12);color:#ff8080;border:1px solid rgba(255,107,107,.2)}
.badge-purple{background:rgba(124,92,255,.15);color:#a080ff;border:1px solid rgba(124,92,255,.25)}
.badge-gray{background:rgba(255,255,255,.06);color:var(--text2);border:1px solid var(--border)}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.65rem 1.4rem;border-radius:var(--radius);font-family:var(--font);font-size:.875rem;font-weight:600;cursor:pointer;border:none;transition:all .25s ease;letter-spacing:.01em;text-decoration:none}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;box-shadow:0 4px 20px rgba(79,126,255,.35)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 30px rgba(79,126,255,.5)}
.btn-ghost{background:var(--glass2);border:1px solid var(--border2);color:var(--text)}
.btn-ghost:hover{background:var(--glass3);border-color:var(--border3)}
.btn-sm{padding:.45rem 1rem;font-size:.8rem}
.btn-xs{padding:.3rem .75rem;font-size:.72rem}
.btn-danger{background:rgba(255,107,107,.15);border:1px solid rgba(255,107,107,.3);color:#ff8080}
.btn-success{background:rgba(0,212,170,.12);border:1px solid rgba(0,212,170,.25);color:#00d4aa}

/* ── INPUTS ── */
.input{width:100%;background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius);padding:.65rem 1rem;color:var(--text);font-family:var(--font);font-size:.875rem;outline:none;transition:border-color .2s}
.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(79,126,255,.1)}
.input::placeholder{color:var(--text3)}
select.input option{background:var(--bg2)}
.label{display:block;font-size:.78rem;font-weight:600;color:var(--text2);margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.06em}

/* ── PROGRESS ── */
.progress-bar{width:100%;height:6px;background:var(--border);border-radius:3px;overflow:hidden}
.progress-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width .5s ease}

/* ── STATUS DOTS ── */
.dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}
.dot-green{background:#00d4aa;box-shadow:0 0 6px rgba(0,212,170,.6)}
.dot-gold{background:#f59e0b;box-shadow:0 0 6px rgba(245,158,11,.6)}
.dot-coral{background:#ff6b6b;box-shadow:0 0 6px rgba(255,107,107,.6)}
.dot-blue{background:#4f7eff;box-shadow:0 0 6px rgba(79,126,255,.6)}
.dot-gray{background:var(--text3)}

/* ── DIVIDER ── */
.divider{width:100%;height:1px;background:var(--border);margin:1.5rem 0}

/* ── STAT CARD ── */
.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius2);padding:1.25rem 1.5rem}
.stat-num{font-family:var(--font2);font-size:2rem;font-weight:700;letter-spacing:-.02em;line-height:1}
.stat-label{font-size:.78rem;color:var(--text2);margin-top:.3rem;text-transform:uppercase;letter-spacing:.05em}
.stat-change{font-size:.75rem;margin-top:.5rem}

/* ── TABLE ── */
.table{width:100%;border-collapse:collapse}
.table th{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);padding:.65rem 1rem;border-bottom:1px solid var(--border);text-align:left}
.table td{padding:.75rem 1rem;border-bottom:1px solid var(--border);font-size:.85rem}
.table tr:last-child td{border-bottom:none}
.table tr:hover td{background:var(--glass)}

/* ── NAV ── */
#topnav{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(7,10,18,.85);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);height:62px;display:flex;align-items:center;padding:0 2rem;justify-content:space-between}
#topnav .logo{font-family:var(--font2);font-size:1.1rem;font-weight:700;background:linear-gradient(135deg,#fff 0%,var(--accent) 60%,var(--accent2) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:.01em}
#topnav .logo span{font-size:.6rem;display:block;color:var(--text3);-webkit-text-fill-color:var(--text3);font-weight:400;letter-spacing:.1em;text-transform:uppercase;font-family:var(--font)}
#nav-links{display:flex;align-items:center;gap:.25rem}
#nav-links a{padding:.4rem .75rem;color:var(--text2);font-size:.82rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s;text-decoration:none;border:none;background:none}
#nav-links a:hover,#nav-links a.active{color:var(--text);background:var(--glass2)}
#nav-right{display:flex;align-items:center;gap:.75rem}

/* ── SIDEBAR ── */
#sidebar{position:fixed;top:62px;left:0;bottom:0;width:220px;background:var(--bg2);border-right:1px solid var(--border);overflow-y:auto;z-index:900;transition:transform .3s ease}
#sidebar.hidden{display:none}
.sidebar-section{padding:.75rem 1rem .5rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--text3)}
.sidebar-link{display:flex;align-items:center;gap:.6rem;padding:.55rem 1rem;color:var(--text2);font-size:.82rem;cursor:pointer;border-radius:8px;margin:1px 6px;transition:all .2s;border:none;background:none;width:calc(100% - 12px);text-align:left}
.sidebar-link:hover{background:var(--glass2);color:var(--text)}
.sidebar-link.active{background:linear-gradient(135deg,rgba(79,126,255,.15),rgba(124,92,255,.1));color:#6f9fff;border:1px solid rgba(79,126,255,.15)}
.sidebar-icon{font-size:.9rem;width:18px;text-align:center;flex-shrink:0}

/* ── MAIN CONTENT ── */
#main-content{padding-top:62px;transition:margin-left .3s}
#main-content.with-sidebar{margin-left:220px}
.page{display:none;min-height:calc(100vh - 62px)}
.page.active{display:block}
.page-inner{padding:2rem}

/* ── HERO ── */
#hero-page{min-height:100vh;display:block;position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 60% 30%, rgba(79,126,255,.1) 0%,transparent 60%),radial-gradient(ellipse 50% 50% at 20% 60%,rgba(124,92,255,.08) 0%,transparent 50%),radial-gradient(ellipse 40% 40% at 80% 80%,rgba(0,212,170,.06) 0%,transparent 50%);pointer-events:none}
.hero-orb{position:absolute;border-radius:50%;filter:blur(60px);pointer-events:none;animation:orb-float 8s ease-in-out infinite}
@keyframes orb-float{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-20px) scale(1.05)}}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;min-height:calc(100vh - 62px);padding:6rem 2rem 4rem;max-width:1200px;margin:0 auto;position:relative;z-index:2}
.hero-eyebrow{display:flex;align-items:center;gap:.6rem;margin-bottom:1.5rem}
.hero-eyebrow-line{width:40px;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent2))}
.hero-h1{font-family:var(--font2);font-size:3.2rem;font-weight:800;line-height:1.1;letter-spacing:-.03em;margin-bottom:1rem}
.hero-h1 .gradient-text{background:linear-gradient(135deg,var(--accent),var(--accent2),var(--accent3));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hero-sub{font-size:1.05rem;color:var(--text2);line-height:1.7;margin-bottom:2rem;max-width:500px}
.hero-ctas{display:flex;gap:.75rem;flex-wrap:wrap}
.hero-trust{display:flex;gap:1.5rem;margin-top:2.5rem;flex-wrap:wrap}
.hero-trust-item{display:flex;align-items:center;gap:.4rem;font-size:.78rem;color:var(--text2)}
.hero-visual{position:relative;height:460px}
.hero-3d-card{position:absolute;border-radius:var(--radius2);backdrop-filter:blur(20px);border:1px solid var(--border2);padding:1.2rem 1.4rem;background:rgba(13,18,32,.8)}
.hero-3d-main{width:320px;left:50%;top:50%;transform:translate(-50%,-50%);z-index:3;box-shadow:0 20px 60px rgba(0,0,0,.5),0 0 60px rgba(79,126,255,.1);border-color:rgba(79,126,255,.3)}
.hero-3d-card1{width:200px;left:0;top:20%;z-index:2;animation:float1 6s ease-in-out infinite}
.hero-3d-card2{width:200px;right:0;top:40%;z-index:2;animation:float2 7s ease-in-out infinite}
.hero-3d-card3{width:180px;left:30%;bottom:5%;z-index:2;animation:float3 5.5s ease-in-out infinite}
@keyframes float1{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes float2{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes float3{0%,100%{transform:translateY(0)}50%{transform:translateY(-15px)}}
.mini-stat{font-family:var(--font2);font-size:1.5rem;font-weight:700}

/* ── SECTION ── */
.section{padding:4rem 2rem;max-width:1200px;margin:0 auto}
.section-title{font-family:var(--font2);font-size:2rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.5rem}
.section-sub{color:var(--text2);font-size:1rem;margin-bottom:2.5rem;max-width:600px}
.section-header{margin-bottom:2.5rem}

/* ── TRUST BAR ── */
.trust-bar{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:1.25rem 2rem;overflow:hidden}
.trust-items{display:flex;gap:2rem;align-items:center;justify-content:center;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text2);white-space:nowrap}
.trust-item .ti{font-size:1rem}

/* ── COURSE CARD ── */
.course-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius2);overflow:hidden;transition:all .3s;cursor:pointer}
.course-card:hover{border-color:var(--border2);transform:translateY(-3px);box-shadow:var(--shadow)}
.course-card-img{height:120px;background:linear-gradient(135deg,var(--bg3),var(--bg));display:flex;align-items:center;justify-content:center;font-size:2.5rem;position:relative;overflow:hidden}
.course-card-body{padding:1.2rem}
.course-card-tags{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.75rem}
.course-meta{display:flex;gap:1rem;margin-top:.75rem;font-size:.75rem;color:var(--text3)}

/* ── FAQ ── */
.faq-item{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:.5rem}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;cursor:pointer;font-weight:500;font-size:.9rem;transition:background .2s}
.faq-q:hover{background:var(--glass)}
.faq-q .faq-arrow{transition:transform .3s;color:var(--text3);font-size:.75rem}
.faq-item.open .faq-arrow{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-item.open .faq-a{max-height:200px}
.faq-a-inner{padding:.75rem 1.25rem 1.25rem;font-size:.875rem;color:var(--text2);line-height:1.7;border-top:1px solid var(--border)}

/* ── TOAST ── */
#toast-container{position:fixed;bottom:2rem;right:2rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem}
.toast{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius);padding:.85rem 1.25rem;font-size:.83rem;max-width:320px;box-shadow:var(--shadow2);display:flex;align-items:center;gap:.6rem;animation:toast-in .3s ease;border-left:3px solid var(--accent)}
.toast.success{border-left-color:var(--accent3)}
.toast.error{border-left-color:var(--coral)}
.toast.warning{border-left-color:var(--gold)}
@keyframes toast-in{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}

/* ── MODAL ── */
#modal-overlay{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.7);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:1rem}
#modal-box{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius2);max-width:540px;width:100%;max-height:90vh;overflow-y:auto;padding:2rem;position:relative;box-shadow:var(--shadow2)}
.modal-close{position:absolute;top:1rem;right:1rem;background:var(--glass);border:1px solid var(--border);border-radius:8px;width:32px;height:32px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text2);font-size:.85rem;transition:all .2s}
.modal-close:hover{background:var(--glass2);color:var(--text)}

/* ── WORKFLOW STEP ── */
.workflow-steps{display:flex;gap:0;position:relative}
.workflow-step{flex:1;text-align:center;position:relative}
.step-num{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-family:var(--font2);font-weight:700;font-size:.8rem;margin:0 auto .75rem;position:relative;z-index:2}
.step-label{font-size:.78rem;font-weight:600;color:var(--text2)}
.step-line{position:absolute;top:18px;left:50%;right:-50%;height:2px;background:linear-gradient(90deg,var(--border2),var(--border));z-index:1}
.workflow-step:last-child .step-line{display:none}

/* ── PORTAL HEADER ── */
.portal-header{background:linear-gradient(135deg,var(--bg2),var(--bg3));border-bottom:1px solid var(--border);padding:2rem;margin-bottom:0}
.portal-title{font-family:var(--font2);font-size:1.6rem;font-weight:700;margin-bottom:.25rem}
.portal-sub{color:var(--text2);font-size:.875rem}

/* ── EMPTY STATE ── */
.empty-state{text-align:center;padding:4rem 2rem;color:var(--text2)}
.empty-icon{font-size:3rem;margin-bottom:1rem;display:block}
.empty-title{font-size:1.1rem;font-weight:600;color:var(--text);margin-bottom:.5rem}
.empty-msg{font-size:.875rem;line-height:1.6;max-width:340px;margin:0 auto 1.5rem}

/* ── SEARCH BAR ── */
.search-bar{position:relative;display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;margin-bottom:1.5rem}
.search-input-wrap{position:relative;flex:1;min-width:200px}
.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--text3);font-size:.9rem}
.search-input-wrap .input{padding-left:2.2rem}

/* ── PERMISSION LOCK ── */
.permission-lock{background:rgba(255,107,107,.05);border:1px solid rgba(255,107,107,.2);border-radius:var(--radius2);padding:2rem;text-align:center}
.lock-icon{font-size:2.5rem;margin-bottom:.75rem}

/* ── ANIMATIONS ── */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes spin{to{transform:rotate(360deg)}}
.animate-pulse{animation:pulse 2s infinite}
.animate-spin{animation:spin 1s linear infinite}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .hero-grid{grid-template-columns:1fr;gap:2rem;padding:5rem 1rem 2rem}
  .hero-visual{display:none}
  .hero-h1{font-size:2rem}
  .grid-4,.grid-3{grid-template-columns:1fr 1fr}
  .grid-2{grid-template-columns:1fr}
  #main-content.with-sidebar{margin-left:0}
  #sidebar{transform:translateX(-100%)}
  #sidebar.mobile-open{transform:translateX(0)}
  #sidebar-toggle {display: block !important;}
  /* MOBILE NAV FIX */
#nav-links {
  position: absolute;
  top: 62px;
  right: 10px;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 1rem;
  flex-direction: column;
  width: 220px;
  display: none;
  z-index: 1000;
}

#nav-links.active {
  display: flex;
}
}
@media(prefers-reduced-motion:reduce){
  .hero-3d-card,.hero-orb{animation:none}
  *{transition:none!important}
}

/* ── GLOW LINES ── */
.glow-line{height:1px;background:linear-gradient(90deg,transparent,var(--accent),var(--accent2),transparent);opacity:.3}

/* ── LEARNING MODE COMPARE ── */
.compare-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius2);padding:2rem;position:relative;overflow:hidden}
.compare-card.featured{border-color:rgba(79,126,255,.4);background:linear-gradient(135deg,rgba(79,126,255,.05),rgba(124,92,255,.03))}
.compare-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent2))}
.compare-feature{display:flex;align-items:flex-start;gap:.6rem;padding:.5rem 0;border-bottom:1px solid var(--border);font-size:.83rem}
.compare-feature:last-child{border-bottom:none}
.compare-check{color:var(--accent3);flex-shrink:0;margin-top:.1rem}
.compare-cross{color:var(--text3);flex-shrink:0;margin-top:.1rem}

/* ── CERTIFICATION CARD ── */
.cert-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius2);overflow:hidden;transition:all .3s}
.cert-card:hover{border-color:rgba(245,158,11,.3);box-shadow:0 0 30px rgba(245,158,11,.06)}
.cert-header{background:linear-gradient(135deg,rgba(245,158,11,.1),rgba(79,126,255,.1));padding:1.5rem;position:relative}
.cert-badge-icon{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--gold),#f97316);display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:.75rem;box-shadow:0 4px 15px rgba(245,158,11,.3)}

/* ── PIPELINE ── */
.pipeline-col{flex:1;min-width:160px}
.pipeline-header{padding:.65rem 1rem;border-radius:var(--radius);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem;text-align:center}
.pipeline-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;margin-bottom:.5rem;font-size:.8rem;transition:all .2s;cursor:grab}
.pipeline-card:hover{border-color:var(--border2);background:var(--glass)}

/* ── SECURITY ── */
.risk-bar{height:8px;border-radius:4px;background:var(--border);overflow:hidden;margin-top:.5rem}
.risk-fill{height:100%;border-radius:4px}

/* ── NAV ROLE TAG ── */
.role-tag{background:linear-gradient(135deg,rgba(79,126,255,.15),rgba(124,92,255,.1));border:1px solid rgba(79,126,255,.2);border-radius:6px;padding:.2rem .6rem;font-size:.68rem;font-weight:700;color:#6f9fff;text-transform:uppercase;letter-spacing:.07em}

/* ── SIDEBAR USER ── */
.sidebar-user{padding:1rem;border-top:1px solid var(--border);margin-top:auto}
.sidebar-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;flex-shrink:0}

/* ── ANNOUNCEMENT ── */
.announcement{background:linear-gradient(135deg,rgba(79,126,255,.12),rgba(0,212,170,.08));border:1px solid rgba(79,126,255,.2);border-radius:var(--radius2);padding:1.25rem 1.5rem;display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}

/* ── SCROLL REVEAL ── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ── FOOTER ── */
footer{background:var(--bg2);border-top:1px solid var(--border);padding:3rem 2rem 1.5rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem;max-width:1200px;margin:0 auto;margin-bottom:2rem}
.footer-brand{font-family:var(--font2);font-size:1.1rem;font-weight:700;margin-bottom:.75rem;background:linear-gradient(135deg,#fff,var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.footer-desc{font-size:.8rem;color:var(--text2);line-height:1.7;max-width:280px}
.footer-col-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);margin-bottom:.75rem}
.footer-link{display:block;font-size:.8rem;color:var(--text2);margin-bottom:.4rem;cursor:pointer;transition:color .2s;text-decoration:none}
.footer-link:hover{color:var(--text)}
.footer-bottom{border-top:1px solid var(--border);padding-top:1.25rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:gap;gap:.5rem;max-width:1200px;margin:0 auto;font-size:.75rem;color:var(--text3)}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr}}
