/* ===========================
   NeoGH — Design System
   Ghana NYP Gamified Platform
   =========================== */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;700;800&family=DM+Sans:wght@300;400;500&display=swap');
@import url('https://cdn.jsdelivr.net/npm/@tabler/icons-webfont@latest/tabler-icons.min.css');

:root{
  --gold:#C89B3C;--gold-light:#E8C06E;--gold-dark:#8B6A1C;
  --green:#006B3F;--green-light:#1A8A55;--green-dark:#004D2E;
  --red:#CF202F;--red-light:#E84050;
  --black:#0A0A0A;--white:#FAFAF7;
  --grey:#2A2A2A;--grey2:#3D3D3D;--grey3:#6B6B6B;
  --surface:#161616;--surface2:#1E1E1E;--surface3:#252525;
  --text:#F0EDE4;--text2:#B8B4A8;--text3:#7A7670;
  --radius:12px;--radius-lg:20px;
  --header-h:60px;--bottom-h:68px;
}

*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'DM Sans',sans-serif;background:var(--black);color:var(--text);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ===== SCREENS ===== */
.screen{display:none;min-height:100vh}
.screen.active{display:flex;flex-direction:column}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ===== HEADER ===== */
.hdr{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid rgba(255,255,255,.06);background:rgba(10,10,10,.9);position:sticky;top:0;z-index:100}
.logo{display:flex;align-items:center;gap:8px;text-decoration:none}
.logo-text{display:flex;flex-direction:column;line-height:1.15}
.logo-title{font-family:'Syne',sans-serif;font-size:15px;font-weight:800;color:var(--gold);letter-spacing:.5px}
.logo-tagline{font-size:9px;color:var(--text3);letter-spacing:.3px;font-style:italic;white-space:nowrap}
.logo-img,.admin-logo-img{height:24px;width:24px;border-radius:4px;object-fit:cover}
.xp-bar-mini{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text2)}
.xp-fill{height:6px;width:80px;background:var(--grey2);border-radius:3px;overflow:hidden}
.xp-fill-inner{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-light));border-radius:3px;transition:width .5s ease}
.level-badge{background:var(--gold);color:var(--black);font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px;font-family:'Syne',sans-serif}
.streak-indicator{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text3)}
.streak-fire{color:var(--red-light)}

