/* =====================================================================
   VidiClock — Bootstrap ↔ VidiScope-Token-Bridge
   Lädt NACH bootstrap.css und vs-tokens.css.
   vs-tokens.css liefert die Marken-Variablen (--vs-*, --accent, --fg-*,
   --bg-*, Radii, Schatten, Fonts). Diese Datei mappt Bootstraps --bs-*
   darauf und definiert den Dark-Mode + die Komponenten-Feinheiten.
   Markenfarben 1:1 von vidiscope.com (css/vs-tokens.css).
   ===================================================================== */

/* ─── Bootstrap-Variablen auf VidiScope-Tokens mappen (Light) ───────── */
:root {
    --bs-body-bg: var(--bg-canvas);
    --bs-body-color: var(--fg-1);
    --bs-secondary-color: var(--fg-2);
    --bs-tertiary-color: var(--fg-3);
    --bs-body-font-family: var(--font-sans);
    --bs-emphasis-color: var(--fg-1);

    --bs-border-color: var(--border-subtle);
    --bs-border-color-translucent: var(--border-subtle);

    --bs-border-radius: var(--radius-md);
    --bs-border-radius-sm: var(--radius-sm);
    --bs-border-radius-lg: var(--radius-lg);
    --bs-border-radius-xl: var(--radius-xl);

    --bs-box-shadow: var(--shadow-md);
    --bs-box-shadow-sm: var(--shadow-sm);
    --bs-box-shadow-lg: var(--shadow-lg);

    /* Brand = Navy (Struktur, Links, Outline). CTA = Gold (siehe .btn-primary) */
    --bs-primary: var(--vs-midnight-navy);
    --bs-primary-rgb: 7, 26, 47;
    --bs-secondary: var(--vs-slate-blue);
    --bs-secondary-rgb: 36, 59, 83;
    --bs-success: var(--status-success);
    --bs-success-rgb: 30, 142, 90;
    --bs-danger: var(--status-danger);
    --bs-danger-rgb: 197, 52, 52;
    --bs-warning: var(--vs-warm-sand);
    --bs-warning-rgb: 242, 160, 31;
    --bs-info: var(--vs-slate-blue);
    --bs-info-rgb: 36, 59, 83;

    --bs-link-color: var(--vs-slate-blue);
    --bs-link-color-rgb: 36, 59, 83;
    --bs-link-hover-color: var(--accent-press);
    --bs-link-hover-color-rgb: 184, 134, 31;

    --bs-focus-ring-color: var(--accent-ring);
}

/* ─── Dark-Mode (VidiScope-Werte) — getoggelt via data-bs-theme="dark" ─ */
[data-bs-theme="dark"] {
    --bg-canvas: #0B131D;
    --bg-surface: #15202E;
    --bg-surface-2: #1B2738;
    --fg-1: #F3F6FA;
    --fg-2: #C5CFDC;
    --fg-3: #8A98AB;
    --border-subtle: rgba(255, 255, 255, 0.08);
    --border-default: rgba(255, 255, 255, 0.14);
    --shadow-md: 0 4px 14px rgba(0, 0, 0, 0.45), 0 2px 4px rgba(0, 0, 0, 0.3);
    --shadow-lg: 0 14px 32px rgba(0, 0, 0, 0.55), 0 4px 8px rgba(0, 0, 0, 0.35);

    --bs-body-bg: var(--bg-canvas);
    --bs-body-color: var(--fg-1);
    --bs-secondary-bg: var(--bg-surface-2);
    --bs-tertiary-bg: var(--bg-surface-2);
    --bs-secondary-color: var(--fg-2);
    --bs-tertiary-color: var(--fg-3);
    --bs-border-color: var(--border-default);
    --bs-emphasis-color: var(--fg-1);
    --bs-heading-color: var(--fg-1);

    --bs-card-bg: var(--bg-surface);
    --bs-card-cap-bg: var(--bg-surface-2);
    --bs-modal-bg: var(--bg-surface);
    --bs-dropdown-bg: var(--bg-surface);
    --bs-dropdown-link-hover-bg: var(--bg-surface-2);

    /* Links etwas heller im Dunkeln */
    --bs-link-color: var(--vs-amber);
    --bs-link-color-rgb: 232, 180, 82;
    --bs-link-hover-color: var(--vs-warm-sand);
    --bs-link-hover-color-rgb: 242, 160, 31;
}

/* ─── Basis ─────────────────────────────────────────────────────────── */
body {
    font-family: var(--font-sans);
    background: var(--bg-canvas);
    color: var(--fg-1);
}

h1, h2, h3, .h1, .h2, .h3, .navbar-brand {
    font-family: var(--font-display);
    letter-spacing: var(--ls-display);
}

code, .font-mono { font-family: var(--font-mono); }

/* ─── Marken-Flächen (ersetzen die .bg-white-Navbars; dark-fest) ────── */
.vc-surface { background: var(--bg-surface) !important; }
.navbar.vc-navbar {
    background: var(--bg-surface);
    border-bottom: 1px solid var(--border-subtle);
    box-shadow: var(--shadow-sm);
}
.navbar-brand { font-weight: var(--fw-bold); color: var(--fg-1); display: inline-flex; align-items: center; gap: .5rem; }
.navbar-brand img { height: 26px; width: auto; display: block; }

