/* =========================================================
   CSS Custom Properties — alle überschreibbar via Branding
   ========================================================= */

:root {
    /* Hauptfarben */
    --portal-primary:          #5da47a;
    --portal-primary-dark:     #4b8e66;

    /* Layout */
    --portal-bg:               #f5f7f6;
    --portal-surface:          #ffffff;
    --portal-border:           #e7ece9;
    --portal-text:             #263238;
    --portal-muted:            #7b8781;

    /* Sidebar */
    --sidebar-bg:              #ffffff;
    --sidebar-text:            #44514b;
    --sidebar-active-bg:       color-mix(in srgb, var(--portal-primary) 15%, transparent);
    --sidebar-active-text:     #1f2a25;

    /* Topbar */
    --topbar-bg:               #ffffff;

    /* Body */
    --body-bg:                 #f5f7f6;

    /* Login */
    --portal-left-bg:          #5da47a;
    --portal-left-bg-dark:     #4b8e66;
    --portal-right-bg:         #f8faf9;

    /* Buttons */
    --btn-primary-bg:          #5da47a;
    --btn-primary-hover:       #4b8e66;
    --btn-primary-text:        #ffffff;

    --btn-secondary-bg:        #6c757d;
    --btn-secondary-hover:     #5a6268;
    --btn-secondary-text:      #ffffff;

    --btn-success-bg:          #198754;
    --btn-success-hover:       #157347;
    --btn-success-text:        #ffffff;

    --btn-danger-bg:           #dc3545;
    --btn-danger-hover:        #bb2d3b;
    --btn-danger-text:         #ffffff;

    --btn-warning-bg:          #ffc107;
    --btn-warning-hover:       #ffca2c;
    --btn-warning-text:        #000000;

    --btn-info-bg:             #0dcaf0;
    --btn-info-hover:          #31d2f2;
    --btn-info-text:           #000000;

    --btn-border-radius:       0.5rem;

    /* Links */
    --link-color:              #5da47a;
    --link-hover-color:        #4b8e66;

    /* Karten */
    --card-border-radius:      0.75rem;
    --card-shadow:             0 1px 4px rgba(0,0,0,.06);
    --border-color:            #e7ece9;

    /* Typografie */
    --font-family:             'Inter', system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    --font-size-base:          14px;

    /* Badge */
    --badge-border-radius:     999px;
}

/* =========================================================
   Base
   ========================================================= */

html, body {
    min-height: 100%;
}

body {
    font-family:    var(--font-family);
    font-size:      var(--font-size-base);
    color:          var(--portal-text);
    background:     var(--body-bg);
}

/* Links */
a {
    color:           var(--link-color);
    text-decoration: none;
}

a:hover {
    color: var(--link-hover-color);
}

/* Badges */
.badge {
    border-radius: var(--badge-border-radius);
}

/* Karten */
.card {
    border-radius: var(--card-border-radius) !important;
    box-shadow:    var(--card-shadow);
}

/* =========================================================
   Buttons — Bootstrap überschreiben
   ========================================================= */

.btn {
    border-radius: var(--btn-border-radius);
}

/* Primary */
.btn-primary {
    background-color: var(--btn-primary-bg)   !important;
    border-color:     var(--btn-primary-bg)   !important;
    color:            var(--btn-primary-text) !important;
}
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
    background-color: var(--btn-primary-hover) !important;
    border-color:     var(--btn-primary-hover) !important;
    color:            var(--btn-primary-text)  !important;
}
.btn-outline-primary {
    color:        var(--btn-primary-bg)   !important;
    border-color: var(--btn-primary-bg)   !important;
}
.btn-outline-primary:hover {
    background-color: var(--btn-primary-bg)   !important;
    color:            var(--btn-primary-text) !important;
}

/* Secondary */
.btn-secondary {
    background-color: var(--btn-secondary-bg)   !important;
    border-color:     var(--btn-secondary-bg)   !important;
    color:            var(--btn-secondary-text) !important;
}
.btn-secondary:hover,
.btn-secondary:focus {
    background-color: var(--btn-secondary-hover) !important;
    border-color:     var(--btn-secondary-hover) !important;
}
.btn-outline-secondary {
    color:        var(--btn-secondary-bg) !important;
    border-color: var(--btn-secondary-bg) !important;
}
.btn-outline-secondary:hover {
    background-color: var(--btn-secondary-bg)   !important;
    color:            var(--btn-secondary-text) !important;
}

