:root {
    --tvm-primary: #1246a0;
    --tvm-primary-rgb: 18, 70, 160;
    --tvm-primary-dark: #0d3579;
    --tvm-accent: #3d7cff;
    --tvm-accent-rgb: 61, 124, 255;
    --tvm-bg: #f4f7fb;
    --tvm-text-rgb: 23, 50, 77;
    --tvm-surface: #ffffff;
    --tvm-surface-soft: #f8fbff;
    --tvm-border: #dfe7f3;
    --tvm-border-strong: #cfd9e8;
    --tvm-text: #17324d;
    --tvm-text-soft: #61758b;
    --tvm-shadow: 0 14px 40px rgba(15, 40, 75, 0.08);
    --tvm-shadow-soft: 0 8px 24px rgba(15, 40, 75, 0.05);
    --tvm-radius: 1.15rem;
    --tvm-radius-sm: 0.9rem;
    --tvm-radius-lg: 1.45rem;
    --tvm-container-max: 1240px;
    --tvm-content-max: 1040px;
    --tvm-topbar-height: 78px;
    --tvm-page-padding-y: 1.5rem;
    --tvm-card-padding: 1.25rem;
}

html {
    scroll-behavior: smooth;
}

body {
    background:
        radial-gradient(circle at top right, rgba(var(--tvm-accent-rgb), 0.08), transparent 22%),
        linear-gradient(180deg, #f8fbff 0%, var(--tvm-bg) 22%, #eef3f9 100%);
    color: var(--tvm-text);
    min-height: 100vh;
}

a {
    text-decoration: none;
}

.page-shell {
    min-height: calc(100vh - var(--tvm-topbar-height));
}

.container-narrow {
    max-width: var(--tvm-content-max);
}

.topbar {
    background: rgba(255, 255, 255, 0.88);
    backdrop-filter: blur(16px);
    border-bottom: 1px solid rgba(var(--tvm-primary-rgb), 0.08);
    box-shadow: 0 10px 30px rgba(var(--tvm-text-rgb), 0.05);
}

.topbar-inner {
    min-height: var(--tvm-topbar-height);
}

.navbar-brand {
    display: inline-flex;
    align-items: center;
    gap: 0.85rem;
    font-weight: 800;
    color: var(--tvm-text);
    letter-spacing: -0.02em;
}


.brand-logo {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
}

.brand-logo-image {
    display: block;
    max-height: 56px;
    width: auto;
    object-fit: contain;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.12);
    padding: 6px;
}

.brand-mark {
    width: 2.65rem;
    height: 2.65rem;
    border-radius: 0.95rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--tvm-primary) 0%, var(--tvm-accent) 100%);
    color: #fff;
    font-size: 0.98rem;
    box-shadow: 0 10px 24px rgba(var(--tvm-primary-rgb), 0.24);
}

.brand-meta {
    display: flex;
    flex-direction: column;
    line-height: 1.05;
}

.brand-title {
    font-size: 1rem;
}

.brand-subtitle {
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--tvm-text-soft);
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.nav-pills-shell {
    align-items: center;
    gap: 0.35rem;
}

.navbar .nav-link {
    color: var(--tvm-text-soft);
    font-weight: 700;
    border-radius: 999px;
    padding: 0.6rem 0.95rem;
    transition: all 0.18s ease;
}

.navbar .nav-link:hover,
.navbar .nav-link.active,
.navbar .show > .nav-link {
    color: var(--tvm-account-hero-outline-hover-text);
    background: rgba(var(--tvm-primary-rgb), 0.08);
}

.nav-cart-item {
    display: flex;
    align-items: center;
    margin-left: 0.15rem;
}

.nav-cart-link {
    position: relative;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--tvm-text-soft);
    background: transparent;
    text-decoration: none;
    transition: color 0.18s ease, background-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.nav-cart-link:hover,
.nav-cart-link:focus,
.nav-cart-link.active {
    color: var(--tvm-primary);
    background: rgba(var(--tvm-primary-rgb), 0.08);
    box-shadow: 0 10px 24px rgba(var(--tvm-primary-rgb), 0.12);
}

.nav-cart-svg {
    display: block;
    flex: 0 0 auto;
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.nav-cart-badge {
    position: absolute;
    top: -0.2rem;
    right: -0.2rem;
    min-width: 1.25rem;
    height: 1.25rem;
    padding: 0 0.3rem;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--tvm-primary);
    color: #fff;
    border: 2px solid #fff;
    font-size: 0.68rem;
    line-height: 1;
    font-weight: 900;
    box-shadow: 0 8px 16px rgba(var(--tvm-primary-rgb), 0.22);
}

@media (max-width: 1199.98px) {
    .nav-cart-item {
        margin: 0.35rem 0 0;
    }

    .nav-cart-link {
        width: 100%;
        height: 2.65rem;
        justify-content: flex-start;
        gap: 0.55rem;
        padding: 0 0.9rem;
        border-radius: 0.95rem;
    }

    .nav-cart-link::after {
        content: 'Sammelbuchung';
        font-weight: 800;
        font-size: 0.95rem;
    }

    .nav-cart-badge {
        top: 0.15rem;
        left: 2.05rem;
        right: auto;
    }
}

.modern-dropdown {
    min-width: 240px;
    border-radius: 1rem;
    padding: 0.55rem;
    background: rgba(255, 255, 255, 0.98);
    backdrop-filter: blur(14px);
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.08) !important;
    box-shadow: 0 18px 44px rgba(var(--tvm-text-rgb), 0.12) !important;
}

.modern-dropdown .dropdown-item,
.modern-dropdown .dropdown-header {
    border-radius: 0.8rem;
}

.modern-dropdown .dropdown-header {
    color: var(--tvm-text-soft);
    font-weight: 700;
    padding: 0.45rem 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 0.72rem;
}

.modern-dropdown .dropdown-item {
    padding: 0.65rem 0.8rem;
    font-weight: 600;
    color: var(--tvm-text);
}

.modern-dropdown .dropdown-item:hover,
.modern-dropdown .dropdown-item.active {
    background: rgba(var(--tvm-primary-rgb), 0.08);
    color: var(--tvm-account-hero-outline-hover-text);
}

.btn-user {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.12);
    background: rgba(255, 255, 255, 0.82);
    border-radius: 1rem;
    padding: 0.45rem 0.8rem;
    color: var(--tvm-text);
    box-shadow: var(--tvm-shadow-soft);
}

.btn-user:hover,
.btn-user:focus,
.btn-user.show {
    border-color: rgba(var(--tvm-primary-rgb), 0.18);
    background: #fff;
    color: var(--tvm-text);
}

.user-avatar {
    width: 2.15rem;
    height: 2.15rem;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(var(--tvm-primary-rgb), 0.12), rgba(var(--tvm-accent-rgb), 0.18));
    color: var(--tvm-primary-dark);
    font-weight: 800;
    font-size: 0.86rem;
}

.user-meta {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    line-height: 1.1;
}

.user-meta-title {
    font-size: 0.92rem;
    font-weight: 700;
}

.user-meta-subtitle {
    font-size: 0.73rem;
    color: var(--tvm-text-soft);
}

.hero-box,
.surface-panel,
.section-sidebar {
    background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.98) 100%);
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.10);
    border-radius: 1.4rem;
    padding: 1.5rem;
    box-shadow: var(--tvm-shadow);
}

.hero-box {
    position: relative;
    overflow: hidden;
}

.hero-box::after {
    content: "";
    position: absolute;
    right: -4rem;
    top: -4rem;
    width: 12rem;
    height: 12rem;
    background: radial-gradient(circle, rgba(var(--tvm-accent-rgb), 0.18), transparent 68%);
    pointer-events: none;
}

.hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    border-radius: 999px;
    padding: 0.38rem 0.75rem;
    background: rgba(var(--tvm-primary-rgb), 0.08);
    color: var(--tvm-account-hero-outline-hover-text);
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.section-sidebar {
    padding: 1.25rem;
}

.section-sidebar-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.section-sidebar-kicker {
    color: var(--tvm-account-hero-outline-hover-text);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.74rem;
    font-weight: 800;
    margin-bottom: 0.25rem;
}

.section-sidebar-title {
    color: var(--tvm-text);
}

.section-sidebar-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.section-sidebar-grid-single {
    grid-template-columns: minmax(0, 320px);
}

.sidebar-card {
    border: 1px solid var(--tvm-border);
    border-radius: 1.15rem;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: var(--tvm-shadow-soft);
    padding: 1rem;
}

.sidebar-card-compact {
    max-width: 280px;
}

.sidebar-card-title {
    font-size: 0.8rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: var(--tvm-text-soft);
    margin-bottom: 0.75rem;
}

.sidebar-nav-list {
    display: grid;
    gap: 0.4rem;
}

.sidebar-nav-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    border-radius: 0.95rem;
    padding: 0.75rem 0.9rem;
    color: var(--tvm-text);
    font-weight: 700;
    transition: all 0.18s ease;
}

.sidebar-nav-link:hover {
    background: rgba(var(--tvm-primary-rgb), 0.05);
    color: var(--tvm-account-hero-outline-hover-text);
}

.sidebar-nav-link.is-active {
    background: linear-gradient(135deg, rgba(18, 70, 160, 0.1), rgba(61, 124, 255, 0.12));
    color: var(--tvm-primary-dark);
    box-shadow: inset 0 0 0 1px rgba(18, 70, 160, 0.08);
}

.card-soft {
    border: 1px solid var(--tvm-border);
    border-radius: 1.25rem;
    background: rgba(255,255,255,0.96);
    box-shadow: var(--tvm-shadow-soft);
}

.card-soft > .card-body {
    padding: 1.35rem;
}

.metric-tile {
    border: 1px solid var(--tvm-border);
    border-radius: 1rem;
    padding: 1rem 1.1rem;
    background: linear-gradient(180deg, #fff 0%, #f8fbff 100%);
}

.metric-value {
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--tvm-primary-dark);
}

.muted-label,
.text-secondary,
.form-text,
.small.text-secondary {
    color: var(--tvm-text-soft) !important;
}

.price-badge {
    font-weight: 700;
    border: 1px solid var(--tvm-border);
    background: #fff !important;
    color: var(--tvm-text) !important;
}

.session-row,
.session-card {
    background: linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
    border: 1px solid var(--tvm-border);
    border-radius: 1rem;
    box-shadow: var(--tvm-shadow-soft);
}

.booking-box {
    border: 1px dashed rgba(18, 70, 160, 0.2);
    background: rgba(18, 70, 160, 0.03);
    border-radius: 1rem;
    padding: 0.9rem;
}

.info-list {
    display: grid;
    gap: 0.8rem;
}

.info-list-item {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid rgba(23, 50, 77, 0.08);
}

.info-list-item:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.info-list-item span:first-child {
    color: var(--tvm-text-soft);
}

.form-control,
.form-select,
textarea.form-control {
    border-radius: 0.9rem;
    border-color: var(--tvm-border-strong);
    min-height: 2.9rem;
    box-shadow: none !important;
}

.form-control:focus,
.form-select:focus,
textarea.form-control:focus {
    border-color: rgba(18, 70, 160, 0.42);
    box-shadow: 0 0 0 0.25rem rgba(var(--tvm-primary-rgb), 0.12) !important;
}

.btn {
    border-radius: 0.9rem;
    font-weight: 700;
    padding: 0.65rem 1rem;
}

.btn-sm {
    border-radius: 0.8rem;
    padding: 0.5rem 0.8rem;
}

.btn-primary {
    background: linear-gradient(135deg, var(--tvm-primary) 0%, var(--tvm-accent) 100%);
    border-color: transparent;
    box-shadow: 0 10px 24px rgba(var(--tvm-primary-rgb), 0.18);
}

.btn-primary:hover,
.btn-primary:focus {
    background: linear-gradient(135deg, var(--tvm-primary-dark) 0%, var(--tvm-accent) 100%);
    border-color: transparent;
}

.btn-outline-primary {
    border-color: rgba(var(--tvm-primary-rgb), 0.22);
    color: var(--tvm-account-hero-outline-hover-text);
}

.btn-outline-primary:hover,
.btn-outline-secondary:hover {
    transform: translateY(-1px);
}

.table-responsive {
    border-radius: 1rem;
}

.table {
    --bs-table-bg: transparent;
    margin-bottom: 0;
}

.table > :not(caption) > * > * {
    padding-top: 0.95rem;
    padding-bottom: 0.95rem;
    border-bottom-color: rgba(23, 50, 77, 0.08);
}

.table thead th {
    white-space: nowrap;
    color: var(--tvm-text-soft);
    font-size: 0.83rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.table tbody tr:hover {
    background: rgba(18, 70, 160, 0.025);
}

.progress {
    background: rgba(var(--tvm-primary-rgb), 0.08);
    border-radius: 999px;
    overflow: hidden;
}

.alert {
    border: 0;
    border-radius: 1rem;
    box-shadow: var(--tvm-shadow-soft);
}

.section-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.section-kicker {
    color: var(--tvm-account-hero-outline-hover-text);
    text-transform: uppercase;
    letter-spacing: 0.07em;
    font-size: 0.78rem;
    font-weight: 700;
}

.page-footer {
    margin-top: 2.5rem;
    padding: 1.25rem 0 2rem;
    color: var(--tvm-text-soft);
    font-size: 0.92rem;
}

.login-card,
.auth-card {
    max-width: 520px;
    margin: 0 auto;
}

.border.rounded-3.bg-light-subtle,
.border.rounded.p-3.bg-light,
.bg-light-subtle {
    background: var(--tvm-surface-soft) !important;
    border-color: var(--tvm-border) !important;
}

.badge.text-bg-light {
    background: #f2f6fc !important;
    color: var(--tvm-text) !important;
}

@media (max-width: 1199.98px) {
    .nav-pills-shell {
        align-items: stretch;
    }

    .modern-dropdown {
        min-width: 100%;
    }
}

@media (max-width: 991.98px) {
    .hero-box,
    .surface-panel,
    .section-sidebar {
        padding: 1.1rem;
    }

    .navbar .nav-link {
        margin-bottom: 0.2rem;
    }

    .section-sidebar-head {
        margin-bottom: 0.5rem;
    }
}

@media print {
    nav,
    .btn,
    .alert,
    .section-sidebar,
    .page-footer {
        display: none !important;
    }

    .container {
        max-width: none !important;
    }

    .invoice-card {
        box-shadow: none !important;
        border: none !important;
    }
}


.backend-shell {
    display: grid;
    grid-template-columns: 290px minmax(0, 1fr);
    gap: 1.5rem;
    align-items: start;
}

.backend-sidebar {
    position: sticky;
    top: 96px;
    background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.98) 100%);
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.10);
    border-radius: 1.4rem;
    box-shadow: var(--tvm-shadow);
    padding: 1.25rem;
}

.backend-sidebar-head {
    margin-bottom: 1rem;
}

.backend-sidebar-kicker {
    color: var(--tvm-account-hero-outline-hover-text);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.74rem;
    font-weight: 800;
    margin-bottom: 0.25rem;
}

.backend-sidebar-title {
    margin: 0;
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--tvm-text);
}

.backend-sidebar-subtitle {
    margin-top: 0.35rem;
    color: var(--tvm-text-soft);
    font-size: 0.9rem;
}

.backend-sidebar-body {
    display: grid;
    gap: 1rem;
}

.backend-nav-group {
    border-top: 1px solid var(--tvm-border);
    padding-top: 1rem;
}

.backend-nav-group:first-child {
    border-top: 0;
    padding-top: 0;
}

.backend-nav-group-secondary {
    margin-top: 0.25rem;
}

.backend-nav-group-title {
    font-size: 0.74rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--tvm-text-soft);
    margin-bottom: 0.75rem;
}

.backend-nav {
    display: grid;
    gap: 0.35rem;
}

.backend-nav-link {
    display: flex;
    align-items: center;
    min-height: 46px;
    padding: 0.72rem 0.9rem;
    border-radius: 0.95rem;
    color: var(--tvm-text);
    font-weight: 700;
    transition: all 0.18s ease;
}

.backend-nav-link:hover {
    background: rgba(var(--tvm-primary-rgb), 0.05);
    color: var(--tvm-account-hero-outline-hover-text);
}

.backend-nav-link.is-active {
    background: linear-gradient(135deg, rgba(18, 70, 160, 0.1), rgba(61, 124, 255, 0.12));
    color: var(--tvm-primary-dark);
    box-shadow: inset 0 0 0 1px rgba(18, 70, 160, 0.08);
}

.backend-main {
    min-width: 0;
}

@media (max-width: 991.98px) {
    .backend-shell {
        grid-template-columns: 1fr;
        gap: 1rem;
    }

    .backend-sidebar {
        position: static;
        padding: 1rem;
    }
}


.navbar-toggler {
    border-radius: 0.95rem;
    border-color: rgba(18, 70, 160, 0.12);
    padding: 0.55rem 0.8rem;
}

.navbar-toggler:focus {
    box-shadow: 0 0 0 0.25rem rgba(18, 70, 160, 0.12);
}

.backend-sidebar {
    overflow: hidden;
}

.backend-sidebar::before {
    content: "";
    display: block;
    height: 4px;
    margin: -1.25rem -1.25rem 1rem;
    background: linear-gradient(90deg, var(--tvm-primary) 0%, var(--tvm-accent) 100%);
}

.backend-main > * + * {
    margin-top: 1.5rem;
}

.auth-shell {
    min-height: calc(100vh - 210px);
    display: flex;
    align-items: center;
}

.auth-card {
    position: relative;
    overflow: hidden;
}

.auth-card::after {
    content: "";
    position: absolute;
    top: -5rem;
    right: -4rem;
    width: 12rem;
    height: 12rem;
    background: radial-gradient(circle, rgba(61, 124, 255, 0.16), transparent 68%);
    pointer-events: none;
}

.auth-card .card-body {
    position: relative;
    z-index: 1;
}

.auth-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    border-radius: 999px;
    padding: 0.38rem 0.75rem;
    background: rgba(var(--tvm-primary-rgb), 0.08);
    color: var(--tvm-account-hero-outline-hover-text);
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 1rem;
}

.auth-title {
    font-size: clamp(1.55rem, 2vw, 2rem);
    font-weight: 800;
    letter-spacing: -0.03em;
    margin-bottom: 0.45rem;
}

.auth-subtitle {
    color: var(--tvm-text-soft);
    margin-bottom: 1.4rem;
}

.auth-actions {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-top: 1rem;
}

.auth-side-note {
    color: var(--tvm-text-soft);
    font-size: 0.92rem;
}

.dashboard-hero {
    position: relative;
    overflow: hidden;
}

.dashboard-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at top right, rgba(61, 124, 255, 0.16), transparent 34%);
    pointer-events: none;
}

.dashboard-hero > .card-body,
.stat-card > .card-body,
.list-card > .card-body {
    position: relative;
    z-index: 1;
}

.dashboard-hero-meta {
    display: grid;
    gap: 0.75rem;
}

.dashboard-hero-list {
    display: grid;
    gap: 0.75rem;
    margin-top: 1rem;
}

.dashboard-hero-list-item {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.85rem 1rem;
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(18, 70, 160, 0.08);
}

.dashboard-hero-list-item span:first-child {
    color: var(--tvm-text-soft);
}

.stat-card {
    position: relative;
    overflow: hidden;
    min-height: 100%;
}

.stat-card::after {
    content: "";
    position: absolute;
    top: -1.4rem;
    right: -1rem;
    width: 5rem;
    height: 5rem;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(61, 124, 255, 0.16), transparent 70%);
    pointer-events: none;
}

.stat-label {
    color: var(--tvm-text-soft);
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 700;
    margin-bottom: 0.45rem;
}

.stat-value {
    font-size: clamp(1.8rem, 3vw, 2.35rem);
    font-weight: 800;
    line-height: 1;
    color: var(--tvm-primary-dark);
}

.stat-note {
    margin-top: 0.55rem;
    color: var(--tvm-text-soft);
    font-size: 0.88rem;
}

.list-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.list-card-item {
    border: 1px solid var(--tvm-border);
    border-radius: 1rem;
    background: var(--tvm-surface-soft);
    padding: 1rem;
}

.list-card-item + .list-card-item {
    margin-top: 0.85rem;
}

.table-card .table thead th {
    background: rgba(18, 70, 160, 0.03);
}

.inline-status {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    font-size: 0.86rem;
    color: var(--tvm-text-soft);
}

.inline-status::before {
    content: "";
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 999px;
    background: rgba(18, 70, 160, 0.35);
}

.section-divider {
    height: 1px;
    background: linear-gradient(90deg, rgba(18, 70, 160, 0.08), rgba(18, 70, 160, 0));
    margin: 1.25rem 0;
}

@media (max-width: 991.98px) {
    .auth-shell {
        min-height: auto;
        display: block;
    }

    .backend-sidebar::before {
        margin: -1rem -1rem 1rem;
    }
}


.admin-table thead th {
    font-size: 0.79rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--tvm-text-soft);
    white-space: nowrap;
}

.admin-table tbody td {
    vertical-align: middle;
}

.sticky-panel {
    position: sticky;
    top: 1.5rem;
}

@media (max-width: 1199.98px) {
    .sticky-panel {
        position: static;
    }
}

.admin-metric-card {
    position: relative;
    overflow: hidden;
    min-height: 100%;
}

.admin-metric-card::after {
    content: "";
    position: absolute;
    top: -1.5rem;
    right: -1.1rem;
    width: 5.2rem;
    height: 5.2rem;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(61, 124, 255, 0.18), transparent 72%);
    pointer-events: none;
}

.admin-metric-card .card-body,
.admin-list-header,
.filter-toolbar,
.admin-table-card .card-body {
    position: relative;
    z-index: 1;
}

.admin-page-title {
    font-size: clamp(1.25rem, 2vw, 1.55rem);
    font-weight: 800;
    letter-spacing: -0.03em;
    margin-bottom: 0.35rem;
}

.admin-page-subtitle {
    color: var(--tvm-text-soft);
    margin-bottom: 0;
}

.admin-list-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.filter-toolbar {
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.1rem;
    padding: 1rem;
    background: rgba(248, 251, 255, 0.88);
}

.filter-toolbar .form-label {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--tvm-text-soft);
    margin-bottom: 0.45rem;
}

.admin-table-card {
    overflow: hidden;
}

.admin-table-card .table thead th {
    background: rgba(18, 70, 160, 0.035);
}

.stacked-meta {
    display: grid;
    gap: 0.18rem;
}

.stacked-meta strong,
.stacked-meta .fw-semibold {
    font-weight: 700;
}

.meta-note {
    color: var(--tvm-text-soft);
    font-size: 0.84rem;
}

.table-actions {
    display: flex;
    gap: 0.5rem;
    justify-content: flex-end;
    flex-wrap: wrap;
}

.status-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.42rem 0.7rem;
    border-radius: 999px;
    font-size: 0.8rem;
    font-weight: 700;
    line-height: 1;
    border: 1px solid transparent;
}

.status-pill::before {
    content: "";
    width: 0.45rem;
    height: 0.45rem;
    border-radius: 50%;
    background: currentColor;
    opacity: 0.75;
}

.status-pill.is-success {
    color: #137a58;
    background: rgba(19, 122, 88, 0.1);
    border-color: rgba(19, 122, 88, 0.14);
}

.status-pill.is-muted {
    color: #607286;
    background: rgba(96, 114, 134, 0.1);
    border-color: rgba(96, 114, 134, 0.14);
}

.status-pill.is-danger {
    color: #b03a48;
    background: rgba(176, 58, 72, 0.1);
    border-color: rgba(176, 58, 72, 0.14);
}

.status-pill.is-warning {
    color: #99621a;
    background: rgba(153, 98, 26, 0.12);
    border-color: rgba(153, 98, 26, 0.16);
}

.status-pill.is-info {
    color: var(--tvm-account-hero-outline-hover-text);
    background: rgba(var(--tvm-primary-rgb), 0.08);
    border-color: rgba(18, 70, 160, 0.12);
}

.empty-state {
    text-align: center;
    color: var(--tvm-text-soft);
    padding: 2rem 1rem;
}

.quick-note {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.35rem 0.65rem;
    border-radius: 999px;
    background: rgba(18, 70, 160, 0.06);
    color: var(--tvm-account-hero-outline-hover-text);
    font-size: 0.78rem;
    font-weight: 700;
}

.table-tight td,
.table-tight th {
    white-space: nowrap;
}

.table-tight td:first-child,
.table-tight th:first-child {
    white-space: normal;
}

@media (max-width: 991.98px) {
    .admin-list-header {
        margin-bottom: 0.9rem;
    }

    .filter-toolbar {
        padding: 0.85rem;
    }

    .table-actions {
        justify-content: stretch;
    }

    .table-actions .btn,
    .table-actions form,
    .table-actions form .btn {
        width: 100%;
    }
}


.admin-detail-hero {
    position: relative;
    overflow: hidden;
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
    flex-wrap: wrap;
}

.admin-detail-hero::after {
    content: "";
    position: absolute;
    right: -3rem;
    top: -3rem;
    width: 11rem;
    height: 11rem;
    background: radial-gradient(circle, rgba(61, 124, 255, 0.16), transparent 68%);
    pointer-events: none;
}

.admin-detail-hero > * {
    position: relative;
    z-index: 1;
}

.admin-detail-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    border-radius: 999px;
    padding: 0.38rem 0.72rem;
    background: rgba(var(--tvm-primary-rgb), 0.08);
    color: var(--tvm-account-hero-outline-hover-text);
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 0.85rem;
}

.admin-detail-title {
    font-size: clamp(1.4rem, 2.2vw, 1.9rem);
    font-weight: 800;
    letter-spacing: -0.03em;
    margin-bottom: 0.3rem;
}

.admin-detail-subtitle {
    color: var(--tvm-text-soft);
    margin-bottom: 0;
}

.admin-detail-actions {
    display: flex;
    gap: 0.65rem;
    flex-wrap: wrap;
    align-items: center;
}

.admin-summary-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.admin-summary-card {
    border: 1px solid var(--tvm-border);
    border-radius: 1.15rem;
    background: linear-gradient(180deg, #fff 0%, #f8fbff 100%);
    padding: 1rem 1.05rem;
    box-shadow: var(--tvm-shadow-soft);
    min-height: 100%;
}

.admin-summary-label {
    color: var(--tvm-text-soft);
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 800;
    margin-bottom: 0.5rem;
}

.admin-summary-value {
    font-size: 1.15rem;
    font-weight: 800;
    color: var(--tvm-primary-dark);
    line-height: 1.2;
}

.admin-summary-note {
    margin-top: 0.35rem;
    color: var(--tvm-text-soft);
    font-size: 0.88rem;
}

.detail-card-head,
.form-card-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.detail-card-title,
.form-card-title {
    margin: 0;
    font-size: 1.08rem;
    font-weight: 800;
    letter-spacing: -0.02em;
}

.detail-card-subtitle,
.form-card-subtitle {
    margin-top: 0.25rem;
    color: var(--tvm-text-soft);
    font-size: 0.92rem;
}

.detail-stack {
    display: grid;
    gap: 0.9rem;
}

.detail-row {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding-bottom: 0.8rem;
    border-bottom: 1px solid rgba(23, 50, 77, 0.08);
}

.detail-row:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.detail-row-label {
    color: var(--tvm-text-soft);
    font-size: 0.88rem;
    min-width: 38%;
}

.detail-row-value {
    font-weight: 700;
    text-align: right;
}

.detail-list-card {
    border: 1px solid var(--tvm-border);
    border-radius: 1rem;
    background: var(--tvm-surface-soft);
    padding: 0.95rem 1rem;
}

.form-help-box {
    border: 1px dashed rgba(18, 70, 160, 0.18);
    border-radius: 1rem;
    background: rgba(18, 70, 160, 0.035);
    padding: 0.95rem 1rem;
    color: var(--tvm-text-soft);
    font-size: 0.92rem;
}

@media (max-width: 1199.98px) {
    .admin-summary-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .admin-summary-grid {
        grid-template-columns: 1fr;
    }

    .detail-row {
        flex-direction: column;
        gap: 0.3rem;
    }

    .detail-row-value {
        text-align: left;
    }

    .admin-detail-actions .btn,
    .admin-detail-actions form,
    .admin-detail-actions form .btn {
        width: 100%;
    }
}


.page-intro-card {
    border: 1px solid rgba(18, 70, 160, 0.10);
    border-radius: 1.25rem;
    background: linear-gradient(135deg, rgba(18, 70, 160, 0.06), rgba(61, 124, 255, 0.03));
    box-shadow: var(--tvm-shadow-soft);
}

.page-intro-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--tvm-account-hero-outline-hover-text);
}

.metric-tile {
    border: 1px solid rgba(18, 70, 160, 0.10);
    border-radius: 1.15rem;
    background: #fff;
    box-shadow: var(--tvm-shadow-soft);
    padding: 1rem 1.05rem;
    height: 100%;
}

.metric-tile-label {
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--tvm-text-soft);
    font-weight: 700;
}

.metric-tile-value {
    font-size: 1.65rem;
    font-weight: 800;
    color: var(--tvm-text);
    margin-top: 0.25rem;
}

.metric-tile-note {
    color: var(--tvm-text-soft);
    font-size: 0.84rem;
}

.card-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 1.25rem;
}

.card-toolbar-title {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 800;
}

.card-toolbar-text {
    color: var(--tvm-text-soft);
    margin-top: 0.2rem;
    font-size: 0.92rem;
}

.form-section-card {
    border: 1px solid rgba(18, 70, 160, 0.10);
    border-radius: 1.25rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.99) 0%, rgba(248,251,255,0.98) 100%);
    box-shadow: var(--tvm-shadow-soft);
}

.form-section-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.form-section-title {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 800;
    color: var(--tvm-text);
}

.form-section-description {
    color: var(--tvm-text-soft);
    font-size: 0.92rem;
    margin-top: 0.25rem;
}

.sticky-side-card {
    position: sticky;
    top: 1.5rem;
}

.info-list {
    display: grid;
    gap: 0.85rem;
}

.info-list-item {
    display: flex;
    gap: 0.8rem;
    align-items: flex-start;
}

.info-list-bullet {
    width: 0.75rem;
    height: 0.75rem;
    border-radius: 999px;
    margin-top: 0.35rem;
    background: linear-gradient(135deg, var(--tvm-primary), var(--tvm-accent));
    flex: 0 0 auto;
}

.info-list strong {
    display: block;
    font-size: 0.95rem;
    color: var(--tvm-text);
}

.info-list span {
    color: var(--tvm-text-soft);
    font-size: 0.9rem;
}

.settings-grid {
    display: grid;
    gap: 1.25rem;
}

.settings-section {
    border: 1px solid rgba(18, 70, 160, 0.10);
    border-radius: 1.25rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.99) 0%, rgba(248,251,255,0.98) 100%);
    padding: 1.35rem;
    box-shadow: var(--tvm-shadow-soft);
}

.settings-section h2 {
    margin: 0;
    font-size: 1.02rem;
    font-weight: 800;
    color: var(--tvm-text);
}

.settings-section p {
    margin: 0.3rem 0 0;
    color: var(--tvm-text-soft);
    font-size: 0.9rem;
}

.settings-section .section-divider {
    height: 1px;
    background: rgba(18, 70, 160, 0.10);
    margin: 1rem 0 0.25rem;
}

.code-pill {
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.6rem;
    border-radius: 999px;
    background: rgba(var(--tvm-primary-rgb), 0.08);
    color: var(--tvm-primary-dark);
    font-weight: 800;
    letter-spacing: 0.04em;
}

.data-table-clean thead th {
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--tvm-text-soft);
    border-bottom-width: 1px;
}

.data-table-clean tbody td {
    vertical-align: middle;
    border-color: rgba(18, 70, 160, 0.08);
}

.data-table-clean tbody tr:hover {
    background: rgba(18, 70, 160, 0.025);
}

.form-help-box {
    border-radius: 1rem;
    border: 1px solid rgba(18, 70, 160, 0.10);
    background: rgba(255,255,255,0.85);
    padding: 1rem;
}


.utility-card {
    border: 1px solid var(--tvm-border);
    border-radius: 1.15rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.95) 100%);
    box-shadow: var(--tvm-shadow-soft);
}

.utility-card > .card-body {
    padding: 1.25rem;
}

.utility-item {
    border: 1px solid var(--tvm-border);
    border-radius: 1rem;
    background: rgba(255,255,255,0.94);
    box-shadow: var(--tvm-shadow-soft);
    padding: 1rem;
}

.utility-item-soft {
    background: var(--tvm-surface-soft);
}

.metric-grid-compact {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.metric-grid-compact .metric-tile,
.metric-grid-compact .card {
    min-height: 100%;
}

.inline-code-pill {
    display: inline-flex;
    align-items: center;
    padding: 0.28rem 0.55rem;
    border-radius: 999px;
    background: rgba(18, 70, 160, 0.06);
    color: var(--tvm-primary-dark);
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, Liberation Mono, monospace;
    font-size: 0.78rem;
    font-weight: 700;
}

.log-context {
    margin: 0;
    padding: 0.9rem 1rem;
    border-radius: 1rem;
    border: 1px solid var(--tvm-border);
    background: #f6f9fd;
    color: var(--tvm-text);
    font-size: 0.82rem;
    line-height: 1.45;
    max-height: 260px;
    overflow: auto;
}

.notice-card,
.task-card,
.note-card,
.email-preview-card,
.log-card {
    border: 1px solid var(--tvm-border);
    border-radius: 1.05rem;
    background: rgba(255,255,255,0.96);
    box-shadow: var(--tvm-shadow-soft);
    padding: 1rem;
}

.email-preview-body {
    margin: 0;
    padding: 1rem 1.1rem;
    border-radius: 1rem;
    border: 1px solid var(--tvm-border);
    background: #f7faff;
    white-space: pre-wrap;
    font-family: inherit;
    line-height: 1.55;
}

.permission-matrix th,
.permission-matrix td {
    text-align: center;
}

.permission-matrix td:first-child,
.permission-matrix th:first-child {
    text-align: left;
}

.variable-list {
    display: grid;
    gap: 0.65rem;
}

.variable-list-item {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
    padding: 0.8rem 0.95rem;
    border-radius: 0.95rem;
    border: 1px solid var(--tvm-border);
    background: rgba(248,251,255,0.9);
}

.variable-list-item span:last-child {
    color: var(--tvm-text-soft);
    text-align: right;
}

@media (max-width: 991.98px) {
    .metric-grid-compact {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .metric-grid-compact {
        grid-template-columns: 1fr;
    }
}


/* User area polish */
.account-shell {
    display: grid;
    gap: 1.5rem;
}

.account-hero {
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, var(--tvm-account-hero-start) 0%, var(--tvm-account-hero-end) 100%);
    color: var(--tvm-account-hero-text);
    border: 0;
    border-radius: 1.6rem;
    box-shadow: var(--tvm-account-hero-shadow);
}

.account-hero::after {
    content: "";
    position: absolute;
    right: -5rem;
    top: -4rem;
    width: 16rem;
    height: 16rem;
    background: radial-gradient(circle, rgba(255,255,255,0.2), transparent 70%);
}

.account-hero .card-body,
.account-panel .card-body,
.account-metric .card-body {
    position: relative;
    z-index: 1;
}

.account-hero-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.38rem 0.78rem;
    border-radius: 999px;
    background: var(--tvm-account-hero-kicker-bg);
    color: var(--tvm-account-hero-kicker-text);
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.account-hero-title {
    font-size: clamp(1.65rem, 2.4vw, 2.2rem);
    font-weight: 800;
    margin: 0.8rem 0 0.35rem;
}

.account-hero-text {
    color: var(--tvm-account-hero-text-soft);
    max-width: 45rem;
    margin-bottom: 0;
}

.account-hero-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-top: 1.35rem;
}

.account-hero .btn-outline-light {
    border-width: 1px;
    background: var(--tvm-account-hero-outline-bg);
}

.account-hero .btn-outline-light:hover {
    background: #fff;
    color: var(--tvm-account-hero-outline-hover-text);
}

.account-metric {
    border: 0;
    border-radius: 1.35rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(246,249,255,0.98));
    box-shadow: var(--tvm-shadow-soft);
}

.account-metric-label {
    color: var(--tvm-text-soft);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 0.75rem;
    font-weight: 700;
    margin-bottom: 0.45rem;
}

.account-metric-value {
    font-size: clamp(1.45rem, 2vw, 1.95rem);
    font-weight: 800;
    color: var(--tvm-text);
    line-height: 1.05;
}

.account-metric-note {
    margin-top: 0.4rem;
    color: var(--tvm-text-soft);
    font-size: 0.88rem;
}

.account-panel {
    border: 0;
    border-radius: 1.4rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.99), rgba(248,251,255,0.98));
    box-shadow: var(--tvm-shadow);
}

.account-panel-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 1.25rem;
}

.account-panel-title {
    font-size: 1.08rem;
    font-weight: 800;
    margin: 0;
}

.account-panel-subtitle {
    color: var(--tvm-text-soft);
    font-size: 0.92rem;
    margin-top: 0.18rem;
}

.account-info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 0.9rem;
}

.account-info-item {
    border: 1px solid rgba(18,70,160,0.1);
    background: rgba(246,249,255,0.82);
    border-radius: 1rem;
    padding: 0.95rem 1rem;
}

.account-info-label {
    color: var(--tvm-text-soft);
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 700;
    margin-bottom: 0.3rem;
}

.account-info-value {
    font-weight: 700;
    color: var(--tvm-text);
}

.account-stack {
    display: grid;
    gap: 1rem;
}

.account-list-card {
    border: 1px solid rgba(18,70,160,0.1);
    border-radius: 1rem;
    padding: 1rem;
    background: rgba(248,251,255,0.75);
}

.account-list-card + .account-list-card {
    margin-top: 0.95rem;
}

.account-inline-meta {
    display: flex;
    gap: 0.5rem 1rem;
    flex-wrap: wrap;
    color: var(--tvm-text-soft);
    font-size: 0.9rem;
}

.account-table thead th {
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--tvm-text-soft);
    border-bottom-width: 1px;
}

.account-table tbody tr {
    vertical-align: middle;
}

.account-table tbody tr td {
    padding-top: 0.95rem;
    padding-bottom: 0.95rem;
}