/* ===== HOME HERO ===== */
.home-hero{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;text-align:center;position:relative;overflow:hidden}
.home-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 600px 400px at 50% 60%,rgba(200,155,60,.08) 0%,transparent 70%);pointer-events:none}
.hero-kente{display:flex;gap:3px;margin-bottom:32px;opacity:.6}
.kente-strip{width:8px;height:60px;border-radius:2px}
.k1,.k4,.k7{background:var(--red)}
.k2,.k5{background:var(--gold)}
.k3,.k6{background:var(--green)}
.hero-eyebrow{font-size:11px;letter-spacing:2px;color:var(--gold);text-transform:uppercase;margin-bottom:6px;font-weight:500}
.hero-tagline{font-size:13px;color:var(--text3);font-style:italic;margin-bottom:12px;letter-spacing:.3px}
.hero-title{font-family:'Syne',sans-serif;font-size:clamp(28px,6vw,52px);font-weight:800;line-height:1.1;margin-bottom:16px}
.hero-title span{color:var(--gold)}
.hero-sub{font-size:15px;color:var(--text2);max-width:400px;line-height:1.7;margin-bottom:36px}
.stats-row{display:flex;gap:20px;margin-top:20px;justify-content:center;flex-wrap:wrap}
.stat-chip{background:var(--surface2);border:1px solid rgba(255,255,255,.06);border-radius:8px;padding:10px 16px;text-align:center;font-size:11px}
.stat-chip .n{font-family:'Syne',sans-serif;font-size:20px;font-weight:700;color:var(--gold);display:block}
.stat-chip .l{color:var(--text3);margin-top:2px}
.pillars-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;padding:0 24px 32px;max-width:760px;margin:0 auto;width:100%}
.pillar-card{background:var(--surface2);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);padding:16px;cursor:pointer;transition:all .2s;text-align:left;position:relative;overflow:hidden}
.pillar-card::after{content:'';position:absolute;inset:0;background:var(--pillar-c);opacity:0;transition:opacity .2s}
.pillar-card:hover{border-color:var(--pillar-c);transform:translateY(-2px)}
.pillar-card:hover::after{opacity:.05}
.pillar-icon{font-size:22px;margin-bottom:10px;display:block}
.pillar-name{font-family:'Syne',sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text);margin-bottom:4px}
.pillar-q{font-size:11px;color:var(--text3);line-height:1.4}
.pillar-badge{position:absolute;top:10px;right:10px;background:rgba(200,155,60,.15);color:var(--gold);font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px}
.p1{--pillar-c:#CF202F}.p2{--pillar-c:#1A8A55}.p3{--pillar-c:#C89B3C}.p4{--pillar-c:#3B8BD4}.p5{--pillar-c:#9B59B6}

/* ===== BUTTONS ===== */
.btn-primary{background:var(--gold);color:var(--black);font-family:'Syne',sans-serif;font-size:14px;font-weight:700;padding:14px 32px;border-radius:var(--radius);border:none;cursor:pointer;letter-spacing:.3px;transition:all .2s;display:inline-flex;align-items:center;gap:8px;text-decoration:none}
.btn-primary:hover{background:var(--gold-light);transform:translateY(-1px)}
.btn-secondary{background:transparent;color:var(--text);font-family:'Syne',sans-serif;font-size:14px;font-weight:600;padding:14px 32px;border-radius:var(--radius);border:1px solid rgba(255,255,255,.15);cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px;text-decoration:none}
.btn-secondary:hover{border-color:var(--gold);color:var(--gold)}
.hero-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:16px}
.btn-secondary{background:transparent;color:var(--text2);font-size:13px;padding:10px 20px;border-radius:var(--radius);border:1px solid rgba(255,255,255,.1);cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:6px;font-family:'DM Sans',sans-serif;text-decoration:none}
.btn-secondary:hover{border-color:var(--gold);color:var(--gold)}
.btn-ghost{background:transparent;border:none;color:var(--text2);font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;font-family:'DM Sans',sans-serif;padding:6px 10px;transition:color .2s}
.btn-ghost:hover{color:var(--gold)}
.back-btn{display:flex;align-items:center;gap:6px;color:var(--text2);font-size:13px;cursor:pointer;margin-bottom:20px;background:none;border:none;padding:0;font-family:'DM Sans',sans-serif;transition:color .2s}
.back-btn:hover{color:var(--gold)}
.btn-sm{padding:10px 20px;font-size:12px}
.btn-lg{padding:16px 36px;font-size:16px}
.btn-xl{padding:18px 40px;font-size:18px;width:100%}