/* Success */
.btn-success {
    background-color: var(--btn-success-bg)   !important;
    border-color:     var(--btn-success-bg)   !important;
    color:            var(--btn-success-text) !important;
}
.btn-success:hover,
.btn-success:focus {
    background-color: var(--btn-success-hover) !important;
    border-color:     var(--btn-success-hover) !important;
}
.btn-outline-success {
    color:        var(--btn-success-bg)   !important;
    border-color: var(--btn-success-bg)   !important;
}
.btn-outline-success:hover {
    background-color: var(--btn-success-bg)   !important;
    color:            var(--btn-success-text) !important;
}

/* Danger */
.btn-danger {
    background-color: var(--btn-danger-bg)   !important;
    border-color:     var(--btn-danger-bg)   !important;
    color:            var(--btn-danger-text) !important;
}
.btn-danger:hover,
.btn-danger:focus {
    background-color: var(--btn-danger-hover) !important;
    border-color:     var(--btn-danger-hover) !important;
}
.btn-outline-danger {
    color:        var(--btn-danger-bg)   !important;
    border-color: var(--btn-danger-bg)   !important;
}
.btn-outline-danger:hover {
    background-color: var(--btn-danger-bg)   !important;
    color:            var(--btn-danger-text) !important;
}

/* Warning */
.btn-warning {
    background-color: var(--btn-warning-bg)   !important;
    border-color:     var(--btn-warning-bg)   !important;
    color:            var(--btn-warning-text) !important;
}
.btn-warning:hover,
.btn-warning:focus {
    background-color: var(--btn-warning-hover) !important;
    border-color:     var(--btn-warning-hover) !important;
}
.btn-outline-warning {
    color:        var(--btn-warning-bg)   !important;
    border-color: var(--btn-warning-bg)   !important;
}
.btn-outline-warning:hover {
    background-color: var(--btn-warning-bg)   !important;
    color:            var(--btn-warning-text) !important;
}

/* Info */
.btn-info {
    background-color: var(--btn-info-bg)   !important;
    border-color:     var(--btn-info-bg)   !important;
    color:            var(--btn-info-text) !important;
}
.btn-info:hover,
.btn-info:focus {
    background-color: var(--btn-info-hover) !important;
    border-color:     var(--btn-info-hover) !important;
}
.btn-outline-info {
    color:        var(--btn-info-bg)   !important;
    border-color: var(--btn-info-bg)   !important;
}
.btn-outline-info:hover {
    background-color: var(--btn-info-bg)   !important;
    color:            var(--btn-info-text) !important;
}

/* Portal-Button (Login-Seite) */
.btn-portal {
    background:    var(--btn-primary-bg);
    border-color:  var(--btn-primary-bg);
    color:         var(--btn-primary-text);

    border-radius: 40px;
    border:        none;
}
.btn-portal:hover,
.btn-portal:focus {
    background:   var(--btn-primary-hover);
    border-color: var(--btn-primary-hover);
    color:        var(--btn-primary-text);
}

/* =========================================================
   Forms
   ========================================================= */

.form-control,
.form-select {
    min-height:   36px;
    border-radius: 12px;
    border-color: #d7dfdb;
    font-size:    var(--font-size-base);
}

.form-control:focus,
.form-select:focus {
    border-color: var(--portal-primary);
    box-shadow:   0 0 0 .2rem color-mix(in srgb, var(--portal-primary) 20%, transparent);
}

.alert {
    border:        none;
    border-radius: 14px;
    padding:       14px 16px;
}

/* =========================================================
   Guest Layout (Login / Register)
   ========================================================= */

.portal-wrapper {
    min-height: 100vh;
    display:    flex;
}

.portal-left {
    flex:            1;
    background:      linear-gradient(140deg, var(--portal-left-bg), var(--portal-left-bg-dark));
    color:           #fff;
    display:         flex;
    align-items:     center;
    justify-content: center;
    padding:         48px;
}

.portal-left-inner {
    max-width:   520px;
    text-align:  center;
    padding:     40px;
}

.portal-brand {
    display:         inline-block;
    font-size:       38px;
    font-weight:     700;
    color:           #fff;
    text-decoration: none;
    margin-bottom:   28px;
}

.portal-brand:hover {
    color: #fff;
}

.portal-headline {
    font-size:     42px;
    line-height:   1.15;
    font-weight:   700;
    margin-bottom: 18px;
}

.portal-copy {
    font-size:   17px;
    line-height: 1.7;
    opacity:     .92;
    margin:      0;
}

.portal-right {
    flex:            1;
    display:         flex;
    align-items:     center;
    justify-content: center;
    padding:         32px;
    background:      var(--portal-right-bg);
}

.portal-card {
    width:         100%;
    max-width:     520px;
    background:    #fff;
    border:        1px solid var(--portal-border);
    border-radius: 24px;
    box-shadow:    0 10px 30px rgba(38,50,56,.06);
    padding:       32px;
}

