﻿@import url("https://fonts.googleapis.com/css2?family=Rajdhani:wght@500;600;700&family=Saira+Condensed:wght@500;600;700;800&display=swap");

:root {
  --bg: #070604;
  --bg-2: #130f07;
  --panel: rgba(22, 17, 8, 0.86);
  --panel-strong: #251a08;
  --line: rgba(250, 204, 21, 0.2);
  --line-strong: rgba(250, 204, 21, 0.46);
  --text: #fff8df;
  --muted: #c7b98d;
  --green: #f59e0b;
  --lime: #facc15;
  --gold: #fde68a;
  --orange: #f97316;
  --cyan: #fbbf24;
  --red: #ff5d78;
  --ink: #211400;
  --shadow: 0 26px 90px rgba(0, 0, 0, 0.5);
  --glow: 0 0 34px rgba(250, 204, 21, 0.16), 0 0 58px rgba(245, 158, 11, 0.12);
  --radius: 8px;
  --nav-height: 74px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-height: 100vh;
  color: var(--text);
  font-family: "Rajdhani", sans-serif;
  font-size: 17px;
  font-weight: 600;
  background:
    linear-gradient(115deg, rgba(250, 204, 21, 0.08) 0 1px, transparent 1px 26px) 0 0 / 28px 28px,
    linear-gradient(158deg, rgba(245, 158, 11, 0.14), transparent 28rem),
    linear-gradient(24deg, rgba(253, 230, 138, 0.1), transparent 30rem),
    linear-gradient(180deg, var(--bg), var(--bg-2) 48%, #050b08),
    var(--bg);
  overflow-x: hidden;
  text-rendering: optimizeLegibility;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(180deg, transparent 0 48%, rgba(212,255,79,.035) 50%, transparent 52% 100%);
  background-size: 38px 38px, 38px 38px, 100% 7px;
  mask-image: linear-gradient(to bottom, black, transparent 80%);
  z-index: 0;
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background:
    radial-gradient(circle at 18% 18%, rgba(250, 204, 21, .12), transparent 26rem),
    radial-gradient(circle at 88% 28%, rgba(245, 158, 11, .11), transparent 24rem),
    linear-gradient(90deg, rgba(255, 184, 28, .08), transparent 16%, transparent 84%, rgba(253, 230, 138, .08));
  opacity: .65;
}

button, input, select, textarea { font: inherit; }
a { color: inherit; }
img { max-width: 100%; display: block; }
img[src$="-transparent.png"] {
  object-fit: contain;
}
main, .navbar, .footer, .toast, .modal, .mobile-menu { position: relative; z-index: 1; }
::selection { color: var(--ink); background: var(--lime); }

.network-bg { position: fixed; inset: 0; pointer-events: none; z-index: 0; overflow: hidden; }
.particle {
  --size: 4px;
  position: absolute;
  width: var(--size);
  height: var(--size);
  background: var(--lime);
  box-shadow: 0 0 18px var(--green);
  animation: particleDrift 8s ease-in-out infinite;
  opacity: .45;
}
@keyframes particleDrift {
  50% { transform: translate3d(28px, -76px, 0) rotate(45deg); opacity: .9; }
}
@keyframes toxicSweep {
  0% { transform: translateX(-120%) skewX(-18deg); opacity: 0; }
  18% { opacity: .72; }
  46%, 100% { transform: translateX(160%) skewX(-18deg); opacity: 0; }
}
@keyframes panelWake {
  from { opacity: 0; transform: translateY(18px) scale(.985); filter: saturate(.7); }
  to { opacity: 1; transform: translateY(0) scale(1); filter: saturate(1); }
}
@keyframes livePulse {
  50% { box-shadow: 0 0 0 9px rgba(250,204,21,.1), 0 0 26px var(--lime); }
}
@keyframes goldAurora {
  0%, 100% { background-position: 0% 50%; filter: saturate(1); }
  50% { background-position: 100% 50%; filter: saturate(1.25); }
}
@keyframes floatPanel {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-7px); }
}
@keyframes goldBreath {
  0%, 100% { box-shadow: var(--shadow), 0 0 26px rgba(250,204,21,.1); }
  50% { box-shadow: var(--shadow), 0 0 44px rgba(250,204,21,.24); }
}
@keyframes borderSpin {
  to { transform: rotate(360deg); }
}

.navbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  border-bottom: 1px solid var(--line);
  background: rgba(5, 13, 9, 0.82);
  backdrop-filter: blur(18px);
  z-index: 8;
  transition: background .25s, box-shadow .25s;
}
.navbar.scrolled { background: rgba(5, 13, 9, 0.95); box-shadow: 0 12px 40px rgba(0,0,0,.35); }
.nav-inner { max-width: 1240px; margin: 0 auto; height: 74px; padding: 0 22px; display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.brand { display: inline-flex; align-items: center; gap: 10px; color: white; text-decoration: none; font-family: "Saira Condensed", sans-serif; font-size: 1.8rem; font-weight: 800; text-transform: uppercase; }
.brand img { width: 42px; height: 42px; border-radius: 7px; object-fit: contain; border: 1px solid var(--line); }
.nav-links, .nav-actions { display: flex; align-items: center; gap: 8px; }
.nav-links a { position: relative; text-decoration: none; color: var(--muted); padding: 10px 14px; border: 1px solid transparent; border-radius: var(--radius); font-weight: 800; font-size: .86rem; text-transform: uppercase; overflow: hidden; }
.nav-links a::after { content: ""; position: absolute; left: 12px; right: 12px; bottom: 7px; height: 2px; background: var(--lime); transform: scaleX(0); transform-origin: left; transition: transform .22s ease; }
.nav-links a:hover, .nav-links a.active { color: var(--text); background: rgba(35,209,139,.09); border-color: var(--line); }
.nav-links a:hover::after, .nav-links a.active::after { transform: scaleX(1); }
.mobile-toggle { display: none; border: 1px solid var(--line); color: var(--text); background: var(--panel); border-radius: var(--radius); width: 42px; height: 42px; cursor: pointer; font-size: 1.4rem; }
.mobile-menu { display: none; position: fixed; top: var(--nav-height); left: 14px; right: 14px; z-index: 7; padding: 14px; background: rgba(8, 20, 14, .98); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow); }
.mobile-menu.open { display: grid; gap: 8px; }
.mobile-menu a, .mobile-menu button { color: var(--text); text-decoration: none; text-align: left; background: rgba(255,255,255,.04); border: 1px solid var(--line); border-radius: var(--radius); padding: 13px; }

.btn, .ip-pill, .copy-large, .filter-btn, .method-tab {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  color: var(--text);
  background: rgba(255,255,255,.05);
  padding: 11px 17px;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: 900;
  transition: transform .2s, border-color .2s, background .2s, box-shadow .2s;
}
.btn:hover, .ip-pill:hover, .copy-large:hover, .filter-btn:hover, .method-tab:hover { transform: translateY(-2px); border-color: var(--line-strong); box-shadow: 0 10px 30px rgba(35,209,139,.14); }
.btn-primary { color: var(--ink); background: linear-gradient(135deg, var(--lime), var(--green)); border-color: transparent; box-shadow: inset 0 -2px 0 rgba(0,0,0,.18), 0 12px 34px rgba(212,255,79,.12); }
.btn-ghost { background: rgba(7,17,13,.62); }
.btn-sm { padding: 9px 13px; font-size: .82rem; }
.ip-pill { font-size: .82rem; }
.status-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 6px rgba(35,209,139,.12), 0 0 18px var(--green); flex: 0 0 auto; animation: livePulse 2.8s ease-in-out infinite; }

