﻿:root {
    --ctm-bg: #0B0F14;
    --ctm-surface: #121922;
    --ctm-surface-2: #182230;
    --ctm-text: #F3F6FA;
    --ctm-text-soft: #A9B4C2;
    --ctm-text-muted: #738091;
    --ctm-gold: #D4A62A;
    --ctm-gold-light: #E6BC4A;
    --ctm-blue: #8FD3FF;
    --ctm-blue-light: #BDE8FF;
    --ctm-border: rgba(255,255,255,.08);
    --ctm-border-gold: rgba(212,166,42,.30);
    --ctm-shadow: 0 10px 30px rgba(0,0,0,.30);
    --ctm-sidebar-width: 280px;
    --ctm-topbar-height: 68px;
}

html,
body {
    height: 100%;
    margin: 0;
    background: var(--ctm-bg);
    color: var(--ctm-text);
}

.ctm-app-body {
    background: radial-gradient(circle at top left, rgba(212,166,42,.07), transparent 20%), radial-gradient(circle at top right, rgba(143,211,255,.08), transparent 18%), var(--ctm-bg);
}

.ctm-app-shell {
    display: flex;
    min-height: 100vh;
}

.ctm-sidebar {
    width: var(--ctm-sidebar-width);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 24px 18px;
    background: linear-gradient(180deg, #0f141b 0%, #0b1016 100%);
    border-right: 1px solid var(--ctm-border);
    position: sticky;
    top: 0;
    z-index: 1040;
    max-height: 100vh;
}

.ctm-sidebar-top {
    display: flex;
    flex-direction: column;
    min-height: 0;
}

.ctm-sidebar-brand {
    margin-bottom: 28px;
}

.ctm-brand-link {
    display: inline-block;
    text-decoration: none;
}

.ctm-brand-logo {
    width: 100%;
    max-width: 220px;
    height: auto;
    display: block;
}

/* Icon-Logo: standardmäßig versteckt */
.ctm-brand-logo-icon {
    display: none;
}

.ctm-brand-subtitle {
    margin-top: 10px;
    padding-left: 4px;
    color: var(--ctm-text-muted);
    font-size: .82rem;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.ctm-sidebar-nav {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.ctm-nav-item {
    position: relative;
    display: flex;
    align-items: center;
    gap: 14px;
    width: 100%;
    padding: 14px 16px;
    border-radius: 14px;
    color: var(--ctm-text-soft);
    text-decoration: none;
    border: 1px solid transparent;
    background: transparent;
    transition: all .2s ease;
}

    .ctm-nav-item i {
        width: 18px;
        text-align: center;
        color: var(--ctm-blue);
    }

    .ctm-nav-item:hover {
        color: var(--ctm-text);
        background: rgba(143,211,255,.07);
        border-color: rgba(143,211,255,.14);
        transform: translateX(2px);
    }

    .ctm-nav-item.active {
        color: var(--ctm-text);
        background: linear-gradient(90deg, rgba(212,166,42,.12) 0%, rgba(212,166,42,.03) 100%), #141c26;
        border-color: var(--ctm-border-gold);
        box-shadow: var(--ctm-shadow);
    }

        .ctm-nav-item.active::before {
            content: "";
            position: absolute;
            left: -10px;
            top: 10px;
            bottom: 10px;
            width: 4px;
            border-radius: 999px;
            background: linear-gradient(180deg, var(--ctm-gold-light), var(--ctm-gold));
        }

        .ctm-nav-item.active i {
            color: var(--ctm-gold-light);
        }

.ctm-sidebar-footer {
    margin-top: 24px;
    padding-top: 18px;
    border-top: 1px solid var(--ctm-border);
}

.ctm-user-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px;
    border-radius: 16px;
    background: rgba(255,255,255,.03);
    border: 1px solid var(--ctm-border);
    margin-bottom: 14px;
}

.ctm-user-avatar {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: linear-gradient(180deg, rgba(212,166,42,.18), rgba(143,211,255,.10));
    border: 1px solid rgba(255,255,255,.08);
}

.ctm-user-name {
    font-weight: 600;
    color: var(--ctm-text);
    line-height: 1.2;
}

.ctm-user-role {
    font-size: .85rem;
    color: var(--ctm-text-muted);
}

.ctm-user-actions,
.ctm-auth-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.ctm-nav-button {
    border: 1px solid transparent;
    background: transparent;
    text-align: left;
}

.ctm-btn-primary {
    background: linear-gradient(180deg, var(--ctm-gold-light), var(--ctm-gold));
    border: none;
    color: #111;
    font-weight: 600;
    border-radius: 12px;
    padding: 12px 14px;
}

    .ctm-btn-primary:hover {
        color: #111;
        filter: brightness(1.04);
    }

.ctm-btn-secondary {
    background: rgba(255,255,255,.04);
    border: 1px solid var(--ctm-border);
    color: var(--ctm-text);
    border-radius: 12px;
    padding: 12px 14px;
}

    .ctm-btn-secondary:hover {
        color: var(--ctm-text);
        background: rgba(255,255,255,.07);
    }

.ctm-app-main {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
}

.ctm-page-content {
    flex: 1;
    padding: 28px;
}

    .ctm-page-content .container,
    .ctm-page-content .container-fluid {
        max-width: 100%;
        padding-left: 0;
        padding-right: 0;
    }

/* Mobile Topbar */
.ctm-mobile-topbar {
    height: var(--ctm-topbar-height);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 16px;
    border-bottom: 1px solid var(--ctm-border);
    background: rgba(11, 15, 20, .92);
    backdrop-filter: blur(10px);
    position: sticky;
    top: 0;
    z-index: 1030;
}

.ctm-mobile-brand {
    display: flex;
    align-items: center;
    text-decoration: none;
}

    .ctm-mobile-brand img {
        height: 34px;
        width: auto;
        display: block;
        max-width: 180px;
    }

.ctm-mobile-toggle,
.ctm-sidebar-close {
    width: 42px;
    height: 42px;
    border-radius: 12px;
    border: 1px solid var(--ctm-border);
    background: rgba(255,255,255,.04);
    color: var(--ctm-text);
    display: inline-grid;
    place-items: center;
    cursor: pointer;
}

    .ctm-mobile-toggle:hover,
    .ctm-sidebar-close:hover {
        background: rgba(255,255,255,.08);
    }

.ctm-sidebar-mobile-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--ctm-border);
}

