/* =========================================================
   Elvarg Theme (Purple/White)
   ========================================================= */

/* ---------- Theme variables ---------- */
:root, [data-theme="dark"] {
  --bg:#0b0a10;
  --panel:#111019;
  --panel-2:#141224;
  --border:#27243a;
  --text:#f5f5fb;
  --muted:#b8b4c9;
  --brand:#9b5cff;
  --brand-2:#6f31ff;
  --brand-glow: 0 0 40px rgba(155,92,255,.55);
  --shadow: 0 10px 30px rgba(0,0,0,.35);
  --radius: 18px;
}

/* Light Mode */
[data-theme="light"] {
  --bg:#f8f7fc;
  --panel:#ffffff;
  --panel-2:#f0eef8;
  --border:#e0dce8;
  --text:#1a1625;
  --muted:#6b6580;
  --brand:#7c3aed;
  --brand-2:#5b21b6;
  --brand-glow: 0 0 40px rgba(124,58,237,.35);
  --shadow: 0 10px 30px rgba(0,0,0,.08);
}

[data-theme="light"] body {
  background:
    radial-gradient(800px 500px at 15% -10%, rgba(124,58,237,.08), transparent 60%),
    radial-gradient(800px 500px at 85% 110%, rgba(91,33,182,.08), transparent 60%),
    var(--bg);
}

/* ---------- Typography ---------- */
h1, h2, h3, h4, h5, .wordmark{
  font-family:'Cinzel', serif;
  letter-spacing:1px;
}

/* ---------- Base ---------- */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:
    radial-gradient(800px 500px at 15% -10%, rgba(155,92,255,.10), transparent 60%),
    radial-gradient(800px 500px at 85% 110%, rgba(111,49,255,.10), transparent 60%),
    var(--bg);
  color:var(--text);
  font-family:RS3, ui-sans-serif, system-ui, Segoe UI, Roboto, Arial, sans-serif;
}
.container{ width:min(1100px, 92%); margin-inline:auto }
.section{ padding:72px 0 }
.section--alt{ background:linear-gradient(180deg, rgba(255,255,255,.02), transparent) }

/* =========================================================
   Header / Nav
   ========================================================= */
.site-header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
  background:rgba(17,16,25,.6);
}
.nav-wrap{ display:flex; align-items:center; justify-content:space-between; padding:14px 0 }
.brand{ display:flex; align-items:center; gap:12px; text-decoration:none; color:var(--text) }
.logo{ width:34px; height:34px; filter: drop-shadow(var(--brand-glow)) }
.wordmark{ font-weight:800; letter-spacing:.5px; font-size:1.25rem }
.nav{ display:flex; align-items:center; gap:18px }
.nav__link{
  color:var(--text); opacity:.8; text-decoration:none; padding:8px 12px; border-radius:12px
}
.nav__link:hover{ opacity:1; background:rgba(255,255,255,.06) }
.nav__link.is-active{
  background:linear-gradient(180deg, rgba(155,92,255,.25), rgba(111,49,255,.15));
  box-shadow:var(--brand-glow)
}