.hero-shell { min-height: 100vh; padding: 112px 22px 44px; max-width: 1280px; margin: 0 auto; display: grid; grid-template-columns: minmax(0, 1fr) 330px; gap: 18px; align-items: stretch; }
.hero-carousel { min-height: 640px; position: relative; overflow: hidden; border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow), var(--glow); background: #101c15; animation: panelWake .72s ease both; }
.hero-carousel::after, .mode-card::after, .product-card::after, .admin-card::after, .cart-panel::after, .login-card::after, .sidebar-card::after {
  content: "";
  position: absolute;
  inset: 0 auto 0 -34%;
  width: 28%;
  pointer-events: none;
  background: linear-gradient(90deg, transparent, rgba(212,255,79,.13), transparent);
  animation: toxicSweep 7.5s ease-in-out infinite;
}
.hero-slide { position: absolute; inset: 0; opacity: 0; transform: translateX(6%) scale(1.02); transition: opacity .7s ease, transform .8s ease; }
.hero-slide.active { opacity: 1; transform: translateX(0) scale(1); z-index: 1; }
.hero-slide img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: saturate(1.1) contrast(1.05); }
.slide-shade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(4,12,8,.95), rgba(4,12,8,.58) 48%, rgba(4,12,8,.2)), linear-gradient(0deg, rgba(7,17,13,.82), transparent 55%); }
.slide-content { position: absolute; z-index: 2; left: clamp(24px, 6vw, 72px); bottom: clamp(40px, 8vw, 86px); max-width: 620px; }
.eyebrow { display: inline-flex; color: var(--lime); font-size: .78rem; text-transform: uppercase; letter-spacing: .22em; font-weight: 900; margin-bottom: 12px; }
h1, h2, h3 { font-family: "Saira Condensed", sans-serif; line-height: .95; margin: 0; text-transform: uppercase; }
.slide-content h1, .page-hero h1 { font-size: clamp(3.2rem, 9vw, 7.8rem); letter-spacing: .02em; text-shadow: 0 10px 30px rgba(0,0,0,.4); }
.slide-content p, .page-hero p, .section-heading p { color: var(--muted); font-size: 1.05rem; line-height: 1.7; max-width: 660px; }
.hero-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 26px; }
.carousel-arrow { position: absolute; z-index: 3; top: 50%; transform: translateY(-50%); width: 42px; height: 70px; border: 1px solid var(--line); background: rgba(7,17,13,.68); color: white; font-size: 2.4rem; cursor: pointer; }
.carousel-arrow.prev { left: 14px; }
.carousel-arrow.next { right: 14px; }
.carousel-dots { position: absolute; z-index: 3; left: 34px; bottom: 24px; display: flex; gap: 8px; }
.carousel-dots button { width: 34px; height: 6px; border-radius: 99px; border: 0; background: rgba(255,255,255,.28); cursor: pointer; }
.carousel-dots button.active { background: var(--slide-accent, var(--lime)); box-shadow: 0 0 20px var(--green); }

.server-panel, .cart-panel, .sidebar-card, .admin-card, .login-card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(18,36,26,.9), rgba(8,18,13,.84));
  box-shadow: var(--shadow);
  position: relative;
  overflow: hidden;
}
.server-panel { padding: 20px; align-self: stretch; display: flex; flex-direction: column; gap: 16px; justify-content: center; }
.panel-logo { border-radius: var(--radius); border: 1px solid var(--line); aspect-ratio: 16/9; object-fit: cover; }
.status-row, .cart-total { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 12px 0; border-bottom: 1px solid var(--line); }
.copy-large { width: 100%; color: var(--lime); font-family: "Saira Condensed", sans-serif; font-size: 1.35rem; }
.mini-grid, .metric-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.mini-grid span, .metric-grid article { background: rgba(255,255,255,.045); border: 1px solid var(--line); border-radius: var(--radius); padding: 13px; color: var(--muted); }
.mini-grid strong, .metric-grid strong { display: block; color: var(--text); font-family: "Saira Condensed", sans-serif; font-size: 1.45rem; }

.ticker { max-width: 1240px; margin: 0 auto; padding: 13px 22px; display: flex; gap: 10px; overflow: hidden; border-block: 1px solid var(--line); }
.ticker span { white-space: nowrap; color: var(--gold); font-weight: 900; text-transform: uppercase; animation: tickerPulse 2.6s ease-in-out infinite; }
@keyframes tickerPulse { 50% { color: var(--lime); } }

.section { max-width: 1240px; margin: 0 auto; padding: 78px 22px; }
.section-heading { text-align: center; margin-bottom: 34px; }
.section-heading.left { text-align: left; }
.section-heading h2, .supporter-board h2, .news-stack h2 { font-size: clamp(2.3rem, 5vw, 4.3rem); }
.mode-grid, .product-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; }
.mode-card, .product-card, .news-item, .supporter {
  position: relative;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel);
  padding: 22px;
  overflow: hidden;
  transition: transform .24s, border-color .24s, background .24s, box-shadow .24s;
}
.mode-card::before, .product-card::before { content: ""; position: absolute; inset: 0 0 auto; height: 4px; background: linear-gradient(90deg, var(--green), var(--gold), var(--orange)); opacity: .85; }
.mode-card:hover, .product-card:hover, .news-item:hover, .supporter:hover, .topic:hover { transform: translateY(-5px); border-color: var(--line-strong); background: rgba(21,43,30,.92); box-shadow: 0 20px 52px rgba(0,0,0,.3), var(--glow); }
.mode-card span { color: var(--orange); font-family: "Saira Condensed"; font-size: 2rem; font-weight: 800; }
.mode-card h3, .product-card h2 { font-size: 2rem; margin: 20px 0 10px; }
.mode-card p, .product-card p, .news-item p, .muted { color: var(--muted); line-height: 1.65; }

.split-section { display: grid; grid-template-columns: 1.1fr .9fr; gap: 18px; align-items: start; }
.news-stack, .supporter-board { display: grid; gap: 12px; }
.news-item time { color: var(--gold); font-weight: 900; font-size: .8rem; }
.news-item h3 { font-size: 1.65rem; margin-top: 8px; }
.supporter { display: grid; grid-template-columns: 44px 1fr auto; gap: 12px; align-items: center; }
.supporter b { display: grid; place-items: center; width: 38px; height: 38px; background: var(--lime); color: var(--ink); border-radius: var(--radius); }
.supporter strong { color: var(--gold); }
.faq-list { max-width: 820px; margin: 0 auto; display: grid; gap: 10px; }
details { border: 1px solid var(--line); border-radius: var(--radius); background: var(--panel); padding: 18px 20px; }
summary { cursor: pointer; font-weight: 900; color: var(--text); }
details p { color: var(--muted); line-height: 1.7; }

