/* ---- Self-hosted Arimo (metric-identical to Helvetica, Apache-2.0). -------
   Wer eine echte "Helvetica Neue"-Lizenz besitzt, kann die woff2-Dateien in
   /static/fonts/ 1:1 austauschen — der Stack greift dann automatisch. -------- */
@font-face{font-family:"Arimo";font-style:normal;font-weight:400;font-display:swap;
  src:url("/static/fonts/arimo-latin-400-normal.woff2") format("woff2")}
@font-face{font-family:"Arimo";font-style:normal;font-weight:500;font-display:swap;
  src:url("/static/fonts/arimo-latin-500-normal.woff2") format("woff2")}
@font-face{font-family:"Arimo";font-style:normal;font-weight:700;font-display:swap;
  src:url("/static/fonts/arimo-latin-700-normal.woff2") format("woff2")}

:root{
  --bg:#0f1113; --bg2:#14171a; --card:#181b1f; --line:#262b30;
  --txt:#e7e9ec; --mut:#99a2ab; --accent:#d8602a; --discord:#5865f2; --ok:#3fb763; --off:#7a828b;
  --radius:12px;
  --font:"Arimo",Helvetica,Arial,sans-serif;
  --mono:ui-monospace,SFMono-Regular,"SF Mono",Menlo,Consolas,"Liberation Mono",monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--txt);font:16px/1.6 var(--font);-webkit-font-smoothing:antialiased;overflow-x:clip}
a{color:inherit;text-decoration:none}
.wrap{max-width:1320px;margin:0 auto;padding:0 24px}
.muted{color:var(--mut)}