.account-empty {
    border: 1px dashed rgba(18,70,160,0.22);
    background: rgba(247,250,255,0.85);
    border-radius: 1rem;
    padding: 1.25rem;
    color: var(--tvm-text-soft);
}

.account-form-section + .account-form-section {
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid rgba(18,70,160,0.08);
}

.account-form-title {
    font-size: 1rem;
    font-weight: 800;
    margin-bottom: 0.95rem;
}

.account-muted-box {
    border: 1px solid rgba(18,70,160,0.1);
    border-radius: 1rem;
    padding: 1rem;
    background: rgba(247,250,255,0.82);
}

.account-filter-bar {
    border: 1px solid rgba(18,70,160,0.08);
    border-radius: 1.15rem;
    padding: 1rem;
    background: rgba(247,250,255,0.9);
}

@media (max-width: 991.98px) {
    .account-hero-actions {
        margin-top: 1rem;
    }
}

/* Public frontend polish */
.public-hero {
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(18, 70, 160, 0.10);
    border-radius: 1.5rem;
    background: linear-gradient(135deg, rgba(255,255,255,0.98) 0%, rgba(247,250,255,0.98) 56%, rgba(236,243,255,0.96) 100%);
    box-shadow: var(--tvm-shadow);
    padding: 1.75rem;
}

.public-hero::before {
    content: "";
    position: absolute;
    inset: auto -2rem -3rem auto;
    width: 14rem;
    height: 14rem;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(61, 124, 255, 0.18), rgba(61, 124, 255, 0) 68%);
    pointer-events: none;
}

.public-hero-compact {
    padding: 1.55rem;
}

.public-hero-title {
    position: relative;
    z-index: 1;
    font-size: clamp(2rem, 4vw, 3rem);
    line-height: 1.05;
    letter-spacing: -0.03em;
    font-weight: 800;
    color: var(--tvm-text);
}

.public-hero-title-sm {
    font-size: clamp(1.8rem, 3vw, 2.35rem);
}

.public-hero-text,
.public-description {
    position: relative;
    z-index: 1;
    color: var(--tvm-text-soft);
    font-size: 1rem;
    line-height: 1.7;
    max-width: 60ch;
}

.public-hero-actions,
.public-meta-row {
    position: relative;
    z-index: 1;
}

.public-hero-panel {
    position: relative;
    z-index: 1;
    border: 1px solid rgba(18, 70, 160, 0.10);
    border-radius: 1.3rem;
    background: rgba(255,255,255,0.86);
    box-shadow: var(--tvm-shadow-soft);
    padding: 1.25rem;
}

.public-hero-panel-head {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
}

.public-status-pill,
.public-meta-pill {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0.45rem 0.75rem;
    border-radius: 999px;
    background: rgba(var(--tvm-primary-rgb), 0.08);
    color: var(--tvm-primary-dark);
    font-size: 0.8rem;
    font-weight: 700;
}

.public-meta-row {
    display: flex;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.public-mini-stats {
    display: grid;
    gap: 0.8rem;
}

.public-mini-stats-compact {
    gap: 0.65rem;
}

.public-mini-stat {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 0.85rem 0.95rem;
    border-radius: 1rem;
    border: 1px solid rgba(18, 70, 160, 0.08);
    background: rgba(248,251,255,0.94);
}

.public-mini-stat span {
    color: var(--tvm-text-soft);
    font-size: 0.82rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.public-mini-stat strong {
    color: var(--tvm-text);
    font-size: 0.95rem;
    text-align: right;
}

.public-check-list {
    display: grid;
    gap: 0.75rem;
}

.public-check-item {
    position: relative;
    padding-left: 1.75rem;
    color: var(--tvm-text);
    font-weight: 600;
}

.public-check-item::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.45rem;
    width: 0.9rem;
    height: 0.9rem;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--tvm-primary), var(--tvm-accent));
    box-shadow: 0 0 0 4px rgba(18, 70, 160, 0.08);
}

.public-metric-tile {
    border-radius: 1.2rem;
}

.public-course-card,
.public-section-card,
.public-feature-card,
.public-data-card,
.public-price-highlight,
.public-session-card {
    border-radius: 1.2rem;
}

.public-course-card {
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.public-course-card:hover {
    transform: translateY(-2px);
    border-color: rgba(18, 70, 160, 0.16);
    box-shadow: 0 16px 38px rgba(15, 40, 75, 0.09);
}

.public-data-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.8rem;
}

.public-data-grid-single {
    grid-template-columns: 1fr;
}

.public-data-card {
    border: 1px solid rgba(18, 70, 160, 0.08);
    background: rgba(248,251,255,0.96);
    padding: 0.95rem 1rem;
}

.public-data-card span {
    display: block;
    color: var(--tvm-text-soft);
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 700;
    margin-bottom: 0.35rem;
}

.public-data-card strong {
    color: var(--tvm-text);
    font-size: 0.95rem;
    line-height: 1.45;
}

.public-side-stack {
    display: grid;
    gap: 1rem;
}

.public-booking-box {
    background: linear-gradient(180deg, rgba(18, 70, 160, 0.03) 0%, rgba(61, 124, 255, 0.05) 100%);
}

.public-feature-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.public-feature-card {
    border: 1px solid rgba(18, 70, 160, 0.08);
    background: rgba(248,251,255,0.94);
    padding: 1.1rem;
}

.public-feature-card h3 {
    margin: 0 0 0.55rem;
    font-size: 1rem;
    font-weight: 800;
    color: var(--tvm-text);
}

.public-feature-card p {
    margin: 0;
    color: var(--tvm-text-soft);
    line-height: 1.6;
    font-size: 0.93rem;
}

.public-price-highlight {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.12);
    background: linear-gradient(135deg, rgba(18, 70, 160, 0.06) 0%, rgba(61, 124, 255, 0.08) 100%);
    padding: 1rem 1.1rem;
}

.public-price-highlight span {
    color: var(--tvm-text-soft);
    font-weight: 700;
}

.public-price-highlight strong {
    color: var(--tvm-primary-dark);
    font-size: 1.05rem;
}

@media (max-width: 991.98px) {
    .public-data-grid,
    .public-feature-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .public-hero,
    .public-hero-compact {
        padding: 1.25rem;
        border-radius: 1.25rem;
    }

    .public-hero-title,
    .public-hero-title-sm {
        font-size: 1.75rem;
    }

    .public-mini-stat,
    .public-price-highlight {
        flex-direction: column;
        align-items: flex-start;
    }
}


/* Unified messaging, badges and document polish */
.flash-stack {
    display: grid;
    gap: 0.9rem;
    margin-bottom: 1.2rem;
}

.flash-card {
    display: flex;
    align-items: flex-start;
    gap: 0.9rem;
    border: 1px solid transparent;
    border-radius: 1.1rem;
    padding: 1rem 1.15rem;
    box-shadow: var(--tvm-shadow-soft);
    backdrop-filter: blur(10px);
}

.flash-card .btn-close {
    margin-left: auto;
}

.flash-icon {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    font-size: 1rem;
    font-weight: 800;
    background: rgba(255,255,255,0.75);
}

.flash-title {
    font-size: 0.8rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin-bottom: 0.2rem;
}

.flash-message {
    color: inherit;
    line-height: 1.55;
}

.flash-card.alert-success,
.alert.alert-success {
    background: linear-gradient(180deg, rgba(236,252,245,0.96), rgba(227,249,239,0.96));
    border-color: rgba(19, 122, 88, 0.15);
    color: #126949;
}

.flash-card.alert-warning,
.alert.alert-warning {
    background: linear-gradient(180deg, rgba(255,249,232,0.98), rgba(255,245,214,0.98));
    border-color: rgba(153, 98, 26, 0.16);
    color: #8a5a17;
}

.flash-card.alert-danger,
.flash-card.alert-error,
.alert.alert-danger {
    background: linear-gradient(180deg, rgba(255,241,243,0.98), rgba(255,234,237,0.98));
    border-color: rgba(176, 58, 72, 0.16);
    color: #9e3041;
}

.flash-card.alert-info,
.alert.alert-info,
.alert.alert-light {
    background: linear-gradient(180deg, rgba(244,248,255,0.98), rgba(236,243,255,0.98));
    border-color: rgba(18, 70, 160, 0.12);
    color: var(--tvm-primary-dark);
}

.badge.text-bg-success,
.badge.text-bg-warning,
.badge.text-bg-danger,
.badge.text-bg-secondary,
.badge.text-bg-primary,
.badge.text-bg-light {
    border-radius: 999px;
    padding: 0.48rem 0.72rem;
    font-weight: 700;
    border: 1px solid transparent;
}

.badge.text-bg-success {
    background: rgba(19, 122, 88, 0.1) !important;
    color: #126949 !important;
    border-color: rgba(19, 122, 88, 0.14);
}

.badge.text-bg-warning {
    background: rgba(153, 98, 26, 0.12) !important;
    color: #8a5a17 !important;
    border-color: rgba(153, 98, 26, 0.16);
}

.badge.text-bg-danger {
    background: rgba(176, 58, 72, 0.1) !important;
    color: #9e3041 !important;
    border-color: rgba(176, 58, 72, 0.14);
}

.badge.text-bg-secondary {
    background: rgba(96, 114, 134, 0.1) !important;
    color: #56677a !important;
    border-color: rgba(96, 114, 134, 0.14);
}

.badge.text-bg-primary {
    background: rgba(18, 70, 160, 0.08) !important;
    color: var(--tvm-primary-dark) !important;
    border-color: rgba(18, 70, 160, 0.12);
}

.empty-state,
.account-empty {
    position: relative;
    overflow: hidden;
}

.empty-state::before,
.account-empty::before {
    content: "";
    display: block;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 999px;
    margin: 0 auto 0.9rem;
    background: radial-gradient(circle at 35% 35%, rgba(61,124,255,0.26), rgba(18,70,160,0.09));
    box-shadow: inset 0 0 0 8px rgba(255,255,255,0.72);
}

.email-shell {
    border: 1px solid var(--tvm-border);
    border-radius: 1.2rem;
    overflow: hidden;
    background: #fff;
    box-shadow: var(--tvm-shadow-soft);
}

.email-shell-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 0.9rem 1rem;
    border-bottom: 1px solid var(--tvm-border);
    background: linear-gradient(180deg, #f9fbff 0%, #f1f6ff 100%);
}

.email-shell-dots {
    display: inline-flex;
    gap: 0.4rem;
}

.email-shell-dots span {
    width: 0.72rem;
    height: 0.72rem;
    border-radius: 999px;
    background: rgba(18, 70, 160, 0.14);
}

.email-shell-label {
    color: var(--tvm-text-soft);
    font-size: 0.8rem;
    font-weight: 700;
}

.email-shell-subject {
    padding: 1rem 1.15rem 0;
}

.email-shell-body {
    padding: 1rem 1.15rem 1.15rem;
}

.email-preview-body {
    max-height: none;
    min-height: 320px;
    background: linear-gradient(180deg, #fbfdff 0%, #f5f9ff 100%);
}

.code-panel {
    border: 1px solid var(--tvm-border);
    border-radius: 1rem;
    background: #f8fbff;
    padding: 0.95rem 1rem;
}

.code-panel code {
    color: var(--tvm-primary-dark);
    word-break: break-all;
}

.checkout-hero {
    position: relative;
    overflow: hidden;
}

.checkout-hero::after {
    content: "";
    position: absolute;
    right: -4rem;
    top: -4rem;
    width: 12rem;
    height: 12rem;
    background: radial-gradient(circle, rgba(61,124,255,0.2), transparent 70%);
}

.checkout-summary-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.9rem;
}

.checkout-summary-item {
    border: 1px solid rgba(18,70,160,0.1);
    background: rgba(247,250,255,0.82);
    border-radius: 1rem;
    padding: 0.9rem 1rem;
}

.checkout-summary-item span {
    display: block;
    color: var(--tvm-text-soft);
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 700;
    margin-bottom: 0.25rem;
}

.checkout-summary-item strong {
    font-size: 1rem;
    color: var(--tvm-text);
}

.invoice-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

@media (max-width: 767.98px) {
    .checkout-summary-grid {
        grid-template-columns: 1fr;
    }

    .flash-card {
        padding: 0.95rem;
    }
}


.backend-sidebar {
    position: sticky;
    top: 98px;
}

.table-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    justify-content: flex-end;
    align-items: center;
}

.table-actions > * {
    margin: 0;
}

.table-actions .btn,
.table-actions .btn-sm {
    border-radius: 0.85rem;
    min-height: 2.2rem;
    padding-inline: 0.8rem;
}

.inline-help,
.form-helper-text {
    color: var(--tvm-text-soft);
    font-size: 0.84rem;
    margin-top: 0.35rem;
}

.action-note-card {
    border: 1px dashed rgba(18, 70, 160, 0.18);
    background: linear-gradient(180deg, rgba(247, 250, 255, 0.98), rgba(255,255,255,0.98));
    border-radius: 1.1rem;
    padding: 1rem 1.05rem;
}

.action-note-title {
    font-weight: 700;
    margin-bottom: 0.25rem;
}

.confirm-modal {
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.10);
    border-radius: 1.35rem;
    box-shadow: 0 24px 60px rgba(15, 40, 75, 0.18);
    overflow: hidden;
}

.confirm-modal-kicker {
    color: var(--tvm-account-hero-outline-hover-text);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.72rem;
    font-weight: 800;
    margin-bottom: 0.2rem;
}

.confirm-modal-text {
    color: var(--tvm-text);
    line-height: 1.6;
}

.empty-state-box {
    border: 1px dashed rgba(18, 70, 160, 0.16);
    background: rgba(248, 251, 255, 0.88);
    border-radius: 1.1rem;
    padding: 1.1rem 1.2rem;
    color: var(--tvm-text-soft);
}


.admin-form-layout {
    align-items: flex-start;
}

.admin-form-main {
    display: grid;
    gap: 1.25rem;
}

.admin-form-aside {
    display: grid;
    gap: 1.25rem;
}

.form-summary-card,
.form-tip-card,
.form-sticky-actions {
    border: 1px solid var(--tvm-border);
    border-radius: 1.2rem;
    background: #fff;
    box-shadow: var(--tvm-shadow-soft);
}

.form-summary-card .card-body,
.form-tip-card .card-body,
.form-sticky-actions .card-body {
    padding: 1.15rem;
}

.form-summary-list {
    display: grid;
    gap: 0.85rem;
}

.form-summary-item {
    display: grid;
    gap: 0.18rem;
    padding-bottom: 0.85rem;
    border-bottom: 1px solid rgba(var(--tvm-primary-rgb), 0.08);
}

.form-summary-item:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.form-summary-label {
    color: var(--tvm-text-soft);
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 800;
}

.form-summary-value {
    color: var(--tvm-text);
    font-weight: 700;
}

.form-check-tile {
    border: 1px solid rgba(18, 70, 160, 0.11);
    border-radius: 1rem;
    background: linear-gradient(180deg, rgba(249,252,255,0.98), rgba(255,255,255,1));
    padding: 1rem;
    height: 100%;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.form-check-tile:hover {
    border-color: rgba(var(--tvm-primary-rgb), 0.22);
    box-shadow: 0 10px 26px rgba(15, 40, 75, 0.07);
    transform: translateY(-1px);
}

.form-check-tile .form-check-input {
    float: none;
    margin-top: 0.1rem;
}

.form-check-tile-head {
    display: flex;
    align-items: flex-start;
    gap: 0.8rem;
}

.form-muted-box {
    min-height: 46px;
    border: 1px dashed rgba(18, 70, 160, 0.14);
    border-radius: 0.95rem;
    background: rgba(248, 251, 255, 0.88);
    padding: 0.8rem 0.95rem;
    color: var(--tvm-text-soft);
    display: flex;
    align-items: center;
}

.form-sticky-actions {
    position: sticky;
    top: 98px;
}

.form-actions-stack {
    display: grid;
    gap: 0.7rem;
}

.form-inline-note {
    color: var(--tvm-text-soft);
    font-size: 0.84rem;
    margin-top: 0.35rem;
    line-height: 1.5;
}

.form-price-preview {
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.10);
    background: linear-gradient(180deg, rgba(249,252,255,0.98), rgba(244,248,255,0.98));
    border-radius: 1rem;
    padding: 0.95rem 1rem;
}

@media (max-width: 1199.98px) {
    .form-sticky-actions {
        position: static;
    }
}


.list-hero {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1.25rem;
    flex-wrap: wrap;
    margin-bottom: 1.25rem;
}

.list-hero-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.list-hero-note {
    color: var(--tvm-text-soft);
    max-width: 760px;
    margin-bottom: 0;
}

.toolbar-card {
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.2rem;
    background: linear-gradient(180deg, rgba(249,252,255,0.98), rgba(255,255,255,1));
    box-shadow: var(--tvm-shadow-soft);
}

.toolbar-card .card-body {
    padding: 1.15rem;
}

.toolbar-check {
    min-height: 44px;
    display: flex;
    align-items: center;
    padding: 0.75rem 0.95rem;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.10);
    border-radius: 1rem;
    background: rgba(248, 251, 255, 0.82);
}

.toolbar-check .form-check {
    margin: 0;
}

.metric-grid-compact {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.95rem;
    margin-bottom: 1.25rem;
}

.metric-grid-compact .stat-card,
.metric-grid-compact .card {
    min-height: 100%;
}

.metric-grid-compact .stat-note {
    margin-top: 0.35rem;
}

.table-sticky-head thead th {
    position: sticky;
    top: 0;
    z-index: 3;
    background: #f7faff;
    box-shadow: inset 0 -1px 0 rgba(18, 70, 160, 0.08);
}

.table-cell-meta {
    display: grid;
    gap: 0.18rem;
}

.table-cell-meta strong,
.table-cell-meta .fw-semibold {
    font-weight: 700;
}

.table-meta-line {
    color: var(--tvm-text-soft);
    font-size: 0.84rem;
}

.table-meta-inline {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    flex-wrap: wrap;
}

.badge-soft {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.45rem 0.7rem;
    border-radius: 999px;
    font-weight: 700;
    font-size: 0.78rem;
    line-height: 1;
}

.badge-soft-primary {
    background: rgba(var(--tvm-primary-rgb), 0.08);
    color: var(--tvm-account-hero-outline-hover-text);
}

.badge-soft-success {
    background: rgba(25, 135, 84, 0.12);
    color: #146c43;
}

.badge-soft-warning {
    background: rgba(255, 193, 7, 0.18);
    color: #8a5a00;
}

.badge-soft-danger {
    background: rgba(220, 53, 69, 0.12);
    color: #a52834;
}

.badge-soft-secondary {
    background: rgba(108, 117, 125, 0.12);
    color: #495057;
}

.empty-panel {
    border: 1px dashed rgba(18, 70, 160, 0.16);
    border-radius: 1.1rem;
    background: rgba(248, 251, 255, 0.88);
    padding: 1.4rem;
    text-align: center;
}

.empty-panel-title {
    font-weight: 700;
    margin-bottom: 0.35rem;
}

.empty-panel-text {
    color: var(--tvm-text-soft);
    margin-bottom: 0;
}

.progress-tiny {
    height: 8px;
    border-radius: 999px;
}

@media (max-width: 991.98px) {
    .metric-grid-compact {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .metric-grid-compact {
        grid-template-columns: 1fr;
    }

    .list-hero-actions {
        width: 100%;
    }

    .list-hero-actions .btn {
        flex: 1 1 auto;
    }
}


.list-toolbar-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    padding-top: 1rem;
    margin-top: 1rem;
    border-top: 1px solid rgba(18, 70, 160, 0.08);
}

.list-toolbar-meta {
    color: var(--tvm-text-soft);
    font-size: 0.9rem;
}

.filter-chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
}

.filter-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.52rem 0.8rem;
    border-radius: 999px;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.12);
    background: rgba(248, 251, 255, 0.92);
    color: var(--tvm-text);
    font-size: 0.84rem;
    line-height: 1;
}

.filter-chip strong {
    font-weight: 700;
}

.detail-metric-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.95rem;
    margin-bottom: 1.25rem;
}

.detail-panel,
.detail-sidebar-card,
.attendance-panel {
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.25rem;
    background: linear-gradient(180deg, rgba(255,255,255,1), rgba(248,251,255,0.96));
    box-shadow: var(--tvm-shadow-soft);
}

.detail-panel .card-body,
.detail-sidebar-card .card-body,
.attendance-panel .card-body {
    padding: 1.35rem;
}

.panel-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.panel-head-title {
    font-size: 1.02rem;
    font-weight: 700;
    margin: 0;
}

.panel-head-note {
    color: var(--tvm-text-soft);
    margin: 0.3rem 0 0;
    font-size: 0.92rem;
}

.detail-keyfacts {
    display: grid;
    gap: 0.9rem;
}

.detail-keyfact {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
    padding-bottom: 0.9rem;
    border-bottom: 1px solid rgba(var(--tvm-primary-rgb), 0.08);
}

.detail-keyfact:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.detail-keyfact-label {
    color: var(--tvm-text-soft);
    font-size: 0.86rem;
}

.detail-keyfact-value {
    text-align: right;
    font-weight: 700;
}

.info-list {
    display: grid;
    gap: 0.7rem;
}

.info-list-item {
    padding: 0.8rem 0.95rem;
    border-radius: 1rem;
    background: rgba(248, 251, 255, 0.92);
    border: 1px solid rgba(18, 70, 160, 0.08);
}

.info-list-item strong {
    display: block;
    font-size: 0.9rem;
    margin-bottom: 0.2rem;
}

.info-list-item span {
    color: var(--tvm-text-soft);
    font-size: 0.84rem;
}

.attendance-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.attendance-toolbar {
    display: grid;
    gap: 1rem;
    margin-bottom: 1rem;
}

.attendance-search {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.85rem;
}

.attendance-search-actions {
    display: flex;
    gap: 0.7rem;
    align-items: end;
}

.table-note-stack {
    display: grid;
    gap: 0.18rem;
}

.session-hero {
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.4rem;
    background: linear-gradient(135deg, rgba(18,70,160,0.97), rgba(37,99,235,0.92));
    color: #fff;
    padding: 1.45rem;
    box-shadow: var(--tvm-shadow-soft);
    margin-bottom: 1.25rem;
}

.session-hero::after {
    content: "";
    position: absolute;
    inset: auto -60px -60px auto;
    width: 220px;
    height: 220px;
    background: radial-gradient(circle, rgba(255,255,255,0.16), rgba(255,255,255,0));
    pointer-events: none;
}

.session-hero > * {
    position: relative;
    z-index: 1;
}

.session-hero-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.7rem;
    margin-top: 0.8rem;
}

.session-hero-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.5rem 0.75rem;
    border-radius: 999px;
    background: rgba(255,255,255,0.14);
    font-size: 0.86rem;
}

.session-hero-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.session-hero-subtitle {
    color: rgba(255,255,255,0.82);
    max-width: 820px;
    margin-bottom: 0;
}

@media (max-width: 1199.98px) {
    .detail-metric-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .attendance-search {
        grid-template-columns: 1fr;
    }

    .attendance-search-actions {
        align-items: stretch;
    }

    .attendance-search-actions .btn {
        flex: 1 1 auto;
    }
}

@media (max-width: 575.98px) {
    .detail-metric-grid {
        grid-template-columns: 1fr;
    }
}


/* v0.4.2 detail action polish */
.detail-action-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 0.9rem;
}

.detail-action-card {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    padding: 1rem 1.05rem;
    border-radius: 18px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,250,252,0.92));
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
    text-decoration: none;
    color: inherit;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.detail-action-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 30px rgba(15, 23, 42, 0.08);
    border-color: rgba(37, 99, 235, 0.18);
    color: inherit;
}

.detail-action-card-title {
    font-weight: 700;
    font-size: 0.98rem;
}

.detail-action-card-text {
    color: #64748b;
    font-size: 0.88rem;
    line-height: 1.45;
}

.detail-action-card.is-disabled {
    opacity: 0.72;
    pointer-events: none;
}

.inline-status-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 0.75rem;
}

.inline-status-tile {
    padding: 0.85rem 0.95rem;
    border-radius: 16px;
    background: rgba(248, 250, 252, 0.9);
    border: 1px solid rgba(148, 163, 184, 0.2);
}

.inline-status-label {
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #64748b;
    margin-bottom: 0.3rem;
}

.inline-status-value {
    font-size: 1rem;
    font-weight: 700;
    color: #0f172a;
}

.admin-detail-section-title {
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 0.85rem;
}

.stacked-list {
    display: grid;
    gap: 0.85rem;
}

.stacked-list-card {
    border: 1px solid rgba(148, 163, 184, 0.2);
    border-radius: 18px;
    padding: 0.95rem 1rem;
    background: rgba(255,255,255,0.9);
}

.stacked-list-meta {
    color: #64748b;
    font-size: 0.88rem;
}

.top-meta-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    margin-top: 0.9rem;
}

.top-meta-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.38rem 0.72rem;
    border-radius: 999px;
    background: rgba(255,255,255,0.7);
    border: 1px solid rgba(148, 163, 184, 0.2);
    font-size: 0.83rem;
    color: #334155;
}

.quick-note-box {
    padding: 0.95rem 1rem;
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(248,250,252,0.95), rgba(241,245,249,0.92));
    border: 1px dashed rgba(148,163,184,0.5);
    color: #475569;
    font-size: 0.92rem;
    line-height: 1.55;
}

@media (max-width: 991.98px) {
    .detail-action-grid {
        grid-template-columns: 1fr;
    }
}


.backend-shell {
    display: grid;
    grid-template-columns: minmax(280px, 320px) minmax(0, 1fr);
    gap: 1.5rem;
    align-items: start;
}

.backend-sidebar {
    position: sticky;
    top: 96px;
    align-self: start;
    background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(246,250,255,0.98) 100%);
    border: 1px solid rgba(18, 70, 160, 0.10);
    border-radius: 1.35rem;
    box-shadow: 0 18px 42px rgba(15, 40, 75, 0.08);
    overflow: hidden;
}

.backend-sidebar-head {
    padding: 1.25rem 1.25rem 1rem;
    border-bottom: 1px solid rgba(var(--tvm-primary-rgb), 0.08);
    background: linear-gradient(180deg, rgba(18, 70, 160, 0.04) 0%, rgba(61, 124, 255, 0.02) 100%);
}

.backend-sidebar-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-top: 0.9rem;
}

.backend-sidebar-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.6rem;
    border-radius: 999px;
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--tvm-primary-dark);
    background: rgba(18, 70, 160, 0.10);
}

.backend-sidebar-badge.is-soft {
    background: rgba(15, 23, 42, 0.06);
    color: var(--tvm-text-soft);
}

.backend-sidebar-body {
    padding: 1rem;
}

.backend-nav-group + .backend-nav-group {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(18, 70, 160, 0.08);
}

.backend-nav-group-head {
    margin-bottom: 0.7rem;
}

.backend-nav-group-note {
    font-size: 0.78rem;
    color: var(--tvm-text-soft);
    line-height: 1.45;
    margin-top: 0.2rem;
}

.backend-nav {
    display: grid;
    gap: 0.4rem;
}

.backend-nav-link {
    position: relative;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.8rem 0.85rem;
    border-radius: 1rem;
    color: var(--tvm-text);
    background: transparent;
    border: 1px solid transparent;
    transition: transform 0.18s ease, background 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.backend-nav-link:hover {
    transform: translateX(2px);
    background: rgba(var(--tvm-primary-rgb), 0.05);
    border-color: rgba(18, 70, 160, 0.08);
    color: var(--tvm-primary-dark);
}

.backend-nav-link.is-active {
    background: linear-gradient(180deg, rgba(18, 70, 160, 0.11) 0%, rgba(61, 124, 255, 0.08) 100%);
    border-color: rgba(18, 70, 160, 0.14);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.45);
}

.backend-nav-link-mark {
    width: 2rem;
    height: 2rem;
    flex: 0 0 2rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.75rem;
    background: rgba(var(--tvm-primary-rgb), 0.08);
    color: var(--tvm-primary-dark);
    font-size: 0.78rem;
    font-weight: 800;
}

.backend-nav-link.is-active .backend-nav-link-mark {
    background: linear-gradient(135deg, var(--tvm-primary) 0%, var(--tvm-accent) 100%);
    color: #fff;
    box-shadow: 0 10px 24px rgba(18, 70, 160, 0.22);
}

.backend-nav-link-main {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.backend-nav-link-text {
    display: block;
    font-weight: 700;
    line-height: 1.25;
}

.backend-nav-link-subtext {
    display: block;
    font-size: 0.74rem;
    color: var(--tvm-text-soft);
    line-height: 1.35;
    margin-top: 0.15rem;
}

.backend-main {
    min-width: 0;
}

.backend-workspace-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.25rem;
    padding: 1rem 1.15rem;
    border-radius: 1.2rem;
    background: rgba(255,255,255,0.78);
    border: 1px solid rgba(18, 70, 160, 0.08);
    box-shadow: 0 12px 28px rgba(15, 40, 75, 0.05);
    backdrop-filter: blur(12px);
}

.backend-workspace-kicker {
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 800;
    color: var(--tvm-text-soft);
}

.backend-workspace-title {
    font-size: 1.12rem;
    font-weight: 800;
    color: var(--tvm-text);
    margin-top: 0.15rem;
}

.backend-workspace-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.backend-workspace-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.55rem 0.9rem;
    border-radius: 999px;
    background: rgba(18, 70, 160, 0.06);
    color: var(--tvm-primary-dark);
    font-weight: 700;
}

.backend-workspace-link:hover {
    background: rgba(18, 70, 160, 0.11);
    color: var(--tvm-primary-dark);
}

@media (max-width: 991.98px) {
    .backend-shell {
        grid-template-columns: 1fr;
        gap: 1rem;
    }

    .backend-sidebar {
        position: static;
    }
}


.toolbar-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.65rem;
    flex-wrap: wrap;
}

.filter-summary {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.85rem;
    flex-wrap: wrap;
    margin-top: 0.9rem;
    padding-top: 0.9rem;
    border-top: 1px dashed rgba(18, 70, 160, 0.12);
}

.filter-summary-label {
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--tvm-text-soft);
    padding-top: 0.3rem;
}

.filter-chip-list {
    display: flex;
    gap: 0.45rem;
    flex-wrap: wrap;
}

.filter-chip,
.list-inline-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    border-radius: 999px;
    padding: 0.42rem 0.72rem;
    font-size: 0.8rem;
    font-weight: 700;
    line-height: 1;
}

.filter-chip {
    background: rgba(var(--tvm-primary-rgb), 0.08);
    color: var(--tvm-primary-dark);
    border: 1px solid rgba(18, 70, 160, 0.08);
}

.list-inline-badge {
    background: rgba(15, 40, 75, 0.05);
    color: var(--tvm-text);
    border: 1px solid rgba(15, 40, 75, 0.08);
}

.empty-state-card {
    max-width: 30rem;
    margin: 0 auto;
}

.empty-state-title {
    font-size: 1rem;
    font-weight: 800;
    color: var(--tvm-text);
    margin-bottom: 0.35rem;
}

.empty-state-text {
    color: var(--tvm-text-soft);
    font-size: 0.92rem;
}

.template-accordion-item {
    border-color: rgba(18, 70, 160, 0.08) !important;
    box-shadow: 0 12px 28px rgba(15, 40, 75, 0.04);
}

.template-editor-panel,
.template-test-panel {
    background: linear-gradient(180deg, rgba(248, 251, 255, 0.92), rgba(255, 255, 255, 0.98));
}

@media (max-width: 991.98px) {
    .toolbar-actions {
        justify-content: flex-start;
    }

    .filter-summary {
        padding-top: 0.75rem;
    }
}


.utility-insights-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 1rem;
}

.utility-insight-card {
    background: linear-gradient(180deg, rgba(255,255,255,0.96) 0%, rgba(244,248,255,0.98) 100%);
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.10);
    border-radius: 1.2rem;
    padding: 1rem 1.1rem;
    box-shadow: var(--tvm-shadow-soft);
}

.utility-insight-label {
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--tvm-text-soft);
    font-weight: 700;
    margin-bottom: 0.35rem;
}

.utility-insight-value {
    font-size: 1.45rem;
    font-weight: 800;
    letter-spacing: -0.03em;
    color: var(--tvm-text);
}

.utility-insight-text {
    margin-top: 0.25rem;
    color: var(--tvm-text-soft);
    font-size: 0.88rem;
}

.filter-summary {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
    margin-top: 1rem;
}

.filter-summary-label {
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--tvm-text-soft);
    font-weight: 700;
}

.filter-summary.is-spaced {
    margin-bottom: 1rem;
}

.editor-help-box {
    border-radius: 1rem;
    padding: 0.95rem 1rem;
    background: rgba(var(--tvm-primary-rgb), 0.05);
    border: 1px solid rgba(18, 70, 160, 0.08);
    color: var(--tvm-text-soft);
}

.inline-meta-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 0.85rem;
    align-items: center;
}

.inline-meta-list .meta-note {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.log-context-wrap {
    margin-top: 0.75rem;
    border-radius: 1rem;
    background: rgba(15, 40, 75, 0.04);
    border: 1px solid rgba(15, 40, 75, 0.06);
    overflow: hidden;
}

.log-context-head {
    padding: 0.6rem 0.9rem;
    border-bottom: 1px solid rgba(15, 40, 75, 0.06);
    font-size: 0.76rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--tvm-text-soft);
}

.log-context {
    margin: 0;
    padding: 0.9rem;
    max-height: 220px;
    overflow: auto;
    font-size: 0.78rem;
    line-height: 1.45;
    background: transparent;
}

.note-card,
.task-card,
.notice-card {
    border: 1px solid rgba(18, 70, 160, 0.08);
    background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.98) 100%);
    border-radius: 1.15rem;
    padding: 1rem 1.05rem;
    box-shadow: var(--tvm-shadow-soft);
}

.quick-edit-strip {
    margin-top: 0.9rem;
    padding-top: 0.9rem;
    border-top: 1px dashed rgba(18, 70, 160, 0.14);
}

.matrix-toolbar {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
    margin-bottom: 1.1rem;
}

.matrix-toolbar-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.matrix-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.5rem 0.8rem;
    border-radius: 999px;
    background: rgba(var(--tvm-primary-rgb), 0.08);
    color: var(--tvm-account-hero-outline-hover-text);
    font-size: 0.82rem;
    font-weight: 700;
}

.permission-matrix th:first-child,
.permission-matrix td:first-child {
    position: sticky;
    left: 0;
    background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.98) 100%);
    z-index: 1;
}

.permission-matrix thead th:first-child {
    z-index: 2;
}

@media (max-width: 991.98px) {
    .permission-matrix th:first-child,
    .permission-matrix td:first-child {
        position: static;
    }
}


.document-upload-hints {
    display: grid;
    gap: 0.8rem;
}

.document-upload-hint,
.document-row-card {
    border: 1px solid rgba(18, 70, 160, 0.08);
    background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.98) 100%);
    border-radius: 1.05rem;
    padding: 0.95rem 1rem;
    box-shadow: var(--tvm-shadow-soft);
}

.document-upload-hint strong {
    display: block;
    margin-bottom: 0.2rem;
    color: var(--tvm-text);
}

.document-upload-hint span {
    color: var(--tvm-text-soft);
    font-size: 0.9rem;
}

.permission-checkbox {
    transform: scale(1.05);
}

.permission-checkbox:checked {
    box-shadow: 0 0 0 0.2rem rgba(18, 70, 160, 0.14);
}


.page-section-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin: 0 0 1.15rem;
}

.page-section-tab {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.65rem 0.95rem;
    border-radius: 999px;
    text-decoration: none;
    border: 1px solid rgba(18, 70, 160, 0.10);
    background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(246,250,255,0.98) 100%);
    color: var(--tvm-text);
    font-size: 0.88rem;
    font-weight: 700;
    box-shadow: var(--tvm-shadow-soft);
}

.page-section-tab:hover {
    border-color: rgba(var(--tvm-primary-rgb), 0.18);
    color: var(--tvm-account-hero-outline-hover-text);
}

.context-card-grid {
    display: grid;
    gap: 0.85rem;
}

.context-info-card {
    border: 1px solid rgba(18, 70, 160, 0.08);
    background: linear-gradient(180deg, rgba(255,255,255,0.99) 0%, rgba(247,250,255,0.99) 100%);
    border-radius: 1.05rem;
    padding: 1rem 1.05rem;
    box-shadow: var(--tvm-shadow-soft);
}

.context-info-card-title {
    font-size: 0.95rem;
    font-weight: 800;
    color: var(--tvm-text);
    margin-bottom: 0.25rem;
}

.context-info-card-text {
    color: var(--tvm-text-soft);
    font-size: 0.9rem;
    line-height: 1.5;
    margin: 0;
}

.context-mini-list {
    display: grid;
    gap: 0.65rem;
    margin: 0;
}

.context-mini-row {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
    padding-bottom: 0.65rem;
    border-bottom: 1px dashed rgba(18, 70, 160, 0.12);
}

.context-mini-row:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.context-mini-label {
    color: var(--tvm-text-soft);
    font-size: 0.82rem;
    font-weight: 700;
}

.context-mini-value {
    color: var(--tvm-text);
    font-size: 0.88rem;
    font-weight: 700;
    text-align: right;
}

.email-template-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.75rem;
}

.email-history-list {
    display: grid;
    gap: 0.8rem;
}

.email-history-card {
    border: 1px solid rgba(18, 70, 160, 0.08);
    background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.98) 100%);
    border-radius: 1rem;
    padding: 0.95rem 1rem;
    box-shadow: var(--tvm-shadow-soft);
}

.email-history-top {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 0.35rem;
}

.email-history-subject {
    font-weight: 700;
    color: var(--tvm-text);
    margin-top: 0.3rem;
}

.email-preview-meta {
    display: grid;
    gap: 0.75rem;
}

.email-preview-meta-card {
    border: 1px solid rgba(18, 70, 160, 0.08);
    background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.98) 100%);
    border-radius: 1rem;
    padding: 0.9rem 1rem;
}

.email-preview-meta-card .meta-note {
    display: block;
    margin-top: 0.2rem;
}

@media (max-width: 767.98px) {
    .context-mini-row {
        flex-direction: column;
        gap: 0.2rem;
    }

    .context-mini-value {
        text-align: left;
    }
}


.page-section-tabs {
    position: sticky;
    top: 92px;
    z-index: 20;
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin-bottom: 1.5rem;
    padding: 0.85rem 0.95rem;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.78);
    backdrop-filter: blur(14px);
    box-shadow: var(--tvm-shadow-soft);
}

