html{--mat-sys-background: #faf9fd;--mat-sys-error: #ba1a1a;--mat-sys-error-container: #ffdad6;--mat-sys-inverse-on-surface: #f2f0f4;--mat-sys-inverse-primary: #abc7ff;--mat-sys-inverse-surface: #2f3033;--mat-sys-on-background: #1a1b1f;--mat-sys-on-error: #ffffff;--mat-sys-on-error-container: #93000a;--mat-sys-on-primary: #ffffff;--mat-sys-on-primary-container: #00458f;--mat-sys-on-primary-fixed: #001b3f;--mat-sys-on-primary-fixed-variant: #00458f;--mat-sys-on-secondary: #ffffff;--mat-sys-on-secondary-container: #3e4759;--mat-sys-on-secondary-fixed: #131c2b;--mat-sys-on-secondary-fixed-variant: #3e4759;--mat-sys-on-surface: #1a1b1f;--mat-sys-on-surface-variant: #44474e;--mat-sys-on-tertiary: #ffffff;--mat-sys-on-tertiary-container: #0000ef;--mat-sys-on-tertiary-fixed: #00006e;--mat-sys-on-tertiary-fixed-variant: #0000ef;--mat-sys-outline: #74777f;--mat-sys-outline-variant: #c4c6d0;--mat-sys-primary: #005cbb;--mat-sys-primary-container: #d7e3ff;--mat-sys-primary-fixed: #d7e3ff;--mat-sys-primary-fixed-dim: #abc7ff;--mat-sys-scrim: #000000;--mat-sys-secondary: #565e71;--mat-sys-secondary-container: #dae2f9;--mat-sys-secondary-fixed: #dae2f9;--mat-sys-secondary-fixed-dim: #bec6dc;--mat-sys-shadow: #000000;--mat-sys-surface: #faf9fd;--mat-sys-surface-bright: #faf9fd;--mat-sys-surface-container: #efedf0;--mat-sys-surface-container-high: #e9e7eb;--mat-sys-surface-container-highest: #e3e2e6;--mat-sys-surface-container-low: #f4f3f6;--mat-sys-surface-container-lowest: #ffffff;--mat-sys-surface-dim: #dbd9dd;--mat-sys-surface-tint: #005cbb;--mat-sys-surface-variant: #e0e2ec;--mat-sys-tertiary: #343dff;--mat-sys-tertiary-container: #e0e0ff;--mat-sys-tertiary-fixed: #e0e0ff;--mat-sys-tertiary-fixed-dim: #bec2ff;--mat-sys-neutral-variant20: #2d3038;--mat-sys-neutral10: #1a1b1f;--mat-sys-level0: 0px 0px 0px 0px rgba(0, 0, 0, .2), 0px 0px 0px 0px rgba(0, 0, 0, .14), 0px 0px 0px 0px rgba(0, 0, 0, .12);--mat-sys-level1: 0px 2px 1px -1px rgba(0, 0, 0, .2), 0px 1px 1px 0px rgba(0, 0, 0, .14), 0px 1px 3px 0px rgba(0, 0, 0, .12);--mat-sys-level2: 0px 3px 3px -2px rgba(0, 0, 0, .2), 0px 3px 4px 0px rgba(0, 0, 0, .14), 0px 1px 8px 0px rgba(0, 0, 0, .12);--mat-sys-level3: 0px 3px 5px -1px rgba(0, 0, 0, .2), 0px 6px 10px 0px rgba(0, 0, 0, .14), 0px 1px 18px 0px rgba(0, 0, 0, .12);--mat-sys-level4: 0px 5px 5px -3px rgba(0, 0, 0, .2), 0px 8px 10px 1px rgba(0, 0, 0, .14), 0px 3px 14px 2px rgba(0, 0, 0, .12);--mat-sys-level5: 0px 7px 8px -4px rgba(0, 0, 0, .2), 0px 12px 17px 2px rgba(0, 0, 0, .14), 0px 5px 22px 4px rgba(0, 0, 0, .12);--mat-sys-body-large: 400 1rem / 1.5rem Roboto;--mat-sys-body-large-font: Roboto;--mat-sys-body-large-line-height: 1.5rem;--mat-sys-body-large-size: 1rem;--mat-sys-body-large-tracking: .031rem;--mat-sys-body-large-weight: 400;--mat-sys-body-medium: 400 .875rem / 1.25rem Roboto;--mat-sys-body-medium-font: Roboto;--mat-sys-body-medium-line-height: 1.25rem;--mat-sys-body-medium-size: .875rem;--mat-sys-body-medium-tracking: .016rem;--mat-sys-body-medium-weight: 400;--mat-sys-body-small: 400 .75rem / 1rem Roboto;--mat-sys-body-small-font: Roboto;--mat-sys-body-small-line-height: 1rem;--mat-sys-body-small-size: .75rem;--mat-sys-body-small-tracking: .025rem;--mat-sys-body-small-weight: 400;--mat-sys-display-large: 400 3.562rem / 4rem Roboto;--mat-sys-display-large-font: Roboto;--mat-sys-display-large-line-height: 4rem;--mat-sys-display-large-size: 3.562rem;--mat-sys-display-large-tracking: -.016rem;--mat-sys-display-large-weight: 400;--mat-sys-display-medium: 400 2.812rem / 3.25rem Roboto;--mat-sys-display-medium-font: Roboto;--mat-sys-display-medium-line-height: 3.25rem;--mat-sys-display-medium-size: 2.812rem;--mat-sys-display-medium-tracking: 0;--mat-sys-display-medium-weight: 400;--mat-sys-display-small: 400 2.25rem / 2.75rem Roboto;--mat-sys-display-small-font: Roboto;--mat-sys-display-small-line-height: 2.75rem;--mat-sys-display-small-size: 2.25rem;--mat-sys-display-small-tracking: 0;--mat-sys-display-small-weight: 400;--mat-sys-headline-large: 400 2rem / 2.5rem Roboto;--mat-sys-headline-large-font: Roboto;--mat-sys-headline-large-line-height: 2.5rem;--mat-sys-headline-large-size: 2rem;--mat-sys-headline-large-tracking: 0;--mat-sys-headline-large-weight: 400;--mat-sys-headline-medium: 400 1.75rem / 2.25rem Roboto;--mat-sys-headline-medium-font: Roboto;--mat-sys-headline-medium-line-height: 2.25rem;--mat-sys-headline-medium-size: 1.75rem;--mat-sys-headline-medium-tracking: 0;--mat-sys-headline-medium-weight: 400;--mat-sys-headline-small: 400 1.5rem / 2rem Roboto;--mat-sys-headline-small-font: Roboto;--mat-sys-headline-small-line-height: 2rem;--mat-sys-headline-small-size: 1.5rem;--mat-sys-headline-small-tracking: 0;--mat-sys-headline-small-weight: 400;--mat-sys-label-large: 500 .875rem / 1.25rem Roboto;--mat-sys-label-large-font: Roboto;--mat-sys-label-large-line-height: 1.25rem;--mat-sys-label-large-size: .875rem;--mat-sys-label-large-tracking: .006rem;--mat-sys-label-large-weight: 500;--mat-sys-label-large-weight-prominent: 700;--mat-sys-label-medium: 500 .75rem / 1rem Roboto;--mat-sys-label-medium-font: Roboto;--mat-sys-label-medium-line-height: 1rem;--mat-sys-label-medium-size: .75rem;--mat-sys-label-medium-tracking: .031rem;--mat-sys-label-medium-weight: 500;--mat-sys-label-medium-weight-prominent: 700;--mat-sys-label-small: 500 .688rem / 1rem Roboto;--mat-sys-label-small-font: Roboto;--mat-sys-label-small-line-height: 1rem;--mat-sys-label-small-size: .688rem;--mat-sys-label-small-tracking: .031rem;--mat-sys-label-small-weight: 500;--mat-sys-title-large: 400 1.375rem / 1.75rem Roboto;--mat-sys-title-large-font: Roboto;--mat-sys-title-large-line-height: 1.75rem;--mat-sys-title-large-size: 1.375rem;--mat-sys-title-large-tracking: 0;--mat-sys-title-large-weight: 400;--mat-sys-title-medium: 500 1rem / 1.5rem Roboto;--mat-sys-title-medium-font: Roboto;--mat-sys-title-medium-line-height: 1.5rem;--mat-sys-title-medium-size: 1rem;--mat-sys-title-medium-tracking: .009rem;--mat-sys-title-medium-weight: 500;--mat-sys-title-small: 500 .875rem / 1.25rem Roboto;--mat-sys-title-small-font: Roboto;--mat-sys-title-small-line-height: 1.25rem;--mat-sys-title-small-size: .875rem;--mat-sys-title-small-tracking: .006rem;--mat-sys-title-small-weight: 500;--mat-sys-corner-extra-large: 28px;--mat-sys-corner-extra-large-top: 28px 28px 0 0;--mat-sys-corner-extra-small: 4px;--mat-sys-corner-extra-small-top: 4px 4px 0 0;--mat-sys-corner-full: 9999px;--mat-sys-corner-large: 16px;--mat-sys-corner-large-end: 0 16px 16px 0;--mat-sys-corner-large-start: 16px 0 0 16px;--mat-sys-corner-large-top: 16px 16px 0 0;--mat-sys-corner-medium: 12px;--mat-sys-corner-none: 0;--mat-sys-corner-small: 8px;--mat-sys-dragged-state-layer-opacity: .16;--mat-sys-focus-state-layer-opacity: .12;--mat-sys-hover-state-layer-opacity: .08;--mat-sys-pressed-state-layer-opacity: .12}*{box-sizing:border-box}html{overflow-x:hidden}body{margin:0;min-height:100vh;color:#0f172a;background:#f7f9fc;overflow-x:hidden}button{cursor:pointer}input,select,textarea,button{transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease}input:focus,select:focus,textarea:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa33;outline:none}.status-chip{display:inline-block;border-radius:999px;font-size:.74rem;font-weight:700;padding:.2rem .55rem;white-space:nowrap}.status-upcoming{background:#f1f5f9;color:#475569;border:1px solid #cbd5e1}.status-picked_up{background:#dbeafe;color:#1e40af;border:1px solid #93c5fd}.status-picked_up_pending_review{background:#e0e7ff;color:#3730a3;border:1px solid #a5b4fc}.status-completed{background:#f5f3ff;color:#6d28d9;border:1px solid #c4b5fd}.status-completed_pending_review{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.status-approved_no_damage{background:#dcfce7;color:#166534;border:1px solid #86efac}.status-damage_reported{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.status-damage_resolved{background:#fce7f3;color:#9d174d;border:1px solid #f9a8d4}.all-free{background:#f0fdf4;border-color:#86efac}.partial{background:#eff6ff;border-color:#93c5fd}.full{background:#fef2f2;border-color:#fca5a5}.today{box-shadow:inset 0 0 0 2px #2563eb}.selected{box-shadow:inset 0 0 0 2px #0f172a}.month-label,.week-label{min-width:130px;text-align:center;font-weight:700;color:#1e293b;text-transform:capitalize}.vehicle-pills{display:flex;gap:.45rem;margin-bottom:.72rem;flex-wrap:wrap}.pill{border-radius:999px;border:1px solid #cbd5e1;background:#fff;color:#334155;padding:.2rem .62rem;font-size:.78rem;font-weight:700}.pill:hover{background:#f8fafc}.pill.active{background:#dbeafe;border-color:#93c5fd;color:#1e40af}.pill-all.active{background:#dcfce7;border-color:#86efac;color:#166534}.calendar-legend{display:flex;gap:.5rem;margin-bottom:.65rem;flex-wrap:wrap}.legend-chip{display:inline-flex;align-items:center;border-radius:999px;padding:.16rem .52rem;font-size:.76rem;font-weight:700;border:1px solid transparent}.legend-all-free{background:#dcfce7;border-color:#86efac;color:#166534}.legend-partial{background:#dbeafe;border-color:#93c5fd;color:#1e40af}.legend-full{background:#fee2e2;border-color:#fca5a5;color:#991b1b}.vehicle-pill{display:inline-block;border-radius:4px;padding:.08rem .3rem;font-size:.62rem;font-weight:700;line-height:1.3;white-space:nowrap}.vehicle-pill.available{background:#dcfce7;color:#166534;border:1px solid #86efac}.vehicle-pill.booked{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.day-bookings-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}.day-bookings-list li a{display:flex;align-items:center;gap:.65rem;padding:.5rem .7rem;border:1px solid #e2e8f0;border-radius:10px;background:#fff;text-decoration:none;color:#1e293b;font-size:.86rem;transition:background .12s,border-color .12s}.day-bookings-list li a:hover{background:#eff6ff;border-color:#93c5fd}.day-bookings-list .db-number{font-weight:700;color:#1d4ed8;min-width:5rem}.day-bookings-list .db-customer{flex:1;font-weight:600}.day-bookings-list .db-vehicle{font-size:.8rem;font-weight:700;color:#475569;background:#f1f5f9;border:1px solid #cbd5e1;border-radius:6px;padding:.1rem .4rem}.week-list{display:flex;flex-direction:column;gap:.4rem}.week-day-row{display:flex;align-items:center;gap:.6rem;padding:.6rem .7rem;border:1px solid #e2e8f0;border-radius:10px;background:#f8fafc;cursor:pointer;transition:background .12s,box-shadow .15s}.week-day-row:hover{background:#fff;box-shadow:0 2px 8px #0f172a12}.week-day-header{display:flex;flex-direction:column;min-width:4.5rem}.week-day-name{font-weight:700;font-size:.82rem;color:#0f172a;text-transform:capitalize}.week-day-date{font-size:.75rem;color:#64748b}.week-day-pills{display:flex;flex-wrap:wrap;gap:.25rem;flex:1}.week-day-detail{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:.6rem .7rem}.booking-card{display:block;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:.7rem .8rem;margin-bottom:.5rem;text-decoration:none;color:#1e293b;transition:background .12s,border-color .12s}.booking-card:hover{background:#eff6ff;border-color:#93c5fd}.booking-card-top{display:flex;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.3rem}.booking-card-number{font-weight:700;color:#1d4ed8;font-size:.9rem}.booking-card-customer{font-weight:600;color:#0f172a;font-size:.92rem;margin-bottom:.25rem}.booking-card-meta{display:flex;flex-wrap:wrap;gap:.35rem .7rem;font-size:.78rem;color:#64748b;font-weight:500}.vehicle-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:.7rem .8rem;margin-bottom:.5rem}.vehicle-card-row{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.vehicle-card-row:not(:last-child){margin-bottom:.3rem}.vehicle-card-name{font-weight:700;color:#0f172a;font-size:.92rem}.vehicle-card-reg{color:#475569;font-size:.86rem;font-weight:600}.vehicle-card-key{font-weight:700;color:#475569;text-transform:uppercase;background:#f1f5f9;border:1px solid #cbd5e1;border-radius:6px;padding:.1rem .4rem;font-size:.82rem}.vehicle-card-editing{background:#fff;border-color:#93c5fd}.vehicle-card-adding{background:#f0fdf4;border-color:#86efac}.vehicle-card-field{display:flex;flex-direction:column;gap:.25rem;font-size:.82rem;font-weight:600;color:#475569;margin-bottom:.45rem}.vehicle-card-field input{width:100%}.vehicle-card-actions{display:flex;gap:.4rem;margin-top:.3rem}@media(max-width:760px){.day-bookings-list li a{flex-wrap:wrap;gap:.35rem;padding:.4rem .55rem;font-size:.82rem}.db-number{min-width:auto}}@media(max-width:480px){.vehicle-pills{gap:.3rem}.pill{font-size:.72rem;padding:.15rem .45rem}.legend-chip{font-size:.68rem;padding:.1rem .4rem}}
