[data-theme="dark"] {
    --bg: #070b14;
    --bg-elevated: rgba(15, 23, 42, 0.72);
    --card: rgba(15, 23, 42, 0.55);
    --text: #e8eef7;
    --muted: #b8c5d6;
    --accent: #38bdf8;
    --accent-2: #818cf8;
    --border: rgba(148, 163, 184, 0.18);
    --shadow: 0 24px 80px rgba(2, 6, 23, 0.45);
    --glow: rgba(56, 189, 248, 0.15);
}
[data-theme="light"] {
    --bg: #eef2ff;
    --bg-elevated: rgba(255, 255, 255, 0.92);
    --card: rgba(255, 255, 255, 0.88);
    --text: #0f172a;
    --muted: #64748b;
    --accent: #2563eb;
    --accent-2: #7c3aed;
    --border: rgba(15, 23, 42, 0.08);
    --shadow: 0 20px 60px rgba(15, 23, 42, 0.08);
    --glow: rgba(37, 99, 235, 0.08);
}

* { box-sizing: border-box; }

body.frontend-body {
    background: var(--bg);
    color: var(--text);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    position: relative;
}

body.frontend-body::before {
    content: "";
    position: fixed;
    inset: 0;
    background-image: var(--bg-image);
    background-size: cover;
    background-position: center;
    background-attachment: fixed;
    opacity: 0.28;
    z-index: -2;
}

body.frontend-body::after {
    content: "";
    position: fixed;
    inset: 0;
    background:
        radial-gradient(circle at top left, var(--glow), transparent 35%),
        linear-gradient(180deg, rgba(0,0,0,0.15), rgba(0,0,0,0.45));
    z-index: -1;
}

[data-theme="light"] body.frontend-body::after {
    background:
        radial-gradient(circle at top left, var(--glow), transparent 40%),
        linear-gradient(180deg, rgba(255,255,255,0.2), rgba(255,255,255,0.75));
}

.frontend-main { flex: 1; display: flex; flex-direction: column; }

.home-page {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 0;
}

.home-search-center {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: clamp(1.5rem, 4vw, 3rem) 0;
}

.footer-brand-stack {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.35rem;
}

.footer-brand-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.brand-logo,
.footer-favicon {
    display: block;
    background: transparent;
    border: 0;
    box-shadow: none;
    border-radius: 0;
}

[data-theme="dark"] .brand-logo,
[data-theme="dark"] .footer-favicon {
    filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.35));
}

[data-theme="light"] .brand-logo,
[data-theme="light"] .footer-favicon {
    filter: none;
    box-shadow: none;
    background: transparent;
}

.front-nav {
    background: var(--bg-elevated);
    border-bottom: 1px solid var(--border);
    backdrop-filter: blur(16px);
}

.navbar-brand .brand-text {
    font-weight: 700;
    letter-spacing: 0.04em;
    color: var(--text);
}

.footer-brand-name {
    color: var(--text);
    letter-spacing: 0.03em;
}

.btn-front-ghost {
    color: var(--text);
    border: 1px solid var(--border);
    background: transparent;
}

.btn-front-ghost:hover {
    color: var(--text);
    background: rgba(255,255,255,0.06);
    border-color: var(--accent);
}

.btn-front-primary {
    background: linear-gradient(135deg, var(--accent), var(--accent-2));
    border: none;
    color: #fff;
    font-weight: 600;
    box-shadow: 0 10px 30px rgba(56, 189, 248, 0.25);
}

