/* Staff-Card Utilities */
.desc-label {
  font-weight:600;
  opacity:.7;
  min-width:6.5em;
  display:inline-block;
}
.desc-text {
  flex:1;
  display:inline-block;
  word-break:break-word;
}
.desc-placeholder {
  opacity:.4;
  font-style:italic;
}
/* ======= Verbesserte Formular-Übersichtlichkeit ======= */
.form-row {
  display: flex;
  flex-direction: column;
  gap: 0.15em;
  margin-bottom: 1.2em;
}

form {
  margin-left: 0;
  border-radius: 0px;
}

form label {
  font-weight: 500;
  color: var(--footer-link);
  margin-bottom: 0.2em;
}

form small {
  color: #b0b0b0;
  font-size: 0.93em;
  margin-top: 0.1em;
}

form .btn, form button[type="submit"] {
  margin-top: 0.7em;
  font-size: 1.08em;
  font-weight: 600;
  letter-spacing: 0.03em;
  width: auto;
  max-width: 20ch; /* Buttons auch begrenzen */
}

form a {
  display: inline-block;
  margin-top: 1.1em;
  color: var(--accent);
  font-size: 0.97em;
}
form a:hover { color: var(--footer-link); }
/* Unified form control styling */
/* Kompakte Breite für Eingabefelder und Selects, nur Textareas dürfen volle Breite nutzen */
input[type="text"],
input[type="password"],
input[type="email"],
input[type="number"],
select {
  min-height: 40px;
  width: 100%;
  max-width: 20ch; /* kompakt: nur ~20 Zeichen breit */
  box-sizing: border-box;
  background: #222;
  color: #f3f3f3;
  border: 1px solid #444;
  border-radius: 4px;
  padding: 0.4em 0.7em;
  font-size: 1em;
  margin-bottom: 0.7em;
  transition: border 0.2s, background 0.2s;
}

textarea {
  width: 100%;
  box-sizing: border-box;
  background: #222;
  color: #f3f3f3;
  border: 1px solid #444;
  border-radius: 4px;
  padding: 0.4em 0.7em;
  font-size: 1em;
  margin-bottom: 0.7em;
  transition: border 0.2s, background 0.2s;
}

input[type="text"]:focus, input[type="password"]:focus, input[type="email"]:focus, input[type="number"]:focus, select:focus, textarea:focus {
  border-color: var(--accent);
  background: #262e36;
  outline: none;
}

/*
 * Style für Community, angepasst an das Blog-Design von midiandmore.net (August 2025)
 * Autor: Automatisch generiert
 */

:root {


  --hover-link: #b3002d;
  --main-bg: #181c1f;
  --main-fg: #f3f3f3;
  --accent: #2e8ece;
  --accent-hover: #1b5e8c;
  --header-bg: #23272b;
  --nav-bg: #23272b;
  --nav-link: #f3f3f3;
  --nav-link-hover: #2e8ece;
  --card-bg: #23272b;
  --footer-bg: #181A1B;
  --footer-border: #333;
  --footer-link: #FFB300;
  --border-radius: 8px;
  --shadow: 0 2px 8px rgba(0,0,0,0.08);
  --font-main: 'Segoe UI', 'Arial', sans-serif;
}

body {
  background: var(--main-bg);
  color: var(--main-fg);
  font-family: var(--font-main);
  margin: 0;
  padding: 0;
  min-height: 100vh;
}

/* Helper layout constraints */
.container-narrow { max-width: 880px; margin: 0 auto; padding: 0 1rem; }
.container-wide { max-width: 1220px; margin: 0 auto; padding: 0 1.2rem; }


.headerbar {
  background: var(--header-bg);
  box-shadow: var(--shadow);
  display:flex;
  align-items:center;
  gap:1rem;
  justify-content:flex-start;
  padding: 0.5rem 2vw;
}

/* Right side wrapper for language + stats */
.header-right { margin-left:auto; display:flex; align-items:center; gap:.6rem; }
.header-right .lang-dd { margin:0; }
.header-right .header-stats { margin-left:0; }

.logo-fullheight {
  height: 48px;
  margin-right: 1.5rem;
}

nav.nav-inline { display:flex; flex-direction:row; gap:.6rem; align-items:center; }
nav.nav-inline .lang-dd { /* integriert zwischen den Links */ flex:0 0 auto; }
nav.nav-inline .lang-dd select { min-width:4.2rem; }

/* Hamburger Button (reintroduced) */
.nav-toggle { 
  background:#1d2226; 
  border:1px solid #2b3338; 
  border-radius:6px; 
  cursor:pointer; 
  display:none; 
  flex-direction:column; 
  justify-content:center; 
  align-items:center; 
  height:48px; /* Logo-Höhe */
  width:48px; 
  gap:5px; 
}
.nav-toggle span { 
  display:block; 
  height:3px; 
  width:24px; 
  background:var(--footer-link); 
  border-radius:2px; 
  transition:transform .35s ease, opacity .35s ease; 
}
body.nav-open .nav-toggle span:nth-child(1){ transform:translateY(8px) rotate(45deg); }
body.nav-open .nav-toggle span:nth-child(2){ opacity:0; }
body.nav-open .nav-toggle span:nth-child(3){ transform:translateY(-8px) rotate(-45deg); }

