:root{--navy:#0a2657;--navy-light:#0d2f6b;--navy-hover:#ffffff14;--blue:#1589ee;--blue-hover:#0f6fd4;--teal:#00a1e0;--bg:#f4f6f9;--card-bg:#fff;--border:#e1e7ef;--border-dark:#c8d0dc;--text-main:#1a1f36;--text-sub:#6b7280;--text-light:#9ca3af;--shadow:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-md:0 4px 12px #0000001a, 0 2px 6px #0000000f;--shadow-lg:0 8px 24px #0000001f, 0 4px 8px #00000014;--radius:8px;--radius-sm:4px;--radius-lg:12px;--sidebar-width:240px;--topbar-height:60px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{color:var(--text-main);background:var(--bg);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5}h1{color:var(--text-main);font-size:22px;font-weight:700}h2{color:var(--text-main);font-size:18px;font-weight:600}h3{color:var(--text-main);font-size:15px;font-weight:600}h4{color:var(--text-main);font-size:13px;font-weight:600}a{color:var(--blue);text-decoration:none}a:hover{text-decoration:underline}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:1px solid #0000;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:500;line-height:1.4;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue)}.btn-primary:hover:not(:disabled){background:var(--blue-hover);border-color:var(--blue-hover)}.btn-ghost{color:var(--text-main);border-color:var(--border);background:#fff}.btn-ghost:hover:not(:disabled){background:var(--bg)}.btn-danger{color:#fff;background:#ef4444;border-color:#ef4444}.btn-danger:hover:not(:disabled){background:#dc2626;border-color:#dc2626}.btn-sm{padding:5px 10px;font-size:12px}.btn-lg{padding:10px 20px;font-size:14px}.form-group{flex-direction:column;gap:5px;display:flex}.form-label{color:var(--text-sub);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:600}.form-input,.form-select,.form-textarea{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-main);background:#fff;outline:none;padding:8px 12px;font-family:inherit;font-size:14px;transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px #1589ee1f}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-light)}.form-textarea{resize:vertical;min-height:100px;line-height:1.6}.form-textarea.tall{min-height:120px}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-grid-3{grid-template-columns:1fr 1fr 1fr;gap:16px;display:grid}.card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border)}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.card-body{padding:20px}.table-wrapper{border-radius:var(--radius);border:1px solid var(--border);background:var(--card-bg);box-shadow:var(--shadow);overflow-x:auto}table{border-collapse:collapse;width:100%}thead tr{background:var(--bg);border-bottom:2px solid var(--border)}th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-sub);white-space:nowrap;padding:10px 16px;font-size:11px;font-weight:600}td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px 16px;font-size:13px}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:#f8fafc}tbody tr{transition:background .1s}.app-shell{height:100vh;display:flex;overflow:hidden}.main-area{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.page-content{flex:1;padding:24px;overflow-y:auto}.page-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.page-title{flex-direction:column;gap:2px;display:flex}.page-subtitle{color:var(--text-sub);font-size:13px}.spinner{border:2px solid var(--border);border-top-color:var(--blue);border-radius:50%;flex-shrink:0;width:20px;height:20px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{color:var(--text-sub);justify-content:center;align-items:center;gap:12px;padding:60px;display:flex}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#a0aec0}.sidebar-backdrop{display:none}@media (width<=768px){.sidebar-backdrop{z-index:199;background:#0a265773;display:block;position:fixed;inset:0}.page-content{padding:16px}.form-row,.form-grid-3{grid-template-columns:1fr}.page-header{flex-wrap:wrap;gap:10px}.modal-overlay{align-items:flex-end;padding:16px 8px}.modal-panel{border-radius:var(--radius-lg) var(--radius-lg) 0 0}}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--navy);z-index:200;flex-direction:column;height:100vh;transition:transform .25s;display:flex;overflow:hidden}@media (width<=768px){.sidebar{box-shadow:var(--shadow-lg);position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.sidebar-open{transform:translate(0)}}.sidebar-brand{border-bottom:1px solid #ffffff1a;align-items:center;gap:10px;padding:20px 16px 16px;display:flex}.sidebar-logo{object-fit:contain;flex-shrink:0;width:40px;height:40px}.sidebar-brand-text{flex-direction:column;gap:1px;display:flex}.sidebar-name{color:#fff;letter-spacing:-.01em;font-size:15px;font-weight:700}.sidebar-tagline{color:var(--teal);text-transform:uppercase;letter-spacing:.1em;font-size:10px;font-weight:600}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 8px;display:flex;overflow-y:auto}.sidebar-link{color:#ffffffa6;border-radius:6px;align-items:center;gap:10px;padding:9px 10px;font-size:13px;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex;position:relative}.sidebar-link:hover{background:var(--navy-hover);color:#ffffffe6;text-decoration:none}.sidebar-link.active{color:#fff;border-left:2px solid var(--blue);background:#1589ee2e;padding-left:8px}.sidebar-link svg{opacity:.85;flex-shrink:0}.sidebar-link.active svg{opacity:1}.sidebar-badge{color:#fff;text-align:center;background:#ef4444;border-radius:10px;min-width:18px;margin-left:auto;padding:1px 6px;font-size:10px;font-weight:700;line-height:16px}.sidebar-footer{border-top:1px solid #ffffff14;padding:12px 16px}.sidebar-version{color:#ffffff4d;font-size:11px}.topbar{height:var(--topbar-height);background:var(--card-bg);border-bottom:1px solid var(--border);box-shadow:var(--shadow);z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 24px;display:flex}.topbar-left{align-items:center;gap:10px;display:flex}.topbar-hamburger{cursor:pointer;color:var(--text-main);border-radius:var(--radius-sm);background:0 0;border:none;flex-shrink:0;padding:4px;display:none}.topbar-hamburger:hover{background:var(--bg)}@media (width<=768px){.topbar-hamburger{align-items:center;display:flex}.topbar-email{display:none}}.topbar-title{color:var(--text-main);font-size:17px;font-weight:600}.topbar-right{align-items:center;gap:12px;display:flex}.topbar-user{align-items:center;gap:8px;display:flex}.topbar-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:700;display:flex}.topbar-email{color:var(--text-sub);text-overflow:ellipsis;white-space:nowrap;max-width:200px;font-size:13px;overflow:hidden}.login-page{background:var(--navy);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:400px;padding:40px 36px}.login-logo{text-align:center;margin-bottom:28px}.login-logo-img{object-fit:contain;width:80px;height:80px;margin:0 auto 12px;display:block}.login-title{color:var(--navy);margin-bottom:4px;font-size:24px;font-weight:700}.login-subtitle{color:var(--text-sub);font-size:13px}.login-form{flex-direction:column;gap:16px;display:flex}.login-error{color:#dc2626;border-radius:var(--radius-sm);background:#fef2f2;border:1px solid #fca5a5;padding:10px 14px;font-size:13px}.login-btn{justify-content:center;width:100%;margin-top:4px}.login-footer{text-align:center;color:var(--text-light);margin-top:24px;font-size:11px}.avatar{color:#fff;-webkit-user-select:none;user-select:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.badge{white-space:nowrap;letter-spacing:.02em;border:1px solid #0000;border-radius:12px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:60px 24px;display:flex}.empty-emoji{margin-bottom:8px;font-size:48px;line-height:1}.empty-title{color:var(--text-main);font-size:16px;font-weight:600}.empty-subtitle{color:var(--text-sub);max-width:320px;font-size:13px;line-height:1.6}.empty-action{margin-top:8px}.empty-logo{object-fit:contain;opacity:1;width:120px;height:120px;margin-bottom:8px}.bulk-checkbox{cursor:pointer;width:15px;height:15px;accent-color:var(--blue)}.row-selected{background:#1589ee0f!important}.bulk-toolbar{background:var(--navy);border-radius:var(--radius);flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:8px;padding:8px 12px;display:flex}.bulk-count{color:#fff;white-space:nowrap;margin-right:4px;font-size:13px;font-weight:600}.bulk-select{color:#fff;cursor:pointer;-webkit-text-fill-color:#fff;background:#ffffff26;border:1px solid #ffffff40;border-radius:5px;height:30px;padding:0 8px;font-size:12px}.bulk-select option{color:#fff;background:#0a2657}@media (width<=768px){.bulk-toolbar{gap:6px;padding:8px 10px}.bulk-select{flex:120px}}.contact-name-cell{align-items:center;gap:10px;display:flex}.contact-name{color:var(--blue);font-weight:500}.contact-name:hover{text-decoration:underline}.email-link{color:var(--text-sub);font-size:12px}.email-link:hover{color:var(--blue);text-decoration:underline}.text-sub{color:var(--text-sub)}.deal-value{color:var(--text-main);font-weight:600}@media (width<=768px){.hide-mobile{display:none}.table-wrapper{border-radius:var(--radius);overflow:hidden}table thead{display:none}table,tbody,tr,td{width:100%;display:block}tbody tr{border-bottom:1px solid var(--border);padding:14px 16px;position:relative}tbody tr:last-child{border-bottom:none}td{border:none;padding:2px 0;font-size:13px}td:first-child{width:auto;margin-bottom:0;position:absolute;top:14px;right:14px}td[data-label=Actions]{margin-top:10px}td:empty{display:none}.contact-name-cell{padding-right:30px}}.contact-filters{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.filter-search{flex:1;min-width:240px;max-width:400px;position:relative}.search-icon{color:var(--text-light);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.filter-input{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-main);background:#fff;outline:none;padding:8px 12px 8px 32px;font-family:inherit;font-size:14px;transition:border-color .15s,box-shadow .15s}.filter-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #1589ee1f}.filter-input::placeholder{color:var(--text-light)}.filter-clear{color:var(--text-sub);cursor:pointer;background:0 0;border:none;align-items:center;padding:2px;display:flex;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.filter-clear:hover{color:var(--text-main)}.filter-select{flex-shrink:0;width:auto;min-width:140px}.filter-count{color:var(--text-sub);white-space:nowrap;margin-left:auto;font-size:12px}@media (width<=768px){.contact-filters{flex-wrap:wrap}.filter-search{max-width:100%}.filter-select{flex:1;min-width:120px}}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1000;background:#0a265780;justify-content:center;align-items:flex-start;padding:40px 16px;display:flex;position:fixed;inset:0;overflow-y:auto}.modal-panel{background:var(--card-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;animation:.18s modal-in}@keyframes modal-in{0%{opacity:0;transform:translateY(-12px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 24px 16px;display:flex}.modal-title{font-size:16px;font-weight:600}.modal-close{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-sub);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.modal-close:hover{background:var(--bg);color:var(--text-main)}.modal-body{padding:24px}.contact-search-wrap{position:relative}.contact-dropdown{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);z-index:100;max-height:240px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:hidden auto}.contact-option{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:9px 14px;font-family:inherit;transition:background .1s;display:flex}.contact-option:hover{background:var(--bg)}.contact-option-name{color:var(--text-main);font-size:13px;font-weight:500}.contact-option-company{color:var(--text-sub);font-size:12px}.type-toggle{gap:8px;display:flex}.type-btn{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-sub);background:#fff;flex:1;padding:8px 12px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s}.type-btn:hover{border-color:var(--blue);color:var(--blue)}.type-btn.active{border-color:var(--blue);color:var(--blue);background:#1589ee14;font-weight:600}.add-note-trigger{border:1px dashed var(--border-dark);border-radius:var(--radius-sm);color:var(--text-sub);cursor:pointer;background:0 0;align-items:center;gap:5px;margin-top:8px;padding:4px 10px;font-family:inherit;font-size:12px;transition:border-color .15s,color .15s,background .15s;display:inline-flex}.add-note-trigger:hover{border-color:var(--blue);color:var(--blue);background:#1589ee0a}.add-note-form{flex-direction:column;gap:8px;margin-top:10px;display:flex}.add-note-actions{justify-content:flex-end;gap:8px;display:flex}.log-entry{border-bottom:1px solid var(--border);padding:14px 20px}.log-entry:last-child{border-bottom:none}.log-entry:hover{background:#fafbfc}.log-entry-compact{padding:12px 16px}.log-entry-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.log-entry-left{flex:1;align-items:flex-start;gap:10px;min-width:0;display:flex}.log-entry-meta{flex-direction:column;gap:2px;min-width:0;display:flex}.log-contact-link{color:var(--blue);font-size:13px;font-weight:600;text-decoration:none}.log-contact-link:hover{text-decoration:underline}.log-company{color:var(--text-sub);font-weight:400}.log-subject{color:var(--text-main);font-size:13px;font-weight:500}.log-entry-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;display:flex}.log-staff{align-items:center;gap:6px;display:flex}.log-staff-name{color:var(--text-sub);font-size:12px;font-weight:500}.log-datetime{color:var(--text-light);font-size:11px}.log-duration{color:var(--teal);font-size:11px;font-weight:500}.log-notes{border-top:1px dashed var(--border);flex-direction:column;gap:8px;margin-top:10px;padding-top:10px;display:flex}.log-note{background:var(--bg);border-radius:var(--radius-sm);border-left:2px solid var(--teal);padding:8px 12px}.log-note-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.log-note-author{color:var(--text-sub);font-size:11px;font-weight:600}.log-note-time{color:var(--text-light);font-size:11px}.log-note-text{color:var(--text-main);white-space:pre-wrap;font-size:13px;line-height:1.6}@media (width<=768px){.log-entry-header{flex-direction:column;gap:8px}.log-entry-right{flex-flow:wrap;align-items:center;gap:8px}}.profile-back{margin-bottom:16px}.back-btn{cursor:pointer;color:var(--text-sub);background:0 0;border:none;align-items:center;gap:6px;padding:4px 0;font-family:inherit;font-size:13px;transition:color .15s;display:inline-flex}.back-btn:hover{color:var(--blue)}.profile-layout{grid-template-columns:1fr 1fr;align-items:start;gap:20px;display:grid}.profile-left,.profile-right{flex-direction:column;gap:16px;display:flex}.profile-fields{flex-direction:column;gap:0;display:flex}.profile-field{border-bottom:1px solid var(--border);align-items:baseline;gap:16px;padding:10px 0;display:flex}.profile-field:last-child{border-bottom:none}.profile-field-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-sub);flex-shrink:0;min-width:90px;font-size:11px;font-weight:600}.profile-field-value{color:var(--text-main);font-size:14px}@media (width<=900px){.profile-layout{grid-template-columns:1fr}}@media (width<=768px){.profile-field{flex-direction:column;gap:2px}.profile-field-label{min-width:unset}}.log-feed{flex-direction:column;gap:20px;display:flex}.log-group{flex-direction:column;gap:8px;display:flex}.log-group-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-sub);padding-left:2px;font-size:11px;font-weight:700}.log-group-card{overflow:hidden}.log-filters{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;display:flex}.log-search-wrap{flex:1;min-width:240px;max-width:380px;position:relative}.log-search-icon{color:var(--text-light);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.log-search{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-main);background:#fff;outline:none;padding:8px 12px 8px 32px;font-family:inherit;font-size:14px;transition:border-color .15s,box-shadow .15s}.log-search:focus{border-color:var(--blue);box-shadow:0 0 0 3px #1589ee1f}.log-search::placeholder{color:var(--text-light)}@media (width<=768px){.log-filters{flex-wrap:wrap}.log-search-wrap{max-width:100%}.log-filters .form-select{flex:1;min-width:120px}}.metrics-sidebar{background:var(--card-bg);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);padding:16px;position:sticky;top:24px}.metrics-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-sub);margin-bottom:12px;font-size:13px;font-weight:700}.metrics-list{flex-direction:column;gap:2px;display:flex}.metric-item{border-radius:var(--radius-sm);align-items:center;gap:10px;padding:9px 8px;transition:background .1s;display:flex}.metric-item:hover{background:var(--bg)}.metric-icon{text-align:center;flex-shrink:0;width:28px;font-size:18px}.metric-body{flex-direction:column;gap:1px;min-width:0;display:flex}.metric-label{color:var(--text-sub);font-size:11px;font-weight:500}.metric-value{font-size:18px;font-weight:700;line-height:1.2}.gauge-wrap{flex-direction:column;align-items:center;display:flex}.gauge-svg{width:100%;max-width:240px}.gauge-pct{color:var(--text-sub);margin-top:-8px;font-size:12px}.analytics-layout{grid-template-columns:1fr 240px;align-items:start;gap:20px;display:grid}.analytics-main{flex-direction:column;gap:16px;min-width:0;display:flex}.analytics-sidebar{position:sticky;top:0}.analytics-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.analytics-tabs{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);gap:0;padding:3px;display:flex}.analytics-tab{color:var(--text-sub);cursor:pointer;background:0 0;border:none;border-radius:3px;padding:7px 18px;font-family:inherit;font-size:13px;font-weight:500;transition:background .15s,color .15s}.analytics-tab:hover{color:var(--text-main)}.analytics-tab.active{background:var(--navy);color:#fff;font-weight:600}.analytics-tab-content{flex-direction:column;gap:16px;display:flex}.analytics-row{align-items:flex-start;gap:16px;display:flex}.analytics-chart-card{width:100%}.pipeline-stage-cards{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.stage-card{background:var(--card-bg);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);flex-direction:column;gap:4px;padding:14px 16px;display:flex}.stage-card-label{text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:700}.stage-card-count{color:var(--text-main);font-size:28px;font-weight:700;line-height:1}.stage-card-value{color:var(--text-sub);font-size:12px;font-weight:500}.revenue-summary{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.revenue-card{flex-direction:column;gap:6px;padding:16px;display:flex}.revenue-card-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-sub);font-size:11px;font-weight:600}.revenue-card-value{font-size:22px;font-weight:700;line-height:1}.activity-stats{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.activity-stat-card{text-align:center;flex-direction:column;align-items:center;gap:4px;padding:16px;display:flex}.activity-stat-icon{font-size:24px}.activity-stat-value{color:var(--navy);font-size:28px;font-weight:700;line-height:1}.activity-stat-label{color:var(--text-sub);font-size:11px;font-weight:500}.wages-summary-cards{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.wages-card{flex-direction:column;gap:6px;padding:16px;display:flex}.wages-card-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-sub);font-size:11px;font-weight:600}.wages-card-value{color:var(--navy);font-size:24px;font-weight:700;line-height:1}.wages-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-sub);border-bottom:1px solid var(--border);background:var(--bg,#f8f9fa);padding:10px 16px;font-size:11px;font-weight:600}.wages-table td{border-bottom:1px solid var(--border);color:var(--text-main);padding:11px 16px}.wages-table tfoot td{border-top:2px solid var(--border);background:var(--bg,#f8f9fa);border-bottom:none}.wages-name{font-weight:600}.wages-total{color:var(--navy);font-weight:700}@media (width<=1100px){.analytics-layout{grid-template-columns:1fr}.analytics-sidebar{position:static}.pipeline-stage-cards,.revenue-summary,.activity-stats,.wages-summary-cards{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.analytics-row{flex-direction:column}.pipeline-stage-cards{grid-template-columns:repeat(2,1fr)}.revenue-summary{grid-template-columns:1fr}.activity-stats{grid-template-columns:repeat(2,1fr)}.analytics-tabs{overflow-x:auto}.analytics-header{flex-direction:column;align-items:flex-start}}.settings-layout{flex-direction:column;gap:20px;max-width:720px;display:flex}.settings-card{width:100%}.staff-add-form{gap:10px;margin-bottom:16px;display:flex}.staff-add-form .form-input{flex:1}.staff-list{flex-direction:column;gap:2px;display:flex}.staff-item{border-radius:var(--radius-sm);justify-content:space-between;align-items:center;padding:10px 12px;transition:background .1s;display:flex}.staff-item:hover{background:var(--bg)}.staff-item-info{flex-direction:column;gap:1px;display:flex}.staff-item-name{color:var(--text-main);font-size:14px;font-weight:500}.staff-item-email{color:var(--text-sub);font-size:12px}.staff-remove{color:#ef4444;border-color:#0000}.staff-remove:hover{background:#fef2f2;border-color:#ef4444}.settings-actions{flex-direction:column;gap:0;display:flex}.settings-action-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:8px 0;display:flex}.divider{background:var(--border);height:1px;margin:12px 0}.csv-drop-zone{border:2px dashed var(--border);border-radius:var(--radius);cursor:pointer;color:var(--text-sub);flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:36px 20px;font-size:14px;transition:border-color .15s,background .15s;display:flex}.csv-drop-zone:hover{border-color:var(--blue);color:var(--blue);background:#1589ee08}.csv-mapping-grid{flex-direction:column;gap:8px;max-height:280px;display:flex;overflow-y:auto}.csv-map-row{grid-template-columns:150px 1fr;align-items:center;gap:12px;display:grid}.csv-map-label{color:var(--text-main);white-space:nowrap;font-size:13px;font-weight:500}.tc-add-form{background:var(--bg);border-radius:var(--radius-sm);flex-direction:column;gap:10px;margin-bottom:16px;padding:14px;display:flex}.tc-textarea{resize:vertical;min-height:72px;font-size:13px;line-height:1.5}.tc-list{flex-direction:column;gap:6px;display:flex}.tc-item{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);align-items:flex-start;gap:10px;padding:10px 12px;transition:background .1s;display:flex}.tc-item:hover{background:var(--bg)}.tc-item.tc-inactive{opacity:.5}.tc-order-btns{flex-direction:column;flex-shrink:0;align-items:center;gap:2px;padding-top:2px;display:flex}.tc-arrow{color:var(--text-light);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:10px;line-height:1.6}.tc-arrow:disabled{opacity:.25;cursor:default}.tc-arrow:not(:disabled):hover{color:var(--blue)}.tc-num{color:var(--text-light);font-size:11px;font-weight:600;line-height:1}.tc-body{flex:1;min-width:0}.tc-text{color:var(--text-main);white-space:pre-wrap;word-break:break-word;margin:0;font-size:13px;line-height:1.55}.tc-edit-wrap{flex-direction:column;gap:6px;display:flex}.tc-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.tc-active-toggle{color:var(--text-sub);cursor:pointer;white-space:nowrap;align-items:center;gap:4px;font-size:12px;display:flex}.btn-xs{padding:2px 6px;font-size:11px}.segments-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:24px;display:grid}.segment-card{background:var(--card-bg);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);cursor:pointer;flex-direction:column;gap:4px;padding:16px;transition:box-shadow .15s,border-color .15s;display:flex;position:relative}.segment-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-dark)}.segment-card-active{border-color:var(--blue);box-shadow:0 0 0 2px #1589ee26}.segment-card-count{color:var(--navy);font-size:28px;font-weight:700;line-height:1}.segment-card-name{color:var(--text-main);font-size:13px;font-weight:600}.segment-card-value{color:var(--text-sub);font-size:12px}.segment-card-edit{color:var(--text-light);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:3px;padding:2px 4px;font-family:inherit;font-size:11px;transition:opacity .15s;position:absolute;top:8px;right:8px}.segment-card:hover .segment-card-edit{opacity:1}.segment-card-edit:hover{color:var(--blue);background:var(--bg)}.segments-contact-list{flex-direction:column;gap:12px;display:flex}.segments-list-header{justify-content:space-between;align-items:center;display:flex}.type-pill{cursor:pointer;white-space:nowrap;background:0 0;border:1px solid;border-radius:12px;padding:3px 10px;font-family:inherit;font-size:11px;font-weight:600;transition:opacity .15s}.type-pill:hover{opacity:.8}.type-pill-dropdown{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);z-index:100;min-width:180px;position:absolute;top:calc(100% + 4px);left:0;overflow:hidden}.type-pill-option{cursor:pointer;text-align:left;width:100%;color:var(--text-main);background:0 0;border:none;align-items:center;gap:8px;padding:8px 12px;font-family:inherit;font-size:13px;transition:background .1s;display:flex}.type-pill-option:hover{background:var(--bg)}.type-pill-clear{color:var(--text-sub);border-top:1px solid var(--border)}.type-pill-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.color-picker{flex-wrap:wrap;gap:8px;display:flex}.color-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;width:28px;height:28px;transition:transform .15s,border-color .15s}.color-swatch:hover{transform:scale(1.15)}.color-swatch.selected{border-color:var(--text-main);transform:scale(1.15)}@media (width<=768px){.segments-grid{grid-template-columns:repeat(2,1fr)}.segments-table-hide,.segments-contact-list table thead{display:none}.segments-contact-list table tr{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:4px 8px;padding:10px 0;display:flex}.segments-contact-list table td{border:none;padding:0}.segments-contact-list table td:first-child{flex:100%}}.pipeline-board{align-items:flex-start;gap:14px;min-height:60vh;padding-bottom:20px;display:flex;overflow-x:auto}.pipeline-column{border-radius:var(--radius);flex-direction:column;flex-shrink:0;width:255px;min-width:255px;transition:background .15s;display:flex}.pipeline-column.drag-over{background:#1589ee0a}.pipeline-col-header{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0;border-top:3px solid #0000;padding:10px 12px}.pipeline-col-top{justify-content:space-between;align-items:center;gap:8px;display:flex}.pipeline-col-title{align-items:center;gap:6px;display:flex}.pipeline-col-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.pipeline-col-name{color:var(--text-main);font-size:13px;font-weight:600}.pipeline-col-count{background:var(--bg);color:var(--text-sub);border-radius:10px;padding:1px 7px;font-size:11px;font-weight:600}.pipeline-col-value{color:var(--text-sub);font-size:12px;font-weight:600}.pipeline-cards{background:var(--bg);border:1px solid var(--border);border-radius:0 0 var(--radius) var(--radius);border-top:none;flex-direction:column;flex:1;gap:8px;min-height:80px;padding:8px;transition:border-color .15s;display:flex}.pipeline-column.drag-over .pipeline-cards{border-color:var(--blue);border-style:dashed}.pipeline-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);cursor:grab;box-shadow:var(--shadow);-webkit-user-select:none;user-select:none;flex-direction:column;gap:8px;padding:11px 12px;transition:box-shadow .15s,transform .1s,opacity .15s;display:flex}.pipeline-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.pipeline-card.is-dragging{opacity:.45;cursor:grabbing}.pipeline-card-title{color:var(--text-main);font-size:13px;font-weight:600;line-height:1.3}.pipeline-card-contact{align-items:center;gap:7px;display:flex}.pipeline-card-person{flex-direction:column;gap:1px;min-width:0;display:flex}.pipeline-card-name{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:500;overflow:hidden}.pipeline-card-company{color:var(--text-sub);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.pipeline-card-footer{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:6px;display:flex}.pipeline-card-type{white-space:nowrap;border:1px solid;border-radius:10px;padding:2px 7px;font-size:10px;font-weight:600}.pipeline-card-value{color:var(--navy);margin-left:auto;font-size:12px;font-weight:700}.pipeline-card-notes{color:var(--text-sub);border-top:1px solid var(--border);white-space:nowrap;text-overflow:ellipsis;padding-top:7px;font-size:11px;line-height:1.4;overflow:hidden}.pipeline-add-btn{border:1px dashed var(--border);border-radius:var(--radius);width:100%;color:var(--text-light);cursor:pointer;text-align:center;background:0 0;padding:7px;font-family:inherit;font-size:12px;transition:border-color .15s,color .15s,background .15s}.pipeline-add-btn:hover{border-color:var(--blue);color:var(--blue);background:#1589ee0a}.pipeline-stage-badge{border-radius:10px;padding:2px 9px;font-size:11px;font-weight:600;display:inline-block}.pipeline-detail-contact{background:var(--bg);border-radius:8px;align-items:flex-start;gap:10px;padding:10px 12px;display:flex}@media (width<=768px){.pipeline-board{gap:10px}.pipeline-column{width:220px;min-width:220px}}.tasks-summary{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;display:grid}.tasks-summary-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;text-align:left;border-top:3px solid #0000;flex-direction:column;gap:3px;padding:14px 16px;font-family:inherit;transition:box-shadow .15s,border-color .15s;display:flex}.tasks-summary-card:hover{box-shadow:var(--shadow-md)}.tasks-summary-card.active{box-shadow:var(--shadow-md);border-color:var(--blue)}.tasks-summary-count{font-size:28px;font-weight:700;line-height:1}.tasks-summary-label{color:var(--text-sub);font-size:12px;font-weight:600}.tasks-filters{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.tasks-filter-tabs{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);gap:2px;padding:3px;display:flex}.tasks-tab{border-radius:calc(var(--radius) - 2px);color:var(--text-sub);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:5px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:background .1s,color .1s}.tasks-tab:hover{color:var(--text-main)}.tasks-tab.active{background:var(--card-bg);color:var(--text-main);box-shadow:var(--shadow)}.tasks-list{flex-direction:column;gap:2px;display:flex}.task-row{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);align-items:flex-start;gap:12px;padding:12px 14px;transition:box-shadow .15s;display:flex}.task-row:hover{box-shadow:var(--shadow)}.task-row.overdue{border-left:3px solid #ef4444}.task-row.completed{opacity:.55}.task-check{border:2px solid var(--border);cursor:pointer;color:#fff;background:0 0;border-radius:50%;justify-content:center;align-items:center;width:20px;min-width:20px;height:20px;margin-top:2px;transition:border-color .15s,background .15s;display:flex}.task-check:hover{border-color:var(--blue)}.task-check.checked{background:#10b981;border-color:#10b981}.task-row-body{cursor:pointer;flex:1;min-width:0}.task-row-title{color:var(--text-main);margin-bottom:5px;font-size:14px;font-weight:500}.task-row.completed .task-row-title{color:var(--text-light);text-decoration:line-through}.task-row-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.task-contact-link{cursor:pointer;color:var(--text-sub);background:0 0;border:none;align-items:center;gap:5px;padding:0;font-family:inherit;font-size:12px;transition:color .15s;display:inline-flex}.task-contact-link:hover{color:var(--blue)}.task-type-pill{border:1px solid;border-radius:10px;padding:1px 6px;font-size:10px;font-weight:600}.task-assigned{color:var(--text-sub);align-items:center;gap:4px;font-size:12px;display:inline-flex}.task-row-right{flex-direction:column;align-items:flex-end;gap:4px;min-width:90px;display:flex}.task-due{color:var(--text-sub);white-space:nowrap;font-size:12px;font-weight:600}.task-due.today{color:#f59e0b}.task-due.overdue{color:#ef4444}.task-detail-contact{background:var(--bg);cursor:pointer;text-align:left;border:none;border-radius:8px;align-items:center;gap:10px;width:100%;padding:10px 12px;font-family:inherit;transition:background .15s;display:flex}.task-detail-contact:hover{background:var(--border)}@media (width<=768px){.tasks-summary{grid-template-columns:repeat(2,1fr)}.tasks-filter-tabs{overflow-x:auto}.task-row-right{min-width:70px}}.audit-filters{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.audit-search-wrap{flex:1;min-width:200px;max-width:380px;position:relative}.audit-search-icon{color:var(--text-light);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.audit-search{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-main);background:#fff;outline:none;padding:8px 12px 8px 32px;font-family:inherit;font-size:14px;transition:border-color .15s,box-shadow .15s}.audit-search:focus{border-color:var(--blue);box-shadow:0 0 0 3px #1589ee1f}.audit-search::placeholder{color:var(--text-light)}@media (width<=768px){.audit-search-wrap{max-width:100%}}.audit-list{flex-direction:column;gap:2px;display:flex}.audit-entry{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:12px 16px;display:flex}.audit-entry-left{flex-wrap:wrap;flex:1;align-items:center;gap:10px;min-width:0;display:flex}.audit-badge{white-space:nowrap;border-radius:10px;flex-shrink:0;padding:3px 9px;font-size:11px;font-weight:600}.audit-contact{font-size:14px;font-weight:500}.audit-contact-link{cursor:pointer;color:var(--blue);background:0 0;border:none;padding:0;font-family:inherit;font-size:14px;font-weight:500;transition:opacity .15s}.audit-contact-link:hover{opacity:.75}.audit-contact-deleted{color:var(--text-sub)}.audit-change{align-items:center;gap:6px;display:flex}.audit-entry-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:2px;display:flex}.audit-time{color:var(--text-sub);white-space:nowrap;font-size:12px}.audit-by{color:var(--text-light);white-space:nowrap;font-size:11px}@media (width<=768px){.audit-entry{gap:10px}.audit-entry-right{align-items:flex-start}}.dashboard{flex-direction:column;gap:20px;display:flex}.dashboard-header{justify-content:space-between;align-items:center;display:flex}.dashboard-brand{align-items:center;gap:16px;display:flex}.dashboard-logo{object-fit:contain;width:56px;height:56px}.dashboard-greeting{color:var(--navy);margin:0;font-size:22px;font-weight:700}.dashboard-date{color:var(--text-sub);font-size:13px}.dashboard-stats{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;display:grid}.db-stat-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);text-align:left;border-top:none;flex-direction:column;gap:4px;padding:16px;font-family:inherit;transition:box-shadow .15s,transform .1s;display:flex}.db-stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.db-stat-value{font-size:26px;font-weight:700;line-height:1}.db-stat-label{color:var(--text-sub);font-size:12px;font-weight:600}.dashboard-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.db-full-width{grid-column:1/-1}.dashboard-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;display:flex}.dashboard-card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px 10px;display:flex}.dashboard-card-header h3{align-items:center;gap:8px;margin:0;display:flex}.dashboard-empty{color:var(--text-sub);padding:20px 16px;font-size:13px;font-style:italic}.db-count{border-radius:10px;padding:2px 7px;font-size:11px;font-weight:700}.db-count.overdue{color:#b91c1c;background:#fee2e2}.db-count.today{color:#92400e;background:#fef3c7}.db-count-blue{color:#1d4ed8;background:#dbeafe}.db-count-amber{color:#92400e;background:#fef3c7}.db-count-ok{color:#065f46;background:#d1fae5}.db-job-list{flex-direction:column;display:flex}.db-job-row{border-bottom:1px solid var(--border);cursor:pointer;text-align:left;background:0 0;border-top:none;border-left:none;border-right:none;align-items:center;gap:12px;width:100%;padding:10px 16px;font-family:inherit;transition:background .1s;display:flex}.db-job-row:last-child{border-bottom:none}.db-job-row:hover{background:var(--bg)}.db-job-date-col{flex-direction:column;flex-shrink:0;align-items:center;min-width:40px;display:flex}.db-job-date{color:var(--navy);font-size:13px;font-weight:700;line-height:1}.db-job-dow{color:var(--text-sub);text-transform:uppercase;letter-spacing:.04em;font-size:10px;font-weight:500}.db-job-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.db-job-client{color:var(--text-main);font-size:13px;font-weight:500}.db-job-type{color:var(--text-sub);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.db-job-right{flex-shrink:0}.db-task-list{flex-direction:column;display:flex}.db-task-row{border-bottom:1px solid var(--border);cursor:pointer;text-align:left;background:0 0;border-top:none;border-left:none;border-right:none;justify-content:space-between;align-items:flex-start;gap:12px;padding:10px 16px;font-family:inherit;transition:background .1s;display:flex}.db-task-row:last-child{border-bottom:none}.db-task-row:hover{background:var(--bg)}.db-task-info{flex-direction:column;gap:2px;min-width:0;display:flex}.db-task-title{color:var(--text-main);font-size:13px;font-weight:500}.db-task-contact{color:var(--text-sub);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.db-task-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:2px;display:flex}.db-task-overdue{color:#ef4444;white-space:nowrap;font-size:11px;font-weight:600}.db-task-today{color:#f59e0b;font-size:11px;font-weight:600}.db-task-assigned{color:var(--text-light);font-size:10px}.db-more{color:var(--text-sub);padding:8px 16px;font-size:12px;font-style:italic}.db-invoice-list{flex-direction:column;display:flex}.db-invoice-row{border-bottom:1px solid var(--border);cursor:pointer;text-align:left;background:0 0;border-top:none;border-left:none;border-right:none;justify-content:space-between;align-items:center;gap:12px;width:100%;padding:10px 16px;font-family:inherit;transition:background .1s;display:flex}.db-invoice-row:last-child{border-bottom:none}.db-invoice-row:hover{background:var(--bg)}.db-invoice-info{flex-direction:column;gap:2px;min-width:0;display:flex}.db-invoice-client{color:var(--text-main);font-size:13px;font-weight:500}.db-invoice-ref{color:var(--text-sub);align-items:center;gap:6px;font-size:11px;display:flex}.db-dep-badge{color:#854d0e;background:#fef9c3;border-radius:4px;padding:1px 5px;font-size:10px;font-weight:600}.db-invoice-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:2px;display:flex}.db-invoice-amount{color:var(--navy);font-size:13px;font-weight:700}.db-invoice-amount.overdue{color:#dc2626}.db-invoice-due{color:var(--text-sub);font-size:10px}.db-invoice-due.overdue{color:#dc2626;font-weight:600}.db-invoice-footer{color:var(--text-sub);border-top:1px solid var(--border);padding:8px 16px;font-size:11px;font-style:italic}.db-wages-list{flex-direction:column;display:flex}.db-wages-row{border-bottom:1px solid var(--border);cursor:pointer;text-align:left;background:0 0;border-top:none;border-left:none;border-right:none;justify-content:space-between;align-items:center;gap:12px;width:100%;padding:10px 16px;font-family:inherit;transition:background .1s;display:flex}.db-wages-row:hover{background:var(--bg)}.db-wages-info{flex-direction:column;gap:2px;min-width:0;display:flex}.db-wages-name{color:var(--text-main);font-size:13px;font-weight:500}.db-wages-date{color:var(--text-sub);font-size:11px}.db-wages-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.db-wages-amount{color:var(--navy);font-size:13px;font-weight:700}.db-wages-total{border-top:1px solid var(--border);color:var(--text-main);justify-content:space-between;align-items:center;padding:10px 16px;font-size:13px;font-weight:600;display:flex}.db-fleet-list{flex-direction:column;display:flex}.db-fleet-row{border-bottom:1px solid var(--border);cursor:pointer;text-align:left;background:0 0;border-top:none;border-left:none;border-right:none;align-items:center;gap:10px;width:100%;padding:10px 16px;font-family:inherit;transition:background .1s;display:flex}.db-fleet-row:last-child{border-bottom:none}.db-fleet-row:hover{background:var(--bg)}.db-fleet-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.db-fleet-dot.expired{background:#ef4444}.db-fleet-dot.warning{background:#f59e0b}.db-fleet-info{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.db-fleet-vehicle{color:var(--text-main);font-size:13px;font-weight:500}.db-fleet-reg{color:var(--text-sub);font-family:monospace;font-size:11px}.db-fleet-field{flex-shrink:0;font-size:11px;font-weight:600}.db-fleet-field.expired{color:#dc2626}.db-fleet-field.warning{color:#d97706}.db-stock-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:9px 16px;display:flex}.db-stock-row:last-child{border-bottom:none}.db-stock-name{color:var(--text-main);font-size:13px;font-weight:500}.db-stock-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.db-stock-qty{font-size:12px;font-weight:600}.db-pipeline{flex-direction:column;gap:10px;padding:14px 16px;display:flex}.db-pipeline-row{grid-template-columns:130px 1fr 28px 72px;align-items:center;gap:8px;display:grid}.db-pipeline-stage{align-items:center;gap:6px;display:flex}.db-pipeline-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.db-pipeline-label{color:var(--text-main);white-space:nowrap;font-size:12px;font-weight:500}.db-pipeline-bar-wrap{background:var(--bg);border-radius:4px;height:6px;overflow:hidden}.db-pipeline-bar{border-radius:4px;min-width:2px;height:100%;transition:width .3s}.db-pipeline-count{color:var(--text-sub);text-align:right;font-size:12px;font-weight:600}.db-pipeline-value{color:var(--text-main);text-align:right;font-size:12px;font-weight:600}.db-pipeline-total{color:var(--text-sub);border-top:1px solid var(--border);justify-content:space-between;margin-top:2px;padding-top:10px;font-size:13px;display:flex}@media (width<=900px){.dashboard-stats{grid-template-columns:repeat(3,1fr)}.dashboard-grid{grid-template-columns:1fr}.db-full-width{grid-column:1}}@media (width<=600px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}.dashboard-logo{width:40px;height:40px}.dashboard-greeting{font-size:18px}.db-pipeline-row{grid-template-columns:90px 1fr 20px 58px;gap:6px}.db-pipeline-label,.db-pipeline-value{font-size:11px}.db-stat-value{font-size:22px}.db-stat-card{padding:12px}.dashboard-header{flex-wrap:wrap;gap:8px}}.generate-leads{flex-direction:column;gap:20px;display:flex}.gl-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:20px;padding:24px;display:flex}.gl-step-header{align-items:flex-start;gap:14px;display:flex}.gl-step-num{background:var(--navy);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;min-width:32px;height:32px;font-size:15px;font-weight:700;display:flex}.gl-step-title{color:var(--text-main);margin:0 0 3px;font-size:16px;font-weight:700}.gl-step-desc{color:var(--text-sub);margin:0;font-size:13px}.gl-link{color:var(--blue);text-decoration:underline}.gl-form{flex-direction:column;gap:16px;display:flex}.gl-form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.gl-form-group{flex-direction:column;gap:6px;display:flex}.gl-label{color:var(--text-sub);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:600}.gl-input{border:1px solid var(--border);height:38px;color:var(--text-main);background:var(--card-bg);border-radius:6px;padding:0 12px;font-size:14px;transition:border-color .15s}.gl-input:focus{border-color:var(--blue);outline:none}.gl-radius-value{color:var(--blue);text-transform:none;letter-spacing:0;font-size:13px;font-weight:700}.gl-radius-wrap{align-items:center;gap:10px;display:flex}.gl-radius-edge{color:var(--text-sub);white-space:nowrap;flex-shrink:0;font-size:11px}.gl-slider{height:4px;accent-color:var(--blue);cursor:pointer;flex:1}.gl-radius-stops{justify-content:space-between;margin-top:4px;display:flex;overflow:hidden}.gl-radius-stop{color:var(--border);text-align:center;white-space:nowrap;flex:1;font-size:9px;transition:color .15s;overflow:hidden}.gl-radius-stop.active{color:var(--blue);font-weight:700}.gl-platforms{flex-wrap:wrap;gap:6px;display:flex}.gl-platform-chip{border:1.5px solid var(--border);color:var(--text-sub);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:20px;align-items:center;gap:6px;padding:5px 12px;font-size:12px;font-weight:500;transition:border-color .15s,color .15s,background .15s;display:flex}.gl-platform-chip input{display:none}.gl-platform-chip.active{border-color:var(--blue);color:var(--blue);background:#1589ee12;font-weight:600}.gl-count-row{gap:8px;display:flex}.gl-count-btn{border:2px solid var(--border);background:var(--card-bg);width:52px;height:38px;color:var(--text-sub);cursor:pointer;border-radius:6px;font-family:inherit;font-size:14px;font-weight:600;transition:border-color .15s,color .15s}.gl-count-btn:hover{border-color:var(--blue);color:var(--blue)}.gl-count-btn.active{border-color:var(--blue);color:var(--blue);background:#1589ee12}.gl-prompt-box{box-sizing:border-box;border:1px solid var(--border);width:100%;color:var(--text-main);resize:vertical;background:#f8fafc;border-radius:8px;min-height:320px;padding:44px 16px 16px;font-family:Menlo,Consolas,monospace;font-size:12px;line-height:1.7}.gl-copy-btn{border:1px solid var(--border);background:var(--card-bg);color:var(--text-main);cursor:pointer;border-radius:6px;align-items:center;gap:6px;padding:6px 14px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s,color .15s,border-color .15s;display:flex;position:absolute;top:10px;right:10px}.gl-copy-btn:hover{border-color:var(--blue);color:var(--blue)}.gl-copy-btn.copied{color:#059669;background:#ecfdf5;border-color:#10b981}.gl-hint{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe;border-radius:7px;align-items:flex-start;gap:8px;padding:10px 14px;font-size:13px;line-height:1.5;display:flex}.gl-success{color:#059669;background:#ecfdf5;border:1px solid #6ee7b7;border-radius:7px;align-items:center;gap:8px;padding:12px 16px;font-size:14px;font-weight:600;display:flex}.gl-import-row{align-items:center;gap:12px;display:flex}.gl-or{color:var(--text-sub);font-size:13px}.gl-paste-box{box-sizing:border-box;border:1px solid var(--border);width:100%;color:var(--text-main);background:var(--card-bg);resize:vertical;border-radius:6px;padding:12px;font-family:Menlo,Consolas,monospace;font-size:12px}.gl-paste-box:focus{border-color:var(--blue);outline:none}.gl-error{color:#ef4444;margin:0;font-size:13px}.gl-import-meta{color:var(--text-sub);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;font-size:13px;display:flex}.gl-status-select{border:1px solid var(--border);background:var(--card-bg);height:32px;color:var(--text-main);border-radius:6px;padding:0 10px;font-size:13px}.gl-table-wrap{border:1px solid var(--border);border-radius:8px;overflow:auto hidden}.gl-table{border-collapse:collapse;width:100%;font-size:13px}.gl-table th{background:var(--bg);text-align:left;color:var(--text-sub);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);white-space:nowrap;padding:9px 12px;font-size:11px;font-weight:700}.gl-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:10px 12px}.gl-table tbody tr:last-child td{border-bottom:none}.gl-table tbody tr:hover{background:var(--bg)}.gl-row-selected{background:#1589ee0d!important}.gl-row-dupe{opacity:.75;background:#fffbeb!important}.gl-td-main{color:var(--text-main);font-weight:500}.gl-td-sub{color:var(--text-sub)}.gl-dupe-badge{color:#92400e;white-space:nowrap;background:#fef3c7;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:700}.gl-save-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding-top:4px;display:flex}.gl-save-note{color:var(--text-sub);font-size:13px}@media (width<=768px){.gl-card{padding:16px}.gl-form-row{grid-template-columns:1fr}.gl-radius-stops{display:none}.gl-import-meta{flex-direction:column;align-items:flex-start}.gl-save-row{flex-direction:column;align-items:stretch}.gl-save-row .btn{justify-content:center;width:100%}.gl-table th:nth-child(3),.gl-table td:nth-child(3),.gl-table th:nth-child(5),.gl-table td:nth-child(5){display:none}}.inbox-list{flex-direction:column;gap:10px;display:flex}.inbox-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:10px;padding:16px;display:flex}.inbox-card-top{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.inbox-from{flex-direction:column;gap:2px;display:flex}.inbox-name{color:var(--text-main);font-size:14px;font-weight:600}.inbox-email{color:var(--text-sub);font-size:12px}.inbox-meta{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.inbox-mailbox{color:#1d4ed8;background:#eff6ff;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.inbox-mailbox-ops{color:#15803d;background:#f0fdf4}.inbox-mailbox-quotes{color:#c2410c;background:#fff7ed}.inbox-mailbox-info{color:#1d4ed8;background:#eff6ff}.inbox-date{color:var(--text-sub);white-space:nowrap;font-size:11px}.inbox-dir-badge{color:var(--text-sub);background:#f3f4f6;border-radius:8px;padding:2px 6px;font-size:10px;font-weight:700}.inbox-subject{color:var(--text-main);font-size:13px}.inbox-actions{border-top:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:8px;padding-top:4px;display:flex}.inbox-ignore{color:#ef4444!important}.inbox-assign-wrap{border-top:1px solid var(--border);flex-direction:column;gap:8px;padding-top:8px;display:flex}.inbox-assign-search{border:1px solid var(--border);height:36px;color:var(--text-main);background:var(--card-bg);border-radius:6px;padding:0 12px;font-size:13px}.inbox-assign-search:focus{border-color:var(--blue);outline:none}.inbox-assign-list{border:1px solid var(--border);border-radius:6px;flex-direction:column;gap:2px;max-height:180px;display:flex;overflow-y:auto}.inbox-assign-item{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:8px 12px;font-family:inherit;transition:background .1s;display:flex}.inbox-assign-item:hover{background:var(--bg)}.inbox-assign-item.selected{background:#1589ee14}.inbox-assign-name{color:var(--text-main);font-size:13px;font-weight:500}.inbox-assign-company{color:var(--text-sub);margin-left:auto;font-size:11px}.inbox-assign-empty{color:var(--text-sub);padding:10px 12px;font-size:13px;font-style:italic}.inbox-assign-actions{justify-content:flex-end;gap:8px;display:flex}@media (width<=600px){.inbox-card-top{flex-direction:column}.inbox-meta{justify-content:flex-start}.inbox-actions{gap:6px}.inbox-actions .btn{padding:5px 10px;font-size:12px}}.rc-filters{flex-direction:column;gap:12px;margin-bottom:20px;display:flex}.rc-search{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);width:100%;max-width:360px;color:var(--text-main);outline:none;padding:8px 12px;font-family:inherit;font-size:13px;transition:border-color .15s}.rc-search:focus{border-color:var(--blue)}.rc-status-tabs{flex-wrap:wrap;gap:6px;display:flex}.rc-tab{border:1px solid var(--border);background:var(--card-bg);color:var(--text-sub);cursor:pointer;border-radius:20px;align-items:center;gap:5px;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s;display:inline-flex}.rc-tab:hover{border-color:var(--blue);color:var(--blue)}.rc-tab.active{background:var(--blue);border-color:var(--blue);color:#fff}.rc-tab-count{background:#ffffff40;border-radius:10px;padding:1px 6px;font-size:11px}.rc-tab:not(.active) .rc-tab-count{background:var(--bg);color:var(--text-sub)}.rc-table-wrap{background:var(--card-bg);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);overflow:auto}.rc-table{border-collapse:collapse;width:100%;font-size:13px}.rc-table th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--text-sub);border-bottom:1px solid var(--border);white-space:nowrap;background:var(--bg);padding:10px 14px;font-size:11px;font-weight:600}.rc-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px 14px}.rc-table tbody tr:last-child td{border-bottom:none}.rc-table tbody tr:hover td{background:var(--bg)}.rc-row-clickable{cursor:pointer}.rc-cell-sub{color:var(--text-sub);font-size:13px}.rc-client-name{color:var(--text-main);font-weight:600}.rc-client-sub{color:var(--text-sub);margin-top:2px;font-size:12px}.rc-date{white-space:nowrap;color:var(--text-main)}.rc-route{color:var(--text-sub);align-items:center;gap:6px;max-width:280px;font-size:12px;display:flex}.rc-route span{text-overflow:ellipsis;white-space:nowrap;max-width:120px;overflow:hidden}.rc-route svg{color:var(--text-light);flex-shrink:0}.rc-none{color:var(--text-light);font-size:12px}.rc-badge{white-space:nowrap;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.rc-badge-grey{color:#6b7280;background:#f3f4f6}.rc-badge-blue{color:#1d4ed8;background:#eff6ff}.rc-badge-green{color:#059669;background:#ecfdf5}.rc-badge-red{color:#dc2626;background:#fef2f2}.rc-badge-storage{color:#c2410c;background:#fff7ed}.rc-actions{justify-content:flex-end;gap:6px;display:flex}.rc-btn-delete{color:#dc2626;background:#fef2f2;border-color:#fee2e2}.rc-btn-delete:hover:not(:disabled){color:#fff;background:#dc2626;border-color:#dc2626}.rc-empty{color:var(--text-light);text-align:center;flex-direction:column;align-items:center;gap:12px;padding:60px 20px;display:flex}.rc-empty svg{opacity:.3}.rc-form{flex-direction:column;gap:16px;display:flex}.rc-grid{grid-template-columns:1fr 1fr;gap:14px 16px;display:grid}.rc-col-2{grid-column:span 1}.rc-col-full{grid-column:1/-1}.rc-field{flex-direction:column;gap:5px;display:flex}.rc-label{color:var(--text-sub);font-size:12px;font-weight:500}.rc-input{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-main);background:#fff;outline:none;padding:8px 10px;font-family:inherit;font-size:13px;transition:border-color .15s}.rc-input:focus{border-color:var(--blue)}.rc-input::placeholder{color:var(--text-light)}.rc-textarea{resize:vertical;min-height:72px}.rc-checkbox-label{color:var(--text-main);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;font-size:13px;display:flex}.rc-checkbox-label input[type=checkbox]{cursor:pointer;width:15px;height:15px;accent-color:var(--blue)}.rc-required{color:#ef4444}.rc-form-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding-top:4px;display:flex}@media (width<=640px){.rc-grid{grid-template-columns:1fr}.rc-col-2{grid-column:span 1}.rc-route{display:none}}.rcp-page{flex-direction:column;gap:0;display:flex}.rcp-header{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);align-items:center;gap:20px;margin-bottom:0;padding:16px 20px;display:flex}.rcp-back{color:var(--text-sub);cursor:pointer;white-space:nowrap;background:0 0;border:none;align-items:center;gap:4px;padding:4px 0;font-family:inherit;font-size:13px;display:inline-flex}.rcp-back:hover{color:var(--blue)}.rcp-header-info{flex-direction:column;gap:4px;display:flex}.rcp-client-name{color:var(--text-main);margin:0;font-size:20px;font-weight:700}.rcp-header-contacts{color:var(--text-sub);gap:16px;font-size:13px;display:flex}.rcp-header-contacts span{align-items:center;gap:5px;display:flex}.rcp-tabs{border-bottom:2px solid var(--border);background:var(--card-bg);flex-wrap:nowrap;gap:0;margin-top:16px;padding:0 4px;display:flex;overflow-x:auto}.rcp-tab{color:var(--text-sub);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 16px;font-family:inherit;font-size:13px;font-weight:500;transition:color .15s,border-color .15s}.rcp-tab:hover{color:var(--blue)}.rcp-tab.active{color:var(--blue);border-bottom-color:var(--blue);font-weight:600}.rcp-body{background:var(--card-bg);border:1px solid var(--border);border-radius:0 0 var(--radius) var(--radius);box-shadow:var(--shadow);border-top:none;min-height:300px}.rcp-section{padding:20px}.rcp-profile-view{flex-direction:column;gap:0;max-width:480px;display:flex}.rcp-profile-row{border-bottom:1px solid var(--border);align-items:center;gap:16px;padding:12px 0;font-size:14px;display:flex}.rcp-profile-row:last-of-type{border-bottom:none}.rcp-profile-label{width:120px;color:var(--text-sub);text-transform:uppercase;letter-spacing:.03em;flex-shrink:0;font-size:12px;font-weight:600}.rcp-edit-btn{margin-top:16px}.rcp-profile-form .rc-grid{margin-bottom:0}.rcp-profile-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;margin-top:16px;padding-top:16px;display:flex}.rcp-jobs-table-wrap{border:1px solid var(--border);border-radius:var(--radius);overflow-x:auto}.rcp-jobs-table{border-collapse:collapse;width:100%;font-size:13px}.rcp-jobs-table th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--text-sub);background:var(--bg);border-bottom:1px solid var(--border);white-space:nowrap;padding:9px 12px;font-size:11px;font-weight:600}.rcp-jobs-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:11px 12px}.rcp-jobs-table tbody tr:last-child td{border-bottom:none}.rcp-jobs-table tbody tr:hover td{background:var(--bg)}.rcp-job-ref{color:var(--text-main);font-weight:600}.rcp-date-cell{white-space:nowrap;color:var(--text-sub);font-size:12px}.rcp-est-date{color:var(--text-light);font-style:italic}.rcp-date-range{color:var(--text-sub);font-weight:400}.rcp-route-cell{max-width:220px}.rcp-route{color:var(--text-sub);align-items:center;gap:5px;font-size:12px;display:flex}.rcp-route span{text-overflow:ellipsis;white-space:nowrap;max-width:90px;overflow:hidden}.rcp-table-total{color:var(--text-sub);background:var(--bg);border:1px solid var(--border);border-radius:0 0 var(--radius) var(--radius);border-top:none;margin-bottom:16px;padding:8px 12px;font-size:12px;font-weight:600}.rcp-action-bar{flex-wrap:wrap;gap:10px;padding-top:4px;display:flex}.rcp-notes-area{width:100%;min-height:160px}.rc-form-hint{color:var(--text-sub);margin-bottom:4px;font-size:12px}.rc-input-error{border-color:#ef4444!important}.rc-field-error{color:#ef4444;margin-top:2px;font-size:11px}.rc-optional{color:var(--text-light);font-size:11px;font-weight:400}.rcp-appt-type{color:#1d4ed8;background:#eff6ff;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.rcp-coming-soon{color:var(--text-light);text-align:center;flex-direction:column;align-items:center;gap:10px;padding:60px 20px;display:flex}.rcp-coming-soon-icon{font-size:32px}.rcp-coming-soon h3{color:var(--text-sub);font-size:15px}.rcp-coming-soon p{max-width:320px;font-size:13px}.pl-job-strip{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:14px;padding:10px 0 14px;display:flex}.pl-job-ref{color:var(--navy);font-size:14px;font-weight:700}.pl-move-date{color:var(--text-muted);font-size:12px}.pl-move-date.soon{color:#d97706;font-weight:600}.pl-prepared-tag{color:#065f46;background:#d1fae5;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:700}.pl-result{border-radius:6px;margin-bottom:14px;padding:10px 14px;font-size:13px}.pl-result.ok{color:#065f46;background:#d1fae5}.pl-result.warn{color:#92400e;background:#fef3c7}.pl-empty{text-align:center;color:var(--text-muted);padding:20px;font-size:13px;font-style:italic}.pl-table{border-collapse:collapse;width:100%;margin-bottom:12px;font-size:13px}.pl-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:2px solid var(--border);padding:7px 10px;font-size:11px;font-weight:600}.pl-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:9px 10px}.pl-table tbody tr:last-child td{border-bottom:none}.pl-name-cell{color:var(--text);font-weight:500}.pl-unit{color:var(--text-muted);margin-left:4px;font-size:11px}.pl-qty-cell{text-align:center;font-weight:600}.pl-qty-cell.short{color:#dc2626}.pl-qty-cell.editable{cursor:pointer;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.pl-qty-input{width:64px;padding:4px 8px;font-size:13px}.pl-fulfilled{border-radius:10px;padding:2px 7px;font-size:12px;font-weight:600}.pl-fulfilled.full{color:#065f46;background:#d1fae5}.pl-fulfilled.partial{color:#92400e;background:#fef3c7}.pl-add-row{border-top:1px solid var(--border);align-items:center;gap:8px;margin-top:4px;padding:10px 0;display:flex}.pl-stock-select{flex:1}.pl-qty-field{flex-shrink:0;width:80px}.pl-footer{border-top:1px solid var(--border);justify-content:flex-end;align-items:center;margin-top:8px;padding-top:16px;display:flex}.pl-prepared-note{color:#065f46;font-size:13px;font-weight:500}.so-layout{border:1px solid var(--border);border-radius:var(--radius);background:var(--card-bg);grid-template-columns:260px 1fr;gap:0;height:calc(100vh - 180px);min-height:500px;display:grid;overflow:hidden}.so-list-panel{border-right:1px solid var(--border);background:var(--bg-light,#f8f9fa);flex-direction:column;display:flex;overflow:hidden}.so-list-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.so-list-title{color:var(--text-main);text-transform:uppercase;letter-spacing:.05em;font-size:13px;font-weight:700}.so-list{flex-direction:column;flex:1;display:flex;overflow-y:auto}.so-empty{text-align:center;color:var(--text-sub);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:8px;padding:24px;font-size:13px;display:flex}.so-list-item{text-align:left;border:none;border-bottom:1px solid var(--border);cursor:pointer;background:0 0;flex-direction:column;gap:4px;width:100%;padding:12px 16px;transition:background .1s;display:flex}.so-list-item:hover{background:var(--card-bg)}.so-list-item-active{border-left:3px solid var(--blue);background:var(--card-bg)!important}.so-list-item-top{justify-content:space-between;align-items:center;gap:8px;display:flex}.so-list-item-title{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.so-list-item-sub{color:var(--text-light);gap:10px;font-size:11px;display:flex}.so-status-badge{white-space:nowrap;border-radius:20px;flex-shrink:0;padding:2px 7px;font-size:11px;font-weight:600}.so-status-draft{color:#6b7280;background:#f3f4f6}.so-status-signed{color:#065f46;background:#d1fae5}.so-detail-panel{flex-direction:column;flex:1;display:flex;overflow-y:auto}.so-detail-empty{color:var(--text-light);flex:1;justify-content:center;align-items:center;padding:40px;font-size:13px;display:flex}.so-create-form{max-width:600px;padding:24px}.so-form-group{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.so-sheet-detail{flex-direction:column;flex:1;gap:20px;padding:24px;display:flex}.so-sheet-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.so-detail-title{color:var(--text-main);margin:0 0 6px;font-size:16px;font-weight:700}.so-sheet-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.so-meta-tag{color:var(--text-sub);background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:2px 8px;font-size:12px}.so-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-light);align-items:center;gap:10px;margin-bottom:10px;font-size:11px;font-weight:700;display:flex}.so-content-section{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px}.so-content-body{color:var(--text-main);font-size:13px;line-height:1.65}.so-content-body p{margin:0 0 6px}.so-content-empty{color:var(--text-light);font-style:italic}.so-sign-section{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px}.so-sign-form{flex-direction:column;gap:14px;display:flex}.so-sig-label-row{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.so-sig-canvas{cursor:crosshair;touch-action:none;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:#fff;width:100%;height:130px;display:block}.so-sign-btn{width:100%;padding:11px;font-size:.95rem}.so-sign-hint{color:var(--text-light);text-align:center;margin:0;font-size:12px}.so-signed-state{flex-direction:column;gap:10px;display:flex}.so-signed-row{gap:16px;font-size:13px;display:flex}.so-signed-label{color:var(--text-sub);min-width:140px}.so-signed-value{color:var(--text-main);font-weight:500}.so-sig-preview{margin-top:8px}.so-sig-image{border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;max-width:320px;max-height:100px;padding:8px;display:block}.wh-page{flex-direction:column;height:100%;display:flex;overflow:hidden}.wh-toolbar{border-bottom:1px solid var(--border);background:var(--surface);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:12px;padding:12px 20px;display:flex}.wh-toolbar-title{color:var(--text);font-size:16px;font-weight:700}.wh-toolbar-meta{color:var(--text-muted);font-size:12px}.wh-search-wrap{align-items:center;display:flex;position:relative}.wh-search-input{width:180px;padding-right:28px!important}.wh-search-clear{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:16px;line-height:1;position:absolute;right:6px}.wh-search-clear:hover{color:var(--text)}.wh-grid-container{flex:1;padding:16px 20px;overflow:auto}.wh-col-headers{align-items:center;margin-bottom:4px;display:flex}.wh-col-header{text-align:center;width:130px;min-width:130px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:11px;font-weight:600}.wh-rows{flex-direction:column;gap:6px;display:flex}.wh-row{border-radius:6px;align-items:stretch;gap:6px;padding:3px 0;transition:background .1s;display:flex}.wh-row.wh-row-dragging{opacity:.4}.wh-row.wh-row-above{box-shadow:0 -2px 0 var(--primary,#3b82f6)}.wh-row.wh-row-below{box-shadow:0 2px 0 var(--primary,#3b82f6)}.wh-row-header{cursor:grab;width:38px;min-width:38px;color:var(--text-muted);-webkit-user-select:none;user-select:none;border-radius:4px;justify-content:center;align-items:center;gap:4px;font-size:12px;display:flex}.wh-row-header:hover{background:var(--hover,#0000000a)}.wh-row-handle{color:var(--text-muted);opacity:.5;font-size:14px}.wh-cell{border:1px solid var(--border);background:var(--surface);border-radius:8px;justify-content:center;align-items:center;width:130px;min-width:130px;height:90px;transition:border-color .12s,background .12s;display:flex;position:relative}.wh-cell-empty{cursor:pointer;border-style:dashed}.wh-cell-empty:hover{border-color:var(--primary,#3b82f6);background:#3b82f60a}.wh-cell.wh-drag-over{border-color:var(--primary,#3b82f6);background:#3b82f614}.wh-cell-pos{color:var(--text-muted);opacity:.5;font-size:11px}.wh-crate-tile{cursor:grab;border-radius:7px;justify-content:flex-start;align-items:flex-start;width:100%;height:100%;padding:10px 10px 8px;transition:opacity .12s,box-shadow .12s;display:flex;position:relative;overflow:hidden}.wh-crate-tile:active{cursor:grabbing}.wh-crate-tile.wh-dragging{opacity:.3}.wh-crate-tile.wh-highlight-match{box-shadow:0 0 0 2px var(--primary,#3b82f6)}.wh-crate-tile.wh-highlight-dim{opacity:.25}.wh-crate-tile.wh-occupied{background:linear-gradient(135deg,#3b82f61f 0%,#6366f114 100%);border:1px solid #3b82f640}.wh-crate-tile.wh-unassigned{background:var(--bg,#f8f9fa);border:1px solid var(--border)}.wh-crate-num{color:var(--text-muted);letter-spacing:.04em;margin-bottom:4px;font-size:11px;font-weight:700}.wh-crate-client{color:var(--text);word-break:break-word;font-size:12px;font-weight:600;line-height:1.3}.wh-crate-unassigned{color:var(--text-muted);letter-spacing:.1em;opacity:.6;font-size:10px;font-weight:600}.wh-holding{border-top:1px solid var(--border);background:var(--surface);flex-shrink:0;padding:12px 20px 16px;transition:background .12s}.wh-holding.wh-holding-over{background:#3b82f60d}.wh-holding-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;font-size:12px;font-weight:600}.wh-holding-label span{text-transform:none;letter-spacing:0;font-weight:400}.wh-holding-tiles{flex-wrap:wrap;gap:10px;min-height:40px;display:flex}.wh-holding-empty{color:var(--text-muted);opacity:.5;align-self:center;font-size:13px}.wh-toasts{z-index:9999;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.wh-toast{pointer-events:all;border-radius:8px;align-items:center;gap:12px;min-width:240px;max-width:340px;padding:10px 16px;font-size:13px;font-weight:500;animation:.2s wh-toast-in;display:flex;box-shadow:0 4px 16px #00000024}@keyframes wh-toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.wh-toast-success{color:#fff;background:#16a34a}.wh-toast-error{color:#fff;background:#dc2626}.wh-toast-info{color:#fff;background:#0ea5e9}.wh-toast-msg{flex:1}.wh-toast-undo{color:#fff;cursor:pointer;background:#fff3;border:1px solid #fff6;border-radius:4px;flex-shrink:0;padding:2px 8px;font-size:12px;font-weight:600}.wh-toast-undo:hover{background:#ffffff59}.wh-ac-list{background:var(--surface);border:1px solid var(--border);z-index:200;border-radius:6px;max-height:200px;margin-top:2px;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 16px #0000001f}.wh-ac-item{cursor:pointer;color:var(--text);padding:8px 12px;font-size:13px}.wh-ac-item:hover{background:var(--hover,#0000000a)}.wh-det-summary{background:var(--bg,#f8f9fa);border:1px solid var(--border);border-radius:8px;flex-wrap:wrap;gap:16px;margin-bottom:16px;padding:12px 16px;display:flex}.wh-det-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px;font-size:11px}.wh-det-val{color:var(--text);font-size:14px;font-weight:600}.wh-warning-box{color:var(--danger,#dc2626);background:#dc262614;border:1px solid #dc262640;border-radius:6px;margin-bottom:12px;padding:12px 14px;font-size:14px;font-weight:600}.wh-inv-list{border:1px solid var(--border);border-radius:6px;flex-direction:column;gap:2px;display:flex;overflow:hidden}.wh-inv-item{border-bottom:1px solid var(--border);background:var(--surface);align-items:center;gap:8px;padding:6px 10px;font-size:13px;transition:background .1s;display:flex}.wh-inv-item:last-child{border-bottom:none}.wh-inv-item.wh-inv-dragging{opacity:.35}.wh-inv-item.wh-inv-above{box-shadow:inset 0 2px 0 var(--primary,#3b82f6)}.wh-inv-item.wh-inv-below{box-shadow:inset 0 -2px 0 var(--primary,#3b82f6)}.wh-inv-handle{cursor:grab;color:var(--text-muted);opacity:.4;flex-shrink:0;font-size:13px}.wh-inv-num{color:var(--text-muted);flex-shrink:0;min-width:18px;font-size:12px}.wh-inv-qty{border:1px solid var(--border);text-align:center;background:var(--surface);width:44px;color:var(--text);border-radius:4px;flex-shrink:0;padding:2px 6px;font-size:13px}.wh-inv-qty:focus{border-color:var(--primary,#3b82f6);outline:none}.wh-inv-desc{cursor:text;color:var(--text);flex:1;min-width:0}.wh-inv-desc:hover{-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.wh-inv-desc-input{flex:1;min-width:0}.wh-inv-del{color:var(--text-muted);cursor:pointer;opacity:.5;background:0 0;border:none;flex-shrink:0;padding:0 2px;font-size:16px;line-height:1}.wh-inv-del:hover{color:var(--danger,#dc2626);opacity:1}.wh-client-crates{padding:20px 24px}.wh-client-crates-empty{text-align:center;color:var(--text-muted);padding:40px 0;font-size:14px}.wh-client-crate-list{flex-direction:column;gap:8px;display:flex}.wh-client-crate-row{border:1px solid var(--border);background:var(--surface);border-radius:8px;align-items:center;gap:12px;padding:12px 14px;font-size:13px;display:flex}.wh-client-crate-num{color:var(--text);min-width:60px;font-weight:700}.wh-client-crate-wh{color:var(--text-muted);flex:1}.wh-client-crate-pos{color:var(--text-muted);background:var(--bg,#f8f9fa);border:1px solid var(--border);border-radius:4px;padding:2px 8px;font-size:12px}.ap-filters{flex-direction:column;gap:10px;margin-bottom:20px;display:flex}.ap-filter-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.ap-client-link{color:var(--blue);cursor:pointer;text-align:left;background:0 0;border:none;padding:0;font-family:inherit;font-size:13px;font-weight:600}.ap-client-link:hover{text-decoration:underline}.ap-notes-preview{text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}.ap-row-today td{background:#fffbeb!important}.ap-overdue{color:#dc2626;font-weight:600}.eb-page{flex-direction:column;height:100%;min-height:0;display:flex}.eb-topbar{flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;padding:0 0 20px;display:flex}.eb-topbar-left{align-items:center;gap:16px;display:flex}.eb-title-group{align-items:center;gap:10px;display:flex}.eb-title{color:var(--navy);margin:0;font-size:1.4rem;font-weight:700}.eb-topbar-right{align-items:center;gap:8px;display:flex}.eb-status-select{width:auto;min-width:120px}.eb-body{flex-direction:column;flex:1;gap:20px;padding-bottom:40px;display:flex;overflow-y:auto}.eb-section{border:1px solid var(--border);background:#fff;border-radius:10px;padding:20px 22px}.eb-section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:0 0 16px;font-size:.85rem;font-weight:700}.eb-items-wrap{overflow-x:auto}.eb-items-table{border-collapse:collapse;width:100%;font-size:.875rem}.eb-items-table th{background:var(--bg-light,#f8f9fa);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;text-align:left;border-bottom:1px solid var(--border);padding:8px 10px;font-size:.75rem;font-weight:600}.eb-items-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:5px 4px}.eb-items-table tbody tr:last-child td{border-bottom:none}.eb-col-desc{width:40%}.eb-col-qty{width:80px}.eb-col-price{width:130px}.eb-col-vat{width:90px}.eb-col-total{width:110px}.eb-col-del{width:36px}.eb-cell-input{width:100%;color:var(--navy);background:0 0;border:1px solid #0000;border-radius:5px;padding:6px 8px;font-family:inherit;font-size:.875rem;transition:border-color .15s,background .15s}.eb-cell-input:focus{border-color:var(--primary,#2563eb);background:#fff;outline:none}.eb-cell-input:hover{background:var(--bg-light,#f8f9fa)}.eb-cell-num{text-align:right}.eb-line-total{text-align:right;color:var(--navy);white-space:nowrap;padding-right:6px;font-weight:600}.eb-remove-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;transition:color .15s,background .15s;display:flex}.eb-remove-btn:hover{color:var(--danger,#dc2626);background:#fee2e2}.eb-add-row{margin-top:10px}.eb-totals-section{justify-content:flex-end;display:flex}.eb-totals{flex-direction:column;gap:6px;min-width:320px;display:flex}.eb-total-row{color:var(--text-muted);justify-content:space-between;padding:4px 0;font-size:.9rem;display:flex}.eb-total-row span:last-child{color:var(--navy);font-variant-numeric:tabular-nums;font-weight:600}.eb-grand-total{border-top:2px solid var(--navy);margin-top:6px;padding-top:10px;font-size:1.05rem;color:var(--navy)!important}.eb-grand-total span{font-weight:700;color:var(--navy)!important}.eb-note-area{resize:vertical;min-height:120px}.eb-preview-overlay{z-index:1000;background:#0000008c;justify-content:center;align-items:flex-start;padding:24px;display:flex;position:fixed;inset:0;overflow-y:auto}.eb-preview-modal{background:#fff;border-radius:12px;flex-direction:column;width:100%;max-width:820px;display:flex;overflow:hidden;box-shadow:0 24px 64px #0000004d}.eb-preview-bar{border-bottom:1px solid var(--border);background:var(--bg-light,#f8f9fa);color:var(--navy);z-index:1;justify-content:space-between;align-items:center;padding:14px 20px;font-size:.9rem;font-weight:600;display:flex;position:sticky;top:0}.eb-preview-doc{color:#222;padding:40px 48px;font-size:.88rem;line-height:1.6}.eb-doc-header{justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:28px;display:flex}.eb-doc-logo{align-items:center;gap:12px;display:flex}.eb-doc-logo-img{object-fit:contain;width:48px;height:48px}.eb-doc-logo-text{flex-direction:column;display:flex}.eb-doc-brand{letter-spacing:.08em;color:var(--navy,#1e2d45);font-size:1.15rem;font-weight:800}.eb-doc-tagline{color:#666;letter-spacing:.04em;font-size:.75rem}.eb-doc-meta{text-align:right}.eb-doc-meta-row{color:#555;justify-content:flex-end;gap:12px;margin-bottom:2px;font-size:.82rem;display:flex}.eb-doc-meta-row strong{color:#222;text-align:right;min-width:80px}.eb-doc-divider{background:#e5e7eb;height:1px;margin:20px 0}.eb-doc-parties{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:24px;margin-bottom:4px;display:grid}.eb-doc-party-label{text-transform:uppercase;letter-spacing:.07em;color:#888;margin-bottom:4px;font-size:.72rem;font-weight:700}.eb-doc-party-name{color:#1a1a1a;font-size:.95rem;font-weight:700}.eb-doc-party-sub{color:#555;margin-top:2px;font-size:.82rem}.eb-doc-table{border-collapse:collapse;width:100%;margin-bottom:4px;font-size:.85rem}.eb-doc-table th{background:var(--navy,#1e2d45);color:#fff;text-transform:uppercase;letter-spacing:.04em;text-align:left;padding:8px 10px;font-size:.75rem;font-weight:600}.eb-doc-table th.eb-doc-num{text-align:right}.eb-doc-table td{color:#333;border-bottom:1px solid #e5e7eb;padding:8px 10px}.eb-doc-table td.eb-doc-num{text-align:right;font-variant-numeric:tabular-nums}.eb-doc-table tbody tr:nth-child(2n){background:#f9fafb}.eb-doc-section-row td{text-transform:uppercase;letter-spacing:.06em;color:#888;border-bottom:1px solid #e5e7eb;padding:6px 10px;font-size:.78rem;font-weight:700;background:#f3f4f6!important}.eb-doc-totals{flex-direction:column;align-items:flex-end;gap:4px;margin:16px 0 4px;display:flex}.eb-doc-total-row{color:#555;gap:48px;font-size:.85rem;display:flex}.eb-doc-total-row span:last-child{text-align:right;font-variant-numeric:tabular-nums;min-width:90px}.eb-doc-grand{border-top:2px solid #1e2d45;margin-top:4px;padding-top:8px;font-size:1rem;font-weight:700;color:#1e2d45!important}.eb-doc-grand span{color:#1e2d45!important}.eb-doc-note{color:#444;margin:8px 0;font-size:.85rem;line-height:1.7}.eb-doc-note p{margin:0 0 4px}.eb-doc-tcs{margin:8px 0}.eb-doc-tc-title{text-transform:uppercase;letter-spacing:.07em;color:#888;margin-bottom:6px;font-size:.78rem;font-weight:700}.eb-doc-tc-sub{color:#888;margin:0 0 12px;font-size:.8rem}.eb-doc-tc-clauses{flex-direction:column;gap:10px;display:flex}.eb-tc-clause{cursor:pointer;color:#444;align-items:flex-start;gap:10px;font-size:.83rem;line-height:1.55;display:flex}.eb-tc-clause input[type=checkbox]{accent-color:#1e2d45;cursor:pointer;flex-shrink:0;width:15px;height:15px;margin-top:2px}.eb-tc-clause.eb-tc-clause-done,.eb-tc-clause.eb-tc-clause-done input{cursor:default}.eb-tc-clause strong{color:#333;margin-right:2px;font-weight:600}.eb-doc-accept{margin:8px 0}.eb-doc-accept-title{text-transform:uppercase;letter-spacing:.07em;color:#888;margin-bottom:12px;font-size:.78rem;font-weight:700}.eb-doc-accept p{color:#555;margin:0 0 12px;font-size:.82rem}.eb-sig-wrap{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;overflow:hidden}.eb-sig-header{background:#f9fafb;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.eb-sig-client-name{color:#374151;font-size:.82rem;font-weight:600}.eb-sig-canvas{cursor:crosshair;touch-action:none;background:#fff;width:100%;height:140px;display:block}.eb-sig-underline-label{text-align:center;color:#9ca3af;background:#f9fafb;border-top:1px solid #e5e7eb;padding:6px 0;font-size:.75rem}.eb-accept-footer{margin-top:16px}.eb-accept-btn{width:100%;padding:12px;font-size:.95rem}.eb-accept-hint{color:#9ca3af;text-align:center;margin:0;font-size:.82rem}.eb-sig-done{text-align:center;background:#f0fdf4;border:1.5px solid #d1fae5;border-radius:8px;padding:16px}.eb-sig-image{max-width:340px;max-height:120px;margin:0 auto 8px;display:block}.eb-sig-done-label{color:#059669;margin:0;font-size:.83rem;font-weight:600}.eb-doc-footer{text-align:center;color:#aaa;letter-spacing:.04em;margin-top:28px;font-size:.75rem}.inv-status-badge{letter-spacing:.08em;text-transform:uppercase;border-radius:4px;padding:3px 10px;font-size:.75rem;font-weight:800;display:inline-block}.inv-status-badge.paid{color:#15803d;background:#dcfce7}.inv-status-badge.deposit{color:#854d0e;background:#fef9c3}.inv-status-badge.unpaid{color:#dc2626;background:#fee2e2}.inv-watermark{color:#15803d14;letter-spacing:.2em;pointer-events:none;-webkit-user-select:none;user-select:none;white-space:nowrap;font-size:6rem;font-weight:900;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)rotate(-35deg)}.eb-preview-doc{position:relative}.inv-meta-paid{color:#15803d!important}.inv-meta-unpaid{color:#dc2626!important}.dep-header{align-items:center;gap:10px;margin-bottom:14px;display:flex}.dep-optional-label{color:#6b7280;background:#f3f4f6;border-radius:10px;padding:2px 7px;font-size:.72rem;font-weight:500}.dep-controls{align-items:center;gap:10px;margin-bottom:14px;display:flex}.dep-toggle{border:1px solid var(--border);border-radius:6px;display:flex;overflow:hidden}.dep-type-btn{cursor:pointer;color:var(--text-muted);background:#fff;border:none;padding:7px 14px;font-size:.9rem;font-weight:600;transition:background .15s,color .15s}.dep-type-btn.active{background:var(--navy);color:#fff}.dep-input{width:130px}.dep-days-wrap{align-items:center;gap:6px;display:flex}.dep-days-label{color:var(--text-muted);white-space:nowrap;font-size:.85rem}.dep-days-input{width:80px}.dep-days-suffix{color:var(--text-muted);font-size:.85rem}.dep-summary{border:1px solid var(--border);background:#f9fafb;border-radius:8px;flex-direction:column;gap:6px;padding:12px 16px;display:flex}.dep-row{color:var(--text-muted);justify-content:space-between;font-size:.9rem;display:flex}.dep-row span:last-child{color:var(--navy);font-weight:600}.dep-balance{border-top:1px solid var(--border);margin-top:2px;padding-top:8px;font-weight:700;color:var(--navy)!important}.dep-balance span{font-weight:700;color:var(--navy)!important}.inv-dep-row{font-style:italic;color:#555!important}.inv-balance-row,.inv-balance-row span{color:#15803d!important}.inv-bank-section{margin:4px 0}.inv-bank-title{text-transform:uppercase;letter-spacing:.07em;color:#888;margin-bottom:10px;font-size:.78rem;font-weight:700}.inv-bank-grid{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px 24px;padding:14px 16px;display:grid}.inv-bank-grid>div{flex-direction:column;gap:2px;display:flex}.inv-bank-grid span{color:#888;text-transform:uppercase;letter-spacing:.05em;font-size:.72rem}.inv-bank-grid strong{color:#1a1a1a;font-size:.88rem;font-weight:600}.cal-page{background:var(--bg);flex-direction:column;height:calc(100vh - 60px);display:flex;overflow:hidden}.cal-topbar{border-bottom:1px solid var(--border);background:#fff;flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 24px 10px;display:flex}.cal-nav{align-items:center;gap:8px;display:flex}.cal-nav-btn{border:1px solid var(--border);cursor:pointer;width:32px;height:32px;color:var(--navy);background:0 0;border-radius:6px;justify-content:center;align-items:center;font-size:1.3rem;line-height:1;display:flex}.cal-nav-btn:hover{background:var(--bg)}.cal-header-label{color:var(--navy);text-align:center;min-width:220px;font-size:1.1rem;font-weight:700}.cal-today-btn{background:var(--navy);color:#fff;cursor:pointer;border:none;border-radius:6px;margin-left:4px;padding:6px 14px;font-size:.85rem;font-weight:600}.cal-today-btn:hover{opacity:.88}.cal-views{border:1px solid var(--border);border-radius:8px;display:flex;overflow:hidden}.cal-view-btn{color:var(--text-muted);cursor:pointer;border:none;border-right:1px solid var(--border);background:#fff;padding:7px 18px;font-size:.85rem;font-weight:600;transition:background .1s}.cal-view-btn:last-child{border-right:none}.cal-view-btn.active{background:var(--navy);color:#fff}.cal-view-btn:hover:not(.active){background:var(--bg)}.cal-legend{border-bottom:1px solid var(--border);background:#fff;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:16px;padding:8px 24px;display:flex}.cal-legend-item{color:var(--text-muted);align-items:center;gap:6px;font-size:.78rem;font-weight:500;display:flex}.cal-legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.cal-loading{color:var(--text-muted);flex:1;justify-content:center;align-items:center;font-size:.9rem;display:flex}.cal-month{flex-direction:column;flex:1;display:flex;overflow:hidden}.cal-month-header{border-bottom:1px solid var(--border);background:#f9fafb;flex-shrink:0;grid-template-columns:repeat(7,1fr);display:grid}.cal-month-dayname{text-align:center;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:8px 0;font-size:.75rem;font-weight:700}.cal-month-grid{flex:1;grid-template-rows:repeat(6,1fr);grid-template-columns:repeat(7,1fr);display:grid;overflow:hidden}.cal-day-cell{border-right:1px solid var(--border);border-bottom:1px solid var(--border);flex-direction:column;gap:2px;min-height:0;padding:4px 6px;display:flex;overflow:hidden}.cal-day-cell:nth-child(7n){border-right:none}.cal-day-cell.other-month{background:#f9fafb}.cal-day-cell.today{background:#eff6ff}.cal-day-num{color:var(--navy);cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-self:flex-start;align-items:center;width:26px;height:26px;padding:0;font-size:.82rem;font-weight:700;display:flex}.cal-day-cell.today .cal-day-num{background:var(--navy);color:#fff}.cal-day-cell.other-month .cal-day-num{color:#bbb}.cal-day-num:hover{background:var(--border)}.cal-day-cell.today .cal-day-num:hover{background:var(--navy)}.cal-day-events{flex-direction:column;flex:1;gap:2px;min-height:0;display:flex;overflow:hidden}.cal-event-pill{cursor:pointer;text-align:left;white-space:nowrap;text-overflow:ellipsis;border:none;border-radius:4px;flex-shrink:0;align-items:center;gap:4px;width:100%;padding:2px 6px;font-size:.72rem;font-weight:600;line-height:1.4;display:flex;overflow:hidden}.cal-pill-time{opacity:.85;flex-shrink:0;font-weight:700}.cal-pill-label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.cal-overflow{color:var(--text-muted);cursor:pointer;text-align:left;background:0 0;border:none;padding:1px 6px;font-size:.7rem;font-weight:600}.cal-overflow:hover{color:var(--navy)}.cal-week{flex-direction:column;flex:1;display:flex;overflow:hidden}.cal-week-header{border-bottom:1px solid var(--border);background:#f9fafb;flex-shrink:0;display:flex}.cal-time-gutter{flex-shrink:0;width:64px}.cal-week-col-head{border-left:1px solid var(--border);flex-direction:column;flex:1;align-items:center;padding:8px 0;display:flex}.cal-week-col-head.today{background:#eff6ff}.cal-week-dayname{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.72rem;font-weight:700}.cal-week-daynum{color:var(--navy);font-size:1.1rem;font-weight:800;line-height:1.2}.cal-week-col-head.today .cal-week-daynum{color:#2563eb}.cal-allday-row{border-bottom:1px solid var(--border);background:#fafafa;flex-shrink:0;min-height:32px;display:flex}.cal-allday-label{text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;justify-content:flex-end;align-items:center;padding-right:8px;font-size:.65rem;font-weight:700;display:flex}.cal-allday-cell{border-left:1px solid var(--border);flex-direction:column;flex:1;gap:2px;padding:4px;display:flex}.cal-time-grid{flex:1;display:flex;overflow-y:auto}.cal-time-col{flex-shrink:0;width:64px;position:relative}.cal-time-slot{justify-content:flex-end;align-items:flex-start;height:64px;padding-top:0;padding-right:8px;display:flex}.cal-time-label{color:var(--text-muted);white-space:nowrap;margin-top:-8px;font-size:.68rem;font-weight:600}.cal-day-col{border-left:1px solid var(--border);flex:1;min-height:896px;position:relative}.cal-day-col-single{flex:1}.cal-hour-line{pointer-events:none;border-bottom:1px solid #f0f0f0;height:64px}.cal-timed-event{cursor:pointer;text-align:left;z-index:1;border:none;border-radius:4px;flex-direction:column;padding:3px 6px;font-size:.72rem;font-weight:600;line-height:1.3;display:flex;position:absolute;left:2px;right:2px;overflow:hidden}.cal-te-time{opacity:.85;font-size:.68rem}.cal-te-label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.cal-day-view{flex-direction:column;flex:1;display:flex;overflow:hidden}.cal-day-view-header{border-bottom:1px solid var(--border);background:#f9fafb;flex-shrink:0;padding:12px 24px}.cal-day-view-label{color:var(--navy);font-size:1rem;font-weight:700}.cal-day-view-label.today{color:#2563eb}.cal-modal-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.cal-modal{background:var(--card-bg);border-radius:var(--radius);flex-direction:column;width:100%;max-width:520px;display:flex;overflow:hidden;box-shadow:0 20px 60px #00000040}.cal-modal-header{border-bottom:1px solid var(--border);color:var(--text-main);justify-content:space-between;align-items:center;padding:16px 20px;font-size:15px;font-weight:700;display:flex}.cal-modal-body{flex-direction:column;gap:14px;max-height:70vh;padding:20px;display:flex;overflow-y:auto}.cal-modal-footer{justify-content:flex-end;gap:10px;padding-top:8px;display:flex}.cal-form-group{flex-direction:column;flex:1;gap:5px;display:flex}.cal-form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.cal-form-label{color:var(--text-sub);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:600}.cal-form-input{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-main);background:var(--bg);box-sizing:border-box;width:100%;padding:9px 12px;font-size:14px}.cal-form-input:focus{border-color:var(--blue);outline:none}.cal-form-textarea{resize:vertical;min-height:72px}.cal-form-error{color:#ef4444;margin:0;font-size:13px}.cal-detail-row{border-bottom:1px solid var(--border);align-items:center;gap:16px;padding:8px 0;font-size:14px;display:flex}.cal-detail-row:last-child{border-bottom:none}.cal-detail-label{color:var(--text-sub);min-width:80px;font-size:13px}.cal-detail-value{color:var(--text-main);align-items:center;font-weight:500;display:flex}.sv-page{background:var(--bg);flex-direction:column;height:calc(100vh - 60px);display:flex;overflow:hidden}.sv-topbar{border-bottom:1px solid var(--border);background:#fff;flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;padding:12px 24px;display:flex}.sv-back{color:var(--navy);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:0;font-size:.9rem;font-weight:600}.sv-back:hover{text-decoration:underline}.sv-topbar-center{flex:1;justify-content:center;align-items:center;gap:10px;display:flex}.sv-title{color:var(--navy);font-size:1rem;font-weight:700}.sv-status-badge{letter-spacing:.07em;text-transform:uppercase;border-radius:4px;padding:3px 10px;font-size:.72rem;font-weight:800;display:inline-block}.sv-status-badge.draft{color:#6b7280;background:#f3f4f6}.sv-status-badge.complete{color:#15803d;background:#dcfce7}.sv-topbar-actions{align-items:center;gap:10px;display:flex}.sv-error{color:#dc2626;font-size:.82rem}.sv-body{flex:1;gap:0;display:flex;overflow:hidden}.sv-left{flex-direction:column;flex:1;gap:20px;padding:20px 24px;display:flex;overflow-y:auto}.sv-section{border:1px solid var(--border);background:#fff;border-radius:10px;padding:18px 20px}.sv-section-title{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin:0 0 14px;font-size:.78rem;font-weight:700}.sv-grid{grid-template-columns:1fr 1fr;gap:12px 16px;display:grid}.sv-field{flex-direction:column;gap:4px;display:flex}.sv-col-2{grid-column:span 1}.sv-col-full{grid-column:1/-1}.sv-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.sv-input,.sv-select{border:1px solid var(--border);color:var(--navy);box-sizing:border-box;background:#fff;border-radius:6px;width:100%;padding:8px 10px;font-size:.9rem}.sv-input:focus,.sv-select:focus{border-color:var(--navy);outline:none}.sv-textarea{resize:vertical;min-height:60px;font-family:inherit}.sv-room-card{border:1px solid var(--border);background:#f9fafb;border-radius:8px;margin-bottom:12px;padding:14px 16px}.sv-room-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.sv-room-name{color:var(--navy);cursor:pointer;background:0 0;border:none;padding:0;font-size:.95rem;font-weight:700}.sv-room-name:hover{text-decoration:underline}.sv-room-name-input{width:auto;padding:4px 8px;font-size:.95rem;font-weight:700}.sv-room-delete{color:#d1d5db;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:.85rem}.sv-room-delete:hover{color:#dc2626;background:#fee2e2}.sv-items-table{border-collapse:collapse;width:100%;margin-bottom:10px;font-size:.85rem}.sv-items-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);padding:4px 6px 6px;font-size:.7rem;font-weight:700}.sv-items-table td{vertical-align:middle;padding:3px 4px}.sv-col-qty,.sv-col-cbf{width:80px}.sv-col-del{width:28px}.sv-cell-input{box-sizing:border-box;width:100%;color:var(--navy);background:0 0;border:1px solid #0000;border-radius:4px;padding:4px 6px;font-size:.85rem}.sv-cell-input:focus{border-color:var(--navy);background:#fff;outline:none}.sv-cell-num{text-align:right}.sv-item-total{color:var(--navy);text-align:right;white-space:nowrap;padding:4px 8px;font-weight:700}.sv-item-del{color:#d1d5db;cursor:pointer;background:0 0;border:none;border-radius:3px;padding:2px 4px;font-size:.75rem}.sv-item-del:hover{color:#dc2626;background:#fee2e2}.sv-add-item-btn{color:var(--text-muted);cursor:pointer;text-align:center;background:0 0;border:1px dashed #d1d5db;border-radius:6px;width:100%;margin-top:4px;padding:6px 12px;font-size:.82rem}.sv-add-item-btn:hover{border-color:var(--navy);color:var(--navy);background:#f0f4ff}.sv-quickadd-panel{border:1px solid var(--border);background:#fff;border-radius:8px;margin-top:6px;padding:12px}.sv-quickadd-search{margin-bottom:10px}.sv-quickadd-list{flex-direction:column;gap:8px;max-height:220px;margin-bottom:10px;display:flex;overflow-y:auto}.sv-quickadd-cat-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:4px;font-size:.68rem;font-weight:700}.sv-quickadd-chips{flex-wrap:wrap;gap:6px;display:flex}.sv-quickadd-chip{border:1px solid var(--border);color:var(--navy);cursor:pointer;background:#f3f4f6;border-radius:20px;align-items:center;gap:6px;padding:4px 10px;font-size:.78rem;display:flex}.sv-quickadd-chip:hover{background:var(--navy);color:#fff;border-color:var(--navy)}.sv-quickadd-chip:hover .sv-chip-cbf{color:#ffffffb3}.sv-chip-cbf{color:var(--text-muted);font-size:.72rem}.sv-custom-row{border-top:1px solid var(--border);align-items:center;gap:8px;margin-bottom:8px;padding-top:10px;display:flex}.sv-custom-desc{flex:1}.sv-custom-cbf{width:80px}.sv-quickadd-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:.78rem;text-decoration:underline}.sv-add-room-row{align-items:center;gap:10px;display:flex}.sv-room-picker{flex:1}.sv-right{border-left:1px solid var(--border);background:#fff;flex-shrink:0;width:280px;padding:20px 18px;overflow-y:auto}.sv-summary-card{flex-direction:column;gap:12px;display:flex}.sv-summary-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:.72rem;font-weight:700}.sv-total-cbf{color:var(--navy);font-size:3.5rem;font-weight:900;line-height:1}.sv-total-cbf span{color:var(--text-muted);font-size:1.2rem;font-weight:700}.sv-cbf-note{color:var(--text-muted);margin-top:-8px;font-size:.78rem}.sv-room-breakdown{border-top:1px solid var(--border);flex-direction:column;gap:6px;padding-top:12px;display:flex}.sv-breakdown-row{color:var(--text-muted);justify-content:space-between;font-size:.85rem;display:flex}.sv-breakdown-cbf{color:var(--navy);font-weight:600}.sv-breakdown-total{color:var(--navy);border-top:1px solid var(--border);justify-content:space-between;margin-top:4px;padding-top:8px;font-size:.9rem;font-weight:700;display:flex}.sv-estimate-btn{width:100%;margin-top:8px}.st-toolbar{flex-wrap:wrap;align-items:center;gap:16px;padding:0 0 16px;display:flex}.st-table th,.st-table td{vertical-align:middle}.st-col-num{text-align:right;width:90px}.st-threshold{color:var(--text-muted)}.st-qty{color:var(--navy);font-size:1rem;font-weight:800}.st-qty.low{color:#d97706}.st-qty.out{color:#dc2626}.st-row-low td{background:#fffbeb}.st-row-out td{background:#fff5f5}.rc-badge-amber{color:#854d0e;background:#fef9c3}.st-adj-btn{border:1px solid var(--border);cursor:pointer;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:1rem;font-weight:700;line-height:1;display:inline-flex}.st-adj-btn.st-add{color:#15803d;background:#dcfce7;border-color:#bbf7d0}.st-adj-btn.st-add:hover{color:#fff;background:#16a34a}.st-adj-btn.st-remove{color:#dc2626;background:#fee2e2;border-color:#fecaca}.st-adj-btn.st-remove:hover{color:#fff;background:#dc2626}.rc-tab-count.st-warn{color:#854d0e;background:#fef9c3}.rc-tab-count.st-danger{color:#dc2626;background:#fee2e2}.st-adjust-form{flex-direction:column;gap:6px;display:flex}.st-adjust-current{color:var(--text-muted);background:var(--bg);border-radius:6px;margin-bottom:10px;padding:10px 14px;font-size:.9rem}.st-adjust-actions{justify-content:flex-end;gap:10px;margin-top:16px;display:flex}.st-history{flex-direction:column;gap:4px;max-height:360px;display:flex;overflow-y:auto}.st-history-row{background:var(--bg);border-radius:6px;justify-content:space-between;align-items:center;padding:8px 12px;font-size:.85rem;display:flex}.st-history-left{align-items:center;gap:10px;display:flex}.st-history-change{text-align:right;min-width:36px;font-size:.9rem;font-weight:800}.st-history-change.add{color:#15803d}.st-history-change.remove{color:#dc2626}.st-history-note{color:var(--text-muted)}.st-history-date{color:var(--text-muted);font-size:.78rem}.st-item-form .sv-grid{grid-template-columns:1fr 1fr;gap:12px 16px;display:grid}.st-item-form .sv-field{flex-direction:column;gap:4px;display:flex}.st-item-form .sv-col-full{grid-column:1/-1}.st-item-form .sv-col-2{grid-column:span 1}.db-stock-list{flex-direction:column;gap:4px;display:flex}.db-stock-row{background:var(--bg);border-radius:6px;justify-content:space-between;align-items:center;padding:7px 12px;font-size:.85rem;display:flex}.db-stock-name{color:var(--navy);font-weight:600}.db-stock-right{align-items:center;gap:8px;display:flex}.db-stock-qty{font-weight:700}.db-stock-qty.out{color:#dc2626}.db-stock-qty.low{color:#d97706}.st-shortfalls{border-radius:var(--radius);background:#fffbeb;border:1px solid #fde68a;margin-top:24px}.st-shortfalls-header{border-bottom:1px solid #fde68a;flex-direction:column;gap:2px;padding:12px 16px;display:flex}.st-shortfalls-title{color:#92400e;align-items:center;gap:8px;font-size:14px;font-weight:700;display:flex}.st-shortfalls-sub{color:#b45309;font-size:12px}.st-shortfall-prompt-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:10px 0;font-size:13px;display:flex}.st-shortfall-prompt-row:last-child{border-bottom:none}.vc-form{flex-direction:column;gap:0;display:flex}.vc-vehicle-bar{border-bottom:1px solid var(--border);align-items:center;gap:10px;margin-bottom:16px;padding:10px 0 14px;display:flex}.vc-vehicle-name{color:var(--text);font-size:15px;font-weight:700}.vc-vehicle-type{color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:2px 8px;font-size:11px}.vc-meta-grid{grid-template-columns:1fr 1fr 1fr 1fr;gap:12px;margin-bottom:18px;display:grid}.vc-meta-field{flex-direction:column;gap:4px;display:flex}.vc-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:700}.vc-checklist{border:1px solid var(--border);border-radius:8px;max-height:380px;margin-bottom:14px;overflow:hidden auto}.vc-cat-section{border-bottom:2px solid var(--border)}.vc-cat-section:last-child{border-bottom:none}.vc-cat-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);background:var(--bg);border-bottom:1px solid var(--border);padding:5px 12px;font-size:10px;font-weight:800}.vc-item{background:var(--surface);border-bottom:1px solid #0000000a;justify-content:space-between;align-items:center;gap:10px;padding:7px 12px;transition:background .1s;display:flex}.vc-item:last-child{border-bottom:none}.vc-item-fail{background:#dc26260a}.vc-item-text{color:var(--text);flex:1;font-size:12.5px;line-height:1.3}.vc-item-actions{flex-shrink:0;align-items:center;gap:5px;display:flex}.vc-pass-btn,.vc-fail-btn{cursor:pointer;border:1px solid #0000;border-radius:4px;padding:3px 9px;font-size:11.5px;font-weight:600;line-height:1.4;transition:all .1s}.vc-pass-btn{background:var(--bg);border-color:var(--border);color:var(--text-muted)}.vc-pass-btn.active{color:#166534;background:#dcfce7;border-color:#22c55e}.vc-pass-btn:hover:not(.active){color:#166534;border-color:#22c55e}.vc-fail-btn{background:var(--bg);border-color:var(--border);color:var(--text-muted)}.vc-fail-btn.active{color:#991b1b;background:#fee2e2;border-color:#ef4444}.vc-fail-btn:hover:not(.active){color:#991b1b;border-color:#ef4444}.vc-major-label{cursor:pointer;color:#dc2626;white-space:nowrap;-webkit-user-select:none;user-select:none;background:#dc262614;border:1px solid #dc262640;border-radius:4px;align-items:center;gap:4px;padding:2px 7px;font-size:11px;font-weight:700;display:flex}.vc-major-label input{accent-color:#dc2626;cursor:pointer}.vc-status-banner{border-radius:6px;margin-bottom:12px;padding:10px 14px;font-size:13px;font-weight:700}.vc-status-pass{color:#166534;background:#dcfce7;border:1px solid #86efac}.vc-status-advisory{color:#92400e;background:#fef3c7;border:1px solid #fcd34d}.vc-status-fail{color:#991b1b;background:#fee2e2;border:1px solid #fca5a5}.vc-sig-section{border-top:1px solid var(--border);flex-direction:column;gap:12px;margin-top:12px;padding-top:14px;display:flex}.vc-sig-canvas-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.vc-sig-canvas{border:1.5px solid var(--border);cursor:crosshair;touch-action:none;background:#fff;border-radius:6px;width:100%;height:130px;display:block}.vc-sig-hint{color:var(--text-muted);text-align:center;margin:4px 0 0;font-size:11px}.mp-page{background:var(--bg);flex-direction:column;height:100%;display:flex}.mp-header{background:var(--surface);border-bottom:1px solid var(--border);align-items:center;gap:16px;padding:16px 24px;display:flex}.mp-back{color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:6px;align-items:center;gap:6px;padding:4px 8px;font-size:13px;display:flex}.mp-back:hover{background:var(--bg);color:var(--text)}.mp-header-info{flex:1}.mp-breadcrumb{color:var(--text-muted);align-items:center;gap:6px;margin-bottom:2px;font-size:12px;display:flex}.mp-client-name{color:var(--text);font-weight:600}.mp-sep{color:var(--border)}.mp-job-ref{color:var(--text-muted)}.mp-title{color:var(--text);margin:0;font-size:20px;font-weight:700}.mp-body{flex-direction:column;flex:1;display:flex;overflow:hidden}.mp-empty{color:var(--text-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:60px 24px;display:flex}.mp-empty p{margin:0;font-size:14px}.mp-table-wrap{flex:1;padding:20px 24px 0;overflow:auto}.mp-table{border-collapse:collapse;width:100%;font-size:13px}.mp-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap;padding:8px 12px;font-size:11px;font-weight:600}.mp-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:10px 12px}.mp-table tbody tr:hover{background:var(--bg)}.mp-row-complete td{opacity:.6}.mp-stage-num{color:var(--text);font-weight:700}.mp-date-cell{white-space:nowrap;color:var(--text-muted);font-size:12px}.mp-service-cell{white-space:nowrap}.mp-addr-cell{text-overflow:ellipsis;white-space:nowrap;max-width:140px;overflow:hidden}.mp-crew-cell{text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:12px;overflow:hidden}.mp-vehicles-cell{font-size:12px}.mp-none{color:var(--text-muted)}.mp-row-actions{flex-wrap:nowrap;gap:4px;display:flex}.mp-btn-complete{color:var(--success,#16a34a)!important}.mp-action-bar{border-top:1px solid var(--border);background:var(--surface);gap:8px;padding:16px 24px;display:flex}.mp-signoffs{border-top:1px solid var(--border);padding:20px 24px}.mp-signoffs-header{align-items:baseline;gap:12px;margin-bottom:14px;display:flex}.mp-signoffs-title{color:var(--text-main);margin:0;font-size:14px;font-weight:700}.mp-signoffs-sub{color:var(--text-sub);font-size:12px}.mp-signoffs-list{flex-direction:column;gap:8px;display:flex}.mp-signoff-card{border-radius:var(--radius-sm);background:#fffbeb;border:1.5px solid #fde68a;justify-content:space-between;align-items:center;gap:16px;padding:12px 16px;display:flex}.mp-signoff-card.mp-signoff-signed{background:#f0fdf4;border-color:#bbf7d0}.mp-signoff-card-top{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.mp-signoff-title{color:var(--text-main);font-size:13px;font-weight:600}.mp-signoff-signed-info{color:var(--text-sub);gap:16px;font-size:12px;display:flex}.mp-signoff-btn{flex-shrink:0}.mp-signoffs-note{color:var(--text-light);margin:12px 0 0;font-size:11px}.mp-sig-label{color:var(--text-sub);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.mp-sig-input{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-main);background:var(--card-bg);padding:9px 12px;font-size:14px}.mp-crew-section{margin-top:4px;margin-bottom:8px}.mp-crew-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.mp-crew-row{align-items:center;gap:8px;margin-bottom:8px;display:flex}.mp-crew-name{flex:2}.mp-crew-role{flex:1}.mp-crew-hours{flex-shrink:0;width:68px}.mp-crew-rate{flex-shrink:0;width:80px}.mp-crew-remove{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:14px}.mp-crew-remove:hover{color:var(--danger,#dc2626);background:#fef2f2}.mp-jobsheet{flex-direction:column;gap:16px;display:flex}.mp-jobsheet-print-bar{justify-content:flex-end;gap:8px;display:flex}.mp-jobsheet-doc{color:#111;background:#fff;border:1px solid #ddd;border-radius:6px;max-width:680px;margin:0 auto;padding:32px;font-family:Arial,Helvetica,sans-serif;font-size:13px}.mp-js-header{border-bottom:3px solid #1e293b;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:16px;display:flex}.mp-js-logo{align-items:center;gap:10px;display:flex}.mp-js-logo-img{object-fit:contain;height:40px}.mp-js-logo-text{color:#1e293b;letter-spacing:.05em;font-size:20px;font-weight:900}.mp-js-company{text-align:right;color:#555;font-size:12px;line-height:1.6}.mp-js-co-name{color:#1e293b;font-weight:700}.mp-js-title-row{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.mp-js-title{color:#1e293b;letter-spacing:.05em;margin:0;font-size:22px;font-weight:800}.mp-js-stage-badge{color:#fff;letter-spacing:.03em;background:#1e293b;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:700}.mp-js-grid{grid-template-columns:1fr 1fr;gap:12px 24px;margin-bottom:20px;display:grid}.mp-js-field-label{text-transform:uppercase;letter-spacing:.07em;color:#888;margin-bottom:3px;font-size:10px;font-weight:700}.mp-js-field-value{color:#111;font-size:14px;font-weight:500}.mp-js-route{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;align-items:flex-start;gap:16px;margin-bottom:20px;padding:16px;display:flex}.mp-js-route-block{flex:1}.mp-js-route-arrow{color:#94a3b8;padding-top:18px;font-size:22px}.mp-js-addr{white-space:pre-line;font-size:13px;line-height:1.5}.mp-js-section{margin-bottom:20px}.mp-js-section-title{text-transform:uppercase;letter-spacing:.07em;color:#1e293b;border-bottom:1px solid #e2e8f0;margin-bottom:10px;padding-bottom:6px;font-size:12px;font-weight:700}.mp-js-empty-row{color:#aaa;font-size:13px}.mp-js-table{border-collapse:collapse;width:100%;font-size:13px}.mp-js-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:#666;border-bottom:1px solid #e2e8f0;padding:6px 8px;font-size:11px;font-weight:700}.mp-js-table td{border-bottom:1px solid #f1f5f9;padding:8px}.mp-js-notes{color:#333;white-space:pre-line;background:#fffbeb;border:1px solid #fde68a;border-radius:6px;padding:12px;font-size:13px;line-height:1.6}.mp-js-sig-section{margin-top:40px}.mp-js-sig-row{gap:32px;display:flex}.mp-js-sig-block{flex:1}.mp-js-sig-line{border-bottom:1.5px solid #1e293b;height:40px;margin-bottom:6px}.mp-js-sig-label{color:#666;text-align:center;font-size:11px}@media print{body>*{display:none!important}.mp-jobsheet-doc{max-width:100%;box-shadow:none;border:none;border-radius:0;margin:0;padding:20mm;position:fixed;inset:0;display:block!important}.no-print{display:none!important}}.mp-vc-section{background:var(--surface);border:1px solid var(--border);border-radius:10px;margin:20px 24px 0;padding:18px 20px}.mp-vc-header{justify-content:space-between;align-items:flex-start;margin-bottom:14px;display:flex}.mp-vc-title{color:var(--text);margin:0 0 2px;font-size:15px;font-weight:700}.mp-vc-sub{color:var(--text-muted);font-size:12px}.mp-vc-empty{color:var(--text-muted);margin:0;font-size:13px}.mp-vc-list{flex-direction:column;gap:8px;display:flex}.mp-vc-card{background:var(--bg);border:1px solid var(--border);border-left:3px solid var(--border);border-radius:8px;padding:10px 14px}.mp-vc-pass{border-left-color:#22c55e}.mp-vc-advisory{border-left-color:#f59e0b}.mp-vc-fail{border-left-color:#ef4444}.mp-vc-card-top{align-items:center;gap:8px;margin-bottom:6px;display:flex}.mp-vc-type-chip{border-radius:4px;padding:2px 7px;font-size:11px;font-weight:700}.mp-vc-pre{color:#1d4ed8;background:#3b82f61a;border:1px solid #3b82f633}.mp-vc-post{color:#6d28d9;background:#8b5cf61a;border:1px solid #8b5cf633}.mp-vc-vname{color:var(--text);font-size:13px;font-weight:600}.mp-vc-card-meta{color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:10px;font-size:12px;display:flex}.mp-vc-major{color:#dc2626;background:#dc262614;border:1px solid #dc262633;border-radius:4px;padding:1px 6px;font-size:11px;font-weight:700}.mp-vc-status{font-size:12px;font-weight:700}.mp-vc-status-pass{color:#166534}.mp-vc-status-advisory{color:#92400e}.mp-vc-status-fail{color:#991b1b}.fleet-alerts{border:1px solid var(--border);border-radius:8px;margin:16px 24px 0;overflow:hidden}.fleet-alert-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:10px 14px;font-size:13px;display:flex}.fleet-alert-row:last-child{border-bottom:none}.fleet-alert-row.expired{background:#dc26260f}.fleet-alert-row.warning{background:#f59e0b0f}.fleet-alert-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.fleet-alert-dot.expired{background:#dc2626}.fleet-alert-dot.warning{background:#f59e0b}.fleet-alert-text{color:var(--text);flex:1}.fleet-alert-text strong{font-weight:600}.fleet-alert-meta{color:var(--text-muted);font-size:12px}.fleet-expiry{white-space:nowrap;border-radius:4px;align-items:center;gap:5px;padding:2px 8px;font-size:12px;font-weight:500;display:inline-flex}.fleet-expiry.ok{color:#166534;background:#dcfce7}.fleet-expiry.warning{color:#92400e;background:#fef3c7}.fleet-expiry.expired{color:#991b1b;background:#fee2e2}.fleet-expiry.none{color:var(--text-muted);font-size:12px}.fleet-status-active{color:#166534;background:#dcfce7}.fleet-status-off_road{color:#92400e;background:#fef3c7}.fleet-status-sold{color:#6b7280;background:#f3f4f6}.fleet-table th,.fleet-table td{white-space:nowrap}.fleet-name-cell{font-weight:600}.fleet-reg-cell{color:#fff;letter-spacing:.1em;background:#1e3a5f;border-radius:4px;font-family:monospace;font-size:12px;display:inline-block;padding:2px 8px!important}.fleet-type-cell{color:var(--text-muted);font-size:12px}.fleet-capacity{color:var(--text-muted);background:var(--bg,#f8f9fa);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-size:11px}.fleet-picker-wrap{position:relative}.fleet-picker-chips{flex-wrap:wrap;gap:6px;margin-bottom:6px;display:flex}.fleet-picker-chip{color:var(--text);background:#3b82f61a;border:1px solid #3b82f64d;border-radius:4px;align-items:center;gap:4px;padding:3px 8px;font-size:12px;font-weight:500;display:flex}.fleet-picker-chip-remove{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:14px;line-height:1}.fleet-picker-chip-remove:hover{color:var(--danger,#dc2626)}.fleet-picker-dropdown{border:1px solid var(--border);background:var(--surface);border-radius:6px;flex-wrap:wrap;gap:6px;padding:8px;display:flex}.fleet-picker-option{border:1px solid var(--border);cursor:pointer;background:var(--surface);color:var(--text);border-radius:4px;padding:4px 10px;font-size:12px;transition:background .1s,border-color .1s}.fleet-picker-option:hover{border-color:var(--primary,#3b82f6);background:#3b82f60f}.fleet-picker-option.selected{border-color:var(--primary,#3b82f6);background:#3b82f61f;font-weight:600}.fleet-picker-option.off_road{opacity:.45;cursor:not-allowed}.vcp-panel{flex-direction:column;min-height:0;display:flex}.vcp-toolbar{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;margin-bottom:16px;padding:0 0 14px;display:flex}.vcp-tabs{gap:4px;display:flex}.vcp-tab{border:1px solid var(--border);cursor:pointer;background:var(--surface);color:var(--text-muted);border-radius:6px;padding:6px 14px;font-size:13px;font-weight:500;transition:all .1s}.vcp-tab.active{background:var(--primary,#3b82f6);color:#fff;border-color:var(--primary,#3b82f6)}.vcp-tab:hover:not(.active){background:var(--bg);border-color:var(--text-muted)}.vcp-history{flex:1;overflow:hidden}.vcp-empty{text-align:center;color:var(--text-muted);padding:40px 0}.vcp-empty p{margin-bottom:12px}.vcp-check-list{flex-direction:column;gap:8px;max-height:520px;display:flex;overflow-y:auto}.vcp-check-row{border:1px solid var(--border);background:var(--surface);border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;display:flex}.vcp-check-row.vcp-check-fail{background:#dc262608;border-color:#fca5a5}.vcp-check-row.vcp-check-advisory{background:#f59e0b08;border-color:#fcd34d}.vcp-check-left{align-items:center;gap:12px;display:flex}.vcp-check-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.vcp-type-chip{white-space:nowrap;border-radius:4px;padding:3px 8px;font-size:11px;font-weight:700}.vcp-type-pre{color:#1d4ed8;background:#3b82f61a;border:1px solid #3b82f640}.vcp-type-post{color:#6d28d9;background:#8b5cf61a;border:1px solid #8b5cf640}.vcp-check-info{flex-direction:column;gap:2px;display:flex}.vcp-check-date{color:var(--text);font-size:13px;font-weight:600}.vcp-check-driver{color:var(--text-muted);font-size:12px}.vcp-check-odo{color:var(--text-muted);font-family:monospace;font-size:11px}.vcp-major-tag{color:#dc2626;background:#dc26261a;border:1px solid #dc262640;border-radius:4px;padding:2px 7px;font-size:11px;font-weight:700}.vcp-status-chip{border-radius:4px;padding:3px 9px;font-size:12px;font-weight:700}.vcp-status-pass{color:#166534;background:#dcfce7}.vcp-status-advisory{color:#92400e;background:#fef3c7}.vcp-status-fail{color:#991b1b;background:#fee2e2}.vcp-sig-thumb{object-fit:contain;border:1px solid var(--border);background:#fff;border-radius:4px;width:80px;height:32px}.vcp-form-wrap{max-height:620px;padding-right:4px;overflow-y:auto}.vcp-confirm-overlay{z-index:1000;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.vcp-confirm-box{background:var(--surface);border:1px solid var(--border);min-width:300px;max-width:400px;color:var(--text);border-radius:10px;padding:20px 24px;font-size:14px}.vcpdf-controls{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:16px;display:flex}.vcpdf-doc{color:#111;background:#fff;border:1px solid #ddd;border-radius:4px;max-height:560px;padding:28px 32px;font-family:Arial,sans-serif;overflow-y:auto}.vcpdf-header{color:#fff;background:#1a1a2e;border-radius:4px;justify-content:space-between;align-items:center;margin-bottom:18px;padding:14px 18px;display:flex}.vcpdf-logo-block{align-items:center;gap:10px;display:flex}.vcpdf-logo{filter:brightness(10);width:auto;height:36px}.vcpdf-logo-text{letter-spacing:.08em;color:#fff;font-size:18px;font-weight:900}.vcpdf-title-block{text-align:right}.vcpdf-doc-title{letter-spacing:.04em;text-transform:uppercase;color:#fff;font-size:13px;font-weight:700}.vcpdf-doc-sub{color:#fff9;margin-top:2px;font-size:10px}.vcpdf-meta-bar{border:1px solid #ddd;border-radius:4px;gap:0;margin-bottom:18px;display:flex;overflow:hidden}.vcpdf-meta-item{border-right:1px solid #ddd;flex-direction:column;flex:1;gap:2px;padding:8px 12px;display:flex}.vcpdf-meta-item:last-child{border-right:none}.vcpdf-meta-label{text-transform:uppercase;letter-spacing:.08em;color:#666;font-size:9px;font-weight:700}.vcpdf-meta-value{color:#111;font-size:12px;font-weight:600}.vcpdf-reg{color:#fff;background:#1e3a5f;border-radius:3px;padding:1px 6px;font-family:monospace;display:inline-block}.vcpdf-no-checks{text-align:center;color:#999;border:1px dashed #ddd;border-radius:4px;padding:24px;font-size:13px}.vcpdf-table{border-collapse:collapse;width:100%;margin-bottom:18px;font-size:11.5px}.vcpdf-table th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:#555;background:#f3f4f6;border:1px solid #ddd;padding:7px 10px;font-size:10px;font-weight:700}.vcpdf-table td{color:#222;border:1px solid #ddd;padding:7px 10px}.vcpdf-row-fail td{background:#dc26260f}.vcpdf-result-pass{color:#166534;font-weight:700}.vcpdf-result-advisory{color:#92400e;font-weight:700}.vcpdf-result-fail{color:#991b1b;font-weight:700}.vcpdf-section-title{text-transform:uppercase;letter-spacing:.08em;color:#555;border-bottom:2px solid #ddd;margin-bottom:10px;padding-bottom:4px;font-size:11px;font-weight:800}.vcpdf-faults,.vcpdf-sigs{margin-bottom:18px}.vcpdf-sig-grid{flex-wrap:wrap;gap:16px;display:flex}.vcpdf-sig-item{flex-direction:column;align-items:center;gap:4px;display:flex}.vcpdf-sig-img{object-fit:contain;background:#fff;border:1px solid #ddd;border-radius:3px;width:140px;height:50px}.vcpdf-sig-name{color:#222;font-size:11px;font-weight:600}.vcpdf-sig-date{color:#777;font-size:10px}.vcpdf-footer{color:#aaa;text-align:center;border-top:1px solid #eee;padding-top:12px;font-size:9px;line-height:1.5}@media print{.no-print{display:none!important}.vcpdf-doc{border:none;max-height:none;padding:0;overflow:visible}}.wages-page{padding:0}.wages-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:20px 24px 0;display:flex}.wages-header-left h1{color:var(--text);margin:0 0 2px;font-size:22px;font-weight:700}.wages-header-left p{color:var(--text-muted);margin:0;font-size:13px}.wages-header-right{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.wages-summary{grid-template-columns:repeat(4,1fr);gap:12px;padding:16px 24px 0;display:grid}.wages-stat{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:14px 16px}.wages-stat-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:4px;font-size:11px;font-weight:600}.wages-stat-value{color:var(--text);font-size:22px;font-weight:700;line-height:1}.wages-stat-value.highlight{color:var(--primary,#3b82f6)}.wages-toolbar{flex-wrap:wrap;align-items:center;gap:10px;padding:16px 24px 0;display:flex}.wages-status-tabs{background:var(--surface);border:1px solid var(--border);border-radius:6px;gap:2px;padding:3px;display:flex}.wages-status-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:5px 14px;font-family:inherit;font-size:12px;font-weight:500;transition:background .12s,color .12s}.wages-status-tab:hover{color:var(--text)}.wages-status-tab.active{background:var(--navy,#1e3a5f);color:#fff;font-weight:600}.wages-filter-select{max-width:180px}.wages-filter-month{max-width:160px}.wages-filter-search{max-width:200px}.wages-table-wrap{padding:16px 24px 24px;overflow-x:auto}.wages-table{border-collapse:collapse;width:100%;font-size:13px}.wages-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:2px solid var(--border);white-space:nowrap;padding:9px 12px;font-size:11px;font-weight:600}.wages-table td{border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:11px 12px}.wages-table tbody tr:hover{background:var(--hover,#00000005)}.wages-table tbody tr:last-child td{border-bottom:none}.wages-name-cell{font-weight:600}.wages-amount-cell{color:var(--text);text-align:right;font-weight:700}.wages-detail-cell{color:var(--text-muted);font-size:12px}.wages-note-cell{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:12px;overflow:hidden}.wages-job-cell{color:var(--text-muted);font-size:12px}.wages-badge{text-transform:uppercase;letter-spacing:.04em;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.wages-badge-draft{color:#6b7280;background:#f3f4f6}.wages-badge-approved{color:#1d4ed8;background:#dbeafe}.wages-badge-paid{color:#166534;background:#dcfce7}.wages-row-actions{flex-wrap:nowrap;align-items:center;gap:6px;display:flex}.wages-empty{text-align:center;color:var(--text-muted);padding:48px 24px;font-size:14px}.wages-form-total{background:var(--surface);border:1px solid var(--border);border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:4px;padding:12px 16px;display:flex}.wages-form-total-label{color:var(--text-muted);font-size:12px;font-weight:500}.wages-form-total-value{color:var(--text);font-size:20px;font-weight:700}.wages-xero-btn{opacity:.45;align-items:center;gap:6px;font-size:12px;display:flex;cursor:not-allowed!important}@media (width<=900px){.wages-summary{grid-template-columns:repeat(2,1fr)}.wages-table th:nth-child(5),.wages-table td:nth-child(5){display:none}}.st-tabs{border-bottom:1px solid var(--border);background:var(--surface);gap:2px;margin-bottom:0;padding:0 24px;display:flex}.st-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:12px 16px;font-size:13px;font-weight:500}.st-tab.active{color:var(--text);border-bottom-color:var(--primary,#3b82f6)}.st-wh-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;padding:24px;display:grid}.st-wh-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:10px;padding:20px;transition:border-color .15s,box-shadow .15s;position:relative}.st-wh-card:hover{border-color:var(--primary,#3b82f6);box-shadow:0 2px 12px #3b82f614}.st-wh-card-actions{opacity:0;gap:6px;transition:opacity .15s;display:flex;position:absolute;top:12px;right:12px}.st-wh-card:hover .st-wh-card-actions{opacity:1}.st-wh-name{color:var(--text);margin-bottom:6px;padding-right:80px;font-size:17px;font-weight:600}.st-wh-meta{color:var(--text-muted);font-size:12px}.st-log{padding:20px 24px}.st-log-toolbar{flex-wrap:wrap;gap:12px;margin-bottom:16px;display:flex}.st-log-select{max-width:200px}.st-log-search{max-width:260px}.st-snap-list{border:1px solid var(--border);border-radius:8px;overflow:hidden}.st-snap-item{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:10px 14px;font-size:14px;display:flex}.st-snap-item:last-child{border-bottom:none}.st-snap-num{color:var(--text-muted);min-width:20px;font-size:12px}.st-snap-qty{color:var(--primary,#3b82f6);min-width:36px;font-weight:700}.st-snap-desc{flex:1}.exp-summary-grid{grid-template-columns:1fr 1fr 1fr 2fr}.exp-breakdown-stat{flex-direction:column;gap:8px;display:flex}.exp-breakdown-list{flex-direction:column;gap:4px;margin-top:4px;display:flex}.exp-breakdown-row{color:var(--text);justify-content:space-between;font-size:13px;display:flex}.exp-breakdown-cat{color:var(--text-muted)}.exp-breakdown-amt{font-weight:600}.exp-category-badge{background:var(--hover,#0000000a);color:var(--text-muted);white-space:nowrap;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.wages-badge-reconciled{color:#1e40af;background:#dbeafe}.exp-vat-toggle{color:var(--text-muted);cursor:pointer;align-items:center;gap:5px;font-size:12px;font-weight:500;display:flex}@media (width<=900px){.exp-summary-grid{grid-template-columns:1fr 1fr}}
