@import"https://fonts.googleapis.com/css2?family=Barlow:wght@400;500;600;700&family=Barlow+Condensed:wght@500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap";:root{color-scheme:light dark}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:#f5f7fa;color:#1f2937;-webkit-font-smoothing:antialiased}html.designer-mode body{overflow:hidden}.app{display:flex;flex-direction:column;height:100vh;width:100vw}.toolbar{display:flex;align-items:center;padding:0 16px;height:60px;background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000a;z-index:10;flex-shrink:0}.toolbar-brand{display:flex;flex-direction:column;margin-right:32px}.brand-name{font-weight:700;font-size:16px;color:#1e40af;line-height:1.2}.brand-subtitle{font-size:10px;color:#9ca3af;text-transform:uppercase;letter-spacing:.6px;font-weight:600}.toolbar-actions{display:flex;align-items:center;gap:10px;flex:1}.toolbar-spacer{flex:1}.toolbar-stat{display:flex;flex-direction:column;align-items:flex-end;padding:4px 12px;border-left:1px solid #e5e7eb}.stat-label{font-size:9px;color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.stat-value{font-size:12px;color:#1f2937;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-weight:600}.btn{padding:8px 14px;border:1px solid #d1d5db;background:#fff;color:#1f2937;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;font-family:inherit;transition:all .12s ease;white-space:nowrap}.btn:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:#1e40af;color:#fff;border-color:#1e40af}.btn-primary:hover:not(:disabled){background:#1e3a8a;border-color:#1e3a8a}.btn-active{background:#fef3c7;border-color:#f59e0b;color:#92400e;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 0 #f59e0b66}50%{box-shadow:0 0 0 6px #f59e0b00}}.btn-danger{background:#fee2e2;color:#991b1b;border-color:#fca5a5;width:100%;margin-top:14px}.btn-danger:hover{background:#fecaca;border-color:#f87171}.btn-small{padding:5px 10px;font-size:12px}.draw-tools-wrapper{position:relative}.draw-tools-trigger{white-space:nowrap;font-size:13px}.draw-tools-panel{position:absolute;top:calc(100% + 8px);left:0;z-index:200;background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 8px 24px #0000001f,0 2px 8px #00000014;padding:12px;min-width:220px}.draw-tools-panel-header{font-size:10px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px}.draw-tools-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px;margin-bottom:10px}.draw-tools-panel-footer{border-top:1px solid #f1f5f9;padding-top:10px}.btn-draw{padding:7px 10px;font-size:12px;border-color:transparent;background:#f8fafc;color:#475569;border-radius:6px;text-align:left}.btn-draw:hover:not(:disabled){background:#e2e8f0;border-color:transparent}.btn-draw.btn-active{background:#dbeafe;border-color:#3b82f6;color:#1d4ed8;animation:none}.door-section-label{font-size:11px;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;font-weight:700;margin-bottom:8px}.door-device-row{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:6px;background:#f8fafc;margin-bottom:4px}.door-device-label-input{flex:1;font-size:13px;font-weight:600;color:#1e293b;background:transparent;border:none;outline:none;font-family:inherit;padding:0;min-width:0}.door-device-label-input:hover,.door-device-label-input:focus{background:#fff;border-radius:3px;padding:1px 4px;margin:-1px -4px}.main-area{display:flex;flex:1;overflow:hidden;min-height:0;position:relative}.title-block{position:absolute;bottom:0;right:0;background:#fff;border:2px solid #1e3a5f;z-index:50;font-family:Arial,sans-serif;box-shadow:0 4px 20px #0000002e;display:flex;flex-direction:column}.tb-horizontal{width:640px}.tb-vertical{width:200px}.tb-sub{border-top:2px solid #1e3a5f}.tb-sub:first-of-type{border-top:none}.tb-sub-header{font-size:8px;font-weight:700;color:#fff;background:#1e3a5f;padding:3px 10px;letter-spacing:1px;text-transform:uppercase}.tb-controls{display:flex;align-items:center;justify-content:space-between;padding:4px 8px;gap:8px;background:#0f2547;cursor:grab;-webkit-user-select:none;user-select:none}.tb-controls:active{cursor:grabbing}.tb-grip{font-size:13px;color:#60a5fa;letter-spacing:3px}.tb-ctrl-center{display:flex;gap:4px}.tb-ctrl-btn{font-size:10px;padding:2px 7px;border-radius:3px;cursor:pointer;background:#ffffff1a;border:1px solid rgba(255,255,255,.25);color:#bfdbfe}.tb-ctrl-btn:hover{background:#fff3}.tb-ctrl-active{background:#1d4ed8!important;border-color:#60a5fa!important;color:#fff!important}.tb-size-btns{display:flex;align-items:center;gap:4px}.tb-size-btn{background:#ffffff1f;border:1px solid rgba(255,255,255,.25);color:#fff;width:20px;height:20px;border-radius:3px;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.tb-size-btn:hover:not(:disabled){background:#ffffff47}.tb-size-btn:disabled{opacity:.3;cursor:default}.tb-size-label{font-size:10px;color:#bfdbfe;min-width:30px;text-align:center}.tb-info-h{display:flex}.tb-logo-cell{width:170px;min-width:170px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 8px;border-right:2px solid #1e3a5f;background:#fff}.tb-logo{width:145px;height:auto;object-fit:contain}.tb-body,.tb-main-fields{flex:1;display:flex;flex-direction:column}.tb-meta-row{display:flex;border-top:1px solid #c7d2e8}.tb-meta-cell{flex:1;border-right:1px solid #e5e7eb}.tb-meta-cell:last-child{border-right:none}.tb-info-v{display:flex;flex-direction:column}.tb-v-logo-cell{display:flex;align-items:center;justify-content:center;padding:12px 8px;border-bottom:1px solid #c7d2e8;background:#fff}.tb-logo-v{width:160px;height:auto;object-fit:contain}.tb-v-fields{display:flex;flex-direction:column}.tb-field-v{flex-direction:column!important;gap:1px!important}.tb-field-v .tb-label{min-width:unset!important}.tb-field-v .tb-value{font-size:11px!important}.tb-field{display:flex;align-items:baseline;gap:6px;padding:5px 10px;border-bottom:1px solid #e5e7eb;min-height:26px}.tb-field:last-child{border-bottom:none}.tb-label{font-size:8px;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.8px;white-space:nowrap;min-width:56px}.tb-value{font-size:12px;color:#1f2937;font-weight:500;cursor:text;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tb-value:hover{color:#1e40af;text-decoration:underline dotted}.tb-placeholder{color:#94a3b8;font-style:italic}.tb-input{flex:1;font-size:12px;font-weight:500;color:#1f2937;border:none;border-bottom:1px solid #3b82f6;outline:none;background:#eff6ff;padding:1px 4px;border-radius:2px;width:100%;font-family:inherit}.tb-legend-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;padding:4px 0}.tb-legend-grid-v{grid-template-columns:1fr}.tb-legend-row{display:flex;align-items:center;gap:6px;padding:3px 10px;border-bottom:1px solid #f1f5f9;font-size:11px}.tb-legend-row:last-child{border-bottom:none}.tb-legend-icon{font-size:14px;flex-shrink:0}.tb-legend-name{flex:1;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tb-legend-count{font-weight:700;color:#1e3a5f;font-size:12px;flex-shrink:0}.tb-image-block{background:#fafafa}.tb-image-wrap{position:relative;padding:8px}.tb-custom-img{width:100%;max-height:120px;object-fit:contain;display:block}.tb-img-remove{position:absolute;top:10px;right:10px;background:#ef4444e6;color:#fff;border:none;border-radius:50%;width:20px;height:20px;cursor:pointer;font-size:11px;display:flex;align-items:center;justify-content:center}.tb-img-upload-btn{display:block;width:100%;padding:12px;text-align:center;color:#6b7280;border:2px dashed #d1d5db;background:none;cursor:pointer;font-size:12px;border-radius:0}.tb-img-upload-btn:hover{background:#f0f4ff;color:#1e40af;border-color:#93c5fd}.device-library{width:240px;background:#fff;border-right:1px solid #e5e7eb;overflow-y:auto;padding:14px;flex-shrink:0}.panel-header{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:#6b7280;padding:8px 0;margin-bottom:10px;border-bottom:1px solid #e5e7eb}.panel-header-row{display:flex;align-items:center;gap:8px;margin:0 -14px 10px;padding:8px 0 8px 14px;border-bottom:1px solid #e5e7eb;overflow:hidden}.panel-header-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:#6b7280;flex:1}.btn-delete-inline{background:#dc2626;color:#fff;border:none;border-radius:0;width:36px;height:34px;font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;line-height:1;transition:background .1s;align-self:stretch}.btn-delete-inline:hover{background:#b91c1c}.placement-hint{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #f59e0b;border-radius:8px;padding:12px;margin-bottom:14px;font-size:12px;color:#78350f}.placement-hint-title{font-weight:600;margin-bottom:4px}.placement-device{font-weight:700;color:#92400e;font-size:14px;margin-bottom:8px}.device-category{margin-bottom:18px}.category-header{font-size:12px;font-weight:700;color:#374151;padding:4px 0 4px 10px;border-left:3px solid;margin-bottom:6px;text-transform:uppercase;letter-spacing:.3px}.category-header--collapsible{cursor:pointer;-webkit-user-select:none;user-select:none;display:flex;align-items:center;gap:5px;transition:background .1s;border-radius:0 4px 4px 0}.category-header--collapsible:hover{background:#f9fafb}.category-arrow{font-size:10px;color:#9ca3af;flex-shrink:0}.lib-layer-row{display:flex;align-items:center;gap:8px;padding:5px 4px;font-size:13px;color:#374151}.lib-layer-row--cables{margin-bottom:2px}.lib-layer-cb{width:10px;height:10px;cursor:pointer;flex-shrink:0;accent-color:#1d4ed8}.lib-layer-swatch{width:12px;height:12px;border-radius:3px;flex-shrink:0}.lib-layer-name{flex:1;font-size:12px;font-weight:600}.lib-layer-count{font-size:11px;color:#9ca3af;font-variant-numeric:tabular-nums;min-width:16px;text-align:right}.lib-category-divider{height:1px;background:#e5e7eb;margin:6px 0 10px}.lib-category-header{display:flex;align-items:center;gap:6px;padding:4px 0 4px 8px;border-left:3px solid;margin-bottom:6px;border-radius:0 4px 4px 0}.lib-collapse-btn{display:flex;align-items:center;gap:4px;flex:1;background:none;border:none;padding:0;cursor:pointer;font-family:inherit;text-align:left;transition:background .1s}.lib-collapse-btn:hover{opacity:.75}.lib-category-arrow{font-size:35px;color:#6b7280;flex-shrink:0;line-height:.8;width:28px;text-align:center}.lib-category-name{font-size:12px;font-weight:700;color:#374151;text-transform:uppercase;letter-spacing:.3px}.sensor-config{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:10px;margin-bottom:8px}.sensor-config-header{display:flex;justify-content:space-between;align-items:center;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#6b7280;margin-bottom:8px}.device-list{display:flex;flex-direction:column;gap:3px}.device-item{display:flex;align-items:center;gap:8px;padding:5px 8px;background:#fff;border:1px solid #e5e7eb;border-radius:5px;cursor:pointer;font-size:12px;text-align:left;transition:all .12s ease;font-family:inherit}.device-item:hover{border-color:var(--device-color);background:#fafbfc}.device-item-active{border-color:var(--device-color);background:#fef3c7;border-width:2px;padding:4px 7px}.device-lib-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0}.device-lib-icon svg{width:100%;height:100%}.device-name{color:#1f2937;font-weight:500}.canvas-container{flex:1;position:relative;background:#d1d5db;background-image:linear-gradient(45deg,#e5e7eb 25%,transparent 25%),linear-gradient(-45deg,#e5e7eb 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#e5e7eb 75%),linear-gradient(-45deg,transparent 75%,#e5e7eb 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px;overflow:hidden;min-width:0}.canvas-empty-state{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;pointer-events:none;z-index:1;background:#fff;padding:40px 60px;border-radius:12px;box-shadow:0 4px 12px #00000014}.empty-icon{font-size:48px;margin-bottom:14px;opacity:.6}.empty-title{font-size:18px;font-weight:600;color:#4b5563;margin-bottom:6px}.empty-subtitle{font-size:13px;color:#9ca3af}.zoom-controls{position:absolute;bottom:20px;right:20px;display:flex;flex-direction:column;background:#fff;border:1px solid #d1d5db;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001f}.zoom-controls button{width:38px;height:38px;border:none;background:#fff;cursor:pointer;font-size:18px;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb;font-family:inherit}.zoom-controls button:hover{background:#f3f4f6}.zoom-controls button:last-child{border-bottom:none}.zoom-level{font-size:10px;color:#6b7280;text-align:center;padding:5px 0;border-bottom:1px solid #e5e7eb;background:#f9fafb;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-weight:600}.canvas-mode-banner{position:absolute;top:20px;left:50%;transform:translate(-50%);background:#1e40af;color:#fff;padding:10px 20px;border-radius:24px;font-size:13px;font-weight:600;letter-spacing:.3px;box-shadow:0 4px 12px #1e40af4d;pointer-events:none;z-index:5;animation:slideDown .2s ease}@keyframes slideDown{0%{transform:translate(-50%,-10px);opacity:0}to{transform:translate(-50%);opacity:1}}.right-panel{width:290px;background:#fff;border-left:1px solid #e5e7eb;display:flex;flex-direction:column;overflow-y:auto;flex-shrink:0}.properties-panel,.layer-panel{padding:14px}.properties-panel{border-bottom:1px solid #e5e7eb;min-height:200px}.empty-state-small{font-size:13px;color:#9ca3af;text-align:center;padding:24px 8px;line-height:1.5}.device-summary{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}.device-tag{font-size:9px;font-weight:700;text-transform:uppercase;color:#fff;padding:3px 8px;border-radius:4px;letter-spacing:.4px}.device-subtype{font-size:15px;font-weight:600;color:#1f2937}.section-divider{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:#6b7280;border-top:1px solid #e5e7eb;padding-top:12px;margin:16px 0 10px}.form-group{margin-bottom:12px}.form-group label{display:block;font-size:11px;font-weight:600;color:#4b5563;text-transform:uppercase;letter-spacing:.4px;margin-bottom:5px}.hint-text{text-transform:none;letter-spacing:0;color:#9ca3af;font-weight:400;font-size:10px}.form-group input[type=text],.form-group input[type=number],.form-group textarea{width:100%;padding:7px 10px;border:1px solid #d1d5db;border-radius:5px;font-size:13px;color:#1f2937;font-family:inherit;background:#fff}.form-group input[type=text]:focus,.form-group input[type=number]:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.form-group input[type=range]{width:100%;cursor:pointer;accent-color:#3b82f6}.form-group textarea{resize:vertical;font-family:inherit}.layer-toggle{display:flex;align-items:center;gap:10px;padding:8px 6px;cursor:pointer;border-radius:5px;-webkit-user-select:none;user-select:none}.layer-toggle:hover{background:#f9fafb}.layer-toggle input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:#3b82f6}.layer-color{display:inline-block;width:14px;height:14px;border-radius:3px;flex-shrink:0}.layer-name{font-size:13px;color:#1f2937;flex:1}.layer-count{font-size:11px;color:#6b7280;background:#f3f4f6;padding:2px 8px;border-radius:10px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-weight:600}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:#fff;border-radius:12px;padding:28px;min-width:420px;box-shadow:0 20px 50px #00000040;animation:scaleIn .18s ease}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.modal h3{font-size:18px;margin-bottom:10px;color:#1f2937}.modal p{font-size:14px;color:#6b7280;margin-bottom:18px;line-height:1.5}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:10px}.itbox-modal{background:#fff;border-radius:12px;width:1040px;max-height:92vh;display:flex;flex-direction:column;box-shadow:0 20px 50px #00000040;animation:scaleIn .18s ease;overflow:hidden}.itbox-header{display:flex;align-items:flex-start;justify-content:space-between;padding:18px 24px 14px;border-bottom:1px solid #e5e7eb;flex-shrink:0}.itbox-title{font-size:17px;font-weight:700;color:#1f2937;line-height:1.2}.itbox-subtitle{font-size:13px;color:#6b7280;margin-top:3px;display:flex;align-items:center;gap:8px}.itbox-count{background:#dbeafe;color:#1e40af;font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px}.itbox-close{background:none;border:none;font-size:16px;color:#9ca3af;cursor:pointer;padding:4px 8px;border-radius:4px;line-height:1;transition:all .1s ease}.itbox-close:hover{background:#f3f4f6;color:#374151}.itbox-body{display:flex;flex:1;overflow:hidden}.itbox-left{width:220px;flex-shrink:0;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;background:#f9fafb}.itbox-list{flex:1;overflow-y:auto;padding:8px 0}.itbox-empty{font-size:12px;color:#9ca3af;text-align:center;padding:24px 12px;line-height:1.6}.itbox-list-item{display:flex;align-items:center;gap:8px;padding:9px 12px;cursor:pointer;border-left:3px solid transparent;transition:background .1s}.itbox-list-item:hover{background:#f3f4f6}.itbox-list-item--selected{background:#eff6ff;border-left-color:#3b82f6}.itbox-list-info{flex:1;min-width:0}.itbox-list-label{font-size:13px;font-weight:600;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.itbox-list-sub{font-size:10px;color:#9ca3af;text-transform:uppercase;letter-spacing:.3px;margin-top:1px}.rack-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.rack-remove{background:none;border:none;color:#d1d5db;cursor:pointer;font-size:13px;padding:2px 5px;border-radius:4px;line-height:1;transition:all .1s ease;flex-shrink:0}.rack-remove:hover{background:#fee2e2;color:#991b1b}.itbox-add{border-top:1px solid #e5e7eb;padding:12px;background:#f3f4f6;display:flex;flex-direction:column;gap:6px;flex-shrink:0}.itbox-add-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:#9ca3af}.itbox-add select,.itbox-add input[type=text]{width:100%;padding:6px 8px;border:1px solid #d1d5db;border-radius:5px;font-size:12px;font-family:inherit;color:#1f2937;background:#fff;box-sizing:border-box}.itbox-add select:focus,.itbox-add input[type=text]:focus{outline:none;border-color:#3b82f6}.itbox-right{flex:1;overflow-y:auto;padding:20px 24px}.itbox-no-sel{font-size:13px;color:#9ca3af;text-align:center;padding:48px 16px}.itbox-detail-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:4px}.itbox-detail-label-input{font-size:18px;font-weight:700;color:#1f2937;border:none;border-bottom:2px solid transparent;outline:none;padding:0 0 2px;width:100%;font-family:inherit;background:transparent;transition:border-color .15s}.itbox-detail-label-input:focus{border-bottom-color:#3b82f6}.itbox-detail-sub{font-size:11px;color:#9ca3af;text-transform:uppercase;letter-spacing:.4px;margin-top:3px}.port-modal{background:#fff;border-radius:12px;width:640px;max-height:82vh;display:flex;flex-direction:column;box-shadow:0 20px 50px #00000040;animation:scaleIn .18s ease;overflow:hidden}.port-modal-header{padding:18px 24px 14px;border-bottom:1px solid #e5e7eb;flex-shrink:0}.port-modal-title{font-size:17px;font-weight:700;color:#1f2937}.port-modal-route{font-size:12px;color:#6b7280;margin-top:3px}.port-modal-body{display:flex;gap:0;flex:1;overflow:hidden;min-height:0}.port-modal-arrow{display:flex;align-items:center;justify-content:center;font-size:20px;color:#9ca3af;padding:0 8px;flex-shrink:0}.port-selector{flex:1;display:flex;flex-direction:column;padding:16px;overflow:hidden;border-right:1px solid #f3f4f6}.port-selector:last-child{border-right:none}.port-selector-device{font-size:13px;font-weight:700;color:#1f2937;margin-bottom:2px}.port-selector-subtype{font-size:11px;color:#9ca3af;margin-bottom:10px}.port-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:3px}.port-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border:1px solid #e5e7eb;border-radius:6px;background:#fff;cursor:pointer;font-size:13px;font-family:inherit;color:#1f2937;text-align:left;transition:all .1s ease}.port-item:hover:not(:disabled){border-color:#3b82f6;background:#eff6ff}.port-selected{border-color:#3b82f6!important;background:#eff6ff!important;font-weight:600}.port-used{opacity:.45;cursor:not-allowed!important;background:#f9fafb!important}.port-type-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.port-item-label{flex:1}.port-badge{font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px;letter-spacing:.3px;flex-shrink:0}.port-badge-used{background:#fee2e2;color:#991b1b}.port-badge-sel{background:#dbeafe;color:#1e40af}.port-auto-note{font-size:11px;color:#9ca3af;margin-top:8px;font-style:italic}.port-modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:14px 24px;border-top:1px solid #e5e7eb;flex-shrink:0}.connections-list{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.connection-row{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;background:#f9fafb;border-radius:6px;border:1px solid #e5e7eb}.conn-arrow{font-size:13px;color:#6b7280;margin-top:1px;flex-shrink:0}.conn-info{flex:1;min-width:0}.conn-other-device{font-size:12px;font-weight:600;color:#1f2937;margin-bottom:4px}.conn-ports{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.conn-port-badge{display:inline-block;font-size:10px;font-weight:600;color:#fff;padding:2px 7px;border-radius:4px}.conn-port-other{background:#e5e7eb!important;color:#374151}.conn-port-unset{font-size:10px;color:#d1d5db;font-style:italic}.conn-cable-type{font-size:10px;color:#9ca3af;flex-shrink:0;margin-top:2px}.conn-endpoint{display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}.conn-ep-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#9ca3af;width:28px;flex-shrink:0}.conn-ep-device{font-size:12px;font-weight:600;color:#1f2937;flex:1}.context-menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000}.context-menu{position:fixed;z-index:1001;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 8px 24px #0000001f,0 2px 8px #00000014;min-width:180px;padding:4px 0;font-size:13px}.context-menu-item{padding:8px 14px;cursor:pointer;color:#1f2937;transition:background .1s;-webkit-user-select:none;user-select:none}.context-menu-item:hover{background:#f3f4f6}.context-menu-item--danger{color:#dc2626}.context-menu-item--danger:hover{background:#fef2f2}.context-menu-separator{height:1px;background:#e5e7eb;margin:4px 0}.layer-divider{height:1px;background:#e5e7eb;margin:6px 0}.layer-toggle--cables{opacity:.85}.port-grid-container{margin:6px 0 10px}.port-grid{display:flex;flex-wrap:wrap;gap:4px}.port-sq{width:28px;height:28px;border:1.5px solid;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;cursor:pointer;transition:opacity .12s;overflow:hidden;-webkit-user-select:none;user-select:none;flex-shrink:0}.port-sq:hover{opacity:.72}.port-sq-renaming{width:52px;height:28px;background:#fff!important;padding:0 3px}.port-sq-input{width:100%;height:100%;border:none;outline:none;font-size:9px;font-weight:700;text-align:center;background:transparent;padding:0}.rconn-section{margin-top:20px;border-top:1px solid #e5e7eb;padding-top:14px}.rconn-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.rconn-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#6b7280}.rconn-empty{font-size:12px;color:#9ca3af;margin-bottom:8px}.rconn-row{display:flex;align-items:center;gap:8px;padding:6px 8px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;margin-bottom:5px}.rconn-info{flex:1;display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:12px}.rconn-port{background:#e5e7eb;color:#374151;padding:1px 6px;border-radius:4px;font-size:11px;font-weight:600;font-family:ui-monospace,monospace}.rconn-arrow{color:#9ca3af;font-size:12px}.rconn-device{font-size:12px;font-weight:600;color:#1f2937}.rconn-form{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:8px;padding:12px;margin-top:8px;display:flex;flex-direction:column;gap:8px}.rconn-form-row{display:flex;align-items:center;gap:8px}.rconn-form-row label{font-size:11px;font-weight:600;color:#6b7280;white-space:nowrap;width:70px;flex-shrink:0}.rconn-form-row select{flex:1;padding:5px 8px;border:1px solid #d1d5db;border-radius:4px;font-size:12px;font-family:inherit;background:#fff}.rconn-form-row select:focus{outline:none;border-color:#3b82f6}.rconn-form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.itbox-rack-meta{display:flex;gap:6px;align-items:center;margin-right:12px}.itbox-meta-select{padding:5px 8px;border:1px solid #d1d5db;border-radius:5px;font-size:12px;font-family:inherit;color:#1f2937;background:#fff}.itbox-meta-select:focus{outline:none;border-color:#3b82f6}.itbox-rack-util{display:flex;flex-direction:column;gap:4px;margin-right:12px;min-width:110px}.itbox-rack-util-text{font-size:11px;font-weight:600;color:#374151;white-space:nowrap}.itbox-rack-util-text.over{color:#ef4444}.itbox-rack-bar{height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden}.itbox-rack-bar-fill{height:100%;border-radius:3px;transition:width .2s,background .2s}.itbox-u-badge{font-size:10px;font-weight:700;color:#6b7280;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:4px;padding:1px 5px;flex-shrink:0;margin-right:4px}.itbox-ucount-row{display:flex;align-items:center;gap:8px}.itbox-ucount-label{font-size:11px;color:#6b7280;font-weight:600;white-space:nowrap}.itbox-ucount-input{width:60px;padding:5px 8px;border:1px solid #d1d5db;border-radius:4px;font-size:13px;font-family:inherit}.custom-port-swatch{width:10px;height:10px;border-radius:3px;display:inline-block;flex-shrink:0}.custom-port-add-row{display:flex;align-items:center;gap:6px;margin-top:8px}.custom-port-color-pick{width:28px;height:28px;border:1px solid #d1d5db;border-radius:4px;padding:2px;cursor:pointer;flex-shrink:0}.custom-port-name-input{flex:1;padding:5px 8px;border:1px solid #d1d5db;border-radius:4px;font-size:12px;font-family:inherit}.custom-port-name-input:focus{outline:none;border-color:#3b82f6}.tour-trigger-btn{width:28px;height:28px;border-radius:50%;border:2px solid #334155;background:#1e293b;color:#64748b;font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s,color .15s,background .15s;flex-shrink:0}.tour-trigger-btn:hover{border-color:#3b82f6;color:#3b82f6;background:#172033}.tour-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:#000000b8;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.tour-welcome-card{background:#1e293b;border:1px solid #334155;border-radius:18px;width:420px;max-width:92vw;padding:44px 40px 36px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px;box-shadow:0 32px 80px #000000b3;animation:tourSlideUp .28s cubic-bezier(.34,1.56,.64,1)}@keyframes tourSlideUp{0%{transform:translateY(28px) scale(.96);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.tour-logo{width:58px;height:58px;background:linear-gradient(135deg,#3b82f6,#6366f1);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:900;color:#fff;letter-spacing:-1px}.tour-welcome-card h2{font-size:22px;font-weight:700;color:#f1f5f9;margin:0}.tour-welcome-card p{font-size:14px;color:#94a3b8;line-height:1.65;margin:0}.tour-welcome-q{color:#cbd5e1!important;font-weight:500}.tour-welcome-btns{display:flex;flex-direction:column;gap:10px;width:100%;margin-top:6px}.tour-start-btn{background:linear-gradient(135deg,#3b82f6,#6366f1);color:#fff;border:none;border-radius:10px;padding:12px;font-size:15px;font-weight:600;cursor:pointer;transition:opacity .15s,transform .15s}.tour-start-btn:hover{opacity:.88;transform:translateY(-1px)}.tour-skip-btn{background:none;border:none;color:#64748b;font-size:13px;cursor:pointer;padding:6px}.tour-skip-btn:hover{color:#94a3b8}.tour-svg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;pointer-events:none}.tour-ring{animation:tourRingPulse 2.2s ease-in-out infinite}@keyframes tourRingPulse{0%,to{opacity:1;stroke-width:2.5}50%{opacity:.5;stroke-width:1.5}}.tour-halo{position:fixed;z-index:199;border-radius:10px;pointer-events:none;box-shadow:0 0 #3b82f680;animation:tourHalo 2.2s ease-out infinite}@keyframes tourHalo{0%{box-shadow:0 0 #3b82f673}70%{box-shadow:0 0 0 12px #3b82f600}to{box-shadow:0 0 #3b82f600}}.tour-tip{position:fixed;z-index:210;width:300px;background:#1e293b;border:1px solid #334155;border-radius:12px;padding:16px 18px 14px;box-shadow:0 16px 48px #0009;animation:tourSlideUp .22s cubic-bezier(.34,1.56,.64,1);pointer-events:auto}.tour-tip-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.tour-tip-count{font-size:11px;color:#475569;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.tour-tip-x{background:none;border:none;color:#475569;font-size:13px;cursor:pointer;padding:2px 5px;border-radius:5px;line-height:1}.tour-tip-x:hover{color:#94a3b8;background:#0f172a}.tour-tip-title{font-size:14px;font-weight:700;color:#f1f5f9;margin:0 0 7px}.tour-tip-body{font-size:13px;color:#94a3b8;line-height:1.65;margin:0 0 12px}.tour-pips{display:flex;gap:5px;justify-content:center;margin-bottom:12px}.tour-pip{width:7px;height:7px;border-radius:50%;background:#334155;border:none;cursor:pointer;padding:0;transition:background .2s,transform .2s}.tour-pip.cur{background:#3b82f6;transform:scale(1.35)}.tour-pip.past{background:#6366f1}.tour-tip-nav{display:flex;gap:8px;justify-content:flex-end}.tour-back-btn{background:#0f172a;border:1px solid #334155;color:#94a3b8;border-radius:7px;padding:7px 14px;font-size:13px;cursor:pointer;transition:background .15s}.tour-back-btn:hover:not(:disabled){background:#1e293b}.tour-back-btn:disabled{opacity:.35;cursor:default}.tour-next-btn{background:linear-gradient(135deg,#3b82f6,#6366f1);color:#fff;border:none;border-radius:7px;padding:7px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .15s}.tour-next-btn:hover{opacity:.88}.tour-tip-arrow-up:before{content:"";position:absolute;top:-9px;left:var(--ap, 50%);transform:translate(-50%);width:0;height:0;border-left:9px solid transparent;border-right:9px solid transparent;border-bottom:9px solid #334155}.tour-tip-arrow-up:after{content:"";position:absolute;top:-7px;left:var(--ap, 50%);transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:8px solid #1e293b}.tour-tip-arrow-down:before{content:"";position:absolute;bottom:-9px;left:var(--ap, 50%);transform:translate(-50%);width:0;height:0;border-left:9px solid transparent;border-right:9px solid transparent;border-top:9px solid #334155}.tour-tip-arrow-down:after{content:"";position:absolute;bottom:-7px;left:var(--ap, 50%);transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-top:8px solid #1e293b}.tour-tip-arrow-left:before{content:"";position:absolute;left:-9px;top:var(--ap, 50%);transform:translateY(-50%);width:0;height:0;border-top:9px solid transparent;border-bottom:9px solid transparent;border-right:9px solid #334155}.tour-tip-arrow-left:after{content:"";position:absolute;left:-7px;top:var(--ap, 50%);transform:translateY(-50%);width:0;height:0;border-top:8px solid transparent;border-bottom:8px solid transparent;border-right:8px solid #1e293b}.tour-tip-arrow-right:before{content:"";position:absolute;right:-9px;top:var(--ap, 50%);transform:translateY(-50%);width:0;height:0;border-top:9px solid transparent;border-bottom:9px solid transparent;border-left:9px solid #334155}.tour-tip-arrow-right:after{content:"";position:absolute;right:-7px;top:var(--ap, 50%);transform:translateY(-50%);width:0;height:0;border-top:8px solid transparent;border-bottom:8px solid transparent;border-left:8px solid #1e293b}.tb-group{display:flex;align-items:center;gap:2px;flex-shrink:0}.tb-icon-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;border:1px solid #c7cdd6;background:#fff;color:#374151;cursor:pointer;transition:background .12s,border-color .12s,color .12s;flex-shrink:0;padding:0}.tb-icon-btn:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af;color:#111827}.tb-icon-btn:active:not(:disabled){transform:translateY(1px)}.tb-icon-btn:disabled{opacity:.38;cursor:not-allowed}.tb-icon-btn:focus-visible{outline:2px solid #2563eb;outline-offset:2px}.tb-icon-btn--warn{background:#fef3c7;border-color:#f59e0b;color:#92400e}.tb-icon-btn--warn:hover:not(:disabled){background:#fde68a;border-color:#d97706;color:#78350f}.tb-btn{display:flex;align-items:center;gap:6px;padding:0 12px;height:32px;border:1px solid #c7cdd6;background:#fff;color:#111827;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;font-family:inherit;white-space:nowrap;flex-shrink:0;transition:background .12s,border-color .12s,color .12s}.tb-btn:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.tb-btn:active:not(:disabled){transform:translateY(1px)}.tb-btn:disabled{opacity:.38;cursor:not-allowed}.tb-btn:focus-visible{outline:2px solid #2563eb;outline-offset:2px}.tb-btn--primary{background:#1e40af;color:#fff;border-color:#1e40af}.tb-btn--primary:hover:not(:disabled){background:#1e3a8a;border-color:#1e3a8a}.tb-btn--active{background:#fef3c7;border-color:#f59e0b;color:#92400e;animation:pulse 1.5s ease-in-out infinite}.tb-btn--dropdown{padding-right:8px;gap:5px}.tb-chevron{flex-shrink:0;opacity:.6}.tb-label{white-space:nowrap}@media (max-width: 1200px){.tb-label--collapse{display:none}}.btn-draw{display:flex;align-items:center;gap:7px}.tb-save-saved{color:#10b981}.tb-save-error{color:#ef4444}.tb-save-saving{color:#f59e0b}.toolbar-divider{width:1px;height:28px;background:#e5e7eb;margin:0 4px;flex-shrink:0}.theme-toggle-btn{width:32px;height:32px;border-radius:8px;border:1px solid #d1d5db;background:#f9fafb;color:#374151;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s;flex-shrink:0;padding:0}.theme-toggle-btn:hover{background:#e5e7eb;border-color:#9ca3af}[data-theme=dark] body{background:#0f172a;color:#f1f5f9}[data-theme=dark] .toolbar{background:#1e293b;border-bottom-color:#334155;border-top:1px solid #334155}[data-theme=dark] .brand-name{color:#60a5fa}[data-theme=dark] .brand-subtitle{color:#475569}[data-theme=dark] .stat-value{color:#e2e8f0}[data-theme=dark] .stat-label{color:#475569}[data-theme=dark] .toolbar-divider{background:#334155}[data-theme=dark] .toolbar-stat{border-left-color:#334155}[data-theme=dark] .btn{background:#1e293b;color:#e2e8f0;border-color:#475569}[data-theme=dark] .btn:hover:not(:disabled){background:#334155;border-color:#64748b}[data-theme=dark] .btn-primary{background:#1d4ed8;color:#fff;border-color:#1d4ed8}[data-theme=dark] .btn-primary:hover:not(:disabled){background:#2563eb;border-color:#2563eb}[data-theme=dark] .tb-icon-btn{background:#0f172a;color:#cbd5e1;border-color:#475569}[data-theme=dark] .tb-icon-btn:hover:not(:disabled){background:#1e293b;border-color:#64748b;color:#f1f5f9}[data-theme=dark] .tb-icon-btn--warn{background:#3a2e10;border-color:#d97706;color:#fbbf24}[data-theme=dark] .tb-icon-btn--warn:hover:not(:disabled){background:#4a3d1a;border-color:#f59e0b}[data-theme=dark] .tb-btn{background:#0f172a;color:#f1f5f9;border-color:#475569}[data-theme=dark] .tb-btn:hover:not(:disabled){background:#1e293b;border-color:#64748b;color:#f8fafc}[data-theme=dark] .tb-btn--primary{background:#1d4ed8;color:#fff;border-color:#1d4ed8}[data-theme=dark] .tb-btn--primary:hover:not(:disabled){background:#2563eb;border-color:#2563eb}[data-theme=dark] .tb-btn--active{background:#3a2e10;border-color:#d97706;color:#fbbf24}[data-theme=dark] .tb-save-saved{color:#34d399}[data-theme=dark] .tb-save-error{color:#f87171}[data-theme=dark] .tb-save-saving{color:#fbbf24}[data-theme=dark] .draw-tools-panel{background:#1e293b;border-color:#334155;box-shadow:0 8px 24px #00000080,0 2px 8px #0000004d}[data-theme=dark] .draw-tools-panel-header{color:#475569}[data-theme=dark] .draw-tools-panel-footer{border-top-color:#334155}[data-theme=dark] .btn-draw{background:#0f172a;color:#94a3b8;border-color:transparent}[data-theme=dark] .btn-draw:hover:not(:disabled){background:#334155;border-color:transparent}[data-theme=dark] .btn-draw.btn-active{background:#1e3a8a;border-color:#3b82f6;color:#93c5fd;animation:none}[data-theme=dark] .theme-toggle-btn{background:#0f172a;border-color:#334155;color:#94a3b8}[data-theme=dark] .theme-toggle-btn:hover{background:#1e293b;border-color:#475569;color:#e2e8f0}[data-theme=dark] .device-library{background:#1e293b;border-right-color:#334155}[data-theme=dark] .panel-header{color:#475569;border-bottom-color:#334155}[data-theme=dark] .panel-header-row{border-bottom-color:#334155}[data-theme=dark] .panel-header-title{color:#475569}[data-theme=dark] .lib-category-divider{background:#334155}[data-theme=dark] .lib-category-name{color:#94a3b8}[data-theme=dark] .lib-category-arrow{color:#475569}[data-theme=dark] .lib-layer-row{color:#94a3b8}[data-theme=dark] .lib-layer-count{color:#475569}[data-theme=dark] .placement-hint{background:linear-gradient(135deg,#78350f,#92400e);border-color:#d97706;color:#fef3c7}[data-theme=dark] .placement-device{color:#fde68a}[data-theme=dark] .category-header{color:#94a3b8}[data-theme=dark] .category-header--collapsible:hover{background:#334155}[data-theme=dark] .sensor-config{background:#0f172a;border-color:#334155}[data-theme=dark] .sensor-config-header{color:#475569}[data-theme=dark] .device-item{background:#0f172a;border-color:#334155}[data-theme=dark] .device-item:hover{background:#1e293b}[data-theme=dark] .device-name{color:#e2e8f0}[data-theme=dark] .canvas-container{background:#0f172a;background-image:none}[data-theme=dark] .canvas-empty-state{background:#1e293b;box-shadow:0 4px 12px #00000080}[data-theme=dark] .empty-title{color:#64748b}[data-theme=dark] .empty-subtitle{color:#475569}[data-theme=dark] .canvas-mode-banner{box-shadow:0 4px 12px #1e40af80}[data-theme=dark] .zoom-controls{background:#1e293b;border-color:#334155}[data-theme=dark] .zoom-controls button{background:#1e293b;color:#94a3b8;border-bottom-color:#334155}[data-theme=dark] .zoom-controls button:hover{background:#334155}[data-theme=dark] .zoom-level{background:#0f172a;color:#475569;border-bottom-color:#334155}[data-theme=dark] .right-panel{background:#1e293b;border-left-color:#334155}[data-theme=dark] .properties-panel{border-bottom-color:#334155}[data-theme=dark] .device-subtype{color:#f1f5f9}[data-theme=dark] .section-divider{color:#475569;border-top-color:#334155}[data-theme=dark] .empty-state-small{color:#475569}[data-theme=dark] .form-group label{color:#64748b}[data-theme=dark] .form-group input[type=text],[data-theme=dark] .form-group input[type=number],[data-theme=dark] .form-group textarea{background:#0f172a;border-color:#334155;color:#f1f5f9}[data-theme=dark] .form-group input[type=text]:focus,[data-theme=dark] .form-group input[type=number]:focus,[data-theme=dark] .form-group textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}[data-theme=dark] .layer-toggle:hover{background:#334155}[data-theme=dark] .layer-name{color:#e2e8f0}[data-theme=dark] .layer-count{background:#0f172a;color:#64748b}[data-theme=dark] .layer-divider{background:#334155}[data-theme=dark] .modal{background:#1e293b;box-shadow:0 20px 50px #0009}[data-theme=dark] .modal h3{color:#f1f5f9}[data-theme=dark] .modal p{color:#94a3b8}[data-theme=dark] .itbox-modal{background:#1e293b;box-shadow:0 20px 50px #0009}[data-theme=dark] .itbox-header{border-bottom-color:#334155}[data-theme=dark] .itbox-title{color:#f1f5f9}[data-theme=dark] .itbox-subtitle{color:#64748b}[data-theme=dark] .itbox-left{background:#0f172a;border-right-color:#334155}[data-theme=dark] .itbox-list-item:hover{background:#1e293b}[data-theme=dark] .itbox-list-item--selected{background:#3b82f61f;border-left-color:#3b82f6}[data-theme=dark] .itbox-list-label{color:#f1f5f9}[data-theme=dark] .itbox-list-sub,[data-theme=dark] .itbox-empty{color:#475569}[data-theme=dark] .itbox-add{background:#0f172a;border-top-color:#334155}[data-theme=dark] .itbox-add select,[data-theme=dark] .itbox-add input[type=text]{background:#1e293b;border-color:#334155;color:#f1f5f9}[data-theme=dark] .itbox-add-title,[data-theme=dark] .itbox-no-sel{color:#475569}[data-theme=dark] .itbox-detail-label-input{color:#f1f5f9}[data-theme=dark] .itbox-detail-sub{color:#475569}[data-theme=dark] .itbox-close:hover{background:#334155;color:#e2e8f0}[data-theme=dark] .itbox-meta-select{background:#0f172a;border-color:#334155;color:#e2e8f0}[data-theme=dark] .itbox-rack-util-text{color:#94a3b8}[data-theme=dark] .itbox-rack-bar{background:#334155}[data-theme=dark] .itbox-u-badge{background:#0f172a;border-color:#334155;color:#64748b}[data-theme=dark] .itbox-ucount-label{color:#64748b}[data-theme=dark] .itbox-ucount-input{background:#0f172a;border-color:#334155;color:#f1f5f9}[data-theme=dark] .rconn-section{border-top-color:#334155}[data-theme=dark] .rconn-title,[data-theme=dark] .rconn-empty{color:#475569}[data-theme=dark] .rconn-row{background:#0f172a;border-color:#334155}[data-theme=dark] .rconn-port{background:#334155;color:#94a3b8}[data-theme=dark] .rconn-device{color:#e2e8f0}[data-theme=dark] .rconn-form{background:#0f172a;border-color:#334155}[data-theme=dark] .rconn-form-row label{color:#475569}[data-theme=dark] .rconn-form-row select{background:#1e293b;border-color:#334155;color:#e2e8f0}[data-theme=dark] .custom-port-name-input{background:#0f172a;border-color:#334155;color:#f1f5f9}[data-theme=dark] .custom-port-color-pick{border-color:#334155}[data-theme=dark] .rack-remove{color:#475569}[data-theme=dark] .rack-remove:hover{background:#450a0a;color:#fca5a5}.rack-drag-handle{font-size:13px;color:#cbd5e1;cursor:grab;flex-shrink:0;padding:0 2px;-webkit-user-select:none;user-select:none}.rack-drag-handle:active{cursor:grabbing}.itbox-list-item--dragover{border-top:2px solid #3b82f6;background:#3b82f60f}[data-theme=dark] .rack-drag-handle{color:#475569}[data-theme=dark] .itbox-list-item--dragover{border-top-color:#3b82f6;background:#3b82f61a}.itbox-list-badges{display:flex;gap:4px;align-items:center}.itbox-upos-badge{font-size:10px;font-weight:700;color:#1d4ed8;background:#dbeafe;border-radius:4px;padding:1px 5px}.itbox-list-item--spacer{opacity:.75;background:repeating-linear-gradient(45deg,transparent,transparent 4px,rgba(0,0,0,.03) 4px,rgba(0,0,0,.03) 8px)}.itbox-spacer-divider{border-top:1px dashed #e2e8f0;margin:10px 0}.itbox-rack-full-msg{font-size:11px;color:#ef4444;font-weight:600;padding:4px 0}[data-theme=dark] .itbox-rack-full-msg{color:#fca5a5}[data-theme=dark] .itbox-upos-badge{background:#3b82f633;color:#93c5fd}[data-theme=dark] .itbox-list-item--spacer{background:repeating-linear-gradient(45deg,transparent,transparent 4px,rgba(255,255,255,.03) 4px,rgba(255,255,255,.03) 8px)}[data-theme=dark] .itbox-spacer-divider{border-top-color:#334155}[data-theme=dark] .port-modal{background:#1e293b;box-shadow:0 20px 50px #0009}[data-theme=dark] .port-modal-header{border-bottom-color:#334155}[data-theme=dark] .port-modal-title{color:#f1f5f9}[data-theme=dark] .port-modal-route{color:#64748b}[data-theme=dark] .port-modal-arrow{color:#475569}[data-theme=dark] .port-selector{border-right-color:#334155}[data-theme=dark] .port-selector-device{color:#f1f5f9}[data-theme=dark] .port-selector-subtype{color:#475569}[data-theme=dark] .port-item{background:#0f172a;border-color:#334155;color:#e2e8f0}[data-theme=dark] .port-item:hover:not(:disabled){background:#3b82f61a;border-color:#3b82f6}[data-theme=dark] .port-selected{background:#3b82f626!important}[data-theme=dark] .port-used{background:#0f172a!important}[data-theme=dark] .port-modal-footer{border-top-color:#334155}[data-theme=dark] .port-auto-note{color:#475569}[data-theme=dark] .connection-row{background:#0f172a;border-color:#334155}[data-theme=dark] .conn-other-device{color:#e2e8f0}[data-theme=dark] .conn-port-other{background:#334155!important;color:#94a3b8}[data-theme=dark] .conn-port-unset,[data-theme=dark] .conn-cable-type{color:#475569}[data-theme=dark] .conn-ep-device{color:#e2e8f0}[data-theme=dark] .conn-arrow,[data-theme=dark] .conn-ep-label{color:#475569}[data-theme=dark] .context-menu{background:#1e293b;border-color:#334155;box-shadow:0 8px 24px #00000080}[data-theme=dark] .context-menu-item{color:#e2e8f0}[data-theme=dark] .context-menu-item:hover,[data-theme=dark] .context-menu-separator{background:#334155}[data-theme=dark] .title-block{background:#1e293b;border-color:#1e3a5f}[data-theme=dark] .tb-logo-cell,[data-theme=dark] .tb-v-logo-cell{background:#1e293b;border-right-color:#1e3a5f}[data-theme=dark] .tb-field{border-bottom-color:#334155}[data-theme=dark] .tb-value{color:#e2e8f0}[data-theme=dark] .tb-value:hover{color:#60a5fa}[data-theme=dark] .tb-label,[data-theme=dark] .tb-placeholder{color:#475569}[data-theme=dark] .tb-input{color:#e2e8f0;background:#172033}[data-theme=dark] .tb-meta-cell{border-right-color:#334155}[data-theme=dark] .tb-meta-row{border-top-color:#334155}[data-theme=dark] .tb-legend-row{border-bottom-color:#334155}[data-theme=dark] .tb-legend-name{color:#94a3b8}[data-theme=dark] .tb-legend-count{color:#93c5fd}[data-theme=dark] .tb-sub{border-top-color:#1e3a5f}[data-theme=dark] .tb-image-block{background:#0f172a}[data-theme=dark] .tb-img-upload-btn{color:#475569;border-color:#334155}[data-theme=dark] .tb-img-upload-btn:hover{background:#1e3a5f;color:#93c5fd;border-color:#3b82f6}[data-theme=dark] .door-device-row{background:#0f172a}[data-theme=dark] .door-device-label-input{color:#f1f5f9}[data-theme=dark] .door-device-label-input:hover,[data-theme=dark] .door-device-label-input:focus{background:#1e293b}.report-panel{flex-shrink:0;border-top:1px solid #e2e8f0;background:#f8fafc;display:flex;flex-direction:column;max-height:320px}.report-panel--collapsed{max-height:none}.report-panel-header{display:flex;align-items:center;border-bottom:1px solid #e2e8f0;background:#fff;flex-shrink:0}.rp-tabs{display:flex;gap:0;flex:1}.rp-tab{padding:8px 18px;font-size:12px;font-weight:600;color:#64748b;background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;letter-spacing:.2px;transition:color .15s,border-color .15s}.rp-tab:hover{color:#1e40af}.rp-tab--active{color:#1e40af;border-bottom-color:#3b82f6;background:#f0f9ff}.rp-collapse-btn{padding:8px 14px;font-size:11px;color:#94a3b8;background:transparent;border:none;cursor:pointer;border-left:1px solid #e2e8f0}.rp-collapse-btn:hover{color:#475569;background:#f1f5f9}.report-panel-body{overflow-y:auto;flex:1;padding:12px 16px}.rp-section{display:flex;flex-direction:column;gap:12px}.rp-summary{font-size:12px;font-weight:600;color:#475569;padding-bottom:4px}.rp-group{display:flex;flex-direction:column;gap:4px}.rp-group-header{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:700;color:#1e293b;padding:2px 0}.rp-cat-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.rp-cat-name{flex:1}.rp-cat-count{font-size:11px;font-weight:700;color:#64748b;background:#e2e8f0;border-radius:10px;padding:1px 7px}.rp-table{width:100%;border-collapse:collapse;font-size:12px}.rp-table th{text-align:left;font-size:10px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.4px;padding:4px 8px;background:#f1f5f9;border-bottom:1px solid #e2e8f0}.rp-table td{padding:5px 8px;color:#374151;border-bottom:1px solid #f1f5f9}.rp-table tr:last-child td{border-bottom:none}.rp-table tr:hover td{background:#f0f9ff}.rp-table--cable th:not(:first-child),.rp-table--cable td:not(:first-child){text-align:right}.rp-bold{font-weight:700;color:#1e293b}.rp-total-row td{font-weight:700;color:#1e293b;background:#e0f2fe;border-top:1px solid #bae6fd}.rp-note{font-size:11px;color:#94a3b8;font-style:italic}.rp-empty{font-size:12px;color:#94a3b8;padding:12px 0}.rp-empty--inline{padding:6px 0;font-style:italic}.rp-rack-block{display:flex;flex-direction:column;gap:6px;padding-bottom:12px;border-bottom:1px solid #e2e8f0}.rp-rack-block:last-child{border-bottom:none}.rp-rack-title{font-size:13px;font-weight:700;color:#1e293b;display:flex;align-items:baseline;gap:10px}.rp-rack-meta{font-size:11px;font-weight:400;color:#64748b}.rp-sub-label{font-size:10px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;margin-top:4px}.rp-arrow{color:#94a3b8;font-size:12px;text-align:center;padding:0 2px}.rp-port{display:inline-block;background:#e2e8f0;color:#475569;font-size:11px;font-family:ui-monospace,monospace;padding:1px 5px;border-radius:3px}[data-theme=dark] .report-panel{background:#0f172a;border-top-color:#334155}[data-theme=dark] .report-panel-header{background:#1e293b;border-bottom-color:#334155}[data-theme=dark] .rp-tab{color:#475569}[data-theme=dark] .rp-tab:hover{color:#93c5fd}[data-theme=dark] .rp-tab--active{color:#93c5fd;border-bottom-color:#3b82f6;background:#3b82f614}[data-theme=dark] .rp-collapse-btn{color:#475569;border-left-color:#334155}[data-theme=dark] .rp-collapse-btn:hover{color:#94a3b8;background:#0f172a}[data-theme=dark] .rp-summary{color:#64748b}[data-theme=dark] .rp-group-header{color:#e2e8f0}[data-theme=dark] .rp-cat-count{background:#334155;color:#94a3b8}[data-theme=dark] .rp-table th{background:#1e293b;color:#475569;border-bottom-color:#334155}[data-theme=dark] .rp-table td{color:#cbd5e1;border-bottom-color:#1e293b}[data-theme=dark] .rp-table tr:hover td{background:#3b82f60f}[data-theme=dark] .rp-bold{color:#f1f5f9}[data-theme=dark] .rp-total-row td{background:#0ea5e91f;border-top-color:#0ea5e9;color:#f1f5f9}[data-theme=dark] .rp-note,[data-theme=dark] .rp-empty{color:#475569}[data-theme=dark] .rp-rack-block{border-bottom-color:#334155}[data-theme=dark] .rp-rack-title{color:#e2e8f0}[data-theme=dark] .rp-rack-meta,[data-theme=dark] .rp-sub-label,[data-theme=dark] .rp-arrow{color:#475569}[data-theme=dark] .rp-port{background:#334155;color:#94a3b8}[data-theme=dark] .door-section-label{color:#475569}.floor-tab-bar{display:flex;align-items:center;gap:2px;padding:0 16px;height:40px;background:#fff;border-bottom:1px solid #e5e7eb;overflow-x:auto;flex-shrink:0}[data-theme=dark] .floor-tab-bar{background:#1e293b;border-bottom-color:#334155}.floor-tab{display:flex;align-items:center;height:32px;padding:0 12px;border-radius:6px 6px 0 0;font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;min-width:80px;color:#6b7280;border:1px solid transparent;border-bottom:none;-webkit-user-select:none;user-select:none}.floor-tab--active{background:#fff;color:#1e40af;border-color:#e5e7eb}[data-theme=dark] .floor-tab--active{background:#1e293b;color:#60a5fa;border-color:#334155}.floor-tab--drop-target{border:2px dashed #3b82f6}.floor-tab-name{pointer-events:none}.floor-tab-rename{background:transparent;border:none;outline:1px solid #3b82f6;border-radius:3px;font-size:13px;font-weight:500;color:inherit;padding:1px 4px;width:100%}.floor-tab-add{display:flex;align-items:center;gap:4px;padding:0 10px;height:32px;font-size:12px;font-weight:500;color:#6b7280;background:none;border:1px dashed #d1d5db;border-radius:6px;cursor:pointer;margin-left:4px}[data-theme=dark] .floor-tab-add{color:#94a3b8;border-color:#475569}.floor-2mb-warning{padding:6px 16px;background:#fffbeb;color:#b45309;font-size:12px;border-bottom:1px solid #fde68a}[data-theme=dark] .floor-2mb-warning{background:#3a2e10;color:#fbbf24;border-bottom-color:#6b5318}.wd-toolbar{display:flex;align-items:center;justify-content:space-between;padding:0 14px;height:44px;flex-shrink:0;background:#152030;border-bottom:1px solid #27394f}.wd-toolbar-title{font-size:13px;font-weight:600;color:#dde6f0;letter-spacing:.2px;-webkit-user-select:none;user-select:none}.wd-toolbar-actions{display:flex;gap:6px;align-items:center}.wd-divider{width:1px;height:20px;background:#27394f;margin:0 2px}.wd-btn{height:28px;padding:0 12px;font-size:12px;font-weight:500;color:#dde6f0;background:#1c2c40;border:1px solid #344e6a;border-radius:6px;cursor:pointer}.wd-btn:hover{background:#22334a}.wd-btn-accent{background:#1a3256;color:#3b82f6;border-color:#3b82f6}.wd-btn-success{background:transparent;color:#22c55e;border-color:#22c55e}.wd-btn-success:hover{background:#22c55e1a}.wd-btn-danger{background:#3b1111;color:#fca5a5;border-color:#7f1d1d;border-radius:4px}.wd-btn-danger:hover{background:#4a1515;border-color:#ef4444}.wd-toolbar-rename-input{padding:4px 8px;border:1px solid #27394f;border-radius:4px;background:#0d1826;color:#dde6f0;font-size:13px;font-weight:600;letter-spacing:.2px;min-width:220px;outline:none}.wd-toolbar-rename-input:focus-visible{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f659}.wd-inp{background:#0d1826;color:#dde6f0;border:1px solid #27394f;border-radius:3px;padding:4px 7px;font-size:11px;font-family:Consolas,SFMono-Regular,monospace;outline:none;min-width:0;width:100%}.wd-inp:focus{border-color:#3b82f6}.wd-inp::placeholder{color:#4e6476}select.wd-inp{cursor:pointer}.wd-item{display:block;padding:5px 10px;margin:1px 4px;border-radius:4px;font-size:12px;color:#8da5bf;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .1s,color .1s}.wd-item:hover{background:#22334a;color:#dde6f0}.vp-item{display:flex;align-items:flex-start;gap:5px;padding:4px 6px;border-radius:3px;font-size:11px;cursor:pointer;transition:background .1s;line-height:1.4}.vp-item:hover{background:#22334a}@media print{.no-print{display:none!important}}:root[data-jm-theme=light]{--jm-bg: var(--color-gray-50);--jm-surface: var(--color-white);--jm-surface-2: var(--color-gray-50);--jm-text: var(--color-gray-800);--jm-text-muted: var(--color-gray-500);--jm-border: var(--color-gray-100);--jm-border-strong: var(--color-gray-200);--jm-accent: var(--color-red-500);--jm-accent-fg: #ffffff;--jm-accent-soft: var(--color-red-100);--jm-danger: var(--color-error);--jm-danger-bg: rgba(229, 62, 62, .08);--jm-success: var(--color-success);--jm-success-soft: rgba(34, 197, 94, .14);--jm-value: var(--color-success);--jm-warn-fg: var(--color-warning);--jm-warn-bg: rgba(245, 158, 11, .1);--jm-warn-border: rgba(245, 158, 11, .35);--jm-overlay: color-mix(in srgb, var(--color-navy-900) 45%, transparent);--jm-header-bg: var(--color-navy-900);--jm-header-fg: #ffffff;--jm-shadow: rgba(0, 0, 0, .12)}:root[data-jm-theme=dark]{--jm-bg: var(--color-navy-800);--jm-surface: var(--color-navy-700);--jm-surface-2: var(--color-navy-600);--jm-text: var(--color-white);--jm-text-muted: var(--color-gray-400);--jm-border: rgba(255, 255, 255, .08);--jm-border-strong: rgba(255, 255, 255, .16);--jm-accent: var(--color-red-500);--jm-accent-fg: #ffffff;--jm-accent-soft: rgba(227, 30, 36, .18);--jm-danger: var(--color-error-light);--jm-danger-bg: rgba(248, 113, 113, .12);--jm-success: var(--color-success-light);--jm-success-soft: rgba(34, 197, 94, .16);--jm-value: var(--color-success-light);--jm-warn-fg: var(--color-warning-light);--jm-warn-bg: rgba(245, 158, 11, .12);--jm-warn-border: rgba(245, 158, 11, .3);--jm-overlay: color-mix(in srgb, var(--color-navy-900) 55%, transparent);--jm-header-bg: var(--color-navy-900);--jm-header-fg: #ffffff;--jm-shadow: rgba(0, 0, 0, .4)}:root[data-jm-theme] body{background:var(--jm-bg);font-family:var(--font-ui)}:root[data-jm-theme=dark] .rbc-calendar{color:var(--jm-text)}:root[data-jm-theme=dark] .rbc-toolbar button{color:var(--jm-text);border-color:var(--jm-border-strong);background:var(--jm-surface)}:root[data-jm-theme=dark] .rbc-toolbar button:hover,:root[data-jm-theme=dark] .rbc-toolbar button:focus{background:var(--jm-surface-2)}:root[data-jm-theme=dark] .rbc-toolbar button.rbc-active{background:var(--jm-accent);color:var(--jm-accent-fg);border-color:var(--jm-accent)}:root[data-jm-theme=dark] .rbc-month-view,:root[data-jm-theme=dark] .rbc-time-view,:root[data-jm-theme=dark] .rbc-time-header,:root[data-jm-theme=dark] .rbc-time-content,:root[data-jm-theme=dark] .rbc-month-row,:root[data-jm-theme=dark] .rbc-day-bg,:root[data-jm-theme=dark] .rbc-header,:root[data-jm-theme=dark] .rbc-time-slot,:root[data-jm-theme=dark] .rbc-timeslot-group,:root[data-jm-theme=dark] .rbc-day-slot,:root[data-jm-theme=dark] .rbc-time-gutter,:root[data-jm-theme=dark] .rbc-time-header-content{border-color:var(--jm-border)!important;background:var(--jm-surface)}:root[data-jm-theme=dark] .rbc-header,:root[data-jm-theme=dark] .rbc-button-link,:root[data-jm-theme=dark] .rbc-time-gutter .rbc-label{color:var(--jm-text)}:root[data-jm-theme=dark] .rbc-off-range-bg{background:var(--jm-bg)}:root[data-jm-theme=dark] .rbc-today{background:var(--jm-accent-soft)}:root[data-jm-theme=dark] .rbc-event{background:var(--jm-accent);color:var(--jm-accent-fg);border-color:var(--jm-accent)}:root[data-jm-theme=dark] .rbc-show-more{background:transparent;color:var(--jm-accent)}:root[data-jm-theme=dark] .rbc-current-time-indicator{background:var(--jm-danger)}.jm-page{min-height:100vh;background:var(--jm-bg);display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased}.jm-header{height:60px;background:var(--jm-header-bg);display:flex;align-items:center;padding:0 20px 0 84px;gap:0;flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.06);position:sticky;top:0;z-index:50}.jm-header-left{display:flex;align-items:center;gap:28px;flex:1;min-width:0}.jm-header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.jm-brand{display:flex;align-items:center;gap:10px;flex-shrink:0}.jm-brand-logo{height:26px;width:auto;display:block;flex-shrink:0}.jm-brand-mark{width:30px;height:30px;border-radius:7px;background:var(--jm-accent);color:#fff;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;letter-spacing:.5px;flex-shrink:0}.jm-brand-name{color:var(--jm-header-fg);font-weight:700;font-size:15px;white-space:nowrap}.jm-nav{display:flex;align-items:center;gap:2px;overflow-x:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.25) transparent}.jm-nav::-webkit-scrollbar{height:6px}.jm-nav::-webkit-scrollbar-track{background:transparent}.jm-nav::-webkit-scrollbar-thumb{background:#ffffff40;border-radius:3px}.jm-nav::-webkit-scrollbar-thumb:hover{background:#ffffff73}.jm-nav-link{display:flex;align-items:center;gap:6px;padding:6px 11px;height:34px;border-radius:7px;font-size:13px;font-weight:500;color:#ffffff80;cursor:pointer;background:transparent;border:none;font-family:inherit;white-space:nowrap;transition:background .12s,color .12s}.jm-nav-link:hover{background:#ffffff14;color:#ffffffd9}.jm-nav-link--active{background:#ffffff1c;color:#fff;cursor:default;font-weight:600}.jm-search{position:relative;display:flex;align-items:center}.jm-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#ffffff59;pointer-events:none;flex-shrink:0}.jm-search-input{width:210px;height:34px;padding:0 12px 0 32px;background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:7px;color:#ffffffe6;font-size:13px;font-family:inherit;outline:none;transition:border-color .15s,background .15s;-webkit-appearance:none}.jm-search-input::placeholder{color:#ffffff4d}.jm-search-input:focus{border-color:#ffffff38;background:#ffffff1f}.jm-btn-primary{display:flex;align-items:center;gap:6px;padding:0 14px;height:34px;background:var(--jm-accent);color:#fff;border:none;border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;font-family:inherit;transition:background .12s;flex-shrink:0}.jm-btn-primary:hover{background:#1d4ed8}.jm-btn-primary:active{background:#1e40af;transform:translateY(1px)}.jm-btn-primary:focus-visible{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.jm-btn-icon{width:34px;height:34px;border-radius:7px;background:#ffffff12;border:1px solid rgba(255,255,255,.1);color:#fff9;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s;flex-shrink:0;padding:0}.jm-btn-icon:hover{background:#ffffff21;color:#ffffffe6}.jm-btn-icon:focus-visible{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}.jm-overflow-wrap,.jm-plus-wrap{position:relative;display:inline-flex}.jm-overflow-trigger,.jm-plus-trigger{position:relative}.jm-overflow-active-dot{position:absolute;top:4px;right:4px;width:7px;height:7px;border-radius:50%;background:var(--jm-accent);box-shadow:0 0 0 2px var(--jm-header-bg);pointer-events:none}.jm-dropdown{position:absolute;top:calc(100% + 6px);background:var(--jm-surface);border:1px solid var(--jm-border);border-radius:10px;box-shadow:0 8px 28px var(--jm-shadow);min-width:200px;padding:6px;z-index:60;display:flex;flex-direction:column;gap:2px}.jm-dropdown--overflow{left:0}.jm-dropdown--plus{right:0}.jm-dropdown-item{display:flex;align-items:center;gap:10px;padding:8px 10px;font-size:13px;color:var(--jm-text);background:transparent;border:none;border-radius:6px;cursor:pointer;font-family:inherit;text-align:left;min-height:34px;transition:background .12s}.jm-dropdown-item:hover{background:var(--jm-surface-2)}.jm-dropdown-item:focus-visible{outline:2px solid var(--jm-accent);outline-offset:-2px}.jm-dropdown-item--active{background:var(--jm-accent-soft);color:var(--jm-accent);font-weight:600}.jm-header-search .jm-search-input{width:280px}@media (max-width: 1100px){.jm-header-search .jm-search-input{width:200px}}.jm-board{flex:1;display:grid;grid-template-columns:repeat(5,minmax(220px,1fr));gap:14px;padding:20px;overflow-x:auto;align-items:start}.jm-col{background:var(--jm-surface);border-radius:12px;border:1px solid var(--jm-border);overflow:hidden;min-height:180px;transition:outline .1s;display:flex;flex-direction:column}.jm-col:before{content:"";display:block;height:3px;background:var(--col-color, #94a3b8);flex-shrink:0}.jm-col--drop{outline:2px dashed var(--col-color, #94a3b8);outline-offset:-1px;background:var(--jm-surface-2)}.jm-col-header{display:flex;align-items:center;gap:8px;padding:12px 14px 11px;border-bottom:1px solid var(--jm-border);flex-shrink:0}.jm-col-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.jm-col-label{font-size:12px;font-weight:700;color:var(--jm-text);flex:1;text-transform:uppercase;letter-spacing:.4px}.jm-col-count{display:inline-flex;align-items:center;gap:6px;background:var(--jm-border);color:var(--jm-text-muted);border-radius:20px;padding:2px 8px;font-size:12px;font-weight:700;min-width:22px;text-align:center;line-height:1.5}.jm-col-value{color:var(--jm-text);font-weight:600;font-size:11px;font-variant-numeric:tabular-nums;padding-left:6px;border-left:1px solid var(--jm-border-strong)}.jm-col-body{padding:10px;display:flex;flex-direction:column;gap:8px;flex:1}.jm-col-empty{text-align:center;padding:32px 12px;color:var(--jm-text-muted);font-size:13px}.jm-col-load-more{width:100%;padding:8px;border:1px dashed var(--jm-border-strong);border-radius:7px;background:transparent;cursor:pointer;color:var(--jm-text-muted);font-size:13px;font-family:inherit;transition:background .12s,border-color .12s}.jm-col-load-more:hover:not(:disabled){background:var(--jm-border);border-color:var(--jm-text-muted)}.jm-col-load-more:disabled{opacity:.5;cursor:not-allowed}.jm-col-loading{display:flex;flex-direction:column;gap:8px;padding:4px 0}.jm-skeleton{height:72px;border-radius:8px;background:linear-gradient(90deg,var(--jm-border) 25%,var(--jm-border-strong) 50%,var(--jm-border) 75%);background-size:200% 100%;animation:jm-shimmer 1.4s ease-in-out infinite}.jm-skeleton--short{height:52px}@keyframes jm-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.jm-card{background:var(--jm-surface);border-radius:9px;padding:12px 12px 10px 11px;border:1px solid var(--jm-border);border-left:3px solid var(--card-color, var(--jm-border-strong));cursor:grab;transition:box-shadow .15s,transform .12s,border-color .12s;outline:none;display:flex;flex-direction:column;gap:0}.jm-card:hover{box-shadow:0 4px 16px var(--jm-shadow);transform:translateY(-1px)}.jm-card:active{cursor:grabbing;transform:translateY(0)}.jm-card:focus-visible{outline:2px solid var(--jm-accent);outline-offset:1px}.jm-card-job{font-size:10px;font-weight:700;color:var(--jm-text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.jm-card-client{font-size:14px;font-weight:700;color:var(--jm-text);line-height:1.35;margin-bottom:3px}.jm-card-address{font-size:12px;color:var(--jm-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:10px;line-height:1.4}.jm-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto}.jm-card-value{font-size:13px;font-weight:700;color:var(--jm-value);font-variant-numeric:tabular-nums}.jm-card-arrow{color:var(--jm-border-strong);transition:color .12s,transform .12s}.jm-card:hover .jm-card-arrow{color:var(--jm-text-muted);transform:translate(2px)}.jm-btn-ghost{display:flex;align-items:center;gap:5px;padding:0 12px;height:34px;background:transparent;border:1px solid var(--jm-border-strong);border-radius:7px;color:var(--jm-text-muted);font-size:13px;font-family:inherit;cursor:pointer;white-space:nowrap;transition:background .12s,border-color .12s,color .12s;flex-shrink:0}.jm-btn-ghost:hover{background:var(--jm-surface-2);border-color:var(--jm-text-muted);color:var(--jm-text)}.jm-btn-ghost:focus-visible{outline:2px solid var(--jm-accent);outline-offset:2px}.jm-btn-ghost:disabled{opacity:.38;cursor:not-allowed}.jm-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--jm-surface-2);border:1px solid var(--jm-border);border-radius:20px;padding:2px 9px;font-size:12px;font-weight:600;color:var(--jm-text-muted);min-width:22px;line-height:1.5;flex-shrink:0}.jm-subheader{display:flex;align-items:center;gap:10px;padding:0 20px;height:52px;background:var(--jm-surface);border-bottom:1px solid var(--jm-border);flex-shrink:0}.jm-filter-search{position:relative;display:flex;align-items:center;flex:1;max-width:380px}.jm-filter-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--jm-text-muted);pointer-events:none;flex-shrink:0}.jm-filter-search-input{width:100%;height:34px;padding:0 12px 0 32px;background:var(--jm-surface);border:1px solid var(--jm-border-strong);border-radius:7px;color:var(--jm-text);font-size:13px;font-family:inherit;outline:none;box-sizing:border-box;transition:border-color .15s;-webkit-appearance:none}.jm-filter-search-input::placeholder{color:var(--jm-text-muted)}.jm-filter-search-input:focus{border-color:var(--jm-accent)}.jm-filter-select{height:34px;padding:0 28px 0 10px;background:var(--jm-surface);border:1px solid var(--jm-border-strong);border-radius:7px;color:var(--jm-text);font-size:13px;font-family:inherit;cursor:pointer;outline:none;transition:border-color .15s;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.5'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.jm-filter-select:focus{border-color:var(--jm-accent)}.jm-table-wrap{flex:1;overflow-y:auto}.jm-table{width:100%;border-collapse:collapse;font-size:13px}.jm-table thead{position:sticky;top:0;z-index:1}.jm-table-th{padding:9px 14px;text-align:left;font-size:11px;font-weight:700;color:var(--jm-text-muted);letter-spacing:.6px;white-space:nowrap;text-transform:uppercase;background:var(--jm-surface-2);border-bottom:2px solid var(--jm-border)}.jm-table-row{border-bottom:1px solid var(--jm-border);cursor:pointer;transition:background .1s}.jm-table-row:nth-child(odd){background:var(--jm-surface)}.jm-table-row:nth-child(2n){background:var(--jm-surface-2)}.jm-table-row:hover{background:var(--jm-accent-soft)}.jm-table-row:focus-visible{outline:2px solid var(--jm-accent);outline-offset:-2px}.jm-table-td{padding:10px 14px;color:var(--jm-text)}.jm-table-td--muted{color:var(--jm-text-muted);font-size:12px}.jm-table-td--nowrap{white-space:nowrap}.jm-table-td--truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.jm-table-cell-primary{font-weight:700;color:var(--jm-accent);font-size:13px}.jm-table-cell-sub{font-size:11px;color:var(--jm-text-muted);margin-top:2px}.jm-empty-state{display:flex;flex-direction:column;align-items:center;gap:12px;padding:72px 24px;text-align:center}.jm-empty-state-icon{color:var(--jm-border-strong)}.jm-empty-state-title{margin:0;font-size:16px;font-weight:600;color:var(--jm-text)}.jm-empty-state-body{margin:0;font-size:13px;color:var(--jm-text-muted);max-width:320px}.jm-cal-tools{display:flex;align-items:center;gap:8px;padding:0 20px;height:48px;background:var(--jm-surface);border-bottom:1px solid var(--jm-border);flex-shrink:0}.jm-cal-tools-label{font-size:13px;color:var(--jm-text-muted);display:flex;align-items:center;gap:6px;white-space:nowrap}.jm-cal-date-input{height:30px;padding:0 8px;border-radius:6px;border:1px solid var(--jm-border-strong);font-size:13px;color:var(--jm-text);background:var(--jm-surface);font-family:inherit;outline:none;transition:border-color .15s}.jm-cal-date-input:focus{border-color:var(--jm-accent)}.jm-cal-error{font-size:13px;color:var(--jm-danger);margin-left:12px}.jm-cal-body{flex:1;display:flex;overflow:hidden}.jm-cal-main{flex:1;padding:16px;overflow:hidden}.jm-cal-sidebar{width:180px;border-left:1px solid var(--jm-border);padding:16px;overflow-y:auto;background:var(--jm-surface-2);flex-shrink:0}.jm-cal-sidebar-title{font-size:12px;font-weight:700;color:var(--jm-text-muted);text-transform:uppercase;letter-spacing:.4px;margin:0 0 10px}.jm-cal-person{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:13px;color:var(--jm-text)}.jm-cal-person-dot{width:14px;height:14px;border-radius:4px;flex-shrink:0;border:2px solid var(--jm-surface);box-shadow:0 0 0 1px #0000001f}.jm-feeds-panel{background:var(--jm-bg);border-bottom:1px solid var(--jm-border);padding:16px 20px;max-height:240px;overflow-y:auto}.jm-feeds-title{margin:0 0 8px;font-size:13px;font-weight:600;color:var(--jm-text)}.jm-feeds-note{margin:0 0 10px;font-size:12px;color:var(--jm-text-muted)}.jm-feeds-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:13px}.jm-feeds-name{width:120px;font-weight:600;color:var(--jm-text);flex-shrink:0}.jm-feeds-url{flex:1;min-width:0;background:var(--jm-surface);border:1px solid var(--jm-border);border-radius:4px;padding:4px 8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--jm-text);font-family:monospace;font-size:12px}.jm-feeds-action{padding:4px 10px;border-radius:4px;border:1px solid var(--jm-border-strong);background:var(--jm-surface);cursor:pointer;font-size:12px;color:var(--jm-text);text-decoration:none;white-space:nowrap;font-family:inherit;transition:background .12s}.jm-feeds-action:hover{background:var(--jm-surface-2)}.jm-feeds-action:focus-visible{outline:2px solid var(--jm-accent);outline-offset:2px}.jm-login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--jm-header-bg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased}.jm-login-toggle{position:fixed;top:16px;right:16px}.jm-login-card{background:var(--jm-surface);border-radius:12px;padding:48px 40px;width:360px;box-shadow:0 20px 60px #0006}.jm-login-card--shake{animation:jm-shake .4s ease}.jm-login-title{margin:0 0 8px;font-size:24px;font-weight:700;color:var(--jm-text)}.jm-login-subtitle{margin:0 0 32px;color:var(--jm-text-muted);font-size:14px}.jm-login-input{width:100%;padding:12px 16px;font-size:16px;border:1.5px solid var(--jm-border-strong);border-radius:8px;box-sizing:border-box;outline:none;margin-bottom:8px;color:var(--jm-text);background:var(--jm-surface);font-family:inherit;transition:border-color .15s;-webkit-appearance:none}.jm-login-input:focus{border-color:var(--jm-accent)}.jm-login-input--error{border-color:var(--jm-danger)!important}.jm-login-error{color:var(--jm-danger);font-size:13px;margin:0 0 12px}.jm-login-btn{width:100%;padding:12px;font-size:16px;font-weight:600;background:var(--jm-accent);color:var(--jm-accent-fg);border:none;border-radius:8px;cursor:pointer;font-family:inherit;transition:background .12s,opacity .12s}.jm-login-btn:hover:not(:disabled){background:#1d4ed8}.jm-login-btn:disabled{opacity:.38;cursor:not-allowed}.jm-login-btn:focus-visible{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}@keyframes jm-shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-8px)}40%,80%{transform:translate(8px)}}.jm-status-badge{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;padding:2px 8px;border-radius:20px;display:inline-block}.jm-status-badge--draft{background:var(--jm-surface-2);color:var(--jm-text-muted)}.jm-status-badge--dispatched{background:var(--jm-accent-soft);color:var(--jm-accent)}.jm-status-badge--completed{background:color-mix(in srgb,var(--jm-success) 15%,transparent);color:var(--jm-success)}.jm-status-badge--active{background:var(--jm-accent-soft);color:var(--jm-success)}.jm-status-badge--inactive{background:var(--jm-surface-2);color:var(--jm-text-muted)}.jm-btn-danger{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 18px;border-radius:8px;font-size:14px;font-weight:600;font-family:inherit;border:none;cursor:pointer;background:var(--jm-danger);color:var(--jm-accent-fg);transition:opacity .15s}.jm-btn-danger:hover{opacity:.88}.jm-btn-danger:active{opacity:.76}.jm-btn-danger:disabled{opacity:.38;cursor:not-allowed}.jm-btn-danger:focus-visible{outline:2px solid var(--jm-danger);outline-offset:2px}.jm-btn-danger-text{background:transparent;border:none;color:var(--jm-danger);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;padding:4px 0;text-decoration:underline;text-underline-offset:2px}.jm-btn-danger-text:hover{opacity:.8}.jm-btn-danger-text:focus-visible{outline:2px solid var(--jm-danger);outline-offset:2px}.jm-status-badge--paid{background:color-mix(in srgb,var(--jm-value) 15%,transparent);color:var(--jm-value)}.jm-status-badge--expired{background:color-mix(in srgb,var(--jm-danger) 10%,transparent);color:var(--jm-danger)}.jm-status-badge--sent{background:var(--jm-accent-soft);color:var(--jm-accent)}.jm-status-badge--accepted{background:color-mix(in srgb,var(--jm-success) 15%,transparent);color:var(--jm-success)}.jm-status-badge--expiring,.jm-status-badge--paused{background:var(--jm-warn-bg);color:var(--jm-warn-fg);border:1px solid var(--jm-warn-border)}.jm-status-badge--cancelled{background:var(--jm-surface-2);color:var(--jm-text-muted)}.jm-settings-tabs{display:flex;align-items:center;gap:4px}.jm-settings-tab{background:none;border:none;font-family:inherit;font-size:13px;font-weight:500;color:var(--jm-text-muted);cursor:pointer;padding:6px 12px;border-bottom:2px solid transparent;transition:color .12s,border-color .12s}.jm-settings-tab:hover{color:var(--jm-text)}.jm-settings-tab--active{color:var(--jm-text);border-bottom:2px solid var(--jm-accent)}.jm-settings-tab:focus-visible{outline:2px solid var(--jm-accent);outline-offset:2px}.jm-settings-panel{background:var(--jm-surface);border-radius:12px;padding:24px;max-width:640px}.jm-settings-section{margin-bottom:24px;border-bottom:1px solid var(--jm-border);padding-bottom:24px}.jm-settings-section:last-child{border-bottom:none}.jm-settings-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--jm-text-muted);margin-bottom:16px}.jm-write-only-field{position:relative}.jm-write-only-hint{font-size:12px;color:var(--jm-text-muted);display:block;margin-top:4px}.jm-tax-tab{padding:24px}.jm-tax-tab-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.jm-tax-tab-title{font-size:14px;font-weight:600;color:var(--jm-text)}.jm-tax-banner{background:var(--jm-accent-soft);border:1px solid var(--jm-accent);border-radius:8px;padding:12px 16px;margin-bottom:16px;color:var(--jm-text);font-size:13px;line-height:1.5;display:flex;align-items:flex-start;gap:10px}.jm-tax-banner-icon{color:var(--jm-accent);flex-shrink:0;margin-top:2px}.jm-tax-table{width:100%;font-size:13px}.jm-tax-table-pct{font-variant-numeric:tabular-nums}.jm-tax-table-actions{display:flex;gap:8px;align-items:center}.jm-tax-table-radio{display:inline-flex;align-items:center;cursor:pointer}.jm-tax-table-radio input{accent-color:var(--jm-accent);cursor:pointer}.jm-tax-table-empty{padding:32px 24px;color:var(--jm-text-muted);font-size:13px;text-align:center}.jm-tax-table-error{color:var(--jm-danger);font-size:12px;padding:8px 16px;background:color-mix(in srgb,var(--jm-danger) 10%,transparent);border-radius:6px;margin-top:8px}.jm-tax-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--jm-overlay);display:flex;align-items:center;justify-content:center;z-index:500}.jm-tax-modal{background:var(--jm-surface);border-radius:12px;width:440px;max-width:95vw;max-height:90vh;overflow-y:auto;padding:24px 28px;box-shadow:0 20px 60px var(--jm-shadow)}.jm-tax-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.jm-tax-modal-title{font-size:16px;font-weight:700;color:var(--jm-text);margin:0}.jm-tax-modal-close{margin:-6px -6px -6px 0}.jm-tax-modal-loading{padding:12px 0;color:var(--jm-text-muted);font-size:14px}.jm-tax-modal-field{margin-bottom:16px}.jm-tax-modal-hint{display:block;margin-top:6px;font-size:12px;color:var(--jm-text-muted);line-height:1.4}.jm-tax-modal-checkbox{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--jm-text);cursor:pointer}.jm-tax-modal-checkbox input{accent-color:var(--jm-accent);cursor:pointer}.jm-tax-modal-error{margin-top:4px;margin-bottom:12px}.jm-tax-modal-actions{display:flex;gap:10px;justify-content:space-between;margin-top:24px}.jm-payments-section{margin-top:24px}.jm-payments-table{width:100%;font-size:13px;border-collapse:collapse}.jm-running-totals{background:var(--jm-surface-2);border-top:1px solid var(--jm-border);padding:12px 16px;border-radius:0 0 8px 8px}.jm-running-totals-row{display:flex;justify-content:space-between;font-size:13px;padding:2px 0}.jm-running-totals-balance--due{color:var(--jm-danger)}.jm-running-totals-balance--paid{color:var(--jm-value)}.jm-bell-btn{position:relative}.jm-bell-badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;border-radius:20px;background:var(--jm-danger);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px;pointer-events:none}.jm-notification-panel{position:absolute;right:0;top:calc(100% + 8px);width:360px;max-height:480px;background:var(--jm-surface);border:1px solid var(--jm-border);border-radius:12px;box-shadow:0 8px 24px var(--jm-shadow);overflow-y:auto;z-index:300}.jm-notification-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--jm-border);font-size:14px;font-weight:700;color:var(--jm-text);flex-shrink:0}.jm-notification-row{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;width:100%;text-align:left;background:none;border:none;cursor:pointer;border-bottom:1px solid var(--jm-border);font-family:inherit}.jm-notification-row--unread{background:var(--jm-accent-soft)}.jm-notification-row:hover{background:var(--jm-surface-2)}.jm-notification-row:focus-visible{outline:2px solid var(--jm-accent);outline-offset:-2px}.jm-notification-icon-wrap{flex-shrink:0;width:28px;height:28px;border-radius:6px;background:var(--jm-surface-2);display:flex;align-items:center;justify-content:center}.jm-notification-content{flex:1;min-width:0}.jm-notification-message{font-size:13px;font-weight:400;color:var(--jm-text);line-height:1.4;display:block}.jm-notification-time{font-size:11px;color:var(--jm-text-muted);margin-top:2px;display:block}.jm-notification-dot{width:8px;height:8px;border-radius:50%;background:var(--jm-accent);flex-shrink:0;margin-top:4px}.jm-notification-empty{padding:32px 16px;text-align:center;color:var(--jm-text-muted);font-size:13px}.jm-accept-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--jm-bg);padding:24px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased}.jm-accept-card{background:var(--jm-surface);border-radius:12px;padding:48px 40px;max-width:560px;width:100%;box-shadow:0 4px 24px var(--jm-shadow)}.jm-accept-brandbar{display:flex;align-items:center;justify-content:space-between;margin:-48px -40px 28px;padding:16px 28px;background:var(--color-navy-900, #0D1B2E);border-radius:12px 12px 0 0;border-bottom:3px solid var(--color-red-500, #E31E24)}.jm-accept-brandbar-name{font-size:15px;font-weight:700;letter-spacing:.04em}.jm-accept-brandbar-name .accent{color:#fff}.jm-accept-brandbar-name .muted{color:#b0bac8}.jm-accept-theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:7px;background:#ffffff14;border:1px solid rgba(255,255,255,.16);color:#fff;cursor:pointer;flex-shrink:0}.jm-accept-theme-toggle:hover{background:#ffffff29}.jm-accept-theme-toggle:focus-visible{outline:2px solid var(--color-red-500, #E31E24);outline-offset:2px}.jm-accept-quote-number{display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--jm-text-muted);margin-bottom:12px}.jm-accept-items-table{width:100%;font-size:13px;border-collapse:collapse;margin-bottom:16px}.jm-accept-total{font-size:18px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--jm-text);text-align:right;margin:12px 0}.jm-accept-valid-until{font-size:12px;color:var(--jm-text-muted);margin-bottom:20px}.jm-accept-valid-until--warning{color:var(--jm-warn-fg)}.jm-signature-area{border:1px solid var(--jm-border);border-radius:8px;padding:16px;margin:16px 0}.jm-signature-tabs{display:flex;gap:4px;margin-bottom:12px}.jm-signature-tab{background:none;border:none;font-family:inherit;font-size:13px;font-weight:500;color:var(--jm-text-muted);cursor:pointer;padding:5px 10px;border-bottom:2px solid transparent;transition:color .12s,border-color .12s}.jm-signature-tab--active{color:var(--jm-accent);border-bottom:2px solid var(--jm-accent)}.jm-signature-tab:focus-visible{outline:2px solid var(--jm-accent);outline-offset:2px}.jm-signature-canvas{width:100%;height:120px;border:1px dashed var(--jm-border);border-radius:6px;background:var(--jm-surface-2);cursor:crosshair;touch-action:none;display:block}.jm-signature-typed{width:100%;font-family:Brush Script MT,Segoe Script,cursive;font-size:22px;padding:8px 10px;border:1px solid var(--jm-border-strong);border-radius:6px;background:var(--jm-surface);color:var(--jm-text);box-sizing:border-box;outline:none}.jm-signature-typed:focus{border-color:var(--jm-accent)}.jm-accept-checkbox-row{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--jm-text);cursor:pointer;margin:16px 0}.jm-accept-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:12px 18px;border-radius:8px;font-size:15px;font-weight:600;font-family:inherit;border:none;cursor:pointer;background:var(--jm-accent);color:var(--jm-accent-fg);transition:opacity .15s}.jm-accept-btn:hover:not(:disabled){opacity:.88}.jm-accept-btn:disabled{opacity:.38;cursor:not-allowed}.jm-accept-btn:focus-visible{outline:2px solid var(--jm-accent-fg);outline-offset:2px}.jm-accept-pay{display:flex;gap:10px;margin:6px 0 20px;flex-wrap:wrap}.jm-accept-pay-btn{flex:1 1 0;min-width:150px;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:12px 16px;border-radius:8px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;background:var(--color-navy-900, #0D1B2E);color:#fff;border:1px solid var(--color-navy-900, #0D1B2E);transition:opacity .15s}.jm-accept-pay-btn:hover{opacity:.9}.jm-accept-pay-btn:focus-visible{outline:2px solid var(--color-red-500, #E31E24);outline-offset:2px}.jm-accept-pay-btn--ghost{background:transparent;color:var(--jm-text);border:1px solid var(--jm-border-strong)}.jm-accept-state{text-align:center;padding:32px 0}.jm-accept-state-icon{display:flex;justify-content:center;margin-bottom:16px}.jm-accept-state-title{font-size:18px;font-weight:700;color:var(--jm-text);margin:0 0 8px}.jm-accept-state-body{font-size:14px;font-weight:400;color:var(--jm-text-muted);margin:0;line-height:1.5}@media (max-width: 600px){.jm-accept-card{padding:32px 24px}.jm-accept-brandbar{margin:-32px -24px 24px;padding:14px 20px}}.jm-contract-card{background:var(--jm-surface-2);border:1px solid var(--jm-border);border-radius:8px;padding:12px 16px;margin-bottom:8px}.jm-contract-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.jm-contract-card-name{font-size:14px;font-weight:700;color:var(--jm-text)}.jm-contract-card-meta{display:flex;justify-content:space-between;font-size:12px;color:var(--jm-text-muted);margin-top:4px}.jm-contract-card-rate{font-weight:600;font-variant-numeric:tabular-nums}.jm-contract-card-dates{font-size:12px;color:var(--jm-text-muted);margin-top:4px}.jm-contract-card-actions{display:flex;gap:8px;margin-top:10px}.jm-auto-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--jm-text-muted)}.jm-input{width:100%;padding:8px 10px;border:1px solid var(--jm-border-strong);border-radius:6px;font-size:13px;color:var(--jm-text);background:var(--jm-surface);box-sizing:border-box;outline:none;min-height:36px;font-family:inherit;transition:border-color .15s;-webkit-appearance:none}.jm-input:focus{border-color:var(--jm-accent)}.jm-input:focus-visible{outline:2px solid var(--jm-accent);outline-offset:1px}.jm-input:disabled{opacity:.38;cursor:not-allowed}.jm-input--error{border-color:var(--jm-danger)!important}.jm-label,.jm-field-label{font-size:11px;font-weight:600;color:var(--jm-text-muted);display:block;margin-bottom:4px;letter-spacing:.4px;text-transform:uppercase}.jm-select{width:100%;padding:8px 28px 8px 10px;border:1px solid var(--jm-border-strong);border-radius:6px;font-size:13px;color:var(--jm-text);background:var(--jm-surface);box-sizing:border-box;outline:none;min-height:36px;font-family:inherit;transition:border-color .15s;cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.jm-select:focus{border-color:var(--jm-accent)}.jm-select:focus-visible{outline:2px solid var(--jm-accent);outline-offset:1px}.jm-select:disabled{opacity:.38;cursor:not-allowed}.jm-input-error{font-size:12px;color:var(--jm-danger);margin-top:4px;display:block}.jm-dashboard-page{padding:24px;display:flex;flex-direction:column;gap:16px}.jm-kpi-row{display:flex;gap:16px}.jm-kpi-card{background:var(--jm-surface);border-radius:8px;padding:16px 20px;flex:1;border:1px solid var(--jm-border)}.jm-kpi-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--jm-text-muted);margin-bottom:8px}.jm-kpi-value{font-size:24px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--jm-text)}.jm-kpi-value--positive{color:var(--jm-value)}.jm-kpi-value--negative{color:var(--jm-danger)}.jm-kpi-sub{font-size:12px;color:var(--jm-text-muted);margin-top:4px}.jm-alert-strip{background:var(--jm-surface-2);border:1px solid var(--jm-border);border-radius:8px;padding:10px 16px}.jm-alert-strip-items{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.jm-alert-item{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:20px;font-size:12px;font-weight:500;cursor:pointer;border:none;background:transparent}.jm-alert-item--warn{background:var(--jm-warn-bg);color:var(--jm-warn-fg);border:1px solid var(--jm-warn-border)}.jm-alert-item--danger{background:color-mix(in srgb,var(--jm-danger) 10%,transparent);color:var(--jm-danger);border:1px solid color-mix(in srgb,var(--jm-danger) 30%,transparent)}.jm-alert-item--info{background:var(--jm-accent-soft);color:var(--jm-accent);border:1px solid var(--jm-accent-soft)}.jm-dashboard-main{display:flex;gap:16px;flex:1;min-height:0}.jm-dashboard-center{flex:1;display:flex;flex-direction:column;gap:16px;min-width:0}.jm-dashboard-sidebar{width:280px;flex-shrink:0;display:flex;flex-direction:column;gap:16px}.jm-chart-card{background:var(--jm-surface);border-radius:8px;border:1px solid var(--jm-border);padding:16px}.jm-chart-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.jm-chart-card-title{font-size:13px;font-weight:700;color:var(--jm-text)}.jm-chart-tabs{display:flex;gap:4px;margin-bottom:12px}.jm-chart-tab{padding:5px 12px;border-radius:6px;font-size:12px;font-weight:500;background:none;border:1px solid var(--jm-border);color:var(--jm-text-muted);cursor:pointer}.jm-chart-tab--active{background:var(--jm-accent);color:var(--jm-accent-fg);border-color:var(--jm-accent)}.jm-widget-card{background:var(--jm-surface);border-radius:8px;border:1px solid var(--jm-border);overflow:hidden}.jm-widget-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--jm-border)}.jm-widget-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--jm-text-muted)}.jm-widget-body{padding:8px 0;max-height:280px;overflow-y:auto}.jm-widget-empty{padding:20px 14px;text-align:center;font-size:12px;color:var(--jm-text-muted)}.jm-task-row{display:flex;align-items:center;gap:8px;padding:7px 14px;border-bottom:1px solid var(--jm-border)}.jm-task-row--today{background:var(--jm-accent-soft)}.jm-task-check{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--jm-text-muted)}.jm-task-check:hover{color:var(--jm-success)}.jm-task-row-content{flex:1;min-width:0}.jm-task-row-project-line{font-size:13px;font-weight:700;color:var(--jm-text);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.jm-task-row-title{font-size:12px;color:var(--jm-text-muted);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.jm-task-row-project{font-size:11px;color:var(--jm-text-muted);margin-top:1px}.jm-task-row-due{font-size:11px;color:var(--jm-text-muted);flex-shrink:0}.jm-appt-widget-row{display:flex;align-items:center;gap:10px;padding:8px 14px;cursor:pointer;border-bottom:1px solid var(--jm-border)}.jm-appt-widget-row:hover{background:var(--jm-surface-2)}.jm-appt-widget-time{font-size:11px;font-weight:700;color:var(--jm-text-muted);min-width:40px;flex-shrink:0}.jm-appt-widget-info{flex:1;min-width:0}.jm-appt-widget-num{font-size:10px;text-transform:uppercase;color:var(--jm-text-muted);display:block}.jm-appt-widget-client{font-size:13px;color:var(--jm-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.jm-status-badge--pending{background:var(--jm-surface-2);color:var(--jm-text-muted)}.jm-status-badge--overdue{background:color-mix(in srgb,var(--jm-danger) 10%,transparent);color:var(--jm-danger)}.jm-task-title--done{text-decoration:line-through;color:var(--jm-text-muted)}.jm-task-complete-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--jm-text-muted);border-radius:6px}.jm-task-complete-btn:hover{color:var(--jm-success);background:color-mix(in srgb,var(--jm-success) 10%,transparent)}.jm-search-modal{background:var(--jm-surface);border-radius:14px;width:600px;max-width:95vw;box-shadow:0 20px 60px #00000040;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.jm-search-input-wrap{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--jm-border)}.jm-search-input{flex:1;font-size:15px;background:none;border:none;outline:none;color:var(--jm-text)}.jm-search-input::placeholder{color:var(--jm-text-muted)}.jm-search-results{overflow-y:auto;max-height:500px}.jm-search-group-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--jm-text-muted);padding:10px 16px 4px}.jm-search-result-row{display:flex;align-items:center;gap:10px;padding:9px 16px;cursor:pointer;width:100%;text-align:left;background:none;border:none;border-bottom:1px solid var(--jm-border)}.jm-search-result-row:hover,.jm-search-result-row--active{background:var(--jm-surface-2)}.jm-search-result-primary{font-size:13px;font-weight:500;color:var(--jm-text)}.jm-search-result-meta{font-size:12px;color:var(--jm-text-muted)}.jm-search-shortcut{display:inline-flex;align-items:center;gap:4px}.jm-search-kbd{font-size:11px;background:var(--jm-surface-2);border:1px solid var(--jm-border);border-radius:4px;padding:2px 6px;font-family:inherit;color:var(--jm-text-muted)}.jm-bom-table{width:100%;font-size:13px}.jm-bom-row--unmatched{background:var(--jm-warn-bg)}.jm-bom-unmatched-flag{display:inline-flex;align-items:center;gap:4px;color:var(--jm-warn-fg);font-size:12px}.jm-bom-assign-btn{font-size:12px;color:var(--jm-accent);background:none;border:none;cursor:pointer;text-decoration:underline;margin-left:8px;padding:0}.jm-bom-assign-btn:focus-visible{outline:2px solid var(--jm-accent);outline-offset:2px}.jm-bom-assign-dropdown{position:absolute;left:0;top:100%;z-index:400;background:var(--jm-surface);border:1px solid var(--jm-border);border-radius:8px;box-shadow:0 8px 24px #00000026;min-width:260px;max-height:200px;overflow-y:auto}.jm-bom-assign-opt{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;background:none;border:none;width:100%;text-align:left;font-size:13px;color:var(--jm-text)}.jm-bom-assign-opt:hover{background:var(--jm-surface-2)}.jm-bom-assign-opt--create{color:var(--jm-accent);border-top:1px solid var(--jm-border)}.jm-bom-assign-search{width:100%;padding:8px 12px;font-size:13px;background:none;border:none;border-bottom:1px solid var(--jm-border);outline:none;color:var(--jm-text)}.jm-btn-primary:disabled{opacity:.38;cursor:not-allowed}.jm-reports-page{padding:24px;display:flex;flex-direction:column;gap:0;min-height:0;flex:1}.jm-report-subheader{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--jm-border);background:var(--jm-surface);gap:12px}.jm-report-content{flex:1;min-height:0;overflow-y:auto}.jm-report-totals-row{background:var(--jm-surface-2);font-weight:700;border-top:2px solid var(--jm-border-strong)}.jm-report-td--number{text-align:right;font-variant-numeric:tabular-nums}.jm-report-td--positive{color:var(--jm-value)}.jm-report-td--negative{color:var(--jm-danger)}.jm-report-money{font-variant-numeric:tabular-nums;font-weight:700}.jm-aging-bucket-header{background:var(--jm-surface-2)}.jm-aging-bucket-label{padding:8px 16px;display:flex;align-items:center;gap:12px}.jm-aging-bucket-label--warn{background:var(--jm-warn-bg);border-top:1px solid var(--jm-warn-border);border-bottom:1px solid var(--jm-warn-border);color:var(--jm-warn-fg)}.jm-aging-bucket-label--danger{background:color-mix(in srgb,var(--jm-danger) 8%,transparent);border-top:1px solid color-mix(in srgb,var(--jm-danger) 25%,transparent);border-bottom:1px solid color-mix(in srgb,var(--jm-danger) 25%,transparent);color:var(--jm-danger)}.jm-aging-bucket-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}.jm-aging-bucket-total{font-size:12px;color:var(--jm-text-muted)}.jm-aging-credit-flag{display:inline-block;margin-left:8px;padding:1px 6px;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:.4px;background:var(--jm-warn-bg);border:1px solid var(--jm-warn-border);color:var(--jm-warn-fg)}.jm-report-summary-card{background:var(--jm-surface);border:1px solid var(--jm-border);border-radius:8px;padding:20px 24px;margin-bottom:20px;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px 24px}.jm-report-metric{display:flex;flex-direction:column;gap:4px}.jm-report-metric-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--jm-text-muted)}.jm-report-metric-value{font-size:24px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--jm-text)}.jm-report-metric-value--positive{color:var(--jm-value)}.jm-report-metric-value--negative{color:var(--jm-danger)}.jm-report-metric--internal{border-left:2px solid var(--jm-border);padding-left:12px}@media print{.jm-report-metric--internal{display:none}}.jm-closing-report-wrap{max-width:900px;margin:0 auto;padding:24px;background:var(--jm-surface);border:1px solid var(--jm-border);border-radius:8px}.jm-closing-report-header{display:flex;flex-direction:column;gap:4px;padding-bottom:16px;border-bottom:2px solid var(--jm-border-strong);margin-bottom:20px}.jm-closing-report-title{font-size:18px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--jm-text)}.jm-closing-report-meta{font-size:13px;color:var(--jm-text-muted);display:flex;flex-wrap:wrap;gap:4px 24px}.jm-closing-report-section{margin-bottom:24px}.jm-closing-report-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--jm-text-muted);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--jm-border)}.jm-closing-report-section-body{font-size:13px;color:var(--jm-text);line-height:1.6}.jm-closing-report-photos{display:flex;flex-wrap:wrap;gap:8px}.jm-closing-report-photo{flex:1;min-width:0;max-width:calc(33.33% - 6px);height:120px;object-fit:cover;border-radius:6px;border:1px solid var(--jm-border)}@media print{.jm-header,.jm-subheader,.jm-report-subheader,.jm-closing-report-actions{display:none!important}.jm-closing-report-wrap{max-width:100%;margin:0;padding:0;border:none}.jm-closing-report-section{page-break-inside:avoid}@page{margin:20mm 15mm}}.jm-migration-page{padding:24px;display:flex;flex-direction:column;gap:20px;min-height:0;flex:1}.jm-import-section{background:var(--jm-surface);border:1px solid var(--jm-border);border-radius:8px;overflow:hidden}.jm-import-section-header{padding:12px 16px;border-bottom:1px solid var(--jm-border);display:flex;align-items:center;justify-content:space-between}.jm-import-section-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--jm-text-muted)}.jm-import-section-body{padding:16px}.jm-upload-zone{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px;border:2px dashed var(--jm-border);border-radius:8px;cursor:pointer;background:var(--jm-surface-2);text-align:center;transition:background .15s,border-color .15s;position:relative}.jm-upload-zone:hover,.jm-upload-zone--drag-over{background:var(--jm-accent-soft);border-color:var(--jm-accent)}.jm-upload-icon{color:var(--jm-text-muted)}.jm-upload-label{font-size:14px;font-weight:600;color:var(--jm-accent)}.jm-upload-hint{font-size:12px;color:var(--jm-text-muted)}.jm-upload-input{position:absolute;width:0;height:0;opacity:0}.jm-upload-filename{font-size:13px;color:var(--jm-text);font-weight:500;margin-top:8px}.jm-mapping-preview{margin-top:16px;overflow-x:auto}.jm-import-duplicate-summary{background:var(--jm-warn-bg);border:1px solid var(--jm-warn-border);border-radius:6px;padding:12px 14px;margin-top:12px;display:flex;flex-direction:column;gap:6px}.jm-import-duplicate-count{font-size:13px;font-weight:600;color:var(--jm-warn-fg);display:flex;align-items:center;gap:6px}.jm-import-duplicate-body{font-size:12px;color:var(--jm-warn-fg)}.jm-import-overwrite-label{display:flex;align-items:center;gap:8px;margin-top:12px;font-size:13px;color:var(--jm-text);cursor:pointer}.jm-import-overwrite-checkbox{width:16px;height:16px;cursor:pointer;accent-color:var(--jm-danger)}.jm-import-log-wrap{margin-top:16px;max-height:320px;overflow-y:auto;border:1px solid var(--jm-border);border-radius:6px}.jm-import-log-header{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--jm-text-muted);background:var(--jm-surface-2)}.jm-import-log-row{border-top:1px solid var(--jm-border)}.jm-import-log-row--error{background:color-mix(in srgb,var(--jm-danger) 6%,transparent)}.jm-import-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;padding:2px 7px;border-radius:20px;white-space:nowrap}.jm-import-badge--success{background:color-mix(in srgb,var(--jm-success) 15%,transparent);color:var(--jm-success)}.jm-import-badge--warn{background:var(--jm-warn-bg);color:var(--jm-warn-fg)}.jm-import-badge--danger{background:color-mix(in srgb,var(--jm-danger) 12%,transparent);color:var(--jm-danger)}.jm-import-summary{background:var(--jm-surface-2);border:1px solid var(--jm-border);border-radius:6px;padding:10px 14px;margin-bottom:12px;font-size:13px;color:var(--jm-text)}.jm-import-progress{font-size:12px;color:var(--jm-text-muted);margin-top:8px}.jm-import-footer{display:flex;align-items:center;justify-content:flex-end;padding:12px 16px;border-top:1px solid var(--jm-border);gap:8px}.jm-spin{animation:jm-spin-anim .8s linear infinite;display:inline-block;vertical-align:middle}@keyframes jm-spin-anim{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.qe-recompute-spinner{animation:jm-spin-anim .9s linear infinite}.jm-import-detail{font-size:12px;color:var(--jm-danger);padding:4px 8px 4px 16px}.jm-table-empty{padding:16px;font-size:13px;color:var(--jm-text-muted);text-align:center}.jm-subheader-desc{font-size:13px;color:var(--jm-text-muted);margin:0}.jm-table-th-inner{display:flex;flex-direction:column;gap:4px}.jm-input-hint{font-size:12px;color:var(--jm-text-muted);margin-top:4px;display:block}.jm-readout{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--jm-surface-2);border:1px solid var(--jm-border);border-radius:6px;font-size:13px;color:var(--jm-text);font-variant-numeric:tabular-nums}.jm-readout--muted{color:var(--jm-text-muted)}.jm-readout-label{font-size:11px;font-weight:600;color:var(--jm-text-muted);letter-spacing:.4px;text-transform:uppercase}.jm-readout-value{font-weight:600;margin-left:auto}.jm-import-log-row--clickable{cursor:pointer}.qe-labor-cost-row{display:inline-flex;align-items:center;gap:6px;margin-top:6px;padding:4px 10px;font-size:12px;color:var(--jm-text-muted);background:var(--jm-surface-2);border:1px dashed var(--jm-border);border-radius:6px;font-style:italic}.qe-labor-cost-row b{color:var(--jm-text);font-style:normal}.qe-labor-cost-row__icon{color:var(--jm-text-muted);flex-shrink:0}.qe-labor-line-hint{display:block;margin-top:2px;font-size:11px;color:var(--jm-text-muted);font-style:italic;line-height:1.3}@media print{.qe-labor-cost-row{display:none!important}}.jm-form-label{display:block;margin-bottom:4px;font-size:11px;font-weight:700;color:var(--jm-text-muted);text-transform:uppercase;letter-spacing:.4px}.jm-form-label-required-marker{color:var(--jm-danger)}.jm-form-card{background:var(--jm-surface-2);border:1px solid var(--jm-border);border-radius:8px;padding:12px;margin-bottom:10px}.jm-form-actions{display:flex;gap:8px;margin-top:6px}.jm-form-error{color:var(--jm-danger);font-size:12px;margin:0 0 6px}.jm-form-textarea{resize:vertical}.jm-form-btn{padding:6px 14px;font-size:13px}.jm-form-btn:disabled{opacity:.38;cursor:not-allowed}.jm-order-page{background:var(--jm-surface);color:var(--jm-text);border:1px solid var(--jm-border);border-radius:6px;padding:18px 22px 28px;margin:0 auto 18px;max-width:980px;display:flex;flex-direction:column;gap:10px;position:relative;box-shadow:0 1px 3px var(--jm-shadow)}.jm-order-toolbar{display:flex;justify-content:flex-end;align-items:center;gap:8px;max-width:980px;margin:0 auto 8px;padding:0 4px}.jm-order-page-break{height:1px;margin:8px 0;background:var(--jm-border);border-top:1px dashed var(--jm-border-strong)}.jm-order-page-num{text-align:right;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--jm-text-muted);font-weight:600;margin-top:4px}.jm-order-hdr-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding-bottom:8px;border-bottom:1.5px solid var(--jm-border-strong)}.jm-order-hdr-strip .jm-order-field-row{display:flex;flex-direction:column;gap:3px}.jm-order-section-h{font-weight:700;text-align:center;font-size:15px;letter-spacing:.04em;text-transform:uppercase;margin:6px 0 4px;color:var(--jm-text);border-bottom:1px solid var(--jm-border-strong);padding-bottom:3px}.jm-order-sub-h{font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.04em;margin:6px 0 4px;color:var(--jm-text)}.jm-order-panel{padding-top:4px}.jm-order-panel+.jm-order-panel{border-top:1px solid var(--jm-border-strong);margin-top:6px;padding-top:8px}.jm-order-p1-top{display:grid;grid-template-columns:minmax(220px,1fr) 1fr;gap:18px;align-items:start;margin-top:6px}.jm-order-meas{display:flex;flex-direction:column;gap:4px}.jm-order-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:6px 18px}.jm-order-grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px 14px}.jm-order-notes-sign{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:8px}.jm-order-field-row{display:flex;align-items:center;gap:8px;margin-bottom:2px}.jm-order-field-row>.jm-order-label{min-width:110px;font-size:12px;font-weight:600;color:var(--jm-text)}.jm-order-field-row>.jm-order-label b{display:inline-block;min-width:12px;font-weight:700}.jm-order-field-row--stack{flex-direction:column;align-items:stretch;gap:3px}.jm-order-input{background:var(--jm-surface-2);border:1px solid var(--jm-border-strong);border-radius:3px;color:var(--jm-text);font:inherit;font-size:12.5px;padding:4px 6px;height:26px;min-width:60px;flex:1;outline:none}.jm-order-input:focus-visible{border-color:var(--jm-accent);box-shadow:0 0 0 2px var(--jm-accent-soft)}.jm-order-input--mini{height:22px;font-size:11.5px;min-width:60px}.jm-order-input--wide{min-width:160px}textarea.jm-order-input{height:auto;resize:vertical;padding:6px 8px}.jm-order-svg-wrap{width:100%;display:flex;justify-content:center}.jm-door-measurement-svg{width:100%;height:auto;max-width:360px;display:block}.jm-order-radio-group{border:1px solid var(--jm-border);border-radius:4px;padding:6px 10px 8px;margin:0;background:var(--jm-surface)}.jm-order-group-legend{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--jm-text);padding:0 4px}.jm-order-options-row{display:flex;flex-wrap:wrap;gap:4px 12px;margin-top:2px}.jm-order-cb{display:inline-flex;align-items:center;gap:6px;cursor:pointer;min-height:32px;font-size:12px;color:var(--jm-text);padding:2px;border-radius:3px}.jm-order-cb:focus-within{outline:2px solid var(--jm-accent);outline-offset:2px}.jm-order-cb input[type=radio],.jm-order-cb input[type=checkbox]{accent-color:var(--jm-accent);width:14px;height:14px;cursor:pointer;margin:0}.jm-order-accessory-cell{display:flex;align-items:center;gap:8px;min-height:32px}.jm-order-accessory-cell>.jm-order-cb{flex:1;min-width:0}.jm-order-accessory-cell>.jm-order-input{flex:0 0 90px}.jm-order-sign-stack{display:flex;flex-direction:column;gap:8px}.jm-order-sign-note{font-size:10.5px;color:var(--jm-text-muted);font-style:italic}@media (max-width: 720px){.jm-order-p1-top,.jm-order-grid-2,.jm-order-grid-3,.jm-order-notes-sign,.jm-order-hdr-strip{grid-template-columns:1fr}}.jm-modal-header{display:flex;align-items:center;gap:12px;height:60px;padding:0 24px;flex-shrink:0;background:var(--jm-header-bg);border-bottom:1px solid rgba(255,255,255,.08)}.jm-modal-header-logo{height:24px;width:auto;display:block;flex-shrink:0}.jm-modal-header-title{color:var(--jm-header-fg);font-weight:700;font-size:16px;white-space:nowrap;flex-shrink:0}.jm-modal-header-sub{color:#ffffff8c;font-size:13px;white-space:nowrap;flex:0 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis}.jm-modal-header-value{color:var(--jm-success);font-size:13px;font-weight:600;flex-shrink:0}.jm-modal-header-actions{margin-left:auto;display:flex;align-items:center;gap:8px;flex-shrink:0}.jm-modal-header .jm-btn-ghost{color:#ffffffd1;border-color:#ffffff2e}.jm-modal-header .jm-btn-ghost:hover{background:#ffffff1a;color:#fff}.jm-modal-header .jm-btn-ghost--danger{color:var(--jm-danger);border-color:#e31e2480}.jm-modal-header .jm-btn-ghost--danger:hover{background:#e31e241f;color:var(--jm-danger)}.jm-order-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 20px 12px 84px;background:var(--jm-header-bg);border-bottom:1px solid rgba(255,255,255,.08);box-shadow:0 1px 2px var(--jm-shadow)}.jm-order-header-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.jm-order-header-title-block{display:flex;align-items:center;gap:8px;min-width:0}.jm-order-header-title{font-size:15px;font-weight:600;color:var(--jm-header-fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:320px}.jm-order-header-rename-input{font-size:14px;padding:4px 8px;border:1px solid var(--jm-accent);border-radius:6px;background:var(--jm-surface);color:var(--jm-text);font-family:inherit;outline:none;width:240px}.jm-order-header-rename-input:focus-visible{outline:2px solid var(--jm-accent);outline-offset:1px}.jm-order-header-icon-btn{width:32px;height:32px;min-width:32px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid rgba(255,255,255,.18);border-radius:6px;color:#ffffffb8;cursor:pointer;font-family:inherit;padding:0}.jm-order-header-icon-btn:hover{background:#ffffff1a;color:var(--jm-header-fg)}.jm-order-header-icon-btn:focus-visible{outline:2px solid var(--jm-accent);outline-offset:1px}.jm-order-header-icon-btn:disabled{opacity:.38;cursor:not-allowed}.jm-order-header-logo{height:32px;width:auto;flex-shrink:0}.jm-order-header-status{font-size:11px;color:#fff9;text-transform:uppercase;letter-spacing:.4px;flex-shrink:0;min-width:80px;text-align:right}.jm-order-header-status--saved{color:var(--jm-success)}.jm-order-header-status--error{color:var(--jm-danger)}.jm-order-body{padding:24px;background:var(--jm-bg);min-height:calc(100vh - 56px)}.orders-form-badge{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.4px;padding:3px 9px;border-radius:20px;background:var(--jm-accent-soft);color:var(--jm-accent);font-variant-numeric:tabular-nums;white-space:nowrap}.jm-engraving-section{margin-top:8px}.jm-engraving-header{display:flex;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap}.jm-engraving-count-label{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--jm-text)}.jm-engraving-count-input{width:72px;height:28px;padding:4px 8px;background:var(--jm-surface-2);border:1px solid var(--jm-border-strong);border-radius:3px;color:var(--jm-text);font:inherit;font-size:13px;outline:none}.jm-engraving-count-input:focus-visible{border-color:var(--jm-accent);box-shadow:0 0 0 2px var(--jm-accent-soft)}.jm-engraving-cap-hint{font-size:11px;font-style:italic}.jm-engraving-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:6px 16px}.jm-engraving-row{display:flex;align-items:center;gap:8px;min-height:36px}.jm-engraving-row-num{color:var(--jm-text-muted);min-width:28px;font-variant-numeric:tabular-nums;font-size:12px}.jm-engraving-input{padding:4px 8px;height:28px;border:1px solid var(--jm-border);border-radius:4px;background:var(--jm-surface);color:var(--jm-text);font:inherit;font-size:12.5px;outline:none}.jm-engraving-input:focus-visible{border-color:var(--jm-accent);box-shadow:0 0 0 2px var(--jm-accent-soft)}.jm-engraving-input-apt{width:88px;flex:0 0 88px}.jm-engraving-input-label{flex:1;min-width:0}.jm-order-inline-text{margin-left:6px;height:24px;padding:2px 6px;background:var(--jm-surface-2);border:1px solid var(--jm-border-strong);border-radius:3px;color:var(--jm-text);font:inherit;font-size:12px;outline:none;min-width:90px;max-width:200px}.jm-order-inline-text:focus-visible{border-color:var(--jm-accent);box-shadow:0 0 0 2px var(--jm-accent-soft)}.jm-order-page-footer-hint{margin-top:8px;font-size:11px;color:var(--jm-text-muted);font-style:italic;text-align:center}.jm-order-cutout-box{display:flex;flex-direction:column;gap:6px}.jm-order-cutout-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}@media (max-width: 720px){.jm-engraving-list{grid-template-columns:1fr}}.jm-orders-panel-error{color:var(--jm-danger);font-size:12px;margin:0 0 8px}.jm-orders-dropdown-wrap{position:relative;margin-bottom:12px}.jm-orders-dropdown-trigger{display:inline-flex;align-items:center;gap:6px;font-size:12px;min-height:32px}.jm-orders-dropdown-caret{font-size:10px;opacity:.7}.orders-dropdown-menu{position:absolute;top:100%;left:0;margin-top:4px;background:var(--jm-surface);border:1px solid var(--jm-border);border-radius:6px;box-shadow:0 4px 12px var(--jm-shadow);min-width:180px;z-index:10}.jm-orders-dropdown-item{display:flex;align-items:center;gap:8px;padding:8px 12px;width:100%;text-align:left;border:none;background:transparent;font-size:13px;cursor:pointer;color:var(--jm-text)}.jm-orders-dropdown-item:hover:not(:disabled),.jm-orders-dropdown-item:focus-visible{background:var(--jm-surface-2)}.jm-orders-dropdown-item:disabled{opacity:.38;cursor:not-allowed}.jm-orders-empty-hint{font-size:13px;color:var(--jm-text-muted);margin:0 0 8px}.jm-orders-row{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--jm-border)}.jm-orders-row-rename-input{flex:1;padding:3px 8px;border:1px solid var(--jm-border-strong);border-radius:4px;font-size:13px;color:var(--jm-text);background:var(--jm-surface)}.jm-orders-row-name{flex:1;font-size:13px;color:var(--jm-text)}.jm-orders-row-open{padding:3px 10px;font-size:12px}.jm-orders-row-delete-confirm{display:flex;gap:4px;align-items:center;font-size:12px}.jm-orders-row-delete-confirm-prompt{color:var(--jm-text-muted)}.jm-orders-row-delete-yes{font-size:12px}.jm-orders-row-delete-no{padding:2px 6px;font-size:12px}.jm-order-route-error{padding:40px;color:var(--jm-danger)}.jm-order-route-loading{padding:40px;color:var(--jm-text-muted)}.jm-order-route-back{margin-bottom:16px;padding:6px 12px;background:transparent;border:1px solid var(--jm-border);border-radius:6px;color:var(--jm-text);cursor:pointer;font-family:inherit}.jm-order-route-back:hover,.jm-order-route-back:focus-visible{background:var(--jm-surface-2)}.jm-tax-row{display:flex;flex-wrap:wrap;align-items:flex-end;gap:16px;margin-bottom:6px}.jm-tax-row-rate{flex:1 1 200px;min-width:0;max-width:320px}.jm-tax-row-status{flex:0 0 auto;display:flex;flex-direction:column;gap:6px;min-width:0}.jm-tax-row-label{font-size:12px;font-weight:600;color:var(--jm-text-muted);display:block;margin-bottom:4px}.jm-tax-row-select{padding:6px 10px;border:1px solid var(--jm-border-strong);border-radius:6px;font-size:14px;width:100%;color:var(--jm-text);background:var(--jm-surface);font-family:inherit}.jm-tax-row-select:focus-visible{outline:2px solid var(--jm-accent);outline-offset:2px;border-color:var(--jm-accent)}.jm-tax-row-helper{font-size:11px;color:var(--jm-text-muted);margin:6px 0 0;line-height:1.4;font-style:italic}.jm-tax-row-exempt-btn{padding:8px 14px;border-radius:6px;border:1px solid var(--jm-accent);background:transparent;color:var(--jm-accent);cursor:pointer;font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:6px;min-height:32px;font-family:inherit}.jm-tax-row-exempt-btn:hover{background:var(--jm-accent-soft)}.jm-tax-row-exempt-btn:focus-visible{outline:2px solid var(--jm-accent);outline-offset:2px}.jm-prod-autocomplete{position:relative;width:100%}.jm-prod-autocomplete-input{padding-right:22px}.jm-prod-autocomplete-input:focus-visible{outline:2px solid var(--jm-accent);outline-offset:1px}.jm-prod-autocomplete-icon{position:absolute;right:6px;top:50%;transform:translateY(-50%);color:var(--jm-text-muted);pointer-events:none}.jm-prod-autocomplete-results{position:absolute;top:calc(100% + 2px);left:0;min-width:520px;max-width:720px;z-index:1200;max-height:360px;overflow-y:auto;margin:0;padding:4px 0;list-style:none;background:var(--jm-surface);color:var(--jm-text);border:1px solid var(--jm-border-strong);border-radius:6px;box-shadow:0 4px 14px var(--jm-shadow);font-size:13px}.jm-prod-autocomplete-row{display:flex;align-items:baseline;gap:12px;padding:8px 12px;cursor:pointer;min-height:36px}.jm-prod-autocomplete-row--active{background:var(--jm-accent-soft)}.jm-prod-autocomplete-row--empty{cursor:default;color:var(--jm-text-muted);font-style:italic}.jm-prod-autocomplete-name{font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.jm-prod-autocomplete-part{color:var(--jm-text-muted);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:11px;white-space:nowrap}.jm-addr-autocomplete{position:relative;width:100%}.jm-addr-autocomplete-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--jm-text-muted);pointer-events:none;z-index:1}.jm-addr-autocomplete-input:focus-visible{outline:2px solid var(--jm-accent);outline-offset:1px}.jm-addr-autocomplete-results{position:absolute;top:calc(100% + 2px);left:0;right:0;z-index:1200;max-height:320px;overflow-y:auto;margin:0;padding:4px 0;list-style:none;background:var(--jm-surface);color:var(--jm-text);border:1px solid var(--jm-border-strong);border-radius:8px;box-shadow:0 8px 24px var(--jm-shadow);font-size:13px}.jm-addr-autocomplete-row{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;min-height:36px}.jm-addr-autocomplete-row--active{background:var(--jm-accent-soft)}.jm-addr-autocomplete-row-icon{color:var(--jm-text-muted);flex-shrink:0}.jm-addr-autocomplete-row-text{display:flex;flex-direction:column;min-width:0}.jm-addr-autocomplete-row-main{font-weight:600;color:var(--jm-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.jm-addr-autocomplete-row-sub{font-size:11px;color:var(--jm-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.jm-project-tabs{display:flex;align-items:stretch;gap:4px;border-bottom:1px solid var(--jm-border);margin:-4px 0 20px;position:sticky;top:-24px;background:var(--jm-surface);z-index:2;padding-top:4px}.jm-doc-divider{border:none;border-top:2px solid var(--jm-border-strong);margin:28px 0}.jm-project-tab{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--jm-text-muted);cursor:pointer;font-size:13px;font-weight:500;padding:10px 14px;min-height:36px;border-radius:6px 6px 0 0;transition:color .12s ease,background .12s ease,border-color .12s ease}.jm-project-tab:hover{color:var(--jm-text);background:var(--jm-surface-2)}.jm-project-tab:focus-visible{outline:2px solid var(--jm-accent);outline-offset:2px}.jm-project-tab--active{color:var(--jm-text);border-bottom-color:var(--jm-accent);font-weight:600}.jm-project-tab--active:hover{background:transparent}.jm-accounts-shell{display:grid;grid-template-columns:240px 1fr;gap:24px;padding:24px;max-width:1600px;margin:0 auto;align-items:start}.jm-filters-side{position:sticky;top:80px;align-self:start;background:var(--jm-surface);border:1px solid var(--jm-border);border-radius:12px;padding:14px 14px 8px;font-size:13px;max-height:calc(100vh - 100px);overflow-y:auto}.jm-filters-side-header{display:flex;align-items:center;margin-bottom:10px}.jm-filters-side-title{font-size:11px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;color:var(--jm-text-muted)}.jm-filters-side-clear{margin-left:auto;display:inline-flex;align-items:center;gap:4px;background:transparent;border:none;color:var(--jm-accent);font-size:11px;font-weight:600;cursor:pointer;padding:2px 6px;border-radius:6px}.jm-filters-side-clear:hover{background:var(--jm-accent-soft)}.jm-filters-side-clear:focus-visible{outline:2px solid var(--jm-accent);outline-offset:2px}.jm-filters-side-group{margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--jm-border)}.jm-filters-side-group:last-child{border-bottom:none;margin-bottom:0}.jm-filters-side-group-label{font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--jm-text-muted);margin-bottom:8px}.jm-filters-side-row{display:flex;align-items:center;gap:8px;padding:4px 6px;border-radius:6px;cursor:pointer;color:var(--jm-text);font-size:13px;-webkit-user-select:none;user-select:none}.jm-filters-side-row:hover{background:var(--jm-surface-2)}.jm-filters-side-row--active{color:var(--jm-text);font-weight:600}.jm-filters-side-row input[type=radio]{accent-color:var(--jm-accent);margin:0}.jm-filters-side-select{width:100%;padding:6px 8px;background:var(--jm-surface);color:var(--jm-text);border:1px solid var(--jm-border-strong);border-radius:6px;font-size:13px;font-family:inherit}.jm-filters-side-select:focus-visible{outline:2px solid var(--jm-accent);outline-offset:-1px}.jm-accounts-main{min-width:0}.jm-accounts-stats{font-size:13px;color:var(--jm-text-muted);margin-bottom:12px}.jm-accounts-empty{text-align:center;padding:80px 24px;color:var(--jm-text-muted);display:flex;flex-direction:column;align-items:center;gap:12px}.jm-accounts-empty-title{font-size:18px;font-weight:600;color:var(--jm-text);margin:0}.jm-accounts-empty-body{font-size:14px;margin:0 0 8px}.jm-accounts-list{background:var(--jm-surface);border:1px solid var(--jm-border);border-radius:12px;overflow:hidden}.jm-accounts-list-head,.jm-accounts-row{display:grid;grid-template-columns:2.2fr 2fr .8fr 1.1fr 1.4fr;align-items:center;gap:16px;padding:10px 16px}.jm-accounts-list-head{background:var(--jm-surface-2);border-bottom:1px solid var(--jm-border);font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--jm-text-muted)}.jm-accounts-row{background:transparent;border:none;border-top:1px solid var(--jm-border);text-align:left;font:inherit;color:var(--jm-text);cursor:pointer;padding-top:14px;padding-bottom:14px}.jm-accounts-row:first-of-type{border-top:none}.jm-accounts-row:hover{background:var(--jm-surface-2)}.jm-accounts-row:focus-visible{outline:2px solid var(--jm-accent);outline-offset:-2px}.jm-accounts-col-name{display:flex;align-items:center;gap:12px;min-width:0}.jm-accounts-avatar{width:36px;height:36px;border-radius:8px;background:var(--jm-accent-soft);color:var(--jm-accent);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.jm-accounts-avatar--site{background:var(--jm-surface-2);color:var(--jm-text-muted);border:1px solid var(--jm-border)}.jm-accounts-name-block{display:flex;flex-direction:column;gap:2px;min-width:0}.jm-accounts-company{font-size:14px;font-weight:600;color:var(--jm-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.jm-accounts-parent{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--jm-accent);font-weight:600}.jm-accounts-col-contact{display:flex;flex-direction:column;gap:3px;font-size:12px;color:var(--jm-text-muted);min-width:0}.jm-accounts-contact-name{color:var(--jm-text);font-weight:500;font-size:13px}.jm-accounts-contact-line{display:inline-flex;align-items:center;gap:6px;min-width:0}.jm-accounts-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.jm-accounts-muted{color:var(--jm-text-muted)}.jm-accounts-col-projects{display:flex;align-items:baseline;gap:6px}.jm-accounts-projects-count{font-size:16px;font-weight:700;color:var(--jm-text);font-variant-numeric:tabular-nums}.jm-accounts-projects-label{font-size:11px;color:var(--jm-text-muted)}.jm-accounts-col-value{text-align:right}.jm-accounts-total{font-size:14px;font-weight:700;color:var(--jm-accent);font-variant-numeric:tabular-nums}.jm-accounts-col-meta{display:flex;flex-wrap:wrap;gap:4px;justify-content:flex-end}.jm-accounts-tag{font-size:10px;font-weight:600;padding:2px 7px;border-radius:6px;white-space:nowrap}.jm-accounts-tag--accent{background:var(--jm-accent-soft);color:var(--jm-accent)}.jm-accounts-tag--muted{background:var(--jm-surface-2);color:var(--jm-text-muted);border:1px solid var(--jm-border)}.jm-accounts-tag--success{background:var(--jm-success-soft, rgba(16, 185, 129, .15));color:var(--jm-success, #10b981)}@media (max-width: 960px){.jm-accounts-shell{grid-template-columns:1fr}.jm-filters-side{position:static;max-height:none}.jm-accounts-list-head,.jm-accounts-row{grid-template-columns:2fr 1.5fr .8fr 1fr}.jm-accounts-col-meta{display:none}}.jm-date-presets{display:flex;flex-wrap:wrap;gap:6px;padding:8px 24px 12px;align-items:center}.jm-date-preset{display:inline-flex;align-items:center;padding:5px 12px;border-radius:999px;background:var(--jm-surface);border:1px solid var(--jm-border-strong);color:var(--jm-text-muted);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;transition:background .12s,color .12s,border-color .12s;min-height:28px}.jm-date-preset:hover{background:var(--jm-surface-2);color:var(--jm-text)}.jm-date-preset:focus-visible{outline:2px solid var(--jm-accent);outline-offset:2px}.jm-date-preset--active{background:var(--jm-accent);color:var(--jm-accent-fg);border-color:var(--jm-accent)}.jm-date-preset--active:hover{background:var(--jm-accent);color:var(--jm-accent-fg)}.jm-date-preset--current-quarter:not(.jm-date-preset--active){border-color:var(--jm-accent);color:var(--jm-accent)}.jm-order-terms-h{font-weight:700;font-size:12px;margin:8px 0 4px;color:var(--jm-text)}.jm-order-terms p{font-size:11px;line-height:1.45;color:var(--jm-text);margin:0 0 6px}.jm-order-terms-foot{margin-top:10px;font-size:11px;color:var(--jm-text)}.jm-order-terms-ack{margin-top:8px;display:inline-flex;align-items:center;gap:6px}.jm-order-state-zip{display:flex;gap:6px}.jm-order-zone-table{width:100%;border-collapse:collapse;margin-top:4px;table-layout:auto;font-size:12px}.jm-order-zone-table th{background:var(--jm-surface-2);color:var(--jm-text);font-weight:700;text-align:left;padding:4px 6px;border-bottom:1px solid var(--jm-border);font-size:11px;text-transform:uppercase;letter-spacing:.04em}.jm-order-zone-table td{padding:3px 4px;border-bottom:1px solid var(--jm-border);vertical-align:middle}.jm-order-zone-th-num{width:60px}.jm-order-zone-th-verify{width:86px;text-align:center}.jm-order-zone-th-del{width:36px;text-align:center}.jm-order-zone-idx{font-weight:700;text-align:center;color:var(--jm-text-muted)}.jm-order-zone-verify{display:inline-flex;gap:8px}.jm-order-zone-actions{display:flex;align-items:center;gap:12px;margin-top:8px}.jm-order-zone-count{font-size:11px;color:var(--jm-text-muted)}.jm-diary-wrap{display:flex;flex-direction:column;height:100%}.jm-diary-toolbar{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:12px}.jm-diary-add-wrap{position:relative}.jm-diary-add-trigger{display:inline-flex;align-items:center;gap:6px;font-size:12px;min-height:32px;padding:4px 10px}.jm-diary-add-menu{position:absolute;top:100%;right:0;margin-top:4px;background:var(--jm-surface);border:1px solid var(--jm-border);border-radius:8px;box-shadow:0 6px 16px var(--jm-shadow);min-width:240px;padding:4px 0;z-index:30}.jm-diary-add-group-label{display:block;padding:6px 12px 4px;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--jm-text-muted)}.jm-diary-add-item{display:flex;align-items:center;gap:8px;padding:7px 12px;width:100%;border:none;background:transparent;text-align:left;font-size:13px;color:var(--jm-text);cursor:pointer;min-height:32px}.jm-diary-add-item:hover:not(:disabled),.jm-diary-add-item:focus-visible{background:var(--jm-surface-2)}.jm-diary-add-item:disabled{opacity:.38;cursor:not-allowed}.jm-diary-add-divider{height:1px;background:var(--jm-border);margin:4px 0}.jm-diary-filter-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.jm-diary-chip{display:inline-flex;align-items:center;gap:4px;border:1px solid var(--jm-border);background:var(--jm-surface);color:var(--jm-text);border-radius:999px;padding:4px 10px;font-size:12px;font-weight:600;cursor:pointer;min-height:28px;font-family:inherit}.jm-diary-chip:hover{background:var(--jm-surface-2)}.jm-diary-chip:focus-visible{outline:2px solid var(--jm-accent);outline-offset:2px}.jm-diary-chip--active{background:var(--jm-accent);color:var(--jm-accent-fg);border-color:var(--jm-accent)}.jm-diary-note-form{display:flex;gap:8px;margin-bottom:14px}.jm-diary-note-input{flex:1;padding:8px 12px;border:1px solid var(--jm-border);border-radius:6px;font-size:14px;color:var(--jm-text);background:var(--jm-surface);font-family:inherit}.jm-diary-note-input:focus-visible{outline:2px solid var(--jm-accent);outline-offset:1px}.jm-diary-entries{flex:1;overflow-y:auto}.jm-diary-entry{display:flex;gap:10px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--jm-border)}.jm-diary-entry-icon{flex-shrink:0;margin-top:2px;color:var(--jm-text-muted);display:inline-flex;align-items:flex-start}.jm-diary-entry-body{flex:1;min-width:0}.jm-diary-entry-meta{font-size:12px;color:var(--jm-text-muted);margin-bottom:4px;display:flex;flex-wrap:wrap;gap:6px}.jm-diary-entry-meta-sep{opacity:.5}.jm-diary-entry-content{font-size:14px;color:var(--jm-text);word-break:break-word}.jm-diary-entry-open{margin-top:6px;display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:var(--jm-accent);background:none;border:none;cursor:pointer;padding:0;font-family:inherit}.jm-diary-entry-open:hover{text-decoration:underline}.jm-diary-attachment-link{font-size:13px;color:var(--jm-accent);display:inline-flex;align-items:center;gap:4px;margin-top:4px}.jm-tax-exempt-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--jm-overlay);z-index:500;display:flex;align-items:center;justify-content:center;padding:24px}.jm-tax-exempt-dialog{background:var(--jm-bg);border-radius:12px;box-shadow:0 20px 60px var(--jm-shadow);width:100%;max-width:560px;max-height:92vh;display:flex;flex-direction:column;border:1px solid var(--jm-border)}.jm-tax-exempt-header{padding:20px 24px;border-bottom:1px solid var(--jm-border);display:flex;align-items:center;gap:12px}.jm-tax-exempt-header-icon{width:36px;height:36px;border-radius:8px;background:var(--jm-accent-soft);color:var(--jm-accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}.jm-tax-exempt-header-text{flex:1;min-width:0}.jm-tax-exempt-title{font-size:16px;font-weight:700;color:var(--jm-text)}.jm-tax-exempt-subtitle{font-size:12px;color:var(--jm-text-muted);margin-top:2px}.jm-tax-exempt-body{padding:24px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:16px}.jm-tax-exempt-req{color:var(--jm-danger)}.jm-tax-exempt-optional{text-transform:none;letter-spacing:0;font-weight:400;color:var(--jm-text-muted)}.jm-tax-exempt-field{width:100%}.jm-tax-exempt-field--textarea{min-height:80px;resize:vertical}.jm-tax-exempt-file-input{display:none}.jm-tax-exempt-file-btn{width:100%;background:var(--jm-surface-2);color:var(--jm-text);border:1px dashed var(--jm-border-strong);border-radius:6px;padding:18px 12px;display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;min-height:36px;transition:opacity .15s}.jm-tax-exempt-file-btn:focus-visible{outline:2px solid var(--jm-accent);outline-offset:1px}.jm-tax-exempt-file-btn:disabled{opacity:.38;cursor:not-allowed}.jm-tax-exempt-file-card{display:flex;align-items:center;gap:10px;background:var(--jm-surface-2);border:1px solid var(--jm-border);border-radius:6px;padding:10px 12px}.jm-tax-exempt-file-meta{flex:1;min-width:0}.jm-tax-exempt-file-name{font-size:13px;color:var(--jm-text);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.jm-tax-exempt-file-size{font-size:11px;color:var(--jm-text-muted)}.jm-tax-exempt-file-change{background:transparent;color:var(--jm-text-muted);border:1px solid var(--jm-border);border-radius:6px;padding:4px 8px;font-size:12px;font-family:inherit;font-weight:600;cursor:pointer;min-height:28px;transition:opacity .15s}.jm-tax-exempt-file-change:focus-visible{outline:2px solid var(--jm-accent);outline-offset:1px}.jm-tax-exempt-file-change:disabled{opacity:.38;cursor:not-allowed}.jm-tax-exempt-file-error{margin-top:8px;font-size:12px;color:var(--jm-warn-fg);background:var(--jm-warn-bg);border:1px solid var(--jm-warn-border);border-radius:6px;padding:6px 10px;display:flex;align-items:center;gap:6px}.jm-tax-exempt-help{font-size:11px;color:var(--jm-text-muted);margin-top:6px;font-style:italic;line-height:1.4}.jm-tax-exempt-server-error{font-size:12px;color:var(--jm-danger);background:var(--jm-danger-bg);border:1px solid var(--jm-danger);border-radius:6px;padding:8px 10px}.jm-tax-exempt-footer{padding:14px 24px;border-top:1px solid var(--jm-border);display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--jm-surface);border-bottom-left-radius:12px;border-bottom-right-radius:12px}.jm-tax-exempt-footer-help{font-size:11px;color:var(--jm-text-muted);flex:1;min-width:0}.jm-tax-exempt-footer-actions{display:flex;gap:8px}.jm-tax-exempt-close,.jm-tax-exempt-cancel,.jm-tax-exempt-save{padding:8px 16px;border-radius:6px;font-size:13px;cursor:pointer;font-family:inherit;font-weight:600;border:none;transition:opacity .15s;min-height:36px}.jm-tax-exempt-close:focus-visible,.jm-tax-exempt-cancel:focus-visible,.jm-tax-exempt-save:focus-visible{outline:2px solid var(--jm-accent);outline-offset:1px}.jm-tax-exempt-close{background:transparent;color:var(--jm-text-muted);border:1px solid var(--jm-border);padding:6px 8px;min-height:32px}.jm-tax-exempt-cancel{background:var(--jm-surface-2);color:var(--jm-text);border:1px solid var(--jm-border-strong);font-weight:500}.jm-tax-exempt-save{background:var(--jm-accent);color:var(--jm-accent-fg)}.jm-tax-exempt-save:disabled{opacity:.38;cursor:not-allowed}.jm-staff-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--jm-overlay);display:flex;align-items:center;justify-content:center;z-index:200}.jm-staff-dialog{background:var(--jm-surface);border-radius:14px;width:440px;max-width:95vw;padding:28px;box-shadow:0 20px 60px var(--jm-shadow);max-height:90vh;overflow-y:auto}.jm-staff-title{font-size:16px;font-weight:700;color:var(--jm-text);margin-bottom:20px}.jm-staff-loading{color:var(--jm-text-muted);font-size:14px;padding:8px 0}.jm-staff-field{margin-bottom:14px}.jm-staff-fieldset{border:none;padding:0;margin:0}.jm-staff-legend{margin-bottom:8px}.jm-staff-radio-group{display:flex;gap:16px}.jm-staff-radio-option{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--jm-text);cursor:pointer}.jm-staff-radio-input{accent-color:var(--jm-accent)}.jm-staff-readout-label{display:block;margin-bottom:4px}.jm-staff-error{color:var(--jm-danger);font-size:13px;margin-bottom:12px}.jm-staff-err-span{display:block;margin-top:4px;font-size:12px;color:var(--jm-danger)}.jm-staff-footer{display:flex;gap:10px;justify-content:space-between;margin-top:24px}.qe-recompute-wrap{margin-top:6px}.qe-recompute-btn{display:inline-flex;align-items:center;gap:5px;width:auto;cursor:pointer}.qe-recompute-btn:focus-visible{outline:2px solid var(--jm-accent);outline-offset:1px}.qe-recompute-btn:disabled{opacity:.38;cursor:not-allowed}.qe-recompute-error{color:var(--jm-danger);font-size:11px;margin-top:4px;max-width:200px}.qe-tax-exempt-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;background:var(--jm-success-soft);color:var(--jm-success);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}.qe-tax-exempt-line{color:var(--jm-text-muted)}.asi-toast-viewport{position:fixed;bottom:20px;right:20px;z-index:2147483000;display:flex;flex-direction:column;gap:10px;max-width:400px;pointer-events:none}.asi-toast{display:flex;align-items:flex-start;gap:10px;min-width:280px;padding:12px 14px;background:var(--jm-surface, #ffffff);color:var(--jm-text, #1a202c);border:1px solid var(--jm-border, #e5e7eb);border-left:4px solid var(--jm-border-strong, #d1d5db);border-radius:8px;box-shadow:0 8px 24px #0000002e;pointer-events:auto;animation:asi-toast-in .16s ease-out}@keyframes asi-toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.asi-toast--success{border-left-color:#10b981}.asi-toast--error{border-left-color:#e31e24}.asi-toast--warn{border-left-color:#f59e0b}.asi-toast--info{border-left-color:#2563eb}.asi-toast-icon{flex-shrink:0;margin-top:1px}.asi-toast--success .asi-toast-icon{color:#10b981}.asi-toast--error .asi-toast-icon{color:#e31e24}.asi-toast--warn .asi-toast-icon{color:#f59e0b}.asi-toast--info .asi-toast-icon{color:#2563eb}.asi-toast-msg{flex:1;font-size:13px;line-height:1.4}.asi-toast-close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;background:none;border:none;border-radius:4px;cursor:pointer;color:var(--jm-text-muted, #6b7280)}.asi-toast-close:hover{background:var(--jm-border, #eceef1)}.asi-toast-close:focus-visible{outline:2px solid var(--jm-accent, #2563eb);outline-offset:1px}:root{--color-navy-900: #070F1C;--color-navy-800: #0D1B2E;--color-navy-700: #1B2A4A;--color-navy-600: #243455;--color-navy-500: #2C3E6A;--color-navy-400: #3D5280;--color-red-700: #9B1419;--color-red-600: #C41A1F;--color-red-500: #E31E24;--color-red-400: #F04448;--color-red-100: #FDE8E8;--color-white: #FFFFFF;--color-gray-50: #F4F5F7;--color-gray-100: #E8EAED;--color-gray-200: #D1D5DB;--color-gray-300: #B0B7C3;--color-gray-400: #9AA3B0;--color-gray-500: #6B7585;--color-gray-600: #4A5568;--color-gray-700: #2D3748;--color-gray-800: #1A202C;--color-black: #000000;--color-success-bg: #0D2B1A;--color-success: #1A7F4B;--color-success-light: #22C55E;--color-warning-bg: #2B1D07;--color-warning: #C77B0A;--color-warning-light: #F59E0B;--color-error-bg: #2B0A0A;--color-error: #E31E24;--color-error-light: #F87171;--color-info-bg: #0D1E2B;--color-info: #0EA5E9;--color-info-light: #38BDF8;--bg-page: var(--color-navy-800);--bg-panel: var(--color-navy-700);--bg-elevated: var(--color-navy-600);--bg-hover: rgba(255, 255, 255, .04);--bg-active: rgba(227, 30, 36, .1);--bg-overlay: rgba(13, 27, 46, .85);--border-default: rgba(255, 255, 255, .08);--border-subtle: rgba(255, 255, 255, .04);--border-accent: var(--color-red-500);--border-strong: rgba(255, 255, 255, .16);--fg-primary: var(--color-white);--fg-secondary: var(--color-gray-400);--fg-muted: var(--color-gray-500);--fg-disabled: var(--color-gray-600);--fg-accent: var(--color-red-500);--fg-on-accent: var(--color-white);--shadow-sm: 0 1px 3px rgba(0,0,0,.2);--shadow-md: 0 4px 16px rgba(0,0,0,.24);--shadow-lg: 0 8px 32px rgba(0,0,0,.32);--shadow-xl: 0 16px 48px rgba(0,0,0,.4);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--space-20: 80px;--radius-none: 0px;--radius-xs: 2px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--transition-fast: .15s cubic-bezier(.2, 0, .2, 1);--transition-base: .2s cubic-bezier(.2, 0, .2, 1);--transition-slow: .3s cubic-bezier(.2, 0, .2, 1);--font-display: "Barlow Condensed", "Arial Narrow", sans-serif;--font-ui: "Barlow", "Arial", sans-serif;--font-mono: "JetBrains Mono", "Courier New", monospace;--text-xs: 11px;--text-sm: 13px;--text-base: 14px;--text-md: 16px;--text-lg: 18px;--text-xl: 22px;--text-2xl: 28px;--text-3xl: 36px;--text-4xl: 48px;--text-5xl: 64px;--text-6xl: 80px;--leading-tight: 1.1;--leading-snug: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.65;--tracking-tight: -.02em;--tracking-normal: 0em;--tracking-wide: .05em;--tracking-wider: .08em;--tracking-widest: .12em}:root[data-asi-theme=light],:root[data-jm-theme=light]{--bg-page: var(--color-gray-50);--bg-panel: var(--color-white);--bg-elevated: var(--color-gray-50);--bg-hover: rgba(0, 0, 0, .03);--bg-active: var(--color-red-100);--bg-overlay: rgba(255, 255, 255, .92);--border-default: var(--color-gray-100);--border-subtle: var(--color-gray-50);--border-strong: var(--color-gray-200);--fg-primary: var(--color-gray-800);--fg-secondary: var(--color-gray-500);--fg-muted: var(--color-gray-400);--fg-disabled: var(--color-gray-300);--shadow-sm: 0 1px 3px rgba(0,0,0,.1);--shadow-md: 0 4px 16px rgba(0,0,0,.1);--shadow-lg: 0 8px 32px rgba(0,0,0,.12)}.asi-app{font-family:var(--font-ui);font-size:var(--text-base);color:var(--fg-primary);-webkit-font-smoothing:antialiased}.asi-app.asi-shell{width:100%;min-height:100vh;display:grid;grid-template-columns:232px 1fr;background:var(--bg-page);overflow:hidden}.asi-app .card{background:var(--bg-panel);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.asi-app .label{font-family:var(--font-ui);font-size:var(--text-xs);font-weight:600;letter-spacing:var(--tracking-widest);text-transform:uppercase;color:var(--fg-muted);white-space:nowrap}.asi-app .h-display{font-family:var(--font-display);font-weight:700;letter-spacing:var(--tracking-tight);line-height:var(--leading-tight);color:var(--fg-primary);white-space:nowrap}.asi-app .mono{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--fg-secondary)}.asi-app .truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.asi-app .nowrap{white-space:nowrap}.asi-app .dot{width:6px;height:6px;border-radius:50%;display:inline-block;flex-shrink:0}.asi-app .scroll::-webkit-scrollbar{width:8px;height:8px}.asi-app .scroll::-webkit-scrollbar-track{background:transparent}.asi-app .scroll::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:4px}.asi-app .scroll::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}.asi-app button:focus-visible,.asi-app a:focus-visible,.asi-app input:focus-visible,.asi-app select:focus-visible,.asi-app textarea:focus-visible{outline:2px solid var(--color-red-500);outline-offset:2px}.asi-app button{font-family:inherit;cursor:pointer}.asi-app button:not(.asi-allow-wrap){white-space:nowrap}button,a,input,select,textarea,label,[role=button],[role=menuitem],[role=tab]{-webkit-app-region:no-drag}:root{--color-navy-900: #070F1C;--color-navy-800: #0D1B2E;--color-navy-700: #1B2A4A;--color-navy-600: #243455;--color-navy-500: #2C3E6A;--color-navy-400: #3D5280;--color-red-700: #9B1419;--color-red-600: #C41A1F;--color-red-500: #E31E24;--color-red-400: #F04448;--color-red-100: #FDE8E8;--color-white: #FFFFFF;--color-gray-50: #F4F5F7;--color-gray-100: #E8EAED;--color-gray-200: #D1D5DB;--color-gray-300: #B0B7C3;--color-gray-400: #9AA3B0;--color-gray-500: #6B7585;--color-gray-600: #4A5568;--color-gray-700: #2D3748;--color-gray-800: #1A202C;--color-black: #000000;--color-success-bg: #0D2B1A;--color-success: #1A7F4B;--color-success-light: #22C55E;--color-warning-bg: #2B1D07;--color-warning: #C77B0A;--color-warning-light: #F59E0B;--color-error-bg: #2B0A0A;--color-error: #E31E24;--color-error-light: #F87171;--color-info-bg: #0D1E2B;--color-info: #0EA5E9;--color-info-light: #38BDF8;--bg-page: var(--color-navy-800);--bg-panel: var(--color-navy-700);--bg-elevated: var(--color-navy-600);--bg-hover: rgba(255, 255, 255, .04);--bg-active: rgba(227, 30, 36, .1);--bg-overlay: rgba(13, 27, 46, .85);--border-default: rgba(255, 255, 255, .08);--border-subtle: rgba(255, 255, 255, .04);--border-accent: var(--color-red-500);--border-strong: rgba(255, 255, 255, .16);--fg-primary: var(--color-white);--fg-secondary: var(--color-gray-400);--fg-muted: var(--color-gray-500);--fg-disabled: var(--color-gray-600);--fg-accent: var(--color-red-500);--fg-on-accent: var(--color-white);--shadow-sm: 0 1px 3px rgba(0,0,0,.2);--shadow-md: 0 4px 16px rgba(0,0,0,.24);--shadow-lg: 0 8px 32px rgba(0,0,0,.32);--shadow-xl: 0 16px 48px rgba(0,0,0,.4);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--space-20: 80px;--radius-none: 0px;--radius-xs: 2px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--transition-fast: .15s cubic-bezier(.2, 0, .2, 1);--transition-base: .2s cubic-bezier(.2, 0, .2, 1);--transition-slow: .3s cubic-bezier(.2, 0, .2, 1);--font-display: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-ui: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: "JetBrains Mono", "Courier New", monospace;--text-xs: 11px;--text-sm: 13px;--text-base: 14px;--text-md: 16px;--text-lg: 18px;--text-xl: 22px;--text-2xl: 28px;--text-3xl: 36px;--text-4xl: 48px;--text-5xl: 64px;--text-6xl: 80px;--leading-tight: 1.1;--leading-snug: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.65;--tracking-tight: -.02em;--tracking-normal: 0em;--tracking-wide: .05em;--tracking-wider: .08em;--tracking-widest: .12em}[data-theme=light],.theme-light,:root[data-jm-theme=light],:root[data-asi-theme=light]{--bg-page: var(--color-gray-50);--bg-panel: var(--color-white);--bg-elevated: var(--color-gray-50);--bg-hover: rgba(0, 0, 0, .03);--bg-active: var(--color-red-100);--bg-overlay: rgba(255, 255, 255, .92);--border-default: var(--color-gray-100);--border-subtle: var(--color-gray-50);--border-strong: var(--color-gray-200);--fg-primary: var(--color-gray-800);--fg-secondary: var(--color-gray-500);--fg-muted: var(--color-gray-400);--fg-disabled: var(--color-gray-300);--shadow-sm: 0 1px 3px rgba(0,0,0,.1);--shadow-md: 0 4px 16px rgba(0,0,0,.1);--shadow-lg: 0 8px 32px rgba(0,0,0,.12)}h1,.h1{font-family:var(--font-display);font-size:var(--text-5xl);font-weight:700;line-height:var(--leading-tight);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--fg-primary)}h2,.h2{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:700;line-height:var(--leading-tight);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--fg-primary)}h3,.h3{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:600;line-height:var(--leading-snug);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--fg-primary)}h4,.h4{font-family:var(--font-ui);font-size:var(--text-lg);font-weight:600;line-height:var(--leading-snug);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--fg-primary)}h5,.h5{font-family:var(--font-ui);font-size:var(--text-md);font-weight:600;line-height:var(--leading-normal);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--fg-secondary)}h6,.h6{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:600;line-height:var(--leading-normal);letter-spacing:var(--tracking-widest);text-transform:uppercase;color:var(--fg-muted)}p,.body{font-family:var(--font-ui);font-size:var(--text-base);font-weight:400;line-height:var(--leading-relaxed);color:var(--fg-secondary)}.body-sm{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:400;line-height:var(--leading-normal);color:var(--fg-secondary)}.label{font-family:var(--font-ui);font-size:var(--text-xs);font-weight:600;letter-spacing:var(--tracking-widest);text-transform:uppercase;color:var(--fg-muted)}code,.mono{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:400;color:var(--fg-accent);background:var(--bg-active);padding:2px 6px;border-radius:var(--radius-xs)}.caption{font-family:var(--font-ui);font-size:var(--text-xs);font-weight:400;line-height:var(--leading-normal);color:var(--fg-muted)}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}body{font-family:var(--font-ui);background:var(--color-navy-900);color:var(--fg-primary);-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}img{display:block;max-width:100%}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:5px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:#ffffff29;background-clip:padding-box;border:2px solid transparent}#root{height:100vh}.app{display:grid;grid-template-rows:56px 1fr;height:100vh;background:var(--bg-page)}.app-bar{display:flex;align-items:center;justify-content:space-between;padding:0 18px;background:var(--bg-panel);border-bottom:1px solid var(--border-default);position:relative;z-index:5}.app-bar-left{display:flex;align-items:center;gap:12px}.app-bar-symbol{height:30px;width:auto}.app-bar-eyebrow{font-size:9px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-muted);line-height:1;margin-bottom:4px}.app-bar-title{font-family:var(--font-display);font-size:18px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-primary);line-height:1}.app-bar-right{display:flex;align-items:center;gap:8px}.app-mode-toggle{display:inline-flex;background:#00000040;border:1px solid var(--border-default);border-radius:4px;padding:2px;margin-right:6px}.app-mode-toggle button{background:transparent;border:none;color:var(--fg-secondary);padding:5px 12px;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;border-radius:3px;transition:all .15s}.app-mode-toggle button.active{background:var(--color-red-500);color:#fff}.app-mode-toggle button:hover:not(.active){color:var(--fg-primary)}.app-btn{display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:7px 14px;border-radius:4px;border:1px solid transparent;transition:all .15s}.app-btn.primary{background:var(--color-red-500);color:#fff;border-color:var(--color-red-500)}.app-btn.primary:hover{background:var(--color-red-600);border-color:var(--color-red-600)}.app-btn.ghost{background:transparent;color:var(--fg-secondary);border-color:var(--border-default)}.app-btn.ghost:hover{color:var(--fg-primary);border-color:var(--border-strong)}.app-body{display:grid;grid-template-columns:minmax(380px,460px) 1fr;min-height:0;overflow:hidden}.app-form .app-body,.app-preview .app-body{grid-template-columns:1fr}.form-pane{display:flex;flex-direction:column;min-height:0;background:var(--bg-page);border-right:1px solid var(--border-default)}.form-pane-head{padding:14px 22px 12px;border-bottom:1px solid var(--border-default);background:var(--bg-page);flex-shrink:0}.form-pane-eyebrow{font-size:9px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--color-red-500);margin-bottom:4px}.form-pane-title{font-family:var(--font-display);font-size:22px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--fg-primary);margin:0}.form-pane-meta{margin-top:6px;font-size:11px;color:var(--fg-muted)}.form-pane-body{flex:1;overflow-y:auto;padding:12px 22px 32px}.form-section{border:1px solid var(--border-default);border-radius:4px;background:var(--bg-panel);margin-bottom:12px;overflow:hidden}.form-section-head{display:flex;align-items:center;gap:8px;padding:10px 14px;cursor:pointer;-webkit-user-select:none;user-select:none;background:#0000001a;transition:background .12s}.form-section-head:hover{background:#0000002e}.form-section.is-open .form-section-head{border-bottom:1px solid var(--border-default)}.form-section-chev{color:var(--fg-muted);font-size:10px;width:12px}.form-section-head h3{margin:0;font-family:var(--font-display);font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-primary)}.form-section-count{font-size:9px;font-weight:600;letter-spacing:.08em;color:var(--fg-muted);background:#ffffff0f;padding:2px 6px;border-radius:2px;margin-left:4px}.form-section-body{padding:16px 14px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-label{display:inline-flex;align-items:center;gap:4px;font-size:9px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-muted)}.form-hint{font-size:10px;color:var(--fg-muted);font-style:italic}.field-tip{position:relative;display:inline-flex;align-items:center;justify-content:center;padding:2px;border-radius:4px;color:var(--fg-muted);cursor:help}.field-tip:hover,.field-tip:focus-visible{color:var(--color-red-500)}.field-tip:focus-visible{outline:2px solid var(--color-red-500);outline-offset:1px}.field-tip-bubble{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);z-index:50;width:max-content;max-width:220px;padding:8px 10px;background:var(--bg-elevated);color:var(--fg-primary);border:1px solid var(--border-strong);border-radius:6px;box-shadow:var(--shadow-lg);font-size:11px;font-weight:500;line-height:1.4;letter-spacing:0;text-transform:none;font-style:normal;text-align:left;white-space:normal;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .12s ease,visibility .12s ease}.field-tip:hover .field-tip-bubble,.field-tip:focus-visible .field-tip-bubble{opacity:1;visibility:visible}.form-input{width:100%;background:var(--bg-page);border:1px solid var(--border-default);color:var(--fg-primary);font-size:12.5px;font-family:var(--font-ui);padding:7px 10px;border-radius:4px;transition:border-color .12s,box-shadow .12s}.form-input:hover{border-color:var(--border-strong)}.form-input:focus{outline:none;border-color:var(--color-red-500);box-shadow:0 0 0 2px #e31e242e}.form-input::placeholder{color:var(--color-gray-500)}.form-textarea{resize:vertical;min-height:60px;line-height:1.45;font-family:var(--font-ui)}.form-select{padding-right:28px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--fg-muted) 50%),linear-gradient(135deg,var(--fg-muted) 50%,transparent 50%);background-position:calc(100% - 14px) center,calc(100% - 9px) center;background-size:5px 5px,5px 5px;background-repeat:no-repeat}.form-check-inline{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-secondary);cursor:pointer}.form-check-inline input{accent-color:var(--color-red-500)}.form-empty{padding:22px;text-align:center;font-size:12px;color:var(--fg-muted);border:1px dashed var(--border-default);border-radius:4px;background:#0000001a}.form-empty strong{color:var(--fg-primary)}.address-block{margin-top:12px;padding:12px;background:#0000002e;border:1px solid var(--border-subtle);border-radius:4px}.address-block-label{font-size:9px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-muted);margin-bottom:10px}.category-card{background:var(--bg-panel);border:1px solid var(--border-default);border-radius:4px;margin-bottom:12px;overflow:hidden}.category-head{display:flex;align-items:center;padding:8px 10px 8px 12px;background:#e31e240d;border-bottom:1px solid var(--border-default);gap:8px}.category-select{background:transparent;border:1px solid transparent;color:var(--fg-primary);font-family:var(--font-display);font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px 8px;border-radius:3px;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;flex:1;min-width:0}.category-select:hover{background:#ffffff0a;border-color:var(--border-default)}.category-subtotal{font-family:var(--font-mono);font-size:11px;color:var(--color-red-400);font-weight:500}.category-actions{display:flex;gap:4px}.category-actions button{background:transparent;border:1px solid var(--border-default);color:var(--fg-muted);width:22px;height:22px;font-size:11px;border-radius:3px;transition:all .12s}.category-actions button:hover{color:var(--fg-primary);border-color:var(--border-strong)}.category-actions button.danger:hover{color:#e31e24;border-color:#e31e2499;background:#e31e2414}.category-items{padding:4px 0}.line-item-empty{padding:14px;text-align:center;font-size:11px;color:var(--fg-muted);font-style:italic}.category-add-item{width:100%;padding:8px;background:transparent;border:none;border-top:1px dashed var(--border-default);color:var(--color-red-400);font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;transition:background .12s}.category-add-item:hover{background:#e31e2414;color:var(--color-red-500)}.line-item{display:flex;flex-direction:column;gap:10px;padding:12px 14px;border-bottom:1px solid var(--border-subtle)}.line-item:last-child{border-bottom:none}.line-item-grid{display:grid;grid-template-columns:60px 1fr 110px 110px;gap:8px;align-items:end}.line-item-total{background:#00000040;border:1px solid var(--border-default);border-radius:4px;padding:7px 10px;font-family:var(--font-mono);font-size:12px;color:var(--fg-primary);text-align:right;font-weight:500}.line-item-recurring{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-secondary);cursor:pointer}.line-item-recurring input{accent-color:var(--color-red-500)}.line-item-remove{display:inline-flex;align-items:center;gap:5px;background:transparent;border:1px solid transparent;color:var(--fg-muted);font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:4px 8px;border-radius:3px;transition:all .12s}.line-item-remove:hover{color:#e31e24;border-color:#e31e2466}.preview-pane{display:flex;flex-direction:column;min-height:0;background:radial-gradient(circle at 50% 0%,rgba(255,255,255,.02),transparent 60%),var(--bg-page)}.preview-toolbar{display:flex;align-items:center;justify-content:space-between;padding:8px 18px;border-bottom:1px solid var(--border-default);background:var(--bg-panel);flex-shrink:0;font-size:11px}.preview-toolbar-meta{color:var(--fg-secondary)}.preview-zoom{display:inline-flex;align-items:center;gap:4px;background:#00000040;border:1px solid var(--border-default);border-radius:4px;padding:2px 4px}.preview-zoom button{background:transparent;border:none;color:var(--fg-secondary);width:22px;height:22px;font-size:13px;border-radius:3px}.preview-zoom button:hover{background:#ffffff0f;color:var(--fg-primary)}.preview-zoom button.reset{width:auto;padding:0 10px;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.preview-zoom span{font-size:11px;font-weight:500;color:var(--fg-primary);min-width:42px;text-align:center}.preview-scroll{flex:1;overflow:auto;padding:28px 32px 60px}.preview-stage{margin:0 auto;width:8.5in;transition:transform .15s}.doc{background:#fff;color:#1a202c;font-family:var(--font-ui);width:8.5in;margin:0 auto;box-shadow:0 24px 60px #00000080,0 2px 4px #0000004d}.doc-page{padding:.55in .6in .7in;min-height:11in;position:relative;display:flex;flex-direction:column}.doc-header{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:14px;border-bottom:2px solid #0D1B2E;margin-bottom:22px}.doc-header-left{flex:0 0 auto}.doc-logo{height:56px;width:auto}.doc-header-right{text-align:right;font-size:9.5px;line-height:1.55;color:#2d3748}.doc-licenses{margin-top:4px;padding-top:4px;border-top:1px solid #E8EAED;font-size:8.5px;color:#6b7585}.doc-title-row{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid #E8EAED}.doc-title{font-family:var(--font-display);font-size:44px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#0d1b2e;margin:0;line-height:1}.doc-title-num{display:flex;align-items:baseline;gap:8px}.doc-title-num-label{font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:#9aa3b0}.doc-title-num-value{font-family:var(--font-mono);font-size:16px;font-weight:500;color:#e31e24;letter-spacing:.04em}.doc-meta{background:#f4f5f7;border-left:3px solid #E31E24;padding:12px 16px;margin-bottom:18px}.doc-meta-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.doc-meta-row+.doc-meta-row{margin-top:12px;padding-top:12px;border-top:1px solid #E8EAED}.doc-meta-label{font-size:8.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#6b7585;margin-bottom:3px}.doc-meta-value{font-size:13px;font-weight:500;color:#0d1b2e;line-height:1.25}.doc-meta-value.strong{font-family:var(--font-display);font-size:18px;font-weight:700;letter-spacing:.02em}.doc-meta-value.mono{font-family:var(--font-mono);font-size:12.5px}.doc-meta-sub{font-size:10px;font-weight:500;color:#6b7585;letter-spacing:.04em}.doc-parties{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:22px}.doc-party{padding:12px 14px;background:#fff;border:1px solid #E8EAED;border-top:2px solid #0D1B2E}.doc-party-label{font-size:8.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#9aa3b0;margin-bottom:6px}.doc-party-name{font-family:var(--font-display);font-size:17px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#0d1b2e;margin-bottom:4px}.doc-party-line{font-size:11px;color:#2d3748;line-height:1.5}.doc-party-line.muted{color:#9aa3b0;font-size:10px}.doc-block{margin-bottom:22px}.doc-section-title{font-family:var(--font-display);font-size:13px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#0d1b2e;margin:0 0 10px;padding-bottom:6px;border-bottom:1px solid #0D1B2E;display:flex;align-items:center}.doc-section-title:before{content:"";display:inline-block;width:8px;height:8px;background:#e31e24;margin-right:8px}.doc-scope-p{font-size:11px;line-height:1.55;color:#2d3748;margin:0 0 8px}.doc-scope-p:last-child{margin-bottom:0}.doc-table{width:100%;border-collapse:collapse;font-size:11px}.doc-table thead th{background:#0d1b2e;color:#fff;font-size:8.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;padding:8px 10px;text-align:left}.doc-table thead th.num{text-align:right}.doc-table-section-head td{background:#f4f5f7;padding:6px 10px;border-top:1px solid #E8EAED;border-bottom:1px solid #E8EAED}.doc-table-section-name{font-family:var(--font-display);font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#0d1b2e}.doc-table-section-total{float:right;font-family:var(--font-mono);font-size:10.5px;font-weight:500;color:#6b7585}.doc-table tbody td{padding:8px 10px;vertical-align:top;border-bottom:1px solid #F4F5F7}.doc-table tbody td.num{text-align:right;white-space:nowrap}.doc-table tbody td.num.mono{font-family:var(--font-mono)}.doc-table-idx{color:#9aa3b0;font-size:10px;font-family:var(--font-mono);width:32px}.doc-item-name{font-weight:600;color:#1a202c;font-size:11.5px;margin-bottom:2px}.doc-item-desc{font-size:10px;color:#6b7585;line-height:1.45}.doc-item-unit{font-size:9px;color:#9aa3b0;text-transform:uppercase;letter-spacing:.08em;margin-top:1px}.doc-item-recurring{display:inline-block;font-size:8.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#e31e24;background:#e31e2414;padding:1px 5px;margin-top:4px;border-radius:2px}.doc-table-empty{text-align:center;color:#9aa3b0;font-style:italic;font-size:10px;padding:8px}.doc-empty{color:#9aa3b0;font-style:italic;font-size:11px;padding:16px;border:1px dashed #E8EAED;text-align:center}.doc-table .strong{color:#0d1b2e;font-weight:600}.muted{color:#9aa3b0;font-style:italic}.doc-totals-wrap{display:flex;justify-content:flex-end;margin-bottom:22px}.doc-totals{width:320px}.doc-totals-row{display:flex;justify-content:space-between;padding:5px 4px;font-size:11.5px;color:#2d3748}.doc-totals-row.sub{font-size:10.5px;color:#6b7585;padding:3px 4px}.doc-totals-row .mono{font-family:var(--font-mono)}.doc-totals-grand{margin-top:4px;padding:10px 12px;background:#0d1b2e;color:#fff;font-family:var(--font-display);font-size:16px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.doc-totals-grand .mono{font-family:var(--font-mono);font-size:18px;color:#fff;letter-spacing:.02em;background:transparent;padding:0}.doc-totals-recurring{margin-top:8px;padding-top:8px;border-top:1px dashed #E8EAED}.doc-notes-payment{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:24px}.doc-mini-title{font-family:var(--font-display);font-size:10.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#0d1b2e;margin:0 0 6px}.doc-notes p{font-size:11px;line-height:1.5;color:#2d3748;margin:0;padding:10px 12px;background:#f4f5f7;border-left:2px solid #9AA3B0}.doc-payment{border:1px solid #E8EAED;padding:10px 12px;background:#fff}.doc-payment-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.doc-payment-grid>div{display:flex;flex-direction:column;gap:2px}.doc-payment-label{font-size:8.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:#9aa3b0}.doc-payment-value{font-size:11.5px;color:#1a202c;font-weight:500}.doc-payment-value.mono{font-family:var(--font-mono);font-size:11px;background:transparent;padding:0;color:#1a202c;align-self:flex-start}.doc-terms-p{font-size:10.5px;line-height:1.55;color:#2d3748;margin:0 0 8px}.doc-signature{margin-top:30px;display:grid;grid-template-columns:2fr 1fr;gap:30px}.doc-signature-block{display:flex;flex-direction:column}.doc-signature-line{height:28px;border-bottom:1.5px solid #0D1B2E}.doc-signature-caption{font-size:9px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#6b7585;margin-top:4px}.doc-annexure-intro{font-size:10.5px;font-style:italic;color:#6b7585;margin:0 0 12px}.doc-annexure-list{list-style:none;counter-reset:annex;padding:0;margin:0}.doc-annexure-list li{counter-increment:annex;padding:8px 0 8px 30px;position:relative;border-bottom:1px solid #F4F5F7}.doc-annexure-list li:before{content:counter(annex) ".";position:absolute;left:0;top:8px;font-family:var(--font-display);font-size:12px;font-weight:700;color:#e31e24}.doc-annexure-title{font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#0d1b2e;margin-bottom:3px}.doc-annexure-body{font-size:10.5px;line-height:1.55;color:#2d3748}.doc-annexure-body strong{color:#0d1b2e}.doc-footer{margin-top:auto;padding-top:16px;border-top:1px solid #E8EAED;font-size:9px;color:#9aa3b0}.doc-footer-line{display:flex;justify-content:space-between;letter-spacing:.08em;text-transform:uppercase;font-weight:600}.doc-page-break-before{break-before:page;page-break-before:always}@page{size:A4;margin:0}@media print{html,body,.doc,.doc *,.doc-header,.doc-table thead th,.doc-table-section-head td,.doc-meta,.inv-meta-left,.inv-balance,.doc-totals-grand,.doc-notes p,.inv-pay-method,.doc-party,.inv-work .doc-scope-p,.doc-item-recurring,.doc-section-title:before{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;color-adjust:exact!important}body{background:#fff!important}.no-print{display:none!important}.app{display:block;height:auto;overflow:visible;background:#fff!important}.app-body{display:block;overflow:visible;background:#fff!important}.form-pane{display:none!important}.preview-pane{background:#fff!important;display:flex!important}.preview-toolbar{display:none!important}.preview-scroll{padding:0;overflow:visible;background:#fff!important}.preview-stage{transform:none!important;width:auto!important}.doc{box-shadow:none!important;width:100%;margin:0}.doc-page{padding:.5in .55in;min-height:0}.doc-table thead{display:table-header-group}.doc-table-section,.doc-table tbody tr,.line-item,.doc-annexure-list li,.doc-meta,.inv-meta,.doc-parties,.doc-party,.doc-totals-wrap,.doc-totals,.doc-notes-payment,.doc-notes,.doc-payment,.inv-pay,.inv-pay-methods,.inv-pay-method,.inv-pay-amount-line,.inv-notes-sign,.inv-signature,.doc-signature,.doc-scope,.doc-block{break-inside:avoid;page-break-inside:avoid}.doc-items{break-inside:auto;page-break-inside:auto}}body.printing .app-form .preview-pane,body.printing .app-preview .form-pane{display:block}.doc-item-cat{font-size:8.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#9aa3b0;margin-top:4px}@media (max-width: 1100px){.app-body{grid-template-columns:1fr}.preview-pane{display:none}.app-preview .preview-pane{display:flex}.app-preview .form-pane{display:none}}.inv-meta{display:grid;grid-template-columns:1fr 220px;gap:14px;margin-bottom:18px;align-items:stretch}.inv-meta-left{background:#f4f5f7;border-left:3px solid #E31E24;padding:12px 16px}.inv-meta-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.inv-meta-row>div{min-width:0}.inv-balance{background:#0d1b2e;color:#fff;padding:14px 16px;display:flex;flex-direction:column;justify-content:center;text-align:right;border-top:3px solid #E31E24}.inv-balance.is-overdue{border-top-color:#e31e24;background:#1a0608}.inv-balance.is-paid{background:#0d2b1a;border-top-color:#1a7f4b}.inv-balance-label{font-size:8.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#fff9;margin-bottom:4px}.inv-balance.is-overdue .inv-balance-label{color:#f87171}.inv-balance.is-paid .inv-balance-label{color:#22c55e}.inv-balance-amount{font-family:var(--font-display);font-size:28px;font-weight:800;letter-spacing:.02em;line-height:1;color:#fff}.inv-balance-meta{margin-top:6px;font-size:9.5px;color:#ffffff8c;letter-spacing:.04em}.inv-work .doc-scope-p{background:#f4f5f7;border-left:2px solid #0D1B2E;padding:10px 14px;margin:0}.inv-work .doc-scope-p+.doc-scope-p{margin-top:6px}.inv-totals-total{border-top:1px solid #E8EAED;padding-top:8px!important;margin-top:4px;font-weight:600;color:#0d1b2e;font-size:12.5px!important}.inv-totals-total .mono{color:#0d1b2e}.inv-pay{margin-bottom:18px}.inv-pay-amount-line{display:flex;align-items:baseline;gap:10px;padding:8px 0 14px;border-bottom:1px solid #E8EAED;margin-bottom:12px}.inv-pay-amount{font-family:var(--font-display);font-size:22px;font-weight:800;color:#e31e24;letter-spacing:.02em}.inv-pay-amount-meta{font-size:11px;color:#6b7585}.inv-pay-methods{display:grid;grid-template-columns:1fr 1fr;gap:14px}.inv-pay-method{border:1px solid #E8EAED;padding:10px 12px;background:#fff}.inv-pay-method-label{font-size:8.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#9aa3b0;margin-bottom:6px}.inv-pay-bank{font-family:var(--font-display);font-size:14px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#0d1b2e;margin-bottom:6px}.inv-pay-row{display:flex;justify-content:space-between;font-size:11px;padding:2px 0;color:#2d3748}.inv-pay-row span:first-child{font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#9aa3b0}.inv-pay-row .mono{font-family:var(--font-mono)}.inv-pay-row-stack{font-size:11px;color:#2d3748;line-height:1.5}.inv-signature-terms{font-size:10px;color:#6b7585;line-height:1.5;margin:14px 0 0}.inv-signature-terms .mono{font-family:var(--font-mono);color:#2d3748}.bld-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0000008c;display:flex;align-items:center;justify-content:center}.bld-root{width:97vw;height:96vh;border-radius:10px;overflow:hidden;box-shadow:0 24px 80px #00000080}.bld-root .app{height:100%}.bld-loading{height:100%;display:flex;align-items:center;justify-content:center;background:var(--color-navy-900);color:var(--color-gray-200);font-size:14px}.bld-status{background:var(--color-navy-700);color:#fff;border:1px solid var(--border-strong);border-radius:4px;padding:5px 8px;font-size:11px;text-transform:capitalize;cursor:pointer}.bld-msg{color:var(--color-success-light);font-size:11px;font-weight:600}.bld-err{color:var(--color-error-light);font-size:11px;font-weight:600;max-width:220px}.bld-field{display:flex;flex-direction:column;gap:6px}.bld-readonly{display:flex;flex-direction:column;gap:12px}.bld-readonly>div>div{color:var(--fg-primary);font-size:13px;margin-top:2px}.bld-add-section{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:5px 10px;border-radius:4px;cursor:pointer;background:#e31e24;color:#fff;border:1px solid #E31E24}.preview-stage{width:8.5in;margin:0 auto}.bld-send-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:60;background:#00000080;display:flex;align-items:center;justify-content:center}.bld-send-dialog{width:420px;max-width:92%;background:var(--color-navy-800);color:var(--color-gray-100);border:1px solid var(--border-strong);border-radius:10px;padding:20px 22px;box-shadow:0 24px 60px #00000080}.bld-send-dialog h3{margin:0 0 14px;font-size:16px;font-weight:700;color:#fff}.bld-send-label{display:block;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-gray-400);margin-bottom:6px}.bld-send-input{width:100%;box-sizing:border-box;padding:9px 11px;font-size:14px;background:var(--color-navy-900);color:#fff;border:1px solid var(--border-strong);border-radius:6px;outline:none}.bld-send-input:focus{border-color:#e31e24}.bld-send-hint{font-size:11px;color:var(--color-gray-500);margin:8px 0 0}.bld-send-err{font-size:12px;color:var(--color-error-light);margin:8px 0 0}.bld-send-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.bld-send-ok{font-size:14px;color:var(--color-success-light);font-weight:600;padding:8px 0 4px}.bld-send-warn{font-size:13px;color:var(--color-warning-light);padding:8px 0;line-height:1.5}.dispatch-page{display:flex;flex-direction:column;height:100%;min-height:0;background:var(--jm-bg)}.dispatch-header{display:flex;align-items:center;gap:12px;padding:12px 18px;border-bottom:1px solid var(--jm-border);flex:0 0 auto}.dispatch-title{font-family:var(--font-display);font-size:18px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--jm-text);margin-right:8px}.dispatch-daynav{display:flex;align-items:center;gap:6px}.dispatch-date{font-size:14px;font-weight:600;color:var(--jm-text);min-width:190px;text-align:center}.dispatch-spacer{flex:1}.dispatch-nav-btn{width:34px;height:34px;border-radius:7px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--jm-surface);color:var(--jm-text);border:1px solid var(--jm-border-strong);cursor:pointer;transition:background .12s,color .12s}.dispatch-nav-btn:hover{background:var(--jm-surface-2)}.dispatch-nav-btn:focus-visible{outline:2px solid var(--color-red-500);outline-offset:2px}.dispatch-body{display:flex;flex:1;min-height:0}.dispatch-board{flex:1;min-width:0;overflow:auto}.dispatch-scroll{display:flex;min-width:max-content}.dispatch-timeaxis{width:56px;flex:0 0 56px}.dispatch-axis-head,.dispatch-col-head{height:40px;position:sticky;top:0;z-index:3;background:var(--jm-surface);border-bottom:1px solid var(--jm-border)}.dispatch-col-head{display:flex;align-items:center;justify-content:center;gap:6px;font-size:12px;font-weight:700;color:var(--jm-text);border-left:1px solid var(--jm-border);padding:0 6px;text-align:center}.dispatch-axis-slot{height:28px;font-size:10px;color:var(--jm-text-muted);text-align:right;padding-right:6px;transform:translateY(-6px)}.dispatch-col-wrap{flex:1 1 0;min-width:150px}.dispatch-col{position:relative}.dispatch-slot{height:28px;border-left:1px solid var(--jm-border);border-bottom:1px solid var(--jm-border-subtle, rgba(127,127,127,.12))}.dispatch-slot.dispatch-slot--hour{border-bottom-color:var(--jm-border)}.dispatch-slot.dispatch-slot--over{background:var(--jm-accent-soft, rgba(59,130,246,.18))}.dispatch-appt{position:absolute;left:3px;right:3px;z-index:2;border-radius:5px;padding:3px 6px;overflow:hidden;cursor:grab;color:#fff;font-size:11px;line-height:1.25;box-shadow:0 1px 2px #0000002e}.dispatch-appt--done{opacity:.5;box-shadow:inset 4px 0 #10b981}.dispatch-appt-title{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dispatch-appt-sub{opacity:.9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dispatch-appt-resize{position:absolute;left:0;right:0;height:7px;cursor:ns-resize;z-index:3}.dispatch-appt-resize--top{top:0}.dispatch-appt-resize--bottom{bottom:0}.dispatch-standby{width:180px;flex:0 0 180px;display:flex;flex-direction:column;border-right:2px solid var(--jm-border)}.dispatch-standby .dispatch-col-head{background:var(--jm-surface)}.dispatch-standby-body{flex:1;overflow:auto;padding:8px;min-height:300px}.dispatch-sidebar{width:300px;flex:0 0 300px;border-left:1px solid var(--jm-border);display:flex;flex-direction:column;min-height:0;background:var(--jm-surface)}.dispatch-sidebar-head{padding:12px 14px 8px;flex:0 0 auto}.dispatch-sidebar-title{font-size:13px;font-weight:700;color:var(--jm-text);margin-bottom:8px}.dispatch-seg{display:flex;border:1px solid var(--jm-border);border-radius:var(--radius-sm);overflow:hidden}.dispatch-seg button{flex:1;padding:6px 8px;font-size:12px;font-weight:600;border:none;background:transparent;color:var(--jm-text-muted);cursor:pointer}.dispatch-seg button.is-active{background:var(--jm-accent, #3b82f6);color:#fff}.dispatch-sidebar-filter{padding:8px 14px 0}.dispatch-sidebar-list{flex:1;overflow:auto;padding:8px 10px 16px}.dispatch-jobcard{border:1px solid var(--jm-border);border-left-width:3px;border-radius:var(--radius-sm);padding:11px 13px;margin-bottom:9px;background:var(--jm-surface);box-shadow:var(--shadow-sm);cursor:grab;-webkit-user-select:none;user-select:none}.dispatch-jobcard:hover{border-color:var(--jm-accent, #3b82f6)}.dispatch-jobcard-title{font-size:13px;font-weight:700;color:var(--jm-text)}.dispatch-jobcard-sub{font-size:11px;color:var(--jm-text-muted);margin-top:2px}.dispatch-jobcard.is-overlay{box-shadow:0 6px 20px #00000047;cursor:grabbing}.dispatch-empty{font-size:12px;color:var(--jm-text-muted);padding:16px 6px;text-align:center}.dispatch-input,.dispatch-select{width:100%;padding:6px 8px;font-size:12px;border-radius:6px;border:1px solid var(--jm-border);background:var(--jm-bg);color:var(--jm-text)}.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}