/* ===== MISSION CARDS ===== */
.mission-screen{flex:1;overflow-y:auto;padding:24px}
.section-title{font-family:'Syne',sans-serif;font-size:18px;font-weight:700;margin-bottom:6px}
.section-sub{font-size:13px;color:var(--text2);margin-bottom:24px}
.missions-grid{display:flex;flex-direction:column;gap:12px}
.mission-card{background:var(--surface2);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-lg);padding:20px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:16px;position:relative;overflow:hidden}
.mission-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--m-c)}
.mission-card:hover{border-color:var(--m-c);background:var(--surface3)}
.mission-card.locked{opacity:.5;cursor:not-allowed}
.mission-icon-wrap{width:48px;height:48px;border-radius:12px;background:rgba(255,255,255,.04);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;border:1px solid rgba(255,255,255,.06)}
.mission-info{flex:1}
.mission-title{font-family:'Syne',sans-serif;font-size:13px;font-weight:700;margin-bottom:4px}
.mission-desc{font-size:12px;color:var(--text3);line-height:1.5}
.mission-meta{display:flex;align-items:center;gap:10px;margin-top:8px;flex-wrap:wrap}
.mission-arrow{color:var(--text3);font-size:18px;flex-shrink:0}
.tag{font-size:10px;font-weight:500;padding:3px 8px;border-radius:4px;display:inline-flex;align-items:center;gap:4px}
.tag-xp{background:rgba(200,155,60,.15);color:var(--gold)}
.tag-time{background:rgba(255,255,255,.05);color:var(--text3)}
.tag-diff,.tag-play{font-size:10px;font-weight:500;padding:3px 8px;border-radius:4px}
.tag-play{background:var(--gold);color:var(--black)}
.easy{background:rgba(26,138,85,.15);color:#4CAF80}
.medium{background:rgba(200,155,60,.15);color:var(--gold)}
.hard{background:rgba(207,32,47,.15);color:var(--red-light)}
.m1{--m-c:#CF202F}.m2{--m-c:#1A8A55}.m3{--m-c:#C89B3C}.m4{--m-c:#3B8BD4}.m5{--m-c:#9B59B6}.m6{--m-c:#E67E22}.m7{--m-c:#CF202F}.m8{--m-c:#1A8A55}.m9{--m-c:#C89B3C}.m10{--m-c:#CF202F}.m11{--m-c:#C89B3C}.m12{--m-c:#CF202F}

/* ===== QUIZ ===== */
.quiz-wrap{flex:1;display:flex;flex-direction:column;padding:24px;max-width:700px;margin:0 auto;width:100%}
.quiz-progress-bar{height:4px;background:var(--grey2);border-radius:2px;margin-bottom:24px;overflow:hidden}
.quiz-progress-fill{height:100%;background:var(--gold);border-radius:2px;transition:width .4s ease}
.quiz-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:12px;color:var(--text3)}
.quiz-category{display:flex;align-items:center;gap:6px;margin-bottom:20px}
.category-dot{width:8px;height:8px;border-radius:50%;background:var(--cat-c)}
.category-label{font-size:12px;font-weight:500;color:var(--text2)}
.quiz-question{font-family:'Syne',sans-serif;font-size:18px;font-weight:700;line-height:1.4;margin-bottom:28px}
.quiz-fact{background:var(--surface2);border:1px solid rgba(200,155,60,.2);border-radius:var(--radius);padding:14px 16px;margin-bottom:20px;font-size:12px;color:var(--text2);line-height:1.6;display:flex;gap:10px}
.fact-icon{color:var(--gold);flex-shrink:0;font-size:16px;margin-top:1px}
.options-grid{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
.option-btn{background:var(--surface2);border:1px solid rgba(255,255,255,.07);border-radius:var(--radius);padding:14px 16px;cursor:pointer;text-align:left;font-size:14px;color:var(--text);transition:all .2s;display:flex;align-items:center;gap:12px;font-family:'DM Sans',sans-serif}
.option-btn:hover:not(:disabled){border-color:var(--gold);color:var(--gold);background:rgba(200,155,60,.05)}
.option-btn.correct{border-color:#4CAF80;background:rgba(76,175,128,.08);color:#4CAF80}
.option-btn.wrong{border-color:var(--red-light);background:rgba(207,32,47,.08);color:var(--red-light)}
.option-btn:disabled{cursor:default}
.option-letter{width:28px;height:28px;border-radius:8px;background:rgba(255,255,255,.05);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.feedback-box{background:var(--surface3);border-radius:var(--radius);padding:16px;margin-bottom:20px;display:none}
.feedback-box.show{display:block;animation:fadeIn .3s ease}
.feedback-correct{border:1px solid rgba(76,175,128,.3)}
.feedback-wrong{border:1px solid rgba(207,32,47,.3)}
.feedback-title{font-family:'Syne',sans-serif;font-size:13px;font-weight:700;margin-bottom:6px}
.feedback-correct .feedback-title{color:#4CAF80}
.feedback-wrong .feedback-title{color:var(--red-light)}
.feedback-text{font-size:12px;color:var(--text2);line-height:1.6}
.quiz-nav{display:flex;justify-content:flex-end;gap:10px}
.xp-gain{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--gold);font-weight:500}

/* ===== RESULTS ===== */
.results-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 24px;text-align:center}
.score-ring{width:130px;height:130px;border-radius:50%;background:var(--surface2);border:3px solid var(--gold);display:flex;flex-direction:column;align-items:center;justify-content:center;margin:0 auto 24px}
.score-pct{font-family:'Syne',sans-serif;font-size:36px;font-weight:800;color:var(--gold)}
.score-label{font-size:11px;color:var(--text3)}
.results-title{font-family:'Syne',sans-serif;font-size:22px;font-weight:800;margin-bottom:8px}
.results-sub{font-size:14px;color:var(--text2);margin-bottom:28px;line-height:1.6}
.reward-chips{display:flex;justify-content:center;gap:12px;margin-bottom:28px;flex-wrap:wrap}
.reward-chip{background:var(--surface2);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:10px 16px;text-align:center}
.reward-chip .rn{font-family:'Syne',sans-serif;font-size:18px;font-weight:700;color:var(--gold);display:block}
.reward-chip .rl{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.5px}
.badge-row{display:flex;justify-content:center;gap:10px;margin-bottom:28px}
.badge-item{width:64px;height:64px;border-radius:16px;background:var(--surface2);border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;font-size:28px;position:relative}
.badge-new{position:absolute;top:-4px;right:-4px;background:var(--gold);color:var(--black);font-size:8px;font-weight:700;padding:1px 4px;border-radius:3px}
.results-btns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}

/* ===== LEADERBOARD ===== */
.lb-wrap{flex:1;padding:24px;overflow-y:auto}
.lb-podium{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:24px}
.podium-card{background:var(--surface2);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-lg);padding:16px;text-align:center}
.podium-card.first{border-color:rgba(200,155,60,.3);background:rgba(200,155,60,.05)}
.podium-rank{font-family:'Syne',sans-serif;font-size:24px;margin-bottom:8px}
.podium-avatar{width:40px;height:40px;border-radius:50%;margin:0 auto 8px;display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-size:14px;font-weight:700}
.av1{background:rgba(200,155,60,.2);color:var(--gold)}
.av2,.av3{background:rgba(255,255,255,.08);color:var(--text)}
.podium-name{font-size:12px;font-weight:500;margin-bottom:4px;color:var(--text)}
.podium-pts{font-family:'Syne',sans-serif;font-size:16px;font-weight:700;color:var(--gold)}
.lb-list{background:var(--surface2);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-lg);overflow:hidden}
.lb-row{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.04);transition:background .2s;cursor:pointer}
.lb-row:last-child{border-bottom:none}
.lb-row:hover{background:var(--surface3)}
.lb-row.you{background:rgba(200,155,60,.05);border-color:rgba(200,155,60,.15)}
.lb-rank{font-family:'Syne',sans-serif;font-size:12px;font-weight:700;color:var(--text3);width:24px;text-align:center;flex-shrink:0}
.lb-av{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}
.lb-info{flex:1}
.lb-name{font-size:13px;font-weight:500}
.lb-tag{font-size:11px;color:var(--text3)}
.lb-pts{font-family:'Syne',sans-serif;font-size:14px;font-weight:700;color:var(--gold)}

