/* Gamvora — style.css — Part 1: Core */
:root {
  --bg:#0a0c10; --bg2:#0f1117; --bg3:#161922; --bg4:#1d2130;
  --surface:#181c27; --surface2:#1f2436;
  --border:#252a3a; --border2:#2e3448;
  --accent:#6c63ff; --accent2:#9d97ff;
  --accent-glow:rgba(108,99,255,.3); --accent-dim:rgba(108,99,255,.12);
  --green:#22c55e; --red:#ef4444; --yellow:#f59e0b; --orange:#f97316;
  --text:#eceef5; --text2:#8b92ad; --text3:#4a5068;
  --radius:10px; --radius-sm:7px; --radius-lg:16px;
  --shadow:0 4px 20px rgba(0,0,0,.5); --shadow-lg:0 12px 48px rgba(0,0,0,.7);
  --transition:.2s cubic-bezier(.4,0,.2,1);
  --font:'Inter',system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{cursor:pointer;font-family:var(--font)}
input,select,textarea,button{outline:none}
.container{max-width:1380px;margin:0 auto;padding:0 24px}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:99px}
::-webkit-scrollbar-thumb:hover{background:var(--accent)}

/* NAVBAR */
.topbar{position:sticky;top:0;z-index:200;background:rgba(10,12,16,.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);height:62px}
.nav-wrap{display:flex;align-items:center;gap:16px;height:62px}
.logo{font-size:1.45rem;font-weight:900;letter-spacing:-.5px;color:var(--text);white-space:nowrap;flex-shrink:0}
.logo span{color:var(--accent)}
.logo.center{display:block;text-align:center;margin-bottom:8px}
.nav-links{display:flex;gap:2px;flex-shrink:0}
.nav-links a{padding:6px 13px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;color:var(--text2);transition:color var(--transition),background var(--transition)}
.nav-links a:hover,.nav-links a.active{color:var(--text);background:var(--bg3)}
.search-wrap{flex:1;max-width:400px;position:relative}
.search-wrap input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:99px;padding:9px 18px 9px 40px;color:var(--text);font-size:.875rem;transition:border-color var(--transition),box-shadow var(--transition);background-repeat:no-repeat;background-position:14px center}
.search-wrap input::placeholder{color:var(--text3)}
.search-wrap input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.search-dropdown{position:absolute;top:calc(100% + 8px);left:0;right:0;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:300;overflow:hidden;animation:fadeIn .15s ease}
.dropdown-item{display:flex;align-items:center;gap:12px;padding:10px 14px;cursor:pointer;transition:background var(--transition);border-bottom:1px solid var(--border)}
.dropdown-item:last-child{border-bottom:none}
.dropdown-item:hover{background:var(--bg4)}
.dropdown-thumb{width:52px;height:34px;border-radius:5px;overflow:hidden;flex-shrink:0;background:var(--bg3)}
.dropdown-thumb img{width:100%;height:100%;object-fit:cover}
.dropdown-info{display:flex;flex-direction:column;gap:2px;min-width:0}
.dropdown-name{font-size:.85rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dropdown-name mark{background:transparent;color:var(--accent2);font-weight:700}
.dropdown-meta{font-size:.72rem;color:var(--text3)}
.auth-area{display:flex;align-items:center;gap:8px;flex-shrink:0}
.user-pill{font-size:.82rem;font-weight:600;color:var(--text2);background:var(--bg3);border:1px solid var(--border);border-radius:99px;padding:5px 13px;white-space:nowrap}
.admin-btn{background:linear-gradient(135deg,#f59e0b,#f97316)!important;color:#000!important;font-weight:700!important}
.admin-btn:hover{opacity:.9;transform:translateY(-1px)}
.support-nav-btn{background:transparent;border:1px solid var(--border);color:var(--text2);border-radius:var(--radius-sm);padding:6px 12px;font-size:.82rem;font-weight:600;cursor:pointer;transition:all var(--transition);white-space:nowrap;flex-shrink:0}
.support-nav-btn:hover{border-color:var(--accent);color:var(--accent2);background:var(--accent-dim)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 20px;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;border:none;transition:all var(--transition);white-space:nowrap;cursor:pointer;letter-spacing:.01em}
.btn.primary{background:var(--accent);color:#fff}
.btn.primary:hover{background:var(--accent2);transform:translateY(-1px);box-shadow:0 6px 20px var(--accent-glow)}
.btn.secondary{background:var(--bg3);color:var(--text);border:1px solid var(--border)}
.btn.secondary:hover{background:var(--bg4);border-color:var(--border2);transform:translateY(-1px)}
.btn.danger{background:rgba(239,68,68,.15);color:var(--red);border:1px solid rgba(239,68,68,.3)}
.btn.danger:hover{background:rgba(239,68,68,.25);transform:translateY(-1px)}
.btn.large{padding:13px 32px;font-size:.95rem;border-radius:var(--radius)}
.btn.sm{padding:5px 12px;font-size:.78rem}
.btn:active{transform:translateY(0) scale(.98)}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}

/* HERO */
.epic-hero{background:linear-gradient(135deg,#0a0c10 0%,#0f1117 40%,#130e22 100%);padding:68px 0 52px;border-bottom:1px solid var(--border);overflow:hidden;position:relative}
.epic-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 55% 90% at 72% 50%,rgba(108,99,255,.1) 0%,transparent 70%);pointer-events:none}
.hero-panel{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.hero-panel > div:first-child{animation:rise .6s ease both}
.hero-panel .kicker{font-size:.7rem;font-weight:700;letter-spacing:2.5px;color:var(--accent);text-transform:uppercase;margin-bottom:14px}
.hero-panel h1{font-size:clamp(1.9rem,3.5vw,3rem);font-weight:900;line-height:1.15;margin-bottom:16px}
.hero-panel h1 span{color:var(--accent)}
.hero-panel > div:first-child > p{color:var(--text2);font-size:1rem;margin-bottom:28px;max-width:460px;line-height:1.7}
.featured-hero-card{animation:rise .6s .12s ease both}
.hero-feature{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:16/9;background:var(--bg3)}
.hero-feature img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.hero-feature:hover img{transform:scale(1.04)}
.hero-feature-info{position:absolute;bottom:0;left:0;right:0;padding:28px 24px 22px;background:linear-gradient(to top,rgba(0,0,0,.92) 0%,rgba(0,0,0,.4) 60%,transparent 100%)}
.hero-feature-info .kicker{font-size:.65rem;font-weight:700;letter-spacing:2.5px;color:var(--accent2);text-transform:uppercase;margin-bottom:6px}
.hero-feature-info h3{font-size:1.25rem;font-weight:800;margin-bottom:6px;line-height:1.2}
.hero-feature-info p{font-size:.8rem;color:var(--text2);margin-bottom:14px}

/* FILTERS */
.filters-section{padding:16px 0 12px;background:var(--bg2);border-bottom:1px solid var(--border)}
.filter-bar{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.filter-bar select{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:8px 32px 8px 12px;font-size:.82rem;font-family:var(--font);cursor:pointer;transition:border-color var(--transition);appearance:none;-webkit-appearance:none;background-repeat:no-repeat;background-position:right 11px center}
.filter-bar select:focus{border-color:var(--accent)}
.filter-bar select option{background:var(--bg3)}
.active-filters{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.filter-chip{background:var(--accent-dim);border:1px solid rgba(108,99,255,.3);color:var(--accent2);border-radius:99px;padding:3px 11px;font-size:.75rem;font-weight:600}

/* SECTIONS */
.section{padding:44px 0}
.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:24px}
.section-head h2{font-size:1.35rem;font-weight:800;letter-spacing:-.01em}
.section-head p{font-size:.82rem;color:var(--text3)}

/* GAME GRID & CARDS */
.game-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:18px}
.compact-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr))}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);animation:rise .35s ease both;cursor:pointer;user-select:none}
.card:hover{transform:translateY(-5px);box-shadow:0 14px 36px rgba(0,0,0,.65),0 0 0 1px var(--accent);border-color:var(--accent)}
.card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.card-img-wrap{position:relative;aspect-ratio:16/9;background:var(--bg3);overflow:hidden}
.card-img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.card:hover .card-img{transform:scale(1.07)}
.card-overlay{position:absolute;inset:0;background:rgba(108,99,255,.55);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition)}
.card:hover .card-overlay{opacity:1}
.overlay-label{color:#fff;font-size:.82rem;font-weight:700;letter-spacing:.5px;background:rgba(0,0,0,.4);padding:6px 16px;border-radius:99px;border:1px solid rgba(255,255,255,.25);backdrop-filter:blur(4px)}
.img-skeleton{position:absolute;inset:0;background:linear-gradient(90deg,var(--bg3) 25%,var(--bg4) 50%,var(--bg3) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;z-index:1;transition:opacity .3s ease}
.card-body{padding:12px 14px 14px;display:flex;flex-direction:column;gap:7px;flex:1}
.badge-row{display:flex;gap:5px;flex-wrap:wrap}
.badge{font-size:.67rem;font-weight:700;padding:2px 8px;border-radius:99px;background:var(--bg4);color:var(--text2);border:1px solid var(--border);white-space:nowrap;letter-spacing:.02em}
.badge.genre-badge{background:var(--accent-dim);color:var(--accent2);border-color:rgba(108,99,255,.3)}
.badge.muted{color:var(--text3)}
.card-title{font-size:.88rem;font-weight:700;line-height:1.35;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.meta{font-size:.75rem;color:var(--text3);margin-top:auto}
.load-more-wrap{text-align:center;margin-top:36px}
.load-more-wrap .btn{padding:11px 40px;font-size:.9rem}
.empty-state{grid-column:1/-1;text-align:center;padding:60px 24px;color:var(--text3);font-size:1rem;background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius-lg)}

/* DETAIL PAGE */
.detail-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:80px 0;color:var(--text3)}
.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .75s linear infinite}
.detail-hero{display:grid;grid-template-columns:380px 1fr;gap:44px;align-items:start;margin-bottom:44px}
.detail-cover-wrap{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:2/3;background:var(--bg3);position:sticky;top:80px}
.detail-cover{width:100%;height:100%;object-fit:cover}
.detail-panel{padding-top:4px}
.detail-panel h1{font-size:clamp(1.5rem,2.8vw,2.2rem);font-weight:900;line-height:1.2;margin:12px 0 14px}
.detail-sub{color:var(--text2);font-size:.92rem;line-height:1.75;margin-bottom:22px}
.detail-meta-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:28px}
.detail-meta-grid > div{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:11px 14px;display:flex;flex-direction:column;gap:3px}
.detail-meta-grid strong{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text3)}
.detail-meta-grid span{font-size:.9rem;font-weight:600;color:var(--text)}
.versions-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:16px}
.versions-title{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text3);padding:14px 18px 10px;border-bottom:1px solid var(--border)}
.versions-list{display:flex;flex-direction:column}
.version-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 18px;border-bottom:1px solid var(--border);transition:background var(--transition)}
.version-row:last-child{border-bottom:none}
.version-row:hover{background:var(--bg3)}
.version-row.version-latest{background:var(--accent-dim)}
.version-row.version-latest:hover{background:rgba(108,99,255,.18)}
.version-info{display:flex;align-items:center;gap:10px;flex-wrap:wrap;min-width:0}
.version-name{font-size:.85rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:280px}
.version-size{font-size:.78rem;color:var(--text3);white-space:nowrap}
.version-badge{font-size:.65rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;background:var(--accent);color:#fff;padding:2px 8px;border-radius:99px}
.version-dl-btn{flex-shrink:0;padding:7px 16px;font-size:.8rem}
.version-dl-btn.is-locked{opacity:.55;cursor:not-allowed;filter:grayscale(.15)}
.dl-captcha-wrap{display:flex;flex-direction:column;gap:6px;min-width:260px;background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:10px 12px}
.dl-captcha-line{display:flex;align-items:center;gap:8px}
.dl-captcha-label{font-size:.72rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.8px}
.dl-captcha-code{font-size:1rem;font-weight:900;letter-spacing:3px;color:var(--accent2);background:rgba(108,99,255,.12);padding:3px 9px;border-radius:7px;border:1px dashed rgba(157,151,255,.45)}
.dl-captcha-input-row{display:flex;gap:7px}
.dl-captcha-input-row input{flex:1;background:var(--bg4);border:1px solid var(--border2);border-radius:7px;color:var(--text);padding:8px 10px;font-size:.82rem}
.dl-captcha-input-row input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}
.detail-actions-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.report-btn{color:var(--yellow)!important;border-color:rgba(245,158,11,.3)!important}
.report-btn:hover{background:rgba(245,158,11,.1)!important;border-color:var(--yellow)!important}
.screenshots-section{margin-bottom:36px}
.screenshots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:10px}
.shot{border-radius:var(--radius-sm);aspect-ratio:16/9;object-fit:cover;width:100%;transition:transform var(--transition),box-shadow var(--transition);cursor:pointer}
.shot:hover{transform:scale(1.03);box-shadow:var(--shadow)}
.detail-tabs{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:48px}
.tab-content{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px}
.tab-content h3{font-size:.9rem;font-weight:700;margin-bottom:14px;color:var(--accent2);text-transform:uppercase;letter-spacing:.5px}
.tab-content p{color:var(--text2);font-size:.88rem;line-height:1.75}
.spec-list{list-style:none;display:flex;flex-direction:column;gap:8px}
.spec-list li{font-size:.87rem;color:var(--text2);padding:8px 12px;background:var(--bg3);border-radius:var(--radius-sm);border-left:3px solid var(--accent)}
.spec-list li strong{color:var(--text);margin-right:6px}
.not-found{text-align:center;padding:80px 24px}
.not-found h1{font-size:2rem;margin-bottom:12px}
.not-found p{color:var(--text2);margin-bottom:24px}