/* Aktiver Navi-Punkt: navy/gold-Akzent statt Bootstrap-Blau */
.navbar .nav-link.active,
.navbar .nav-link.show { color: var(--fg-1); font-weight: var(--fw-semibold); }
.navbar .dropdown-item.active,
.navbar .dropdown-item:active {
    background: var(--accent-soft);
    color: var(--vs-midnight-navy);
}

/* ─── Buttons ───────────────────────────────────────────────────────── */
.btn { --bs-btn-border-radius: var(--radius-md); font-weight: var(--fw-semibold); }
.btn:focus-visible { box-shadow: var(--shadow-focus); }

/* Primär-CTA = Gold mit navy Text (VidiScope-Signatur) */
.btn-primary {
    --bs-btn-bg: var(--accent);
    --bs-btn-border-color: var(--accent);
    --bs-btn-color: var(--vs-midnight-navy);
    --bs-btn-hover-bg: var(--accent-hover);
    --bs-btn-hover-border-color: var(--accent-hover);
    --bs-btn-hover-color: var(--vs-midnight-navy);
    --bs-btn-active-bg: var(--accent-press);
    --bs-btn-active-border-color: var(--accent-press);
    --bs-btn-active-color: var(--vs-midnight-navy);
    --bs-btn-disabled-bg: var(--accent);
    --bs-btn-disabled-border-color: var(--accent);
    --bs-btn-disabled-color: var(--vs-midnight-navy);
    --bs-btn-focus-shadow-rgb: 242, 160, 31;
}

.btn-outline-primary {
    --bs-btn-color: var(--vs-slate-blue);
    --bs-btn-border-color: var(--vs-slate-blue);
    --bs-btn-hover-bg: var(--vs-slate-blue);
    --bs-btn-hover-border-color: var(--vs-slate-blue);
    --bs-btn-active-bg: var(--vs-midnight-navy);
}

/* Touch-Targets: Icon-Aktions-Buttons auf ≥40px (mit hitslop ~44px) */
.btn-icon {
    --bs-btn-padding-x: .5rem;
    --bs-btn-padding-y: .5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    min-height: 40px;
    line-height: 1;
}

/* ─── Cards ─────────────────────────────────────────────────────────── */
.card {
    --bs-card-border-color: var(--border-subtle);
    --bs-card-border-radius: var(--radius-lg);
    --bs-card-inner-border-radius: calc(var(--radius-lg) - 1px);
    border: 1px solid var(--border-subtle);
    box-shadow: var(--shadow-sm);
}
.card .card-header {
    background: var(--bg-surface-2);
    border-bottom: 1px solid var(--border-subtle);
    font-weight: var(--fw-semibold);
}

/* ─── Tabellen ──────────────────────────────────────────────────────── */
.table { --bs-table-border-color: var(--border-subtle); }
.table > thead { --bs-table-color: var(--fg-2); }
[data-bs-theme="dark"] .table-light {
    --bs-table-bg: var(--bg-surface-2);
    --bs-table-color: var(--fg-1);
    --bs-table-border-color: var(--border-default);
}