.page-section-tab {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.58rem 0.95rem;
    border-radius: 999px;
    font-size: 0.86rem;
    font-weight: 700;
    color: var(--tvm-text-soft);
    background: rgba(var(--tvm-primary-rgb), 0.05);
    transition: all 0.18s ease;
}

.page-section-tab:hover,
.page-section-tab.is-active {
    color: #fff;
    background: linear-gradient(135deg, var(--tvm-primary) 0%, var(--tvm-accent) 100%);
    box-shadow: 0 12px 24px rgba(18, 70, 160, 0.2);
}

.sticky-stack {
    position: sticky;
    top: 160px;
}

.document-card-grid,
.quick-guidance-grid,
.template-support-grid {
    display: grid;
    gap: 1rem;
}

.document-row-card {
    border: 1px solid rgba(18, 70, 160, 0.08);
    background: linear-gradient(180deg, rgba(255,255,255,0.99) 0%, rgba(248,251,255,0.98) 100%);
    border-radius: 1.1rem;
    padding: 1rem 1.05rem;
    box-shadow: var(--tvm-shadow-soft);
}

.document-row-top {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

.document-title {
    font-size: 1rem;
    font-weight: 800;
    color: var(--tvm-text);
}

.document-subline,
.document-description,
.meta-note {
    color: var(--tvm-text-soft);
}

.document-description {
    margin-top: 0.3rem;
    line-height: 1.55;
}

.document-chip-list,
.inline-chip-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.7rem;
}

.document-chip,
.inline-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    background: rgba(18, 70, 160, 0.07);
    color: var(--tvm-primary-dark);
    font-size: 0.78rem;
    font-weight: 700;
}

.upload-dropzone {
    border: 1px dashed rgba(18, 70, 160, 0.22);
    border-radius: 1rem;
    background: linear-gradient(180deg, rgba(250,252,255,0.98) 0%, rgba(244,248,255,0.98) 100%);
    padding: 1rem;
}

.upload-dropzone-title {
    font-size: 0.95rem;
    font-weight: 800;
    margin-bottom: 0.2rem;
    color: var(--tvm-text);
}

.upload-dropzone-text {
    color: var(--tvm-text-soft);
    font-size: 0.88rem;
    margin: 0;
}

.template-accordion-item .accordion-button {
    background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(247,250,255,0.98) 100%);
    font-weight: 800;
    color: var(--tvm-text);
    box-shadow: none;
}

.template-accordion-item .accordion-button:not(.collapsed) {
    background: linear-gradient(180deg, rgba(18,70,160,0.08) 0%, rgba(61,124,255,0.08) 100%);
    color: var(--tvm-primary-dark);
}

.template-accordion-item .accordion-body {
    background: rgba(255, 255, 255, 0.75);
}

.template-editor-panel,
.template-test-panel,
.helper-panel {
    border-radius: 1rem;
    border: 1px solid rgba(18, 70, 160, 0.08);
    background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.98) 100%);
    box-shadow: var(--tvm-shadow-soft);
}

.template-test-panel {
    padding: 1rem;
}

.email-history-subject {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.email-history-excerpt {
    margin-top: 0.55rem;
    color: var(--tvm-text-soft);
    font-size: 0.9rem;
    line-height: 1.55;
}

.email-shell {
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.10);
    border-radius: 1.15rem;
    overflow: hidden;
    box-shadow: var(--tvm-shadow-soft);
}

.email-shell-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 0.85rem 1rem;
    background: linear-gradient(180deg, rgba(248,251,255,0.98) 0%, rgba(241,246,255,0.98) 100%);
    border-bottom: 1px solid rgba(var(--tvm-primary-rgb), 0.08);
}

.email-shell-dots {
    display: inline-flex;
    gap: 0.35rem;
}

.email-shell-dots span {
    width: 0.68rem;
    height: 0.68rem;
    border-radius: 999px;
    background: rgba(18, 70, 160, 0.16);
}

.email-shell-label {
    font-size: 0.8rem;
    color: var(--tvm-text-soft);
    font-weight: 700;
}

.email-shell-subject,
.email-shell-body {
    padding: 1rem;
    background: rgba(255,255,255,0.96);
}

.email-shell-subject {
    border-bottom: 1px solid rgba(var(--tvm-primary-rgb), 0.08);
}

.email-preview-body {
    margin: 0.5rem 0 0;
    white-space: pre-wrap;
    word-break: break-word;
    font-family: inherit;
    color: var(--tvm-text);
    background: transparent;
}

@media (max-width: 991.98px) {
    .page-section-tabs,
    .sticky-stack {
        position: static;
        top: auto;
    }
}

@media (max-width: 767.98px) {
    .page-section-tabs {
        padding: 0.7rem;
        gap: 0.5rem;
    }

    .page-section-tab {
        width: 100%;
        justify-content: center;
    }

    .document-row-top {
        flex-direction: column;
    }
}


.page-intro-meta-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
}

.page-intro-meta-card {
    min-width: 132px;
    padding: 0.8rem 0.95rem;
    border-radius: 1rem;
    border: 1px solid rgba(18, 70, 160, 0.08);
    background: linear-gradient(180deg, rgba(255,255,255,0.96) 0%, rgba(246,250,255,0.96) 100%);
    box-shadow: var(--tvm-shadow-soft);
}

.page-intro-meta-card span {
    display: block;
    font-size: 0.78rem;
    color: var(--tvm-text-soft);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.page-intro-meta-card strong {
    display: block;
    margin-top: 0.2rem;
    font-size: 1.05rem;
    color: var(--tvm-text);
}

.settings-section-anchored {
    scroll-margin-top: 150px;
}

.settings-side-card,
.settings-save-card {
    border-radius: 1.2rem;
}

.account-shell .page-section-tabs,
.public-hero + .page-section-tabs,
.page-section-tabs.mb-4 {
    margin-bottom: 1.4rem !important;
}

.account-shell .sticky-stack .account-panel,
.public-side-stack.sticky-stack .public-section-card {
    box-shadow: var(--tvm-shadow-soft);
}

@media (max-width: 991.98px) {
    .page-intro-meta-grid {
        width: 100%;
    }

    .page-intro-meta-card {
        flex: 1 1 140px;
    }
}

@media (max-width: 767.98px) {
    .page-intro-meta-card {
        width: 100%;
    }
}


.color-setting-group .form-control-color {
    width: 54px;
    min-width: 54px;
    padding: 0.35rem;
    cursor: pointer;
}

.design-preview-card {
    padding: 1.15rem 1.2rem;
    border-radius: 1.1rem;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.10);
    background: linear-gradient(135deg, rgba(var(--tvm-primary-rgb), 0.06), rgba(var(--tvm-accent-rgb), 0.06));
    box-shadow: var(--tvm-shadow-soft);
}

.design-preview-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    border-radius: 999px;
    padding: 0.35rem 0.7rem;
    background: rgba(var(--tvm-primary-rgb), 0.10);
    color: var(--tvm-account-hero-outline-hover-text);
    font-size: 0.76rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 0.75rem;
}

.design-preview-title {
    font-size: 1rem;
    font-weight: 800;
    color: var(--tvm-text);
    margin-bottom: 0.35rem;
}

.design-preview-text {
    color: var(--tvm-text-soft);
}

.design-preview-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 0.65rem 0.95rem;
    background: rgba(var(--tvm-primary-rgb), 0.10);
    color: var(--tvm-account-hero-outline-hover-text);
    font-weight: 700;
}


.register-form-section {
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.12);
    background: linear-gradient(135deg, rgba(255,255,255,0.98), rgba(var(--tvm-primary-rgb), 0.045));
    border-radius: var(--tvm-radius-lg);
    padding: 1.25rem;
    box-shadow: 0 16px 35px rgba(15, 23, 42, 0.06);
}

.register-form-section-header {
    display: flex;
    align-items: flex-start;
    gap: 0.9rem;
    padding-bottom: 1rem;
    margin-bottom: 1rem;
    border-bottom: 1px solid rgba(var(--tvm-primary-rgb), 0.10);
}

.register-form-section-icon {
    width: 2.7rem;
    height: 2.7rem;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    color: var(--tvm-account-hero-outline-hover-text);
    background: rgba(var(--tvm-primary-rgb), 0.10);
}

.register-form-section-kicker {
    margin-bottom: 0.15rem;
    color: var(--tvm-account-hero-outline-hover-text);
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.register-form-section-title {
    margin: 0;
    color: var(--tvm-text);
    font-size: 1.12rem;
    font-weight: 800;
}

.register-form-section-text {
    margin: 0.25rem 0 0;
    color: var(--tvm-text-soft);
    font-size: 0.9rem;
}

@media (max-width: 575.98px) {
    .register-form-section {
        padding: 1rem;
    }

    .register-form-section-header {
        gap: 0.75rem;
    }
}

.container {
    max-width: var(--tvm-container-max);
}

.page-shell > .container {
    padding-top: var(--tvm-page-padding-y) !important;
    padding-bottom: var(--tvm-page-padding-y) !important;
}

.card,
.card-soft,
.page-intro-card,
.settings-section,
.quick-note-box,
.context-info-card,
.detail-card,
.detail-card-side,
.empty-state-card,
.design-preview-card,
.design-preview-mini-card,
.flash-card,
.modern-dropdown,
.table-modern,
.booking-hero,
.profile-summary-card,
.summary-panel {
    border-radius: var(--tvm-radius-lg) !important;
}

.btn,
.form-control,
.form-select,
.input-group-text,
.navbar .nav-link,
.page-section-tab,
.design-preview-chip,
.badge,
.alert,
.user-avatar,
.brand-mark {
    border-radius: var(--tvm-radius) !important;
}

.btn-sm,
.btn-group-sm > .btn,
.form-control-sm,
.form-select-sm {
    border-radius: var(--tvm-radius-sm) !important;
}

.card,
.card-soft,
.page-intro-card,
.design-preview-card,
.design-preview-mini-card,
.flash-card,
.topbar,
.modern-dropdown {
    box-shadow: var(--tvm-shadow-soft) !important;
}

.card .card-body,
.card-soft .card-body,
.settings-save-card .card-body,
.settings-side-card .card-body {
    padding: var(--tvm-card-padding) !important;
}

.topbar {
    box-shadow: var(--tvm-shadow-soft);
}

.design-preview-mini-card {
    background: linear-gradient(180deg, rgba(255,255,255,0.96) 0%, rgba(var(--tvm-primary-rgb), 0.04) 100%);
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.10);
    padding: var(--tvm-card-padding);
}

.design-preview-mini-title {
    font-weight: 700;
    margin-bottom: 0.35rem;
    color: var(--tvm-text);
}

.design-preview-mini-text {
    color: var(--tvm-text-soft);
    font-size: 0.95rem;
    line-height: 1.5;
}


.public-calendar-preview-card {
    overflow: hidden;
}

.calendar-preview-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 1rem;
}

.calendar-preview-day {
    border: 1px solid var(--tvm-border);
    border-radius: var(--tvm-radius);
    background: var(--tvm-surface);
    padding: 1rem;
    min-height: 100%;
}

.calendar-preview-day.is-today {
    border-color: rgba(var(--tvm-primary-rgb), 0.4);
    box-shadow: inset 0 0 0 1px rgba(var(--tvm-primary-rgb), 0.14);
}

.calendar-preview-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 0.75rem;
    margin-bottom: 0.85rem;
}

.calendar-preview-weekday {
    font-size: 0.84rem;
    color: var(--tvm-text-soft);
}

.calendar-preview-session {
    padding: 0.85rem;
    border-radius: var(--tvm-radius-sm);
    background: rgba(var(--tvm-primary-rgb), 0.05);
}

@media (max-width: 1399.98px) {
    .calendar-preview-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .calendar-preview-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .calendar-preview-grid {
        grid-template-columns: 1fr;
    }
}


.calendar-filter-form {
    padding: 1rem;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.08);
    border-radius: var(--tvm-radius);
    background: rgba(255, 255, 255, 0.72);
}

.calendar-filter-check {
    min-height: 38px;
    display: flex;
    align-items: center;
}

.calendar-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
}

.calendar-toolbar-title {
    font-weight: 700;
    font-size: 1.1rem;
}

.calendar-month-grid-wrap {
    overflow-x: auto;
}

.calendar-month-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(140px, 1fr));
    gap: 0.75rem;
    min-width: 980px;
}

.calendar-month-grid + .calendar-month-grid {
    margin-top: 0.75rem;
}

.calendar-month-grid-head div {
    padding: 0.75rem 0.9rem;
    border-radius: var(--tvm-radius-sm);
    background: rgba(var(--tvm-primary-rgb), 0.08);
    color: var(--tvm-text);
    font-weight: 700;
    text-align: center;
}

.calendar-day-cell {
    min-height: 160px;
    border: 1px solid var(--tvm-border);
    border-radius: var(--tvm-radius);
    background: var(--tvm-surface);
    padding: 0.85rem;
}

.calendar-day-cell.is-muted {
    opacity: 0.55;
    background: var(--tvm-surface-soft);
}

.calendar-day-cell.is-today {
    border-color: rgba(var(--tvm-primary-rgb), 0.45);
    box-shadow: inset 0 0 0 1px rgba(var(--tvm-primary-rgb), 0.18);
}

.calendar-day-number {
    font-weight: 700;
    margin-bottom: 0.65rem;
}

.calendar-day-sessions {
    display: grid;
    gap: 0.45rem;
}

.calendar-day-session {
    display: grid;
    gap: 0.15rem;
    padding: 0.5rem 0.6rem;
    border-radius: 0.8rem;
    text-decoration: none;
    color: var(--tvm-text);
    background: rgba(var(--tvm-primary-rgb), 0.06);
}

.calendar-day-session:hover {
    background: rgba(var(--tvm-primary-rgb), 0.11);
    color: var(--tvm-account-hero-outline-hover-text);
}

.calendar-day-session,
.calendar-week-session {
    border: 1px solid transparent;
    border-left-width: 4px;
}

.calendar-day-session strong {
    font-size: 0.8rem;
}

.calendar-day-session span {
    font-size: 0.82rem;
    line-height: 1.25;
}

.calendar-more,
.calendar-day-empty {
    font-size: 0.82rem;
    color: var(--tvm-text-soft);
}

@media (max-width: 991.98px) {
    .calendar-toolbar {
        align-items: stretch;
    }

    .calendar-toolbar > * {
        width: 100%;
    }
}


.calendar-day-list {
    display: none;
}

.calendar-day-list-item {
    border: 1px solid var(--tvm-border);
    border-radius: var(--tvm-radius);
    background: var(--tvm-surface);
    padding: 0.9rem;
}

.calendar-day-list + .calendar-day-list-item {
    margin-top: 0.75rem;
}

.calendar-day-list-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
    font-size: 0.92rem;
}

@media (max-width: 991.98px) {
    .calendar-month-grid {
        grid-template-columns: repeat(7, minmax(120px, 1fr));
        min-width: 840px;
    }
}

@media (max-width: 767.98px) {
    .calendar-month-grid-wrap {
        display: none;
    }

    .calendar-day-list {
        display: grid;
        gap: 0.85rem;
    }

    .calendar-preview-session {
        padding: 0.85rem;
    }
}

.calendar-view-switch {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.calendar-week-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.9rem;
}

.calendar-week-column {
    border: 1px solid var(--tvm-border);
    border-radius: var(--tvm-radius);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(248, 251, 255, 0.98) 100%);
    padding: 0.9rem;
    min-height: 220px;
}

.calendar-week-column.is-today {
    border-color: rgba(var(--tvm-primary-rgb), 0.4);
    box-shadow: inset 0 0 0 1px rgba(var(--tvm-primary-rgb), 0.15);
}

.calendar-week-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.85rem;
}

.calendar-weekday {
    font-weight: 800;
    color: var(--tvm-text);
}

.calendar-weekdate {
    font-size: 0.85rem;
    color: var(--tvm-text-soft);
}

.calendar-week-sessions {
    display: grid;
    gap: 0.6rem;
}

.calendar-week-session {
    display: block;
    border: 1px solid var(--tvm-border);
    border-left-width: 4px;
    border-radius: 0.95rem;
    background: rgba(255, 255, 255, 0.9);
    padding: 0.7rem 0.8rem;
    color: var(--tvm-text);
    text-decoration: none;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.calendar-week-session:hover {
    transform: translateY(-1px);
    box-shadow: var(--tvm-shadow-soft);
    color: var(--tvm-account-hero-outline-hover-text);
}

.calendar-week-session-time {
    font-size: 0.78rem;
    font-weight: 800;
    margin-bottom: 0.18rem;
}

.calendar-week-session-title {
    font-size: 0.9rem;
    font-weight: 700;
    line-height: 1.25;
}

.calendar-week-session-meta {
    font-size: 0.78rem;
    color: var(--tvm-text-soft);
    margin-top: 0.2rem;
}

.calendar-category-pill {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 0.28rem 0.6rem;
    border: 1px solid currentColor;
    font-size: 0.74rem;
    font-weight: 700;
}

.calendar-tone-1 {
    border-color: rgba(18, 70, 160, 0.18);
    background: rgba(18, 70, 160, 0.06);
    color: #1246a0;
}

.calendar-tone-2 {
    border-color: rgba(0, 129, 93, 0.18);
    background: rgba(0, 129, 93, 0.08);
    color: #007d5b;
}

.calendar-tone-3 {
    border-color: rgba(167, 87, 10, 0.18);
    background: rgba(167, 87, 10, 0.08);
    color: #9a5607;
}

.calendar-tone-4 {
    border-color: rgba(120, 78, 196, 0.18);
    background: rgba(120, 78, 196, 0.08);
    color: #784ec4;
}

.calendar-tone-5 {
    border-color: rgba(180, 42, 82, 0.18);
    background: rgba(180, 42, 82, 0.08);
    color: #b42a52;
}

.public-session-card.calendar-tone-1,
.public-session-card.calendar-tone-2,
.public-session-card.calendar-tone-3,
.public-session-card.calendar-tone-4,
.public-session-card.calendar-tone-5,
.public-session-card.calendar-tone-6 {
    background-image: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.98) 100%);
}

.calendar-tone-6 {
    border-color: rgba(16, 111, 143, 0.18);
    background: rgba(16, 111, 143, 0.08);
    color: #106f8f;
}

.calendar-day-session.calendar-tone-1,
.calendar-day-session.calendar-tone-2,
.calendar-day-session.calendar-tone-3,
.calendar-day-session.calendar-tone-4,
.calendar-day-session.calendar-tone-5,
.calendar-day-session.calendar-tone-6,
.calendar-week-session.calendar-tone-1,
.calendar-week-session.calendar-tone-2,
.calendar-week-session.calendar-tone-3,
.calendar-week-session.calendar-tone-4,
.calendar-week-session.calendar-tone-5,
.calendar-week-session.calendar-tone-6 {
    background: rgba(255, 255, 255, 0.95);
}

