*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.block{display:block}.inline{display:inline}.flex{display:flex}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.border{border-width:1px}.underline{text-decoration-line:underline}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{--bg: #efe9dc;--bg-soft: #f5f0e4;--bg-card: #faf6ec;--bg-inverse: #1f1c16;--fg: #1f1c16;--fg-muted: #6e6657;--fg-faint: #9b9079;--border: #d6cdb9;--border-strong: #b9ad94;--accent: #b88a5a;--accent-ink: #1f1c16;--accent-soft: color-mix(in oklab, var(--accent) 14%, var(--bg));--success: #4f7a4a;--danger: #b85046;--radius-sm: 4px;--radius: 8px;--radius-lg: 14px;--shadow-sm: 0 1px 0 rgba(31,28,22,.04), 0 1px 2px rgba(31,28,22,.04);--shadow: 0 2px 4px rgba(31,28,22,.04), 0 12px 28px -10px rgba(31,28,22,.1);--shadow-lg: 0 4px 8px rgba(31,28,22,.06), 0 28px 56px -16px rgba(31,28,22,.14);--serif: "Instrument Serif", "Times New Roman", serif;--sans: "Geist", "Söhne", system-ui, sans-serif;--mono: "Geist Mono", "JetBrains Mono", ui-monospace, monospace;--container: 1240px;--pad: clamp(20px, 4vw, 56px)}*{box-sizing:border-box}html,body,#root{min-height:100%}html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:var(--sans);font-feature-settings:"ss01","ss02","cv11";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-size:16px;line-height:1.5;letter-spacing:-.005em}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit;color:inherit}img{display:block;max-width:100%}svg{max-width:100%}::-moz-selection{background:var(--accent);color:var(--accent-ink)}::selection{background:var(--accent);color:var(--accent-ink)}.wrap{width:100%;max-width:var(--container);margin:0 auto;padding-inline:var(--pad)}.eyebrow{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-muted)}.eyebrow .dot{display:inline-block;width:6px;height:6px;background:var(--accent);border-radius:50%;margin-right:8px;vertical-align:.12em}h1,h2,h3,h4{margin:0;font-weight:500;letter-spacing:-.025em;line-height:1.04;text-wrap:balance}h1{font-size:clamp(40px,6vw,80px);font-weight:450}h2{font-size:clamp(28px,3.6vw,48px)}h3{font-size:clamp(20px,1.8vw,26px)}h4{font-size:16px;font-weight:500;letter-spacing:-.01em}p{margin:0;text-wrap:pretty}.lede{font-size:18px;line-height:1.55;color:var(--fg-muted);max-width:56ch}.small{font-size:13px;color:var(--fg-muted)}.tiny{font-size:11px;font-family:var(--mono);letter-spacing:.04em;color:var(--fg-muted);text-transform:uppercase}.num-mono{font-family:var(--mono);font-variant-numeric:tabular-nums}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:48px;padding:0 22px;border-radius:var(--radius);border:1px solid transparent;background:var(--bg-inverse);color:var(--bg);font-size:14px;font-weight:500;letter-spacing:-.005em;transition:transform .12s ease,background .15s ease,color .15s ease,border-color .15s ease;white-space:nowrap}.btn:hover{transform:translateY(-1px);background:#2a261d}.btn:active{transform:translateY(0)}.btn.ghost{background:transparent;color:var(--fg);border-color:var(--border-strong)}.btn.ghost:hover{background:var(--bg-soft);border-color:var(--fg)}.btn.accent{background:var(--accent);color:var(--accent-ink)}.btn.accent:hover{background:color-mix(in oklab,var(--accent) 88%,black)}.btn.sm{height:36px;padding:0 14px;font-size:13px}.btn.lg{height:56px;padding:0 28px;font-size:15px}.btn .arrow{display:inline-block;transition:transform .2s ease}.btn:hover .arrow{transform:translate(3px)}.nav{position:sticky;top:0;z-index:50;background:#efe9dcc7;backdrop-filter:saturate(140%) blur(14px);-webkit-backdrop-filter:saturate(140%) blur(14px);border-bottom:1px solid var(--border)}.nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px}.brand{display:flex;align-items:center;gap:10px;font-weight:500;letter-spacing:-.02em;font-size:18px}.brand-mark{width:28px;height:28px;display:grid;place-items:center;background:var(--bg-inverse);color:var(--bg);border-radius:6px}.brand-mark svg{display:block}.nav-links{display:flex;align-items:center;gap:28px}.nav-links a{font-size:14px;color:var(--fg-muted);transition:color .15s ease}.nav-links a:hover{color:var(--fg)}.nav-cta{display:flex;align-items:center;gap:12px}.cart-btn{position:relative;height:38px;width:38px;display:grid;place-items:center;border-radius:8px;background:transparent;border:1px solid var(--border-strong);color:var(--fg)}.cart-btn:hover{background:var(--bg-soft)}.cart-btn .badge{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;border-radius:9px;background:var(--accent);color:var(--accent-ink);font-family:var(--mono);font-size:10px;font-weight:600;display:grid;place-items:center;padding:0 5px;border:1.5px solid var(--bg)}@media (max-width: 720px){.nav-links{display:none}}.footer{margin-top:96px;padding:48px 0 32px;border-top:1px solid var(--border);color:var(--fg-muted);font-size:13px}.footer-grid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:32px;margin-bottom:48px}.footer h4{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--fg);margin-bottom:14px}.footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.footer a:hover{color:var(--fg)}.footer-bottom{display:flex;justify-content:space-between;padding-top:24px;border-top:1px solid var(--border);font-family:var(--mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase}@media (max-width: 720px){.footer-grid{grid-template-columns:1fr 1fr}}.cart-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#1f1c1652;z-index:100;opacity:0;pointer-events:none;transition:opacity .2s ease}.cart-scrim.open{opacity:1;pointer-events:auto}.cart-drawer{position:fixed;top:0;right:0;height:100vh;width:min(440px,92vw);background:var(--bg-card);border-left:1px solid var(--border);box-shadow:var(--shadow-lg);transform:translate(110%);transition:transform .28s cubic-bezier(.2,.7,.2,1);z-index:101;display:flex;flex-direction:column}.cart-drawer.open{transform:translate(0)}.cart-head{display:flex;align-items:center;justify-content:space-between;padding:22px 24px;border-bottom:1px solid var(--border)}.cart-head h3{font-size:18px;letter-spacing:-.02em}.cart-close{width:36px;height:36px;border-radius:8px;background:transparent;border:1px solid var(--border);display:grid;place-items:center}.cart-close:hover{background:var(--bg-soft)}.cart-items{flex:1;overflow-y:auto;padding:8px 24px}.cart-item{display:grid;grid-template-columns:64px 1fr auto;gap:14px;padding:18px 0;border-bottom:1px solid var(--border);align-items:center}.cart-item:last-child{border-bottom:0}.cart-item-thumb{width:64px;height:64px;background:var(--bg);border:1px solid var(--border);border-radius:6px;display:grid;place-items:center;overflow:hidden}.cart-item-thumb svg{width:80%;height:80%}.cart-item-meta{display:flex;flex-direction:column;gap:2px;min-width:0}.cart-item-meta b{font-weight:500;font-size:14px}.cart-item-meta span{font-size:12px;color:var(--fg-muted);font-family:var(--mono)}.cart-item-price{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.cart-item-price b{font-weight:500;font-family:var(--mono);font-variant-numeric:tabular-nums}.cart-item-remove{border:0;background:transparent;font-size:11px;font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase;color:var(--fg-faint)}.cart-item-remove:hover{color:var(--danger)}.cart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:32px;color:var(--fg-muted);gap:16px}.cart-empty svg{opacity:.5}.cart-foot{border-top:1px solid var(--border);padding:22px 24px;display:flex;flex-direction:column;gap:14px}.cart-line{display:flex;justify-content:space-between;align-items:baseline;font-size:13px;color:var(--fg-muted)}.cart-line.total{color:var(--fg);font-size:16px;font-weight:500}.cart-line .num-mono{font-size:14px}.cart-line.total .num-mono{font-size:18px}.config-shell{padding:clamp(28px,5vw,56px) 0 0}.config-head{display:flex;flex-direction:column;gap:14px;margin-bottom:32px}.stepper{display:flex;gap:8px;padding:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:24px;overflow-x:auto}.stepper-item{display:flex;align-items:center;gap:10px;padding:10px 16px;border-radius:8px;font-size:13px;color:var(--fg-muted);white-space:nowrap;flex:1;min-width:-moz-max-content;min-width:max-content}.stepper-item .num{width:22px;height:22px;border-radius:50%;background:var(--bg);border:1px solid var(--border-strong);display:grid;place-items:center;font-family:var(--mono);font-size:11px;color:var(--fg-muted)}.stepper-item.done{color:var(--fg)}.stepper-item.done .num{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.stepper-item.active{color:var(--fg);background:var(--bg)}.stepper-item.active .num{background:var(--fg);color:var(--bg);border-color:var(--fg)}.prep-checklist{border:1px solid var(--border);background:var(--bg-card);border-radius:var(--radius-lg);padding:28px;margin-bottom:24px;display:flex;flex-direction:column;gap:20px}.prep-head{display:flex;flex-direction:column;gap:6px;max-width:64ch}.prep-head h3{font-size:22px;letter-spacing:-.02em}.prep-steps{display:grid;grid-template-columns:1.2fr 1fr;gap:0;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--bg)}.prep-step{padding:18px 18px 20px;border-right:1px solid var(--border);display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;-moz-column-gap:12px;column-gap:12px;row-gap:8px;align-items:start}.prep-step:last-child{border-right:0}.prep-num{grid-row:1;grid-column:1;font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--fg-faint);align-self:center}.prep-icon{grid-row:1;grid-column:2;width:36px;height:36px;display:grid;place-items:center;border-radius:8px;background:var(--bg-soft);border:1px solid var(--border);color:var(--fg);justify-self:end;align-self:center}.prep-body{grid-row:2;grid-column:1 / -1;display:flex;flex-direction:column;gap:4px}.prep-body b{font-weight:500;font-size:15px;color:var(--fg)}.prep-body .small{line-height:1.5}.prep-body .small b{font-family:var(--mono);font-size:11px;font-weight:500;color:var(--fg);background:var(--bg-soft);padding:1px 5px;border-radius:3px;border:1px solid var(--border)}.prep-download{display:inline-flex;align-items:center;gap:10px;align-self:flex-start;padding:10px 14px;border:1px dashed var(--border-strong);border-radius:8px;font-family:var(--mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--fg);background:var(--bg);transition:background .15s ease,border-color .15s ease}.prep-download:hover{background:var(--bg-soft);border-color:var(--fg);border-style:solid}.prep-download.inline{margin-top:8px;padding:8px 12px;font-size:11px;background:var(--bg-inverse);color:var(--bg);border:1px solid var(--bg-inverse);border-style:solid}.prep-download.inline:hover{background:#2a261d;border-color:#2a261d}@media (max-width: 720px){.prep-steps{grid-template-columns:1fr}.prep-step{border-right:0;border-bottom:1px solid var(--border)}.prep-step:last-child{border-bottom:0}}.config-layout{display:grid;grid-template-columns:1.4fr 1fr;gap:24px;align-items:start}@media (max-width: 960px){.config-layout{grid-template-columns:1fr}}.config-canvas{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);position:relative;min-height:520px;overflow:hidden;display:flex;flex-direction:column}.config-canvas-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-muted)}.config-canvas-head .dot{width:8px;height:8px;border-radius:50%;background:var(--fg-faint);display:inline-block;margin-right:8px}.config-canvas-head .dot.live{background:var(--success);animation:pulse 1.6s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.config-canvas-body{flex:1;position:relative;display:flex;align-items:center;justify-content:center;background:linear-gradient(var(--border) 1px,transparent 1px) 0 0/32px 32px,linear-gradient(90deg,var(--border) 1px,transparent 1px) 0 0/32px 32px,var(--bg-card);background-position:-1px -1px;padding:32px}.config-canvas-foot{border-top:1px solid var(--border);padding:14px 20px;display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:11px;color:var(--fg-muted);letter-spacing:.04em}.config-canvas-foot b{color:var(--fg);font-weight:500}.upload-zone{width:100%;max-width:440px;aspect-ratio:4 / 3;border:1.5px dashed var(--border-strong);border-radius:var(--radius-lg);background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:32px;text-align:center;cursor:pointer;transition:border-color .15s ease,background .15s ease}.upload-zone:hover{border-color:var(--fg);background:var(--bg-soft)}.upload-zone.dragover{border-color:var(--accent);background:var(--accent-soft)}.upload-zone .icon{width:44px;height:44px;border-radius:10px;background:var(--bg-soft);border:1px solid var(--border);display:grid;place-items:center;color:var(--fg-muted)}.upload-zone b{font-weight:500;font-size:15px}.upload-zone span{font-size:13px;color:var(--fg-muted)}.upload-zone .formats{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-faint)}.analyzing{display:flex;flex-direction:column;align-items:center;gap:18px;text-align:center;color:var(--fg-muted)}.analyzing .preview-img{max-width:340px;width:100%;border-radius:var(--radius);border:1px solid var(--border);background-color:var(--bg);position:relative;overflow:hidden;line-height:0}.analyzing .preview-img img{width:100%;height:auto;display:block}.analyzing .scan{position:absolute;left:0;right:0;height:2px;background:var(--accent);box-shadow:0 0 16px var(--accent);animation:scan 2s linear infinite}@keyframes scan{0%{top:0}50%{top:100%}to{top:0}}.analyzing .status{font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--fg)}.analyzing .progress{width:200px;height:2px;background:var(--border);border-radius:1px;overflow:hidden}.analyzing .progress:after{content:"";display:block;height:100%;width:40%;background:var(--accent);animation:prog 1.5s ease-in-out infinite}@keyframes prog{0%{transform:translate(-100%)}to{transform:translate(350%)}}.svg-preview{width:100%;display:flex;flex-direction:column;align-items:stretch}.svg-preview>div{overflow:auto}.svg-preview svg{width:100%!important;height:auto!important}.plinth-legend{position:absolute;top:16px;left:20px;display:flex;flex-direction:column;gap:4px;font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-muted)}.plinth-legend b{color:var(--fg);font-weight:500;font-size:11px}.plinth-legend .id{font-family:var(--mono);font-size:10px;color:var(--fg-faint)}.reupload-btn{position:absolute;bottom:16px;right:20px;background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:6px 12px;font-size:11px;font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase;color:var(--fg-muted);white-space:nowrap}.reupload-btn:hover{background:var(--bg-soft);color:var(--fg);border-color:var(--border-strong)}.config-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;display:flex;flex-direction:column;gap:24px;position:sticky;top:88px}.config-panel h3{font-size:22px}.config-panel.locked .locked-state{display:flex;flex-direction:column;align-items:flex-start;gap:10px;padding:22px 0 4px;border-top:1px dashed var(--border-strong)}.config-panel.locked .locked-icon{width:40px;height:40px;border-radius:10px;background:var(--bg);border:1px solid var(--border);display:grid;place-items:center;color:var(--fg-muted);margin-bottom:4px}.config-panel.locked b{font-weight:500;font-size:16px}.config-panel.locked .locked-meta{display:flex;justify-content:space-between;align-items:baseline;border-top:1px dashed var(--border-strong);padding-top:16px;margin-top:-8px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-muted)}.config-panel.locked .locked-meta .num-mono{color:var(--fg)}.field{display:flex;flex-direction:column;gap:10px}.field-label{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-muted)}.field-label .req{color:var(--accent)}.material-options{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.material-opt{border:1px solid var(--border);border-radius:10px;background:var(--bg);padding:10px;display:flex;align-items:center;gap:12px;cursor:pointer;text-align:left;transition:border-color .15s ease,background .15s ease}.material-opt:hover{border-color:var(--border-strong)}.material-opt.selected{border-color:var(--fg);background:var(--bg-card);box-shadow:0 0 0 1px var(--fg)}.material-opt .chip{width:36px;height:36px;border-radius:6px;flex-shrink:0;border:1px solid rgba(0,0,0,.08)}.material-opt .info{display:flex;flex-direction:column;gap:2px;min-width:0}.material-opt b{font-weight:500;font-size:13px}.material-opt span{font-family:var(--mono);font-size:10px;color:var(--fg-muted);letter-spacing:.04em}.material-opt .info span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.slider{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:100%;height:24px;background:transparent}.slider::-webkit-slider-runnable-track{height:4px;background:var(--border);border-radius:2px}.slider::-moz-range-track{height:4px;background:var(--border);border-radius:2px}.slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;background:var(--fg);border:3px solid var(--bg-card);border-radius:50%;margin-top:-8px;box-shadow:0 0 0 1px var(--fg);cursor:pointer}.slider::-moz-range-thumb{width:14px;height:14px;background:var(--fg);border:3px solid var(--bg-card);border-radius:50%;box-shadow:0 0 0 1px var(--fg);cursor:pointer}.slider-row{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;color:var(--fg-faint);letter-spacing:.04em}.qty-input{display:flex;align-items:center;border:1px solid var(--border);border-radius:8px;background:var(--bg);overflow:hidden;width:-moz-max-content;width:max-content}.qty-input button{width:36px;height:36px;background:transparent;border:0;font-size:16px;color:var(--fg)}.qty-input button:hover{background:var(--bg-soft)}.qty-input input{width:56px;height:36px;border:0;background:transparent;text-align:center;font-family:var(--mono);font-size:14px;font-variant-numeric:tabular-nums;outline:none}.price-block{border-top:1px dashed var(--border-strong);padding-top:18px;display:flex;flex-direction:column;gap:10px}.price-row{display:flex;justify-content:space-between;align-items:baseline;font-size:13px;color:var(--fg-muted)}.price-row.total{color:var(--fg);font-size:15px;font-weight:500;margin-top:6px}.price-row.total .amount{font-size:28px;letter-spacing:-.02em}.amount{font-family:var(--mono);font-variant-numeric:tabular-nums}.delivery-note{display:flex;align-items:flex-start;gap:10px;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:12px 14px;font-size:12px;color:var(--fg-muted);line-height:1.5}.delivery-note .icon{flex-shrink:0;color:var(--success)}.download-row{display:flex;flex-wrap:wrap;gap:8px}.toast{position:fixed;top:84px;right:24px;background:var(--bg-inverse);color:var(--bg);padding:14px 18px;border-radius:10px;font-size:13px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-lg);z-index:200;transform:translateY(-10px);opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease}.toast.show{opacity:1;transform:translateY(0)}.toast .check{width:22px;height:22px;border-radius:50%;background:var(--accent);color:var(--accent-ink);display:grid;place-items:center;flex-shrink:0}.hero{padding:clamp(48px,8vw,96px) 0 clamp(56px,10vw,120px);position:relative}.hero-split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(32px,5vw,64px);align-items:center}.hero-centered{display:flex;flex-direction:column;align-items:center;text-align:center;gap:28px}.hero-centered .hero-cta{justify-content:center}.hero-centered .lede{text-align:center}.hero-centered .hero-drawing-wrap{width:100%;max-width:880px;margin-top:16px}.hero-meta{display:flex;flex-wrap:wrap;gap:24px;margin-top:8px;padding-top:24px;border-top:1px solid var(--border)}.hero-meta>div{display:flex;flex-direction:column;gap:2px}.hero-meta b{font-family:var(--mono);font-size:22px;font-weight:500;letter-spacing:-.02em}.hero-meta span{font-size:12px;color:var(--fg-muted)}.hero h1 .accent-word{font-family:var(--serif);font-style:italic;font-weight:400;letter-spacing:-.01em}.hero-tagline{font-family:var(--serif);font-style:italic;font-size:clamp(22px,2.4vw,28px);font-weight:400;color:var(--accent);letter-spacing:-.015em;margin:-8px 0 -10px;line-height:1.1}.hero-centered .hero-tagline{text-align:center}.hero-cta{display:flex;gap:12px;flex-wrap:wrap}@media (max-width: 880px){.hero-split{grid-template-columns:1fr}}.hero-drawing-wrap{position:relative;aspect-ratio:5 / 4;background:linear-gradient(var(--border) 1px,transparent 1px) 0 0/40px 40px,linear-gradient(90deg,var(--border) 1px,transparent 1px) 0 0/40px 40px,var(--bg-card);background-position:-1px -1px;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.hero-drawing-wrap:after{content:"FIG. 01 — KOZIJN + PLINT";position:absolute;bottom:14px;left:16px;font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--fg-faint)}.hero-drawing-wrap .corner{position:absolute;width:14px;height:14px;border:1px solid var(--fg-muted)}.hero-drawing-wrap .corner.tl{top:10px;left:10px;border-right:0;border-bottom:0}.hero-drawing-wrap .corner.tr{top:10px;right:10px;border-left:0;border-bottom:0}.hero-drawing-wrap .corner.bl{bottom:10px;left:10px;border-right:0;border-top:0}.hero-drawing-wrap .corner.br{bottom:10px;right:10px;border-left:0;border-top:0}.hero-drawing{position:absolute;top:0;right:0;bottom:0;left:0;padding:36px}.hero-drawing svg{width:100%;height:100%}.dwg-line{stroke:var(--fg);stroke-width:1.2;fill:none}.dwg-line-thin{stroke:var(--fg-muted);stroke-width:.75;fill:none}.dwg-line-thick{stroke:var(--fg);stroke-width:2;fill:none}.dwg-fill-soft{fill:var(--accent-soft);stroke:var(--accent);stroke-width:1.2}.dwg-hatch,.dwg-dim{stroke:var(--fg-muted);stroke-width:.5;fill:none}.dwg-label{font-family:var(--mono);font-size:9px;fill:var(--fg-muted);letter-spacing:.04em}.dwg-label-bold{font-family:var(--mono);font-size:10px;fill:var(--fg);letter-spacing:.04em;font-weight:500}.dwg-callout{font-family:var(--mono);font-size:10px;fill:var(--accent-ink)}section{padding:clamp(56px,8vw,112px) 0}.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:32px;margin-bottom:48px;flex-wrap:wrap}.section-head .left{max-width:720px;display:flex;flex-direction:column;gap:14px}.section-head .right{color:var(--fg-muted);font-size:14px;max-width:320px}.process{background:var(--bg-card);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg);overflow:hidden}.step{padding:28px 24px 32px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:14px;position:relative;min-height:240px}.step:nth-child(3n){border-right:0}.step:nth-child(n+4){border-bottom:0}.step-num{font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--fg-faint)}.step h3{font-size:20px}.step p{color:var(--fg-muted);font-size:14px;line-height:1.55}.step-visual{margin-top:auto;height:88px;display:flex;align-items:flex-end}.step-visual svg{width:100%;height:100%}@media (max-width: 880px){.steps{grid-template-columns:1fr 1fr}.step:nth-child(3n){border-right:1px solid var(--border)}.step:nth-child(2n){border-right:0}.step:nth-child(n+4){border-bottom:1px solid var(--border)}.step:nth-last-child(-n+2){border-bottom:0}}@media (max-width: 560px){.steps{grid-template-columns:1fr}.step{border-right:0!important;border-bottom:1px solid var(--border)!important}.step:last-child{border-bottom:0!important}}.compare{display:grid;grid-template-columns:1fr 1fr;gap:24px}.compare-card{padding:32px;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-card);display:flex;flex-direction:column;gap:22px;position:relative}.compare-card.win{background:var(--bg-inverse);color:var(--bg);border-color:var(--bg-inverse)}.compare-card.win .compare-list li{color:#ffffffc7}.compare-card.win .compare-list li:before{background:var(--accent);color:var(--accent-ink);content:"+"}.compare-card.win .compare-tag{color:var(--accent);background:#b88a5a29;border-color:#b88a5a52}.compare-card.win h3{color:var(--bg)}.compare-tag{align-self:flex-start;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:4px 8px;background:var(--bg);border:1px solid var(--border-strong);border-radius:4px;color:var(--fg-muted);white-space:nowrap}.compare-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.compare-list li{display:flex;align-items:flex-start;gap:12px;font-size:14px;color:var(--fg-muted);line-height:1.5}.compare-list li:before{content:"–";flex-shrink:0;width:18px;height:18px;border-radius:4px;background:var(--border-strong);color:var(--bg-card);display:grid;place-items:center;font-family:var(--mono);font-size:12px;font-weight:600;margin-top:1px}@media (max-width: 720px){.compare{grid-template-columns:1fr}}.materials-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.material-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-card);overflow:hidden;display:flex;flex-direction:column;transition:border-color .15s ease,transform .15s ease}.material-card:hover{border-color:var(--border-strong);transform:translateY(-2px)}.material-swatch{aspect-ratio:4 / 3;position:relative;overflow:hidden}.material-swatch:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(transparent 70%,#1f1c160f)}.material-meta{padding:16px;display:flex;flex-direction:column;gap:4px}.material-meta b{font-weight:500;font-size:15px}.material-meta span{font-family:var(--mono);font-size:11px;color:var(--fg-muted);letter-spacing:.04em}@media (max-width: 880px){.materials-grid{grid-template-columns:repeat(2,1fr)}}.swatch-white{background:repeating-linear-gradient(115deg,rgba(31,28,22,.025) 0 1px,transparent 1px 5px),#f6f3ec}.swatch-ral9010{background:repeating-linear-gradient(115deg,rgba(255,255,255,.45) 0 1px,transparent 1px 5px),#f3eee2}.swatch-brown{background:repeating-linear-gradient(115deg,rgba(31,28,22,.06) 0 1px,transparent 1px 4px),#6e4d33}.swatch-oak{background:repeating-linear-gradient(115deg,rgba(31,28,22,.08) 0 1px,transparent 2px 6px),linear-gradient(180deg,#c79768,#a87a4f)}.faq-list{display:flex;flex-direction:column;border-top:1px solid var(--border)}.faq-item{border-bottom:1px solid var(--border)}.faq-q{display:flex;align-items:center;justify-content:space-between;gap:24px;width:100%;text-align:left;background:transparent;border:0;padding:24px 4px;font-size:18px;font-weight:500;color:var(--fg);letter-spacing:-.015em}.faq-q .plus{flex-shrink:0;width:28px;height:28px;border-radius:50%;border:1px solid var(--border-strong);display:grid;place-items:center;transition:transform .2s ease,background .15s ease;font-family:var(--mono);font-size:14px;color:var(--fg-muted)}.faq-item.open .plus{transform:rotate(45deg);background:var(--fg);color:var(--bg);border-color:var(--fg)}.faq-a{overflow:hidden;max-height:0;transition:max-height .3s ease}.faq-item.open .faq-a{max-height:320px}.faq-a-inner{padding:0 4px 24px;max-width:70ch;color:var(--fg-muted);line-height:1.6}.cta-banner{background:var(--bg-inverse);color:var(--bg);border-radius:var(--radius-lg);padding:clamp(40px,6vw,72px);display:grid;grid-template-columns:1.4fr auto;gap:32px;align-items:center;position:relative;overflow:hidden}.cta-banner h2{color:var(--bg)}.cta-banner p{color:#ffffffa8;max-width:48ch;margin-top:8px}.cta-banner .btn.accent{color:var(--bg-inverse)}.cta-banner:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 92% 18%,var(--accent) 0%,transparent 36%);opacity:.18;pointer-events:none}@media (max-width: 720px){.cta-banner{grid-template-columns:1fr}}.tag{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:100px;border:1px solid var(--border-strong);background:var(--bg-card);font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-muted);white-space:nowrap}.tag .ping{width:6px;height:6px;background:var(--success);border-radius:50%;box-shadow:0 0 0 3px color-mix(in oklab,var(--success) 22%,transparent)}