/* ===== PROFILE ===== */
.profile-wrap{flex:1;padding:24px;overflow-y:auto}
.profile-hero{background:var(--surface2);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-lg);padding:24px;margin-bottom:16px;text-align:center}
.profile-avatar{width:72px;height:72px;border-radius:50%;background:rgba(200,155,60,.15);border:2px solid var(--gold);margin:0 auto 12px;display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-size:24px;font-weight:700;color:var(--gold)}
.profile-name{font-family:'Syne',sans-serif;font-size:18px;font-weight:700;margin-bottom:4px}
.profile-title{font-size:12px;color:var(--gold);margin-bottom:16px}
.profile-xp-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.profile-xp-bar{flex:1;height:8px;background:var(--grey2);border-radius:4px;overflow:hidden}
.profile-xp-fill{height:100%;background:linear-gradient(90deg,var(--gold-dark),var(--gold),var(--gold-light));border-radius:4px;transition:width .8s ease}
.xp-text{font-size:11px;color:var(--text3)}
.profile-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:16px}
.profile-stat{text-align:center}
.profile-stat .psn{font-family:'Syne',sans-serif;font-size:20px;font-weight:700;color:var(--text)}
.profile-stat .psl{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.5px}
.section-card{background:var(--surface2);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-lg);padding:16px;margin-bottom:12px}
.section-card-title{font-family:'Syne',sans-serif;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text3);margin-bottom:12px}
.badges-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.badge-cell{aspect-ratio:1;border-radius:10px;background:var(--surface3);border:1px solid rgba(255,255,255,.05);display:flex;align-items:center;justify-content:center;font-size:22px;position:relative}
.badge-cell.locked{opacity:.3;filter:grayscale(1)}
.badge-cell.earned{border-color:rgba(200,155,60,.25);background:rgba(200,155,60,.05)}
.pillars-progress{display:flex;flex-direction:column;gap:10px}
.pillar-row{display:grid;grid-template-columns:100px 1fr auto;gap:10px;align-items:center}
.pillar-row-name{font-size:12px;color:var(--text2)}
.pillar-prog-bar{height:6px;background:var(--grey2);border-radius:3px;overflow:hidden}
.pillar-prog-fill{height:100%;border-radius:3px;transition:width .6s ease}

/* ===== BOTTOM NAV ===== */
.bottom-nav{display:flex;background:var(--surface);border-top:1px solid rgba(255,255,255,.06);padding:8px 0 12px;position:fixed;bottom:0;left:0;right:0;z-index:200}
.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;padding:6px;border:none;background:none;color:var(--text3);transition:color .2s;text-decoration:none;font-family:'DM Sans',sans-serif}
.nav-item.active{color:var(--gold)}
.nav-item i{font-size:20px}
.nav-item span{font-size:9px;font-weight:500;letter-spacing:.3px;text-transform:uppercase}