.calendar-day-session.calendar-tone-1,
.calendar-week-session.calendar-tone-1 { border-left-color: #1246a0; }
.calendar-day-session.calendar-tone-2,
.calendar-week-session.calendar-tone-2 { border-left-color: #007d5b; }
.calendar-day-session.calendar-tone-3,
.calendar-week-session.calendar-tone-3 { border-left-color: #9a5607; }
.calendar-day-session.calendar-tone-4,
.calendar-week-session.calendar-tone-4 { border-left-color: #784ec4; }
.calendar-day-session.calendar-tone-5,
.calendar-week-session.calendar-tone-5 { border-left-color: #b42a52; }
.calendar-day-session.calendar-tone-6,
.calendar-week-session.calendar-tone-6 { border-left-color: #106f8f; }

.calendar-day-list-mobile {
    display: none;
}

@media (max-width: 1199.98px) {
    .calendar-week-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .calendar-week-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .calendar-day-list-mobile {
        display: grid;
        gap: 0.85rem;
    }

    .calendar-week-grid {
        grid-template-columns: 1fr;
    }
}


.btn-xs {
    padding: 0.22rem 0.55rem;
    font-size: 0.72rem;
    border-radius: 0.6rem;
    line-height: 1.2;
}

.calendar-day-session,
.calendar-week-session {
    display: block;
}

.calendar-session-mainlink {
    display: block;
    color: inherit;
}

.calendar-session-mainlink:hover {
    color: inherit;
}

.calendar-session-actions {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 0.35rem;
    margin-top: 0.45rem;
}

.calendar-session-actions form {
    margin: 0;
}

.calendar-session-actions .badge {
    font-size: 0.68rem;
}

.calendar-day-session strong,
.calendar-session-mainlink strong {
    display: block;
}

/* Kalender public */
.kpcal-shell{display:grid;gap:1.25rem}
.kpcal-card{background:#fff;border:1px solid var(--tvm-border,#dbe3ef);border-radius:1rem;box-shadow:0 10px 30px rgba(15,23,42,.05)}
.kpcal-card-body{padding:1.25rem}
.kpcal-hero{display:grid;grid-template-columns:minmax(0,1fr) 290px;gap:1rem;align-items:start}
.kpcal-stats{display:grid;gap:.65rem}
.kpcal-stat{display:flex;justify-content:space-between;gap:.75rem;padding:.75rem .9rem;border:1px solid var(--tvm-border,#dbe3ef);border-radius:.85rem;background:#f8fbff;font-size:.92rem}
.kpcal-stat span{color:#64748b}
.kpcal-switch,.kpcal-toolbar,.kpcal-filter-grid,.kpcal-day-head,.kpcal-session-foot,.kpcal-day-detail-head{display:flex;gap:.75rem}.kpcal-switch,.kpcal-toolbar{align-items:center;justify-content:space-between;flex-wrap:wrap}.kpcal-switch-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.kpcal-toolbar-title{font-weight:800;font-size:1rem;color:#10233f}.kpcal-filter-grid{flex-wrap:wrap;align-items:end}.kpcal-filter-item{flex:1 1 220px}.kpcal-filter-actions{max-width:330px}.kpcal-filter-check{display:flex;align-items:center;min-height:38px;margin-bottom:.5rem}
.kpcal-month-head{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:.65rem;margin-bottom:.65rem}.kpcal-month-head>div{padding:.7rem .5rem;text-align:center;background:#f8fbff;border:1px solid var(--tvm-border,#dbe3ef);border-radius:.85rem;font-size:.88rem;font-weight:700;color:#4b5d78}
.kpcal-month-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:.65rem}
.kpcal-day-card,.kpcal-week-column,.kpcal-preview-day{position:relative;background:#fff;border:1px solid var(--tvm-border,#dbe3ef);border-radius:1rem;box-shadow:0 8px 24px rgba(15,23,42,.04)}
.kpcal-day-card{padding:.8rem;min-height:220px}.kpcal-day-card.is-muted{background:#f8fafc;opacity:.72}.kpcal-day-card.is-today,.kpcal-week-column.is-today,.kpcal-preview-day.is-today{border-color:rgba(220,38,38,.35);box-shadow:inset 0 0 0 1px rgba(220,38,38,.12),0 8px 24px rgba(15,23,42,.04)}
.kpcal-day-head{justify-content:space-between;align-items:flex-start;margin-bottom:.7rem}.kpcal-day-number{font-weight:800;font-size:1.05rem;color:#10233f}.kpcal-day-weekday{font-size:.77rem;color:#64748b}.kpcal-day-empty{font-size:.84rem;color:#64748b}
.kpcal-day-detail-toggle,.kpcal-day-detail-close{border:1px solid var(--tvm-border,#dbe3ef);background:#f8fbff;color:#10233f;border-radius:999px;padding:.2rem .65rem;font-size:.74rem;font-weight:700}.kpcal-day-detail-close{padding:.05rem .55rem;font-size:1rem;line-height:1}
.kpcal-day-sessions,.kpcal-week-sessions,.kpcal-session-list,.kpcal-day-detail-list,.kpcal-preview-list{display:grid;gap:.55rem}
.kpcal-session-chip{display:grid;gap:.4rem;padding:.55rem .65rem;border:1px solid #e5e7eb;border-left-width:4px;border-radius:.85rem;background:linear-gradient(180deg,#fff 0%,#fbfdff 100%)}
.kpcal-session-link{color:inherit;text-decoration:none}.kpcal-session-link:hover{color:inherit}.kpcal-session-time{font-size:.76rem;font-weight:800;color:#4b5d78}.kpcal-session-title{font-size:.84rem;font-weight:700;line-height:1.25;color:#10233f}.kpcal-session-foot{justify-content:space-between;align-items:center;flex-wrap:wrap}
.kpcal-more{font-size:.8rem;color:#64748b}
.kpcal-week-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:.8rem}.kpcal-week-column{padding:.85rem;min-height:250px}.kpcal-week-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.75rem}.kpcal-week-head strong{display:block;font-size:.95rem;color:#10233f}.kpcal-week-head span{display:block;font-size:.8rem;color:#64748b}
.kpcal-day-detail-panel{position:absolute;left:.6rem;right:.6rem;top:3.3rem;z-index:20;border:1px solid rgba(16,35,63,.12);border-radius:1rem;background:#fff;box-shadow:0 24px 54px rgba(15,23,42,.18);padding:.85rem}.kpcal-day-detail-head{justify-content:space-between;align-items:center;margin-bottom:.75rem}.kpcal-detail-session{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.85rem;padding:.75rem;border:1px solid #e5e7eb;border-left-width:4px;border-radius:.85rem;background:#fcfdff}.kpcal-detail-main{min-width:0}.kpcal-detail-time{font-size:.78rem;font-weight:800;color:#4b5d78;margin-bottom:.2rem}.kpcal-detail-title a{font-weight:700;color:#10233f;text-decoration:none}.kpcal-detail-side{display:flex;align-items:flex-end;justify-content:center;flex-direction:column;gap:.45rem}
.kpcal-session-row{border:1px solid var(--tvm-border,#dbe3ef);border-left-width:4px;border-radius:1rem;background:#fff;padding:1rem;box-shadow:0 8px 24px rgba(15,23,42,.04)}.kpcal-session-row-grid{display:grid;grid-template-columns:220px minmax(0,1fr) 220px 180px;gap:1rem;align-items:start}
.kpcal-category-pill,.kpcal-capacity-pill{display:inline-flex;align-items:center;padding:.3rem .62rem;border-radius:999px;font-size:.74rem;font-weight:700;line-height:1.2}.kpcal-category-pill{border:1px solid currentColor}.kpcal-capacity-pill{border:1px solid transparent}
.kpcal-capacity-free{background:#e9f7ef;color:#166534}.kpcal-capacity-tight{background:#fff4db;color:#a16207}.kpcal-capacity-full{background:#fde8e8;color:#b91c1c}
.kpcal-tone-1{border-left-color:#1246a0}.kpcal-tone-2{border-left-color:#007d5b}.kpcal-tone-3{border-left-color:#9a5607}.kpcal-tone-4{border-left-color:#784ec4}.kpcal-tone-5{border-left-color:#b42a52}.kpcal-tone-6{border-left-color:#106f8f}.kpcal-category-pill.kpcal-tone-1{color:#1246a0}.kpcal-category-pill.kpcal-tone-2{color:#007d5b}.kpcal-category-pill.kpcal-tone-3{color:#9a5607}.kpcal-category-pill.kpcal-tone-4{color:#784ec4}.kpcal-category-pill.kpcal-tone-5{color:#b42a52}.kpcal-category-pill.kpcal-tone-6{color:#106f8f}
.kpcal-preview-card .card-body{padding:1.15rem}.kpcal-preview-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:.85rem}.kpcal-preview-day{padding:.85rem}.kpcal-preview-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.75rem}.kpcal-preview-weekday{font-size:.78rem;color:#64748b}.kpcal-preview-count{font-size:.72rem;font-weight:700;color:#64748b;background:#f8fbff;border:1px solid var(--tvm-border,#dbe3ef);padding:.2rem .5rem;border-radius:999px}.kpcal-preview-session{padding:.75rem;border-radius:.85rem;background:#f8fbff;border:1px solid var(--tvm-border,#dbe3ef)}.kpcal-preview-time{font-size:.77rem;font-weight:800;color:#4b5d78;margin-bottom:.2rem}
@media (max-width:1399.98px){.kpcal-preview-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media (max-width:1199.98px){.kpcal-hero{grid-template-columns:1fr}.kpcal-month-grid,.kpcal-month-head{grid-template-columns:repeat(4,minmax(0,1fr))}.kpcal-week-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.kpcal-session-row-grid{grid-template-columns:180px minmax(0,1fr) 180px 160px}}
@media (max-width:991.98px){.kpcal-month-grid,.kpcal-month-head,.kpcal-week-grid,.kpcal-preview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.kpcal-session-row-grid{grid-template-columns:1fr 1fr}.kpcal-detail-session{grid-template-columns:1fr}}
@media (max-width:767.98px){.kpcal-month-grid,.kpcal-month-head,.kpcal-week-grid,.kpcal-preview-grid{grid-template-columns:1fr}.kpcal-session-row-grid{grid-template-columns:1fr}.kpcal-filter-actions{max-width:none}.kpcal-day-card,.kpcal-week-column,.kpcal-preview-day{min-height:auto}.kpcal-day-detail-panel{position:static;left:auto;right:auto;top:auto;margin-top:.75rem;box-shadow:0 12px 30px rgba(15,23,42,.12)}.kpcal-detail-side{align-items:flex-start}}

/* Stable public calendar */
.kp-calendar-shell {
    display: block;
}

.kp-calendar-hero-card {
    overflow: hidden;
}

.kp-calendar-stats {
    display: grid;
    gap: 0.75rem;
}

.kp-calendar-stat {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 0.9rem 1rem;
    border: 1px solid var(--tvm-border);
    border-radius: 1rem;
    background: var(--tvm-surface-soft);
}

.kp-calendar-stat span {
    color: var(--tvm-text-soft);
    font-size: 0.92rem;
}

.kp-calendar-stat strong {
    color: var(--tvm-text);
    text-align: right;
}

.kp-calendar-legend-dot {
    width: 0.7rem;
    height: 0.7rem;
    display: inline-block;
    border-radius: 999px;
    margin-left: 0.4rem;
    margin-right: -0.1rem;
}

.kp-calendar-legend-dot.is-free { background: #16a34a; }
.kp-calendar-legend-dot.is-tight { background: #d97706; }
.kp-calendar-legend-dot.is-full { background: #dc2626; }

.kp-month-weekdays,
.kp-month-week {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.85rem;
}

.kp-month-view {
    display: grid;
    gap: 0.85rem;
}

.kp-month-weekdays div {
    padding: 0.75rem 0.5rem;
    border-radius: 0.95rem;
    border: 1px solid var(--tvm-border);
    background: var(--tvm-surface-soft);
    text-align: center;
    font-weight: 700;
    color: var(--tvm-text-soft);
}

.kp-month-day {
    border: 1px solid var(--tvm-border);
    border-radius: 1rem;
    min-height: 245px;
    box-shadow: none;
}

.kp-month-day.is-muted {
    background: #f8fafc;
    opacity: 0.86;
}

.kp-month-day.is-today,
.kp-week-day-today {
    border-color: rgba(var(--tvm-primary-rgb), 0.32);
    box-shadow: inset 0 0 0 1px rgba(var(--tvm-primary-rgb), 0.12);
}

.kp-month-day-number {
    font-size: 1.2rem;
    font-weight: 700;
    line-height: 1;
}

.kp-day-session-stack,
.kp-detail-session-list {
    display: grid;
    gap: 0.7rem;
}

.kp-day-chip,
.kp-detail-session {
    border: 1px solid var(--tvm-border);
    border-left: 4px solid var(--tvm-primary);
    border-radius: 0.95rem;
    background: #fbfdff;
    padding: 0.8rem 0.9rem;
}

.kp-detail-session-large {
    padding: 1rem;
}

.kp-day-chip.kpcal-tone-1,
.kp-detail-session.kpcal-tone-1 { border-left-color: #1246a0; }
.kp-day-chip.kpcal-tone-2,
.kp-detail-session.kpcal-tone-2 { border-left-color: #007d5b; }
.kp-day-chip.kpcal-tone-3,
.kp-detail-session.kpcal-tone-3 { border-left-color: #9a5607; }
.kp-day-chip.kpcal-tone-4,
.kp-detail-session.kpcal-tone-4 { border-left-color: #784ec4; }
.kp-day-chip.kpcal-tone-5,
.kp-detail-session.kpcal-tone-5 { border-left-color: #b42a52; }
.kp-day-chip.kpcal-tone-6,
.kp-detail-session.kpcal-tone-6 { border-left-color: #106f8f; }

.kp-day-chip.is-success {
    background: linear-gradient(180deg, #ffffff 0%, #f7fcf8 100%);
}

.kp-day-chip.is-warning {
    background: linear-gradient(180deg, #ffffff 0%, #fffaf2 100%);
}

.kp-day-chip.is-danger {
    background: linear-gradient(180deg, #ffffff 0%, #fff5f5 100%);
}

.kp-home-preview-day {
    border: 1px solid var(--tvm-border);
    border-radius: 1rem;
    box-shadow: none;
}

.kp-home-preview-day.is-today {
    border-color: rgba(var(--tvm-primary-rgb), 0.32);
    box-shadow: inset 0 0 0 1px rgba(var(--tvm-primary-rgb), 0.12);
}

.calendar-status-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.32rem 0.68rem;
    border-radius: 999px;
    font-size: 0.74rem;
    font-weight: 700;
    line-height: 1.2;
}

.calendar-status-success {
    background: #e9f7ef;
    color: #166534;
}

.calendar-status-warning {
    background: #fff4db;
    color: #a16207;
}

.calendar-status-danger {
    background: #fde8e8;
    color: #b91c1c;
}

@media (max-width: 1399.98px) {
    .kp-month-weekdays,
    .kp-month-week {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .kp-month-weekdays,
    .kp-month-week {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .kp-month-day {
        min-height: auto;
    }
}

@media (max-width: 767.98px) {
    .kp-month-weekdays,
    .kp-month-week {
        grid-template-columns: 1fr;
    }
}

/* Kursverwaltung: kompaktere und ruhigere Übersicht */
.course-overview-page .card-body {
    overflow: hidden;
}

.course-list-hero {
    padding-bottom: 1rem;
    border-bottom: 1px solid rgba(18, 70, 160, 0.08);
}

.course-metric-row {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.85rem;
    margin: 1.2rem 0;
}

.course-metric-card {
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1rem;
    background: linear-gradient(180deg, rgba(249, 252, 255, 0.96), rgba(255, 255, 255, 1));
    padding: 0.95rem 1rem;
    box-shadow: 0 12px 28px rgba(18, 70, 160, 0.05);
}

.course-metric-card span,
.course-metric-card small {
    display: block;
    color: var(--tvm-text-soft);
}

.course-metric-card span {
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.course-metric-card strong {
    display: block;
    margin: 0.18rem 0 0.05rem;
    color: var(--tvm-danger);
    font-size: clamp(1.55rem, 3vw, 2rem);
    line-height: 1;
    font-weight: 850;
}

.course-metric-card.is-success strong {
    color: #146c43;
}

.course-metric-card.is-muted strong {
    color: #495057;
}

.course-metric-card.is-info strong {
    color: var(--tvm-account-hero-outline-hover-text);
}

.course-overview-toolbar {
    display: grid;
    grid-template-columns: minmax(260px, 1fr) minmax(130px, 170px) minmax(170px, 230px) auto;
    gap: 0.85rem;
    align-items: end;
    padding: 1rem;
    margin-bottom: 1rem;
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1.15rem;
    background: rgba(248, 251, 255, 0.82);
}

.course-overview-toolbar .form-label {
    color: var(--tvm-text-soft);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-bottom: 0.35rem;
}

.course-toolbar-result {
    min-width: 112px;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.09);
    border-radius: 0.95rem;
    background: #fff;
    padding: 0.65rem 0.85rem;
    text-align: center;
}

.course-toolbar-result span,
.course-toolbar-result small {
    display: block;
}

.course-toolbar-result span {
    font-size: 1.25rem;
    line-height: 1;
    font-weight: 850;
    color: var(--tvm-danger);
}

.course-toolbar-result small {
    margin-top: 0.15rem;
    color: var(--tvm-text-soft);
    font-size: 0.76rem;
}

.course-table-wrap {
    overflow: visible;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.15rem;
    background: #fff;
}

.course-admin-table {
    table-layout: fixed;
}

.course-admin-table thead th {
    background: rgba(18, 70, 160, 0.035);
    padding: 0.9rem 1rem;
}

.course-admin-table tbody td {
    padding: 1rem;
    border-top: 1px solid rgba(18, 70, 160, 0.08);
}

.course-admin-table th:nth-child(1) {
    width: 34%;
}

.course-admin-table th:nth-child(2) {
    width: 22%;
}

.course-admin-table th:nth-child(3) {
    width: 27%;
}

.course-admin-table th:nth-child(4) {
    width: 17%;
}

.course-title-main {
    font-weight: 800;
    line-height: 1.35;
}

.course-title-meta,
.course-muted {
    color: var(--tvm-text-soft);
    font-size: 0.84rem;
}

.course-title-tags {
    display: flex;
    gap: 0.4rem;
    flex-wrap: wrap;
    margin-top: 0.45rem;
}

.course-title-tags span {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    background: rgba(18, 70, 160, 0.06);
    color: var(--tvm-text-soft);
    padding: 0.28rem 0.55rem;
    font-size: 0.75rem;
    font-weight: 700;
}

.course-price-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem;
}

.course-price-grid div {
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 0.85rem;
    background: rgba(248, 251, 255, 0.74);
    padding: 0.58rem 0.7rem;
}

.course-price-grid span,
.course-price-grid strong {
    display: block;
}

.course-price-grid span {
    color: var(--tvm-text-soft);
    font-size: 0.74rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.course-price-grid strong {
    margin-top: 0.1rem;
    font-size: 0.95rem;
}

.course-next-date {
    font-weight: 800;
}

.course-trainer-line {
    margin-top: 0.55rem;
    font-size: 0.9rem;
}

.course-status-action {
    display: inline-flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.55rem;
}

.course-status-action .btn {
    min-width: 104px;
}

@media (max-width: 1199.98px) {
    .course-overview-toolbar {
        grid-template-columns: minmax(240px, 1fr) 160px 200px;
    }

    .course-toolbar-result {
        grid-column: 1 / -1;
        justify-self: stretch;
    }
}

@media (max-width: 991.98px) {
    .course-metric-row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .course-overview-toolbar {
        grid-template-columns: 1fr;
    }

    .course-admin-table,
    .course-admin-table thead,
    .course-admin-table tbody,
    .course-admin-table tr,
    .course-admin-table th,
    .course-admin-table td {
        display: block;
        width: 100% !important;
    }

    .course-admin-table thead {
        display: none;
    }

    .course-admin-table tbody tr {
        border-top: 1px solid rgba(18, 70, 160, 0.08);
        padding: 0.95rem;
    }

    .course-admin-table tbody tr:first-child {
        border-top: 0;
    }

    .course-admin-table tbody td {
        border: 0;
        padding: 0.35rem 0;
    }

    .course-action-cell {
        text-align: left !important;
    }

    .course-status-action {
        width: 100%;
        align-items: stretch;
        flex-direction: row;
        justify-content: space-between;
        flex-wrap: wrap;
        margin-top: 0.5rem;
    }
}

@media (max-width: 575.98px) {
    .course-metric-row {
        grid-template-columns: 1fr;
    }

    .course-price-grid {
        grid-template-columns: 1fr;
    }
}

/* v0.6.17 korrigiert: Preisboxen in der Kursverwaltung nur kompakter darstellen.
   Bestehende Datei bleibt vollständig erhalten, es werden nur diese Overrides ergänzt. */
.course-overview-page .course-price-grid {
    grid-template-columns: repeat(2, max-content);
    gap: 0.45rem;
    align-items: start;
}

.course-overview-page .course-price-grid div {
    min-width: 74px;
    max-width: 88px;
    padding: 0.42rem 0.52rem;
    border-radius: 0.72rem;
}

.course-overview-page .course-price-grid span {
    font-size: 0.66rem;
    line-height: 1.05;
    letter-spacing: 0.025em;
    white-space: nowrap;
}

.course-overview-page .course-price-grid strong {
    margin-top: 0.08rem;
    font-size: 0.86rem;
    line-height: 1.2;
    white-space: nowrap;
}

@media (max-width: 575.98px) {
    .course-overview-page .course-price-grid {
        grid-template-columns: repeat(2, max-content);
    }
}

/* v0.6.18 Terminverwaltung: kompaktere und ruhigere Übersicht */
.session-overview-page .sticky-panel {
    top: 98px;
}

.session-admin-hero {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
    padding: 1.25rem 1.35rem;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.25rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.96) 100%);
    box-shadow: var(--tvm-shadow-soft);
}

.session-hero-actions {
    display: flex;
    gap: 0.65rem;
    flex-wrap: wrap;
}

.session-create-card .card-body {
    overflow: hidden;
}

.session-repeat-box {
    padding: 0.95rem;
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1rem;
    background: rgba(248, 251, 255, 0.72);
}

.session-repeat-note {
    margin-top: 0.65rem;
    color: var(--tvm-text-soft);
    font-size: 0.84rem;
    line-height: 1.45;
}

.session-metric-row {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.85rem;
    margin-bottom: 1rem;
}

.session-metric-card {
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1rem;
    background: linear-gradient(180deg, rgba(249, 252, 255, 0.96), rgba(255, 255, 255, 1));
    padding: 0.95rem 1rem;
    box-shadow: 0 12px 28px rgba(18, 70, 160, 0.05);
}

.session-metric-card span,
.session-metric-card small {
    display: block;
    color: var(--tvm-text-soft);
}

.session-metric-card span {
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.session-metric-card strong {
    display: block;
    margin: 0.18rem 0 0.05rem;
    color: var(--tvm-danger);
    font-size: clamp(1.55rem, 3vw, 2rem);
    line-height: 1;
    font-weight: 850;
}

.session-metric-card.is-success strong {
    color: #146c43;
}

.session-metric-card.is-warning strong {
    color: #a16207;
}

.session-metric-card.is-info strong {
    color: var(--tvm-account-hero-outline-hover-text);
}

.session-filter-card {
    padding: 1rem;
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1.15rem;
    background: rgba(248, 251, 255, 0.82);
    box-shadow: var(--tvm-shadow-soft);
}

.session-filter-grid {
    display: grid;
    grid-template-columns: minmax(220px, 1.1fr) minmax(140px, 0.7fr) minmax(180px, 1fr) auto;
    gap: 0.85rem;
    align-items: end;
}

.session-filter-grid .form-label {
    color: var(--tvm-text-soft);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-bottom: 0.35rem;
}

.session-filter-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.5rem;
    min-width: 116px;
}

.session-list-card {
    overflow: hidden;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.15rem;
    background: #fff;
    box-shadow: var(--tvm-shadow-soft);
}

.session-list-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
    padding: 1.15rem 1.25rem;
    border-bottom: 1px solid rgba(18, 70, 160, 0.08);
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,251,255,0.92));
}

.session-list-count {
    padding: 0.45rem 0.75rem;
    border-radius: 999px;
    background: rgba(18, 70, 160, 0.06);
    color: var(--tvm-primary-dark);
    font-size: 0.82rem;
    font-weight: 800;
}

.session-table-wrap {
    overflow: visible;
}

.session-admin-table {
    table-layout: fixed;
}

.session-admin-table thead th {
    background: rgba(18, 70, 160, 0.035);
    padding: 0.85rem 1rem;
}

.session-admin-table tbody td {
    padding: 0.95rem 1rem;
    border-top: 1px solid rgba(18, 70, 160, 0.08);
    vertical-align: middle;
}

.session-admin-table th:nth-child(1) { width: 33%; }
.session-admin-table th:nth-child(2) { width: 24%; }
.session-admin-table th:nth-child(3) { width: 20%; }
.session-admin-table th:nth-child(4) { width: 23%; }

.session-title-main,
.session-date-main {
    font-weight: 800;
    line-height: 1.35;
}

.session-muted {
    color: var(--tvm-text-soft);
    font-size: 0.84rem;
}

.session-capacity-grid {
    display: grid;
    grid-template-columns: repeat(2, max-content);
    gap: 0.45rem;
}

.session-capacity-grid div {
    min-width: 74px;
    padding: 0.42rem 0.52rem;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 0.72rem;
    background: rgba(248, 251, 255, 0.74);
}

.session-capacity-grid span,
.session-capacity-grid strong {
    display: block;
}

.session-capacity-grid span {
    color: var(--tvm-text-soft);
    font-size: 0.66rem;
    line-height: 1.05;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.025em;
    white-space: nowrap;
}

.session-capacity-grid strong {
    margin-top: 0.08rem;
    font-size: 0.9rem;
    line-height: 1.2;
}

.session-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.45rem;
    flex-wrap: wrap;
}

.session-actions form {
    margin: 0;
}

.session-actions .btn {
    min-height: 2.05rem;
    padding: 0.4rem 0.65rem;
    font-size: 0.78rem;
}

@media (max-width: 1199.98px) {
    .session-filter-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .session-filter-actions {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        grid-column: 1 / -1;
    }
}

@media (max-width: 991.98px) {
    .session-metric-row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .session-admin-table,
    .session-admin-table thead,
    .session-admin-table tbody,
    .session-admin-table tr,
    .session-admin-table th,
    .session-admin-table td {
        display: block;
        width: 100% !important;
    }

    .session-admin-table thead {
        display: none;
    }

    .session-admin-table tbody tr {
        border-top: 1px solid rgba(18, 70, 160, 0.08);
        padding: 0.95rem;
    }

    .session-admin-table tbody tr:first-child {
        border-top: 0;
    }

    .session-admin-table tbody td {
        border: 0;
        padding: 0.35rem 0;
    }

    .session-action-cell {
        text-align: left !important;
    }

    .session-actions {
        justify-content: flex-start;
        margin-top: 0.4rem;
    }
}

@media (max-width: 575.98px) {
    .session-admin-hero,
    .session-list-head {
        padding: 1rem;
    }

    .session-hero-actions,
    .session-hero-actions .btn,
    .session-filter-actions .btn,
    .session-filter-actions a {
        width: 100%;
    }

    .session-filter-grid,
    .session-filter-actions,
    .session-metric-row {
        grid-template-columns: 1fr;
    }

    .session-capacity-grid {
        grid-template-columns: repeat(2, max-content);
    }
}

/* v0.6.19 Terminverwaltung: Anlageformular auf eigene Seite ausgelagert */
.session-overview-page .session-metric-row-wide {
    margin-bottom: 1.15rem;
}

.session-overview-page .session-filter-card-wide {
    padding: 1.05rem 1.1rem;
}

.session-overview-page .session-filter-grid-wide {
    grid-template-columns: minmax(260px, 1.35fr) minmax(170px, 0.75fr) minmax(220px, 1fr) auto;
}

.session-list-card-wide .session-admin-table-wide th:nth-child(1) { width: 35%; }
.session-list-card-wide .session-admin-table-wide th:nth-child(2) { width: 22%; }
.session-list-card-wide .session-admin-table-wide th:nth-child(3) { width: 18%; }
.session-list-card-wide .session-admin-table-wide th:nth-child(4) { width: 25%; }

.session-actions-compact {
    gap: 0.4rem;
}

.session-actions-compact .btn {
    padding: 0.36rem 0.6rem;
    font-size: 0.76rem;
}

.session-capacity-grid-compact div {
    min-width: 68px;
}

.session-create-page .session-create-card {
    overflow: hidden;
}

.session-create-page .session-repeat-box-wide {
    padding: 1rem;
}

@media (max-width: 1199.98px) {
    .session-overview-page .session-filter-grid-wide {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .session-overview-page .session-filter-grid-wide {
        grid-template-columns: 1fr;
    }
}

/* Flatrateverwaltung: kompakte, professionelle Übersicht */
.subscription-overview-page .card-body {
    overflow: hidden;
}

.subscription-list-hero {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
    padding-bottom: 1rem;
    border-bottom: 1px solid rgba(18, 70, 160, 0.08);
}

.subscription-hero-actions {
    display: flex;
    gap: 0.65rem;
    flex-wrap: wrap;
    align-items: center;
}

.subscription-hero-actions form {
    margin: 0;
}

.subscription-metric-row {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.85rem;
    margin: 1.2rem 0;
}

.subscription-metric-card {
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1rem;
    background: linear-gradient(180deg, rgba(249, 252, 255, 0.96), rgba(255, 255, 255, 1));
    padding: 0.95rem 1rem;
    box-shadow: 0 12px 28px rgba(18, 70, 160, 0.05);
}

.subscription-metric-card span,
.subscription-metric-card small {
    display: block;
    color: var(--tvm-text-soft);
}

.subscription-metric-card span {
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.subscription-metric-card strong {
    display: block;
    margin: 0.18rem 0 0.05rem;
    color: var(--tvm-text);
    font-size: clamp(1.55rem, 3vw, 2rem);
    line-height: 1;
    font-weight: 850;
}

.subscription-metric-card.is-success strong {
    color: #146c43;
}

.subscription-metric-card.is-warning strong {
    color: #99621a;
}

.subscription-metric-card.is-muted strong {
    color: #495057;
}

.subscription-metric-card.is-danger strong {
    color: var(--tvm-danger, #dc3545);
}

.subscription-filter-card {
    display: grid;
    grid-template-columns: minmax(260px, 1fr) minmax(160px, 220px) auto;
    gap: 0.85rem;
    align-items: end;
    padding: 1rem;
    margin-bottom: 1rem;
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1.15rem;
    background: rgba(248, 251, 255, 0.82);
}

.subscription-filter-card .form-label {
    color: var(--tvm-text-soft);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-bottom: 0.35rem;
}

.subscription-filter-actions {
    display: flex;
    gap: 0.55rem;
    align-items: center;
}

.subscription-filter-actions .btn {
    min-width: 112px;
}

.subscription-table-card {
    overflow: hidden;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.15rem;
    background: #fff;
}

.subscription-table-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    padding: 1rem 1.15rem;
    border-bottom: 1px solid rgba(18, 70, 160, 0.08);
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,251,255,0.98));
}

.subscription-table-head h2 {
    margin: 0;
    font-size: 1.25rem;
    font-weight: 800;
    letter-spacing: -0.03em;
}

.subscription-admin-table {
    table-layout: fixed;
    margin-bottom: 0;
}

.subscription-admin-table thead th {
    background: rgba(18, 70, 160, 0.035);
    padding: 0.85rem 1rem;
}

.subscription-admin-table tbody td {
    padding: 1rem;
    border-top: 1px solid rgba(18, 70, 160, 0.08);
    vertical-align: middle;
}

.subscription-admin-table th:nth-child(1) { width: 34%; }
.subscription-admin-table th:nth-child(2) { width: 24%; }
.subscription-admin-table th:nth-child(3) { width: 27%; }
.subscription-admin-table th:nth-child(4) { width: 15%; }

.subscription-user-block,
.subscription-status-block,
.subscription-payment-action {
    display: grid;
    gap: 0.35rem;
}

.subscription-user-name,
.subscription-course-title,
.subscription-period-line {
    font-weight: 800;
    line-height: 1.35;
}

.subscription-user-mail,
.subscription-period-line,
.subscription-due-note,
.subscription-chip-row span,
.subscription-payment-box span,
.subscription-payment-box small {
    font-size: 0.82rem;
}

.subscription-user-mail,
.subscription-period-line,
.subscription-chip-row span,
.subscription-payment-box span,
.subscription-payment-box small {
    color: var(--tvm-text-soft);
}

.subscription-chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin-top: 0.2rem;
}

.subscription-chip-row span {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    background: rgba(18, 70, 160, 0.06);
    padding: 0.28rem 0.55rem;
    font-weight: 700;
}

.subscription-due-note {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    border-radius: 999px;
    padding: 0.28rem 0.6rem;
    background: rgba(153, 98, 26, 0.12);
    color: #99621a;
    font-weight: 800;
}

.subscription-payment-action {
    justify-items: end;
}

.subscription-payment-box {
    min-width: 88px;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 0.9rem;
    background: rgba(248, 251, 255, 0.82);
    padding: 0.55rem 0.7rem;
    text-align: center;
}

.subscription-payment-box strong {
    display: block;
    font-size: 1.05rem;
    line-height: 1.1;
}

@media (max-width: 1199.98px) {
    .subscription-filter-card {
        grid-template-columns: minmax(240px, 1fr) 200px;
    }

    .subscription-filter-actions {
        grid-column: 1 / -1;
    }
}

@media (max-width: 991.98px) {
    .subscription-metric-row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .subscription-filter-card {
        grid-template-columns: 1fr;
    }

    .subscription-filter-actions,
    .subscription-filter-actions .btn {
        width: 100%;
    }

    .subscription-admin-table,
    .subscription-admin-table thead,
    .subscription-admin-table tbody,
    .subscription-admin-table tr,
    .subscription-admin-table th,
    .subscription-admin-table td {
        display: block;
        width: 100% !important;
    }

    .subscription-admin-table thead {
        display: none;
    }

    .subscription-admin-table tbody tr {
        border-top: 1px solid rgba(18, 70, 160, 0.08);
        padding: 0.95rem;
    }

    .subscription-admin-table tbody tr:first-child {
        border-top: 0;
    }

    .subscription-admin-table tbody td {
        border: 0;
        padding: 0.35rem 0;
    }

    .subscription-payment-action {
        justify-items: stretch;
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: center;
        margin-top: 0.45rem;
    }

    .subscription-payment-box {
        text-align: left;
    }
}

@media (max-width: 575.98px) {
    .subscription-metric-row {
        grid-template-columns: 1fr;
    }

    .subscription-hero-actions,
    .subscription-hero-actions .btn,
    .subscription-hero-actions form,
    .subscription-hero-actions form .btn,
    .subscription-filter-actions {
        width: 100%;
    }

    .subscription-payment-action {
        grid-template-columns: 1fr;
    }
}

/* Nutzerverwaltung: kompaktere und ruhigere Übersicht */
.user-admin-page .card-body {
    overflow: hidden;
}

.user-admin-hero .card-body {
    padding: 1.35rem 1.45rem !important;
}

.user-admin-hero-main {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
}

.user-admin-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.55rem;
    flex-wrap: wrap;
    max-width: 620px;
}

.user-admin-metrics,
.user-admin-alerts {
    display: grid;
    gap: 0.85rem;
}

.user-admin-metrics {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.user-admin-alerts {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.user-admin-metric-card,
.user-admin-alert-card {
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1rem;
    background: linear-gradient(180deg, rgba(249, 252, 255, 0.96), rgba(255, 255, 255, 1));
    box-shadow: 0 12px 28px rgba(18, 70, 160, 0.05);
    padding: 0.95rem 1rem;
}

.user-admin-alert-card {
    border-style: dashed;
    background: rgba(248, 251, 255, 0.82);
}

.user-admin-metric-card span,
.user-admin-alert-card span,
.user-admin-metric-card small,
.user-admin-alert-card small {
    display: block;
    color: var(--tvm-text-soft);
}

.user-admin-metric-card span,
.user-admin-alert-card span {
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.user-admin-metric-card strong,
.user-admin-alert-card strong {
    display: block;
    margin: 0.18rem 0 0.05rem;
    color: var(--tvm-danger);
    font-size: clamp(1.45rem, 3vw, 1.9rem);
    line-height: 1;
    font-weight: 850;
}

.user-admin-metric-card.is-success strong {
    color: #146c43;
}

.user-admin-metric-card.is-muted strong {
    color: #495057;
}

.user-admin-filter-card .card-body {
    padding: 1rem !important;
}

.user-admin-filter-grid {
    display: grid;
    grid-template-columns: minmax(260px, 1fr) minmax(130px, 170px) minmax(130px, 170px) minmax(150px, 190px) auto;
    gap: 0.85rem;
    align-items: end;
}

.user-admin-filter-grid .form-label {
    color: var(--tvm-text-soft);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-bottom: 0.35rem;
}

.user-admin-filter-actions {
    display: flex;
    gap: 0.55rem;
}

.user-admin-filter-actions .btn {
    min-width: 92px;
}

.user-admin-list-card {
    overflow: hidden;
}

.user-admin-list-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
    padding: 1.25rem 1.35rem 1rem;
    border-bottom: 1px solid rgba(18, 70, 160, 0.08);
}

.user-admin-list-head h2 {
    margin: 0;
    font-size: 1.35rem;
    font-weight: 850;
    letter-spacing: -0.03em;
}

.user-admin-table-wrap {
    overflow-x: visible;
}

.user-admin-table {
    table-layout: fixed;
}

.user-admin-table thead th {
    background: rgba(18, 70, 160, 0.035);
    color: var(--tvm-text-soft);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    padding: 0.85rem 1rem;
}

.user-admin-table tbody td {
    padding: 1rem;
    border-top: 1px solid rgba(18, 70, 160, 0.08);
    vertical-align: middle;
}

.user-admin-table th:nth-child(1) { width: 30%; }
.user-admin-table th:nth-child(2) { width: 13%; }
.user-admin-table th:nth-child(3) { width: 24%; }
.user-admin-table th:nth-child(4) { width: 17%; }
.user-admin-table th:nth-child(5) { width: 16%; }

.user-cell-main,
.user-cell-stack {
    display: grid;
    gap: 0.18rem;
}

.user-cell-main strong {
    font-weight: 800;
    line-height: 1.25;
}

.user-cell-main span,
.user-subscription-link {
    color: var(--tvm-text-soft);
    font-size: 0.84rem;
}

.user-subscription-link {
    font-weight: 700;
}

.user-mini-stat-row {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.user-mini-stat-row span {
    min-width: 72px;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 0.8rem;
    background: rgba(248, 251, 255, 0.78);
    padding: 0.48rem 0.6rem;
}

.user-mini-stat-row strong,
.user-mini-stat-row small {
    display: block;
}

.user-mini-stat-row strong {
    line-height: 1;
    font-size: 1rem;
}

.user-mini-stat-row small {
    margin-top: 0.16rem;
    color: var(--tvm-text-soft);
    font-size: 0.72rem;
}

@media (max-width: 1199.98px) {
    .user-admin-metrics {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .user-admin-filter-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .user-admin-filter-search,
    .user-admin-filter-actions {
        grid-column: 1 / -1;
    }

    .user-admin-filter-actions .btn {
        flex: 1 1 auto;
    }
}

@media (max-width: 991.98px) {
    .user-admin-metrics,
    .user-admin-alerts {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .user-admin-table,
    .user-admin-table thead,
    .user-admin-table tbody,
    .user-admin-table tr,
    .user-admin-table th,
    .user-admin-table td {
        display: block;
        width: 100% !important;
    }

    .user-admin-table thead {
        display: none;
    }

    .user-admin-table tbody tr {
        border-top: 1px solid rgba(18, 70, 160, 0.08);
        padding: 0.95rem;
    }

    .user-admin-table tbody tr:first-child {
        border-top: 0;
    }

    .user-admin-table tbody td {
        border: 0;
        padding: 0.35rem 0;
    }

    .user-action-cell {
        text-align: left !important;
    }

    .user-action-cell .table-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 575.98px) {
    .user-admin-actions,
    .user-admin-filter-actions,
    .user-action-cell .table-actions {
        width: 100%;
    }

    .user-admin-actions .btn,
    .user-admin-filter-actions .btn,
    .user-action-cell .table-actions .btn {
        flex: 1 1 auto;
    }

    .user-admin-metrics,
    .user-admin-alerts,
    .user-admin-filter-grid {
        grid-template-columns: 1fr;
    }
}

/* v0.6.22 Nutzerverwaltung: Kopfbereich und Übersicht ruhiger */
.user-admin-hero {
    background: linear-gradient(180deg, rgba(255,255,255,0.99), rgba(248,251,255,0.96));
}

.user-admin-hero .card-body {
    padding: 1.15rem 1.25rem !important;
}

.user-admin-hero-main {
    align-items: center;
    gap: 1.25rem;
}

.user-admin-hero-main .admin-page-title {
    margin-bottom: 0.25rem;
}

.user-admin-actions {
    flex-direction: column;
    align-items: flex-end;
    gap: 0.65rem;
    max-width: 100%;
}

.user-admin-secondary-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.user-admin-primary-action {
    min-width: 150px;
    box-shadow: 0 12px 26px rgba(220, 38, 38, 0.16);
}

.user-admin-metrics {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 0.75rem;
    margin-bottom: 0.85rem !important;
}

.user-admin-alerts {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.user-admin-metric-card,
.user-admin-alert-card {
    padding: 0.78rem 0.9rem;
    min-height: 94px;
}

.user-admin-alert-card {
    border-style: solid;
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,251,255,0.92));
}

.user-admin-metric-card strong,
.user-admin-alert-card strong {
    font-size: clamp(1.35rem, 2.2vw, 1.7rem);
}

.user-admin-filter-card {
    margin-top: 0.95rem;
}

.user-admin-filter-card .card-body {
    padding: 0.9rem !important;
}

.user-admin-filter-grid {
    grid-template-columns: minmax(280px, 1fr) 150px 150px 170px auto;
    gap: 0.75rem;
}

.user-admin-filter-actions .btn {
    min-width: 86px;
}

.user-admin-list-card .card-body.p-0 {
    overflow: hidden;
}

.user-admin-list-head {
    padding: 1rem 1.15rem 0.85rem;
}

.user-admin-table thead th,
.user-admin-table tbody td {
    padding-left: 0.8rem;
    padding-right: 0.8rem;
}

.user-mini-stat-row span {
    min-width: 64px;
    padding: 0.42rem 0.52rem;
}

@media (max-width: 1199.98px) {
    .user-admin-hero-main {
        align-items: flex-start;
    }

    .user-admin-actions {
        align-items: flex-start;
        width: 100%;
    }

    .user-admin-secondary-actions {
        justify-content: flex-start;
    }

    .user-admin-metrics {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .user-admin-filter-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .user-admin-secondary-actions,
    .user-admin-secondary-actions .btn,
    .user-admin-primary-action {
        width: 100%;
    }

    .user-admin-metrics,
    .user-admin-alerts {
        grid-template-columns: 1fr;
    }
}

/* Gutscheine: ruhigere Admin-Übersicht */
.discount-admin-page {
    display: grid;
    gap: 1.25rem;
}

.discount-hero .card-body,
.discount-list-card .card-body,
.discount-form-card .card-body {
    padding: 1.35rem !important;
}

.discount-hero-inner,
.discount-section-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
}

.discount-kicker {
    color: var(--tvm-danger, #d10000);
    font-size: 0.74rem;
    font-weight: 850;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-bottom: 0.35rem;
}

.discount-title,
.discount-section-title {
    color: var(--tvm-text);
    font-weight: 850;
    letter-spacing: -0.035em;
    margin: 0;
}

.discount-title {
    font-size: clamp(1.45rem, 2.2vw, 1.95rem);
}

.discount-section-title {
    font-size: clamp(1.2rem, 1.8vw, 1.55rem);
}

.discount-subtitle,
.discount-section-text,
.discount-note,
.discount-empty-text,
.discount-tip-text {
    color: var(--tvm-text-soft);
    line-height: 1.55;
}

.discount-hero-actions,
.discount-form-actions,
.discount-code-actions {
    display: flex;
    gap: 0.65rem;
    flex-wrap: wrap;
}

.discount-metric-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.9rem;
}

.discount-metric-card {
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1.1rem;
    background: linear-gradient(180deg, rgba(249, 252, 255, 0.98), rgba(255, 255, 255, 1));
    box-shadow: var(--tvm-shadow-soft);
    padding: 1rem 1.1rem;
}

.discount-metric-card span,
.discount-metric-card small,
.discount-fact span,
.discount-fact small {
    display: block;
    color: var(--tvm-text-soft);
}

.discount-metric-card span,
.discount-fact span {
    font-size: 0.74rem;
    font-weight: 850;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.discount-metric-card strong {
    display: block;
    margin: 0.18rem 0 0.05rem;
    color: var(--tvm-danger, #d10000);
    font-size: clamp(1.5rem, 3vw, 2rem);
    line-height: 1;
    font-weight: 850;
}

.discount-metric-card.is-success strong {
    color: #146c43;
}

.discount-metric-card.is-muted strong {
    color: #495057;
}

.discount-metric-card.is-info strong {
    color: var(--tvm-account-hero-outline-hover-text, var(--tvm-primary-dark));
}

.discount-code-list {
    display: grid;
    gap: 0.8rem;
    margin-top: 1rem;
}

.discount-code-row {
    display: grid;
    grid-template-columns: minmax(180px, 1.1fr) minmax(420px, 2.2fr) auto;
    gap: 1rem;
    align-items: center;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.05rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,251,255,0.98));
    padding: 0.95rem 1rem;
}

.discount-code-main {
    min-width: 0;
}

.discount-code-pill {
    display: inline-flex;
    max-width: 100%;
    align-items: center;
    border-radius: 999px;
    background: rgba(var(--tvm-primary-rgb), 0.08);
    color: var(--tvm-primary-dark);
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, Liberation Mono, monospace;
    font-size: 0.86rem;
    font-weight: 850;
    padding: 0.42rem 0.7rem;
    word-break: break-all;
}

.discount-note {
    font-size: 0.86rem;
    margin-top: 0.45rem;
}

.discount-code-facts {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.65rem;
}

.discount-fact {
    min-height: 70px;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 0.95rem;
    background: rgba(255,255,255,0.86);
    padding: 0.72rem 0.8rem;
}

.discount-fact strong {
    display: block;
    color: var(--tvm-text);
    font-size: 0.95rem;
    margin-top: 0.2rem;
}

.discount-fact .status-pill {
    margin-top: 0.35rem;
}

.discount-code-actions {
    justify-content: flex-end;
}

.discount-code-actions form {
    margin: 0;
}

.discount-empty-state {
    margin-top: 1rem;
    border: 1px dashed rgba(18, 70, 160, 0.16);
    border-radius: 1.05rem;
    background: rgba(248, 251, 255, 0.88);
    padding: 1.35rem;
}

.discount-empty-title,
.discount-tip-title {
    color: var(--tvm-text);
    font-weight: 800;
    margin-bottom: 0.25rem;
}

.discount-form-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(260px, 320px);
    gap: 1rem;
    align-items: start;
    margin-top: 1rem;
}

.discount-form-main,
.discount-form-side,
.discount-tip-box,
.discount-active-box {
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.05rem;
    background: rgba(248, 251, 255, 0.72);
    padding: 1rem;
}

.discount-form-side {
    display: grid;
    gap: 0.8rem;
    background: transparent;
    border: 0;
    padding: 0;
}

.discount-active-box {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    cursor: pointer;
}

.discount-active-box strong,
.discount-active-box small {
    display: block;
}

.discount-active-box small {
    color: var(--tvm-text-soft);
    margin-top: 0.2rem;
}

@media (max-width: 1199.98px) {
    .discount-code-row {
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .discount-code-actions {
        justify-content: flex-start;
    }

    .discount-form-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 991.98px) {
    .discount-metric-grid,
    .discount-code-facts {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .discount-metric-grid,
    .discount-code-facts {
        grid-template-columns: 1fr;
    }

    .discount-hero-actions .btn,
    .discount-form-actions .btn,
    .discount-code-actions .btn,
    .discount-code-actions form,
    .discount-code-actions form .btn {
        width: 100%;
    }
}

/* E-Mail- und Benachrichtigungscenter: kompakte Verwaltungsansicht */
.email-center-page .card-soft {
    overflow: hidden;
}

.email-center-hero {
    background: linear-gradient(135deg, rgba(255,255,255,0.99), rgba(248,251,255,0.98));
}

.email-center-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 470px);
    gap: 1.25rem;
    align-items: center;
}

.email-center-stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.65rem;
}

.email-center-stat {
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1rem;
    background: #fff;
    padding: 0.85rem 0.9rem;
    box-shadow: var(--tvm-shadow-soft);
}

.email-center-stat span {
    display: block;
    color: var(--tvm-text-soft);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.email-center-stat strong {
    display: block;
    margin-top: 0.2rem;
    color: var(--tvm-primary-dark);
    font-size: 1.55rem;
    line-height: 1;
    font-weight: 850;
}

.email-center-stat.is-success strong { color: #137a58; }
.email-center-stat.is-danger strong { color: #b03a48; }
.email-center-stat.is-muted strong { color: #607286; }

.email-center-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    padding: 0.8rem;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.15rem;
    background: rgba(255, 255, 255, 0.86);
    box-shadow: var(--tvm-shadow-soft);
}

.email-center-nav-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.45rem;
    padding: 0.55rem 0.95rem;
    border-radius: 0.95rem;
    background: rgba(18, 70, 160, 0.05);
    color: var(--tvm-text);
    font-weight: 800;
}

.email-center-nav-link:hover,
.email-center-nav-link.is-active {
    background: linear-gradient(135deg, #dc0000, #ff4d4d);
    color: #fff;
    box-shadow: 0 12px 24px rgba(220, 0, 0, 0.16);
}

.email-info-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
    gap: 1rem;
}

.email-info-card {
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.2rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,251,255,0.98));
    box-shadow: var(--tvm-shadow-soft);
    padding: 1.15rem;
}

.email-info-title {
    font-size: 1rem;
    font-weight: 850;
    color: var(--tvm-text);
}

.email-info-text {
    margin: 0.25rem 0 0;
    color: var(--tvm-text-soft);
    font-size: 0.92rem;
}

.email-status-list {
    display: grid;
    gap: 0.65rem;
}

.email-status-list > div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.85rem;
    padding-bottom: 0.65rem;
    border-bottom: 1px dashed rgba(18, 70, 160, 0.1);
}

.email-status-list > div:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.email-status-list strong {
    color: var(--tvm-text);
    font-size: 0.85rem;
    text-align: right;
}

.email-filter-grid {
    display: grid;
    grid-template-columns: minmax(150px, 180px) minmax(170px, 230px) minmax(260px, 1fr) auto;
    gap: 0.85rem;
    align-items: end;
}

.email-filter-grid .form-label {
    color: var(--tvm-text-soft);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.email-filter-actions {
    display: flex;
    gap: 0.55rem;
}

.email-template-list {
    display: grid;
    gap: 0.85rem;
}

.email-template-item {
    border: 1px solid rgba(18, 70, 160, 0.08) !important;
    border-radius: 1.1rem !important;
    overflow: hidden;
    box-shadow: var(--tvm-shadow-soft);
}

.email-template-button {
    gap: 1rem;
    padding: 1rem 1.15rem;
    background: linear-gradient(180deg, rgba(248,251,255,0.98), rgba(255,255,255,0.98));
}

.email-template-button:not(.collapsed) {
    background: linear-gradient(180deg, rgba(18,70,160,0.08), rgba(61,124,255,0.05));
    color: var(--tvm-text);
}

.email-template-button-main {
    display: grid;
    gap: 0.18rem;
    min-width: 0;
}

.email-template-button-main strong {
    font-size: 1rem;
    color: var(--tvm-text);
}

.email-template-button-main small {
    color: var(--tvm-text-soft);
    font-weight: 800;
    word-break: break-word;
}

.email-template-button-meta {
    margin-left: auto;
    margin-right: 1.75rem;
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    background: rgba(18, 70, 160, 0.07);
    color: var(--tvm-text-soft);
    font-size: 0.76rem;
    font-weight: 800;
}

.email-template-body {
    background: rgba(255,255,255,0.72);
}

.email-template-edit-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(240px, 310px);
    gap: 1rem;
}

.email-template-editor,
.email-test-box,
.email-check-box {
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1rem;
    background: rgba(255,255,255,0.96);
    padding: 1rem;
}

.email-template-editor textarea {
    min-height: 220px;
}

.email-template-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.email-template-side {
    display: grid;
    gap: 0.85rem;
    align-content: start;
}

.email-test-box h3 {
    font-size: 0.98rem;
    font-weight: 850;
    margin-bottom: 0.85rem;
}

.email-test-box p,
.email-check-box span {
    color: var(--tvm-text-soft);
    font-size: 0.88rem;
    line-height: 1.55;
}

.email-check-box strong,
.email-check-box span {
    display: block;
}

.email-check-box strong {
    margin-bottom: 0.25rem;
}

.email-history-list-compact {
    display: grid;
    gap: 0.75rem;
}

.email-history-card-compact {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(175px, 230px);
    gap: 1rem;
    align-items: start;
    padding: 1rem 1.1rem;
}

.email-history-main {
    min-width: 0;
}

.email-history-side {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.45rem;
}

.email-history-card-compact .email-history-subject {
    margin-top: 0.25rem;
    font-weight: 700;
}

@media (max-width: 1199.98px) {
    .email-center-hero-grid,
    .email-info-grid,
    .email-template-edit-grid {
        grid-template-columns: 1fr;
    }

    .email-filter-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .email-center-stats,
    .email-filter-grid,
    .email-history-card-compact {
        grid-template-columns: 1fr;
    }

    .email-filter-actions,
    .email-template-actions {
        flex-direction: column;
    }

    .email-filter-actions .btn,
    .email-template-actions .btn {
        width: 100%;
    }

    .email-history-side {
        align-items: flex-start;
    }

    .email-history-side .text-end {
        text-align: left !important;
    }

    .email-template-button-meta {
        display: none;
    }
}

/* Hinweise: kompakte Admin-Übersicht */
.notice-admin-hero .card-body,
.notice-filter-card .card-body,
.notice-results-card .card-body,
.notice-form-card .card-body {
    padding: 1.25rem !important;
}

.notice-admin-hero-inner,
.notice-card-heading,
.notice-overview-footer {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

.notice-admin-hero-actions {
    display: flex;
    gap: 0.65rem;
    flex-wrap: wrap;
}

.notice-metric-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.9rem;
}

.notice-metric-card {
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1rem;
    background: linear-gradient(180deg, rgba(249, 252, 255, 0.98), rgba(255, 255, 255, 1));
    box-shadow: var(--tvm-shadow-soft);
    padding: 1rem 1.05rem;
}

.notice-metric-card span,
.notice-metric-card small {
    display: block;
    color: var(--tvm-text-soft);
}

.notice-metric-card span {
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.notice-metric-card strong {
    display: block;
    margin: 0.15rem 0;
    color: var(--tvm-danger, #d10000);
    font-size: clamp(1.55rem, 3vw, 2rem);
    line-height: 1;
    font-weight: 850;
}

.notice-metric-card.is-success strong { color: #146c43; }
.notice-metric-card.is-info strong { color: var(--tvm-account-hero-outline-hover-text); }
.notice-metric-card.is-muted strong { color: #495057; }

.notice-filter-grid {
    display: grid;
    grid-template-columns: minmax(180px, 240px) minmax(180px, 240px) auto;
    gap: 0.85rem;
    align-items: end;
    margin-top: 1rem;
}

.notice-filter-grid .form-label,
.notice-form-grid .form-label {
    color: var(--tvm-text-soft);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-bottom: 0.35rem;
}

.notice-filter-actions {
    display: flex;
    gap: 0.6rem;
    align-items: center;
}

.notice-card-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
    margin-top: 1rem;
}

.notice-overview-card {
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.05rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,251,255,0.98));
    box-shadow: var(--tvm-shadow-soft);
    padding: 1rem;
}

.notice-overview-top {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.75rem;
}

.notice-overview-title {
    color: var(--tvm-text);
    font-size: 1rem;
    font-weight: 800;
    line-height: 1.35;
}

.notice-overview-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-top: 0.55rem;
}

.notice-overview-message {
    color: var(--tvm-text);
    line-height: 1.55;
    margin-bottom: 0.9rem;
}

.notice-overview-footer {
    padding-top: 0.85rem;
    border-top: 1px dashed rgba(18, 70, 160, 0.12);
}

.notice-form-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 1rem;
    align-items: start;
    margin-top: 1rem;
}

.notice-form-main,
.notice-form-side {
    display: grid;
    gap: 1rem;
}

.notice-form-side {
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.05rem;
    background: rgba(248, 251, 255, 0.88);
    padding: 1rem;
}

.notice-form-options {
    border: 1px dashed rgba(18, 70, 160, 0.14);
    border-radius: 0.95rem;
    background: rgba(255,255,255,0.75);
    padding: 0.85rem;
}

@media (max-width: 1199.98px) {
    .notice-metric-grid,
    .notice-card-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .notice-form-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .notice-metric-grid,
    .notice-card-grid,
    .notice-filter-grid {
        grid-template-columns: 1fr;
    }

    .notice-filter-actions,
    .notice-filter-actions .btn,
    .notice-admin-hero-actions,
    .notice-admin-hero-actions .btn {
        width: 100%;
    }
}

/* Aufgabenverwaltung: breitere Übersicht und Formular nach unten */
.task-overview-card .card-body {
    overflow: visible;
}

.task-filter-grid {
    display: grid;
    grid-template-columns: minmax(150px, 190px) minmax(150px, 190px) minmax(170px, 220px) minmax(240px, 1fr) auto;
    gap: 0.85rem;
    align-items: end;
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1.15rem;
    background: rgba(248, 251, 255, 0.82);
    padding: 1rem;
}

.task-filter-grid .form-label,
.task-create-grid .form-label,
.task-quick-edit .form-label {
    color: var(--tvm-text-soft);
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-bottom: 0.35rem;
}

.task-filter-actions {
    display: flex;
    gap: 0.55rem;
    align-items: end;
}

.task-filter-actions .btn {
    min-width: 96px;
}

.task-card-grid {
    display: grid;
    gap: 0.9rem;
}

.task-card-modern {
    padding: 1rem 1.05rem;
}

.task-card-top {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
    flex-wrap: wrap;
}

.task-title {
    color: var(--tvm-text);
    font-size: 1rem;
    font-weight: 800;
    line-height: 1.35;
}

.task-actions {
    flex: 0 0 auto;
}

.task-meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem 0.85rem;
    margin-top: 0.75rem;
    color: var(--tvm-text-soft);
    font-size: 0.86rem;
}

.task-meta-row span {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    background: rgba(18, 70, 160, 0.055);
    padding: 0.32rem 0.65rem;
}

.task-description {
    margin-top: 0.85rem;
    padding: 0.85rem 0.95rem;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 0.95rem;
    background: rgba(248, 251, 255, 0.78);
    color: var(--tvm-text);
    line-height: 1.55;
}

.task-quick-edit {
    display: grid;
    grid-template-columns: minmax(150px, 1fr) minmax(150px, 1fr) auto;
    gap: 0.75rem;
    align-items: end;
}

.task-quick-button .btn {
    min-width: 120px;
}

.task-create-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.9rem;
    align-items: end;
}

.task-create-title,
.task-create-description {
    grid-column: span 2;
}

.task-create-submit {
    grid-column: 1 / -1;
}

.task-create-submit .btn {
    min-width: 180px;
}

@media (max-width: 1199.98px) {
    .task-filter-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .task-filter-search,
    .task-filter-actions {
        grid-column: 1 / -1;
    }

    .task-filter-actions .btn {
        flex: 1 1 auto;
    }

    .task-create-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .task-filter-grid,
    .task-quick-edit,
    .task-create-grid {
        grid-template-columns: 1fr;
    }

    .task-create-title,
    .task-create-description,
    .task-filter-search,
    .task-filter-actions {
        grid-column: auto;
    }

    .task-card-top,
    .task-actions,
    .task-filter-actions {
        width: 100%;
    }

    .task-actions .btn,
    .task-actions form,
    .task-actions form .btn {
        width: 100%;
    }
}

/* v0.6.29 Aufgabenfilter: kompakter und sauber ausgerichtet */
.task-overview-card {
    overflow: hidden;
}

.task-overview-card .card-body {
    padding: 1.15rem !important;
}

.task-overview-card .list-card-header {
    align-items: center;
    margin-bottom: 0.9rem;
}

.task-overview-card .admin-page-title {
    letter-spacing: -0.035em;
}

.task-overview-card .quick-note {
    padding: 0.45rem 0.75rem;
    font-size: 0.78rem;
    white-space: nowrap;
    background: rgba(220, 38, 38, 0.08);
    color: #b00000;
}

.task-filter-grid {
    grid-template-columns: minmax(132px, 160px) minmax(120px, 150px) minmax(150px, 175px) minmax(210px, 1fr) minmax(150px, 170px);
    gap: 0.65rem;
    padding: 0.85rem;
    border-radius: 1rem;
    background: linear-gradient(180deg, rgba(248, 251, 255, 0.95), rgba(255, 255, 255, 0.98));
}

.task-filter-grid .form-label {
    font-size: 0.72rem;
    margin-bottom: 0.28rem;
}

.task-filter-grid .form-control,
.task-filter-grid .form-select {
    min-height: 2.55rem;
    font-size: 0.92rem;
    border-radius: 0.85rem;
}

.task-filter-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.5rem;
    align-items: end;
}

.task-filter-actions .btn {
    min-width: 0;
    width: 100%;
    min-height: 2.55rem;
    padding: 0.55rem 0.75rem;
    border-radius: 0.85rem !important;
}

.task-overview-card .filter-summary {
    margin-top: 0.85rem;
    padding-top: 0.8rem;
    align-items: center;
}

.task-overview-card .filter-summary-label {
    padding-top: 0;
}

.task-overview-card .filter-chip {
    padding: 0.4rem 0.68rem;
    font-size: 0.78rem;
    background: rgba(220, 38, 38, 0.08);
    color: #b00000;
}

@media (max-width: 1399.98px) {
    .task-filter-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .task-filter-search {
        grid-column: span 2;
    }

    .task-filter-actions {
        grid-column: span 2;
    }
}

@media (max-width: 991.98px) {
    .task-filter-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .task-filter-search,
    .task-filter-actions {
        grid-column: 1 / -1;
    }
}

@media (max-width: 575.98px) {
    .task-overview-card .card-body {
        padding: 1rem !important;
    }

    .task-filter-grid,
    .task-filter-actions {
        grid-template-columns: 1fr;
    }
}

/* Notizen: ruhigere und breitere Verwaltungsübersicht */
.notes-overview-hero {
    overflow: hidden;
}

.notes-metric-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.9rem;
}

.notes-metric-card {
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1.05rem;
    background: linear-gradient(180deg, rgba(249, 252, 255, 0.96), rgba(255, 255, 255, 1));
    padding: 1rem 1.1rem;
    box-shadow: var(--tvm-shadow-soft);
}

.notes-metric-card span,
.notes-metric-card small {
    display: block;
    color: var(--tvm-text-soft);
}

.notes-metric-card span {
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.notes-metric-card strong {
    display: block;
    margin: 0.2rem 0 0.1rem;
    color: var(--tvm-text);
    font-size: clamp(1.55rem, 3vw, 2rem);
    line-height: 1;
    font-weight: 850;
}

.notes-metric-card.is-warning strong {
    color: #99621a;
}

.notes-metric-card.is-info strong {
    color: var(--tvm-account-hero-outline-hover-text);
}

.notes-filter-grid {
    display: grid;
    grid-template-columns: minmax(180px, 240px) minmax(130px, 180px) minmax(260px, 1fr) auto;
    gap: 0.85rem;
    align-items: end;
    padding: 1rem;
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1.15rem;
    background: rgba(248, 251, 255, 0.82);
}

.notes-filter-grid .form-label {
    color: var(--tvm-text-soft);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-bottom: 0.35rem;
}

.notes-filter-actions {
    display: flex;
    gap: 0.55rem;
    align-items: center;
    justify-content: flex-end;
}

.notes-card-grid {
    display: grid;
    gap: 0.85rem;
}

.notes-result-card {
    display: grid;
    gap: 0.75rem;
    border-left: 4px solid rgba(var(--tvm-primary-rgb), 0.35);
}

.notes-result-card.is-pinned {
    border-left-color: #d97706;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(255, 250, 242, 0.92));
}

.notes-result-head,
.notes-result-actions {
    display: flex;
    justify-content: space-between;
    gap: 0.8rem;
    align-items: flex-start;
    flex-wrap: wrap;
}

.notes-result-title {
    font-size: 1rem;
    font-weight: 800;
    color: var(--tvm-text);
}

.notes-result-meta {
    display: flex;
    gap: 0.45rem 0.85rem;
    flex-wrap: wrap;
    margin-top: 0.25rem;
    color: var(--tvm-text-soft);
    font-size: 0.84rem;
}

.notes-result-message {
    color: var(--tvm-text);
    line-height: 1.6;
}

.notes-result-actions {
    justify-content: flex-end;
    padding-top: 0.55rem;
    border-top: 1px dashed rgba(18, 70, 160, 0.12);
}

.notes-result-actions form {
    margin: 0;
}

.notes-empty-state {
    padding: 2rem 1rem;
}

.notes-create-card {
    scroll-margin-top: 120px;
}

@media (max-width: 1199.98px) {
    .notes-filter-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .notes-filter-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 767.98px) {
    .notes-metric-grid,
    .notes-filter-grid {
        grid-template-columns: 1fr;
    }

    .notes-filter-actions,
    .notes-filter-actions .btn,
    .notes-result-actions,
    .notes-result-actions .btn,
    .notes-result-actions form {
        width: 100%;
    }
}

/* Aktivitätslog: kompakte Übersicht ohne breite Tabelle */
.activity-overview-hero {
    overflow: hidden;
}

.activity-hero-head {
    margin-bottom: 0;
}

.activity-metric-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.95rem;
}

.activity-metric-card {
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1.05rem;
    background: linear-gradient(180deg, rgba(249, 252, 255, 0.98), rgba(255, 255, 255, 1));
    padding: 0.95rem 1rem;
    box-shadow: var(--tvm-shadow-soft);
}

.activity-metric-card span,
.activity-metric-card small {
    display: block;
    color: var(--tvm-text-soft);
}

.activity-metric-card span {
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.activity-metric-card strong {
    display: block;
    margin-top: 0.2rem;
    font-size: clamp(1.55rem, 3vw, 2rem);
    line-height: 1;
    color: var(--tvm-text);
}

.activity-metric-card.is-success strong {
    color: #146c43;
}

.activity-metric-card.is-danger strong {
    color: #b00000;
}

.activity-metric-card.is-muted strong {
    color: #495057;
}

.activity-section-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.activity-section-head h2 {
    margin: 0;
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--tvm-text);
}

.activity-section-head p {
    margin: 0.25rem 0 0;
    color: var(--tvm-text-soft);
}

.activity-filter-grid {
    display: grid;
    grid-template-columns: minmax(150px, 190px) minmax(190px, 1fr) minmax(190px, 1fr) minmax(170px, 220px) auto;
    gap: 0.85rem;
    align-items: end;
    padding: 1rem;
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1.15rem;
    background: rgba(248, 251, 255, 0.82);
}

.activity-filter-grid .form-label {
    color: var(--tvm-text-soft);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-bottom: 0.35rem;
}

.activity-filter-actions .btn {
    min-width: 112px;
}

.activity-list-card {
    overflow: hidden;
}

.activity-card-list {
    display: grid;
    gap: 0.85rem;
}

.activity-card {
    display: grid;
    grid-template-columns: 170px minmax(0, 1fr);
    gap: 1rem;
    padding: 1rem;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.1rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,251,255,0.98));
    box-shadow: var(--tvm-shadow-soft);
}

.activity-card-time {
    display: grid;
    align-content: start;
    gap: 0.45rem;
}

.activity-card-time strong {
    color: var(--tvm-text);
    line-height: 1.35;
}

.activity-card-time span {
    display: inline-flex;
    width: fit-content;
    border-radius: 999px;
    padding: 0.38rem 0.65rem;
    background: rgba(var(--tvm-primary-rgb), 0.08);
    color: var(--tvm-primary-dark);
    font-size: 0.78rem;
    font-weight: 800;
}

.activity-card-main {
    min-width: 0;
    display: grid;
    gap: 0.85rem;
}

.activity-card-top {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
}

.activity-card-title {
    font-weight: 800;
    color: var(--tvm-text);
    line-height: 1.35;
}

.activity-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem 0.8rem;
    margin-top: 0.25rem;
    color: var(--tvm-text-soft);
    font-size: 0.86rem;
}

.activity-card-facts {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.7rem;
}

.activity-card-facts div {
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 0.95rem;
    background: rgba(255,255,255,0.74);
    padding: 0.7rem 0.8rem;
}

.activity-card-facts span,
.activity-card-facts strong {
    display: block;
}

.activity-card-facts span {
    color: var(--tvm-text-soft);
    font-size: 0.74rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.activity-card-facts strong {
    margin-top: 0.12rem;
    font-size: 0.9rem;
    color: var(--tvm-text);
}

.activity-card-actions {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    flex-wrap: wrap;
}

.activity-context-details {
    min-width: min(100%, 420px);
}

.activity-context-details summary {
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    border-radius: 0.85rem;
    border: 1px solid rgba(18, 70, 160, 0.12);
    background: rgba(248, 251, 255, 0.92);
    color: var(--tvm-primary-dark);
    padding: 0.5rem 0.75rem;
    font-size: 0.84rem;
    font-weight: 800;
}

.activity-context-details .log-context {
    margin-top: 0.7rem;
}

@media (max-width: 1199.98px) {
    .activity-metric-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .activity-filter-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .activity-filter-actions {
        grid-column: 1 / -1;
    }

    .activity-filter-actions .btn {
        width: 100%;
    }
}

@media (max-width: 767.98px) {
    .activity-metric-grid,
    .activity-filter-grid,
    .activity-card,
    .activity-card-facts {
        grid-template-columns: 1fr;
    }

    .activity-card-top {
        flex-direction: column;
    }
}

/* Automatik: professionelle Übersicht */
.automation-page {
    display: grid;
    gap: 1.35rem;
}

.automation-hero {
    overflow: hidden;
}

.automation-hero-top,
.automation-section-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

.automation-hero-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.7rem;
    flex-wrap: wrap;
}

.automation-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.9rem;
}

.automation-metric-card {
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1.05rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.98) 100%);
    padding: 1rem 1.1rem;
    box-shadow: var(--tvm-shadow-soft);
}

.automation-metric-card span,
.automation-metric-card small {
    display: block;
    color: var(--tvm-text-soft);
}

.automation-metric-card span {
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.automation-metric-card strong {
    display: block;
    margin-top: 0.22rem;
    font-size: clamp(1.55rem, 3vw, 2rem);
    line-height: 1;
    font-weight: 850;
    color: var(--tvm-text);
}

.automation-metric-card.is-danger strong { color: #b00000; }
.automation-metric-card.is-info strong { color: var(--tvm-primary-dark); }
.automation-metric-card.is-muted strong { color: #34445a; }

.automation-tabs {
    margin-bottom: 0;
}

.automation-action-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
}

.automation-action-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin: 0;
    padding: 1rem;
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1.1rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.94) 100%);
    box-shadow: var(--tvm-shadow-soft);
}

.automation-action-card.is-primary {
    border-color: rgba(220, 0, 0, 0.16);
    background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(255,245,245,0.92) 100%);
}

.automation-action-card strong,
.automation-action-card span {
    display: block;
}

.automation-action-card strong {
    color: var(--tvm-text);
    font-weight: 800;
    margin-bottom: 0.2rem;
}

.automation-action-card span {
    color: var(--tvm-text-soft);
    font-size: 0.9rem;
    line-height: 1.45;
}

.automation-action-card .btn {
    flex: 0 0 auto;
    min-width: 108px;
}

.automation-log-list {
    display: grid;
    gap: 0.85rem;
}

.automation-log-card {
    display: grid;
    grid-template-columns: 180px minmax(0, 1fr);
    gap: 1rem;
    padding: 1rem;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.1rem;
    background: rgba(248, 251, 255, 0.72);
}

.automation-log-time {
    display: grid;
    align-content: start;
    gap: 0.28rem;
}

.automation-log-time strong {
    color: var(--tvm-text);
    font-weight: 800;
}

.automation-log-time span,
.automation-log-meta {
    color: var(--tvm-text-soft);
    font-size: 0.86rem;
}

.automation-log-top {
    margin-bottom: 0.45rem;
}

.automation-log-title {
    color: var(--tvm-text);
    font-weight: 800;
    line-height: 1.4;
}

.automation-settings-form {
    display: grid;
    gap: 1rem;
}

.automation-settings-group {
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.15rem;
    background: rgba(248, 251, 255, 0.72);
    padding: 1rem;
}

.automation-settings-group h3 {
    margin: 0 0 0.85rem;
    color: var(--tvm-text);
    font-size: 1rem;
    font-weight: 850;
}

.automation-cron-box {
    display: grid;
    gap: 0.45rem;
    padding: 1rem;
    border: 1px dashed rgba(18, 70, 160, 0.18);
    border-radius: 1.05rem;
    background: rgba(255,255,255,0.86);
    color: var(--tvm-text-soft);
}

.automation-cron-box strong {
    color: var(--tvm-text);
}

.automation-cron-box code {
    display: block;
    white-space: normal;
    word-break: break-all;
    color: var(--tvm-primary-dark);
}

.automation-save-row {
    display: flex;
    justify-content: flex-end;
}

.automation-help-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 0.85rem;
}

@media (max-width: 1399.98px) {
    .automation-help-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 1199.98px) {
    .automation-action-grid,
    .automation-help-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .automation-metrics,
    .automation-action-grid,
    .automation-help-grid {
        grid-template-columns: 1fr;
    }

    .automation-action-card,
    .automation-log-card {
        grid-template-columns: 1fr;
    }

    .automation-action-card {
        align-items: stretch;
        flex-direction: column;
    }

    .automation-action-card .btn,
    .automation-hero-actions .btn,
    .automation-hero-actions form {
        width: 100%;
    }

    .automation-save-row .btn {
        width: 100%;
    }
}

/* Rechte und Bereiche: ruhige Kartenansicht statt breiter Matrix */
.permissions-page-hero {
    overflow: hidden;
}

.permissions-hero-layout,
.permissions-head,
.permissions-role-head,
.permissions-savebar {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

.permissions-hero-actions,
.permissions-head-meta {
    display: flex;
    gap: 0.55rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.permissions-metric-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.permissions-metric-card {
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1.15rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.98) 100%);
    box-shadow: var(--tvm-shadow-soft);
    padding: 1rem 1.1rem;
}

.permissions-metric-card span,
.permissions-metric-card small {
    display: block;
    color: var(--tvm-text-soft);
}

.permissions-metric-card span {
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.permissions-metric-card strong {
    display: block;
    margin-top: 0.25rem;
    color: var(--tvm-danger, #b00000);
    font-size: 2rem;
    line-height: 1;
    font-weight: 850;
}

.permissions-metric-card small {
    margin-top: 0.35rem;
    font-size: 0.88rem;
}

.permissions-head-meta span,
.permissions-role-count {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    background: rgba(18, 70, 160, 0.06);
    color: var(--tvm-primary-dark);
    padding: 0.45rem 0.7rem;
    font-size: 0.78rem;
    font-weight: 800;
}

.permissions-tip {
    border: 1px dashed rgba(18, 70, 160, 0.16);
    border-radius: 1rem;
    background: rgba(248, 251, 255, 0.88);
    color: var(--tvm-text-soft);
    padding: 0.95rem 1rem;
    line-height: 1.55;
}

.permissions-tip strong {
    color: var(--tvm-text);
}

.permissions-role-list {
    display: grid;
    gap: 1rem;
}

.permissions-role-card {
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1.15rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.99) 0%, rgba(248,251,255,0.96) 100%);
    padding: 1rem;
    box-shadow: var(--tvm-shadow-soft);
}

.permissions-role-head {
    align-items: center;
    padding-bottom: 0.85rem;
    margin-bottom: 0.9rem;
    border-bottom: 1px solid rgba(18, 70, 160, 0.08);
}

.permissions-role-head h3 {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 850;
    color: var(--tvm-text);
}

.permissions-role-head p {
    margin: 0.2rem 0 0;
    color: var(--tvm-text-soft);
    font-size: 0.88rem;
}

.permissions-module-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 0.65rem;
}

.permissions-module-tile {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    min-height: 64px;
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.92);
    padding: 0.75rem 0.8rem;
    cursor: pointer;
    transition: border-color 0.18s ease, background 0.18s ease, transform 0.18s ease;
}

.permissions-module-tile:hover {
    border-color: rgba(18, 70, 160, 0.2);
    background: #fff;
    transform: translateY(-1px);
}

.permissions-module-tile .form-check-input {
    flex: 0 0 auto;
    margin-top: 0.15rem;
}

.permissions-module-tile span,
.permissions-module-tile strong,
.permissions-module-tile small {
    display: block;
}

.permissions-module-tile strong {
    color: var(--tvm-text);
    font-size: 0.92rem;
    line-height: 1.25;
}

.permissions-module-tile small {
    margin-top: 0.2rem;
    color: var(--tvm-text-soft);
    font-size: 0.74rem;
}

.permissions-savebar {
    align-items: center;
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1rem;
    background: rgba(248, 251, 255, 0.9);
    padding: 1rem;
}

.permissions-savebar strong,
.permissions-savebar span {
    display: block;
}

.permissions-savebar span {
    margin-top: 0.2rem;
    color: var(--tvm-text-soft);
    font-size: 0.9rem;
}

@media (max-width: 991.98px) {
    .permissions-metric-grid {
        grid-template-columns: 1fr;
    }

    .permissions-hero-actions,
    .permissions-head-meta {
        justify-content: flex-start;
    }

    .permissions-savebar .btn {
        flex: 1 1 auto;
    }
}

@media (max-width: 575.98px) {
    .permissions-module-grid {
        grid-template-columns: 1fr;
    }
}


/* v0.6.35 Systemeinstellungen: breitere, ruhigere Einstellungsseite */
.settings-admin-page {
    display: block;
}

.settings-wide-layout {
    width: 100%;
}

.settings-action-strip {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.15rem;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.09);
    border-radius: 1.25rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,251,255,0.96));
    box-shadow: var(--tvm-shadow-soft);
}

.settings-action-kicker {
    color: var(--tvm-account-hero-outline-hover-text);
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 0.2rem;
}

.settings-action-title {
    color: var(--tvm-text);
    font-size: 1.05rem;
    font-weight: 800;
    line-height: 1.25;
}

.settings-action-text {
    color: var(--tvm-text-soft);
    font-size: 0.92rem;
    margin-top: 0.2rem;
}

.settings-action-buttons {
    display: flex;
    gap: 0.7rem;
    align-items: center;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.settings-admin-page .settings-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.15rem;
}

.settings-admin-page .settings-section {
    padding: 1.45rem;
}

.settings-admin-page .settings-section > .row {
    align-items: start;
}

.settings-admin-page .settings-section h2 {
    font-size: 1.18rem;
    letter-spacing: -0.02em;
}

.settings-admin-page .settings-section p {
    max-width: 860px;
}

.settings-admin-page .form-help-box,
.settings-admin-page .quick-note-box,
.settings-admin-page .public-data-card {
    box-shadow: none;
}

.settings-admin-page textarea.form-control {
    min-height: 150px;
}

.settings-admin-page .public-data-card {
    height: 100%;
}

.settings-admin-page #bereich-rechtliches textarea.form-control {
    min-height: 240px;
}

.settings-admin-page #bereich-email textarea.form-control,
.settings-admin-page #bereich-rechtliches textarea.form-control {
    line-height: 1.55;
}

.settings-admin-page .settings-section .col-12 > .form-help-box {
    border-style: solid;
    background: rgba(248, 251, 255, 0.92);
}

.settings-admin-page .settings-section .row.g-3 > .col-12:first-child {
    padding-bottom: 0.2rem;
}

@media (min-width: 1200px) {
    .settings-admin-page #bereich-allgemein .col-md-4,
    .settings-admin-page #bereich-allgemein .col-md-5,
    .settings-admin-page #bereich-allgemein .col-md-3,
    .settings-admin-page #bereich-design .col-md-6.col-lg-3,
    .settings-admin-page #bereich-buchungen .col-md-6,
    .settings-admin-page #bereich-flatrate .col-md-6,
    .settings-admin-page #bereich-zahlung .col-md-6,
    .settings-admin-page #bereich-email .col-md-6,
    .settings-admin-page #bereich-wallet .col-md-6,
    .settings-admin-page #bereich-rabatte .col-md-6,
    .settings-admin-page #bereich-rechtliches .col-md-6 {
        max-width: 33.333333%;
    }
}

@media (max-width: 991.98px) {
    .settings-action-strip {
        align-items: flex-start;
        flex-direction: column;
    }

    .settings-action-buttons,
    .settings-action-buttons .btn {
        width: 100%;
    }

    .settings-action-buttons {
        justify-content: stretch;
    }

    .settings-admin-page .settings-section {
        padding: 1.1rem;
    }
}

/* v0.6.36 Termindetail: ruhigeres Layout ohne schmale rechte Spalte */
.session-admin-page {
    display: block;
}

.session-detail-hero {
    overflow: hidden;
}

.session-detail-hero-grid {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1.25rem;
    flex-wrap: wrap;
}

.session-detail-title {
    margin: 0;
    font-size: clamp(1.65rem, 2.4vw, 2.25rem);
    font-weight: 850;
    letter-spacing: -0.04em;
    color: var(--tvm-text);
}

.session-detail-subtitle {
    color: var(--tvm-text-soft);
    font-size: 1rem;
    margin-top: 0.3rem;
}

.session-detail-pills {
    display: flex;
    gap: 0.55rem;
    flex-wrap: wrap;
    margin-top: 1rem;
}

.session-detail-pills span {
    display: inline-flex;
    align-items: center;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 999px;
    background: rgba(248, 251, 255, 0.9);
    color: var(--tvm-text);
    padding: 0.42rem 0.72rem;
    font-size: 0.84rem;
    font-weight: 700;
}

.session-detail-actions {
    display: flex;
    gap: 0.65rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.session-detail-stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.95rem;
}

.session-stat-card {
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.15rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,251,255,0.96));
    box-shadow: var(--tvm-shadow-soft);
    padding: 1rem 1.1rem;
}

.session-stat-card span,
.session-stat-card small {
    display: block;
    color: var(--tvm-text-soft);
}

.session-stat-card span {
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.session-stat-card strong {
    display: block;
    margin: 0.25rem 0 0.15rem;
    color: var(--tvm-text);
    font-size: 1.55rem;
    line-height: 1.1;
    font-weight: 850;
}

.session-card-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 1.1rem;
}

.session-action-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.9rem;
}

.session-action-card {
    display: block;
    height: 100%;
    border: 1px solid rgba(18, 70, 160, 0.08) !important;
    border-radius: 1rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,251,255,0.96));
    box-shadow: none;
    color: var(--tvm-text);
    padding: 1rem 1.05rem;
    transition: border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.session-action-card:hover {
    border-color: rgba(var(--tvm-primary-rgb), 0.2) !important;
    box-shadow: var(--tvm-shadow-soft);
    color: var(--tvm-text);
    transform: translateY(-1px);
}

.session-action-card span,
.session-action-card small {
    display: block;
}

.session-action-card span {
    font-weight: 850;
    margin-bottom: 0.35rem;
}

.session-action-card small {
    color: var(--tvm-text-soft);
    line-height: 1.5;
}

.session-filter-bar {
    display: grid;
    grid-template-columns: minmax(260px, 1fr) auto;
    gap: 0.85rem;
    align-items: end;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.1rem;
    background: rgba(248,251,255,0.86);
    padding: 1rem;
}

.session-filter-actions,
.session-save-row,
.session-check-row {
    display: flex;
    gap: 0.65rem;
    flex-wrap: wrap;
    align-items: center;
}

.session-participant-list {
    display: grid;
    gap: 0.75rem;
}

.session-participant-card {
    display: grid;
    grid-template-columns: minmax(220px, 1.4fr) minmax(160px, 0.8fr) minmax(190px, 0.75fr) auto;
    gap: 0.85rem;
    align-items: center;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.05rem;
    background: #fff;
    padding: 0.95rem 1rem;
}

.session-participant-main {
    display: grid;
    gap: 0.18rem;
    min-width: 0;
}

.session-participant-main strong {
    font-weight: 850;
    line-height: 1.25;
}

.session-participant-main span {
    color: var(--tvm-text-soft);
    font-size: 0.88rem;
    overflow-wrap: anywhere;
}

.session-participant-meta {
    display: flex;
    gap: 0.45rem;
    align-items: center;
    flex-wrap: wrap;
}

.session-price-pill {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    background: rgba(18, 70, 160, 0.06);
    color: var(--tvm-text);
    padding: 0.42rem 0.65rem;
    font-size: 0.82rem;
    font-weight: 800;
}

.session-participant-actions {
    text-align: right;
}

.session-management-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    align-items: start;
}

.session-info-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    align-items: start;
}

.session-management-grid .card,
.session-info-grid .card {
    height: 100%;
}

@media (max-width: 1199.98px) {
    .session-detail-stats,
    .session-management-grid,
    .session-info-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .session-action-grid {
        grid-template-columns: 1fr;
    }

    .session-participant-card {
        grid-template-columns: minmax(220px, 1fr) minmax(180px, 0.7fr);
    }
}

@media (max-width: 767.98px) {
    .session-detail-stats,
    .session-management-grid,
    .session-info-grid {
        grid-template-columns: 1fr;
    }

    .session-filter-bar {
        grid-template-columns: 1fr;
    }

    .session-filter-actions .btn,
    .session-save-row .btn,
    .session-detail-actions .btn {
        flex: 1 1 auto;
    }

    .session-participant-card {
        grid-template-columns: 1fr;
    }

    .session-participant-actions {
        text-align: left;
    }
}

/* v0.6.38 Flatrate-Detailseite: ruhigere Übersicht */
.subscription-detail-hero {
    overflow: hidden;
}

.subscription-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1.25rem;
    align-items: start;
}