.ctm-sidebar-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.55);
    opacity: 0;
    visibility: hidden;
    transition: .2s ease;
    z-index: 1035;
}

/* Mobile behaviour */
@media (max-width: 991.98px) {
    .ctm-sidebar {
        position: fixed;
        top: 0;
        left: 0;
        width: min(86vw, 320px);
        height: 100vh;
        min-height: 100vh;
        transform: translateX(-100%);
        transition: transform .25s ease;
        box-shadow: 0 20px 40px rgba(0,0,0,.45);
    }

    .ctm-page-content {
        padding: 20px 16px;
    }

    body.ctm-sidebar-open .ctm-sidebar {
        transform: translateX(0);
    }

    body.ctm-sidebar-open .ctm-sidebar-overlay {
        opacity: 1;
        visibility: visible;
    }

    body.ctm-sidebar-open {
        overflow: hidden;
    }
}

/* Desktop behaviour */
@media (min-width: 992px) {
    .ctm-sidebar-overlay {
        display: none;
    }
}

/* ---- Sidebar collapse (desktop only) ---- */
.ctm-sidebar-collapse-btn {
    width: 34px;
    height: 34px;
    border-radius: 10px;
    border: 1px solid var(--ctm-border);
    background: rgba(255,255,255,.04);
    color: var(--ctm-text-soft);
    display: none;
    place-items: center;
    cursor: pointer;
    flex-shrink: 0;
    transition: background .18s ease, color .18s ease, transform .25s ease;
}

    .ctm-sidebar-collapse-btn:hover {
        background: rgba(255,255,255,.08);
        color: var(--ctm-text);
    }