.portal-title {
    font-size:     32px;
    font-weight:   700;
    margin-bottom: 24px;
    color:         var(--portal-text);
    text-align:    center;
}

/* =========================================================
   App Layout
   ========================================================= */

.app-body {
    background:  var(--body-bg);
    overflow-x:  hidden;
}

.app-layout {
    min-height: 100vh;
    display:    flex;
}

.app-sidebar {
    width:        280px;
    flex:         0 0 280px;
    max-width:    280px;
    background:   var(--sidebar-bg);
    border-right: 1px solid var(--border-color);
    transition:   all .25s ease;
}

.app-sidebar-inner {
    padding: 24px 18px;
    height:  100%;
}

.app-main {
    flex:       1;
    min-width:  0;
    display:    flex;
    flex-direction: column;
}

.app-brand-wrap {
    margin-bottom: 28px;
}

.app-brand {
    display:         flex;
    align-items:     center;
    gap:             12px;
    text-decoration: none;
    color:           var(--sidebar-text);
}

.app-brand:hover {
    color: var(--sidebar-text);
}

.app-brand-mark {
    width:         44px;
    height:        44px;
    border-radius: 14px;
    background:    linear-gradient(135deg, var(--portal-primary) 0%, var(--portal-primary-dark) 100%);
    color:         #fff;
    display:       flex;
    align-items:   center;
    justify-content: center;
    font-size:     14px;
    font-weight:   800;
    letter-spacing: .04em;
    box-shadow:    0 8px 18px rgba(0,0,0,.15);
    flex:          0 0 44px;
}

.app-brand-text {
    font-size:   20px;
    font-weight: 700;
    line-height: 1.1;
    white-space: nowrap;
    color:       var(--sidebar-text);
}

.app-sidebar-section {
    display:        flex;
    flex-direction: column;
    gap:            14px;
}

.app-sidebar-label {
    font-size:      12px;
    font-weight:    700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color:          var(--portal-muted);
    padding:        0 .75rem;
}

.app-nav-link {
    border-radius: 12px;
    color:         var(--sidebar-text);
    font-weight:   500;
    padding:       .85rem 1rem;
    display:       flex;
    align-items:   center;
    gap:           10px;
}

.app-nav-link:hover {
    background: color-mix(in srgb, var(--portal-primary) 10%, transparent);
    color:      var(--sidebar-active-text);
}

.app-nav-link.active {
    background: var(--sidebar-active-bg);
    color:      var(--sidebar-active-text);
}

.app-nav-icon {
    display:         inline-flex;
    align-items:     center;
    justify-content: center;
    width:           18px;
    flex:            0 0 18px;
    font-size:       16px;
    line-height:     1;
}

.app-nav-text {
    white-space: nowrap;
}

.app-topbar {
    background:    var(--topbar-bg);
    border-bottom: 1px solid var(--border-color);
}

.app-topbar-title {
    font-size:   24px;
    font-weight: 700;
    color:       var(--portal-text);
    line-height: 1.2;
}

.app-topbar-subtitle {
    font-size:  14px;
    color:      var(--portal-muted);
    margin-top: 4px;
}

.app-main-content {
    flex: 1;
}

.app-menu-btn {
    width:          46px;
    height:         46px;
    border-radius:  12px;
    border:         1px solid var(--border-color);
    background:     #fff;
    display:        flex;
    flex-direction: column;
    justify-content: center;
    align-items:    center;
    gap:            5px;
    padding:        0;
}

.app-menu-btn:hover,
.app-menu-btn:focus {
    background:   #f4f7f5;
    border-color: #d9e3dd;
}

.app-menu-bar {
    display:       block;
    width:         18px;
    height:        2px;
    background:    #405049;
    border-radius: 999px;
}

.app-locale-badge {
    border:          1px solid var(--border-color);
    background:      #f7f9f8 !important;
    color:           #4a5b53 !important;
    font-weight:     700;
    min-width:       52px;
    height:          40px;
    display:         flex;
    align-items:     center;
    justify-content: center;
    border-radius:   999px;
}

.app-logout-btn {
    border-radius: 999px;
    padding:       .65rem 1rem;
    font-weight:   600;
    background:    var(--portal-primary);
    border-color:  var(--portal-primary);
}

.app-logout-btn:hover,
.app-logout-btn:focus {
    background:   var(--portal-primary-dark);
    border-color: var(--portal-primary-dark);
}

/* =========================================================
   Eingeklappte Sidebar
   ========================================================= */

.app-layout.app-layout-collapsed .app-sidebar {
    width:     88px;
    flex:      0 0 88px;
    max-width: 88px;
}

.app-layout.app-layout-collapsed .app-brand {
    justify-content: center;
}

