@layer forum-base {
/* ============================================
   FORUM MODERN DESIGN - aktie.at
   Overrides für DCForum+ Farben/Abstände
   Wird NACH dc.css geladen
   ============================================ */

/* --- CSS-Variablen (Farbpalette) --- */
:root {
  --blue-900: #0e233e;
  --blue-800: #15335b;
  --blue-700: #1e4476;
  --blue-600: #235495;
  --blue-500: #2867b8;
  --blue-400: #528bd6;
  --blue-300: #8ab2e5;
  --blue-100: #dbe6f5;
  --blue-50:  #f0f4f9;
  --red:      #c11f2d;
  --red-dark: #652026;
  --red-light:#faebec;
  --green:    #1a8a4a;
  --text:     #2a2e35;
  --text-sec: #5a6272;
  --border:   #d5dde7;
}

/* --- Grundfarben --- */
body {
  color: #333;
  font-size: 14px;
  padding: 0 15px;
  box-sizing: border-box;
}
td, th {
  color: #333;
  font-size: 13px;
}
.dcdark, .dcdark td, .dcdark a {
  color: #333;
}
.dclite, .dclite td, .dclite a {
  color: #333;
}

/* --- Links: Website-Farben statt #0000f1 --- */
a { color: var(--blue-600, #235495); }
a:visited { color: var(--blue-600, #235495); }
a:hover { color: var(--blue-500, #2867b8); text-decoration: underline; }

/* --- Header/Überschriften: #2c5a87 statt #000099 --- */
.dcheading, td.dcheading {
  background-color: var(--blue-50, #e8f0fb) !important;
  color: var(--blue-800, #15335b) !important;
  font-size: 13px;
  padding: 8px 10px;
  border: none;
  font-weight: bold;
}
.dcheading a, td.dcheading a,
.dcheading a:visited, td.dcheading a:visited {
  color: var(--blue-700, #1e4476) !important;
}

.dcforumheader {
  background-color: var(--blue-50, #e8f0fb) !important;
  color: var(--blue-800, #15335b) !important;
  font-size: 11px;
  padding: 6px 8px;
}
.dcforumheader a, .dcforumheader a:visited {
  color: var(--blue-700, #1e4476) !important;
}

.dcbluebox {
  background-color: var(--blue-700, #1e4476) !important;
  color: #fff !important;
}
.dcbluebox a, .dcbluebox a:visited {
  color: #fff !important;
}

/* --- Zeilen: Dezente Grautöne --- */
.dcdark { background-color: var(--blue-50, #f0f4f9); }
.dclite { background-color: #ffffff; }

/* --- Tabellen-Borders: kein Rahmen --- */
.dcborder {
  border: 0 !important;
  border-radius: 4px;
}
.dcborder td {
  border-color: #eee;
}

/* --- Text-Styles --- */
.dctitle {
  color: var(--blue-700, #1e4476);
  font-weight: bold;
}
.dcnormal { color: #333; }
.dcsmall { color: #666; font-size: 12px; }
.dcsmallemp { color: var(--blue-700, #1e4476); font-size: 12px; }
.dcemp { color: var(--blue-700, #1e4476); }
.dcinfo, .dccaption, .dcdate { color: #666; }
.dcstrong { color: #333; }

/* --- Forum-Titel-Links --- */
.dclink {
  color: var(--blue-600, #235495) !important;
  font-weight: bold;
}
.dclink:hover { color: var(--blue-500, #2867b8) !important; }

/* --- Nav-Menü: Helles Blau-Grau statt #C0C0F0 --- */
.dcnavmenu, .dcnavmenu2 {
  background-color: var(--blue-100, #dbe6f5) !important;
  color: var(--blue-700, #1e4476) !important;
  padding: 8px 10px;
  vertical-align: middle !important;
}
.dcnavmenu a, .dcnavmenu2 a {
  color: var(--blue-600, #235495) !important;
}
.dcoptionmenu {
  background-color: #f0f4f8;
  color: #333;
  padding: 6px 10px;
}
.dcmenu {
  background-color: var(--blue-50, #f0f4f9);
  color: #333;
  font-size: 12px;
}
.dcmenu a { color: var(--blue-600, #235495); }

/* --- Header-Typ (Forengruppe) --- */
.dcheadertype {
  background-color: var(--blue-100, #dbe6f5) !important;
  font-size: 11px;
  color: #666;
}

/* --- Moderator/Misc --- */
.dcmoderator {
  color: #666;
  font-size: 12px;
}
.dcmisc { font-size: 12px; color: #666; }

/* --- Nachrichten-Bereich --- */
.message_head {
  background: var(--blue-50, #f0f4fa) !important;
  color: var(--blue-800, #15335b) !important;
  padding: 8px 12px;
  border-bottom: 1px solid var(--blue-200, #c5d5e8);
}
.message_head,
.message_head *,
.message_head a,
.message_head a:visited,
.message_head .dcdate,
#message .message_head,
#message .message_head *,
#message .message_head a,
#message .message_head a:visited {
  color: var(--blue-800, #15335b) !important;
}
/* Aktien-Stat-Panel: eigene Farben (liegt innerhalb message_head) */
#aktien_stat_panel,
#aktien_stat_panel td {
  color: #333 !important;
}
#aktien_stat_panel a[style],
#aktien_stat_panel span[style] {
  color: inherit;
}
#aktien_stat_panel th,
#aktien_stat_panel table th,
#aktien_stat_panel .data-table th,
#aktien_stat_panel thead th {
  background: var(--blue-50, #f0f4f9) !important;
  color: var(--blue-700, #1e4476) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  padding: 8px 10px !important;
  border-bottom: 2px solid var(--border, #d5dde7) !important;
}
#aktien_stat_panel {
  background-color: #fff !important;
  border: 1px solid #ddd;
  border-radius: 6px;
  padding: 0;
  overflow: hidden;
}
#message a {
  color: var(--blue-600, #235495);
}
.important a, .important b {
  color: var(--blue-700, #1e4476) !important;
}
.message_bottom {
  background-color: var(--blue-50, #f0f4f9);
  border-top: 1px solid #eee;
}
.dcmessage {
  font-size: 14px;
  color: #333;
  line-height: 1.6;
}

/* --- Autor-Bereich --- */
.dcauthorlink { color: var(--blue-700, #1e4476) !important; font-size: 13px !important; }
.author_div {
  color: #666;
  display: flex;
  align-items: center;
  gap: 4px;
  line-height: 1;
}
.author_div img { height: 16px !important; width: auto !important; vertical-align: middle; }
.author_div img[src*="award_star"],
img[src*="award_star"] { height: 17px !important; width: auto !important; }
/* Author-Action Icons: modern hover */
a.author-action {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 3px; border-radius: 4px;
  transition: background .15s, transform .15s;
}
a.author-action:hover {
  background: rgba(40,103,184,0.10);
  transform: scale(1.15);
}
a.author-action img { height: 16px !important; margin: 0 !important; }

/* --- Zitat-Styling --- */
.dcquote {
  border-left: 3px solid var(--blue-700, #1e4476);
  background-color: #f5f8fb;
  padding: 8px 12px;
  margin: 8px 0;
}
.dcquoteheader {
  color: #666;
  font-size: 12px;
  font-style: italic;
}

/* --- Dropdown-Menüs --- */
.dc_menu_header {
  background-color: var(--blue-700, #1e4476) !important;
  color: #fff !important;
  padding: 4px 8px;
}
.dc_menu_header a, .dc_menu_header a:visited {
  color: #fff !important;
}
.dc_menu_td {
  background-color: var(--blue-50, #f0f4f9);
  padding: 4px 8px;
}
.dc_menu_td:hover { background-color: var(--blue-100, #dbe6f5); }

/* --- Status-Farben --- */
.status_anzeige { color: var(--blue-700, #1e4476); }
.status_variablen { color: var(--blue-500, #2867b8); }
.right_links {
  background-color: var(--blue-50, #f0f4f9);
  color: #333;
}
.important { color: var(--blue-700, #1e4476) !important; }

/* --- Forum-Footer --- */
.footer_container {
  border-top: 1px solid #ddd;
  padding: 10px 0;
  color: #666;
}

/* --- Allgemeine Abstände --- */
td[width="20"] { padding: 6px; vertical-align: middle; }

/* --- Weiße Trennlinien entfernen (cellspacing="1") --- */
.dcborder, .dcborder table {
  border-collapse: collapse !important;
  border-spacing: 0 !important;
}

/* --- Themen-Tabelle: Subject-Spalte maximieren --- */
.dcborder > tr > td > table {
  table-layout: fixed !important;
  width: 100% !important;
}

/* --- Forum-Übersicht: Icon-Spalte schmal --- */
td[width="20"] {
  width: 30px !important;
  max-width: 40px !important;
}

/* --- Icon-Text zentriert unter Symbolen --- */
#button_pic, .button_text {
  text-align: left;
}
td[align="center"] > #button_pic,
td[align="center"] > .button_text {
  text-align: left !important;
}

/* --- Menü-Leiste: Dropdown nicht überlappend --- */
select[name="forum"] {
  position: relative !important;
  z-index: 1;
  max-width: 160px;
  font-size: 12px;
  vertical-align: middle;
}
#button_pic {
  text-align: left;
  display: inline-block;
}
.button_text a {
  color: var(--blue-600, #235495) !important;
  font-size: 12px;
}
.button_text a:hover {
  color: var(--blue-500, #2867b8) !important;
}
#breadcrumb_div a {
  color: var(--blue-700, #1e4476) !important;
  font-size: 12px;
}
#page_links {
  color: var(--blue-700, #1e4476) !important;
  font-size: 12px !important;
}
#page_links a {
  color: var(--blue-600, #235495) !important;
}
#page_links a.page-btn.active {
  color: #fff !important;
}
#optionen_div {
  color: #333;
  font-size: 12px;
}

/* --- Message-Container: nicht über Viewport hinaus --- */
#message {
  max-width: 100% !important;
  box-sizing: border-box !important;
}

/* --- Selektierte Zeile --- */
.selected_row { background-color: #fff8e0 !important; }

/* ============================================
   FORUM PAGE LAYOUTS (2026 Redesign)
   Matches design templates in /design/
   ============================================ */

/* --- Shared: Card Pattern (from all designs) --- */
.card {
  background: #fff;
  border: 1px solid var(--border, #d5dde7);
  border-radius: 8px;
  box-shadow: 0 1px 5px rgba(0,0,0,0.06);
  overflow: hidden;
  margin-bottom: 20px;
}
.card-header {
  background: var(--blue-50, #f0f4f9);
  border-bottom: 2px solid var(--blue-100, #dbe6f5);
  padding: 12px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.card-title {
  font-size: 17px;
  font-weight: 700;
  color: var(--blue-800, #15335b);
  display: flex;
  align-items: center;
  gap: 8px;
}
.card-title::before {
  content: '';
  display: inline-block;
  width: 10px; height: 10px;
  background: var(--red, #c11f2d);
  border-radius: 1px;
  flex-shrink: 0;
}

/* --- Shared: Section Title (red square + bold text) --- */
.section-title {
  font-size: 22px;
  font-weight: 700;
  color: var(--blue-800, #15335b);
  margin-bottom: 18px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.section-title::before {
  content: '';
  display: inline-block;
  width: 12px; height: 12px;
  background: var(--red, #c11f2d);
  border-radius: 1px;
  flex-shrink: 0;
}

/* --- Shared: Breadcrumb --- */
.breadcrumb {
  font-size: 13px;
  color: var(--text-sec, #5a6272);
  margin-bottom: 14px;
}
.breadcrumb a { color: var(--text-sec, #5a6272); }
.breadcrumb a:hover { color: var(--blue-600, #235495); }
.breadcrumb .sep { margin: 0 6px; color: #b0bdd0; }

/* --- Shared: Button Primary --- */
.btn-primary {
  padding: 7px 16px;
  background: var(--blue-600, #235495);
  color: #fff;
  border: none;
  border-radius: 4px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
}
.btn-primary:hover {
  background: var(--blue-700, #1e4476);
  color: #fff;
  text-decoration: none;
}

/* --- Shared: Pagination --- */
.pagination {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 4px;
  padding: 8px 0;
  border-top: none;
}
.page-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 30px; height: 30px;
  border: 1px solid var(--border, #d5dde7);
  border-radius: 4px;
  font-size: 13px;
  font-weight: 600;
  color: var(--blue-600, #235495);
  background: #fff;
  cursor: pointer;
  text-decoration: none;
  padding: 0 8px;
}
.page-btn:hover {
  background: var(--blue-50, #f0f4f9);
  color: var(--blue-600, #235495);
  border-color: var(--blue-300, #8ab2e5);
  text-decoration: none;
}
.page-btn.active {
  background: var(--blue-600, #235495);
  color: #fff;
  border-color: var(--blue-600, #235495);
}
.page-btn.disabled {
  color: #bbb;
  border-color: #eee;
  cursor: default;
  pointer-events: none;
}
.page-info {
  font-size: 12px;
  color: var(--text-sec, #5a6272);
  margin: 0 8px;
}
.pagination-forum {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
  padding: 12px 0;
  font-size: 13px;
}
.pagination-forum .page-info {
  color: var(--text-sec, #5a6272);
  font-size: 12px;
}

/* ============================================
   1. FORUM INDEX PAGE
   Design: forum-index-redesign.html
   ============================================ */
.page-forum-index {
  max-width: 1440px;
  margin: 16px auto;
  padding: 0 16px;
}
.page-forum-index .card {
  padding: 0;
}
.page-forum-index table {
  width: 100% !important;
  border-collapse: collapse !important;
}
.page-forum-index .dcheading td,
.page-forum-index td.dcheading {
  border-radius: 4px 4px 0 0;
}
/* Forum index table styling */
.forum-index-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.forum-index-table th {
  background: var(--blue-50, #f0f4f9);
  padding: 8px 12px;
  font-size: 12px; font-weight: 600;
  color: var(--text-sec, #5a6272);
  border-bottom: 2px solid var(--border, #d5dde7);
  text-align: left;
  white-space: nowrap;
}
.forum-index-table th.num { text-align: right; }
.forum-index-table td { padding: 10px 12px; border-bottom: 1px solid #f0f2f5; vertical-align: top; }
.forum-index-table td.num { text-align: right; white-space: nowrap; color: var(--text-sec, #5a6272); font-size: 13px; }
.forum-index-table tbody tr:hover { background: var(--blue-50, #f0f4f9); }
.forum-index-table tbody tr:last-child td { border-bottom: none; }
.forum-name a { font-weight: 700; font-size: 14px; color: var(--text, #2a2e35); }
.forum-name a:hover { color: var(--blue-600, #235495); }
.forum-desc { font-size: 12px; color: var(--text-sec, #5a6272); margin-top: 2px; }
.forum-last { font-size: 12px; color: var(--text-sec, #5a6272); }
.forum-last a { color: var(--blue-600, #235495); font-weight: 600; }
.forum-last .last-date { display: block; color: #999; margin-top: 1px; }

/* ============================================
   2. FORUM TOPICS PAGE
   Design: forum-topics-redesign.html
   ============================================ */
.page-forum-topics {
  margin: 16px 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 20px;
}
.page-forum-topics .breadcrumb {
  grid-column: 1 / -1;
}
/* Globale Toolbar — gilt für alle Seiten (show_topics, show_mesg, show_forums, index, rangliste, ...) */
.forum-toolbar { display: flex; flex-wrap: wrap; gap: 20px; padding: 14px 0 10px; justify-content: center; }
.forum-toolbar a { display: flex; flex-direction: column; align-items: center; text-decoration: none; color: #555; font-size: 11px; gap: 4px; transition: color .2s; }
.forum-toolbar a:hover { color: #003580; }
.forum-toolbar img { width: 32px; height: 32px; }
/* Scoped overrides (Abstand bei page-wrapper) */
.page-forum-topics-outer .forum-toolbar { padding: 14px 0 10px; }
.page-rangliste-outer .forum-toolbar { padding: 14px 16px 10px; }
.forum-topics-main { min-width: 0; }
.forum-topics-sidebar { min-width: 0; }
.forum-topics-sidebar .card { padding: 16px 18px; }
.forum-topics-sidebar .card-title { margin-bottom: 10px; }

/* Thread list */
.thread-list { font-size: 13px; }
.thread-block { border-bottom: 2px solid var(--border, #d5dde7); }
.thread-block:last-child { border-bottom: none; }

/* Main topic row */
.thread-topic {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 4px 10px;
  padding: 10px 14px;
  background: var(--blue-50, #f0f4f9);
  border-bottom: 1px solid var(--blue-100, #dbe6f5);
}
.thread-topic-title { font-size: 14px; font-weight: 700; flex: 1 1 300px; }
.thread-topic-title a { color: var(--blue-800, #15335b); }
.thread-topic-title a:hover { color: var(--blue-500, #2867b8); }
.thread-topic-meta {
  font-size: 12px;
  color: var(--text-sec, #5a6272);
  font-weight: normal;
  white-space: nowrap;
  display: flex;
  align-items: center;
  gap: 4px;
}
.thread-topic-stats {
  display: flex;
  gap: 14px;
  font-size: 12px;
  color: var(--text-sec, #5a6272);
  white-space: nowrap;
}
.thread-topic-stats span strong { color: var(--text, #2a2e35); }

/* Award icon */
.award-icon { height: 14px; width: auto; vertical-align: middle; margin-right: 2px; }

/* Reply tree — yellow left bar only on selected/active thread */
.thread-replies {
  border-left: 5px solid #FFD700;
  margin-left: 14px;
  padding: 2px 0 4px;
}
.reply-row {
  display: flex;
  align-items: baseline;
  gap: 6px;
  padding: 5px 10px 5px 0;
  border-bottom: 1px solid #f4f6f8;
  font-size: 13px;
}
.reply-row:last-child { border-bottom: none; }
.reply-indent { display: inline-block; flex-shrink: 0; color: var(--border, #d5dde7); }
.reply-title { flex: 1 1 200px; }
.reply-title a { color: var(--text, #2a2e35); }
.reply-title a:hover { color: var(--blue-600, #235495); }
.reply-meta { font-size: 12px; color: var(--text-sec, #5a6272); white-space: nowrap; display: flex; align-items: center; gap: 3px; }
.reply-id { font-size: 11px; color: #b0bdd0; }

/* Badges */
.badge-hot {
  display: inline-block; padding: 1px 6px; background: #fff3e0;
  color: #e65100; font-size: 10px; font-weight: 700;
  border-radius: 3px; margin-left: 6px; vertical-align: middle;
}
.badge-new {
  display: inline-block; padding: 1px 6px; background: #e3f2fd;
  color: #1565c0; font-size: 10px; font-weight: 700;
  border-radius: 3px; margin-left: 6px; vertical-align: middle;
}
.badge-pin {
  display: inline-block; padding: 1px 6px; background: #f3e5f5;
  color: #6a1b9a; font-size: 10px; font-weight: 700;
  border-radius: 3px; margin-left: 6px; vertical-align: middle;
}

/* Yellow stripe for selected/active thread (legacy DCForum rows) */
.page-forum-topics .selected_row {
  border-left: 5px solid #FFD700 !important;
  background-color: #fffef5 !important;
}

/* Sidebar cards */
.sidebar-card {
  background: #fff;
  border: 1px solid var(--border, #d5dde7);
  border-radius: 8px;
  box-shadow: 0 1px 5px rgba(0,0,0,0.06);
  padding: 14px;
  margin-bottom: 14px;
}
.sidebar-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--blue-800, #15335b);
  display: flex;
  align-items: center;
  gap: 6px;
  border-bottom: 2px solid var(--blue-100, #dbe6f5);
  padding-bottom: 8px;
  margin-bottom: 10px;
}
.sidebar-title::before {
  content: '';
  width: 8px; height: 8px;
  background: var(--red, #c11f2d);
  border-radius: 1px;
}
.filter-btns { display: flex; gap: 6px; margin-bottom: 8px; }
.filter-btn {
  padding: 5px 12px;
  border: 1px solid var(--border, #d5dde7);
  border-radius: 4px;
  font-size: 12px;
  color: var(--text-sec, #5a6272);
  background: #fff;
  cursor: pointer;
}
.filter-btn:hover { border-color: var(--blue-300, #8ab2e5); color: var(--blue-600, #235495); }
.filter-btn.active { background: var(--blue-600, #235495); color: #fff; border-color: var(--blue-600, #235495); }
.forum-list { list-style: none; font-size: 13px; }
.forum-list li { padding: 4px 0; border-bottom: 1px solid #f4f4f4; }
.forum-list li:last-child { border-bottom: none; }
.forum-list a { color: var(--blue-600, #235495); }
.forum-list .current { font-weight: 700; color: var(--text, #2a2e35); }
.sidebar-stat { font-size: 12px; color: var(--text-sec, #5a6272); padding: 3px 0; }
.sidebar-stat strong { color: var(--text, #2a2e35); }

/* ============================================
   3. FORUM LOGIN PAGE
   Design: forum-login-redesign.html
   ============================================ */
.page-forum-login {
  max-width: 700px;
  margin: 20px auto;
  padding: 0 16px;
}
/* Two-column login layout (OAuth left | form right) */
.login-two-col {
  display: flex;
  align-items: stretch;
  gap: 0;
}
.login-left {
  flex: 1;
  padding-right: 32px;
  display: flex;
  flex-direction: column;
}
.login-left .oauth-username-notice {
  margin-top: auto;
  margin-bottom: 10px;
  padding-top: 20px;   /* mehr Luft zwischen OAuth-Buttons und gelbem Hinweis */
}
.login-left .oauth-link-hint {
  font-size: 12px;
  color: #888;
  margin: 8px 0 0;     /* Abstand zum gelben Hinweis darueber */
  line-height: 1.4;
}
.login-left .oauth-link-hint a {
  color: var(--blue-700, #1a4b8c);
}
.login-divider-v {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  padding: 0 20px;
  color: #999;
  font-size: 13px;
  flex-shrink: 0;
}
.login-divider-v::before {
  content: '';
  position: absolute;
  top: 0; bottom: 0; left: 50%;
  border-left: 1px solid var(--border, #d5dde7);
}
.login-divider-v span {
  position: relative;
  background: #fff;
  padding: 6px 0;
  margin-top: 60px;
}
.login-right {
  flex: 1;
  padding-left: 32px;
}
@media (max-width: 600px) {
  .login-two-col { flex-direction: column; }
  .login-left { padding-right: 0; padding-bottom: 24px; }
  .login-divider-v {
    flex-direction: row;
    padding: 0;
    margin: 0 0 16px;
  }
  .login-divider-v::before {
    top: 50%; bottom: auto;
    left: 0; right: 0;
    border-left: none;
    border-top: 1px solid var(--border, #d5dde7);
    width: 100%;
  }
  .login-divider-v span {
    margin-top: 0;
    padding: 0 14px;
  }
  .login-right { padding-left: 0; }
}
.page-forum-login .card {
  background: #fff;
  border: 1px solid var(--border, #d5dde7);
  border-radius: 8px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.10);
  padding: 32px;
  overflow: visible;
}
.page-forum-login .card-title {
  font-size: 20px;
  font-weight: 700;
  color: var(--blue-800, #15335b);
  margin-bottom: 24px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.page-forum-login .card-title::before {
  content: '';
  display: inline-block;
  width: 11px; height: 11px;
  background: var(--red, #c11f2d);
  border-radius: 1px;
  flex-shrink: 0;
}
/* Form elements */
.form-group { margin-bottom: 16px; }
.form-label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--text, #2a2e35);
  margin-bottom: 6px;
}
.form-control {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--border, #d5dde7);
  border-radius: 4px;
  font-size: 14px;
  color: var(--text, #2a2e35);
  outline: none;
  background: #fff;
  box-sizing: border-box;
}
.form-control:focus {
  border-color: var(--blue-600, #235495);
  box-shadow: 0 0 0 3px rgba(35,84,149,0.12);
}
.page-forum-login .form-group {
  margin-bottom: 16px;
}
.page-forum-login label,
.page-forum-login .form-label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--text, #2a2e35);
  margin-bottom: 6px;
}
.page-forum-login input[type="text"],
.page-forum-login input[type="password"] {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--border, #d5dde7);
  border-radius: 4px;
  font-size: 14px;
  box-sizing: border-box;
  outline: none;
}
.page-forum-login input[type="text"]:focus,
.page-forum-login input[type="password"]:focus {
  border-color: var(--blue-600, #235495);
  box-shadow: 0 0 0 3px rgba(35,84,149,0.12);
}
/* Checkbox row */
.checkbox-row { display: flex; align-items: center; gap: 8px; margin-bottom: 20px; }
.checkbox-row input[type=checkbox] { width: 16px; height: 16px; accent-color: var(--blue-600, #235495); cursor: pointer; }
.checkbox-row label { font-size: 13px; color: var(--text-sec, #5a6272); cursor: pointer; }
/* Submit button */
.btn-submit {
  width: 100%;
  padding: 12px;
  background: var(--blue-600, #235495);
  color: #fff;
  border: none;
  border-radius: 4px;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
}
.btn-submit:hover { background: var(--blue-700, #1e4476); }
.page-forum-login input[type="submit"],
.page-forum-login .btn-submit {
  width: 100%;
  padding: 12px;
  background: var(--blue-600, #235495);
  color: #fff;
  border: none;
  border-radius: 4px;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
}
.page-forum-login input[type="submit"]:hover,
.page-forum-login .btn-submit:hover {
  background: var(--blue-700, #1e4476);
}
/* Divider */
.form-divider {
  border: none;
  border-top: 1px solid var(--border, #d5dde7);
  margin: 16px 0;
}
/* Footer links */
.form-links {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 13px;
}
.form-links a { color: var(--blue-600, #235495); }
.form-links a:hover { color: var(--blue-500, #2867b8); text-decoration: underline; }
.form-links .register-link { font-weight: 600; }
.page-forum-login .form-links {
  display: flex;
  justify-content: space-between;
  margin-top: 16px;
  padding-top: 12px;
  border-top: 1px solid var(--border, #d5dde7);
  font-size: 13px;
}

/* ============================================
   4. FORUM RANGLISTE PAGE
   Design: forum-rangliste-redesign.html
   ============================================ */

/* Breadcrumb + Toolbar außerhalb des Grids (wie page-forum-topics-outer) */
.page-rangliste-outer .breadcrumb { padding: 12px 16px 0; }
.page-rangliste-outer .forum-toolbar a.active { color: #003580; }

.page-rangliste {
  max-width: 1440px;
  margin: 16px auto;
  padding: 0 16px;
  display: grid;
  grid-template-columns: 1fr 260px;
  gap: 20px;
  align-items: stretch;
}
.page-rangliste .page-header {
  grid-column: 1 / -1;
}
.page-rangliste > main,
.rangliste-main { display: flex; flex-direction: column; min-width: 0; }
.page-rangliste > main .card,
.rangliste-main .card { flex: 1; }
.rangliste-sidebar,
.page-rangliste .sidebar { display: flex; flex-direction: column; min-width: 0; }
.rangliste-sidebar .card:last-child,
.page-rangliste .sidebar .card:last-child { flex: 1; }
.page-rangliste .card {
  background: #fff;
  border: 1px solid var(--border, #d5dde7);
  border-radius: 8px;
  box-shadow: 0 1px 5px rgba(0,0,0,0.06);
  overflow: hidden;
  margin-bottom: 20px;
}
.page-rangliste .card:last-child { margin-bottom: 0; }
.rangliste-grid {
  display: contents;
}

/* Rang table */
.rang-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.rang-table th {
  background: var(--blue-50, #f0f4f9);
  padding: 9px 12px;
  font-size: 12px; font-weight: 600;
  color: var(--text-sec, #5a6272);
  border-bottom: 2px solid var(--border, #d5dde7);
  text-align: left;
  white-space: nowrap;
}
.rang-table th.num { text-align: right; }
.rang-table td { padding: 10px 12px; border-bottom: 1px solid #f0f2f5; vertical-align: middle; }
.rang-table td.num { text-align: right; white-space: nowrap; color: var(--text-sec, #5a6272); }
.rang-table tbody tr:hover { background: var(--blue-50, #f0f4f9); }
.rang-table tbody tr:last-child td { border-bottom: none; }

/* Rang badges */
.rang-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px; height: 28px;
  border-radius: 50%;
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
}
.rang-badge.gold   { background: #FFD700; color: #7a5c00; }
.rang-badge.silver { background: #C0C0C0; color: #5a5a5a; }
.rang-badge.bronze { background: #CD7F32; color: #fff; }
.rang-badge.rest   { background: var(--blue-50, #f0f4f9); color: var(--blue-600, #235495); border: 1px solid var(--blue-100, #dbe6f5); font-size: 12px; }

.user-link { font-weight: 700; color: var(--text, #2a2e35); }
.user-link:hover { color: var(--blue-600, #235495); }

/* Award images */
.award-img { height: 26px; width: auto; vertical-align: middle; display: inline-block; margin: 0 1px; }
/* Rang-Spalte (2. td) zentrieren — Badges sind Kreise, nicht Zahlen */
.rang-table td:nth-child(2) { text-align: center; }
/* Auszeichnungs-Icons: Seitenverhältnis erhalten (nicht verzerren) */
.rang_icon_gross {
  height: 24px !important;
  width: auto !important;
  object-fit: contain;
  vertical-align: middle;
  display: inline-block;
}
.rang_icon_klein {
  height: 10px !important;
  width: auto !important;
  object-fit: contain;
  vertical-align: middle;
  display: inline-block;
}

/* Rangliste table (legacy DCForum) */
.dcborder.rangliste { width: 100% !important; }
.dcborder.rangliste td { padding: 8px 10px !important; }

/* Sidebar: Status levels */
.level-list { list-style: none; padding: 14px 16px; }
.level-list li {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 10px 0; border-bottom: 1px solid #f0f2f5;
}
.level-list li:last-child { border-bottom: none; }
.level-stars { font-size: 13px; flex-shrink: 0; color: #f0a500; }
.level-info { flex: 1; }
.level-name { font-weight: 700; font-size: 13px; color: var(--text, #2a2e35); }
.level-pts { font-size: 12px; color: var(--text-sec, #5a6272); margin-top: 1px; }
.level-note { font-size: 12px; color: var(--text-sec, #5a6272); padding: 0 16px 14px; line-height: 1.6; }

/* Sidebar: Aktuelle Woche */
.week-list { list-style: none; padding: 8px 16px 14px; }
.week-list li {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 0; border-bottom: 1px solid #f0f2f5;
}
.week-list li:last-child { border-bottom: none; }
.week-rank { font-size: 16px; flex-shrink: 0; }
.week-info { flex: 1; }
.week-user { font-weight: 700; font-size: 13px; color: var(--text, #2a2e35); }
.week-detail { font-size: 12px; color: var(--text-sec, #5a6272); }

/* ============================================
   5. FORUM REGISTER PAGE
   Design: forum-register-redesign.html
   ============================================ */
.page-forum-register {
  max-width: 520px;
  margin: 32px auto;
  padding: 0 16px;
}
.page-forum-register .card,
.register-card {
  background: #fff;
  border: 1px solid var(--border, #d5dde7);
  border-radius: 8px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.10);
  padding: 32px;
  overflow: visible;
}
.page-forum-register input[type="text"],
.page-forum-register input[type="password"],
.page-forum-register input[type="email"] {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--border, #d5dde7);
  border-radius: 4px;
  font-size: 14px;
  box-sizing: border-box;
  outline: none;
  background: #fff;
}
.page-forum-register input[type="text"]:focus,
.page-forum-register input[type="password"]:focus,
.page-forum-register input[type="email"]:focus {
  border-color: var(--blue-600, #235495);
  box-shadow: 0 0 0 3px rgba(35,84,149,0.12);
}
.page-forum-register input[type="submit"] {
  padding: 12px 24px;
  background: var(--blue-600, #235495);
  color: #fff;
  border: none;
  border-radius: 4px;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
}
.page-forum-register input[type="submit"]:hover {
  background: var(--blue-700, #1e4476);
}
/* AGB Textarea größer — kein Scrollen nötig */
.page-forum-register textarea,
.register-card textarea {
  width: 100%;
  min-height: 350px;
  padding: 12px;
  border: 1px solid var(--border, #d5dde7);
  border-radius: 4px;
  font-size: 14px;
  line-height: 1.6;
  box-sizing: border-box;
  resize: vertical;
}
/* Step indicator */
.step-indicator {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 24px; font-size: 13px;
}
.step { display: flex; align-items: center; gap: 6px; color: var(--text-sec, #5a6272); }
.step.done { color: var(--green, #1a8a4a); }
.step.active { color: var(--blue-600, #235495); font-weight: 700; }
.step-num {
  width: 22px; height: 22px; border-radius: 50%;
  border: 2px solid currentColor;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700; flex-shrink: 0;
}
.step.done .step-num { background: var(--green, #1a8a4a); color: #fff; border-color: var(--green, #1a8a4a); }
.step.active .step-num { background: var(--blue-600, #235495); color: #fff; border-color: var(--blue-600, #235495); }
.step-arrow { color: #ccc; font-size: 16px; line-height: 1; }
.step-label { white-space: nowrap; }
.step.done .step-label { text-decoration: line-through; color: var(--green, #1a8a4a); }
/* 2-column grid for name fields */
.form-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 16px;
}
.form-grid-2 .form-group { margin-bottom: 0; }
/* Hint text */
.form-hint {
  font-size: 12px;
  color: var(--text-sec, #5a6272);
  margin-bottom: 20px;
}
/* Buttons row */
.buttons-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}
.btn-back {
  padding: 11px 20px;
  background: #fff;
  color: var(--text-sec, #5a6272);
  border: 1px solid var(--border, #d5dde7);
  border-radius: 4px;
  font-size: 14px; font-weight: 600;
  cursor: pointer;
}
.btn-back:hover { background: var(--blue-50, #f0f4f9); border-color: #b0bdd0; color: var(--text, #2a2e35); }

/* Register-Formular: cellspacing-Lücken entfernen, kein Hover */
.page-forum-register table { border-collapse: collapse !important; width: 100%; }
.page-forum-register tr td {
  padding: 10px 14px !important;
  border-bottom: 1px solid #e8edf2 !important;
  font-size: 13px !important;
  line-height: 1.5 !important;
}
.page-forum-register tr td.dclite,
.page-forum-register tr.dclite td { background: #fff !important; }
.page-forum-register tr td.dcdark,
.page-forum-register tr.dcdark td { background: var(--blue-50, #f0f4f9) !important; }
/* Kein Hover auf Formular-Zeilen */
.page-forum-register tr:hover td { background: inherit !important; }
.page-forum-register tr.dclite:hover td { background: #fff !important; }
.page-forum-register tr.dcdark:hover td { background: var(--blue-50, #f0f4f9) !important; }
.page-forum-register .dcemp { font-size: 14px !important; font-weight: 700 !important; }

/* ============================================
   6. FORUM USER PROFILE PAGE
   Design: forum-user-profile-redesign.html
   ============================================ */
.page-profile {
  max-width: 1100px;
  margin: 16px auto;
  padding: 0 16px;
  display: grid;
  grid-template-columns: 170px 1fr;
  gap: 20px;
  align-items: start;
}
/* Forum sub-nav */
.forum-subnav { background: var(--blue-100, #dbe6f5); border-bottom: 1px solid var(--border, #d5dde7); }
.forum-subnav-inner { max-width: 1100px; margin: 0 auto; display: flex; gap: 0; padding: 0 16px; }
.forum-subnav a { font-size: 13px; color: var(--blue-700, #1e4476); padding: 7px 14px; display: block; border-right: 1px solid var(--border, #d5dde7); }
.forum-subnav a:first-child { padding-left: 0; }
.forum-subnav a:hover { background: rgba(0,0,0,0.05); text-decoration: none; }

/* Profile sidebar */
.profile-index-card {
  background: #fff;
  border: 1px solid var(--border, #d5dde7);
  border-radius: 6px;
  padding: 14px;
}
.index-title { font-size: 13px; font-weight: 700; color: var(--blue-800, #15335b); margin-bottom: 10px; }
.index-search input {
  width: 100%; padding: 5px 8px;
  border: 1px solid var(--border, #d5dde7);
  border-radius: 3px;
  font-size: 12px;
  color: var(--text, #2a2e35);
}
.index-search button,
.index-search input[type=submit] {
  margin-top: 5px; width: 100%; padding: 5px;
  background: var(--blue-600, #235495);
  color: #fff; border: none; border-radius: 3px;
  font-size: 12px; cursor: pointer;
}
.index-search button:hover,
.index-search input[type=submit]:hover { background: var(--blue-500, #2867b8); }
.index-legend { margin-top: 12px; padding-top: 10px; border-top: 1px solid var(--border, #d5dde7); }
.legend-row { display: flex; align-items: center; gap: 6px; font-size: 11px; color: var(--text-sec, #5a6272); margin-bottom: 5px; }
.legend-row img { width: 14px; height: 14px; opacity: 0.7; }
.alpha-group { margin-bottom: 6px; display: flex; flex-wrap: wrap; gap: 3px; }
.alpha-link {
  display: inline-block; padding: 3px 7px;
  border: 1px solid var(--border, #d5dde7);
  border-radius: 3px; font-size: 12px;
  color: var(--blue-600, #235495);
  line-height: 1.4; text-decoration: none;
}
.alpha-link:hover { background: var(--blue-50, #f0f4f9); text-decoration: none; }
.alpha-link.empty { color: #bcc6d0; border-color: #e8ecf0; pointer-events: none; }
.alpha-link.active { background: var(--blue-700, #1e4476); color: #fff; border-color: var(--blue-700, #1e4476); }

/* Profile main area */
.profile-main { min-width: 0; }

/* Profile header */
.profile-header { display: flex; gap: 16px; align-items: flex-start; flex-wrap: wrap; margin-bottom: 16px; }
.profile-avatar { flex-shrink: 0; }
.profile-avatar img {
  width: 72px; height: 72px; border-radius: 50%;
  border: 2px solid var(--blue-100, #dbe6f5);
  object-fit: cover;
}
.profile-avatar-placeholder {
  width: 72px; height: 72px; border-radius: 50%;
  background: var(--blue-100, #dbe6f5);
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; font-weight: 700; color: var(--blue-600, #235495);
}
.profile-info { flex: 1 1 200px; }
.profile-username { font-size: 20px; font-weight: 700; color: var(--blue-800, #15335b); margin-bottom: 2px; }
.profile-status { font-size: 13px; color: var(--text-sec, #5a6272); margin-bottom: 6px; }
.profile-meta { font-size: 13px; color: var(--text-sec, #5a6272); margin-bottom: 6px; }
.profile-rang { display: inline-flex; align-items: center; gap: 6px; }
.profile-rang a { font-size: 13px; color: var(--blue-600, #235495); }
.profile-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 10px; }
.action-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 12px;
  border: 1px solid var(--border, #d5dde7);
  border-radius: 4px;
  font-size: 12px;
  color: var(--blue-600, #235495);
  background: #fff;
  text-decoration: none;
}
.action-btn:hover { background: var(--blue-50, #f0f4f9); text-decoration: none; }
.action-btn svg { width: 14px; height: 14px; flex-shrink: 0; }
.action-btn img { width: 14px; height: 14px; vertical-align: middle; }

/* Aktien panel */
.aktien-panel {
  flex-shrink: 0; min-width: 180px;
  background: var(--blue-50, #f0f4f9);
  border: 1px solid var(--border, #d5dde7);
  border-radius: 6px;
  padding: 10px 12px;
}
.aktien-panel-title {
  font-size: 12px; font-weight: 700;
  color: var(--blue-800, #15335b);
  margin-bottom: 6px;
  padding-bottom: 5px;
  border-bottom: 1px solid var(--border, #d5dde7);
}

/* Profile fields table */
.profile-fields { width: 100%; border-collapse: collapse; font-size: 13px; margin-bottom: 0; }
.profile-fields td { padding: 7px 10px; border-bottom: 1px solid var(--border, #d5dde7); vertical-align: top; }
.profile-fields tr:last-child td { border-bottom: none; }
.profile-fields .lbl { width: 30%; color: var(--text-sec, #5a6272); font-weight: 600; white-space: nowrap; }
.profile-fields .val { color: var(--text, #2a2e35); }
.profile-fields tr:nth-child(even) td { background: var(--blue-50, #f0f4f9); }

/* Data table (Letzte Beitraege) */
.data-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.data-table th { background: var(--blue-50, #f0f4fa); color: var(--blue-800, #15335b); padding: 8px 10px; text-align: left; font-size: 12px; font-weight: 600; white-space: nowrap; }
.data-table td { padding: 7px 10px; border-bottom: 1px solid var(--border, #d5dde7); vertical-align: middle; }
.data-table tr:nth-child(even) td { background: var(--blue-50, #f0f4f9); }
.data-table tr:hover td { background: var(--blue-100, #dbe6f5); }
.data-table td.date { white-space: nowrap; color: var(--text-sec, #5a6272); font-size: 12px; }
.data-table td.subject a { color: var(--blue-600, #235495); }
.topic-icon { width: 16px; height: 16px; vertical-align: middle; margin-right: 4px; }
.aus-imgs { white-space: nowrap; }
.aus-imgs img { height: 16px; width: auto; vertical-align: middle; margin: 0 1px; }

/* User list table */
.list-user-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.list-user-table th { background: var(--blue-50, #f0f4fa) !important; color: var(--blue-800, #15335b) !important; padding: 7px 10px; font-size: 12px; font-weight: 600; text-align: left; }
.list-user-table td { padding: 6px 10px; border-bottom: 1px solid var(--border, #d5dde7); }
.list-user-table tr:nth-child(even) td { background: var(--blue-50, #f0f4f9); }
.list-user-table tr:hover td { background: var(--blue-100, #dbe6f5); }

/* ============================================
   FORUM UEBERSICHT (existing)
   ============================================ */
.page-forum-uebersicht .left_news .card {
  overflow: visible !important;
}
.page-forum-uebersicht .left_news table {
  width: 100% !important;
}
.page-forum-uebersicht .item {
  padding: 12px 0;
  border-bottom: 1px solid #e8e8e8;
}
.page-forum-uebersicht .item:last-of-type {
  border-bottom: none;
}
.page-forum-uebersicht .message {
  background: var(--blue-50, #f0f4f9);
  border-left: 3px solid var(--blue-300, #8ab2e5);
  border-radius: 0 6px 6px 0;
  padding: 14px 16px;
  font-size: 14px;
  line-height: 1.6;
  margin: 8px 0;
}
.page-forum-uebersicht .dottedline {
  display: none;
}
.page-forum-uebersicht .teaser {
  background: var(--blue-50, #f0f4f9) !important;
  border-radius: 6px;
  margin-top: 12px;
}

/* ============================================
   FORUM BUTTONS
   ============================================ */
.btn-forum,
.btn.btn-mini.btn-primary {
  display: inline-block;
  padding: 6px 16px;
  border-radius: 4px;
  font-size: 13px;
  font-weight: 600;
  color: #fff;
  background: var(--blue-600, #235495);
  border: none;
  cursor: pointer;
  text-decoration: none;
}
.btn-forum:hover,
.btn.btn-mini.btn-primary:hover {
  background: var(--blue-500, #2867b8);
  text-decoration: none;
  color: #fff;
}
.btn.btn-mini {
  display: inline-block;
  padding: 6px 16px;
  border-radius: 4px;
  font-size: 13px;
  font-weight: 600;
  color: var(--blue-600, #235495);
  background: transparent;
  border: 1px solid var(--blue-600, #235495);
  cursor: pointer;
  text-decoration: none;
}
.btn.btn-mini:hover {
  background: var(--blue-50, #f0f4f9);
  color: var(--blue-500, #2867b8);
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 760px) {
  .page-forum-topics {
    grid-template-columns: 1fr;
  }
  .page-forum-topics .forum-topics-sidebar {
    display: none;
  }
  .page-forum-topics-outer .forum-toolbar { gap: 12px; padding: 10px 0 8px; }
  .page-forum-topics-outer .forum-toolbar img { width: 24px; height: 24px; }
  .page-forum-topics-outer .forum-toolbar a { font-size: 10px; gap: 2px; }
  .page-forum-topics-outer .forum-status-bar { font-size: 12px; padding: 8px 12px; }
  .page-forum-topics-outer .breadcrumb { font-size: 12px; }
  .page-rangliste-outer .forum-toolbar { gap: 12px; padding: 10px 8px 8px; }
  .page-rangliste-outer .forum-toolbar img { width: 24px; height: 24px; }
  .page-rangliste-outer .forum-toolbar a { font-size: 10px; gap: 2px; }
  .page-rangliste-outer .breadcrumb { font-size: 12px; }
  .page-rangliste {
    grid-template-columns: 1fr;
  }
  .page-rangliste .page-header { grid-column: 1; }
  .rangliste-sidebar {
    order: -1;
  }
  .page-profile {
    grid-template-columns: 1fr;
  }
  .profile-index-card { order: 2; }
}
@media (max-width: 640px) {
  .page-forum-login {
    margin: 24px auto;
  }
  .page-forum-login .card {
    padding: 24px 20px;
  }
  .page-forum-register {
    margin: 24px auto;
  }
  .page-forum-register .card,
  .register-card {
    padding: 24px 20px;
  }
  .form-grid-2 { grid-template-columns: 1fr; }
  .page-forum-index {
    padding: 0 8px;
  }
  .forum-index-table th.col-desc,
  .forum-index-table td.col-desc { display: none; }
  .rang-table th.col-pts,
  .rang-table td.col-pts { display: none; }
}

/* ===== Forum Search Results Redesign ===== */

/* Pagination: besserer Kontrast aktive Seite — überschreibt td.dcpagelink a */
td.dcpagelink a.page-btn.active,
td.dcpagelink2 a.page-btn.active,
.pagination a.page-btn.active,
a.page-btn.active {
  background: var(--blue-700, #1e4476) !important;
  color: #fff !important;
  border-color: var(--blue-700, #1e4476) !important;
}
/* Auch die dcpagelink Links generell stylen */
td.dcpagelink a.page-btn,
td.dcpagelink2 a.page-btn {
  color: var(--blue-600, #235495) !important;
}
/* Hover auf ganze Seite entfernen — nur äußere Wrapper-Zeile (hat td.dcdark als direktes Kind) */
body > table[width="100%"]:hover,
table.dctable tr:hover { background: transparent !important; }
tr.dclite:has(> td.dcdark):hover td { background: transparent !important; }
/* Hover auf Pagination-Zeilen unterdrücken (TR.dclite enthält Pagination tief verschachtelt) */
tr.dclite:has(td.dcpagelink):hover td,
tr.dclite:has(td.dcpagelink2):hover td { background: transparent !important; }

/* Letzte Beiträge Pagination */
.profile-pagination {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 0 4px;
  font-size: 13px;
}
.profile-pagination-info {
  color: var(--text-sec, #5a6272); flex: 1; text-align: center; font-size: 12px;
}

/* ============================================
   PROFILE REDESIGN — Avatar-Hero, Definition List, Mobile
   ============================================ */

/* Größerer Avatar (90px) */
.profile-avatar-lg img {
  width: 90px; height: 90px; border-radius: 50%;
  border: 3px solid var(--blue-100, #dbe6f5); object-fit: cover;
}
.profile-avatar-placeholder-lg {
  width: 90px; height: 90px; border-radius: 50%;
  background: var(--blue-600, #235495);
  display: flex; align-items: center; justify-content: center;
  font-size: 36px; font-weight: 700; color: #fff;
}

/* Profil-Felder als Definition List (Grid-Layout) */
.profile-dl {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 0;
  margin: 0;
  font-size: 13px;
}
.profile-dl dt {
  padding: 7px 10px;
  border-bottom: 1px solid var(--border, #d5dde7);
  color: var(--text-sec, #5a6272);
  font-weight: 600;
  background: var(--blue-50, #f0f4f9);
  word-break: break-word;
}
.profile-dl dd {
  margin: 0;
  padding: 7px 10px;
  border-bottom: 1px solid var(--border, #d5dde7);
  color: var(--text, #2a2e35);
  word-break: break-word;
}
.profile-dl dt:last-of-type,
.profile-dl dd:last-of-type { border-bottom: none; }

/* Mobile: Header zentriert, Fields gestapelt */
@media (max-width: 500px) {
  .profile-header-hero { flex-direction: column; align-items: center; text-align: center; }
  .profile-header-hero .profile-actions { justify-content: center; }
  .profile-dl { grid-template-columns: 1fr; }
  .profile-dl dt { border-bottom: none; padding-bottom: 2px; }
  .profile-dl dd { padding-top: 2px; border-bottom: 1px solid var(--border, #d5dde7); }
}

/* Letzte Beiträge: unwichtige Spalten auf Mobile ausblenden */
@media (max-width: 640px) {
  .data-table th.col-aus,
  .data-table td.col-aus,
  .data-table th.col-aktien,
  .data-table td.col-aktien { display: none; }
}

/* Suchergebnisse als Cards */
tr.dclite td {
  padding: 12px 16px !important;
  border-bottom: 1px solid #e8edf2 !important;
  background: #fff !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
}
tr.dclite td a {
  font-size: 14px !important;
  font-weight: 400 !important;
  color: #1e4476 !important;
  text-decoration: none !important;
}
/* Reply-Betreff: normal weight — nur topic-Titel (dclink) soll fett sein */
a.dctocsubject {
  font-weight: 400 !important;
  font-size: 13px !important;
}
tr.dclite td a:hover {
  color: #2867b8 !important;
  text-decoration: underline !important;
}
/* Hover nur auf Ergebnis-Zeilen (nicht Wrapper-Zeile, nicht Pagination-Zeile) */
/* Ausgenommen: show_topics (.page-forum-topics) und show_mesg (.page-show-topic) */
body:not(:has(.page-forum-topics)):not(:has(.page-show-topic)) tr.dclite:not(:has(> td.dcdark)):not(:has(td.dcpagelink)):not(:has(td.dcpagelink2)):hover td {
  background: #f0f4f9 !important;
}
/* Hover in show_mesg komplett deaktivieren */
.page-show-topic tr.dclite:not(:has(> td.dcdark)):not(:has(td.dcpagelink)):not(:has(td.dcpagelink2)):hover td,
.page-show-topic table.dctoc tr:hover td,
.page-show-topic table.dctoc tr.dclite:hover td,
.page-show-topic table.dctoc tr.dcdark:hover td {
  background: transparent !important;
}
/* Meta-Info (Autor, Datum) — größere Schrift für bessere Lesbarkeit */
span.dccaption {
  font-size: 13px !important;
  color: #5a6272 !important;
  line-height: 1.6 !important;
  display: block !important;
  margin-top: 3px !important;
}
span.dcdate {
  font-weight: 600 !important;
  color: #2a2e35 !important;
}
/* Forum-Header in Suchergebnissen */
tr.dcdark td {
  background: var(--blue-50, #f0f4f9) !important;
  padding: 10px 16px !important;
  border-bottom: 2px solid var(--blue-100, #dbe6f5) !important;
  font-size: 15px !important;
}
tr.dcdark td a {
  color: var(--blue-800, #15335b) !important;
  font-weight: 700 !important;
  text-decoration: none !important;
}
/* Suchformular Titel */
.dcemp {
  font-size: 18px !important;
  font-weight: 700 !important;
  color: var(--blue-800, #15335b) !important;
}

/* ===== Thread-Baum (dctoc): kompakte Schrift für Author/Datum/ID ===== */
/* Überschreibt die globalen tr.dclite/tr.dcdark 14-15px-Regeln */
table.dctoc td,
table.dctoc table td {
  font-size: 14px !important;
  padding: 2px 4px !important;
  line-height: 1.4 !important;
  border-bottom: none !important;
}
table.dctoc td a,
table.dctoc table td a {
  font-size: 14px !important;
  font-weight: 400 !important;
}
/* Subject-Link — gleiche Schrift wie show_topics */
table.dctoc td a.dcmessageTreetocsubject,
table.dctoc table td a.dcmessageTreetocsubject {
  font-size: 14px !important;
  font-weight: 400 !important;
}
/* Author-Link: a.dcauthorlink.link hat Vorrang vor a.link (2 Klassen > 1 Klasse) */
table.dctoc table td a.dcauthorlink.link {
  font-size: 12px !important;
  font-weight: 400 !important;
}
/* Meta-Spans (dctocmisc, dcmessageTreetocmisc) */
table.dctoc table .dcmessageTreetocmisc,
table.dctoc table .dctocmisc {
  font-size: 12px !important;
}

/* ===== read_new: obere doppelte Treffer-Anzeige (dcerrorsubject) ausblenden ===== */
tr.dclite:has(> td > div.dcerrorsubject),
td.dclite:has(> table.dcborder:has(tr.dclite > td > div.dcerrorsubject)) {
  display: none !important;
}

/* ===== read_new: Aufzählungszeichen links Abstand ===== */
.dclist, .dclite ul, .read-new-list {
  padding-left: 24px !important;
}

/* ===== Pagination allgemein im Forum ===== */
table[width="100%"] td[align="center"] > a.page-btn,
table[width="100%"] td[align="center"] > span {
  display: inline-block;
  min-width: 32px;
  height: 32px;
  line-height: 32px;
  text-align: center;
  border: 1px solid #d5dde7;
  border-radius: 6px;
  margin: 0 2px;
  font-size: 14px;
  font-weight: 600;
  color: #1e4476;
  background: #fff;
  text-decoration: none;
  padding: 0 8px;
}

/* ===== Suchformular: mehr Abstand + größere Schrift ===== */
/* Linke Spalte: Formularfelder */
form[name="thisform"]:has(input[name="search"]) {
  padding: 4px 8px !important;
}
form[name="thisform"]:has(input[name="search"]) p {
  margin: 0 0 18px !important;
  font-size: 14px !important;
  line-height: 1.75 !important;
  color: var(--text, #2a2e35) !important;
}
form[name="thisform"]:has(input[name="search"]) input[type="text"],
form[name="thisform"]:has(input[name="search"]) select {
  font-size: 14px !important;
  padding: 5px 8px !important;
  border: 1px solid var(--border, #d5dde7) !important;
  border-radius: 4px !important;
  margin-top: 4px !important;
  display: block !important;
}
form[name="thisform"]:has(input[name="search"]) input[type="submit"] {
  font-size: 14px !important;
  padding: 7px 18px !important;
  background: var(--blue-700, #1e4476) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 5px !important;
  cursor: pointer !important;
  margin-top: 6px !important;
}
/* Rechte Spalte: Hilfetext */
td.dclite[width="100%"] {
  padding: 16px 20px !important;
  vertical-align: top !important;
}
td.dclite[width="100%"] p {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--blue-800, #15335b) !important;
  margin: 0 0 12px !important;
  line-height: 1.6 !important;
}
td.dclite[width="100%"] ol {
  padding-left: 24px !important;
  margin: 0 !important;
}
td.dclite[width="100%"] li {
  font-size: 14px !important;
  line-height: 1.75 !important;
  margin-bottom: 10px !important;
  color: var(--text, #2a2e35) !important;
  padding-left: 4px !important;
}

/* ===== Post/Edit-Formular: modernes, übersichtliches Layout ===== */
/* Abstand zwischen Toolbar und erstem Abschnitt (kein "Strich direkt am Rand") */
:is(
  form[name="thisform"]:has(input[name="az"][value="post"]),
  form[name="thisform"]:has(input[name="az"][value="edit"])
) {
  display: block;
  margin-top: 12px;
}

/* Karten-Wrapper: subtiler Schatten, runde Ecken, Abstand unten */
:is(
  form[name="thisform"]:has(input[name="az"][value="post"]),
  form[name="thisform"]:has(input[name="az"][value="edit"])
) table.dcborder {
  border: 1px solid var(--border, #d5dde7) !important;
  border-radius: 8px !important;
  margin-bottom: 14px !important;
  box-shadow: 0 1px 5px rgba(0,0,0,.05) !important;
  overflow: hidden !important;
}

/* Innentabelle: keine Cellspacing-Linien */
:is(
  form[name="thisform"]:has(input[name="az"][value="post"]),
  form[name="thisform"]:has(input[name="az"][value="edit"])
) table.dcborder > tbody > tr > td > table {
  border-collapse: collapse !important;
}

/* Abschnitts-Header (Originalbeitrag, Dein Beitrag) — muss NACH den Zeilen-Regeln kommen */
/* Formular-Zeilen (nicht dcheading!) */
:is(
  form[name="thisform"]:has(input[name="az"][value="post"]),
  form[name="thisform"]:has(input[name="az"][value="edit"])
) tr.dcdark > td:not(.dcheading),
:is(
  form[name="thisform"]:has(input[name="az"][value="post"]),
  form[name="thisform"]:has(input[name="az"][value="edit"])
) tr.dcdark > th:not(.dcheading) {
  background: var(--blue-50, #f7f9fc) !important;
  border-bottom: 1px solid var(--border, #eaeef4) !important;
  padding: 10px 14px !important;
}

/* Abschnitts-Header explizit überschreiben */
:is(
  form[name="thisform"]:has(input[name="az"][value="post"]),
  form[name="thisform"]:has(input[name="az"][value="edit"])
) tr.dcdark > td.dcheading {
  background: var(--blue-50, #f0f4fa) !important;
  color: var(--blue-800, #15335b) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  padding: 10px 16px !important;
  border-bottom: 1px solid var(--blue-200, #c5d5e8) !important;
}

/* Originalbeitrag-Inhalt */
:is(
  form[name="thisform"]:has(input[name="az"][value="post"]),
  form[name="thisform"]:has(input[name="az"][value="edit"])
) tr.dclite > td {
  background: #fff !important;
  padding: 12px 16px !important;
}

/* Blockquote: schlichtes Zitat-Styling */
:is(
  form[name="thisform"]:has(input[name="az"][value="post"]),
  form[name="thisform"]:has(input[name="az"][value="edit"])
) blockquote {
  border-left: 3px solid var(--blue-300, #7baad4) !important;
  background: var(--blue-50, #f0f4f9) !important;
  border-radius: 0 4px 4px 0 !important;
  margin: 8px 0 0 0 !important;
  padding: 8px 12px !important;
  color: #555 !important;
  font-size: 13px !important;
}

/* Label-Spalte (th.dcright): kompakte, oben ausgerichtete Beschriftung */
:is(
  form[name="thisform"]:has(input[name="az"][value="post"]),
  form[name="thisform"]:has(input[name="az"][value="edit"])
) th.dcright {
  width: 110px !important;
  min-width: 90px !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  color: var(--blue-800, #15335b) !important;
  text-align: left !important;
  vertical-align: top !important;
  padding: 12px 10px 10px 14px !important;
  white-space: normal !important;
}

/* Hinweise (HTML ist an, Smilies) in der Label-Spalte — sichtbar, dezent gestylt */
:is(
  form[name="thisform"]:has(input[name="az"][value="post"]),
  form[name="thisform"]:has(input[name="az"][value="edit"])
) th.dcright p.dcemp {
  display: block !important;
  font-size: 11px !important;
  color: var(--text-sec, #5a6272) !important;
  font-weight: 400 !important;
  margin: 4px 0 0 0 !important;
  line-height: 1.4 !important;
}
:is(
  form[name="thisform"]:has(input[name="az"][value="post"]),
  form[name="thisform"]:has(input[name="az"][value="edit"])
) th.dcright a {
  display: inline !important;
  font-size: 11px !important;
  color: var(--blue-500, #2867b8) !important;
}

/* Inhalts-Spalte (td.dcleft) */
:is(
  form[name="thisform"]:has(input[name="az"][value="post"]),
  form[name="thisform"]:has(input[name="az"][value="edit"])
) td.dcleft {
  padding: 8px 14px !important;
  vertical-align: middle !important;
}

/* Text-Inputs */
:is(
  form[name="thisform"]:has(input[name="az"][value="post"]),
  form[name="thisform"]:has(input[name="az"][value="edit"])
) td.dcleft input[type="text"] {
  width: 100% !important;
  box-sizing: border-box !important;
  font-size: 14px !important;
  padding: 6px 10px !important;
  border: 1px solid var(--border, #d5dde7) !important;
  border-radius: 4px !important;
  background: #fff !important;
}

/* Textarea */
:is(
  form[name="thisform"]:has(input[name="az"][value="post"]),
  form[name="thisform"]:has(input[name="az"][value="edit"])
) td.dcleft textarea {
  width: 100% !important;
  box-sizing: border-box !important;
  font-size: 14px !important;
  padding: 8px 10px !important;
  border: 1px solid var(--border, #d5dde7) !important;
  border-radius: 4px !important;
  min-height: 180px !important;
  font-family: inherit !important;
  line-height: 1.5 !important;
  resize: vertical !important;
}

/* Submit-Buttons */
:is(
  form[name="thisform"]:has(input[name="az"][value="post"]),
  form[name="thisform"]:has(input[name="az"][value="edit"])
) input[type="submit"] {
  padding: 8px 20px !important;
  font-size: 14px !important;
  border-radius: 5px !important;
  cursor: pointer !important;
  margin-right: 8px !important;
}
:is(
  form[name="thisform"]:has(input[name="az"][value="post"]),
  form[name="thisform"]:has(input[name="az"][value="edit"])
) input[type="submit"][name="post"],
:is(
  form[name="thisform"]:has(input[name="az"][value="post"]),
  form[name="thisform"]:has(input[name="az"][value="edit"])
) input[type="submit"][name="edit"] {
  background: var(--blue-700, #1e4476) !important;
  color: #fff !important;
  border: none !important;
}
:is(
  form[name="thisform"]:has(input[name="az"][value="post"]),
  form[name="thisform"]:has(input[name="az"][value="edit"])
) input[type="submit"][name="preview"] {
  background: #fff !important;
  color: var(--blue-700, #1e4476) !important;
  border: 1px solid var(--blue-700, #1e4476) !important;
}

/* ===== OAuth: Login-Buttons ===== */
.oauth-buttons {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 16px;
}
.oauth-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 11px 16px;
  min-height: 44px;
  border: 1px solid var(--border, #d5dde7);
  border-radius: 6px;
  background: #fff;
  color: var(--text, #2a2e35) !important;
  font-size: 14px;
  font-weight: 500;
  text-decoration: none !important;
  transition: background 0.15s, border-color 0.15s;
  box-sizing: border-box;
}
.oauth-btn:hover {
  background: var(--blue-50, #f0f4f9);
  border-color: var(--blue-200, #b3caec);
  color: var(--text, #2a2e35) !important;
  text-decoration: none !important;
}
.oauth-btn svg { flex-shrink: 0; }
.oauth-divider {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 16px 0;
  color: var(--text-sec, #5a6272);
  font-size: 13px;
}
.oauth-divider::before,
.oauth-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border, #d5dde7);
}

/* ===== OAuth: Fehlermeldung ===== */
.oauth-error {
  background: #fff5f5;
  border: 1px solid #fca5a5;
  border-radius: 6px;
  color: #b91c1c;
  font-size: 13px;
  padding: 10px 14px;
  margin-bottom: 16px;
}

/* ===== OAuth: choose_username Seite ===== */
.login-card {
  background: #fff;
  border: 1px solid var(--border, #d5dde7);
  border-radius: 10px;
  padding: 32px 28px;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
.oauth-welcome-info {
  background: var(--blue-50, #f0f4f9);
  border-radius: 6px;
  padding: 12px 14px;
  margin-bottom: 16px;
  font-size: 14px;
  text-align: center;
}
.oauth-welcome-info p { margin: 0 0 4px; }
.oauth-welcome-info p:last-child { margin-bottom: 0; }
.oauth-email-display {
  color: var(--text-sec, #5a6272);
  font-size: 13px;
}
.oauth-username-notice {
  background: #fffbeb;
  border: 1px solid #fde68a;
  border-radius: 6px;
  padding: 10px 14px;
  font-size: 13px;
  margin-bottom: 16px;
  line-height: 1.5;
}
.required { color: #c0392b; margin-left: 2px; }
.optional { color: var(--text-sec, #5a6272); font-size: 12px; font-weight: 400; }

/* ===== OAuth: Profil — Verknüpfte Konten ===== */
.oauth-linked-accounts { margin-top: 8px; }
.oauth-linked-accounts h4 {
  font-size: 15px;
  font-weight: 600;
  color: var(--blue-800, #15335b);
  margin: 0 0 12px;
}
.oauth-link-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid var(--border, #e8edf2);
  font-size: 14px;
}
.oauth-link-row:last-child { border-bottom: none; }
.oauth-link-label { flex: 1; font-weight: 500; }
.oauth-link-status { font-size: 13px; }
.oauth-linked { color: #16a34a; font-weight: 500; }
.oauth-link-btn,
.oauth-unlink-btn {
  font-size: 13px;
  padding: 5px 12px;
  border-radius: 5px;
  text-decoration: none;
  border: 1px solid;
  cursor: pointer;
  white-space: nowrap;
}
.oauth-link-btn {
  color: var(--blue-600, #235495);
  border-color: var(--blue-300, #7aaad4);
  background: #fff;
}
.oauth-link-btn:hover {
  background: var(--blue-50, #f0f4f9);
  text-decoration: none;
}
.oauth-unlink-btn {
  color: #b91c1c !important;
  border-color: #fca5a5;
  background: #fff;
}
.oauth-unlink-btn:hover {
  background: #fff5f5;
  text-decoration: none !important;
}
.oauth-hint {
  font-size: 12px;
  color: var(--text-sec, #5a6272);
}

/* ===== Alert-Formular: modernes Layout ===== */

/* Karten-Wrapper */
body:has(input[name="az"][value="alert"]) table.dcborder {
  border: 1px solid var(--border, #d5dde7) !important;
  border-radius: 8px !important;
  margin-top: 8px !important;
  box-shadow: 0 1px 5px rgba(0,0,0,.05) !important;
  overflow: hidden !important;
  max-width: 700px !important;
}

/* Abschnitts-Header */
body:has(input[name="az"][value="alert"]) tr.dcheading > td {
  background: var(--blue-700, #1e4476) !important;
  color: #fff !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  padding: 10px 16px !important;
  border-bottom: none !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

/* Formular-Zeilen */
body:has(input[name="az"][value="alert"]) tr.dcdark > td {
  background: var(--blue-50, #f7f9fc) !important;
  border-bottom: 1px solid var(--border, #eaeef4) !important;
  padding: 10px 14px !important;
  vertical-align: top !important;
  font-size: 13px !important;
}

/* Textarea */
body:has(input[name="az"][value="alert"]) textarea {
  width: 100% !important;
  box-sizing: border-box !important;
  min-height: 120px !important;
  resize: vertical !important;
  border: 1px solid var(--border, #d5dde7) !important;
  border-radius: 4px !important;
  padding: 8px !important;
  font-size: 13px !important;
  font-family: inherit !important;
}

/* Submit-Button */
body:has(input[name="az"][value="alert"]) input[type="submit"] {
  background: var(--blue-700, #1e4476) !important;
  color: #fff !important;
  border: none !important;
  padding: 8px 20px !important;
  border-radius: 5px !important;
  cursor: pointer !important;
  font-size: 13px !important;
  font-weight: 600 !important;
}
body:has(input[name="az"][value="alert"]) input[type="submit"]:hover {
  background: var(--blue-600, #235495) !important;
}

/* ============================================
   Watchlist-Public Toggle
   ============================================ */
.mw-public-toggle {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 0 10px;
  border-top: 1px solid var(--border, #d5dde7);
  margin-top: 4px;
  font-size: 12px;
  color: var(--text-sec, #5a6272);
}
.mw-toggle-label {
  display: flex;
  align-items: center;
  gap: 5px;
  cursor: default;
  user-select: none;
}
.mw-toggle-input {
  display: none;
}
.mw-toggle-slider {
  position: relative;
  display: inline-block;
  width: 36px;
  height: 20px;
  background: var(--border, #c8d0db);
  border-radius: 20px;
  cursor: pointer;
  transition: background .2s;
  flex-shrink: 0;
}
.mw-toggle-slider::after {
  content: '';
  position: absolute;
  top: 3px;
  left: 3px;
  width: 14px;
  height: 14px;
  background: #fff;
  border-radius: 50%;
  transition: transform .2s;
  box-shadow: 0 1px 3px rgba(0,0,0,.2);
}
.mw-toggle-input:checked ~ .mw-toggle-slider {
  background: var(--blue-600, #235495);
}
.mw-toggle-input:checked ~ .mw-toggle-slider::after {
  transform: translateX(16px);
}

/* ============================================================
   Profile redesign: 3-column header + stats panel
   ============================================================ */

/* New 3-column header layout */
.profile-header-v2 {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  flex-wrap: wrap;
}
/* Avatar column: unchanged size, left-aligned */
.profile-header-v2 .profile-avatar-lg { flex-shrink: 0; }

/* Center column: name/rang/guru/actions — grows to fill space */
.profile-header-v2 .profile-info { flex: 1 1 180px; }

/* Right column: stats panel */
.ph-stats {
  flex: 0 0 220px;
  background: var(--blue-50, #f0f4f9);
  border-radius: 8px;
  padding: 10px 14px;
  font-size: 13px;
  align-self: stretch;
}
.ph-stat-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 5px 0;
  border-bottom: 1px solid var(--border, #d5dde7);
  gap: 8px;
}
.ph-stat-row:last-child { border-bottom: none; }
.ph-stat-label { color: var(--text-sec, #5a6272); font-weight: 600; white-space: nowrap; }
.ph-stat-val   { color: var(--text, #2a2e35); font-weight: 700; text-align: right; }

/* Guru badges row in header */
.ph-guru { margin-top: 6px; }

@media (max-width: 640px) {
  .ph-stats { flex: 1 1 100%; }
  .profile-header-v2 { flex-direction: column; align-items: center; text-align: center; }
  .profile-header-v2 .profile-actions { justify-content: center; }
}

/* Reply count badge in Letzte Beiträge table */
.badge-replies {
  display: inline-block;
  padding: 1px 7px;
  background: var(--blue-50, #f0f4f9);
  color: var(--blue-600, #235495);
  font-size: 10px;
  font-weight: 700;
  border-radius: 10px;
  margin-left: 6px;
  vertical-align: middle;
  border: 1px solid var(--blue-100, #dbe6f5);
}

/* Forum user menu bar spacing on profile pages */
.dc-user-menu, .forum-user-bar, #dc-menu td, .menu-bar td {
  padding-left: 10px !important;
  padding-right: 10px !important;
}

/* Guru badges in profile header */
.ph-guru { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 6px; }
.badge-guru {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 12px;
  font-size: 11px;
  font-weight: 700;
  white-space: nowrap;
}
.badge-guru-guru    { background: #FFF8E1; color: #F57F17; border: 1px solid #FFE082; }
.badge-guru-experte { background: #F3E5F5; color: #6A1B9A; border: 1px solid #CE93D8; }
.badge-guru-kenner  { background: #E3F2FD; color: #1565C0; border: 1px solid #90CAF9; }

/* Toggle-all button in Meine Werte toolbar */
.mw-toggle-all-btn {
  display: inline-flex; align-items: center; gap: 4px;
  background: none; border: 1px solid var(--border, #d5dde7);
  border-radius: 4px; padding: 3px 8px;
  font-size: 12px; color: var(--text-sec, #5a6272);
  cursor: pointer; font-family: inherit;
}
.mw-toggle-all-btn:hover { background: var(--blue-50, #f0f4f9); }

/* ===== Ausgezeichnete Beiträge Tabelle (.aus-tabelle) — v20260412f ===== */
table.aus-tabelle {
  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  border: 1px solid var(--border, #d5dde7) !important;
  border-radius: 8px !important;
  overflow: hidden !important;
  font-size: 13px;
  box-shadow: 0 1px 5px rgba(0,0,0,.07);
  margin-bottom: 0 !important;
}

/* Titelzeile: "Folgende Beiträge von … sind ausgezeichnet worden" */
table.aus-tabelle tr:first-child td {
  background: var(--blue-700, #1e4476) !important;
  color: #fff !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  padding: 12px 16px !important;
  border-bottom: none !important;
}
table.aus-tabelle tr:first-child a { color: #b8d4f5 !important; }
table.aus-tabelle tr:first-child a:hover { color: #fff !important; }

/* Pagination-Zeile oben (2. TR) */
table.aus-tabelle tr:nth-child(2) td {
  background: var(--blue-50, #f0f4f9) !important;
  padding: 5px 14px !important;
  font-size: 12px !important;
  border-bottom: 1px solid var(--border, #d5dde7) !important;
  text-align: center !important;
}

/* Spalten-Header (zweite dcheading-Zeile) */
table.aus-tabelle tr.dcheading:not(:first-child) td,
table.aus-tabelle tr.dcheading:not(:first-child) th {
  background: var(--blue-100, #dbe6f5) !important;
  color: var(--blue-800, #15335b) !important;
  font-weight: 700 !important;
  font-size: 11px !important;
  text-transform: uppercase;
  letter-spacing: .04em;
  padding: 7px 10px !important;
  border-bottom: 2px solid #b8cfe8 !important;
  white-space: nowrap;
}

/* Daten-Zeilen */
table.aus-tabelle tr.dclite td,
table.aus-tabelle tr.dcdark td {
  padding: 9px 10px !important;
  border-bottom: 1px solid #eef1f5 !important;
  vertical-align: middle !important;
  line-height: 1.4;
}
table.aus-tabelle tr.dclite { background: #fff !important; }
table.aus-tabelle tr.dcdark { background: var(--blue-50, #f8fafd) !important; }
table.aus-tabelle tr.dclite:hover td,
table.aus-tabelle tr.dcdark:hover td { background: #edf3fb !important; transition: background .12s; }

/* Icon-Spalte */
table.aus-tabelle td:first-child {
  width: 28px !important;
  text-align: center !important;
  padding: 6px 4px !important;
}

/* Subject-Spalte: fettere Links */
table.aus-tabelle td:nth-child(2) a {
  color: var(--blue-700, #1e4476) !important;
  font-weight: 600 !important;
  text-decoration: none;
}
table.aus-tabelle td:nth-child(2) a:hover { text-decoration: underline; }

/* Datum-Spalte: klein + gedimmt */
table.aus-tabelle td:nth-child(3) {
  color: var(--text-sec, #6b7585) !important;
  white-space: nowrap;
  font-size: 12px !important;
  width: 90px !important;
}

/* Auszeichnungen-Spalte */
table.aus-tabelle td:nth-child(4) {
  width: 100px !important;
  text-align: center !important;
}

/* Aktien-Spalte */
table.aus-tabelle td:nth-child(5) {
  width: 140px !important;
}

/* Pagination-Zeile unten (letzte TR) */
table.aus-tabelle tr:last-child td {
  background: var(--blue-50, #f0f4f9) !important;
  padding: 7px 14px !important;
  text-align: center !important;
  border-bottom: none !important;
  font-size: 12px !important;
}

/* Pagination-Links */
table.aus-tabelle td a[href*="page="] {
  display: inline-block;
  padding: 2px 7px;
  border-radius: 4px;
  color: var(--blue-600, #235495) !important;
  font-weight: 600;
  text-decoration: none;
}
table.aus-tabelle td a[href*="page="]:hover {
  background: var(--blue-600, #235495);
  color: #fff !important;
}
table.aus-tabelle td b a[href*="page="] {
  background: var(--blue-700, #1e4476);
  color: #fff !important;
}

/* Mobile: Auszeichnungen + Aktien ausblenden */
@media (max-width: 640px) {
  table.aus-tabelle td:nth-child(4),
  table.aus-tabelle th:nth-child(4),
  table.aus-tabelle td:nth-child(5),
  table.aus-tabelle th:nth-child(5) { display: none !important; }
  table.aus-tabelle td:nth-child(3) { width: 70px !important; }
}

/* ===== Toolbar Button Spacing (az=user, include_menu) ===== */
table[border="0"][align="center"] > tbody > tr > td { padding: 0 6px !important; }
#button_pic { display: flex; flex-direction: column; align-items: center; }
.button_text a { white-space: nowrap; }

/* ===== Beitrag bewerten: dark text on message_head ===== */
.message_head .bewerten-inline {
  display: inline-block;
  background: rgba(255,255,255,0.70);
  color: var(--text, #2a2e35) !important;
  border-radius: 4px;
  padding: 2px 6px;
  font-size: 12px;
  font-weight: 600;
  line-height: 1.5;
}
.message_head .bewerten-inline * { color: var(--text, #2a2e35) !important; }

/* ===== dctoc: feste Spaltenbreiten, Subject bekommt Restbreite ===== */
table.dctoc table { table-layout: fixed !important; width: 100% !important; }

/* Auszeichnungen */
table.dctoc table th:nth-child(2),
table.dctoc table td:nth-child(2) {
  width: 70px !important; max-width: 70px !important;
  overflow: hidden;
}
/* Author */
table.dctoc table th:nth-child(3),
table.dctoc table td:nth-child(3) {
  width: 155px !important; max-width: 155px !important;
  overflow: hidden; white-space: nowrap;
}
/* Message Date */
table.dctoc table th:nth-child(4),
table.dctoc table td:nth-child(4) {
  width: 105px !important; max-width: 105px !important;
  white-space: nowrap !important; overflow: hidden;
}
/* ID */
table.dctoc table th:nth-child(5),
table.dctoc table td:nth-child(5) {
  width: 30px !important; max-width: 30px !important;
  text-align: center;
}
/* Rang-Icon in Author-Zelle verkleinern */
table.dctoc table td img.rang_icon_gross { height: 12px !important; width: auto !important; vertical-align: middle; }

/* Banner-Margins entfernen in Forum-Seiten */
#gba_rect, div[id="gba_rect"] { margin: 0 !important; }
/* Thread-Baum: kein Rahmen, minimales Padding, kein Hover */
.page-show-topic table.dcborder { border: 0 !important; }
.page-show-topic table.dcborder td.dclite { border: 0 !important; padding: 2px !important; }
.page-show-topic tr.dclite:hover td,
.page-show-topic tr.dcdark:hover td,
.page-show-topic table.dctoc tr:hover td,
.page-show-topic table tr:hover td { background: transparent !important; }

/* show_topics: kein Hover auf Tabellenzeilen */
.page-forum-topics tr.dclite:hover td,
.page-forum-topics tr.dcdark:hover td,
.page-forum-topics tr.dclite:not(:has(> td.dcdark)):not(:has(td.dcpagelink)):not(:has(td.dcpagelink2)):hover td { background: transparent !important; }

/* show_topics: reduziertes Padding (überschreibt globales tr.dclite/dcdark td !important) */
.page-forum-topics-outer tr.dclite td,
.page-forum-topics-outer tr.dcdark td,
.forum-topics-main tr.dclite td,
.forum-topics-main tr.dcdark td { padding: 5px 8px !important; }

/* Reply-Tree-Zeile: Metadata rechts ausrichten */
.tree-reply-row { display: flex; justify-content: space-between; align-items: center; gap: 8px; line-height: 1.7; }
.tree-reply-row .tree-left { flex: 1; min-width: 0; text-align: left; }
.tree-reply-row .tree-meta { flex-shrink: 0; display: flex; align-items: center; gap: 12px; min-width: 300px; }
.tree-reply-row .tree-meta-author { display: flex; align-items: center; gap: 3px; white-space: nowrap; flex: 1; }
.tree-reply-row .tree-meta-date { white-space: nowrap; text-align: right; color: #888; font-size: 12px; }
.tree-reply-row .tree-meta img { height: 16px !important; width: auto !important; vertical-align: middle; }
.tree-reply-row .tree-meta .dcauthor { font-size: 12px !important; }
.tree-reply-row .tree-meta .dcdate, .tree-reply-row .tree-meta .dcinfo { font-size: 12px !important; color: #888; }

/* Aktien-Statistik Panel Header — hell statt grau */
#aktien_stat_panel .a_st_p_header { background: #f0f4fa !important; color: #15335b !important; }

}