/* COMMENTS */
.comments-section{margin-bottom:60px;padding-top:8px}
.comment-login-prompt{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 22px;margin-bottom:20px;font-size:.9rem;color:var(--text2)}
.comment-login-prompt a{color:var(--accent2);font-weight:600}
.comment-login-prompt a:hover{text-decoration:underline}
.comment-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;margin-bottom:24px}
.comment-form textarea{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font);font-size:.9rem;padding:12px 14px;resize:vertical;min-height:90px;transition:border-color var(--transition),box-shadow var(--transition)}
.comment-form textarea::placeholder{color:var(--text3)}
.comment-form textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.comment-form-footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px}
.comment-char-count{font-size:.78rem;color:var(--text3)}
.comment-msg{font-size:.82rem;margin-top:8px;min-height:18px}
.comment-msg.error{color:var(--red)}
.comment-msg.success{color:var(--green)}
.comments-list{display:flex;flex-direction:column;gap:14px}
.comment-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px}
.comment-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.comment-avatar{width:36px;height:36px;border-radius:50%;background:var(--accent-dim);border:1px solid rgba(108,99,255,.3);display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700;color:var(--accent2);flex-shrink:0}
.comment-meta{display:flex;flex-direction:column;gap:1px;flex:1}
.comment-username{font-size:.88rem;font-weight:700;color:var(--text)}
.comment-date{font-size:.75rem;color:var(--text3)}
.comment-text{font-size:.88rem;color:var(--text2);line-height:1.65;white-space:pre-wrap;word-break:break-word}
.comment-delete-btn{background:transparent;border:none;color:var(--text3);font-size:.9rem;padding:4px 6px;border-radius:var(--radius-sm);cursor:pointer;transition:color var(--transition),background var(--transition);margin-left:auto}
.comment-delete-btn:hover{color:var(--red);background:rgba(239,68,68,.1)}
.comment-loading,.comment-empty,.comment-notice{color:var(--text3);font-size:.88rem;padding:20px 0;text-align:center}

