/* ============================================================
   TOPICS DESIGN SYSTEM - Quizkoenig
   Basiert auf topics.tools.energy
   Version: 3.0.0 - Optimiert + Micro-Interactions
   ============================================================ */

/* ============================================================
   CSS CUSTOM PROPERTIES (DESIGN TOKENS)
   ============================================================ */
:root {
    /* Topics Original Colors */
    --color-primary: #0AA692;
    --color-primary-hover: #098a7a;
    --color-success: #51A551;
    --color-success-hover: #3B7C3B;
    --color-warning: #ffc107;
    --color-danger: #DA504F;
    --color-danger-hover: #c24544;
    --color-info: #0081C3;
    --color-purple: #675579;
    --color-purple-hover: #574869;

    /* OVERRIDE alte style.css Variablen */
    --energy-red: #0AA692;  /* War rot, jetzt Teal */

    /* Grays - Topics Style */
    --color-navbar: #525252;
    --color-text: #333333;
    --color-text-secondary: #555555;
    --color-text-muted: #999999;
    --color-background: #E9E9E9;
    --color-surface: #FFFFFF;
    --color-border: #DDDDDD;
    --border-color: #DDDDDD;
    --color-border-light: #EEEEEE;
    --color-table-row: #F9F9F9;

    /* Content Width */
    --content-width: 900px;

    /* Transition Easing */
    --ease-smooth: cubic-bezier(0.4, 0, 0.2, 1);
    --ease-bounce: cubic-bezier(0.34, 1.56, 0.64, 1);
    --ease-spring: cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* ============================================================
   BODY - Topics Background mit Grid Texture
   Dark Mode: smooth transition
   ============================================================ */
body {
    font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
    font-size: 16px;
    color: var(--color-text);
    background-color: var(--color-background);
    background-image: url('tiny_grid.png');
    line-height: 1.5;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    padding-top: 90px; /* 48px navbar + 42px mission-control */
    margin: 0;
    transition: background-color 0.3s ease, color 0.3s ease;
}

/* ============================================================
   PROGRESS BAR - Teal zu Blau (nicht Rot)
   ============================================================ */
.progress-fill {
    background: linear-gradient(90deg, var(--color-primary), var(--color-info));
}

/* ============================================================
   CONTAINER - Max Breite fuer Content
   !important behalten: inline-styles im HTML moeglich
   ============================================================ */
.container {
    max-width: var(--content-width) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

/* ============================================================
   NAVBAR - Topics Original (Volle Breite, Dunkelgrau)
   !important behalten: ueberschreibt alte style.css floating/weisse Navbar
   ============================================================ */
.nav-wrapper {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 1000 !important;
    background: var(--color-navbar) !important;
    height: 52px !important;
    padding: 0 !important;
}

.nav-wrapper.scrolled {
    padding: 0 !important;
    height: 52px !important;
}

.nav {
    display: flex !important;
    align-items: stretch !important;
    height: 100% !important;
    max-width: 100% !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    background: var(--color-navbar) !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}

.nav.scrolled {
    border-radius: 0 !important;
    box-shadow: none !important;
}

/* Ueberlappendes Logo links - Topics Style */
.nav-logo,
.nav-logo-mobile {
    height: 75px !important;
    margin: 10px 15px 0 15px !important;
    border-radius: 10px !important;
    box-shadow: 0 4px 15px rgba(0,0,0,0.15) !important;
    background: white !important;
    padding: 6px !important;
    z-index: 100 !important;
    cursor: pointer !important;
    transition: transform 0.2s var(--ease-smooth), box-shadow 0.2s var(--ease-smooth) !important;
    flex-shrink: 0 !important;
    display: block !important;
}

.nav-logo:hover,
.nav-logo-mobile:hover {
    transform: scale(1.05) !important;
    box-shadow: 0 6px 20px rgba(0,0,0,0.25) !important;
}

/* Scrolled State - Logo bleibt gleich im Topics Design */
.nav.scrolled .nav-logo {
    height: 75px !important;
    border-radius: 10px !important;
    margin-bottom: 0 !important;
}

/* Kein zentriertes Logo mehr */
.nav-center-logo {
    display: none;
}

.nav-links {
    display: flex;
    align-items: stretch;
    flex: 1;
    height: 100%;
}

.nav-section {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.nav-section-links {
    display: flex;
    align-items: stretch;
    height: 52px;
}

/* Section Labels ausblenden im Topics Style */
.nav-section-label {
    display: none;
}

.nav-links-left {
    display: flex;
    align-items: stretch;
}

.nav-links-right {
    display: flex;
    align-items: stretch;
    margin-left: auto;
}

/* Nav Links: verbesserte Transitions + Active Indicator */
.nav a,
.nav-section-links a {
    display: flex !important;
    align-items: center !important;
    padding: 0 15px !important;
    text-decoration: none !important;
    color: #e8e8e8 !important;
    font-weight: 400 !important;
    font-size: 14px !important;
    transition: background 0.2s ease, color 0.2s ease !important;
    white-space: nowrap !important;
    height: 100% !important;
    border-radius: 0 !important;
    position: relative !important;
}

/* Hover: sanfter Glow */
.nav a:hover,
.nav-section-links a:hover {
    background: rgba(255,255,255,0.08) !important;
    color: white !important;
    backdrop-filter: brightness(1.1) !important;
}

/* Active Link: 2px Teal-Balken als Indikator unten */
.nav a.active,
.nav-section-links a.active {
    background: var(--color-primary) !important;
    color: white !important;
}

.nav a.active::after,
.nav-section-links a.active::after {
    content: '' !important;
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    height: 2px !important;
    background: white !important;
    opacity: 0.5 !important;
}

/* Farbige Nav-Buttons: subtiler Box-Shadow bei Hover */
.nav a.nav-teal,
.nav-section-links a.nav-teal {
    background: #099589 !important;
    color: white !important;
}
.nav a.nav-teal:hover,
.nav-section-links a.nav-teal:hover {
    background: #087a70 !important;
    box-shadow: 0 0 12px rgba(9, 149, 137, 0.5) !important;
}

.nav a.nav-red,
.nav-section-links a.nav-red {
    background: #DA504F !important;
    color: white !important;
}
.nav a.nav-red:hover,
.nav-section-links a.nav-red:hover {
    background: #c24544 !important;
    box-shadow: 0 0 12px rgba(218, 80, 79, 0.5) !important;
}

.nav a.nav-purple,
.nav-section-links a.nav-purple {
    background: #675579 !important;
    color: white !important;
}
.nav a.nav-purple:hover,
.nav-section-links a.nav-purple:hover {
    background: #574869 !important;
    box-shadow: 0 0 12px rgba(103, 85, 121, 0.5) !important;
}

.nav a.nav-blue,
.nav-section-links a.nav-blue {
    background: #0081C3 !important;
    color: white !important;
}
.nav a.nav-blue:hover,
.nav-section-links a.nav-blue:hover {
    background: #006da6 !important;
    box-shadow: 0 0 12px rgba(0, 129, 195, 0.5) !important;
}

/* Mobile Toggle */
.nav-toggle {
    display: none;
    background: transparent;
    border: none;
    color: white;
    padding: 15px;
    cursor: pointer;
    font-size: 1.3rem;
    margin-left: auto;
}

.nav-mobile-menu {
    display: none !important;
    position: absolute !important;
    top: 52px !important;
    left: 0 !important;
    right: 0 !important;
    background: var(--color-navbar) !important;
    padding: 10px 0 !important;
    z-index: 999 !important;
    border-radius: 0 !important;
    box-shadow: 0 4px 15px rgba(0,0,0,0.2) !important;
    margin-top: 0 !important;
    width: 100% !important;
}

.nav-mobile-menu.show {
    display: flex !important;
    flex-direction: column !important;
}

.nav-mobile-menu a {
    padding: 14px 20px !important;
    text-decoration: none !important;
    color: #e8e8e8 !important;
    font-weight: 400 !important;
    border-radius: 0 !important;
    transition: background 0.2s ease !important;
}

.nav-mobile-menu a:hover {
    background: rgba(255,255,255,0.1) !important;
}

.nav-mobile-menu a.active {
    background: var(--color-primary) !important;
    color: white !important;
}

/* ============================================================
   CARDS / PANELS - Topics Style + Hover-Effekte
   ============================================================ */
.card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: 4px;
    padding: 24px;
    margin-bottom: 20px;
    box-shadow: 0 1px 1px rgba(0,0,0,0.05);
    transition: box-shadow 0.2s ease, background-color 0.3s, border-color 0.3s;
}

.card:hover {
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}

/* ============================================================
   INFO BOX - Purple mit weisser Schrift
   ============================================================ */
.info-box {
    background: var(--color-purple);
    color: white;
    border-radius: 4px;
    padding: 20px 25px;
    margin-bottom: 15px;
}

.info-box *,
.info-box p,
.info-box strong,
.info-box span,
.info-box h3 {
    color: white;
}

.info-box-header {
    font-size: 14px;
    opacity: 0.9;
    margin-bottom: 5px;
}

.info-box-value {
    font-size: 28px;
    font-weight: 300;
}

/* Spezifisch: Schaetzfrage Empty State */
.info-box.no-schaetzfrage,
.no-schaetzfrage {
    background: var(--color-purple);
    color: white;
    text-align: center;
    padding: 40px 25px;
}

.info-box.no-schaetzfrage *,
.no-schaetzfrage * {
    color: white;
}

.info-box.no-schaetzfrage p,
.no-schaetzfrage p {
    color: rgba(255,255,255,0.9);
    margin: 10px 0;
}

/* ============================================================
   DATUM BAR - Purple Style (Bearbeiten Seite)
   !important behalten: hat Inline-Styles im HTML
   ============================================================ */
.datum-bar {
    display: flex !important;
    align-items: center !important;
    gap: 15px !important;
    background: var(--color-purple) !important;
    color: white !important;
    padding: 15px 25px !important;
    border-radius: 4px !important;
    margin-bottom: 20px !important;
    border: none !important;
    box-shadow: 0 2px 8px rgba(103, 85, 121, 0.3) !important;
}

.datum-bar .datum-label,
.datum-bar label,
.datum-label {
    font-weight: 500 !important;
    color: white !important;
}

.datum-bar .datum-status,
.datum-status {
    margin-left: auto !important;
    color: white !important;
    font-weight: 500 !important;
}

.datum-bar select,
.datum-bar input,
.archiv-select-inline {
    background: rgba(255,255,255,0.2) !important;
    border: 1px solid rgba(255,255,255,0.3) !important;
    color: white !important;
    padding: 8px 12px !important;
    border-radius: 4px !important;
    font-size: 14px !important;
}

.datum-bar select option,
.archiv-select-inline option {
    background: var(--color-purple) !important;
    color: white !important;
}

/* ============================================================
   MODUS TOGGLE - Animierter Slider (Teal ueberlappt Purple)
   !important behalten: hidden class + JS-gesteuerter Display
   ============================================================ */
.modus-toggle-global {
    display: flex !important;
    justify-content: center !important;
    margin-bottom: 20px !important;
}

.modus-toggle-slider {
    display: flex !important;
    gap: 0 !important;
    background: var(--color-purple) !important;
    position: relative !important;
    border-radius: 30px !important;
    overflow: hidden !important;
    padding: 4px !important;
}

/* Animierter Slider-Background mit smooth Slide */
.modus-slider-bg {
    display: block !important;
    position: absolute !important;
    top: 4px !important;
    left: 4px !important;
    width: calc(50% - 4px) !important;
    height: calc(100% - 8px) !important;
    background: var(--color-primary) !important;
    border-radius: 26px !important;
    z-index: 1 !important;
    transition: left 0.4s var(--ease-spring),
                background 0.4s ease,
                box-shadow 0.4s ease !important;
    box-shadow: 0 4px 15px rgba(10, 166, 146, 0.4) !important;
}

/* Slider nach rechts wenn Pro aktiv - GRUEN */
.modus-toggle-slider.pro-active .modus-slider-bg {
    left: calc(50%) !important;
    background: var(--color-success) !important;
    box-shadow: 0 4px 15px rgba(81, 165, 81, 0.5) !important;
}

/* ALLE Modus-Buttons: Basis-Style (inaktiv = transparent) */
.modus-slider-btn,
.modus-toggle-slider button,
.modus-toggle-slider .modus-slider-btn {
    padding: 12px 30px !important;
    border: none !important;
    background: transparent !important;
    cursor: pointer !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: rgba(255,255,255,0.7) !important;
    transition: all 0.3s ease !important;
    position: relative !important;
    z-index: 2 !important;
    border-radius: 26px !important;
}

.modus-slider-btn:first-child {
    border-radius: 26px !important;
}

.modus-slider-btn:last-child {
    border-radius: 26px !important;
}

/* Hover auf inaktivem Button */
.modus-slider-btn:not(.active):hover,
.modus-toggle-slider button:not(.active):hover {
    color: white !important;
    background: rgba(255,255,255,0.1) !important;
}

/* AKTIVER Button = Weisse Schrift, transparenter Hintergrund (Slider zeigt Farbe) */
.modus-slider-btn.active,
.modus-toggle-slider button.active,
.modus-toggle-slider .modus-slider-btn.active {
    color: white !important;
    background: transparent !important;
    box-shadow: none !important;
}

.modus-slider-btn.active:hover,
.modus-toggle-slider button.active:hover {
    background: transparent !important;
}

/* ============================================================
   STATION CARDS - Topics Style + Micro-Interactions
   ============================================================ */
.station-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 15px;
    margin-bottom: 25px;
}

.station-card,
.station-card-edit {
    background: var(--color-table-row);
    border: 3px solid var(--color-border);
    border-radius: 8px;
    padding: 20px 15px;
    text-align: center;
    cursor: pointer;
    transition: all 0.2s var(--ease-smooth);
    position: relative;
}

.station-card:hover,
.station-card-edit:hover {
    border-color: var(--color-primary);
    background: #f0faf8;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(10, 166, 146, 0.15);
}

.station-card.selected,
.station-card-edit.selected,
.station-card.active,
.station-card-edit.active {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: white;
    transition: background 0.25s var(--ease-smooth), border-color 0.25s var(--ease-smooth);
}

.station-card .station-check {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 24px;
    height: 24px;
    background: white;
    border-radius: 50%;
    display: none;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    color: var(--color-success);
    font-size: 14px;
}

/* Check-Mark: Bounce-Animation beim Auswaehlen */
.station-card.selected .station-check {
    display: flex;
    animation: checkBounce 0.3s var(--ease-bounce);
}

.station-card .station-name {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 4px;
}

.station-card .station-code {
    font-size: 13px;
    opacity: 0.8;
}

/* ============================================================
   BUTTONS - Topics Style + Micro-Interactions
   ============================================================ */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 20px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    border: 1px solid transparent;
    border-radius: 4px;
    transition: all 0.2s var(--ease-smooth);
}

