/* ═══════════════════════════════════════════════════════════
 * ASD Opitz Urlaubsplanung — Brand + Mobile-First Redesign
 * Bootstrap 2.x Override • Soft Healthcare Editorial
 * ═══════════════════════════════════════════════════════════ */

:root {
    --asd-primary:       #0f3460;
    --asd-primary-dark:  #0a2540;
    --asd-accent:        #007ba3;
    --asd-accent-dark:   #006d91;
    --asd-accent-warm:   #a67516;
    --asd-cream:         #faf6f0;
    --asd-surface:       #ffffff;
    --asd-ink:           #1e293b;
    --asd-ink-soft:      #475569;
    --asd-line:          rgba(15, 52, 96, 0.08);
    --asd-shadow-sm:     0 1px 2px rgba(15, 52, 96, 0.06), 0 1px 3px rgba(15, 52, 96, 0.08);
    --asd-shadow:        0 4px 12px rgba(15, 52, 96, 0.08), 0 1px 3px rgba(15, 52, 96, 0.06);
    --asd-shadow-lg:     0 24px 60px -12px rgba(15, 52, 96, 0.18), 0 8px 24px -8px rgba(15, 52, 96, 0.10);
    --asd-radius-sm:     8px;
    --asd-radius:        14px;
    --asd-radius-lg:     22px;
    --asd-radius-pill:   999px;
    --asd-display:       "Fraunces", "Source Serif 4", Georgia, serif;
    --asd-body:          "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;
}

/* ─── DESKTOP CI (Bootstrap 2.x overrides) ─── */