/* =========================================================
   Buttons / Inputs
   ========================================================= */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:12px 18px; border-radius:14px; text-decoration:none;
  border:1px solid var(--border); background:var(--panel-2); color:var(--text);
  box-shadow:var(--shadow); cursor:pointer
}
.btn--primary{
  background:linear-gradient(180deg, var(--brand), var(--brand-2));
  border-color:transparent; box-shadow:var(--brand-glow)
}
.btn--primary:hover{ filter:brightness(1.05) }
.btn--ghost{ background:transparent }
.btn--discord{
  background:#5865F2;
  border-color:#4752C4;
  color:#fff
}
.btn--discord:hover{ background:#4752C4 }
.btn--danger{
  background:#dc2626;
  border-color:#b91c1c;
  color:#fff
}
.btn--danger:hover{ background:#b91c1c }
.w-100{ width:100% }

.input{
  width:100%; padding:12px 14px; border-radius:12px;
  background:var(--panel); border:1px solid var(--border); color:var(--text)
}
label{ display:grid; gap:8px; margin:10px 0 }

/* =========================================================
   Hero
   ========================================================= */
.hero{ padding:48px 0 24px; border-bottom:1px solid var(--border) }
.hero__inner{ display:grid; gap:30px; grid-template-columns:1.1fr .9fr; align-items:center }
.hero__copy .display{ font-size:clamp(32px, 5vw, 56px); line-height:1.05; margin:0 0 12px }
.accent{ color:var(--brand) }
.lead{ color:var(--muted); font-size:1.1rem; max-width:50ch }
.cta-row{ display:flex; gap:12px; margin:18px 0 22px }
.hero__stats{ display:flex; gap:16px }
.stat-card{
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  border:1px solid var(--border); border-radius:14px; padding:12px 14px; text-align:center; min-width:100px
}
.stat{ font-size:1.25rem; font-weight:800 }
.label{ color:var(--muted); font-size:.85rem }
.hero__art{ position:relative }
.hero__img{ width:100%; border-radius:var(--radius); border:1px solid var(--border); box-shadow:var(--shadow) }
.orb{
  position:fixed; inset:auto -40px 40% auto; width:180px; height:180px; border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(155,92,255,.7), rgba(111,49,255,.2) 60%, transparent 70%);
  filter:blur(14px); animation:float 6s ease-in-out infinite
}
@keyframes float{ 0%,100%{ transform:translateY(0)} 50%{ transform:translateY(-8px)} }

/* =========================================================
   Cards / Panels / Prose
   ========================================================= */
.card{
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  border:1px solid var(--border); border-radius:var(--radius);
  box-shadow:var(--shadow); padding:18px
}
.card__header{ display:flex; align-items:baseline; justify-content:space-between; gap:12px; margin-bottom:8px }
.card__body{ display:grid; gap:10px }
.panel{ background:var(--panel); border:1px solid var(--border); border-radius:var(--radius); padding:18px; box-shadow:var(--shadow) }

/* Blog / News body copy */
.prose{ line-height:1.7; font-size:1.05rem; color:var(--text) }
.prose p{ margin:0 0 1em }
.prose a{ color:var(--brand); text-decoration:underline }
.prose img{ max-width:100%; border-radius:10px; margin:12px 0; display:block }
.prose ul,.prose ol{ padding-left:1.4em; margin:0 0 1em }

/* =========================================================
   Grids
   ========================================================= */
.news-grid,
.features,
.dl-grid,
.store-grid{ display:grid; gap:18px; grid-template-columns:repeat(3, 1fr) }

.vote-grid{ display:grid; gap:16px; grid-template-columns:repeat(4, 1fr) }

/* =========================================================
   Products
   ========================================================= */
.product__img{
  width:100%;
  aspect-ratio:16 / 9;           /* consistent tiles */
  border-radius:10px;
  overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.03);
  border:1px solid var(--border);
}
.product__img img{
  width:100%; height:100%;
  object-fit:contain; object-position:center; display:block;
}
.price-row{ display:flex; align-items:center; justify-content:space-between }
.price{ font-weight:800 }

/* =========================================================
   Pills
   ========================================================= */
.pill-row{ display:flex; gap:10px; margin:14px 0 20px }
.pill{
  padding:8px 14px; border-radius:999px; border:1px solid var(--border);
  background:var(--panel); color:var(--text); cursor:pointer
}
.pill.is-active{
  background:linear-gradient(180deg, var(--brand), var(--brand-2));
  box-shadow:var(--brand-glow); border-color:transparent
}

/* =========================================================
   Vote
   ========================================================= */
.vote-card{
  display:flex; align-items:center; gap:10px; height:84px; padding:0 16px;
  border-radius:14px; border:1px solid var(--border); text-decoration:none; color:var(--text);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  box-shadow:var(--shadow); transition:.15s ease transform, .15s ease outline;
  justify-content:center
}
.vote-card:hover{ transform:translateY(-2px); outline:1px solid rgba(155,92,255,.35) }
.vote-ico{ font-size:20px; filter:drop-shadow(0 0 8px rgba(155,92,255,.6)) }

/* Vote form (consolidated) */
.claim-form{
  display:flex; gap:12px; align-items:flex-end; max-width:520px; margin-top:10px;
}
.claim-form label{ flex:1; margin:0 }
.claim-form label > span{ display:block; margin:0 0 6px; color:var(--muted); font-size:.9rem }
.claim-form input.input{ height:46px; padding:0 14px; font-size:1rem }
.claim-form .btn{
  height:46px; line-height:46px; padding:0 20px; border-radius:12px; font-weight:600; font-size:.95rem;
  background:linear-gradient(180deg, var(--brand), var(--brand-2)); border:none;
  box-shadow:0 0 20px rgba(155,92,255,.45); transition:all .25s ease;
}
.claim-form .btn:hover{
  filter:brightness(1.1); box-shadow:0 0 26px rgba(155,92,255,.65); transform:translateY(-1px);
}