.app-layout.app-layout-collapsed .app-brand-text,
.app-layout.app-layout-collapsed .app-sidebar-label,
.app-layout.app-layout-collapsed .app-nav-text {
    display: none;
}

.app-layout.app-layout-collapsed .app-nav-link {
    justify-content: center;
    padding:         .85rem;
}

/* =========================================================
   Responsive
   ========================================================= */

@media (max-width: 992px) {
    .portal-left {
        display: none;
    }

    .portal-right {
        flex: 1;
    }
}

@media (max-width: 767.98px) {
    .portal-wrapper {
        flex-direction: column;
    }

    .portal-left,
    .portal-right {
        padding: 24px;
    }

    .portal-headline {
        font-size: 32px;
    }

    .portal-card {
        padding:       24px;
        border-radius: 20px;
    }

    .app-sidebar {
        width:     88px;
        flex:      0 0 88px;
        max-width: 88px;
    }

    .app-sidebar-inner {
        padding: 18px 12px;
    }

    .app-brand {
        justify-content: center;
    }

    .app-brand-text,
    .app-sidebar-label,
    .app-nav-text {
        display: none;
    }

    .app-nav-link {
        justify-content: center;
        padding:         .85rem;
    }

    .app-topbar-title {
        font-size: 22px;
    }
}

/* =========================================================
   Dashboard
   ========================================================= */

.db-stat-card {
    border:        1px solid var(--border-color);
    border-radius: 14px;
    background:    #fff;
    padding:       22px 22px 18px;
    transition:    box-shadow .2s;
}

.db-stat-card:hover {
    box-shadow: 0 4px 20px rgba(0,0,0,.07);
}

.db-stat-icon {
    width:           44px;
    height:          44px;
    border-radius:   12px;
    display:         flex;
    align-items:     center;
    justify-content: center;
    font-size:       20px;
}

.db-trend {
    font-size:   12px;
    font-weight: 600;
    display:     inline-flex;
    align-items: center;
    gap:         2px;
}

.db-panel {
    border:        1px solid var(--border-color);
    border-radius: 14px;
    background:    #fff;
    overflow:      hidden;
}

.db-panel-head {
    padding:         18px 22px;
    border-bottom:   1px solid #f1f3f5;
    display:         flex;
    align-items:     center;
    justify-content: space-between;
}

.db-panel-title {
    font-size:   15px;
    font-weight: 600;
    color:       #1a1a2e;
}

.db-table {
    margin: 0;
}

.db-table thead th {
    font-size:      11px;
    font-weight:    700;
    letter-spacing: .06em;
    text-transform: uppercase;
    color:          #9ca3af;
    border-bottom:  1px solid #f1f3f5;
    padding:        12px 22px;
    background:     #fafafa;
}

.db-table tbody td {
    font-size:      13px;
    padding:        13px 22px;
    border-bottom:  1px solid #f8f9fa;
    vertical-align: middle;
    color:          #374151;
}

.db-table tbody tr:last-child td {
    border-bottom: none;
}

.db-table tbody tr:hover td {
    background: #fafcfb;
}

.db-avatar {
    width:           32px;
    height:          32px;
    border-radius:   50%;
    background:      #e9ecef;
    display:         flex;
    align-items:     center;
    justify-content: center;
    font-size:       12px;
    font-weight:     700;
    color:           #6b7280;
    flex:            0 0 32px;
}

.db-badge {
    font-size:     11px;
    font-weight:   600;
    padding:       3px 10px;
    border-radius: var(--badge-border-radius);
    display:       inline-block;
}

.db-badge.success {
    background: color-mix(in srgb, var(--portal-primary) 12%, transparent);
    color:      var(--portal-primary-dark);
}

.db-badge.warning {
    background: rgba(245,158,11,.12);
    color:      #b45309;
}

.db-badge.danger {
    background: rgba(239,68,68,.12);
    color:      #b91c1c;
}

.db-shift-row {
    display:       flex;
    align-items:   center;
    gap:           14px;
    padding:       13px 22px;
    border-bottom: 1px solid #f1f3f5;
}

.db-shift-row:last-child {
    border-bottom: none;
}

.db-shift-dot {
    width:         8px;
    height:        8px;
    border-radius: 50%;
    flex:          0 0 8px;
}

.db-shift-bar-wrap {
    flex:          1;
    height:        4px;
    background:    #f1f3f5;
    border-radius: 999px;
    overflow:      hidden;
}

.db-shift-bar {
    height:        100%;
    border-radius: 999px;
    background:    var(--portal-primary);
}


/* HEADER */
#sessionTimer,.language-swich{
    height: 38px;
}

thead tr th{
    font-size: 12px;
    font-weight: 600;
    color: #1a1a2e;
}

.foto_upload{
    display: flex;
    flex-direction: column;
    align-items: center;
}