.navbar-inverse .navbar-inner,
.navbar.navbar-inverse {
    background-color: var(--asd-primary) !important;
    background-image: linear-gradient(180deg, var(--asd-primary) 0%, var(--asd-primary-dark) 100%) !important;
    border-color: var(--asd-primary-dark) !important;
}
.navbar-inverse .brand,
.navbar-inverse .nav > li > a { color: #ffffff !important; }
.navbar-inverse .nav > li > a:hover,
.navbar-inverse .nav > .active > a {
    background-color: var(--asd-accent-dark) !important;
    color: #fff !important;
}
.navbar .brand {
    font-family: var(--asd-display);
    font-weight: 600;
    letter-spacing: 0.2px;
    font-size: 18px;
}

.btn-primary, .btn-primary:focus {
    background-color: var(--asd-accent) !important;
    background-image: linear-gradient(180deg, var(--asd-accent) 0%, var(--asd-accent-dark) 100%) !important;
    border-color: var(--asd-accent-dark) !important;
    text-shadow: none;
}
.btn-primary:hover, .btn-primary:active {
    background-image: linear-gradient(180deg, var(--asd-accent-dark) 0%, var(--asd-primary) 100%) !important;
    border-color: var(--asd-primary) !important;
}
.btn-info { background-color: var(--asd-primary) !important; border-color: var(--asd-primary-dark) !important; }
a, a:visited { color: var(--asd-accent); }
a:hover { color: var(--asd-primary); }
.label-info, .badge-info { background-color: var(--asd-accent); }
.label-important, .badge-important { background-color: var(--asd-accent-warm); }
.fc-event { background-color: var(--asd-accent) !important; border-color: var(--asd-accent-dark) !important; }
.form-box {
    border-top: 4px solid var(--asd-accent-warm) !important;
    border-radius: var(--asd-radius) !important;
}
.form-box h2 { color: var(--asd-primary); font-family: var(--asd-display); }

/* Hide non-essential menu items everywhere */
a[href$="/leaves/counters"],
a[href$="/calendar/tabular"],
a[href$="/calendar/year"],
a[href$="/reports/balance"],
a[href$="/reports/leaves"],
a[href$="/reports"],
a[href$="/leavetypes"] { display: none !important; }

/* Mobile shell HIDDEN on desktop */
.mobile-shell { display: none; }

/* ═══════════════════════════════════════════
 * MOBILE REDESIGN — 767px and below
 * ═══════════════════════════════════════════ */
@media (max-width: 767px) {

    body {
        font-family: var(--asd-body);
        font-size: 16px;
        line-height: 1.55;
        color: var(--asd-ink);
        background: var(--asd-cream) !important;
        background-image:
            radial-gradient(at 15% -10%, rgba(0,123,163,0.08) 0%, transparent 50%),
            radial-gradient(at 85% 110%, rgba(166,117,22,0.06) 0%, transparent 50%) !important;
        padding: 0 !important;
        padding-top: 64px !important;
        padding-bottom: 88px !important;
        min-height: 100vh;
        -webkit-text-size-adjust: 100%;
    }
    h1, h2, h3, h4 { font-family: var(--asd-display); font-weight: 600; letter-spacing: -0.02em; color: var(--asd-primary); }
    h1 { font-size: 26px; }
    h2 { font-size: 22px; }
    h3 { font-size: 18px; }

    /* HIDE original Bootstrap navbar */
    .navbar.navbar-fixed-top,
    .navbar-inverse,
    #wrap > .navbar { display: none !important; }
    #wrap { padding-top: 0; }

    /* SHOW custom mobile-shell */
    .mobile-shell { display: block; }

    /* Drawer toggle (hidden checkbox) */
    .m-drawer-cb { display: none; }

    /* Top Header (sticky) */
    .m-header {
        position: fixed; top: 0; left: 0; right: 0;
        height: 56px;
        background: rgba(255,255,255,0.92);
        border-bottom: 1px solid var(--asd-line);
        display: flex; align-items: center; justify-content: space-between;
        padding: 0 16px;
        z-index: 100;
        backdrop-filter: saturate(180%) blur(14px);
        -webkit-backdrop-filter: saturate(180%) blur(14px);
    }
    .m-brand {
        display: flex; align-items: center; gap: 10px;
        color: var(--asd-primary) !important;
        text-decoration: none !important;
        font-family: var(--asd-display);
        font-weight: 600;
        font-size: 18px;
        letter-spacing: -0.01em;
    }
    .m-brand img { height: 32px; width: auto; display: block; }
    .m-brand span { white-space: nowrap; }

    /* Burger */
    .m-burger {
        width: 40px; height: 40px;
        display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 5px;
        background: transparent; border: 0;
        cursor: pointer; padding: 0;
        border-radius: var(--asd-radius-sm);
        transition: background-color .15s;
    }
    .m-burger:hover, .m-burger:focus { background: rgba(15,52,96,0.06); }
    .m-burger span {
        display: block;
        width: 22px; height: 2px;
        background: var(--asd-primary);
        border-radius: 2px;
        transition: transform .25s, opacity .2s;
    }
    .m-drawer-cb:checked ~ .m-header .m-burger span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
    .m-drawer-cb:checked ~ .m-header .m-burger span:nth-child(2) { opacity: 0; }
    .m-drawer-cb:checked ~ .m-header .m-burger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

    /* Off-Canvas Drawer */
    .m-drawer {
        position: fixed;
        top: 0; right: 0;
        width: 86%; max-width: 360px;
        height: 100vh;
        background: var(--asd-surface);
        box-shadow: var(--asd-shadow-lg);
        transform: translateX(100%);
        transition: transform .32s cubic-bezier(0.32, 0.72, 0, 1);
        z-index: 200;
        padding: 80px 8px 24px;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }
    .m-drawer-cb:checked ~ .m-drawer { transform: translateX(0); }
    .m-drawer a {
        display: flex; align-items: center; gap: 14px;
        padding: 14px 18px;
        margin: 2px 8px;
        border-radius: var(--asd-radius);
        color: var(--asd-ink) !important;
        text-decoration: none !important;
        font-weight: 500;
        font-size: 16px;
        transition: background-color .15s;
    }
    .m-drawer a:hover, .m-drawer a:active { background: var(--asd-cream); color: var(--asd-primary) !important; }
    .m-drawer .m-drawer-section {
        font-family: var(--asd-display);
        font-size: 11px;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.12em;
        color: var(--asd-ink-soft);
        padding: 20px 18px 6px;
    }
    .m-drawer .m-drawer-divider { height: 1px; background: var(--asd-line); margin: 12px 18px; }
    .m-drawer .m-logout { color: #b91c1c !important; }
    .m-drawer .m-drawer-icon {
        width: 22px; height: 22px;
        display: inline-flex; align-items: center; justify-content: center;
        color: var(--asd-accent);
        flex-shrink: 0;
    }

    /* Backdrop */
    .m-backdrop {
        position: fixed; inset: 0;
        background: rgba(10, 37, 64, 0);
        z-index: 150;
        pointer-events: none;
        transition: background-color .32s;
        cursor: pointer;
    }
    .m-drawer-cb:checked ~ .m-backdrop {
        background: rgba(10, 37, 64, 0.55);
        pointer-events: auto;
    }

    /* Bottom TabBar */
    .m-tabbar {
        position: fixed; bottom: 0; left: 0; right: 0;
        height: 76px;
        background: rgba(255,255,255,0.96);
        border-top: 1px solid var(--asd-line);
        display: flex;
        align-items: stretch;
        justify-content: space-around;
        z-index: 100;
        padding-bottom: env(safe-area-inset-bottom, 0);
        backdrop-filter: saturate(180%) blur(14px);
        -webkit-backdrop-filter: saturate(180%) blur(14px);
        box-shadow: 0 -8px 24px -12px rgba(15, 52, 96, 0.10);
    }
    .m-tab {
        flex: 1;
        display: flex; flex-direction: column; align-items: center; justify-content: center;
        gap: 4px;
        color: var(--asd-ink-soft) !important;
        text-decoration: none !important;
        font-size: 11px;
        font-weight: 500;
        padding: 8px 4px;
        transition: color .15s;
    }
    .m-tab svg { width: 26px; height: 26px; }
    .m-tab:hover, .m-tab.active { color: var(--asd-primary) !important; }
    .m-tab.active svg { stroke: var(--asd-accent); }
    .m-tab-primary {
        background: linear-gradient(135deg, var(--asd-accent) 0%, var(--asd-primary) 100%);
        color: #fff !important;
        margin: 10px 6px;
        border-radius: var(--asd-radius-lg);
        box-shadow: 0 6px 16px rgba(0, 123, 163, 0.32);
    }
    .m-tab-primary:hover, .m-tab-primary.active { color: #fff !important; }
    .m-tab-primary svg { stroke: #fff; }

    /* Page content container */
    .container, .container-fluid {
        width: 100% !important;
        padding: 18px 14px !important;
        margin: 0 !important;
        max-width: 100%;
    }
    [class*="span"] { width: 100% !important; margin-left: 0 !important; float: none !important; box-sizing: border-box; }
    .row, .row-fluid { margin-left: 0 !important; display: block; }

    /* Cards: turn .well + bordered tables into cards */
    .well {
        background: var(--asd-surface);
        border: 1px solid var(--asd-line) !important;
        border-radius: var(--asd-radius-lg) !important;
        box-shadow: var(--asd-shadow) !important;
        padding: 18px !important;
        margin-bottom: 14px;
    }

    /* Tables: convert to card list */
    table.table {
        display: block;
        background: transparent;
        border: 0 !important;
        margin-bottom: 16px;
    }
    table.table thead { display: none; }
    table.table tbody, table.table tr, table.table td {
        display: block; width: 100%;
        border: 0 !important;
    }
    table.table tbody tr {
        background: var(--asd-surface);
        border-radius: var(--asd-radius-lg) !important;
        box-shadow: var(--asd-shadow);
        padding: 16px 18px;
        margin-bottom: 12px;
        border: 1px solid var(--asd-line) !important;
    }
    table.table tbody td {
        padding: 4px 0 !important;
        font-size: 14px;
        line-height: 1.45;
        position: relative;
    }
    table.table tbody td:first-child {
        font-family: var(--asd-display);
        font-weight: 600;
        font-size: 17px;
        color: var(--asd-primary);
        margin-bottom: 6px;
    }

    /* Forms */
    label {
        display: block;
        font-size: 13px;
        font-weight: 600;
        margin: 14px 0 6px;
        color: var(--asd-ink-soft);
        text-transform: uppercase;
        letter-spacing: 0.05em;
    }
    input[type="text"], input[type="email"], input[type="password"],
    input[type="number"], input[type="date"], input[type="tel"],
    select, textarea,
    .input-medium, .input-large, .input-xlarge, .input-xxlarge {
        width: 100% !important; max-width: 100% !important;
        height: 48px !important;
        padding: 12px 16px !important;
        font-size: 16px !important;
        font-family: var(--asd-body);
        background: var(--asd-surface) !important;
        border: 1.5px solid var(--asd-line) !important;
        border-radius: var(--asd-radius) !important;
        box-shadow: none !important;
        transition: border-color .15s, box-shadow .15s, background-color .15s;
        box-sizing: border-box;
    }
    textarea { height: auto !important; min-height: 110px !important; padding: 14px 16px !important; }
    input:focus, select:focus, textarea:focus {
        border-color: var(--asd-accent) !important;
        box-shadow: 0 0 0 4px rgba(0, 123, 163, 0.12) !important;
        outline: none !important;
    }

    /* Buttons */
    .btn {
        height: 48px;
        padding: 0 22px !important;
        font-size: 15px !important;
        font-weight: 600;
        font-family: var(--asd-body);
        border-radius: var(--asd-radius-pill) !important;
        border: 0 !important;
        text-shadow: none !important;
        box-shadow: var(--asd-shadow-sm);
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        gap: 8px;
        line-height: 1;
        transition: transform .15s, box-shadow .15s, filter .15s;
    }
    .btn:active { transform: translateY(1px); filter: brightness(0.95); }
    .btn-primary, .btn-warning, .btn-info, .btn-success, .btn-danger {
        width: 100%;
        margin-bottom: 8px;
    }
    .btn-primary {
        background: linear-gradient(135deg, var(--asd-accent) 0%, var(--asd-primary) 100%) !important;
        color: #fff !important;
        box-shadow: 0 6px 16px rgba(0, 123, 163, 0.28);
    }
    .btn-warning { background: var(--asd-accent-warm) !important; color: #fff !important; }

    /* Status badges */
    .label, .badge {
        padding: 5px 12px !important;
        border-radius: var(--asd-radius-pill);
        font-size: 11px;
        font-weight: 600;
        letter-spacing: 0.04em;
        text-transform: uppercase;
        font-family: var(--asd-body);
    }
    .label-warning, .badge-warning { background: #fef3c7 !important; color: #92400e !important; }
    .label-success, .badge-success { background: #d1fae5 !important; color: #065f46 !important; }
    .label-info, .badge-info { background: #dbeafe !important; color: #1e40af !important; }
    .label-important, .badge-important { background: #fee2e2 !important; color: #991b1b !important; }

    /* Login page mobile */
    .vertical-center { min-height: auto !important; padding: 32px 16px !important; }
    .form-box {
        padding: 28px 22px !important;
        margin: 16px 0;
        border-radius: var(--asd-radius-lg) !important;
        box-shadow: var(--asd-shadow-lg) !important;
        border-top: 4px solid var(--asd-accent-warm) !important;
        background: var(--asd-surface);
    }
    .form-box h2 {
        font-size: 26px;
        font-family: var(--asd-display);
        color: var(--asd-primary);
        margin: 0 0 16px;
        letter-spacing: -0.01em;
    }

    /* Modal mobile */
    .modal {
        width: 92% !important; left: 4% !important; margin: 0 !important;
        top: 16px !important;
        border-radius: var(--asd-radius-lg);
    }
    .modal-body { max-height: 70vh; overflow-y: auto; padding: 16px 20px; }
    .modal-header { border-radius: var(--asd-radius-lg) var(--asd-radius-lg) 0 0; padding: 16px 20px; }
    .modal-footer { padding: 12px 20px; border-radius: 0 0 var(--asd-radius-lg) var(--asd-radius-lg); }

    /* FullCalendar mobile */
    .fc-toolbar { flex-direction: column !important; align-items: stretch !important; gap: 10px; padding: 4px 0; }
    .fc-toolbar .fc-left, .fc-toolbar .fc-center, .fc-toolbar .fc-right {
        display: flex !important; justify-content: center; gap: 6px;
    }
    .fc-toolbar h2 { font-size: 18px !important; font-family: var(--asd-display) !important; }
    .fc-day-header { font-size: 11px !important; padding: 6px 0 !important; }
    .fc-event { font-size: 11px !important; padding: 2px 5px !important; border-radius: 6px !important; }
    .fc-day-number { font-size: 12px !important; padding: 2px 4px !important; }

    /* Stagger reveal animation */
    .container > * { animation: asdFadeUp .42s ease both; }
    .container > *:nth-child(2) { animation-delay: .06s; }
    .container > *:nth-child(3) { animation-delay: .12s; }
    .container > *:nth-child(4) { animation-delay: .18s; }
    @keyframes asdFadeUp {
        from { opacity: 0; transform: translateY(8px); }
        to   { opacity: 1; transform: translateY(0); }
    }

    footer { padding: 16px; font-size: 11px; text-align: center; color: var(--asd-ink-soft); }
}

/* Tablet polish */
@media (min-width: 768px) and (max-width: 1024px) {
    body { font-size: 15px; }
}

/* ═══════════════════════════════════════════════════════════
 * DESKTOP POLISH — unified look with mobile
 * (applies globally; mobile media-query above overrides where needed)
 * ═══════════════════════════════════════════════════════════ */

html, body {
    font-family: var(--asd-body);
    color: var(--asd-ink);
    background: var(--asd-cream);
    background-image:
        radial-gradient(at 8% -5%, rgba(0,123,163,0.06) 0%, transparent 45%),
        radial-gradient(at 92% 105%, rgba(166,117,22,0.05) 0%, transparent 50%);
    background-attachment: fixed;
}
h1, h2, h3, h4, h5, .page-header h1, .page-header h2 {
    font-family: var(--asd-display);
    font-weight: 600;
    letter-spacing: -0.015em;
    color: var(--asd-primary);
}
.page-header { border-bottom-color: var(--asd-line); padding-bottom: 12px; margin: 20px 0 24px; }

/* ── Desktop top navbar: light + clean (override Bootstrap dark) ── */
@media (min-width: 768px) {
    body {
        padding-top: 72px !important;
    }
    .navbar.navbar-fixed-top,
    .navbar-inverse {
        background: rgba(255,255,255,0.92) !important;
        background-image: none !important;
        border: 0 !important;
        box-shadow: 0 1px 3px rgba(15, 52, 96, 0.06), 0 8px 24px -16px rgba(15, 52, 96, 0.12) !important;
        backdrop-filter: saturate(180%) blur(14px);
        -webkit-backdrop-filter: saturate(180%) blur(14px);
        min-height: 60px;
    }
    .navbar.navbar-fixed-top .navbar-inner {
        background: transparent !important;
        background-image: none !important;
        border: 0 !important;
        box-shadow: none !important;
        min-height: 60px;
        padding: 0 28px;
    }
    .navbar-inverse .brand,
    .navbar.navbar-fixed-top .brand {
        color: var(--asd-primary) !important;
        font-family: var(--asd-display);
        font-weight: 600;
        font-size: 19px;
        letter-spacing: -0.01em;
        padding: 18px 12px 18px 0 !important;
        text-shadow: none !important;
    }
    .navbar-inverse .nav > li > a,
    .navbar.navbar-fixed-top .nav > li > a {
        color: var(--asd-ink-soft) !important;
        font-weight: 500;
        padding: 20px 14px !important;
        text-shadow: none !important;
        background: transparent !important;
        transition: color .15s;
    }
    .navbar-inverse .nav > li > a:hover,
    .navbar-inverse .nav > .active > a,
    .navbar.navbar-fixed-top .nav > li > a:hover {
        color: var(--asd-primary) !important;
        background: transparent !important;
    }
    .navbar .nav > li.dropdown.open > .dropdown-toggle,
    .navbar .nav > li > .dropdown-toggle:focus {
        background: transparent !important;
        color: var(--asd-primary) !important;
    }
    .navbar .dropdown-menu {
        margin-top: 4px;
        border: 1px solid var(--asd-line);
        border-radius: var(--asd-radius);
        box-shadow: var(--asd-shadow-lg);
        padding: 8px;
        background: var(--asd-surface);
    }
    .navbar .dropdown-menu > li > a {
        padding: 10px 14px !important;
        border-radius: var(--asd-radius-sm);
        color: var(--asd-ink) !important;
        font-weight: 500;
    }
    .navbar .dropdown-menu > li > a:hover,
    .navbar .dropdown-menu > li > a:focus {
        background: var(--asd-cream) !important;
        color: var(--asd-primary) !important;
    }
    .navbar .dropdown-menu .nav-header {
        font-family: var(--asd-display);
        font-size: 11px;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.12em;
        color: var(--asd-ink-soft);
        padding: 8px 14px 4px;
    }
    .navbar .dropdown-menu .divider {
        background: var(--asd-line);
        border: 0;
        height: 1px;
        margin: 6px 4px;
    }
    .navbar-form .btn.btn-warning,
    .navbar-form .btn {
        height: 38px;
        padding: 0 18px !important;
        border-radius: var(--asd-radius-pill) !important;
        background: linear-gradient(135deg, var(--asd-accent) 0%, var(--asd-primary) 100%) !important;
        background-image: linear-gradient(135deg, var(--asd-accent) 0%, var(--asd-primary) 100%) !important;
        color: #fff !important;
        font-weight: 600;
        border: 0 !important;
        text-shadow: none !important;
        box-shadow: 0 4px 12px rgba(0,123,163,0.28) !important;
        display: inline-flex !important;
        align-items: center;
    }
    .navbar .pull-right .brand {
        font-family: var(--asd-body) !important;
        font-size: 14px !important;
        font-weight: 500 !important;
        color: var(--asd-ink-soft) !important;
        padding: 20px 8px !important;
    }
    .navbar-inverse .nav .badge { vertical-align: middle; }
}

/* ── Buttons (global pill) ── */
.btn {
    font-family: var(--asd-body);
    font-weight: 600;
    border-radius: var(--asd-radius-pill);
    border: 0 !important;
    text-shadow: none !important;
    padding: 9px 18px;
    box-shadow: var(--asd-shadow-sm);
    transition: transform .12s, filter .12s, box-shadow .12s;
}
.btn:hover { filter: brightness(1.04); }
.btn:active { transform: translateY(1px); }
.btn-primary {
    background: linear-gradient(135deg, var(--asd-accent) 0%, var(--asd-primary) 100%) !important;
    background-image: linear-gradient(135deg, var(--asd-accent) 0%, var(--asd-primary) 100%) !important;
    color: #fff !important;
    box-shadow: 0 4px 12px rgba(0,123,163,0.24);
}
.btn-warning {
    background: var(--asd-accent-warm) !important;
    background-image: none !important;
    color: #fff !important;
}
.btn-info {
    background: var(--asd-primary) !important;
    background-image: none !important;
    color: #fff !important;
}
.btn-success {
    background: #10b981 !important;
    background-image: none !important;
    color: #fff !important;
}
.btn-danger {
    background: #ef4444 !important;
    background-image: none !important;
    color: #fff !important;
}

/* ── Inputs (global modern style) ── */
input[type="text"], input[type="email"], input[type="password"],
input[type="number"], input[type="date"], input[type="tel"],
select, textarea,
.input-medium, .input-large, .input-xlarge, .input-xxlarge {
    font-family: var(--asd-body) !important;
    background: var(--asd-surface) !important;
    border: 1.5px solid var(--asd-line) !important;
    border-radius: var(--asd-radius) !important;
    box-shadow: none !important;
    padding: 10px 14px !important;
    height: 42px;
    color: var(--asd-ink);
    transition: border-color .15s, box-shadow .15s;
}
textarea { min-height: 96px; height: auto !important; }
input:focus, select:focus, textarea:focus {
    border-color: var(--asd-accent) !important;
    box-shadow: 0 0 0 4px rgba(0, 123, 163, 0.12) !important;
    outline: 0 !important;
}

/* ── Tables (desktop modern) ── */
@media (min-width: 768px) {
    table.table {
        background: var(--asd-surface);
        border: 1px solid var(--asd-line) !important;
        border-radius: var(--asd-radius) !important;
        overflow: hidden;
        box-shadow: var(--asd-shadow-sm);
    }
    table.table thead th {
        background: var(--asd-cream) !important;
        color: var(--asd-ink-soft) !important;
        font-family: var(--asd-body);
        font-size: 12px;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.06em;
        border-bottom: 1px solid var(--asd-line) !important;
        padding: 12px 14px !important;
    }
    table.table tbody td {
        padding: 12px 14px !important;
        border-top: 1px solid var(--asd-line) !important;
        vertical-align: middle;
        font-size: 14px;
    }
    table.table tbody tr:hover td {
        background: rgba(0,123,163,0.04);
    }
    table.table-striped tbody tr:nth-child(2n) td {
        background: rgba(15,52,96,0.02);
    }
}

/* ── Cards (.well) ── */
.well {
    background: var(--asd-surface) !important;
    border: 1px solid var(--asd-line) !important;
    border-radius: var(--asd-radius-lg) !important;
    box-shadow: var(--asd-shadow) !important;
    padding: 22px !important;
}

/* ── Labels / badges ── */
.label, .badge {
    font-family: var(--asd-body) !important;
    font-weight: 600;
    font-size: 11px;
    padding: 4px 10px !important;
    border-radius: var(--asd-radius-pill);
    letter-spacing: 0.04em;
    text-transform: uppercase;
    text-shadow: none !important;
}
.label-warning, .badge-warning { background: #fef3c7 !important; color: #92400e !important; }
.label-success, .badge-success { background: #d1fae5 !important; color: #065f46 !important; }
.label-info, .badge-info { background: #dbeafe !important; color: #1e40af !important; }
.label-important, .badge-important { background: #fee2e2 !important; color: #991b1b !important; }

/* ── Container max-width on desktop (Bootstrap-2 was 940px, tight) ── */
@media (min-width: 1200px) {
    .container { max-width: 1180px !important; width: auto !important; }
}

/* ── FullCalendar desktop polish ── */
.fc-toolbar h2 { font-family: var(--asd-display); font-weight: 600; color: var(--asd-primary); }
.fc-button {
    background: var(--asd-surface) !important;
    background-image: none !important;
    color: var(--asd-ink) !important;
    border: 1px solid var(--asd-line) !important;
    border-radius: var(--asd-radius-sm) !important;
    text-shadow: none !important;
    box-shadow: none !important;
    padding: 6px 12px !important;
}
.fc-button:hover { background: var(--asd-cream) !important; color: var(--asd-primary) !important; }
.fc-button.fc-state-active, .fc-button:active {
    background: var(--asd-primary) !important;
    color: #fff !important;
    border-color: var(--asd-primary) !important;
}
.fc-event {
    background: linear-gradient(135deg, var(--asd-accent), var(--asd-primary)) !important;
    border: 0 !important;
    border-radius: 6px !important;
    padding: 2px 6px !important;
    color: #fff !important;
    font-weight: 500;
    font-size: 12px;
}
.fc-day-header { background: var(--asd-cream); color: var(--asd-ink-soft); font-weight: 600; }

/* ── Form-actions sticky helper ── */
.form-actions {
    background: transparent !important;
    border-top: 1px solid var(--asd-line) !important;
    padding: 18px 0 !important;
    margin-top: 24px !important;
}

/* ── Modal polish ── */
.modal {
    border-radius: var(--asd-radius-lg) !important;
    box-shadow: var(--asd-shadow-lg) !important;
    border: 0 !important;
}
.modal-header { border-bottom-color: var(--asd-line) !important; padding: 18px 22px !important; }
.modal-header h3 { font-family: var(--asd-display); color: var(--asd-primary); }
.modal-body { padding: 20px 22px !important; }
.modal-footer { border-top-color: var(--asd-line) !important; padding: 14px 22px !important; }

/* ── Subtle entry animation also on Desktop ── */
@media (min-width: 768px) {
    .container > * { animation: asdFadeUpDesktop .35s ease both; }
    .container > *:nth-child(2) { animation-delay: .05s; }
    .container > *:nth-child(3) { animation-delay: .10s; }
    @keyframes asdFadeUpDesktop {
        from { opacity: 0; transform: translateY(6px); }
        to   { opacity: 1; transform: translateY(0); }
    }
}

/* ── Login page — global polish (both desktop+mobile) ── */
.form-box {
    background: var(--asd-surface);
    border-radius: var(--asd-radius-lg) !important;
    border-top: 4px solid var(--asd-accent-warm) !important;
    box-shadow: var(--asd-shadow-lg) !important;
    padding: 32px !important;
}
.form-box h2 {
    font-family: var(--asd-display);
    color: var(--asd-primary);
    font-size: 28px;
    font-weight: 600;
    letter-spacing: -0.015em;
    margin: 0 0 18px;
}

/* ═══════════════════════════════════════════════════════════
 * POLISH FIXES — UI/UX Pro Max Audit pass (2026-05-22)
 * ═══════════════════════════════════════════════════════════ */

/* ── §1 A11y: prefers-reduced-motion ── */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        animation-delay: 0ms !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
    .m-drawer { transition: none !important; }
    .m-backdrop { transition: none !important; }
}

/* ── §1 A11y: Focus-Visible ring on all interactive ── */
.btn:focus-visible,
input:focus-visible, select:focus-visible, textarea:focus-visible,
.m-tab:focus-visible, .m-brand:focus-visible, .m-burger:focus-visible,
.m-drawer a:focus-visible {
    outline: 3px solid var(--asd-accent) !important;
    outline-offset: 2px !important;
    box-shadow: 0 0 0 6px rgba(0, 123, 163, 0.15) !important;
}
.btn:focus { outline: 0; }
*:focus:not(:focus-visible) { outline: 0; box-shadow: none; }

/* ── §6 Tabular numbers in tables (alignment of dates/durations/counts) ── */
table.table td, table.table th,
.tabular, .badge, .label,
input[type="number"], input[type="date"] {
    font-variant-numeric: tabular-nums;
    font-feature-settings: "tnum" 1;
}

/* ── §8 Disabled / loading button polish ── */
.btn[disabled], .btn.disabled {
    opacity: 0.4 !important;
    cursor: not-allowed !important;
    filter: grayscale(0.3);
    box-shadow: none !important;
    transform: none !important;
}
.btn[disabled]:hover, .btn.disabled:hover {
    filter: grayscale(0.3) !important;
}

/* ── Form-box: prevent border-radius cropping the warm-gold border-top ── */
.form-box {
    overflow: hidden;
    position: relative;
    border-top: 0 !important;
}
.form-box::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--asd-accent-warm) 0%, #d4a05a 50%, var(--asd-accent-warm) 100%);
    border-top-left-radius: var(--asd-radius-lg);
    border-top-right-radius: var(--asd-radius-lg);
    z-index: 1;
}

/* ── Custom scrollbar (Desktop only, Webkit) ── */
@media (min-width: 768px) {
    *::-webkit-scrollbar { width: 10px; height: 10px; }
    *::-webkit-scrollbar-track { background: transparent; }
    *::-webkit-scrollbar-thumb {
        background: var(--asd-line);
        border-radius: 6px;
        border: 2px solid transparent;
        background-clip: padding-box;
    }
    *::-webkit-scrollbar-thumb:hover { background: rgba(15,52,96,0.18); background-clip: padding-box; border: 2px solid transparent; }
}

/* ── Mobile-specific overrides (override the earlier @media block) ── */
@media (max-width: 767px) {
    /* Login page on mobile: kein padding-top/bottom + Gradient als BG (statt cream) */
    body:has(.form-box) {
        padding-top: 0 !important;
        padding-bottom: 0 !important;
        min-height: 100vh;
        background: linear-gradient(135deg, #0f3460 0%, #0a2540 35%, #007ba3 80%, #006d91 100%) !important;
        background-image: linear-gradient(135deg, #0f3460 0%, #0a2540 35%, #007ba3 80%, #006d91 100%) !important;
    }
    body:has(.form-box) .vertical-center {
        min-height: 100vh !important;
        padding: 0 20px !important;
    }

    /* Brand img not too big in compact header */
    .m-brand img { max-height: 32px; }

    /* Drawer: scroll inertia + safe-area bottom */
    .m-drawer {
        padding-bottom: calc(24px + env(safe-area-inset-bottom, 0));
    }

    /* TabBar safe-area on iOS */
    .m-tabbar {
        height: calc(76px + env(safe-area-inset-bottom, 0));
    }

    /* Card-tables: subtle hover only on devices that support it */
    @media (hover: hover) {
        table.table tbody tr:hover { transform: translateY(-1px); box-shadow: var(--asd-shadow-lg); transition: transform .15s, box-shadow .15s; }
    }

    /* Mobile: status badge in card-row goes inline-block right */
    table.table tbody td .label,
    table.table tbody td .badge {
        display: inline-block;
        margin-top: 2px;
    }

    /* Mobile bottom-bar: pressed feedback */
    .m-tab:active { transform: scale(0.96); transition: transform .1s; }
    .m-tab-primary:active { transform: scale(0.96); }
}

/* ── Selection color matches brand ── */
::selection { background: rgba(0, 123, 163, 0.22); color: var(--asd-primary); }
::-moz-selection { background: rgba(0, 123, 163, 0.22); color: var(--asd-primary); }

/* ── Skip-to-content link (a11y) ── */
.skip-to-main {
    position: absolute;
    top: -40px;
    left: 8px;
    background: var(--asd-primary);
    color: #fff !important;
    padding: 10px 16px;
    border-radius: var(--asd-radius);
    z-index: 9999;
    font-weight: 600;
    text-decoration: none !important;
    transition: top .2s;
}
.skip-to-main:focus { top: 8px; }

/* ── Empty states polished ── */
.empty-state, .no-data {
    text-align: center;
    padding: 48px 16px;
    color: var(--asd-ink-soft);
    font-family: var(--asd-body);
}
.empty-state h3, .no-data h3 {
    font-family: var(--asd-display);
    font-size: 20px;
    color: var(--asd-primary);
    margin-bottom: 6px;
}

/* ── Print: clean output without nav ── */
@media print {
    .navbar, .mobile-shell, .m-tabbar, .m-drawer, .m-header, .m-backdrop,
    footer, .navbar-fixed-top { display: none !important; }
    body { padding: 0 !important; background: #fff !important; }
    .container { max-width: 100% !important; }
    a { color: #000 !important; text-decoration: underline; }
    table.table { box-shadow: none !important; border: 1px solid #000 !important; }
}

/* ── Consolidate: nur ein gemeinsamer Kalender ── */
a[href$="/calendar/individual"],
a[href$="/calendar/workmates"],
a[href$="/calendar/department"],
a[href$="/calendar/collaborators"] { display: none !important; }

/* ═══════════════════════════════════════════════════════════
 * BUG-HUNT PASS — Visual fixes across views (2026-05-22)
 * ═══════════════════════════════════════════════════════════ */

/* ── Bootstrap-2 form classes (.control-group / .control-label / .controls) ── */
.control-group {
    margin-bottom: 14px;
    display: block;
}
.control-group .control-label {
    display: block;
    font-family: var(--asd-body);
    font-size: 13px;
    font-weight: 600;
    color: var(--asd-ink-soft);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin: 0 0 6px;
    text-align: left !important;
}
.control-group .controls { margin-left: 0 !important; }
.control-group .controls input,
.control-group .controls select,
.control-group .controls textarea {
    width: auto;
    min-width: 240px;
}
.help-block, .help-inline {
    font-size: 12.5px;
    color: var(--asd-ink-soft);
    margin-top: 4px;
    font-family: var(--asd-body);
}
.control-group.error .control-label,
.control-group.error .help-block,
.control-group.error .help-inline { color: #b91c1c; }
.control-group.error input,
.control-group.error select,
.control-group.error textarea {
    border-color: #fca5a5 !important;
    background: #fef2f2 !important;
}

/* ── Bootstrap-2 alerts ── */
.alert {
    border: 0 !important;
    border-radius: var(--asd-radius) !important;
    padding: 14px 18px !important;
    font-family: var(--asd-body);
    box-shadow: var(--asd-shadow-sm);
    text-shadow: none !important;
    margin: 12px 0 16px;
}
.alert-error, .alert-danger {
    background: #fee2e2 !important;
    color: #991b1b !important;
}
.alert-success { background: #d1fae5 !important; color: #065f46 !important; }
.alert-info { background: #dbeafe !important; color: #1e40af !important; }
.alert-warning { background: #fef3c7 !important; color: #92400e !important; }
.alert .close {
    color: inherit !important;
    opacity: 0.6;
    text-shadow: none !important;
    font-weight: 400;
    line-height: 1;
}
.alert .close:hover { opacity: 1; }

/* ── jQuery UI Datepicker → ASD CI ── */
.ui-datepicker {
    background: var(--asd-surface) !important;
    border: 1px solid var(--asd-line) !important;
    border-radius: var(--asd-radius) !important;
    box-shadow: var(--asd-shadow-lg) !important;
    padding: 12px !important;
    font-family: var(--asd-body) !important;
    width: auto !important;
    max-width: 320px;
}
.ui-datepicker-header {
    background: transparent !important;
    border: 0 !important;
    color: var(--asd-primary) !important;
    font-family: var(--asd-display);
    padding-bottom: 8px;
}
.ui-datepicker-title { font-weight: 600 !important; color: var(--asd-primary) !important; }
.ui-datepicker-prev, .ui-datepicker-next {
    cursor: pointer !important;
    border-radius: var(--asd-radius-sm) !important;
    transition: background-color .15s;
    top: 6px !important;
}
.ui-datepicker-prev:hover, .ui-datepicker-next:hover { background: var(--asd-cream) !important; }
.ui-datepicker table {
    border-collapse: separate;
    border-spacing: 2px;
}
.ui-datepicker td a, .ui-datepicker td span {
    padding: 8px 4px !important;
    border-radius: var(--asd-radius-sm) !important;
    text-align: center;
    background: transparent !important;
    color: var(--asd-ink) !important;
    font-weight: 500;
    border: 0 !important;
    transition: background-color .12s, color .12s;
}
.ui-datepicker td a:hover {
    background: var(--asd-cream) !important;
    color: var(--asd-primary) !important;
}
.ui-datepicker td .ui-state-active {
    background: linear-gradient(135deg, var(--asd-accent), var(--asd-primary)) !important;
    color: #fff !important;
}
.ui-datepicker .ui-state-highlight { /* today */
    background: var(--asd-accent-warm) !important;
    color: #fff !important;
    border-radius: var(--asd-radius-sm) !important;
}
.ui-datepicker th {
    font-weight: 600;
    color: var(--asd-ink-soft);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 6px 4px;
}

/* ── leaves/create form: layout polish ── */
#frmLeaveForm br { display: none; }
#frmLeaveForm > label { margin-top: 16px; }
#frmLeaveForm select[name="startdatetype"],
#frmLeaveForm select[name="enddatetype"] {
    margin-top: 8px;
    width: auto;
    min-width: 160px;
}
#frmLeaveForm input#viz_startdate,
#frmLeaveForm input#viz_enddate {
    width: 180px;
    min-width: 180px;
    display: inline-block;
}
#frmLeaveForm input#duration {
    width: 100px;
    min-width: 100px;
    display: inline-block;
}
#frmLeaveForm textarea {
    width: 100%;
    max-width: 600px;
    min-height: 90px;
    margin-top: 4px;
}

/* Button-group as proper form-actions */
#frmLeaveForm button[type="submit"],
#frmLeaveForm + form button[type="submit"] {
    margin-right: 8px;
    margin-top: 10px;
}
#frmLeaveForm a.btn-danger {
    margin-top: 10px;
    background: transparent !important;
    background-image: none !important;
    color: var(--asd-ink-soft) !important;
    box-shadow: none !important;
    border: 1.5px solid var(--asd-line) !important;
}
#frmLeaveForm a.btn-danger:hover {
    color: #b91c1c !important;
    border-color: #fca5a5 !important;
    background: #fef2f2 !important;
}

/* ── Single-item dropdown: hide caret + make it a direct link feel ── */
.navbar .nav > li.dropdown:has(.dropdown-menu > li:only-child) > .dropdown-toggle .caret {
    display: none;
}

/* ── Modal Bootstrap-2 positioning ── */
.modal.hide.in, .modal.in { display: block !important; }
.modal-backdrop { background: rgba(10, 37, 64, 0.55); }
.modal-backdrop.in { opacity: 1 !important; }

/* ── FullCalendar v2.8 visual polish ── */
.fc-state-default {
    background: var(--asd-surface) !important;
    background-image: none !important;
    border: 1px solid var(--asd-line) !important;
    color: var(--asd-ink) !important;
    text-shadow: none !important;
    box-shadow: none !important;
    border-radius: var(--asd-radius-sm) !important;
}
.fc-state-default:hover { background: var(--asd-cream) !important; color: var(--asd-primary) !important; }
.fc-state-active, .fc-state-down {
    background: var(--asd-primary) !important;
    color: #fff !important;
    border-color: var(--asd-primary) !important;
}
.fc-today { background: rgba(0, 123, 163, 0.06) !important; }
.fc-event {
    background: linear-gradient(135deg, var(--asd-accent), var(--asd-primary)) !important;
    border: 0 !important;
    color: #fff !important;
    padding: 2px 6px !important;
    border-radius: 6px !important;
    font-weight: 500;
    font-size: 12px;
}
.fc-other-month { opacity: 0.45; }
.fc-day-grid-event { margin: 1px 2px !important; }

/* FullCalendar mobile: compress header */
@media (max-width: 767px) {
    .fc-toolbar {
        gap: 8px;
    }
    .fc-toolbar h2 {
        font-size: 17px !important;
        text-align: center;
        flex: 1;
    }
    .fc-button {
        padding: 6px 10px !important;
        font-size: 12px !important;
    }
    .fc-day-header {
        font-size: 10px !important;
        padding: 4px 0 !important;
    }
    .fc-day-grid .fc-row {
        min-height: 56px !important;
    }
    .fc-event {
        font-size: 10px !important;
        padding: 1px 4px !important;
    }
    .fc-day-number {
        font-size: 11px !important;
    }
    /* Hide month/agendaWeek buttons text on small screens, keep icons */
    .fc-button-group .fc-button { min-width: 36px; }
}

/* ── Modal mobile fix (override .modal.hide left/top from Bootstrap-2) ── */
@media (max-width: 767px) {
    .modal {
        position: fixed !important;
        top: 5% !important;
        left: 5% !important;
        right: 5% !important;
        bottom: auto !important;
        width: auto !important;
        max-width: 90vw !important;
        margin: 0 !important;
    }
}

/* ── Profile-picture sizing if rendered as plain <img> ── */
img[src*="/users/picture/"], .avatar, .profile-image {
    border-radius: 50%;
    object-fit: cover;
    width: 96px;
    height: 96px;
    border: 3px solid var(--asd-surface);
    box-shadow: var(--asd-shadow);
}

/* ── Bootstrap-2 alert .close button ── */
.close {
    background: transparent !important;
    border: 0;
    cursor: pointer;
    font-size: 22px;
    line-height: 1;
    color: inherit;
    opacity: 0.55;
    transition: opacity .15s;
}
.close:hover { opacity: 1; }

/* ── Mobile: reset all <br> spacing inside forms ── */
@media (max-width: 767px) {
    form br { display: none; }
    form label { margin-top: 12px; }
    #frmLeaveForm input#viz_startdate,
    #frmLeaveForm input#viz_enddate,
    #frmLeaveForm input#duration {
        width: 100% !important;
        min-width: 0 !important;
        display: block !important;
        margin-bottom: 8px;
    }
    #frmLeaveForm select[name="startdatetype"],
    #frmLeaveForm select[name="enddatetype"] {
        width: 100% !important;
        min-width: 0 !important;
        margin-bottom: 12px;
    }
    #frmLeaveForm button[type="submit"],
    #frmLeaveForm a.btn-danger {
        display: block;
        width: 100%;
        margin: 6px 0;
    }
}

/* ── Container "row-fluid > .span8" desktop: max-width ── */
@media (min-width: 768px) {
    .row-fluid .span8, .row-fluid .span9 { max-width: 720px; }
}

/* ── Bootstrap-2 .muted: cleanup ── */
.muted { color: var(--asd-ink-soft) !important; font-weight: 500; }

/* ── Loading spinner: brand the loading gif ── */
img[src$="/loading.gif"] {
    width: 32px;
    height: 32px;
    filter: hue-rotate(180deg) saturate(0.5);
}

/* ── Tooltip Bootstrap-2 ── */
.tooltip-inner {
    background: var(--asd-primary) !important;
    border-radius: var(--asd-radius-sm) !important;
    font-family: var(--asd-body);
    font-size: 12px;
    padding: 6px 10px !important;
    max-width: 240px;
}
.tooltip.in { opacity: 0.96 !important; }
.tooltip-arrow {
    border-top-color: var(--asd-primary) !important;
    border-bottom-color: var(--asd-primary) !important;
}

/* ── Dropdown caret subtle ── */
.caret { border-top-color: currentColor !important; opacity: 0.55; }
