*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--brand:#1a6b5a;--brand-dark:#145248;--brand-light:#e8f5f1;--text:#1a1a1a;--text-muted:#666;--border:#dde2e0;--bg:#f5f7f6;--white:#fff;--danger:#c0392b;--sidebar-w:52px}html,body{height:100%;color:var(--text);background:var(--bg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;overflow:hidden}#login-screen{background:var(--brand);justify-content:center;align-items:center;height:100vh;display:flex}.login-box{background:var(--white);border-radius:12px;flex-direction:column;gap:16px;width:360px;padding:40px 36px;display:flex;box-shadow:0 8px 32px #0000002e}.login-title{color:var(--brand);text-align:center;margin-bottom:4px;font-size:20px;font-weight:700}.login-box input[type=email],.login-box input[type=password],.login-box input[type=text]{border:1px solid var(--border);border-radius:6px;outline:none;width:100%;padding:10px 12px;font-size:14px;transition:border-color .15s}.login-box input:focus{border-color:var(--brand)}.password-wrap{display:flex;position:relative}.password-wrap input{flex:1;padding-right:40px}.btn-eye{cursor:pointer;background:0 0;border:none;padding:4px;font-size:16px;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.error-msg{color:var(--danger);min-height:18px;font-size:13px}.login-copyright{color:var(--text-muted);text-align:center;margin-top:8px;font-size:11px}.btn-primary{background:var(--brand);color:var(--white);cursor:pointer;border:none;border-radius:6px;width:100%;padding:10px 18px;font-size:14px;font-weight:600;transition:background .15s}.btn-primary:hover{background:var(--brand-dark)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:var(--white);color:var(--brand);border:1px solid var(--brand);cursor:pointer;border-radius:6px;padding:8px 16px;font-size:14px;font-weight:600;transition:background .15s}.btn-secondary:hover{background:var(--brand-light)}#app{flex-direction:row;height:100vh;display:flex;overflow:hidden}#sidebar{width:var(--sidebar-w);background:var(--brand);flex-direction:column;flex-shrink:0;align-items:center;gap:4px;padding:8px 0;display:flex}.sidebar-spacer{flex:1}.nav-btn{cursor:pointer;color:#ffffffb3;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;transition:background .15s;display:flex}.nav-btn:hover{color:#fff;background:#ffffff26}.nav-btn.active{color:#fff;background:#ffffff40}#content{flex-direction:column;flex:1;display:flex;overflow:hidden}.screen{flex-direction:column;flex:1;height:100%;display:flex;overflow:hidden}.screen-header{border-bottom:1px solid var(--border);background:var(--white);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.screen-header h2{color:var(--text);font-size:18px;font-weight:700}.screen-header .btn-primary{width:auto;padding:8px 16px}.screen-body{flex:1;padding:16px 20px;overflow-y:auto}.job-card{background:var(--white);border:1px solid var(--border);cursor:pointer;border-radius:8px;grid-template-columns:110px 120px 1fr auto;align-items:center;gap:12px;margin-bottom:10px;padding:14px 16px;transition:box-shadow .15s;display:grid}.job-card:hover{box-shadow:0 2px 8px #0000001a}.job-date{color:var(--text-muted);font-size:13px;font-weight:600}.job-time{color:var(--text-muted);font-size:13px}.job-title{font-weight:600}.job-location{color:var(--text-muted);font-size:13px}.job-status{text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;border-radius:12px;padding:3px 8px;font-size:11px;font-weight:700}.status-scheduled{color:#1d4ed8;background:#dbeafe}.status-confirmed{color:#166534;background:#dcfce7}.status-in-progress{color:#854d0e;background:#fef9c3}.status-completed{color:#475569;background:#f1f5f9}.status-cancelled{color:#991b1b;background:#fee2e2}.status-rescheduled{color:#5b21b6;background:#ede9fe}.status-no-access{color:#9a3412;background:#ffedd5}.loading,.empty,.error{text-align:center;color:var(--text-muted);padding:40px;font-size:15px}.error{color:var(--danger)}.header-actions{align-items:center;gap:10px;display:flex}.search-input{border:1px solid var(--border);background:var(--bg);border-radius:6px;outline:none;width:200px;padding:7px 12px;font-size:13px;transition:border-color .15s,background .15s}.search-input:focus{border-color:var(--brand);background:var(--white)}.maint-table{border-collapse:collapse;width:100%}.maint-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--bg);padding:10px 20px;font-size:11px;font-weight:700;position:sticky;top:0}.maint-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px 20px;font-size:13px}.maint-table tr.clickable{cursor:pointer;transition:background .1s}.maint-table tr.clickable:hover{background:var(--brand-light)}.maint-table .sub{color:var(--text-muted);font-size:12px;font-weight:400;display:block}.status-pill{text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;border-radius:12px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.pill-active{color:#166534;background:#dcfce7}.pill-paused{color:#854d0e;background:#fef9c3}.pill-closed{color:#475569;background:#f1f5f9}.drawer-overlay{z-index:100;background:#00000040;position:fixed;inset:0}.drawer{background:var(--white);z-index:101;flex-direction:column;width:400px;display:flex;position:fixed;top:0;bottom:0;right:0;box-shadow:-4px 0 24px #00000026}.drawer-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.drawer-header h3{font-size:16px;font-weight:700}.btn-icon{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:16px;line-height:1}.btn-icon:hover{background:var(--bg);color:var(--text)}.drawer-body{flex-direction:column;flex:1;gap:14px;padding:16px 20px;display:flex;overflow-y:auto}.drawer-footer{border-top:1px solid var(--border);flex-shrink:0;justify-content:flex-end;gap:8px;padding:14px 20px;display:flex}.drawer-footer .btn-primary,.drawer-footer .btn-secondary{width:auto}.form-group{flex-direction:column;gap:5px;display:flex}.form-group label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:700}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border);background:var(--white);color:var(--text);border-radius:6px;outline:none;padding:8px 10px;font-family:inherit;font-size:14px;transition:border-color .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--brand)}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background:var(--bg);cursor:default}.form-group textarea{resize:vertical}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.checkbox-group{flex-wrap:wrap;gap:8px;display:flex}.checkbox-label{cursor:pointer;border:1px solid var(--border);-webkit-user-select:none;user-select:none;border-radius:6px;align-items:center;gap:6px;padding:5px 10px;font-size:13px;transition:background .1s,border-color .1s;display:flex}.checkbox-label:hover:not(.disabled){background:var(--brand-light);border-color:var(--brand)}.checkbox-label.disabled{cursor:default;color:var(--text-muted)}#confirm-modal{z-index:500;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.confirm-box{background:var(--white);border-radius:10px;flex-direction:column;gap:12px;width:340px;padding:28px 24px;display:flex;box-shadow:0 8px 32px #0003}#confirm-title{font-size:16px;font-weight:700}#confirm-body{color:var(--text-muted);font-size:14px}.confirm-buttons{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.confirm-buttons button{cursor:pointer;border:none;border-radius:6px;padding:8px 20px;font-size:14px;font-weight:600}#confirm-cancel{background:var(--bg);color:var(--text)}#confirm-ok{background:var(--brand);color:var(--white)}.account-header{align-items:center;gap:16px;margin-bottom:28px;display:flex}.account-email{color:var(--text-muted);margin:0;font-size:14px}.sched-section{margin-bottom:32px}.sched-title{margin:0 0 12px;font-size:15px;font-weight:700}.sched-section-hdr{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.sched-section-hdr .sched-title{margin:0}.hours-table{border-collapse:collapse}.hours-table td{vertical-align:middle;padding:5px 8px}.hours-table .day-label{width:100px;font-size:14px;font-weight:500}.hours-table .time-sep{text-align:center;width:24px;color:var(--text-muted)}.hours-toggle{cursor:pointer;align-items:center;gap:6px;min-width:90px;font-size:13px;display:flex}.time-input{border:1px solid var(--border);background:var(--white);width:100px;color:var(--text);border-radius:6px;outline:none;padding:5px 8px;font-family:inherit;font-size:13px}.time-input:focus{border-color:var(--brand)}.hours-actions{align-items:center;gap:10px;margin-top:12px;display:flex}.saved-flash{color:#166534;font-size:13px;font-weight:500}.block-add-form{border:1px solid var(--border);background:#f8fafc;border-radius:8px;flex-direction:column;gap:12px;margin-bottom:12px;padding:16px;display:flex}.block-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 0;font-size:14px;display:flex}.block-row:last-child{border-bottom:none}