.page-hero { min-height: 430px; padding: 118px 22px 42px; display: grid; grid-template-columns: minmax(0, 1fr) 360px; align-items: end; gap: 18px; max-width: 1240px; margin: 0 auto; }
.store-hero, .forum-hero, .admin-hero { background: linear-gradient(135deg, rgba(52,211,153,.12), rgba(255,107,53,.08)); }
.cart-panel { padding: 20px; }
.cart-panel h2, .sidebar-card h2, .admin-card h2 { font-size: 2rem; margin-bottom: 12px; }
.cart-items { display: grid; gap: 8px; min-height: 90px; }
.empty { color: var(--muted); align-content: center; }
.cart-line { display: grid; grid-template-columns: 1fr auto auto; gap: 9px; align-items: center; padding: 9px 0; border-bottom: 1px solid var(--line); }
.cart-line button { border: 0; background: rgba(251,113,133,.15); color: var(--red); border-radius: 6px; cursor: pointer; width: 28px; height: 28px; }
.cart-line em { color: var(--muted); font-style: normal; }
.grand strong { color: var(--lime); font-size: 1.35rem; }
.discount-line strong { color: var(--gold); }
.store-toolbar { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; margin-bottom: 26px; }
.filter-btn.active, .method-tab.active { background: linear-gradient(135deg, var(--orange), var(--gold)); color: var(--ink); border-color: transparent; }
.product-card { min-height: 280px; display: flex; flex-direction: column; }
.product-top, .product-bottom { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.product-icon { display: grid; place-items: center; width: 54px; height: 54px; border-radius: var(--radius); background: color-mix(in srgb, var(--accent) 28%, transparent); color: var(--accent); border: 1px solid color-mix(in srgb, var(--accent) 55%, transparent); font-family: "Saira Condensed"; font-size: 2rem; font-weight: 900; }
.product-top b { color: var(--gold); font-size: .78rem; text-transform: uppercase; }
.product-card p { flex: 1; }
.product-bottom strong { font-family: "Saira Condensed"; font-size: 2rem; color: var(--lime); }

.modal[hidden] { display: none; }
.modal { position: fixed; inset: 0; z-index: 10; display: grid; place-items: center; padding: 18px; background: rgba(0,0,0,.72); backdrop-filter: blur(8px); }
.modal-panel { width: min(1040px, 100%); max-height: min(860px, 92vh); overflow: auto; border: 1px solid var(--line); border-radius: var(--radius); background: linear-gradient(180deg, #0b1a12, #07110d); box-shadow: var(--shadow), var(--glow); padding: 24px; position: relative; }
.modal-close { position: absolute; right: 18px; top: 14px; width: 38px; height: 38px; border: 1px solid var(--line); border-radius: var(--radius); background: rgba(255,255,255,.05); color: var(--text); cursor: pointer; font-size: 1.5rem; }
.modal-panel h2 { font-size: 2.6rem; margin-bottom: 16px; }
.checkout-layout { display: grid; grid-template-columns: 1fr 330px; gap: 18px; }
.method-tabs { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 14px; }
.checkout-form, .admin-card, .login-card { display: grid; gap: 13px; }
.method-panel { display: none; gap: 13px; }
.method-panel.active { display: grid; }
label { display: grid; gap: 7px; color: var(--muted); font-weight: 800; }
input, select, textarea { width: 100%; border: 1px solid var(--line); border-radius: var(--radius); background: rgba(255,255,255,.055); color: var(--text); padding: 12px 13px; outline: none; transition: border-color .2s, background .2s, box-shadow .2s; }
textarea { min-height: 92px; resize: vertical; }
select option { color: #0b1510; background: #f2f8e8; }
input[type="color"] { min-height: 46px; padding: 5px; cursor: pointer; }
input::placeholder, textarea::placeholder { color: rgba(166,181,164,.72); }
input:hover, select:hover, textarea:hover { border-color: var(--line-strong); background: rgba(255,255,255,.075); }
input:focus, select:focus, textarea:focus { border-color: var(--lime); box-shadow: 0 0 0 4px rgba(212,255,79,.1); }
:focus-visible { outline: 3px solid rgba(212,255,79,.5); outline-offset: 3px; }
.btn:focus-visible, .ip-pill:focus-visible, .copy-large:focus-visible, .filter-btn:focus-visible, .method-tab:focus-visible, .modal-close:focus-visible, .cart-line button:focus-visible, .admin-row button:focus-visible, .carousel-arrow:focus-visible, .carousel-dots button:focus-visible { outline: 3px solid rgba(212,255,79,.58); outline-offset: 3px; box-shadow: 0 0 0 6px rgba(35,209,139,.1); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.card-input { display: grid; grid-template-columns: 1fr 92px; gap: 8px; }
.card-input span { display: grid; place-items: center; border: 1px solid var(--line); border-radius: var(--radius); color: var(--lime); font-weight: 900; }
.copy-box { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 8px; border: 1px dashed rgba(212,255,79,.35); border-radius: var(--radius); padding: 10px; align-items: center; }
.copy-box span { overflow-wrap: anywhere; color: var(--text); }
.copy-box button { border: 1px solid var(--line); background: rgba(255,255,255,.05); color: var(--text); border-radius: var(--radius); padding: 9px 12px; cursor: pointer; }
.checkout-summary { border: 1px solid var(--line); border-radius: var(--radius); padding: 16px; background: rgba(255,255,255,.035); }
.checkout-result { margin-top: 14px; display: grid; gap: 4px; color: var(--lime); }

.forum-layout { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 18px; align-items: start; }
.forum-main, .forum-sidebar { display: grid; gap: 14px; }
.forum-category { border: 1px solid var(--line); border-radius: var(--radius); background: var(--panel); overflow: hidden; }
.forum-category header { display: grid; grid-template-columns: 90px 1fr auto; gap: 12px; align-items: center; padding: 18px; border-bottom: 1px solid var(--line); background: rgba(255,255,255,.035); }
.forum-category header span { color: var(--lime); font-weight: 900; font-size: .76rem; letter-spacing: .16em; }
.forum-category header h2 { font-size: 2rem; }
.topic { display: grid; grid-template-columns: 48px 1fr auto; gap: 14px; align-items: center; padding: 15px 18px; border-bottom: 1px solid var(--line); transition: transform .2s, background .2s; }
.topic:last-child { border-bottom: 0; }
.topic h3 { font-size: 1.35rem; }
.topic p, .sidebar-card p { color: var(--muted); margin: 5px 0 0; }
.topic strong { color: var(--gold); white-space: nowrap; }
.avatar { display: grid; place-items: center; width: 46px; height: 46px; border-radius: var(--radius); background: linear-gradient(135deg, var(--orange), var(--gold)); color: var(--ink); font-weight: 900; }
.avatar.green { background: linear-gradient(135deg, var(--green), var(--lime)); }
.avatar.gold { background: linear-gradient(135deg, var(--gold), var(--orange)); }
.avatar.cyan { background: linear-gradient(135deg, var(--cyan), var(--green)); }
.pinned { background: rgba(246,211,101,.05); }
.sidebar-card { padding: 18px; }

.admin-login { min-height: 100vh; display: grid; place-items: center; padding: 100px 18px 40px; }
.login-card { width: min(430px, 100%); padding: 24px; }
.login-card img { border-radius: var(--radius); border: 1px solid var(--line); aspect-ratio: 16/9; object-fit: cover; }
.login-card h1 { font-size: 3.5rem; }
.admin-shell[hidden], .admin-login[hidden] { display: none; }
.admin-hero { min-height: 320px; grid-template-columns: 1fr auto; }
.metric-grid { max-width: 1240px; margin: 0 auto; padding: 0 22px 28px; grid-template-columns: repeat(4, 1fr); }
.metric-grid article strong { font-size: 2.4rem; }
.admin-grid { max-width: 1240px; margin: 0 auto; padding: 0 22px 24px; display: grid; grid-template-columns: 420px 1fr; gap: 18px; }
.admin-card { padding: 18px; }
.admin-list { display: grid; gap: 9px; }
.admin-row, .order-row { display: grid; grid-template-columns: 1fr auto auto; gap: 10px; align-items: center; border: 1px solid var(--line); border-radius: var(--radius); padding: 12px; background: rgba(255,255,255,.035); }
.admin-row { min-width: 0; }
.admin-row > div, .order-row > * { min-width: 0; overflow-wrap: anywhere; }
.admin-row span { display: block; color: var(--muted); font-size: .86rem; margin-top: 4px; }
.admin-row button { border: 1px solid var(--line); border-radius: var(--radius); color: var(--text); background: rgba(255,255,255,.05); padding: 8px 10px; cursor: pointer; }
.orders-table { display: grid; gap: 8px; }
.order-row { grid-template-columns: 1.1fr .9fr .8fr .7fr 1.2fr; color: var(--muted); }
.order-row strong { color: var(--text); }

.footer { max-width: 1240px; margin: 40px auto 0; padding: 28px 22px 40px; border-top: 1px solid var(--line); display: flex; justify-content: space-between; gap: 18px; color: var(--muted); }
.footer strong { display: block; color: var(--text); font-family: "Saira Condensed"; font-size: 1.5rem; text-transform: uppercase; }
.footer nav { display: flex; gap: 14px; }
.footer a { color: var(--muted); text-decoration: none; font-weight: 800; }
.toast { position: fixed; left: 50%; bottom: 24px; transform: translate(-50%, 20px); opacity: 0; pointer-events: none; padding: 12px 16px; border: 1px solid var(--line); border-radius: var(--radius); background: #0b1c13; box-shadow: var(--shadow); color: var(--lime); font-weight: 900; transition: opacity .2s, transform .2s; }
.toast.show { opacity: 1; transform: translate(-50%, 0); }
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .65s ease, transform .65s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

@media (min-width: 1280px) {
  .hero-shell, .section, .page-hero, .nav-inner, .footer, .ticker { max-width: 1360px; }
  .hero-shell { grid-template-columns: minmax(0, 1fr) 360px; }
  .hero-carousel { min-height: 680px; }
  .mode-grid, .product-grid { gap: 18px; }
}

@media (max-width: 1040px) {
  .nav-links, .nav-actions { display: none; }
  .mobile-toggle { display: block; }
  .hero-shell, .page-hero, .split-section, .checkout-layout, .forum-layout, .admin-grid { grid-template-columns: 1fr; }
  .hero-carousel { min-height: 560px; }
  .mode-grid, .product-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .metric-grid { grid-template-columns: repeat(2, 1fr); }
  .page-hero { align-items: start; }
  .admin-hero { grid-template-columns: 1fr; }
  .checkout-summary { order: -1; }
  .order-row { grid-template-columns: repeat(5, minmax(0, 1fr)); }
}

/* Simpler homepage pass */
.simple-page {
  background: #eef3f5;
}

.simple-page .network-bg,
.simple-page .portal-hero,
.simple-page .hero-art,
.simple-page .hero-cloud {
  display: none;
}

.simple-hero {
  background: #d8c34a;
  background-image:
    linear-gradient(rgba(255,255,255,.38), rgba(255,255,255,.18)),
    url("assets/craftulus-banner.jpeg");
  background-position: center;
  background-size: cover;
  padding: 64px 14px 76px;
}

.simple-hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 260px;
  gap: 24px;
  align-items: center;
  width: min(1080px, 100%);
  margin: 0 auto;
}

.simple-copy {
  max-width: 680px;
}

.simple-label {
  display: inline-block;
  margin-bottom: 12px;
  padding: 8px 12px;
  border-radius: 999px;
  color: #1e2a2f;
  background: rgba(255,255,255,.82);
  font-weight: 900;
}

.simple-logo {
  width: min(620px, 100%);
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 16px 36px rgba(0,0,0,.16);
}

.simple-copy h1 {
  margin: 22px 0 8px;
  color: #18242b;
  font-family: "Barlow Condensed", sans-serif;
  font-size: clamp(2.4rem, 5vw, 4.2rem);
  line-height: .98;
  text-transform: uppercase;
}

.simple-copy p {
  margin: 0;
  max-width: 520px;
  color: #33454c;
  font-size: 1.08rem;
  font-weight: 800;
  line-height: 1.6;
}

.simple-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 22px;
}

.simple-status {
  padding: 20px;
  border-radius: 16px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 16px 36px rgba(0,0,0,.16);
  text-align: center;
}

.simple-status img {
  width: 112px;
  height: 112px;
  margin: 0 auto 12px;
  border-radius: 18px;
  object-fit: cover;
}

.simple-status span,
.simple-status small {
  display: block;
  color: #7d8b91;
  font-weight: 900;
}

.simple-status strong {
  display: block;
  color: #c2a22a;
  font-size: 2rem;
}

.simple-page .portal-body {
  margin-top: 34px;
}

.simple-page .leader-post,
.simple-page .side-box,
.simple-page .section-title,
.simple-page .faq-grid details {
  box-shadow: 0 8px 20px rgba(29, 50, 60, 0.07);
}

.simple-page .leader-post {
  grid-template-columns: 180px minmax(0, 1fr);
}

.simple-page .post-thumb {
  min-height: 138px;
}

.simple-page .top-alert a {
  padding: 9px 14px;
}

.simple-page .portal-footer {
  margin-top: 24px;
}

@media (max-width: 860px) {
  .simple-hero-inner,
  .simple-page .leader-post {
    grid-template-columns: 1fr;
  }

  .simple-status {
    max-width: 360px;
  }
}

@media (max-width: 768px) {
  body { font-size: 16px; }
  .nav-inner { padding: 0 16px; }
  .brand { font-size: 1.55rem; }
  .brand img { width: 38px; height: 38px; }
  .hero-shell { min-height: auto; padding-top: 94px; }
  .page-hero { min-height: 360px; padding-top: 108px; }
  .slide-content h1, .page-hero h1 { font-size: clamp(3rem, 12vw, 5.5rem); }
  .section { padding-top: 60px; padding-bottom: 60px; }
  .modal { align-items: end; padding: 10px; }
  .modal-panel { max-height: 88vh; padding: 20px; }
  .method-tabs { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .method-tab { min-height: 46px; }
  .admin-grid { padding-left: 16px; padding-right: 16px; }
}

@media (max-width: 640px) {
  .hero-shell, .section, .page-hero { padding-left: 14px; padding-right: 14px; }
  .hero-carousel { min-height: 540px; }
  .slide-content { left: 20px; right: 20px; bottom: 58px; }
  .carousel-arrow { display: none; }
  .mode-grid, .product-grid, .metric-grid, .mini-grid, .form-row, .card-input { grid-template-columns: 1fr; }
  .supporter, .topic, .forum-category header, .order-row { grid-template-columns: 1fr; }
  .copy-box, .cart-line { grid-template-columns: 1fr; }
  .cart-line button { width: 100%; }
  .product-bottom { align-items: stretch; flex-direction: column; }
  .product-bottom .btn { width: 100%; }
  .admin-row { grid-template-columns: 1fr 1fr; }
  .admin-row > div { grid-column: 1 / -1; }
  .footer { flex-direction: column; }
}

@media (max-width: 430px) {
  :root { --nav-height: 66px; }
  .nav-inner { height: var(--nav-height); padding: 0 12px; }
  .mobile-menu { left: 10px; right: 10px; }
  .brand { gap: 8px; font-size: 1.35rem; }
  .brand img { width: 34px; height: 34px; }
  .mobile-toggle { width: 38px; height: 38px; }
  .hero-shell { padding-top: 82px; gap: 12px; }
  .hero-carousel { min-height: 500px; }
  .slide-content { left: 16px; right: 16px; bottom: 52px; }
  .slide-content h1, .page-hero h1 { font-size: clamp(2.7rem, 15vw, 4.15rem); }
  .slide-content p, .page-hero p, .section-heading p { font-size: 1rem; line-height: 1.55; }
  .hero-actions, .store-toolbar, .method-tabs { display: grid; grid-template-columns: 1fr; }
  .hero-actions .btn, .store-toolbar .filter-btn { width: 100%; }
  .server-panel, .cart-panel, .sidebar-card, .admin-card, .login-card, .mode-card, .product-card, .news-item, .supporter { padding: 16px; }
  .page-hero { min-height: 330px; padding-top: 92px; }
  .section { padding-top: 48px; padding-bottom: 48px; }
  .section-heading { margin-bottom: 24px; }
  .modal { padding: 0; }
  .modal-panel { width: 100%; max-height: 92vh; border-radius: 8px 8px 0 0; padding: 18px 14px 22px; }
  .modal-close { right: 12px; top: 12px; }
  .modal-panel h2 { padding-right: 44px; font-size: 2.2rem; }
  .admin-login { padding-top: 82px; }
  .admin-row { grid-template-columns: 1fr; }
  .admin-row button { width: 100%; min-height: 42px; }
  .footer nav { flex-wrap: wrap; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
    scroll-behavior: auto !important;
  }
  html { scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; }
  .hero-slide, .hero-slide.active { transform: none; }
  .btn:hover, .ip-pill:hover, .copy-large:hover, .filter-btn:hover, .method-tab:hover, .mode-card:hover, .product-card:hover, .news-item:hover, .supporter:hover, .topic:hover { transform: none; }
}

/* LeaderOS-style portal override */
.portal-page {
  color: #263238;
  background: #eef3f5;
}

.portal-page::before {
  display: none;
}

.top-alert {
  position: relative;
  z-index: 5;
  background: #f24d4d;
  text-align: center;
}

.top-alert a {
  display: block;
  padding: 11px 16px;
  color: #fff;
  font-weight: 900;
  text-decoration: none;
}

.portal-navbar {
  position: sticky;
  top: 0;
  background: #fff;
  border-bottom: 1px solid #e5edf0;
  box-shadow: 0 10px 30px rgba(29, 50, 60, 0.08);
  backdrop-filter: none;
}

.portal-navbar .brand {
  color: #263238;
}

.portal-navbar .brand img {
  border-color: #e7d38a;
}

.portal-navbar .nav-links a {
  color: #5c6c72;
  background: transparent;
}

.portal-navbar .nav-links a:hover,
.portal-navbar .nav-links a.active {
  color: #d0ad24;
  border-color: transparent;
  background: transparent;
}

.login-link {
  color: #52636a;
  font-weight: 900;
  text-decoration: none;
}

.portal-page .btn-primary {
  color: #fff;
  background: linear-gradient(135deg, #d4b72d, #b9941b);
}

.btn-white {
  color: #263238;
  background: #fff;
  border-color: #fff;
}

.portal-hero {
  position: relative;
  min-height: 565px;
  overflow: hidden;
  color: #fff;
  background:
    linear-gradient(rgba(20, 27, 22, .35), rgba(20, 27, 22, .62)),
    url("assets/craftulus-banner.jpeg") center / cover no-repeat;
}

.hero-art {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 20%, rgba(255, 224, 68, .35), transparent 22rem),
    linear-gradient(45deg, rgba(255,255,255,.08) 25%, transparent 25%) 0 0 / 40px 40px,
    linear-gradient(-45deg, rgba(0,0,0,.08) 25%, transparent 25%) 0 20px / 40px 40px;
  opacity: .85;
}

.hero-cloud {
  position: absolute;
  inset: auto 0 0;
  height: 118px;
  background: linear-gradient(to bottom, transparent, #eef3f5 78%);
}

.portal-hero .hero-slide {
  position: static;
  display: none;
  transform: none;
  opacity: 1;
}

.portal-hero .hero-slide.active {
  display: block;
}

.hero-center {
  position: relative;
  z-index: 1;
  width: min(760px, calc(100% - 420px));
  min-height: 565px;
  margin: 0 auto;
  padding: 82px 0 120px;
  text-align: center;
}

.hero-logo {
  width: min(720px, 92vw);
  margin: 0 auto 18px;
  border-radius: 8px;
  box-shadow: 0 22px 60px rgba(0,0,0,.24);
}

.hero-center h1 {
  margin: 0 auto 12px;
  max-width: 720px;
  font-family: "Barlow Condensed", sans-serif;
  font-size: clamp(2.7rem, 6vw, 4.7rem);
  line-height: .95;
  text-transform: uppercase;
  color: #fff;
  text-shadow: 0 8px 24px rgba(0,0,0,.35);
}

.hero-center p {
  max-width: 630px;
  margin: 0 auto;
  color: rgba(255,255,255,.92);
  font-weight: 800;
  line-height: 1.7;
}

.hero-connect {
  position: absolute;
  z-index: 2;
  top: 50%;
  width: 245px;
  min-height: 118px;
  transform: translateY(-50%);
  border: 0;
  border-radius: 18px;
  padding: 19px;
  color: #263238;
  background: rgba(255,255,255,.96);
  box-shadow: 0 20px 45px rgba(0,0,0,.24);
  text-align: left;
  text-decoration: none;
}

.card-left { left: max(22px, calc((100% - 1180px) / 2)); }
.card-right { right: max(22px, calc((100% - 1180px) / 2)); }

.hero-connect span,
.hero-connect small {
  display: block;
  color: #7f8d92;
  font-weight: 900;
}

.hero-connect strong {
  display: block;
  margin: 5px 0;
  color: #bea02a;
  font-size: 1.2rem;
  font-weight: 900;
  overflow-wrap: anywhere;
}

.portal-hero .carousel-arrow {
  top: auto;
  bottom: 54px;
  transform: none;
  background: rgba(255,255,255,.94);
  color: #263238;
}

.portal-hero .carousel-arrow.prev {
  left: calc(50% - 72px);
}

.portal-hero .carousel-arrow.next {
  right: calc(50% - 72px);
}

.portal-hero .carousel-dots {
  position: relative;
  z-index: 2;
  justify-content: center;
  margin-top: 22px;
}

.portal-body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 330px;
  gap: 24px;
  width: min(1180px, calc(100% - 28px));
  margin: -42px auto 52px;
  position: relative;
  z-index: 3;
}

.main-column,
.leader-sidebar {
  display: grid;
  align-content: start;
  gap: 18px;
}

.section-title {
  padding: 22px;
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 10px 26px rgba(29, 50, 60, 0.08);
}

.section-title h2 {
  margin: 0 0 4px;
  color: #263238;
  font-family: "Barlow Condensed", sans-serif;
  font-size: 2rem;
  text-transform: uppercase;
}

.section-title p {
  margin: 0;
  color: #7d8b91;
}

.leader-post,
.side-box,
.faq-grid details {
  border: 1px solid #e2eaed;
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 10px 26px rgba(29, 50, 60, 0.08);
}

.leader-post {
  display: grid;
  grid-template-columns: 230px minmax(0, 1fr);
  overflow: hidden;
}

.post-thumb {
  display: grid;
  min-height: 178px;
  place-items: center;
  color: #fff;
  font-weight: 900;
  text-transform: uppercase;
  background:
    linear-gradient(135deg, rgba(255,255,255,.18), transparent),
    repeating-linear-gradient(45deg, rgba(0,0,0,.08) 0 10px, transparent 10px 20px);
}

.green-thumb { background-color: #43a85e; }
.gold-thumb { background-color: #c7a72a; }
.blue-thumb { background-color: #3d74c8; }

.post-content {
  padding: 22px;
}

.post-kind {
  color: #c2a22a;
  font-weight: 900;
}

.post-content time {
  margin-left: 10px;
  color: #9aa8ad;
  font-weight: 800;
}

.post-content h3 {
  margin: 8px 0;
  color: #263238;
  font-family: "Manrope", sans-serif;
  font-size: 1.35rem;
  line-height: 1.25;
  text-transform: none;
}

.post-content p {
  color: #7d8b91;
  line-height: 1.65;
}

.post-content a {
  color: #c2a22a;
  font-weight: 900;
  text-decoration: none;
}

.side-box {
  padding: 20px;
}

.side-box h3 {
  margin: 0 0 14px;
  color: #263238;
  font-family: "Barlow Condensed", sans-serif;
  font-size: 1.45rem;
  text-transform: uppercase;
}

.top-supporter {
  text-align: center;
}

.top-supporter img {
  width: 94px;
  height: 94px;
  object-fit: cover;
  border-radius: 18px;
  margin: 12px auto;
  box-shadow: 0 12px 26px rgba(0,0,0,.16);
}

.top-supporter span,
.top-supporter strong,
.top-supporter b {
  display: block;
}

.top-supporter span {
  color: #9aa8ad;
}

.top-supporter strong {
  color: #263238;
}

.top-supporter b,
.support-line strong {
  color: #c2a22a;
}

.activity-row,
.support-line {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 6px 12px;
  padding: 10px 0;
  border-bottom: 1px solid #edf2f4;
}

.activity-row span,
.support-line span {
  color: #263238;
  font-weight: 900;
}

.activity-row strong {
  color: #c2a22a;
}

.activity-row small {
  grid-column: 1 / -1;
  color: #9aa8ad;
  font-weight: 800;
}

.support-line b {
  color: #43a85e;
}

.faq-portal {
  width: min(1180px, calc(100% - 28px));
  margin: 0 auto 52px;
}

.faq-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.faq-grid details {
  padding: 20px;
}

.faq-grid summary {
  cursor: pointer;
  color: #263238;
  font-weight: 900;
}

.faq-grid p {
  color: #7d8b91;
  line-height: 1.65;
}

.portal-footer {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  padding: 34px max(14px, calc((100% - 1180px) / 2));
  color: #cdd7da;
  background: #18242b;
}

.portal-footer strong {
  color: #fff;
  font-size: 1.2rem;
}

.portal-footer p {
  margin: 6px 0 0;
}

.portal-footer nav {
  display: flex;
  gap: 14px;
  font-weight: 900;
}

@media (max-width: 1040px) {
  .portal-links {
    display: none;
  }
  .hero-center {
    width: min(760px, calc(100% - 28px));
    padding-top: 34px;
  }
  .hero-connect {
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    transform: none;
    width: min(420px, calc(100% - 28px));
    margin: 14px auto;
  }
  .portal-hero {
    padding: 24px 0 80px;
  }
  .portal-body,
  .leader-post,
  .faq-grid {
    grid-template-columns: 1fr;
  }
}

/* Craftulus purple glass homepage theme */
.theme-tox {
  --theme-primary: #facc15;
  --theme-primary-rgb: 250, 204, 21;
  --theme-accent: #f59e0b;
  --theme-accent-rgb: 245, 158, 11;
  --theme-hot: #fde68a;
  --theme-green: #10b981;
  --theme-bg: #05050a;
  --theme-card: rgba(15, 15, 22, 0.86);
  --theme-border: rgba(255, 255, 255, 0.12);
  --theme-muted: rgba(255, 255, 255, 0.66);
  color: #fff;
  font-family: "Rubik", sans-serif;
  background: var(--theme-bg);
}

.theme-tox h1,
.theme-tox h2,
.theme-tox h3,
.theme-tox .brand {
  font-family: "TASA Explorer", sans-serif;
  letter-spacing: 0;
}

.theme-tox::before {
  display: none;
}

.tox-effects {
  position: fixed;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
}

.tox-grid,
.tox-header-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(var(--theme-primary-rgb), 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(var(--theme-primary-rgb), 0.035) 1px, transparent 1px);
  background-size: 44px 44px;
  animation: gridMove 22s linear infinite;
}

.tox-orb {
  position: absolute;
  border-radius: 999px;
  background: var(--theme-primary);
  filter: blur(92px);
  opacity: 0.16;
  animation: floatOrb 18s ease-in-out infinite;
}

.tox-orb-one { width: 520px; height: 520px; top: -120px; left: -140px; }
.tox-orb-two { width: 460px; height: 460px; right: -130px; top: 34%; background: var(--theme-accent); animation-delay: -6s; }
.tox-orb-three { width: 280px; height: 280px; left: 36%; bottom: 8%; background: var(--theme-hot); opacity: 0.08; animation-delay: -11s; }

@keyframes gridMove {
  to { transform: translate(44px, 44px); }
}

@keyframes floatOrb {
  0%, 100% { transform: translate3d(0, 0, 0); }
  45% { transform: translate3d(34px, 54px, 0); }
  70% { transform: translate3d(-24px, 18px, 0); }
}

.tox-alert {
  background: linear-gradient(90deg, var(--theme-primary), var(--theme-accent), var(--theme-hot));
  box-shadow: 0 10px 34px rgba(var(--theme-primary-rgb), 0.24);
}

.tox-alert a {
  color: #fff;
  font-family: "Comic Relief", cursive;
  font-weight: 700;
}

.tox-header {
  position: relative;
  min-height: 760px;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(var(--theme-primary-rgb), 0.18), rgba(5, 5, 10, 0.96)),
    url("assets/craftulus-banner.jpeg") center / cover no-repeat;
}

.tox-header::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(90deg, rgba(5, 5, 10, 0.92), transparent 25%, transparent 75%, rgba(5, 5, 10, 0.92)),
    linear-gradient(180deg, rgba(5, 5, 10, 0.4), transparent 48%, var(--theme-bg));
  pointer-events: none;
}

.tox-header-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: radial-gradient(circle at 50% 22%, rgba(var(--theme-primary-rgb), 0.34), transparent 36rem);
}

.tox-bubbles {
  position: absolute;
  inset: 0;
  z-index: 1;
  overflow: hidden;
  pointer-events: none;
}

.tox-bubbles span {
  position: absolute;
  bottom: -60px;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(var(--theme-primary-rgb), 0.34), rgba(var(--theme-primary-rgb), 0.08));
  opacity: 0;
  animation: rise 15s linear infinite;
}

.tox-bubbles span:nth-child(1) { left: 10%; animation-delay: 0s; }
.tox-bubbles span:nth-child(2) { left: 25%; width: 18px; height: 18px; animation-delay: 2s; animation-duration: 12s; }
.tox-bubbles span:nth-child(3) { left: 48%; width: 34px; height: 34px; animation-delay: 4s; }
.tox-bubbles span:nth-child(4) { left: 66%; width: 22px; height: 22px; animation-delay: 1s; animation-duration: 17s; }
.tox-bubbles span:nth-child(5) { left: 82%; width: 38px; height: 38px; animation-delay: 5s; }
.tox-bubbles span:nth-child(6) { left: 92%; width: 16px; height: 16px; animation-delay: 7s; animation-duration: 13s; }

@keyframes rise {
  0% { transform: translateY(0); opacity: 0; }
  12%, 82% { opacity: 0.5; }
  100% { transform: translateY(-106vh); opacity: 0; }
}

.tox-navbar {
  position: relative;
  z-index: 5;
  background: transparent;
  border: 0;
  box-shadow: none;
  backdrop-filter: none;
}

.tox-navbar.scrolled {
  position: fixed;
  background: rgba(5, 5, 10, 0.78);
  backdrop-filter: blur(20px) saturate(160%);
  border-bottom: 1px solid var(--theme-border);
}

.tox-navbar .brand {
  color: #fff;
}

.tox-navbar .brand img {
  border-color: rgba(var(--theme-primary-rgb), 0.35);
  box-shadow: 0 0 20px rgba(var(--theme-primary-rgb), 0.22);
}

.tox-navbar .nav-links a,
.tox-navbar .login-link,
.tox-navbar .mobile-toggle,
.theme-tox .mobile-menu a,
.theme-tox .mobile-menu button {
  color: var(--theme-muted);
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid transparent;
  border-radius: 8px;
  backdrop-filter: blur(12px);
}

.tox-navbar .nav-links a:hover,
.tox-navbar .nav-links a.active,
.tox-navbar .login-link:hover {
  color: #fff;
  border-color: var(--theme-border);
  background: rgba(var(--theme-primary-rgb), 0.16);
}

.theme-tox .mobile-menu {
  background: rgba(5, 5, 10, 0.96);
  border-color: var(--theme-border);
  z-index: 9;
}

.theme-tox .btn,
.theme-tox .btn-white,
.theme-tox .btn-ghost {
  border-radius: 12px;
  border-color: var(--theme-border);
  color: #fff;
  background: rgba(255, 255, 255, 0.08);
  box-shadow: none;
}

.theme-tox .btn-primary {
  color: #211400;
  background: linear-gradient(135deg, var(--theme-primary), var(--theme-accent));
  border-color: rgba(var(--theme-primary-rgb), 0.32);
  box-shadow: 0 14px 34px rgba(var(--theme-primary-rgb), 0.22);
}

.theme-tox .btn:hover {
  border-color: rgba(var(--theme-primary-rgb), 0.5);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.28);
}

.tox-hero {
  position: relative;
  z-index: 4;
  min-height: 625px;
  max-width: 1180px;
  margin: 0 auto;
  padding: 72px 22px 96px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.tox-hero-copy {
  width: min(900px, 100%);
  text-align: center;
}

.tox-logo {
  width: min(480px, 82vw);
  max-height: 170px;
  object-fit: contain;
  margin: 0 auto 22px;
  filter: drop-shadow(0 18px 44px rgba(0, 0, 0, 0.54));
}

.tox-hero h1,
.tox-section-title h2,
.tox-faq-copy h2,
.tox-cta h2 {
  margin: 0;
  font-weight: 800;
  line-height: 1.04;
  text-transform: none;
  background: linear-gradient(to bottom, #fff 22%, #fff3b0 58%, var(--theme-primary));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.tox-hero h1 {
  font-size: clamp(3rem, 8vw, 6.5rem);
  max-width: 950px;
  margin-inline: auto;
}

.tox-hero p,
.tox-section-title p,
.tox-faq-copy p,
.tox-cta p {
  max-width: 720px;
  margin: 22px auto 0;
  color: var(--theme-muted);
  font-size: clamp(1rem, 2vw, 1.3rem);
  line-height: 1.7;
}

.tox-hero-actions {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 34px;
}

.tox-info-card {
  position: absolute;
  top: 50%;
  width: 250px;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 15px 17px;
  color: #fff;
  text-decoration: none;
  border: 1px solid var(--theme-border);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.07);
  backdrop-filter: blur(18px) saturate(170%);
  transform: translateY(-50%);
  transition: transform .25s, border-color .25s, box-shadow .25s;
}

.tox-info-card:hover {
  transform: translateY(calc(-50% - 3px));
  border-color: rgba(var(--theme-primary-rgb), 0.48);
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.32);
}

.tox-info-left { left: 22px; }
.tox-info-right { right: 22px; }

.tox-info-card strong,
.tox-info-card small {
  display: block;
}

.tox-info-card strong {
  overflow-wrap: anywhere;
  font-size: 0.94rem;
}

.tox-info-card small {
  margin-top: 4px;
  color: var(--theme-muted);
  font-size: 0.75rem;
}

.tox-icon {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  flex: 0 0 42px;
  border-radius: 12px;
  color: var(--theme-primary);
  background: rgba(var(--theme-primary-rgb), 0.12);
  border: 1px solid rgba(var(--theme-primary-rgb), 0.28);
  font-weight: 900;
}

.tox-discord {
  color: #fbbf24;
}

.tox-section {
  position: relative;
  z-index: 2;
  width: min(1180px, calc(100% - 28px));
  margin: 0 auto;
  padding: 86px 0;
}

.tox-section-title {
  text-align: center;
  margin-bottom: 36px;
}

.tox-section-title h2,
.tox-faq-copy h2,
.tox-cta h2 {
  font-size: clamp(2.45rem, 5vw, 4.2rem);
}

.tox-news-grid,
.tox-stat-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.tox-news-card,
.tox-stat-card,
.tox-faq-list details {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(var(--theme-primary-rgb), 0.16);
  border-radius: 24px;
  background: linear-gradient(165deg, rgba(24, 18, 36, 0.9), rgba(6, 6, 10, 0.96));
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.2);
  transition: transform .35s, border-color .35s, box-shadow .35s;
}

.tox-news-card:hover,
.tox-stat-card:hover,
.tox-faq-list details:hover {
  transform: translateY(-10px);
  border-color: rgba(var(--theme-primary-rgb), 0.7);
  box-shadow: 0 24px 58px rgba(var(--theme-primary-rgb), 0.22);
}

.tox-news-card::after,
.tox-stat-card::after,
.tox-faq-list details::after {
  content: "";
  position: absolute;
  left: 10%;
  right: 10%;
  bottom: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--theme-primary), transparent);
  opacity: 0;
  transition: opacity .35s;
}