/* Mobile collapse logic */
@media (max-width: 880px) {
  .nav-toggle { display:flex; }
  .headerbar { position:relative; flex-wrap:nowrap; }
  /* Overlay-Menü links, Headerhöhe bleibt konstant */
  .nav-scroll { 
    position:absolute; 
    top:100%; 
    left:0; 
    width:260px; 
    background:#1d2226; 
    border:1px solid #2b3338; 
    border-top:none; 
    box-shadow:0 6px 16px rgba(0,0,0,.45); 
    display:none; 
    padding:.6rem .6rem .9rem; 
    max-height:70vh; 
    overflow-y:auto; 
    z-index:1200; 
    border-bottom-left-radius:8px; 
    border-bottom-right-radius:8px; 
  }
  body.nav-open .nav-scroll { display:block; animation:navSlide .35s ease; }
  /* Backdrop für bessere Fokussierung */
  .nav-backdrop {
    position:fixed; inset:0; background:rgba(0,0,0,.45); display:none; z-index:1100;
  }
  body.nav-open .nav-backdrop { display:block; }
  /* Body-Scroll sperren wenn Menü offen */
  body.nav-open { overflow:hidden; }
  @keyframes navSlide { from { opacity:0; transform:translateY(-6px); } to { opacity:1; transform:translateY(0); } }
  nav.nav-inline { flex-direction:column; align-items:stretch; gap:.35rem; }
  nav.nav-inline a { width:100%; background:#232a2f; border:1px solid #2b3338; border-radius:6px; padding:.6rem .7rem; font-size:.95rem; }
  nav.nav-inline a:hover { background:#27343b; }
  nav.nav-inline .lang-dd { margin-left:0; width:100%; }
  nav.nav-inline .lang-dd select { width:100%; }
}

nav a {
  color: var(--footer-link);
  text-decoration: none;
  font-weight: 500;
  padding: 0.3em 0.8em;
  border-radius: 4px;
  transition: background 0.2s, color 0.2s;
}



/* Language dropdown */
.lang-dd select { 
  background:#1d2226; 
  color:var(--footer-link); 
  border:1px solid #2b3338; 
  padding:.35rem .65rem; /* gleiche vertikale/horizontale Polsterung wie Links */
  border-radius:6px; 
  font-size:.8rem; 
}
.nav-inline .lang-dd { display:flex; align-items:center; }
.nav-inline .lang-dd select { margin:0; line-height:1.2; }
.lang-dd select:focus { outline:2px solid var(--accent); outline-offset:2px; }

/* Scroll container for nav */
.nav-scroll { flex:1; overflow-x:auto; overflow-y:hidden; }
.nav-scroll::-webkit-scrollbar { height:8px; }
.nav-scroll::-webkit-scrollbar-track { background:#1d2226; }
.nav-scroll::-webkit-scrollbar-thumb { background:var(--accent); border-radius:4px; }
.nav-scroll::-webkit-scrollbar-thumb:hover { background:var(--accent-hover); }

nav.nav-inline a { white-space:nowrap; padding:.35rem .65rem; background:#1d2226; border:1px solid #2b3338; }
nav.nav-inline a:hover { background:#253038; }

nav a:hover, nav a:focus {
  background: var(--nav-link-hover);
  color: #fff;
}

/* Base reset for nav backdrop to avoid default button rendering */
.nav-backdrop {
  position: fixed;
  inset: 0;
  display: none; /* only shown when nav-open on small screens */
  background: transparent;
  border: 0;
  padding: 0;
  margin: 0;
  border-radius: 0;
  box-shadow: none;
  outline: none;
}

/* Header-Stats rechts */
.header-stats { margin-left:auto; display:flex; align-items:center; gap:.45rem; }
.header-stats .pill { display:inline-flex; align-items:center; gap:.35rem; background:#1d2226; border:1px solid #2b3338; color:#ddd; padding:.25rem .5rem; border-radius:999px; box-shadow:0 1px 2px rgba(0,0,0,.25); font-size:.8rem; }
.header-stats .pill .label { opacity:.8; font-weight:600; letter-spacing:.3px; }
.header-stats .pill strong { font-variant-numeric: tabular-nums; letter-spacing:.2px; }
.header-stats .pill.reg { border-color:#2e8ece55; }
.header-stats .pill.online { border-color:#FFB30055; }
/* Mobile: Stats ausblenden für mehr Übersicht */
@media (max-width: 520px){ .header-stats { display:none; } }

.maincontent {
  width: 100%;
  margin: 2rem 0 0 0;
  background: var(--card-bg);
  border-radius: var(--border-radius);
  box-shadow: var(--shadow);
  padding: 2rem 0.5rem;
  box-sizing: border-box;
}

h1, h2, h3, h4, h5, h6 {
  color: var(--accent);
  font-family: var(--font-main);
  margin-top: 1.5em;
}

/* Code & pre formatting */
code, pre code { font-family: "JetBrains Mono", "Fira Code", monospace; font-size: .95em; }
pre { 
  background:#12171b; /* etwas heller für besseren Kontrast */
  padding: .85em 1em; 
  border:1px solid #2f3a40; 
  border-radius:6px; 
  overflow:auto; 
  line-height:1.4; 
  font-size:.9rem; 
  color:#e2e8ec; 
  -webkit-font-smoothing: antialiased; 
}
pre code { background: transparent; padding:0; color:inherit; }

/* Spezifisch: Codeblöcke in Help-Karten höherer Kontrast */
.help-container .card pre { 
  background:#101418; 
  border-color:#39454c; 
  color:#edf3f6; 
  box-shadow: inset 0 0 0 1px #1d2529, 0 1px 2px rgba(0,0,0,0.4); 
}
.help-container .card pre code { color:inherit; }

/* Bessere Lesbarkeit von Kommandolisten (einheitliche horizontale Scrollbar & leichte Einrückung) */
.help-container pre::-webkit-scrollbar { height:8px; }
.help-container pre::-webkit-scrollbar-track { background:#1c2226; }
.help-container pre::-webkit-scrollbar-thumb { background:#2e8ece; border-radius:4px; }
.help-container pre:hover::-webkit-scrollbar-thumb { background:#349edf; }

/* Optionale Klasse für besonders wichtige Snippets */
.code-accent { background:#16212a !important; border-color:#2e8ece !important; box-shadow:0 0 0 1px #2e8ece55; }


a {
  color: var(--footer-link);
  text-decoration: none;
}

a:hover {
  color: var(--hover-link);
  text-decoration: underline;
}

button, .btn {
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 4px;
  padding: 0.5em 1.2em;
  font-size: 1em;
  cursor: pointer;
  transition: background 0.2s;
}

button:hover, .btn:hover {
  background: var(--accent-hover);
}

footer {
  background: var(--footer-bg);
  border-top: 2px solid var(--footer-border);
  margin-top: 2rem;
  padding: 1.5rem 0 1.2rem 0;
  text-align: center;
  font-size: 1rem;
  color: #aaa;
  font-family: var(--font-main);
}

footer a {
  color: var(--footer-link);
  text-decoration: none;
}

footer a:hover, footer a:focus {
  text-decoration: underline;
}

/* ================= HELP PAGES ================= */
.help-container, .help-redirect { 
  max-width: 1000px; 
  margin: 2rem auto; 
  padding: 1.5rem 1.5rem 2.5rem; 
  background: var(--card-bg); 
  border-radius: var(--border-radius); 
  box-shadow: var(--shadow);
  line-height: 1.55;
}
.help-layout { display:flex; gap:2.2rem; align-items:flex-start; }
.help-sidenav { flex:0 0 220px; position:sticky; top:82px; max-height:calc(100vh - 110px); overflow:auto; }
.help-article { flex:1 1 auto; min-width:0; }
.help-sidenav-nav { font-size:.85rem; }
.help-sidenav-group { margin:.2rem 0 .4rem; font-size:.62rem; letter-spacing:1px; font-weight:600; opacity:.65; text-transform:uppercase; }
.help-sidenav-nav ul { list-style:none; margin:0 0 1.1rem; padding:0; display:flex; flex-direction:column; gap:.25rem; }
.help-sidenav-nav a { background:#1d2226; border:1px solid #2b3338; border-radius:5px; padding:.42rem .55rem .48rem; display:block; text-decoration:none; color:var(--footer-link); line-height:1.25; }
.help-sidenav-nav a:hover { background:#253038; text-decoration:none; }
.help-sidenav-nav a.active { border-color:var(--accent); box-shadow:0 0 0 1px #2e8ece55; background:#21292e; }
.help-index-groups { display:grid; gap:2rem; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); }
.help-section-list { list-style:none; padding:0; margin:.4rem 0 0; display:flex; flex-direction:column; gap:.35rem; font-size:.92rem; }
.help-section-list a { font-weight:600; }
.help-bookmark { margin-top:2rem; font-size:.8rem; opacity:.75; }
@media (max-width: 920px) {
  .help-layout { flex-direction:column; }
  .help-sidenav { position:relative; top:auto; max-height:none; }
  .help-sidenav-nav { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:1rem; }
  .help-sidenav-group { display:none; }
  .help-sidenav-nav ul { margin:0; }
  .help-sidenav-nav a { font-size:.78rem; }
}
.help-container h1, .help-redirect h1 { margin-top:0; }
.help-nav ul { list-style:none; padding:0; margin:1rem 0 2rem; display:grid; gap:.6rem; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); }
.help-nav a { display:block; background:#1d2226; padding:.55rem .75rem; border:1px solid #2b3338; border-radius:6px; font-weight:500; letter-spacing:.3px; }
.help-nav a:hover { background:#253038; text-decoration:none; border-color:#345; }
.help-back { margin-top:2.5rem; font-size:.9rem; }
.help-back a { color: var(--accent); }
.help-back a:hover { color: var(--footer-link); }
.help-container section { margin-top:2rem; }
.help-container table { font-size:.95em; }
.help-container dl { background:#1d2226; border:1px solid #2b3338; padding:1rem 1.2rem; border-radius:6px; }
.help-container dt { font-weight:600; color: var(--footer-link); margin-top:1rem; }
.help-container dt:first-child { margin-top:0; }
.help-container dd { margin: .25rem 0 0 0; }
.help-container ul { padding-left:1.1rem; }
.help-container li { margin:.3rem 0; }
.help-container .highlight { background:#2e8ece22; border-left:4px solid var(--accent); padding:.6rem .9rem; border-radius:4px; }
.help-container .two-cols { display:grid; gap:1.2rem; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); }
.help-container .card { background:#1d2226; border:1px solid #2b3338; border-radius:6px; padding:1rem 1rem 1.2rem; }
.help-container .card h3 { margin-top:.2rem; font-size:1.05rem; }

/* Responsive improvements */
@media (max-width: 780px){
  .help-nav ul { grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); }
  .help-container, .help-redirect { padding:1.2rem 1rem 2rem; }
}

@media (max-width: 700px) {
  .maincontent {
    padding: 1rem 0.5rem;
  }
  /* Headerbar bleibt Reihe: Hamburger immer rechts vom Logo */
  .headerbar { flex-direction:row; align-items:center; }
  .logo-fullheight {
    height: 38px;
  }
  nav {
    gap: 0.7rem;
    flex-direction: column;
    align-items: flex-end;
    justify-content: flex-end;
  }
  nav a {
    display: block;
    width: 100%;
  }
}

/* Übersichtliche Tabellen für FAQ und Übersichten */
.faq-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: #23272b;
  color: #f3f3f3;
  border-radius: 8px;
  overflow: hidden;
  margin: 1.5em 0;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}
.faq-table th, .faq-table td {
  padding: 0.7em 1em;
  border-bottom: 1px solid #333;
  text-align: left;
}
.faq-table th {
  background: #181c1f;
  color: #FFB300;
  font-weight: 600;
  border-bottom: 2px solid #2e8ece;
}
.faq-table tr:nth-child(even) {
  background: #23272b;
}
.faq-table tr:nth-child(odd) {
  background: #262e36;
}
.faq-table tr:hover {
  background: #2e8ece22;
}
.faq-table td code {
  background: #181c1f;
  color: #FFB300;
  padding: 0.1em 0.4em;
  border-radius: 4px;
  font-size: 0.98em;
}

/* Generic responsive table wrapper */
.table-responsive {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin: 1rem 0; /* harmonize spacing around tables */
}
.table-responsive > table {
  min-width: 600px; /* allow scroll when viewport is narrow */
}
@media (max-width: 560px) {
  .table-responsive > table { min-width: 520px; }
}

/* ===== Server Listen-Ansicht ===== */
.server-list-wrapper { margin:1.2rem 0 1.8rem; }
.server-list { list-style:none; margin:0; padding:0; display:grid; gap: .9rem; }
.server-item { background:#1d2226; border:1px solid #2b3338; border-radius:8px; padding:.85rem 1rem 1rem; position:relative; box-shadow:0 2px 4px rgba(0,0,0,0.25); }
.server-item.empty { text-align:center; }
.server-item-head { display:flex; justify-content:space-between; align-items:flex-start; gap:.8rem; flex-wrap:wrap; }
.server-name { font-weight:600; font-size:1.05rem; color:var(--footer-link); }
.server-location { font-size:.85rem; opacity:.85; }
.server-users { margin-left:auto; font-size:.75rem; background:#1d2226; border:1px solid #2b3338; padding:.2rem .45rem; border-radius:999px; color:#ddd; box-shadow:0 1px 2px rgba(0,0,0,0.25); }
.server-item-ports, .server-item-ips { display:flex; flex-wrap:wrap; gap:.8rem; margin-top:.4rem; font-size:.82rem; }
.server-item-ports span, .server-item-ips span { background:#232a2f; padding:.3rem .55rem; border:1px solid #2f383d; border-radius:4px; }
.server-port.ssl strong { color:#2e8ece; }
.server-port.std strong { color:#FFB300; }
.server-desc { margin-top:.55rem; font-size:.85rem; line-height:1.35; color:#ddd; }
.topic-snippet { /* keep the label and topic text visually attached */
  display: flex;
  align-items: center;
  gap: .45rem;
  /* allow the snippet to shrink and ellipsize when space is limited */
  max-width: 100%;
}
.topic-snippet .topic-label {
  flex: 0 0 auto;
  white-space: nowrap;
  font-weight: 600;
  color: var(--footer-link);
}
.topic-snippet .one-line-ellipsis {
  flex: 1 1 auto;
  min-width: 0; /* allows flex children to shrink and enable text-overflow */
  display: inline-block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: middle;
}

/* reusable utility for single-line ellipsis outside of topic-snippet */
.one-line-ellipsis {
  display: inline-block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: middle;
  min-width: 0;
}

/* Make modes follow the same visual pattern as topic */
.modes-snippet {
  display: flex;
  align-items: center;
  gap: .45rem;
  max-width: 100%;
  font-size:0.85rem;
  color:#ccc;
  margin-top:0.3rem;
}
.modes-snippet .modes-label {
  flex: 0 0 auto;
  white-space: nowrap;
  font-weight: 600;
  color: var(--footer-link);
}
.modes-snippet .modes-value {
  flex: 1 1 auto;
  min-width: 0;
}
.topic-empty { color: #888; font-style: italic; }


.mode-empty { color:#888; font-style:italic; }
.server-last { margin-top:.6rem; font-size:.72rem; letter-spacing:.5px; opacity:.8; display:flex; gap:.4rem; align-items:center; }
.server-last time { font-family:monospace; font-size:.72rem; background:#181c1f; padding:.2rem .4rem; border-radius:4px; border:1px solid #2e373d; }
.server-last .label { opacity:.9; font-weight:600; }
.server-uptime { margin-top:.35rem; font-size:.72rem; letter-spacing:.5px; opacity:.85; display:flex; gap:.4rem; align-items:center; }
.server-uptime time { font-family:monospace; font-size:.72rem; background:#181c1f; padding:.2rem .4rem; border-radius:4px; border:1px solid #2e373d; letter-spacing:.5px; }
.server-uptime .label { opacity:.9; font-weight:600; }
@media (min-width:900px){
  .server-list { grid-template-columns:repeat(auto-fill,minmax(360px,1fr)); }
}
@media (max-width:520px){
  .server-item { padding:.8rem .85rem .9rem; }
  .server-item-ports span, .server-item-ips span { font-size:.75rem; }
  .server-last { font-size:.65rem; }
}

/* ===== User Search (Benutzersuche) ===== */
.help-container .filters-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: .6rem;
  align-items: center;
}
.help-container .filters-grid label {
  display: flex;
  gap: .4rem;
  align-items: center;
}
.help-container .filters-grid label > select,
.help-container .filters-grid label > input[type="number"],
.help-container .filters-grid label > input[type="text"] {
  width: 100%;
  max-width: none; /* override global compact form control width */
}
.help-container .stats-row {
  margin-top: .5rem;
  color: #bbb;
  font-size: .95em;
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}
.help-container .table-card {
  padding: 0;
  overflow-x: auto;
  background:#1d2226;
  border:1px solid #2b3338;
  border-radius:6px;
}
.help-container table.table {
  width: 100%;
  border-collapse: collapse;
}
.help-container table.table thead th {
  position: sticky;
  top: 0;
  background: #181c1f;
  color: var(--footer-link);
  border-bottom: 2px solid var(--accent);
  z-index: 1;
}
.help-container table.table th, .help-container table.table td {
  padding: 8px 10px;
  text-align: left;
}
.help-container table.table tbody tr:nth-child(odd) { background: #262e36; }
.help-container table.table tbody tr:nth-child(even) { background: #23272b; }
.help-container table.table tbody tr:hover { background: #2e8ece22; }
.help-container .nowrap { white-space: nowrap; }
.help-container .pager { display:flex; gap:.4rem; align-items:center; }
@media (max-width: 640px){
  .help-container table.table { font-size: .95em; }
  .help-container .stats-row { font-size: .9em; }
  .help-container .filters-grid { grid-template-columns: 1fr; }
}

/* Utility classes used by user-search.jsp after inline cleanup */
.mt-1 { margin-top:1rem; }
.text-error { color:#ff4d4d; padding:0.8rem 1rem; }
.text-muted { color:#888; padding:0.8rem 1rem; }
.minw-18 { min-width:18rem; }
.table-footer { display:flex; justify-content:space-between; align-items:center; padding:0.6rem 0.8rem; border-top:1px solid #2b3338; font-size:0.9em; flex-wrap:wrap; gap:0.6rem; }
.pager-info { padding:0 0.4rem; }
.btn.disabled, .btn[disabled] { opacity:0.4; cursor:default; }

/* Grid helpers for clearer filter layout */
.help-container .filters-grid .span-2 { grid-column: span 2; }
.help-container .switches-row { display:flex; gap:.8rem; align-items:center; flex-wrap:wrap; }
.help-container .inline-group { display:flex; gap:.6rem; align-items:center; flex-wrap:wrap; }
.help-container .form-actions { display:flex; align-items:flex-end; gap:.6rem; }

@media (max-width: 700px){
  .help-container .filters-grid .span-2 { grid-column: auto; }
}

/* ===== Netzwerk Statistik ===== */
.net-stats { display:flex; flex-direction:column; gap:.9rem; }
.net-stats-head { display:flex; flex-wrap:wrap; gap:.8rem; justify-content:space-between; align-items:center; }
.net-stats-head strong { color:var(--footer-link); font-size:1.05rem; }
.net-stats-head .updated { font-size:.65rem; letter-spacing:.5px; opacity:.75; }
.net-stats-kpis { display:flex; flex-wrap:wrap; gap:.8rem; }
.net-stats-kpis .kpi { background:#1d2226; border:1px solid #2b3338; padding:.55rem .75rem .6rem; border-radius:6px; min-width:122px; flex:0 1 auto; display:flex; flex-direction:column; gap:.15rem; box-shadow:0 1px 3px rgba(0,0,0,0.25); }
.kpi-label { font-size:.65rem; text-transform:uppercase; letter-spacing:1px; opacity:.65; }
.kpi-value { font-size:1.15rem; font-weight:600; }
.net-stats-bars { display:grid; gap:.75rem; }
.stat-bar { display:flex; flex-direction:column; gap:.35rem; }
.stat-bar-head { display:flex; justify-content:space-between; font-size:.78rem; letter-spacing:.3px; }
.bar-label { font-weight:600; color:#ddd; }
.bar-val { font-family:monospace; font-size:.7rem; opacity:.75; }
.bar-track { position:relative; background:#1d2226; border:1px solid #2b3338; border-radius:20px; height:14px; overflow:hidden; box-shadow:inset 0 1px 2px rgba(0,0,0,0.45); }
.bar-fill { position:absolute; top:0; left:0; bottom:0; width:calc(var(--w,0) * 1%); background:linear-gradient(90deg,#2e8ece,#4aa7e6); box-shadow:0 0 0 1px #2e8ece55, 0 0 6px -1px #2e8eceaa; transition:width .6s cubic-bezier(.4,.0,.2,1); }
.bar-fill.services { background:linear-gradient(90deg,#FFB300,#ffcf4d); box-shadow:0 0 0 1px #FFB30055, 0 0 6px -1px #FFB300aa; }
.bar-fill.cloaked { background:linear-gradient(90deg,#7d5bd6,#b08bff); box-shadow:0 0 0 1px #7d5bd655, 0 0 6px -1px #7d5bd6aa; }
@media (max-width:600px){
  .net-stats-kpis { gap:.55rem; }
  .net-stats-kpis .kpi { min-width:100px; padding:.5rem .6rem; }
  .kpi-value { font-size:1rem; }
  .stat-bar-head { font-size:.7rem; }
  .bar-track { height:12px; }
}

/* ===== Staff Übersicht ===== */
.staff-list { display:grid; gap:1rem; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); }
.staff-card { background:#1d2226; border:1px solid #2b3338; border-radius:10px; padding:.85rem .95rem 1rem; position:relative; box-shadow:0 2px 6px rgba(0,0,0,0.28); display:flex; flex-direction:column; gap:.55rem; justify-content:space-between; }
.staff-card.oper { border-color:#2e8ece; }
.staff-card.service { border-color:#FFB300; }
.staff-card-head { display:flex; justify-content:space-between; align-items:center; }
.staff-nick { font-weight:600; font-size:1.05rem; color:var(--footer-link); word-break:break-word; }
.staff-badge { font-size:.6rem; letter-spacing:1px; font-weight:600; padding:.25rem .45rem; border-radius:4px; background:#232a2f; border:1px solid #2f383d; }
.staff-badge.oper { color:#2e8ece; border-color:#2e8ece55; }
.staff-badge.service { color:#FFB300; border-color:#FFB30055; }
.staff-meta { display:flex; flex-wrap:wrap; gap:.5rem; font-size:.72rem; letter-spacing:.4px; opacity:.8; }
.staff-host { font-family:monospace; background:#181c1f; padding:.2rem .4rem; border-radius:4px; border:1px solid #2e373d; }
.staff-account { background:#262e36; padding:.2rem .45rem; border-radius:4px; border:1px solid #2e373d; }
.staff-chans { display:flex; flex-wrap:wrap; gap:.35rem; }
.staff-chans .chan { font-size:.65rem; background:#1f2529; padding:.2rem .4rem; border-radius:4px; border:1px solid #2b3338; letter-spacing:.5px; }
.staff-chans .more { font-size:.65rem; background:#2e8ece22; padding:.2rem .45rem; border-radius:4px; border:1px solid #2e8ece55; color:#2e8ece; }
.staff-empty { background:#1d2226; border:1px dashed #2b3338; border-radius:8px; padding:1rem; text-align:center; font-size:.85rem; opacity:.75; }
.staff-desc { margin-top:auto; margin-bottom:.2rem; background:#181c1f; border:1px solid #232a2f; border-radius:6px; padding:.5em .9em; font-size:.85rem; color:#ddd; display:flex; align-items:flex-start; gap:.7em; }
@media (max-width:540px){
  .staff-list { grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); }
  .staff-meta { font-size:.65rem; }
  .staff-nick { font-size:.95rem; }
}

/* ===== Channel Statistics ===== */

/* Container & Layout */
.stats-container {
  max-width: 1200px;
  margin: 2rem auto;
  padding: 0 1rem;
}

/* Navigation Tabs */
.stats-nav {
  display: flex;
  gap: 1rem;
  margin-bottom: 2rem;
  flex-wrap: wrap;
  border-bottom: 2px solid #2b3338;
}

.stats-nav a {
  padding: 0.75rem 1.5rem;
  background: transparent;
  border-radius: 0;
  text-decoration: none;
  color: #ddd;
  transition: all 0.2s;
  position: relative;
  font-weight: 500;
  letter-spacing: 0.5px;
}

.stats-nav a:hover {
  background: rgba(46,142,206,0.1);
  color: var(--footer-link);
}

.stats-nav a.active {
  color: #2e8ece;
  border-bottom: 2px solid #2e8ece;
  margin-bottom: -2px;
}

/* Content Cards */
.stats-card {
  background: #1d2226;
  border: 1px solid #2b3338;
  border-radius: 10px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.3);
  padding: 1.5rem;
  margin-bottom: 1.5rem;
}

.stats-card h2 {
  font-size: 1.5rem;
  margin-bottom: 1rem;
  color: var(--footer-link);
  font-weight: 600;
  letter-spacing: 0.5px;
}

/* KPI Boxes */
.stats-kpi {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem;
  margin-bottom: 2rem;
}

.kpi-box {
  background: linear-gradient(135deg, #2e8ece 0%, #4aa7e6 100%);
  color: white;
  padding: 1.5rem;
  border-radius: 10px;
  text-align: center;
  box-shadow: 0 4px 12px rgba(46,142,206,0.3);
  transition: transform 0.2s;
}

.kpi-box:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(46,142,206,0.4);
}

.kpi-box .value {
  font-size: 2.5rem;
  font-weight: bold;
  margin-bottom: 0.5rem;
  text-shadow: 0 2px 4px rgba(0,0,0,0.2);
}

.kpi-box .label {
  font-size: 0.9rem;
  opacity: 0.9;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.kpi-box:nth-child(2) {
  background: linear-gradient(135deg, #FFB300 0%, #ffcf4d 100%);
  box-shadow: 0 4px 12px rgba(255,179,0,0.3);
}

.kpi-box:nth-child(3) {
  background: linear-gradient(135deg, #7d5bd6 0%, #b08bff 100%);
  box-shadow: 0 4px 12px rgba(125,91,214,0.3);
}

/* Charts */
.chart-container {
  position: relative;
  height: 400px;
  margin: 2rem 0;
  background: #181c1f;
  padding: 1rem;
  border-radius: 8px;
  border: 1px solid #2b3338;
}

/* Tables */
.channel-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: auto;
}

.channel-table th {
  background: #232a2f;
  padding: 0.5rem 0.6rem;
  text-align: left;
  font-weight: 600;
  border-bottom: 2px solid #2b3338;
  color: var(--footer-link);
  letter-spacing: 0.5px;
  text-transform: uppercase;
  font-size: 0.8rem;
}

.channel-table td {
  padding: 0.5rem 0.6rem;
  border-bottom: 1px solid #2b3338;
  color: #ddd;
  font-size: 0.9rem;
}

.channel-table tbody tr {
  transition: background 0.2s;
  background: #1a1d21;
}

.channel-table tbody tr:nth-child(even) {
  background: #141619;
}

.channel-table tbody tr:hover {
  background: #232a2f !important;
}

/* Table wrapper to prevent overflow */
.table-wrapper {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: #2e8ece #181c1f;
}

.table-wrapper::-webkit-scrollbar {
  height: 8px;
}

.table-wrapper::-webkit-scrollbar-track {
  background: #181c1f;
  border-radius: 4px;
}

.table-wrapper::-webkit-scrollbar-thumb {
  background: #2e8ece;
  border-radius: 4px;
}

.table-wrapper::-webkit-scrollbar-thumb:hover {
  background: #4aa7e6;
}

/* Sticky erste beiden Spalten (Rang + Name/Kanal) beim horizontalen Scrollen */
.channel-table thead th:nth-child(1),
.channel-table thead th:nth-child(2),
.channel-table tbody td:nth-child(1),
.channel-table tbody td:nth-child(2) {
  position: sticky;
  z-index: 10;
}

.channel-table thead th:nth-child(1),
.channel-table tbody td:nth-child(1) {
  left: 0;
}

.channel-table thead th:nth-child(2),
.channel-table tbody td:nth-child(2) {
  left: 60px;
}

/* Hintergrund für sticky Spalten in thead - dunkles Theme */
.channel-table thead th:nth-child(1),
.channel-table thead th:nth-child(2) {
  background: #2e8ece;
}

/* Hintergrund für sticky Spalten in tbody - dunkles Theme */
.channel-table tbody td:nth-child(1),
.channel-table tbody td:nth-child(2) {
  background: #1a1d21;
}

.channel-table tbody tr:nth-child(even) td:nth-child(1),
.channel-table tbody tr:nth-child(even) td:nth-child(2) {
  background: #0f1214;
}

/* Schatten-Effekt für sticky Spalten */
.channel-table thead th:nth-child(2)::after,
.channel-table tbody td:nth-child(2)::after {
  content: '';
  position: absolute;
  top: 0;
  right: -8px;
  bottom: 0;
  width: 8px;
  background: linear-gradient(to right, rgba(0,0,0,0.3), transparent);
  pointer-events: none;
}

/* Ranking Badges */
.rank-badge {
  display: inline-block;
  width: 2rem;
  height: 2rem;
  line-height: 2rem;
  text-align: center;
  background: #2e8ece;
  color: white;
  border-radius: 50%;
  font-weight: bold;
  font-size: 0.9rem;
  box-shadow: 0 2px 4px rgba(0,0,0,0.3);
}

.rank-badge.gold {
  background: linear-gradient(135deg, #f6d365 0%, #fda085 100%);
  box-shadow: 0 2px 8px rgba(246,211,101,0.5);
}

.rank-badge.silver {
  background: linear-gradient(135deg, #e0e0e0 0%, #b0b0b0 100%);
  box-shadow: 0 2px 8px rgba(224,224,224,0.5);
}

.rank-badge.bronze {
  background: linear-gradient(135deg, #cd7f32 0%, #8b4513 100%);
  box-shadow: 0 2px 8px rgba(205,127,50,0.5);
}

/* Activity Bars */
.activity-bar {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.activity-bar .bar {
  flex: 1;
  height: 10px;
  background: #181c1f;
  border: 1px solid #2b3338;
  border-radius: 5px;
  overflow: hidden;
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.3);
}

.activity-bar .fill {
  height: 100%;
  background: linear-gradient(90deg, #2e8ece 0%, #4aa7e6 100%);
  transition: width 0.4s cubic-bezier(.4,.0,.2,1);
  box-shadow: 0 0 8px rgba(46,142,206,0.6);
}

.activity-bar .count {
  min-width: 80px;
  text-align: right;
  font-weight: 600;
  color: var(--footer-link);
  font-family: monospace;
}

/* Empty States */
.empty-state {
  text-align: center;
  padding: 3rem;
  color: #999;
}

.empty-state svg {
  width: 64px;
  height: 64px;
  margin-bottom: 1rem;
  opacity: 0.3;
  stroke: currentColor;
}

/* Utilities */
.timestamp {
  color: #999;
  font-size: 0.85rem;
  font-family: monospace;
  letter-spacing: 0.3px;
}

/* Responsive Design */
@media (max-width: 768px) {
  .stats-container {
    margin: 1rem auto;
    padding: 0 0.75rem;
  }

  .stats-kpi {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }
  
  .kpi-box {
    padding: 1rem;
  }
  
  .kpi-box .value {
    font-size: 2rem;
  }
  
  .stats-card {
    padding: 1rem;
    margin-bottom: 1rem;
    border-radius: 8px;
  }
  
  .stats-card h2 {
    font-size: 1.25rem;
  }
  
  .chart-container {
    height: 300px;
    padding: 0.5rem;
  }
  
  /* Table responsive container */
  .stats-card > table.channel-table,
  details > table.channel-table,
  .table-wrapper {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    width: 100%;
    max-width: 100%;
    scrollbar-width: thin;
    scrollbar-color: #2e8ece #181c1f;
  }
  
  .stats-card > table.channel-table::-webkit-scrollbar,
  details > table.channel-table::-webkit-scrollbar,
  .table-wrapper::-webkit-scrollbar {
    height: 8px;
  }
  
  .stats-card > table.channel-table::-webkit-scrollbar-track,
  details > table.channel-table::-webkit-scrollbar-track,
  .table-wrapper::-webkit-scrollbar-track {
    background: #181c1f;
    border-radius: 4px;
  }
  
  .stats-card > table.channel-table::-webkit-scrollbar-thumb,
  details > table.channel-table::-webkit-scrollbar-thumb,
  .table-wrapper::-webkit-scrollbar-thumb {
    background: #2e8ece;
    border-radius: 4px;
  }
  
  .stats-card > table.channel-table::-webkit-scrollbar-thumb:hover,
  details > table.channel-table::-webkit-scrollbar-thumb:hover,
  .table-wrapper::-webkit-scrollbar-thumb:hover {
    background: #4aa7e6;
  }
  
  .channel-table {
    min-width: 800px;
    max-width: none;
  }
  
  .stats-card {
    overflow: hidden;
  }
  
  .channel-table thead {
    display: table-header-group;
  }
  
  .channel-table tbody {
    display: table-row-group;
  }
  
  .channel-table tr {
    display: table-row;
  }
  
  .channel-table th,
  .channel-table td {
    display: table-cell;
    padding: 0.5rem 0.4rem;
    font-size: 0.75rem;
    white-space: nowrap;
  }
  
  .channel-table th {
    font-size: 0.7rem;
    padding: 0.6rem 0.4rem;
  }
  
  .stats-nav {
    gap: 0.5rem;
    border-bottom: 1px solid #2b3338;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    display: flex;
    flex-wrap: nowrap;
  }
  
  .stats-nav a {
    padding: 0.5rem 1rem;
    font-size: 0.85rem;
    white-space: nowrap;
    flex-shrink: 0;
  }
  
  .activity-bar {
    flex-direction: column;
    align-items: stretch;
    gap: 0.25rem;
  }
  
  .activity-bar .count {
    min-width: auto;
    font-size: 0.8rem;
    text-align: left;
  }
  
  .rank-badge {
    width: 1.75rem;
    height: 1.75rem;
    line-height: 1.75rem;
    font-size: 0.8rem;
  }
  
  /* Relations Graph responsive - proper container sizing */
  #relationsGraph {
    min-height: 500px !important;
    height: 500px !important;
    overflow: visible !important;
    padding: 0.5rem !important;
    position: relative !important;
    width: 100% !important;
  }
  
  #relationsSvg {
    height: 100% !important;
    width: 100% !important;
    max-width: 100% !important;
    display: block !important;
  }
  
  /* Legend repositioning for mobile */
  #relationsGraph > div[style*="position: absolute"] {
    position: absolute !important;
    bottom: 10px !important;
    right: 10px !important;
    left: auto !important;
    font-size: 10px !important;
    padding: 8px !important;
    max-width: 85% !important;
    line-height: 1.4 !important;
  }
  
  /* Search form mobile optimization */
  .stats-card form[style*="display: flex"] {
    display: flex !important;
    flex-direction: column !important;
    gap: 0.5rem !important;
  }
  
  .stats-card form input[type="text"],
  .stats-card form input[name="search"] {
    flex: 1 1 100% !important;
    width: 100% !important;
  }
  
  .stats-card form button {
    width: 100% !important;
    margin: 0 !important;
  }
  
  /* Channel detail header on mobile */
  .stats-card > div[style*="display: flex"] {
    flex-direction: column !important;
    gap: 1rem !important;
  }
  
  .stats-card > div[style*="display: flex"] h2 {
    margin-bottom: 0.5rem !important;
  }
  
  .stats-card > div[style*="display: flex"] a.btn {
    align-self: flex-start !important;
  }
}

@media (max-width: 480px) {
  .stats-container {
    padding: 0 0.5rem;
    margin: 0.5rem auto;
  }
  
  .stats-kpi {
    gap: 0.5rem;
  }
  
  .kpi-box {
    padding: 0.75rem;
  }
  
  .kpi-box .value {
    font-size: 1.75rem;
  }
  
  .kpi-box .label {
    font-size: 0.75rem;
  }
  
  .stats-card {
    padding: 0.75rem;
  }
  
  .stats-card h2 {
    font-size: 1.1rem;
  }
  
  .chart-container {
    height: 250px;
    padding: 0.25rem;
  }
  
  .channel-table th,
  .channel-table td {
    padding: 0.4rem 0.3rem;
    font-size: 0.7rem;
  }
  
  .channel-table th {
    font-size: 0.65rem;
  }
  
  .channel-table {
    min-width: 700px;
    max-width: none;
  }
  
  .stats-card > table.channel-table::-webkit-scrollbar,
  details > table.channel-table::-webkit-scrollbar,
  .table-wrapper::-webkit-scrollbar {
    height: 6px;
  }
  
  .stats-nav a {
    padding: 0.4rem 0.75rem;
    font-size: 0.8rem;
  }
  
  .rank-badge {
    width: 1.5rem;
    height: 1.5rem;
    line-height: 1.5rem;
    font-size: 0.7rem;
  }
  
  /* Relations Graph - properly sized for small screens */
  #relationsGraph {
    min-height: 450px !important;
    height: 450px !important;
    overflow: visible !important;
    padding: 0.25rem !important;
    width: 100% !important;
  }
  
  #relationsSvg {
    height: 100% !important;
    width: 100% !important;
    max-width: 100% !important;
    display: block !important;
  }
  
  /* Smaller legend on mobile */
  #relationsGraph > div[style*="position: absolute"] {
    font-size: 8px !important;
    padding: 6px !important;
    max-width: 90% !important;
    line-height: 1.3 !important;
  }
  
  /* Extended statistics details */
  details summary {
    padding: 0.75rem !important;
    font-size: 0.85rem !important;
  }
  
  /* Empty state */
  .empty-state {
    padding: 2rem 1rem;
  }
  
  .empty-state svg {
    width: 48px;
    height: 48px;
  }
  
  /* Alert messages */
  .alert {
    padding: 0.75rem !important;
    font-size: 0.85rem !important;
  }
  
  /* Visibility radio options on mobile */
  .radio-option {
    padding: 0.4rem !important;
    font-size: 0.85rem !important;
  }
}