/* AUTH PAGES */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse 80% 80% at 50% 0%,rgba(108,99,255,.13) 0%,transparent 60%),var(--bg);padding:24px}
.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px 36px;width:100%;max-width:420px;box-shadow:var(--shadow-lg);animation:rise .45s ease both}
.auth-card h1{font-size:1.5rem;font-weight:800;margin-bottom:24px;text-align:center}
.auth-form{display:flex;flex-direction:column;gap:12px}
.auth-form input{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 15px;color:var(--text);font-size:.9rem;font-family:var(--font);transition:border-color var(--transition),box-shadow var(--transition);width:100%}
.auth-form input::placeholder{color:var(--text3)}
.auth-form input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.auth-form .btn{width:100%;padding:12px;font-size:.95rem;margin-top:4px}
.auth-switch{text-align:center;margin-top:16px;font-size:.85rem;color:var(--text2)}
.auth-switch a{color:var(--accent2);font-weight:600}
.auth-switch a:hover{text-decoration:underline}
.auth-message{text-align:center;margin-top:12px;font-size:.85rem;min-height:20px;border-radius:var(--radius-sm);padding:0;transition:all var(--transition)}
.auth-message.error{color:var(--red);background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25);padding:10px 14px}
.auth-message.success{color:var(--green);background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.25);padding:10px 14px}
.forgot-link{text-align:right;margin-top:-4px}
.forgot-link a{font-size:.8rem;color:var(--text3);cursor:pointer}
.forgot-link a:hover{color:var(--accent2)}
.captcha-wrap{display:flex;justify-content:center;margin:4px 0}