.tox-news-card:hover::after,
.tox-stat-card:hover::after,
.tox-faq-list details:hover::after {
  opacity: 1;
}

.tox-news-art {
  min-height: 200px;
  display: grid;
  place-items: start;
  padding: 18px;
  background:
    linear-gradient(180deg, transparent 42%, rgba(5, 5, 10, 0.96)),
    radial-gradient(circle at 72% 25%, rgba(255, 255, 255, 0.2), transparent 9rem),
    linear-gradient(135deg, rgba(var(--theme-primary-rgb), 0.72), rgba(5, 5, 10, 0.9));
}

.tox-news-gold { background: linear-gradient(135deg, rgba(251, 191, 36, 0.72), rgba(5, 5, 10, 0.9)); }
.tox-news-blue { background: linear-gradient(135deg, rgba(234, 179, 8, 0.72), rgba(5, 5, 10, 0.9)); }

.tox-news-art span {
  display: inline-flex;
  padding: 6px 14px;
  border-radius: 999px;
  background: var(--theme-primary);
  color: #fff;
  font-family: "Comic Relief", cursive;
  font-size: 0.78rem;
  font-weight: 700;
}

.tox-news-content,
.tox-stat-card {
  padding: 24px;
}

.tox-news-content small {
  color: var(--theme-primary);
  font-weight: 800;
  letter-spacing: .06em;
}

