@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";html,body,#root{width:100%;height:100%;overflow:auto;overscroll-behavior-y:auto}@media (max-width: 768px){html,body{overflow-x:hidden;-webkit-tap-highlight-color:transparent}}*{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%}body{font-family:Inter,system-ui,sans-serif;background:#f4f5f7;color:#111827;font-size:14px;line-height:1.5}@media (max-width:768px){html,body{overflow-x:hidden}}.app{display:flex;position:relative;height:100%;width:100%}@media (max-width:768px){.app{display:flex}}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:40}.sidebar-overlay.open{display:block}.ptr-indicator{position:fixed;top:-44px;left:50%;width:36px;height:36px;background:#fff;border-radius:50%;box-shadow:0 2px 10px #0c23402e;display:none;align-items:center;justify-content:center;opacity:0;z-index:35;pointer-events:none;transform:translate(-50%);transition:opacity .2s ease,transform .28s cubic-bezier(.2,.8,.2,1)}.ptr-spinner{width:20px;height:20px;border:2.5px solid #E5E7EB;border-top-color:#e8a020;border-radius:50%;transition:transform .1s linear}.ptr-indicator.ptr-refreshing .ptr-spinner{animation:ptr-spin .8s linear infinite;transition:none}@keyframes ptr-spin{to{transform:rotate(360deg)}}@keyframes toastFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes addonCardIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.upgrade-options-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media (max-width:640px){.upgrade-options-grid{grid-template-columns:1fr}}.addon-modules-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}@media (max-width:640px){.addon-modules-grid{grid-template-columns:1fr}}@media (max-width:768px){.ptr-indicator{display:flex}}.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;min-width:0;height:100%;min-height: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}@media (max-width:768px){.topbar{position:sticky;top:0;z-index:30}}.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;padding:16px;overflow-y:auto;-webkit-overflow-scrolling:touch;height:100%;min-height:0;touch-action:pan-y;overscroll-behavior-y:contain}.topbar-icon-btn{width:34px;height:34px;border-radius:8px;border:1.5px solid #E5E7EB;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;color:#6b7280;transition:all .15s}.topbar-icon-btn:hover{background:#fef2f2;border-color:#dc2626;color:#dc2626}.topbar-avatar{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;-webkit-user-select:none;user-select:none}@media (max-width:768px){.topbar-icon-btn,.topbar-avatar{width:40px;height:40px}.topbar-avatar{font-size:12px}}.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}.invoices-list-wrap{touch-action:pan-y}.inv-cards,.q-cards{display:none}@media (max-width:768px){.invoices-list-wrap{overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;touch-action:pan-y}.invoices-list-wrap table{min-width:0}.inv-table,.q-table{display:none}.inv-cards,.q-cards{display:block}}.aging-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}@media (max-width:900px){.aging-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:600px){.aging-grid{grid-template-columns:repeat(2,1fr)}}.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:14px;color:#9ca3af;margin-bottom:24px}.form-label{display:block;font-size:13px;font-weight:600;color:#374151;margin-bottom:6px}.form-input{width:100%;padding:11px 13px;background:#f9fafb;border:1px solid #E5E7EB;border-radius:8px;font-size:16px;color:#111827;outline:none;transition:border-color .2s;margin-bottom:14px}.form-input:focus{border-color:#0c2340;background:#fff}.btn-login{width:100%;padding:13px;background:#0c2340;color:#fff;border:none;border-radius:8px;font-size:15px;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;min-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){button{min-height:44px}input,textarea,select,.form-input,.form-select,.form-textarea{font-size:16px}.sidebar{position:fixed;top:0;left:0;height:100vh;transform:translate(-100%);overflow-y:auto}.sidebar.open{transform:translate(0)}.sidebar-close{display:block;min-height:auto;padding:6px 8px}.nav-item{font-size:15px;padding:12px 14px}.nav-section{font-size:10px;padding:14px 12px 4px}.user-name{font-size:13px}.user-role{font-size:11px}.hamburger{display:flex;align-items:center;justify-content:center;min-height:44px;width:44px;height:44px;padding:8px;margin-left:-6px}.search-box{display:none}.topbar{padding:0 12px;gap:8px}.page-title{font-size:15px}.content{padding:14px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:14px}.stat-value{font-size:22px;letter-spacing:-.5px;word-break:break-word}.stat-label{font-size:11px}.stat-sub{font-size:12px}.stat-card{padding:14px 12px}.two-col{grid-template-columns:1fr;gap:12px}.alert-strip{font-size:13px;flex-wrap:wrap;padding:12px 14px}.alert-link{margin-left:0;margin-top:4px}.job-row{padding:12px;gap:10px;min-height:56px}.job-time{display:none}.job-name{font-size:13px}.job-addr{font-size:12px}.job-badge{font-size:11px;padding:4px 10px}.tech-row{padding:12px;gap:10px;min-height:56px}.tech-av{width:34px;height:34px;font-size:12px}.tech-name{font-size:13px}.tech-sub{font-size:12px}.tech-badge{font-size:11px;padding:4px 10px}.card-hd{padding:14px 16px}.card-title{font-size:14px}.card-action{font-size:13px}.kpi-row{padding:16px}.kpi-val{font-size:20px;letter-spacing:-.3px}.kpi-lbl{font-size:11px}.bar-label{font-size:12px;width:32px}.bar-val{font-size:12px;width:60px}.form-label{font-size:13px}.form-input,.form-select,.form-textarea{padding:12px 13px}.modal-body{padding:18px}.modal-title{font-size:16px}.btn-primary,.btn-ghost,.btn-new-job,.sch-nav-btn{min-height:44px;font-size:14px}.status-btn{min-height:40px;font-size:13px;padding:9px 14px}.card,.two-col,.stats-grid{max-width:100%}}@media (max-width: 400px){.stats-grid{grid-template-columns:1fr 1fr;gap:8px}.stat-value{font-size:19px}.stat-card{padding:12px 10px}.login-card{padding:24px 20px}.kpi-row{grid-template-columns:1fr;gap:6px}.kpi{text-align:left;padding:8px 0;border-bottom:1px solid #F3F4F6;display:flex;justify-content:space-between;align-items:baseline}.kpi:last-child{border-bottom:none}.kpi-val{font-size:18px}}.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-month{background:#fff;border:1px solid #E5E7EB;border-radius:12px;overflow:hidden}.sch-month-hdrow{display:grid;grid-template-columns:repeat(7,1fr);background:#fafafa;border-bottom:1px solid #E5E7EB}.sch-month-hdcell{padding:10px 6px;text-align:center;font-size:11px;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.6px}.sch-month-grid{display:grid;grid-template-columns:repeat(7,1fr);background:#e5e7eb;gap:1px}.sch-month-cell{background:#fff;min-height:96px;padding:8px 8px 10px;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:flex-start;gap:6px;font-family:inherit;text-align:left;transition:background .12s;position:relative}.sch-month-cell:hover{background:#f9fafb}.sch-month-cell.out{background:#fafafa}.sch-month-cell.out .sch-month-daynum{color:#d1d5db}.sch-month-cell.today .sch-month-daynum{background:#0c2340;color:#fff;width:26px;height:26px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}.sch-month-cell.sel{background:#eff6ff}.sch-month-cell.sel.today .sch-month-daynum{background:#e8a020}.sch-month-daynum{font-size:14px;font-weight:700;color:#111827;line-height:1}.sch-month-badge{display:inline-flex;align-items:center;gap:5px;background:#eff6ff;border:1px solid #BFDBFE;color:#1e40af;border-radius:100px;padding:2px 8px;font-size:11px;font-weight:700;line-height:1}.sch-month-dot{width:6px;height:6px;border-radius:50%;background:#2563eb;display:inline-block}.sch-month-count{font-size:11px;font-weight:700;line-height:1}.sch-job-pill{font-size:9px;font-weight:700;padding:2px 6px;border-radius:100px;display:inline-block}.sch-job-addr{font-size:9px;color:#9ca3af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.sch-dayview{margin-top:4px}.sch-dayview-hd{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:10px 12px;background:#fff;border:1px solid #E5E7EB;border-radius:10px;margin-bottom:12px}.sch-dayview-title{flex:1;min-width:0;font-size:14px;font-weight:700;color:#0c2340}.sch-dayview-empty{text-align:center;padding:48px 16px;color:#9ca3af;font-size:13px;background:#f9fafb;border:1px dashed #E5E7EB;border-radius:12px}.sch-dayview-list{display:flex;flex-direction:column;gap:10px}.sch-dayview-card{background:#fff;border:1px solid #E5E7EB;border-left:4px solid #D1D5DB;border-radius:12px;padding:12px 14px;cursor:pointer;transition:box-shadow .15s,transform .1s}.sch-dayview-card:hover{box-shadow:0 2px 10px #0000000f}.sch-dayview-card:active{transform:scale(.99)}.sch-dayview-card-top{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px}.sch-dayview-card-time{font-size:14px;font-weight:700;color:#0c2340}.sch-dayview-card-client{font-size:15px;font-weight:700;color:#111827;line-height:1.3}.sch-dayview-card-type{font-size:12px;color:#6b7280;margin-top:3px}.sch-dayview-card-meta{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:6px;font-size:12px;color:#6b7280}.sch-dayview-advance{margin-top:10px;width:100%;padding:8px 10px;border-radius:8px;border:1.5px solid currentColor;background:#fff;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit}.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-conflict-banner{display:flex;align-items:center;gap:10px;background:#fef3c7;border:1px solid #FDE68A;border-radius:10px;padding:10px 14px;margin-bottom:12px}.sch-conflict-banner-ico{font-size:18px;flex-shrink:0}.sch-month-conflict{position:absolute;top:4px;right:6px;font-size:13px;line-height:1;color:#dc2626;font-weight:700;pointer-events:none}.sch-cols-wrap{margin-top:4px}.sch-cols-count{font-weight:500;color:#6b7280;font-size:12px;margin-left:6px}.sch-cols{background:#fff;border:1px solid #E5E7EB;border-radius:12px;overflow:auto;max-width:100%}.sch-cols-hdrow{display:grid;background:#fafafa;border-bottom:1px solid #E5E7EB;position:sticky;top:0;z-index:2;min-width:max-content}.sch-cols-corner{border-right:1px solid #E5E7EB}.sch-cols-hdtech{padding:10px 12px;border-right:1px solid #E5E7EB;display:flex;flex-direction:column;gap:2px;min-width:140px}.sch-cols-hdtech:last-child{border-right:none}.sch-cols-hdtech-name{font-size:13px;font-weight:700;color:#0c2340;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sch-cols-hdtech-count{font-size:11px;color:#9ca3af;font-weight:500}.sch-cols-hdtech.conflict .sch-cols-hdtech-name:after{content:" ⚠";color:#dc2626}.sch-cols-body{display:grid;position:relative;min-width:max-content}.sch-cols-hours{border-right:1px solid #E5E7EB;background:#fafafa;display:flex;flex-direction:column}.sch-cols-hour{border-top:1px solid #E5E7EB;background:none;padding:4px 0 0 8px;display:flex;align-items:flex-start;justify-content:flex-start;cursor:pointer;font-family:inherit;border-left:none;border-right:none;border-bottom:none;transition:background .15s}.sch-cols-hour:first-child{border-top:none}.sch-cols-hour:hover{background:#f3f4f6}.sch-cols-hour-lbl{font-size:11px;font-weight:600;color:#6b7280;line-height:1}.sch-cols-col{position:relative;border-right:1px solid #E5E7EB;min-width:140px}.sch-cols-col:last-child{border-right:none}.sch-cols-slot{border-top:1px dashed #E5E7EB;cursor:pointer;transition:background .15s}.sch-cols-slot:first-child{border-top:none}.sch-cols-slot:hover{background:#f9fafb}.sch-cols-job{position:absolute;border-radius:6px;padding:4px 6px 3px;font-size:11px;line-height:1.25;color:#111827;cursor:pointer;overflow:hidden;box-shadow:0 1px 2px #0000000f;transition:box-shadow .15s}.sch-cols-job:hover{box-shadow:0 4px 10px #0000001a;z-index:3}.sch-cols-job.conflict{outline:2px dashed #DC2626;outline-offset:-2px}.sch-cols-job-time{font-size:10px;font-weight:700;opacity:.85}.sch-cols-job-client{font-weight:700;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sch-cols-job-type{font-size:10px;opacity:.75;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sch-hour-panel{background:#fff;border-radius:14px;width:min(460px,100%);max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000040;overflow:hidden}.sch-hour-panel-hd{padding:16px 20px;border-bottom:1px solid #F3F4F6;display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.sch-hour-panel-small{font-size:11px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.6px}.sch-hour-panel-title{font-size:16px;font-weight:700;color:#0c2340;margin-top:3px}.sch-hour-panel-body{padding:10px;overflow-y:auto;display:flex;flex-direction:column;gap:6px}.sch-hour-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;border:1px solid #E5E7EB;background:#fff}.sch-hour-row.free{background:#ecfdf5;border-color:#a7f3d0}.sch-hour-row.blocked{background:#fef2f2;border-color:#fecaca}.sch-hour-row-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.sch-hour-row-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.sch-hour-row.free .sch-hour-row-dot{background:#059669}.sch-hour-row.blocked .sch-hour-row-dot{background:#dc2626}.sch-hour-row-name{font-size:13px;font-weight:700;color:#111827;line-height:1.2}.sch-hour-row-sub{font-size:11px;color:#6b7280;margin-top:2px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sch-hour-row-btn{background:#0c2340;color:#fff;border:none;border-radius:7px;padding:6px 12px;font-size:11px;font-weight:700;cursor:pointer;font-family:inherit;flex-shrink:0}.sch-hour-row-btn:hover{background:#1a3a5c}.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){.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;display:flex;flex-direction:column}.modal-hd{border-radius:14px 14px 0 0}.modal-body{flex:1 1 auto;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:16px}.modal-footer,.modal-actions{position:sticky;bottom:0;background:#fff;z-index:2;padding:12px 16px;border-top:1px solid #E5E7EB;border-radius:0;box-shadow:0 -4px 12px #0000000f;display:flex;gap:8px}.modal-footer>button,.modal-actions>button{flex:1;min-height:48px;font-size:14px;padding:12px 16px}.sch-week-label{font-size:12px}.sch-month-cell{min-height:64px;padding:6px 4px 7px;gap:4px}.sch-month-daynum{font-size:13px}.sch-month-cell.today .sch-month-daynum{width:22px;height:22px;font-size:12px}.sch-month-badge{padding:1px 6px;font-size:10px}.sch-month-dot{width:5px;height:5px}.sch-month-hdcell{padding:8px 2px;font-size:10px;letter-spacing:.3px}.sch-dayview-hd{padding:10px;gap:8px}.sch-dayview-title{flex:1 1 100%;order:-1;font-size:13px}}.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}}:root{--opi-navy:#0D2B5E;--opi-navy-soft:#1B3B7A;--opi-gold:#FAC775;--opi-bg:#FFFFFF;--opi-bubble-bg:#F4F5F7;--opi-border:#E5E7EB;--opi-text:#0F172A;--opi-muted:#6B7280}.opi-fab{position:fixed;bottom:20px;right:20px;z-index:1000;width:60px;height:60px;border-radius:50%;background:var(--opi-navy);color:var(--opi-gold);border:none;cursor:pointer;box-shadow:0 8px 32px #0d2b5e47;display:flex;align-items:center;justify-content:center;flex-direction:column;transition:transform .15s ease,box-shadow .15s ease}.opi-fab:hover{transform:translateY(-2px);box-shadow:0 12px 36px #0d2b5e57}.opi-fab:focus-visible{outline:3px solid var(--opi-gold);outline-offset:2px}.opi-fab-icon{display:flex;line-height:0}.opi-fab-badge{position:absolute;bottom:4px;font-size:9px;font-weight:700;letter-spacing:.5px;color:#fff;text-transform:uppercase}.opi-fab-dot{position:absolute;top:6px;right:6px;width:12px;height:12px;border-radius:50%;background:#ef4444;border:2px solid var(--opi-navy)}.opi-panel{position:fixed;bottom:20px;right:20px;z-index:1000;width:380px;height:600px;max-height:calc(100vh - 40px);background:var(--opi-bg);border-radius:14px;box-shadow:0 8px 32px #0d2b5e2e;display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--opi-border);font-family:Inter,system-ui,sans-serif}@media (max-width:480px){.opi-panel{top:0;left:0;bottom:0;right:0;width:100vw;height:100vh;max-height:100vh;border-radius:0;border:none}}.opi-header{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--opi-navy);color:#fff}.opi-avatar{width:36px;height:36px;border-radius:50%;background:var(--opi-gold);color:var(--opi-navy);font-weight:700;font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.opi-header-main{flex:1;min-width:0}.opi-header-title{font-weight:700;font-size:15px;line-height:1.1}.opi-header-status{display:flex;align-items:center;gap:6px;font-size:11px;color:#ffffffbf;margin-top:2px}.opi-status-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 2px #22c55e40}.opi-icon-btn{background:transparent;border:none;color:#fff;cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center;justify-content:center}.opi-icon-btn:hover{background:#ffffff1f}.opi-icon-btn:focus-visible{outline:2px solid var(--opi-gold);outline-offset:1px}.opi-chat{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px;background:#fafbfc}.opi-msg{display:flex;flex-direction:column;max-width:85%}.opi-msg--user{align-self:flex-end;align-items:flex-end}.opi-msg--assistant{align-self:flex-start;align-items:flex-start}.opi-msg-bubble{padding:10px 12px;border-radius:12px;font-size:14px;line-height:1.45;word-wrap:break-word;overflow-wrap:anywhere;white-space:pre-wrap}.opi-msg--user .opi-msg-bubble{background:var(--opi-navy);color:#fff;border-bottom-right-radius:4px}.opi-msg--assistant .opi-msg-bubble{background:var(--opi-bubble-bg);color:var(--opi-text);border-bottom-left-radius:4px}.opi-msg-line{margin:0}.opi-msg-line+.opi-msg-line{margin-top:6px}.opi-typing{display:inline-flex;gap:4px;padding:12px 14px;min-width:48px}.opi-typing-dot{width:6px;height:6px;border-radius:50%;background:var(--opi-muted);animation:opi-bounce 1s infinite ease-in-out}.opi-typing-dot:nth-child(2){animation-delay:.15s}.opi-typing-dot:nth-child(3){animation-delay:.3s}@keyframes opi-bounce{0%,80%,to{transform:translateY(0);opacity:.4}40%{transform:translateY(-4px);opacity:1}}.opi-msg-actions{display:flex;gap:4px;margin-top:4px;padding-left:2px}.opi-fb{background:transparent;border:1px solid var(--opi-border);padding:2px 6px;border-radius:6px;cursor:pointer;font-size:12px;line-height:1;opacity:.6;transition:opacity .15s ease,background .15s ease}.opi-fb:hover{opacity:1;background:#fff}.opi-fb:disabled{cursor:default}.opi-fb--active{opacity:1;background:var(--opi-gold);border-color:var(--opi-gold)}.opi-suggestions{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;padding-left:2px}.opi-chip{background:#fff;border:1px solid var(--opi-border);color:var(--opi-navy);padding:6px 10px;border-radius:999px;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .15s ease,border-color .15s ease}.opi-chip:hover{background:var(--opi-gold);border-color:var(--opi-gold);color:var(--opi-navy)}.opi-action{margin-top:10px;padding-left:2px}.opi-nav-btn{display:inline-flex;align-items:center;gap:6px;background:var(--opi-gold);color:var(--opi-navy);border:none;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:700;cursor:pointer;transition:filter .15s ease,transform .1s ease}.opi-nav-btn:hover{filter:brightness(1.08);transform:translateY(-1px)}.opi-nav-btn:active{transform:translateY(0)}.opi-error{margin:0 14px;padding:8px 10px;background:#fee2e2;color:#991b1b;border-radius:8px;font-size:12px;line-height:1.4}.opi-footer{border-top:1px solid var(--opi-border);padding:10px 12px 12px;background:#fff}.opi-input-wrap{display:flex;align-items:flex-end;gap:8px;border:1px solid var(--opi-border);border-radius:12px;padding:6px 6px 6px 10px;background:#fff;transition:border-color .15s ease,box-shadow .15s ease}.opi-input-wrap:focus-within{border-color:var(--opi-navy);box-shadow:0 0 0 3px #0d2b5e14}.opi-input{flex:1;border:none;outline:none;resize:none;font-family:inherit;font-size:14px;line-height:1.4;color:var(--opi-text);background:transparent;max-height:120px;padding:6px 0}.opi-send{width:34px;height:34px;border-radius:50%;border:none;cursor:pointer;background:var(--opi-gold);color:var(--opi-navy);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s ease,transform .1s ease}.opi-send:hover:not(:disabled){background:#f9be5c}.opi-send:active{transform:scale(.95)}.opi-send:disabled{background:var(--opi-border);color:var(--opi-muted);cursor:default}.opi-footer-hint{font-size:10px;color:var(--opi-muted);text-align:center;margin-top:6px}.opi-chat::-webkit-scrollbar{width:8px}.opi-chat::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.opi-chat::-webkit-scrollbar-thumb:hover{background:#9ca3af}.opi-confirm-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;background:#0d2b5e8c;display:flex;align-items:center;justify-content:center;border-radius:14px}.opi-confirm-box{background:#fff;border-radius:12px;padding:24px 20px;width:calc(100% - 48px);max-width:300px;box-shadow:0 4px 24px #0d2b5e47;text-align:center}.opi-confirm-msg{font-size:14px;line-height:1.55;color:var(--opi-text);margin:0 0 20px}.opi-confirm-actions{display:flex;gap:10px}.opi-confirm-btn{flex:1;padding:9px 0;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s ease}.opi-confirm-btn:hover{opacity:.85}.opi-confirm-btn--cancel{background:var(--opi-border);color:var(--opi-text)}.opi-confirm-btn--close{background:#ef4444;color:#fff}.opi-fab{cursor:grab}.opi-fab:active{cursor:grabbing}.dash-two-col{display:grid;grid-template-columns:1fr;gap:14px;margin-bottom:14px}.dash-col-main,.dash-col-side{display:flex;flex-direction:column;gap:14px}.dash-activity-inner{padding:12px 16px;overflow-y:auto;max-height:420px}@media (min-width:1025px){.stat-value{font-size:2.5rem;letter-spacing:-1px}.stat-card{padding:20px 22px}.stat-sub{margin-top:6px;font-size:12px}.dash-two-col{grid-template-columns:60fr 40fr;align-items:start}.dash-col-side{position:sticky;top:16px;max-height:calc(100vh - 80px);overflow-y:auto}}