/* FOOTER */
.footer{background:var(--bg2);border-top:1px solid var(--border);padding:26px 0;text-align:center;color:var(--text3);font-size:.82rem}

/* GLOBAL LOADER */
.global-loader{
  position:fixed;inset:0;z-index:100000;
  display:flex;align-items:center;justify-content:center;
  background:radial-gradient(ellipse at center,rgba(8,12,22,.78) 0%,rgba(3,4,8,.94) 100%);
  backdrop-filter:blur(8px) saturate(110%);-webkit-backdrop-filter:blur(8px) saturate(110%);
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .28s ease,visibility .28s ease;
}
.global-loader.show{opacity:1;visibility:visible;pointer-events:auto}
.global-loader-box{
  min-width:330px;max-width:min(92vw,460px);text-align:center;
  background:
    radial-gradient(120% 100% at 0% 0%,rgba(108,99,255,.15) 0%,transparent 50%),
    linear-gradient(180deg,rgba(28,34,52,.98),rgba(16,20,31,.98));
  border:1px solid rgba(157,151,255,.35);border-radius:22px;
  padding:30px 26px;
  box-shadow:
    0 24px 80px rgba(0,0,0,.7),
    0 0 0 1px rgba(108,99,255,.22) inset,
    0 0 48px rgba(108,99,255,.18);
  animation:loaderPop .32s cubic-bezier(.2,.9,.2,1);
}
.global-loader-brand{
  font-size:1.28rem;font-weight:900;letter-spacing:-.4px;
  color:#f2f4ff;margin-bottom:16px;
}
.global-loader-brand span{color:var(--accent2)}
.global-loader-spinner{
  width:68px;height:68px;margin:0 auto 16px;
  border:5px solid rgba(108,99,255,.18);
  border-top-color:#8e85ff;
  border-right-color:#b7b2ff;
  border-left-color:rgba(108,99,255,.45);
  border-radius:50%;
  animation:spin .75s linear infinite;
  box-shadow:
    0 0 0 4px rgba(108,99,255,.07),
    0 0 30px rgba(108,99,255,.35);
}
.global-loader-box h3{
  font-size:1.18rem;font-weight:850;letter-spacing:.2px;
  color:#ffffff;margin-bottom:7px;line-height:1.25;
}
.global-loader-box p{
  font-size:.91rem;color:#b4bbd2;line-height:1.55;
  max-width:320px;margin:0 auto;
}
.global-loader-dots{
  margin-top:14px;display:flex;justify-content:center;gap:7px;
}
.global-loader-dots span{
  width:7px;height:7px;border-radius:50%;
  background:#9d97ff;opacity:.28;animation:loaderDots 1s infinite ease-in-out;
}
.global-loader-dots span:nth-child(2){animation-delay:.15s}
.global-loader-dots span:nth-child(3){animation-delay:.3s}

/* ANIMATIONS */
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
@keyframes loaderPop{from{opacity:0;transform:translateY(10px) scale(.965)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes loaderDots{0%,100%{opacity:.22;transform:translateY(0)}50%{opacity:1;transform:translateY(-2px)}}