.tox-news-content h3 {
  margin: 12px 0;
  color: #fff;
  font-size: 1.35rem;
  line-height: 1.25;
  text-transform: none;
}

.tox-news-content p,
.tox-faq-list p {
  color: var(--theme-muted);
  line-height: 1.65;
}

.tox-news-content a {
  display: inline-flex;
  margin-top: 8px;
  color: #fff;
  font-weight: 800;
  text-decoration: none;
}

.tox-stats-section {
  padding-top: 52px;
}

.tox-stat-card header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 22px;
}

.tox-stat-card header span {
  display: grid;
  place-items: center;
  width: 45px;
  height: 45px;
  border-radius: 12px;
  background: rgba(var(--theme-primary-rgb), 0.12);
  border: 1px solid rgba(var(--theme-primary-rgb), 0.3);
  color: var(--theme-primary);
}

.tox-stat-card h3 {
  margin: 0;
  color: #fff;
  font-size: 1.1rem;
  text-transform: uppercase;
}

.tox-player-row {
  display: grid;
  grid-template-columns: auto 38px minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  padding: 13px;
  margin-top: 10px;
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.035);
}

.tox-player-row:has(> img:first-child) {
  grid-template-columns: 38px minmax(0, 1fr) auto;
}

.tox-player-row img {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  object-fit: cover;
  border: 1px solid rgba(var(--theme-primary-rgb), 0.3);
}