.subscription-hero-pills,
.subscription-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    align-items: center;
}

.subscription-hero-actions {
    justify-content: flex-end;
    max-width: 430px;
}

.subscription-hero-actions form {
    margin: 0;
}

.subscription-summary-grid .admin-summary-card {
    min-height: 132px;
}

.subscription-overview-grid,
.subscription-data-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 1.25rem;
}

.subscription-facts-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
}

.subscription-facts-grid .detail-list-card {
    display: grid;
    gap: 0.25rem;
}

.subscription-facts-grid .detail-list-card span {
    color: var(--tvm-text-soft);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.subscription-facts-grid .detail-list-card strong {
    color: var(--tvm-text);
    font-size: 0.98rem;
    line-height: 1.35;
}

@media (max-width: 1199.98px) {
    .subscription-hero-grid,
    .subscription-overview-grid,
    .subscription-data-grid {
        grid-template-columns: 1fr;
    }

    .subscription-hero-actions {
        justify-content: flex-start;
        max-width: none;
    }
}

@media (max-width: 575.98px) {
    .subscription-facts-grid {
        grid-template-columns: 1fr;
    }

    .subscription-hero-actions .btn,
    .subscription-hero-actions form,
    .subscription-hero-actions form .btn {
        width: 100%;
    }
}

/* v0.6.39 Nutzer-Sonderseiten: ruhigere Kartenansichten */
.user-admin-hero {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;
    flex-wrap: wrap;
    margin-bottom: 1.25rem;
}

.user-admin-hero-actions {
    display: flex;
    gap: 0.65rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.user-admin-metrics {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 0.85rem;
    margin: 1rem 0 1.2rem;
}

.user-admin-metric {
    border: 1px solid rgba(18,70,160,0.09);
    border-radius: 1rem;
    background: linear-gradient(180deg, rgba(249,252,255,0.98), rgba(255,255,255,1));
    padding: 0.95rem 1rem;
    box-shadow: var(--tvm-shadow-soft);
    min-height: 100%;
}

.user-admin-metric-label {
    color: var(--tvm-text-soft);
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin-bottom: 0.4rem;
}

.user-admin-metric-value {
    color: var(--tvm-primary-dark);
    font-size: 1.65rem;
    line-height: 1;
    font-weight: 850;
}

.user-admin-metric-note {
    color: var(--tvm-text-soft);
    font-size: 0.84rem;
    margin-top: 0.35rem;
}

.user-admin-filter {
    border: 1px solid rgba(18,70,160,0.09);
    border-radius: 1.15rem;
    background: rgba(248,251,255,0.85);
    padding: 1rem;
    margin-bottom: 1.15rem;
}

.user-admin-filter .form-label {
    color: var(--tvm-text-soft);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.user-admin-card-grid {
    display: grid;
    gap: 0.85rem;
}

.user-admin-card {
    border: 1px solid rgba(18,70,160,0.08);
    border-radius: 1.1rem;
    background: linear-gradient(180deg, #fff 0%, rgba(248,251,255,0.96) 100%);
    padding: 1rem;
    box-shadow: var(--tvm-shadow-soft);
}

.user-admin-card-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
}

.user-admin-card-name {
    font-size: 1rem;
    font-weight: 850;
    color: var(--tvm-text);
    margin-bottom: 0.15rem;
}

.user-admin-card-meta {
    color: var(--tvm-text-soft);
    font-size: 0.86rem;
    line-height: 1.45;
}

.user-admin-card-body {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 0.7rem;
    margin-top: 0.9rem;
}

.user-admin-info-box {
    border: 1px solid rgba(18,70,160,0.08);
    border-radius: 0.95rem;
    background: rgba(255,255,255,0.74);
    padding: 0.8rem 0.9rem;
}

.user-admin-info-label {
    display: block;
    color: var(--tvm-text-soft);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin-bottom: 0.28rem;
}

.user-admin-info-value {
    font-weight: 700;
    color: var(--tvm-text);
}

.user-admin-actions {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.user-admin-empty {
    border: 1px dashed rgba(18,70,160,0.16);
    border-radius: 1.1rem;
    background: rgba(248,251,255,0.88);
    padding: 1.6rem 1rem;
    text-align: center;
    color: var(--tvm-text-soft);
}

.user-admin-chip-row {
    display: flex;
    gap: 0.45rem;
    flex-wrap: wrap;
    align-items: center;
}

@media (max-width: 767.98px) {
    .user-admin-hero-actions,
    .user-admin-actions {
        justify-content: stretch;
        width: 100%;
    }
    .user-admin-hero-actions .btn,
    .user-admin-actions .btn,
    .user-admin-actions form,
    .user-admin-actions form .btn {
        width: 100%;
    }
}

/* v0.6.40 Wiedervorlagen: kompaktere, professionellere Übersicht */
.user-followup-page .card-body,
.user-followup-results .card-body {
    overflow: hidden;
}

.user-followup-hero,
.user-followup-results-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
}

.user-followup-hero {
    padding-bottom: 1rem;
    border-bottom: 1px solid rgba(18, 70, 160, 0.08);
}

.user-followup-hero-main {
    max-width: 760px;
}

.user-followup-hero-actions,
.user-followup-filter-actions,
.user-followup-card-actions {
    display: flex;
    gap: 0.65rem;
    flex-wrap: wrap;
    align-items: center;
}

.user-followup-hero-actions {
    justify-content: flex-end;
}

.user-followup-dashboard {
    display: grid;
    gap: 1rem;
    margin-top: 1.15rem;
}

.user-followup-metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.85rem;
}

.user-followup-metric {
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1rem;
    background: linear-gradient(180deg, rgba(249, 252, 255, 0.98), rgba(255, 255, 255, 1));
    padding: 0.9rem 1rem;
    box-shadow: var(--tvm-shadow-soft);
}

.user-followup-metric span,
.user-followup-metric small,
.user-followup-card-grid span,
.user-followup-card-grid small {
    display: block;
    color: var(--tvm-text-soft);
}

.user-followup-metric span,
.user-followup-card-grid span {
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.user-followup-metric strong {
    display: block;
    margin: 0.2rem 0 0.2rem;
    color: var(--tvm-primary-dark);
    font-size: 1.65rem;
    line-height: 1;
    font-weight: 850;
}

.user-followup-metric.is-danger strong { color: #b00000; }
.user-followup-metric.is-warning strong { color: #9a5607; }
.user-followup-metric.is-success strong { color: #146c43; }

.user-followup-filter {
    display: grid;
    grid-template-columns: minmax(260px, 1fr) minmax(150px, 220px) minmax(150px, 190px) auto;
    gap: 0.85rem;
    align-items: end;
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1.15rem;
    background: rgba(248, 251, 255, 0.85);
    padding: 1rem;
}

.user-followup-filter .form-label {
    color: var(--tvm-text-soft);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-bottom: 0.35rem;
}

.user-followup-filter-actions .btn {
    min-width: 92px;
}

.user-followup-results-head {
    margin-bottom: 1rem;
}

.user-followup-list {
    display: grid;
    gap: 0.85rem;
}

.user-followup-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: stretch;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-left: 5px solid rgba(18, 70, 160, 0.16);
    border-radius: 1.1rem;
    background: linear-gradient(180deg, #fff 0%, rgba(248, 251, 255, 0.96) 100%);
    padding: 1rem;
    box-shadow: var(--tvm-shadow-soft);
}

.user-followup-card.is-overdue {
    border-left-color: #b00000;
}

.user-followup-card.is-due-soon {
    border-left-color: #d97706;
}

.user-followup-card-titleline {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
}

.user-followup-card-titleline h3 {
    margin: 0 0 0.18rem;
    color: var(--tvm-text);
    font-size: 1.02rem;
    font-weight: 850;
    letter-spacing: -0.02em;
}

.user-followup-person {
    color: var(--tvm-text-soft);
    font-size: 0.88rem;
}

.user-followup-badges {
    display: flex;
    gap: 0.45rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.user-followup-card-grid {
    display: grid;
    grid-template-columns: minmax(150px, 0.8fr) minmax(140px, 0.7fr) minmax(240px, 1.6fr);
    gap: 0.7rem;
    margin-top: 0.85rem;
}

.user-followup-card-grid > div {
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 0.95rem;
    background: rgba(255, 255, 255, 0.76);
    padding: 0.8rem 0.9rem;
}

.user-followup-card-grid strong {
    display: block;
    margin-top: 0.2rem;
    color: var(--tvm-text);
    font-size: 0.95rem;
    line-height: 1.4;
}

.user-followup-card-grid small {
    margin-top: 0.25rem;
    font-size: 0.8rem;
    line-height: 1.4;
}

.user-followup-card-actions {
    min-width: 170px;
    flex-direction: column;
    justify-content: center;
    align-items: stretch;
}

.user-followup-card-actions .btn,
.user-followup-card-actions form,
.user-followup-card-actions form .btn {
    width: 100%;
}

.user-followup-empty {
    display: grid;
    gap: 0.3rem;
    border: 1px dashed rgba(18, 70, 160, 0.16);
    border-radius: 1.1rem;
    background: rgba(248, 251, 255, 0.88);
    padding: 1.6rem 1rem;
    text-align: center;
    color: var(--tvm-text-soft);
}

.user-followup-empty strong {
    color: var(--tvm-text);
}

@media (max-width: 1199.98px) {
    .user-followup-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .user-followup-filter {
        grid-template-columns: minmax(240px, 1fr) minmax(150px, 200px) minmax(150px, 190px);
    }

    .user-followup-filter-actions {
        grid-column: 1 / -1;
        justify-content: flex-end;
    }
}

@media (max-width: 991.98px) {
    .user-followup-filter,
    .user-followup-card,
    .user-followup-card-grid {
        grid-template-columns: 1fr;
    }

    .user-followup-card-actions {
        min-width: 0;
        flex-direction: row;
        justify-content: flex-start;
    }

    .user-followup-card-actions .btn,
    .user-followup-card-actions form,
    .user-followup-card-actions form .btn {
        width: auto;
    }
}

@media (max-width: 575.98px) {
    .user-followup-metrics {
        grid-template-columns: 1fr;
    }

    .user-followup-hero-actions,
    .user-followup-filter-actions,
    .user-followup-card-actions,
    .user-followup-card-actions form,
    .user-followup-card-actions .btn,
    .user-followup-card-actions form .btn {
        width: 100%;
    }
}

/* v0.6.41 Nutzer-Eskalationen: ruhigere Übersicht */
.user-escalation-page {
    display: grid;
    gap: 1.25rem;
}

.user-escalation-hero .card-body,
.user-escalation-results .card-body {
    padding: 1.35rem !important;
}

.user-escalation-hero-inner,
.user-escalation-results-head,
.user-escalation-card-titleline {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
}

.user-escalation-hero-copy {
    max-width: 780px;
}

.user-escalation-actions,
.user-escalation-filter-actions,
.user-escalation-badges,
.user-escalation-card-actions,
.user-escalation-reasons,
.user-escalation-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.user-escalation-actions {
    justify-content: flex-end;
}

.user-escalation-tabs {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(18, 70, 160, 0.08);
}

.user-escalation-tab {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.2rem;
    border-radius: 999px;
    border: 1px solid rgba(18, 70, 160, 0.10);
    background: rgba(248, 251, 255, 0.92);
    color: var(--tvm-text);
    padding: 0.5rem 0.85rem;
    font-size: 0.82rem;
    font-weight: 800;
}

.user-escalation-tab:hover,
.user-escalation-tab.is-active {
    color: #b00000;
    background: rgba(220, 38, 38, 0.08);
    border-color: rgba(220, 38, 38, 0.18);
}

.user-escalation-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.85rem;
    margin-top: 1rem;
}

.user-escalation-metric {
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1.05rem;
    background: linear-gradient(180deg, rgba(249, 252, 255, 0.98), rgba(255,255,255,1));
    padding: 0.95rem 1rem;
    box-shadow: var(--tvm-shadow-soft);
}

.user-escalation-metric span,
.user-escalation-metric small,
.user-escalation-card-grid span,
.user-escalation-card-grid small,
.user-escalation-person,
.user-escalation-results-head p {
    display: block;
    color: var(--tvm-text-soft);
}

.user-escalation-metric span,
.user-escalation-card-grid span {
    font-size: 0.74rem;
    font-weight: 850;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.user-escalation-metric strong {
    display: block;
    margin: 0.2rem 0 0.15rem;
    color: var(--tvm-primary-dark);
    font-size: 1.7rem;
    line-height: 1;
    font-weight: 850;
}

.user-escalation-metric.is-danger strong { color: #b00000; }
.user-escalation-metric.is-warning strong { color: #9a5607; }
.user-escalation-metric.is-success strong { color: #146c43; }

.user-escalation-filter {
    display: grid;
    grid-template-columns: minmax(260px, 1fr) auto;
    gap: 0.85rem;
    align-items: end;
    margin-top: 1rem;
    padding: 1rem;
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1.15rem;
    background: rgba(248, 251, 255, 0.86);
}

.user-escalation-filter .form-label {
    color: var(--tvm-text-soft);
    font-size: 0.78rem;
    font-weight: 850;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-bottom: 0.35rem;
}

.user-escalation-filter-actions .btn {
    min-width: 92px;
}

.user-escalation-results-head {
    margin-bottom: 1rem;
}

.user-escalation-results-head h2 {
    margin: 0;
    color: var(--tvm-text);
    font-size: clamp(1.25rem, 2vw, 1.55rem);
    font-weight: 850;
    letter-spacing: -0.03em;
}

.user-escalation-results-head p {
    margin: 0.25rem 0 0;
    line-height: 1.5;
}

.user-escalation-list {
    display: grid;
    gap: 0.85rem;
}

.user-escalation-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 170px;
    gap: 1rem;
    align-items: stretch;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-left: 5px solid rgba(18, 70, 160, 0.18);
    border-radius: 1.15rem;
    background: linear-gradient(180deg, #fff 0%, rgba(248, 251, 255, 0.96) 100%);
    padding: 1rem;
    box-shadow: var(--tvm-shadow-soft);
}

.user-escalation-card.needs-task {
    border-left-color: #b00000;
}

.user-escalation-card.has-task {
    border-left-color: #146c43;
}

.user-escalation-card-titleline h3 {
    margin: 0 0 0.18rem;
    color: var(--tvm-text);
    font-size: 1.05rem;
    font-weight: 850;
    letter-spacing: -0.02em;
}

.user-escalation-person {
    font-size: 0.88rem;
}

.user-escalation-badges {
    justify-content: flex-end;
}

.user-escalation-card-grid {
    display: grid;
    grid-template-columns: minmax(240px, 1.5fr) minmax(150px, 0.8fr) minmax(170px, 0.8fr);
    gap: 0.75rem;
    margin-top: 0.9rem;
}

.user-escalation-card-grid > div {
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 0.95rem;
    background: rgba(255, 255, 255, 0.78);
    padding: 0.8rem 0.9rem;
}

.user-escalation-card-grid strong {
    display: block;
    margin-top: 0.2rem;
    color: var(--tvm-text);
    font-size: 0.95rem;
    line-height: 1.4;
}

.user-escalation-card-grid small {
    margin-top: 0.25rem;
    font-size: 0.8rem;
    line-height: 1.4;
}

.user-escalation-reasons {
    margin-top: 0.35rem;
}

.user-escalation-reasons span {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    background: rgba(18, 70, 160, 0.06);
    color: var(--tvm-text-soft);
    padding: 0.35rem 0.65rem;
    font-size: 0.78rem;
    font-weight: 750;
}

.user-escalation-card-actions {
    flex-direction: column;
    justify-content: center;
    align-items: stretch;
}

.user-escalation-card-actions .btn {
    width: 100%;
}

.user-escalation-empty {
    display: grid;
    gap: 0.25rem;
    border: 1px dashed rgba(18, 70, 160, 0.16);
    border-radius: 1.15rem;
    background: rgba(248, 251, 255, 0.88);
    padding: 1.65rem 1rem;
    text-align: center;
    color: var(--tvm-text-soft);
}

.user-escalation-empty strong {
    color: var(--tvm-text);
}

@media (max-width: 1199.98px) {
    .user-escalation-card,
    .user-escalation-card-grid {
        grid-template-columns: 1fr;
    }

    .user-escalation-card-actions {
        flex-direction: row;
        justify-content: flex-start;
    }

    .user-escalation-card-actions .btn {
        width: auto;
    }
}

@media (max-width: 991.98px) {
    .user-escalation-metrics,
    .user-escalation-filter {
        grid-template-columns: 1fr;
    }

    .user-escalation-actions,
    .user-escalation-filter-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 575.98px) {
    .user-escalation-actions,
    .user-escalation-actions .btn,
    .user-escalation-filter-actions,
    .user-escalation-filter-actions .btn,
    .user-escalation-card-actions,
    .user-escalation-card-actions .btn {
        width: 100%;
    }
}

/* v0.6.61 Mein Bereich: Flatrate Feinschliff */
.subscription-page {
    gap: 1.35rem;
}

.subscription-hero {
    overflow: hidden;
}

.subscription-hero .card-body {
    padding: 1.45rem 1.55rem !important;
}

.subscription-hero-main {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
}

.subscription-hero-title {
    margin: 0.22rem 0 0.35rem;
    font-size: clamp(1.65rem, 2.5vw, 2.15rem);
    font-weight: 850;
    letter-spacing: -0.035em;
    color: var(--tvm-text);
}

.subscription-hero-text {
    margin: 0;
    max-width: 58rem;
    color: var(--tvm-text-soft);
    line-height: 1.65;
}

.subscription-hero-actions {
    display: flex;
    gap: 0.65rem;
    flex-wrap: wrap;
    align-items: center;
}

.subscription-metric-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.95rem;
}

.subscription-metric-card {
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.15rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.99), rgba(248,251,255,0.96));
    box-shadow: var(--tvm-shadow-soft);
    padding: 1.05rem 1.1rem;
    min-height: 100%;
}

.subscription-metric-card span,
.subscription-metric-card small {
    display: block;
}

.subscription-metric-card > span {
    color: var(--tvm-text-soft);
    font-size: 0.77rem;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 0.48rem;
}

.subscription-metric-card strong {
    display: block;
    color: var(--tvm-text);
    font-size: clamp(1.45rem, 2.2vw, 1.95rem);
    line-height: 1.12;
    font-weight: 850;
    letter-spacing: -0.03em;
}

.subscription-metric-card strong.is-text {
    font-size: 1.05rem;
    line-height: 1.28;
}

.subscription-metric-status .badge {
    display: inline-flex;
    font-size: 0.88rem !important;
    padding: 0.48rem 0.76rem;
}

.subscription-metric-card small {
    margin-top: 0.5rem;
    color: var(--tvm-text-soft);
    line-height: 1.45;
}

.subscription-page .account-panel {
    border: 1px solid rgba(18, 70, 160, 0.08);
}

.subscription-page .account-panel .card-body {
    padding: 1.35rem !important;
}

.subscription-page .account-muted-box {
    background: linear-gradient(180deg, rgba(248,251,255,0.94), rgba(255,255,255,0.98));
    border: 1px solid rgba(18, 70, 160, 0.08);
}

.subscription-page .account-info-grid {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.subscription-page .account-info-item {
    background: #fff;
}

.subscription-booking-grid {
    display: grid;
    gap: 0.8rem;
}

.subscription-booking-card {
    display: grid;
    grid-template-columns: minmax(150px, 0.8fr) minmax(220px, 1.4fr) auto;
    gap: 1rem;
    align-items: center;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1rem;
    background: rgba(248, 251, 255, 0.82);
    padding: 0.95rem 1rem;
}

.subscription-booking-date {
    font-weight: 800;
    color: var(--tvm-text);
}

.subscription-booking-tags {
    display: flex;
    justify-content: flex-end;
    gap: 0.45rem;
    flex-wrap: wrap;
}

@media (max-width: 1199.98px) {
    .subscription-metric-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .subscription-hero .card-body,
    .subscription-page .account-panel .card-body {
        padding: 1.05rem !important;
    }

    .subscription-hero-actions,
    .subscription-hero-actions .btn {
        width: 100%;
    }

    .subscription-metric-grid,
    .subscription-booking-card {
        grid-template-columns: 1fr;
    }

    .subscription-booking-tags {
        justify-content: flex-start;
    }
}

/* v0.6.62 Mein Bereich: Zahlungen Feinschliff */
.payment-page {
    gap: 1.35rem;
}

.payment-hero-soft {
    overflow: hidden;
}

.payment-hero-soft .card-body {
    padding: 1.45rem 1.55rem !important;
}

.payment-hero-main {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    flex-wrap: wrap;
}

.payment-hero-title {
    margin: 0.22rem 0 0.35rem;
    color: var(--tvm-text);
    font-size: clamp(1.65rem, 2.4vw, 2.1rem);
    font-weight: 850;
    letter-spacing: -0.035em;
}

.payment-hero-text {
    margin: 0;
    color: var(--tvm-text-soft);
    line-height: 1.65;
}

.payment-hero-actions {
    display: flex;
    gap: 0.65rem;
    flex-wrap: wrap;
    align-items: center;
}

.payment-metric-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.95rem;
}

.payment-metric-card {
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.15rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.99), rgba(248,251,255,0.96));
    box-shadow: var(--tvm-shadow-soft);
    padding: 1.05rem 1.1rem;
    min-height: 100%;
}

.payment-metric-card span,
.payment-metric-card small {
    display: block;
}

.payment-metric-card > span {
    color: var(--tvm-text-soft);
    font-size: 0.77rem;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 0.45rem;
}

.payment-metric-card strong {
    display: block;
    color: var(--tvm-text);
    font-size: clamp(1.55rem, 2.4vw, 2rem);
    line-height: 1;
    font-weight: 850;
    letter-spacing: -0.03em;
}

.payment-metric-card small {
    margin-top: 0.55rem;
    color: var(--tvm-text-soft);
    line-height: 1.45;
}

.payment-metric-card.is-success strong {
    color: #137a58;
}

.payment-metric-card.is-warning strong,
.payment-metric-card.is-danger strong {
    color: var(--tvm-danger, #d00000);
}

.payment-list-panel .card-body {
    padding: 1.35rem !important;
}

.payment-list-header {
    margin-bottom: 1rem;
}

.payment-card-list {
    display: grid;
    gap: 0.85rem;
}

.payment-row-card {
    display: grid;
    grid-template-columns: minmax(260px, 1.35fr) minmax(360px, 1.65fr) auto;
    gap: 1rem;
    align-items: center;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.1rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.99), rgba(248,251,255,0.92));
    padding: 1rem;
}

.payment-row-title {
    color: var(--tvm-text);
    font-weight: 800;
    line-height: 1.35;
}

.payment-row-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem 0.7rem;
    margin-top: 0.35rem;
    color: var(--tvm-text-soft);
    font-size: 0.86rem;
}

.payment-row-note {
    margin-top: 0.65rem;
    display: inline-flex;
    align-items: center;
    width: fit-content;
    max-width: 100%;
    padding: 0.38rem 0.68rem;
    border-radius: 999px;
    background: rgba(18, 70, 160, 0.06);
    color: var(--tvm-text-soft);
    font-size: 0.8rem;
    font-weight: 700;
}

.payment-row-facts {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.55rem;
}

.payment-fact {
    min-height: 4.05rem;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 0.95rem;
    background: rgba(255, 255, 255, 0.82);
    padding: 0.65rem 0.75rem;
}

.payment-fact span {
    display: block;
    color: var(--tvm-text-soft);
    font-size: 0.72rem;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.25rem;
}

.payment-fact strong {
    display: block;
    color: var(--tvm-text);
    font-size: 0.9rem;
    line-height: 1.25;
    word-break: break-word;
}

.payment-fact-amount strong {
    font-size: 1rem;
}

.payment-row-actions {
    display: flex;
    justify-content: flex-end;
}

.payment-row-actions .btn {
    min-width: 92px;
}

@media (max-width: 1199.98px) {
    .payment-metric-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .payment-row-card {
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .payment-row-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 767.98px) {
    .payment-hero-soft .card-body,
    .payment-list-panel .card-body {
        padding: 1.05rem !important;
    }

    .payment-hero-actions,
    .payment-hero-actions .btn,
    .payment-row-actions .btn {
        width: 100%;
    }

    .payment-metric-grid,
    .payment-row-facts {
        grid-template-columns: 1fr;
    }
}

/* v0.6.63 Mein Bereich: Zahlungen ruhigeres Design */
.payment-page {
    gap: 1.15rem;
}

.payment-page .payment-hero-soft,
.payment-page .account-hero.payment-hero-soft {
    background: linear-gradient(180deg, rgba(255,255,255,0.99) 0%, rgba(248,251,255,0.98) 100%) !important;
    color: var(--tvm-text) !important;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.10) !important;
    box-shadow: var(--tvm-shadow-soft) !important;
}

.payment-page .payment-hero-soft::after {
    display: none !important;
}

.payment-page .payment-hero-soft .card-body {
    padding: 1.3rem 1.45rem !important;
}

.payment-page .payment-hero-main {
    align-items: center;
}

.payment-page .account-hero-kicker {
    background: rgba(220, 0, 0, 0.08);
    color: var(--tvm-danger, #d00000);
}

.payment-page .payment-hero-title {
    color: var(--tvm-text) !important;
    font-size: clamp(1.45rem, 2.1vw, 1.85rem);
}

.payment-page .payment-hero-text {
    color: var(--tvm-text-soft) !important;
    max-width: 58rem;
}

.payment-page .payment-hero-actions .btn-light {
    background: var(--tvm-danger, #e30613);
    border-color: var(--tvm-danger, #e30613);
    color: #fff;
    box-shadow: 0 12px 24px rgba(227, 6, 19, 0.14);
}

.payment-page .payment-hero-actions .btn-light:hover,
.payment-page .payment-hero-actions .btn-light:focus {
    background: #b80000;
    border-color: #b80000;
    color: #fff;
}

.payment-page .payment-hero-actions .btn-outline-light {
    background: #fff;
    border-color: rgba(18, 70, 160, 0.22);
    color: var(--tvm-text);
}

.payment-page .payment-hero-actions .btn-outline-light:hover,
.payment-page .payment-hero-actions .btn-outline-light:focus {
    background: rgba(18, 70, 160, 0.06);
    border-color: rgba(18, 70, 160, 0.30);
    color: var(--tvm-text);
}

.payment-page .payment-metric-grid {
    gap: 0.85rem;
}

.payment-page .payment-metric-card {
    padding: 0.95rem 1rem;
    border-radius: 1rem;
}

.payment-page .payment-metric-card strong {
    font-size: clamp(1.35rem, 2vw, 1.75rem);
}

.payment-page .payment-list-panel {
    overflow: hidden;
}

.payment-page .payment-list-header {
    padding-bottom: 0.9rem;
    border-bottom: 1px solid rgba(18, 70, 160, 0.08);
}

.payment-page .payment-card-list {
    gap: 0.7rem;
}

.payment-page .payment-row-card {
    grid-template-columns: minmax(260px, 1.4fr) minmax(300px, 1.35fr) auto;
    padding: 0.9rem;
    border-radius: 1rem;
}

.payment-page .payment-row-title {
    font-size: 0.98rem;
}

.payment-page .payment-row-facts {
    grid-template-columns: repeat(4, minmax(76px, 1fr));
    gap: 0.45rem;
}

.payment-page .payment-fact {
    min-height: 3.45rem;
    padding: 0.55rem 0.62rem;
    border-radius: 0.8rem;
}

.payment-page .payment-fact span {
    font-size: 0.68rem;
}

.payment-page .status-pill {
    padding: 0.34rem 0.56rem;
    font-size: 0.74rem;
}

@media (max-width: 1199.98px) {
    .payment-page .payment-row-card {
        grid-template-columns: 1fr;
    }

    .payment-page .payment-row-facts {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .payment-page .payment-hero-main {
        align-items: stretch;
    }

    .payment-page .payment-hero-actions,
    .payment-page .payment-hero-actions .btn {
        width: 100%;
    }

    .payment-page .payment-row-facts {
        grid-template-columns: 1fr;
    }
}

/* v0.6.64 Mein Bereich: Zahlungsdetail ruhiger und übersichtlicher */
.payment-detail-page {
    gap: 1.25rem;
}

.payment-detail-hero {
    overflow: hidden;
    background: linear-gradient(180deg, rgba(255,255,255,0.99) 0%, rgba(248,251,255,0.98) 100%) !important;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.10) !important;
    box-shadow: var(--tvm-shadow-soft) !important;
}

.payment-detail-hero .card-body {
    padding: 1.35rem 1.45rem !important;
}

.payment-detail-hero-main {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1.25rem;
    flex-wrap: wrap;
}

.payment-detail-page .account-hero-kicker {
    background: rgba(220, 0, 0, 0.08);
    color: var(--tvm-danger, #d00000);
    margin-bottom: 0.75rem;
}

.payment-detail-title {
    margin: 0;
    color: var(--tvm-text);
    font-size: clamp(1.5rem, 2.4vw, 2rem);
    line-height: 1.08;
    font-weight: 850;
    letter-spacing: -0.035em;
}

.payment-detail-text {
    margin-top: 0.45rem;
    color: var(--tvm-text-soft);
    max-width: 62rem;
    line-height: 1.55;
}

.payment-detail-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.85rem;
}

.payment-detail-meta > span:not(.status-pill) {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0.42rem 0.68rem;
    border-radius: 999px;
    background: rgba(18, 70, 160, 0.06);
    border: 1px solid rgba(18, 70, 160, 0.08);
    color: var(--tvm-text-soft);
    font-size: 0.82rem;
    font-weight: 700;
}

.payment-detail-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.65rem;
    flex-wrap: wrap;
}

.payment-detail-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.55fr) minmax(320px, 0.75fr);
    gap: 1.25rem;
    align-items: start;
}

.payment-detail-maincol,
.payment-detail-sidecol {
    min-width: 0;
}

.payment-detail-card .card-body {
    padding: 1.3rem !important;
}

.payment-detail-section-head {
    margin-bottom: 1rem;
}

.payment-detail-fact-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.75rem;
}

.payment-detail-fact {
    min-height: 5rem;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1rem;
    background: linear-gradient(180deg, rgba(248, 251, 255, 0.96), rgba(255,255,255,0.98));
    padding: 0.85rem 0.95rem;
}

.payment-detail-fact span,
.payment-transaction-meta span {
    display: block;
    color: var(--tvm-text-soft);
    font-size: 0.72rem;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: 0.055em;
    margin-bottom: 0.28rem;
}

.payment-detail-fact strong {
    display: block;
    color: var(--tvm-text);
    font-size: 0.98rem;
    line-height: 1.3;
    word-break: break-word;
}

.payment-detail-fact-amount strong {
    color: var(--tvm-danger, #d00000);
    font-size: 1.1rem;
}

.payment-detail-reference {
    margin-top: 1rem;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1rem;
    background: rgba(248, 251, 255, 0.78);
    padding: 0.85rem 0.95rem;
    color: var(--tvm-text);
}

.payment-detail-actionbox {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    margin-top: 1rem;
    border-radius: 1rem;
    padding: 1rem;
}

.payment-detail-actionbox strong,
.payment-detail-actionbox span {
    display: block;
}

.payment-detail-actionbox span {
    margin-top: 0.18rem;
    font-size: 0.9rem;
}

.payment-detail-actionbox.is-success {
    background: linear-gradient(180deg, rgba(236,252,245,0.98), rgba(227,249,239,0.96));
    color: #126949;
}

.payment-detail-actionbox.is-warning {
    background: linear-gradient(180deg, rgba(255,249,232,0.98), rgba(255,245,214,0.96));
    color: #8a5a17;
}

.payment-detail-actionbox-actions {
    display: flex;
    gap: 0.65rem;
    flex-wrap: wrap;
}

.payment-detail-actionbox-actions form {
    margin: 0;
}

.payment-transaction-list {
    display: grid;
    gap: 0.75rem;
}

.payment-transaction-card {
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1rem;
    background: linear-gradient(180deg, rgba(248,251,255,0.94), rgba(255,255,255,0.98));
    padding: 0.9rem 1rem;
}

.payment-transaction-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.payment-transaction-top strong {
    color: var(--tvm-text);
    line-height: 1.3;
}

.payment-transaction-top span {
    display: inline-flex;
    padding: 0.34rem 0.58rem;
    border-radius: 999px;
    background: rgba(18, 70, 160, 0.07);
    color: var(--tvm-text-soft);
    font-size: 0.78rem;
    font-weight: 800;
}

.payment-transaction-meta {
    display: grid;
    gap: 0.6rem;
}

.payment-transaction-meta strong {
    display: block;
    color: var(--tvm-text);
    font-size: 0.9rem;
    line-height: 1.35;
    word-break: break-word;
}

@media (max-width: 1199.98px) {
    .payment-detail-grid {
        grid-template-columns: 1fr;
    }

    .payment-detail-fact-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .payment-detail-hero .card-body,
    .payment-detail-card .card-body {
        padding: 1.05rem !important;
    }

    .payment-detail-actions,
    .payment-detail-actions .btn,
    .payment-detail-actionbox-actions,
    .payment-detail-actionbox-actions .btn,
    .payment-detail-actionbox-actions form {
        width: 100%;
    }

    .payment-detail-fact-grid {
        grid-template-columns: 1fr;
    }

    .payment-detail-actionbox {
        align-items: stretch;
    }
}

/* v0.6.65 Meine Rechnungen: ruhige Kartenansicht */
.invoice-page .account-hero,
.invoice-hero-soft {
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,251,255,0.98)) !important;
    color: var(--tvm-text) !important;
    border: 1px solid rgba(18, 70, 160, 0.08) !important;
    box-shadow: var(--tvm-shadow-soft) !important;
}

.invoice-page .account-hero::after {
    background: radial-gradient(circle, rgba(var(--tvm-accent-rgb), 0.12), transparent 68%);
}

.invoice-page .account-hero-kicker {
    background: rgba(220, 0, 0, 0.08);
    color: #b00000;
}

.invoice-hero-main {
    position: relative;
    z-index: 1;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1.25rem;
    flex-wrap: wrap;
}

.invoice-hero-title {
    margin: 0.7rem 0 0.35rem;
    color: var(--tvm-text);
    font-size: clamp(1.55rem, 2.7vw, 2.15rem);
    font-weight: 850;
    letter-spacing: -0.035em;
}

.invoice-hero-text {
    max-width: 60rem;
    margin: 0;
    color: var(--tvm-text-soft);
    line-height: 1.6;
}

.invoice-hero-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.65rem;
    flex-wrap: wrap;
}

