@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";html,body,#root{width:100%;height:100%;overflow:hidden}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,sans-serif;background:#f4f5f7;color:#111827}.app{display:flex;height:100vh;overflow:hidden;position:relative}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:40}.sidebar-overlay.open{display:block}.sidebar{width:220px;display:flex;flex-direction:column;flex-shrink:0;transition:transform .25s ease;z-index:50}.logo-area{padding:20px 18px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between}.logo-text{font-size:20px;font-weight:700;color:#fff;letter-spacing:-.5px}.logo-badge{font-size:9px;font-weight:600;padding:2px 8px;border-radius:100px;width:fit-content;margin-top:6px;letter-spacing:.5px;text-transform:uppercase}.sidebar-close{display:none;background:none;border:none;color:#fff9;font-size:22px;cursor:pointer;padding:4px;line-height:1}.nav-section{padding:14px 12px 4px;font-size:9px;color:#ffffff4d;letter-spacing:1px;text-transform:uppercase;font-weight:600}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 14px;margin:1px 8px;border-radius:8px;cursor:pointer;color:#ffffff80;font-size:13px;font-weight:500;transition:all .15s}.nav-item:hover{background:#ffffff0f;color:#ffffffd9}.nav-spacer{flex:1}.user-area{padding:14px;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:10px;cursor:pointer}.user-av{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.user-name{font-size:12px;color:#fff;font-weight:600}.user-role{font-size:10px;color:#ffffff59}.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.topbar{background:#fff;border-bottom:1px solid #E5E7EB;padding:0 16px;height:56px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;gap:12px}.topbar-left{display:flex;align-items:center;gap:12px;min-width:0}.hamburger{display:none;background:none;border:none;cursor:pointer;padding:6px;border-radius:6px;color:#6b7280;flex-shrink:0}.hamburger:hover{background:#f3f4f6}.page-title{font-size:15px;font-weight:700;color:#0c2340;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.search-box{display:flex;align-items:center;gap:8px;background:#f9fafb;border:1px solid #E5E7EB;border-radius:8px;padding:7px 12px;font-size:13px;color:#9ca3af;width:200px}.content{flex:1;overflow-y:auto;padding:16px}.alert-strip{background:#fffbeb;border:1px solid #FCD34D;border-radius:8px;padding:10px 14px;margin-bottom:16px;display:flex;align-items:flex-start;gap:10px;font-size:13px;color:#92400e}.alert-link{margin-left:auto;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}.stat-card{background:#fff;border:1px solid #E5E7EB;border-radius:10px;padding:14px;position:relative;overflow:hidden}.stat-top{position:absolute;top:0;left:0;right:0;height:3px;border-radius:10px 10px 0 0}.stat-label{font-size:10px;color:#6b7280;font-weight:500;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.stat-value{font-size:22px;font-weight:700;color:#0c2340;letter-spacing:-.5px}.stat-sub{font-size:11px;color:#9ca3af;margin-top:3px}.two-col{display:grid;grid-template-columns:1fr 320px;gap:14px;margin-bottom:14px}.card{background:#fff;border:1px solid #E5E7EB;border-radius:10px;overflow:hidden}.card-hd{padding:12px 16px;border-bottom:1px solid #F3F4F6;display:flex;align-items:center;justify-content:space-between}.card-title{font-size:13px;font-weight:700;color:#0c2340}.card-action{font-size:12px;font-weight:600;cursor:pointer}.job-row{display:flex;align-items:center;gap:10px;padding:11px 16px;border-bottom:1px solid #F9FAFB}.job-row:last-child{border-bottom:none}.job-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.job-info{flex:1;min-width:0}.job-name{font-size:12px;font-weight:600;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.job-addr{font-size:11px;color:#9ca3af;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.job-time{font-size:11px;color:#6b7280;flex-shrink:0}.job-badge{font-size:10px;font-weight:700;padding:3px 9px;border-radius:100px;flex-shrink:0}.tech-row{display:flex;align-items:center;gap:10px;padding:9px 16px;border-bottom:1px solid #F9FAFB}.tech-row:last-child{border-bottom:none}.tech-av{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.tech-info{flex:1;min-width:0}.tech-name{font-size:12px;font-weight:600;color:#111827}.tech-sub{font-size:11px;color:#9ca3af}.tech-badge{font-size:10px;font-weight:700;padding:3px 9px;border-radius:100px;flex-shrink:0}.bar-section{padding:12px 16px}.bar-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}.bar-label{font-size:11px;color:#6b7280;width:28px;flex-shrink:0}.bar-track{flex:1;height:7px;background:#f3f4f6;border-radius:100px;overflow:hidden}.bar-fill{height:100%;border-radius:100px}.bar-val{font-size:11px;font-weight:600;color:#374151;width:46px;text-align:right;flex-shrink:0}.kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:14px 16px}.kpi{text-align:center}.kpi-val{font-size:20px;font-weight:700;color:#0c2340}.kpi-lbl{font-size:10px;color:#9ca3af;margin-top:2px}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f4f5f7;padding:16px}.login-card{background:#fff;border:1px solid #E5E7EB;border-radius:16px;padding:32px 28px;width:100%;max-width:400px;box-shadow:0 4px 24px #0000000f}.login-logo{font-size:28px;font-weight:700;color:#0c2340;margin-bottom:4px}.login-sub{font-size:13px;color:#9ca3af;margin-bottom:24px}.form-label{display:block;font-size:12px;font-weight:600;color:#374151;margin-bottom:6px}.form-input{width:100%;padding:10px 13px;background:#f9fafb;border:1px solid #E5E7EB;border-radius:8px;font-size:14px;color:#111827;outline:none;transition:border-color .2s;margin-bottom:14px}.form-input:focus{border-color:#0c2340;background:#fff}.btn-login{width:100%;padding:12px;background:#0c2340;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer}.btn-login:hover{background:#1a3a5c}.error-msg{color:#dc2626;font-size:13px;margin-bottom:12px}.coming-soon{display:flex;align-items:center;justify-content:center;height:60vh;flex-direction:column;gap:16px}@media (max-width: 1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}.two-col{grid-template-columns:1fr}.search-box{width:160px}}@media (max-width: 768px){.sidebar{position:fixed;top:0;left:0;height:100%;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-close{display:block}.hamburger{display:flex;align-items:center;justify-content:center}.search-box{display:none}.topbar{padding:0 12px}.page-title{font-size:14px}.content{padding:12px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:12px}.stat-value{font-size:18px}.stat-card{padding:12px}.two-col{grid-template-columns:1fr;gap:10px}.alert-strip{font-size:12px;flex-wrap:wrap}.alert-link{margin-left:0;margin-top:4px}.job-row{padding:10px 12px;gap:8px}.job-time{display:none}.kpi-val{font-size:16px}}@media (max-width: 400px){.stats-grid{grid-template-columns:1fr 1fr}.stat-value{font-size:16px}.login-card{padding:24px 18px}.kpi-row{grid-template-columns:1fr;gap:6px}.kpi{text-align:left;padding:6px 0;border-bottom:1px solid #F3F4F6}.kpi:last-child{border-bottom:none}}.sch-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:10px}.sch-week-nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.sch-nav-btn{background:#fff;border:1px solid #E5E7EB;border-radius:8px;padding:7px 12px;cursor:pointer;font-size:13px;font-weight:600;color:#374151;transition:background .15s;line-height:1}.sch-nav-btn:hover{background:#f3f4f6}.sch-week-label{font-size:13px;font-weight:600;color:#0c2340;white-space:nowrap}.btn-new-job{background:#0c2340;color:#fff;border:none;border-radius:8px;padding:9px 16px;font-size:13px;font-weight:700;cursor:pointer;flex-shrink:0}.btn-new-job:hover{background:#1a3a5c}.sch-grid{display:grid;grid-template-columns:repeat(7,1fr);background:#e5e7eb;border-radius:10px;overflow:hidden;border:1px solid #E5E7EB;gap:1px}.sch-day-col{background:#fff;min-height:160px;display:flex;flex-direction:column}.sch-day-hd{padding:8px 6px 6px;border-bottom:1px solid #E5E7EB;text-align:center;flex-shrink:0;background:#fafafa}.sch-day-today .sch-day-hd{background:#eff6ff}.sch-day-name{font-size:9px;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.sch-day-num{font-size:15px;font-weight:700;color:#111827;line-height:1.2;margin-top:1px}.sch-day-today .sch-day-num{color:#0c2340}.sch-today-dot{width:5px;height:5px;border-radius:50%;background:#e8a020;margin:2px auto 0}.sch-job-card{margin:4px 4px 0;padding:5px 7px;border-radius:6px;cursor:pointer;border-left:3px solid #D1D5DB;background:#f9fafb;transition:box-shadow .15s}.sch-job-card:last-of-type{margin-bottom:4px}.sch-job-card:hover{box-shadow:0 1px 6px #0000001a;background:#fff}.sch-job-time{font-size:9px;color:#6b7280;font-weight:600;line-height:1}.sch-job-client{font-size:11px;font-weight:700;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.sch-job-type{font-size:10px;color:#9ca3af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sch-job-tech{font-size:10px;color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.sch-job-pill{font-size:9px;font-weight:700;padding:2px 6px;border-radius:100px;display:inline-block;margin-top:3px}.sch-empty{color:#d1d5db;font-size:11px;text-align:center;padding:16px 4px}.sch-list{display:none}.sch-list-day{margin-bottom:16px}.sch-list-day-hd{font-size:11px;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;padding-bottom:6px;border-bottom:1px solid #E5E7EB;margin-bottom:8px;display:flex;align-items:center;gap:6px}.sch-list-job{background:#fff;border:1px solid #E5E7EB;border-radius:10px;padding:12px 14px;margin-bottom:6px;cursor:pointer;display:flex;align-items:center;gap:10px}.sch-list-job:hover{box-shadow:0 1px 4px #00000014}.sch-tech-filter{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.sch-tech-btn{padding:5px 13px;border-radius:100px;border:1.5px solid #E5E7EB;background:#fff;font-size:12px;font-weight:600;color:#6b7280;cursor:pointer;transition:all .15s;line-height:1}.sch-tech-btn:hover{border-color:#0c2340;color:#0c2340}.sch-tech-btn.active{background:#0c2340;border-color:#0c2340;color:#fff}.sch-summary{display:flex;align-items:center;background:#fff;border:1px solid #E5E7EB;border-radius:10px;padding:10px 20px;margin-bottom:14px;gap:0}.sch-summary-stat{display:flex;flex-direction:column;align-items:center;flex:1;padding:4px 0}.sch-summary-num{font-size:22px;font-weight:700;color:#0c2340;line-height:1}.sch-summary-lbl{font-size:10px;color:#9ca3af;margin-top:2px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.sch-summary-div{width:1px;height:36px;background:#e5e7eb;flex-shrink:0}.sch-unassigned-strip{background:#fffbeb;border:1px solid #FDE68A;border-radius:10px;margin-bottom:12px;overflow:hidden}.sch-unassigned-hd{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;-webkit-user-select:none;user-select:none}.sch-unassigned-hd:hover{background:#fef9c3}.sch-job-addr{font-size:9px;color:#9ca3af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.dispatch-row{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:#fff;border:1px solid #F3F4F6;border-radius:10px;margin-bottom:6px;cursor:pointer;transition:box-shadow .15s,border-color .15s}.dispatch-row:hover{box-shadow:0 2px 8px #0000000f;border-color:#e5e7eb}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:100;display:flex;align-items:center;justify-content:center;padding:16px}.modal-box{background:#fff;border-radius:14px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.modal-hd{padding:16px 20px;border-bottom:1px solid #E5E7EB;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:#fff;z-index:1;border-radius:14px 14px 0 0}.modal-title{font-size:15px;font-weight:700;color:#0c2340}.modal-close{background:none;border:none;font-size:18px;cursor:pointer;color:#9ca3af;padding:4px 7px;border-radius:6px;line-height:1}.modal-close:hover{background:#f3f4f6;color:#374151}.modal-body{padding:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-group{display:flex;flex-direction:column}.form-select{width:100%;padding:10px 13px;background:#f9fafb;border:1px solid #E5E7EB;border-radius:8px;font-size:14px;color:#111827;outline:none;cursor:pointer;margin-bottom:14px;font-family:inherit}.form-select:focus{border-color:#0c2340;background:#fff}.form-textarea{width:100%;padding:10px 13px;background:#f9fafb;border:1px solid #E5E7EB;border-radius:8px;font-size:14px;color:#111827;outline:none;resize:vertical;min-height:80px;font-family:inherit;margin-bottom:14px}.form-textarea:focus{border-color:#0c2340;background:#fff}.modal-footer{padding:14px 20px;border-top:1px solid #E5E7EB;display:flex;gap:8px;justify-content:flex-end}.btn-primary{background:#0c2340;color:#fff;border:none;border-radius:8px;padding:10px 20px;font-size:13px;font-weight:700;cursor:pointer}.btn-primary:hover{background:#1a3a5c}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-ghost{background:#f3f4f6;color:#374151;border:none;border-radius:8px;padding:10px 16px;font-size:13px;font-weight:600;cursor:pointer}.btn-ghost:hover{background:#e5e7eb}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.detail-label{font-size:10px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.detail-value{font-size:13px;color:#111827;font-weight:500}.status-flow{display:flex;gap:6px;flex-wrap:wrap;padding-top:12px}.status-btn{padding:7px 12px;border-radius:8px;border:1.5px solid #E5E7EB;font-size:12px;font-weight:700;cursor:pointer;background:#fff;transition:all .15s;color:#374151}.status-btn:hover{border-color:#0c2340;color:#0c2340}@media (max-width:768px){.sch-grid{display:none}.sch-list{display:block}.form-row,.detail-grid{grid-template-columns:1fr}.modal-backdrop{align-items:flex-end;padding:0}.modal-box{max-width:100%;border-radius:14px 14px 0 0;max-height:88vh}.modal-hd{border-radius:14px 14px 0 0}.modal-footer{border-radius:0}.sch-week-label{font-size:12px}}.sett-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.sett-type-btn{flex:1;padding:14px 12px;border:2px solid #E5E7EB;border-radius:10px;cursor:pointer;font-family:inherit;font-weight:600;font-size:13px;background:#f9fafb;color:#6b7280;transition:all .15s;text-align:center}.sett-type-btn.active{background:#eff6ff;border-color:#0c2340;color:#0c2340}.sett-type-emoji{font-size:22px;margin-bottom:6px}.sett-type-desc{font-size:11px;font-weight:400;margin-top:3px;color:#9ca3af}.sett-type-btn.active .sett-type-desc{color:#374151}.sett-toggle{position:relative;display:inline-block;width:40px;height:22px;flex-shrink:0;cursor:pointer}.sett-toggle input{opacity:0;width:0;height:0;position:absolute}.sett-toggle-track{position:absolute;top:0;right:0;bottom:0;left:0;background:#d1d5db;border-radius:22px;transition:background .2s;cursor:pointer}.sett-toggle input:checked+.sett-toggle-track{background:#0c2340}.sett-toggle-track:before{content:"";position:absolute;width:16px;height:16px;background:#fff;border-radius:50%;top:3px;left:3px;transition:transform .2s;box-shadow:0 1px 3px #0003}.sett-toggle input:checked+.sett-toggle-track:before{transform:translate(18px)}.sett-success{color:#059669;font-size:13px;font-weight:600;margin-bottom:12px}@media (max-width:600px){.sett-grid{grid-template-columns:1fr}}