.btn:hover {
    transform: translateY(-1px);
}

.btn:active {
    transform: translateY(0) scale(0.98);
}

.btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
    transition: opacity 0.2s ease;
}

/* Primary Button - Teal */
.btn-primary,
.btn.btn-primary,
button.btn-primary {
    background: var(--color-primary) !important;
    color: #fff !important;
    border: 2px solid var(--color-primary) !important;
}

.btn-primary:hover,
.btn.btn-primary:hover,
button.btn-primary:hover {
    background: var(--color-primary-hover) !important;
    border-color: var(--color-primary-hover) !important;
    box-shadow: 0 4px 12px rgba(10, 166, 146, 0.35) !important;
}

/* Recherche Button - Purple */
.btn-recherche,
.btn.btn-recherche,
button.btn-recherche,
#btn-recherche {
    background: var(--color-purple) !important;
    color: #fff !important;
    border: 2px solid var(--color-purple) !important;
}

.btn-recherche:hover,
.btn.btn-recherche:hover,
button.btn-recherche:hover,
#btn-recherche:hover {
    background: var(--color-purple-hover) !important;
    border-color: var(--color-purple-hover) !important;
    box-shadow: 0 4px 12px rgba(103, 85, 121, 0.35) !important;
}

.btn-large {
    padding: 14px 28px;
    font-size: 16px;
}

