:root{--bg-primary:#0d0d0f;--bg-surface:#111114;--bg-elevated:#16161a;--border:#1e1e22;--border-hover:#2e2e36;--text-primary:#f0ece4;--text-secondary:#c8c6c0;--text-muted:#5a5a62;--gold:#e8b84b;--red:#e05050;--amber:#e8a030;--green:#3dba72;--blue:#4499e8;--purple:#9966e8;--sidebar-width:240px;--topbar-height:56px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--transition:.14s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg-primary);height:100%;color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5}#app{height:100%}a{color:var(--blue);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition), color var(--transition), border-color var(--transition);border:none;font-family:inherit;font-size:13px}input,select,textarea{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;transition:border-color var(--transition);outline:none;padding:8px 10px;font-family:inherit;font-size:13px}input:focus,select:focus,textarea:focus{border-color:var(--gold)}input::placeholder,textarea::placeholder{color:var(--text-muted)}select option{background:var(--bg-elevated)}textarea{resize:vertical;min-height:80px}.auth-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex}.auth-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:380px;padding:40px 36px}.auth-logo{align-items:center;gap:10px;margin-bottom:28px;display:flex}.auth-logo .logo-icon{background:var(--gold);border-radius:var(--radius-sm);color:#0d0d0f;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.auth-logo .logo-text{letter-spacing:-.3px;color:var(--text-primary);font-size:20px;font-weight:700}.auth-card h2{margin-bottom:4px;font-size:16px;font-weight:600}.auth-card p{color:var(--text-muted);margin-bottom:24px;font-size:13px}.auth-field{margin-bottom:16px}.auth-field label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;display:block}.btn-primary{background:var(--gold);color:#0d0d0f;border-radius:var(--radius-sm);width:100%;padding:10px 16px;font-size:14px;font-weight:600}.btn-primary:hover{background:#f0c85a}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.auth-confirm{text-align:center;padding:16px 0}.auth-confirm .confirm-icon{color:var(--green);margin-bottom:12px;font-size:40px}.auth-confirm h3{margin-bottom:8px;font-size:16px}.auth-confirm p{color:var(--text-muted);margin-bottom:0;font-size:13px}.auth-error{border-radius:var(--radius-sm);color:var(--red);background:#e050501a;border:1px solid #e050504d;margin-bottom:12px;padding:10px 12px;font-size:13px}.app-shell{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--bg-surface);border-right:1px solid var(--border);flex-direction:column;height:100vh;display:flex;overflow:hidden}.sidebar-header{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:10px;padding:16px 14px;display:flex}.sidebar-logo-icon{background:var(--gold);border-radius:var(--radius-sm);color:#0d0d0f;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:flex}.sidebar-logo-text{letter-spacing:-.2px;color:var(--text-primary);font-size:15px;font-weight:700}.sidebar-section{flex-shrink:0;padding:10px 0}.sidebar-section-label{text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);padding:0 14px 6px;font-size:10px;font-weight:600}.sidebar-vehicle{cursor:pointer;width:100%;color:var(--text-secondary);text-align:left;background:0 0;border:none;border-radius:0;align-items:center;gap:8px;padding:7px 14px;font-size:13px;display:flex;position:relative}.sidebar-vehicle:hover{color:var(--text-primary);background:#ffffff0a}.sidebar-vehicle.active{color:var(--gold);background:#e8b84b14}.sidebar-vehicle.active:before{content:"";background:var(--gold);border-radius:0 2px 2px 0;width:2px;position:absolute;top:4px;bottom:4px;left:0}.status-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.status-dot.red{background:var(--red)}.status-dot.amber{background:var(--amber)}.status-dot.green{background:var(--green)}.status-dot.muted{background:var(--text-muted)}.sidebar-vehicle-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.sidebar-add-btn{width:100%;color:var(--text-muted);text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:7px 14px;font-size:13px;display:flex}.sidebar-add-btn:hover{color:var(--gold);background:#e8b84b0f}.sidebar-divider{background:var(--border);flex-shrink:0;height:1px;margin:4px 0}.sidebar-bottom{border-top:1px solid var(--border);flex-shrink:0;margin-top:auto;padding:10px 14px}.sidebar-user{align-items:center;gap:10px;display:flex}.user-avatar{background:var(--bg-elevated);border:1px solid var(--border);width:28px;height:28px;color:var(--text-secondary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:600;display:flex}.user-info{flex:1;overflow:hidden}.user-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:500;overflow:hidden}.user-email{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.btn-signout{color:var(--text-muted);border-radius:var(--radius-sm);background:0 0;justify-content:center;align-items:center;padding:4px;font-size:16px;display:flex}.btn-signout:hover{color:var(--red);background:#e0505014}.main-area{flex-direction:column;flex:1;display:flex;overflow:hidden}.topbar{height:var(--topbar-height);background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:0;padding:0 24px;display:flex}.topbar-nav{gap:2px;margin-left:auto;display:flex}.topbar-tab{color:var(--text-muted);border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;display:flex}.topbar-tab:hover{color:var(--text-primary);background:#ffffff0a}.topbar-tab.active{color:var(--gold);background:#e8b84b14}.topbar-tab i{font-size:16px}.page-content{scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex:1;padding:28px 28px 48px;overflow-y:auto}.page-header{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:24px;display:flex}.page-header h1{color:var(--text-primary);letter-spacing:-.3px;font-size:22px;font-weight:700}.chip{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary);border-radius:20px;align-items:center;gap:5px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex}.chip.ymm{color:var(--text-secondary)}.chip.mileage{color:var(--blue);background:#4499e814;border-color:#4499e840}.page-header-actions{gap:8px;margin-left:auto;display:flex}.btn-secondary{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:6px;padding:8px 14px;font-size:13px;display:inline-flex}.btn-secondary:hover{border-color:var(--border-hover);color:var(--text-primary)}.btn-gold{background:var(--gold);color:#0d0d0f;border-radius:var(--radius-sm);align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;display:inline-flex}.btn-gold:hover{background:#f0c85a}.stats-row{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:28px;display:grid}.stat-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px 18px}.stat-label{text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);margin-bottom:8px;font-size:11px;font-weight:600}.stat-value{color:var(--text-primary);letter-spacing:-.5px;font-size:24px;font-weight:700;line-height:1}.stat-sub{color:var(--text-muted);margin-top:4px;font-size:11px}.section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.section-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.section-link{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:12px}.section-link:hover{color:var(--gold)}.projects-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:28px;display:grid}.project-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--transition), background var(--transition);padding:16px}.project-card:hover{border-color:var(--border-hover);background:var(--bg-elevated)}.project-card-header{justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:10px;display:flex}.project-card-title{color:var(--text-primary);font-size:14px;font-weight:600;line-height:1.3}.project-badges{flex-wrap:wrap;gap:5px;margin-bottom:10px;display:flex}.badge{white-space:nowrap;border-radius:20px;align-items:center;padding:2px 8px;font-size:11px;font-weight:500;display:inline-flex}.badge-status-planning{color:var(--blue);background:#4499e81f}.badge-status-inprogress{color:var(--amber);background:#e8a0301f}.badge-status-complete{color:var(--green);background:#3dba721f}.badge-status-onhold{color:var(--text-muted);background:#5a5a6233}.badge-type-preventative{color:var(--green);background:#3dba721a}.badge-type-corrective{color:var(--amber);background:#e8a0301a}.badge-type-overhaul{color:var(--purple);background:#9966e81f}.badge-priority-low{color:var(--text-muted);background:#5a5a6233}.badge-priority-medium{color:var(--blue);background:#4499e81f}.badge-priority-high{color:var(--amber);background:#e8a0301f}.badge-priority-critical{color:var(--red);background:#e050501f}.badge-part-researching{color:var(--text-muted);background:#5a5a6233}.badge-part-ordered{color:var(--blue);background:#4499e81f}.badge-part-received{color:var(--amber);background:#e8a0301f}.badge-part-installed{color:var(--green);background:#3dba721f}.progress-bar-wrap{background:var(--bg-primary);border-radius:20px;height:4px;margin-bottom:10px;overflow:hidden}.progress-bar-fill{background:var(--gold);border-radius:20px;height:100%;transition:width .3s}.project-card-meta{color:var(--text-muted);justify-content:space-between;align-items:center;font-size:12px;display:flex}.project-budget{gap:8px;display:flex}.budget-actual{color:var(--text-secondary);font-weight:500}.budget-of,.budget-estimated{color:var(--text-muted)}.task-list{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:28px;overflow:hidden}.task-row{border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--transition);align-items:center;gap:10px;padding:11px 14px;display:flex}.task-row:last-child{border-bottom:none}.task-row:hover{background:#ffffff08}.task-status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.task-status-dot.pending{background:var(--text-muted)}.task-status-dot.inprogress{background:var(--amber)}.task-status-dot.done{background:var(--green)}.task-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;overflow:hidden}.task-category-chip{color:var(--text-muted);background:var(--bg-elevated);border:1px solid var(--border);white-space:nowrap;border-radius:20px;padding:2px 8px;font-size:11px}.task-cost{color:var(--text-secondary);white-space:nowrap;text-align:right;min-width:60px;font-size:12px}.task-chevron{color:var(--text-muted);flex-shrink:0;font-size:16px}.due-row{border-bottom:1px solid var(--border);transition:background var(--transition);align-items:center;gap:10px;padding:11px 14px;display:flex}.due-row:last-child{border-bottom:none}.due-row:hover{background:#ffffff08}.due-icon{flex-shrink:0;font-size:16px}.due-icon.red{color:var(--red)}.due-icon.amber{color:var(--amber)}.due-icon.blue{color:var(--blue)}.due-info{flex:1;overflow:hidden}.due-title{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.due-sub{color:var(--text-muted);margin-top:1px;font-size:11px}.due-when{white-space:nowrap;text-align:right;font-size:12px;font-weight:500}.due-when.red{color:var(--red)}.due-when.amber{color:var(--amber)}.due-when.blue{color:var(--blue)}.empty-state{text-align:center;color:var(--text-muted);padding:32px 20px;font-size:13px}.schedule-filters{flex-wrap:wrap;gap:10px;margin-bottom:20px;display:flex}.schedule-filters select{width:auto;min-width:160px}.urgency-group{margin-bottom:24px}.urgency-header{border-bottom:1px solid var(--border);align-items:center;gap:10px;margin-bottom:8px;padding:8px 0;display:flex}.urgency-label{text-transform:uppercase;letter-spacing:.6px;font-size:12px;font-weight:700}.urgency-label.red{color:var(--red)}.urgency-label.amber{color:var(--amber)}.urgency-label.neutral{color:var(--text-muted)}.urgency-count{color:var(--text-muted);background:var(--bg-elevated);border:1px solid var(--border);border-radius:20px;padding:1px 8px;font-size:11px}.schedule-row{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:10px;margin-bottom:4px;padding:11px 14px;display:flex}.schedule-row-main{flex:1;overflow:hidden}.schedule-row-title{color:var(--text-primary);font-size:13px}.schedule-row-sub{color:var(--text-muted);margin-top:2px;font-size:11px}.schedule-row-when{white-space:nowrap;font-size:12px;font-weight:500}.schedule-row-when.red{color:var(--red)}.schedule-row-when.amber{color:var(--amber)}.schedule-row-when.neutral{color:var(--text-muted)}.spend-total-banner{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);flex-wrap:wrap;gap:40px;margin-bottom:20px;padding:20px 24px;display:flex}.spend-banner-item .banner-label{text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);margin-bottom:4px;font-size:11px}.spend-banner-item .banner-value{color:var(--text-primary);letter-spacing:-.5px;font-size:26px;font-weight:700}.spend-banner-item .banner-value.gold{color:var(--gold)}.accordion-vehicle{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:10px;overflow:hidden}.accordion-header{cursor:pointer;transition:background var(--transition);align-items:center;gap:12px;padding:14px 18px;display:flex}.accordion-header:hover{background:#ffffff08}.accordion-vehicle-name{color:var(--text-primary);flex:1;font-size:14px;font-weight:600}.accordion-ytd{color:var(--gold);font-size:13px;font-weight:600}.accordion-toggle{color:var(--text-muted);transition:transform var(--transition);font-size:18px}.accordion-header.open .accordion-toggle{transform:rotate(180deg)}.accordion-body{border-top:1px solid var(--border);padding:0 18px 18px;display:none}.accordion-body.open{display:block}.spend-split{gap:20px;margin-bottom:14px;padding:14px 0;display:flex}.spend-split-item{flex:1}.spend-split-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:4px;font-size:11px}.spend-split-value{font-size:18px;font-weight:700}.spend-split-value.parts{color:var(--blue)}.spend-split-value.labor{color:var(--purple)}.category-bars{margin-bottom:16px}.cat-bar-row{align-items:center;gap:10px;margin-bottom:7px;display:flex}.cat-bar-label{color:var(--text-secondary);flex-shrink:0;width:90px;font-size:12px}.cat-bar-track{background:var(--bg-primary);border-radius:20px;flex:1;height:5px;overflow:hidden}.cat-bar-fill{background:var(--gold);border-radius:20px;height:100%}.cat-bar-amount{color:var(--text-muted);text-align:right;flex-shrink:0;width:64px;font-size:12px}.recent-tasks-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:8px;font-size:11px;font-weight:600}.modal-backdrop{z-index:1000;background:#0009;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-backdrop.hidden{display:none}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;width:100%;max-width:560px;max-height:90vh;display:flex;overflow:hidden}.modal.modal-wide{max-width:800px}.modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.modal-title{color:var(--text-primary);font-size:15px;font-weight:600}.modal-close{color:var(--text-muted);border-radius:var(--radius-sm);background:0 0;justify-content:center;align-items:center;padding:4px;font-size:20px;display:flex}.modal-close:hover{color:var(--text-primary);background:#ffffff0f}.modal-body{scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex:1;padding:20px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);flex-shrink:0;justify-content:flex-end;gap:10px;padding:14px 20px;display:flex}.btn-cancel{color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius-sm);background:0 0;padding:8px 16px}.btn-cancel:hover{border-color:var(--border-hover);color:var(--text-primary)}.slide-panel-backdrop{z-index:900;background:#00000080;justify-content:flex-end;display:flex;position:fixed;inset:0}.slide-panel-backdrop.hidden{display:none}.slide-panel{background:var(--bg-surface);border-left:1px solid var(--border);flex-direction:column;width:680px;max-width:90vw;height:100%;display:flex;overflow:hidden}.slide-panel-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.slide-panel-body{scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex:1;padding:20px;overflow-y:auto}.form-row{grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;display:grid}.form-group{margin-bottom:14px}.form-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:6px;font-size:11px;font-weight:600;display:block}.form-section-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:1px solid var(--border);margin-top:20px;margin-bottom:14px;padding-bottom:8px;font-size:12px;font-weight:600}.project-meta-grid{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px;display:grid}.meta-cell-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:4px;font-size:11px}.meta-cell-value{color:var(--text-primary);font-size:13px}.parts-table{border-collapse:collapse;width:100%;margin-bottom:12px;font-size:12px}.parts-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:1px solid var(--border);padding:6px 10px;font-size:10px;font-weight:600}.parts-table td{border-bottom:1px solid var(--border);color:var(--text-secondary);vertical-align:middle;padding:8px 10px}.parts-table tr:last-child td{border-bottom:none}.parts-table tr:hover td{background:#ffffff05}.part-status-select{width:auto;padding:3px 8px;font-size:11px}.photo-preview{object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-primary);width:100%;height:120px;margin-top:6px;display:none}.photo-preview.visible{display:block}.btn-inline{color:var(--text-muted);border:1px dashed var(--border);border-radius:var(--radius-sm);background:0 0;align-items:center;gap:6px;margin-top:8px;padding:6px 12px;font-size:12px;display:inline-flex}.btn-inline:hover{color:var(--gold);border-color:var(--gold)}.settings-section{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);margin-top:16px;padding:14px 16px}.settings-section-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:10px;font-size:11px;font-weight:600}.share-input-row{gap:8px;display:flex}.share-input-row input{flex:1}.share-input-row button{white-space:nowrap;width:auto}.member-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:6px 0;font-size:12px;display:flex}.member-row:last-child{border-bottom:none}.member-email{color:var(--text-secondary);flex:1}.member-role{color:var(--text-muted);background:var(--bg-surface);border-radius:20px;padding:2px 8px;font-size:11px}.btn-danger{color:var(--red);border-radius:var(--radius-sm);background:#e050501a;border:1px solid #e0505040;padding:8px 14px;font-size:13px}.btn-danger:hover{background:#e0505033}.loading-state{height:200px;color:var(--text-muted);justify-content:center;align-items:center;gap:10px;font-size:13px;display:flex}.spinner{border:2px solid var(--border);border-top-color:var(--gold);border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.toast-container{z-index:9999;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);align-items:center;gap:10px;min-width:240px;padding:12px 16px;font-size:13px;animation:.2s toast-in;display:flex;box-shadow:0 4px 20px #0006}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.toast.success{border-color:#3dba7266}.toast.error{border-color:#e0505066}.toast i.success{color:var(--green)}.toast i.error{color:var(--red)}.no-vehicle-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;height:60vh;display:flex}.no-vehicle-state i{color:var(--text-muted);font-size:48px}.no-vehicle-state h2{color:var(--text-secondary);font-size:18px;font-weight:600}.no-vehicle-state p{color:var(--text-muted);max-width:280px;font-size:13px}hr.section-hr{border:none;border-top:1px solid var(--border);margin:20px 0}.sidebar-scroll{scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex:1;overflow-y:auto}
