*{box-sizing:border-box;margin:0;padding:0}:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:oklch(17% .012 255);--bg-deep:oklch(13% .012 255);--surface:oklch(22% .013 255);--surface-2:oklch(26% .014 255);--surface-hi:oklch(30% .015 255);--border:oklch(34% .012 255);--border-soft:oklch(28% .011 255);--text:oklch(95% .006 80);--text-2:oklch(72% .012 80);--text-3:oklch(55% .013 80);--text-4:oklch(42% .012 80);--accent:oklch(80% .12 72);--accent-2:oklch(65% .11 72);--accent-hover:oklch(85% .12 72);--accent-soft:oklch(35% .06 72);--accent-glow:oklch(80% .12 72/.15);--danger:oklch(68% .17 30);--danger-bg:oklch(24% .04 20);--danger-bg-hi:oklch(28% .05 20);--info:oklch(72% .1 240);--info-bg:oklch(24% .04 240);--info-bg-hi:oklch(28% .05 240);--ok:oklch(72% .16 150);--ok-bg:oklch(24% .05 150);--ok-bg-hi:oklch(28% .06 150);--warning:oklch(85% .14 90);--warning-bg:oklch(24% .04 80);--tool-active:oklch(78% .12 200);--tool-active-bg:oklch(22% .05 200);--measure:oklch(90% .18 100);--pivot:oklch(65% .22 25);--shadow:0 6px 18px -6px #00000073, 0 1px 3px #0000004d;--shadow-lg:0 24px 48px -12px #0000008c, 0 2px 8px -2px #00000059;--overlay:#0009}[data-theme=paper]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:oklch(95% .012 80);--bg-deep:oklch(91% .014 80);--surface:oklch(97% .008 80);--surface-2:oklch(93% .012 80);--surface-hi:oklch(89% .014 80);--border:oklch(78% .018 70);--border-soft:oklch(85% .014 70);--text:oklch(22% .02 50);--text-2:oklch(40% .018 50);--text-3:oklch(55% .016 50);--text-4:oklch(65% .014 50);--accent:oklch(58% .16 38);--accent-2:oklch(48% .16 38);--accent-hover:oklch(52% .16 38);--accent-soft:oklch(85% .05 38);--accent-glow:oklch(58% .16 38/.12);--danger:oklch(55% .2 25);--danger-bg:oklch(92% .04 25);--danger-bg-hi:oklch(88% .06 25);--info:oklch(52% .14 240);--info-bg:oklch(92% .04 240);--info-bg-hi:oklch(88% .06 240);--ok:oklch(52% .16 150);--ok-bg:oklch(92% .05 150);--ok-bg-hi:oklch(88% .06 150);--warning:oklch(60% .16 80);--warning-bg:oklch(92% .04 80);--tool-active:oklch(50% .14 200);--tool-active-bg:oklch(92% .04 200);--measure:oklch(55% .18 80);--pivot:oklch(55% .22 25);--shadow:0 4px 12px -4px #46321e26;--shadow-lg:0 18px 36px -12px #46321e2e, 0 1px 4px #46321e1a;--overlay:#46321e66}html,body,#root{background:var(--bg-deep);width:100%;height:100%;color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;overflow:hidden}.app{flex-direction:column;width:100%;height:100%;display:flex}.app-header{background:var(--bg);border-bottom:1px solid var(--border-soft);align-items:center;padding:8px 20px;display:flex}.header-left{align-items:center;gap:10px;display:flex}.app-header h1{color:var(--accent);letter-spacing:.5px;margin:0;font-size:18px;font-weight:600}.header-actions{gap:4px;margin-left:auto;display:flex}.btn-history{background:var(--surface);color:var(--accent);border:1px solid var(--border-soft);cursor:pointer;border-radius:4px;padding:4px 12px;font-size:16px;line-height:1;transition:all .12s}.btn-history:hover:not(:disabled){background:var(--border-soft);border-color:var(--accent)}.btn-history:disabled{opacity:.3;cursor:default}.app-body{flex:1;min-height:0;display:flex}.sidebar{background:var(--bg);border-color:var(--border-soft);width:260px;min-width:260px;padding:16px;overflow-y:auto}.sidebar-left{border-right:1px solid var(--border-soft)}.sidebar-right{border-left:1px solid var(--border-soft)}.viewport{flex:1;min-width:0;position:relative}.lumber-catalog h2,.settings-panel h2{text-transform:uppercase;letter-spacing:1px;color:var(--text-3);margin-bottom:12px;font-size:13px;font-weight:600}.settings-section-header{border:none;border-bottom:1px solid var(--border-soft);cursor:pointer;text-align:left;background:0 0;align-items:center;gap:6px;width:100%;padding:8px 0;display:flex}.settings-section-header h2{margin-bottom:0}.settings-section-header:hover h2{color:var(--text-2)}.build-space-settings h3{text-transform:uppercase;letter-spacing:.5px;color:var(--text-3);margin:10px 0 6px;font-size:11px;font-weight:600}.build-space-settings h3:first-child{margin-top:4px}.lumber-list{flex-direction:column;gap:2px;margin-bottom:20px;display:flex}.lumber-category{flex-direction:column;display:flex}.lumber-category-header{background:var(--bg);border:1px solid var(--border);color:var(--text-2);cursor:pointer;text-transform:uppercase;letter-spacing:.5px;border-radius:6px;align-items:center;gap:6px;padding:6px 8px;font-size:12px;font-weight:600;display:flex}.lumber-category-header:hover{background:var(--surface-2);border-color:var(--border)}.lumber-category-header.has-selected{border-color:color-mix(in oklch, var(--accent), transparent 47%);color:var(--text)}.lumber-category-arrow{width:12px;color:var(--text-3);flex-shrink:0;font-size:10px}.lumber-category-label{flex:1}.lumber-category-count{color:var(--text-4);font-size:10px;font-weight:400}.lumber-category-items{flex-direction:column;gap:2px;padding:4px 0 4px 12px;display:flex}.lumber-item{background:var(--surface);cursor:pointer;text-align:left;color:var(--text);border:1px solid #0000;border-radius:6px;align-items:center;gap:10px;padding:6px 8px;transition:all .15s;display:flex}.lumber-item:hover{background:var(--surface-2)}.lumber-item.selected{border-color:var(--accent);background:var(--surface)}.lumber-swatch{border:1px solid var(--border-soft);background-position:50%;background-repeat:no-repeat;background-size:cover;border-radius:4px;flex-shrink:0;width:28px;height:28px}.lumber-info{flex-direction:column;display:flex}.lumber-name{font-size:14px;font-weight:600}.lumber-dims{color:var(--text-3);font-size:11px}.length-input{margin-bottom:16px}.length-input h3{text-transform:uppercase;letter-spacing:1px;color:var(--text-3);margin-bottom:8px;font-size:12px}.length-fields{gap:8px;display:flex}.field{flex:1;align-items:center;gap:4px;display:flex}.field input{background:var(--surface);border:1px solid var(--border-soft);width:100%;color:var(--text);border-radius:4px;padding:6px 8px;font-size:14px}.field input:focus{border-color:var(--accent);outline:none}.field label{color:var(--text-3);min-width:16px;font-size:12px}.length-total{color:var(--text-3);margin-top:6px;font-size:12px}.btn{cursor:pointer;border:none;border-radius:6px;width:100%;padding:10px;font-size:14px;font-weight:600;transition:all .15s}.place-buttons{gap:4px;display:flex}.place-buttons .btn{flex:1}.btn-place{background:var(--accent);color:var(--bg-deep)}.btn-place:hover{background:var(--accent-hover)}.btn-place-end{background:var(--accent-2);color:var(--bg-deep)}.btn-place-end:hover{background:var(--accent-hover)}.btn-cancel{background:var(--border-soft);color:var(--text)}.btn-cancel:hover{background:var(--border)}.btn-rotate{background:var(--info-bg);color:var(--info);padding:6px 10px;font-size:12px}.btn-rotate:hover{background:var(--info-bg-hi)}.btn-delete{background:var(--danger-bg);color:var(--danger);padding:6px 10px;font-size:12px}.btn-delete:hover{background:var(--danger-bg-hi)}.place-actions{flex-direction:column;gap:8px;display:flex}.placing-indicator{background:var(--accent-glow);border:1px solid var(--accent);color:var(--accent);text-align:center;border-radius:6px;padding:8px;font-size:13px}.placing-hint{color:var(--text-3);text-align:center;font-size:12px}.settings-panel{flex-direction:column;gap:16px;display:flex}.settings-grid{grid-template-columns:auto 1fr;align-items:center;gap:8px;display:grid}.settings-grid label{color:var(--text-2);font-size:13px}.settings-grid input[type=number],.settings-grid select{background:var(--surface);border:1px solid var(--border-soft);color:var(--text);border-radius:4px;padding:6px 8px;font-size:13px}.settings-grid input[type=number]:focus,.settings-grid select:focus{border-color:var(--accent);outline:none}.settings-grid input[type=checkbox]{accent-color:var(--accent)}.selected-piece-info p{color:var(--text-2);margin-bottom:10px;font-size:12px}.piece-type-label{font-weight:600;color:var(--text)!important;font-size:14px!important}.edit-length{margin-bottom:10px}.edit-length-label{text-transform:uppercase;letter-spacing:1px;color:var(--text-3);margin-bottom:6px;font-size:12px;display:block}.edit-length .length-fields{align-items:center;gap:6px;display:flex}.edit-length .field input{width:48px;min-width:48px}.btn-apply{background:var(--info-bg);color:var(--info);cursor:pointer;white-space:nowrap;border:none;border-radius:4px;padding:6px 10px;font-size:12px;font-weight:600}.btn-apply:hover{background:var(--info-bg-hi)}.piece-actions{flex-wrap:wrap;gap:6px;display:flex}.piece-actions .btn{flex:1;width:auto}.pt-toggle{margin-bottom:16px}.toggle-label{cursor:pointer;color:var(--text);align-items:center;gap:8px;font-size:14px;display:flex}.toggle-label input[type=checkbox]{accent-color:var(--ok);width:16px;height:16px}.toggle-text{flex:1}.pt-badge{background:var(--ok-bg-hi);color:var(--ok);letter-spacing:.5px;border-radius:3px;padding:2px 6px;font-size:11px;font-weight:700}.supply-list-trigger{z-index:10;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.btn-supply-toggle{background:var(--bg);color:var(--accent);border:1px solid var(--accent);cursor:pointer;white-space:nowrap;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:600;transition:all .15s}.btn-supply-toggle:hover{background:var(--surface)}.supply-list-overlay{background:var(--overlay);z-index:100;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.supply-list-panel{background:var(--bg);border:1px solid var(--border-soft);border-radius:12px;width:600px;max-width:90vw;max-height:85vh;padding:24px;overflow-y:auto}.supply-list-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.supply-list-header h2{color:var(--accent);margin:0;font-size:20px}.btn-close{color:var(--text-3);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:24px;line-height:1}.btn-close:hover{color:var(--text)}.supply-summary{background:var(--surface);border-radius:8px;margin-bottom:20px;padding:16px}.supply-total{justify-content:space-between;align-items:baseline;margin-bottom:8px;display:flex}.total-label{color:var(--text-3);text-transform:uppercase;letter-spacing:1px;font-size:14px}.total-price{color:var(--ok);font-size:28px;font-weight:700}.supply-stats{color:var(--text-3);gap:16px;font-size:13px;display:flex}.supply-section{margin-bottom:20px}.supply-section h3{text-transform:uppercase;letter-spacing:1px;color:var(--text-3);margin-bottom:10px;font-size:13px;font-weight:600}.supply-empty{color:var(--text-3);text-align:center;padding:40px 20px;font-size:14px}.shopping-list{flex-direction:column;gap:4px;display:flex}.shopping-item{background:var(--surface);border-radius:6px;align-items:center;gap:10px;padding:8px 12px;display:flex}.shopping-qty{color:var(--accent);min-width:30px;font-weight:700}.shopping-label{color:var(--text);flex:1;font-size:14px}.shopping-price{color:var(--ok);font-weight:600}.cut-plan{flex-direction:column;gap:10px;display:flex}.cut-board{background:var(--surface);border-radius:6px;padding:10px 12px}.cut-board-header{justify-content:space-between;margin-bottom:6px;display:flex}.cut-board-name{color:var(--text);font-size:13px}.cut-board-price{color:var(--ok);font-size:13px}.cut-bar{background:var(--bg-deep);border-radius:4px;height:24px;display:flex;overflow:hidden}.cut-segment{background:var(--accent);border-right:1px solid var(--bg-deep);justify-content:center;align-items:center;min-width:2px;display:flex}.cut-waste{background:var(--danger-bg);justify-content:center;align-items:center;min-width:2px;display:flex}.cut-label{color:var(--bg-deep);white-space:nowrap;text-overflow:ellipsis;padding:0 4px;font-size:10px;font-weight:600;overflow:hidden}.cut-waste .cut-label{color:var(--danger)}.cut-segment-miter{background:var(--accent);border-left:2px solid var(--pivot);border-right:2px solid var(--pivot)}.cut-miter-notes{flex-direction:column;gap:3px;margin-top:6px;display:flex}.cut-miter-note{align-items:center;gap:8px;font-size:11px;display:flex}.miter-note-length{color:var(--text-2);min-width:48px}.miter-tag{background:var(--warning-bg);color:var(--warning);letter-spacing:.3px;border-radius:3px;padding:1px 6px;font-size:10px;font-weight:600}.piece-buried-info{color:var(--accent-2);font-size:11px;font-weight:600}.piece-miter-info{color:var(--warning);font-size:11px;font-weight:600}.pieces-list{flex-direction:column;gap:2px;display:flex}.piece-row{background:var(--surface);border-radius:4px;justify-content:space-between;padding:6px 12px;font-size:13px;display:flex}.piece-type{color:var(--text)}.piece-length{color:var(--text-3)}.build-dimensions{z-index:10;background:color-mix(in oklch, var(--bg), transparent 15%);border:1px solid var(--border-soft);pointer-events:none;border-radius:8px;padding:10px 14px;position:absolute;top:12px;left:12px}.dim-title{text-transform:uppercase;letter-spacing:1px;color:var(--text-3);margin-bottom:6px;font-size:11px;font-weight:600}.dim-row{align-items:center;gap:8px;margin-bottom:2px;display:flex}.dim-axis{border-radius:3px;justify-content:center;align-items:center;width:16px;height:16px;font-size:11px;font-weight:700;display:flex}.dim-x{background:var(--danger-bg);color:var(--danger)}.dim-y{background:var(--ok-bg);color:var(--ok)}.dim-z{background:var(--border-soft);color:var(--info)}.dim-value{color:var(--text);font-variant-numeric:tabular-nums;font-size:13px;font-weight:600}.miter-controls{margin-bottom:10px}.miter-row{align-items:center;gap:6px;margin-bottom:4px;display:flex}.miter-row label{color:var(--text-2);min-width:32px;font-size:12px}.miter-row input[type=number]{background:var(--surface);border:1px solid var(--border-soft);width:56px;color:var(--text);border-radius:4px;padding:4px 6px;font-size:13px}.miter-row input[type=number]:focus{border-color:var(--accent);outline:none}.miter-row select{background:var(--surface);border:1px solid var(--border-soft);color:var(--text);border-radius:4px;padding:4px 6px;font-size:12px}.miter-row select:focus{border-color:var(--accent);outline:none}.miter-actions{gap:4px;margin-top:6px;display:flex}.btn-miter-action{background:var(--info-bg);color:var(--info);border:1px solid var(--info-bg-hi);flex:1;padding:4px 8px;font-size:11px}.btn-miter-action:hover{background:var(--info-bg-hi)}.btn-miter-clear{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-bg-hi);padding:4px 8px;font-size:11px}.btn-miter-clear:hover{background:var(--danger-bg-hi)}.gizmo-toggle{gap:4px;margin-bottom:10px;display:flex}.btn-gizmo{background:var(--surface);color:var(--text-3);border:1px solid var(--border-soft);padding:6px 12px;font-size:12px}.btn-gizmo:hover{background:var(--surface-2)}.btn-gizmo-active{background:var(--info-bg);color:var(--info);border:1px solid var(--info);padding:6px 12px;font-size:12px}.rotation-inputs{margin-bottom:10px}.rotation-fields{align-items:center;gap:6px;display:flex}.rotation-fields .field input{width:56px;min-width:48px}.align-controls{margin-bottom:10px}.btn-align{background:var(--info-bg);color:var(--info);padding:6px 10px;font-size:12px}.btn-align:hover{background:var(--info-bg-hi)}.auto-miter-info{margin-bottom:10px}.btn-miter{background:var(--ok-bg);color:var(--ok);padding:8px 12px;font-size:13px}.btn-miter:hover{background:var(--ok-bg-hi)}.auto-miter-hint{color:var(--text-3);margin-top:4px;font-size:11px}.lock-toggle{margin-top:6px}.lock-toggle .toggle-label{gap:6px;font-size:12px}.lock-toggle input[type=checkbox]{accent-color:var(--warning);width:14px;height:14px}.pivot-info{background:color-mix(in oklch, var(--pivot), transparent 92%);border:1px solid var(--pivot);border-radius:6px;justify-content:space-between;align-items:center;gap:8px;margin-top:8px;padding:8px 10px;display:flex}.pivot-label{color:var(--danger);font-size:12px;font-weight:600}.lock-info{margin-bottom:10px}.lock-row{justify-content:space-between;align-items:center;gap:6px;padding:3px 0;display:flex}.lock-label{color:var(--warning);font-size:12px}.btn-clear-build{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-bg-hi)}.btn-clear-build:hover:not(:disabled){background:var(--danger-bg-hi);border-color:var(--danger)}.btn-clear-build:disabled{opacity:.3;cursor:default}.tool-buttons-stack{flex-direction:column;gap:4px;display:flex}.tool-buttons-row{grid-template-columns:1fr 1fr;gap:4px;display:grid}.tool-btn-full{width:100%}.tool-buttons-stack .btn{white-space:nowrap;text-align:center;padding:6px 8px;font-size:12px}.btn-tool{background:var(--surface);color:var(--text-3);border:1px solid var(--border-soft)}.btn-tool:hover{background:var(--surface-2);color:var(--text-2)}.btn-tool-active{background:var(--tool-active-bg);color:var(--tool-active);border:1px solid var(--tool-active)}.btn-tool-active:hover{background:var(--tool-active-bg)}.tool-status{background:color-mix(in oklch, var(--tool-active), transparent 94%);border:1px solid var(--tool-active);border-radius:6px;margin-top:8px;padding:10px}.tool-prompt{color:var(--tool-active);text-align:center;margin:0;font-size:13px;font-weight:500}.tool-prompt-step2{color:var(--warning)}.btn-measure{background:var(--info-bg);color:var(--info)}.btn-measure:hover{background:var(--info-bg-hi)}.btn-measure-active{background:var(--info);color:var(--bg-deep)}.btn-measure-active:hover{background:var(--info)}.measure-info{margin-top:8px}.measure-type-select{margin-bottom:10px}.measure-type-select select{background:var(--surface);border:1px solid var(--border-soft);width:100%;color:var(--text);border-radius:4px;padding:6px 8px;font-size:13px}.measure-type-select select:focus{border-color:var(--info);outline:none}.measure-prompt{color:var(--text-2);align-items:center;gap:6px;font-size:13px;display:flex}.measure-dot-a{background:var(--info);border-radius:50%;width:10px;height:10px;display:inline-block}.measure-dot-b{background:#ff4a9e;border-radius:50%;width:10px;height:10px;display:inline-block}.measure-result{background:var(--surface);border-radius:8px;padding:12px}.measure-distance{color:var(--measure);margin-bottom:6px;font-size:24px;font-weight:700}.measure-pieces{color:var(--text-2);align-items:center;gap:8px;font-size:13px;display:flex}.measure-pieces span{align-items:center;gap:4px;display:flex}.measure-label{color:var(--measure);border:1px solid var(--measure);white-space:nowrap;background:#000000d9;border-radius:4px;padding:4px 10px;font-family:system-ui,sans-serif;font-size:14px;font-weight:700}.template-builder{margin-bottom:16px}.template-builder h2{text-transform:uppercase;letter-spacing:1px;color:var(--text-3);margin-bottom:10px;font-size:13px;font-weight:600}.template-search{gap:4px;margin-bottom:4px;display:flex}.template-input{background:var(--surface);border:1px solid var(--border-soft);color:var(--text);border-radius:6px;flex:1;padding:8px 10px;font-size:13px}.template-input:focus{border-color:var(--accent);outline:none}.template-input::placeholder{color:var(--text-4);font-size:12px}.template-browse-btn{background:var(--surface);min-width:36px;color:var(--text-3);border:1px solid var(--border-soft);width:36px!important;padding:0!important;font-size:16px!important}.template-browse-btn:hover{background:var(--surface-2);color:var(--accent)}.template-suggestions{background:var(--bg);border:1px solid var(--border);border-radius:6px;flex-direction:column;margin-bottom:6px;display:flex;overflow:hidden}.template-suggestion{text-align:left;cursor:pointer;border:none;border-bottom:1px solid var(--surface-2);background:0 0;flex-direction:column;padding:8px 10px;transition:background .1s;display:flex}.template-suggestion:last-child{border-bottom:none}.template-suggestion:hover,.template-suggestion.focused{background:var(--surface-2)}.suggestion-name{color:var(--text);font-size:14px;font-weight:600}.suggestion-category{color:var(--text-4);text-transform:uppercase;letter-spacing:.5px;margin-top:1px;font-size:10px}.suggestion-desc{color:var(--text-3);margin-top:2px;font-size:11px}.template-no-results{color:var(--text-4);text-align:center;padding:12px 8px;font-size:12px}.template-browse{flex-direction:column;gap:2px;margin-bottom:8px;display:flex}.browse-header{color:var(--text-3);margin-bottom:2px;padding:4px 0;font-size:12px;font-weight:600}.browse-category-btn{background:var(--surface);color:var(--text-2);cursor:pointer;text-align:left;border:1px solid #0000;border-radius:5px;justify-content:space-between;align-items:center;padding:8px 10px;font-size:13px;display:flex}.browse-category-btn:hover{background:var(--surface-2);border-color:var(--border)}.browse-count{color:var(--text-4);font-size:11px}.browse-back-btn{color:var(--accent);cursor:pointer;text-align:left;background:0 0;border:none;margin-bottom:4px;padding:4px 0;font-size:12px}.browse-back-btn:hover{color:var(--accent-hover)}.browse-template-btn{background:var(--surface);cursor:pointer;text-align:left;border:1px solid #0000;border-radius:5px;flex-direction:column;padding:8px 10px;display:flex}.browse-template-btn:hover{background:var(--surface-2);border-color:var(--border)}.template-editor{background:var(--bg);border:1px solid var(--border-soft);border-radius:8px;margin-top:6px;padding:12px}.template-editor-header{justify-content:space-between;align-items:center;display:flex}.template-editor h3{color:var(--accent);margin:0;font-size:16px;font-weight:600}.template-close{padding:0 4px;font-size:20px;line-height:1}.template-desc{color:var(--text-3);margin:4px 0 10px;font-size:12px}.template-params{flex-direction:column;gap:8px;margin-bottom:12px;display:flex}.template-param{justify-content:space-between;align-items:center;gap:8px;display:flex}.template-param label{color:var(--text-2);flex-shrink:0;font-size:13px}.template-param input[type=number]{background:var(--surface);border:1px solid var(--border-soft);width:70px;color:var(--text);text-align:right;border-radius:4px;padding:5px 6px;font-size:13px}.template-param input[type=number]:focus{border-color:var(--accent);outline:none}.template-param select{background:var(--surface);border:1px solid var(--border-soft);color:var(--text);border-radius:4px;padding:5px 6px;font-size:13px}.template-param select:focus{border-color:var(--accent);outline:none}.param-number{align-items:center;gap:4px;display:flex}.param-unit{color:var(--text-4);min-width:18px;font-size:11px}.param-checkbox input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px}.template-actions{gap:6px;display:flex}.btn-template-generate,.btn-template-add{background:var(--accent);color:var(--bg-deep);flex:1}.btn-template-generate:hover,.btn-template-add:hover{background:var(--accent-hover)}.btn-template-replace{background:var(--accent-soft);color:var(--accent);flex:1}.btn-template-replace:hover{background:var(--accent-soft)}.template-hint{color:var(--text-4);text-align:center;padding:12px 8px;font-size:12px;line-height:1.5}.auth-overlay{background:var(--overlay);z-index:200;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.auth-modal{background:var(--bg);border:1px solid var(--border-soft);border-radius:12px;width:380px;max-width:90vw;padding:24px;position:relative}.auth-close{position:absolute;top:12px;right:12px}.auth-tabs{border-bottom:1px solid var(--border-soft);gap:0;margin-bottom:20px;display:flex}.auth-tab{color:var(--text-3);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:10px 0;font-size:14px;font-weight:600;transition:all .15s}.auth-tab:hover{color:var(--text-2)}.auth-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.auth-form{flex-direction:column;gap:14px;display:flex}.auth-field{flex-direction:column;gap:5px;display:flex}.auth-field label{color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.auth-field input{background:var(--surface);border:1px solid var(--border-soft);color:var(--text);border-radius:6px;padding:10px 12px;font-size:14px;transition:border-color .15s}.auth-field input:focus{border-color:var(--accent);outline:none}.auth-field input::placeholder{color:var(--text-4)}.auth-error{background:color-mix(in oklch, var(--danger), transparent 90%);border:1px solid var(--danger-bg-hi);color:var(--danger);border-radius:6px;padding:10px 12px;font-size:13px}.btn-auth-submit{background:var(--accent);color:var(--bg-deep);margin-top:4px;padding:12px;font-size:15px}.btn-auth-submit:hover:not(:disabled){background:var(--accent-hover)}.btn-auth-submit:disabled{opacity:.5;cursor:default}.header-user{align-items:center;gap:8px;margin-left:16px;display:flex}.header-username{color:var(--text-2);font-size:13px;font-weight:500}.btn-header{background:var(--surface);color:var(--accent);border:1px solid var(--border-soft);cursor:pointer;border-radius:4px;padding:4px 12px;font-size:12px;font-weight:600;transition:all .12s}.btn-header:hover{background:var(--border-soft);border-color:var(--accent)}.btn-header-signin{background:var(--accent);color:var(--bg-deep);border-color:var(--accent)}.btn-header-signin:hover{background:var(--accent-hover)}.btn-header-signout{color:var(--text-3);background:0 0;border-color:#0000}.btn-header-signout:hover{color:var(--danger);background:var(--danger-bg)}.saveload-panel{background:var(--bg);border:1px solid var(--border-soft);border-radius:12px;width:460px;max-width:90vw;max-height:85vh;padding:24px;overflow-y:auto}.saveload-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.saveload-header h2{color:var(--accent);margin:0;font-size:20px}.saveload-success{background:color-mix(in oklch, var(--ok), transparent 90%);border:1px solid var(--ok-bg-hi);color:var(--ok);border-radius:6px;margin-bottom:12px;padding:10px 12px;font-size:13px}.saveload-form{flex-direction:column;gap:14px;display:flex}.saveload-checkbox{color:var(--text-2);cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.saveload-checkbox input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px}.saveload-meta{color:var(--text-4);font-size:12px}.btn-save-new{background:var(--border-soft);color:var(--text-2);font-size:13px}.btn-save-new:hover{background:var(--border)}.saveload-list{flex-direction:column;gap:6px;display:flex}.saveload-loading{color:var(--text-3);text-align:center;padding:20px;font-size:13px}.saveload-empty{color:var(--text-4);text-align:center;padding:30px 16px;font-size:13px}.saveload-item{background:var(--surface);border:1px solid var(--surface-2);border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.saveload-item:hover{border-color:var(--border)}.saveload-item-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.saveload-item-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.saveload-item-meta{color:var(--text-4);font-size:11px}.saveload-item-actions{flex-shrink:0;gap:4px;display:flex}.btn-load{background:var(--info-bg);color:var(--info);width:auto;padding:5px 12px;font-size:12px}.btn-load:hover{background:var(--info-bg-hi)}.btn-delete-small{background:var(--danger-bg);color:var(--danger);width:auto;padding:5px 10px;font-size:12px}.btn-delete-small:hover{background:var(--danger-bg)}.legal-footer{background:color-mix(in oklch, var(--bg), transparent 15%);border-top:1px solid var(--border-soft);border-left:1px solid var(--border-soft);border-right:1px solid var(--border-soft);z-index:50;border-radius:8px 8px 0 0;align-items:center;gap:8px;padding:4px 16px;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.legal-link{color:var(--text-4);cursor:pointer;background:0 0;border:none;padding:2px 4px;font-size:11px;transition:color .15s}.legal-link:hover{color:var(--accent)}.legal-sep{color:var(--border);font-size:11px}.legal-modal{background:var(--bg);border:1px solid var(--border-soft);border-radius:12px;width:640px;max-width:90vw;max-height:85vh;padding:32px;position:relative;overflow-y:auto}.legal-content{color:var(--text-2);font-size:14px;line-height:1.65}.legal-content h2{color:var(--accent);margin:0 0 4px;font-size:22px}.legal-content h3{color:var(--text);margin:20px 0 6px;font-size:15px}.legal-content p{margin:6px 0}.legal-content ul{margin:6px 0;padding-left:20px}.legal-content li{margin:4px 0}.legal-updated{color:var(--text-4);font-size:12px;font-style:italic}.auth-terms{margin-top:4px}.auth-terms-label{color:var(--text-2);cursor:pointer;align-items:flex-start;gap:8px;font-size:13px;display:flex}.auth-terms-label input[type=checkbox]{accent-color:var(--accent);margin-top:3px}.legal-inline-link{color:var(--accent);cursor:pointer;text-underline-offset:2px;background:0 0;border:none;padding:0;font-size:13px;text-decoration:underline}.legal-inline-link:hover{color:var(--accent-hover)}.pricing-modal{background:var(--surface);border-radius:14px;width:600px;max-width:95vw;padding:32px 28px;position:relative;box-shadow:0 20px 60px #00000080}.pricing-modal-wide{width:880px}.pricing-title{text-align:center;color:var(--text);margin:0 0 24px;font-size:22px}.pricing-cards{gap:16px;display:flex}.pricing-card{background:var(--surface-2);border:2px solid #0000;border-radius:10px;flex-direction:column;flex:1;align-items:center;padding:24px 20px;transition:border-color .2s;display:flex}.pricing-card h3{color:var(--text);margin:0 0 8px;font-size:18px}.pricing-card-pro{border-color:var(--accent)}.pricing-card-lifetime{border-color:var(--ok)}.pricing-save-badge{background:var(--accent-glow);color:var(--accent);text-transform:uppercase;letter-spacing:.5px;border-radius:12px;margin-bottom:8px;padding:3px 12px;font-size:11px;font-weight:700}.pricing-save-best{background:color-mix(in oklch, var(--ok), transparent 85%);color:var(--ok)}.pricing-per-month{color:var(--text-3);margin-top:-12px;margin-bottom:16px;font-size:12px}.pricing-warning{text-align:center;background:color-mix(in oklch, var(--danger), transparent 90%);border:1px solid color-mix(in oklch, var(--danger), transparent 70%);color:var(--danger);border-radius:8px;margin-top:16px;padding:10px 16px;font-size:13px}.pricing-current{border-color:var(--border)}.pricing-price{color:var(--text);margin-bottom:16px;font-size:32px;font-weight:700}.pricing-period{color:var(--text-3);font-size:14px;font-weight:400}.pricing-features{width:100%;margin:0 0 20px;padding:0;list-style:none}.pricing-features li{color:var(--text-2);border-bottom:1px solid var(--border-soft);padding:6px 0;font-size:13px}.pricing-features li:last-child{border-bottom:none}.pricing-features li:before{content:"✓ ";color:var(--accent);font-weight:700}.pricing-badge{background:var(--border-soft);color:var(--text-3);border-radius:20px;margin-bottom:8px;padding:4px 14px;font-size:12px;font-weight:600}.pricing-badge-pro{background:var(--accent-glow);color:var(--accent)}.pricing-badge-warn{color:var(--danger);background:#dc783c26}.btn-pricing-primary{background:var(--accent);color:var(--bg);cursor:pointer;border:none;border-radius:8px;margin-top:auto;padding:10px 24px;font-size:14px;font-weight:600;transition:background .2s}.btn-pricing-primary:hover{background:var(--accent-hover)}.btn-pricing-secondary{color:var(--text-2);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:8px;margin-top:8px;padding:8px 20px;font-size:13px;transition:border-color .2s,color .2s}.btn-pricing-secondary:hover{border-color:var(--accent);color:var(--text)}.donate-modal{background:var(--surface);border-radius:14px;width:400px;max-width:95vw;padding:32px 28px;position:relative;box-shadow:0 20px 60px #00000080}.donate-title{text-align:center;color:var(--text);margin:0 0 8px;font-size:20px}.donate-desc{text-align:center;color:var(--text-3);margin:0 0 20px;font-size:13px}.donate-presets{gap:10px;margin-bottom:16px;display:flex}.btn-donate-preset{border:2px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:8px;flex:1;padding:12px 0;font-size:16px;font-weight:600;transition:border-color .2s,background .2s}.btn-donate-preset:hover{border-color:var(--accent);background:var(--accent-glow)}.btn-donate-preset:disabled{opacity:.5;cursor:not-allowed}.donate-custom{align-items:stretch;gap:10px;display:flex}.donate-custom-input{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;flex:1;align-items:center;padding:0 12px;display:flex}.donate-dollar{color:var(--text-3);margin-right:4px;font-size:16px}.donate-custom-input input{color:var(--text);background:0 0;border:none;outline:none;flex:1;width:80px;padding:10px 0;font-size:15px}.donate-custom-input input::placeholder{color:var(--text-4)}.btn-donate-custom{background:var(--accent);color:var(--bg);cursor:pointer;border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:background .2s}.btn-donate-custom:hover{background:var(--accent-hover)}.btn-donate-custom:disabled{opacity:.5;cursor:not-allowed}.btn-header-donate{border:1px solid var(--danger);color:var(--danger);background:0 0;border-radius:6px;padding:4px 12px;font-size:13px}.btn-header-donate:hover{background:color-mix(in oklch, var(--danger) 12%, transparent)}.btn-header-upgrade{background:var(--accent);color:var(--bg);border:none;border-radius:6px;padding:4px 14px;font-size:13px;font-weight:600}.btn-header-upgrade:hover{background:var(--accent-hover)}.btn-pro-badge{background:linear-gradient(135deg, var(--accent), var(--accent-2));color:var(--bg);letter-spacing:1px;cursor:pointer;border:none;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:700}.btn-pro-badge:hover{background:linear-gradient(135deg, var(--accent-hover), var(--accent-2))}.template-locked{position:relative}.template-locked-overlay{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:32px 16px;display:flex}.template-locked-icon{margin-bottom:12px;font-size:36px}.template-locked-overlay p{color:var(--text-2);margin:0;font-size:14px}.template-locked-price{color:var(--text-3)!important;margin-top:4px!important;margin-bottom:16px!important;font-size:13px!important}.toast{background:var(--accent);color:var(--bg);cursor:pointer;z-index:9999;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:600;animation:.3s ease-out toast-in;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #0006}@keyframes toast-in{0%{opacity:0;transform:translate(-50%)translateY(20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@media (width<=900px){.pricing-cards{flex-wrap:wrap}.pricing-card{min-width:calc(50% - 12px)}.pricing-modal-wide{width:600px}}@media (width<=600px){.pricing-cards{flex-direction:column}.pricing-card{min-width:100%}.pricing-modal,.pricing-modal-wide{width:95vw;padding:20px 16px}}.lshape-controls{border-top:1px solid var(--border-soft);margin-top:8px;padding:8px 0}.lshape-toggle{color:var(--text-2);cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.lshape-toggle input[type=checkbox]{accent-color:var(--accent)}.lshape-params{flex-direction:column;gap:6px;margin-top:8px;display:flex}.lshape-corner{align-items:center;gap:8px;display:flex}.lshape-corner label{color:var(--text-3);min-width:48px;font-size:12px}.lshape-corner select{background:var(--surface-2);border:1px solid var(--border);color:var(--text);border-radius:4px;flex:1;padding:3px 6px;font-size:12px}.lshape-dims{gap:8px;display:flex}.lshape-dims .field{flex:1}.lshape-dims .field input{width:100%}.lshape-dims .field label{font-size:11px}.cut-sheet-overlay{background:var(--overlay);z-index:5000;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.cut-sheet-panel{background:var(--bg);border-radius:12px;width:90vw;max-width:1000px;max-height:85vh;padding:24px;position:relative;overflow-y:auto;box-shadow:0 20px 60px #00000080}.cut-sheet-header{align-items:center;gap:16px;margin-bottom:20px;display:flex}.cut-sheet-header h2{color:var(--text);margin:0;font-size:20px}.cut-sheet-summary{color:var(--text-2);flex:1;gap:8px;font-size:13px;display:flex}.cut-sheet-sep{color:var(--border)}.cut-sheet-close{position:absolute;top:16px;right:16px}.cut-sheet-empty{text-align:center;color:var(--text-4);padding:40px;font-size:14px}.cut-sheet-grid{flex-direction:column;gap:24px;display:flex}.cut-sheet-diagram{background:var(--bg);border-radius:8px;padding:12px}.cut-sheet-label{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.cut-sheet-label-name{color:var(--text);font-size:14px;font-weight:600}.cut-sheet-label-info{color:var(--text-3);font-size:12px}.cut-sheet-svg{margin:0 auto;display:block}.cut-sheet-piece-label{pointer-events:none;font-family:monospace;font-weight:600}.btn-cutsheet{background:var(--accent);width:100%;color:var(--bg);cursor:pointer;border:none;border-radius:8px;padding:10px;font-size:14px;font-weight:600;transition:background .2s}.btn-cutsheet:hover{background:var(--accent-hover)}.gallery-overlay{background:var(--overlay);z-index:1000;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.gallery-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:min(900px,95vw);max-height:85vh;padding:24px;overflow-y:auto}.gallery-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.gallery-header h2{color:var(--text);margin:0;font-size:20px}.gallery-loading,.gallery-empty{text-align:center;color:var(--text-3);padding:40px 0;font-size:15px}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.gallery-card{background:var(--border-soft);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:12px;padding:16px;transition:border-color .15s;display:flex}.gallery-card:hover{border-color:var(--accent)}.gallery-card-thumb{background:var(--bg);border-radius:4px;justify-content:center;align-items:center;min-height:100px;display:flex;overflow:hidden}.gallery-card-thumb img{object-fit:contain;width:100%;max-height:140px}.gallery-card-info{flex-direction:column;gap:4px;display:flex}.gallery-card-name{color:var(--text);font-size:15px;font-weight:600}.gallery-card-author{color:var(--accent);font-size:13px}.gallery-card-desc{color:var(--text-2);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:13px;line-height:1.4;display:-webkit-box;overflow:hidden}.gallery-card-meta{color:var(--text-4);margin-top:4px;font-size:12px}.btn-gallery-load{background:var(--accent);color:var(--bg);cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-size:13px;font-weight:600;transition:background .15s}.btn-gallery-load:hover{background:var(--accent-hover)}.btn-gallery-load:disabled{opacity:.6;cursor:default}.gallery-pagination{border-top:1px solid var(--border-soft);justify-content:center;align-items:center;gap:16px;margin-top:20px;padding-top:16px;display:flex}.gallery-page-info{color:var(--text-2);font-size:13px}.btn-gallery-page{background:var(--border-soft);color:var(--text);border:1px solid var(--border);cursor:pointer;border-radius:6px;padding:6px 14px;font-size:13px;transition:background .15s}.btn-gallery-page:hover:not(:disabled){background:var(--border)}.btn-gallery-page:disabled{opacity:.4;cursor:default}.btn-header-gallery{color:var(--accent)!important}@media (width<=600px){.gallery-grid{grid-template-columns:1fr}.gallery-panel{padding:16px}}.notes-section{border-top:1px solid var(--border-soft);margin-top:12px;padding-top:8px}.notes-textarea{background:var(--surface);width:100%;color:var(--text);border:1px solid var(--border-soft);resize:vertical;box-sizing:border-box;border-radius:4px;outline:none;min-height:60px;max-height:200px;padding:8px;font-family:inherit;font-size:12px}.notes-textarea:focus{border-color:var(--accent)}.notes-textarea::placeholder{color:var(--text-4)}.connector-section{border-top:1px solid var(--border-soft);margin-top:12px;padding-top:8px}.connector-add{align-items:center;gap:6px;display:flex}.connector-type-select{background:var(--surface);color:var(--text);border:1px solid var(--border-soft);border-radius:4px;outline:none;flex:1;padding:4px 6px;font-size:12px}.connector-type-select:focus{border-color:var(--accent)}.connector-list{flex-direction:column;gap:3px;max-height:150px;margin-top:6px;display:flex;overflow-y:auto}.connector-item{background:var(--surface);border:1px solid var(--border-soft);border-radius:4px;justify-content:space-between;align-items:center;padding:4px 8px;font-size:12px;display:flex}.connector-item-label{color:var(--text);flex-direction:column;gap:1px;display:flex}.connector-item-pieces{color:var(--text-4);font-size:10px}.connector-add-form{flex-direction:column;gap:4px;display:flex}.connector-row{align-items:center;gap:4px;display:flex}.connector-row select{flex:1;min-width:0}.supply-tabs{border-bottom:1px solid var(--border-soft);gap:0;margin-bottom:12px;display:flex}.supply-tab{color:var(--text-3);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:8px 12px;font-size:13px;font-weight:600;transition:all .15s}.supply-tab:hover{color:var(--text)}.supply-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.instructions-content{overflow-y:auto}.instructions-list{flex-direction:column;gap:3px;display:flex}.instruction-item{border-bottom:1px solid var(--surface);align-items:baseline;gap:8px;padding:4px 0;font-size:12px;display:flex}.instruction-label{color:var(--accent);flex-shrink:0;min-width:32px;font-weight:700}.instruction-detail{color:var(--text);flex:1}.instruction-miter{color:var(--danger);font-size:11px}.instruction-notes{color:var(--text);white-space:pre-wrap;background:var(--surface);border:1px solid var(--border-soft);border-radius:4px;max-height:200px;padding:8px;font-size:12px;overflow-y:auto}.theme-toggle{background:var(--surface-2);border:1px solid var(--border-soft);border-radius:999px;flex-shrink:0;align-items:center;gap:0;height:28px;padding:2px;display:inline-flex}.theme-seg{height:100%;color:var(--text-2);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:999px;align-items:center;gap:5px;padding:0 11px;font-family:inherit;font-size:12.5px;font-weight:500;line-height:1;transition:color .12s,background .12s;display:inline-flex}.theme-seg:hover{color:var(--text)}.theme-seg.active{background:var(--accent);color:var(--bg-deep);font-weight:600}.theme-seg svg{flex-shrink:0}body,.app-header,.sidebar,.panel,.btn-header,.btn-history{transition:background-color .15s,color .15s,border-color .15s}