/* =========================================================
   Footer
   ========================================================= */
.site-footer{
  border-top:1px solid var(--border); padding:30px 0; margin-top:40px;
  background:rgba(255,255,255,.02)
}
.footer-grid{ display:flex; align-items:flex-start; justify-content:space-between; gap:20px }
.footer-links{ display:flex; gap:16px }
.footer-links a{ color:var(--text); opacity:.8; text-decoration:none }
.footer-links a:hover{ opacity:1 }
.footer-wordmark{ font-weight:900; letter-spacing:1px }

/* =========================================================
   Admin (login card)
   ========================================================= */
.admin-body{ display:grid; place-items:center; min-height:100vh }
.admin-card{
  width:min(460px, 92%); background:var(--panel-2); border:1px solid var(--border);
  border-radius:var(--radius); padding:24px; box-shadow:var(--shadow)
}

/* =========================================================
   Utilities / Effects
   ========================================================= */
.reveal{ opacity:0; transform:translateY(14px); transition:opacity .6s ease, transform .6s ease }
.reveal.is-visible{ opacity:1; transform:none }

.h2{ font-size:clamp(24px, 3.6vw, 34px); margin:0 0 14px }
.h3{ font-size:clamp(20px, 3vw, 28px); margin:0 0 10px }
.h4{ font-size:clamp(18px, 2.4vw, 22px); margin:0 }
.h5{ font-size:1rem; margin:0 }
.small{ font-size:.9rem }
.muted{ color:var(--muted) }

.display{ text-shadow:0 2px 0 rgba(0,0,0,.35), 0 14px 36px rgba(155,92,255,.22) }

/* Ambient BG canvas holder */
#bgfx{ position:fixed; inset:0; z-index:-2; pointer-events:none }
#bgfx canvas{ width:100%; height:100%; display:block }

/* Runic divider */
.divider{
  height:1px; border:0; margin:40px 0; position:relative;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent)
}
.divider--runes::before{
  content:"ᚱ ᛋ ᛈ ᛋ"; position:absolute; left:50%; transform:translateX(-50%);
  top:-10px; font-family:RS3, Cinzel, serif; font-size:12px; letter-spacing:12px;
  color:rgba(255,255,255,.35); padding:0 14px; border-radius:9999px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), transparent)
}

/* Rune-stone stat chips */
.runechips{ display:flex; gap:14px; margin-top:14px; flex-wrap:wrap }
.runechip{
  display:flex; align-items:center; gap:8px; padding:10px 12px; border-radius:16px;
  background:radial-gradient(60% 120% at 20% 0, rgba(155,92,255,.18), rgba(255,255,255,.02));
  border:1px solid #2c2740; box-shadow:0 8px 24px rgba(0,0,0,.35), 0 0 18px rgba(155,92,255,.18)
}
.runechip__icon{ filter:drop-shadow(0 0 8px rgba(155,92,255,.6)) }
.runechip .stat{ font-weight:800 }
.runechip .label{ color:var(--muted); font-size:.85rem }

/* News card */
.newscard{ position:relative; overflow:hidden; transition-delay:var(--delay,0ms) }
.newscard__thumb{ width:100%; height:140px; object-fit:cover; border-radius:12px; margin-bottom:10px; display:block }
.newscard__link{ display:block; color:inherit; text-decoration:none }
.newscard:hover{ transform:translateY(-2px) }
.newscard .h4{ transition:opacity .15s ease }
.newscard:hover .h4{ opacity:.95 }
.post-footer{ display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap }
.post-footer .nav-right{ margin-left:auto; display:flex; gap:8px }

/* =========================================================
   Download Tiles
   ========================================================= */
