:root,[data-theme=dark]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-canvas: #0c1222;--border-primary: #334155;--border-secondary: #475569;--text-primary: #e2e8f0;--text-secondary: #94a3b8;--text-muted: #64748b;--accent-primary: #3b82f6;--accent-secondary: #8b5cf6;--accent-gradient: linear-gradient(135deg, #3b82f6 0%, #8b5cf6 100%);--accent-text: linear-gradient(135deg, #60a5fa 0%, #a78bfa 100%);--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--glass-fill: rgba(56, 189, 248, .15);--glass-stroke: #38bdf8;--glass-selected: #2563eb;--grid-color: rgba(100, 116, 139, .15);--grid-major: rgba(100, 116, 139, .3);--hole-fill: rgba(15, 23, 42, .9);--shadow: 0 4px 6px -1px rgba(0, 0, 0, .3)}[data-theme=light]{--bg-primary: #f8fafc;--bg-secondary: #e2e8f0;--bg-tertiary: #cbd5e1;--bg-canvas: #ffffff;--border-primary: #cbd5e1;--border-secondary: #94a3b8;--text-primary: #1e293b;--text-secondary: #475569;--text-muted: #64748b;--accent-primary: #2563eb;--accent-secondary: #7c3aed;--accent-gradient: linear-gradient(135deg, #2563eb 0%, #7c3aed 100%);--accent-text: linear-gradient(135deg, #1d4ed8 0%, #6d28d9 100%);--success: #059669;--warning: #d97706;--danger: #dc2626;--glass-fill: rgba(37, 99, 235, .1);--glass-stroke: #2563eb;--glass-selected: #1d4ed8;--grid-color: rgba(100, 116, 139, .2);--grid-major: rgba(100, 116, 139, .4);--hole-fill: rgba(255, 255, 255, .95);--shadow: 0 4px 6px -1px rgba(0, 0, 0, .1)}[data-theme=midnight]{--bg-primary: #0a1628;--bg-secondary: #132039;--bg-tertiary: #1e3a5f;--bg-canvas: #060d18;--border-primary: #1e3a5f;--border-secondary: #2563eb;--text-primary: #e0f2fe;--text-secondary: #7dd3fc;--text-muted: #38bdf8;--accent-primary: #0ea5e9;--accent-secondary: #06b6d4;--accent-gradient: linear-gradient(135deg, #0ea5e9 0%, #06b6d4 100%);--accent-text: linear-gradient(135deg, #38bdf8 0%, #22d3ee 100%);--success: #14b8a6;--warning: #fbbf24;--danger: #f43f5e;--glass-fill: rgba(14, 165, 233, .2);--glass-stroke: #0ea5e9;--glass-selected: #0284c7;--grid-color: rgba(56, 189, 248, .1);--grid-major: rgba(56, 189, 248, .25);--hole-fill: rgba(6, 13, 24, .95);--shadow: 0 4px 6px -1px rgba(0, 0, 0, .4)}[data-theme=forest]{--bg-primary: #0a1f0a;--bg-secondary: #14351a;--bg-tertiary: #1e4d26;--bg-canvas: #061006;--border-primary: #1e4d26;--border-secondary: #22c55e;--text-primary: #dcfce7;--text-secondary: #86efac;--text-muted: #4ade80;--accent-primary: #22c55e;--accent-secondary: #10b981;--accent-gradient: linear-gradient(135deg, #22c55e 0%, #10b981 100%);--accent-text: linear-gradient(135deg, #4ade80 0%, #34d399 100%);--success: #22c55e;--warning: #eab308;--danger: #ef4444;--glass-fill: rgba(34, 197, 94, .15);--glass-stroke: #22c55e;--glass-selected: #16a34a;--grid-color: rgba(74, 222, 128, .1);--grid-major: rgba(74, 222, 128, .25);--hole-fill: rgba(6, 16, 6, .95);--shadow: 0 4px 6px -1px rgba(0, 0, 0, .4)}[data-theme=sunset]{--bg-primary: #1c1210;--bg-secondary: #2d1f1a;--bg-tertiary: #44302a;--bg-canvas: #140d0b;--border-primary: #44302a;--border-secondary: #f97316;--text-primary: #fff7ed;--text-secondary: #fed7aa;--text-muted: #fdba74;--accent-primary: #f97316;--accent-secondary: #ef4444;--accent-gradient: linear-gradient(135deg, #f97316 0%, #ef4444 100%);--accent-text: linear-gradient(135deg, #fb923c 0%, #f87171 100%);--success: #22c55e;--warning: #f59e0b;--danger: #ef4444;--glass-fill: rgba(249, 115, 22, .15);--glass-stroke: #f97316;--glass-selected: #ea580c;--grid-color: rgba(251, 146, 60, .1);--grid-major: rgba(251, 146, 60, .25);--hole-fill: rgba(20, 13, 11, .95);--shadow: 0 4px 6px -1px rgba(0, 0, 0, .4)}[data-theme=purple]{--bg-primary: #1a0a2e;--bg-secondary: #2d1b4e;--bg-tertiary: #44337a;--bg-canvas: #120720;--border-primary: #44337a;--border-secondary: #a855f7;--text-primary: #faf5ff;--text-secondary: #e9d5ff;--text-muted: #c084fc;--accent-primary: #a855f7;--accent-secondary: #ec4899;--accent-gradient: linear-gradient(135deg, #a855f7 0%, #ec4899 100%);--accent-text: linear-gradient(135deg, #c084fc 0%, #f472b6 100%);--success: #22c55e;--warning: #fbbf24;--danger: #ef4444;--glass-fill: rgba(168, 85, 247, .15);--glass-stroke: #a855f7;--glass-selected: #9333ea;--grid-color: rgba(192, 132, 252, .1);--grid-major: rgba(192, 132, 252, .25);--hole-fill: rgba(18, 7, 32, .95);--shadow: 0 4px 6px -1px rgba(0, 0, 0, .4)}[data-theme=contrast]{--bg-primary: #000000;--bg-secondary: #171717;--bg-tertiary: #262626;--bg-canvas: #000000;--border-primary: #404040;--border-secondary: #ffffff;--text-primary: #ffffff;--text-secondary: #d4d4d4;--text-muted: #a3a3a3;--accent-primary: #fbbf24;--accent-secondary: #f59e0b;--accent-gradient: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);--accent-text: linear-gradient(135deg, #fcd34d 0%, #fbbf24 100%);--success: #4ade80;--warning: #fbbf24;--danger: #f87171;--glass-fill: rgba(251, 191, 36, .1);--glass-stroke: #fbbf24;--glass-selected: #f59e0b;--grid-color: rgba(255, 255, 255, .1);--grid-major: rgba(255, 255, 255, .2);--hole-fill: rgba(0, 0, 0, .95);--shadow: 0 4px 6px -1px rgba(255, 255, 255, .1)}*{box-sizing:border-box;margin:0;padding:0}.cad-pro{display:flex;flex-direction:column;height:100vh;background:var(--bg-primary);color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow:hidden}.header{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;background:linear-gradient(180deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);border-bottom:1px solid var(--border-primary);height:52px;flex-shrink:0}.brand{display:flex;align-items:center;gap:.5rem}.logo{width:32px;height:32px;background:var(--accent-gradient);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff}.logo-text{font-weight:700;font-size:1.1rem;background:var(--accent-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.badge{font-size:.6rem;font-weight:600;background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff;padding:2px 6px;border-radius:4px}.header-center,.header-right{display:flex;gap:.5rem}.hdr-btn{display:flex;align-items:center;gap:.4rem;padding:.4rem .75rem;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-primary);font-size:.8rem;cursor:pointer;transition:all .15s}.hdr-btn:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--border-secondary)}.hdr-btn:disabled{opacity:.5;cursor:not-allowed}.hdr-btn.primary{background:var(--accent-gradient);border-color:var(--accent-primary)}.hdr-btn.primary:hover:not(:disabled){filter:brightness(1.1)}.hdr-btn kbd{font-size:.65rem;padding:1px 4px;background:#0000004d;border-radius:3px;margin-left:4px}.theme-selector{position:relative}.theme-btn{display:flex;align-items:center;gap:6px}.theme-name{max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.theme-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:10px;padding:8px;min-width:200px;z-index:1000;box-shadow:0 8px 32px #0006;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.theme-menu-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:4px 8px 8px;border-bottom:1px solid var(--border-primary);margin-bottom:8px}.theme-option{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;background:transparent;border:none;border-radius:6px;color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:all .15s}.theme-option:hover{background:var(--bg-tertiary)}.theme-option.active{background:var(--accent-primary);color:#fff}.theme-preview{width:24px;height:24px;border-radius:6px;border:2px solid var(--border-primary);flex-shrink:0}.theme-preview-dark{background:linear-gradient(135deg,#0f172a,#1e293b,#3b82f6)}.theme-preview-light{background:linear-gradient(135deg,#f8fafc,#e2e8f0,#2563eb)}.theme-preview-midnight{background:linear-gradient(135deg,#0a1628,#132039,#0ea5e9)}.theme-preview-forest{background:linear-gradient(135deg,#0a1f0a,#14351a,#22c55e)}.theme-preview-sunset{background:linear-gradient(135deg,#1c1210,#2d1f1a,#f97316)}.theme-preview-purple{background:linear-gradient(135deg,#1a0a2e,#2d1b4e,#a855f7)}.theme-preview-contrast{background:linear-gradient(135deg,#000,#171717,#fbbf24)}.theme-option-name{flex:1;text-align:left}.theme-check{font-size:.9rem;font-weight:700}.workspace{flex:1;display:flex;position:relative;overflow:hidden}.float-toolbar{position:absolute;left:16px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:4px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:10px;padding:6px;z-index:100;box-shadow:var(--shadow)}.tool-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.tool-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.tool-btn.active{background:var(--accent-primary);color:#fff}.tool-div{height:1px;background:var(--border-primary);margin:4px 0}.canvas-wrap{flex:1;position:relative;background:var(--bg-canvas)}.canvas{width:100%;height:100%;cursor:crosshair}.grid-lines line.grid{stroke:var(--grid-color);stroke-width:1}.grid-lines line.axis{stroke:var(--grid-major);stroke-width:2}.origin line{stroke:var(--border-secondary);stroke-width:1}.origin circle{fill:var(--border-secondary)}.shape-path{cursor:pointer;transition:stroke .15s}.shape-path:hover{stroke:var(--success)}.shape.selected .shape-path{filter:drop-shadow(0 0 8px rgba(5,150,105,.5))}.vertex-handle circle{cursor:move;transition:transform .1s}.vertex-handle:hover circle{transform:scale(1.2)}.vertex-handle text{pointer-events:none;-webkit-user-select:none;user-select:none;font-family:monospace;font-size:11px}.hole{fill:var(--hole-fill);stroke:var(--text-muted);stroke-width:1.5}.custom-hole-element{fill:none;stroke:var(--text-muted);stroke-width:1.5}.hole-group.selected .hole,.hole-group.selected .custom-hole-element{stroke:var(--danger);stroke-width:2}.hole-group.hovered .hole,.hole-group.hovered .custom-hole-element{stroke:#059669}.hole-group.dragging .hole{stroke:#f59e0b}.hole-handle{cursor:move}.drawing-preview polyline,.drawing-preview circle{pointer-events:none}.snap-indicator{pointer-events:none}.snap-indicator circle:first-child{opacity:.6}.drawing-hint{position:absolute;bottom:60px;left:50%;transform:translate(-50%);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;padding:8px 16px;font-size:.8rem;color:var(--text-secondary)}.view-ctrl{position:absolute;bottom:50px;right:16px;display:flex;align-items:center;gap:4px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;padding:4px}.view-ctrl button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:4px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.view-ctrl button:hover{background:var(--bg-tertiary);color:var(--text-primary)}.zoom-lbl{font-size:.75rem;color:var(--text-muted);min-width:40px;text-align:center}.ctrl-div{width:1px;height:20px;background:var(--border-primary);margin:0 4px}.coords{position:absolute;bottom:50px;left:80px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:6px;padding:4px 10px;font-size:.75rem;font-family:SF Mono,Fira Code,monospace;color:var(--text-secondary)}.coords .snap-label{color:var(--success)}.status{position:absolute;bottom:0;left:0;right:0;height:32px;background:var(--bg-secondary);border-top:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between;padding:0 16px;font-size:.75rem;color:var(--text-muted)}.status-left,.status-right{display:flex;gap:16px}.status .dot{display:inline-block;width:6px;height:6px;background:#10b981;border-radius:50%;margin-right:6px}.rotation-hint{color:#f59e0b}.measure-count{color:#10b981;font-weight:500}.measure-hint{background:#10b9811a!important;border-color:#10b981!important;color:#10b981!important}.measurements-layer text{font-family:SF Mono,Fira Code,monospace;text-shadow:0 0 3px rgba(0,0,0,.5)}.tool-btn:disabled{opacity:.4;cursor:not-allowed}.side-panels{width:300px;background:var(--bg-secondary);border-left:1px solid var(--border-primary);display:flex;flex-direction:column;overflow:hidden}.panel{display:flex;flex-direction:column;border-bottom:1px solid var(--border-primary)}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--bg-primary);border-bottom:1px solid var(--border-primary)}.panel-header h3{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin:0;display:flex;align-items:center;gap:8px}.panel-content{padding:12px;overflow-y:auto;max-height:300px}.layers-panel{max-height:220px}.panel-head .count{margin-left:auto;background:#3b82f633;color:var(--accent-primary);font-size:.65rem;padding:2px 6px;border-radius:8px}.layers-list{padding:8px;overflow-y:auto;max-height:180px}.panel-empty.small{padding:20px 12px}.panel-empty.small svg{width:20px;height:20px}.panel-empty.small span{font-size:.8rem}.layer-item{display:flex;align-items:center;gap:8px;padding:8px;border-radius:6px;cursor:pointer;transition:background .15s}.layer-item:hover{background:var(--bg-tertiary)}.layer-item.selected{background:#3b82f633;border:1px solid var(--accent-primary)}.layer-icon{color:var(--accent-primary);flex-shrink:0}.layer-info{font-size:.7rem;color:var(--text-muted);margin-left:auto}.layer-name{font-size:.85rem;color:var(--text-primary)}.layer-meta{font-size:.7rem;color:var(--text-muted)}.vis-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;transition:all .15s}.vis-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.vis-btn.hidden{color:var(--text-muted)}.props-panel{flex:1;overflow:hidden;display:flex;flex-direction:column}.props-panel .panel-content{flex:1;overflow-y:auto;max-height:none}.panel-head{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--bg-primary);border-bottom:1px solid var(--border-primary);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.panel-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 16px;color:var(--text-muted);gap:8px}.panel-empty svg{opacity:.5}.panel-empty span{font-size:.85rem}.prop-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:#3b82f633;border-radius:4px;font-size:.75rem;color:var(--accent-primary);margin-bottom:12px}.prop-section{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border-primary)}.prop-section:last-of-type{border-bottom:none}.prop-section h4{font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin:0 0 10px}.prop-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.prop-row label{font-size:.8rem;color:var(--text-secondary);min-width:60px}.prop-row input,.prop-row select{flex:1;padding:6px 8px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:4px;color:var(--text-primary);font-size:.8rem}.prop-row input:focus,.prop-row select:focus{outline:none;border-color:var(--accent-primary)}.corner-radii{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin-top:8px}.corner-radius-item{display:flex;align-items:center;gap:6px}.corner-radius-item span{font-size:.7rem;color:var(--text-muted);min-width:24px}.corner-radius-item input{flex:1;padding:4px 6px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:4px;color:var(--text-primary);font-size:.75rem}.hole-actions{display:flex;gap:6px;margin-bottom:8px}.btn-add-hole{display:flex;align-items:center;gap:4px;padding:6px 10px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:4px;color:var(--text-secondary);font-size:.75rem;cursor:pointer;transition:all .15s}.btn-add-hole:hover{background:var(--bg-secondary);border-color:var(--border-secondary);color:var(--text-primary)}.btn-add-hole.library{border-color:var(--accent-secondary);color:var(--accent-secondary)}.btn-add-hole.library:hover{background:#7c3aed33}.hole-wrapper{position:relative;margin-bottom:8px}.hole-actions-row{display:flex;gap:4px;position:absolute;top:4px;right:4px}.btn-edit-cutout,.btn-save-to-lib{width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:4px;cursor:pointer;transition:all .15s}.btn-edit-cutout{background:#3b82f633;border:1px solid var(--accent-primary);color:var(--accent-primary)}.btn-edit-cutout:hover{background:var(--accent-primary);color:#fff}.btn-save-to-lib{background:#7c3aed33;border:1px solid var(--accent-secondary);color:var(--accent-secondary)}.btn-save-to-lib:hover{background:var(--accent-secondary);color:#fff}.calc-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.calc-item{display:flex;justify-content:space-between;padding:6px 8px;background:var(--bg-primary);border-radius:4px}.calc-item span:first-child{font-size:.7rem;color:var(--text-muted)}.calc-item span:last-child{font-size:.8rem;color:var(--text-primary);font-family:SF Mono,monospace}.vertices-compact{display:flex;flex-direction:column;gap:4px;max-height:150px;overflow-y:auto}.vertex-compact{display:grid;grid-template-columns:28px 1fr 1fr;gap:4px;align-items:center}.v-label{font-size:.7rem;color:var(--text-muted);font-weight:500}.vertex-compact input{padding:4px 6px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:4px;color:var(--text-primary);font-size:.75rem;font-family:SF Mono,monospace}.vertex-compact input:focus{outline:none;border-color:var(--accent-primary)}.btn-delete{width:100%;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;background:transparent;border:1px solid var(--danger);border-radius:6px;color:var(--danger);font-size:.85rem;cursor:pointer;transition:all .15s;margin-top:16px}.btn-delete:hover{background:var(--danger);color:#fff}.prop-group{margin-bottom:16px}.prop-label{font-size:.7rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.prop-input{width:100%;padding:8px 10px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-primary);font-size:.85rem;transition:border-color .15s}.prop-input:focus{outline:none;border-color:var(--accent-primary)}.prop-input:disabled{opacity:.5}.prop-select{width:100%;padding:8px 10px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-primary);font-size:.85rem;cursor:pointer}.prop-select:focus{outline:none;border-color:var(--accent-primary)}.material-options{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.mat-opt{aspect-ratio:1;border-radius:6px;border:2px solid transparent;cursor:pointer;transition:all .15s}.mat-opt:hover{transform:scale(1.1)}.mat-opt.selected{border-color:var(--accent-primary);box-shadow:0 0 0 2px #3b82f64d}.metrics-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.metric{background:var(--bg-primary);border-radius:6px;padding:8px 10px}.metric-label{font-size:.65rem;color:var(--text-muted);text-transform:uppercase}.metric-value{font-size:.9rem;font-weight:600;color:var(--text-primary);font-family:SF Mono,Fira Code,monospace}.holes-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.hole-item{background:var(--bg-primary);border-radius:6px;border:1px solid var(--border-primary);padding:8px}.hole-item:hover{border-color:var(--border-secondary)}.hole-item.selected{border-color:#dc2626;background:#dc26261a}.hole-header{display:flex;align-items:center;gap:6px;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--border-primary)}.hole-header svg{color:var(--text-muted)}.hole-header span{flex:1;font-size:.75rem;color:var(--text-primary);text-transform:capitalize}.hole-header button{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:2px;border-radius:2px;display:flex;align-items:center;justify-content:center}.hole-header button:hover{background:#dc2626;color:#fff}.hole-params{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.hole-param{display:flex;align-items:center;gap:4px}.hole-param.full{grid-column:span 3}.hole-param label{font-size:.65rem;color:var(--text-muted);min-width:16px;display:flex;align-items:center;justify-content:center}.hole-param input{flex:1;min-width:0;padding:4px 6px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:3px;color:var(--text-primary);font-size:.7rem;font-family:SF Mono,monospace}.hole-param input:focus{outline:none;border-color:var(--accent-primary)}.hole-param select{flex:1;padding:4px 6px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:3px;color:var(--text-primary);font-size:.7rem}.custom-info{font-size:.7rem;color:#a78bfa;font-family:SF Mono,monospace}.mirror-btn{padding:3px 6px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:3px;color:var(--text-secondary);font-size:.65rem;cursor:pointer;transition:all .15s}.mirror-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.hole-icon{width:28px;height:28px;background:var(--bg-secondary);border-radius:4px;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.hole-info{flex:1}.hole-type{font-size:.8rem;color:var(--text-primary);text-transform:capitalize}.hole-coords{font-size:.7rem;color:var(--text-muted);font-family:SF Mono,Fira Code,monospace}.hole-del{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;transition:all .15s}.hole-del:hover{background:#dc2626;color:#fff}.hole-placement{margin-top:12px;padding:12px;background:var(--bg-primary);border-radius:8px;border:1px solid var(--border-primary)}.placement-title{font-size:.75rem;font-weight:600;color:var(--text-secondary);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.placement-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.placement-field{display:flex;flex-direction:column;gap:4px}.placement-field.full{grid-column:span 2}.placement-label{font-size:.7rem;color:var(--text-muted)}.placement-input{padding:6px 8px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:4px;color:var(--text-primary);font-size:.8rem;font-family:SF Mono,Fira Code,monospace}.placement-input:focus{outline:none;border-color:var(--accent-primary)}.action-btns{display:flex;flex-direction:column;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border-primary)}.action-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;border-radius:6px;border:1px solid var(--border-primary);background:var(--bg-primary);color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:all .15s}.action-btn:hover{background:var(--bg-secondary);border-color:var(--border-secondary)}.action-btn.danger{border-color:#dc2626;color:#fca5a5}.action-btn.danger:hover{background:#dc2626;color:#fff}.vertex-editor{margin-top:8px}.vertex-list{max-height:200px;overflow-y:auto}.vertex-row{display:grid;grid-template-columns:24px 1fr 1fr 40px;gap:6px;align-items:center;padding:4px 0}.vertex-label{font-size:.75rem;color:var(--text-muted);font-weight:500}.vertex-input{padding:4px 6px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:4px;color:var(--text-primary);font-size:.8rem;font-family:SF Mono,Fira Code,monospace}.vertex-input:focus{outline:none;border-color:var(--accent-primary)}.radius-input{padding:4px 6px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:4px;color:var(--text-primary);font-size:.75rem;width:100%}.empty-state{text-align:center;padding:32px 16px;color:var(--text-muted)}.empty-icon{width:48px;height:48px;margin:0 auto 12px;background:var(--bg-tertiary);border-radius:12px;display:flex;align-items:center;justify-content:center}.empty-title{font-size:.9rem;color:var(--text-secondary);margin-bottom:4px}.empty-text{font-size:.8rem}.wiz-overlay,.cutout-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;transition:opacity .2s ease-out}.wiz-overlay.visible,.cutout-overlay.visible{opacity:1}.wiz-modal,.cutout-modal{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;box-shadow:0 20px 60px #00000080;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;transform:translateY(20px);opacity:0;transition:all .3s ease-out}.wiz-modal.visible,.cutout-modal.visible{transform:translateY(0);opacity:1}.wiz-modal{width:680px}.wiz-header,.cutout-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--bg-primary);border-bottom:1px solid var(--border-primary)}.wiz-title,.cutout-title{display:flex;align-items:center;gap:10px;color:var(--accent-primary)}.wiz-title h2,.cutout-title h2{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.wiz-close,.cutout-close{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;transition:all .15s;display:flex;align-items:center;justify-content:center}.wiz-close:hover,.cutout-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.wiz-body-split{display:grid;grid-template-columns:1fr 260px;gap:20px;padding:20px}.wiz-form-side{display:flex;flex-direction:column;gap:20px}.wiz-form-side label,.wiz-preview-side label{display:block;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.shape-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.shape-type-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;background:var(--bg-primary);border:2px solid var(--border-primary);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.shape-type-btn:hover{border-color:var(--border-secondary);color:var(--text-primary)}.shape-type-btn.active{border-color:var(--accent-primary);background:#3b82f61a;color:var(--accent-primary)}.shape-type-btn span{font-size:.75rem}.wiz-params{display:flex;flex-direction:column;gap:8px}.param-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.param-row span{font-size:.8rem;color:var(--text-secondary)}.param-row input{width:120px;padding:6px 10px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:4px;color:var(--text-primary);font-size:.85rem;text-align:right;font-family:SF Mono,monospace}.param-row input:focus{outline:none;border-color:var(--accent-primary)}.param-row.highlight{padding:8px;background:#3b82f61a;border-radius:6px;margin-top:8px}.param-row.highlight span{color:var(--accent-primary)}.wiz-material .material-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.material-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px;background:var(--bg-primary);border:2px solid var(--border-primary);border-radius:6px;cursor:pointer;transition:all .15s}.material-btn:hover{border-color:var(--border-secondary)}.material-btn.active{border-color:var(--accent-primary)}.mat-swatch{width:28px;height:28px;border-radius:4px;border:1px solid rgba(255,255,255,.1)}.material-btn span{font-size:.65rem;color:var(--text-secondary);text-align:center}.wiz-preview-side{display:flex;flex-direction:column}.preview-area{flex:1;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;overflow:hidden;min-height:200px}.preview-area svg{width:100%;height:100%}.preview-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}.preview-stats .stat{text-align:center;padding:8px;background:var(--bg-primary);border-radius:6px}.preview-stats .stat span:first-child{display:block;font-size:.65rem;color:var(--text-muted);text-transform:uppercase;margin-bottom:2px}.preview-stats .stat span:last-child{font-size:.85rem;font-weight:600;color:var(--text-primary)}.wiz-footer{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--bg-primary);border-top:1px solid var(--border-primary)}.wiz-note{font-size:.8rem;color:var(--warning)}.wiz-actions{display:flex;gap:8px}.btn-sec,.btn-pri{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s}.btn-sec{background:var(--bg-secondary);border:1px solid var(--border-primary);color:var(--text-primary)}.btn-sec:hover{background:var(--bg-tertiary)}.btn-pri{background:var(--accent-gradient);border:none;color:#fff}.btn-pri:hover{filter:brightness(1.1)}.cutout-modal.library-modal{width:700px}.cutout-body{padding:20px;overflow-y:auto;max-height:calc(90vh - 140px)}.library-categories{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.category-btn{padding:6px 12px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all .15s}.category-btn:hover{border-color:var(--border-secondary);color:var(--text-primary)}.category-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.library-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;max-height:350px;overflow-y:auto;padding:4px}.cutout-card{display:flex;flex-direction:column;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;overflow:hidden;cursor:pointer;transition:all .15s}.cutout-card:hover{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:var(--shadow)}.cutout-preview{aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);padding:12px}.cutout-preview svg{width:100%;height:100%}.cutout-info{padding:8px;border-top:1px solid var(--border-primary)}.cutout-info .name{font-size:.75rem;color:var(--text-primary);text-align:center}.cutout-card-actions{display:flex;justify-content:center;padding:4px;border-top:1px solid var(--border-primary)}.cutout-del-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px 8px;border-radius:4px;font-size:.7rem;transition:all .15s}.cutout-del-btn:hover{background:var(--danger);color:#fff}.import-section{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-primary)}.import-section h4{font-size:.8rem;color:var(--text-secondary);margin:0 0 12px}.import-dropzone{border:2px dashed var(--border-primary);border-radius:8px;padding:24px;text-align:center;cursor:pointer;transition:all .15s}.import-dropzone:hover{border-color:var(--accent-primary);background:#3b82f60d}.import-dropzone input{display:none}.import-dropzone p{margin:0;color:var(--text-muted);font-size:.85rem}.import-dropzone svg{color:var(--text-muted);margin-bottom:8px}.import-preview{margin-top:16px;padding:16px;background:var(--bg-primary);border-radius:8px;border:1px solid var(--border-primary)}.import-preview-title{font-size:.75rem;color:var(--text-secondary);margin-bottom:12px;text-transform:uppercase}.import-preview-canvas{background:#fff;border-radius:6px;padding:12px;margin-bottom:12px}.import-preview-canvas svg{width:100%;height:auto}.import-name-row{display:flex;gap:8px}.import-name-row input{flex:1;padding:8px 10px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-primary);font-size:.85rem}.import-name-row input:focus{outline:none;border-color:var(--accent-primary)}.import-name-row button{padding:8px 16px;background:var(--accent-primary);border:none;border-radius:6px;color:#fff;font-size:.85rem;cursor:pointer;transition:background .15s}.import-name-row button:hover{filter:brightness(1.1)}.cutout-modal.large{width:95vw;max-width:1200px;height:90vh;max-height:800px}.cutout-header-info{display:flex;gap:16px;font-size:.8rem;color:var(--text-muted)}.cutout-header-info span.active{color:var(--accent-secondary)}.cutout-body-advanced{flex:1;display:flex;gap:12px;padding:12px;overflow:hidden;min-height:0}.cutout-toolbar-left{display:flex;flex-direction:column;gap:12px;width:120px;flex-shrink:0;overflow-y:auto;overflow-x:hidden;padding-right:4px;max-height:100%}.cutout-toolbar-left::-webkit-scrollbar{width:4px}.cutout-toolbar-left::-webkit-scrollbar-track{background:transparent}.cutout-toolbar-left::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:2px}.cutout-toolbar-left::-webkit-scrollbar-thumb:hover{background:var(--border-secondary)}.toolbar-section{display:flex;flex-direction:column;gap:3px}.toolbar-section label{font-size:.65rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.tool-btn-adv{display:flex;align-items:center;gap:6px;padding:5px 8px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:5px;color:var(--text-secondary);font-size:.7rem;cursor:pointer;transition:all .15s;text-align:left}.tool-btn-adv svg{width:14px;height:14px;flex-shrink:0}.tool-btn-adv span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tool-btn-adv:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--border-secondary);color:var(--text-primary)}.tool-btn-adv.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.tool-btn-adv:disabled{opacity:.4;cursor:not-allowed}.tool-btn-adv.danger{border-color:#dc2626;color:#fca5a5}.tool-btn-adv.danger:hover{background:#dc2626;color:#fff}.toolbar-btn-row{display:flex;gap:3px}.tool-btn-mini{flex:1;display:flex;align-items:center;justify-content:center;padding:5px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:4px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.tool-btn-mini:hover{background:var(--bg-secondary);border-color:var(--border-secondary);color:var(--text-primary)}.tool-btn-mini svg{width:14px;height:14px}.tool-btn-adv span{flex:1}.cutout-canvas-advanced{flex:1;background:#f8fafc;border-radius:8px;overflow:hidden;position:relative}.cutout-canvas-advanced svg{width:100%;height:100%;cursor:crosshair}.cutout-element{cursor:pointer;transition:stroke .1s}.cutout-element:hover{stroke:#f43f5e!important;stroke-width:5!important}.cutout-element.selected{stroke:var(--danger)!important;stroke-width:2.5!important}.cutout-element.construction{stroke:#a855f7!important;stroke-dasharray:6 4;opacity:.7}.trim-preview{stroke:#dc2626!important;stroke-width:3!important;opacity:.7}.origin-marker line{stroke:#dc2626;stroke-width:2}.origin-marker circle{fill:#dc2626}.cutout-status{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#1e293bf2;font-size:.75rem;color:var(--text-secondary);border-top:1px solid var(--border-primary)}.cutout-status-left{display:flex;gap:16px}.cutout-status .snap-type{color:#10b981}.cutout-status .mode-hint{color:#f59e0b}.cutout-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 20px;background:var(--bg-primary);border-top:1px solid var(--border-primary)}.library-body{padding:16px 20px;overflow-y:auto;max-height:calc(85vh - 140px)}.library-header-actions{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.btn-import-dxf{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all .15s;margin-left:auto}.btn-import-dxf:hover{background:var(--bg-secondary);border-color:var(--border-secondary);color:var(--text-primary)}.import-preview-section{margin-bottom:16px;padding:16px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px}.import-preview-section h3{font-size:.85rem;color:var(--text-primary);margin:0 0 12px}.import-preview-content{display:flex;gap:16px}.import-preview-svg{width:120px;height:120px;background:#fff;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.import-preview-info{flex:1;display:flex;flex-direction:column;gap:8px}.import-stats{display:flex;gap:12px;font-size:.75rem;color:var(--text-muted)}.import-name-input{padding:8px 10px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-primary);font-size:.85rem}.import-name-input:focus{outline:none;border-color:var(--accent-primary)}.import-actions{display:flex;gap:8px;margin-top:auto}.library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px}.library-item{position:relative;display:flex;flex-direction:column;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;overflow:hidden;cursor:pointer;transition:all .15s}.library-item:hover{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.library-item-preview{aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:#fff;padding:8px}.library-item-preview svg{width:100%;height:100%}.library-item-name{padding:8px;font-size:.75rem;color:var(--text-primary);text-align:center;border-top:1px solid var(--border-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.library-item-badge{position:absolute;top:4px;right:4px;font-size:.6rem;padding:2px 5px;border-radius:3px;font-weight:600}.library-item-badge.imported{background:#7c3aed;color:#fff}.library-item-delete{position:absolute;top:4px;left:4px;width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:#dc2626e6;border:none;border-radius:4px;color:#fff;cursor:pointer;opacity:0;transition:opacity .15s}.library-item:hover .library-item-delete{opacity:1}.library-save-section{margin-top:16px;padding:16px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px}.library-save-section h3{font-size:.85rem;color:var(--text-primary);margin:0 0 12px}.save-form{display:flex;gap:8px}.save-form input{flex:1;padding:8px 10px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-primary);font-size:.85rem}.save-form input:focus{outline:none;border-color:var(--accent-primary)}.cutout-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--bg-primary);border-top:1px solid var(--border-primary)}.footer-left .hint{font-size:.8rem;color:var(--text-muted)}.footer-right{display:flex;gap:8px}.cutout-sidebar-right{width:160px;flex-shrink:0;display:flex;flex-direction:column;gap:12px;overflow-y:auto;overflow-x:hidden;max-height:100%}.cutout-sidebar-right::-webkit-scrollbar{width:4px}.cutout-sidebar-right::-webkit-scrollbar-track{background:transparent}.cutout-sidebar-right::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:2px}.sidebar-section{display:flex;flex-direction:column;gap:4px}.sidebar-section label{font-size:.65rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.quick-shape-btn{display:flex;align-items:center;gap:6px;padding:6px 10px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:5px;color:var(--text-secondary);font-size:.7rem;cursor:pointer;transition:all .15s}.quick-shape-btn:hover{background:var(--bg-secondary);border-color:var(--border-secondary);color:var(--text-primary)}.snap-legend{display:flex;flex-direction:column;gap:4px}.snap-item{display:flex;align-items:center;gap:8px;font-size:.7rem;color:var(--text-secondary)}.snap-dot{width:10px;height:10px;border-radius:50%}.snap-dot.endpoint{background:#10b981}.snap-dot.midpoint{background:var(--accent-primary)}.snap-dot.center{background:#f59e0b}.snap-dot.intersection{background:#ef4444}.snap-dot.quadrant{background:#8b5cf6}.snap-dot.perpendicular{background:#06b6d4}.selected-list{display:flex;flex-direction:column;gap:4px;max-height:120px;overflow-y:auto}.selected-item{display:flex;align-items:center;justify-content:space-between;padding:4px 8px;background:var(--bg-primary);border-radius:4px}.element-properties{display:flex;flex-direction:column;gap:6px}.element-properties .prop-type{font-size:.65rem;font-weight:700;color:var(--accent-primary);padding:4px 8px;background:#3b82f61a;border-radius:4px;text-align:center;letter-spacing:1px}.element-properties .prop-row{display:flex;align-items:center;justify-content:space-between;gap:6px}.element-properties .prop-row label{font-size:.65rem;color:var(--text-secondary);min-width:50px;text-transform:none;margin:0}.element-properties .prop-row input[type=number]{width:70px;padding:3px 6px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:4px;color:var(--text-primary);font-size:.7rem;text-align:right}.element-properties .prop-row input[type=number]:focus{outline:none;border-color:var(--accent-primary)}.element-properties .prop-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent-primary);cursor:pointer}.element-properties .prop-row.readonly{opacity:.7}.element-properties .prop-row.readonly span{font-size:.7rem;color:var(--text-muted);font-family:SF Mono,monospace}.element-properties .prop-delete-btn{display:flex;align-items:center;justify-content:center;gap:4px;margin-top:6px;padding:6px;background:transparent;border:1px solid #dc2626;border-radius:4px;color:#f87171;font-size:.7rem;cursor:pointer;transition:all .15s}.element-properties .prop-delete-btn:hover{background:#dc2626;color:#fff}.element-properties input[type=number]::-webkit-inner-spin-button,.element-properties input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.element-properties input[type=number]{-moz-appearance:textfield}font-size: .75rem; color: var(--text-primary); } .selected-item button{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:2px;border-radius:2px}.selected-item button:hover{background:#dc2626;color:#fff}.no-selection{font-size:.75rem;color:var(--text-muted);font-style:italic}.origin-coords{display:flex;gap:12px;font-size:.8rem;font-family:SF Mono,monospace;color:var(--text-primary)}.cutout-status .trim-mode,.cutout-status .extend-mode{color:var(--warning)}.cutout-status .pan-mode{color:var(--accent-primary)}.cutout-status .measure-mode{color:var(--success)}.cutout-status .measurements-count{color:var(--success);font-weight:500}.cutout-status .drawing-hint{color:var(--accent-primary)}.grid-size-input{display:flex;align-items:center;gap:4px;padding:5px 8px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:5px}.grid-size-input label{font-size:.65rem;color:var(--text-secondary);margin:0;white-space:nowrap;text-transform:none}.grid-size-input input{width:36px;padding:2px 4px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:3px;color:var(--text-primary);font-size:.7rem;text-align:center}.grid-size-input input:focus{outline:none;border-color:var(--accent-primary)}.grid-size-input input::-webkit-inner-spin-button,.grid-size-input input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.grid-size-input input[type=number]{-moz-appearance:textfield}.grid-size-input .unit{font-size:.6rem;color:var(--text-muted)}.cutout-view-controls{position:absolute;bottom:40px;right:12px;display:flex;align-items:center;gap:4px;background:#1e293bf2;border:1px solid var(--border-primary);border-radius:6px;padding:4px}.cutout-view-controls button{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:4px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.cutout-view-controls button:hover{background:var(--bg-tertiary);color:var(--text-primary)}.cutout-view-controls .zoom-label{font-size:.7rem;color:var(--text-muted);min-width:36px;text-align:center}.cutout-status{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:6px 12px;background:#1e293bf2;font-size:.75rem;color:var(--text-secondary);border-top:1px solid var(--border-primary)}.cutout-status-left{display:flex;gap:12px}.cutout-status-right{display:flex;gap:16px;color:var(--text-muted)}.dimensions-layer text{font-family:SF Mono,Fira Code,monospace}.preview-dimensions text{font-family:SF Mono,Fira Code,monospace;text-shadow:0 0 3px rgba(0,0,0,.5),0 1px 2px rgba(0,0,0,.3)}.preview-dimensions line{pointer-events:none}.measurements-layer text{font-family:SF Mono,Fira Code,monospace;text-shadow:0 0 3px rgba(0,0,0,.5),0 1px 2px rgba(0,0,0,.3)}.measurements-layer line,.measurements-layer circle{pointer-events:none}.measurement-group{pointer-events:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-secondary)}