/* accessibility: visible focus, skip-link, screenreader-only */
a:focus-visible,button:focus-visible,input:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}
.skip{position:absolute;left:-9999px;top:0;z-index:30;background:var(--accent);color:#fff;font-weight:700;padding:10px 14px;border-radius:0 0 8px 0}
.skip:focus{left:0}
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* header / footer */
header.site{border-bottom:1px solid var(--line);background:var(--bg2);position:sticky;top:0;z-index:10}
.navbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-top:14px;padding-bottom:14px;position:relative}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:.3px;font-size:20px;color:#fff;flex-shrink:0}
.brandlogo{display:block;width:34px;height:34px;border-radius:7px}
.brandtext span{color:var(--accent);font-weight:700}
nav{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
nav a{color:#cbd2d9;font-weight:600;font-size:14px}
nav a:hover{color:#fff}
nav .who{color:var(--txt);font-size:13px}

/* mobile nav toggle (hamburger) — hidden on desktop */
.navtoggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;padding:10px;background:transparent;border:1px solid var(--line);border-radius:9px;cursor:pointer;flex-shrink:0}
.navtoggle-bar{display:block;width:100%;height:2px;background:#fff;border-radius:2px;transition:transform .2s,opacity .2s}
.navtoggle[aria-expanded="true"] .navtoggle-bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
.navtoggle[aria-expanded="true"] .navtoggle-bar:nth-child(2){opacity:0}
.navtoggle[aria-expanded="true"] .navtoggle-bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
footer.site{border-top:1px solid var(--line);margin-top:64px;padding:26px 0;color:var(--mut);font-size:13px;text-align:center}
footer.site a{color:var(--accent)}

/* buttons */
.btn{display:inline-block;background:var(--accent);color:#fff;font-weight:700;font-size:14px;padding:10px 16px;border:0;border-radius:9px;cursor:pointer;transition:.15s}
.btn:hover{filter:brightness(1.08)}
.btn.block{display:block;text-align:center;margin-top:12px}
.btn.small{padding:7px 12px;font-size:13px}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--txt)}
.btn.discord{background:var(--discord)}
/* CTA-Vereinheitlichung: Vote-Button immer Marken-Orange, unabhängig vom Server-Akzent des Blocks */
.btn.vote{background:#d8602a}
.btn.ghost.support{color:var(--mut)}
.btn.ghost.support:hover{color:var(--txt);border-color:var(--accent);filter:none}
.btn.steam{background:#1b2838} .btn[disabled]{opacity:.5;cursor:default}

/* hero — full-bleed: Hintergrund über die gesamte Seitenbreite, Inhalt zentriert */
.hero{position:relative;text-align:center;padding:84px 24px 52px;overflow:hidden;
  margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(216,96,42,.13), transparent 58%),
    radial-gradient(90% 60% at 50% 120%, rgba(32,200,182,.05), transparent 60%),
    linear-gradient(#0f1113,#0b0c0e)}
/* feines technisches Raster + Vignette für Tiefe (kein Bild-Asset) */
.hero::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:46px 46px;
  -webkit-mask-image:radial-gradient(120% 90% at 50% 0%,#000 35%,transparent 80%);
  mask-image:radial-gradient(120% 90% at 50% 0%,#000 35%,transparent 80%)}
.hero::after{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  box-shadow:inset 0 -90px 80px -60px var(--bg)}
.hero-inner{position:relative;z-index:1;max-width:1320px;margin:0 auto}
.hero.small{padding:48px 24px 24px;background:none}
.hero.small::before,.hero.small::after{display:none}
.hero h1{font-size:clamp(34px,6vw,60px);font-weight:700;letter-spacing:.5px}
.hero h1 span{color:var(--accent)}
.hero p{color:var(--mut);max-width:660px;margin:16px auto 0}
.tags{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin:26px auto 0;max-width:720px}
.tag{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);background:rgba(20,23,26,.7);
  padding:7px 13px;border-radius:9px;font-size:13px;font-weight:500;color:var(--txt)}
.tag svg{width:15px;height:15px;color:var(--accent);flex-shrink:0}
.tag--strong{border-color:rgba(63,183,99,.45);background:rgba(63,183,99,.08);font-weight:700}
.tag--strong svg{color:var(--ok)}
.liveband{margin-top:28px;font-size:16px;color:var(--mut)}
.liveband strong{color:var(--txt);font-size:20px;font-weight:700}
.live-dot{display:inline-block;width:9px;height:9px;border-radius:50%;background:var(--ok);
  margin-right:8px;vertical-align:middle;box-shadow:0 0 0 0 rgba(63,183,99,.6);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(63,183,99,.5)}70%{box-shadow:0 0 0 7px rgba(63,183,99,0)}100%{box-shadow:0 0 0 0 rgba(63,183,99,0)}}
@media(prefers-reduced-motion:reduce){.live-dot{animation:none}}

.sec{font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--mut);text-align:center;margin:54px 0 22px}
.hl{color:var(--txt);font-weight:500;border-bottom:1px solid var(--accent)}

/* error pages (404/403) */
.errpage{padding:72px 0 56px}
.errcode{font-size:clamp(72px,16vw,140px);font-weight:700;line-height:1;color:var(--accent);
  letter-spacing:2px;opacity:.92}
.errpage h1{font-size:clamp(22px,4vw,30px);margin-top:6px}
.errcta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:24px}

/* server cards */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:980px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.grid{grid-template-columns:1fr}}
.card{position:relative;min-width:0;background:var(--card);border:1px solid var(--line);border-top:3px solid var(--accent);border-radius:var(--radius);padding:18px;display:flex;flex-direction:column}
.card--featured{box-shadow:0 0 0 1px var(--accent), 0 18px 46px -22px var(--accent);background:linear-gradient(180deg,rgba(255,92,30,.06),transparent 140px),var(--card)}
.popular{position:absolute;top:-11px;right:16px;background:var(--accent);color:#fff;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:4px 10px;border-radius:6px;box-shadow:0 4px 14px -4px var(--accent)}
.cardhead{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.cad{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent)}
.cardhead h3{font-size:20px;margin-top:2px}
.status{font-size:12px;font-weight:700;padding:4px 9px;border-radius:20px;white-space:nowrap}
.status.on{background:rgba(63,183,99,.15);color:var(--ok)} .status.off{background:rgba(122,130,139,.15);color:var(--off)}

.mapbox{margin:14px 0}
.mapbox img{width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:10px;display:block;background:#000}
.mapph{width:100%;aspect-ratio:16/10;display:flex;align-items:center;justify-content:center;text-align:center;padding:14px;color:var(--mut);font-size:13px;background:var(--bg2);border:1px dashed var(--line);border-radius:10px}
.maprow{display:flex;justify-content:space-between;font-size:12px;color:var(--mut);margin-top:8px}
.maprow a{color:var(--accent)}

.stats{list-style:none;margin:6px 0 14px}
.stats li{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--line);font-size:14px}
.stats li span{color:var(--mut)} .stats li b{font-weight:700}
.stats li b i{font-style:normal;color:var(--accent)}

/* Quick-Connect: Terminal-Snippet, kein Abschneiden mehr */
.connect{display:flex;align-items:stretch;gap:0;background:var(--bg);border:1px solid var(--line);border-radius:9px;overflow:hidden}
.connect-prompt{display:flex;align-items:center;padding:0 4px 0 11px;color:var(--accent);font-family:var(--mono);font-weight:700;font-size:13px;user-select:none}
.connect code{flex:1;min-width:0;background:transparent;border:0;padding:10px 8px;font-family:var(--mono);font-size:12.5px;line-height:1.4;white-space:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.connect code::-webkit-scrollbar{display:none}
.copy{background:var(--bg2);border:0;border-left:1px solid var(--line);color:var(--txt);padding:0 14px;font-size:12.5px;font-weight:700;cursor:pointer;flex-shrink:0}
.copy:hover{background:#22262b;color:var(--accent)}

.howto ol{max-width:680px;margin:0 auto;padding-left:20px}
.howto li{margin:8px 0} .howto code{background:var(--bg2);border:1px solid var(--line);border-radius:6px;padding:2px 6px;font-size:13px}
.howto p{text-align:center;margin-top:14px}

/* vote */
.nick{margin-top:14px;font-size:14px}
.nick input{background:var(--bg2);border:1px solid var(--line);color:var(--txt);border-radius:8px;padding:8px 10px;margin:0 6px}
.voteblock{margin:36px 0;border:1px solid var(--line);border-top:3px solid var(--accent);border-radius:var(--radius);padding:20px;background:var(--card)}
.vbhead{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.vbhead h2{font-size:22px}
.cands{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.cand{border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--bg2);display:flex;flex-direction:column}
.cand.won{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent) inset}
.cand .mapbox{margin:0}
.cand .mapbox img{aspect-ratio:1/1;max-height:420px;border-radius:0}
.cand .mapph{aspect-ratio:1/1}
.candbody{padding:14px;display:flex;flex-direction:column;gap:8px}
.candtop{display:flex;justify-content:space-between;align-items:baseline}
.mons{font-size:12px;margin:0}
.bar{height:8px;background:var(--bg);border-radius:6px;overflow:hidden}
.bar span{display:block;height:100%;border-radius:6px;background:var(--accent);transform-origin:left;animation:grow .7s cubic-bezier(.22,1,.36,1)}
@keyframes grow{from{transform:scaleX(0)}to{transform:scaleX(1)}}
@media(prefers-reduced-motion:reduce){.bar span{animation:none}}
.barrow{display:flex;justify-content:space-between;font-size:13px}
.yourvote{color:var(--accent);font-weight:700;font-size:14px;text-align:center;padding:8px}

/* rules language toggle (DE/EN) */
.langtoggle{display:inline-flex;gap:4px;margin-top:18px;padding:4px;background:var(--bg2);border:1px solid var(--line);border-radius:10px}
.langbtn{background:transparent;border:0;color:var(--mut);font-weight:600;font-size:14px;padding:7px 16px;border-radius:7px;cursor:pointer;transition:.15s}
.langbtn:hover{color:var(--txt)}
.langbtn.is-active{background:var(--accent);color:#fff}

/* legal / rules (ToS-Layout mit Sticky-Inhaltsverzeichnis) */
.legal{display:grid;grid-template-columns:220px 1fr;gap:40px;margin:24px 0 16px;align-items:start}
.legal-toc{position:sticky;top:86px;display:flex;flex-direction:column;gap:2px;border-left:2px solid var(--line);padding-left:14px}
.legal-toc-title{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--mut);margin-bottom:8px}
.legal-toc a{color:var(--mut);font-size:14px;font-weight:500;padding:5px 0}
.legal-toc a:hover{color:var(--txt)}
.legal-body{min-width:0}
.legal-sec{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;margin-bottom:18px;scroll-margin-top:86px}
.legal-sec h2{font-size:19px;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--line)}
.legal-sec ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.legal-sec ul ul{margin-top:10px;padding-left:18px;gap:7px}
.legal-sec li{position:relative;padding-left:20px;color:var(--txt);line-height:1.6}
.legal-sec li::before{content:"";position:absolute;left:2px;top:11px;width:6px;height:6px;border-radius:2px;background:var(--accent)}
.legal-sec li b{font-weight:700}
.legal-sec code{background:var(--bg2);border:1px solid var(--line);border-radius:6px;padding:1px 6px;font-family:var(--mono);font-size:13px}
.legal-foot{margin-top:16px;padding-top:6px}
.legal-foot a{color:var(--accent)}
@media(max-width:760px){
  .legal{grid-template-columns:1fr;gap:18px}
  .legal-toc{position:static;flex-flow:row wrap;gap:8px 16px;border-left:0;border-top:1px solid var(--line);padding:12px 0 0}
  .legal-toc-title{width:100%;margin-bottom:0}
}

.admintbl{width:100%;border-collapse:collapse;margin-top:10px;font-size:14px}
.admintbl th,.admintbl td{text-align:left;padding:8px;border-bottom:1px solid var(--line)}

@media(max-width:560px){.cands{grid-template-columns:1fr}}

/* ============ responsive / mobile ============ */
@media(max-width:720px){
  .navtoggle{display:flex}
  nav#primary-nav{display:none;position:absolute;left:0;right:0;top:100%;flex-direction:column;align-items:stretch;gap:0;
    background:var(--bg2);border:1px solid var(--line);border-radius:0 0 12px 12px;padding:8px 22px 14px;
    box-shadow:0 14px 28px rgba(0,0,0,.4);max-height:calc(100vh - 76px);overflow-y:auto;z-index:20}
  nav#primary-nav.open{display:flex}
  nav#primary-nav a,nav#primary-nav .who{display:flex;align-items:center;min-height:44px;font-size:16px;padding:6px 2px}
  nav#primary-nav .btn{display:flex;align-items:center;justify-content:center;min-height:44px;margin-top:8px}
  .hero{padding:44px 20px 28px}
  .hero.small{padding:30px 20px 16px}
}
@media(max-width:768px){
  .tablewrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .admintbl{min-width:520px}
  .nick{flex-wrap:wrap;align-items:stretch}
  .nick input{width:100%;margin:8px 0 0}
  .copy{min-height:44px;padding:0 16px}
  .btn.small{min-height:40px}
}
@media(max-width:560px){
  .brand{font-size:19px}
  .wrap{padding:0 16px}
  nav#primary-nav{padding-left:16px;padding-right:16px}
}
/* große Monitore: Inhalt deutlich breiter, damit er nicht als schmale Mittelspalte wirkt */
@media(min-width:1600px){
  .wrap{max-width:1500px}
  .hero-inner{max-width:1500px}
}

/* --- SEO additions: breadcrumbs, server-detail grid, FAQ accordion --- */
.crumbs{max-width:1320px;margin:18px auto 0;padding:0 24px;font-size:13px;color:var(--mut)}
.crumbs a{color:var(--mut)}
.crumbs a:hover{color:var(--txt)}
.crumbs span{color:var(--txt)}
.grid.grid--2{grid-template-columns:1fr 1fr}
.cardlinks{margin-top:auto;display:flex;flex-direction:column;gap:8px}
.cardlinks .btn.block{margin-top:0}
.faq{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:4px 18px}
.faq-item summary{cursor:pointer;list-style:none;display:flex;align-items:center;gap:10px;padding:14px 0}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::before{content:"+";color:var(--accent);font-weight:700;font-size:20px;line-height:1}
.faq-item[open] summary::before{content:"\2013"}
.faq-item summary h2{display:inline;font-size:17px;font-weight:600;margin:0}
.faq-item p{color:var(--mut);margin:0 0 14px;padding-left:20px}
.faq-foot{text-align:center;margin-top:22px}
@media(max-width:720px){.grid.grid--2{grid-template-columns:1fr}}
/* safety net: a .legal page without a TOC must still span full width */
.legal-body:only-child{grid-column:1 / -1}