.dl-card{
  display:grid; grid-template-columns:58px 1fr auto; align-items:center; gap:14px; padding:16px 18px;
  border-radius:16px; text-decoration:none; color:var(--text);
  background:radial-gradient(120% 180% at 20% 0, rgba(155,92,255,.12), rgba(255,255,255,.02));
  border:1px solid var(--border);
  box-shadow:0 10px 26px rgba(0,0,0,.35), 0 0 18px rgba(155,92,255,.14) inset;
  transition:transform .18s ease, box-shadow .18s ease, outline .18s ease;
  position:relative; overflow:hidden;
}
.dl-card:hover{
  transform:translateY(-2px);
  outline:1px solid rgba(155,92,255,.35);
  box-shadow:0 14px 30px rgba(0,0,0,.45), 0 0 22px rgba(155,92,255,.22) inset;
}
.dl-card:active{ transform:translateY(0) }
.dl-icon{
  width:48px; height:48px; border-radius:12px; display:grid; place-items:center;
  background:linear-gradient(180deg, rgba(155,92,255,.25), rgba(111,49,255,.12));
  border:1px solid #3d345a; color:#d8c9ff; filter:drop-shadow(0 0 14px rgba(155,92,255,.35))
}
.dl-icon svg{ width:28px; height:28px; display:block }
.dl-meta .dl-title{ font-weight:800; letter-spacing:.4px }
.dl-meta .dl-sub{ color:var(--muted); font-size:.9rem }
.dl-badges{ display:flex; gap:8px; align-items:center }
.pill.small{ font-size:.75rem; padding:6px 10px }
.java-hint{ display:flex; align-items:center; gap:8px; margin-top:12px; color:var(--muted); font-size:.95rem }
.java-dot{
  width:10px; height:10px; border-radius:50%;
  background:radial-gradient(circle, #ff9b9b, #ff4a4a);
  box-shadow:0 0 12px rgba(255,74,74,.6)
}

/* =========================================================
   Cart Drawer (Store)
   ========================================================= */
.cart{
  position:fixed; inset:0;
  display:grid; grid-template-columns:1fr auto;
  background:rgba(0,0,0,.45); backdrop-filter:blur(6px);
  z-index:70; transition:opacity .18s ease;
}
.cart.hidden{ display:none }
.cart__panel{
  width:min(520px,92%); background:var(--panel-2); border-left:1px solid var(--border);
  box-shadow:-12px 0 36px rgba(0,0,0,.45); transform:translateX(100%);
  transition:transform .18s ease; display:flex; flex-direction:column;
}
.cart.is-open .cart__panel{ transform:translateX(0) }
.cart__head{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 16px; border-bottom:1px solid var(--border)
}
.cart__close{ background:transparent; border:0; color:var(--text); font-size:18px; cursor:pointer }
.cart__items{ padding:10px 14px; display:grid; gap:10px; overflow:auto; max-height:58vh }
.cart__row{
  display:grid; grid-template-columns:1fr auto auto auto; gap:10px; align-items:center; padding:8px 10px;
  border:1px solid var(--border); border-radius:12px; background:var(--panel)
}
.cart__name{ font-weight:700 }
.cart__qty{ display:flex; align-items:center; gap:8px }
.qbtn{ width:28px; height:28px; border-radius:8px; border:1px solid var(--border); background:var(--panel-2); color:var(--text) }
.rmv{ background:transparent; border:0; color:var(--muted); cursor:pointer }
.cart__price{ font-weight:800 }
.cart__foot{ margin-top:auto; border-top:1px solid var(--border); padding:14px 16px; display:grid; gap:10px }
.cart__total{ display:flex; align-items:center; justify-content:space-between }

/* Cart count badge */
.cart-link{ position:relative }
.cart-count{
  position:absolute; top:-6px; right:-12px; min-width:18px; height:18px; padding:0 5px;
  display:inline-grid; place-items:center; border-radius:999px; font-size:.7rem; font-weight:800;
  color:#fff; background:linear-gradient(180deg, #b28aff, #6f31ff);
  border:1px solid rgba(255,255,255,.25); box-shadow:0 0 10px rgba(155,92,255,.6)
}

/* =========================================================
   Highscores (Shell + Table + Badges)
   ========================================================= */
.hs-controls{
  display:flex; gap:12px; align-items:center; margin:16px 0 12px; flex-wrap:wrap;
}
.hs-controls label{
  display:flex; gap:8px; align-items:center; color:var(--muted); font-size:.95rem;
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  border:1px solid var(--border); padding:8px 10px; border-radius:12px;
}
.hs-controls select{
  appearance:none; background:var(--panel); color:var(--text);
  border:1px solid var(--border); padding:8px 10px; border-radius:10px; box-shadow:var(--shadow);
}

.table-wrap{
  overflow:auto; border:1px solid var(--border); border-radius:var(--radius);
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  box-shadow:var(--shadow);
}
.hs-table{ width:100%; border-collapse:collapse }
.hs-table thead th{
  position:sticky; top:0;
  background:linear-gradient(180deg, rgba(155,92,255,.12), rgba(255,255,255,.02));
  border-bottom:1px solid var(--border); text-align:left; padding:12px 14px; font-weight:800;
  color:var(--text); font-family:'Cinzel', serif; letter-spacing:.5px; box-shadow:inset 0 -1px 0 var(--border)
}
.hs-table tbody td{ padding:12px 14px; border-bottom:1px solid var(--border) }
.hs-table tbody tr:hover{
  background:radial-gradient(50% 120% at 0 0, rgba(155,92,255,.08), transparent 60%),
             linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0))
}

