:root{--bg-0: #0a0e14;--bg-1: #0f141c;--bg-2: #161c26;--bg-3: #1d2531;--bg-4: #2a3442;--bg-5: #38445a;--border: #283142;--border-light: #3a4660;--text: #e6e8ec;--text-dim: #9aa3b2;--text-mute: #6b7484;--accent: #3ba3ff;--accent-2: #5cdcff;--accent-3: #8b6cff;--warn: #ffb347;--danger: #ff5d5d;--good: #6dd17c;--wire: #ff3a3a;--selection: #ffd84d;--hover: #5cdcff;--grid-minor: #1a2230;--grid-major: #243044;--canvas-bg: #0a0e14;--shadow: 0 4px 16px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .7);--font-mono: ui-monospace, "JetBrains Mono", "SF Mono", Menlo, Consolas, monospace;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:var(--font-sans);font-size:13px;color:var(--text);background:var(--bg-0);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-user-select:none;user-select:none}button{font-family:inherit;font-size:inherit;background:transparent;border:1px solid transparent;color:var(--text);cursor:pointer;padding:4px 8px;border-radius:4px;transition:background .12s,border-color .12s}button:hover{background:var(--bg-3);border-color:var(--border-light)}button:active{background:var(--bg-4)}button:disabled{opacity:.4;cursor:not-allowed}input,select,textarea{font-family:inherit;font-size:inherit;background:var(--bg-1);border:1px solid var(--border);color:var(--text);padding:4px 8px;border-radius:4px;outline:none}input:focus,select:focus,textarea:focus{border-color:var(--accent)}input[type=color]{padding:2px;width:32px;height:24px;cursor:pointer}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-1)}::-webkit-scrollbar-thumb{background:var(--bg-4);border-radius:5px;border:2px solid var(--bg-1)}::-webkit-scrollbar-thumb:hover{background:var(--bg-5)}.app{display:grid;grid-template-rows:32px 40px 1fr 24px;grid-template-columns:220px 1fr 280px;grid-template-areas:"menu menu menu" "ribbon ribbon ribbon" "left main right" "status status status";height:100vh;width:100vw;background:var(--bg-0);color:var(--text)}.menu-bar{grid-area:menu;display:flex;align-items:center;padding:0 12px;background:linear-gradient(180deg,var(--bg-2) 0%,var(--bg-1) 100%);border-bottom:1px solid var(--border);gap:4px;font-size:12px}.menu-brand{font-weight:600;margin-right:16px;display:flex;align-items:center;gap:8px;letter-spacing:.3px}.menu-brand .logo{width:18px;height:18px;background:linear-gradient(135deg,var(--accent),var(--accent-3));border-radius:3px;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff}.menu-item{padding:4px 10px;border-radius:3px;cursor:pointer;position:relative}.menu-item:hover{background:var(--bg-3)}.menu-spacer{flex:1}.menu-info{color:var(--text-mute);font-size:11px;font-family:var(--font-mono)}.ribbon{grid-area:ribbon;display:flex;align-items:center;background:var(--bg-1);border-bottom:1px solid var(--border);padding:0 10px;gap:2px;overflow-x:auto}.ribbon-group{display:flex;align-items:center;border-right:1px solid var(--border);padding:0 6px;gap:0}.ribbon-group:last-child{border-right:none}.ribbon-group-label{display:none}.ribbon-buttons{display:flex;gap:1px}.tool-btn{display:inline-flex;align-items:center;justify-content:center;padding:6px;border-radius:4px;cursor:pointer;background:transparent;border:1px solid transparent;color:var(--text-dim);transition:all .12s}.tool-btn:hover{background:var(--bg-3);color:var(--text)}.tool-btn.active{background:var(--bg-4);color:var(--accent);border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent),0 0 8px #3ba3ff33}.tool-btn .icon{font-size:18px;line-height:1}.tool-btn .label{display:none}.tool-btn-small{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:4px;cursor:pointer;background:transparent;border:1px solid transparent;color:var(--text-dim)}.tool-btn-small:hover{background:var(--bg-3);color:var(--text)}.tool-btn-small.active{background:var(--bg-4);color:var(--accent);border-color:var(--accent)}.left-panel{grid-area:left;background:var(--bg-1);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.right-panel{grid-area:right;background:var(--bg-1);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.main{grid-area:main;position:relative;background:var(--canvas-bg);overflow:hidden;display:flex;flex-direction:column}.status-bar{grid-area:status;background:linear-gradient(180deg,var(--bg-2) 0%,var(--bg-1) 100%);border-top:1px solid var(--border);display:flex;align-items:center;padding:0 10px;font-size:11px;font-family:var(--font-mono);color:var(--text-dim);gap:14px}.status-section{display:flex;align-items:center;gap:6px;padding:0 6px;border-right:1px solid var(--border);height:100%}.status-section:last-child{border-right:none}.status-section.active{color:var(--accent)}.status-spacer{flex:1}.panel-section{display:flex;flex-direction:column;border-bottom:1px solid var(--border);flex-shrink:0}.panel-section.flex{flex:1;overflow:hidden}.panel-header{display:flex;align-items:center;padding:6px 10px;background:var(--bg-2);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);border-bottom:1px solid var(--border)}.panel-header .panel-actions{margin-left:auto;display:flex;gap:2px}.panel-body{flex:1;overflow-y:auto;padding:6px 0}.layer-row{display:flex;align-items:center;padding:3px 8px;cursor:pointer;gap:4px;font-size:12px}.layer-row:hover{background:var(--bg-2)}.layer-row.active{background:var(--bg-3)}.layer-row.active:before{content:"";position:absolute;left:0;width:3px;height:100%;background:var(--accent)}.layer-color{width:14px;height:14px;border-radius:2px;border:1px solid var(--border-light);flex-shrink:0;cursor:pointer}.layer-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.layer-toggle{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-mute)}.layer-toggle:hover{color:var(--text)}.layer-toggle.active{color:var(--accent)}.symbol-categories{display:flex;flex-wrap:wrap;gap:2px;padding:4px 6px;border-bottom:1px solid var(--border);background:var(--bg-2)}.cat-pill{font-size:10px;padding:2px 6px;border-radius:10px;background:var(--bg-3);cursor:pointer;white-space:nowrap;border:1px solid var(--border);color:var(--text-dim)}.cat-pill:hover{background:var(--bg-4);color:var(--text)}.cat-pill.active{background:var(--accent);color:#000;border-color:var(--accent)}.symbol-search{padding:6px;border-bottom:1px solid var(--border)}.symbol-search input{width:100%}.symbol-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4px;padding:6px}.symbol-tile{background:var(--bg-2);border:1px solid var(--border);border-radius:4px;padding:6px;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:grab;transition:all .12s}.symbol-tile:hover{background:var(--bg-3);border-color:var(--accent);transform:translateY(-1px);box-shadow:var(--shadow)}.symbol-tile.active{background:var(--bg-4);border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.symbol-tile-preview{width:56px;height:56px;background:var(--canvas-bg);border-radius:3px;display:flex;align-items:center;justify-content:center}.symbol-tile-name{font-size:10px;color:var(--text-dim);line-height:1.1;height:22px;display:flex;align-items:center;text-align:center;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.prop-row{display:grid;grid-template-columns:90px 1fr;gap:6px;padding:3px 10px;align-items:center}.prop-label{font-size:11px;color:var(--text-dim)}.prop-value input,.prop-value select{width:100%;font-size:12px}.sheet-tabs{display:flex;background:var(--bg-1);border-top:1px solid var(--border);padding:0 4px;height:26px;align-items:stretch;flex-shrink:0}.sheet-tab{display:flex;align-items:center;padding:0 12px;font-size:11px;cursor:pointer;color:var(--text-dim);border-right:1px solid var(--border);gap:6px}.sheet-tab:hover{background:var(--bg-2);color:var(--text)}.sheet-tab.active{background:var(--canvas-bg);color:var(--accent);border-bottom:2px solid var(--accent)}.sheet-tab .num{font-family:var(--font-mono);color:var(--text-mute);font-size:10px}.sheet-tab-add{display:inline-flex;align-items:center;justify-content:center;width:26px;cursor:pointer;color:var(--text-mute);font-size:16px}.sheet-tab-add:hover{color:var(--accent);background:var(--bg-2)}.canvas-container{flex:1;position:relative;overflow:hidden;display:flex}.canvas-2d{flex:1;display:block;cursor:crosshair}.canvas-2d.tool-pan{cursor:grab}.canvas-2d.tool-pan.panning{cursor:grabbing}.canvas-2d.tool-select{cursor:default}.canvas-3d{border-left:1px solid var(--border);background:linear-gradient(180deg,#0c1420,#1a2638);position:relative}.splitter{width:5px;flex-shrink:0;cursor:col-resize;background:var(--border);transition:background .15s;position:relative}.splitter:hover,.splitter:active{background:var(--accent)}.splitter:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:2px;height:30px;background:var(--text-mute);border-radius:1px;opacity:.4}.canvas-3d-overlay{position:absolute;top:8px;left:8px;font-size:10px;color:var(--text-mute);font-family:var(--font-mono);padding:4px 8px;background:#0006;border-radius:3px;pointer-events:none}.canvas-3d-controls{position:absolute;top:8px;right:8px;display:flex;flex-direction:column;gap:4px;z-index:2}.canvas-3d-controls .group{display:flex;gap:1px;background:#0000008c;border-radius:4px;padding:2px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.canvas-3d-controls button{font-family:var(--font-mono);font-size:10px;letter-spacing:.04em;padding:4px 8px;min-width:38px;background:transparent;color:var(--text);border:0;border-radius:3px;cursor:pointer;transition:background .1s}.canvas-3d-controls button:hover{background:#ffffff1a}.canvas-3d-controls button.active{background:var(--accent);color:#0a0e14}.canvas-overlay{position:absolute;top:8px;left:8px;font-size:10px;color:var(--text-mute);font-family:var(--font-mono);padding:4px 8px;background:#00000080;border-radius:3px;pointer-events:none}.coord-readout{position:absolute;top:8px;right:8px;font-family:var(--font-mono);font-size:11px;color:var(--text-dim);background:#0009;padding:4px 8px;border-radius:3px;pointer-events:none;border:1px solid var(--border)}.canvas-text-input{position:absolute;z-index:20;background:#0f141cf2;border:1px solid var(--accent);color:var(--text);font-family:var(--font-sans);font-size:13px;padding:4px 8px;border-radius:3px;outline:none;min-width:120px;box-shadow:0 0 0 2px #3ba3ff40,var(--shadow);caret-color:var(--accent)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--bg-1);border:1px solid var(--border-light);border-radius:6px;box-shadow:var(--shadow-lg);min-width:400px;max-width:80vw;max-height:80vh;display:flex;flex-direction:column}.modal-header{padding:12px 16px;border-bottom:1px solid var(--border);font-weight:600;display:flex;align-items:center}.modal-header .close{margin-left:auto;cursor:pointer;color:var(--text-mute)}.modal-body{padding:16px;overflow:auto}.modal-footer{padding:12px 16px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end}.btn-primary{background:var(--accent);color:#000;border:1px solid var(--accent);padding:6px 14px;font-weight:600}.btn-primary:hover{background:var(--accent-2);border-color:var(--accent-2)}.btn-ghost{background:transparent;border:1px solid var(--border-light)}.bom-table{width:100%;border-collapse:collapse;font-size:11px}.bom-table th,.bom-table td{text-align:left;padding:4px 8px;border-bottom:1px solid var(--border)}.bom-table th{background:var(--bg-2);color:var(--text-dim);font-weight:600;text-transform:uppercase;font-size:10px;letter-spacing:.5px;position:sticky;top:0}.bom-table tr:hover{background:var(--bg-2)}.bom-modal{display:flex;flex-direction:column}.bom-tabs{display:flex;padding:6px 12px;border-bottom:1px solid var(--border);background:var(--bg-2);gap:4px;overflow-x:auto;flex-shrink:0}.bom-tab{padding:4px 10px;font-size:11px;border:1px solid transparent;border-radius:3px;background:transparent;color:var(--text-dim);white-space:nowrap;cursor:pointer}.bom-tab:hover{background:var(--bg-3)}.bom-tab.active{background:var(--bg-3);color:#5cdcff;border-color:#5cdcff}.bom-modal-body{overflow:auto}.bom-scroll{overflow:auto;max-width:100%}.bom-scroll .bom-table{min-width:100%}.vg-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px;align-items:start}.vg-field{display:flex;flex-direction:column;gap:4px;font-size:11px;color:var(--text-dim)}.vg-field input,.vg-field select{background:var(--bg-2);border:1px solid var(--border-light);color:var(--text);border-radius:3px;padding:4px 6px;font-size:12px}.vg-hint{margin:12px 0 0;font-size:11px;color:var(--text-mute)}.context-menu .item.submenu-anchor{display:flex;align-items:center}.context-menu .submenu{margin-left:2px;min-width:240px}.context-menu .item.is-open{background:var(--bg-3)}.kbd{font-family:var(--font-mono);font-size:10px;background:var(--bg-3);border:1px solid var(--border);border-bottom-width:2px;padding:1px 4px;border-radius:3px;color:var(--text-dim)}.divider{border-top:1px solid var(--border);margin:4px 0}.context-menu{position:absolute;background:var(--bg-2);border:1px solid var(--border-light);border-radius:4px;box-shadow:var(--shadow-lg);z-index:50;min-width:180px;padding:4px 0}.context-menu .item{padding:6px 12px;cursor:pointer;font-size:12px;display:flex;align-items:center;gap:8px}.context-menu .item:hover{background:var(--bg-3)}.context-menu .item .key{margin-left:auto;color:var(--text-mute);font-size:10px;font-family:var(--font-mono)}.command-bar{position:absolute;bottom:8px;left:50%;transform:translate(-50%);background:#0f141ceb;border:1px solid var(--border-light);border-radius:4px;padding:4px 10px;font-family:var(--font-mono);font-size:11px;color:var(--accent);box-shadow:var(--shadow);pointer-events:none;display:flex;align-items:center;gap:8px;max-width:70%}.command-bar .prompt{color:var(--text-mute)}.mobile-fab{display:none}@media (max-width: 900px){.app{grid-template-rows:36px 40px 1fr 22px;grid-template-columns:1fr;grid-template-areas:"menu" "ribbon" "main" "status"}.menu-bar{padding:0 8px;font-size:12px;overflow-x:auto;scrollbar-width:none}.menu-bar::-webkit-scrollbar{display:none}.menu-brand{margin-right:8px;flex-shrink:0}.menu-brand .logo{font-size:16px}.menu-info{display:none}.menu-item{flex-shrink:0}.ribbon{padding:4px 6px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch}.ribbon-group{padding:0 6px;min-width:auto}.ribbon-group-label{display:none}.tool-btn{padding:4px}.tool-btn .label{display:none}.tool-btn .icon svg{width:18px;height:18px}.left-panel,.right-panel{position:fixed;top:76px;bottom:22px;width:min(86vw,320px);z-index:40;box-shadow:var(--shadow-lg);transition:transform .22s ease;border-left:1px solid var(--border);border-right:1px solid var(--border)}.left-panel{left:0;transform:translate(-105%)}.right-panel{right:0;transform:translate(105%)}.left-panel.open,.right-panel.open{transform:translate(0)}.drawer-backdrop{position:fixed;top:76px;right:0;bottom:22px;left:0;background:#0006;z-index:35;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.canvas-3d{width:100%!important;border-left:none;border-top:1px solid var(--border)}.splitter{display:none}.main>div:first-child{flex-direction:column!important}.mobile-fab{display:flex;position:fixed;z-index:30;width:44px;height:44px;border-radius:50%;align-items:center;justify-content:center;background:var(--bg-3);border:1px solid var(--border-light);box-shadow:var(--shadow);color:var(--text);cursor:pointer;font-size:20px}.mobile-fab:active{background:var(--bg-4);transform:scale(.95)}.mobile-fab.fab-left{left:10px;bottom:38px}.mobile-fab.fab-right{right:10px;bottom:38px}.mobile-fab.fab-zoomin{right:10px;bottom:92px}.mobile-fab.fab-zoomout{right:10px;bottom:144px}.mobile-fab.fab-fit{right:10px;bottom:196px}.status-bar{font-size:10px;gap:6px;overflow-x:auto;white-space:nowrap;padding:0 6px}.status-section{padding:0 4px;flex-shrink:0}.status-section.status-snap,.status-section.status-grid,.status-section.status-ortho,.status-section.status-sheet,.status-section.status-entities,.status-section.status-selection,.status-section.status-zoom,.status-section.status-standard{display:none}.coord-readout,.canvas-overlay{font-size:9px;padding:3px 6px}.sheet-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.sheet-tab{flex-shrink:0;padding:0 10px;font-size:10px}.symbol-grid{grid-template-columns:repeat(3,1fr);gap:3px;padding:4px}.symbol-tile-preview{width:44px;height:44px}.symbol-tile-name{font-size:9px;height:18px}.modal{min-width:96vw!important;max-width:96vw!important;width:96vw!important;min-height:92vh!important;max-height:92vh!important;height:92vh!important;border-radius:8px}.modal-header{padding:10px 12px;font-size:13px;line-height:1.3}.modal-footer{padding:8px 12px;position:sticky;bottom:0;background:var(--bg-1);border-top:1px solid var(--border)}.cable-schedule-toolbar select,.cable-schedule-toolbar .btn-ghost{min-height:36px;flex:1 1 calc(50% - 4px)}.cable-schedule-toolbar{gap:4px;padding:6px 8px}.cable-schedule-spacer{display:none}.bom-tabs{padding:4px 8px;gap:2px}.bom-tab{min-height:36px;padding:6px 12px;font-size:12px}.compliance-cards{grid-template-columns:1fr!important}.catalogue-tabs{overflow-x:auto;scrollbar-width:none}.catalogue-tabs::-webkit-scrollbar{display:none}.catalogue-tab{min-height:36px;flex-shrink:0}.catalogue-toolbar{flex-direction:column;align-items:stretch;gap:6px}.catalogue-toolbar select,.catalogue-toolbar input{width:100%!important;min-height:36px}.cable-form-grid,.form-grid{grid-template-columns:1fr!important;gap:8px!important}.cable-form-grid label,.form-row label{font-size:11px}.cable-form-grid input,.cable-form-grid select,.cable-form-grid textarea,.form-row input,.form-row select,.form-row textarea{min-height:38px;font-size:14px}.site-navigator{display:none!important}.ribbon-group[data-group=Place],.ribbon-group[data-group=Snap],.ribbon-group[data-group=Nav]{display:none}button.primary,button.btn-primary{min-height:40px}}@media (max-width: 420px){.menu-item{padding:4px 6px;font-size:11px}.tool-btn{min-width:34px}.tool-btn .label{display:none}.symbol-grid{grid-template-columns:repeat(2,1fr)}.menu-brand .brand-name{display:none}}.cable-schedule-modal{display:flex;flex-direction:column}.cable-schedule-toolbar{display:flex;gap:6px;padding:8px 12px;border-bottom:1px solid var(--border);background:var(--bg-2);align-items:center;flex-wrap:wrap}.cable-schedule-spacer{flex:1}.cable-schedule-table-wrap{flex:1;overflow:auto;background:var(--bg-1)}.cable-table{width:100%;border-collapse:collapse;font-size:11px}.cable-table th,.cable-table td{text-align:left;padding:4px 6px;border-bottom:1px solid var(--border);white-space:nowrap}.cable-table th{background:var(--bg-2);position:sticky;top:0;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);z-index:1}.cable-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.cable-table th.sortable:hover{color:var(--accent)}.cable-table tr.has-warn{background:#ff5d5d14}.cable-table tr.has-warn:hover{background:#ff5d5d1f}.cable-table .fail{color:var(--danger);font-weight:600}.inline-input{width:100%;background:transparent;border:1px solid transparent;padding:2px 4px}.inline-input:hover{border-color:var(--border);background:var(--bg-2)}.inline-input:focus{border-color:var(--accent);background:var(--bg-1)}.inline-input.small{width:60px}.btn-tiny{padding:2px 8px;font-size:11px}.cable-edit-modal{min-width:640px;max-width:760px}.cable-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 16px;margin-bottom:12px}.cable-field{display:grid;grid-template-columns:130px 1fr;gap:8px;align-items:center}.cable-field-label{font-size:11px;color:var(--text-dim)}.cable-field-input input,.cable-field-input select{width:100%}.cable-calc-preview{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.calc-card{padding:10px;background:var(--bg-2);border:1px solid var(--border);border-radius:4px}.calc-card-label{font-size:10px;color:var(--text-mute);text-transform:uppercase;letter-spacing:.5px}.calc-card-value{font-size:14px;margin:4px 0;font-family:var(--font-mono)}.calc-card-value.ok{color:var(--good)}.calc-card-value.fail{color:var(--danger)}.calc-card-status{font-size:11px;color:var(--text-dim)}.compliance-modal{display:flex;flex-direction:column}.compliance-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.compliance-card{padding:12px 14px;background:var(--bg-2);border-left:4px solid var(--accent);border-radius:4px}.compliance-card.status-good{border-left-color:var(--good)}.compliance-card.status-amber{border-left-color:var(--warn)}.compliance-card.status-red{border-left-color:var(--danger)}.compliance-card.status-neutral{border-left-color:var(--border-light)}.compliance-card-title{font-size:10px;color:var(--text-mute);text-transform:uppercase;letter-spacing:.5px}.compliance-card-value{font-size:22px;font-family:var(--font-mono);margin:4px 0;color:var(--text)}.compliance-card-sub{font-size:11px;color:var(--text-dim)}.compliance-violations{flex:1;display:flex;flex-direction:column;min-height:200px}.compliance-section-header{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:6px 0;color:var(--text-dim)}.compliance-violation-list{flex:1;overflow-y:auto;border:1px solid var(--border);border-radius:4px}.compliance-violation{display:flex;align-items:center;gap:12px;padding:6px 12px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}.compliance-violation:last-child{border-bottom:none}.compliance-violation:hover{background:var(--bg-2)}.violation-kind{font-size:10px;text-transform:uppercase;font-weight:600;letter-spacing:.5px;padding:2px 6px;border-radius:3px;background:var(--bg-3);min-width:60px;text-align:center}.compliance-violation.severity-amber .violation-kind{background:#ffb34733;color:var(--warn)}.compliance-violation.severity-red .violation-kind{background:#ff5d5d33;color:var(--danger)}.violation-message{flex:1;font-size:12px}.violation-arrow{color:var(--text-mute)}.compliance-empty{padding:16px;color:var(--text-mute);text-align:center;font-size:12px}.overlay-modes{display:flex;gap:4px;padding:6px 8px;flex-wrap:wrap}.overlay-mode-btn{padding:4px 10px;font-size:11px;border:1px solid var(--border);border-radius:3px;background:var(--bg-2);color:var(--text-dim)}.overlay-mode-btn.active{background:var(--accent);color:#000;border-color:var(--accent)}.overlay-legend{padding:6px 12px}.overlay-legend-row{display:flex;align-items:center;gap:8px;padding:2px 0;font-size:11px;color:var(--text-dim)}.overlay-swatch{display:inline-block;width:12px;height:12px;border-radius:2px;border:1px solid var(--border-light)}.overlay-hint{padding:6px 12px;font-size:11px;color:var(--text-mute);font-style:italic}.cross-section-modal{min-width:540px}.cross-section-meta{display:flex;gap:16px;padding-bottom:12px;font-size:11px;color:var(--text-dim)}.cross-section-stats{display:flex;gap:16px;padding-top:12px;font-size:12px}.cs-label{color:var(--text-dim);margin-right:6px}.cs-value{font-family:var(--font-mono)}.cs-value.ok{color:var(--good)}.cs-value.fail{color:var(--danger)}.cs-limit{color:var(--text-mute);margin-left:6px}.catalogue-modal{display:flex;flex-direction:column}.catalogue-tabs{display:flex;padding:6px 12px;border-bottom:1px solid var(--border);background:var(--bg-2);gap:4px;overflow-x:auto}.catalogue-tab{padding:4px 10px;font-size:11px;border:1px solid transparent;border-radius:3px;background:transparent;color:var(--text-dim);white-space:nowrap}.catalogue-tab:hover{background:var(--bg-3)}.catalogue-tab.active{background:var(--bg-3);color:var(--accent);border-color:var(--accent)}.catalogue-toolbar{display:flex;gap:6px;padding:8px 12px;border-bottom:1px solid var(--border);align-items:center;flex-wrap:wrap}.catalogue-table-wrap{flex:1;overflow:auto}.catalogue-table{width:100%;border-collapse:collapse;font-size:11px}.catalogue-table th,.catalogue-table td{padding:4px 8px;border-bottom:1px solid var(--border);text-align:left}.catalogue-table th{background:var(--bg-2);position:sticky;top:0;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);z-index:1}.catalogue-table tr:hover{background:var(--bg-2)}.site-navigator{display:flex;flex-direction:column;border-top:1px solid var(--border);background:var(--bg-1);flex-shrink:0}.site-navigator-fallback{display:flex;flex-direction:column}.site-init-btn{margin:4px;align-self:flex-start;font-size:11px}.site-navigator-header{display:flex;align-items:center;padding:4px 10px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);background:var(--bg-2);border-bottom:1px solid var(--border)}.site-navigator-header button{margin-left:auto}.site-tree{padding:4px 0;max-height:240px;overflow-y:auto}.tree-row{display:flex;align-items:center;gap:6px;padding:3px 8px;cursor:pointer;font-size:11px}.tree-row:hover{background:var(--bg-2)}.tree-row.active{background:var(--bg-3);color:var(--accent)}.tree-row.level-1{padding-left:22px}.tree-row.level-2{padding-left:36px}.tree-row.level-3{padding-left:52px;color:var(--text-mute)}.tree-twist{width:12px;color:var(--text-mute);cursor:pointer}.tree-icon{color:var(--text-mute)}.tree-label{flex:1}.tree-meta{font-size:10px;color:var(--text-mute);font-family:var(--font-mono);margin-left:6px}.standards-picker{padding:12px;min-width:240px}.standards-row{display:flex;align-items:center;gap:8px}.standards-label{font-size:11px;color:var(--text-dim);width:80px}.standards-info{margin-top:8px;font-size:11px;color:var(--text-dim)}.standards-info span{color:var(--text-mute)}.standards-info div{padding:2px 0}.standards-affects{margin-top:8px;font-size:10px;color:var(--text-mute);font-style:italic}.standards-pill select{background:transparent;border:none;color:var(--accent);font-size:11px;padding:2px 4px}.settings-pane{background:var(--bg-2)}.filter-bar{display:flex;align-items:center;gap:8px;padding:4px 8px;font-size:11px}.filter-label{color:var(--text-dim);text-transform:uppercase;font-size:10px;letter-spacing:.5px;width:50px}.phase-swatch{display:inline-block;width:12px;height:12px;border-radius:2px;border:1px solid var(--border-light)}.markup-panel{display:flex;flex-direction:column}.markup-panel-header{display:flex;gap:6px;padding:6px 10px;background:var(--bg-2);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);border-bottom:1px solid var(--border);align-items:center}.markup-panel-actions{margin-left:auto;display:flex;gap:4px}.markup-list{padding:6px;display:flex;flex-direction:column;gap:6px}.markup-empty{padding:16px;color:var(--text-mute);text-align:center;font-size:11px}.markup-item{background:var(--bg-2);border:1px solid var(--border);border-radius:4px;padding:8px}.markup-item.status-resolved{opacity:.7}.markup-head{display:flex;align-items:center;gap:8px;font-size:11px;margin-bottom:4px}.markup-author{font-weight:600}.markup-status{font-size:10px;padding:1px 6px;border-radius:8px;background:var(--bg-3);text-transform:uppercase;letter-spacing:.5px}.markup-status.status-open{background:#ffb34733;color:var(--warn)}.markup-status.status-resolved{background:#6dd17c33;color:var(--good)}.markup-spacer{flex:1}.markup-body{font-size:12px;padding:4px 0}.markup-replies{padding:4px 0;border-top:1px dashed var(--border);margin-top:4px}.markup-reply{font-size:11px;padding:2px 0;color:var(--text-dim)}.markup-actions,.markup-reply-form{display:flex;gap:4px;padding-top:4px}.markup-reply-form input{flex:1}.revision-panel{display:flex;flex-direction:column}.revision-panel-header{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--bg-2);font-size:11px;border-bottom:1px solid var(--border)}.revision-actions{margin-left:auto;display:flex;gap:4px;align-items:center}.status-pill{font-size:10px;padding:2px 6px;border-radius:8px;background:var(--bg-3);text-transform:uppercase;font-family:var(--font-mono)}.status-pill.status-S0,.status-pill.status-S1,.status-pill.status-S2{background:#5cdcff33;color:var(--accent-2)}.status-pill.status-S3{background:#ffb34733;color:var(--warn)}.status-pill.status-S4{background:#6dd17c33;color:var(--good)}.status-pill.status-S5{background:#bb8cff33;color:var(--accent-3)}.status-pill.status-S6,.status-pill.status-S7{background:#ff5d5d33;color:var(--danger)}.revision-table-wrap{padding:6px;overflow-x:auto}.revision-table{width:100%;border-collapse:collapse;font-size:11px}.revision-table th,.revision-table td{padding:4px 8px;border-bottom:1px solid var(--border);text-align:left}.itp-panel{display:flex;flex-direction:column}.itp-panel-header{display:flex;gap:6px;padding:6px 10px;background:var(--bg-2);font-size:11px;border-bottom:1px solid var(--border);align-items:center}.itp-panel-header>span:first-child{font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim)}.itp-list{padding:6px;display:flex;flex-direction:column;gap:6px}.itp-empty{padding:16px;color:var(--text-mute);text-align:center;font-size:11px}.itp-item{background:var(--bg-2);border:1px solid var(--border);border-radius:4px;padding:8px}.itp-head{display:flex;align-items:center;gap:8px;margin-bottom:4px}.itp-ref{font-family:var(--font-mono);font-size:11px;color:var(--accent-2)}.itp-activity{font-size:12px}.itp-spacer{flex:1}.itp-status{font-size:10px;padding:2px 6px;border-radius:8px;background:var(--bg-3);text-transform:uppercase;letter-spacing:.5px}.itp-status.status-pending{background:#9aa4b233;color:var(--text-dim)}.itp-status.status-in-progress{background:#5cdcff33;color:var(--accent-2)}.itp-status.status-inspected-pass{background:#6dd17c33;color:var(--good)}.itp-status.status-inspected-fail{background:#ff5d5d33;color:var(--danger)}.itp-status.status-cleared{background:#bb8cff33;color:var(--accent-3)}.itp-meta{display:flex;gap:12px;font-size:11px;color:var(--text-dim);padding:4px 0;flex-wrap:wrap}.itp-actions{display:flex;gap:6px;padding-top:4px}.itp-actions select{width:auto}.itp-actions input{flex:1}.cost-modal{min-width:720px}.cost-section-title{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);margin-bottom:8px}.cost-rate-row{display:grid;grid-template-columns:180px 1fr;gap:8px;align-items:center;padding:4px 0}.cost-rate-row label{font-size:11px;color:var(--text-dim)}.cost-row{display:flex;justify-content:space-between;padding:4px 0;font-size:12px;border-bottom:1px solid var(--border)}.cost-row.grand{font-size:14px;font-weight:600;color:var(--accent-2);border-bottom:none;border-top:1px solid var(--border-light);padding-top:8px;margin-top:8px}.cost-value{font-family:var(--font-mono)}.calc-section{padding:4px 0}.calc-row{display:grid;grid-template-columns:100px 1fr;gap:6px;padding:3px 8px;font-size:11px;align-items:center}.calc-row-label{color:var(--text-dim)}.calc-row-value{font-family:var(--font-mono)}.calc-row-value.accent-good{color:var(--good)}.calc-row-value.accent-fail{color:var(--danger)}
