:root {
    --bg: #070b16;
    --bg-soft: #0d1425;
    --card: rgba(14, 23, 41, .78);
    --card-strong: rgba(16, 28, 52, .94);
    --line: rgba(123, 215, 255, .16);
    --text: #eef7ff;
    --muted: #9cafc8;
    --primary: #00e5ff;
    --primary-2: #8c5cff;
    --danger: #ff5d7a;
    --success: #4dffb0;
    --warning: #ffd166;
    --shadow: 0 24px 80px rgba(0, 0, 0, .45);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    color: var(--text);
    background: var(--bg);
    min-height: 100vh;
    line-height: 1.6;
}
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
.site-bg {
    position: fixed;
    inset: 0;
    z-index: -1;
    background:
        radial-gradient(circle at 20% 10%, rgba(0, 229, 255, .18), transparent 32rem),
        radial-gradient(circle at 78% 18%, rgba(140, 92, 255, .24), transparent 34rem),
        radial-gradient(circle at 50% 100%, rgba(0, 255, 170, .07), transparent 30rem),
        linear-gradient(180deg, #070b16 0%, #09101f 52%, #05070e 100%);
}
.site-bg::after {
    content: "";
    position: absolute;
    inset: 0;
    opacity: .18;
    background-image: linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
    background-size: 48px 48px;
    mask-image: linear-gradient(to bottom, black, transparent 75%);
}
.site-header, .admin-header {
    position: sticky;
    top: 0;
    z-index: 20;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    padding: 1rem clamp(1rem, 4vw, 4rem);
    background: rgba(7, 11, 22, .78);
    border-bottom: 1px solid var(--line);
    backdrop-filter: blur(18px);
}
.logo { display: inline-flex; align-items: center; gap: .75rem; }
.logo-icon, .brand-mark {
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border-radius: 14px;
    color: #031016;
    font-weight: 900;
    background: linear-gradient(135deg, var(--primary), var(--primary-2));
    box-shadow: 0 0 32px rgba(0, 229, 255, .26);
}
.logo strong { display: block; letter-spacing: .04em; line-height: 1; }
.logo small { display: block; color: var(--muted); font-size: .78rem; }
.main-nav { display: flex; align-items: center; flex-wrap: wrap; gap: .65rem; }
.main-nav a, .link-button {
    color: var(--muted);
    padding: .55rem .8rem;
    border-radius: 999px;
    border: 1px solid transparent;
    background: transparent;
    cursor: pointer;
}
.main-nav a:hover, .link-button:hover, .nav-admin {
    color: var(--text);
    border-color: var(--line);
    background: rgba(255,255,255,.05);
}
.section-wrap { width: min(1180px, calc(100% - 2rem)); margin: 0 auto; }
.hero {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(320px, .72fr);
    gap: clamp(2rem, 5vw, 5rem);
    align-items: center;
    min-height: calc(100vh - 78px);
    padding: 5rem 0;
}
.eyebrow {
    color: var(--primary);
    text-transform: uppercase;
    letter-spacing: .18em;
    font-weight: 800;
    font-size: .75rem;
    margin: 0 0 .7rem;
}
h1, h2, h3 { line-height: 1.08; margin: 0; }
h1 { font-size: clamp(2.35rem, 5vw, 4.6rem); letter-spacing: -.055em; }
h2 { font-size: clamp(2rem, 4vw, 3.2rem); letter-spacing: -.04em; }
h3 { font-size: 1.2rem; }
p { color: var(--muted); }
.hero-text { font-size: clamp(1.05rem, 2vw, 1.35rem); max-width: 680px; }
.hero-actions { display: flex; gap: .85rem; flex-wrap: wrap; margin-top: 2rem; }
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    border: 0;
    cursor: pointer;
    border-radius: 999px;
    padding: .85rem 1.15rem;
    font-weight: 800;
    transition: transform .2s ease, border-color .2s ease, background .2s ease;
}
.btn:hover { transform: translateY(-2px); }
.btn-primary {
    color: #031016;
    background: linear-gradient(135deg, var(--primary), #74ffda);
    box-shadow: 0 0 38px rgba(0, 229, 255, .25);
}
.btn-ghost {
    color: var(--text);
    border: 1px solid var(--line);
    background: rgba(255,255,255,.045);
}
.btn-small { padding: .55rem .8rem; font-size: .88rem; color: #06111d; background: var(--primary); }
.hero-metrics { display: grid; grid-template-columns: repeat(3, 1fr); gap: .75rem; margin-top: 2.3rem; max-width: 720px; }
.hero-metrics div, .stat-card {
    padding: 1rem;
    border: 1px solid var(--line);
    border-radius: 20px;
    background: rgba(255,255,255,.04);
}
.hero-metrics strong, .stat-card strong { display: block; font-size: 1.8rem; color: var(--text); }
.hero-metrics span, .stat-card span { color: var(--muted); font-size: .85rem; }
.server-card, .feature-card, .split-panel, .contact-form, .admin-card, .auth-card, .admin-table-wrap {
    border: 1px solid var(--line);
    border-radius: 30px;
    background: var(--card);
    box-shadow: var(--shadow);
    backdrop-filter: blur(16px);
}
.server-card { padding: 1.4rem; transform: perspective(1200px) rotateY(-5deg) rotateX(2deg); }
.static-card { transform: none; }
.server-topline { display: flex; align-items: center; gap: .55rem; color: var(--muted); font-weight: 800; }
.pulse { width: 10px; height: 10px; border-radius: 99px; background: var(--success); box-shadow: 0 0 0 0 rgba(77, 255, 176, .8); animation: pulse 1.8s infinite; }
.server-map {
    min-height: 220px;
    display: grid;
    place-items: center;
    margin: 1rem 0;
    border-radius: 24px;
    font-size: clamp(2rem, 5vw, 4rem);
    font-weight: 950;
    letter-spacing: -.06em;
    background:
        linear-gradient(135deg, rgba(0,229,255,.2), rgba(140,92,255,.2)),
        repeating-linear-gradient(45deg, rgba(255,255,255,.05) 0 1px, transparent 1px 14px);
    border: 1px solid rgba(255,255,255,.08);
}
.loadbar { height: 10px; border-radius: 999px; background: rgba(255,255,255,.08); overflow: hidden; }
.loadbar span { display: block; height: 100%; background: linear-gradient(90deg, var(--primary), var(--primary-2)); }
.server-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: .75rem; margin: 1rem 0; }
.server-grid.roomy { grid-template-columns: 1fr; }
.server-grid div { padding: .9rem; border-radius: 18px; background: rgba(0,0,0,.2); border: 1px solid rgba(255,255,255,.07); }
.server-grid span { display: block; color: var(--muted); font-size: .82rem; }
.server-grid strong { font-size: 1.05rem; }

.live-server-card { position: relative; overflow: hidden; }
.live-server-card::after {
    content: '';
    position: absolute;
    inset: auto -25% -35% 35%;
    height: 160px;
    background: radial-gradient(circle, rgba(0,229,255,.18), transparent 68%);
    pointer-events: none;
}
.live-server-card.is-offline .pulse { background: var(--danger); box-shadow: none; animation: none; }
.live-server-card.is-offline .server-map { color: rgba(255,255,255,.52); }
.connect-box {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: .65rem;
    align-items: center;
    margin-top: .85rem;
}
.connect-box code {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.copy-btn {
    color: var(--text);
    background: rgba(255,255,255,.07);
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: .55rem .75rem;
    font-weight: 800;
    cursor: pointer;
}
.copy-btn:hover { border-color: rgba(0,229,255,.45); }
.full-btn { width: 100%; margin-top: .75rem; }
.server-updated { margin: .85rem 0 0; }
code { color: var(--primary); background: rgba(0,0,0,.3); border: 1px solid var(--line); border-radius: 12px; padding: .35rem .5rem; }
.service-section, .page-top { padding: 5rem 0; }
.section-heading { max-width: 760px; margin-bottom: 2rem; }
.cards-grid, .infra-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.feature-card { padding: 1.25rem; min-height: 230px; }
.card-icon { display: inline-grid; place-items: center; width: 48px; height: 48px; border-radius: 16px; background: rgba(0,229,255,.1); margin-bottom: 1.2rem; }
.split-panel {
    display: grid;
    grid-template-columns: 1fr .9fr;
    gap: 2rem;
    align-items: center;
    padding: clamp(1.3rem, 4vw, 3rem);
    margin-bottom: 4rem;
}
.panel-list { display: grid; gap: .75rem; }
.panel-list span { padding: .9rem 1rem; border-radius: 18px; background: rgba(255,255,255,.045); border: 1px solid var(--line); color: var(--text); }
.cta { text-align: center; padding: 4rem 1rem 6rem; }
.cta p { max-width: 680px; margin: 1rem auto 2rem; }
.plugin-list { display: grid; gap: .9rem; }
.plugin-row {
    display: grid;
    grid-template-columns: 120px 1fr auto;
    gap: 1.2rem;
    align-items: center;
    padding: 1.25rem;
    border: 1px solid var(--line);
    border-radius: 26px;
    background: rgba(255,255,255,.04);
}
.plugin-tag { color: var(--primary); font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace; }
.contact-page { max-width: 940px; }
.contact-form {
    display: grid;
    gap: 1.25rem;
    padding: clamp(1.25rem, 3vw, 2.1rem);
}
.contact-form > .btn { justify-self: start; margin-top: .1rem; }
.contact-form .small-muted { margin: -.35rem 0 0; }
.form-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.15rem 1.25rem; }
label { display: grid; gap: .55rem; color: var(--text); font-weight: 700; }
input, select, textarea {
    width: 100%;
    color: var(--text);
    background: rgba(0,0,0,.28);
    border: 1px solid var(--line);
    border-radius: 16px;
    padding: .9rem 1rem;
    outline: none;
}
textarea { resize: vertical; min-height: 210px; }
input:focus, select:focus, textarea:focus { border-color: rgba(0,229,255,.6); box-shadow: 0 0 0 4px rgba(0,229,255,.08); }
.hp-field { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.small-muted { color: var(--muted); font-size: .86rem; }
.alert { padding: 1rem; border-radius: 18px; border: 1px solid; margin-bottom: 1rem; }
.alert-success { color: #d8fff0; background: rgba(77,255,176,.12); border-color: rgba(77,255,176,.35); }
.alert-error { color: #ffe8ed; background: rgba(255,93,122,.12); border-color: rgba(255,93,122,.35); }
.legal-page { max-width: 860px; }
.site-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 2rem clamp(1rem, 4vw, 4rem);
    border-top: 1px solid var(--line);
    color: var(--muted);
}
.footer-links { display: flex; gap: 1rem; flex-wrap: wrap; }
.footer-links a:hover { color: var(--primary); }
.install-page { background: radial-gradient(circle at 50% 0%, rgba(0,229,255,.18), transparent 40rem), var(--bg); }
.auth-shell { min-height: 100vh; display: grid; place-items: center; padding: 1rem; }
.auth-card { width: min(460px, 100%); padding: 2rem; }
.brand-mark { margin-bottom: 1rem; }
.stack-form { display: grid; gap: 1rem; }
.back-link { display: inline-block; margin-top: 1rem; color: var(--muted); }
.admin-body { background: #07101f; }
.admin-main { width: min(1200px, calc(100% - 2rem)); margin: 0 auto; padding: 2rem 0 4rem; }
.inline-form { display: inline; }
.admin-titlebar { display: flex; justify-content: space-between; gap: 1rem; align-items: flex-end; margin-bottom: 1.5rem; }
.admin-user { color: var(--muted); }
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: .8rem; margin-bottom: 1rem; }
.stat-card { display: block; }
.stat-card:hover { border-color: rgba(0,229,255,.45); }
.filter-row { display: flex; flex-wrap: wrap; gap: .5rem; margin: 1rem 0; }
.filter-row a { color: var(--muted); border: 1px solid var(--line); border-radius: 999px; padding: .45rem .8rem; }
.filter-row a.active, .filter-row a:hover { color: var(--text); background: rgba(0,229,255,.1); }
.admin-table-wrap { overflow: auto; }
.admin-table { width: 100%; border-collapse: collapse; min-width: 820px; }
.admin-table th, .admin-table td { text-align: left; padding: 1rem; border-bottom: 1px solid var(--line); vertical-align: top; }
.admin-table th { color: var(--muted); font-size: .82rem; text-transform: uppercase; letter-spacing: .08em; }
.click-row { cursor: pointer; }
.click-row:hover { background: rgba(0,229,255,.06); }
.badge { display: inline-flex; border-radius: 999px; padding: .22rem .58rem; font-size: .78rem; font-weight: 900; border: 1px solid; }
.badge-new { color: #07101f; background: var(--primary); border-color: var(--primary); }
.badge-open { color: #07101f; background: var(--warning); border-color: var(--warning); }
.badge-answered { color: #07101f; background: var(--success); border-color: var(--success); }
.badge-closed { color: var(--muted); background: rgba(255,255,255,.05); border-color: var(--line); }
.empty-state { text-align: center; color: var(--muted); padding: 3rem !important; }
.inquiry-grid { display: grid; grid-template-columns: minmax(0, 1fr) 360px; gap: 1rem; align-items: start; }
.admin-card { padding: 1.3rem; }
.detail-list { display: grid; gap: .65rem; }
.detail-list div { display: grid; grid-template-columns: 140px 1fr; gap: 1rem; border-bottom: 1px solid var(--line); padding-bottom: .65rem; }
.detail-list dt { color: var(--muted); }
.detail-list dd { margin: 0; }
.message-box { white-space: normal; color: var(--text); background: rgba(0,0,0,.25); border: 1px solid var(--line); border-radius: 18px; padding: 1rem; }
.reply-card { margin-top: 1rem; }
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .55s ease, transform .55s ease; }
.reveal.is-visible { opacity: 1; transform: none; }
.delay-1 { transition-delay: .12s; }
@keyframes pulse { 70% { box-shadow: 0 0 0 12px rgba(77,255,176,0); } 100% { box-shadow: 0 0 0 0 rgba(77,255,176,0); } }
@media (max-width: 920px) {
    .hero, .split-panel, .inquiry-grid { grid-template-columns: 1fr; }
    .server-card { transform: none; }
    .cards-grid, .infra-grid { grid-template-columns: repeat(2, 1fr); }
    .stats-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 680px) {
    .site-header, .admin-header { align-items: flex-start; flex-direction: column; }
    .main-nav { width: 100%; }
    .main-nav a, .link-button { padding: .45rem .65rem; }
    .hero { min-height: auto; padding: 3rem 0; }
    .hero-metrics, .cards-grid, .infra-grid, .form-grid { grid-template-columns: 1fr; }
    .game-toolbar { align-items: stretch; flex-direction: column; }
    .game-toolbar input { max-width: none; }
    .plugin-row { grid-template-columns: 1fr; }
    .site-footer { flex-direction: column; align-items: flex-start; }

    .connect-box { grid-template-columns: 1fr; }
    .connect-box code { white-space: normal; overflow-wrap: anywhere; }
    h1 { font-size: clamp(2.3rem, 12vw, 3.6rem); }
    .admin-titlebar { align-items: flex-start; flex-direction: column; }
    .detail-list div { grid-template-columns: 1fr; gap: .2rem; }
}

.games-section { padding-top: 3rem; }
.game-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}
.game-toolbar input { max-width: 560px; }
.game-toolbar span { color: var(--muted); font-weight: 800; white-space: nowrap; }
.popular-games, .game-list {
    display: flex;
    flex-wrap: wrap;
    gap: .55rem;
}
.game-pill {
    display: inline-flex;
    align-items: center;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: rgba(255,255,255,.045);
    color: var(--muted);
    padding: .48rem .72rem;
    font-weight: 750;
    font-size: .92rem;
}
.game-pill:hover, .featured-game {
    color: var(--text);
    border-color: rgba(0,229,255,.48);
    background: rgba(0,229,255,.09);
}
.game-list-panel {
    margin-top: 1rem;
    padding: 1rem;
    border: 1px solid var(--line);
    border-radius: 24px;
    background: rgba(255,255,255,.035);
}
.game-list-panel summary {
    cursor: pointer;
    color: var(--text);
    font-weight: 900;
    margin-bottom: .75rem;
}
.game-list-panel:not([open]) summary { margin-bottom: 0; }
.game-pill.is-hidden { display: none; }
.full-field { grid-column: 1 / -1; }

/* Clean homepage sections without large card boxes */
.clean-section {
    padding: 4rem 0;
    border-top: 1px solid rgba(123, 215, 255, .12);
}
.clean-section h2 {
    max-width: 860px;
    margin: .2rem 0 1rem;
}
.clean-section p {
    max-width: 900px;
    color: var(--muted);
}
.fact-line {
    display: flex;
    flex-wrap: wrap;
    gap: .65rem;
    margin-top: 1.4rem;
}
.fact-line span {
    display: inline-flex;
    align-items: center;
    border: 1px solid rgba(123, 215, 255, .18);
    border-radius: 999px;
    padding: .5rem .8rem;
    color: var(--text);
    background: rgba(255,255,255,.035);
    font-weight: 850;
}
.compact-actions { margin-top: 1.4rem; }
.clean-list {
    display: grid;
    gap: .15rem;
    margin-top: 1.4rem;
    border-top: 1px solid rgba(123, 215, 255, .16);
}
.clean-list div {
    display: grid;
    grid-template-columns: minmax(220px, .35fr) 1fr;
    gap: 1rem;
    padding: 1rem 0;
    border-bottom: 1px solid rgba(123, 215, 255, .16);
}
.clean-list strong {
    color: var(--text);
    font-size: 1.02rem;
}
.clean-list span {
    color: var(--muted);
}
.clean-cta {
    padding-bottom: 6rem;
}
.clean-cta .btn { margin-top: 1rem; }

/* Separate Gameliste page */
.games-directory-page {
    max-width: 1120px;
}
.game-directory-toolbar {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: center;
    margin: 2rem 0 1.25rem;
}
.game-directory-toolbar span {
    color: var(--muted);
    font-weight: 900;
    white-space: nowrap;
}
.game-directory-list {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    border-top: 1px solid rgba(123, 215, 255, .18);
}
.game-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: .9rem 0;
    margin-right: 1.3rem;
    border-bottom: 1px solid rgba(123, 215, 255, .14);
    color: var(--text);
}
.game-row span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-weight: 820;
}
.game-row small {
    flex: 0 0 auto;
    color: var(--primary);
    font-weight: 850;
    opacity: .82;
}
.game-row:hover span,
.game-row:hover small { color: var(--primary); }
.game-row.is-special span { color: var(--primary); }
.game-row.is-hidden { display: none; }

@media (max-width: 920px) {
    .game-directory-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 680px) {
    .clean-list div { grid-template-columns: 1fr; gap: .25rem; }
    .game-directory-toolbar { grid-template-columns: 1fr; }
    .game-directory-list { grid-template-columns: 1fr; }
    .game-row { margin-right: 0; }
}