/* Rank + Skill chips */
.rank-badge{
  display:inline-flex; gap:6px; align-items:center; padding:5px 10px; border-radius:999px;
  font-size:.78rem; font-weight:700; letter-spacing:.2px; color:var(--text); text-transform:capitalize;
  border:1px solid color-mix(in srgb, var(--rank, var(--brand)) 75%, #ffffff 0%);
  background:linear-gradient(180deg, color-mix(in srgb, var(--rank, var(--brand)) 18%, transparent 0%) 0%, rgba(255,255,255,.02) 100%);
  box-shadow:0 0 16px color-mix(in srgb, var(--rank, var(--brand)) 35%, transparent), var(--brand-glow);
}
.rank-badge .rank-ico{ width:16px; height:16px; object-fit:contain; display:block; filter:drop-shadow(0 0 8px rgba(155,92,255,.25)) }

.mode-chip{
  display:inline-grid; place-items:center; min-width:22px; height:22px; padding:0 8px;
  border-radius:999px; font-size:.72rem; font-weight:800;
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border:1px solid var(--border); color:var(--muted);
}

.hs-shell{ display:grid; grid-template-columns:260px 1fr; gap:18px; margin-top:14px }
.hs-sidebar{
  padding:12px; border-radius:var(--radius);
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  border:1px solid var(--border)
}
.hs-skill-list{ list-style:none; padding:0; margin:0; display:grid; gap:6px }
.hs-skill{
  display:flex; align-items:center; gap:10px; padding:10px 12px; border-radius:12px; color:var(--text);
  cursor:pointer; border:1px solid transparent;
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
  transition:.15s ease transform, .15s ease background, .15s ease border;
}
.hs-skill:hover{
  transform:translateY(-1px);
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border-color:var(--border)
}
.hs-skill.is-active{
  background:linear-gradient(180deg, rgba(155,92,255,.20), rgba(111,49,255,.10));
  border-color:#3d345a; box-shadow:var(--brand-glow)
}

.sk-ico{
  width:22px; height:22px; border-radius:6px; display:inline-grid; place-items:center; overflow:hidden;
  background:radial-gradient(80% 120% at 30% 20%, rgba(155,92,255,.6), rgba(111,49,255,.2));
  border:1px solid #3d345a; box-shadow:0 0 8px rgba(155,92,255,.35)
}
.sk-ico img{ width:100%; height:100%; object-fit:contain; display:block; background:transparent; border:0; box-shadow:none }

/* Pager */
.pager{ display:flex; gap:12px; align-items:center; justify-content:center; margin:14px 0 }
.pager .btn{
  padding:10px 14px; border-radius:12px; border:1px solid var(--border);
  background:var(--panel-2); color:var(--text); box-shadow:var(--shadow)
}
.pager .btn:disabled{ opacity:.55; cursor:not-allowed }
#hsInfo{ color:var(--muted) }

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width: 960px){
  .hero__inner{ grid-template-columns:1fr }
  .news-grid, .features, .store-grid{ grid-template-columns:1fr 1fr }
  .vote-grid, .dl-grid{ grid-template-columns:1fr 1fr }
  .cart__items{ max-height:50vh }
}
@media (max-width: 640px){
  .news-grid, .features, .store-grid, .vote-grid, .dl-grid{ grid-template-columns:1fr }
  .cta-row{ flex-wrap:wrap }
}
@media (max-width: 520px){
  .claim-form{ flex-direction:column; align-items:stretch }
  .claim-form .btn{ width:100%; height:44px; line-height:44px }
}
@media (max-width: 980px){
  .hs-shell{ grid-template-columns:1fr }
}
@media (max-width: 820px){
  .hs-table thead th:nth-child(4),
  .hs-table tbody td:nth-child(4){ display:none } /* hide Mode on narrow screens */
}