.tox-player-row b {
  color: var(--theme-primary);
  font-size: .86rem;
}

.tox-player-row strong,
.tox-player-row small,
.tox-player-row em {
  display: block;
}

.tox-player-row small {
  color: var(--theme-muted);
  font-size: .76rem;
}

.tox-player-row em {
  padding: 6px 10px;
  border-radius: 10px;
  color: var(--theme-primary);
  background: rgba(var(--theme-primary-rgb), 0.12);
  border: 1px solid rgba(var(--theme-primary-rgb), 0.2);
  font-style: normal;
  font-size: .8rem;
  font-weight: 800;
  white-space: nowrap;
}

.tox-faq-section {
  display: grid;
  grid-template-columns: .78fr 1.22fr;
  gap: 52px;
  align-items: center;
  padding-top: 64px;
}

.tox-faq-copy p {
  margin-left: 0;
}

.tox-faq-copy .btn {
  margin-top: 24px;
}

.tox-faq-list {
  display: grid;
  gap: 14px;
}

.tox-faq-list details {
  padding: 20px 24px;
  border-radius: 18px;
}

.tox-faq-list details[open] {
  border-color: rgba(var(--theme-primary-rgb), 0.62);
  background: linear-gradient(165deg, rgba(31, 21, 48, 0.94), rgba(6, 6, 10, 0.96));
}