.btn-secondary,
.btn-default {
    background: var(--color-surface);
    color: var(--color-text);
    border-color: var(--color-border);
}

.btn-secondary:hover,
.btn-default:hover {
    background: var(--color-border-light);
    border-color: #ccc;
    box-shadow: 0 2px 6px rgba(0,0,0,0.08);
}

.btn-success {
    background: var(--color-success);
    color: #fff;
    border-color: var(--color-success);
}

.btn-success:hover {
    background: var(--color-success-hover);
    box-shadow: 0 4px 12px rgba(81, 165, 81, 0.35);
}

.btn-danger {
    background: var(--color-danger);
    color: #fff;
    border-color: var(--color-danger);
}

.btn-danger:hover {
    background: var(--color-danger-hover);
    box-shadow: 0 4px 12px rgba(218, 80, 79, 0.35);
}

/* Topics-Style Aktions-Buttons */
.btn-danger-outline {
    background: transparent;
    color: var(--color-danger);
    border: 2px solid var(--color-danger);
    padding: 10px 20px;
}

.btn-danger-outline:hover {
    background: var(--color-danger);
    color: white;
    box-shadow: 0 4px 12px rgba(218, 80, 79, 0.3);
}

.btn-outline-info {
    background: transparent;
    color: var(--color-primary);
    border: 2px solid var(--color-primary);
    padding: 10px 20px;
}

