*,*:before,*:after{box-sizing:border-box}body{margin:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}#root{width:100%;max-width:100%;min-height:100svh}:root{--epl-yellow: #FFD100;--epl-blue: #2C50CD;--epl-black: #000000;--epl-grey: #54565A;--epl-grey-light: #98989A;--color-bg: #0a1628;--color-surface: #0d1b2e;--color-surface-alt: #112236;--color-border: rgba(255,255,255,.09);--color-border-mid: rgba(255,255,255,.16);--color-border-strong: rgba(255,255,255,.28);--color-text-primary: rgba(255,255,255,.92);--color-text-secondary: rgba(255,255,255,.72);--color-text-muted: rgba(255,255,255,.52);--color-accent: var(--epl-blue);--color-accent-hover: #2040B0;--color-accent-subtle: rgba(44,80,205,.18);--color-highlight: var(--epl-yellow);--color-highlight-subtle: rgba(255,209,0,.15);--color-topbar-bg: #0d1b2e;--color-topbar-text: #FFFFFF;--color-topbar-sub: rgba(255,255,255,.72);--color-topbar-border: #1A1A1A;--color-btn-bg: rgba(255,255,255,.07);--color-btn-text: rgba(255,255,255,.88);--color-btn-border: rgba(255,255,255,.16);--color-btn-hover-bg: rgba(255,255,255,.14);--color-danger-bg: #B91C1C;--color-danger-hover: #991818;--color-danger-text: #FFFFFF;--focus-ring: 0 0 0 3px rgba(44, 80, 205, .45);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--shadow-card: 0 2px 8px rgba(0,0,0,.35), 0 1px 3px rgba(0,0,0,.2);--shadow-canvas: 0 2px 16px rgba(0,0,0,.1);--font-sans: "Barlow", system-ui, -apple-system, sans-serif;--font-condensed: "Barlow Condensed", "Barlow", system-ui, sans-serif;--font-mono: "SF Mono", "Cascadia Code", "Fira Mono", Consolas, monospace}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text-primary);font-size:15px;line-height:1.55}button,select,input{font:inherit}:focus-visible{outline:none;box-shadow:var(--focus-ring)}body.is-resizing{cursor:col-resize;-webkit-user-select:none;user-select:none}.app{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden}.main-row{display:flex;flex:1 1 auto;min-height:0;overflow:hidden}.sidebar,.right-panel{flex:0 0 auto;background:var(--color-surface);padding:20px;overflow-y:auto;overflow-x:hidden}.sidebar{border-right:1px solid var(--color-border)}.right-panel{border-left:1px solid var(--color-border)}.resize-handle{flex:0 0 5px;width:5px;background:#ffffff0d;cursor:col-resize;position:relative;z-index:10;transition:background .15s ease}.resize-handle:hover{background:var(--epl-yellow)}.resize-handle:after{content:"";position:absolute;top:50%;left:1px;width:3px;height:28px;transform:translateY(-50%);border-left:2px dotted rgba(255,255,255,.12);pointer-events:none}.canvas-wrap{flex:1 1 auto;min-width:240px;display:flex;flex-direction:column;overflow:hidden}.canvas-scroll{flex:1 1 auto;overflow:hidden;padding:20px;background:#0a1628;position:relative}.canvas{display:block;width:100%;height:100%;background:#0a1628;border-radius:var(--radius-lg);box-shadow:0 0 0 1px #ffffff12,0 8px 40px #0009;border:none}.canvas-empty-state{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:1}.canvas-empty-state p{font-size:14px;color:#ffffff80;background:#ffffff0a;padding:10px 20px;border-radius:var(--radius-md);border:1px dashed rgba(255,255,255,.12)}.topbar{flex:0 0 auto;padding:0 48px;height:88px;background:var(--color-topbar-bg);border-bottom:3px solid var(--epl-yellow);display:flex;align-items:center;justify-content:space-between;gap:20px}.topbar-brand{display:flex;flex-direction:column;gap:2px}.topbar-brand-name{font-size:22px;font-weight:600;letter-spacing:.04em;color:var(--epl-yellow);line-height:1.15}.topbar-brand-name sup{font-size:14px;font-weight:600;vertical-align:super;letter-spacing:0}.topbar-brand-sub{font-size:14px;font-weight:400;color:#ffffff80;letter-spacing:.08em;text-transform:none;margin-top:2px}.topbar-divider{width:1px;height:36px;background:#ffffff1f;flex-shrink:0}.topbar-app-name{font-size:14px;font-weight:300;color:var(--color-topbar-sub);white-space:nowrap;letter-spacing:.16em;text-transform:uppercase}.zoom-controls{display:flex;align-items:center;gap:6px;flex:0 0 auto}.zoom-controls button{min-height:30px;padding:4px 10px;border:1px solid #333333;border-radius:var(--radius-sm);background:#1a1a1a;color:var(--color-topbar-text);cursor:pointer;font-size:14px;font-weight:500;transition:background .12s ease,border-color .12s ease}.zoom-controls button:hover:not(:disabled){background:#2a2a2a;border-color:var(--epl-yellow)}.zoom-controls button:focus-visible{box-shadow:var(--focus-ring)}.zoom-controls button:disabled{opacity:.35;cursor:not-allowed}.zoom-controls span{min-width:44px;text-align:center;font-size:14px;font-weight:600;color:var(--color-topbar-sub)}.sidebar h2{margin:0 0 4px;font-size:16px;font-weight:700;color:var(--color-text-primary);letter-spacing:-.02em}.helper-text{margin:0 0 14px;color:var(--color-text-secondary);font-size:14px;line-height:1.5}.fixture-options-card{margin:14px 0 20px;padding:14px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-alt);box-shadow:var(--shadow-card)}.fixture-options-card h3{margin:0 0 12px;font-size:14px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-secondary)}.field-label{display:block;margin-bottom:10px;font-size:14px;font-weight:600;color:var(--color-text-secondary);letter-spacing:.03em;text-transform:uppercase}.field-label select{display:block;width:100%;min-height:34px;margin-top:5px;padding:6px 28px 6px 10px;border:1px solid var(--color-border-mid);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text-primary);font-size:14px;font-weight:500;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%23aaaaaa' d='M5 6L0 0h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;cursor:pointer;transition:border-color .12s ease,box-shadow .12s ease}.field-label select:focus{outline:none;border-color:var(--color-accent);box-shadow:var(--focus-ring)}.field-label select:hover{border-color:var(--color-border-strong)}.module-section-title{margin:18px 0 8px;font-size:14px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-secondary)}.module-button{width:100%;display:block;text-align:left;padding:10px 12px;margin-bottom:5px;border:1px solid var(--color-border);background:var(--color-surface-alt);border-radius:var(--radius-md);cursor:pointer;color:var(--color-text-primary);transition:background .12s ease,border-color .12s ease}.module-button:hover{background:var(--color-highlight);border-color:var(--color-highlight);color:var(--epl-black)}.module-button:focus-visible{box-shadow:var(--focus-ring);outline:none}.module-button strong{display:block;font-size:14px;font-weight:600;color:inherit}.module-button span{display:block;margin-top:2px;font-size:14px;color:var(--color-text-secondary)}.module-button:hover span{color:var(--epl-black)}.curve-group{margin-bottom:6px;padding:10px 11px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-alt)}.curve-group-title{margin-bottom:8px;font-size:14px;font-weight:600;color:var(--color-text-primary)}.curve-angle-row{display:grid;grid-template-columns:1fr 1fr;gap:6px}.angle-button{min-height:34px;border:1px solid var(--color-border-mid);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text-primary);cursor:pointer;font-size:14px;font-weight:600;transition:background .12s ease,border-color .12s ease,color .12s ease}.angle-button:hover{background:var(--color-highlight);border-color:var(--color-highlight);color:var(--epl-black)}.angle-button:focus-visible{box-shadow:var(--focus-ring);outline:none}.controls{margin-top:18px;display:grid;gap:7px}.rotation-control-group{display:grid;gap:7px}.control-label{font-size:14px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-secondary)}.rotate-row{display:grid;grid-template-columns:1fr 1fr;gap:7px}.transform-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:7px}.controls button,.bom-header button{min-height:38px;padding:7px 12px;border:1px solid var(--color-btn-border);border-radius:var(--radius-sm);background:var(--color-btn-bg);color:var(--color-btn-text);cursor:pointer;font-size:14px;font-weight:500;transition:background .12s ease,border-color .12s ease}.controls button:hover:not(:disabled),.bom-header button:hover:not(:disabled){background:var(--color-btn-hover-bg);border-color:var(--color-btn-hover-bg)}.controls button:focus-visible,.bom-header button:focus-visible{box-shadow:var(--focus-ring);outline:none}.controls button:disabled,.bom-header button:disabled{background:var(--color-surface-alt);color:var(--color-text-secondary);border-color:var(--color-border);cursor:not-allowed}.btn-danger{background:var(--color-danger-bg)!important;color:var(--color-danger-text)!important;border-color:var(--color-danger-bg)!important}.btn-danger:hover:not(:disabled){background:var(--color-danger-hover)!important;border-color:var(--color-danger-hover)!important}.btn-danger:disabled{background:var(--color-surface-alt)!important;color:var(--color-text-secondary)!important;border-color:var(--color-border)!important}.selected-card{margin-top:18px;padding:13px;border:1px solid var(--color-border);border-left:3px solid var(--epl-yellow);border-radius:var(--radius-md);background:var(--color-highlight-subtle);box-shadow:var(--shadow-card)}.selected-card h3{margin:0 0 8px;font-size:14px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-secondary)}.selected-card-row{margin-bottom:10px}.selected-card-row strong{display:block;font-size:14px;font-weight:600;color:var(--color-text-primary)}.selected-card-row span{display:block;font-size:14px;color:var(--color-text-secondary);margin-top:2px}.selected-card-grid{display:grid;grid-template-columns:auto 1fr;gap:4px 12px;font-size:14px;margin-bottom:10px}.selected-card-label{color:var(--color-text-secondary);font-weight:500}.selected-card-value{color:var(--color-text-primary);font-weight:600}.selected-part-number{padding-top:9px;border-top:1px solid var(--color-border-mid);font-size:14px;color:var(--color-text-secondary);font-weight:500;word-break:break-all;font-family:var(--font-mono)}.right-panel h2{margin:0 0 12px;font-size:14px;font-weight:700;color:var(--color-text-primary);letter-spacing:-.01em}.spec-card,.bom-card{padding:15px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-alt);box-shadow:var(--shadow-card)}.bom-card{margin-top:14px}.spec-table{width:100%;border-collapse:collapse;font-size:14px}.spec-table th,.spec-table td{border-bottom:1px solid var(--color-border);padding:7px 0;vertical-align:top}.spec-table th{width:138px;text-align:left;color:var(--color-text-secondary);font-weight:500}.spec-table td{color:var(--color-text-primary);font-weight:500}.badge{display:inline-block;font-size:14px;font-weight:700;padding:2px 8px;border-radius:99px;letter-spacing:.03em}.badge-open{background:var(--epl-yellow);color:var(--epl-black)}.badge-closed{background:var(--epl-blue);color:#fff}.bom-header{display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;margin-bottom:12px}.bom-header h2{margin:0}.export-button-row{display:flex;gap:6px}.export-button-row button{white-space:nowrap}.bom-table{width:100%;border-collapse:collapse;font-size:14px}.bom-table th{text-align:left;border-bottom:2px solid var(--epl-black);padding:5px 0 7px;color:var(--color-text-primary);font-weight:700;font-size:14px;letter-spacing:.08em;text-transform:uppercase}.bom-table td{border-bottom:1px solid var(--color-border);padding:7px 0;vertical-align:top}.bom-qty{width:36px;font-weight:700;font-size:14px;color:var(--color-text-primary)}.bom-table td strong{display:block;font-size:14px;color:var(--color-text-primary);font-weight:600;margin-bottom:2px;font-family:var(--font-mono)}.bom-table td span{color:var(--color-text-secondary);font-size:14px;line-height:1.4}.draw-tool-button{width:100%;display:flex;align-items:center;gap:12px;text-align:left;padding:12px 13px;margin-bottom:6px;border:1.5px dashed var(--color-border-mid);background:var(--color-surface);border-radius:var(--radius-md);cursor:pointer;color:var(--color-text-primary);transition:background .12s ease,border-color .12s ease,color .12s ease}.draw-tool-button:hover{background:var(--color-highlight-subtle);border-color:var(--epl-yellow);border-style:solid}.draw-tool-button:focus-visible{box-shadow:var(--focus-ring);outline:none}.qty-input-row{display:flex;align-items:center;gap:6px;margin-top:5px}.qty-btn{width:32px;height:34px;flex-shrink:0;border:1px solid var(--color-border-mid);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text-primary);font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s ease,border-color .12s ease}.qty-btn:hover:not(:disabled){background:var(--color-highlight);border-color:var(--epl-yellow);color:var(--epl-black)}.qty-btn:disabled{opacity:.35;cursor:not-allowed}.qty-input{flex:1;text-align:center;font-weight:700;font-size:15px;-moz-appearance:textfield}.qty-input::-webkit-outer-spin-button,.qty-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.qty-note{margin:5px 0 0;font-size:14px;color:var(--epl-blue);font-weight:500}.float-rotate-controls{position:absolute;display:flex;align-items:center;gap:4px;background:#1c1c1c;border:1px solid rgba(255,255,255,.14);border-radius:var(--radius-md);padding:5px 7px;box-shadow:0 4px 20px #0000008c;z-index:100;pointer-events:auto;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transform:translate(-50%);white-space:nowrap}.float-rotate-btn{min-width:42px;height:28px;padding:0 8px;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-sm);background:#ffffff12;color:#ffffffd9;font-size:13px;font-weight:600;cursor:pointer;transition:background .12s,border-color .12s}.float-rotate-btn:hover{background:#2a2a2a;border-color:var(--epl-yellow);color:#fff}.float-rotate-divider{width:1px;height:18px;background:#ffffff26;margin:0 2px;flex-shrink:0}.float-length-controls{position:absolute;display:flex;align-items:center;gap:6px;background:#1c1c1c;border:1px solid rgba(255,255,255,.14);border-radius:var(--radius-md);padding:5px 8px;box-shadow:0 4px 20px #0000008c;z-index:100;pointer-events:auto;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.float-length-btn{min-width:44px;height:28px;padding:0 10px;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-sm);background:#ffffff12;color:#ffffffd9;font-size:14px;font-weight:600;cursor:pointer;transition:background .12s,border-color .12s;white-space:nowrap}.float-length-btn:hover:not(:disabled){background:#2a2a2a;border-color:var(--epl-yellow)}.float-length-btn:disabled{opacity:.28;cursor:not-allowed}.float-length-label{min-width:52px;text-align:center;font-size:14px;font-weight:700;color:#ffffffbf;letter-spacing:.02em}.floating-undo-redo{position:fixed;z-index:500;display:flex;align-items:center;gap:2px;background:var(--epl-black);border:1px solid #333;border-radius:var(--radius-md);padding:5px 7px;box-shadow:0 4px 16px #00000059;-webkit-user-select:none;user-select:none}.floating-drag-handle{display:flex;align-items:center;color:#555;cursor:grab;padding:2px 4px 2px 0;margin-right:3px;transition:color .12s}.floating-drag-handle:hover{color:var(--epl-yellow)}.floating-drag-handle:active{cursor:grabbing}.floating-undo-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid #333;border-radius:var(--radius-sm);background:#1a1a1a;color:#fff;cursor:pointer;transition:background .12s,border-color .12s,color .12s}.floating-undo-btn:hover:not(:disabled){background:#2a2a2a;border-color:var(--epl-yellow);color:var(--epl-yellow)}.floating-undo-btn:disabled{opacity:.3;cursor:not-allowed}.floating-undo-btn:focus-visible{box-shadow:var(--focus-ring);outline:none}.floating-undo-btn{position:relative}.undo-redo-count{position:absolute;top:-5px;right:-5px;min-width:16px;height:16px;padding:0 3px;background:var(--epl-yellow);color:#0a1628;border-radius:8px;font-size:9px;font-weight:700;line-height:16px;text-align:center;pointer-events:none}.panel-tabs{display:flex;gap:2px;padding:14px 14px 0;margin:-20px -20px 16px;background:var(--color-surface-alt);border-bottom:1px solid var(--color-border)}.panel-tab{flex:1;padding:9px 6px;border:none;border-bottom:2px solid transparent;background:transparent;color:var(--color-text-muted);font-size:14px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:5px;transition:color .12s,border-color .12s}.panel-tab:hover{color:var(--color-text-primary)}.panel-tab--active{color:var(--epl-blue);border-bottom-color:var(--epl-blue)}.panel-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 4px;background:var(--epl-blue);color:#fff;font-size:14px;font-weight:700;border-radius:99px}.tab-content{display:flex;flex-direction:column;gap:14px}.curve-grid{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;font-size:14px}.curve-grid-header{display:grid;grid-template-columns:1fr 1fr 1fr;background:var(--color-surface-alt);border-bottom:1px solid var(--color-border);padding:6px 10px;font-size:14px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-secondary)}.curve-grid-row{display:grid;grid-template-columns:1fr 1fr 1fr;align-items:center;padding:5px 10px;border-bottom:1px solid var(--color-border);gap:6px}.curve-grid-row:last-child{border-bottom:none}.curve-grid-label{font-size:14px;font-weight:600;color:var(--color-text-primary)}.curve-grid-btn{width:100%;height:40px;border:1px solid var(--color-border-mid);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text-secondary);font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,border-color .12s,color .12s}.curve-grid-btn:hover{background:var(--color-highlight);border-color:var(--epl-yellow);color:var(--epl-black)}.rotate-compact-row{display:flex;align-items:center;gap:6px}.rotate-btn{width:40px;height:38px;flex-shrink:0;border:1px solid var(--color-btn-border);border-radius:var(--radius-sm);background:var(--color-btn-bg);color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s}.rotate-btn:hover:not(:disabled){background:var(--color-btn-hover-bg)}.rotate-btn:disabled{background:var(--color-surface-alt);color:var(--color-text-muted);border-color:var(--color-border);cursor:not-allowed}.rotate-deg-toggle{flex:1;display:flex;border:1px solid var(--color-border-mid);border-radius:var(--radius-sm);overflow:hidden}.deg-btn{flex:1;height:38px;border:none;background:var(--color-surface);color:var(--color-text-secondary);font-size:14px;font-weight:600;cursor:pointer;transition:background .12s,color .12s}.deg-btn+.deg-btn{border-left:1px solid var(--color-border-mid)}.deg-btn--active{background:var(--epl-black);color:#fff}.deg-btn:hover:not(.deg-btn--active){background:var(--color-highlight-subtle);color:var(--epl-black)}.canvas-onboarding{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:24px 28px;max-width:340px;box-shadow:0 4px 24px #0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.canvas-onboarding-title{font-size:15px;font-weight:700;color:#ffffffeb;margin:0 0 14px;letter-spacing:-.01em}.canvas-onboarding-steps{margin:0;padding:0 0 0 18px;display:flex;flex-direction:column;gap:8px}.canvas-onboarding-steps li{font-size:14px;color:#ffffff80;line-height:1.5}.canvas-onboarding-steps li strong{color:#ffffffd9;font-weight:600}.context-menu{position:fixed;z-index:9000;min-width:160px;background:var(--color-surface);border:1px solid var(--color-border-mid);border-radius:var(--radius-md);box-shadow:0 8px 24px #0000002e;padding:4px;display:flex;flex-direction:column}.context-menu-item{width:100%;text-align:left;padding:7px 12px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:background .1s}.context-menu-item:hover{background:var(--color-surface-alt)}.context-menu-item--danger{color:var(--color-danger-bg)}.context-menu-item--danger:hover{background:#fff0f0}.topbar-selection-badge{font-size:14px;font-weight:600;color:var(--epl-yellow);letter-spacing:.04em;padding:3px 8px;border:1px solid rgba(255,209,0,.4);border-radius:99px;white-space:nowrap}.panel-tab-badge--yellow{background:var(--epl-yellow);color:var(--epl-black)}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;background:#00000073;display:flex;align-items:center;justify-content:center}.confirm-box{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:0 12px 40px #00000040;padding:28px 28px 22px;max-width:360px;width:calc(100% - 48px)}.confirm-message{font-size:14px;color:var(--color-text-primary);margin:0 0 20px;line-height:1.5}.confirm-actions{display:flex;gap:10px;justify-content:flex-end}.confirm-btn-cancel{padding:8px 18px;border:1px solid var(--color-border-mid);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-primary);font-size:14px;font-weight:500;cursor:pointer}.confirm-btn-danger{padding:8px 18px;border:none;border-radius:var(--radius-md);background:var(--color-danger-bg);color:var(--color-danger-text);font-size:14px;font-weight:600;cursor:pointer}.confirm-btn-danger:hover{background:var(--color-danger-hover)}.canvas-connect-hint{position:absolute;top:16px;left:50%;transform:translate(-50%);background:#ffd1001f;border:1px solid rgba(255,209,0,.45);color:#ffffffe0;font-size:14px;font-weight:500;padding:6px 16px;border-radius:99px;pointer-events:none;letter-spacing:.04em;z-index:50;white-space:nowrap}.bom-code-col{width:28px;min-width:28px;text-align:center;font-weight:700;font-size:14px;color:var(--epl-blue);letter-spacing:.02em;padding:0 4px}.align-row{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;margin-bottom:8px}.align-row button{padding:5px 0;font-size:15px;border:1px solid var(--color-border-mid);border-radius:var(--radius-sm);background:var(--color-surface-alt);color:var(--color-text-primary);cursor:pointer;transition:background .12s,border-color .12s}.align-row button:hover{background:var(--color-highlight);border-color:var(--color-highlight);color:var(--epl-black)}.note-edit-overlay{position:absolute;z-index:200;pointer-events:auto}.note-edit-input{background:#0a1628f5;border:1.5px solid rgba(255,209,0,.7);border-radius:4px;color:#fffffff2;font-family:var(--font-sans);font-size:14px;padding:4px 8px;min-width:120px;outline:none;box-shadow:0 4px 16px #0006}input,select,textarea{background:var(--color-surface-alt)!important;color:var(--color-text-primary)!important;border-color:var(--color-border-mid)!important}input::placeholder{color:var(--color-text-muted)}.fixture-options-card,.project-info-card,.disclaimer-card,.bom-card,.spec-card,.selected-card{background:var(--color-surface-alt);border-color:var(--color-border)}.selected-card-value{color:var(--color-text-primary)}.selected-part-number{color:#ffffff8c}.module-section-title{color:var(--color-text-secondary)}.bom-table td,.bom-table th,.spec-table td,.spec-table th{border-color:var(--color-border);color:var(--color-text-primary)}.spec-table th{color:var(--color-text-secondary)}.bom-table strong{color:var(--color-text-primary)}.bom-table span{color:var(--color-text-secondary)}.panel-tabs{background:var(--color-surface-alt);border-bottom-color:var(--color-border)}.panel-tab{color:var(--color-text-secondary)}.panel-tab--active{color:var(--color-text-primary);border-bottom-color:var(--epl-yellow)}.panel-tab:hover:not(.panel-tab--active){color:var(--color-text-primary)}.curve-grid-header span{color:var(--color-text-secondary)}.curve-grid-label{color:var(--color-text-primary)}.draw-tool-button{background:var(--color-surface-alt);border-color:var(--color-border-mid)}.draw-tool-button--active{background:#ffd1001f;border-color:#ffd10080}.confirm-box{background:var(--color-surface-alt)}.confirm-message{color:var(--color-text-primary)}.confirm-btn-cancel{background:var(--color-surface);color:var(--color-text-primary);border-color:var(--color-border-mid)}.confirm-btn-cancel:hover{background:var(--color-surface-alt)}.context-menu{background:var(--color-surface-alt);border-color:var(--color-border-mid)}.context-menu-item{color:var(--color-text-primary)}.context-menu-item:hover{background:#ffffff14}.helper-text,.field-label{color:var(--color-text-secondary)}.disclaimer-label{color:var(--epl-yellow)!important}.disclaimer-text{color:#ffd100b3!important}.topbar-brand-by{font-size:14px;font-weight:400;color:#ffffffb3;margin-left:6px;letter-spacing:.01em}.topbar-brand-name{display:flex;align-items:baseline;gap:0}.topbar-brand-sub{font-size:14px;font-weight:400;color:#ffffff73;letter-spacing:.03em;text-transform:none;margin-top:3px}.app-footer{flex:0 0 auto;display:flex;justify-content:space-between;align-items:center;padding:0 24px;height:28px;background:var(--color-surface);border-top:1px solid var(--color-border);font-size:14px;color:var(--color-text-muted);letter-spacing:.04em}.footer-credit,.footer-revised{opacity:.7}.key-specs-strip{flex:0 0 auto;display:flex;align-items:center;padding:0 24px;height:38px;background:var(--color-surface-alt);border-bottom:1px solid var(--color-border);gap:0}.key-spec-item{display:flex;align-items:baseline;gap:8px;padding:0 18px}.key-spec-item:first-child{padding-left:0}.key-spec-label{font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted);white-space:nowrap}.key-spec-value{font-size:14px;font-weight:700;color:var(--color-text-primary);font-family:var(--font-mono);white-space:nowrap}.key-spec-divider{width:1px;height:18px;background:var(--color-border-mid);flex-shrink:0}.sidebar-zone{padding-bottom:18px}.sidebar-zone--edit{margin-top:4px;padding-top:16px;border-top:1px solid var(--color-border-mid);display:grid;gap:7px}.sidebar-zone-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}.sidebar-zone-title{font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-secondary)}.sidebar-zone-count{font-size:12px;font-weight:600;color:var(--epl-yellow);background:#ffd1001f;border:1px solid rgba(255,209,0,.3);border-radius:99px;padding:1px 8px}.btn-delete-selected{width:100%;min-height:38px;padding:7px 12px;border:1px solid rgba(185,28,28,.4);border-radius:var(--radius-sm);background:#b91c1c1a;color:#fca5a5;cursor:pointer;font-size:14px;font-weight:500;transition:background .12s ease,border-color .12s ease}.btn-delete-selected:hover{background:var(--color-danger-bg);border-color:var(--color-danger-bg);color:var(--color-danger-text)}.btn-delete-selected:focus-visible{box-shadow:var(--focus-ring);outline:none}.sidebar-danger-footer{margin-top:auto;padding-top:16px;border-top:1px solid var(--color-border)}.sidebar-danger-footer .btn-danger{width:100%;min-height:36px;padding:6px 12px;font-size:13px}.curve-grid-btn{flex-direction:column;gap:2px}.curve-grid-btn-label{font-size:11px;font-weight:700;line-height:1;color:inherit}.panel-export-footer{flex:0 0 auto;padding:14px 16px;border-top:1px solid var(--color-border-mid);background:var(--color-surface-alt);margin:0 -20px -20px}.btn-export-pdf{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:10px 16px;border:none;border-radius:var(--radius-md);background:var(--epl-yellow);color:var(--epl-black);font-size:15px;font-weight:600;cursor:pointer;letter-spacing:.01em;transition:background .15s ease,opacity .15s ease}.btn-export-pdf:hover:not(:disabled){background:#ffc600}.btn-export-pdf:focus-visible{box-shadow:var(--focus-ring);outline:none}.btn-export-pdf:disabled{opacity:.38;cursor:not-allowed}.canvas-onboarding{background:#0d1b2eeb;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-lg);padding:28px 32px;max-width:680px;box-shadow:0 8px 40px #00000080;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.canvas-onboarding-title{font-size:16px;font-weight:700;color:#ffffff8c;margin:0 0 20px;letter-spacing:.08em;text-transform:uppercase;text-align:center}.canvas-onboarding-steps-visual{display:flex;align-items:flex-start;gap:12px}.onboarding-step{display:flex;flex-direction:column;align-items:center;gap:12px;flex:1;text-align:center}.onboarding-step-number{width:36px;height:36px;border-radius:50%;background:var(--epl-yellow);color:var(--epl-black);font-size:16px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}.onboarding-step-content{display:flex;flex-direction:column;gap:6px}.onboarding-step-content strong{font-size:14px;font-weight:700;color:#ffffffeb;display:block}.onboarding-step-content span{font-size:13px;color:#ffffff80;line-height:1.5;display:block}.onboarding-step-arrow{font-size:20px;color:#ffd10073;margin-top:8px;flex-shrink:0;align-self:flex-start;padding-top:6px}.disclaimer-card{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-alt);overflow:hidden}.disclaimer-label{display:block;padding:10px 14px;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;list-style:none}.disclaimer-label::-webkit-details-marker{display:none}.disclaimer-label:after{content:" ›";font-size:14px;color:var(--color-text-muted)}details[open] .disclaimer-label:after{content:" ↑"}.disclaimer-text{padding:0 14px 12px;font-size:12px;color:var(--color-text-muted);line-height:1.6;margin:0}.lp{--epl-yellow: #ffd100;--epl-blue: #2c50cd;--lp-bg: #0a1628;--lp-surface: #0d1b2e;--lp-surface-alt: #112236;--lp-border: rgba(255, 255, 255, .09);--lp-border-mid: rgba(255, 255, 255, .16);--lp-text: rgba(255, 255, 255, .92);--lp-text-2: rgba(255, 255, 255, .72);--lp-text-3: rgba(255, 255, 255, .52);--lp-font: "Barlow", system-ui, -apple-system, sans-serif;--lp-cond: "Barlow Condensed", "Barlow", system-ui, sans-serif;--lp-radius: 14px;font-family:var(--lp-font);background:var(--lp-bg);color:var(--lp-text);min-height:100vh;width:100%;overflow-x:hidden}.lp a{color:inherit;text-decoration:none}.lp *,.lp *:before,.lp *:after{box-sizing:border-box}.lp :focus-visible{outline:none;box-shadow:0 0 0 3px #2c50cd8c;border-radius:6px}.lp-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 20px;border-radius:8px;font-weight:600;font-size:15px;letter-spacing:.01em;cursor:pointer;border:1px solid transparent;transition:transform .12s ease,background .15s ease,border-color .15s ease;white-space:nowrap}.lp-btn:active{transform:translateY(1px)}.lp-btn-lg{padding:15px 28px;font-size:16px}.lp-btn-primary{background:var(--epl-yellow);color:#000}.lp-btn-primary:hover{background:#ffdb38}.lp-btn-ghost{background:#ffffff0a;border-color:var(--lp-border-mid);color:var(--lp-text)}.lp-btn-ghost:hover{background:#ffffff1a;border-color:var(--epl-yellow)}.lp-link{font-weight:500;color:var(--lp-text-2);font-size:15px}.lp-link:hover{color:var(--lp-text)}.lp-brand{display:flex;flex-direction:column;gap:1px}.lp-brand-name{font-size:21px;font-weight:700;letter-spacing:.05em;color:var(--epl-yellow);line-height:1.1}.lp-brand-name sup{font-size:11px;vertical-align:super}.lp-brand-sub{font-size:12px;color:var(--lp-text-3);letter-spacing:.08em}.lp-nav{position:sticky;top:0;z-index:50;background:#0a1628d1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--lp-border)}.lp-nav-inner{max-width:1200px;margin:0 auto;padding:16px 32px;display:flex;align-items:center;gap:32px}.lp-nav-links{display:flex;gap:28px;margin-left:auto;font-size:15px;font-weight:500;color:var(--lp-text-2)}.lp-nav-links a:hover{color:var(--epl-yellow)}.lp-nav-actions{display:flex;align-items:center;gap:18px}.lp-hero{position:relative;padding:88px 32px 96px;max-width:1200px;margin:0 auto}.lp-hero:before{content:"";position:absolute;top:-120px;right:-160px;width:620px;height:620px;background:radial-gradient(circle,rgba(44,80,205,.28),transparent 62%);pointer-events:none;z-index:0}.lp-hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center}.lp-eyebrow{display:inline-block;font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--epl-yellow);margin-bottom:20px}.lp-h1{font-family:var(--lp-cond);font-size:clamp(40px,6vw,68px);font-weight:600;line-height:1.04;letter-spacing:-.01em;margin:0 0 22px}.lp-accent{color:var(--epl-yellow)}.lp-lede{font-size:18px;line-height:1.6;color:var(--lp-text-2);max-width:540px;margin:0 0 32px}.lp-hero-cta{display:flex;gap:14px;flex-wrap:wrap}.lp-hero-cta.lp-center{justify-content:center}.lp-audience-chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:32px}.lp-audience-chips span{font-size:13px;font-weight:500;color:var(--lp-text-2);padding:6px 14px;border:1px solid var(--lp-border-mid);border-radius:999px}.lp-hero-visual{position:relative;display:flex;justify-content:center}.lp-hero-visual img{width:100%;max-width:360px;filter:drop-shadow(0 24px 60px rgba(0,0,0,.55))}.lp-hero-badge{position:absolute;bottom:6px;left:0;display:flex;flex-direction:column;background:var(--lp-surface);border:1px solid var(--lp-border-mid);border-left:3px solid var(--epl-yellow);border-radius:10px;padding:12px 16px;box-shadow:0 12px 30px #0006}.lp-hero-badge-k{font-weight:700;font-size:14px}.lp-hero-badge-v{font-size:12px;color:var(--lp-text-3)}.lp-section{padding:84px 32px;max-width:1200px;margin:0 auto}.lp-section-alt{max-width:none;background:var(--lp-surface);border-top:1px solid var(--lp-border);border-bottom:1px solid var(--lp-border)}.lp-section-alt>*{max-width:1200px;margin-left:auto;margin-right:auto}.lp-section-head{max-width:680px;margin:0 auto 52px;text-align:center}.lp-kicker{display:inline-block;font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--epl-blue);margin-bottom:14px}.lp-h2{font-family:var(--lp-cond);font-size:clamp(30px,4vw,44px);font-weight:600;line-height:1.1;margin:0 0 14px}.lp-sub{font-size:17px;line-height:1.6;color:var(--lp-text-2);margin:0}.lp-feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.lp-feature{background:var(--lp-surface);border:1px solid var(--lp-border);border-radius:var(--lp-radius);padding:28px 26px;transition:border-color .16s ease,transform .16s ease}.lp-feature:hover{border-color:var(--lp-border-mid);transform:translateY(-3px)}.lp-feature-icon{display:inline-flex;width:44px;height:44px;align-items:center;justify-content:center;border-radius:10px;background:#2c50cd29;color:var(--epl-yellow);margin-bottom:18px}.lp-feature-icon svg{width:22px;height:22px}.lp-feature h3{font-size:18px;font-weight:600;margin:0 0 8px}.lp-feature p{font-size:15px;line-height:1.6;color:var(--lp-text-2);margin:0}.lp-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}.lp-step{position:relative;padding-top:8px}.lp-step-n{font-family:var(--lp-cond);font-size:56px;font-weight:700;line-height:1;color:#ffd10038;display:block;margin-bottom:8px}.lp-step h3{font-size:20px;font-weight:600;margin:0 0 8px}.lp-step p{font-size:15px;line-height:1.6;color:var(--lp-text-2);margin:0}.lp-audience-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.lp-audience-card{background:var(--lp-surface-alt);border:1px solid var(--lp-border);border-top:3px solid var(--epl-yellow);border-radius:var(--lp-radius);padding:30px 28px}.lp-audience-card h3{font-size:21px;font-weight:600;margin:0 0 10px}.lp-audience-card p{font-size:15px;line-height:1.6;color:var(--lp-text-2);margin:0}.lp-output{display:grid;grid-template-columns:1fr .9fr;gap:56px;align-items:center}.lp-output-copy .lp-h2{margin-top:8px}.lp-output-list{list-style:none;padding:0;margin:24px 0 32px;display:grid;gap:16px}.lp-output-list li{position:relative;padding-left:30px;font-size:15px;line-height:1.6;color:var(--lp-text-2)}.lp-output-list li:before{content:"";position:absolute;left:0;top:7px;width:16px;height:16px;border-radius:4px;background:var(--epl-yellow);box-shadow:inset 0 0 0 4px var(--lp-surface)}.lp-output-list strong{color:var(--lp-text);font-weight:600}.lp-output-card{display:flex;justify-content:center}.lp-doc{width:100%;max-width:380px;background:var(--lp-bg);border:1px solid var(--lp-border-mid);border-radius:var(--lp-radius);overflow:hidden;box-shadow:0 24px 60px #00000080}.lp-doc-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--lp-surface);border-bottom:2px solid var(--epl-yellow)}.lp-doc-tag{font-size:12px;font-weight:700;letter-spacing:.12em;color:var(--epl-yellow)}.lp-doc-pn{font-size:12px;color:var(--lp-text-3);font-family:monospace}.lp-doc-canvas{padding:18px 16px;color:#ffffff73}.lp-doc-canvas svg{width:100%;height:auto}.lp-doc-rows{padding:4px 16px 14px;display:grid;gap:8px}.lp-doc-row{display:flex;justify-content:space-between;font-size:13px;color:var(--lp-text-2);padding-bottom:8px;border-bottom:1px solid var(--lp-border)}.lp-doc-row b{color:var(--lp-text)}.lp-doc-foot{padding:12px 16px;font-size:11px;letter-spacing:.1em;font-weight:600;color:var(--lp-text-3);background:var(--lp-surface);border-top:1px solid var(--lp-border)}.lp-cta{text-align:center;padding:96px 32px;max-width:760px;margin:0 auto}.lp-cta .lp-sub{margin:0 auto 32px;max-width:520px}.lp-footer{border-top:1px solid var(--lp-border);background:var(--lp-surface)}.lp-footer-inner{max-width:1200px;margin:0 auto;padding:36px 32px;display:flex;align-items:center;gap:40px;flex-wrap:wrap}.lp-footer-note{font-size:13px;color:var(--lp-text-3);margin:0;max-width:520px;line-height:1.6}@media(max-width:900px){.lp-hero-grid,.lp-output{grid-template-columns:1fr;gap:40px}.lp-hero-visual{order:-1}.lp-feature-grid,.lp-steps,.lp-audience-grid{grid-template-columns:1fr}.lp-nav-links{display:none}}@media(max-width:600px){.lp-nav-inner{padding:14px 18px;gap:16px}.lp-hero{padding:56px 18px 64px}.lp-section{padding:60px 18px}.lp-nav-actions .lp-link{display:none}}