.tox-faq-list summary {
  display: flex;
  gap: 10px;
  color: #fff;
  font-weight: 800;
  cursor: pointer;
  list-style: none;
}

.tox-faq-list summary::-webkit-details-marker {
  display: none;
}

.tox-faq-list summary span {
  color: var(--theme-primary);
}

.tox-cta {
  position: relative;
  z-index: 2;
  width: min(1180px, calc(100% - 28px));
  margin: 28px auto 0;
  padding: 28px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  border-top: 1px solid rgba(var(--theme-primary-rgb), 0.22);
  background: rgba(10, 10, 15, 0.94);
  box-shadow: 0 -12px 42px rgba(0, 0, 0, 0.36);
}

.tox-cta h2 {
  font-size: clamp(1.8rem, 4vw, 2.6rem);
}

.tox-cta p {
  margin: 8px 0 0;
}

.tox-cta nav {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.tox-footer {
  position: relative;
  z-index: 2;
  margin-top: 0;
  color: rgba(255, 255, 255, 0.72);
  background: #06060c;
  border-top: 1px solid rgba(var(--theme-primary-rgb), 0.18);
}

.tox-footer nav a {
  text-decoration: none;
}

.theme-tox .toast {
  border-color: rgba(var(--theme-primary-rgb), 0.38);
  background: rgba(9, 8, 14, 0.92);
  color: #fff;
  backdrop-filter: blur(14px);
}

/* Shared gold glass theme for store, forum and admin */
body:not(.theme-tox) .navbar {
  background: rgba(8, 6, 3, 0.78);
  border-bottom-color: rgba(250, 204, 21, 0.18);
  backdrop-filter: blur(20px) saturate(165%);
}

body:not(.theme-tox) .navbar.scrolled {
  background: rgba(8, 6, 3, 0.94);
  box-shadow: 0 16px 42px rgba(0, 0, 0, .42), 0 0 34px rgba(250, 204, 21, .08);
}

body:not(.theme-tox) .brand img,
body:not(.theme-tox) .panel-logo,
body:not(.theme-tox) .login-card img {
  border-color: rgba(250, 204, 21, .34);
  box-shadow: 0 0 24px rgba(250, 204, 21, .14);
}

body:not(.theme-tox) .nav-links a,
body:not(.theme-tox) .ip-pill,
body:not(.theme-tox) .mobile-toggle {
  border-radius: 10px;
  background: rgba(255, 255, 255, .055);
  backdrop-filter: blur(12px);
}

body:not(.theme-tox) .nav-links a:hover,
body:not(.theme-tox) .nav-links a.active {
  color: #fff;
  background: rgba(250, 204, 21, .12);
  border-color: rgba(250, 204, 21, .22);
}

body:not(.theme-tox) .btn,
body:not(.theme-tox) .ip-pill,
body:not(.theme-tox) .copy-large,
body:not(.theme-tox) .filter-btn,
body:not(.theme-tox) .method-tab,
body:not(.theme-tox) .admin-row button {
  border-radius: 12px;
}

body:not(.theme-tox) .btn-primary,
body:not(.theme-tox) .filter-btn.active,
body:not(.theme-tox) .method-tab.active {
  color: var(--ink);
  background: linear-gradient(135deg, #facc15, #f59e0b, #fde68a);
  background-size: 200% 200%;
  animation: goldAurora 4.5s ease-in-out infinite;
  border-color: transparent;
  box-shadow: 0 14px 34px rgba(250, 204, 21, .2);
}

body:not(.theme-tox) .btn:hover,
body:not(.theme-tox) .ip-pill:hover,
body:not(.theme-tox) .copy-large:hover,
body:not(.theme-tox) .filter-btn:hover,
body:not(.theme-tox) .method-tab:hover {
  transform: translateY(-3px) scale(1.01);
  box-shadow: 0 16px 34px rgba(250, 204, 21, .16);
}

body:not(.theme-tox) .page-hero {
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid rgba(250, 204, 21, .12);
  min-height: 560px;
  align-items: center;
}

body:not(.theme-tox) .store-hero,
body:not(.theme-tox) .forum-hero,
body:not(.theme-tox) .admin-hero {
  background:
    radial-gradient(circle at 18% 20%, rgba(250, 204, 21, .2), transparent 26rem),
    radial-gradient(circle at 84% 28%, rgba(245, 158, 11, .16), transparent 24rem),
    linear-gradient(135deg, rgba(16, 12, 5, .96), rgba(5, 5, 8, .92)),
    url("assets/craftulus-banner.jpeg") center / cover no-repeat;
}

body:not(.theme-tox) .page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(250, 204, 21, .045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(250, 204, 21, .035) 1px, transparent 1px);
  background-size: 46px 46px;
  animation: gridMove 20s linear infinite;
  pointer-events: none;
}

body:not(.theme-tox) .page-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(5, 5, 8, .08), rgba(5, 5, 8, .72));
  pointer-events: none;
}