.invoice-hero-actions .btn-outline-secondary {
    background: rgba(255,255,255,0.8);
}

.invoice-metric-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.invoice-metric-card {
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.2rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,251,255,0.98));
    box-shadow: var(--tvm-shadow-soft);
    padding: 1rem 1.1rem;
    min-height: 7.25rem;
}

.invoice-metric-card span,
.invoice-fact span {
    display: block;
    color: var(--tvm-text-soft);
    font-size: 0.76rem;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: 0.055em;
}

.invoice-metric-card strong {
    display: block;
    margin-top: 0.25rem;
    color: var(--tvm-danger, #d00000);
    font-size: 1.8rem;
    line-height: 1;
    font-weight: 850;
}

.invoice-metric-card small {
    display: block;
    margin-top: 0.45rem;
    color: var(--tvm-text-soft);
    line-height: 1.4;
}

.invoice-metric-card.is-success strong { color: #137a58; }
.invoice-metric-card.is-warning strong { color: #99621a; }
.invoice-metric-card.is-danger strong { color: #b03a48; }

.invoice-list-panel .card-body {
    padding: 1.25rem !important;
}

.invoice-list-header {
    align-items: center;
}

.invoice-card-list {
    display: grid;
    gap: 0.85rem;
}

.invoice-row-card {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(320px, 0.95fr) auto;
    gap: 1rem;
    align-items: center;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.1rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,251,255,0.82));
    padding: 1rem;
}

.invoice-row-main {
    min-width: 0;
    display: grid;
    gap: 0.65rem;
}

.invoice-row-title {
    color: var(--tvm-text);
    font-weight: 850;
    line-height: 1.25;
}

.invoice-row-description {
    margin-top: 0.2rem;
    color: var(--tvm-text-soft);
    font-size: 0.9rem;
    line-height: 1.45;
}

.invoice-row-facts {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.65rem;
}

.invoice-fact {
    min-height: 4.6rem;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 0.95rem;
    background: rgba(255,255,255,0.76);
    padding: 0.75rem 0.85rem;
}

.invoice-fact strong {
    display: block;
    margin-top: 0.25rem;
    color: var(--tvm-text);
    font-size: 0.95rem;
    line-height: 1.3;
}

.invoice-fact-amount strong {
    color: var(--tvm-danger, #d00000);
    font-size: 1.05rem;
}

.invoice-row-actions {
    display: flex;
    justify-content: flex-end;
}

@media (max-width: 1199.98px) {
    .invoice-row-card {
        grid-template-columns: 1fr;
    }

    .invoice-row-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 991.98px) {
    .invoice-metric-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .invoice-row-facts {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .invoice-hero-actions,
    .invoice-hero-actions .btn,
    .invoice-row-actions .btn {
        width: 100%;
    }

    .invoice-metric-grid,
    .invoice-row-facts {
        grid-template-columns: 1fr;
    }
}

/* v0.6.67 Mein Bereich Dashboard Feinschliff */
.account-home-page {
    display: grid;
    gap: 1.35rem;
}

.account-home-page .account-home-hero {
    background: linear-gradient(135deg, rgba(255,255,255,0.99) 0%, rgba(248,251,255,0.98) 100%);
    border: 1px solid rgba(18, 70, 160, 0.08) !important;
    box-shadow: 0 14px 34px rgba(15, 40, 75, 0.06) !important;
}

.account-home-hero-main {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1.25rem;
    flex-wrap: wrap;
}

.account-home-title {
    margin: 0;
    font-size: clamp(1.85rem, 3vw, 2.55rem);
    font-weight: 800;
    letter-spacing: -0.04em;
    color: var(--tvm-text);
}

.account-home-lead {
    margin: 0.55rem 0 0;
    max-width: 760px;
    color: var(--tvm-text-soft);
    line-height: 1.65;
}

.account-home-actions,
.account-home-section-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
}

.account-home-profile-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.75rem;
}

.account-home-profile-item,
.account-home-facts > div {
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1rem;
    background: rgba(248, 251, 255, 0.82);
    padding: 0.82rem 0.95rem;
    min-width: 0;
}

.account-home-profile-item span,
.account-home-facts span {
    display: block;
    color: var(--tvm-text-soft);
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    margin-bottom: 0.25rem;
}

.account-home-profile-item strong,
.account-home-facts strong {
    display: block;
    color: var(--tvm-text);
    font-weight: 800;
    line-height: 1.3;
    word-break: break-word;
}

.account-home-metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.account-home-metrics .stat-card {
    min-height: 0;
}

.account-home-metrics .card-body {
    padding: 1.1rem 1.15rem !important;
}

.account-home-metrics .stat-value {
    font-size: clamp(1.8rem, 3vw, 2.2rem);
    color: var(--tvm-danger, #d00000);
}

.account-home-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.55fr) minmax(300px, 0.85fr);
    gap: 1.35rem;
    align-items: start;
}

.account-home-main,
.account-home-sidebar {
    min-width: 0;
}

.account-home-sidebar {
    display: grid;
    gap: 1.25rem;
}

.account-home-two-col {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.25rem;
}

.account-home-section .card-body {
    padding: 1.25rem !important;
}

.account-home-section-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}

.account-home-section-head.compact {
    align-items: center;
}

.account-home-section-head h2 {
    margin: 0;
    font-size: 1.15rem;
    font-weight: 850;
    letter-spacing: -0.025em;
    color: var(--tvm-text);
}

.account-home-section-head p {
    margin: 0.25rem 0 0;
    color: var(--tvm-text-soft);
    line-height: 1.55;
}

.account-home-card-grid,
.account-home-booking-list,
.account-home-mini-list {
    display: grid;
    gap: 0.85rem;
}

.account-home-booking-card {
    display: grid;
    grid-template-columns: minmax(145px, 0.8fr) minmax(0, 1.35fr) minmax(140px, 0.7fr) auto;
    gap: 0.95rem;
    align-items: center;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.1rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,251,255,0.86));
    padding: 0.95rem 1rem;
}

.account-home-booking-date strong,
.account-home-booking-info h3 {
    display: block;
    color: var(--tvm-text);
    font-weight: 850;
    line-height: 1.3;
}

.account-home-booking-date span,
.account-home-booking-info div {
    display: block;
    margin-top: 0.25rem;
    color: var(--tvm-text-soft);
    font-size: 0.88rem;
}

.account-home-booking-info h3 {
    margin: 0;
    font-size: 1rem;
}

.account-home-booking-meta {
    display: grid;
    gap: 0.35rem;
    justify-items: start;
}

.account-home-booking-meta strong {
    font-weight: 850;
    color: var(--tvm-text);
}

.account-home-booking-actions {
    display: flex;
    gap: 0.5rem;
    justify-content: flex-end;
    flex-wrap: wrap;
}

.account-home-booking-actions form {
    margin: 0;
}

.account-home-mini-card {
    display: block;
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1rem;
    background: rgba(248, 251, 255, 0.82);
    padding: 0.9rem 0.95rem;
    color: var(--tvm-text);
    text-decoration: none;
}

.account-home-mini-card:hover {
    color: var(--tvm-text);
    border-color: rgba(18, 70, 160, 0.16);
    background: #fff;
}

.account-home-mini-card span {
    display: block;
    color: var(--tvm-text);
    font-weight: 750;
    line-height: 1.35;
}

.account-home-mini-card div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-top: 0.5rem;
}

.account-home-mini-card em {
    color: var(--tvm-text-soft);
    font-size: 0.84rem;
    font-style: normal;
}

.account-home-mini-card strong {
    color: var(--tvm-text);
    font-weight: 850;
    white-space: nowrap;
}

.account-home-empty {
    border: 1px dashed rgba(18, 70, 160, 0.16);
    border-radius: 1rem;
    background: rgba(248, 251, 255, 0.78);
    padding: 1.15rem;
    color: var(--tvm-text-soft);
    text-align: center;
}

.account-home-empty.small {
    padding: 0.9rem;
    font-size: 0.9rem;
}

.account-home-notice {
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1rem;
    padding: 0.95rem 1rem;
    background: rgba(248, 251, 255, 0.88);
}

.account-home-notice strong,
.account-home-notice span {
    display: block;
}

.account-home-notice span {
    margin-top: 0.25rem;
    color: var(--tvm-text-soft);
    line-height: 1.5;
}

.account-home-facts {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
}

.account-home-inline-form {
    border-top: 1px solid rgba(18, 70, 160, 0.08);
    padding-top: 1rem;
}

@media (max-width: 1199.98px) {
    .account-home-layout {
        grid-template-columns: 1fr;
    }

    .account-home-sidebar {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .account-home-booking-card {
        grid-template-columns: minmax(140px, 0.8fr) minmax(0, 1.3fr);
    }

    .account-home-booking-meta,
    .account-home-booking-actions {
        justify-content: flex-start;
        justify-items: start;
    }
}

@media (max-width: 991.98px) {
    .account-home-profile-grid,
    .account-home-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .account-home-two-col,
    .account-home-sidebar {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .account-home-hero-main,
    .account-home-section-head {
        display: grid;
    }

    .account-home-actions .btn,
    .account-home-section-actions .btn {
        width: 100%;
    }

    .account-home-booking-card {
        grid-template-columns: 1fr;
    }

    .account-home-booking-actions,
    .account-home-booking-actions .btn,
    .account-home-booking-actions form,
    .account-home-booking-actions form .btn {
        width: 100%;
    }
}

@media (max-width: 575.98px) {
    .account-home-profile-grid,
    .account-home-metrics,
    .account-home-facts {
        grid-template-columns: 1fr;
    }
}

/* v0.6.68 Mein Profil: ruhigeres Layout und saubere Profilkarten */
.profile-page-shell {
    gap: 1.35rem;
}

.profile-page-shell .account-hero {
    background: linear-gradient(180deg, rgba(255,255,255,0.99) 0%, rgba(248,251,255,0.98) 100%) !important;
    color: var(--tvm-text) !important;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.10) !important;
    box-shadow: var(--tvm-shadow-soft) !important;
}

.profile-page-shell .account-hero::after {
    background: radial-gradient(circle, rgba(var(--tvm-accent-rgb), 0.12), transparent 68%) !important;
}

.profile-page-shell .account-hero .card-body {
    padding: 1.45rem 1.55rem !important;
}

.profile-page-shell .account-hero-kicker {
    background: rgba(220, 38, 38, 0.08) !important;
    color: var(--tvm-danger, #c00000) !important;
}

.profile-page-shell .account-hero-title {
    color: var(--tvm-text) !important;
    font-size: clamp(1.65rem, 2.4vw, 2.2rem);
    margin-top: 0.65rem;
}

.profile-page-shell .account-hero-text {
    color: var(--tvm-text-soft) !important;
    max-width: 58rem;
}

.profile-page-shell .account-hero-actions .btn-light {
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.10);
    background: #fff;
    color: var(--tvm-text);
}

.profile-page-shell .account-hero-actions .btn-outline-light {
    border-color: rgba(220, 38, 38, 0.28);
    color: var(--tvm-danger, #c00000);
    background: rgba(255,255,255,0.84);
}

.profile-overview-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.95rem;
}

.profile-overview-card {
    min-height: 100%;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.09);
    border-radius: 1.1rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.96) 100%);
    box-shadow: var(--tvm-shadow-soft);
    padding: 1rem 1.05rem;
}

.profile-overview-card span,
.profile-overview-card small {
    display: block;
    color: var(--tvm-text-soft);
}

.profile-overview-card span {
    font-size: 0.76rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 0.4rem;
}

.profile-overview-card strong {
    display: block;
    color: var(--tvm-text);
    font-size: 1rem;
    line-height: 1.25;
    word-break: break-word;
}

.profile-overview-card small {
    margin-top: 0.25rem;
    font-size: 0.84rem;
    line-height: 1.4;
    word-break: break-word;
}

.profile-page-shell .page-section-tabs {
    position: static;
    top: auto;
    padding: 0.85rem;
    margin-bottom: 0.1rem !important;
    border-radius: 1.2rem;
    background: rgba(255,255,255,0.94);
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.08);
    box-shadow: var(--tvm-shadow-soft);
}

.profile-page-shell .page-section-tab {
    min-height: 2.35rem;
    padding: 0.55rem 0.82rem;
    background: rgba(248,251,255,0.96);
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.10);
    color: var(--tvm-text-soft);
    box-shadow: none;
}

.profile-page-shell .page-section-tab:hover,
.profile-page-shell .page-section-tab.is-active {
    background: linear-gradient(135deg, #e30613 0%, #ff4b55 100%);
    border-color: transparent;
    color: #fff;
    box-shadow: 0 10px 22px rgba(227, 6, 19, 0.16);
}

.profile-page-shell .account-panel {
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.08) !important;
    box-shadow: var(--tvm-shadow-soft) !important;
}

.profile-page-shell .account-panel > .card-body {
    padding: 1.35rem !important;
}

.profile-page-shell .account-form-section + .account-form-section {
    margin-top: 1.25rem;
    padding-top: 1.25rem;
}

.profile-page-shell .account-form-title {
    margin-bottom: 0.8rem;
}

