﻿        :root {
            --primary: #FF6D00;
            --primary-light: #FF9E40;
            --primary-dark: #C43C00;
            --secondary: #FFFFFF;
            --background: #F5F5F5;
            --text: #333333;
            --text-light: #666666;
            --border: #E0E0E0;
            --success: #4CAF50;
            --warning: #FFC107;
            --danger: #D32F2F;
        }

        body.dark-mode {
            --secondary: #1f2329;
            --background: #12161c;
            --text: #f1f3f5;
            --text-light: #b6bec8;
            --border: #38414c;
        }

        * {
            box-sizing: border-box;
            margin: 0;
            padding: 0;
            font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
        }

        body {
            background-color: var(--background);
            color: var(--text);
            padding: 20px;
            overflow-x: hidden;
        }

        .offline-banner {
            align-items: center;
            background: #fff7e6;
            border: 1px solid #ffcc80;
            border-radius: 8px;
            color: #7a3b00;
            display: none;
            font-weight: 700;
            gap: 8px;
            left: 16px;
            padding: 10px 12px;
            position: fixed;
            right: 16px;
            top: 12px;
            z-index: 130;
            box-shadow: 0 8px 20px rgba(0,0,0,0.12);
        }

        .offline-banner.is-visible {
            display: flex;
        }

        body.dark-mode .offline-banner {
            background: #3d2a12;
            color: #ffd9a3;
        }

        .document-loading-overlay {
            align-items: center;
            background: rgba(18, 22, 28, 0.58);
            bottom: 0;
            display: none;
            justify-content: center;
            left: 0;
            padding: 24px;
            position: fixed;
            right: 0;
            top: 0;
            z-index: 2000;
        }

        .document-loading-overlay.is-visible {
            display: flex;
        }

        .document-loading-card {
            align-items: center;
            background: var(--secondary);
            border: 1px solid var(--border);
            border-radius: 8px;
            box-shadow: 0 18px 42px rgba(0,0,0,0.24);
            color: var(--text);
            display: grid;
            gap: 12px;
            justify-items: center;
            max-width: 360px;
            padding: 24px;
            text-align: center;
            width: min(100%, 360px);
        }

        .document-loading-spinner {
            animation: documentSpin 0.9s linear infinite;
            border: 4px solid rgba(255,109,0,0.2);
            border-radius: 50%;
            border-top-color: var(--primary);
            height: 44px;
            width: 44px;
        }

        .document-loading-card strong {
            font-size: 18px;
        }

        .document-loading-card span {
            color: var(--text-light);
            line-height: 1.35;
        }

        @keyframes documentSpin {
            to { transform: rotate(360deg); }
        }

        .app-shell > .header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 18px;
            padding: 14px 18px;
            background: var(--secondary);
            border: 1px solid var(--border);
            border-radius: 8px;
            box-shadow: 0 2px 10px rgba(0,0,0,0.06);
        }

        .title {
            font-size: 21px;
            font-weight: bold;
            color: var(--primary);
            line-height: 1.2;
        }

        .controls {
            display: flex;
            gap: 15px;
            margin-bottom: 20px;
            align-items: center;
            flex-wrap: wrap;
        }

        .btn {
            padding: 10px 15px;
            border: none;
            border-radius: 5px;
            cursor: pointer;
            font-weight: bold;
            transition: all 0.3s;
            display: flex;
            align-items: center;
            gap: 8px;
            white-space: nowrap;
        }

        .btn-primary {
            background-color: var(--primary);
            color: var(--secondary);
        }

        .btn-primary:hover {
            background-color: var(--primary-dark);
        }

        .btn-secondary {
            background-color: var(--secondary);
            color: var(--primary);
            border: 1px solid var(--primary);
        }

        .btn-secondary:hover {
            background-color: var(--background);
        }

        .btn-danger {
            background-color: var(--danger);
            color: var(--secondary);
        }

        .btn-danger:hover {
            background-color: #B71C1C;
        }

        .btn-success {
            background-color: var(--success);
            color: var(--secondary);
        }

        .btn-success:hover {
            background-color: #388E3C;
        }

        .table-container {
            background-color: var(--secondary);
            border-radius: 8px;
            box-shadow: 0 2px 10px rgba(0,0,0,0.1);
            overflow-x: auto;
            margin-bottom: 20px;
            position: relative;
        }

        table {
            width: 100%;
            border-collapse: collapse;
        }

        th, td {
            padding: 12px 15px;
            text-align: left;
            border-bottom: 1px solid var(--border);
        }

        th {
            background-color: var(--primary);
            color: var(--secondary);
            font-weight: bold;
            position: sticky;
            top: 0;
        }

        tr:nth-child(even) {
            background-color: var(--background);
        }

        tr:hover {
            background-color: #FFECB3;
        }

        .sum-row {
            background-color: #E3F2FD !important;
            font-weight: bold;
        }

        .action-btn {
            background: none;
            border: none;
            cursor: pointer;
            color: var(--text-light);
            margin: 0 5px;
            transition: all 0.3s;
        }

        .action-btn:hover {
            color: var(--primary);
        }

        .modal {
            display: none;
            position: fixed;
            z-index: 100;
            left: 0;
            top: 0;
            width: 100%;
            height: 100%;
            background-color: rgba(0,0,0,0.5);
            overflow-y: auto;
        }

        .modal-content {
            background-color: var(--secondary);
            margin: 2% auto;
            padding: 25px;
            border-radius: 8px;
            width: 80%;
            max-width: 800px;
            box-shadow: 0 5px 15px rgba(0,0,0,0.3);
            max-height: 90vh;
            overflow-y: auto;
        }

        .modal-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 20px;
            padding-bottom: 10px;
            border-bottom: 1px solid var(--border);
        }

        .modal-title {
            font-size: 20px;
            font-weight: bold;
            color: var(--primary);
        }

        .close {
            color: var(--text-light);
            font-size: 28px;
            font-weight: bold;
            cursor: pointer;
        }

        .close:hover {
            color: var(--text);
        }

        .form-group {
            margin-bottom: 15px;
        }

        .form-row {
            display: flex;
            gap: 15px;
        }

        .form-col {
            flex: 1;
        }

        label {
            display: block;
            margin-bottom: 5px;
            font-weight: 500;
            color: var(--text-light);
        }

        input, select {
            width: 100%;
            padding: 10px;
            border: 1px solid var(--border);
            border-radius: 5px;
            font-size: 14px;
        }

        input:focus, select:focus {
            outline: none;
            border-color: var(--primary);
            box-shadow: 0 0 0 2px rgba(255,109,0,0.2);
        }

        .modal-footer {
            display: flex;
            justify-content: flex-end;
            gap: 10px;
            margin-top: 20px;
            padding-top: 15px;
            border-top: 1px solid var(--border);
        }

        .checkbox-label {
            margin-bottom: 0;
            font-weight: normal;
        }

        #wagonModal .modal-content {
            max-width: 980px;
            padding: 0;
            max-height: calc(100vh - 32px);
            max-height: calc(100dvh - 32px);
            overflow: hidden;
            display: flex;
            flex-direction: column;
        }

        #wagonModal .modal-header {
            padding: 18px 22px;
            margin-bottom: 0;
            background: var(--background);
            flex: 0 0 auto;
        }

        #wagonForm {
            padding: 18px 22px;
            overflow-y: auto;
            min-height: 0;
            flex: 1 1 auto;
            overscroll-behavior: contain;
        }

        #wagonModal .modal-footer {
            padding: 16px 22px;
            background: var(--background);
            flex: 0 0 auto;
            margin-top: 0;
        }

        #wagonForm .section-title {
            margin: 18px 0 12px;
            padding: 9px 11px;
            border-radius: 6px;
            background: #f6f7f9;
            color: var(--primary);
            font-size: 14px;
            font-weight: 800;
            border: 1px solid var(--border);
        }

        #wagonForm .form-row {
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: 14px;
        }

        #wagonForm .form-col {
            min-width: 0;
        }

        .choice-group {
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: 8px;
            margin-bottom: 10px;
        }

        .choice-group input[hidden],
        input.fancy-control-input {
            position: absolute;
            opacity: 0;
            pointer-events: none;
        }

        .option-pill,
        .switch-card {
            min-height: 42px;
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 10px;
            border: 1px solid var(--border);
            border-radius: 8px;
            padding: 10px 12px;
            background: var(--secondary);
            color: var(--text);
            cursor: pointer;
            transition: border-color 0.2s, background 0.2s, color 0.2s;
            user-select: none;
            font: inherit;
            text-align: left;
        }

        .option-pill {
            justify-content: center;
            font-weight: 800;
        }

        .option-pill.is-active,
        .switch-card.is-active {
            border-color: var(--primary);
            background: rgba(255, 109, 0, 0.1);
            color: var(--primary);
        }

        .switch-card::after {
            content: "";
            width: 34px;
            height: 20px;
            border-radius: 999px;
            background: radial-gradient(circle at 10px 50%, #fff 0 6px, transparent 7px), #d6dbe1;
            box-shadow: inset 0 0 0 2px rgba(0,0,0,0.04);
            flex: 0 0 auto;
        }

        .switch-card.is-active::after {
            background: radial-gradient(circle at 24px 50%, #fff 0 6px, transparent 7px), var(--primary);
        }

        .stacked-controls {
            display: grid;
            gap: 10px;
        }

        .brake-load-settings {
            display: grid;
            gap: 10px;
            margin: 10px 0 12px;
            padding: 12px;
            border: 1px solid var(--border);
            border-radius: 8px;
            background: #f8f9fb;
        }

        .brake-load-panel {
            display: none;
            gap: 10px;
            grid-template-columns: repeat(3, minmax(0, 1fr));
        }

        .brake-load-panel.active {
            display: grid;
        }

        .brake-load-panel.single {
            grid-template-columns: 1fr;
        }

        .radio-group {
            display: flex;
            gap: 15px;
            margin-bottom: 10px;
            flex-wrap: nowrap;
        }

        .radio-option {
            display: flex;
            align-items: center;
            gap: 5px;
            flex-wrap: nowrap;
        }

        .radio-option label {
            margin-bottom: 0;
            font-weight: normal;
            cursor: pointer;
            white-space: nowrap;
        }

        .radio-option input[type="radio"] {
            margin: 0;
            cursor: pointer;
            width: auto;
        }

        .wagon-counter {
            background-color: var(--primary);
            color: white;
            padding: 5px 10px;
            border-radius: 20px;
            font-weight: bold;
            margin-left: 10px;
        }

        .section-title {
            font-size: 16px;
            font-weight: bold;
            color: var(--primary);
            margin: 20px 0 10px 0;
            padding-bottom: 5px;
            border-bottom: 1px solid var(--border);
        }

        .input-group {
            display: flex;
            gap: 10px;
            align-items: center;
        }

        .input-group input {
            flex: 1;
        }

        .input-group button {
            width: auto;
            padding: 0 15px;
        }

        .vehicle-number-field {
            position: relative;
        }

        .vehicle-suggestion-dropdown {
            position: absolute;
            left: 0;
            right: 0;
            top: calc(100% - 2px);
            z-index: 80;
            display: none;
            max-height: 260px;
            overflow-y: auto;
            border: 1px solid var(--border);
            border-radius: 8px;
            background: var(--secondary);
            box-shadow: 0 14px 32px rgba(0,0,0,0.18);
        }

        .vehicle-suggestion-dropdown.is-open {
            display: grid;
        }

        .wagon-lookup-field {
            position: relative;
        }

        .wagon-lookup-field .vehicle-suggestion-dropdown {
            top: calc(100% + 4px);
            z-index: 140;
        }

        .vehicle-suggestion-item {
            border: 0;
            border-bottom: 1px solid var(--border);
            background: var(--secondary);
            color: var(--text);
            display: grid;
            grid-template-columns: minmax(0, 1fr) auto;
            gap: 8px;
            padding: 11px 12px;
            text-align: left;
            cursor: pointer;
        }

        .vehicle-suggestion-item:last-child {
            border-bottom: 0;
        }

        .vehicle-suggestion-item:hover,
        .vehicle-suggestion-item:focus {
            outline: none;
            background: rgba(255,109,0,0.1);
        }

        .vehicle-suggestion-number {
            font-weight: 800;
            overflow-wrap: anywhere;
        }

        .vehicle-suggestion-type,
        .vehicle-suggestion-meta {
            color: var(--text-light);
            font-size: 12px;
        }

        .vehicle-suggestion-empty {
            padding: 11px 12px;
            color: var(--text-light);
            font-size: 13px;
        }

        .validation-icon {
            margin-left: 5px;
            font-size: 16px;
        }

        .vehicle-duplicate-warning {
            align-items: center;
            color: var(--danger);
            display: inline-flex;
            font-size: 12px;
            font-weight: 700;
            gap: 6px;
            line-height: 1.2;
            margin-top: 6px;
        }

        .valid {
            color: var(--success);
        }

        .invalid {
            color: var(--danger);
        }

        .header[hidden] {
            display: none !important;
        }

        /* Warning Modal */
        .warning-modal {
            display: none;
            position: fixed;
            z-index: 101;
            left: 0;
            top: 0;
            width: 100%;
            height: 100%;
            background-color: rgba(0,0,0,0.5);
        }

        .warning-modal-content {
            background-color: var(--secondary);
            margin: 15% auto;
            padding: 20px;
            border-radius: 8px;
            width: 80%;
            max-width: 400px;
            box-shadow: 0 5px 15px rgba(0,0,0,0.3);
        }

        .warning-modal-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 15px;
            padding-bottom: 10px;
            border-bottom: 1px solid var(--border);
        }

        .warning-modal-title {
            font-size: 18px;
            font-weight: bold;
            color: var(--danger);
        }

        .warning-modal-body {
            margin-bottom: 20px;
        }

        .warning-modal-footer {
            display: flex;
            justify-content: flex-end;
            gap: 10px;
        }

        textarea {
            width: 100%;
            padding: 10px;
            border: 1px solid var(--border);
            border-radius: 5px;
            font-size: 14px;
            resize: vertical;
        }

        #damageReportSuccess {
            margin-left: 10px;
            font-size: 14px;
        }

        #damageImages {
            margin-top: 5px;
        }

        .damage-report-modal {
            max-height: 88vh;
            max-width: 760px;
            overflow-y: auto;
        }

        .damage-report-grid {
            display: grid;
            gap: 14px;
            grid-template-columns: repeat(2, minmax(0, 1fr));
        }

        .damage-report-grid .form-wide {
            grid-column: 1 / -1;
        }

        .damage-label-options {
            display: grid;
            gap: 8px;
            grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
        }

        .damage-label-option {
            align-items: center;
            border: 1px solid var(--border);
            border-radius: 8px;
            cursor: pointer;
            display: flex;
            gap: 8px;
            justify-content: flex-start;
            min-height: 42px;
            padding: 8px 10px;
            white-space: nowrap;
        }

        .damage-label-option input,
        .damage-label-option input[type="checkbox"] {
            flex: 0 0 auto;
            height: 18px;
            margin: 0;
            padding: 0;
            width: 18px;
        }

        .damage-label-option span {
            flex: 1 1 auto;
            min-width: 0;
        }

        .damage-upload-preview {
            display: grid;
            gap: 10px;
            grid-template-columns: repeat(auto-fill, minmax(96px, 1fr));
            margin-top: 10px;
        }

        .damage-upload-preview img {
            aspect-ratio: 1;
            border: 1px solid var(--border);
            border-radius: 8px;
            object-fit: cover;
            width: 100%;
        }

        /* Bremszettel Styles */
        .bremszettel-container {
            display: none;
            margin-top: 20px;
        }

        .bremszettel {
            border: 2px solid #000;
            padding: 15px;
            width: 100%;
            margin: 0 auto;
            background-color: white;
            box-sizing: border-box;
            font-size: 12px;
            color: #000;
        }

        .bremszettel .header {
            display: flex;
            justify-content: space-between;
            margin-bottom: 15px;
            align-items: center;
            color: #000
        }

        .bremszettel table {
            width: 100%;
            border-collapse: collapse;
            margin-bottom: 15px;
            color: #000;
        }

        .bremszettel tr {
        min-height: 50px;
        }

        .bremszettel th, .bremszettel td {
            border: 1px solid #000;
            padding: 4px 4px;
            height: 25px;
            vertical-align: middle;
            text-align: center;
            color: #000;
        }

        .bremszettel th {
            background-color: #f2f2f2;
            font-weight: normal;
        }

        .bremszettel .section-title {
            background-color: #e6e6e6;
            font-weight: bold;
            padding: 6px 4px;
        }

        .bremszettel .signature {
            margin-top: 30px;
            display: flex;
            justify-content: space-between;
        }

        .bremszettel input, .bremszettel select {
            padding: 4px;
            width: 100%;
            box-sizing: border-box;
            border: 1px solid #ccc;
            background-color: transparent;
            border: none;
            border-bottom: 1px solid #ccc;
            text-align: center;
            font-size: 12px;
        }

        .bremszettel input:focus, .bremszettel select:focus {
            outline: none;
            border-bottom: 1px solid var(--primary);
        }

        .bremszettel .radio-group {
            display: flex;
            gap: 5px;
            justify-content: flex-start;
            margin-bottom: 0;
        }

        .bremszettel .radio-option {
            display: flex;
            align-items: center;
            gap: 2px;
        }

        .bremszettel .radio-option label {
            margin-bottom: 0;
            font-size: 10px;
        }

        .bremszettel .small-input {
            width: 60px;
        }

        .bremszettel .medium-input {
            width: 80px;
        }

        .bremszettel .vertical-text {
            writing-mode: vertical-rl;
            transform: rotate(180deg);
            text-align: center;
            white-space: nowrap;
            padding: 5px 2px;
            height: auto;
            min-height: 100px;
        }

        .brake-note-number-row {
            display: flex;
            align-items: center;
            gap: 5px;
            flex: 1;
        }

        .brake-note-number-row label {
            margin-bottom: 0;
            white-space: nowrap;
            min-width: 100px;
            text-align: right;
        }

        .brake-note-number-row input {
            flex: 1;
            min-width: 0;
        }

        /* Scrollbares Modal */
        .modal-content {
            max-height: 90vh;
            overflow-y: auto;
        }

        @media (max-width: 768px) {
            body {
                padding: 10px;
                overflow-x: auto;
            }
            
            .form-row {
                flex-direction: column;
            }
            
            .controls {
                flex-direction: column;
                align-items: flex-start;
                gap: 10px;
            }
            
            .btn {
                width: 100%;
                justify-content: center;
            }
            
            .table-container {
                overflow-x: auto;
            }
            
            table {
                font-size: 14px;
            }
            
            th, td {
                padding: 8px 10px;
            }
            
            .modal-content {
                width: 95%;
                padding: 15px;
            }

            #wagonModal .modal-content {
                width: 95%;
                padding: 0;
            }

            #wagonForm .form-row,
            .choice-group,
            .brake-load-panel {
                grid-template-columns: 1fr;
            }
            
            .bremszettel {
                padding: 5px;
            }
            
            .bremszettel .small-input {
                width: 40px;
            }
            
            .bremszettel .medium-input {
                width: 60px;
            }

            .bremszettel tr {
                min-height: 20px !important; /* Etwas kleiner für Druck */
        }
        
            .bremszettel th, .bremszettel td {
                height: 20px !important; /* Etwas kleiner für Druck */
                padding: 2px 2px !important;
            }
        }

        @media print {
            body {
                font-size: 12px !important;
                margin: 0 !important;
                padding: 0 !important;
                background-color: white !important;
            }
            .bremszettel {
                width: 100% !important;
                padding: 5px !important;
                border: none !important;
                margin: 0 !important;
            }
            table {
                font-size: 12px !important;
            }
            th, td {
                padding: 2px !important;
            }
            input, select {
                font-size: 11px !important;
                padding: 2px !important;
                border-bottom: none !important;
            }
            .small-input {
                width: 50px !important;
            }
            .medium-input {
                width: 70px !important;
            }
            body * {
                visibility: hidden;
            }
            #bremszettel-content, #bremszettel-content * {
                visibility: visible;
            }
            #bremszettel-content {
                position: absolute;
                left: 0;
                top: 0;
                width: 100%;
                margin: 0;
                padding: 0;
            }
            .controls {
                display: none !important;
            }
            @page {
                size: auto;
                margin: 5mm;
            }
        }
    
        .auth-view,
        .overview-view {
            min-height: calc(100vh - 40px);
        }

        .auth-view {
            display: grid;
            place-items: center;
            padding: 28px 16px;
        }

        .login-panel {
            width: min(460px, 100%);
            background: var(--secondary);
            border: 1px solid var(--border);
            border-radius: 8px;
            box-shadow: 0 12px 32px rgba(0,0,0,0.10);
            padding: 28px;
        }

        .login-logo {
            display: block;
            height: 112px;
            margin: 0 auto 18px;
            object-fit: contain;
            width: 112px;
        }

        .login-panel h1,
        .overview-title h1 {
            color: var(--primary);
            font-size: 26px;
            margin-bottom: 8px;
        }

        .login-panel p,
        .overview-title p,
        .list-meta,
        .auth-note {
            color: var(--text-light);
            line-height: 1.45;
        }

        .login-form {
            display: grid;
            gap: 14px;
            margin-top: 22px;
        }

        .login-form label,
        .list-form label {
            display: grid;
            gap: 6px;
            font-weight: 700;
        }

        .login-form input,
        .list-form input {
            width: 100%;
            padding: 11px 12px;
            border: 1px solid var(--border);
            border-radius: 5px;
            font-size: 15px;
        }

        .auth-error {
            min-height: 20px;
            color: var(--danger);
            font-weight: 700;
        }

        .auth-note {
            font-size: 13px;
            margin-top: 16px;
        }

        .auth-link-button {
            background: transparent;
            border: 0;
            color: var(--primary);
            cursor: pointer;
            display: inline-flex;
            font: inherit;
            font-weight: 800;
            margin-top: 14px;
            padding: 0;
        }

        .auth-link-button:hover,
        .auth-link-button:focus-visible {
            color: var(--primary-dark);
            text-decoration: underline;
        }

        .password-reset-panel {
            display: grid;
            gap: 16px;
            padding-top: 8px;
        }

        .password-reset-form {
            background: var(--background);
            border: 1px solid var(--border);
            border-radius: 8px;
            display: grid;
            gap: 12px;
            padding: 14px;
        }

        .password-reset-form label {
            color: var(--text);
            display: grid;
            font-weight: 800;
            gap: 6px;
        }

        .password-reset-form input {
            background: var(--secondary);
            border: 1px solid var(--border);
            border-radius: 6px;
            color: var(--text);
            font: inherit;
            padding: 10px 12px;
            width: 100%;
        }

        .password-reset-status {
            min-height: 22px;
        }

        .overview-view {
            padding: 20px 0 40px;
        }

        .overview-topbar {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 16px;
            margin-bottom: 18px;
            padding: 14px 18px;
            background: var(--secondary);
            border: 1px solid var(--border);
            border-radius: 8px;
            box-shadow: 0 2px 10px rgba(0,0,0,0.06);
        }

        .overview-title h1 {
            color: var(--primary);
            font-size: 21px;
            line-height: 1.2;
        }

        .overview-mobile-status,
        .overview-logo,
        .mobile-bottom-nav,
        .mobile-more-menu,
        .list-card-kebab {
            display: none;
        }

        #overviewUserLabel {
            display: none;
        }

        .title-container {
            min-width: 0;
        }

        .app-menu {
            position: relative;
            flex: 0 0 auto;
        }

        .header-hidden-meta {
            display: none;
        }

        .header-menu-btn {
            width: 42px;
            height: 42px;
            border: 1px solid var(--border);
            border-radius: 8px;
            background: var(--secondary);
            color: var(--primary);
            display: inline-flex;
            align-items: center;
            justify-content: center;
            font-size: 18px;
            cursor: pointer;
            transition: background 0.2s, border-color 0.2s;
        }

        .header-menu-btn:hover,
        .header-menu-btn[aria-expanded="true"] {
            background: var(--background);
            border-color: var(--primary);
        }

        .header-menu {
            display: none;
            position: fixed;
            right: 0;
            top: 0;
            width: min(360px, calc(100vw - 24px));
            height: 100vh;
            min-width: 280px;
            background: var(--secondary);
            border-left: 1px solid var(--border);
            box-shadow: -12px 0 28px rgba(0,0,0,0.18);
            padding: 72px 18px 18px;
            z-index: 200;
            align-content: start;
        }

        .header-menu.open {
            display: grid;
            gap: 10px;
        }

        .menu-profile {
            display: grid;
            grid-template-columns: 48px minmax(0, 1fr);
            align-items: center;
            gap: 12px;
            padding: 0 0 16px;
            border-bottom: 1px solid var(--border);
            margin-bottom: 8px;
        }

        .menu-avatar {
            width: 48px;
            height: 48px;
            border: 0;
            border-radius: 50%;
            background: var(--primary);
            color: #fff;
            cursor: pointer;
            display: inline-grid;
            place-items: center;
            font-weight: 800;
            letter-spacing: 0;
        }

        .menu-avatar:hover,
        .menu-avatar:focus-visible {
            background: var(--primary-dark);
            outline: 3px solid rgba(255, 109, 0, 0.22);
            outline-offset: 3px;
        }

        .menu-profile strong,
        .menu-profile span {
            display: block;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }

        .menu-profile span {
            color: var(--text-light);
            font-size: 13px;
            margin-top: 2px;
        }

        .password-field {
            align-items: stretch;
            display: grid;
            grid-template-columns: minmax(0, 1fr) 44px;
            gap: 6px;
        }

        .password-toggle {
            align-items: center;
            background: var(--background);
            border: 1px solid var(--border);
            border-radius: 6px;
            color: var(--text);
            cursor: pointer;
            display: inline-flex;
            justify-content: center;
            min-height: 40px;
        }

        .header-menu .btn {
            justify-content: flex-start;
            width: 100%;
            min-height: 44px;
        }

        .header-menu .btn.is-active {
            background: var(--primary);
            border-color: var(--primary);
            color: #fff;
        }

        .header-menu .btn.is-active:hover {
            background: var(--primary-dark);
            border-color: var(--primary-dark);
            color: #fff;
        }

        .directory-grid {
            display: grid;
            gap: 10px;
        }

        .directory-card {
            background: var(--secondary);
            border: 1px solid var(--border);
            border-radius: 8px;
            padding: 14px;
            display: grid;
            grid-template-columns: minmax(0, 1fr) auto;
            gap: 12px;
            align-items: center;
        }

        .directory-card h2 {
            font-size: 17px;
            color: var(--text);
            overflow-wrap: anywhere;
        }

        .directory-meta {
            color: var(--text-light);
            font-size: 13px;
            margin-top: 4px;
        }

        .fab-button {
            position: fixed;
            right: 28px;
            bottom: 28px;
            width: 58px;
            height: 58px;
            border: none;
            border-radius: 50%;
            background: var(--primary);
            color: white;
            display: inline-grid;
            place-items: center;
            font-size: 22px;
            cursor: pointer;
            box-shadow: 0 10px 24px rgba(0,0,0,0.22);
            z-index: 80;
            transition: transform 0.2s, background 0.2s;
        }

        .fab-button:hover {
            background: var(--primary-dark);
            transform: translateY(-2px);
        }

        .new-list-modal-content {
            max-width: 980px;
        }

        #newListModal .new-list-modal-content {
            display: flex;
            flex-direction: column;
            max-height: min(92vh, 900px);
            overflow: hidden;
        }

        .new-list-modal-content .list-form {
            flex: 1 1 auto;
            min-height: 0;
            overflow-y: auto;
            margin-bottom: 0;
            padding-bottom: 0;
        }

        .new-list-modal-content .form-actions-row {
            background: var(--secondary);
            border-top: 1px solid var(--border);
            bottom: 0;
            margin-top: 8px;
            padding-top: 12px;
            position: sticky;
            z-index: 8;
        }

        .wagon-lookup-result {
            background: var(--muted);
            border: 1px solid var(--border);
            border-radius: 8px;
            color: var(--text-light);
            font-weight: 700;
            padding: 10px 12px;
        }

        .quick-wagon-meta {
            background: rgba(255, 109, 0, 0.08);
            border: 1px solid rgba(255, 109, 0, 0.22);
            border-radius: 8px;
            color: var(--text);
            display: grid;
            gap: 4px;
            padding: 12px;
        }

        .quick-wagon-meta strong {
            font-size: 18px;
        }

        .quick-wagon-meta span {
            color: var(--text-light);
            font-size: 13px;
        }

        .list-form {
            display: grid;
            grid-template-columns: minmax(220px, 1fr) minmax(180px, 0.7fr) auto;
            gap: 12px;
            align-items: end;
            background: var(--secondary);
            border: 1px solid var(--border);
            border-radius: 8px;
            padding: 16px;
            margin-bottom: 18px;
        }

        .list-grid {
            display: grid;
            grid-template-columns: 1fr;
            gap: 14px;
        }

        .list-day-heading {
            align-items: end;
            color: var(--text);
            display: flex;
            gap: 12px;
            justify-content: space-between;
            margin: 8px 2px -4px;
        }

        .list-day-heading strong {
            font-size: 17px;
            font-weight: 900;
        }

        .list-day-heading span {
            color: var(--text-light);
            font-size: 13px;
            font-weight: 700;
            white-space: nowrap;
        }

        .list-card-main {
            min-width: 0;
        }

        .list-card-head {
            align-items: start;
            display: grid;
            gap: 12px;
            grid-template-columns: minmax(0, 1fr);
        }

        .list-train-badge {
            display: none;
        }

        .list-card-meta-row {
            color: var(--text-light);
            line-height: 1.45;
        }

        .list-card {
            background: var(--secondary);
            border: 1px solid var(--border);
            border-radius: 8px;
            padding: 16px;
            box-shadow: 0 2px 10px rgba(0,0,0,0.06);
            display: grid;
            grid-template-columns: minmax(0, 1fr) auto;
            gap: 12px;
            align-items: center;
        }

        .list-card h2 {
            font-size: 18px;
            color: var(--text);
            overflow-wrap: anywhere;
        }

        .list-card-actions {
            display: flex;
            gap: 8px;
            flex-wrap: wrap;
        }

        .list-card-actions .btn {
            height: 42px;
            justify-content: center;
            padding: 0;
            width: 42px;
        }

        .list-card-actions .btn i {
            margin: 0;
        }

        .list-card-actions .btn span {
            display: none;
        }

        .list-card-menu-wrap {
            position: absolute;
            right: 14px;
            top: 14px;
            z-index: 3;
        }

        .list-card-kebab {
            align-items: center;
            background: rgba(255,255,255,0.94);
            border: 1px solid rgba(15,23,42,0.10);
            border-radius: 12px;
            color: #303846;
            cursor: pointer;
            display: inline-flex;
            height: 40px;
            justify-content: center;
            width: 40px;
        }

        .list-card-kebab:hover,
        .list-card-kebab[aria-expanded="true"] {
            border-color: var(--primary);
            color: var(--primary);
        }

        .list-card-menu {
            background: var(--secondary);
            border: 1px solid var(--border);
            border-radius: 12px;
            box-shadow: 0 16px 34px rgba(0,0,0,0.18);
            display: grid;
            gap: 6px;
            min-width: 190px;
            padding: 8px;
            position: absolute;
            right: 0;
            top: calc(100% + 8px);
            z-index: 4;
        }

        .list-card-menu[hidden] {
            display: none;
        }

        .list-card-menu .btn {
            justify-content: flex-start;
            min-height: 40px;
            width: 100%;
        }

        body.dark-mode .list-card-kebab {
            background: rgba(31,35,41,0.94);
            border-color: rgba(255,255,255,0.12);
            color: #f1f3f5;
        }

        body.dark-mode .list-card-menu {
            background: var(--secondary);
            border-color: var(--border);
        }

        .empty-overview {
            background: var(--secondary);
            border: 1px dashed var(--border);
            border-radius: 8px;
            padding: 28px;
            text-align: center;
            color: var(--text-light);
        }

        .overview-filters {
            display: grid;
            grid-template-columns: minmax(220px, 1fr) minmax(160px, 0.35fr);
            gap: 10px;
            margin-bottom: 14px;
            background: var(--secondary);
            border: 1px solid var(--border);
            border-radius: 8px;
            padding: 12px;
        }

        .overview-filters input {
            width: 100%;
            padding: 11px 12px;
            border: 1px solid var(--border);
            border-radius: 5px;
            font-size: 15px;
        }

        .overview-filters .filter-field {
            display: block;
            margin: 0;
            position: relative;
        }

        .overview-filters .filter-field > i {
            display: none;
        }

        .admin-view {
            display: none;
            padding: 20px 0 40px;
        }

        .admin-panel {
            background: var(--secondary);
            border: 1px solid var(--border);
            border-radius: 8px;
            padding: 16px;
            margin-bottom: 14px;
            display: grid;
            gap: 12px;
        }

        .admin-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
            gap: 10px;
            align-items: end;
        }

        .brake-form-panel {
            grid-column: 1 / -1;
            border: 1px solid var(--border);
            border-radius: 8px;
            padding: 12px;
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
            gap: 10px;
            align-items: end;
            background: var(--background);
        }

        .brake-form-panel h3 {
            grid-column: 1 / -1;
            font-size: 15px;
            color: var(--primary);
        }

        .brake-manual-fields {
            display: contents;
        }

        .brake-manual-fields[hidden] {
            display: none;
        }

        .brake-note-wide {
            grid-column: 1 / -1;
        }

        .train-prep-task-grid {
            display: grid;
            grid-template-columns: minmax(240px, 1fr) 120px 140px 120px minmax(180px, 1.2fr);
            gap: 10px;
            align-items: end;
        }

        .train-prep-row-title {
            align-self: center;
            color: var(--muted);
            font-weight: 700;
        }

        .brake-note-note {
            grid-column: 1 / -1;
            color: var(--muted-text);
            font-size: 13px;
            line-height: 1.35;
        }

        .admin-grid .form-span-2 {
            grid-column: span 2;
        }

        .admin-grid .form-actions-row {
            grid-column: 1 / -1;
            display: flex;
            gap: 10px;
            justify-content: flex-end;
        }

        .admin-list {
            display: grid;
            gap: 8px;
        }

        .admin-list-item {
            display: grid;
            grid-template-columns: minmax(0, 1fr) auto;
            align-items: center;
            gap: 10px;
            border: 1px solid var(--border);
            border-radius: 6px;
            padding: 10px;
            background: var(--background);
        }

        .admin-company-section {
            display: grid;
            gap: 8px;
            padding: 10px;
            border: 1px solid var(--border);
            border-radius: 8px;
            background: var(--secondary);
        }

        .admin-company-heading {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 10px;
            color: var(--text);
        }

        .admin-company-heading span {
            color: var(--muted);
            font-size: 13px;
            font-weight: 700;
        }

        .admin-list-actions {
            display: flex;
            gap: 8px;
            flex-wrap: wrap;
            justify-content: flex-end;
        }

        .company-logo-preview-wrap {
            display: flex;
            align-items: center;
            gap: 12px;
            min-height: 58px;
        }

        .company-logo-preview {
            display: none;
            max-width: 120px;
            max-height: 52px;
            object-fit: contain;
            border: 1px solid var(--border);
            border-radius: 6px;
            background: #fff;
            padding: 6px;
        }

        .company-logo-thumb {
            width: 70px;
            height: 42px;
            object-fit: contain;
            border: 1px solid var(--border);
            border-radius: 6px;
            background: #fff;
            padding: 4px;
        }

        .admin-panel textarea {
            min-height: 120px;
            padding: 10px;
            border: 1px solid var(--border);
            border-radius: 5px;
            font-family: monospace;
        }

        .app-shell {
            display: none;
        }

        @media (min-width: 761px) {
            #directoryView .overview-filters,
            #damageReportsView .overview-filters,
            .admin-view .overview-filters {
                grid-template-columns: 1fr;
            }

            #directoryView .overview-filters input,
            #damageReportsView .overview-filters input,
            .admin-view .overview-filters input {
                min-height: 48px;
                width: 100%;
            }

            .admin-panel {
                border: 0;
                box-shadow: none;
                padding: 0;
                background: transparent;
            }

            .directory-grid,
            .damage-report-grid,
            .admin-list {
                gap: 14px;
            }

            .directory-card,
            .damage-report-card,
            .admin-list-item,
            .admin-company-section {
                background: var(--secondary);
                border: 1px solid var(--border);
                border-left: 5px solid var(--primary);
                border-radius: 14px;
                box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
                padding: 18px;
            }

            .directory-card {
                grid-template-columns: minmax(0, 1fr) auto;
                gap: 16px;
                align-items: start;
            }

            .directory-card h2,
            .admin-list-item strong,
            .damage-report-card h2 {
                color: var(--text);
                font-size: 22px;
                line-height: 1.15;
            }

            .directory-meta,
            .damage-report-meta,
            .damage-report-details {
                font-size: 14px;
                line-height: 1.45;
            }

            .admin-list-actions {
                align-items: center;
                gap: 10px;
            }

            .app-shell {
                display: none;
                padding: 10px 10px 138px;
            }

            .train-info-card,
            .wagon-card-grid,
            .wagon-summary-card {
                margin-left: auto;
                margin-right: auto;
                width: min(100%, 1880px);
            }

            .wagon-card-grid {
                align-items: start;
                display: grid;
                gap: 16px;
                grid-template-columns: repeat(auto-fit, minmax(min(620px, 100%), 1fr));
                margin-bottom: 16px;
            }

            .wagon-card {
                border-left: 5px solid var(--primary);
                border-radius: 14px;
                box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
                grid-template-columns: 62px minmax(0, 1fr);
                min-height: 126px;
            }

            .wagon-card-drag {
                background: color-mix(in srgb, var(--background) 74%, var(--secondary));
                border-right: 1px solid var(--border);
                font-size: 20px;
                min-height: 126px;
            }

            .wagon-card-body {
                gap: 14px;
                padding: 18px 18px 16px;
            }

            .wagon-card-summary {
                gap: 16px;
                grid-template-columns: auto minmax(240px, 1fr) minmax(260px, auto);
                padding-right: 48px;
            }

            .wagon-card-index {
                align-self: start;
                font-size: 16px;
                padding: 8px 14px;
            }

            .wagon-card-main strong {
                font-size: 26px;
                line-height: 1.1;
            }

            .wagon-card-type {
                font-size: 16px;
            }

            .wagon-card-controls {
                justify-content: end;
            }

            .wagon-brake-setting {
                background: var(--background);
                border: 1px solid var(--border);
                border-radius: 14px;
                padding: 8px 10px;
            }

            .wagon-card-menu-btn,
            .wagon-card-toggle {
                border-radius: 12px;
                height: 44px;
                width: 44px;
            }

            .wagon-card-actions {
                right: 18px;
                top: 18px;
            }

            .wagon-card-details {
                border-radius: 12px;
            }

            .wagon-summary-card {
                border-radius: 14px;
                box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
                grid-template-columns: repeat(6, minmax(160px, 1fr));
                margin: 0 auto 120px;
                padding: 16px;
            }

            .wagon-summary-card .wagon-metric {
                border-radius: 10px;
                min-height: 82px;
                padding: 12px;
            }

            .wagon-number-lookup-content {
                max-width: 640px;
            }

            #wagonNumberLookupForm.admin-grid {
                grid-template-columns: 1fr;
                gap: 14px;
            }

            #wagonNumberLookupForm .form-actions-row {
                justify-content: flex-end;
            }
        }

        .wagon-lookup-result[hidden] {
            display: none !important;
        }

        .wagon-number-lookup-content .wagon-lookup-field {
            display: grid;
            gap: 8px;
        }

        .wagon-number-lookup-content input {
            font-size: 24px;
            font-weight: 800;
            letter-spacing: 0;
            min-height: 60px;
        }

        .wagon-number-lookup-content .vehicle-suggestion-dropdown {
            border-radius: 12px;
            max-height: 220px;
        }

        @media (max-width: 760px) {
            body.mobile-nav-visible {
                background:
                    radial-gradient(circle at 24% 18%, rgba(255,255,255,0.08), transparent 18%),
                    radial-gradient(circle at 82% 42%, rgba(255,255,255,0.05), transparent 22%),
                    linear-gradient(145deg, #111820 0%, #0a0f14 100%);
                color: #f7f7f7;
            }

            .list-form {
                grid-template-columns: 1fr;
            }

            .fab-button {
                right: 18px;
                bottom: 18px;
            }

            .overview-topbar,
            .app-shell > .header {
                align-items: flex-start;
                flex-direction: row;
            }

            #overviewView.overview-view {
                min-height: calc(100vh - 40px);
                padding: 14px 14px 112px;
            }

            .overview-view .overview-topbar {
                align-items: center;
                background: linear-gradient(135deg, #ff4f00 0%, #ff6d00 100%);
                border: 0;
                border-radius: 26px;
                box-shadow: 0 16px 34px rgba(255, 109, 0, 0.25);
                color: #fff;
                display: grid;
                gap: 14px;
                grid-template-columns: minmax(0, 1fr) auto;
                margin: 0 0 20px;
                min-height: 132px;
                padding: 22px 24px;
            }

            .overview-view .overview-title {
                align-items: center;
                display: grid;
                gap: 18px;
                grid-template-columns: 78px minmax(0, 1fr);
                min-width: 0;
            }

            .overview-heading-text {
                min-width: 0;
            }

            .overview-view .overview-title::before {
                content: none;
            }

            .overview-view .overview-logo {
                align-items: center;
                background: rgba(255,255,255,0.98);
                border: 3px solid rgba(255,255,255,0.95);
                border-radius: 50%;
                display: block;
                height: 76px;
                object-fit: cover;
                padding: 4px;
                width: 76px;
            }

            .overview-view .overview-title h1 {
                color: #fff;
                font-size: clamp(22px, 6vw, 34px);
                font-weight: 900;
                line-height: 1.05;
                margin: 0 0 8px;
                overflow-wrap: anywhere;
            }

            .overview-view .overview-title #overviewUserLabel {
                display: none;
            }

            .overview-view .app-menu {
                display: none;
            }

            .overview-mobile-status {
                align-content: center;
                align-items: center;
                background: rgba(255,255,255,0.95);
                box-shadow: 0 10px 20px rgba(0,0,0,0.12);
                border-radius: 999px;
                color: #168c35;
                display: inline-flex;
                justify-content: center;
                justify-self: end;
                min-height: 56px;
                padding: 0;
                width: 56px;
            }

            .overview-mobile-status div {
                align-items: center;
                display: flex;
                gap: 8px;
                min-width: 0;
            }

            .overview-mobile-status strong {
                display: none;
            }

            .status-dot {
                background: #1fa447;
                border-radius: 50%;
                display: inline-block;
                height: 24px;
                width: 24px;
            }

            .status-dot.is-offline {
                background: #d32f2f;
            }

            .overview-mobile-status.is-offline {
                color: #d32f2f;
            }

            #overviewView .overview-filters {
                background: rgba(30, 36, 44, 0.94);
                border: 1px solid rgba(255,255,255,0.06);
                border-radius: 26px;
                box-shadow: 0 16px 34px rgba(0,0,0,0.22);
                gap: 18px;
                grid-template-columns: 1fr;
                margin-bottom: 26px;
                padding: 22px;
            }

            #overviewView .overview-filters input {
                background-color: #fff;
                border: 1px solid rgba(0,0,0,0.08);
                border-radius: 12px;
                color: #222;
                font-size: 24px;
                min-height: 74px;
                padding: 16px 18px 16px 70px;
            }

            #overviewView .overview-filters input::placeholder {
                color: #8a8a8a;
                opacity: 1;
            }

            #overviewView .overview-filters .filter-field {
                position: relative;
            }

            #overviewView .overview-filters .filter-field > i {
                color: #666;
                display: block;
                font-size: 32px;
                left: 25px;
                pointer-events: none;
                position: absolute;
                top: 50%;
                transform: translateY(-50%);
            }

            #overviewView .list-grid {
                gap: 18px;
                margin-bottom: 0;
            }

            #overviewView .list-day-heading {
                align-items: center;
                color: #fff;
                display: grid;
                gap: 10px;
                grid-template-columns: auto minmax(0, 1fr) auto;
                margin: 8px 20px 0;
                padding: 0;
            }

            #overviewView .list-day-heading i {
                color: var(--primary);
                font-size: 24px;
            }

            #overviewView .list-day-heading strong {
                color: #fff;
                font-size: 24px;
                font-weight: 900;
                line-height: 1.15;
            }

            #overviewView .list-day-heading span {
                background: rgba(255,255,255,0.07);
                border-radius: 999px;
                color: #fff;
                font-size: 19px;
                font-weight: 700;
                padding: 7px 15px;
            }

            #overviewView .list-card {
                background:
                    radial-gradient(circle at 25% 16%, rgba(255,255,255,0.08), transparent 18%),
                    linear-gradient(145deg, rgba(34, 40, 48, 0.95), rgba(22, 27, 34, 0.96));
                border: 1px solid rgba(255,255,255,0.05);
                border-radius: 26px;
                box-shadow: 0 16px 34px rgba(0,0,0,0.25);
                display: grid;
                grid-template-columns: 1fr;
                padding: 30px;
                position: relative;
            }

            #overviewView .list-card-main {
                display: grid;
                gap: 18px;
            }

            #overviewView .list-card-head {
                align-items: center;
                display: grid;
                gap: 22px;
                grid-template-columns: 76px minmax(0, 1fr);
            }

            #overviewView .list-train-badge {
                align-items: center;
                background: linear-gradient(135deg, #ff5a00, #ff7a00);
                border-radius: 50%;
                color: #fff;
                display: inline-flex;
                height: 76px;
                justify-content: center;
                width: 76px;
            }

            #overviewView .list-train-badge i {
                font-size: 27px;
            }

            #overviewView .list-card h2 {
                color: #fff;
                font-size: 34px;
                font-weight: 900;
                line-height: 1.05;
                margin-bottom: 8px;
                padding-right: 0;
            }

            #overviewView .list-meta {
                color: rgba(255,255,255,0.74);
                font-size: 22px;
                margin-top: 0;
            }

            #overviewView .list-card-meta-row {
                align-items: center;
                color: #fff;
                display: grid;
                font-size: 22px;
                gap: 14px;
                grid-template-columns: 34px minmax(0, 1fr);
                line-height: 1.25;
            }

            #overviewView .list-card-meta-row i {
                color: rgba(255,255,255,0.72);
                font-size: 27px;
                text-align: center;
            }

            #overviewView .list-card-actions {
                border-top: 1px solid rgba(255,255,255,0.13);
                display: grid;
                gap: 13px;
                grid-template-columns: repeat(4, minmax(0, 1fr));
                margin-top: 22px;
                padding-top: 26px;
            }

            #overviewView .list-card-actions .btn {
                background: #fff;
                border: 1px solid rgba(255,255,255,0.74);
                border-radius: 14px;
                color: var(--primary);
                display: grid;
                gap: 8px;
                height: 96px;
                padding: 10px 4px;
                place-items: center;
                width: 100%;
            }

            #overviewView .list-card-actions .btn-secondary {
                background: #fff;
                border-color: rgba(255, 255, 255, 0.74);
                color: var(--primary);
            }

            #overviewView .list-card-actions .btn-secondary i,
            #overviewView .list-card-actions .btn-secondary span {
                color: var(--primary);
            }

            #overviewView .list-card-actions .btn-danger {
                background: #fff;
                border-color: rgba(255,255,255,0.74);
                color: #d40000;
            }

            #overviewView .list-card-actions .btn-danger i,
            #overviewView .list-card-actions .btn-danger span {
                color: #d40000;
            }

            #overviewView .list-card-actions .btn i {
                font-size: 29px;
            }

            #overviewView .list-card-actions .btn span {
                display: block;
                font-size: 16px;
                font-weight: 800;
                line-height: 1.1;
            }

            .mobile-bottom-nav {
                align-items: center;
                background: rgba(27, 33, 41, 0.96);
                border: 1px solid rgba(255,255,255,0.05);
                border-radius: 26px;
                box-shadow: 0 -8px 24px rgba(0,0,0,0.28);
                bottom: 20px;
                display: none;
                gap: 4px;
                grid-template-columns: repeat(4, 1fr);
                left: 26px;
                padding: 13px 10px 16px;
                position: fixed;
                right: 26px;
                z-index: 90;
            }

            body.mobile-nav-visible .mobile-bottom-nav {
                display: grid;
            }

            body.mobile-nav-visible .fab-button:not(.wagon-fab-button) {
                bottom: 150px;
                height: 96px;
                right: 44px;
                width: 96px;
            }

            body.mobile-nav-visible .overview-view {
                padding-bottom: 146px;
            }

            .mobile-bottom-nav button {
                align-items: center;
                background: transparent;
                border: 0;
                color: #fff;
                display: grid;
                font-size: 15px;
                gap: 7px;
                justify-items: center;
                min-width: 0;
                position: relative;
            }

            .mobile-bottom-nav i {
                font-size: 29px;
            }

            .mobile-bottom-nav .is-active,
            .mobile-bottom-nav button:hover {
                color: var(--primary);
            }

            .mobile-bottom-nav .is-active::after {
                background: var(--primary);
                border-radius: 999px;
                content: "";
                display: block;
                height: 5px;
                left: 50%;
                position: absolute;
                top: -13px;
                transform: translateX(-50%);
                width: 76px;
            }

            .mobile-more-menu {
                background: rgba(27, 33, 41, 0.98);
                border: 1px solid rgba(255,255,255,0.08);
                border-radius: 18px;
                bottom: 118px;
                box-shadow: 0 16px 34px rgba(0,0,0,0.34);
                display: none;
                gap: 8px;
                padding: 10px;
                position: fixed;
                right: 26px;
                width: min(300px, calc(100vw - 52px));
                z-index: 95;
            }

            .mobile-more-menu.open {
                display: grid;
            }

            .mobile-more-menu button {
                align-items: center;
                background: rgba(255,255,255,0.06);
                border: 1px solid rgba(255,255,255,0.08);
                border-radius: 12px;
                color: #fff;
                cursor: pointer;
                display: grid;
                font-size: 15px;
                font-weight: 800;
                gap: 10px;
                grid-template-columns: 28px minmax(0, 1fr);
                min-height: 48px;
                padding: 10px 12px;
                text-align: left;
            }

            .mobile-more-menu button:hover,
            .mobile-more-menu button:focus-visible {
                border-color: var(--primary);
                color: var(--primary);
                outline: none;
            }

            .mobile-more-menu i {
                font-size: 22px;
                text-align: center;
            }

            .mobile-sync-status {
                background: rgba(255,255,255,0.06);
                border: 1px solid rgba(255,255,255,0.08);
                border-radius: 14px;
                color: #fff;
                display: grid;
                gap: 9px;
                padding: 12px;
            }

            .mobile-sync-status-row {
                align-items: center;
                display: grid;
                gap: 10px;
                grid-template-columns: 24px minmax(0, 1fr);
            }

            .mobile-sync-status-row i {
                color: var(--primary);
                font-size: 18px;
            }

            .mobile-sync-status-row .mobile-connection-icon {
                color: #1fa447;
            }

            .mobile-sync-status-row .mobile-connection-icon.is-offline {
                color: #d32f2f;
            }

            .mobile-sync-status-row strong,
            .mobile-sync-status-row span {
                display: block;
                line-height: 1.25;
            }

            .mobile-sync-status-row strong {
                font-size: 13px;
            }

            .mobile-sync-status-row span {
                color: rgba(255,255,255,0.72);
                font-size: 12px;
            }

            @media (max-width: 560px) {
                .overview-view .overview-topbar {
                    align-items: center;
                    border-radius: 22px;
                    gap: 10px;
                    grid-template-columns: minmax(0, 1fr) auto;
                    min-height: 108px;
                    padding: 17px 18px;
                }

                .overview-view .overview-title {
                    gap: 13px;
                    grid-template-columns: 58px minmax(0, 1fr);
                    min-width: 0;
                }

                .overview-view .overview-logo {
                    height: 58px;
                    width: 58px;
                }

                .overview-mobile-status {
                    justify-self: end;
                    max-width: none;
                    min-height: 42px;
                    width: 42px;
                }

                .overview-mobile-status div {
                    gap: 6px;
                }

                .overview-mobile-status strong {
                    font-size: 13px;
                }

                .status-dot {
                    height: 17px;
                    width: 17px;
                }

                #overviewView .overview-filters {
                    border-radius: 20px;
                    padding: 14px;
                }

                #overviewView .overview-filters input {
                    font-size: 18px;
                    min-height: 58px;
                    padding-left: 54px;
                }

                #overviewView .overview-filters .filter-field > i {
                    font-size: 24px;
                    left: 19px;
                }

                #overviewView .list-day-heading {
                    margin-inline: 14px;
                }

                #overviewView .list-day-heading strong {
                    font-size: 19px;
                }

                #overviewView .list-day-heading span {
                    font-size: 14px;
                    padding: 6px 10px;
                }

                #overviewView .list-card {
                    border-radius: 20px;
                    padding: 22px 18px;
                }

                #overviewView .list-card-head {
                    gap: 14px;
                    grid-template-columns: 56px minmax(0, 1fr);
                }

                #overviewView .list-train-badge {
                    height: 56px;
                    width: 56px;
                }

                #overviewView .list-card h2 {
                    font-size: 27px;
                }

                #overviewView .list-meta,
                #overviewView .list-card-meta-row {
                    font-size: 17px;
                }

                #overviewView .list-card-meta-row {
                    grid-template-columns: 26px minmax(0, 1fr);
                }

                #overviewView .list-card-meta-row i {
                    font-size: 22px;
                }

                #overviewView .list-card-actions {
                    gap: 8px;
                    padding-top: 18px;
                }

                #overviewView .list-card-actions .btn {
                    height: 74px;
                }

                #overviewView .list-card-actions .btn i {
                    font-size: 24px;
                }

                #overviewView .list-card-actions .btn span {
                    font-size: 12px;
                }

                .mobile-bottom-nav {
                    left: 14px;
                    right: 14px;
                }

                .mobile-more-menu {
                    bottom: 104px;
                    right: 14px;
                    width: min(290px, calc(100vw - 28px));
                }

                .mobile-bottom-nav button {
                    font-size: 11px;
                }

                .mobile-bottom-nav i {
                    font-size: 24px;
                }

                body.mobile-nav-visible .fab-button:not(.wagon-fab-button) {
                    bottom: 128px;
                    height: 74px;
                    right: 30px;
                    width: 74px;
                }
            }

            .app-shell > .header {
                align-items: center;
            }

            .title {
                font-size: 18px;
            }

            .wagon-card-grid {
                gap: 10px;
                margin-bottom: 12px;
            }

            .wagon-card {
                grid-template-columns: 44px minmax(0, 1fr);
                border-radius: 7px;
            }

            .wagon-card-body {
                padding: 10px 46px 10px 10px;
                gap: 10px;
            }

            .wagon-card-summary {
                grid-template-columns: minmax(0, 1fr);
                gap: 8px;
            }

            .wagon-card-index {
                grid-column: 1 / -1;
                width: max-content;
                font-size: 12px;
                padding: 3px 7px;
            }

            .wagon-card-main strong {
                font-size: 15px;
            }

            .wagon-card-actions {
                gap: 6px;
            }

            .wagon-card-menu-btn {
                width: 32px;
                height: 32px;
            }

            .wagon-card-toggle {
                width: 32px;
                height: 32px;
            }

            .wagon-detail-grid {
                grid-template-columns: repeat(2, minmax(0, 1fr));
            }

            .wagon-summary-card {
                grid-template-columns: repeat(2, minmax(0, 1fr));
                gap: 8px;
                margin-bottom: 120px;
                padding: 10px;
            }

            .wagon-summary-card .summary-wide {
                grid-column: 1 / -1;
            }

            .wagon-summary-card .wagon-metric {
                padding: 7px;
            }

            .wagon-summary-card .wagon-metric span {
                font-size: 11px;
            }

            .wagon-summary-card .wagon-metric strong {
                font-size: 13px;
                line-height: 1.25;
            }
        }
    
        .list-form {
            grid-template-columns: repeat(4, minmax(180px, 1fr));
        }

        .list-form .form-span-2 {
            grid-column: span 2;
        }

        .list-form .form-actions-row {
            grid-column: 1 / -1;
            display: flex;
            justify-content: flex-end;
        }

        .wagon-card-grid {
            display: grid;
            grid-template-columns: 1fr;
            gap: 14px;
            margin-bottom: 16px;
        }

        .damage-report-grid {
            display: grid;
            gap: 14px;
            grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
        }

        .damage-report-card {
            background: var(--secondary);
            border: 1px solid var(--border);
            border-left: 5px solid var(--primary);
            border-radius: 8px;
            box-shadow: 0 2px 10px rgba(0,0,0,0.06);
            display: flex;
            flex-direction: column;
            gap: 12px;
            overflow: hidden;
            padding: 0;
        }

        .damage-report-card header {
            align-items: flex-start;
            display: grid;
            gap: 8px;
            grid-template-columns: minmax(0, 1fr) auto;
            padding: 16px 16px 0;
        }

        .damage-report-card h2 {
            color: var(--text);
            font-size: 21px;
            line-height: 1.2;
            margin: 0;
            overflow-wrap: anywhere;
        }

        .damage-report-code {
            background: rgba(255, 112, 0, 0.12);
            border: 1px solid rgba(255, 112, 0, 0.32);
            border-radius: 999px;
            color: var(--primary);
            font-weight: 800;
            justify-self: end;
            max-width: 100%;
            overflow-wrap: anywhere;
            padding: 6px 11px;
            text-align: center;
            white-space: nowrap;
        }

        .damage-report-meta,
        .damage-report-details {
            color: var(--text-light);
            font-size: 13px;
            line-height: 1.45;
        }

        .damage-report-route {
            color: var(--text-light);
            font-size: 14px;
            overflow-wrap: anywhere;
        }

        .damage-report-body {
            display: grid;
            gap: 10px;
            padding: 0 16px 16px;
        }

        .damage-report-facts {
            display: grid;
            gap: 8px;
            grid-template-columns: repeat(2, minmax(0, 1fr));
        }

        .damage-report-fact {
            background: var(--muted);
            border: 1px solid var(--border);
            border-radius: 8px;
            min-width: 0;
            padding: 9px 10px;
        }

        .damage-report-fact span {
            color: var(--text-light);
            display: block;
            font-size: 12px;
            margin-bottom: 3px;
        }

        .damage-report-fact strong {
            color: var(--text);
            display: block;
            font-size: 14px;
            line-height: 1.25;
            overflow-wrap: anywhere;
        }

        .damage-report-details {
            background: var(--muted);
            border: 1px solid var(--border);
            border-radius: 8px;
            color: var(--text);
            padding: 10px;
            white-space: pre-wrap;
        }

        .damage-report-labels,
        .damage-report-attachments {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
        }

        .damage-report-labels span {
            background: var(--muted);
            border: 1px solid var(--border);
            border-radius: 999px;
            color: var(--text);
            font-size: 12px;
            font-weight: 700;
            padding: 5px 9px;
        }

        .damage-report-attachments button {
            justify-content: flex-start;
            max-width: 100%;
            overflow: hidden;
            text-align: left;
            width: 100%;
        }

        .damage-report-attachments button span {
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }

        .damage-report-status {
            border-radius: 999px;
            font-size: 12px;
            font-weight: 800;
            padding: 5px 9px;
            width: fit-content;
        }

        .damage-report-status.open {
            background: rgba(255, 112, 0, 0.12);
            color: var(--primary);
        }

        .damage-report-status.done {
            background: rgba(34, 197, 94, 0.14);
            color: #15803d;
        }

        .checkbox-inline {
            align-items: center;
            display: flex !important;
            flex-direction: row !important;
            gap: 10px;
        }

        .checkbox-inline input {
            width: auto;
        }

        @media (max-width: 520px) {
            .damage-report-grid {
                grid-template-columns: 1fr;
            }

            .damage-report-card header {
                grid-template-columns: 1fr;
            }

            .damage-report-code {
                justify-self: start;
                white-space: normal;
            }

            .damage-report-facts {
                grid-template-columns: 1fr;
            }
        }

        .train-info-card {
            background: var(--secondary);
            background: color-mix(in srgb, var(--secondary) 94%, transparent);
            border: 1px solid var(--border);
            border-left: 5px solid var(--primary);
            border-radius: 8px;
            box-shadow: 0 2px 10px rgba(0,0,0,0.06);
            backdrop-filter: blur(10px);
            display: grid;
            grid-template-columns: auto minmax(0, 1fr) auto;
            gap: 12px;
            align-items: center;
            margin-bottom: 14px;
            padding: 14px 16px;
            position: sticky;
            top: 0;
            z-index: 70;
        }

        .train-info-card span {
            color: var(--text-light);
            display: block;
            font-size: 12px;
            font-weight: 700;
            text-transform: uppercase;
        }

        .train-info-card strong {
            color: var(--text);
            display: block;
            font-size: 22px;
            line-height: 1.2;
            overflow-wrap: anywhere;
        }

        .train-info-main small {
            color: var(--text-light);
            display: block;
            font-size: 13px;
            font-weight: 700;
            margin-top: 4px;
            overflow-wrap: anywhere;
        }

        .train-back-btn,
        .train-info-btn {
            align-items: center;
            border: 0;
            border-radius: 8px;
            cursor: pointer;
            display: inline-flex;
            height: 42px;
            justify-content: center;
            transition: transform 0.2s ease, box-shadow 0.2s ease;
            width: 42px;
        }

        .train-back-btn {
            background: var(--primary);
            color: white;
        }

        .train-info-btn {
            background: rgba(255,109,0,0.12);
            border: 1px solid rgba(255,109,0,0.28);
            color: var(--primary);
        }

        .train-back-btn:hover,
        .train-info-btn:hover {
            box-shadow: 0 6px 16px rgba(255,109,0,0.28);
            transform: translateY(-1px);
        }

        .train-info-card .train-back-btn i,
        .train-info-card .train-info-btn i {
            background: transparent;
            color: inherit;
            font-size: 18px;
            height: auto;
            width: auto;
        }

        .train-info-card i {
            align-items: center;
            background: rgba(255,109,0,0.12);
            border-radius: 8px;
            color: var(--primary);
            display: flex;
            font-size: 20px;
            height: 42px;
            justify-content: center;
            width: 42px;
        }

        .wagon-card {
            background: var(--secondary);
            border: 1px solid var(--border);
            border-radius: 8px;
            box-shadow: 0 2px 10px rgba(0,0,0,0.06);
            display: grid;
            grid-template-columns: 48px minmax(0, 1fr);
            cursor: default;
            overflow: hidden;
            position: relative;
            transform-origin: center;
            transition: box-shadow 0.18s ease, opacity 0.18s ease, transform 0.18s ease, border-color 0.18s ease, background 0.18s ease;
            width: 100%;
        }

        .wagon-card.wagon-scroll-target,
        tr.wagon-scroll-target {
            animation: wagonFocusPulse 1.4s ease;
        }

        @keyframes wagonFocusPulse {
            0% {
                box-shadow: 0 0 0 0 rgba(255, 109, 0, 0.42);
                outline: 2px solid rgba(255, 109, 0, 0.8);
            }
            100% {
                box-shadow: 0 0 0 14px rgba(255, 109, 0, 0);
                outline: 2px solid rgba(255, 109, 0, 0);
            }
        }

        .wagon-card.invalid {
            border-color: var(--danger);
            background: #fff7f7;
        }

        .wagon-card.dragging {
            opacity: 0.6;
            transform: scale(0.985) rotate(-0.35deg);
            box-shadow: 0 12px 26px rgba(0,0,0,0.16);
            border-color: var(--primary);
        }

        .wagon-card.touch-dragging {
            opacity: 0;
            transform: scale(0.985);
            border-color: var(--primary);
        }

        .wagon-card.drag-preview {
            position: fixed;
            z-index: 1200;
            pointer-events: none;
            opacity: 0.96;
            transform: translate3d(var(--drag-x, 0), var(--drag-y, 0), 0) rotate(-1deg) scale(1.02);
            box-shadow: 0 18px 42px rgba(0,0,0,0.28);
            border-color: var(--primary);
            transition: none;
        }

        .wagon-card-placeholder {
            border: 2px dashed var(--primary);
            border-radius: 8px;
            background: rgba(245, 124, 0, 0.08);
            min-height: 86px;
            box-shadow: inset 0 0 0 4px rgba(255,255,255,0.6);
            transition: transform 0.18s ease, min-height 0.18s ease, background 0.18s ease;
        }

        .wagon-card.drag-over {
            position: relative;
            outline: 2px solid var(--primary);
            outline-offset: 2px;
            transform: translateY(4px) scale(1.01);
            box-shadow: 0 14px 28px rgba(245, 124, 0, 0.22);
            background: #fffaf5;
        }

        .wagon-card.drag-over::before {
            content: "";
            position: absolute;
            left: 12px;
            right: 12px;
            top: -8px;
            height: 4px;
            border-radius: 999px;
            background: var(--primary);
            box-shadow: 0 0 0 4px rgba(245, 124, 0, 0.12);
        }

        .wagon-card.drag-over.drop-after::before {
            top: auto;
            bottom: -8px;
        }

        .wagon-card.reorder-target {
            animation: reorderPulse 0.42s ease;
        }

        @keyframes reorderPulse {
            0% { box-shadow: 0 0 0 0 rgba(245, 124, 0, 0.36); }
            70% { box-shadow: 0 0 0 8px rgba(245, 124, 0, 0); }
            100% { box-shadow: var(--shadow); }
        }

        .wagon-card-drag {
            border: 0;
            border-right: 1px solid var(--border);
            background: var(--background);
            color: var(--text-light);
            display: flex;
            align-items: center;
            justify-content: center;
            cursor: grab;
            min-height: 72px;
            font-size: 16px;
            touch-action: none;
            user-select: none;
            transition: background 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
        }

        .wagon-card-drag:hover,
        .wagon-card.dragging .wagon-card-drag {
            background: var(--primary);
            color: var(--secondary);
            box-shadow: inset -3px 0 0 rgba(0,0,0,0.08);
        }

        .wagon-card-drag:active {
            cursor: grabbing;
        }

        .wagon-card-body {
            display: grid;
            gap: 12px;
            min-width: 0;
            padding: 14px 50px 14px 14px;
        }

        .wagon-card-summary {
            display: grid;
            grid-template-columns: auto minmax(0, 1fr) auto;
            gap: 12px;
            align-items: center;
        }

        .wagon-card-main {
            display: grid;
            gap: 4px;
            min-width: 0;
        }

        .wagon-card-main strong {
            font-size: 17px;
            overflow-wrap: anywhere;
        }

        .wagon-card-type {
            color: var(--text-light);
            font-size: 13px;
            line-height: 1.35;
            overflow-wrap: anywhere;
        }

        .wagon-card-index {
            color: var(--primary);
            font-weight: 800;
            background: #fff3e8;
            border: 1px solid #ffd5b0;
            border-radius: 999px;
            padding: 4px 8px;
        }

        .wagon-card-details {
            display: none;
            gap: 10px;
            border: 1px solid var(--border);
            border-radius: 8px;
            background: var(--background);
            padding: 12px;
        }

        .wagon-card.expanded .wagon-card-details {
            display: grid;
        }

        .wagon-detail-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
            gap: 8px;
        }

        .wagon-metric {
            border: 1px solid var(--border);
            border-radius: 6px;
            padding: 8px;
            min-width: 0;
        }

        .wagon-metric span {
            display: block;
            color: var(--text-light);
            font-size: 12px;
            margin-bottom: 3px;
        }

        .wagon-metric strong {
            font-size: 15px;
        }

        .wagon-metric.detail-wide {
            grid-column: 1 / -1;
        }

        .wagon-card-actions {
            align-items: center;
            display: flex;
            gap: 8px;
            justify-content: flex-end;
            position: absolute;
            right: 12px;
            top: 12px;
            z-index: 20;
        }

        .wagon-card-menu-btn {
            width: 34px;
            height: 34px;
            border: 1px solid var(--border);
            border-radius: 6px;
            background: var(--secondary);
            display: inline-flex;
            align-items: center;
            justify-content: center;
            color: var(--text);
            cursor: pointer;
        }

        .wagon-card-menu-btn:hover,
        .wagon-card.menu-open .wagon-card-menu-btn {
            border-color: var(--primary);
            color: var(--primary);
            box-shadow: 0 4px 12px rgba(255,109,0,0.16);
        }

        .wagon-card-menu {
            background: var(--secondary);
            border: 1px solid var(--border);
            border-radius: 8px;
            box-shadow: 0 14px 34px rgba(0,0,0,0.18);
            display: grid;
            gap: 4px;
            min-width: 180px;
            padding: 6px;
            position: absolute;
            right: 0;
            top: calc(100% + 8px);
            z-index: 90;
        }

        .wagon-card.menu-open {
            overflow: visible !important;
            z-index: 140;
        }

        .wagon-card.menu-open .wagon-card-body,
        .wagon-card.menu-open .wagon-card-summary,
        .wagon-card-grid:has(.wagon-card.menu-open) {
            overflow: visible;
        }

        .wagon-card-menu[hidden] {
            display: none;
        }

        .wagon-card-menu .action-btn {
            align-items: center;
            background: transparent;
            border: 0;
            border-radius: 6px;
            color: var(--text);
            cursor: pointer;
            display: grid;
            font-weight: 700;
            gap: 10px;
            grid-template-columns: 22px minmax(0, 1fr);
            justify-items: start;
            min-height: 38px;
            padding: 8px 10px;
            text-align: left;
            width: 100%;
        }

        .wagon-card-menu .action-btn:hover {
            background: rgba(255,109,0,0.1);
            color: var(--primary);
        }

        .wagon-card-menu .delete-btn {
            color: var(--danger);
        }

        .wagon-card-actions .action-label {
            display: inline;
        }

        .wagon-card-controls {
            align-items: center;
            display: flex;
            gap: 8px;
            justify-content: flex-end;
            min-width: 0;
            width: 100%;
        }

        .wagon-brake-setting {
            align-items: center;
            display: flex;
            gap: 8px;
            justify-content: flex-end;
            min-width: 0;
        }

        .wagon-card-controls .wagon-brake-setting {
            flex: 1 1 auto;
        }

        .wagon-brake-setting span {
            color: var(--text-light);
            font-size: 12px;
            font-weight: 700;
            white-space: nowrap;
        }

        .wagon-brake-toggle {
            background: var(--background);
            border: 1px solid var(--border);
            border-radius: 999px;
            display: inline-grid;
            grid-template-columns: repeat(2, 34px);
            padding: 3px;
        }

        .wagon-brake-toggle button {
            background: transparent;
            border: 0;
            border-radius: 999px;
            color: var(--text-light);
            cursor: pointer;
            font-weight: 800;
            height: 28px;
            line-height: 1;
        }

        .wagon-brake-toggle button.is-active {
            background: var(--primary);
            color: white;
            box-shadow: 0 3px 10px rgba(255,109,0,0.25);
        }

        .wagon-card-toggle {
            background: var(--secondary);
            border: 1px solid var(--border);
            border-radius: 6px;
            color: var(--text-light);
            display: inline-flex;
            align-items: center;
            justify-content: center;
            height: 34px;
            width: 34px;
            cursor: pointer;
        }

        .wagon-card-toggle:hover {
            border-color: var(--primary);
            color: var(--primary);
            box-shadow: 0 4px 12px rgba(255,109,0,0.16);
        }

        .wagon-card-toggle i {
            transition: transform 0.2s ease;
        }

        .wagon-card.expanded .wagon-card-toggle i {
            transform: rotate(180deg);
        }

        .wagon-table-hidden {
            position: absolute;
            width: 1px;
            height: 1px;
            overflow: hidden;
            clip: rect(0 0 0 0);
        }

        .wagon-summary-card {
            position: static;
            background: var(--secondary);
            border: 1px solid var(--border);
            border-left: 5px solid var(--primary);
            border-radius: 8px;
            box-shadow: 0 4px 18px rgba(0,0,0,0.08);
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
            gap: 10px;
            margin: 16px 0 120px;
            overflow: visible;
            padding: 12px;
        }

        .wagon-summary-card .wagon-metric {
            background: var(--background);
        }

        .wagon-summary-card .summary-wide {
            grid-column: auto;
        }

        .wagon-summary-card.list-info-summary-card {
            margin: 0;
        }

        .summary-breakdown {
            display: grid;
            gap: 2px;
            line-height: 1.2;
        }

        .summary-breakdown span {
            color: var(--text);
            font-size: 12px;
        }

        .list-info-modal-content {
            max-width: 840px;
        }

        .list-info-content {
            display: grid;
            gap: 18px;
        }

        .list-info-section {
            display: grid;
            gap: 10px;
        }

        .list-info-section h3 {
            color: var(--text);
            font-size: 16px;
            margin: 0;
        }

        .brake-rule-modal-content {
            max-width: 620px;
        }

        .brake-rule-body {
            display: grid;
            gap: 12px;
            color: var(--text);
        }

        .brake-rule-summary {
            background: rgba(255,109,0,0.09);
            border: 1px solid rgba(255,109,0,0.24);
            border-radius: 8px;
            padding: 12px;
        }

        .brake-rule-summary strong {
            display: block;
            margin-bottom: 4px;
        }

        .brake-rule-list {
            display: grid;
            gap: 6px;
            margin: 0;
            padding: 0;
        }

        .brake-rule-list li {
            background: var(--background);
            border: 1px solid var(--border);
            border-radius: 8px;
            display: flex;
            justify-content: space-between;
            gap: 12px;
            list-style: none;
            padding: 8px 10px;
        }

        .brake-rule-list span:last-child {
            color: var(--primary);
            font-weight: 800;
            white-space: nowrap;
        }

        .brake-rule-note {
            color: var(--text-light);
            font-size: 13px;
            line-height: 1.4;
        }

        .brake-rule-actions {
            display: flex;
            gap: 10px;
            justify-content: flex-end;
            margin-top: 18px;
            flex-wrap: wrap;
        }

        body.dragging-wagon {
            user-select: none;
        }

        .export-document-actions,
        .export-document-toolbar {
            display: grid;
            gap: 10px;
        }

        .export-document-actions {
            grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
            margin-bottom: 16px;
        }

        .export-document-toolbar {
            grid-template-columns: repeat(3, minmax(180px, 1fr));
            align-items: start;
        }

        .export-document-choices {
            display: grid;
            gap: 8px;
            grid-column: 1 / -1;
            grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
        }

        .export-document-choice {
            align-items: center;
            background: var(--background);
            border: 1px solid var(--border);
            border-radius: 6px;
            display: grid;
            gap: 8px;
            grid-template-columns: auto minmax(0, 1fr) auto;
            min-width: 0;
            padding: 10px;
        }

        .export-document-choice strong {
            min-width: 0;
            overflow-wrap: anywhere;
        }

        .export-document-choice input {
            width: 18px;
            height: 18px;
        }

        .export-document-choice span {
            color: var(--text-light);
            display: block;
            font-size: 12px;
            margin-top: 2px;
        }

        .export-document-view {
            height: 36px;
            justify-content: center;
            padding: 0;
            width: 36px;
        }

        .export-email-panel {
            background: var(--background);
            border: 1px solid var(--border);
            border-radius: 8px;
            display: grid;
            gap: 10px;
            margin-top: 14px;
            padding: 12px;
        }

        .export-email-panel h3 {
            color: var(--text);
            font-size: 16px;
            margin: 0;
        }

        .export-email-grid {
            display: grid;
            gap: 10px;
            grid-template-columns: repeat(2, minmax(0, 1fr));
        }

        .export-email-recipients {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
            grid-column: 1 / -1;
        }

        .export-email-documents {
            display: grid;
            gap: 8px;
            grid-column: 1 / -1;
            grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
        }

        .export-email-add-controls {
            display: grid;
            gap: 8px;
            grid-template-columns: minmax(0, 1fr) 46px;
        }

        .export-email-add-controls .btn {
            align-items: center;
            border-radius: 8px;
            display: inline-flex;
            height: 42px;
            justify-content: center;
            padding: 0;
        }

        .export-email-recipient-chip {
            align-items: center;
            background: var(--secondary);
            border: 1px solid var(--border);
            border-radius: 999px;
            display: inline-grid;
            gap: 8px;
            grid-template-columns: minmax(0, 1fr) auto;
            max-width: 100%;
            min-width: min(100%, 240px);
            padding: 8px 8px 8px 12px;
        }

        .export-email-recipient-chip span,
        .export-email-recipient-chip strong {
            display: block;
            min-width: 0;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }

        .export-email-recipient-chip strong {
            color: var(--text);
            font-size: 12px;
            line-height: 1.2;
        }

        .export-email-recipient-chip span span {
            color: var(--text-light);
            font-size: 12px;
            font-weight: 700;
        }

        .export-email-recipient-chip button {
            align-items: center;
            background: rgba(255, 102, 0, 0.12);
            border: 1px solid rgba(255, 102, 0, 0.25);
            border-radius: 999px;
            color: var(--primary);
            cursor: pointer;
            display: inline-flex;
            height: 30px;
            justify-content: center;
            width: 30px;
        }

        .export-email-chip {
            align-items: center;
            background: var(--secondary);
            border: 1px solid var(--border);
            border-radius: 8px;
            cursor: pointer;
            display: grid;
            gap: 8px;
            grid-template-columns: auto minmax(0, 1fr);
            min-width: 0;
            padding: 9px 10px;
        }

        .export-email-chip input {
            width: 18px;
            height: 18px;
        }

        .export-email-chip strong,
        .export-email-chip span {
            display: block;
            min-width: 0;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }

        .export-email-chip strong {
            color: var(--text);
            font-size: 13px;
        }

        .export-email-chip span {
            color: var(--text-light);
            font-size: 12px;
            font-weight: 600;
        }

        .export-email-panel label {
            color: var(--text-light);
            display: grid;
            font-size: 13px;
            font-weight: 700;
            gap: 5px;
        }

        .export-email-panel input,
        .export-email-panel textarea {
            background: var(--secondary);
            border: 1px solid var(--border);
            border-radius: 6px;
            color: var(--text);
            font: inherit;
            padding: 9px 10px;
            width: 100%;
        }

        .export-email-panel input[readonly],
        .export-email-panel textarea[readonly] {
            background: rgba(15,23,42,0.04);
            color: var(--text-light);
        }

        .export-email-panel textarea {
            min-height: 74px;
            resize: vertical;
        }

        .export-email-panel .detail-wide {
            grid-column: 1 / -1;
        }

        .export-email-status {
            color: var(--text-light);
            font-size: 13px;
            min-height: 18px;
        }

        .document-preview-content {
            height: min(90vh, 900px);
            max-width: min(96vw, 1080px);
            overflow: hidden;
            padding: 0;
            width: 96vw;
        }

        .document-preview-content .modal-header {
            margin: 0;
            padding: 14px 18px;
        }

        .pdf-viewer-toolbar {
            align-items: center;
            background: var(--secondary);
            border-bottom: 1px solid var(--border);
            border-top: 1px solid var(--border);
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
            justify-content: space-between;
            padding: 10px 14px;
        }

        .pdf-viewer-controls {
            align-items: center;
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
        }

        .pdf-viewer-page-info {
            color: var(--muted);
            font-weight: 700;
            min-width: 92px;
            text-align: center;
        }

        .pdf-viewer-stage {
            align-items: flex-start;
            background: #6f7378;
            display: flex;
            height: calc(100% - 116px);
            justify-content: center;
            overflow: auto;
            padding: 18px;
        }

        .pdf-viewer-canvas {
            background: #fff;
            box-shadow: 0 12px 34px rgba(0, 0, 0, 0.28);
            image-rendering: auto;
            max-width: none;
        }

        .pdf-viewer-message {
            align-self: center;
            background: #fff;
            border-radius: 8px;
            color: var(--text);
            font-weight: 700;
            padding: 14px 18px;
        }

        .image-viewer-toolbar {
            align-items: center;
            background: var(--secondary);
            border-bottom: 1px solid var(--border);
            border-top: 1px solid var(--border);
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
            justify-content: space-between;
            padding: 10px 14px;
        }

        .image-viewer-stage {
            align-items: center;
            background: #202326;
            display: flex;
            height: calc(100% - 116px);
            justify-content: center;
            overflow: auto;
            padding: 18px;
        }

        .image-viewer-stage img {
            display: block;
            max-height: none;
            max-width: none;
            object-fit: contain;
            transform-origin: center center;
        }

        .image-viewer-message {
            align-self: center;
            background: #fff;
            border-radius: 8px;
            color: var(--text);
            font-weight: 700;
            padding: 14px 18px;
        }

        .export-status-note {
            color: var(--text-light);
            font-size: 13px;
            margin-top: 10px;
        }

        @media (max-width: 640px) {
            .export-document-actions,
            .export-document-toolbar {
                grid-template-columns: 1fr;
            }

            .export-email-grid {
                grid-template-columns: 1fr;
            }

            .document-preview-content {
                height: 96vh;
                width: 98vw;
            }

            .document-preview-content .modal-header {
                align-items: center;
                gap: 10px;
                padding: 10px 12px;
            }

            .document-preview-content .modal-title {
                font-size: 16px;
                min-width: 0;
                overflow: hidden;
                text-overflow: ellipsis;
                white-space: nowrap;
            }

            .pdf-viewer-toolbar {
                align-items: center;
                display: grid;
                gap: 6px;
                grid-template-columns: 1fr auto;
                padding: 8px;
            }

            .pdf-viewer-controls {
                display: grid;
                gap: 6px;
                grid-auto-flow: column;
                grid-auto-columns: 40px;
                justify-content: center;
            }

            .pdf-viewer-controls .btn {
                height: 38px;
                min-height: 38px;
                padding: 0;
                width: 40px;
            }

            .pdf-viewer-controls:first-child {
                grid-template-columns: 40px minmax(84px, auto) 40px;
                grid-auto-flow: initial;
                grid-auto-columns: initial;
                justify-self: start;
            }

            .pdf-viewer-controls:last-child {
                justify-self: end;
            }

            .pdf-viewer-page-info {
                align-self: center;
                font-size: 13px;
                min-width: 0;
                white-space: nowrap;
            }

            #pdfZoomInfo {
                display: none;
            }

            .pdf-viewer-stage {
                height: calc(100% - 106px);
                justify-content: flex-start;
                padding: 8px;
            }

            .image-viewer-toolbar {
                display: grid;
                gap: 6px;
                grid-template-columns: 1fr auto;
                padding: 8px;
            }

            .image-viewer-stage {
                height: calc(100% - 106px);
                justify-content: flex-start;
                padding: 8px;
            }
        }

        .fab-stack {
            position: fixed;
            right: 24px;
            bottom: 24px;
            display: grid;
            gap: 12px;
            z-index: 50;
        }

        .fab-stack .fab-button {
            position: static;
        }

        .fab-stack .fab-button.btn-danger {
            background: var(--danger);
        }

        .fab-stack .fab-button.btn-danger:hover {
            background: #B71C1C;
        }

        .bulk-cargo-fab {
            background: #fff;
            border: 1px solid var(--border);
            overflow: hidden;
            padding: 7px;
        }

        .bulk-cargo-fab:hover {
            background: #fff;
        }

        .bulk-cargo-fab img {
            display: block;
            height: 100%;
            object-fit: contain;
            width: 100%;
        }

        .bulk-cargo-list {
            display: grid;
            gap: 10px;
            max-height: min(62vh, 620px);
            overflow-y: auto;
            padding-right: 4px;
        }

        .bulk-cargo-row {
            align-items: end;
            border: 1px solid var(--border);
            border-radius: 8px;
            display: grid;
            gap: 10px;
            grid-template-columns: minmax(150px, 1.15fr) minmax(150px, 1fr) minmax(120px, 0.7fr);
            padding: 12px;
        }

        .bulk-cargo-wagon {
            display: grid;
            gap: 4px;
            min-width: 0;
        }

        .bulk-cargo-wagon strong {
            color: var(--text);
            font-size: 15px;
            overflow-wrap: anywhere;
        }

        .bulk-cargo-wagon span {
            color: var(--text-light);
            font-size: 13px;
        }

        .bulk-cargo-empty {
            border: 1px dashed var(--border);
            border-radius: 8px;
            color: var(--text-light);
            padding: 18px;
            text-align: center;
        }

        @media (max-width: 720px) {
            .bulk-cargo-row {
                grid-template-columns: 1fr;
            }
        }

        @media (max-width: 960px) {
            .list-form {
                grid-template-columns: repeat(2, minmax(0, 1fr));
            }
        }

        @media (max-width: 760px) {
            .list-form {
                grid-template-columns: 1fr;
            }

            .train-prep-task-grid {
                grid-template-columns: 1fr;
            }

            .overview-filters,
            .list-card {
                grid-template-columns: 1fr;
            }

            .wagon-card-grid {
                gap: 16px;
                margin-bottom: 12px;
            }

            .train-info-card {
                grid-template-columns: auto minmax(0, 1fr) auto;
                margin-bottom: 10px;
                padding: 12px;
                top: 8px;
                z-index: 85;
                box-shadow: 0 10px 26px rgba(0,0,0,0.16);
            }

            .train-info-card strong {
                font-size: 19px;
            }

            .wagon-card {
                grid-template-columns: 58px minmax(0, 1fr);
                border-radius: 14px;
                box-shadow: 0 8px 26px rgba(0,0,0,0.12);
                min-height: 190px;
            }

            .wagon-card-body {
                gap: 14px;
                padding: 18px 18px 16px;
            }

            .wagon-card-summary {
                grid-template-columns: 1fr;
                gap: 10px;
            }

            .wagon-card-index {
                grid-column: 1 / -1;
                width: max-content;
                font-size: 14px;
                padding: 8px 14px;
            }

            .wagon-card-main strong {
                font-size: 27px;
                line-height: 1.1;
            }

            .wagon-card-main {
                padding-right: 62px;
            }

            .wagon-card-type {
                font-size: 15px;
                margin-top: 4px;
            }

            .wagon-card-drag {
                font-size: 22px;
                min-height: 100%;
            }

            .wagon-card-actions {
                border-top: 0;
                display: flex;
                gap: 8px;
                justify-content: flex-end;
                padding-top: 0;
                right: 16px;
                top: 16px;
                width: auto;
            }

            .wagon-card-controls {
                align-items: stretch;
                grid-column: 1 / -1;
                justify-content: stretch;
                padding-right: 0;
                width: 100%;
            }

            .wagon-brake-setting {
                background: var(--background);
                border: 1px solid var(--border);
                border-radius: 12px;
                justify-content: space-between;
                min-width: 0;
                padding: 9px 10px;
                width: 100%;
            }

            .wagon-card-controls .wagon-brake-setting {
                width: auto;
            }

            .wagon-card-menu-btn,
            .wagon-card-toggle {
                align-items: center;
                border: 1px solid var(--border);
                border-radius: 12px;
                background: var(--secondary);
                display: inline-flex;
                font-size: 19px;
                height: 46px;
                justify-content: center;
                width: 46px;
            }

            .wagon-card-menu {
                min-width: min(210px, calc(100vw - 72px));
                right: 0;
                top: calc(100% + 10px);
            }

            .wagon-card-toggle {
                color: var(--text);
                min-height: 0;
                padding: 0;
            }

            .wagon-card-toggle::after {
                content: none;
            }

            .wagon-detail-grid {
                grid-template-columns: repeat(2, minmax(0, 1fr));
            }

            .wagon-summary-card {
                grid-auto-columns: auto;
                grid-auto-flow: row;
                grid-template-columns: repeat(2, minmax(0, 1fr));
                gap: 8px;
                margin-bottom: 130px;
                overflow: visible;
                padding: 10px;
            }

            .wagon-summary-card .summary-wide {
                grid-column: 1 / -1;
            }

            .wagon-summary-card .wagon-metric {
                padding: 7px;
            }

            .wagon-summary-card .wagon-metric span {
                font-size: 11px;
            }

            .wagon-summary-card .wagon-metric strong {
                font-size: 13px;
                line-height: 1.25;
            }
        }

        body.mobile-nav-visible {
            padding: 0 0 148px;
        }

        body:not(.mobile-nav-visible) .mobile-bottom-nav,
        body:not(.mobile-nav-visible) .mobile-more-menu,
        body[data-active-view="login"] .mobile-bottom-nav,
        body[data-active-view="login"] .mobile-more-menu,
        body[data-active-view="app"] .mobile-bottom-nav {
            display: none !important;
        }

        body[data-active-view="app"] .mobile-more-menu {
            display: none !important;
        }

        body.mobile-nav-visible:not(.dark-mode) {
            background:
                radial-gradient(circle at 18% 14%, rgba(255,109,0,0.08), transparent 18%),
                linear-gradient(145deg, #f6f8fb 0%, #edf1f5 100%);
            color: #232830;
        }

        body.mobile-nav-visible.dark-mode {
            background:
                radial-gradient(circle at 24% 18%, rgba(255,255,255,0.08), transparent 18%),
                radial-gradient(circle at 82% 42%, rgba(255,255,255,0.05), transparent 22%),
                linear-gradient(145deg, #111820 0%, #0a0f14 100%);
            color: #f7f7f7;
        }

        body.mobile-nav-visible .overview-view,
        body.mobile-nav-visible .admin-view {
            margin: 0;
            max-width: none;
            padding: 14px 20px 132px;
            width: 100%;
        }

        body.mobile-nav-visible .overview-topbar {
            align-items: center;
            background: linear-gradient(135deg, #ff4f00 0%, #ff6d00 100%);
            border: 0;
            border-radius: 18px;
            box-shadow: 0 10px 24px rgba(255, 109, 0, 0.20);
            color: #fff;
            display: grid;
            gap: 12px;
            grid-template-columns: minmax(0, 1fr);
            margin: 0 0 14px;
            min-height: 82px;
            padding: 14px 18px;
            position: sticky;
            top: 14px;
            z-index: 75;
        }

        body.mobile-nav-visible .overview-title {
            align-items: center;
            display: grid;
            gap: 14px;
            grid-template-columns: 54px minmax(0, 1fr);
            min-width: 0;
        }

        body.mobile-nav-visible .overview-logo {
            background: rgba(255,255,255,0.98);
            border: 3px solid rgba(255,255,255,0.95);
            border-radius: 50%;
            display: block;
            height: 54px;
            object-fit: cover;
            padding: 4px;
            width: 54px;
        }

        body.mobile-nav-visible .overview-title h1 {
            color: #fff;
            font-size: clamp(23px, 3vw, 32px);
            font-weight: 900;
            line-height: 1.05;
            margin: 0;
            overflow-wrap: anywhere;
        }

        body.mobile-nav-visible .overview-title p,
        #directoryUserLabel,
        #damageReportsUserLabel {
            display: none;
        }

        body.mobile-nav-visible .app-menu {
            display: none;
        }

        body.mobile-nav-visible .overview-filters {
            background: rgba(255,255,255,0.94);
            border: 1px solid rgba(15,23,42,0.08);
            border-radius: 16px;
            box-shadow: 0 8px 22px rgba(15,23,42,0.08);
            display: grid;
            gap: 12px;
            grid-template-columns: minmax(260px, 1fr) minmax(180px, 0.38fr);
            margin-bottom: 18px;
            padding: 14px;
            position: sticky;
            top: 110px;
            z-index: 74;
        }

        body.mobile-nav-visible.dark-mode .overview-filters {
            background: rgba(30, 36, 44, 0.94);
            border-color: rgba(255,255,255,0.06);
            box-shadow: 0 16px 34px rgba(0,0,0,0.22);
        }

        body.mobile-nav-visible .overview-filters .filter-field {
            display: block;
            position: relative;
        }

        body.mobile-nav-visible .overview-filters .filter-field > i {
            color: #667085;
            display: block;
            font-size: 20px;
            left: 16px;
            pointer-events: none;
            position: absolute;
            top: 50%;
            transform: translateY(-50%);
        }

        body.mobile-nav-visible .overview-filters input {
            background-color: #fff;
            border: 1px solid rgba(15,23,42,0.12);
            border-radius: 10px;
            color: #222;
            font-size: 16px;
            min-height: 48px;
            padding: 10px 14px;
            width: 100%;
        }

        body.mobile-nav-visible .overview-filters .filter-field input {
            padding-left: 46px;
        }

        body.mobile-nav-visible #overviewView .list-grid {
            gap: 12px;
            grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
            margin-bottom: 0;
        }

        body.mobile-nav-visible #overviewView .list-day-heading {
            align-items: center;
            display: grid;
            gap: 10px;
            grid-column: 1 / -1;
            grid-template-columns: auto minmax(0, 1fr) auto;
            margin: 6px 0 0;
            padding: 0;
            position: sticky;
            top: 210px;
            z-index: 60;
        }

        body.mobile-nav-visible #overviewView .list-day-heading i {
            color: var(--primary);
            font-size: 19px;
        }

        body.mobile-nav-visible #overviewView .list-day-heading strong {
            color: #232830;
            font-size: 18px;
            font-weight: 900;
            line-height: 1.15;
        }

        body.mobile-nav-visible.dark-mode #overviewView .list-day-heading strong {
            color: #fff;
        }

        body.mobile-nav-visible #overviewView .list-day-heading span {
            background: rgba(15,23,42,0.08);
            border-radius: 999px;
            color: #232830;
            font-size: 14px;
            font-weight: 800;
            padding: 5px 11px;
            white-space: nowrap;
        }

        body.mobile-nav-visible.dark-mode #overviewView .list-day-heading span {
            background: rgba(255,255,255,0.07);
            color: #fff;
        }

        body.mobile-nav-visible #overviewView .list-card {
            background: #fff;
            border: 1px solid rgba(15,23,42,0.08);
            border-radius: 16px;
            box-shadow: 0 10px 24px rgba(15,23,42,0.10);
            display: grid;
            gap: 12px;
            grid-template-columns: 1fr;
            padding: 18px;
            position: relative;
        }

        body.mobile-nav-visible.dark-mode #overviewView .list-card {
            background:
                radial-gradient(circle at 25% 16%, rgba(255,255,255,0.08), transparent 18%),
                linear-gradient(145deg, rgba(34, 40, 48, 0.95), rgba(22, 27, 34, 0.96));
            border-color: rgba(255,255,255,0.05);
            box-shadow: 0 16px 34px rgba(0,0,0,0.25);
        }

        body.mobile-nav-visible #overviewView .list-card-main {
            display: grid;
            gap: 10px;
            padding-right: 48px;
        }

        body.mobile-nav-visible #overviewView .list-card-head {
            align-items: center;
            display: grid;
            gap: 14px;
            grid-template-columns: 48px minmax(0, 1fr);
        }

        body.mobile-nav-visible #overviewView .list-train-badge {
            align-items: center;
            background: linear-gradient(135deg, #ff5a00, #ff7a00);
            border-radius: 50%;
            color: #fff;
            display: inline-flex;
            height: 48px;
            justify-content: center;
            width: 48px;
        }

        body.mobile-nav-visible #overviewView .list-train-badge i {
            font-size: 19px;
        }

        body.mobile-nav-visible #overviewView .list-card h2 {
            color: #232830;
            font-size: 24px;
            font-weight: 900;
            line-height: 1.05;
            margin-bottom: 4px;
            padding-right: 0;
        }

        body.mobile-nav-visible.dark-mode #overviewView .list-card h2 {
            color: #fff;
        }

        body.mobile-nav-visible #overviewView .list-meta,
        body.mobile-nav-visible #overviewView .list-card-meta-row {
            color: #526173;
            font-size: 15px;
        }

        body.mobile-nav-visible.dark-mode #overviewView .list-meta,
        body.mobile-nav-visible.dark-mode #overviewView .list-card-meta-row {
            color: rgba(255,255,255,0.74);
        }

        body.mobile-nav-visible #overviewView .list-card-meta-row {
            align-items: center;
            display: grid;
            gap: 9px;
            grid-template-columns: 22px minmax(0, 1fr);
            line-height: 1.25;
        }

        body.mobile-nav-visible #overviewView .list-card-meta-row i {
            color: #667085;
            font-size: 17px;
            text-align: center;
        }

        body.mobile-nav-visible.dark-mode #overviewView .list-card-meta-row i {
            color: rgba(255,255,255,0.72);
        }

        body.mobile-nav-visible #overviewView .list-card-actions {
            border-top: 1px solid rgba(15,23,42,0.10);
            display: grid;
            gap: 10px;
            grid-template-columns: minmax(150px, 220px);
            justify-content: center;
            margin-top: 2px;
            padding-top: 14px;
        }

        body.mobile-nav-visible.dark-mode #overviewView .list-card-actions {
            border-top-color: rgba(255,255,255,0.13);
        }

        body.mobile-nav-visible #overviewView .list-card-actions .btn {
            background: #fff;
            border: 1px solid rgba(255,109,0,0.36);
            border-radius: 11px;
            color: var(--primary);
            display: grid;
            gap: 6px;
            height: 50px;
            grid-template-columns: auto auto;
            padding: 8px 12px;
            place-items: center;
            width: 100%;
        }

        body.mobile-nav-visible #overviewView .list-card-actions .btn-danger {
            border-color: rgba(211,47,47,0.38);
            color: #d40000;
        }

        body.mobile-nav-visible #overviewView .list-card-actions .btn i {
            font-size: 17px;
            margin: 0;
        }

        body.mobile-nav-visible #overviewView .list-card-actions .btn span {
            display: block;
            font-size: 14px;
            font-weight: 800;
            line-height: 1.1;
        }

        body.mobile-nav-visible .admin-panel,
        body.mobile-nav-visible .directory-card,
        body.mobile-nav-visible .damage-report-card,
        body.mobile-nav-visible .empty-overview {
            border-radius: 18px;
            box-shadow: 0 14px 34px rgba(15,23,42,0.08);
        }

        body.mobile-nav-visible.dark-mode .admin-panel,
        body.mobile-nav-visible.dark-mode .directory-card,
        body.mobile-nav-visible.dark-mode .damage-report-card,
        body.mobile-nav-visible.dark-mode .empty-overview {
            box-shadow: 0 16px 34px rgba(0,0,0,0.22);
        }

        body.mobile-nav-visible .mobile-bottom-nav {
            align-items: center;
            background: rgba(255,255,255,0.96);
            border: 1px solid rgba(15,23,42,0.08);
            border-radius: 18px;
            bottom: 14px;
            box-shadow: 0 -6px 18px rgba(15,23,42,0.12);
            display: grid;
            gap: 4px;
            grid-template-columns: repeat(auto-fit, minmax(74px, 1fr));
            left: 20px;
            padding: 8px 10px 10px;
            position: fixed;
            right: 20px;
            transform: none;
            width: auto;
            z-index: 90;
        }

        body.mobile-nav-visible.dark-mode .mobile-bottom-nav {
            background: rgba(27, 33, 41, 0.96);
            border-color: rgba(255,255,255,0.05);
            box-shadow: 0 -8px 24px rgba(0,0,0,0.28);
        }

        body.mobile-nav-visible .mobile-bottom-nav button {
            align-items: center;
            background: transparent;
            border: 0;
            color: #303846;
            cursor: pointer;
            display: grid;
            font-size: 12px;
            font-weight: 800;
            gap: 5px;
            justify-items: center;
            min-width: 0;
            padding: 6px 5px;
            position: relative;
        }

        body.mobile-nav-visible.dark-mode .mobile-bottom-nav button {
            color: #fff;
        }

        body.mobile-nav-visible .mobile-bottom-nav i {
            font-size: 21px;
        }

        body.mobile-nav-visible .mobile-bottom-nav .is-active,
        body.mobile-nav-visible .mobile-bottom-nav button:hover {
            color: var(--primary);
        }

        body.mobile-nav-visible .mobile-bottom-nav .is-active::after {
            background: var(--primary);
            border-radius: 999px;
            content: "";
            display: block;
            height: 4px;
            left: 50%;
            position: absolute;
            top: -8px;
            transform: translateX(-50%);
            width: min(56px, 64%);
        }

        body.mobile-nav-visible .desktop-bottom-status {
            align-items: center;
            align-self: stretch;
            background: rgba(15,23,42,0.05);
            border: 1px solid rgba(15,23,42,0.08);
            border-radius: 12px;
            display: grid;
            gap: 6px;
            grid-column: span 2;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            min-width: 180px;
            padding: 6px 8px;
        }

        body.mobile-nav-visible.dark-mode .desktop-bottom-status {
            background: rgba(255,255,255,0.05);
            border-color: rgba(255,255,255,0.08);
        }

        body.mobile-nav-visible .desktop-bottom-status-row {
            align-items: center;
            display: grid;
            gap: 5px;
            grid-template-columns: 20px minmax(0, 1fr);
            min-width: 0;
        }

        body.mobile-nav-visible .desktop-bottom-status-row i {
            color: var(--primary);
            font-size: 18px;
            text-align: center;
        }

        body.mobile-nav-visible .desktop-bottom-status-row .mobile-connection-icon {
            color: #1fa447;
        }

        body.mobile-nav-visible .desktop-bottom-status-row .mobile-connection-icon.is-offline {
            color: #d32f2f;
        }

        body.mobile-nav-visible .desktop-bottom-status-row strong,
        body.mobile-nav-visible .desktop-bottom-status-row span {
            display: block;
            line-height: 1.15;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }

        body.mobile-nav-visible .desktop-bottom-status-row strong {
            font-size: 12px;
        }

        body.mobile-nav-visible .desktop-bottom-status-row span {
            color: #667085;
            font-size: 10px;
        }

        body.mobile-nav-visible.dark-mode .desktop-bottom-status-row span {
            color: rgba(255,255,255,0.68);
        }

        body.mobile-nav-visible .fab-button:not(.wagon-fab-button) {
            bottom: 108px;
            height: 64px;
            right: 56px;
            width: 64px;
        }

        body.mobile-nav-visible .mobile-more-menu {
            background: rgba(255,255,255,0.98);
            border: 1px solid rgba(15,23,42,0.08);
            color: #303846;
        }

        body.mobile-nav-visible.dark-mode .mobile-more-menu {
            background: rgba(27, 33, 41, 0.98);
            border-color: rgba(255,255,255,0.08);
            color: #fff;
        }

        body.mobile-nav-visible:not(.dark-mode) .mobile-more-menu button,
        body.mobile-nav-visible:not(.dark-mode) .mobile-sync-status {
            background: rgba(15,23,42,0.04);
            border-color: rgba(15,23,42,0.08);
            color: #303846;
        }

        body.mobile-nav-visible:not(.dark-mode) .mobile-sync-status-row span {
            color: #667085;
        }

        @media (min-width: 761px) {
            body.mobile-nav-visible #mobileMoreBtn,
            body.mobile-nav-visible .mobile-more-menu {
                display: none !important;
            }

            body.mobile-nav-visible .overview-topbar {
                border-radius: 14px;
                min-height: 68px;
                padding: 10px 14px;
                top: 14px;
            }

            body.mobile-nav-visible .overview-title {
                gap: 10px;
                grid-template-columns: 44px minmax(0, 1fr);
            }

            body.mobile-nav-visible .overview-logo {
                height: 44px;
                width: 44px;
            }

            body.mobile-nav-visible .overview-title h1 {
                font-size: clamp(21px, 1.7vw, 28px);
            }

            body.mobile-nav-visible .overview-filters {
                border-radius: 13px;
                gap: 10px;
                padding: 10px;
                top: 96px;
            }

            body.mobile-nav-visible .overview-filters input {
                font-size: 14px;
                min-height: 42px;
            }

            body.mobile-nav-visible #overviewView .list-day-heading {
                top: 166px;
            }

            body.mobile-nav-visible #overviewView .list-card {
                border-radius: 14px;
                gap: 10px;
                padding: 14px;
            }

            body.mobile-nav-visible #overviewView .list-card-main {
                gap: 8px;
            }

            body.mobile-nav-visible #overviewView .list-card-head {
                gap: 10px;
                grid-template-columns: 40px minmax(0, 1fr);
            }

            body.mobile-nav-visible #overviewView .list-train-badge {
                height: 40px;
                width: 40px;
            }

            body.mobile-nav-visible #overviewView .list-card h2 {
                font-size: 22px;
            }

            body.mobile-nav-visible #overviewView .list-meta,
            body.mobile-nav-visible #overviewView .list-card-meta-row {
                font-size: 14px;
            }

            body.mobile-nav-visible #overviewView .list-card-actions .btn {
                height: 44px;
            }
        }

        @media (max-width: 760px) {
            body.mobile-nav-visible {
                padding: 0 0 130px;
            }

            body.mobile-nav-visible .overview-view,
            body.mobile-nav-visible .admin-view {
                padding: 14px 14px 136px;
            }

            body.mobile-nav-visible .overview-topbar {
                border-radius: 22px;
                min-height: 108px;
                padding: 17px 18px;
                position: relative;
                top: auto;
            }

            body.mobile-nav-visible .overview-title {
                gap: 13px;
                grid-template-columns: 58px minmax(0, 1fr);
            }

            body.mobile-nav-visible .overview-logo {
                height: 58px;
                width: 58px;
            }

            body.mobile-nav-visible .overview-title h1 {
                font-size: clamp(24px, 7vw, 34px);
            }

            body.mobile-nav-visible .overview-filters {
                border-radius: 20px;
                grid-template-columns: 1fr;
                padding: 14px;
                position: relative;
                top: auto;
            }

            body.mobile-nav-visible .overview-filters input {
                font-size: 18px;
                min-height: 58px;
            }

            body.mobile-nav-visible #overviewView .list-day-heading {
                margin-inline: 0;
                position: relative;
                top: auto;
            }

            body.mobile-nav-visible #overviewView .list-grid {
                grid-template-columns: 1fr;
            }

            body.mobile-nav-visible #overviewView .list-day-heading strong {
                font-size: 19px;
            }

            body.mobile-nav-visible #overviewView .list-day-heading span {
                font-size: 14px;
                padding: 6px 10px;
            }

            body.mobile-nav-visible #overviewView .list-card {
                border-radius: 20px;
                padding: 22px 18px;
            }

            body.mobile-nav-visible #overviewView .list-card-head {
                gap: 14px;
                grid-template-columns: 56px minmax(0, 1fr);
            }

            body.mobile-nav-visible #overviewView .list-train-badge {
                height: 56px;
                width: 56px;
            }

            body.mobile-nav-visible #overviewView .list-card h2 {
                font-size: 27px;
            }

            body.mobile-nav-visible #overviewView .list-meta,
            body.mobile-nav-visible #overviewView .list-card-meta-row {
                font-size: 17px;
            }

            body.mobile-nav-visible #overviewView .list-card-meta-row {
                grid-template-columns: 26px minmax(0, 1fr);
            }

            body.mobile-nav-visible #overviewView .list-card-actions {
                gap: 8px;
                grid-template-columns: 1fr;
                padding-top: 18px;
            }

            body.mobile-nav-visible #overviewView .list-card-actions .btn {
                height: 74px;
                grid-template-columns: auto auto;
            }

            body.mobile-nav-visible #overviewView .list-card-actions .btn i {
                font-size: 24px;
            }

            body.mobile-nav-visible #overviewView .list-card-actions .btn span {
                font-size: 12px;
            }

            body.mobile-nav-visible .mobile-bottom-nav {
                grid-template-columns: repeat(4, 1fr);
                left: 14px;
                right: 14px;
                transform: none;
                width: auto;
            }

            body.mobile-nav-visible .mobile-bottom-nav .admin-menu-item,
            body.mobile-nav-visible .mobile-bottom-nav .superadmin-menu-item,
            body.mobile-nav-visible .mobile-bottom-nav .desktop-bottom-action,
            body.mobile-nav-visible .mobile-bottom-nav .desktop-bottom-status {
                display: none !important;
            }

            body.mobile-nav-visible .mobile-bottom-nav button {
                font-size: 11px;
            }

            body.mobile-nav-visible .mobile-bottom-nav i {
                font-size: 24px;
            }

            body.mobile-nav-visible .fab-button:not(.wagon-fab-button) {
                bottom: 128px;
                height: 74px;
                right: 30px;
                width: 74px;
            }
        }