.btn-front-primary:hover { color: #fff; filter: brightness(1.05); }

.space-card, .premium-card, .login-card, .message-box, .contact-card {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 20px;
    padding: clamp(1.25rem, 2vw, 2rem);
    backdrop-filter: blur(18px);
    box-shadow: var(--shadow);
    position: relative;
    overflow: hidden;
}

.premium-card { max-width: 920px; }
.contact-card { max-width: 760px; }

.premium-card-glow {
    position: absolute;
    inset: 0 auto auto 0;
    width: 220px;
    height: 220px;
    background: radial-gradient(circle, var(--glow), transparent 70%);
    pointer-events: none;
}

.front-tabs .nav-link {
    color: var(--muted);
    border: 1px solid transparent;
    border-radius: 999px;
    margin-right: .5rem;
    padding: .55rem 1rem;
    background: transparent;
}

.front-tabs .nav-link.active {
    background: linear-gradient(135deg, var(--accent), var(--accent-2));
    color: #fff;
    border-color: transparent;
    font-weight: 700;
}

.btn-galactic-toggle {
    background: linear-gradient(145deg, rgba(88, 28, 135, 0.85), rgba(30, 64, 175, 0.85));
    color: #fff;
    border: 1px solid rgba(147, 197, 253, 0.35);
    border-radius: 999px;
    padding: 12px 24px;
    box-shadow: 0 12px 40px rgba(59, 130, 246, 0.25);
}

.content-body {
    line-height: 1.7;
    color: var(--text);
}

.content-body h1, .content-body h2, .content-body h3, .content-body h4 {
    color: var(--text);
    margin-top: 1.25rem;
}

.content-body p, .content-body li { color: var(--text); }
.content-body a { color: var(--accent); }
.content-body img { max-width: 100%; height: auto; border-radius: 12px; }
.content-body ul, .content-body ol { padding-left: 1.25rem; }

/* CMS-Inhalte (Word/Legacy) haben oft inline color:#fff – im Light-Theme überschreiben */
[data-theme="light"] .content-body :is(p, span, li, td, th, div, h1, h2, h3, h4, h5, h6, strong, em, b, i, u) {
    color: var(--text) !important;
}

[data-theme="light"] .content-body a,
[data-theme="light"] .content-body a * {
    color: var(--accent) !important;
}

.front-muted,
[data-theme="dark"] .text-muted,
[data-theme="dark"] .cookie-banner-text,
[data-theme="dark"] #resultsHint,
[data-theme="dark"] .list-group-item-action {
    color: var(--muted) !important;
}

[data-theme="light"] .text-muted { color: var(--muted) !important; }

.form-control::placeholder,
.form-select::placeholder {
    color: var(--muted);
    opacity: 0.9;
}

.hero-slider .carousel-item img { border-radius: 16px; }
.hero-slider .carousel-control-prev-icon,
.hero-slider .carousel-control-next-icon {
    filter: drop-shadow(0 2px 6px rgba(0,0,0,0.6));
}

.list-group-item-action:hover,
.list-group-item-action:focus {
    color: var(--text) !important;
    background: rgba(255,255,255,0.06) !important;
}

.form-control, .form-select {
    background: rgba(255,255,255,0.04);
    border-color: var(--border);
    color: var(--text);
}

[data-theme="light"] .form-control,
[data-theme="light"] .form-select {
    background: #fff;
}

.form-control:focus, .form-select:focus {
    background: rgba(255,255,255,0.06);
    border-color: var(--accent);
    color: var(--text);
    box-shadow: 0 0 0 .2rem rgba(56, 189, 248, 0.15);
}

.result-item {
    background: rgba(255,255,255,0.04);
    border-left: 4px solid var(--accent);
    padding: 1rem;
    border-radius: 12px;
    margin-bottom: .75rem;
}

.front-footer {
    border-top: 1px solid var(--border);
    background: var(--bg-elevated);
    backdrop-filter: blur(16px);
}

.front-footer a { color: var(--muted); text-decoration: none; }
.front-footer a:hover { color: var(--accent); }

.footer-copyright p { margin-bottom: 0; }
.footer-copyright a { color: var(--accent); }

mark { background: rgba(255, 193, 7, 0.35); padding: 0 .2em; border-radius: 3px; }
.login-page, .unsubscribe-page { display:flex; align-items:center; justify-content:center; min-height:100vh; }
.login-card { width: 400px; max-width: 92vw; }
.message-box.success h1 { color: #00ffcc; }
.message-box.error h1 { color: #ff4d4d; }

[data-theme="dark"] .theme-icon-light { display: none; }
[data-theme="light"] .theme-icon-dark { display: none; }
.front-lang-btn {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
}
.front-flag {
    border-radius: 2px;
    object-fit: cover;
}
.dropdown-item img {
    margin-right: .45rem;
    vertical-align: -2px;
}

@media (max-width: 576px) {
    .front-tabs .nav-link { margin-bottom: .5rem; }
}