/* ─── Badges (Status-Soft-Tints, lesbar in beiden Modi) ─────────────── */
.badge.text-bg-success { background: var(--status-success-soft) !important; color: var(--status-success) !important; }
.badge.text-bg-danger { background: var(--status-danger-soft) !important; color: var(--status-danger) !important; }
.badge.text-bg-warning { background: var(--status-warning-soft) !important; color: var(--accent-press) !important; }
.badge.text-bg-secondary { background: var(--bg-surface-2) !important; color: var(--fg-2) !important; }
[data-bs-theme="dark"] .badge.text-bg-success { background: rgba(30, 142, 90, .18) !important; color: #6FD8A8 !important; }
[data-bs-theme="dark"] .badge.text-bg-danger { background: rgba(197, 52, 52, .20) !important; color: #F29595 !important; }
[data-bs-theme="dark"] .badge.text-bg-warning { background: rgba(242, 160, 31, .18) !important; color: var(--vs-amber) !important; }

/* ─── Formulare ─────────────────────────────────────────────────────── */
.form-control, .form-select { border-color: var(--border-default); }
.form-control:focus, .form-select:focus, .form-check-input:focus {
    border-color: var(--accent);
    box-shadow: var(--shadow-focus);
}
.form-check-input:checked { background-color: var(--accent); border-color: var(--accent); }
/* Tom-Select an Bootstrap angleichen */
.ts-control { border-color: var(--border-default); border-radius: var(--radius-md); }
.ts-wrapper.focus .ts-control { border-color: var(--accent); box-shadow: var(--shadow-focus); }

/* ─── Tastatur-Fokus global ─────────────────────────────────────────── */
:focus-visible { outline: none; }
a:focus-visible, .nav-link:focus-visible, .dropdown-item:focus-visible {
    box-shadow: var(--shadow-focus);
    border-radius: var(--radius-sm);
}

/* ─── Wiederverwendbarer Seiten-Header ──────────────────────────────── */
.vc-page-head { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: .75rem; margin-bottom: 1.25rem; }
.vc-page-head h1, .vc-page-head .vc-title { font-size: var(--fs-xl); font-weight: var(--fw-bold); margin: 0; }
.vc-page-head .vc-sub { font-size: var(--fs-sm); color: var(--fg-3); margin: 0; }

/* ─── KPI-Kachel ────────────────────────────────────────────────────── */
.vc-kpi { background: var(--bg-surface-2); border-radius: var(--radius-md); padding: var(--space-4) var(--space-5); }
.vc-kpi .vc-kpi-label { font-size: var(--fs-xs); color: var(--fg-3); display: flex; align-items: center; gap: 6px; }
.vc-kpi .vc-kpi-value { font-family: var(--font-display); font-size: var(--fs-2xl); font-weight: var(--fw-bold); line-height: 1.1; margin-top: 2px; }

/* ─── Klickbare Navigations-Karte (Dashboard) ───────────────────────── */
.vc-card-icon {
    width: 34px; height: 34px; flex: 0 0 auto;
    border-radius: var(--radius-md);
    background: var(--accent-soft);
    color: var(--accent-press);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 1.05rem;
}
.vc-card-link { color: var(--accent-press); font-weight: var(--fw-semibold); text-decoration: none; display: inline-flex; align-items: center; gap: 6px; }
.vc-card-link .bi { transition: transform var(--dur-base) var(--ease-out); }
.card:has(.stretched-link):hover { border-color: var(--border-default); box-shadow: var(--shadow-md); }
.card:has(.stretched-link):hover .vc-card-link .bi { transform: translateX(3px); }
.card:has(.stretched-link):hover .vc-card-icon { background: var(--accent); color: var(--vs-midnight-navy); }

/* ─── Status-Punkte (Anwesenheit) ───────────────────────────────────── */
.vc-status-dot { width: 12px; height: 12px; border-radius: 50%; flex: 0 0 auto; display: inline-block; background: var(--vs-neutral-400); box-shadow: 0 0 0 3px color-mix(in srgb, currentColor 12%, transparent); }
.vc-status-present { background: var(--status-success); color: var(--status-success); }
.vc-status-break { background: var(--vs-warm-sand); color: var(--vs-warm-sand); }
.vc-status-absent { background: var(--vs-neutral-400); color: var(--vs-neutral-400); }

/* ─── Theme-Toggle-Button ───────────────────────────────────────────── */
.js-theme-toggle .bi-sun { display: none; }
[data-bs-theme="dark"] .js-theme-toggle .bi-moon-stars { display: none; }
[data-bs-theme="dark"] .js-theme-toggle .bi-sun { display: inline-block; }

/* ─── Mobile: Tabellen als Karten (<768px) ──────────────────────────── */
@media (max-width: 767.98px) {
    /* ≥16px verhindert iOS-Auto-Zoom beim Fokus */
    .form-control, .form-select { font-size: 16px; }

    .vc-table-cards { border: 0; }
    .vc-table-cards thead { display: none; }
    .vc-table-cards tbody { display: block; }
    .vc-table-cards tbody tr {
        display: block;
        margin-bottom: .75rem;
        padding: .25rem .75rem;
        border: 1px solid var(--border-subtle);
        border-radius: var(--radius-lg);
        background: var(--bg-surface);
        box-shadow: var(--shadow-sm);
    }
    .vc-table-cards.table-striped tbody tr td { --bs-table-bg-type: transparent; background: transparent; }
    .vc-table-cards tbody td {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        padding: .5rem 0;
        text-align: right;
        border: 0;
        border-bottom: 1px solid var(--border-subtle);
    }
    .vc-table-cards tbody td:last-child { border-bottom: 0; }
    .vc-table-cards tbody td::before {
        content: attr(data-label);
        margin-right: auto;
        text-align: left;
        font-weight: var(--fw-semibold);
        color: var(--fg-3);
    }
    .vc-table-cards tbody td[data-label=""]::before { content: none; }
}

/* ─── Mobile Bottom-Nav (Mitarbeiter-Bereich) ───────────────────────── */
.vc-bottom-nav {
    position: fixed; inset: auto 0 0 0; z-index: 1030;
    display: flex;
    background: var(--bg-surface);
    border-top: 1px solid var(--border-subtle);
    box-shadow: 0 -2px 8px rgba(7, 26, 47, .06);
    padding-bottom: env(safe-area-inset-bottom);
}
.vc-bottom-nav a {
    flex: 1; min-height: 56px;
    display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2px;
    padding: 6px 4px;
    color: var(--fg-3); font-size: 11px; text-decoration: none;
}
.vc-bottom-nav a .bi { font-size: 1.2rem; }
.vc-bottom-nav a.active { color: var(--accent-press); font-weight: var(--fw-semibold); }
@media (max-width: 767.98px) { body.vc-has-bottomnav { padding-bottom: 64px; } }

/* ─── Reduced Motion ────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        transition-duration: .001ms !important;
        animation-duration: .001ms !important;
        scroll-behavior: auto !important;
    }
}
