.fahrer-app{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background:var(--bg-page);font-family:var(--font-sans);color:var(--text-primary);line-height:var(--leading-normal)}.fahrer-header{position:sticky;top:0;background:linear-gradient(135deg,var(--color-primary-700) 0%,var(--color-primary-900) 100%);color:var(--text-inverse);padding:var(--space-3) var(--space-4);padding-top:calc(var(--space-3) + var(--safe-area-top));z-index:var(--z-sticky);box-shadow:var(--shadow-lg)}.header-content{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4)}.header-title{font-size:var(--text-lg);font-weight:var(--font-semibold);letter-spacing:var(--tracking-tight);margin:0}.header-user{display:flex;align-items:center;gap:var(--space-3)}.user-avatar{width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-inverse);background:#fff3}.logout-btn{background:#ffffff26;border:none;border-radius:var(--radius-md);padding:var(--space-2);color:var(--text-inverse);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast);-webkit-tap-highlight-color:transparent}.logout-btn:hover{background:#ffffff40}.logout-btn:active{background:#ffffff59;transform:scale(.95)}.fahrer-main{flex:1;padding:var(--space-4);padding-bottom:calc(80px + var(--safe-area-bottom));overflow-y:auto;-webkit-overflow-scrolling:touch}.fahrer-navbar{position:fixed;bottom:0;left:0;right:0;background:var(--bg-card);display:flex;justify-content:space-around;padding:var(--space-2) var(--space-4);padding-bottom:calc(var(--space-2) + var(--safe-area-bottom));border-top:1px solid var(--color-gray-100);box-shadow:0 -4px 12px #00000014;z-index:var(--z-fixed)}.nav-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);min-width:64px;color:var(--color-gray-500);text-decoration:none;font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-lg);transition:var(--transition-fast);-webkit-tap-highlight-color:transparent}.nav-item:hover{color:var(--color-gray-700);background:var(--color-gray-50)}.nav-item.active{color:var(--color-primary-600);background:var(--color-primary-50)}.nav-item.active svg{transform:scale(1.1)}.nav-item svg{transition:transform var(--transition-fast)}.login-container{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;justify-content:center;padding:var(--space-6);padding-top:calc(var(--space-6) + var(--safe-area-top));padding-bottom:calc(var(--space-6) + var(--safe-area-bottom));background:linear-gradient(135deg,var(--color-primary-700) 0%,var(--color-primary-900) 100%)}.login-header{text-align:center;color:var(--text-inverse);margin-bottom:var(--space-8)}.login-logo{background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:80px;height:80px;border-radius:var(--radius-2xl);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-4);box-shadow:0 8px 32px #0003}.login-header h1{font-size:var(--text-2xl);font-weight:var(--font-bold);margin:0 0 var(--space-1);letter-spacing:var(--tracking-tight)}.login-header p{margin:0;opacity:.85;font-size:var(--text-sm)}.login-form{background:var(--bg-card);border-radius:var(--radius-2xl);padding:var(--space-6);box-shadow:var(--shadow-xl)}.login-error{background:var(--color-danger-50);border:1px solid var(--color-danger-100);color:var(--color-danger-700);padding:var(--space-3);border-radius:var(--radius-lg);margin-bottom:var(--space-4);display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm)}.input-group{position:relative;margin-bottom:var(--space-4)}.input-icon{position:absolute;left:var(--space-4);top:50%;transform:translateY(-50%);color:var(--color-gray-400);pointer-events:none}.input-group input{width:100%;padding:var(--space-4) var(--space-4) var(--space-4) var(--space-12);border:1px solid var(--border-default);border-radius:var(--radius-lg);font-size:var(--text-base);font-family:var(--font-sans);background:var(--color-gray-50);box-sizing:border-box;transition:var(--transition-fast)}.input-group input:hover{border-color:var(--border-hover)}.input-group input:focus{outline:none;border-color:var(--border-focus);box-shadow:var(--focus-ring);background:var(--bg-card)}.input-group input::placeholder{color:var(--text-muted)}.login-button{width:100%;padding:var(--space-4);background:var(--color-primary-500);color:var(--text-inverse);border:none;border-radius:var(--radius-lg);font-size:var(--text-base);font-weight:var(--font-semibold);font-family:var(--font-sans);cursor:pointer;margin-top:var(--space-2);transition:var(--transition-fast);box-shadow:var(--shadow-sm)}.login-button:hover:not(:disabled){background:var(--color-primary-600);box-shadow:var(--shadow-primary);transform:translateY(-1px)}.login-button:active:not(:disabled){background:var(--color-primary-700);transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{text-align:center;color:#fffc;margin-top:var(--space-6);font-size:var(--text-sm)}.login-footer code{display:block;margin-top:var(--space-2);background:#ffffff26;padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:var(--text-xs)}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);background:var(--bg-page);color:var(--text-secondary)}.loading-spinner{width:40px;height:40px;border:3px solid var(--color-gray-200);border-top-color:var(--color-primary-500);border-radius:var(--radius-full);animation:spin .8s linear infinite}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.section-title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.section-subtitle{font-size:var(--text-xs);color:var(--text-secondary);margin-top:var(--space-1)}.trips-group{margin-bottom:var(--space-6)}.trips-group-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:var(--tracking-wider);margin-bottom:var(--space-3);padding-left:var(--space-1)}.trips-empty{text-align:center;padding:var(--space-12) var(--space-6);color:var(--text-secondary)}.trips-empty svg{margin-bottom:var(--space-4);color:var(--color-gray-300)}.trips-empty h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0 0 var(--space-2)}.trips-empty p{margin:0;font-size:var(--text-sm)}.trip-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-3);box-shadow:var(--shadow-sm);border-left:4px solid var(--color-gray-200);cursor:pointer;transition:var(--transition-fast);-webkit-tap-highlight-color:transparent}.trip-card:hover{box-shadow:var(--shadow-md)}.trip-card:active{transform:scale(.98)}.trip-card.status-aktiv{border-left-color:var(--color-success-500);background:linear-gradient(90deg,var(--color-success-50) 0%,var(--bg-card) 15%)}.trip-card.status-bestätigt,.trip-card.status-geplant{border-left-color:var(--color-primary-500);background:linear-gradient(90deg,var(--color-primary-50) 0%,var(--bg-card) 15%)}.trip-card.status-abgeschlossen{border-left-color:var(--color-gray-400);opacity:.75}.trip-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-3)}.trip-time{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);font-family:var(--font-mono);letter-spacing:var(--tracking-tight)}.trip-status{padding:var(--space-1) var(--space-2-5);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:capitalize}.trip-status.geplant{background:var(--color-warning-50);color:var(--color-warning-700)}.trip-status.bestätigt{background:var(--color-primary-100);color:var(--color-primary-700)}.trip-status.aktiv{background:var(--color-success-50);color:var(--color-success-700)}.trip-status.abgeschlossen{background:var(--color-gray-100);color:var(--color-gray-600)}.trip-title{font-weight:var(--font-semibold);margin-bottom:var(--space-3);color:var(--text-primary)}.trip-route{display:flex;flex-direction:column;gap:var(--space-2)}.route-point{display:flex;align-items:flex-start;gap:var(--space-3);font-size:var(--text-sm)}.route-dot{width:12px;height:12px;border-radius:var(--radius-full);margin-top:var(--space-1);flex-shrink:0}.route-dot.start{background:var(--color-success-500)}.route-dot.end{background:var(--color-danger-500)}.route-text{color:var(--text-secondary);line-height:var(--leading-snug)}.trip-meta{display:flex;flex-wrap:wrap;gap:var(--space-4);margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--color-gray-100);font-size:var(--text-xs);color:var(--text-secondary)}.trip-meta span{display:flex;align-items:center;gap:var(--space-1)}.trip-meta svg{width:14px;height:14px}.trip-detail{display:flex;flex-direction:column;gap:var(--space-4)}.detail-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-sm)}.detail-card h3{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:var(--tracking-wider);margin:0 0 var(--space-3)}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) 0;border-bottom:1px solid var(--color-gray-100)}.detail-row:last-child{border-bottom:none;padding-bottom:0}.detail-row:first-of-type{padding-top:0}.detail-label{color:var(--text-secondary);font-size:var(--text-sm)}.detail-value{font-weight:var(--font-medium);text-align:right;color:var(--text-primary)}.action-buttons{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-2)}.fahrer-app .btn{padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);font-size:var(--text-base);min-height:52px}.fahrer-app .btn-primary{background:var(--color-primary-500);box-shadow:var(--shadow-sm)}.fahrer-app .btn-primary:hover:not(:disabled){background:var(--color-primary-600);box-shadow:var(--shadow-primary)}.fahrer-app .btn-success{background:var(--color-success-500)}.fahrer-app .btn-success:hover:not(:disabled){background:var(--color-success-600);box-shadow:var(--shadow-success)}.fahrer-app .btn-warning{background:var(--color-warning-500);color:var(--text-inverse)}.fahrer-app .btn-warning:hover:not(:disabled){background:var(--color-warning-600);box-shadow:var(--shadow-warning)}.fahrer-app .btn-secondary{background:var(--color-gray-100);color:var(--text-primary);border:1px solid var(--color-gray-200)}.fahrer-app .btn-secondary:hover:not(:disabled){background:var(--color-gray-200)}.fahrer-app .btn-outline{background:transparent;border:2px solid var(--color-gray-200);color:var(--text-primary)}.fahrer-app .btn-outline:hover:not(:disabled){background:var(--color-gray-50);border-color:var(--color-gray-300)}.fahrer-app .btn-danger{background:var(--color-danger-500)}.fahrer-app .btn-danger:hover:not(:disabled){background:var(--color-danger-600);box-shadow:var(--shadow-danger)}.fahrer-app .form-group{margin-bottom:var(--space-4)}.fahrer-app .form-group label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary);margin-bottom:var(--space-2)}.fahrer-app .form-group input,.fahrer-app .form-group textarea{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--border-default);border-radius:var(--radius-lg);font-size:var(--text-base);font-family:var(--font-sans);background:var(--color-gray-50);box-sizing:border-box;transition:var(--transition-fast)}.fahrer-app .form-group input:hover,.fahrer-app .form-group textarea:hover{border-color:var(--border-hover)}.fahrer-app .form-group input:focus,.fahrer-app .form-group textarea:focus{outline:none;border-color:var(--border-focus);box-shadow:var(--focus-ring);background:var(--bg-card)}.fahrer-app .form-group textarea{min-height:100px;resize:vertical}.fahrer-app .form-group select{width:100%;padding:var(--space-3) var(--space-12) var(--space-3) var(--space-4);border:1px solid var(--border-default);border-radius:var(--radius-lg);font-size:var(--text-base);font-family:var(--font-sans);background-color:var(--color-gray-50);box-sizing:border-box;cursor:pointer;transition:var(--transition-fast);appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;background-size:20px}.fahrer-app .form-group select:hover{border-color:var(--border-hover);background-color:var(--bg-card)}.fahrer-app .form-group select:focus{outline:none;border-color:var(--border-focus);box-shadow:var(--focus-ring);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%234f46e5' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}.fahrer-app .form-group select:disabled{opacity:.6;cursor:not-allowed}.select-wrapper{position:relative}.select-wrapper .select-icon{position:absolute;left:var(--space-4);top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;z-index:1}.select-wrapper select{padding-left:var(--space-12)}.photo-capture{border:2px dashed var(--color-gray-300);border-radius:var(--radius-xl);padding:var(--space-8);text-align:center;cursor:pointer;transition:var(--transition-fast);-webkit-tap-highlight-color:transparent}.photo-capture:hover{border-color:var(--color-primary-300);background:var(--color-primary-50)}.photo-capture:active{border-color:var(--color-primary-500);background:var(--color-primary-100)}.photo-capture svg{margin-bottom:var(--space-3);color:var(--text-secondary)}.photo-capture p{margin:0;color:var(--text-secondary);font-size:var(--text-sm)}.photo-capture .photo-hint{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1)}.photo-preview{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2);margin-top:var(--space-4)}.photo-preview-item{position:relative;aspect-ratio:1;border-radius:var(--radius-lg);overflow:hidden}.photo-preview-item img{width:100%;height:100%;object-fit:cover}.photo-remove{position:absolute;top:var(--space-1);right:var(--space-1);width:24px;height:24px;background:var(--color-danger-500);color:var(--text-inverse);border:none;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:var(--text-sm);line-height:1;box-shadow:var(--shadow-md);transition:var(--transition-fast)}.photo-remove:hover{background:var(--color-danger-600);transform:scale(1.1)}.logbook-list{display:flex;flex-direction:column;gap:var(--space-3)}.logbook-entry{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-sm)}.logbook-entry-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-2)}.logbook-date{font-size:var(--text-xs);color:var(--text-secondary);font-family:var(--font-mono)}.logbook-route{font-weight:var(--font-semibold);margin-bottom:var(--space-2);color:var(--text-primary)}.logbook-stats{display:flex;flex-wrap:wrap;gap:var(--space-4);font-size:var(--text-sm);color:var(--text-secondary)}.logbook-stats span{display:flex;align-items:center;gap:var(--space-1)}.damage-report-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-3);box-shadow:var(--shadow-sm)}.damage-severity{display:flex;gap:var(--space-2);margin-bottom:var(--space-4)}.severity-btn{flex:1;padding:var(--space-3);border:2px solid var(--border-default);border-radius:var(--radius-lg);background:var(--bg-card);cursor:pointer;text-align:center;transition:var(--transition-fast);-webkit-tap-highlight-color:transparent}.severity-btn:hover{border-color:var(--border-hover)}.severity-btn.active{border-width:2px}.severity-btn.gering.active{border-color:var(--color-warning-500);background:var(--color-warning-50);color:var(--color-warning-700)}.severity-btn.mittel.active{border-color:var(--color-warning-600);background:var(--color-warning-100);color:var(--color-warning-700)}.severity-btn.schwer.active{border-color:var(--color-danger-500);background:var(--color-danger-50);color:var(--color-danger-700)}.severity-label{font-size:var(--text-sm);font-weight:var(--font-medium);margin-top:var(--space-1)}.severity-icon{font-size:var(--text-xl)}.fahrer-app .alert{padding:var(--space-4);border-radius:var(--radius-lg);margin-bottom:var(--space-4);display:flex;align-items:flex-start;gap:var(--space-3);font-size:var(--text-sm)}.fahrer-app .alert-success{background:var(--color-success-50);color:var(--color-success-700);border:1px solid var(--color-success-100)}.fahrer-app .alert-error{background:var(--color-danger-50);color:var(--color-danger-700);border:1px solid var(--color-danger-100)}.fahrer-app .alert-warning{background:var(--color-warning-50);color:var(--color-warning-700);border:1px solid var(--color-warning-100)}.fahrer-app .alert-info{background:var(--color-info-50);color:var(--color-info-700);border:1px solid var(--color-info-100)}.bottom-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:var(--z-overlay);animation:fadeIn var(--transition-fast)}.bottom-sheet{position:fixed;bottom:0;left:0;right:0;background:var(--bg-card);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;z-index:var(--z-modal);animation:slideUp var(--transition-normal);padding-bottom:var(--safe-area-bottom)}.bottom-sheet-handle{width:36px;height:4px;background:var(--color-gray-300);border-radius:var(--radius-full);margin:var(--space-3) auto}.bottom-sheet-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-gray-100);display:flex;align-items:center;justify-content:space-between}.bottom-sheet-title{font-size:var(--text-lg);font-weight:var(--font-semibold);margin:0}.bottom-sheet-close{padding:var(--space-2);border-radius:var(--radius-md);color:var(--color-gray-400);background:transparent;border:none;cursor:pointer;transition:var(--transition-fast)}.bottom-sheet-close:hover{background:var(--color-gray-100);color:var(--color-gray-600)}.bottom-sheet-body{padding:var(--space-5);overflow-y:auto;flex:1}.bottom-sheet-footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--color-gray-100);display:flex;gap:var(--space-3)}.bottom-sheet-footer .btn{flex:1}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.text-muted{color:var(--text-secondary)}.text-success{color:var(--color-success-600)}.text-danger{color:var(--color-danger-600)}.text-warning{color:var(--color-warning-600)}:root{--color-primary-50: #e0e7ff;--color-primary-100: #c7d2fe;--color-primary-200: #a5b4fc;--color-primary-300: #818cf8;--color-primary-400: #6366f1;--color-primary-500: #4f46e5;--color-primary-600: #4338ca;--color-primary-700: #3730a3;--color-primary-800: #1e1b4b;--color-primary-900: #0f0a3c;--color-success-50: #ecfdf5;--color-success-100: #d1fae5;--color-success-500: #10b981;--color-success-600: #059669;--color-success-700: #047857;--color-warning-50: #fffbeb;--color-warning-100: #fef3c7;--color-warning-500: #f59e0b;--color-warning-600: #d97706;--color-warning-700: #b45309;--color-danger-50: #fef2f2;--color-danger-100: #fee2e2;--color-danger-500: #ef4444;--color-danger-600: #dc2626;--color-danger-700: #b91c1c;--color-info-50: #ecfeff;--color-info-100: #cffafe;--color-info-500: #06b6d4;--color-info-600: #0891b2;--color-info-700: #0e7490;--color-gray-50: #f8fafc;--color-gray-100: #f1f5f9;--color-gray-200: #e2e8f0;--color-gray-300: #cbd5e1;--color-gray-400: #94a3b8;--color-gray-500: #64748b;--color-gray-600: #475569;--color-gray-700: #334155;--color-gray-800: #1e293b;--color-gray-900: #0f172a;--color-white: #ffffff;--color-black: #000000;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", Monaco, Consolas, monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-none: 1;--leading-tight: 1.25;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--tracking-tighter: -.05em;--tracking-tight: -.025em;--tracking-normal: 0;--tracking-wide: .025em;--tracking-wider: .05em;--tracking-widest: .1em;--space-0: 0;--space-px: 1px;--space-0-5: .125rem;--space-1: .25rem;--space-1-5: .375rem;--space-2: .5rem;--space-2-5: .625rem;--space-3: .75rem;--space-3-5: .875rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-7: 1.75rem;--space-8: 2rem;--space-9: 2.25rem;--space-10: 2.5rem;--space-11: 2.75rem;--space-12: 3rem;--space-14: 3.5rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--radius-none: 0;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-3xl: 2rem;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1), 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--shadow-inner: inset 0 2px 4px rgba(0, 0, 0, .05);--shadow-none: none;--shadow-primary: 0 4px 14px rgba(79, 70, 229, .4);--shadow-success: 0 4px 14px rgba(16, 185, 129, .4);--shadow-warning: 0 4px 14px rgba(245, 158, 11, .4);--shadow-danger: 0 4px 14px rgba(239, 68, 68, .4);--z-base: 0;--z-docked: 10;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-overlay: 400;--z-modal: 500;--z-popover: 600;--z-tooltip: 700;--z-toast: 800;--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--transition-colors: color .15s ease, background-color .15s ease, border-color .15s ease;--transition-shadow: box-shadow .15s ease;--transition-transform: transform .15s ease;--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px;--breakpoint-2xl: 1536px;--sidebar-width: 240px;--sidebar-width-collapsed: 60px;--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px);--safe-area-left: env(safe-area-inset-left, 0px);--safe-area-right: env(safe-area-inset-right, 0px);--bg-page: var(--color-gray-50);--bg-card: var(--color-white);--bg-input: var(--color-white);--bg-hover: var(--color-gray-100);--bg-active: var(--color-primary-50);--bg-sidebar: linear-gradient(180deg, var(--color-primary-800) 0%, var(--color-primary-900) 100%);--text-primary: var(--color-gray-800);--text-secondary: var(--color-gray-500);--text-muted: var(--color-gray-400);--text-inverse: var(--color-white);--text-link: var(--color-primary-500);--text-link-hover: var(--color-primary-600);--border-default: var(--color-gray-200);--border-hover: var(--color-gray-300);--border-focus: var(--color-primary-500);--focus-ring: 0 0 0 3px var(--color-primary-100);--focus-ring-offset: 0 0 0 2px var(--color-white)}@media (prefers-color-scheme: dark){:root.dark-mode{--bg-page: var(--color-gray-900);--bg-card: var(--color-gray-800);--text-primary: var(--color-gray-100);--text-secondary: var(--color-gray-400);--border-default: var(--color-gray-700)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2-5) var(--space-4);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--font-medium);line-height:var(--leading-tight);text-decoration:none;border-radius:var(--radius-md);border:none;cursor:pointer;transition:var(--transition-fast);transition-property:color,background-color,border-color,box-shadow,transform;-webkit-tap-highlight-color:transparent}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.btn-primary{background:var(--color-primary-500);color:var(--color-white);box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background:var(--color-primary-600);box-shadow:var(--shadow-primary);transform:translateY(-1px)}.btn-primary:active:not(:disabled){background:var(--color-primary-700);transform:translateY(0)}.btn-secondary{background:var(--color-white);color:var(--color-gray-700);border:1px solid var(--color-gray-200);box-shadow:var(--shadow-xs)}.btn-secondary:hover:not(:disabled){background:var(--color-gray-50);border-color:var(--color-gray-300)}.btn-secondary:active:not(:disabled){background:var(--color-gray-100)}.btn-ghost{background:transparent;color:var(--color-gray-600)}.btn-ghost:hover:not(:disabled){background:var(--color-gray-100);color:var(--color-gray-800)}.btn-danger{background:var(--color-danger-500);color:var(--color-white)}.btn-danger:hover:not(:disabled){background:var(--color-danger-600);box-shadow:var(--shadow-danger)}.btn-success{background:var(--color-success-500);color:var(--color-white)}.btn-success:hover:not(:disabled){background:var(--color-success-600);box-shadow:var(--shadow-success)}.btn-xs{padding:var(--space-1) var(--space-2);font-size:var(--text-xs);gap:var(--space-1)}.btn-sm{padding:var(--space-1-5) var(--space-3);font-size:var(--text-xs)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--text-base)}.btn-xl{padding:var(--space-4) var(--space-8);font-size:var(--text-lg)}.btn-icon{padding:var(--space-2);border-radius:var(--radius-md)}.btn-icon.btn-sm{padding:var(--space-1-5)}.btn-icon.btn-lg{padding:var(--space-3)}.btn-block{width:100%}.card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-gray-100);overflow:hidden}.card-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-gray-100);display:flex;align-items:center;justify-content:space-between;gap:var(--space-4)}.card-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.card-body{padding:var(--space-5)}.card-footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--color-gray-100);background:var(--color-gray-50)}.card-clickable{cursor:pointer;transition:var(--transition-fast);transition-property:transform,box-shadow}.card-clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.card-clickable:active{transform:scale(.98)}.form-group{margin-bottom:var(--space-4)}.form-label{display:block;margin-bottom:var(--space-1-5);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-gray-700)}.form-label-required:after{content:" *";color:var(--color-danger-500)}.input{width:100%;padding:var(--space-2-5) var(--space-3);font-family:var(--font-sans);font-size:var(--text-base);color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--radius-md);transition:var(--transition-fast);transition-property:border-color,box-shadow}.input:hover:not(:disabled):not(:focus){border-color:var(--border-hover)}.input:focus{outline:none;border-color:var(--border-focus);box-shadow:var(--focus-ring)}.input:disabled{background:var(--color-gray-100);color:var(--color-gray-500);cursor:not-allowed}.input::placeholder{color:var(--text-muted)}.input-sm{padding:var(--space-1-5) var(--space-2-5);font-size:var(--text-sm)}.input-lg{padding:var(--space-3) var(--space-4);font-size:var(--text-lg)}.input-error{border-color:var(--color-danger-500)}.input-error:focus{box-shadow:0 0 0 3px var(--color-danger-100)}.input-success{border-color:var(--color-success-500)}textarea.input{min-height:100px;resize:vertical}select.input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:var(--space-10)}.form-helper{margin-top:var(--space-1);font-size:var(--text-xs);color:var(--text-secondary)}.form-error{margin-top:var(--space-1);font-size:var(--text-xs);color:var(--color-danger-500)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2-5);font-size:var(--text-xs);font-weight:var(--font-medium);line-height:var(--leading-tight);border-radius:var(--radius-full);white-space:nowrap}.badge-primary{background:var(--color-primary-100);color:var(--color-primary-700)}.badge-secondary{background:var(--color-gray-100);color:var(--color-gray-700)}.badge-success{background:var(--color-success-50);color:var(--color-success-700)}.badge-warning{background:var(--color-warning-50);color:var(--color-warning-700)}.badge-danger{background:var(--color-danger-50);color:var(--color-danger-700)}.badge-info{background:var(--color-info-50);color:var(--color-info-700)}.badge-sm{padding:var(--space-0-5) var(--space-1-5);font-size:.625rem}.badge-lg{padding:var(--space-1-5) var(--space-3);font-size:var(--text-sm)}.badge-dot:before{content:"";width:6px;height:6px;border-radius:var(--radius-full);background:currentColor}.alert{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm)}.alert-icon{flex-shrink:0;width:20px;height:20px}.alert-content{flex:1}.alert-title{font-weight:var(--font-semibold);margin-bottom:var(--space-1)}.alert-success{background:var(--color-success-50);color:var(--color-success-700);border:1px solid var(--color-success-100)}.alert-warning{background:var(--color-warning-50);color:var(--color-warning-700);border:1px solid var(--color-warning-100)}.alert-danger{background:var(--color-danger-50);color:var(--color-danger-700);border:1px solid var(--color-danger-100)}.alert-info{background:var(--color-info-50);color:var(--color-info-700);border:1px solid var(--color-info-100)}.table-container{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--color-gray-200)}.table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.table th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:var(--tracking-wider);color:var(--color-gray-500);background:var(--color-gray-50);border-bottom:1px solid var(--color-gray-200)}.table td{padding:var(--space-3) var(--space-4);color:var(--text-primary);border-bottom:1px solid var(--color-gray-100);vertical-align:middle}.table tbody tr:hover{background:var(--color-gray-50)}.table tbody tr:last-child td{border-bottom:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:var(--space-4);z-index:var(--z-modal);animation:fadeIn var(--transition-fast) ease}.modal{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:500px;max-height:calc(100vh - var(--space-8));overflow:hidden;display:flex;flex-direction:column;animation:slideUp var(--transition-normal) ease}.modal-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-gray-100);display:flex;align-items:center;justify-content:space-between;gap:var(--space-4)}.modal-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin:0}.modal-close{padding:var(--space-1);border-radius:var(--radius-md);color:var(--color-gray-400);background:transparent;border:none;cursor:pointer;transition:var(--transition-fast)}.modal-close:hover{background:var(--color-gray-100);color:var(--color-gray-600)}.modal-body{padding:var(--space-6);overflow-y:auto;flex:1}.modal-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-gray-100);background:var(--color-gray-50);display:flex;justify-content:flex-end;gap:var(--space-3)}.modal-sm{max-width:400px}.modal-lg{max-width:700px}.modal-xl{max-width:900px}.avatar{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);background:var(--color-primary-100);color:var(--color-primary-700);font-weight:var(--font-semibold);font-size:var(--text-sm);flex-shrink:0}.avatar-sm{width:32px;height:32px;font-size:var(--text-xs)}.avatar-lg{width:48px;height:48px;font-size:var(--text-base)}.avatar-xl{width:64px;height:64px;font-size:var(--text-lg)}.avatar img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-full)}.spinner{width:24px;height:24px;border:2px solid var(--color-gray-200);border-top-color:var(--color-primary-500);border-radius:var(--radius-full);animation:spin .8s linear infinite}.spinner-sm{width:16px;height:16px;border-width:2px}.spinner-lg{width:40px;height:40px;border-width:3px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-6);text-align:center}.empty-state-icon{width:64px;height:64px;color:var(--color-gray-300);margin-bottom:var(--space-4)}.empty-state-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-2)}.empty-state-description{font-size:var(--text-sm);color:var(--text-secondary);max-width:300px}@keyframes slideDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.flex-wrap{flex-wrap:wrap}.items-end{align-items:flex-end}.justify-center{justify-content:center}.flex-1{flex:1}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.m-0{margin:0}.p-0{padding:0}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.text-base{font-size:var(--text-base)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-center{text-align:center}.text-primary{color:var(--text-primary)}.text-muted{color:var(--text-muted)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-sans);background:var(--bg-page);color:var(--text-primary);line-height:var(--leading-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-container{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);color:var(--text-inverse);position:fixed;height:100vh;overflow-y:auto;z-index:var(--z-fixed)}.sidebar-header{padding:var(--space-5);border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-header h1{font-size:var(--text-xl);font-weight:var(--font-bold);display:flex;align-items:center;gap:var(--space-2);letter-spacing:var(--tracking-tight)}.sidebar-header span{font-size:var(--text-xs);background:var(--color-primary-500);padding:var(--space-0-5) var(--space-2);border-radius:var(--radius-sm);margin-left:auto;font-weight:var(--font-medium)}.sidebar-tenant{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--color-gray-400);margin-top:var(--space-2);padding:var(--space-2) var(--space-3);background:#ffffff0d;border-radius:var(--radius-sm)}.sidebar-tenant svg{width:14px;height:14px;flex-shrink:0;opacity:.7}.sidebar-tenant.super-admin{background:#f59e0b33;color:var(--color-warning-300)}.sidebar-nav{padding:var(--space-4) 0}.nav-section{margin-bottom:var(--space-2)}.nav-section-title{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wider);color:var(--color-gray-500);padding:var(--space-2) var(--space-5);font-weight:var(--font-semibold)}.nav-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);color:var(--color-gray-400);text-decoration:none;font-size:var(--text-sm);font-weight:var(--font-medium);transition:var(--transition-fast);border-left:3px solid transparent}.nav-link:hover{background:#ffffff0d;color:var(--text-inverse)}.nav-link.active{background:#4f46e540;color:var(--text-inverse);border-left-color:var(--color-primary-400)}.nav-link svg{width:20px;height:20px;flex-shrink:0}.sidebar-footer{position:absolute;bottom:0;left:0;right:0;padding:var(--space-4) var(--space-5);border-top:1px solid rgba(255,255,255,.1);background:#0003}.fahrer-link{display:flex;align-items:center;gap:var(--space-2);color:var(--color-gray-400);text-decoration:none;font-size:var(--text-sm);padding:var(--space-2-5) var(--space-3);border-radius:var(--radius-md);background:#ffffff0d;transition:var(--transition-fast)}.fahrer-link:hover{background:#4f46e54d;color:var(--text-inverse)}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh}.page-header{background:var(--bg-card);padding:var(--space-5) var(--space-8);border-bottom:1px solid var(--border-default);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:var(--z-sticky)}.page-header h2{font-size:var(--text-2xl);font-weight:var(--font-semibold);letter-spacing:var(--tracking-tight)}.page-content{padding:var(--space-6) var(--space-8)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-5);margin-bottom:var(--space-6)}.stat-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm);display:flex;align-items:flex-start;gap:var(--space-4);border:1px solid var(--color-gray-100);transition:var(--transition-fast)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.blue{background:var(--color-primary-100);color:var(--color-primary-600)}.stat-icon.green{background:var(--color-success-100);color:var(--color-success-600)}.stat-icon.orange{background:var(--color-warning-100);color:var(--color-warning-600)}.stat-icon.purple{background:#ede9fe;color:#7c3aed}.stat-content h4{font-size:var(--text-xs);color:var(--text-secondary);font-weight:var(--font-medium);text-transform:uppercase;letter-spacing:var(--tracking-wide);margin-bottom:var(--space-1)}.stat-content .value{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--text-primary);letter-spacing:var(--tracking-tight);font-family:var(--font-mono)}.stat-content .subtitle{font-size:var(--text-xs);color:var(--text-secondary);margin-top:var(--space-1)}.table-container{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border-default)}table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}th,td{padding:var(--space-3) var(--space-4);text-align:left;border-bottom:1px solid var(--color-gray-100)}th{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wider);color:var(--text-secondary);font-weight:var(--font-semibold);background:var(--color-gray-50)}td{color:var(--text-primary);vertical-align:middle}tr:hover{background:var(--color-gray-50)}tbody tr:last-child td{border-bottom:none}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-6)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}@media (max-width: 1200px){.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.grid-2,.grid-3{grid-template-columns:1fr}.sidebar{width:var(--sidebar-width-collapsed)}.sidebar-header h1 span,.nav-section-title,.nav-link span{display:none}.main-content{margin-left:var(--sidebar-width-collapsed)}.page-header,.page-content{padding:var(--space-4) var(--space-5)}}.map-container{height:500px;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-default)}.map-container .leaflet-container{height:100%;width:100%}.vehicle-marker{background:var(--bg-card);border-radius:var(--radius-full);width:36px;height:36px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);border:3px solid var(--color-primary-500);font-size:16px}.vehicle-marker.active{border-color:var(--color-success-500);animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 #10b98166}70%{box-shadow:0 0 0 10px #10b98100}to{box-shadow:0 0 #10b98100}}.form-control{width:100%;padding:var(--space-2-5) var(--space-3);border:1px solid var(--border-default);border-radius:var(--radius-md);font-size:var(--text-sm);font-family:var(--font-sans);transition:var(--transition-fast);background:var(--bg-card)}.form-control:hover{border-color:var(--border-hover)}.form-control:focus{outline:none;border-color:var(--border-focus);box-shadow:var(--focus-ring)}select.form-control{cursor:pointer;padding-right:var(--space-10);appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;background-size:18px;background-color:var(--bg-card)}select.form-control:hover{border-color:var(--border-hover);background-color:var(--color-gray-50)}select.form-control:focus{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%234f46e5' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}select.form-control:disabled{opacity:.6;cursor:not-allowed;background-color:var(--color-gray-100)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);animation:fadeIn var(--transition-fast)}.modal{background:var(--bg-card);border-radius:var(--radius-xl);width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:slideUp var(--transition-normal)}.modal-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-default);display:flex;justify-content:space-between;align-items:center}.modal-header h3{font-size:var(--text-xl);font-weight:var(--font-semibold)}.modal-body{padding:var(--space-6)}.modal-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-default);display:flex;justify-content:flex-end;gap:var(--space-3);background:var(--color-gray-50)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.avatar{width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--text-inverse);font-weight:var(--font-semibold);font-size:var(--text-sm);flex-shrink:0}.vehicle-list{max-height:300px;overflow-y:auto}.vehicle-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-default);cursor:pointer;transition:var(--transition-fast)}.vehicle-item:hover{background:var(--color-gray-50)}.vehicle-item .icon{font-size:var(--text-2xl)}.vehicle-item .info h4{font-size:var(--text-sm);font-weight:var(--font-semibold)}.vehicle-item .info p{font-size:var(--text-xs);color:var(--text-secondary)}.vehicle-item .speed{margin-left:auto;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-secondary);font-family:var(--font-mono)}.dispo-board{display:grid;grid-template-columns:200px 1fr;gap:1px;background:var(--border-default);border-radius:var(--radius-md);overflow:hidden}.dispo-timeline{display:flex}.time-slot{min-width:60px;text-align:center;padding:var(--space-2);font-size:var(--text-xs);font-family:var(--font-mono);color:var(--text-secondary);border-left:1px solid var(--border-default)}.dispo-row{display:contents}.dispo-vehicle{background:var(--bg-card);padding:var(--space-3);font-weight:var(--font-medium);font-size:var(--text-sm);display:flex;align-items:center;gap:var(--space-2)}.dispo-slots{display:flex;background:var(--bg-card);position:relative;min-height:50px}.booking-block{position:absolute;top:var(--space-1);bottom:var(--space-1);background:var(--color-primary-500);color:var(--text-inverse);border-radius:var(--radius-md);padding:var(--space-1) var(--space-2);font-size:var(--text-xs);font-weight:var(--font-medium);overflow:hidden;cursor:pointer;transition:var(--transition-fast);box-shadow:var(--shadow-sm)}.booking-block:hover{transform:scale(1.02);z-index:10;box-shadow:var(--shadow-md)}.booking-block.confirmed{background:var(--color-success-500)}.booking-block.planned{background:var(--color-warning-500)}.booking-block.active{background:var(--color-info-500)}.empty-state{text-align:center;padding:var(--space-12) var(--space-6);color:var(--text-secondary)}.empty-state svg{width:64px;height:64px;margin-bottom:var(--space-4);color:var(--color-gray-300)}.empty-state h3{font-size:var(--text-lg);font-weight:var(--font-semibold);margin-bottom:var(--space-2);color:var(--text-primary)}.empty-state p{font-size:var(--text-sm);max-width:300px;margin:0 auto}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-lg{font-size:var(--text-lg)}.text-secondary{color:var(--text-secondary)}.font-medium{font-weight:var(--font-medium)}.font-semibold{font-weight:var(--font-semibold)}.font-bold{font-weight:var(--font-bold)}.font-mono{font-family:var(--font-mono)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary-600) 0%,var(--color-primary-800) 100%);padding:var(--space-4)}.login-card{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:400px;overflow:hidden}.login-header{text-align:center;padding:var(--space-8) var(--space-6) var(--space-6);background:var(--color-gray-50);border-bottom:1px solid var(--border-default)}.login-header .login-icon{color:var(--color-primary-500);margin-bottom:var(--space-3)}.login-header h1{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);letter-spacing:var(--tracking-tight);margin-bottom:var(--space-1)}.login-header p{font-size:var(--text-sm);color:var(--text-secondary)}.login-form{padding:var(--space-6)}.login-form .form-group{margin-bottom:var(--space-4)}.login-form label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);margin-bottom:var(--space-1-5)}.login-form input{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-base);border:1px solid var(--border-default);border-radius:var(--radius-md);background:var(--bg-card);transition:var(--transition-fast)}.login-form input:focus{outline:none;border-color:var(--border-focus);box-shadow:var(--focus-ring)}.login-form input::placeholder{color:var(--text-muted)}.login-btn{width:100%;padding:var(--space-3) var(--space-4);margin-top:var(--space-2)}.login-error{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--color-danger-50);color:var(--color-danger-600);border-radius:var(--radius-md);font-size:var(--text-sm);margin-bottom:var(--space-4)}.login-footer{text-align:center;padding:var(--space-4) var(--space-6);background:var(--color-gray-50);border-top:1px solid var(--border-default)}.login-footer a{color:var(--color-primary-600);text-decoration:none;font-size:var(--text-sm);font-weight:var(--font-medium)}.login-footer a:hover{text-decoration:underline}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-page);color:var(--text-secondary)}.loading-screen .loading-icon{color:var(--color-primary-500);margin-bottom:var(--space-4);animation:pulse 1.5s ease-in-out infinite}.loading-screen p{font-size:var(--text-lg);font-weight:var(--font-medium)}.user-info{display:flex;align-items:center;gap:var(--space-2);color:var(--color-gray-400);font-size:var(--text-sm);margin-bottom:var(--space-3);overflow:hidden}.user-info span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-2-5) var(--space-3);background:#ffffff1a;color:var(--color-gray-300);border:none;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:var(--transition-fast)}.logout-btn:hover{background:#ef44444d;color:var(--color-danger-300)}