.profile-page-shell .context-mini-row {
    align-items: center;
    padding: 0.68rem 0;
}

.profile-page-shell .context-mini-value {
    word-break: break-word;
}

.profile-page-shell .sticky-stack {
    top: 100px;
}

@media (max-width: 1199.98px) {
    .profile-overview-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .profile-page-shell .sticky-stack {
        position: static;
    }
}

@media (max-width: 767.98px) {
    .profile-page-shell .account-hero .card-body {
        padding: 1.2rem !important;
    }

    .profile-overview-grid {
        grid-template-columns: 1fr;
    }

    .profile-page-shell .page-section-tabs {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.5rem;
    }

    .profile-page-shell .page-section-tab {
        width: auto;
        justify-content: center;
        text-align: center;
    }
}

@media (max-width: 480px) {
    .profile-page-shell .page-section-tabs {
        grid-template-columns: 1fr;
    }
}


/* v0.7.59 Profil: Feinschliff fuer neues Mein-Bereich-Layout */
.account-profile-page .account-home-metrics .stat-value.is-text {
    font-size: clamp(1rem, 1.45vw, 1.18rem);
    line-height: 1.28;
    color: var(--tvm-text);
    word-break: break-word;
}

.account-profile-page .profile-jump-section .page-section-tabs {
    box-shadow: none;
}

.account-profile-page .sticky-stack {
    top: 100px;
}

@media (max-width: 991.98px) {
    .account-profile-page .sticky-stack {
        position: static;
    }
}

/* v0.6.70 Mein Bereich: Buchungsuebersicht Feinschliff */
.bookings-page-shell .account-panel {
    overflow: hidden;
}

.bookings-page-shell .account-filter-bar {
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.10);
    border-radius: 1.15rem;
    background: linear-gradient(180deg, rgba(248,251,255,0.96) 0%, rgba(255,255,255,0.98) 100%);
    padding: 1rem;
}

.booking-help-card {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    padding: 0.9rem 1rem;
    border-radius: 1rem;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.09);
    background: rgba(248, 251, 255, 0.88);
    color: var(--tvm-text-soft);
    line-height: 1.55;
}

.booking-help-card strong {
    color: var(--tvm-text);
    white-space: nowrap;
}

.booking-card-list {
    display: grid;
    gap: 0.85rem;
}

.booking-row-card {
    display: grid;
    grid-template-columns: minmax(260px, 1.4fr) minmax(330px, 1.2fr) auto;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.09);
    border-radius: 1.15rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.96) 100%);
    box-shadow: var(--tvm-shadow-soft);
}

.booking-row-main {
    display: grid;
    grid-template-columns: minmax(135px, 0.75fr) minmax(0, 1fr);
    gap: 1rem;
    align-items: center;
    min-width: 0;
}

.booking-row-date,
.booking-row-title {
    display: grid;
    gap: 0.18rem;
    min-width: 0;
}

.booking-row-date strong,
.booking-row-title strong {
    color: var(--tvm-text);
    font-weight: 800;
    line-height: 1.3;
}

.booking-row-date span,
.booking-row-title span {
    color: var(--tvm-text-soft);
    font-size: 0.88rem;
    line-height: 1.35;
}

.booking-row-facts {
    display: grid;
    grid-template-columns: repeat(3, minmax(92px, 1fr));
    gap: 0.65rem;
}

.booking-mini-fact {
    min-height: 4.3rem;
    padding: 0.72rem 0.8rem;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.08);
    border-radius: 0.95rem;
    background: rgba(255,255,255,0.72);
}

.booking-mini-fact span {
    display: block;
    color: var(--tvm-text-soft);
    font-size: 0.72rem;
    line-height: 1.15;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.24rem;
}

.booking-mini-fact strong {
    display: block;
    color: var(--tvm-text);
    font-size: 0.92rem;
    line-height: 1.25;
}

.booking-row-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.booking-row-actions form {
    margin: 0;
}

.booking-row-actions .btn {
    white-space: nowrap;
}

@media (max-width: 1199.98px) {
    .booking-row-card {
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .booking-row-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 767.98px) {
    .booking-help-card,
    .booking-row-main {
        grid-template-columns: 1fr;
        display: grid;
    }

    .booking-help-card strong {
        white-space: normal;
    }

    .booking-row-facts {
        grid-template-columns: 1fr;
    }

    .booking-row-actions .btn,
    .booking-row-actions form,
    .booking-row-actions form .btn {
        width: 100%;
    }
}

/* v0.6.71 invoice detail polish */
.invoice-detail-page .invoice-detail-hero {
    background: linear-gradient(180deg, rgba(255,255,255,0.99) 0%, rgba(248,251,255,0.97) 100%);
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.08);
}

.invoice-item-list {
    display: grid;
    gap: 0.75rem;
}

.invoice-item-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.95rem 1rem;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.08);
    border-radius: 1rem;
    background: rgba(248, 251, 255, 0.86);
}

.invoice-item-main {
    min-width: 0;
}

.invoice-item-title {
    font-weight: 800;
    color: var(--tvm-text);
    line-height: 1.35;
}

.invoice-item-meta {
    margin-top: 0.25rem;
    color: var(--tvm-text-soft);
    font-size: 0.88rem;
}

.invoice-item-total {
    flex: 0 0 auto;
    font-weight: 800;
    color: var(--tvm-primary-dark);
    white-space: nowrap;
}

.invoice-total-box {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.1rem;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.10);
    border-radius: 1rem;
    background: #fff;
}

.invoice-total-box span {
    color: var(--tvm-text-soft);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 0.8rem;
}

.invoice-total-box strong {
    color: var(--tvm-primary-dark);
    font-size: 1.1rem;
}

@media (max-width: 575.98px) {
    .invoice-item-card,
    .invoice-total-box {
        align-items: flex-start;
        flex-direction: column;
    }
}

/* v0.6.74 trainer/workspace design restore */
.trainer-dashboard-page,
.trainer-cover-page,
.trainer-session-page,
.trainer-attendance-page,
.trainer-checkin-page {
    display: grid;
    gap: 1.15rem;
}

.trainer-dashboard-hero,
.trainer-cover-hero,
.trainer-attendance-hero,
.trainer-checkin-hero,
.trainer-session-summary-card,
.trainer-attendance-panel,
.trainer-cover-filter,
.trainer-cover-section,
.trainer-checkin-scan-card,
.trainer-checkin-manual-card,
.trainer-checkin-side-card,
.trainer-session-stat-card,
.trainer-course-stat-card,
.trainer-participant-card,
.trainer-info-box,
.trainer-status-box {
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.08);
    border-radius: var(--tvm-radius-lg);
    box-shadow: var(--tvm-shadow-soft);
    background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,251,255,0.92));
}

.trainer-dashboard-hero,
.trainer-cover-hero,
.trainer-attendance-hero,
.trainer-checkin-hero {
    overflow: hidden;
    position: relative;
}

.trainer-dashboard-hero::before,
.trainer-cover-hero::before,
.trainer-attendance-hero::before,
.trainer-checkin-hero::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 5px;
    background: linear-gradient(90deg, var(--tvm-primary), var(--tvm-accent));
}

.trainer-dashboard-hero-top,
.trainer-cover-hero-top,
.trainer-attendance-hero-top,
.trainer-checkin-hero,
.trainer-panel-head,
.trainer-section-head,
.trainer-cover-filter-head,
.trainer-cover-section-head,
.trainer-session-summary-head,
.trainer-attendance-section-head,
.trainer-checkin-card-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

.trainer-dashboard-actions,
.trainer-cover-actions,
.trainer-checkin-hero-actions,
.trainer-session-actions,
.trainer-participant-actions,
.trainer-sticky-actions,
.trainer-attendance-filter-actions,
.trainer-cover-filter-buttons {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.6rem;
    flex-wrap: wrap;
}

.trainer-metric-grid,
.trainer-cover-metrics,
.trainer-attendance-metrics,
.trainer-checkin-metrics,
.trainer-course-stat-grid,
.trainer-session-stat-list,
.trainer-session-keyfacts,
.trainer-help-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.85rem;
}

.trainer-metric-card,
.trainer-cover-metric,
.trainer-attendance-metric,
.trainer-checkin-metric,
.trainer-course-stat-card,
.trainer-session-stat-card {
    padding: 1rem;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.08);
    border-radius: var(--tvm-radius);
    background: rgba(255,255,255,0.86);
    box-shadow: 0 8px 20px rgba(var(--tvm-text-rgb), 0.04);
}

.trainer-metric-card span,
.trainer-cover-metric span,
.trainer-attendance-metric span,
.trainer-checkin-metric span,
.trainer-session-date span,
.trainer-session-stats span,
.trainer-cover-request-info span,
.trainer-course-stat-main span,
.trainer-participant-meta,
.trainer-participant-note,
.trainer-checkin-camera-hint {
    color: var(--tvm-text-soft);
    font-size: 0.86rem;
}

.trainer-metric-card strong,
.trainer-cover-metric strong,
.trainer-attendance-metric strong,
.trainer-checkin-metric strong {
    display: block;
    margin-top: 0.2rem;
    color: var(--tvm-primary-dark);
    font-size: clamp(1.5rem, 2.2vw, 2.1rem);
    line-height: 1.05;
}

.trainer-metric-card small,
.trainer-cover-metric small,
.trainer-attendance-metric small,
.trainer-checkin-metric small {
    display: block;
    margin-top: 0.35rem;
    color: var(--tvm-text-soft);
}

.trainer-dashboard-section,
.trainer-attendance-section {
    padding: 1.2rem;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.08);
    border-radius: var(--tvm-radius-lg);
    background: rgba(255,255,255,0.72);
    box-shadow: var(--tvm-shadow-soft);
}

.trainer-section-head h2,
.trainer-cover-section-head h2,
.trainer-attendance-section-head h2,
.trainer-cover-filter-head h2 {
    margin: 0;
    color: var(--tvm-text);
    font-weight: 850;
}

.trainer-section-head p,
.trainer-cover-section-head p,
.trainer-attendance-section-head p,
.trainer-cover-filter-head p {
    margin: 0.25rem 0 0;
    color: var(--tvm-text-soft);
}

.trainer-quick-grid,
.trainer-notice-grid,
.trainer-cover-response-grid,
.trainer-participant-grid,
.trainer-checkin-participants {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
}

.trainer-quick-card,
.trainer-notice-card,
.trainer-cover-response-card,
.trainer-participant-card {
    display: block;
    padding: 1rem;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.08);
    border-radius: var(--tvm-radius);
    background: #fff;
    color: inherit;
    text-decoration: none;
    box-shadow: 0 8px 22px rgba(var(--tvm-text-rgb), 0.04);
}

.trainer-quick-card:hover,
.trainer-cover-request-card:hover,
.trainer-session-card:hover,
.trainer-participant-card:hover {
    transform: translateY(-1px);
    box-shadow: var(--tvm-shadow-soft);
}

.trainer-quick-card strong,
.trainer-notice-card strong,
.trainer-participant-name,
.trainer-cover-request-title,
.trainer-session-main strong {
    display: block;
    color: var(--tvm-text);
    font-weight: 850;
}

.trainer-quick-card span,
.trainer-notice-card span {
    display: block;
    margin-top: 0.3rem;
    color: var(--tvm-text-soft);
}

.trainer-session-list,
.trainer-cover-card-list,
.trainer-participant-list {
    display: grid;
    gap: 0.8rem;
}

.trainer-session-card,
.trainer-cover-request-card {
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) minmax(160px, 0.7fr) minmax(150px, 0.8fr) auto;
    align-items: center;
    gap: 1rem;
    padding: 1rem;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.08);
    border-radius: var(--tvm-radius);
    background: #fff;
    box-shadow: 0 8px 22px rgba(var(--tvm-text-rgb), 0.04);
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.trainer-cover-request-card {
    grid-template-columns: minmax(0, 1.65fr) minmax(180px, 0.75fr) auto;
}

.trainer-session-main,
.trainer-cover-request-main,
.trainer-participant-main {
    min-width: 0;
}

.trainer-session-main span,
.trainer-cover-request-meta,
.trainer-cover-response-meta,
.trainer-session-stat-course,
.trainer-course-stat-footer {
    display: block;
    margin-top: 0.2rem;
    color: var(--tvm-text-soft);
    font-size: 0.9rem;
}

.trainer-session-date strong,
.trainer-cover-request-info strong {
    display: block;
    color: var(--tvm-primary-dark);
    font-weight: 850;
}

.trainer-session-stats,
.trainer-course-stat-values,
.trainer-session-stat-values {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.trainer-session-stats div,
.trainer-course-stat-values div,
.trainer-session-stat-values div {
    min-width: 72px;
    padding: 0.55rem 0.7rem;
    border-radius: 0.85rem;
    background: rgba(var(--tvm-primary-rgb), 0.055);
}

.trainer-session-stats strong,
.trainer-course-stat-values strong,
.trainer-session-stat-values strong {
    display: block;
    color: var(--tvm-text);
    font-weight: 850;
}

.trainer-cover-chip-row,
.trainer-attendance-badges,
.trainer-participant-badges {
    display: flex;
    gap: 0.45rem;
    flex-wrap: wrap;
    margin-top: 0.55rem;
}

.badge-soft,
.list-inline-badge,
.quick-note,
.trainer-count-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    border-radius: 999px;
    padding: 0.35rem 0.65rem;
    font-size: 0.78rem;
    font-weight: 800;
    line-height: 1;
    background: rgba(var(--tvm-primary-rgb), 0.08);
    color: var(--tvm-primary-dark);
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.08);
}

.badge-soft-success { background: rgba(25, 135, 84, 0.10); color: #137348; border-color: rgba(25, 135, 84, 0.14); }
.badge-soft-warning { background: rgba(255, 193, 7, 0.15); color: #8a6400; border-color: rgba(255, 193, 7, 0.18); }
.badge-soft-danger { background: rgba(220, 53, 69, 0.10); color: #a52834; border-color: rgba(220, 53, 69, 0.14); }
.badge-soft-info { background: rgba(13, 202, 240, 0.12); color: #087990; border-color: rgba(13, 202, 240, 0.16); }
.badge-soft-secondary { background: rgba(108, 117, 125, 0.10); color: #596168; border-color: rgba(108, 117, 125, 0.14); }
.badge-soft-primary { background: rgba(var(--tvm-primary-rgb), 0.10); color: var(--tvm-primary-dark); border-color: rgba(var(--tvm-primary-rgb), 0.14); }

.trainer-cover-filter-form,
.trainer-attendance-filter-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.9rem;
    align-items: end;
}

.trainer-attendance-search {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.7rem;
}

.trainer-session-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.65fr) minmax(280px, 0.8fr);
    gap: 1rem;
    align-items: start;
}

.trainer-checkin-hero-content,
.trainer-checkin-hero-text,
.trainer-checkin-hints {
    display: grid;
    gap: 0.8rem;
}

.trainer-checkin-camera {
    min-height: 280px;
    border: 1px dashed rgba(var(--tvm-primary-rgb), 0.22);
    border-radius: var(--tvm-radius);
    background: rgba(var(--tvm-primary-rgb), 0.04);
    display: grid;
    place-items: center;
    overflow: hidden;
}

.trainer-checkin-status,
.trainer-attendance-empty,
.empty-panel,
.empty-state {
    padding: 1rem;
    border-radius: var(--tvm-radius);
    border: 1px dashed rgba(var(--tvm-primary-rgb), 0.18);
    background: rgba(var(--tvm-primary-rgb), 0.04);
}

.empty-panel-title {
    font-weight: 850;
    color: var(--tvm-text);
}

.empty-panel-text {
    margin: 0.25rem 0 0;
}

.trainer-inline-cover-form {
    display: grid;
    gap: 0.75rem;
    padding: 1rem;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.08);
    border-radius: var(--tvm-radius);
    background: rgba(255,255,255,0.74);
}

.trainer-sticky-actions {
    position: sticky;
    bottom: 1rem;
    z-index: 5;
    padding: 0.75rem;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.08);
    border-radius: var(--tvm-radius);
    background: rgba(255,255,255,0.94);
    box-shadow: var(--tvm-shadow-soft);
}

@media (max-width: 1199.98px) {
    .trainer-metric-grid,
    .trainer-cover-metrics,
    .trainer-attendance-metrics,
    .trainer-checkin-metrics,
    .trainer-course-stat-grid,
    .trainer-session-stat-list,
    .trainer-session-keyfacts,
    .trainer-help-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .trainer-session-card,
    .trainer-cover-request-card,
    .trainer-session-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .trainer-quick-grid,
    .trainer-notice-grid,
    .trainer-cover-response-grid,
    .trainer-participant-grid,
    .trainer-checkin-participants,
    .trainer-cover-filter-form,
    .trainer-attendance-filter-grid,
    .trainer-attendance-search {
        grid-template-columns: 1fr;
    }

    .trainer-dashboard-section,
    .trainer-attendance-section {
        padding: 1rem;
    }
}

@media (max-width: 575.98px) {
    .trainer-metric-grid,
    .trainer-cover-metrics,
    .trainer-attendance-metrics,
    .trainer-checkin-metrics,
    .trainer-course-stat-grid,
    .trainer-session-stat-list,
    .trainer-session-keyfacts,
    .trainer-help-grid {
        grid-template-columns: 1fr;
    }

    .trainer-dashboard-actions,
    .trainer-cover-actions,
    .trainer-session-actions,
    .trainer-sticky-actions,
    .trainer-cover-filter-buttons,
    .trainer-attendance-filter-actions {
        justify-content: stretch;
    }

    .trainer-dashboard-actions .btn,
    .trainer-cover-actions .btn,
    .trainer-session-actions .btn,
    .trainer-sticky-actions .btn,
    .trainer-cover-filter-buttons .btn,
    .trainer-attendance-filter-actions .btn {
        width: 100%;
    }
}

/* E-Mail-Vorlagen: direkte Vorschau beim Bearbeiten */
.email-live-preview-box {
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 18px;
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
    padding: 1rem;
    box-shadow: 0 14px 35px rgba(15, 23, 42, .07);
}

.email-live-preview-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: .75rem;
    margin-bottom: .85rem;
}

.email-live-preview-header h3 {
    font-size: 1rem;
    margin: 0;
    font-weight: 700;
    color: #111827;
}

.email-preview-badge {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: .25rem .55rem;
    font-size: .72rem;
    font-weight: 700;
    color: #991b1b;
    background: #fef2f2;
    border: 1px solid #fee2e2;
    white-space: nowrap;
}

.email-mini-shell {
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 14px;
    overflow: hidden;
    background: #fff;
}

.email-mini-subject {
    padding: .8rem .9rem;
    font-weight: 700;
    color: #111827;
    border-bottom: 1px solid rgba(15, 23, 42, .08);
    background: #f9fafb;
}

.email-mini-body {
    margin: 0;
    padding: .9rem;
    min-height: 150px;
    max-height: 310px;
    overflow: auto;
    white-space: pre-wrap;
    word-break: break-word;
    font-family: inherit;
    font-size: .9rem;
    line-height: 1.55;
    color: #374151;
    background: #fff;
}

.email-live-preview-note {
    margin: .75rem 0 0;
    color: #6b7280;
    font-size: .82rem;
    line-height: 1.45;
}

/* Mobile Bereichs-Navigation: ersetzt die alten nicht scrollbaren Dropdowns in Admin-, Trainer- und Nutzerbereich. */
.backend-mobile-menu {
    margin-top: 1rem;
}

.backend-mobile-menu-button {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.9rem;
    min-height: 54px;
    padding: 0.75rem 0.95rem;
    text-align: left;
    box-shadow: var(--tvm-shadow-soft);
}

.backend-mobile-menu-current {
    display: inline-flex;
    align-items: center;
    max-width: 48%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    padding: 0.25rem 0.55rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.18);
    font-size: 0.78rem;
    font-weight: 800;
}

.backend-mobile-offcanvas {
    --bs-offcanvas-width: min(92vw, 390px);
    background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,251,255,0.98) 100%);
}

.backend-mobile-offcanvas .offcanvas-header {
    align-items: flex-start;
    border-bottom: 1px solid var(--tvm-border);
    padding: 1.1rem 1.1rem 0.95rem;
}

.backend-mobile-offcanvas .offcanvas-body {
    overflow-y: auto;
    padding: 1rem;
    -webkit-overflow-scrolling: touch;
}

.backend-mobile-kicker,
.backend-mobile-nav-title {
    color: var(--tvm-text-soft);
    font-size: 0.74rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.backend-mobile-offcanvas .offcanvas-title {
    margin-top: 0.15rem;
    color: var(--tvm-text);
    font-weight: 900;
}

.backend-mobile-nav-section + .backend-mobile-nav-section {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--tvm-border);
}

.backend-mobile-nav-title {
    margin-bottom: 0.65rem;
}

.backend-mobile-nav-list {
    display: grid;
    gap: 0.45rem;
}

.backend-mobile-nav-link {
    display: grid;
    gap: 0.14rem;
    padding: 0.78rem 0.9rem;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.08);
    border-radius: var(--tvm-radius);
    background: rgba(255, 255, 255, 0.78);
    color: var(--tvm-text);
    font-weight: 800;
    text-decoration: none;
}

.backend-mobile-nav-link small {
    color: var(--tvm-text-soft);
    font-size: 0.78rem;
    font-weight: 600;
    line-height: 1.25;
}

.backend-mobile-nav-link:hover,
.backend-mobile-nav-link:focus {
    border-color: rgba(var(--tvm-primary-rgb), 0.18);
    background: rgba(var(--tvm-primary-rgb), 0.05);
    color: var(--tvm-primary-dark);
}

.backend-mobile-nav-link.is-active {
    border-color: rgba(var(--tvm-primary-rgb), 0.22);
    background: linear-gradient(135deg, rgba(var(--tvm-primary-rgb), 0.11), rgba(var(--tvm-accent-rgb), 0.11));
    color: var(--tvm-primary-dark);
    box-shadow: inset 0 0 0 1px rgba(var(--tvm-primary-rgb), 0.06);
}

@media (max-width: 991.98px) {
    .backend-sidebar {
        overflow: visible;
    }

    .backend-sidebar-head {
        margin-bottom: 0.85rem;
    }
}


/* SEO-Startseite */
.public-start-hero {
    position: relative;
    overflow: hidden;
}
.public-start-hero::after {
    content: "";
    position: absolute;
    inset: auto -80px -120px auto;
    width: 280px;
    height: 280px;
    border-radius: 999px;
    background: rgba(var(--tvm-primary-rgb), 0.10);
    pointer-events: none;
}
.public-feature-grid-compact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.public-start-course-card,
.public-start-session-card {
    display: flex;
    gap: 0.75rem;
    border: 1px solid var(--tvm-border);
    border-radius: 16px;
    background: rgba(255,255,255,0.92);
    box-shadow: var(--tvm-shadow-soft);
}
.public-start-course-card {
    flex-direction: column;
    height: 100%;
    padding: 1rem;
    color: var(--tvm-text);
    text-decoration: none;
    transition: transform 0.16s ease, box-shadow 0.16s ease, border-color 0.16s ease;
}
.public-start-course-card:hover {
    transform: translateY(-2px);
    border-color: rgba(var(--tvm-primary-rgb), 0.35);
    box-shadow: var(--tvm-shadow);
}
.public-start-course-card span,
.public-start-course-card small,
.public-start-session-card span {
    color: var(--tvm-text-soft);
}
.public-start-course-card span {
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
.public-start-course-card strong {
    font-size: 1rem;
}
.public-start-session-card {
    align-items: center;
    justify-content: space-between;
    padding: 0.85rem;
}
.public-start-session-card strong,
.public-start-session-card span {
    display: block;
}
.public-start-session-card span {
    font-size: 0.86rem;
}
@media (max-width: 575.98px) {
    .public-feature-grid-compact {
        grid-template-columns: 1fr;
    }
    .public-start-session-card {
        align-items: stretch;
        flex-direction: column;
    }
}

/* PWA/App-Funktion */
.pwa-install-button {
    position: fixed;
    right: max(1rem, env(safe-area-inset-right));
    bottom: max(1rem, env(safe-area-inset-bottom));
    z-index: 1080;
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    max-width: calc(100vw - 2rem);
    border: 0;
    border-radius: 999px;
    padding: 0.72rem 0.9rem 0.72rem 0.72rem;
    background: linear-gradient(135deg, var(--tvm-primary), var(--tvm-primary-dark));
    color: #fff;
    box-shadow: 0 18px 42px rgba(var(--tvm-primary-rgb), 0.26);
    font: inherit;
    text-align: left;
}

.pwa-install-button:hover,
.pwa-install-button:focus {
    transform: translateY(-1px);
    box-shadow: 0 22px 48px rgba(var(--tvm-primary-rgb), 0.32);
}

.pwa-install-button-icon {
    display: inline-grid;
    width: 2.1rem;
    height: 2.1rem;
    place-items: center;
    border-radius: 999px;
    background: rgba(255,255,255,0.18);
    font-size: 1.2rem;
    font-weight: 900;
    line-height: 1;
}

.pwa-install-button strong,
.pwa-install-button small {
    display: block;
    line-height: 1.15;
}

.pwa-install-button strong {
    font-size: 0.92rem;
    font-weight: 900;
}

.pwa-install-button small {
    margin-top: 0.1rem;
    color: rgba(255,255,255,0.78);
    font-size: 0.74rem;
    font-weight: 700;
}

.is-pwa-standalone body {
    min-height: 100vh;
    min-height: 100dvh;
}

@media (max-width: 575.98px) {
    .pwa-install-button {
        left: 1rem;
        right: 1rem;
        justify-content: center;
    }
}

/* PWA iPhone-Hinweis und Update-Meldung */
.pwa-ios-hint,
.pwa-update-notice {
    position: fixed;
    left: max(1rem, env(safe-area-inset-left));
    right: max(1rem, env(safe-area-inset-right));
    bottom: max(1rem, env(safe-area-inset-bottom));
    z-index: 1090;
    display: flex;
    align-items: center;
    gap: 0.85rem;
    max-width: 520px;
    margin-inline: auto;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.14);
    border-radius: var(--tvm-radius-lg);
    padding: 0.95rem 3rem 0.95rem 1rem;
    background: rgba(255,255,255,0.96);
    color: var(--tvm-text);
    box-shadow: 0 20px 54px rgba(15, 35, 70, 0.18);
    backdrop-filter: blur(16px);
}

.pwa-ios-hint-icon {
    display: inline-grid;
    flex: 0 0 auto;
    width: 2.35rem;
    height: 2.35rem;
    place-items: center;
    border-radius: 1rem;
    background: linear-gradient(135deg, var(--tvm-primary), var(--tvm-primary-dark));
    color: #fff;
    font-size: 1.1rem;
    font-weight: 900;
    box-shadow: 0 10px 22px rgba(var(--tvm-primary-rgb), 0.22);
}

.pwa-ios-hint strong,
.pwa-update-notice strong {
    display: block;
    font-size: 0.95rem;
    font-weight: 900;
    line-height: 1.2;
}

.pwa-ios-hint p,
.pwa-update-notice small {
    display: block;
    margin: 0.16rem 0 0;
    color: var(--tvm-text-soft);
    font-size: 0.84rem;
    font-weight: 650;
    line-height: 1.35;
}

.pwa-ios-hint-close,
.pwa-toast-close {
    position: absolute;
    top: 0.55rem;
    right: 0.65rem;
    display: inline-grid;
    width: 2rem;
    height: 2rem;
    place-items: center;
    border: 0;
    border-radius: 999px;
    background: rgba(15, 35, 70, 0.07);
    color: var(--tvm-text-soft);
    font-size: 1.15rem;
    line-height: 1;
}

.pwa-ios-hint-close:hover,
.pwa-toast-close:hover {
    background: rgba(15, 35, 70, 0.12);
    color: var(--tvm-text);
}

.pwa-update-notice {
    justify-content: space-between;
}

.pwa-update-notice .btn {
    flex: 0 0 auto;
    border-radius: 999px;
    font-weight: 800;
    box-shadow: 0 8px 18px rgba(15, 35, 70, 0.08);
}

@media (max-width: 575.98px) {
    .pwa-ios-hint,
    .pwa-update-notice {
        align-items: flex-start;
        max-width: none;
    }

    .pwa-update-notice {
        flex-direction: column;
    }

    .pwa-update-notice .btn {
        align-self: flex-start;
    }
}

/* Professionelle Zahlungsarten / Checkout UX */
.checkout-hero-polished .account-hero-text {
    max-width: 760px;
}

.checkout-trust-row {
    align-items: center;
}

.checkout-secure-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    border: 1px solid rgba(255, 255, 255, 0.62);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.86);
    color: var(--tvm-primary-dark);
    padding: 0.42rem 0.82rem;
    font-size: 0.86rem;
    font-weight: 850;
    box-shadow: 0 10px 28px rgba(15, 35, 70, 0.08);
}

.checkout-main-card {
    overflow: hidden;
}

.payment-method-mark {
    display: inline-flex;
    align-items: center;
    gap: 0.48rem;
    min-height: 2.15rem;
    border: 1px solid rgba(18, 70, 160, 0.13);
    border-radius: 0.9rem;
    background: #fff;
    padding: 0.28rem 0.62rem 0.28rem 0.32rem;
    color: var(--tvm-text);
    font-weight: 850;
    line-height: 1;
    box-shadow: 0 8px 20px rgba(15, 35, 70, 0.05);
}

.payment-method-icon {
    display: inline-grid;
    place-items: center;
    min-width: 1.55rem;
    height: 1.55rem;
    border-radius: 0.55rem;
    background: linear-gradient(135deg, var(--tvm-primary), var(--tvm-primary-dark));
    color: #fff;
    font-size: 0.72rem;
    font-weight: 950;
    letter-spacing: -0.02em;
}

.payment-method-name {
    white-space: nowrap;
}