/* ===== MODAL ===== */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:300;align-items:flex-end;justify-content:center}
.modal-overlay.open{display:flex}
.modal-sheet{background:var(--surface);border-radius:24px 24px 0 0;padding:24px;max-height:75vh;overflow-y:auto;width:100%;max-width:700px;animation:slideUp .3s ease}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-handle{width:40px;height:4px;background:var(--grey2);border-radius:2px;margin:0 auto 20px}
.modal-title{font-family:'Syne',sans-serif;font-size:18px;font-weight:700;margin-bottom:12px}
.modal-content{font-size:14px;color:var(--text2);line-height:1.8}
.modal-content p{margin-bottom:12px}
.modal-content strong{color:var(--gold)}
.close-modal{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--text2);cursor:pointer;font-size:20px}

/* ===== ANIMATIONS ===== */
.xp-popup{position:fixed;bottom:80px;right:20px;background:var(--gold);color:var(--black);font-family:'Syne',sans-serif;font-size:14px;font-weight:700;padding:8px 16px;border-radius:30px;animation:popUp .8s ease forwards;pointer-events:none;z-index:999}
@keyframes popUp{0%{opacity:0;transform:translateY(20px) scale(.8)}30%{opacity:1;transform:translateY(0) scale(1.1)}70%{opacity:1;transform:translateY(-10px) scale(1)}100%{opacity:0;transform:translateY(-30px) scale(.9)}}
.confetti-dot{position:fixed;width:6px;height:6px;border-radius:50%;pointer-events:none;z-index:1000;animation:confettiFall 1.5s ease forwards}
@keyframes confettiFall{to{transform:translateY(100vh) rotate(720deg);opacity:0}}
.toast-container{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);z-index:500;display:flex;flex-direction:column;align-items:center;gap:8px}
.toast{padding:10px 20px;border-radius:var(--radius);font-size:13px;font-weight:500;animation:fadeIn .3s ease;background:var(--surface2);border:1px solid rgba(255,255,255,.1);color:var(--text);display:flex;align-items:center;gap:8px;box-shadow:0 4px 20px rgba(0,0,0,.5)}
.toast-success{border-color:rgba(76,175,128,.3);color:#4CAF80}
.toast-error{border-color:rgba(207,32,47,.3);color:var(--red-light)}
.skeleton{background:linear-gradient(90deg,var(--surface2) 25%,var(--surface3) 50%,var(--surface2) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius)}
.skeleton-text{height:14px;width:80%;margin-bottom:10px}
.skeleton-title{height:22px;width:50%;margin-bottom:14px}
.skeleton-card{height:100px}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

/* ===== FORMS ===== */
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:12px;font-weight:500;color:var(--text2);margin-bottom:6px}
.form-input,.form-textarea{width:100%;padding:12px 14px;background:var(--surface2);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);color:var(--text);font-family:'DM Sans',sans-serif;font-size:14px;transition:border-color .2s}
.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--gold)}
.form-textarea{min-height:200px;resize:vertical}

/* ===== GLOBAL FOOTER ===== */
.global-footer{text-align:center;padding:20px 24px;font-size:11px;color:var(--text3);border-top:1px solid rgba(255,255,255,.06)}
.global-footer .footer-brand{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}
.global-footer .footer-brand img{height:20px;width:20px;border-radius:3px;object-fit:cover}
.global-footer .footer-brand span{font-size:12px;font-style:italic}
.global-footer a{color:var(--text3);text-decoration:none;transition:color .15s}
.global-footer a:hover{color:var(--gold)}
.global-footer .footer-links{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}
.global-footer .footer-social{display:flex;justify-content:center;gap:12px;margin:10px 0}
.global-footer .footer-social a{font-size:16px;color:var(--text3);transition:color .15s,transform .15s;display:inline-flex}
.global-footer .footer-social a:hover{color:var(--gold);transform:translateY(-1px)}
.global-footer .footer-disclaimer{margin-top:10px;font-size:10px;color:var(--text3);opacity:.7}

/* ===== UTILITIES ===== */
.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-5{gap:20px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.hidden{display:none}.w-full{width:100%}.text-center{text-align:center}.text-gold{color:var(--gold)}.text-muted{color:var(--text3)}
