@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--color-primary: hsl(215, 85%, 55%);--color-primary-hover: hsl(215, 85%, 48%);--color-primary-light: hsl(215, 85%, 92%);--color-secondary: hsl(280, 70%, 60%);--color-secondary-hover: hsl(280, 70%, 53%);--color-success: hsl(142, 71%, 45%);--color-warning: hsl(38, 92%, 50%);--color-danger: hsl(0, 72%, 51%);--color-background: hsl(220, 20%, 98%);--color-surface: hsl(0, 0%, 100%);--color-surface-hover: hsl(220, 20%, 96%);--color-text: hsl(220, 20%, 15%);--color-text-secondary: hsl(220, 15%, 45%);--color-text-tertiary: hsl(220, 10%, 65%);--color-border: hsl(220, 15%, 88%);--color-border-light: hsl(220, 10%, 93%);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.5rem;--font-size-2xl: 2rem;--font-weight-light: 300;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .35s ease}@media(prefers-color-scheme:dark){:root{--color-primary: hsl(215, 85%, 60%);--color-primary-hover: hsl(215, 85%, 68%);--color-primary-light: hsl(215, 50%, 20%);--color-secondary: hsl(280, 70%, 65%);--color-secondary-hover: hsl(280, 70%, 73%);--color-success: hsl(142, 71%, 50%);--color-warning: hsl(38, 92%, 55%);--color-danger: hsl(0, 72%, 58%);--color-background: hsl(220, 20%, 12%);--color-surface: hsl(220, 18%, 18%);--color-surface-hover: hsl(220, 18%, 22%);--color-text: hsl(220, 20%, 95%);--color-text-secondary: hsl(220, 15%, 70%);--color-text-tertiary: hsl(220, 10%, 50%);--color-border: hsl(220, 15%, 28%);--color-border-light: hsl(220, 10%, 22%)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font-family);font-size:var(--font-size-md);font-weight:var(--font-weight-normal);line-height:1.5;color:var(--color-text);background-color:var(--color-background);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:1.2;margin-bottom:var(--spacing-md)}h1{font-size:var(--font-size-2xl)}h2{font-size:var(--font-size-xl)}h3{font-size:var(--font-size-lg)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}button{font-family:inherit;cursor:pointer;border:none;background:none}input,select,textarea{font-family:inherit;font-size:inherit}*:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}.card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.grid{display:grid;gap:var(--spacing-lg)}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-lg{gap:var(--spacing-lg)}.text-sm{font-size:var(--font-size-sm)}.text-md{font-size:var(--font-size-md)}.text-lg{font-size:var(--font-size-lg)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-lg{margin-bottom:var(--spacing-lg)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.spinner{border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:1.5rem;height:1.5rem;animation:spin .6s linear infinite}.fade-in{animation:fadeIn .3s ease}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-background)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);font-weight:var(--font-weight-medium);text-align:center;white-space:nowrap;border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:pointer;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm)}.btn-md{padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-md)}.btn-lg{padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-lg)}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--color-primary)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){opacity:.9;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--color-surface-hover);color:var(--color-text)}.vehicle-selector{position:relative;margin-right:var(--spacing-md)}.vehicle-selector-btn{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text);cursor:pointer;transition:all var(--transition-fast);min-width:200px;justify-content:space-between}.vehicle-selector-btn:hover{border-color:var(--color-primary);background:var(--color-surface-hover)}.vehicle-reg{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:var(--font-weight-bold);font-family:monospace;font-size:.95rem;letter-spacing:.5px}.vehicle-odo{font-weight:var(--font-weight-normal);font-size:.8rem;color:var(--color-text-secondary);padding-left:var(--spacing-xs);border-left:1px solid var(--color-border)}.chevron{transition:transform var(--transition-fast);color:var(--color-text-secondary)}.chevron.open{transform:rotate(180deg)}.vehicle-dropdown{position:absolute;top:120%;right:0;width:240px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;z-index:1000;overflow:hidden;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.vehicle-list{max-height:300px;overflow-y:auto}.vehicle-option{padding:var(--spacing-md);cursor:pointer;transition:background var(--transition-fast);display:flex;flex-direction:column;border-bottom:1px solid var(--color-border-light)}.vehicle-option:last-child{border-bottom:none}.vehicle-option:hover{background:var(--color-surface-hover)}.vehicle-option.active{background:var(--color-primary-light);border-left:3px solid var(--color-primary)}.vehicle-option-reg{font-weight:var(--font-weight-bold);color:var(--color-text);font-family:monospace}.vehicle-option-name{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.vehicle-actions{padding:var(--spacing-sm);background:#00000005;border-top:1px solid var(--color-border)}.manage-vehicle-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);width:100%;padding:var(--spacing-sm);background:#3b82f61a;border:1px solid transparent;border-radius:var(--radius-md);color:var(--color-primary);cursor:pointer;transition:all var(--transition-fast);font-size:var(--font-size-sm);font-weight:500;margin-bottom:var(--spacing-xs)}.manage-vehicle-btn:hover{background:#3b82f633}.add-vehicle-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);width:100%;padding:var(--spacing-sm);background:none;border:1px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:var(--font-size-sm)}.add-vehicle-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.create-vehicle-form{padding:var(--spacing-xs)}.vehicle-input{width:100%;padding:var(--spacing-sm);background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-family:monospace}.vehicle-input:focus{outline:none;border-color:var(--color-primary)}@media(max-width:768px){.vehicle-selector-btn{min-width:auto;padding:var(--spacing-sm)}.vehicle-reg,.chevron{display:none}.vehicle-dropdown{right:-50px}}.navigation{position:fixed;top:0;left:0;right:0;z-index:100;background:var(--color-surface);border-bottom:1px solid var(--color-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6}@media(prefers-color-scheme:dark){.navigation{background:#20232ae6}}.nav-container{max-width:1400px;margin:0 auto;padding:0 var(--spacing-lg);height:60px;display:flex;align-items:center;justify-content:space-between}.flex-center{display:flex;align-items:center}.gap-md{gap:var(--spacing-md)}.nav-brand{display:flex;align-items:center;gap:var(--spacing-md);text-decoration:none;color:var(--color-text)}.nav-logo{width:36px;height:36px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:#fff}.nav-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text)}.nav-links{display:flex;gap:var(--spacing-sm)}.nav-link{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-decoration:none;transition:all var(--transition-fast)}.nav-link:hover{background:var(--color-surface-hover);color:var(--color-text)}.nav-link-active{background:var(--color-primary-light);color:var(--color-primary)}.nav-user{display:flex;align-items:center;gap:var(--spacing-sm);margin-left:var(--spacing-md);padding-left:var(--spacing-md);border-left:1px solid var(--color-border)}.user-email{font-size:.8rem;color:var(--color-text-secondary);max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sign-out-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;color:var(--color-text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.sign-out-btn:hover{background:#ef44441a;color:#ef4444}@media(max-width:768px){.nav-links{gap:0}.nav-link span{display:none}.nav-link{padding:var(--spacing-sm)}.nav-title{font-size:var(--font-size-md)}.user-email{display:none}.nav-user{margin-left:var(--spacing-sm);padding-left:var(--spacing-sm)}}.card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}.card-glass{background:#ffffffb3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);box-shadow:var(--shadow-md)}@media(prefers-color-scheme:dark){.card-glass{background:#20232ab3;border-color:#ffffff1a}}.card-hoverable{transition:all var(--transition-base);cursor:pointer}.card-hoverable:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.dashboard{max-width:1200px;margin:0 auto;padding:var(--spacing-xl);display:flex;flex-direction:column;gap:var(--spacing-xl)}.dashboard-loading{display:flex;justify-content:center;align-items:center;min-height:400px}.dashboard-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--spacing-lg)}.dashboard-header h1{margin-bottom:var(--spacing-xs)}.projection-card{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:#fff;padding:var(--spacing-xl)}.projection-header{display:flex;flex-direction:column;gap:var(--spacing-lg)}.projection-header h2{color:#fff;margin:0;font-size:var(--font-size-lg)}.projection-main{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-lg);flex-wrap:wrap;text-align:left}.projection-value{font-size:3rem;font-weight:var(--font-weight-bold);line-height:1;margin-bottom:var(--spacing-sm)}.projection-unit{font-size:var(--font-size-lg);font-weight:var(--font-weight-normal);opacity:.9;margin-left:var(--spacing-sm)}.projection-breakdown{display:flex;gap:var(--spacing-xl)}.projection-breakdown div{display:flex;flex-direction:column;font-size:.95rem}.projection-breakdown strong{font-size:1.4rem}.recommendation{margin-top:var(--spacing-xl);padding-top:var(--spacing-xl);border-top:1px solid rgba(255,255,255,.2);text-align:center}.recommendation-label{font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.05em;opacity:.8;margin-bottom:var(--spacing-xs)}.recommendation-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-xs)}.recommendation-note{font-size:var(--font-size-sm);color:#ffffffb3!important}.lease-limits{display:flex;flex-direction:column;gap:var(--spacing-md)}.lease-limit-item{display:grid;grid-template-columns:120px 1fr 150px;align-items:center;gap:var(--spacing-md)}.lease-limit-value{font-weight:var(--font-weight-medium);color:var(--color-text)}.lease-limit-bar{height:8px;background:var(--color-border-light);border-radius:var(--radius-full);overflow:hidden}.lease-limit-fill{height:100%;background:var(--color-primary);transition:width var(--transition-slow);border-radius:var(--radius-full)}.lease-limit-item.over .lease-limit-fill{background:var(--color-danger)}.lease-limit-percentage{text-align:right;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-lg)}.stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary);margin-bottom:var(--spacing-xs)}.stat-label{font-size:var(--font-size-sm)}.upcoming-trips{display:flex;flex-direction:column;gap:var(--spacing-sm)}.trip-item{display:grid;grid-template-columns:60px 1fr auto;gap:var(--spacing-md);padding:var(--spacing-md);border:1px solid var(--color-border-light);border-radius:var(--radius-md);transition:all var(--transition-fast)}.trip-item:hover{border-color:var(--color-primary);background:var(--color-surface-hover)}.trip-date{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-sm);background:var(--color-primary-light);border-radius:var(--radius-md)}.trip-date-day{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-primary);line-height:1}.trip-date-month{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-primary);text-transform:uppercase}.trip-details{display:flex;flex-direction:column;gap:var(--spacing-xs)}.trip-route{font-weight:var(--font-weight-medium);color:var(--color-text)}.trip-meta{font-size:var(--font-size-sm)}.trip-mileage{display:flex;align-items:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.empty-state{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-2xl);text-align:center}@media(max-width:768px){.dashboard{padding:var(--spacing-lg)}.projection-value{font-size:2.5rem}.lease-limit-item{grid-template-columns:1fr;gap:var(--spacing-sm)}.trip-item{grid-template-columns:1fr}.trip-date{flex-direction:row;justify-content:flex-start;gap:var(--spacing-sm)}}.inline-checkbox{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.95rem}.calendar-page{max-width:1400px;margin:0 auto;padding:var(--spacing-xl);animation:fadeIn .5s ease-out}.calendar-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);flex-wrap:wrap;gap:var(--spacing-md)}.calendar-page-header h1{font-size:2rem;font-weight:700;margin:0 0 4px}.calendar-page-header p{margin:0;font-size:.95rem}.calendar-page-header .header-actions{display:flex;gap:var(--spacing-sm)}.calendar-card{background:var(--color-surface);border-radius:16px;padding:24px;box-shadow:0 4px 20px #00000014}.calendar-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--color-border)}.toolbar-nav{display:flex;gap:8px;align-items:center}.toolbar-label h2{font-size:1.5rem;font-weight:700;margin:0;color:var(--color-text);letter-spacing:-.5px}.toolbar-spacer{width:140px}.toolbar-stats{min-width:140px;text-align:right}.monthly-km{font-size:1.1rem;font-weight:600;color:var(--color-primary);background:#3b82f61a;padding:6px 12px;border-radius:var(--radius-md)}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:8px}.calendar-weekday{text-align:center;font-size:11px;font-weight:600;color:var(--color-text-secondary);padding:8px 0;text-transform:uppercase;letter-spacing:.5px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--color-border);border:1px solid var(--color-border);border-radius:8px;overflow:visible}.calendar-day{background:var(--color-background);min-height:120px;padding:8px;display:flex;flex-direction:column;transition:background .15s ease;cursor:pointer}.calendar-day.empty{background:transparent;cursor:default}.calendar-day:not(.empty):hover{background:var(--color-surface-hover)}.calendar-day.today{background:#3b82f60d}.day-number{font-size:14px;font-weight:600;color:var(--color-text);margin-bottom:4px;text-align:right}.calendar-day.today .day-number{color:var(--color-primary);background:#3b82f626;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-left:auto}.day-trips{display:flex;flex-direction:column;gap:4px;margin-top:4px}.trip-event{background:linear-gradient(135deg,#3b82f61f,#3b82f62e);border-left:3px solid var(--color-primary);padding:6px 8px;border-radius:4px;font-size:12px;cursor:pointer;transition:all .15s ease;overflow:hidden}.trip-event:hover{background:linear-gradient(135deg,#3b82f633,#3b82f647);transform:translate(2px);box-shadow:0 2px 4px #0000001a}.trip-distance{font-weight:600;color:var(--color-primary);display:block;margin-bottom:2px}.trip-route{color:var(--color-text-secondary);font-size:11px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trip-more{font-size:11px;color:var(--color-primary);font-weight:600;padding:4px 8px;text-align:center;background:#3b82f614;border-radius:4px}.trip-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999}.trip-modal{background:var(--color-surface);border-radius:16px;width:480px;max-width:90vw;padding:var(--spacing-xl);box-sizing:border-box;overflow:hidden;box-shadow:0 20px 40px -15px #00000073;animation:fadeIn .25s ease-out}.trip-modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-lg)}.trip-modal-header h3{margin:0}.small-text{font-size:.85rem;margin:6px 0 0}.icon-button{background:transparent;border:none;color:var(--color-text);cursor:pointer;padding:6px;border-radius:var(--radius-full);transition:background .2s ease}.icon-button:hover{background:#ffffff1a}.trip-modal-body{display:flex;flex-direction:column;gap:var(--spacing-md);overflow:hidden}.modal-form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.modal-form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.readonly-input{background:var(--color-surface)!important;opacity:.7;cursor:not-allowed}.mileage-note{margin-top:-4px;text-align:center}.ordering-hint{display:flex;align-items:flex-start;gap:var(--spacing-xs);margin-top:var(--spacing-xs);padding:var(--spacing-sm);background:#fbbf241a;border-radius:var(--radius-sm);font-size:.8rem;color:#d97706;line-height:1.4}.ordering-hint svg{flex-shrink:0;margin-top:2px}.personal-km-notice{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:#3b82f61a;border-radius:var(--radius-md);border-left:3px solid var(--color-primary)}.personal-km-label{font-size:.9rem;color:var(--color-text-secondary)}.trip-modal-body input,.trip-modal-body select{padding:10px 12px;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);box-sizing:border-box;width:100%;min-width:0}.modal-form-row input{min-width:0}.modal-inline{margin-top:-4px}.help-text{font-size:.85rem;color:var(--color-text-tertiary);margin:4px 0 0}.modal-error{padding:var(--spacing-sm);border-radius:var(--radius-md);background:#ef444426;color:#ef4444;font-size:.9rem}.modal-error .support-link{display:block;margin-top:var(--spacing-xs);color:var(--color-primary);text-decoration:none;font-weight:500}.modal-error .support-link:hover{text-decoration:underline}.modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);margin-top:var(--spacing-lg);flex-wrap:wrap}.modal-actions button{flex-shrink:0;min-width:150px}.modal-actions.stacked{flex-direction:column;gap:var(--spacing-md);align-items:center}.modal-actions.stacked .primary-actions{display:flex;gap:var(--spacing-sm);justify-content:center;flex-wrap:wrap}.modal-actions.stacked .secondary-actions{display:flex;justify-content:center}@media(max-width:540px){.modal-actions{flex-direction:column;align-items:stretch}.modal-actions button{width:100%;min-width:0}}.modal-actions .danger{color:#f87171}.modal-actions .danger:hover{background:#f8717126}.export-modal .trip-modal-header h3{display:flex;align-items:center;gap:var(--spacing-sm)}.export-summary{display:flex;gap:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-background);border-radius:var(--radius-md)}.export-stat{display:flex;flex-direction:column;gap:4px}.export-stat .stat-value{font-size:1.5rem;font-weight:700;color:var(--color-primary)}.export-stat .stat-label{font-size:.85rem;color:var(--color-text-secondary)}.export-info{font-size:.9rem}.export-info p{margin:0 0 var(--spacing-xs);color:var(--color-text-secondary)}.export-info ul{margin:0;padding-left:var(--spacing-lg);color:var(--color-text)}.export-type-toggle{display:flex;gap:2px;background:var(--color-background);border-radius:var(--radius-md);padding:4px}.export-type-toggle .toggle-btn{flex:1;padding:10px 16px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease}.loading-container{display:flex;align-items:center;justify-content:center;min-height:400px}.spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.calendar-grid{gap:0}.calendar-day{min-height:80px;padding:4px}.day-number{font-size:12px}.trip-event{padding:4px 6px;font-size:10px}.toolbar-spacer{display:none}.toolbar-stats{order:-1;min-width:auto;text-align:center}.calendar-toolbar{flex-direction:column;gap:12px}}.trips-page{max-width:1000px;margin:0 auto;padding:var(--spacing-xl);animation:fadeIn .3s ease-out}.trips-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-lg)}.header-content h1{margin:0 0 var(--spacing-xs) 0}.header-content p{margin:0}.header-actions{display:flex;gap:var(--spacing-sm)}.trips-stats{display:flex;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.stat-item{display:flex;flex-direction:column;gap:2px}.stat-label{font-size:.8rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:1.1rem;font-weight:600;color:var(--color-text)}.stat-value.completed{color:#22c55e}.stat-value.scheduled{color:var(--color-primary)}.filters-card{padding:var(--spacing-md);margin-bottom:var(--spacing-lg)}.filters-row{display:flex;gap:var(--spacing-md);align-items:center;flex-wrap:wrap}.search-input-wrapper{position:relative;flex:1;min-width:200px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-text-tertiary)}.search-input{width:100%;padding:10px 12px 10px 40px;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:.95rem}.search-input:focus{outline:none;border-color:var(--color-primary)}.filter-group{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--color-text-secondary)}.filter-group select{padding:10px 12px;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:.9rem;cursor:pointer}.sort-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:10px 16px;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:.9rem;cursor:pointer;transition:all var(--transition-fast)}.sort-btn:hover{background:var(--color-surface);border-color:var(--color-primary)}.empty-state{padding:var(--spacing-xxl)}.empty-content{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--spacing-md)}.empty-icon{color:var(--color-text-tertiary)}.empty-content h3,.empty-content p{margin:0}.trips-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.trip-card{padding:var(--spacing-md) var(--spacing-lg);cursor:pointer;transition:all var(--transition-fast)}.trip-card:hover{background:#3b82f608;border-color:#3b82f633}.trip-card.expanded{background:var(--color-surface)}.trip-main{display:grid;grid-template-columns:140px 1fr auto;gap:var(--spacing-lg);align-items:center}.trip-date-col{display:flex;flex-direction:column;gap:2px}.trip-date{font-weight:500;color:var(--color-text);font-size:.95rem}.trip-time{font-size:.85rem;color:var(--color-text-secondary);font-family:monospace}.trip-route-col{display:flex;flex-direction:column;gap:4px;min-width:0}.trip-name{font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trip-addresses{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.85rem;color:var(--color-text-tertiary)}.trip-addresses span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trip-distance-col{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.trip-distance{font-weight:600;font-size:1.1rem;color:var(--color-text)}.trip-status{font-size:.8rem;padding:2px 8px;border-radius:var(--radius-full)}.trip-status.completed{background:#22c55e26;color:#22c55e}.trip-status.scheduled{background:#3b82f626;color:var(--color-primary)}.trip-details{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.detail-row{display:flex;justify-content:space-between;padding:var(--spacing-xs) 0;font-size:.9rem}.detail-label{color:var(--color-text-secondary)}.detail-value{color:var(--color-text);text-align:right}.trip-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.trip-actions .danger{color:#ef4444}.trip-actions .danger:hover{background:#ef44441a}@media(max-width:768px){.trips-header{flex-direction:column;gap:var(--spacing-md)}.trips-stats{flex-wrap:wrap}.filters-row{flex-direction:column;align-items:stretch}.search-input-wrapper{min-width:auto}.trip-main{grid-template-columns:1fr;gap:var(--spacing-sm)}.trip-date-col{flex-direction:row;gap:var(--spacing-md)}.trip-distance-col{flex-direction:row;align-items:center;justify-content:space-between}.header-actions{flex-direction:column;width:100%}.header-actions button{width:100%}}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease-out}.export-modal{width:420px;max-width:90vw;padding:0;overflow:hidden}.export-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.export-modal .modal-header h2{margin:0;display:flex;align-items:center;gap:var(--spacing-sm);font-size:1.1rem}.export-modal .close-btn{background:none;border:none;font-size:1.5rem;color:var(--color-text-secondary);cursor:pointer;padding:0;line-height:1}.export-modal .close-btn:hover{color:var(--color-text)}.export-modal .modal-body{padding:var(--spacing-lg)}.export-type-toggle{display:flex;gap:2px;background:var(--color-background);border-radius:var(--radius-md);padding:4px;margin-bottom:var(--spacing-lg)}.export-type-toggle .toggle-btn{flex:1;padding:10px 16px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:.9rem;cursor:pointer;transition:all var(--transition-fast)}.export-type-toggle .toggle-btn.active{background:var(--color-surface);color:var(--color-text);font-weight:500;box-shadow:0 1px 3px #0000001a}.export-modal .form-group{margin-bottom:var(--spacing-md)}.export-modal .form-group label{display:block;margin-bottom:var(--spacing-xs);font-size:.9rem;font-weight:500;color:var(--color-text-secondary)}.export-modal .form-group input{width:100%;padding:12px;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:1rem}.export-modal .form-group input:focus{outline:none;border-color:var(--color-primary)}.export-info{margin-top:var(--spacing-lg);padding:var(--spacing-md);background:#3b82f614;border-radius:var(--radius-md)}.export-info p{margin:0 0 var(--spacing-sm) 0;font-size:.85rem;font-weight:500;color:var(--color-text)}.export-info ul{margin:0;padding-left:var(--spacing-lg);font-size:.85rem;color:var(--color-text-secondary)}.export-info li{margin-bottom:4px}.export-modal .modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-lg);border-top:1px solid var(--color-border);background:var(--color-background);flex-wrap:wrap}.export-modal .modal-actions button{flex-shrink:0;min-width:150px}.export-modal .modal-actions.stacked{flex-direction:column;gap:var(--spacing-md);align-items:center}.export-modal .modal-actions.stacked .primary-actions{display:flex;gap:var(--spacing-sm);justify-content:center;flex-wrap:wrap}.export-modal .modal-actions.stacked .secondary-actions{display:flex;justify-content:center}.pagination-controls{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1.5rem 0}.pagination-info{font-size:.9rem;color:var(--text-secondary, #666)}.vehicle-settings-page{max-width:800px;margin:0 auto;padding:var(--spacing-xl);animation:fadeIn .3s ease-out}.stats-overview-card{margin-bottom:var(--spacing-lg)}.stats-overview{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md);padding:var(--spacing-lg)}.stat-box{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--spacing-md);background:#00000026;border-radius:var(--radius-md)}.stat-box .stat-label{font-size:.7rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.stat-box .stat-value{font-size:1.25rem;font-weight:700;color:var(--color-text)}@media(max-width:600px){.stats-overview{grid-template-columns:repeat(2,1fr)}}.settings-header{display:flex;align-items:center;gap:var(--spacing-md)}.settings-header h1{margin:0}.settings-card{padding:0;overflow:hidden}form{display:flex;flex-direction:column}.form-section{display:flex;gap:var(--spacing-lg);padding:var(--spacing-xl)}.section-icon{width:48px;height:48px;background:#3b82f61a;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0}.section-content{flex:1}.section-content h3{margin-bottom:var(--spacing-xs);font-size:var(--font-size-lg)}.form-group label{display:block;margin-bottom:var(--spacing-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.form-group input{width:100%;padding:12px;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:1rem;transition:all var(--transition-fast)}.form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #3b82f633}.help-text{margin-top:var(--spacing-xs);font-size:.85rem;color:var(--color-text-tertiary)}.divider{height:1px;background:var(--color-border-light);margin:0 var(--spacing-xl)}.value-display{font-size:1.5rem;font-weight:var(--font-weight-bold);color:var(--color-text);padding:var(--spacing-xs) 0}.form-actions{padding:var(--spacing-xl);background:#00000005;border-top:1px solid var(--color-border);display:flex;justify-content:flex-end}@media(max-width:768px){.form-section{flex-direction:column;gap:var(--spacing-md)}.section-icon{width:40px;height:40px}}.danger-zone{margin-top:var(--spacing-xl);border:1px solid rgba(239,68,68,.3)}.danger-zone .section-icon.danger{background:#ef44441a;color:#ef4444}.danger-zone h3{color:#ef4444}.admin-actions{display:flex;flex-direction:column;gap:var(--spacing-md)}.admin-action{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:#00000005;border-radius:var(--radius-md);gap:var(--spacing-md)}.action-info{flex:1}.action-info strong{display:block;margin-bottom:4px}.action-info p{margin:0;font-size:.85rem;color:var(--color-text-tertiary)}.btn-danger{background:#ef4444;color:#fff;border:none}.btn-danger:hover{background:#dc2626}.spinning{animation:spin 1s linear infinite}@media(max-width:768px){.admin-action{flex-direction:column;align-items:stretch}}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg)}.add-vehicle-modal{width:100%;max-width:480px;padding:0;animation:slideUp .2s ease-out}.add-vehicle-modal .modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.add-vehicle-modal .modal-header h2{margin:0;font-size:1.25rem}.add-vehicle-modal .close-btn{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.add-vehicle-modal .close-btn:hover{background:var(--color-background);color:var(--color-text)}.add-vehicle-modal form{padding:var(--spacing-lg)}.add-vehicle-modal .form-section{display:flex;gap:var(--spacing-md)}.add-vehicle-modal .section-icon{width:48px;height:48px;background:#3b82f61a;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--color-primary);flex-shrink:0}.add-vehicle-modal .section-content{flex:1}.add-vehicle-modal .form-group{margin-bottom:var(--spacing-md)}.add-vehicle-modal .form-group label{display:block;font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-xs);color:var(--color-text);font-size:.9rem}.add-vehicle-modal .form-group input{width:100%;padding:12px;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:1rem}.add-vehicle-modal .form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #3b82f633}.add-vehicle-modal .form-group input:disabled{opacity:.6;cursor:not-allowed}.add-vehicle-modal .help-text{margin-top:var(--spacing-xs);font-size:.8rem;color:var(--color-text-tertiary)}.add-vehicle-modal .modal-error{background:#ef44441a;color:#ef4444;padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-size:.9rem}.add-vehicle-modal .modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border);margin-top:var(--spacing-md)}.vehicle-dashboard{max-width:1200px;margin:0 auto;padding:var(--spacing-xl);animation:fadeIn .5s ease-out}.vehicle-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-lg)}.vehicle-card{display:flex;flex-direction:column;gap:var(--spacing-md);transition:all var(--transition-fast);border:1px solid transparent}.vehicle-card:hover{transform:translateY(-2px);border-color:var(--color-border-light);box-shadow:0 10px 25px -5px #0000001a}.vehicle-card.active-vehicle{border-color:var(--color-primary);background:linear-gradient(to bottom right,rgba(59,130,246,.05),transparent)}.vehicle-card-header{display:flex;align-items:center;gap:var(--spacing-md)}.vehicle-icon{width:48px;height:48px;background:var(--color-surface-hover);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.active-vehicle .vehicle-icon{background:var(--color-primary)}.vehicle-info h3{margin:0;font-size:1.2rem;font-family:monospace;letter-spacing:.5px}.vehicle-info p{margin:0;font-size:.9rem}.badge-active{margin-left:auto;background:var(--color-primary);color:#fff;padding:2px 8px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase}.vehicle-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm);padding:var(--spacing-md);background:#0003;border-radius:var(--radius-md)}.vehicle-stats.two-col{grid-template-columns:repeat(2,1fr)}.stat-item{display:flex;flex-direction:column;align-items:center;text-align:center}.stat-label{font-size:.7rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;white-space:nowrap}.stat-val{font-size:1.1rem;font-weight:600;color:var(--color-text);white-space:nowrap}.vehicle-actions-row{display:flex;gap:var(--spacing-sm);margin-top:auto}.flex-1{flex:1}.creation-card{border:1px dashed var(--color-primary);background:#3b82f605}.creation-form{margin-top:var(--spacing-md)}.form-row{display:flex;gap:var(--spacing-md);align-items:center}.vehicle-input-lg{flex:1;padding:12px;font-size:1.1rem;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:monospace}.form-actions{display:flex;gap:var(--spacing-sm)}@media(max-width:768px){.form-row{flex-direction:column;align-items:stretch}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--spacing-xxl);margin-top:var(--spacing-xl)}.empty-state .empty-icon{color:var(--color-text-tertiary);margin-bottom:var(--spacing-lg)}.empty-state h2{margin:0 0 var(--spacing-sm) 0;font-size:1.5rem}.empty-state p{margin:0 0 var(--spacing-lg) 0;color:var(--color-text-secondary);max-width:300px}.address-autocomplete{position:relative;width:100%}.address-autocomplete .input-wrapper{position:relative;display:flex;align-items:center}.address-autocomplete .input-wrapper input{width:100%;padding-left:60px!important;padding-right:16px;padding-top:12px;padding-bottom:12px;font-size:1rem;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);transition:all var(--transition-fast);box-sizing:border-box}.input-wrapper input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.address-autocomplete .input-icon{position:absolute;left:20px;top:50%;transform:translateY(-50%);color:var(--color-text-tertiary);pointer-events:none}.address-autocomplete .input-loader{position:absolute;right:12px;color:var(--color-primary)}.suggestions-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 10px 25px -5px #0003;max-height:300px;overflow-y:auto;z-index:1000;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.suggestion-item{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--color-border)}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover,.suggestion-item.selected{background:var(--color-surface-hover)}.suggestion-icon{color:var(--color-primary);margin-top:2px;flex-shrink:0}.suggestion-text{flex:1;min-width:0}.suggestion-name{font-size:.9rem;color:var(--color-text);line-height:1.4;word-wrap:break-word}.suggestions-dropdown::-webkit-scrollbar{width:6px}.suggestions-dropdown::-webkit-scrollbar-track{background:transparent}.suggestions-dropdown::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.suggestions-dropdown::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.apple-calendar{background:var(--color-surface);border-radius:12px;padding:16px;box-shadow:0 2px 12px #00000014;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,sans-serif;max-width:320px;-webkit-user-select:none;user-select:none}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.header-labels{display:flex;gap:6px;align-items:center}.month-btn,.year-btn{background:transparent;border:none;font-size:17px;font-weight:600;color:var(--color-text);padding:4px 8px;border-radius:6px;cursor:pointer;transition:background .15s ease}.month-btn:hover,.year-btn:hover{background:#0000000d}.nav-btn{background:transparent;border:none;color:var(--color-text-secondary);padding:4px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.nav-btn:hover{background:#0000000d;color:var(--color-text)}.weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:8px}.weekday{text-align:center;font-size:11px;font-weight:600;color:var(--color-text-secondary);padding:4px 0;text-transform:uppercase;letter-spacing:.5px}.days-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.day-cell{aspect-ratio:1;border:none;background:transparent;border-radius:50%;font-size:15px;font-weight:400;color:var(--color-text);cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;position:relative}.day-cell.empty{cursor:default;pointer-events:none}.day-cell:not(.empty):hover{background:#0000000d}.day-cell.today{background:#3b82f61a;font-weight:600;color:var(--color-primary)}.day-cell.selected{background:var(--color-primary);color:#fff;font-weight:600}.day-cell.selected:hover{background:var(--color-primary);opacity:.9}.months-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:8px 0}.month-cell{padding:16px 12px;border:none;background:transparent;border-radius:8px;font-size:15px;font-weight:500;color:var(--color-text);cursor:pointer;transition:all .15s ease}.month-cell:hover{background:#0000000d}.month-cell.selected{background:var(--color-primary);color:#fff;font-weight:600}.years-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:8px 0}.year-cell{padding:16px 12px;border:none;background:transparent;border-radius:8px;font-size:15px;font-weight:500;color:var(--color-text);cursor:pointer;transition:all .15s ease}.year-cell:hover{background:#0000000d}.year-cell.selected{background:var(--color-primary);color:#fff;font-weight:600}.add-trip-page{max-width:800px;margin:0 auto;padding:var(--spacing-lg);animation:fadeIn .5s ease-out}.page-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.page-header h1{margin:0;font-size:2rem}.page-header p{margin:0;font-size:.95rem}.trip-form-card{padding:var(--spacing-lg)}.usage-warning{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);font-size:.9rem}.usage-warning.warning{background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);color:#d97706}.usage-warning.critical{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#dc2626}.error-message .support-link{display:block;margin-top:var(--spacing-sm);color:var(--color-primary);text-decoration:none;font-weight:500}.error-message .support-link:hover{text-decoration:underline}.form-section{margin-bottom:var(--spacing-md);display:flex;flex-direction:column}.section-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.section-header h3{margin:0;font-size:1.1rem;font-weight:600}.form-row{display:flex;gap:var(--spacing-md);align-items:flex-start}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs);width:100%;margin-bottom:var(--spacing-md)}.form-group.flex-1{flex:1}.form-group label{font-size:.9rem;font-weight:500;color:var(--color-text-secondary)}.form-group input,.form-group select{padding:12px;font-size:1rem;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);transition:all var(--transition-fast)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.form-group input[type=date],.form-group input[type=time]{font-family:monospace}.form-group input[type=time]{width:170px;align-self:flex-start}.inline-checkbox{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.95rem;color:var(--color-text)}.inline-checkbox input{width:18px;height:18px}.calendar-wrapper{margin-bottom:var(--spacing-md);display:flex;justify-content:flex-start}.calendar-time-row{display:flex;gap:var(--spacing-lg);align-items:flex-start}.when-section .calendar-wrapper{flex:1;margin-bottom:0}.time-input-group{flex:0 0 220px}.time-input-group .form-group{margin-bottom:0}.help-text{font-size:.85rem;color:var(--color-text-tertiary);margin:0}.divider{height:1px;background:var(--color-border);margin:var(--spacing-lg) 0}.error-message{padding:var(--spacing-md);background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:#ef4444;font-size:.9rem;margin-bottom:var(--spacing-md)}.form-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.auto-calculated-notice{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#22c55e1a;border:1px solid rgba(34,197,94,.3);border-radius:var(--radius-md);color:#22c55e;font-size:.9rem}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.form-row,.calendar-time-row{flex-direction:column}.time-input-group{width:100%}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xxl);color:var(--color-text-secondary)}.no-vehicle-card{padding:var(--spacing-xxl)}.no-vehicle-message{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--spacing-md)}.no-vehicle-icon{color:var(--color-text-tertiary);margin-bottom:var(--spacing-md)}.no-vehicle-message h2{margin:0;font-size:1.5rem}.no-vehicle-message p{margin:0;color:var(--color-text-secondary);max-width:300px}.no-vehicle-message button{margin-top:var(--spacing-md)}.schedule-table{display:flex;flex-direction:column;gap:2px;background:var(--color-border);border-radius:var(--radius-md);overflow:hidden}.schedule-row{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface);transition:background .15s ease}.schedule-row.active{background:#3b82f614}.schedule-day-toggle{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;flex:0 0 100px}.schedule-day-toggle input[type=checkbox]{width:18px;height:18px;cursor:pointer}.day-name{font-weight:500;color:var(--color-text)}.schedule-time{flex:1;max-width:140px;padding:8px 12px;font-size:.9rem;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);transition:all var(--transition-fast)}.schedule-time:disabled{opacity:.4;cursor:not-allowed}.schedule-time:focus{outline:none;border-color:var(--color-primary)}@media(max-width:480px){.schedule-row{flex-wrap:wrap}.schedule-time{max-width:none;flex:1}}.settings-page{max-width:800px;margin:0 auto;padding:var(--spacing-xl);animation:fadeIn .3s ease-out}.settings-header{margin-bottom:var(--spacing-xl)}.settings-header h1{margin:0 0 var(--spacing-xs) 0}.settings-header p{margin:0}.settings-loading{display:flex;justify-content:center;padding:var(--spacing-xxl)}.settings-card{margin-bottom:var(--spacing-lg);padding:var(--spacing-lg)}.settings-card .card-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.settings-card .card-header h2{margin:0;font-size:1.1rem}.account-type-display{margin-bottom:var(--spacing-lg)}.type-badge{display:inline-flex;align-items:center;padding:6px 12px;border-radius:var(--radius-full);font-size:.85rem;font-weight:500}.type-badge.private{background:#94a3b826;color:var(--color-text-secondary)}.type-badge.company{background:#3b82f626;color:var(--color-primary)}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:block;margin-bottom:var(--spacing-xs);font-weight:var(--font-weight-medium);color:var(--color-text);font-size:.9rem}.form-group input,.form-group select{width:100%;padding:12px;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:1rem;transition:all var(--transition-fast)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #3b82f633}.form-group .help-text{margin-top:var(--spacing-xs);font-size:.8rem;color:var(--color-text-tertiary)}.link-button{background:none;border:none;color:var(--color-primary);font-size:.85rem;cursor:pointer;padding:var(--spacing-xs) 0;margin-top:var(--spacing-xs)}.link-button:hover{text-decoration:underline}.settings-message{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);text-align:center}.settings-message.success{background:#22c55e1a;color:#22c55e;border:1px solid rgba(34,197,94,.3)}.settings-message.error{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.form-actions{display:flex;justify-content:flex-end;padding-top:var(--spacing-lg)}.mb-md{margin-bottom:var(--spacing-md)}.usage-card{background:linear-gradient(135deg,var(--color-surface) 0%,rgba(59,130,246,.05) 100%)}.usage-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-xl)}.usage-item{padding:var(--spacing-md);background:var(--color-background);border-radius:var(--radius-md);border:1px solid var(--color-border)}.usage-label{font-size:.85rem;color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.usage-value{font-size:1.5rem;font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-sm)}.usage-value .warning{color:#f59e0b}.usage-limit{font-size:1rem;font-weight:400;color:var(--color-text-tertiary)}.usage-bar{height:6px;background:var(--color-border);border-radius:3px;overflow:hidden;margin-bottom:var(--spacing-xs)}.usage-bar-fill{height:100%;border-radius:3px;transition:width .5s ease-out}.usage-bar-fill.normal{background:linear-gradient(90deg,#22c55e,#4ade80)}.usage-bar-fill.warning{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.usage-bar-fill.critical{background:linear-gradient(90deg,#ef4444,#f87171)}.usage-remaining{font-size:.8rem;color:var(--color-text-tertiary)}.usage-note{margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--color-border);font-size:.85rem;color:var(--color-text-tertiary);text-align:center}@media(max-width:768px){.form-row,.usage-grid{grid-template-columns:1fr}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);padding:var(--spacing-lg)}.login-card{background:var(--color-surface);border-radius:24px;padding:48px;max-width:420px;width:100%;box-shadow:0 25px 50px -12px #00000080;border:1px solid var(--color-border);animation:slideUp .5s ease-out}.login-header{text-align:center;margin-bottom:40px}.login-logo{width:80px;height:80px;background:linear-gradient(135deg,var(--color-primary),#60a5fa);border-radius:20px;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:#fff;box-shadow:0 10px 30px -10px #3b82f680}.login-header h1{font-size:2rem;font-weight:700;margin:0 0 8px;background:linear-gradient(135deg,#fff,#94a3b8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-subtitle{color:var(--color-text-secondary);margin:0;font-size:1rem}.login-content{display:flex;flex-direction:column;gap:var(--spacing-md)}.google-btn{width:100%;padding:14px 24px!important;font-size:1rem!important;display:flex;align-items:center;justify-content:center;gap:12px;background:#fff!important;color:#1f2937!important;border:1px solid #e5e7eb!important;transition:all .2s ease}.google-btn:hover:not(:disabled){background:#f9fafb!important;box-shadow:0 4px 12px #00000026;transform:translateY(-1px)}.google-btn:disabled{opacity:.7;cursor:not-allowed}.google-icon{flex-shrink:0}.btn-spinner{width:20px;height:20px;border:2px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-error{padding:var(--spacing-md);background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:#f87171;font-size:.9rem;text-align:center}.login-success{padding:var(--spacing-md);background:#22c55e1a;border:1px solid rgba(34,197,94,.3);border-radius:var(--radius-md);color:#22c55e;font-size:.9rem;text-align:center}.login-divider{display:flex;align-items:center;gap:var(--spacing-md);color:var(--color-text-tertiary);font-size:.85rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.email-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:12px}.email-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.email-form .form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.email-form label{font-size:.9rem;font-weight:500;color:var(--color-text-secondary)}.email-form input{padding:12px 14px;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:1rem;transition:border-color .2s}.email-form input:focus{outline:none;border-color:var(--color-primary)}.email-form input::placeholder{color:var(--color-text-tertiary)}.submit-btn{width:100%;margin-top:var(--spacing-sm)}.form-links{display:flex;flex-direction:column;gap:var(--spacing-xs);align-items:center}.link-btn{background:none;border:none;color:var(--color-primary);font-size:.9rem;cursor:pointer;padding:4px}.link-btn:hover{text-decoration:underline}.link-btn:disabled{opacity:.5;cursor:not-allowed}.back-btn{background:none;border:none;color:var(--color-text-secondary);font-size:.9rem;cursor:pointer;padding:8px;margin-top:var(--spacing-sm)}.back-btn:hover{color:var(--color-text)}.login-footer{margin-top:40px;text-align:center;color:var(--color-text-tertiary);font-size:.85rem}.login-footer p{margin:0 0 8px}.login-features{color:var(--color-text-secondary);font-size:.8rem}@media(max-width:480px){.login-card{padding:32px 24px}.login-header h1{font-size:1.75rem}.login-features{display:flex;flex-direction:column;gap:4px}}.onboarding-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg)}.onboarding-modal{width:100%;max-width:520px;padding:var(--spacing-xl);animation:slideUp .3s ease-out;max-height:90vh;overflow-y:auto}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.onboarding-header{text-align:center;margin-bottom:var(--spacing-xl)}.onboarding-header h1{margin:0 0 var(--spacing-xs) 0;font-size:1.75rem}.onboarding-header p{margin:0;color:var(--color-text-secondary)}.account-type-toggle{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);background:var(--color-background);padding:var(--spacing-xs);border-radius:var(--radius-md)}.type-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.type-btn:hover{color:var(--color-text);background:#ffffff0d}.type-btn.active{background:var(--color-primary);color:#fff}.onboarding-section{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:#00000005;border-radius:var(--radius-md)}.onboarding-section.optional-section{background:transparent;border:1px dashed var(--color-border)}.onboarding-section .section-icon{width:48px;height:48px;background:#3b82f61a;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:var(--color-primary);flex-shrink:0}.onboarding-section .section-icon.secondary{background:#94a3b81a;color:var(--color-text-tertiary)}.onboarding-section .section-content{flex:1}.onboarding-section label{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-xs);color:var(--color-text)}.optional-badge{font-size:.7rem;font-weight:400;background:var(--color-background);color:var(--color-text-tertiary);padding:2px 6px;border-radius:var(--radius-sm)}.onboarding-section input{width:100%;padding:12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:1rem}.onboarding-section input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #3b82f633}.onboarding-section .help-text{font-size:.8rem;color:var(--color-text-tertiary)}.onboarding-section .mt-md{margin-top:var(--spacing-md)}.onboarding-section .mt-sm{margin-top:var(--spacing-sm)}.onboarding-section .mb-sm{margin-bottom:var(--spacing-sm)}.onboarding-error{background:#ef44441a;color:#ef4444;padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);text-align:center}.onboarding-actions{display:flex;justify-content:center;margin-top:var(--spacing-lg)}.onboarding-actions button{min-width:200px}.app{min-height:100vh;display:flex;flex-direction:column}.app-main{flex:1;padding-top:60px}.placeholder{max-width:800px;margin:var(--spacing-2xl) auto;padding:var(--spacing-2xl);text-align:center;background:var(--color-surface);border:2px dashed var(--color-border);border-radius:var(--radius-lg);font-size:var(--font-size-lg);color:var(--color-text-secondary)}.app-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:var(--spacing-md)}.app-error{text-align:center;padding:var(--spacing-xl);background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid rgba(239,68,68,.3);max-width:400px}.app-error h2{color:#f87171;margin:0 0 var(--spacing-sm) 0}.app-error p{color:var(--color-text-secondary);margin:0 0 var(--spacing-lg) 0}.error-sign-out{padding:12px 24px;background:#ef4444;color:#fff;border:none;border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:background .2s}.error-sign-out:hover{background:#dc2626}