.payment-method-paypal .payment-method-icon {
    background: linear-gradient(135deg, #003087, #009cde);
}

.payment-method-stripe .payment-method-icon {
    background: linear-gradient(135deg, #635bff, #2f2a86);
}

.payment-method-card .payment-method-applepay .payment-method-icon,
.payment-method-applepay .payment-method-icon {
    background: linear-gradient(135deg, #111827, #000);
    font-size: 0.95rem;
}

.payment-method-googlepay .payment-method-icon {
    background: linear-gradient(135deg, #1a73e8, #34a853);
}

.payment-method-card .payment-method-sepa .payment-method-icon,
.payment-method-sepa .payment-method-icon {
    background: linear-gradient(135deg, #0f766e, #115e59);
    font-size: 0.58rem;
}

.payment-method-card .payment-method-card .payment-method-icon,
.payment-method-card .payment-method-card {
    box-shadow: none;
}

.checkout-provider-card {
    border: 1px solid rgba(18, 70, 160, 0.12);
    border-radius: 1.25rem;
    background: linear-gradient(180deg, rgba(248, 251, 255, 0.98), rgba(255, 255, 255, 0.98));
    padding: 1.1rem;
    box-shadow: 0 14px 36px rgba(15, 35, 70, 0.06);
}

.checkout-provider-topline {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.checkout-provider-title {
    color: var(--tvm-text);
    font-size: 1.05rem;
    font-weight: 900;
}

.checkout-provider-subtitle,
.checkout-security-note {
    color: var(--tvm-text-soft);
    font-size: 0.9rem;
    line-height: 1.5;
}

.checkout-provider-lock {
    border-radius: 999px;
    background: rgba(25, 135, 84, 0.1);
    color: #146c43;
    padding: 0.35rem 0.65rem;
    font-size: 0.74rem;
    font-weight: 950;
    letter-spacing: 0.08em;
}

.payment-method-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.8rem;
}

.payment-method-card {
    display: grid;
    gap: 0.5rem;
    border: 1px solid rgba(18, 70, 160, 0.1);
    border-radius: 1rem;
    background: #fff;
    padding: 0.85rem;
}

.payment-method-card small {
    color: var(--tvm-text-soft);
    line-height: 1.35;
}

.checkout-status-alert {
    border-radius: 1rem;
}

.checkout-pay-button {
    box-shadow: 0 14px 30px rgba(var(--tvm-primary-rgb), 0.22);
}

.checkout-provider-select-form {
    display: grid;
}

.checkout-provider-option {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    border: 1px solid rgba(18, 70, 160, 0.12);
    border-radius: 1rem;
    background: #fff;
    padding: 0.75rem;
    cursor: pointer;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.checkout-provider-option:hover,
.checkout-provider-option.is-active {
    border-color: rgba(var(--tvm-primary-rgb), 0.35);
    box-shadow: 0 12px 28px rgba(15, 35, 70, 0.08);
    transform: translateY(-1px);
}

.checkout-provider-option input {
    flex: 0 0 auto;
}

.checkout-method-stack {
    display: grid;
    gap: 0.65rem;
}

.checkout-method-line {
    display: flex;
}

.checkout-benefit-list li + li {
    margin-top: 0.45rem;
}

.payment-stat-provider .payment-method-mark {
    max-width: 100%;
}

@media (max-width: 767.98px) {
    .payment-method-grid {
        grid-template-columns: 1fr;
    }

    .checkout-provider-topline {
        flex-direction: column;
    }

    .checkout-action-row .btn {
        width: 100%;
    }
}

/* v0.10.26 Zahlungs-Rückkehrseite nach Stripe/PayPal */
.payment-result-page {
    gap: 1rem;
}

.payment-result-hero {
    position: relative;
    overflow: hidden;
    border-radius: 1.35rem;
    box-shadow: 0 18px 46px rgba(15, 35, 70, 0.08);
}

.payment-result-hero::after {
    content: "";
    position: absolute;
    inset: auto -8rem -10rem auto;
    width: 22rem;
    height: 22rem;
    border-radius: 999px;
    background: rgba(var(--tvm-primary-rgb), 0.09);
}

.payment-result-hero .card-body {
    position: relative;
    z-index: 1;
}

.payment-result-symbol {
    display: inline-grid;
    place-items: center;
    width: 3.4rem;
    height: 3.4rem;
    margin-bottom: 1rem;
    border-radius: 1.1rem;
    background: #fff;
    color: var(--tvm-primary-dark);
    font-size: 1.85rem;
    font-weight: 950;
    box-shadow: 0 14px 32px rgba(15, 35, 70, 0.1);
}

.payment-result-success {
    background: linear-gradient(120deg, rgba(237, 247, 239, 0.98), rgba(255, 255, 255, 0.96));
}

.payment-result-warning {
    background: linear-gradient(120deg, rgba(255, 248, 230, 0.98), rgba(255, 255, 255, 0.96));
}

.payment-result-danger {
    background: linear-gradient(120deg, rgba(255, 238, 238, 0.98), rgba(255, 255, 255, 0.96));
}

.payment-result-info {
    background: linear-gradient(120deg, rgba(232, 243, 255, 0.98), rgba(255, 255, 255, 0.96));
}

.payment-result-steps {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.85rem;
}

.payment-result-step {
    border: 1px solid rgba(18, 70, 160, 0.1);
    border-radius: 1rem;
    background: #fff;
    padding: 1rem;
    box-shadow: 0 12px 28px rgba(15, 35, 70, 0.05);
}

.payment-result-step strong,
.payment-result-step span {
    display: block;
}

.payment-result-step span {
    margin-top: 0.35rem;
    color: var(--tvm-text-soft);
    font-size: 0.92rem;
    line-height: 1.45;
}

.payment-result-step.is-done {
    border-color: rgba(25, 135, 84, 0.22);
    background: rgba(237, 247, 239, 0.95);
}

.payment-result-step.is-active {
    border-color: rgba(var(--tvm-primary-rgb), 0.24);
    background: rgba(248, 251, 255, 0.98);
}

.payment-result-timeline {
    display: grid;
    gap: 0.75rem;
}

.payment-result-timeline-item {
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1rem;
    background: #fff;
    padding: 0.9rem 1rem;
}

@media (max-width: 767.98px) {
    .payment-result-steps {
        grid-template-columns: 1fr;
    }

    .payment-result-hero .btn {
        width: 100%;
    }
}


/* v0.10.27 Zahlungsübersichten: klare Trennung von offenen, bezahlten und kritischen Vorgängen */
.payment-overview-page .account-home-section {
    margin-top: 1rem;
}

.payment-overview-page .payment-section-attention {
    border: 1px solid rgba(245, 158, 11, 0.25) !important;
    background: linear-gradient(180deg, rgba(255, 251, 235, 0.92), #fff);
}

.payment-overview-table .payment-method-mark {
    justify-content: flex-start;
}

.payment-overview-table th,
.payment-overview-table td {
    vertical-align: middle;
}

.admin-payment-filter-card,
.admin-payment-critical-item {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    height: 100%;
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.10);
    border-radius: var(--tvm-radius-sm);
    background: rgba(255, 255, 255, 0.88);
    padding: 1rem;
    color: var(--tvm-text);
    box-shadow: var(--tvm-shadow-soft);
    transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}

.admin-payment-filter-card:hover,
.admin-payment-critical-item:hover {
    transform: translateY(-1px);
    color: var(--tvm-text);
    border-color: rgba(var(--tvm-primary-rgb), 0.25);
    box-shadow: 0 16px 34px rgba(var(--tvm-text-rgb), 0.10);
}

.admin-payment-filter-card span,
.admin-payment-critical-title {
    color: var(--tvm-text-soft);
    font-size: .82rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .06em;
}

.admin-payment-filter-card strong {
    font-size: 1.65rem;
    line-height: 1;
    letter-spacing: -.04em;
}

.admin-payment-filter-card small,
.admin-payment-critical-item small {
    color: var(--tvm-text-soft);
}

.admin-payment-filter-card.is-active {
    border-color: rgba(var(--tvm-primary-rgb), 0.35);
    background: linear-gradient(135deg, rgba(var(--tvm-primary-rgb), 0.10), rgba(var(--tvm-accent-rgb), 0.08));
}

.admin-payment-filter-card.is-danger,
.admin-payment-critical-card {
    border-color: rgba(220, 53, 69, 0.18) !important;
}

.admin-payment-critical-card {
    background: linear-gradient(180deg, rgba(255, 245, 245, 0.92), #fff);
}

.admin-payment-critical-item strong {
    font-size: .98rem;
}

@media (max-width: 767.98px) {
    .payment-overview-table .btn {
        width: 100%;
    }

    .admin-payment-filter-card strong {
        font-size: 1.35rem;
    }
}


/* v0.10.28 Zahlungsdetails für Nutzer moderner und verständlicher */
.payment-detail-polished {
    gap: 1rem;
}

.payment-detail-hero-polished {
    position: relative;
    overflow: hidden;
    border-radius: 1.35rem;
    background: linear-gradient(120deg, rgba(255, 255, 255, 0.98), rgba(248, 251, 255, 0.98)) !important;
    border: 1px solid rgba(18, 70, 160, 0.10) !important;
    box-shadow: 0 18px 46px rgba(15, 35, 70, 0.08) !important;
}

.payment-detail-hero-polished::after {
    content: "";
    position: absolute;
    right: -8rem;
    bottom: -10rem;
    width: 23rem;
    height: 23rem;
    border-radius: 999px;
    background: rgba(var(--tvm-primary-rgb), 0.08);
}

.payment-detail-hero-polished .card-body {
    position: relative;
    z-index: 1;
    padding: 1.45rem !important;
}

.payment-detail-hero-copy {
    flex: 1 1 32rem;
    min-width: 0;
}

.payment-detail-hero-panel {
    flex: 0 1 22rem;
    border: 1px solid rgba(18, 70, 160, 0.12);
    border-radius: 1.25rem;
    background: rgba(255, 255, 255, 0.88);
    box-shadow: 0 14px 34px rgba(15, 35, 70, 0.08);
    padding: 1.15rem;
}

.payment-detail-hero-panel span,
.payment-detail-summary-card span,
.payment-detail-info-title,
.payment-detail-dl dt {
    display: block;
    color: var(--tvm-text-soft);
    font-size: 0.74rem;
    font-weight: 850;
    text-transform: uppercase;
    letter-spacing: 0.055em;
}

.payment-detail-hero-panel strong {
    display: block;
    margin-top: 0.25rem;
    color: var(--tvm-danger, #d00000);
    font-size: clamp(1.9rem, 4vw, 2.55rem);
    line-height: 1;
    font-weight: 950;
}

.payment-detail-hero-panel small {
    display: block;
    margin-top: 0.45rem;
    color: var(--tvm-text-soft);
    line-height: 1.45;
}

.payment-detail-hero-actions {
    display: flex;
    gap: 0.55rem;
    flex-wrap: wrap;
    margin-top: 1rem;
}

.payment-detail-summary-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.85rem;
}

.payment-detail-summary-card {
    min-height: 7rem;
    border: 1px solid rgba(18, 70, 160, 0.10);
    border-radius: 1.2rem;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 251, 255, 0.98));
    box-shadow: 0 12px 30px rgba(15, 35, 70, 0.06);
    padding: 1rem;
}

.payment-detail-summary-card strong {
    display: block;
    margin-top: 0.3rem;
    color: var(--tvm-text);
    font-size: 1.05rem;
    line-height: 1.25;
    font-weight: 850;
    word-break: break-word;
}

.payment-detail-summary-card > small {
    display: block;
    margin-top: 0.5rem;
    color: var(--tvm-text-soft);
    line-height: 1.35;
}

.payment-detail-stepper {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.85rem;
}

.payment-detail-step {
    display: flex;
    gap: 0.8rem;
    min-height: 6.1rem;
    border: 1px solid rgba(18, 70, 160, 0.10);
    border-radius: 1rem;
    background: #fff;
    padding: 1rem;
    box-shadow: 0 10px 26px rgba(15, 35, 70, 0.05);
}

.payment-detail-step.is-active {
    border-color: rgba(var(--tvm-primary-rgb), 0.28);
    background: rgba(248, 251, 255, 0.98);
}

.payment-detail-step.is-done {
    border-color: rgba(25, 135, 84, 0.22);
    background: rgba(237, 247, 239, 0.92);
}

.payment-detail-step-number {
    display: inline-grid;
    place-items: center;
    flex: 0 0 2rem;
    width: 2rem;
    height: 2rem;
    border-radius: 999px;
    background: rgba(var(--tvm-primary-rgb), 0.10);
    color: var(--tvm-primary-dark);
    font-weight: 950;
}

.payment-detail-step.is-done .payment-detail-step-number {
    background: rgba(25, 135, 84, 0.14);
    color: #137a58;
}

.payment-detail-step strong,
.payment-detail-step span {
    display: block;
}

.payment-detail-step span {
    margin-top: 0.3rem;
    color: var(--tvm-text-soft);
    font-size: 0.92rem;
    line-height: 1.45;
}

.payment-detail-notice {
    display: grid;
    gap: 0.25rem;
    border-radius: 1rem;
    padding: 0.9rem 1rem;
}

.payment-detail-notice-warning {
    border: 1px solid rgba(214, 158, 46, 0.22);
    background: rgba(255, 248, 230, 0.95);
    color: #7a4f13;
}

.payment-detail-info-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
}

.payment-detail-info-box {
    border: 1px solid rgba(18, 70, 160, 0.10);
    border-radius: 1.1rem;
    background: rgba(248, 251, 255, 0.72);
    padding: 1rem;
}

.payment-detail-dl {
    display: grid;
    gap: 0.65rem;
    margin: 0.85rem 0 0;
}

.payment-detail-dl div {
    display: grid;
    grid-template-columns: minmax(8rem, 0.4fr) minmax(0, 1fr);
    gap: 0.75rem;
    align-items: baseline;
}

.payment-detail-dl dd {
    margin: 0;
    color: var(--tvm-text);
    font-weight: 800;
    word-break: break-word;
}

.payment-detail-timeline {
    position: relative;
    display: grid;
    gap: 0.75rem;
}

.payment-detail-timeline-item {
    display: grid;
    grid-template-columns: 1.2rem minmax(0, 1fr);
    gap: 0.75rem;
}

.payment-detail-timeline-dot {
    width: 0.85rem;
    height: 0.85rem;
    margin-top: 0.35rem;
    border-radius: 999px;
}

.payment-detail-timeline-content {
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1rem;
    background: #fff;
    padding: 0.9rem 1rem;
    box-shadow: 0 10px 24px rgba(15, 35, 70, 0.04);
}

.payment-detail-timeline-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
}

.payment-detail-timeline-top strong {
    color: var(--tvm-text);
    line-height: 1.35;
}

.payment-detail-timeline-meta {
    margin-top: 0.25rem;
    color: var(--tvm-text-soft);
    font-size: 0.88rem;
}

@media (max-width: 1199.98px) {
    .payment-detail-summary-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .payment-detail-stepper,
    .payment-detail-info-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 767.98px) {
    .payment-detail-hero-panel,
    .payment-detail-hero-actions,
    .payment-detail-hero-actions .btn {
        width: 100%;
    }

    .payment-detail-summary-grid {
        grid-template-columns: 1fr;
    }

    .payment-detail-dl div {
        grid-template-columns: 1fr;
        gap: 0.2rem;
    }

    .payment-detail-timeline-top {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.4rem;
    }
}


/* v0.10.30 Checkout-Korrektur: Zahlungsarten ohne doppelte Prefixe und ruhigeres Layout */
.payment-method-mark {
    gap: 0.55rem;
}

.payment-method-icon {
    position: relative;
    overflow: hidden;
    flex: 0 0 auto;
    min-width: 1.65rem;
    width: 1.65rem;
    height: 1.65rem;
    font-size: 0;
    letter-spacing: 0;
}

.payment-method-icon::after {
    content: "";
    position: absolute;
    inset: 0.42rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.86);
}

.payment-method-name {
    line-height: 1.2;
}

.payment-method-paypal .payment-method-icon {
    background: linear-gradient(135deg, #003087 0%, #0070ba 48%, #009cde 100%);
}

.payment-method-stripe .payment-method-icon {
    background: linear-gradient(135deg, #635bff 0%, #7a73ff 48%, #2f2a86 100%);
}

.payment-method-creditcard .payment-method-icon {
    background: linear-gradient(135deg, #1f2937, #374151);
}

.payment-method-creditcard .payment-method-icon::after {
    inset: 0.36rem 0.28rem;
    border-radius: 0.24rem;
}

.payment-method-sepa .payment-method-icon {
    background: linear-gradient(135deg, #0f766e, #14b8a6);
}

.payment-method-applepay .payment-method-icon {
    background: linear-gradient(135deg, #111827, #000);
}

.payment-method-googlepay .payment-method-icon {
    background: conic-gradient(from 220deg, #4285f4, #34a853, #fbbc05, #ea4335, #4285f4);
}

.payment-method-card .payment-method-mark {
    width: 100%;
    justify-content: flex-start;
    box-shadow: none;
}

.checkout-hero-balanced {
    border: 1px solid rgba(18, 70, 160, 0.08);
    background:
        radial-gradient(circle at 90% 0%, rgba(var(--tvm-primary-rgb), 0.12), transparent 32%),
        linear-gradient(135deg, #ffffff 0%, #fff7f7 100%);
    box-shadow: 0 18px 46px rgba(15, 35, 70, 0.08);
}

.checkout-hero-balanced .account-hero-kicker {
    background: rgba(var(--tvm-primary-rgb), 0.09);
    color: var(--tvm-primary-dark);
}

.checkout-hero-balanced .account-hero-title {
    color: var(--tvm-text);
}

.checkout-hero-balanced .account-hero-text {
    color: var(--tvm-text-soft);
}

.checkout-hero-balanced .checkout-secure-pill {
    border-color: rgba(18, 70, 160, 0.12);
    background: #fff;
    color: var(--tvm-text);
}

.checkout-main-card,
.checkout-sidebar-card {
    border: 1px solid rgba(18, 70, 160, 0.08);
    box-shadow: 0 16px 42px rgba(15, 35, 70, 0.07);
}

.checkout-summary-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.85rem;
}

.checkout-summary-item {
    border: 1px solid rgba(18, 70, 160, 0.11);
    border-radius: 1rem;
    background: linear-gradient(180deg, #f8fbff, #fff);
    padding: 1rem;
}

.checkout-summary-item span {
    display: block;
    margin-bottom: 0.45rem;
    color: var(--tvm-text-soft);
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.checkout-summary-item strong {
    color: var(--tvm-text);
    font-size: 1rem;
}

.checkout-provider-card {
    background: linear-gradient(180deg, #ffffff, #f9fbff);
}

.checkout-provider-option .payment-method-mark {
    flex: 1 1 auto;
    border: 0;
    background: transparent;
    padding: 0;
    box-shadow: none;
}

.checkout-provider-option input {
    accent-color: var(--tvm-primary);
}

.checkout-method-line .payment-method-mark {
    width: 100%;
}

@media (max-width: 767.98px) {
    .checkout-summary-grid {
        grid-template-columns: 1fr;
    }
}


/* Admin-Zahlungsdetail im neuen Zahlungsdesign */
.admin-payment-page {
    display: block;
}

.admin-payment-hero .payment-method-mark {
    background: rgba(255, 255, 255, 0.92);
}

.admin-payment-hero-meta {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    flex-wrap: wrap;
}

.admin-payment-soft-pill {
    display: inline-flex;
    align-items: center;
    min-height: 2.05rem;
    border-radius: 999px;
    background: rgba(var(--tvm-primary-rgb), 0.08);
    color: var(--tvm-primary-dark);
    padding: 0.35rem 0.75rem;
    font-size: 0.82rem;
    font-weight: 850;
}

.admin-payment-status-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.25rem;
    border: 1px solid rgba(18, 70, 160, 0.1);
    border-radius: 1.35rem;
    background: linear-gradient(135deg, #ffffff, #f7fbff);
    box-shadow: 0 18px 42px rgba(15, 35, 70, 0.07);
    padding: 1.35rem;
}

.admin-payment-status-kicker,
.admin-payment-summary-card span,
.admin-payment-process-grid span,
.admin-payment-status-amount span {
    display: block;
    color: var(--tvm-text-soft);
    font-size: 0.76rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.admin-payment-status-title {
    color: var(--tvm-text);
    font-size: clamp(1.25rem, 2vw, 1.65rem);
    font-weight: 950;
    letter-spacing: -0.04em;
    margin-top: 0.15rem;
}

.admin-payment-status-text {
    color: var(--tvm-text-soft);
    max-width: 720px;
    line-height: 1.55;
}

.admin-payment-status-amount {
    min-width: 190px;
    border: 1px solid rgba(18, 70, 160, 0.1);
    border-radius: 1rem;
    background: #fff;
    padding: 0.95rem 1rem;
    text-align: right;
}

.admin-payment-status-amount strong {
    display: block;
    color: var(--tvm-primary-dark);
    font-size: 1.45rem;
    font-weight: 950;
}

.admin-payment-status-amount small,
.admin-payment-summary-card small,
.admin-payment-method-row small,
.admin-payment-timeline-meta {
    color: var(--tvm-text-soft);
}

.admin-payment-summary-grid,
.admin-payment-process-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.9rem;
}

.admin-payment-summary-card,
.admin-payment-process-grid > div {
    border: 1px solid rgba(18, 70, 160, 0.1);
    border-radius: 1rem;
    background: #fff;
    padding: 1rem;
    box-shadow: 0 12px 30px rgba(15, 35, 70, 0.05);
}

.admin-payment-summary-card strong,
.admin-payment-process-grid strong {
    display: block;
    color: var(--tvm-text);
    font-size: 1.05rem;
    font-weight: 900;
    margin: 0.1rem 0;
}

.admin-payment-detail-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
}

.admin-payment-method-list {
    display: grid;
    gap: 0.75rem;
}

.admin-payment-method-row {
    display: grid;
    gap: 0.4rem;
    border: 1px solid rgba(18, 70, 160, 0.1);
    border-radius: 1rem;
    background: #fff;
    padding: 0.85rem;
}

.admin-payment-resolve-box {
    border: 1px solid rgba(25, 135, 84, 0.18);
    border-radius: 1rem;
    background: linear-gradient(135deg, rgba(25, 135, 84, 0.06), rgba(255, 255, 255, 0.96));
    padding: 1rem;
}

.admin-payment-timeline {
    position: relative;
    display: grid;
    gap: 0.85rem;
}

.admin-payment-timeline-item {
    position: relative;
    display: grid;
    grid-template-columns: 1.1rem 1fr;
    gap: 0.65rem;
    border: 1px solid rgba(18, 70, 160, 0.09);
    border-radius: 1rem;
    background: #fff;
    padding: 0.85rem;
}

.admin-payment-timeline-dot {
    width: 0.78rem;
    height: 0.78rem;
    border-radius: 999px;
    background: var(--tvm-primary);
    margin-top: 0.25rem;
    box-shadow: 0 0 0 0.25rem rgba(var(--tvm-primary-rgb), 0.1);
}

.admin-payment-timeline-title {
    color: var(--tvm-text);
    font-weight: 900;
}

.admin-payment-timeline-ref {
    margin-top: 0.35rem;
    color: var(--tvm-text-soft);
    font-size: 0.78rem;
    word-break: break-all;
}

@media (max-width: 991.98px) {
    .admin-payment-status-card {
        align-items: stretch;
        flex-direction: column;
    }

    .admin-payment-status-amount {
        text-align: left;
        width: 100%;
    }

    .admin-payment-summary-grid,
    .admin-payment-process-grid,
    .admin-payment-detail-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .admin-payment-summary-grid,
    .admin-payment-process-grid,
    .admin-payment-detail-grid {
        grid-template-columns: 1fr;
    }
}

/* Zahlungsdiagnose: optische Angleichung an neues Zahlungsdesign */
.payment-diagnostic-hero {
    display: flex;
    align-items: stretch;
    justify-content: space-between;
    gap: 1.5rem;
    padding: 1.5rem;
    border-radius: 1.35rem;
    border: 1px solid rgba(15, 23, 42, .08);
    background: linear-gradient(135deg, #ffffff 0%, #f8fafc 60%, #eef2ff 100%);
    box-shadow: 0 18px 50px rgba(15, 23, 42, .08);
}
.payment-diagnostic-hero.is-success { background: linear-gradient(135deg, #ffffff 0%, #f0fdf4 60%, #dcfce7 100%); }
.payment-diagnostic-hero.is-warning { background: linear-gradient(135deg, #ffffff 0%, #fffbeb 58%, #fef3c7 100%); }
.payment-diagnostic-hero.is-danger { background: linear-gradient(135deg, #ffffff 0%, #fff1f2 58%, #fee2e2 100%); }
.payment-diagnostic-eyebrow {
    color: #64748b;
    font-size: .75rem;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
    margin-bottom: .35rem;
}
.payment-diagnostic-hero h2 {
    margin: 0 0 .35rem;
    font-size: clamp(1.45rem, 2.5vw, 2.15rem);
    font-weight: 850;
    color: #0f172a;
}
.payment-diagnostic-hero p { margin: 0; color: #475569; max-width: 50rem; }
.payment-diagnostic-hero-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(8rem, 1fr));
    gap: .75rem;
    min-width: min(100%, 26rem);
}
.payment-diagnostic-hero-grid div,
.payment-diagnostic-mini {
    background: rgba(255, 255, 255, .8);
    border: 1px solid rgba(148, 163, 184, .24);
    border-radius: 1rem;
    padding: 1rem;
    box-shadow: 0 10px 28px rgba(15, 23, 42, .06);
}
.payment-diagnostic-hero-grid span,
.payment-diagnostic-mini span {
    display: block;
    color: #64748b;
    font-size: .75rem;
    font-weight: 800;
    letter-spacing: .04em;
    text-transform: uppercase;
}
.payment-diagnostic-hero-grid strong,
.payment-diagnostic-mini strong {
    display: block;
    margin-top: .25rem;
    font-size: 1.55rem;
    line-height: 1.1;
    color: #0f172a;
}
.payment-diagnostic-mini { height: 100%; }
.payment-diagnostic-mini small {
    display: block;
    margin-top: .55rem;
    color: #64748b;
    line-height: 1.35;
}
.payment-diagnostic-card .admin-table tbody tr:hover { background: rgba(239, 246, 255, .55); }
.payment-diagnostic-next {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
    padding: 1.25rem;
    border-radius: 1.25rem;
    background: #fff;
    border: 1px solid rgba(148, 163, 184, .22);
    box-shadow: 0 14px 42px rgba(15, 23, 42, .07);
}
.payment-diagnostic-next strong { display: block; color: #0f172a; font-size: 1.05rem; margin-bottom: .25rem; }
.payment-diagnostic-next p { margin: 0; color: #64748b; }
@media (max-width: 991.98px) {
    .payment-diagnostic-hero,
    .payment-diagnostic-next { flex-direction: column; }
    .payment-diagnostic-hero-grid { min-width: 0; width: 100%; }
}
@media (max-width: 575.98px) {
    .payment-diagnostic-hero-grid { grid-template-columns: 1fr; }
}

/* Zahlungs-Hinweise nach Buchung */
.payment-required-banner,
.booking-payment-reminder {
    background: linear-gradient(135deg, rgba(255, 248, 230, 0.98), rgba(255, 255, 255, 0.96));
    border: 1px solid rgba(214, 158, 46, 0.28) !important;
    box-shadow: 0 1rem 2.5rem rgba(122, 79, 19, 0.08);
}

.payment-required-banner-inner,
.booking-payment-reminder-inner {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: center;
}

.booking-payment-reminder-inner {
    grid-template-columns: minmax(0, 0.95fr) minmax(280px, 1.05fr);
}

.payment-required-icon {
    display: grid;
    place-items: center;
    width: 3rem;
    height: 3rem;
    border-radius: 999px;
    background: rgba(214, 158, 46, 0.18);
    color: #8a5a12;
    font-weight: 950;
    font-size: 1.35rem;
}

.payment-required-copy h2,
.booking-payment-reminder h2 {
    margin: 0;
    color: var(--tvm-text);
    font-size: clamp(1.25rem, 2vw, 1.75rem);
    font-weight: 900;
}

.payment-required-copy p,
.booking-payment-reminder p {
    margin: 0.35rem 0 0;
    color: var(--tvm-text-soft);
    line-height: 1.55;
}

.payment-required-actions {
    display: grid;
    gap: 0.45rem;
    justify-items: end;
}

.payment-required-actions span {
    font-weight: 900;
    color: #8a5a12;
}

.booking-payment-reminder-list {
    display: grid;
    gap: 0.65rem;
}

.booking-payment-reminder-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    gap: 0.75rem;
    align-items: center;
    padding: 0.85rem 0.95rem;
    border: 1px solid rgba(214, 158, 46, 0.20);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.82);
    color: inherit;
    text-decoration: none;
}

.booking-payment-reminder-item span {
    font-weight: 800;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.booking-payment-reminder-item strong {
    color: #8a5a12;
}

.booking-payment-reminder-item em {
    font-style: normal;
    color: var(--tvm-primary);
    font-weight: 850;
}

@media (max-width: 767.98px) {
    .payment-required-banner-inner,
    .booking-payment-reminder-inner {
        grid-template-columns: 1fr;
    }

    .payment-required-actions {
        justify-items: stretch;
    }

    .booking-payment-reminder-item {
        grid-template-columns: 1fr;
        gap: 0.25rem;
    }
}


/* v0.10.36 Zahlungsdetail optisch verfeinert */
.payment-detail-page {
    --payment-soft-border: rgba(18, 70, 160, 0.10);
    --payment-card-bg: rgba(255, 255, 255, 0.96);
}

.payment-detail-page .payment-detail-card,
.payment-detail-page .payment-detail-summary-card,
.payment-detail-page .payment-detail-hero-polished {
    border-color: var(--payment-soft-border) !important;
}

.payment-detail-page .payment-detail-hero-main {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(17rem, 22rem);
    gap: 1rem;
    align-items: stretch;
}

.payment-detail-page .payment-detail-hero-polished {
    background:
        radial-gradient(circle at 92% 8%, rgba(var(--tvm-primary-rgb), 0.11), transparent 34%),
        linear-gradient(135deg, rgba(255, 255, 255, 0.99), rgba(250, 252, 255, 0.99)) !important;
}

.payment-detail-page .payment-detail-title {
    max-width: 46rem;
    margin-bottom: .55rem;
    font-size: clamp(1.65rem, 3.1vw, 2.35rem);
    line-height: 1.05;
    letter-spacing: -.055em;
}

.payment-detail-page .payment-detail-text {
    max-width: 42rem;
    color: var(--tvm-text-soft);
    font-size: 1.02rem;
}

.payment-detail-success-ribbon {
    display: inline-flex;
    align-items: center;
    gap: .75rem;
    margin-top: 1rem;
    border: 1px solid rgba(25, 135, 84, .18);
    border-radius: 999px;
    background: linear-gradient(135deg, rgba(25, 135, 84, .10), rgba(255, 255, 255, .94));
    padding: .55rem .85rem .55rem .55rem;
    color: #146c43;
    box-shadow: 0 12px 26px rgba(25, 135, 84, .09);
}

.payment-detail-success-icon {
    display: inline-grid;
    place-items: center;
    width: 2.05rem;
    height: 2.05rem;
    border-radius: 999px;
    background: #198754;
    color: #fff;
    font-weight: 950;
    box-shadow: 0 8px 20px rgba(25, 135, 84, .25);
}

.payment-detail-success-ribbon strong,
.payment-detail-success-ribbon small {
    display: block;
    line-height: 1.2;
}

.payment-detail-success-ribbon small {
    margin-top: .1rem;
    color: rgba(20, 108, 67, .82);
    font-weight: 700;
}

.payment-detail-page .payment-detail-meta {
    margin-top: 1rem;
}

.payment-detail-page .payment-detail-meta span,
.payment-detail-page .status-pill {
    border: 1px solid rgba(18, 70, 160, .08);
    background: rgba(248, 251, 255, .94);
    box-shadow: none;
}

.payment-detail-page .payment-detail-hero-panel {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    background:
        linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,251,255,.96));
}

.payment-detail-page .payment-detail-hero-panel strong {
    color: var(--tvm-primary-dark);
}

.payment-detail-page .payment-detail-hero-actions .btn {
    min-height: 2.7rem;
    font-weight: 850;
}

.payment-detail-page .payment-detail-summary-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.payment-detail-page .payment-detail-summary-card {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at 100% 0%, rgba(var(--tvm-primary-rgb), .08), transparent 42%),
        linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,251,255,.95));
}

.payment-detail-page .payment-detail-summary-card::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: .22rem;
    background: rgba(var(--tvm-primary-rgb), .30);
}

.payment-detail-page .payment-detail-card .card-body {
    padding: 1.25rem !important;
}

.payment-detail-page .account-home-section-head.compact {
    align-items: center;
    border-bottom: 1px solid rgba(18, 70, 160, .08);
    margin-bottom: 1rem;
    padding-bottom: .9rem;
}

.payment-detail-page .payment-detail-step {
    position: relative;
    min-height: 7rem;
    border-color: rgba(18, 70, 160, .09);
    background: linear-gradient(180deg, #fff, #fbfdff);
}

.payment-detail-page .payment-detail-step.is-done {
    background: linear-gradient(180deg, rgba(240, 253, 244, .98), rgba(255,255,255,.98));
}

.payment-detail-page .payment-detail-step-number {
    box-shadow: 0 8px 18px rgba(18, 70, 160, .10);
}

.payment-detail-page .payment-detail-info-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.payment-detail-page .payment-detail-info-box {
    background: linear-gradient(180deg, #ffffff, #f9fbff);
}

.payment-detail-page .payment-detail-dl {
    gap: .5rem;
}

.payment-detail-page .payment-detail-dl div {
    grid-template-columns: minmax(7.5rem, .38fr) minmax(0, 1fr);
    border-bottom: 1px solid rgba(18, 70, 160, .06);
    padding-bottom: .5rem;
}

.payment-detail-page .payment-detail-dl div:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.payment-detail-page .payment-detail-dl dd {
    font-weight: 780;
}

.payment-detail-page .payment-detail-timeline {
    gap: .65rem;
}

.payment-detail-page .payment-detail-timeline-item {
    grid-template-columns: 1.35rem minmax(0, 1fr);
}

.payment-detail-page .payment-detail-timeline-dot {
    width: .95rem;
    height: .95rem;
    margin-top: .7rem;
    box-shadow: 0 0 0 .28rem rgba(18, 70, 160, .08);
}

.payment-detail-page .payment-detail-timeline-content {
    background: linear-gradient(180deg, #fff, #fbfdff);
}

@media (max-width: 1199.98px) {
    .payment-detail-page .payment-detail-hero-main {
        grid-template-columns: 1fr;
    }

    .payment-detail-page .payment-detail-info-grid,
    .payment-detail-page .payment-detail-summary-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .payment-detail-page .payment-detail-info-grid,
    .payment-detail-page .payment-detail-summary-grid {
        grid-template-columns: 1fr;
    }

    .payment-detail-page .payment-detail-dl div {
        grid-template-columns: 1fr;
    }

    .payment-detail-success-ribbon {
        align-items: flex-start;
        border-radius: 1rem;
        width: 100%;
    }
}


/* v0.10.37 Fix Zahlungsdetail: klare, kompakte Nutzeransicht */
.payment-detail-v2 {
    display: grid;
    gap: 1rem;
}

.payment-detail-v2,
.payment-detail-v2 * {
    box-sizing: border-box;
}

.payment-detail-v2-hero,
.payment-detail-v2-card,
.payment-detail-v2-success {
    border: 1px solid rgba(18, 70, 160, 0.08);
    border-radius: 1.35rem;
    background: rgba(255, 255, 255, 0.98);
    box-shadow: 0 18px 44px rgba(15, 35, 70, 0.07);
}

.payment-detail-v2-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(240px, 320px);
    gap: 1.25rem;
    align-items: stretch;
    padding: 1.25rem;
    overflow: hidden;
}

.payment-detail-v2-hero-copy {
    min-width: 0;
    padding: .25rem 0;
}

.payment-detail-v2-hero h1 {
    margin: .25rem 0 .45rem;
    color: var(--tvm-text);
    font-size: clamp(1.65rem, 2.4vw, 2.25rem);
    line-height: 1.05;
    letter-spacing: -0.045em;
    font-weight: 950;
}

.payment-detail-v2-hero p {
    max-width: 760px;
    margin: 0;
    color: var(--tvm-text-soft);
    font-size: 1rem;
    line-height: 1.55;
}

.payment-detail-v2-badges {
    display: flex;
    flex-wrap: wrap;
    gap: .45rem;
    margin-top: .9rem;
}

.payment-detail-v2-badges > span:not(.status-pill) {
    display: inline-flex;
    align-items: center;
    min-height: 1.9rem;
    padding: .35rem .65rem;
    border-radius: 999px;
    background: rgba(18, 70, 160, .06);
    color: var(--tvm-text-soft);
    font-size: .8rem;
    font-weight: 800;
}

.payment-detail-v2-amountbox {
    display: flex;
    flex-direction: column;
    justify-content: center;
    border-radius: 1.15rem;
    background: linear-gradient(180deg, #f8fbff, #ffffff);
    border: 1px solid rgba(18, 70, 160, .09);
    padding: 1rem;
}

.payment-detail-v2-amountbox > span,
.payment-detail-v2-section-head .section-kicker,
.payment-detail-v2-list dt {
    display: block;
    color: var(--tvm-text-soft);
    font-size: .73rem;
    font-weight: 900;
    letter-spacing: .075em;
    text-transform: uppercase;
}

.payment-detail-v2-amountbox strong {
    display: block;
    margin-top: .25rem;
    color: var(--tvm-danger, #d00000);
    font-size: clamp(1.9rem, 3vw, 2.45rem);
    line-height: 1;
    font-weight: 950;
}

.payment-detail-v2-amountbox small {
    display: block;
    margin-top: .45rem;
    color: var(--tvm-text-soft);
    line-height: 1.35;
}

.payment-detail-v2-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .55rem;
    margin-top: 1rem;
}

.payment-detail-v2-success {
    display: flex;
    align-items: center;
    gap: .85rem;
    padding: 1rem 1.15rem;
    background: linear-gradient(90deg, rgba(236, 252, 245, .98), #fff);
    border-color: rgba(25, 135, 84, .16);
}

.payment-detail-v2-success-icon {
    display: inline-grid;
    place-items: center;
    flex: 0 0 2.4rem;
    width: 2.4rem;
    height: 2.4rem;
    border-radius: 999px;
    background: rgba(25, 135, 84, .13);
    color: #137a58;
    font-weight: 950;
}

.payment-detail-v2-success strong,
.payment-detail-v2-success span {
    display: block;
}

.payment-detail-v2-success strong {
    color: var(--tvm-text);
}

.payment-detail-v2-success span {
    color: var(--tvm-text-soft);
}

.payment-detail-v2-card {
    padding: 1.15rem;
}

.payment-detail-v2-section-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.payment-detail-v2-section-head h2 {
    margin: .12rem 0 0;
    color: var(--tvm-text);
    font-size: 1.15rem;
    line-height: 1.2;
    font-weight: 950;
    letter-spacing: -.03em;
}

.payment-detail-v2-stepper {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: .8rem;
}

.payment-detail-v2-step {
    display: flex;
    gap: .75rem;
    min-width: 0;
    border: 1px solid rgba(18, 70, 160, .09);
    border-radius: 1rem;
    background: #fff;
    padding: .9rem;
}

.payment-detail-v2-step > span {
    display: inline-grid;
    place-items: center;
    flex: 0 0 2rem;
    width: 2rem;
    height: 2rem;
    border-radius: 999px;
    background: rgba(var(--tvm-primary-rgb), .10);
    color: var(--tvm-primary-dark);
    font-weight: 950;
}

.payment-detail-v2-step.is-done {
    background: rgba(237, 247, 239, .72);
    border-color: rgba(25, 135, 84, .20);
}

.payment-detail-v2-step.is-done > span {
    background: rgba(25, 135, 84, .13);
    color: #137a58;
}

.payment-detail-v2-step.is-active {
    background: rgba(255, 248, 230, .72);
    border-color: rgba(214, 158, 46, .22);
}

.payment-detail-v2-step strong,
.payment-detail-v2-step small {
    display: block;
}

.payment-detail-v2-step strong {
    color: var(--tvm-text);
    line-height: 1.25;
}

.payment-detail-v2-step small {
    margin-top: .25rem;
    color: var(--tvm-text-soft);
    line-height: 1.35;
}

.payment-detail-v2-warning {
    margin-top: .9rem;
    border-radius: .9rem;
    background: rgba(255, 248, 230, .85);
    color: #7a4f13;
    padding: .85rem .95rem;
}

.payment-detail-v2-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.payment-detail-v2-list {
    display: grid;
    gap: .7rem;
    margin: 0;
}

.payment-detail-v2-list div {
    display: grid;
    grid-template-columns: minmax(120px, .35fr) minmax(0, 1fr);
    gap: .75rem;
    align-items: start;
    padding-bottom: .65rem;
    border-bottom: 1px solid rgba(18, 70, 160, .07);
}

.payment-detail-v2-list div:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.payment-detail-v2-list dd {
    margin: 0;
    color: var(--tvm-text);
    font-weight: 800;
    line-height: 1.35;
    overflow-wrap: anywhere;
}

.payment-detail-v2-timeline {
    display: grid;
    gap: .7rem;
}

.payment-detail-v2-timeline-item {
    display: grid;
    grid-template-columns: 1rem minmax(0, 1fr);
    gap: .7rem;
    align-items: start;
    border: 1px solid rgba(18, 70, 160, .07);
    border-radius: 1rem;
    background: linear-gradient(180deg, #fff, #f8fbff);
    padding: .85rem;
}

.payment-detail-v2-dot {
    width: .75rem;
    height: .75rem;
    border-radius: 999px;
    margin-top: .35rem;
}

.payment-detail-v2-timeline-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: .65rem;
}

.payment-detail-v2-timeline-top strong {
    color: var(--tvm-text);
    line-height: 1.3;
}

.payment-detail-v2-timeline-item small {
    display: block;
    margin-top: .2rem;
    color: var(--tvm-text-soft);
}

@media (max-width: 991.98px) {
    .payment-detail-v2-hero,
    .payment-detail-v2-grid,
    .payment-detail-v2-stepper {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 575.98px) {
    .payment-detail-v2-hero,
    .payment-detail-v2-card {
        border-radius: 1rem;
        padding: 1rem;
    }

    .payment-detail-v2-section-head,
    .payment-detail-v2-timeline-top {
        flex-direction: column;
        align-items: flex-start;
    }

    .payment-detail-v2-list div {
        grid-template-columns: 1fr;
        gap: .18rem;
    }

    .payment-detail-v2-actions,
    .payment-detail-v2-actions .btn {
        width: 100%;
    }
}


.cart-reminder-modal {
    border: 1px solid rgba(var(--tvm-primary-rgb), 0.12);
    border-radius: 1.35rem;
    box-shadow: 0 24px 60px rgba(15, 40, 75, 0.18);
    overflow: hidden;
}

.cart-reminder-kicker {
    color: var(--tvm-account-hero-outline-hover-text);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.72rem;
    font-weight: 800;
    margin-bottom: 0.2rem;
}

.cart-reminder-text {
    color: var(--tvm-text);
    line-height: 1.6;
}

.cart-reminder-actions {
    gap: 0.5rem;
}

@media (max-width: 575.98px) {
    .cart-reminder-actions {
        align-items: stretch;
        flex-direction: column-reverse;
    }

    .cart-reminder-actions .btn {
        width: 100%;
    }
}


.table-sort-link {
    color: inherit;
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    text-decoration: none;
    white-space: nowrap;
}

.table-sort-link:hover {
    color: var(--bs-primary);
    text-decoration: none;
}


/* Warenkorb: sichtbare Reservierungszeit */
.cart-reservation-note {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    padding: .38rem .65rem;
    border-radius: 999px;
    background: #fff7ed;
    border: 1px solid rgba(245, 158, 11, .28);
    color: #92400e;
    font-size: .78rem;
    font-weight: 700;
    line-height: 1.2;
}

.cart-reservation-note.expired {
    background: #fef2f2;
    border-color: rgba(220, 38, 38, .25);
    color: #991b1b;
}

.cart-reservation-dot {
    width: .45rem;
    height: .45rem;
    border-radius: 999px;
    background: currentColor;
    opacity: .75;
    flex: 0 0 auto;
}

@media (max-width: 767.98px) {
    .cart-reservation-note {
        white-space: normal;
        border-radius: .85rem;
    }
}


/* Passwort sichtbar machen */
.password-toggle-wrap {
    position: relative;
}

.password-toggle-wrap .form-control {
    padding-right: 3.35rem;
}

.password-toggle-wrap input[data-password-toggle="1"]::-ms-reveal,
.password-toggle-wrap input[data-password-toggle="1"]::-ms-clear {
    display: none;
}

.password-toggle-btn {
    position: absolute;
    top: .1rem;
    right: .35rem;
    bottom: .1rem;
    z-index: 3;
    border: 0;
    background: transparent;
    color: #64748b;
    width: 2.65rem;
    min-height: 2.15rem;
    padding: 0;
    border-radius: .65rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    transition: color .16s ease, background-color .16s ease, box-shadow .16s ease;
}

.password-toggle-btn:hover,
.password-toggle-btn:focus {
    color: var(--tvm-primary, var(--bs-primary));
    background: rgba(var(--tvm-primary-rgb, 37, 99, 235), .09);
    outline: none;
}

.password-toggle-btn:focus-visible {
    box-shadow: 0 0 0 .2rem rgba(var(--tvm-primary-rgb, 37, 99, 235), .16);
}

.password-toggle-icon {
    width: 1.22rem;
    height: 1.22rem;
    display: block;
    flex: 0 0 auto;
    pointer-events: none;
    fill: none !important;
    stroke: currentColor !important;
    stroke-width: 1.9;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.password-toggle-icon * {
    vector-effect: non-scaling-stroke;
}

.password-toggle-icon-eye-off {
    display: none;
}

.password-toggle-btn.is-visible .password-toggle-icon-eye {
    display: none;
}

.password-toggle-btn.is-visible .password-toggle-icon-eye-off {
    display: block;
}


.cart-reservation-summary {
    padding: .9rem 1rem;
    border-radius: 1rem;
    background: linear-gradient(135deg, #fff7ed 0%, #ffffff 100%);
    border: 1px solid rgba(245, 158, 11, .28);
}

.cart-reservation-time {
    color: #b45309;
    font-size: 1.55rem;
    font-weight: 900;
    letter-spacing: -.03em;
    line-height: 1.1;
}

.cart-reservation-summary.expired .cart-reservation-time {
    color: #991b1b;
}