@media (min-width: 992px) {
    .ctm-sidebar-collapse-btn {
        display: inline-grid;
    }

    .ctm-sidebar-brand {
        align-items: center;
        justify-content: space-between;
        gap: 8px;
    }

    .ctm-sidebar {
        transition: width .25s ease, padding .25s ease;
    }

    .ctm-nav-item span,
    .ctm-brand-subtitle,
    .ctm-brand-logo-full,
    .ctm-user-meta,
    .ctm-user-actions span,
    .ctm-auth-actions {
        transition: opacity .2s ease;
    }

    /* --- Collapsed state --- */
    body.ctm-sidebar-collapsed .ctm-sidebar {
        width: 72px;
        padding: 24px 10px;
    }

    body.ctm-sidebar-collapsed .ctm-sidebar-collapse-btn i {
        transform: rotate(180deg);
    }

    body.ctm-sidebar-collapsed .ctm-brand-logo-full,
    body.ctm-sidebar-collapsed .ctm-brand-subtitle {
        display: none;
    }

    body.ctm-sidebar-collapsed .ctm-brand-logo,
    body.ctm-sidebar-collapsed .ctm-brand-subtitle {
        opacity: 0;
        width: 0;
        overflow: hidden;
        pointer-events: none;
    }

    .ctm-content-topbar {
        & .ctm-topbar-action:hover {
            color: #111;
            transform: translateY(-1px);
            filter: brightness(1.03);
            box-shadow: 0 14px 30px rgba(212,166,42,.24);
        }
    }

    .ctm-topbar-action:hover {
        color: #111;
        transform: translateY(-1px);
        filter: brightness(1.03);
        box-shadow: 0 14px 30px rgba(212,166,42,.24);
    }

    .ctm-content-topbar {
        & .ctm-topbar-action {
            display: inline-flex;
            align-items: center;
            gap: 10px;
            padding: 12px 16px;
            border-radius: 14px;
            text-decoration: none;
            color: #111;
            font-weight: 700;
            background: linear-gradient(180deg, var(--ctm-gold-light), var(--ctm-gold));
            box-shadow: 0 10px 24px rgba(212,166,42,.18);
            transition: transform .18s ease, filter .18s ease, box-shadow .18s ease;
        }
    }

    .ctm-content-topbar 

{
    border-bottom: 1px solid var(--ctm-border);
    background: rgba(11, 15, 20, 0.82);
    backdrop-filter: blur(14px);
}
    .ctm-content-topbar {
        & .ctm-content-title {
            margin: 0;
            color: var(--ctm-text);
            font-size: clamp(1.5rem, 2vw, 2.1rem);
            line-height: 1.1;
            font-weight: 700;
            letter-spacing: -.02em;
        }
    }
    .ctm-topbar-action i {
        font-size: .95rem;
    }
    .ctm-content-subtitle {
        margin-top: 6px;
        color: var(--ctm-text-soft);
        font-size: .98rem;
    }
.ctm-content-topbar {
    position: sticky;
    top: 0;
    z-index: 1020;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
}

    body.ctm-sidebar-collapsed .ctm-sidebar-brand {
        justify-content: center;
    }

    body.ctm-sidebar-collapsed .ctm-brand-logo-icon {
        display: block;
        width: 115px;
        height: auto;
        max-width: none;
        opacity: 1;
        margin-top: -27px;
    }

    body.ctm-sidebar-collapsed .ctm-sidebar-brand {
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 10px;
    }

    body.ctm-sidebar-collapsed .ctm-nav-item {
        justify-content: center;
        padding: 14px 0;
        gap: 0;
    }

    body.ctm-sidebar-collapsed .ctm-nav-item span {
        display: none;
    }

    body.ctm-sidebar-collapsed .ctm-nav-item i {
        width: auto;
        font-size: 1.1rem;
    }

    body.ctm-sidebar-collapsed .ctm-nav-item.active::before {
        left: -2px;
    }

    body.ctm-sidebar-collapsed .ctm-user-card {
        justify-content: center;
        padding: 10px;
    }

    body.ctm-sidebar-collapsed .ctm-user-meta {
        display: none;
    }

    body.ctm-sidebar-collapsed .ctm-user-actions span,
    body.ctm-sidebar-collapsed .ctm-nav-button span {
        display: none;
    }

    body.ctm-sidebar-collapsed .ctm-user-actions .ctm-nav-item {
        justify-content: center;
        padding: 14px 0;
        gap: 0;
    }

    body.ctm-sidebar-collapsed .ctm-auth-actions {
        display: none;
    }
}


.ctt