body:not(.theme-tox) .page-hero-copy {
  display: grid;
  justify-items: start;
  gap: 12px;
}

body:not(.theme-tox) .page-hero-logo {
  width: min(430px, 78vw);
  max-height: 150px;
  object-fit: contain;
  filter: drop-shadow(0 18px 44px rgba(0, 0, 0, .56)) drop-shadow(0 0 22px rgba(250, 204, 21, .18));
}

body:not(.theme-tox) .page-hero > * {
  position: relative;
  z-index: 1;
}

body:not(.theme-tox) .page-hero h1,
body:not(.theme-tox) .section-heading h2,
body:not(.theme-tox) .supporter-board h2,
body:not(.theme-tox) .news-stack h2,
body:not(.theme-tox) .admin-card h2,
body:not(.theme-tox) .sidebar-card h2,
body:not(.theme-tox) .cart-panel h2 {
  background: linear-gradient(to bottom, #fff 22%, #fff3b0 58%, #facc15);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

body:not(.theme-tox) .cart-panel,
body:not(.theme-tox) .sidebar-card,
body:not(.theme-tox) .admin-card,
body:not(.theme-tox) .login-card,
body:not(.theme-tox) .server-panel,
body:not(.theme-tox) .product-card,
body:not(.theme-tox) .news-item,
body:not(.theme-tox) .supporter,
body:not(.theme-tox) .forum-category,
body:not(.theme-tox) .metric-grid article {
  border-color: rgba(250, 204, 21, .18);
  background: linear-gradient(165deg, rgba(29, 21, 8, .88), rgba(7, 7, 10, .94));
  box-shadow: 0 20px 50px rgba(0, 0, 0, .26);
  backdrop-filter: blur(18px) saturate(150%);
}

body:not(.theme-tox) .cart-panel,
body:not(.theme-tox) .server-panel,
body:not(.theme-tox) .login-card {
  animation: goldBreath 5.5s ease-in-out infinite;
  border-radius: 24px;
  background: rgba(255, 255, 255, .07);
  backdrop-filter: blur(18px) saturate(170%);
}

body:not(.theme-tox) .product-card,
body:not(.theme-tox) .news-item,
body:not(.theme-tox) .supporter,
body:not(.theme-tox) .forum-category,
body:not(.theme-tox) .admin-card,
body:not(.theme-tox) .sidebar-card {
  isolation: isolate;
}

body:not(.theme-tox) .product-card::before,
body:not(.theme-tox) .mode-card::before {
  height: 3px;
  background: linear-gradient(90deg, transparent, #facc15, #f59e0b, transparent);
}

body:not(.theme-tox) .product-card::after,
body:not(.theme-tox) .admin-card::after,
body:not(.theme-tox) .cart-panel::after,
body:not(.theme-tox) .login-card::after,
body:not(.theme-tox) .sidebar-card::after {
  background: linear-gradient(90deg, transparent, rgba(250, 204, 21, .18), transparent);
  animation-duration: 5.2s;
}

body:not(.theme-tox) .product-card:hover,
body:not(.theme-tox) .news-item:hover,
body:not(.theme-tox) .supporter:hover,
body:not(.theme-tox) .topic:hover,
body:not(.theme-tox) .forum-category:hover,
body:not(.theme-tox) .admin-card:hover,
body:not(.theme-tox) .sidebar-card:hover {
  transform: translateY(-7px) scale(1.01);
  border-color: rgba(250, 204, 21, .5);
  box-shadow: 0 24px 58px rgba(0, 0, 0, .34), 0 0 42px rgba(250, 204, 21, .18);
}

body:not(.theme-tox) .product-icon,
body:not(.theme-tox) .avatar,
body:not(.theme-tox) .supporter b {
  background: rgba(250, 204, 21, .13);
  color: #facc15;
  border-color: rgba(250, 204, 21, .34);
  box-shadow: inset 0 0 18px rgba(250, 204, 21, .06), 0 0 18px rgba(250, 204, 21, .08);
}

body:not(.theme-tox) .product-card:nth-child(odd),
body:not(.theme-tox) .sidebar-card:nth-child(odd),
body:not(.theme-tox) .admin-card:nth-child(odd) {
  animation: floatPanel 6.5s ease-in-out infinite;
}

body:not(.theme-tox) .product-card:nth-child(even),
body:not(.theme-tox) .sidebar-card:nth-child(even),
body:not(.theme-tox) .admin-card:nth-child(even) {
  animation: floatPanel 7.2s ease-in-out infinite reverse;
}

body:not(.theme-tox) .topic {
  transition: transform .25s, background .25s, box-shadow .25s;
}

body:not(.theme-tox) .topic:hover {
  background: rgba(250, 204, 21, .07);
}

body:not(.theme-tox) input,
body:not(.theme-tox) select,
body:not(.theme-tox) textarea {
  background: rgba(255, 255, 255, .06);
  border-color: rgba(250, 204, 21, .18);
}

body:not(.theme-tox) input:focus,
body:not(.theme-tox) select:focus,
body:not(.theme-tox) textarea:focus {
  border-color: rgba(250, 204, 21, .55);
  box-shadow: 0 0 0 4px rgba(250, 204, 21, .1);
}

body:not(.theme-tox) .footer {
  border-top-color: rgba(250, 204, 21, .18);
}

body:not(.theme-tox) .toast {
  color: #fff8df;
  background: rgba(16, 12, 5, .94);
  border-color: rgba(250, 204, 21, .34);
  backdrop-filter: blur(14px);
}

@media (max-width: 1120px) {
  .tox-info-card {
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    transform: none;
    width: min(360px, 100%);
  }

  .tox-info-card:hover {
    transform: translateY(-3px);
  }

  .tox-hero {
    flex-direction: column;
    gap: 18px;
    padding-top: 36px;
  }

  .tox-info-left { order: 2; }
  .tox-hero-copy { order: 1; }
  .tox-info-right { order: 3; }
}

@media (max-width: 1040px) {
  .tox-navbar .nav-actions {
    display: none;
  }

  .tox-news-grid,
  .tox-stat-grid,
  .tox-faq-section {
    grid-template-columns: 1fr;
  }

  .tox-faq-section {
    gap: 24px;
  }
}

@media (max-width: 720px) {
  .tox-header {
    min-height: auto;
  }

  .tox-navbar .brand span {
    font-size: 1.4rem;
  }

  .tox-hero {
    min-height: 620px;
    padding-bottom: 58px;
  }

  .tox-hero h1 {
    font-size: clamp(2.5rem, 14vw, 4rem);
  }

  .tox-hero p {
    font-size: 1rem;
  }

  .tox-hero-actions,
  .tox-cta,
  .tox-cta nav {
    display: grid;
    grid-template-columns: 1fr;
  }

  .tox-section {
    padding: 54px 0;
  }

  .tox-news-art {
    min-height: 160px;
  }

  .tox-player-row,
  .tox-player-row:has(> img:first-child) {
    grid-template-columns: 38px minmax(0, 1fr);
  }

  .tox-player-row b,
  .tox-player-row em {
    grid-column: 1 / -1;
  }

  .tox-player-row em {
    justify-self: start;
  }
}