.btn-outline-info:hover {
    background: var(--color-primary);
    color: white;
    box-shadow: 0 4px 12px rgba(10, 166, 146, 0.3);
}

.btn-special {
    background: var(--color-purple);
    color: white;
    border: none;
    padding: 12px 22px;
}

.btn-special:hover {
    background: var(--color-purple-hover);
    box-shadow: 0 4px 12px rgba(103, 85, 121, 0.35);
}

/* ============================================================
   INPUTS / TEXTAREAS - Focus Ring + Transitions
   ============================================================ */
input[type="text"],
input[type="number"],
input[type="date"],
select,
textarea {
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

input[type="text"]:focus,
input[type="number"]:focus,
input[type="date"]:focus,
select:focus,
textarea:focus {
    border-color: var(--color-primary);
    outline: none;
    box-shadow: 0 0 0 3px rgba(10, 166, 146, 0.15);
}

/* ============================================================
   FOOTER - Topics Style (Dunkelgrau, volle Breite)
   !important behalten: ueberschreibt alte style.css weisse Footer
   ============================================================ */
.footer-wrapper {
    padding: 0 !important;
    margin-top: auto !important;
    background: var(--color-navbar) !important;
}

.app-footer {
    background: var(--color-navbar) !important;
    color: white !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    width: 100% !important;
    max-width: 100% !important;
}

.footer-row {
    background: transparent !important;
    border-bottom: 1px solid rgba(255,255,255,0.1) !important;
}

.footer-row:last-child {
    background: rgba(0,0,0,0.1) !important;
    border-bottom: none !important;
}

.footer-item,
.footer-item * {
    color: white !important;
}

.footer-item .icon {
    color: white !important;
}

.footer-item .label {
    color: rgba(255,255,255,0.8) !important;
}

.footer-item .value {
    color: white !important;
    font-weight: 600 !important;
}

/* Footer-Items: Hover mit leichtem Opacity-Effekt */
.footer-item {
    transition: opacity 0.2s ease;
}

.footer-item:hover {
    opacity: 0.85;
}

.footer-divider {
    background: rgba(255,255,255,0.2) !important;
}

.footer-copyright {
    color: rgba(255,255,255,0.8) !important;
}

/* Alle Texte im Footer weiss */
.footer-row,
.footer-row * {
    color: white !important;
}

.footer-row:last-child {
    color: rgba(255,255,255,0.8) !important;
}

.footer-row:last-child * {
    color: rgba(255,255,255,0.8) !important;
}

/* Dark/Test Toggle Labels */
.toggle-icon,
.toggle-label {
    color: white !important;
}

/* Version Badge: Hover-Effekt */
.footer-version {
    background: var(--color-primary) !important;
    color: white !important;
    padding: 4px 12px !important;
    border-radius: 4px !important;
    font-weight: 500 !important;
    opacity: 1 !important;
    cursor: pointer;
    transition: transform 0.2s var(--ease-smooth) !important;
    display: inline-block;
}

.footer-version:hover {
    transform: scale(1.05) !important;
}

/* Status Badges im Footer */
.footer-item .status-badge {
    background: rgba(255,255,255,0.15) !important;
}

.footer-item .status-badge.online {
    background: rgba(40, 167, 69, 0.3) !important;
    color: #7dff7d !important;
}

.footer-item .status-badge.warning {
    background: rgba(255, 193, 7, 0.3) !important;
    color: #ffe066 !important;
}

.footer-item .status-badge.error {
    background: rgba(220, 53, 69, 0.3) !important;
    color: #ff8080 !important;
}

/* Status-Dot: Pulsing Animation fuer Online-Status */
.status-badge.online .status-dot {
    animation: statusPulse 2s ease-in-out infinite;
}

/* Dark/Test Mode Toggles */
.dark-mode-toggle,
.test-mode-toggle {
    cursor: pointer !important;
    padding: 6px 12px !important;
    border-radius: 20px !important;
    background: rgba(255,255,255,0.1) !important;
    transition: background 0.2s ease !important;
}

.dark-mode-toggle:hover,
.test-mode-toggle:hover {
    background: rgba(255,255,255,0.2) !important;
}

.test-mode-toggle.active {
    background: rgba(255, 193, 7, 0.3) !important;
}

/* ============================================================
   FRAGEN EDITOR - Topics Style
   ============================================================ */

/* Frage-Gruppe: Weisser Hintergrund, subtiler Rand */
.frage-group {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-left: 3px solid var(--color-border);
    border-radius: 4px;
    padding: 20px;
    margin-bottom: 15px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
    transition: border-color 0.2s ease, background-color 0.3s, box-shadow 0.3s;
}

/* Focus-within: zeigt aktive Bearbeitung */
.frage-group:focus-within {
    border-left-color: var(--color-primary);
    box-shadow: 0 2px 8px rgba(10, 166, 146, 0.08);
}

/* Angenommene Frage: Teal Akzent links, heller Hintergrund */
.frage-group.accepted {
    background: rgba(10, 166, 146, 0.05);
    border-left: 4px solid var(--color-primary);
}

/* Fragen Editor - Topics Design (Teal Akzent) */
.frage-editor-topics {
    border-left: 4px solid var(--color-primary);
    background: var(--color-surface);
    border-radius: 4px;
    padding: 20px;
    margin-bottom: 20px;
}

/* Lokale Fragen Container - Blau */
.lokale-frage,
.frage-editor.lokale-frage,
div.lokale-frage {
    border-left: 4px solid var(--color-info) !important;
    background: var(--color-surface) !important;
}

/* Status Badge "Angenommen" */
.frage-status,
.status-badge.angenommen,
.btn-accept.accepted {
    background: var(--color-success) !important;
    color: white !important;
}

/* Textareas in Frageboxen */
.frage-group textarea,
.frage-group input[type="text"] {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: 4px;
    color: var(--color-text);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.frage-group textarea:focus,
.frage-group input[type="text"]:focus {
    border-color: var(--color-primary);
    outline: none;
    box-shadow: 0 0 0 3px rgba(10, 166, 146, 0.15);
}

/* Kontext-Box */
.frage-group .kontext,
.kontext-label + textarea {
    background: var(--color-table-row);
    border-left: 3px solid var(--color-primary);
}

/* Quellen-Warnung (Gelbe Box) */
.quellen-warning {
    background: linear-gradient(90deg, #fff3cd 0%, #ffe8a1 100%);
    color: #856404;
    border-left: 4px solid #ffc107;
    border-radius: 4px;
    padding: 10px 15px;
}

.quellen-warning * {
    color: #856404;
}

.frage-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
}

.frage-label {
    font-weight: 700;
    color: var(--color-primary);
}

.frage-kategorie {
    font-size: 12px;
    background: var(--color-primary);
    color: white;
    padding: 3px 10px;
    border-radius: 4px;
}

.frage-textarea,
.frage-group textarea {
    width: 100%;
    padding: 12px;
    border: 1px solid var(--color-border);
    border-radius: 4px;
    font-size: 14px;
    font-family: inherit;
    resize: vertical;
    min-height: 80px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.frage-textarea:focus,
.frage-group textarea:focus {
    border-color: var(--color-primary);
    outline: none;
    box-shadow: 0 0 0 3px rgba(10, 166, 146, 0.15);
}

/* ============================================================
   KONTAKTE LISTE
   ============================================================ */
.kontakt-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 15px;
    background: var(--color-table-row);
    border: 1px solid var(--color-border);
    border-radius: 4px;
    margin-bottom: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
}

.kontakt-item:hover {
    border-color: var(--color-primary);
    background: #f0faf8;
    transform: translateX(2px);
}

.kontakt-item input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: var(--color-primary);
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 768px) {
    .nav-toggle {
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .nav-links,
    .nav-section-links {
        display: none !important;
    }

    .station-cards {
        grid-template-columns: 1fr;
    }

    .nav-logo,
    .nav-logo-mobile {
        height: 50px;
        margin: 5px 10px 0 10px;
    }
}

/* ============================================================
   DARK MODE OVERRIDES fuer Topics
   !important behalten: Dark-Mode-spezifische Overrides brauchen Prioritaet
   ============================================================ */
body.dark-mode {
    --color-background: #1a1a1a;
    --color-surface: #2d2d2d;
    --color-text: #e0e0e0;
    --color-text-secondary: #a0a0a0;
    --color-border: #444444;
    --border-color: #444444;
    --color-table-row: #3a3a3a;
    background-image: none;
}

body.dark-mode .nav,
body.dark-mode .nav-wrapper {
    background: #2d2d2d !important;
}

body.dark-mode .app-footer {
    background: #2d2d2d !important;
}

body.dark-mode .card {
    transition: background-color 0.3s, border-color 0.3s, box-shadow 0.3s;
}

/* ============================================================
   CUSTOM SVG ICONS
   ============================================================ */
.svg-icon {
    width: 22px;
    height: 22px;
    vertical-align: middle;
    display: inline-block;
}

.svg-icon.nav-icon {
    width: 26px;
    height: 26px;
    margin-right: 8px;
}

.svg-icon.footer-icon {
    width: 20px;
    height: 20px;
}

.svg-icon.menu-icon {
    width: 16px;
    height: 16px;
    margin-right: 6px;
}

.svg-icon.toggle-icon {
    width: 18px;
    height: 18px;
    margin-right: 4px;
}

.svg-icon.action-icon {
    width: 16px;
    height: 16px;
}

/* Icon Filter fuer Dark Mode */
body.dark-mode .svg-icon.invert {
    filter: brightness(0) invert(1);
}

/* ============================================================
   ANIMATIONEN
   ============================================================ */

/* Smooth Reveal Animation */
@keyframes slideUp {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Status Dot Pulse fuer Online-Status */
@keyframes statusPulse {
    0%, 100% { opacity: 1; }
    50%       { opacity: 0.5; }
}

/* Subtle Bounce fuer Check-Marks */
@keyframes checkBounce {
    0%   { transform: scale(0); }
    50%  { transform: scale(1.2); }
    100% { transform: scale(1); }
}

/* Kandidaten-Banner */
.kandidaten-banner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    padding: 12px 20px;
    background: var(--color-surface, #fff);
    border-radius: 12px;
    margin: 8px auto 16px;
    max-width: 500px;
    border: 2px solid var(--color-primary, #0AA692);
    box-shadow: 0 2px 8px rgba(10, 166, 146, 0.1);
}
.kandidat-links, .kandidat-rechts {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    flex: 1;
}
.kandidat-label {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--color-primary, #0AA692);
    font-weight: 700;
}
.kandidat-name {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--color-text, #333);
}
.kandidat-vs {
    font-size: 0.8rem;
    color: var(--color-danger, #D45555);
    font-weight: 700;
    text-transform: uppercase;
}

/* Kandidaten-Details */
.kandidaten-details {
    margin-top: 24px;
}
.kandidaten-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
@media (max-width: 600px) {
    .kandidaten-grid { grid-template-columns: 1fr; }
}
.kandidat-detail {
    padding: 12px;
    background: var(--color-surface, #fff);
    border-radius: 8px;
    border: 1px solid var(--color-border, #ddd);
}
.kandidat-station-header {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--color-primary, #0AA692);
    font-weight: 700;
    margin-bottom: 8px;
}
.kandidat-fullname {
    font-size: 1.1rem;
    font-weight: 700;
    margin-bottom: 4px;
    color: var(--color-text, #333);
}
.kandidat-rolle {
    font-size: 0.85rem;
    margin-bottom: 4px;
}
.rolle-koenig { color: #d4a017; }
.rolle-herausforderer { color: var(--color-primary, #0AA692); }
.kandidat-phone {
    font-size: 0.8rem;
    color: var(--color-text-secondary, #666);
    margin-bottom: 4px;
}
.kandidat-spielinfo {
    font-size: 0.85rem;
    color: var(--color-text-secondary, #666);
    font-style: italic;
}
.kandidat-empty {
    color: var(--color-text-secondary, #666);
    font-style: italic;
}

/* ============================================================
   KOMPAKTES FRAGEN-LAYOUT
   Schmaler, grössere Schrift, weniger Whitespace
   ============================================================ */

/* Frage-Gruppen: weniger Abstand */
.frage-group {
    margin-bottom: 12px !important;
    padding-bottom: 12px !important;
}

/* Textareas: grössere Schrift */
.frage-group textarea,
.frage-group input[type="text"] {
    font-size: 1rem !important;
    line-height: 1.5 !important;
}

/* Labels: etwas grösser */
.frage-group label {
    font-size: 0.95rem !important;
}

/* Actions: kompakter */
.frage-actions {
    margin-top: 8px !important;
    padding-top: 8px !important;
}

/* Quellen: etwas grösser */
.frage-quellen {
    font-size: 0.85rem !important;
    margin-top: 8px !important;
    padding-top: 8px !important;
}

/* Cards: weniger Padding */
.card {
    padding: 16px !important;
}

/* Section Labels */
.section-label {
    font-size: 0.9rem !important;
}

/* Hinweis-Box */
.frage-hinweis {
    font-size: 0.9rem !important;
}

/* Page Title: etwas kleiner bei schmalem Container */
.page-title {
    font-size: 2rem !important;
}

/* Fragen-Cards: schmaler + zentriert auf grossen Bildschirmen */
.frage-group,
.frage-editor-topics {
    max-width: 800px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    box-sizing: border-box !important;
}

/* Textareas/Inputs: nie über Card-Rand hinaus */
.frage-group textarea,
.frage-group input[type="text"],
.frage-group .kontext {
    max-width: 100% !important;
    box-sizing: border-box !important;
}

/* Spielsystem: volle Breite behalten */
body[data-page="spielsystem"] .container {
    max-width: 1200px !important;
}

/* Adressbuch/Regeln: mittlere Breite */
body[data-page="adressbuch"] .container,
body[data-page="regeln"] .container,
body[data-page="dialekt"] .container,
body[data-page="admin"] .container {
    max-width: 1100px !important;
}
