*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0}.calc-root [hidden]{display:none!important}.calc-root label{margin:0}.calc-root:not(.is-booted) .calc-config,.calc-root:not(.is-booted) .price-bar{opacity:0;transition:opacity .25s ease}.calc-root.is-booted .calc-config,.calc-root.is-booted .price-bar{opacity:1;transition:opacity .4s ease .05s}.calc-root:not(.is-booted) .preview-empty-hint{opacity:0}.boot-loader{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--ink-3);font-size:13px;pointer-events:none;opacity:1;transition:opacity .3s ease}.calc-root.is-booted .boot-loader{opacity:0;pointer-events:none}.boot-loader-spinner{width:24px;height:24px;border:2px solid var(--line);border-top-color:var(--ink);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.calc-root{--bg: #ffffff;--surface: #ffffff;--surface-2: #f5f5f3;--ink: #111111;--ink-2: #3a3a3a;--ink-3: #6b6b6b;--font-sans: "Poppins", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--fs-xs: 12px;--fs-sm: 13px;--fs-base: 14px;--fs-lg: 16px;--fs-xl: 20px;--fs-2xl: 28px;--lh-tight: 1.25;--lh-normal: 1.5;--line: #e5e5e1;--line-2: #d4d4cf;--line-strong: #000000;--accent: #f6416c;--accent-ink: #ffffff;--accent-soft: rgba(246, 65, 108, .08);--mustard: #c7b232;--teal: #027580;--grey: #dadada;--shadow-sm: 0 1px 0 rgba(0, 0, 0, .05);--shadow-md: 0 2px 0 rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .1);--radius-sm: 0;--radius: 0;--radius-lg: 0;--radius-pill: 0;font-family:Poppins,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;color:var(--ink);background:var(--bg);min-height:100vh;display:flex;flex-direction:column}@media(min-width:1024px){.calc-root{height:100vh;height:100dvh;min-height:0;overflow:hidden}.calc-root.calc-shopify{height:88vh;height:88dvh;height:var(--calc-shopify-height, 88dvh)}}@media(max-width:1023px){.calc-root.calc-shopify{min-height:90vh;min-height:90dvh}}body{background:var(--bg)}.calc-top{display:none}.piece-strip{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.piece-strip-list{display:flex;flex-direction:column;align-items:stretch;gap:6px;min-width:0;max-height:320px;overflow-y:auto;scrollbar-width:thin;-webkit-overflow-scrolling:touch}.piece-chip{display:grid;grid-template-columns:auto 1fr auto;grid-template-areas:"thumb body delete";gap:8px 10px;align-items:stretch;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-sm);padding:8px 10px;cursor:pointer;transition:border-color .15s ease,background .15s ease;width:100%;min-width:0}.piece-chip:hover{border-color:var(--ink-3)}.piece-chip.is-active{border-color:var(--ink);background:var(--surface);box-shadow:0 0 0 1px var(--ink)}.piece-chip-thumb{grid-area:thumb;width:44px;height:44px;border-radius:3px;background:var(--surface-2) center/cover no-repeat;border:1px solid var(--line);align-self:start}.piece-chip.is-active .piece-chip-thumb{width:56px;height:56px}@media(max-width:1023px){.piece-chip{padding:6px 8px;gap:6px 8px}.piece-chip-thumb{width:36px;height:36px}.piece-chip.is-active .piece-chip-thumb{width:44px;height:44px}.piece-chip-row-bottom{margin-top:2px;padding-top:6px}}.piece-chip-body{grid-area:body;display:flex;flex-direction:column;gap:8px;min-width:0;justify-content:center}.piece-chip-row-top{display:flex;align-items:flex-start;gap:10px;min-width:0}.piece-chip-row-bottom{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:4px;padding-top:8px;border-top:1px solid var(--line-2)}.piece-chip-row-bottom:empty{display:none}.piece-chip-badges{display:flex;flex-direction:column;gap:3px;align-items:flex-end;flex-shrink:0}.piece-chip-meta{display:flex;flex-direction:column;min-width:0;flex:1;gap:1px}.piece-chip-titlerow{display:flex;align-items:center;gap:4px;min-width:0}.piece-chip-title{font-size:13px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0;padding:1px 4px;margin:0 -4px;border-radius:2px;cursor:text;outline:none}.piece-chip-title:hover{background:#0000000a}.piece-chip-title:focus{background:#f6416c1a;box-shadow:inset 0 0 0 1px var(--accent)}.piece-chip-pencil{background:transparent;border:0;padding:2px;color:var(--ink-3);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;border-radius:2px;flex-shrink:0;transition:color .15s ease,background .15s ease}.piece-chip-pencil:hover{color:var(--ink);background:#0000000a}.piece-chip-pencil svg{display:block}.piece-chip-sub{font-family:var(--font-mono);font-size:var(--fs-sm);font-feature-settings:"zero" 1;color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.piece-chip-detail{font-size:var(--fs-sm);color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.piece-chip-qty{display:inline-flex;align-items:center;gap:0;border:1px solid var(--line);border-radius:3px;overflow:hidden}.piece-chip-qty-btn{background:transparent;border:0;width:22px;height:24px;font-family:IBM Plex Mono,ui-monospace,monospace;font-size:14px;font-weight:600;line-height:1;color:var(--ink-2);cursor:pointer;transition:background .15s ease,color .15s ease}.piece-chip-qty-btn:hover{background:var(--ink);color:#fff}.piece-chip-qty-val{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:24px;font-family:IBM Plex Mono,ui-monospace,monospace;font-size:12px;font-weight:600;font-feature-settings:"zero" 1;color:var(--ink);background:var(--surface-2);border-left:1px solid var(--line);border-right:1px solid var(--line)}.piece-chip-recrop{background:var(--ink);border:1px solid var(--ink);color:#fff;cursor:pointer;height:32px;padding:0 14px;display:inline-flex;align-items:center;gap:6px;font:inherit;font-size:var(--fs-sm);font-weight:500;letter-spacing:0;transition:background .15s ease}.piece-chip-recrop:hover{background:#000}.piece-chip-recrop svg{flex-shrink:0}.piece-chip-removeimg{background:transparent;border:1px solid var(--line);color:var(--ink-2);cursor:pointer;height:32px;padding:0 12px;display:inline-flex;align-items:center;gap:6px;font:inherit;font-size:var(--fs-sm);font-weight:500;letter-spacing:0;transition:border-color .15s ease,color .15s ease,background .15s ease}.piece-chip-removeimg:hover{border-color:var(--accent);color:var(--accent);background:#f6416c0f}.piece-chip-removeimg svg{flex-shrink:0}.piece-chip-dpi{flex-shrink:0;display:inline-flex;align-items:center;white-space:nowrap;font-family:var(--font-mono);font-size:var(--fs-xs);font-feature-settings:"zero" 1;letter-spacing:0;padding:3px 10px;border-radius:999px;background:var(--surface);border:1px solid var(--line);color:var(--ink-2)}.piece-chip-dpi[data-band=ok]{color:#146d3d;border-color:#b6dec4;background:#ebf6ee}.piece-chip-dpi[data-band=warn]{color:#8a6315;border-color:#e9d4a3;background:#fbf3df}.piece-chip-dpi[data-band=low]{color:#a01818;border-color:#e6b8b8;background:#fbe7e7}.visually-hidden{position:absolute!important;clip:rect(0 0 0 0);width:1px;height:1px;overflow:hidden;padding:0;margin:-1px;border:0}.piece-chip-delete{background:transparent;border:0;color:var(--ink-3);cursor:pointer;padding:2px 4px;border-radius:3px;font-size:14px;line-height:1;margin-left:4px;transition:color .15s ease,background .15s ease}.piece-chip-delete:hover{color:var(--accent);background:#f6416c14}.piece-add-btn{display:flex;align-items:center;justify-content:center;gap:6px;background:transparent;border:1px dashed var(--ink-3);border-radius:var(--radius-sm);padding:8px 14px;font:inherit;font-size:12px;font-weight:600;color:var(--ink-2);cursor:pointer;width:100%;transition:border-color .15s ease,color .15s ease,background .15s ease}.piece-add-btn:hover{border-color:var(--ink);color:var(--ink);background:var(--bg)}.calc-brand{display:flex;align-items:center;gap:12px}.brand-mark{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;background:var(--accent);color:var(--accent-ink);border-radius:0;font-family:Poppins,sans-serif;font-weight:700;font-size:13px;letter-spacing:.5px}.brand-label{font-family:Poppins,sans-serif;font-weight:600;font-size:15px;letter-spacing:.2px}@media(max-width:520px){.brand-label{display:none}.calc-top{padding:12px 14px}.btn-primary,.btn-ghost{padding:12px 18px;font-size:14px;min-height:44px}}.calc-top-actions{display:flex;gap:8px}.btn-primary{display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;background:var(--ink);color:#fff;border:0;border-radius:var(--radius-pill);font:inherit;font-weight:600;font-size:14px;cursor:pointer;transition:transform .15s ease,background .2s ease,box-shadow .2s ease;letter-spacing:.01em}.btn-primary:hover{background:#000;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-ghost{display:inline-flex;align-items:center;justify-content:center;padding:9px 16px;background:transparent;color:var(--ink);border:1px solid var(--line);border-radius:var(--radius-pill);font:inherit;font-weight:500;font-size:14px;cursor:pointer;transition:border-color .15s ease,background .15s ease}.btn-ghost:hover{border-color:var(--ink);background:var(--surface-2)}.btn-link{background:transparent;border:0;padding:4px 0;color:var(--ink);font:inherit;font-size:13px;font-weight:500;cursor:pointer;text-decoration:underline;text-underline-offset:3px}.btn-link:hover{color:var(--accent)}.btn-link-danger{color:#b3261e}.calc-stage{flex:1;min-height:0;display:grid;grid-template-columns:minmax(0,1fr);grid-template-areas:"preview" "form" "summary";gap:0;width:100%;margin:0;padding:0}@media(min-width:1024px){.calc-stage{overflow:hidden}}.calc-stage section+section{margin-top:0}@media(min-width:1024px){.calc-stage{grid-template-columns:minmax(380px,.42fr) minmax(0,1fr);grid-template-rows:1fr auto;grid-template-areas:"form preview" "form summary";gap:0;align-items:stretch}}@media(min-width:1280px){.calc-stage{grid-template-columns:minmax(380px,.42fr) minmax(0,1fr) minmax(320px,.36fr);grid-template-rows:1fr;grid-template-areas:"form preview summary"}}@media(min-width:1600px){.calc-stage{grid-template-columns:380px minmax(0,1fr) 360px}}.calc-form{grid-area:form}.calc-preview{grid-area:preview}.calc-summary{grid-area:summary}.calc-preview{position:relative;background:var(--surface);border-bottom:1px solid var(--line-strong);display:flex;flex-direction:column;min-height:180px;max-height:30vh;min-width:0;overflow-x:hidden}@media(min-width:1024px){.calc-preview{height:100%;min-height:0;max-height:none;border-right:1px solid var(--line-strong);border-bottom:0;overflow:hidden}}.render-section{position:relative;flex:1;min-height:0;background:#efeeea;display:flex;flex-direction:column;align-items:stretch;justify-content:stretch;padding:0;border-bottom:1px solid var(--line-strong)}.preview-frame{position:relative;flex:1;min-height:0;width:100%;display:flex;align-items:center;justify-content:center;padding:0}#previewSvg{width:100%;height:100%}#previewSvg,#previewSvg *{transition:x .32s cubic-bezier(.4,0,.2,1),y .32s cubic-bezier(.4,0,.2,1),width .32s cubic-bezier(.4,0,.2,1),height .32s cubic-bezier(.4,0,.2,1),d .32s cubic-bezier(.4,0,.2,1),fill .25s ease,transform .32s cubic-bezier(.4,0,.2,1)}.calc-root.is-scene-switching #previewSvg,.calc-root.is-scene-switching #previewSvg *{transition:none!important}.calc-root[data-scene=diagram] #pieceGroup,.calc-root[data-scene=diagram] #dimensionLayer,.calc-root[data-scene=diagram] .preview-empty-hint,.calc-root[data-scene=diagram] #scaleRef{display:none!important}.calc-root[data-scene=diagram] #previewSvg{visibility:visible!important}#iso3dCanvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:none;cursor:grab;z-index:1;touch-action:none}#iso3dCanvas:active{cursor:grabbing}.calc-root[data-scene=iso] #iso3dCanvas{display:block}.calc-root[data-scene=iso] #pieceGroup,.calc-root[data-scene=iso] #sceneBg{display:none}.calc-root[data-scene=iso] #previewSvg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;pointer-events:none;background:transparent;visibility:visible!important}.calc-root[data-scene=iso] #previewSvg #dimensionLayer{pointer-events:auto}.preview-empty-hint{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:stretch;justify-content:stretch;padding:0;opacity:0;pointer-events:none;transition:opacity .3s ease}.calc-root[data-image=none] .preview-empty-hint{opacity:1;pointer-events:auto}.calc-root[data-image=sample] .preview-empty-hint,.calc-root[data-image=user] .preview-empty-hint{display:none}.upload-zone-preview{width:100%;height:100%;margin:0;padding:0;border:1.5px dashed var(--ink-3);background:transparent;display:flex;align-items:center;justify-content:center}.calc-root[data-image=none] #previewSvg{visibility:hidden}.calc-root[data-image=none] .preview-tag{display:none}.upload-zone-preview .upload-empty{display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--ink);text-align:center}.upload-zone-preview .upload-empty svg{color:var(--ink-2)}.upload-zone-preview .upload-empty p:first-of-type{font-family:var(--font-mono);font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase}.upload-zone-preview .upload-empty .upload-sub{font-size:12px;color:var(--ink-3)}.upload-zone-preview.is-dragging{border-style:solid;border-color:var(--accent);background:#f6416c0a}.upload-filled-bar{width:100%;background:var(--surface-2);padding:10px 12px;margin-top:4px}.upload-filled-bar[hidden]{display:none}.upload-filled-bar .upload-filled{display:flex;align-items:center;gap:12px}.upload-filled-bar .upload-filled img{width:56px;height:56px;object-fit:cover;background:var(--surface-2);flex-shrink:0}.upload-filled-bar .upload-meta{flex:1;min-width:0}.upload-filled-bar .upload-fname{margin:0;font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upload-filled-bar .upload-fsize{margin:2px 0 0;font-size:11px;color:var(--ink-3)}.upload-filled-bar .upload-dpi{margin:4px 0 0;font-size:10px;font-weight:600;letter-spacing:.02em;display:inline-flex;align-items:center;gap:6px;padding:2px 7px;width:fit-content}.upload-filled-bar .upload-actions{display:flex;gap:12px;flex-shrink:0}.preview-tag{position:absolute;bottom:12px;left:50%;transform:translate(-50%);background:#111111d9;color:#fff;padding:6px 12px;border-radius:var(--radius-pill);font-size:12px;font-weight:600;letter-spacing:.02em;font-variant-numeric:tabular-nums;display:inline-flex;align-items:center;gap:5px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.preview-tag span{opacity:.7}.preview-toggle{position:absolute;top:14px;left:50%;transform:translate(-50%);z-index:5;display:inline-flex;background:#ffffffdb;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid rgba(0,0,0,.08);padding:4px;box-shadow:0 2px 8px #0000000f}.scene-btn{background:transparent;border:0;padding:7px 14px;font:inherit;font-size:13px;font-weight:500;color:var(--ink-2);border-radius:var(--radius-pill);cursor:pointer;transition:background .2s ease,color .2s ease}.scene-btn.is-active{background:var(--ink);color:#fff}.preview-3d-controls{position:absolute;bottom:14px;left:50%;transform:translate(-50%);z-index:5;display:inline-flex;gap:4px;background:#ffffffe0;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid rgba(0,0,0,.08);padding:4px;box-shadow:0 2px 8px #0000000f}.preview-3d-btn{display:inline-flex;align-items:center;gap:6px;background:transparent;border:0;padding:6px 12px;font:inherit;font-size:12px;font-weight:500;color:var(--ink-2);border-radius:var(--radius-pill);cursor:pointer;transition:background .15s ease,color .15s ease}.preview-3d-btn:hover{background:#0000000f;color:var(--ink)}.preview-3d-btn .icon-play{display:none}.preview-3d-btn .icon-pause{display:inline}.preview-3d-btn[aria-pressed=true] .icon-pause{display:none}.preview-3d-btn[aria-pressed=true] .icon-play{display:inline}.preview-3d-zoom{display:inline-flex;gap:0;margin-left:6px;padding-left:6px;border-left:1px solid rgba(0,0,0,.08)}.preview-3d-zoom-btn{padding:6px 10px;min-width:32px;justify-content:center}.preview-3d-zoom-pct{font-variant-numeric:tabular-nums;font-size:11px;letter-spacing:.03em;min-width:30px;text-align:center}.dim-tooltip{position:fixed;background:#111;color:#fff;padding:9px 13px;font-family:Poppins,sans-serif;font-size:12px;line-height:1.45;max-width:280px;z-index:1000;pointer-events:none;letter-spacing:.015em;box-shadow:0 4px 14px #00000026}.dim-tooltip[hidden]{display:none}.dim-tooltip strong{display:block;font-weight:600;font-size:13px;margin-bottom:3px}.dim-tooltip .dim-tip-sku{display:block;margin-top:7px;padding-top:6px;border-top:1px solid rgba(255,255,255,.16);color:#ffffffb8;font-size:11px;letter-spacing:.02em}.dim-group{cursor:help}.dims-toggle-row{margin-top:10px}.dims-toggle-row[hidden]{display:none}.dims-toggle{display:inline-flex;align-items:center;gap:6px;background:transparent;border:1px solid var(--line-2);padding:7px 14px;font:inherit;font-size:var(--fs-sm);font-weight:500;letter-spacing:0;color:var(--ink-2);cursor:pointer;transition:background .2s ease,color .2s ease,border-color .2s ease}.dims-toggle:hover{border-color:var(--ink-3);color:var(--ink)}.dims-toggle.is-active{background:#027580;border-color:#027580;color:#fff}.render-card{position:absolute;bottom:18px;z-index:4;background:#fffffff0;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(0,0,0,.08);box-shadow:0 4px 16px #00000014;display:flex;flex-direction:column;max-width:min(46%,420px)}.render-card-specs{left:18px;width:220px;max-width:220px}.render-card-diagram{right:18px;width:240px}.render-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border-bottom:1px solid var(--line-2)}.render-card[aria-expanded=false] .render-card-head{border-bottom:0}.render-card[aria-expanded=false] .render-card-body{display:none}.render-card-head-end{display:flex;align-items:center;gap:12px}.render-card-title{font-family:Poppins,sans-serif;font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3)}.render-card-toggle{background:transparent;border:0;width:22px;height:22px;font-size:18px;line-height:1;color:var(--ink-2);cursor:pointer;padding:0;display:inline-flex;align-items:center;justify-content:center}.render-card-toggle:hover{color:var(--ink)}.render-card[aria-expanded=false] .render-card-toggle span:before{content:"+"}.render-card[aria-expanded=false] .render-card-toggle span{font-size:0}.render-card[aria-expanded=false] .render-card-toggle span:before{font-size:18px}.render-card-body{padding:10px 14px 14px;overflow:auto;max-height:50vh}.specs-title{font-family:Poppins,sans-serif;font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3)}.dims-switch{display:inline-flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.dims-switch[hidden]{display:none}.dims-switch-label{font-size:var(--fs-sm);font-weight:500;letter-spacing:0;text-transform:none;color:var(--ink-2)}.dims-switch input{position:absolute;opacity:0;width:0;height:0}.dims-switch-track{display:inline-block;width:36px;height:20px;background:var(--line);border-radius:0;position:relative;transition:background .2s ease;flex-shrink:0}.dims-switch-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;transition:transform .2s cubic-bezier(.34,1.56,.64,1);box-shadow:var(--shadow-sm)}.dims-switch input:checked+.dims-switch-track{background:#027580}.dims-switch input:checked+.dims-switch-track .dims-switch-thumb{transform:translate(16px)}.specs-list table{width:100%;border-collapse:collapse;font-size:13px;table-layout:fixed}.specs-list td{padding:6px 0;font-size:12.5px;font-variant-numeric:tabular-nums}.specs-list td:first-child{color:var(--ink-2);font-weight:500;text-align:left;padding-right:10px;white-space:normal;line-height:1.3;width:44%;vertical-align:top}.specs-list td:last-child{color:var(--ink);font-weight:600;text-align:right;white-space:normal;line-height:1.3;vertical-align:top;word-break:keep-all;-webkit-hyphens:none;hyphens:none}.specs-list tr+tr td{border-top:1px solid var(--line-2)}.specs-diagram{width:100%;aspect-ratio:200 / 140;display:flex;align-items:center;justify-content:center}.specs-diagram svg{width:100%;height:100%}.specs-diagram .sd-frame{fill:none;stroke:var(--ink-2);stroke-width:1.2}.specs-diagram .sd-mat{fill:none;stroke:var(--ink-3);stroke-width:.8;stroke-dasharray:2 2}.specs-diagram .sd-art{fill:#0000000a;stroke:var(--ink-2);stroke-width:1}.specs-diagram .sd-dim,.specs-diagram .sd-tick{fill:none;stroke:var(--ink-2);stroke-width:.6}.specs-diagram .sd-label{font-family:JetBrains Mono,Roboto Mono,monospace;font-size:8px;fill:var(--ink-2)}.specs-body table{width:100%;border-collapse:collapse;font-size:13px}.specs-body td{padding:6px 0;font-variant-numeric:tabular-nums;vertical-align:top}.specs-body td:first-child{color:var(--ink-2);text-align:left;font-weight:500;padding-right:18px;width:45%;white-space:nowrap}.specs-body td:last-child{color:var(--ink);text-align:right;font-weight:600}.specs-body tr+tr td{border-top:1px solid var(--line-2)}.calc-config{background:var(--bg);padding:24px 18px 180px;display:flex;flex-direction:column;gap:12px}@media(min-width:1024px){.calc-config{padding:24px;overflow-y:scroll;scrollbar-gutter:stable;height:100%;min-height:0;border-right:1px solid var(--line-strong)}}.calc-summary{background:var(--bg);display:flex;flex-direction:column;gap:0}@media(min-width:1024px){.calc-summary{padding:24px 20px 0;overflow-y:scroll;scrollbar-gutter:stable;height:100%;min-height:0;border-left:1px solid var(--line-strong)}}.summary-panel{background:var(--surface);border:1px solid var(--line-2);border-radius:0;display:flex;flex-direction:column}.summary-panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px 10px;border-bottom:1px solid var(--line-2)}.summary-panel-title{font-family:var(--font-sans);font-size:var(--fs-base);font-weight:600;letter-spacing:-.005em;text-transform:none;color:var(--ink)}.summary-panel-head-end{display:flex;align-items:center;gap:12px}.summary-section-meta{margin:0;font-size:10.5px;color:var(--ink-3);display:inline-flex;align-items:center;gap:5px}.summary-section-meta .dot{display:inline-block;width:5px;height:5px;background:var(--mustard);border-radius:0;animation:pulse 2s ease-in-out infinite}.summary-panel-body{padding:4px 0 10px}.summary-panel-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border-bottom:1px solid var(--line-2)}.summary-panel-toolbar[hidden]{display:none}.summary-panel-toolbar-label{font-size:12px;font-weight:500;color:var(--ink-2);letter-spacing:0;text-transform:none}.merged-group{padding:10px 14px 6px}.merged-group+.merged-group{border-top:1px solid var(--line)}.merged-group.is-nested{padding-left:28px;padding-top:6px;padding-bottom:4px}.merged-group.is-nested+.merged-group.is-nested,.merged-group:not(.is-nested)+.merged-group.is-nested{border-top:1px dashed var(--line-2, var(--line))}.merged-group.is-nested .merged-group-title,.merged-group.is-nested .merged-group-price{font-size:var(--fs-sm);font-weight:500;color:var(--ink-2)}.merged-group-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:4px}.merged-group-title{font-family:var(--font-sans);font-size:var(--fs-base);font-weight:600;letter-spacing:-.005em;color:var(--ink)}.merged-group-price{font-size:var(--fs-base);font-weight:600;font-variant-numeric:tabular-nums;color:var(--ink)}.merged-group-rows{width:100%;border-collapse:collapse;table-layout:fixed}.merged-group-rows td{padding:4px 0;font-size:var(--fs-sm);font-variant-numeric:tabular-nums;line-height:var(--lh-normal);vertical-align:top;color:var(--ink-2)}.merged-group-rows td:first-child{width:44%;padding-right:10px}.merged-group-rows td:last-child{text-align:right;color:var(--ink);font-weight:500;word-break:keep-all}.merged-totals{width:100%;border-collapse:collapse;table-layout:fixed;margin:4px 0 0;border-top:1px solid var(--ink);padding:0}.merged-totals td{padding:6px 14px;font-size:var(--fs-sm);font-variant-numeric:tabular-nums;color:var(--ink-2)}.merged-totals td:first-child{width:60%}.merged-totals td:last-child{text-align:right;font-weight:600;color:var(--ink)}.merged-totals tr.row-final td{padding-top:10px;padding-bottom:12px;font-size:var(--fs-base);border-top:1px solid var(--line)}.merged-totals tr.row-final td:last-child{font-weight:700;color:var(--ink)}@media(min-width:1024px)and (max-width:1279px){.calc-summary{border-left:0;border-top:1px solid var(--line-strong);max-height:45vh}.calc-stage{grid-template-rows:minmax(55vh,1fr) auto}}.calc-summary .price-breakdown{margin-top:0}@media(min-width:1024px){.calc-summary .price-bar{margin:16px -20px 0}.calc-summary .price-bar-inner{grid-template-columns:1fr;grid-template-rows:auto auto}.calc-summary .price-summary{border-right:0;border-bottom:1px solid var(--line-2);padding:12px 16px}.calc-summary .price-total{font-size:20px}.calc-summary .price-bar-actions{display:grid;grid-template-columns:1fr 1fr;gap:0}.calc-summary .btn-share-strip{padding:14px 8px;font-size:13px}}@media(min-width:1024px)and (max-width:1279px){.calc-summary .price-bar{margin:16px 0 0}}.calc-tabs{display:flex;gap:6px;padding:6px;margin:0 0 16px;background:var(--surface-2, #f5f4ef);border:1px solid var(--line);border-radius:0}.calc-tab{flex:1;-webkit-appearance:none;appearance:none;background:transparent;border:1px solid transparent;color:var(--ink-2);font-family:inherit;font-size:13px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:10px 12px;border-radius:0;cursor:pointer;transition:background-color .12s ease,color .12s ease,border-color .12s ease}.calc-tab:hover:not(.is-active){color:var(--ink)}.calc-tab.is-active{background:var(--surface);border-color:var(--line-2);color:var(--ink)}.calc-tab:focus-visible{outline:2px solid var(--ink);outline-offset:2px}@media(max-width:1023px){.calc-tabs{margin:0 -14px 12px;padding:8px 14px;border-radius:0;border-left:0;border-right:0;background:var(--surface, #fff);box-shadow:0 1px 0 var(--line-2)}.calc-tab{min-height:48px;padding:14px 12px}.piece-chip-qty-btn{min-width:44px;min-height:44px}.cropper-aspect-chip{min-height:44px}.scene-btn{min-height:44px;padding:12px 14px}}.calc-config.is-tab-print .step-frame,.calc-config.is-tab-print .step-delivery,.calc-config.is-tab-frame .step-print,.calc-config.is-tab-frame .step-delivery,.calc-config.is-tab-delivery .step-print,.calc-config.is-tab-delivery .step-frame{display:none}.step{background:var(--surface);border:1px solid var(--line-2);border-radius:0;padding:18px;transition:border-color .2s ease}.step:focus-within{border-color:var(--ink)}.step-head{display:flex;align-items:center;gap:10px;min-height:28px;flex-wrap:nowrap}.step-num{font-family:var(--font-mono);font-weight:500;font-size:var(--fs-sm);letter-spacing:0;color:var(--ink-3);flex-shrink:0}.step-title{margin:0;font-size:var(--fs-lg);font-weight:600;letter-spacing:-.01em;color:var(--ink);white-space:nowrap;flex-shrink:0}.step-head .info-tip,.step-head .toggle{flex-shrink:0;margin-left:0}.step-head>.step-summary+.info-tip,.step-head>.step-title+.info-tip{margin-left:auto}.calc-root h2,.calc-root h3{color:var(--ink)}.calc-root .price-eyebrow{color:var(--ink-3)}.calc-root .price-total{color:var(--ink)}.calc-root .specs-head,.calc-root .dims-head,.calc-root .step-summary,.calc-root .step-num,.calc-root .size-note,.calc-root .upload-sub,.calc-root .catalog-meta{color:var(--ink-3)}.calc-root .specs-body td,.calc-root .price-breakdown td{color:var(--ink-2)}.calc-root .specs-body td:last-child,.calc-root .price-breakdown td:last-child{color:var(--ink)}.step-summary{display:block;margin:6px 0 0;padding-left:32px;font-size:var(--fs-base);color:var(--ink-2);font-weight:400;letter-spacing:0;font-variant-numeric:tabular-nums;line-height:var(--lh-tight);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.step-body{padding-top:16px}.step-body[hidden]{display:none}.step-frame-headless>.step-body{padding-top:0}.step-head{flex-direction:column;align-items:stretch;gap:6px;min-height:0;padding-bottom:12px;border-bottom:1px solid var(--line)}.step-head:has(.step-collapse-btn[aria-expanded=false]){border-bottom:none;padding-bottom:0}.step-head:has(.step-collapse-btn[aria-expanded=true])>.step-summary,.step-head:has(.step-collapse-btn[aria-expanded=true])~.step-summary{display:none}.step-head-row{display:flex;align-items:center;gap:10px}.step-head>.step-num{align-self:flex-start;font-family:inherit;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#fff;background:var(--accent);padding:2px 7px;border-radius:3px}.step-head .step-title{flex:0 0 auto}.step-head-row>.info-tip{margin-left:0}.step-head-row>.step-collapse-btn{margin-left:auto}.step-head>.step-summary,.step>.step-summary{margin:0;padding-left:0;font-size:var(--fs-base);font-weight:600;color:var(--ink);text-align:left;white-space:normal;overflow:visible;text-overflow:clip}dl.step-summary{display:flex;flex-direction:column;gap:0;margin:0;padding:0}.step-summary-row{display:flex;align-items:baseline;gap:12px;margin:0;padding:6px 0;border-bottom:1px solid var(--line)}.step-summary-row:has(+.step-summary-row.is-sub){border-bottom:none;padding-bottom:0}.step-summary-row.is-sub{padding-top:2px;padding-bottom:2px}.step-summary-row.is-sub:has(+.step-summary-row.is-sub){border-bottom:none}.step-summary-row.is-sub:not(:has(+.step-summary-row.is-sub)){padding-bottom:6px}.step-summary-row:last-child{border-bottom:none;padding-bottom:0}.step-summary-row dt{flex-shrink:0;min-width:136px;font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-2);line-height:1.35}.step-summary-row dd{margin:0;font-size:var(--fs-base);font-weight:400;color:var(--ink);line-height:1.35}.step-summary-row.is-sub dt{padding-left:14px;font-weight:600;letter-spacing:.04em}.step-collapse-btn{flex-shrink:0;background:transparent;border:1px solid var(--line);color:var(--ink-2);width:32px;height:32px;border-radius:999px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;transition:transform .15s ease,border-color .15s ease,color .15s ease,background .15s ease}.step-collapse-btn:hover{border-color:var(--ink-2);color:var(--ink);background:var(--surface-2)}.step-collapse-btn[aria-expanded=true]{transform:rotate(180deg)}.step-collapse-btn svg{width:14px;height:14px}.step-sub{padding:16px 0 0;margin-top:12px;border-top:1px dashed var(--line-2)}.step-print,.step-frame-headless{background:transparent;border:0;padding:0}.step-print>.step-body,.step-frame-headless>.step-body{padding:0}.step-print .step-sub,.step-frame-headless .step-sub{background:var(--surface);border:1px solid var(--line-2);padding:16px 18px;margin-top:12px;border-top:1px solid var(--line-2)}.step-print .step-sub:first-of-type,.step-frame-headless .step-sub:first-of-type{margin-top:0;padding-top:16px}.floatlift-sub{background:transparent!important;border:0!important;padding:0!important;margin-top:14px!important;border-top:0!important}.floatlift-sub>.medium-finish-row.is-boxed{margin-top:0}.floatlift-sub #floatLiftEdgeAnchor:empty{display:none}.floatlift-sub #floatLiftEdgeAnchor>.step-sub{background:transparent!important;border:0!important;padding:12px 0 0!important;margin-top:12px!important;border-top:1px dashed var(--line-2)!important}.floatlift-sub #floatLiftEdgeAnchor>.step-sub>.step-sub-head{margin-bottom:6px}.floatlift-sub #floatLiftEdgeAnchor>.step-sub>.step-body{padding:0}.step-sub-head{display:flex;align-items:center;gap:10px;flex-wrap:nowrap;min-height:24px;margin-bottom:10px}.step-sub:has(>.step-body[hidden])>.step-sub-head{margin-bottom:0}.step-sub-eyebrow{font-family:var(--font-sans);font-weight:600;font-size:var(--fs-base);letter-spacing:-.005em;text-transform:none;color:var(--ink);flex-shrink:0}.step-sub-summary{display:block;margin:4px 0 0;font-size:var(--fs-base);color:var(--ink-2);font-weight:400;font-variant-numeric:tabular-nums;line-height:var(--lh-tight);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.step-sub-head .info-tip,.step-sub-head .toggle{flex-shrink:0;margin-left:0}.step-sub-head .toggle{width:28px;height:16px}.step-sub-head .toggle-thumb{top:2px;left:2px;width:12px;height:12px}.step-sub-head .toggle input:checked+.toggle-track .toggle-thumb{transform:translate(12px)}.step-sub-collapse-btn{flex-shrink:0;margin-left:0;background:transparent;border:1px solid var(--line);color:var(--ink-2);width:22px;height:22px;border-radius:999px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;transition:transform .15s ease,border-color .15s ease,color .15s ease}.step-sub-collapse-btn:hover{border-color:var(--ink-2);color:var(--ink)}.step-sub-collapse-btn[aria-expanded=true]{transform:rotate(180deg)}.step-sub.is-collapsible .step-sub-head{margin-bottom:0}.step-sub.is-collapsible .step-sub-collapse-body{padding-top:10px}.step-sub.is-collapsible .step-sub-collapse-body[hidden]{display:none}.frame-style-disclosure{margin-bottom:8px}.frame-style-btn{width:100%;display:inline-flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);padding:10px 12px;cursor:pointer;font:inherit;text-align:left;transition:border-color .15s ease,background .15s ease}.frame-style-btn:hover{border-color:var(--ink-2)}.frame-style-btn-label{font-family:var(--font-sans);font-weight:500;font-size:var(--fs-sm);letter-spacing:0;text-transform:none;color:var(--ink);flex-shrink:0}.frame-style-btn-current{flex:1 1 0;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:var(--fs-base);color:var(--ink-2);font-variant-numeric:tabular-nums}.frame-style-btn svg{flex-shrink:0;transition:transform .15s ease}.frame-style-btn[aria-expanded=true] svg{transform:rotate(180deg)}.step-sub-head>.step-sub-summary+.info-tip,.step-sub-head>.step-sub-eyebrow+.info-tip{margin-left:auto}.step-sub:first-of-type{padding-top:0}.frame-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.frame-card{background:var(--surface);border:1px solid var(--line);padding:4px;cursor:pointer;display:flex;flex-direction:column;gap:4px;text-align:left;font:inherit;transition:border-color .15s ease,background .15s ease,transform .15s ease}.frame-card:hover{border-color:var(--ink-3)}.frame-card.is-active{border-color:var(--ink);box-shadow:0 0 0 1px var(--ink);background:var(--surface)}.frame-card-swatch{width:100%;aspect-ratio:1;display:block}.frame-card-meta{display:flex;flex-direction:column;gap:1px}.frame-card-name{font-size:var(--fs-xs);font-weight:600;color:var(--ink);line-height:var(--lh-tight)}.frame-card-variant{font-size:var(--fs-xs);color:var(--ink-2);line-height:var(--lh-tight)}.frame-card-tray-badge{display:inline-flex;align-items:center;align-self:flex-start;font-family:Poppins,sans-serif;font-size:8px;font-weight:700;letter-spacing:.14em;padding:1px 5px;margin-top:2px;border-radius:999px;background:var(--accent);color:#fff}.frame-card.is-active .frame-card-tray-badge{background:#fff;color:var(--accent)}.frame-color-block{margin-top:24px}.frame-color-block[hidden]{display:none}.frame-color-label{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:10px}.frame-color-label-text{font-size:var(--fs-sm);font-weight:500;color:var(--ink-2)}.frame-color-current{font-size:var(--fs-sm);font-weight:500;color:var(--ink)}.frame-color-row{display:flex;flex-wrap:wrap;gap:8px}.frame-color-swatch{width:28px;height:28px;border-radius:4px;border:1px solid var(--line);background:var(--swatch, #888);cursor:pointer;padding:0;position:relative;transition:transform .12s ease,box-shadow .12s ease}.frame-color-swatch:hover{transform:translateY(-1px)}.frame-color-swatch.is-active{box-shadow:0 0 0 2px #fff,0 0 0 4px var(--ink);border-color:var(--ink)}.frame-size-field{display:block;margin-top:8px}.frame-size-field[hidden]{display:none}.frame-size-field select{width:100%;font-size:13px;padding:8px 12px}.frame-dims-callout{margin:10px 0 0;font-size:var(--fs-sm);font-family:var(--font-mono);font-feature-settings:"zero" 1;letter-spacing:0;color:var(--ink);background:var(--surface-2);padding:8px 12px;border-left:2px solid var(--ink)}.frame-dims-callout[hidden]{display:none}.checkbox-row{display:flex;gap:12px;align-items:flex-start;margin-top:14px;padding:12px 14px;background:var(--surface-2);border:1px solid var(--line);cursor:pointer;transition:border-color .15s ease,background .15s ease}.checkbox-row:hover{border-color:var(--ink-3)}.checkbox-row input[type=checkbox]{margin-top:3px;width:16px;height:16px;accent-color:var(--ink);flex-shrink:0}.checkbox-row-text{display:flex;flex-direction:column;gap:2px;min-width:0}.checkbox-row-title{font-size:var(--fs-base);font-weight:600;color:var(--ink)}.checkbox-row-sub{font-size:var(--fs-sm);color:var(--ink-2);line-height:var(--lh-normal)}.toggle{position:relative;cursor:pointer;flex-shrink:0;display:block;width:36px;height:20px;margin:0}.toggle input{position:absolute;opacity:0;width:0;height:0}.toggle-track{display:block;width:100%;height:100%;background:#dc2626;border-radius:0;position:relative;transition:background .2s ease}.toggle-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:0;box-shadow:var(--shadow-sm);transition:transform .22s cubic-bezier(.34,1.56,.64,1)}.toggle input:checked+.toggle-track{background:#16a34a}.toggle input:checked+.toggle-track .toggle-thumb{transform:translate(16px)}.unit-toggle{display:inline-flex;background:var(--surface-2);border-radius:var(--radius-pill);padding:3px}.unit-btn{background:transparent;border:0;padding:6px 12px;font:inherit;font-size:var(--fs-sm);font-weight:500;letter-spacing:0;color:var(--ink-2);border-radius:var(--radius-pill);cursor:pointer;transition:background .2s ease,color .2s ease}.unit-btn[aria-pressed=true]{background:var(--ink);color:#fff}.units-pill{width:100%;display:flex;align-items:center;gap:10px;background:var(--bg);color:var(--ink);border:1px solid var(--line);border-radius:var(--radius-sm);padding:6px 10px;margin:0 0 12px}.units-pill-label{font-family:var(--font-mono);font-size:12.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);flex-shrink:0}.units-pill .unit-toggle{background:var(--surface-2);padding:2px;flex:1;display:flex;justify-content:stretch;gap:2px;border-radius:3px}.units-pill .unit-btn{flex:1;padding:5px 6px;font-size:var(--fs-sm);color:var(--ink-2);background:transparent;border-radius:2px}.units-pill .unit-btn[aria-pressed=true]{background:var(--ink);color:#fff}.units-pill .unit-btn:hover:not([aria-pressed=true]){color:var(--ink);background:#0000000a}.upload-zone{margin-top:14px;border:1.5px dashed var(--ink);border-radius:0;padding:28px 18px;text-align:center;cursor:pointer;transition:border-color .2s ease,background .2s ease;outline:0}.upload-zone:hover,.upload-zone:focus,.upload-zone.is-dragging{border-color:var(--accent);background:var(--accent-soft)}.upload-empty p{margin:0}.upload-empty p:first-of-type{margin-top:10px;font-size:14px;font-weight:600}.upload-sub{margin-top:4px;font-size:12px;color:var(--ink-3)}.upload-empty svg{color:var(--ink-3)}.upload-filled{display:flex;gap:14px;align-items:center;text-align:left}.upload-filled img{width:84px;height:84px;object-fit:cover;border-radius:var(--radius-sm);background:var(--surface-2);flex-shrink:0}.upload-meta{flex:1;min-width:0}.upload-fname{margin:0;font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upload-fsize{margin:2px 0 4px;font-size:12px;color:var(--ink-3)}.upload-dpi{margin:0 0 8px;font-size:11px;font-weight:600;letter-spacing:.02em;display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border-radius:var(--radius-pill);width:fit-content}.upload-dpi.is-low{color:#b3261e;background:#b3261e14}.upload-dpi.is-ok{color:#735c1f;background:#735c1f14}.upload-dpi.is-good{color:#1f6b3e;background:#1f6b3e14}.upload-dpi:empty{display:none}.dpi-suggest{margin-left:6px;background:transparent;border:0;font:inherit;font-size:11px;font-weight:600;color:inherit;cursor:pointer;text-decoration:underline;text-underline-offset:2px;padding:0}.dpi-suggest:hover{color:var(--ink)}.upload-actions{display:flex;gap:14px}.size-presets{margin-top:14px;display:flex;flex-wrap:wrap;gap:6px}.size-preset{background:var(--surface-2);border:1px solid transparent;border-radius:var(--radius-pill);padding:6px 12px;font:inherit;font-size:12px;font-weight:500;color:var(--ink);cursor:pointer;transition:background .15s ease,border-color .15s ease;font-variant-numeric:tabular-nums}.size-preset:hover{background:var(--line-2)}.size-preset.is-active{background:var(--ink);color:#fff;border-color:var(--ink)}.size-inputs{margin-top:14px;display:grid;grid-template-columns:1fr auto 1fr auto;gap:10px;align-items:end}.size-inputs-stacked{grid-template-columns:1fr 42px;grid-template-rows:auto auto;gap:10px}.size-inputs-stacked .size-field:nth-of-type(1){grid-column:1;grid-row:1}.size-inputs-stacked .size-field:nth-of-type(2){grid-column:1;grid-row:2}.size-inputs-stacked .size-toolbar{grid-column:2;grid-row:1 / span 2;align-self:stretch}.size-field{display:flex;flex-direction:column;gap:4px}.size-field span{font-size:var(--fs-sm);font-weight:500;color:var(--ink-2);letter-spacing:0;text-transform:none}.size-field input{border:1px solid var(--line);border-radius:var(--radius-sm);padding:10px 12px;font:inherit;font-size:16px;font-weight:500;font-variant-numeric:tabular-nums;background:var(--bg);width:100%;transition:border-color .15s ease,background .15s ease}.size-field input:focus{outline:0;border-color:var(--ink);background:var(--surface)}.size-x{font-size:18px;font-weight:300;color:var(--ink-3);align-self:flex-end;padding-bottom:11px}.size-field-compact input{padding:6px 9px;font-size:13px}.size-field-compact span{font-size:10px}.size-preset-field{width:100%;min-width:0;margin:0}.size-preset-field>span{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.size-preset-field.is-flash select,.size-preset-field.is-flash .custom-select-trigger{animation:presetFlash .6s ease-out}@keyframes presetFlash{0%{background-color:#f6416c29!important;border-color:var(--accent)}to{background-color:var(--surface);border-color:var(--line)}}.size-custom-row{display:flex;align-items:stretch;gap:10px;margin-top:12px}.size-custom-fields{flex:1;display:flex;flex-direction:column;gap:10px}.size-field-row{display:flex;align-items:center;gap:12px}.size-field-label{flex-shrink:0;width:72px;font-family:var(--font-mono);font-size:12.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-2)}.size-field-inline{flex:1;display:flex;align-items:stretch;gap:0;border:1px solid var(--line);background:var(--surface);padding:0;margin:0;height:38px}.size-field-inline input{flex:1;width:100%;text-align:left;border:0;background:transparent;padding:0 12px;font:inherit;font-size:15px;font-weight:600;font-variant-numeric:tabular-nums;color:var(--ink);outline:none;-moz-appearance:textfield}.size-field-inline input[type=number]::-webkit-outer-spin-button,.size-field-inline input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.num-stepper-btn{flex-shrink:0;width:28px;height:100%;display:inline-flex;align-items:center;justify-content:center;border:0;border-left:1px solid var(--line);background:var(--surface-2);color:var(--ink-2);padding:0;cursor:pointer;transition:background .18s ease,color .18s ease}.num-stepper-btn:hover{background:var(--ink);color:#fff}.num-stepper-btn.is-flash{background:var(--accent);color:var(--accent-ink);transition:background .05s ease,color .05s ease}.num-stepper-btn svg{display:block}.size-field-inline:focus-within{border-color:var(--ink)}.size-field-inline .size-field-unit{flex-shrink:0;width:38px;height:100%;display:inline-flex;align-items:center;justify-content:center;background:var(--surface-2);border:0;border-left:1px solid var(--line);padding:0;font:inherit;font-size:12px;font-weight:600;letter-spacing:.02em;color:var(--ink-2);text-transform:lowercase}.size-field-inline .size-field-unit.unit-cycle{cursor:pointer;transition:background .15s ease,color .15s ease}.size-field-inline .size-field-unit.unit-cycle:hover{background:var(--ink);color:#fff}.artwork-aspect-row{margin:8px 0 0}.artwork-aspect-row[hidden]{display:none}.artwork-aspect-link{font-size:12px;color:var(--ink-2);text-decoration:underline;text-underline-offset:3px}.artwork-aspect-link:hover{color:var(--accent)}.size-readout{margin:12px 0 0;font-size:13px;font-weight:500;font-variant-numeric:tabular-nums;color:var(--ink-2);letter-spacing:.02em}.artwork-dpi-row{margin:16px -18px -16px;border-top:1px solid var(--line-2)}.artwork-dpi-row[hidden]{display:none}.artwork-dpi-chip{display:flex;align-items:center;gap:8px;width:100%;padding:10px 18px;border:0;background:var(--surface);color:var(--ink);font-size:13px;font-weight:500;border-radius:0}.artwork-dpi-chip[data-band=ok]{color:#146d3d;border-color:#b6dec4;background:#ebf6ee}.artwork-dpi-chip[data-band=warn]{color:#8a6315;border-color:#e9d4a3;background:#fbf3df}.artwork-dpi-chip[data-band=low]{color:#a01818;border-color:#e6b8b8;background:#fbe7e7}.artwork-dpi-value{font-weight:600;font-variant-numeric:tabular-nums;flex-shrink:0}.artwork-dpi-note{flex:1;font-weight:400;opacity:.88}.artwork-dpi-chip .info-tip{flex-shrink:0;color:currentColor;opacity:.7}.artwork-dpi-chip .info-tip:hover{opacity:1}.size-roll-help{margin:8px 0 0;font-size:12px;line-height:1.4;color:var(--ink-3)}.size-roll-help:empty{display:none}.size-roll-help strong{color:var(--ink-2);font-weight:600;font-variant-numeric:tabular-nums}.size-max-toast{margin:8px 0 0;padding:9px 12px;background:#fbe7e7;color:#a01818;border-left:3px solid #d33;border-radius:4px;font-size:12.5px;font-weight:500;line-height:1.35;opacity:0;transform:translateY(-4px);transition:opacity .18s ease,transform .18s ease}.size-max-toast[hidden]{display:none}.size-max-toast.is-visible{opacity:1;transform:translateY(0)}.artwork-roll-warn-row{margin:0 -18px -16px;border-top:1px solid var(--line-2)}.artwork-roll-warn-row[hidden]{display:none}.artwork-roll-warn-chip{display:flex;flex-direction:column;align-items:flex-start;gap:2px;width:100%;padding:10px 18px;border:0;background:#fbe7e7;color:#a01818;font-size:13px;font-weight:500}.artwork-roll-warn-value{font-weight:600;font-variant-numeric:tabular-nums}.artwork-roll-warn-note{font-weight:400;opacity:.85;font-size:12px}.stock-card-roll{display:block;font-size:11px;font-family:var(--mono, ui-monospace, SFMono-Regular, Menlo, monospace);letter-spacing:.04em;text-transform:uppercase;color:var(--ink-2);opacity:.7;margin-top:4px}.size-toolbar{display:flex;flex-direction:column;gap:6px;height:100%}.size-tool-btn{flex:1;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);width:42px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink-2);transition:background .15s ease,color .15s ease,border-color .15s ease}.size-tool-btn:hover{background:var(--ink);color:#fff}.size-tool-btn[aria-pressed=true]{background:var(--ink);color:#fff;border-color:var(--ink)}#aspectLockBtn .icon-unlocked,#aspectLockBtn[aria-pressed=false] .icon-locked{display:none}#aspectLockBtn[aria-pressed=false] .icon-unlocked{display:inline-block}#aspectLockBtn[aria-pressed=false]{background:var(--surface-2);color:var(--ink-3);border-color:var(--line);border-style:dashed}.size-note{margin:12px 0 0;font-size:var(--fs-sm);color:var(--ink-2);display:flex;align-items:center;gap:8px;flex-wrap:wrap;line-height:var(--lh-normal)}.size-note-text{color:var(--ink-2)}.dpi-readout{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:var(--fs-xs);font-weight:600;font-feature-settings:"zero" 1;letter-spacing:.02em;border:1px solid currentColor;background:#fff9}.dpi-readout[data-band=ok]{color:#1f7a3a}.dpi-readout[data-band=warn]{color:#b87900}.dpi-readout[data-band=bad]{color:#c0392b}.dpi-readout[data-band=none]{color:var(--ink-3)}.medium-type-row{display:flex;width:100%;border:1px solid var(--line);background:var(--surface);margin-bottom:10px}.medium-type-btn{flex:1;padding:9px 8px;background:transparent;border:0;border-right:1px solid var(--line);font:inherit;font-size:13px;font-weight:500;color:var(--ink-2);cursor:pointer;text-align:center;transition:background .15s ease,color .15s ease}.medium-type-btn:last-child{border-right:0}.medium-type-btn:hover{background:var(--surface-2);color:var(--ink)}.medium-type-btn.is-active{background:var(--ink);color:#fff}.medium-type-btn.is-active:hover{background:#000}.medium-type-btn.is-unavailable{color:var(--ink-3);opacity:.4;cursor:not-allowed}.medium-type-btn.is-unavailable:hover{background:transparent}.frame-type-section{margin-bottom:0}.frame-type-eyebrow{display:block;font-family:var(--font-mono);font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);margin-bottom:12px}.frame-profile-section{margin-top:0}.frame-profile-section[hidden]{display:none}.frame-type-row{margin-bottom:0}.frame-type-row.is-flash,.frame-type-grid.is-flash{animation:presetFlash 1.2s ease-out}.frame-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:0}.frame-type-card{display:flex;flex-direction:column;gap:4px;padding:4px;background:var(--surface);border:1px solid var(--line);cursor:pointer;text-align:left;font:inherit;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease}.frame-type-card:hover{border-color:var(--ink-3)}.frame-type-card.is-active{border-color:var(--ink);box-shadow:0 0 0 1px var(--ink);background:var(--surface)}.frame-type-card.is-unavailable{opacity:.35;cursor:not-allowed}.frame-type-card.is-unavailable:hover{border-color:var(--line)}.frame-type-card-art{display:block;width:100%;aspect-ratio:1 / 1;padding:0;background:transparent;color:var(--ink)}.frame-type-card-art svg{display:block;width:100%;height:100%}.frame-type-card-name{display:block;padding:0 2px 2px;font-size:var(--fs-xs);font-weight:600;color:var(--ink);line-height:var(--lh-tight);letter-spacing:0;text-transform:none;border-top:0}.frame-floatlift-row[hidden]{display:none}.frame-floatlift-row{margin-bottom:14px}.frame-floatlift-row .checkbox-row{margin-top:0}.frame-gap-row{display:flex;align-items:stretch;width:100%;margin:14px 0 0;padding:10px 0;border-top:1px solid var(--line-2);background:var(--surface)}.frame-gap-row[hidden]{display:none}.frame-gap-row-label{display:flex;align-items:center;gap:6px;flex:1;padding-left:2px}.frame-gap-row-label-text{font-family:var(--font-mono);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-2)}.frame-gap-row-input{display:inline-flex;align-items:stretch;border:1px solid var(--line);background:var(--bg);flex-shrink:0}.frame-gap-row-input input[type=number]{width:56px;border:0;padding:6px 8px;font:inherit;font-size:13px;font-weight:500;color:var(--ink);background:transparent;text-align:right;-moz-appearance:textfield}.frame-gap-row-input input[type=number]::-webkit-outer-spin-button,.frame-gap-row-input input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.frame-gap-row-unit{display:inline-flex;align-items:center;justify-content:center;padding:0 10px;background:var(--surface-2);border-left:1px solid var(--line);font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--ink-2);min-width:32px}.medium-finish-row{display:flex;align-items:flex-start;gap:8px;margin:0 0 10px}.medium-finish-row.is-boxed{display:grid;grid-template-columns:auto 1fr;grid-auto-rows:min-content;gap:8px 6px;padding:10px 12px;background:var(--surface);border:1px solid var(--line);margin-bottom:8px}.medium-finish-row.is-boxed[hidden]{display:none!important}.medium-finish-row.is-boxed .medium-finish-label{padding-top:0;width:auto;grid-row:1;grid-column:1;align-self:center}.medium-finish-row.is-boxed .info-tip-inline{grid-row:1;grid-column:2;justify-self:start;align-self:center}.medium-finish-row.is-boxed .medium-finish-chips{grid-row:2;grid-column:1 / -1;display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.medium-finish-row.is-boxed .medium-finish-chips:has(>.medium-finish-chip:nth-child(4)):not(:has(>.medium-finish-chip:nth-child(5))){grid-template-columns:repeat(2,1fr)}.medium-finish-row.is-boxed.stretching-row .medium-finish-chips{grid-template-columns:repeat(4,1fr);gap:4px}.medium-finish-row.is-boxed.stretching-row .medium-finish-chip:first-child{grid-column:1 / -1}.medium-finish-row.is-boxed.stretching-row .medium-finish-chip{padding:8px 6px}.medium-finish-row.is-boxed .medium-finish-chip{padding:8px 14px;font-size:12.5px;min-width:0;width:100%;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box}.medium-finish-label{flex-shrink:0;width:72px;padding-top:5px;font-family:var(--font-mono);font-size:12.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-2)}.medium-finish-chips{display:flex;flex-wrap:wrap;gap:4px;flex:1}.medium-finish-chip{padding:4px 10px;background:var(--surface);border:1px solid var(--line);font:inherit;font-size:12px;font-weight:500;color:var(--ink-2);cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.medium-finish-chip:hover{border-color:var(--ink-3);color:var(--ink)}.medium-finish-chip.is-active,.medium-finish-chip[aria-pressed=true]{background:var(--ink);border-color:var(--ink);color:#fff}.medium-finish-chip.is-disabled{cursor:not-allowed;color:var(--ink-3);background:var(--surface);border-color:var(--line);opacity:.55;position:relative}.medium-finish-chip.is-disabled:hover{border-color:var(--line);color:var(--ink-3)}.medium-finish-chip.is-disabled.is-active{background:var(--ink);border-color:var(--ink);color:#fff;opacity:.78}.medium-finish-chip.is-disabled:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top right,transparent calc(50% - .6px),currentColor 50%,transparent calc(50% + .6px));opacity:.35;pointer-events:none}.medium-finish-chip.is-disabled.is-active:after{opacity:.5}.stock-section{margin-top:4px}.stock-section-label{display:block;margin-bottom:6px;font-family:var(--font-mono);font-size:12.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-2)}.stock-list{display:flex;flex-direction:column;gap:6px}.stock-card{position:relative;display:flex;flex-direction:column;gap:4px;width:100%;padding:12px 14px;background:var(--surface);border:1px solid var(--line);font:inherit;color:var(--ink);cursor:pointer;text-align:left;border-radius:0;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease}.stock-card:hover{border-color:var(--ink-3);background:var(--surface-2)}.stock-card.is-selected{border-color:var(--accent);background:#f6416c0d;box-shadow:inset 0 0 0 1px var(--accent)}.stock-card-vendor{font-family:var(--font-mono);font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3)}.stock-card-name{font-size:14px;font-weight:600;line-height:1.25;color:var(--ink);white-space:normal}.stock-card-meta{margin-top:2px;font-size:11.5px;font-weight:500;letter-spacing:.01em;color:var(--ink-2)}.stock-card.is-selected .stock-card-meta{color:var(--ink-2)}.stock-card-rec{position:absolute;top:10px;right:12px;padding:2px 8px;font-family:var(--font-mono);font-size:9.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--accent-ink, #fff);background:var(--accent);border-radius:2px}.stock-card.is-recommended:not(.is-selected){border-color:var(--accent)}.stock-btn.is-selected .stock-btn-meta{background:#ffffff1a;border-color:#fff3;color:#ffffffd9}.stock-empty{margin:0;padding:12px;text-align:center;font-size:12.5px;color:var(--ink-3);background:var(--surface-2);border:1px dashed var(--line)}.paper-select-field{display:contents}.paper-finish-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.paper-finish-chip{display:inline-flex;align-items:center;font-size:var(--fs-xs);font-weight:500;letter-spacing:0;text-transform:none;padding:4px 10px;background:var(--surface-2);color:var(--ink-2);border:1px solid var(--line-2)}.paper-family{margin-top:14px;display:flex;flex-wrap:wrap;gap:6px}.paper-family-btn{background:var(--surface-2);border:1px solid transparent;border-radius:var(--radius-pill);padding:7px 14px;font:inherit;font-size:13px;font-weight:500;color:var(--ink);cursor:pointer;transition:background .15s ease,color .15s ease}.paper-family-btn.is-active{background:var(--ink);color:#fff}.paper-family-btn:hover:not(.is-active){background:var(--line-2)}.paper-list{margin-top:12px;display:grid;grid-template-columns:1fr;gap:6px;max-height:240px;overflow-y:auto;padding-right:4px;scrollbar-width:thin}.paper-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--line);background:var(--bg);border-radius:var(--radius-sm);cursor:pointer;transition:border-color .15s ease,background .15s ease,transform .15s ease;text-align:left;font:inherit}.paper-item:hover{border-color:var(--ink-3);background:var(--surface)}.paper-item.is-selected{border-color:var(--ink);background:var(--surface)}.paper-item .pi-radio{width:14px;height:14px;border-radius:0;border:1.5px solid var(--ink);flex-shrink:0;position:relative;transition:border-color .15s ease,background .15s ease}.paper-item.is-selected .pi-radio{background:var(--ink);border-color:var(--ink)}.paper-item.is-selected .pi-radio:after{content:"";position:absolute;top:3px;right:3px;bottom:3px;left:3px;border-radius:0;background:#fff}.paper-item .pi-name{font-size:13px;font-weight:500;flex:1;min-width:0;line-height:1.3}.paper-item .pi-price{font-size:12px;color:var(--ink-3);font-variant-numeric:tabular-nums;flex-shrink:0}.select-row{display:grid;grid-template-columns:1fr;gap:10px}.select-field{display:flex;flex-direction:column;gap:4px;margin:0}.select-field[hidden]{display:none}.select-field>span{font-size:var(--fs-sm);font-weight:500;color:var(--ink-2);letter-spacing:0;text-transform:none}.select-field select{appearance:none;-webkit-appearance:none;width:100%;height:38px;border:1px solid var(--line);background-color:var(--surface);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M3 4.5 L6 7.5 L9 4.5' stroke='%23111' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>"),linear-gradient(to right,var(--surface) calc(100% - 38px),var(--surface-2) calc(100% - 38px));background-repeat:no-repeat,no-repeat;background-position:right 13px center,0 0;background-size:12px,100% 100%;box-shadow:inset -38px 0 0 -37px var(--line);padding:0 50px 0 12px;font:inherit;font-size:14px;font-weight:500;color:var(--ink);cursor:pointer;border-radius:0;transition:border-color .15s ease,background-color .15s ease}.select-field select:hover{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M3 4.5 L6 7.5 L9 4.5' stroke='%23ffffff' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>"),linear-gradient(to right,var(--surface) calc(100% - 38px),var(--ink) calc(100% - 38px))}.select-field select:focus{outline:0;border-color:var(--ink)}.custom-select{position:relative;width:100%}.custom-select select.is-customized{position:absolute;opacity:0;pointer-events:none;width:100%;height:100%;top:0;left:0}.custom-select-trigger{position:relative;width:100%;height:38px;display:flex;align-items:stretch;text-align:left;border:1px solid var(--line);background:var(--surface);padding:0 0 0 12px;font:inherit;font-size:14px;font-weight:500;color:var(--ink);cursor:pointer;border-radius:0;transition:border-color .15s ease}.custom-select-trigger-label{flex:1;min-width:0;align-self:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.custom-select-icon-cell{flex-shrink:0;width:38px;display:inline-flex;align-items:center;justify-content:center;background:var(--surface-2);border-left:1px solid var(--line);color:var(--ink);transition:background .18s ease,color .18s ease}.custom-select-icon{position:relative;width:12px;height:12px;transform:rotate(0);transition:transform .25s cubic-bezier(.4,0,.2,1);pointer-events:none}.custom-select-icon:before,.custom-select-icon:after{content:"";position:absolute;background:currentColor;border-radius:1px}.custom-select-icon:before{top:50%;left:0;right:0;height:1.6px;transform:translateY(-50%)}.custom-select-icon:after{left:50%;top:0;bottom:0;width:1.6px;transform:translate(-50%)}.custom-select-trigger:hover{border-color:var(--ink)}.custom-select-trigger:hover .custom-select-icon-cell{background:var(--ink);color:#fff}.custom-select.is-open .custom-select-trigger{border-color:var(--ink)}.custom-select.is-open .custom-select-icon-cell{background:var(--accent);color:var(--accent-ink);border-left-color:var(--accent)}.custom-select.is-open .custom-select-icon{transform:rotate(45deg)}.custom-select-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;max-height:320px;overflow-y:auto;background:var(--surface);border:1px solid var(--line);box-shadow:0 8px 24px #0000001a,0 2px 6px #0000000f;z-index:100;padding:4px 0;border-radius:0}.custom-select-group{font-family:var(--font-mono);font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);padding:8px 14px 4px}.custom-select-group+.custom-select-option,.custom-select-option+.custom-select-group{margin-top:0}.custom-select-option{display:block;width:100%;text-align:left;padding:9px 14px;border:0;background:transparent;font:inherit;font-size:13.5px;font-weight:400;color:var(--ink);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:background .12s ease}.custom-select-option:hover{background:var(--surface-2)}.custom-select-option.is-selected{background:var(--ink);color:#fff}.custom-select-option.is-selected:hover{background:#000}.picker-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.picker-row:last-child{margin-bottom:0}.picker-row-secondary{padding-left:0}.picker-chip{background:var(--surface-2);border:1px solid transparent;border-radius:var(--radius-pill);padding:7px 14px;font:inherit;font-size:13px;font-weight:500;color:var(--ink);cursor:pointer;transition:background .15s ease,color .15s ease,transform .15s ease;display:inline-flex;align-items:center;gap:7px}.picker-chip:hover{background:var(--line-2)}.picker-chip.is-active{background:var(--ink);color:#fff;border-color:var(--ink)}.picker-chip .chip-swatch{display:inline-block;width:14px;height:14px;border-radius:0;background:var(--swatch, #ccc);box-shadow:inset 0 0 0 1px #0000001a;flex-shrink:0}.picker-chip.chip-frame{padding:4px 4px 4px 10px;gap:8px}.picker-chip.chip-frame .chip-mini-preview{width:26px;height:26px;border-radius:0;background:var(--swatch, #ccc);box-shadow:inset 0 0 0 2px #fff6,0 0 0 1px #0000001a;position:relative}.picker-chip.chip-frame .chip-mini-preview:after{content:"";position:absolute;top:6px;right:6px;bottom:6px;left:6px;background:#fff;border-radius:0}.mat-shape{display:inline-flex;background:var(--surface-2);border-radius:var(--radius-pill);padding:3px;margin-bottom:12px}.mat-shape-btn,.border-shape-btn{background:transparent;border:0;padding:6px 14px;font:inherit;font-size:12px;font-weight:600;color:var(--ink-2);border-radius:var(--radius-pill);cursor:pointer;transition:background .2s ease,color .2s ease}.mat-shape-btn.is-active,.border-shape-btn.is-active{background:var(--ink);color:#fff}.step-hint{margin:0 0 12px;font-size:var(--fs-sm);color:var(--ink-2);line-height:var(--lh-normal)}.paper-derived{margin:14px 0 0;padding:12px 14px;background:var(--surface-2);border:1px solid var(--line);display:flex;align-items:baseline;justify-content:space-between;gap:10px;font-size:var(--fs-base)}.paper-derived-label{font-family:var(--font-sans);font-weight:500;font-size:var(--fs-base);letter-spacing:0;text-transform:none;color:var(--ink-2)}.paper-derived-value{font-variant-numeric:tabular-nums;color:var(--ink);font-weight:600}.border-diagram{--bdiag-aspect: 3 / 2;position:relative;display:grid;grid-template-columns:32px minmax(140px,1fr) 32px;grid-template-rows:32px 1fr 32px;gap:8px;align-items:center;justify-items:center;padding:14px;background:var(--surface);border:1px solid var(--line)}.border-edge{position:relative;z-index:2;display:flex;align-items:stretch;height:28px;width:38px;margin:0;border:1px solid var(--line);background:var(--surface)}.border-edge input{flex:1;width:100%;min-width:0;border:0;background:transparent;padding:0 4px;font:inherit;font-size:13px;font-weight:600;font-variant-numeric:tabular-nums;color:var(--ink);text-align:center;outline:none;-moz-appearance:textfield}.border-edge input::-webkit-outer-spin-button,.border-edge input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.border-edge:focus-within{border-color:var(--ink)}.border-edge-top{grid-column:2;grid-row:1}.border-edge-left{grid-column:1;grid-row:2}.border-edge-right{grid-column:3;grid-row:2}.border-edge-bottom{grid-column:2;grid-row:3}.border-diagram[data-locked=true]:before,.border-diagram[data-locked=true]:after{content:"";position:absolute;background:var(--ink-2);pointer-events:none;z-index:0;opacity:.45}.border-diagram[data-locked=true]:before{left:14px;right:14px;top:50%;height:1px;transform:translateY(-.5px)}.border-diagram[data-locked=true]:after{top:14px;bottom:14px;left:50%;width:1px;transform:translate(-.5px)}.border-diagram-artwork{position:relative;z-index:1;grid-column:2;grid-row:2;align-self:center;justify-self:center;width:100%;max-height:100%;aspect-ratio:var(--bdiag-aspect);background:var(--surface-2);border:1px dashed var(--ink-2);opacity:.55}.border-corner-btn{position:absolute;z-index:3;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--line);color:var(--ink-2);cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.border-corner-btn:hover,.border-corner-btn[aria-pressed=true]{background:var(--ink);color:#fff;border-color:var(--ink)}.border-lock-btn{top:6px;right:6px}.border-units-btn{top:6px;left:6px}.border-diagram .border-units-btn{font-size:11px;font-weight:600;letter-spacing:.02em;text-transform:lowercase;padding:0}.border-colour-row{display:flex;align-items:center;gap:10px;margin-top:10px;padding:10px 12px;background:var(--surface);border:1px solid var(--line)}.border-colour-label{flex-shrink:0;width:72px;font-family:var(--font-mono);font-size:12.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2)}.border-colour-swatch-wrap{position:relative;flex:0 0 auto;display:inline-flex;align-items:center}.border-colour-swatch{position:relative;flex:0 0 auto;width:28px;height:28px;padding:0;border:0;background:transparent;display:inline-block;cursor:pointer}.border-colour-popover{position:absolute;top:calc(100% + 6px);left:0;z-index:50;display:flex;flex-direction:column;gap:8px;padding:10px;background:var(--bg, #ffffff);border:1px solid var(--line);box-shadow:0 6px 20px #0000001a}.border-colour-popover[hidden]{display:none}.border-colour-popover-presets{display:flex;gap:6px}.cp-sv{position:relative;width:200px;height:130px;cursor:crosshair;background:linear-gradient(to top,#000 0%,transparent 100%),linear-gradient(to right,#fff 0%,transparent 100%),hsl(var(--cp-hue, 0),100%,50%);border:1px solid var(--line);touch-action:none;-webkit-user-select:none;user-select:none}.cp-sv-pointer{position:absolute;width:12px;height:12px;border:2px solid #fff;border-radius:50%;box-shadow:0 0 0 1px #0000008c;transform:translate(-50%,-50%);pointer-events:none}.cp-hue{position:relative;width:200px;height:14px;cursor:crosshair;background:linear-gradient(to right,red,#ff0,#0f0,#0ff,#00f,#f0f,red);border:1px solid var(--line);touch-action:none;-webkit-user-select:none;user-select:none}.cp-hue-pointer{position:absolute;top:-2px;bottom:-2px;width:4px;border:2px solid #fff;box-shadow:0 0 0 1px #0000008c;transform:translate(-50%);pointer-events:none}.border-colour-swatch-chip{position:absolute;top:0;right:0;bottom:0;left:0;border:1px solid var(--line);background:#fff;transition:border-color .15s ease}.border-colour-swatch:hover .border-colour-swatch-chip{border-color:var(--ink)}.border-colour-swatch input[type=color]:focus-visible+.border-colour-swatch-chip{border-color:var(--ink);box-shadow:0 0 0 2px var(--surface),0 0 0 3px var(--ink)}.border-colour-swatch-chip.is-transparent{background-color:#fff;background-image:linear-gradient(45deg,#cccccc 25%,transparent 25%),linear-gradient(-45deg,#cccccc 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#cccccc 75%),linear-gradient(-45deg,transparent 75%,#cccccc 75%);background-size:8px 8px;background-position:0 0,0 4px,4px -4px,-4px 0}.border-colour-hex{flex:1;min-width:0;height:28px;border:1px solid var(--line);background:var(--surface);padding:0 8px;font:inherit;font-size:12px;font-weight:600;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-variant-numeric:tabular-nums;letter-spacing:.04em;color:var(--ink);text-transform:uppercase;outline:none}.border-colour-hex:focus{border-color:var(--ink)}.border-colour-hex.is-transparent{color:var(--ink-2);font-style:italic}.border-colour-presets{display:flex;gap:4px;flex:0 0 auto}.border-colour-preset{position:relative;width:22px;height:22px;border:1px solid var(--line);background:var(--swatch, #fff);cursor:pointer;padding:0;transition:border-color .15s ease,transform .1s ease}.border-colour-preset:hover{border-color:var(--ink);transform:translateY(-1px)}.border-colour-preset.is-active{border-color:var(--ink);box-shadow:inset 0 0 0 1px var(--ink)}.border-colour-preset-transparent{background-color:#fff;background-image:linear-gradient(45deg,#cccccc 25%,transparent 25%),linear-gradient(-45deg,#cccccc 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#cccccc 75%),linear-gradient(-45deg,transparent 75%,#cccccc 75%);background-size:8px 8px;background-position:0 0,0 4px,4px -4px,-4px 0}.border-colour-preset-transparent:after{content:"";position:absolute;top:1px;right:1px;bottom:1px;left:1px;background:linear-gradient(to top right,transparent calc(50% - .6px),#e63946 50%,transparent calc(50% + .6px));pointer-events:none}.canvas-wrap-colour-preview{display:inline-flex;align-items:center;justify-content:center;height:28px;padding:0 10px;border:1px solid var(--line);background:var(--swatch, #ffffff);color:var(--swatch-ink, #111);font-size:11px;font-weight:600;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-variant-numeric:tabular-nums;letter-spacing:.04em;text-transform:uppercase;cursor:default;margin-left:4px;align-self:center}.canvas-wrap-colour-preview.is-transparent{background-color:#fff;background-image:linear-gradient(45deg,#cccccc 25%,transparent 25%),linear-gradient(-45deg,#cccccc 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#cccccc 75%),linear-gradient(-45deg,transparent 75%,#cccccc 75%);background-size:8px 8px;background-position:0 0,0 4px,4px -4px,-4px 0;color:var(--ink)}.medium-finish-chip.is-disabled[data-tip-text]:hover:before{content:attr(data-tip-text);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--ink);color:#fff;padding:6px 10px;font-size:11px;font-weight:500;letter-spacing:.01em;line-height:1.35;text-transform:none;white-space:normal;max-width:240px;width:max-content;pointer-events:none;z-index:30;opacity:1;box-shadow:0 4px 12px #0003}.mat-symmetric{display:block;margin-top:6px}.mat-width-row .size-field-inline{flex:0 0 160px;max-width:160px}.mat-asymmetric .mat-asym-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.mat-asym-grid label{display:flex;flex-direction:column;gap:4px}.mat-asym-grid span{font-size:11px;font-weight:500;color:var(--ink-2);letter-spacing:.04em;text-transform:uppercase}.mat-asym-grid input{border:1px solid var(--line);border-radius:var(--radius-sm);padding:9px 12px;font:inherit;font-size:14px;font-variant-numeric:tabular-nums;background:var(--bg)}.mat-asym-grid input:focus{outline:0;border-color:var(--ink)}.mat-colour-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}.mat-colour{background:transparent;border:1px solid var(--line);border-radius:var(--radius-pill);padding:6px 12px 6px 8px;font:inherit;font-size:12px;font-weight:500;color:var(--ink);cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:border-color .15s ease}.mat-colour:before{content:"";display:inline-block;width:14px;height:14px;border-radius:0;background:var(--swatch, #ccc);box-shadow:inset 0 0 0 1px #00000026}.mat-colour:hover{border-color:var(--ink-3)}.mat-colour.mat-colour-active{border-color:var(--ink);background:var(--surface)}.catalog-meta{margin:4px 0 0;font-size:11px;color:var(--ink-3);display:inline-flex;align-items:center;gap:6px}.catalog-meta .dot{display:inline-block;width:6px;height:6px;background:var(--mustard);border-radius:0;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.55}50%{opacity:1}}.price-bar{position:sticky;bottom:0;z-index:5;background:var(--surface);border-top:2px solid var(--line-strong);box-shadow:0 -8px 24px #0000000f;margin:16px -24px 0;padding:0;display:flex;flex-direction:column}@media(max-width:1023px){.price-bar{position:fixed;bottom:0;left:0;right:0;margin:0;z-index:40;box-shadow:0 -10px 30px #0000000f}}.price-bar-inner{display:grid;grid-template-columns:1fr auto;gap:0;align-items:stretch}.price-summary{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:2px;padding:14px 18px;background:transparent;border:0;border-right:1px solid var(--line-2);font:inherit;text-align:left;cursor:pointer;min-width:0;transition:background .15s ease}.price-summary:hover{background:var(--surface-2)}.price-eyebrow{margin:0;font-size:var(--fs-sm);font-weight:500;letter-spacing:0;text-transform:none;color:var(--ink-2);display:inline-flex;align-items:center;gap:6px}.price-chev{transition:transform .2s ease}.price-summary[aria-expanded=true] .price-chev{transform:rotate(180deg)}.price-total{margin:0;font-family:var(--font-sans);font-size:var(--fs-2xl);font-weight:600;letter-spacing:-.015em;font-variant-numeric:tabular-nums;line-height:var(--lh-tight);color:var(--ink);transition:color .2s ease}.price-total.is-pulse{animation:pricePulse .4s cubic-bezier(.34,1.56,.64,1)}@keyframes pricePulse{0%{transform:scale(1)}35%{transform:scale(1.04);color:var(--accent)}to{transform:scale(1)}}.price-total span{display:inline-block;transform-origin:left center}.btn-share-strip{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 24px;background:var(--ink);color:#fff;border:0;font:inherit;font-weight:600;font-size:14px;letter-spacing:.02em;cursor:pointer;transition:background .18s ease}.btn-share-strip:hover{background:#000}.btn-share-strip svg{transition:transform .18s ease}.btn-share-strip:hover svg{transform:translate(2px)}.btn-save-primary{background:var(--accent);color:var(--accent-ink)}.btn-save-primary:hover{background:#e53462}.btn-share-strip-secondary{background:#2a2a2a}.btn-share-strip-secondary:hover{background:#111}.price-bar-actions{display:inline-flex;align-items:stretch}.price-bar-actions .btn-share-strip{border-left:1px solid rgba(255,255,255,.1)}.price-breakdown{margin-top:8px;padding:16px 18px;background:var(--surface);border:1px solid var(--line-2)}.price-breakdown[hidden]{display:none}.price-breakdown table{width:100%;border-collapse:collapse;font-size:13px;font-variant-numeric:tabular-nums}.price-breakdown tbody td{padding:5px 0;color:var(--ink-2)}.price-breakdown tbody td:last-child{text-align:right;color:var(--ink);font-weight:500;white-space:nowrap}.price-breakdown tfoot td{padding:5px 0;color:var(--ink-2)}.price-breakdown tfoot td:last-child{white-space:nowrap}.price-breakdown tfoot tr:first-child td{border-top:1px solid var(--line-2);padding-top:10px}.price-breakdown tfoot td:last-child{text-align:right}.price-breakdown tfoot tr.row-final td{color:var(--ink);font-weight:700;padding-top:6px;font-size:14px}.price-breakdown table{width:100%;border-collapse:collapse;font-size:12px}.price-breakdown td{padding:4px 0;font-variant-numeric:tabular-nums}.price-breakdown td:last-child{text-align:right;font-weight:500}.price-breakdown tbody td{color:var(--ink-2)}.price-breakdown tfoot td{padding-top:8px;color:var(--ink-2)}.price-breakdown tfoot tr:first-child td{border-top:1px solid var(--line);padding-top:8px}.price-breakdown tfoot tr.row-final td{padding-top:4px;color:var(--ink);font-weight:600;font-size:13px}.upload-intro{border:0;padding:0;background:#f5f4f0f7;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);top:0;right:0;bottom:0;left:0;width:100vw;height:100vh;max-width:100vw;max-height:100vh;margin:0}.upload-intro[open]{display:flex;align-items:center;justify-content:center}.upload-intro::backdrop{background:transparent}.upload-intro-inner{width:min(760px,92vw);display:flex;flex-direction:column;gap:28px;padding:8px}.upload-intro-head{text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}.upload-intro-head .brand-mark{background:var(--accent);color:#fff;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;border-radius:0}.upload-intro-head h2{font-size:32px;font-weight:700;margin:0;letter-spacing:-.01em;color:var(--ink)}.upload-intro-head p{font-size:14px;color:var(--ink-2);max-width:520px;margin:0;line-height:1.5}.upload-intro-zone{border:2px dashed var(--ink-3);border-radius:0;padding:80px 40px;text-align:center;cursor:pointer;color:var(--ink-2);background:#ffffff80;transition:border-color .15s ease,background .15s ease,color .15s ease}.upload-intro-zone:hover,.upload-intro-zone:focus-visible{border-color:var(--ink);background:var(--surface);color:var(--ink);outline:none}.upload-intro-zone.is-dragging{border-style:solid;border-color:var(--accent);background:#f6416c0a;color:var(--ink);outline:none}.upload-intro-icon{color:var(--ink-3);margin-bottom:8px}.upload-intro-zone:hover .upload-intro-icon,.upload-intro-zone.is-dragging .upload-intro-icon{color:var(--ink)}.upload-intro-zone-title{font-family:var(--font-mono);font-size:13px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin:8px 0 4px;color:var(--ink)}.upload-intro-zone-sub{font-size:13px;color:var(--ink-3);margin:0;font-weight:400}.upload-intro-progress{margin-top:22px;max-width:380px;margin-left:auto;margin-right:auto}.upload-intro-progress-bar{height:4px;background:var(--line);border-radius:2px;overflow:hidden}.upload-intro-progress-fill{height:100%;background:var(--ink);width:0%;transition:width .2s ease}.upload-intro-progress-label{margin:8px 0 0;font-family:IBM Plex Mono,ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;font-feature-settings:"zero" 1;font-variant-numeric:slashed-zero tabular-nums;color:var(--ink-3);text-align:center}.upload-intro-foot{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}.upload-intro-foot .btn-link{color:var(--ink-2);font-size:13px}.existing-print{border:0;padding:0;background:#f5f4f0f7;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);top:0;right:0;bottom:0;left:0;width:100vw;height:100vh;max-width:100vw;max-height:100vh;margin:0}.existing-print[open]{display:flex;align-items:center;justify-content:center}.existing-print::backdrop{background:transparent}.existing-print-inner{width:min(560px,92vw);display:flex;flex-direction:column;gap:24px;padding:8px}.existing-print-head{text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px}.existing-print-head .brand-mark{background:var(--accent);color:#fff;font-size:13px;font-weight:700;letter-spacing:.06em;padding:4px 10px;border-radius:var(--radius-sm)}.existing-print-head h2{font-size:28px;font-weight:700;margin:0;letter-spacing:-.01em;color:var(--ink)}.existing-print-head p{font-size:14px;color:var(--ink-2);max-width:480px;margin:0;line-height:1.5}.existing-print-body{display:flex;flex-direction:column;gap:14px;background:var(--surface);border:1px solid var(--line);padding:22px}.existing-medium-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:4px}.existing-medium-btn{-webkit-appearance:none;appearance:none;border:1px solid var(--line);background:var(--surface);padding:12px 12px 14px;text-align:left;display:flex;flex-direction:column;gap:4px;cursor:pointer;font:inherit;border-radius:var(--radius-sm);transition:border-color .15s ease,background .15s ease,box-shadow .15s ease}.existing-medium-btn:hover{border-color:var(--ink-2)}.existing-medium-btn.is-active{border-color:var(--ink);background:var(--ink);color:#fff}.existing-medium-btn.is-active .existing-medium-sub{color:#ffffffb3}.existing-medium-title{font-size:13px;font-weight:600;color:inherit;letter-spacing:-.005em}.existing-medium-sub{font-size:11px;color:var(--ink-3);line-height:1.35}.existing-canvas-depth-field{margin-top:2px}.existing-size-row{display:flex;align-items:end;gap:10px}.existing-size-row .size-field{flex:1}.existing-size-row .size-x{font-size:18px;color:var(--ink-3);padding-bottom:10px}.existing-print-hint{margin:0;font-size:12px;color:var(--ink-3);line-height:1.4}.existing-image-drop{display:flex;flex-direction:column;align-items:center;gap:6px;padding:22px 14px;border:2px dashed var(--ink-3);border-radius:var(--radius-md);cursor:pointer;color:var(--ink-3);transition:border-color .15s ease,color .15s ease,background .15s ease}.existing-image-drop:hover,.existing-image-drop:focus-visible,.existing-image-drop.is-dragging{border-color:var(--ink);color:var(--ink);background:#fff9;outline:none}.existing-image-drop-title{font-size:13px;font-weight:600;color:var(--ink-2)}.existing-image-drop-sub{font-size:11px;color:var(--ink-3);text-align:center}.existing-image-thumb{max-width:100%;max-height:140px;object-fit:contain;border-radius:var(--radius-sm)}.existing-image-drop.has-image .existing-image-drop-title,.existing-image-drop.has-image .existing-image-drop-sub,.existing-image-drop.has-image svg{display:none}.existing-print-foot{display:flex;justify-content:space-between;align-items:center;gap:12px}.existing-print-foot .btn-primary{background:var(--accent);color:#fff;border:0;padding:10px 18px;font-weight:600;font-size:13px;cursor:pointer;border-radius:var(--radius-sm);transition:opacity .15s ease}.existing-print-foot .btn-primary:hover{opacity:.9}.existing-print-foot .btn-link{color:var(--ink-3);font-size:13px}.step{position:relative}.step-existing-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#fff5f0eb;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);z-index:2;display:flex;align-items:center;justify-content:center;border:1px dashed var(--accent)}.step-existing-overlay-inner{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px;text-align:center;max-width:280px}.step-existing-overlay-eyebrow{font-family:Poppins,sans-serif;font-weight:700;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}.step-existing-overlay-body{margin:0;font-size:13px;color:var(--ink-2);line-height:1.45}.step-existing-overlay .btn-link{color:var(--ink);font-size:12px;text-decoration:underline;margin-top:4px}.piece-existing-chip{flex-shrink:0;display:inline-flex;align-items:center;white-space:nowrap;background:var(--accent);color:#fff;font-family:Poppins,sans-serif;font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:2px 8px;border-radius:999px}.cropper{border:1px solid var(--line);border-radius:0;padding:0;max-width:720px;width:calc(100vw - 32px);max-height:calc(100vh - 32px);background:var(--surface);box-shadow:var(--shadow-lg);overflow:hidden}.cropper::backdrop{background:#0000008c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.confirm-dialog{border:1px solid var(--line-2);border-radius:var(--radius-sm);padding:0;max-width:460px;width:calc(100vw - 32px);background:var(--surface);box-shadow:var(--shadow-lg)}.confirm-dialog::backdrop{background:#00000073;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.confirm-inner{padding:22px 24px}.confirm-inner h3{margin:0 0 8px;font-family:Poppins,sans-serif;font-size:18px;font-weight:600;letter-spacing:-.01em}.confirm-inner p{margin:0;font-size:14px;color:var(--ink-2);line-height:1.5}.confirm-inner p strong{color:var(--ink);font-weight:600}.confirm-cta{display:flex;justify-content:flex-end;gap:8px;margin-top:18px}.cropper-head{padding:20px 22px 0}.cropper-head h3{margin:0;font-family:Poppins,sans-serif;font-size:20px;font-weight:600;letter-spacing:-.01em}.cropper-sub{margin:4px 0 0;font-size:13px;color:var(--ink-2)}.cropper{max-width:1280px;max-height:calc(100vh - 32px)}.cropper-body{display:flex;gap:22px;padding:18px 22px 0;align-items:stretch}.cropper-left{flex:1;min-width:0;display:flex;flex-direction:column;gap:14px}.cropper-stage{position:relative;margin:0;background:var(--surface-2, #f5f5f3);border-radius:0;border:1px solid var(--line);overflow:hidden;aspect-ratio:16 / 11;max-height:calc(100vh - 220px);touch-action:none}#cropperCanvas{display:block;width:100%;height:100%}.cropper-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.cropper-window{position:absolute;border:2px solid #fff;box-shadow:0 0 0 9999px #0009;pointer-events:auto;cursor:move}.cropper-handle{position:absolute;width:16px;height:16px;background:#fff;border:2px solid var(--ink);border-radius:0;pointer-events:auto;z-index:2}.cropper-handle.handle-tl{top:-10px;left:-10px;cursor:nwse-resize}.cropper-handle.handle-tr{top:-10px;right:-10px;cursor:nesw-resize}.cropper-handle.handle-bl{bottom:-10px;left:-10px;cursor:nesw-resize}.cropper-handle.handle-br{bottom:-10px;right:-10px;cursor:nwse-resize}.cropper-aside{flex:0 0 220px;display:flex;flex-direction:column;gap:8px;min-width:0}.cropper-aside-title{margin:0;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2)}.cropper-aspect-list{display:flex;flex-direction:column;gap:4px;flex:1 1 auto;overflow-y:auto;min-height:0}.cropper-aspect-chip{display:flex;align-items:baseline;justify-content:space-between;gap:10px;background:var(--surface);border:1px solid var(--line-2);border-radius:0;padding:10px 12px;font:inherit;font-size:13px;font-weight:500;color:var(--ink);cursor:pointer;text-align:left;transition:background .15s ease,color .15s ease,border-color .15s ease}.cropper-aspect-chip:hover{border-color:var(--ink-2)}.cropper-aspect-chip.is-active{background:var(--ink);color:#fff;border-color:var(--ink)}.cropper-aspect-chip-meta{font-size:11px;font-weight:400;opacity:.7;margin-left:0;font-variant-numeric:tabular-nums;letter-spacing:.01em;white-space:nowrap}.cropper-chip-left{display:inline-flex;align-items:center;gap:8px;min-width:0}.cropper-chip-lock{display:inline-flex;align-items:center;color:currentColor;opacity:.55;flex-shrink:0}.cropper-aspect-chip.is-active .cropper-chip-lock{opacity:1}.cropper-aspect-divider{height:1px;background:var(--line-2);margin:8px 0}.cropper-custom-ar{display:none;padding:10px 12px 12px;background:var(--surface-2, #f5f5f3);border:1px solid var(--line-2);border-top:0;margin-top:-1px}.cropper-aside[data-mode=free] .cropper-custom-ar{display:block}.cropper-custom-ar-row{display:flex;align-items:flex-end;gap:8px}.cropper-custom-ar-field{flex:1;display:flex;flex-direction:column;gap:4px;margin:0;min-width:0}.cropper-custom-ar-field>span{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2)}.cropper-custom-ar-field input{width:100%;min-width:0;border:1px solid var(--line-2);background:var(--surface);padding:8px 10px;font:inherit;font-size:14px;font-weight:600;font-variant-numeric:tabular-nums;text-align:center}.cropper-custom-ar-field input:focus{outline:0;border-color:var(--ink)}.cropper-custom-ar-colon{color:var(--ink-2);font-weight:500;padding-bottom:6px}.cropper-custom-ar-lock{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:10px;padding:9px 12px;background:var(--surface);border:1px solid var(--line-2);border-radius:0;font:inherit;font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink);cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease}.cropper-custom-ar-lock:hover{border-color:var(--ink-2)}.cropper-custom-ar-lock[aria-pressed=true]{background:var(--ink);color:#fff;border-color:var(--ink)}@media(max-width:720px){.cropper-body{flex-direction:column;padding:14px;gap:12px}.cropper-aside{flex:0 0 auto}.cropper-aspect-list{flex-direction:row;flex-wrap:wrap;max-height:none}.cropper-aspect-chip{flex:0 1 auto}}.cropper-grid{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to right,transparent 33%,rgba(255,255,255,.25) 33%,rgba(255,255,255,.25) calc(33% + 1px),transparent calc(33% + 1px),transparent 66%,rgba(255,255,255,.25) 66%,rgba(255,255,255,.25) calc(66% + 1px),transparent calc(66% + 1px)),linear-gradient(to bottom,transparent 33%,rgba(255,255,255,.25) 33%,rgba(255,255,255,.25) calc(33% + 1px),transparent calc(33% + 1px),transparent 66%,rgba(255,255,255,.25) 66%,rgba(255,255,255,.25) calc(66% + 1px),transparent calc(66% + 1px))}.cropper-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 22px 20px;border-top:1px solid var(--line-2);margin-top:18px;flex-wrap:wrap}.cropper-utils{display:inline-flex;gap:8px}.cropper-util-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;font-size:13px;font-weight:500}.cropper-cta{display:inline-flex;gap:8px}.share-dialog{border:0;border-radius:var(--radius-lg);padding:24px;max-width:480px;width:calc(100vw - 32px);background:var(--surface);box-shadow:var(--shadow-lg)}.share-dialog::backdrop{background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.share-head h3{margin:0 0 6px;font-family:Poppins,sans-serif;font-size:22px;font-weight:600}.share-head p{margin:0;font-size:13px;color:var(--ink-2)}.share-link{margin:18px 0;display:flex;gap:8px}.share-link input{flex:1;border:1px solid var(--line);border-radius:var(--radius-sm);padding:10px 12px;font:inherit;font-size:12px;font-family:Menlo,monospace;background:var(--surface-2)}.share-summary{background:var(--surface-2);border-radius:var(--radius-sm);padding:14px;font-size:12px;color:var(--ink);line-height:1.6}.share-summary .ss-row{display:flex;justify-content:space-between;padding:3px 0}.share-summary .ss-label{color:var(--ink-3)}.share-summary .ss-val{font-weight:500;font-variant-numeric:tabular-nums}.share-foot{margin-top:16px;text-align:right;display:flex;justify-content:flex-end;gap:8px}.save-dialog .save-fields{display:flex;flex-direction:column;gap:10px;margin-top:16px}.save-dialog .save-fields .size-field input,.save-dialog .save-fields .size-field textarea{border:1px solid var(--line);border-radius:var(--radius-sm);padding:9px 12px;font:inherit;font-size:14px;background:var(--bg);width:100%;resize:vertical}.save-dialog .save-fields .size-field input:focus,.save-dialog .save-fields .size-field textarea:focus{outline:0;border-color:var(--ink);background:var(--surface)}.save-result{margin-top:14px;padding:12px 14px;border-radius:var(--radius-sm);background:#1f7a3a14;border:1px solid rgba(31,122,58,.25);color:#1f7a3a;font-size:13px}.save-result.is-error{background:#c0392b14;border-color:#c0392b40;color:#c0392b}.save-result code{font-family:IBM Plex Mono,ui-monospace,monospace;font-size:12px;background:#0000000f;padding:1px 6px;border-radius:3px}.share-channels{display:flex;gap:8px;margin:10px 0 4px}.share-channel{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border:1px solid var(--line);border-radius:var(--radius-pill);background:var(--surface);font:inherit;font-size:13px;font-weight:500;color:var(--ink);text-decoration:none;cursor:pointer;transition:border-color .15s ease,background .15s ease,transform .15s ease}.share-channel:hover{border-color:var(--ink);transform:translateY(-1px)}.share-whatsapp{color:#25d366;border-color:#25d3664d}.share-whatsapp:hover{background:#25d3660f;border-color:#25d366}.share-email{color:var(--ink)}.toast{position:fixed;bottom:96px;left:50%;transform:translate(-50%) translateY(20px);background:var(--ink);color:#fff;padding:10px 18px;border-radius:var(--radius-pill);font-size:13px;font-weight:500;box-shadow:var(--shadow-md);opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease;z-index:60}.toast.is-visible{opacity:1;transform:translate(-50%) translateY(0)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.calc-root[data-mode=share] .calc-config .toggle,.calc-root[data-mode=share] .calc-config input,.calc-root[data-mode=share] .calc-config button{pointer-events:none}.calc-root[data-mode=share] #resetBtn{display:none}.paper-list::-webkit-scrollbar{width:6px}.paper-list::-webkit-scrollbar-track{background:transparent}.paper-list::-webkit-scrollbar-thumb{background:var(--line);border-radius:0}.paper-list::-webkit-scrollbar-thumb:hover{background:var(--ink-3)}@media(max-width:1023px){.calc-preview{min-height:48vh;max-height:60vh}.render-section{min-height:280px}.render-card-specs{position:fixed;left:0;right:0;bottom:132px;max-width:none;width:100vw;margin:0;border-left:0;border-right:0;border-bottom:0;border-top:1px solid var(--line-strong);background:#fffffffa;z-index:45;box-shadow:0 -6px 20px #0000001a;transition:transform .25s cubic-bezier(.4,0,.2,1)}.render-card-specs .render-card-head{padding:10px 16px}.render-card-specs .render-card-body{max-height:38vh;padding:8px 16px 14px}.render-card-specs[aria-expanded=false]{transform:translateY(0)}.render-card-specs[aria-expanded=false] .render-card-body,.render-card-diagram{display:none}.calc-top{padding:10px 14px}.brand-label{display:none}.piece-strip-list{max-height:240px}.piece-chip{min-height:44px}.piece-chip-qty-btn,.piece-chip-delete{min-width:32px;min-height:32px}.piece-add-btn{min-height:40px;padding:8px 10px}.calc-config{padding:14px 14px 100px!important}.step{padding:14px}.step-head{gap:10px}.step-title{font-size:15px}.step-num{font-size:10px}.step-sub{margin-top:14px;padding-top:14px}.step-print>.step-sub:first-of-type{padding-top:10px}.size-inputs-stacked{grid-template-columns:1fr 1fr auto!important;gap:10px}.size-toolbar{gap:6px}.size-row .size-tool-btn{width:36px;height:36px}.select-field.size-preset-field select{height:36px;padding:0 28px 0 10px}input[type=number],.size-field input{font-size:16px!important;min-height:44px}.mat-asym-grid{grid-template-columns:1fr 1fr!important}.mat-asym-grid input{min-height:44px;font-size:16px!important}.paper-list{max-height:280px}.price-bar-inner{grid-template-columns:1fr!important}.price-summary{border-right:0!important;border-bottom:1px solid var(--line-2);padding:12px 16px}.price-total{font-size:22px}.price-bar .btn-share-strip,.price-bar .btn-share-strip-secondary{width:100%;padding:16px 18px;font-size:15px;border-radius:0;min-height:52px;border-top:1px solid rgba(255,255,255,.1)}.price-bar-actions{display:grid;grid-template-columns:1.4fr 1fr;width:100%}.price-bar-actions .btn-share-strip-secondary{background:#2a2a2a}.dims-switch-label{font-size:10px}.toggle-track{width:48px;height:28px}.toggle-thumb{width:24px;height:24px}.toggle input:checked+.toggle-track .toggle-thumb{transform:translate(20px)}.preview-toggle{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:6px 8px;gap:4px}.scene-btn{flex-shrink:0;padding:8px 12px;font-size:11px;min-height:36px}.save-dialog,.share-dialog{width:min(94vw,480px)!important;max-width:94vw;padding:18px!important}.save-fields .size-field input,.save-fields .size-field textarea{font-size:16px!important}.render-card-specs .render-card-toggle{font-size:22px}}@media(max-width:559px){.piece-chip-thumb{width:36px;height:36px}.piece-chip.is-active .piece-chip-thumb{width:44px;height:44px}.piece-chip-qty-btn{min-width:28px;min-height:28px;width:28px;height:28px;font-size:13px}.piece-chip-qty-val{min-width:22px;height:28px;font-size:11px}}@media(max-width:419px){.calc-top{padding:8px 12px}.piece-chip{max-width:196px}.step{padding:12px}.price-total{font-size:20px}}.calc-config{background:var(--bg)}.calc-config .catalog-meta{color:var(--ink-3)}.calc-config:has(.step:focus-within) .step:not(:focus-within){opacity:.55}.calc-config:has(.step:focus-within) .step:focus-within{opacity:1}.calc-config .step{transition:opacity .18s ease,border-color .2s ease}#dimensionLayer .dim-group{opacity:.42;transition:opacity .18s ease}#dimensionLayer .dim-group:hover{opacity:1}.info-tip{-webkit-appearance:none;appearance:none;border:1px solid rgba(0,0,0,.15);background:#ffffffb3;color:#555;width:20px;height:20px;border-radius:999px;font-family:ui-sans-serif,system-ui,sans-serif;font-weight:700;font-size:12px;font-style:italic;line-height:1;display:inline-flex;align-items:center;justify-content:center;margin-left:6px;cursor:pointer;flex:0 0 auto;transition:background .15s,color .15s,border-color .15s,transform .1s;padding:0}.info-tip:hover,.info-tip:focus-visible{background:#f6416c;color:#fff;border-color:#f6416c;transform:scale(1.06);outline:none}.info-tip[aria-expanded=true]{background:#f6416c;color:#fff;border-color:#f6416c}.info-tip-sub{width:16px;height:16px;font-size:10px;margin-left:4px}.info-tip-inline{vertical-align:middle;margin-left:4px}.tip-popover{position:fixed;z-index:1100;width:min(360px,calc(100vw - 24px));background:#fff;border:1px solid rgba(0,0,0,.08);box-shadow:0 10px 40px #0000002e;border-radius:10px;padding:16px 16px 14px;color:#222;font-size:13px;line-height:1.5;animation:tip-pop .16s ease-out}.tip-popover[hidden]{display:none}@keyframes tip-pop{0%{opacity:0;transform:translateY(-4px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.tip-close{-webkit-appearance:none;appearance:none;background:transparent;border:0;position:absolute;top:6px;right:8px;width:24px;height:24px;border-radius:999px;font-size:18px;color:#888;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.tip-close:hover{background:#0000000f;color:#222}.tip-title{font-size:14px;font-weight:700;margin:0 24px 8px 0;color:#111}.tip-body p{margin:0 0 6px}.tip-body strong{color:#111}.tip-body em{font-style:italic;color:#444}.tip-media{margin:4px 0 10px}.tip-svg{width:100%;height:auto;display:block;background:#f7f6f3;border-radius:6px;border:1px solid rgba(0,0,0,.06)}.tip-photo{width:100%;height:auto;display:block;border-radius:6px;border:1px solid rgba(0,0,0,.06);background:#f7f6f3}.tip-photo-caption{margin:6px 0 0;font-size:11px;color:#666;line-height:1.4}.tip-media-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.tip-compare-label{margin:4px 0 0;font-size:10.5px;color:#555;text-align:center;line-height:1.3}.help-btn{position:fixed;bottom:18px;left:18px;width:40px;height:40px;border-radius:999px;background:#1c1c1a;color:#fff;border:0;cursor:pointer;z-index:1050;box-shadow:0 4px 16px #0000002e;display:inline-flex;align-items:center;justify-content:center;transition:transform .15s,background .15s}.help-btn:hover{background:#f6416c;transform:scale(1.06)}.help-btn-glyph{font-family:ui-sans-serif,system-ui,sans-serif;font-weight:700;font-size:18px;line-height:1}@media(max-width:1023px){.help-btn{display:none}}.restore-banner{position:fixed;top:16px;left:50%;transform:translate(-50%,-16px);z-index:1100;background:#1c1c1a;color:#fff;border-radius:var(--radius-pill);padding:10px 14px 10px 18px;box-shadow:0 8px 24px #00000038;opacity:0;transition:opacity .25s ease,transform .25s ease;max-width:calc(100vw - 32px)}.restore-banner.is-visible{opacity:1;transform:translate(-50%)}.restore-banner-inner{display:flex;align-items:center;gap:14px;font-size:13px;font-weight:500}.restore-banner-ago{opacity:.62;margin-left:6px;font-weight:400}.restore-banner-actions{display:flex;gap:6px}.restore-banner-btn{-webkit-appearance:none;appearance:none;border:0;border-radius:var(--radius-pill);padding:8px 14px;font:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s ease,color .15s ease}.restore-banner-btn-primary{background:#fff;color:#1c1c1a}.restore-banner-btn-primary:hover{background:#f0f0f0}.restore-banner-btn-secondary{background:transparent;color:#ffffffc7}.restore-banner-btn-secondary:hover{color:#fff}@media(max-width:520px){.restore-banner{top:12px;padding:8px 10px 8px 14px}.restore-banner-inner{font-size:12px;gap:8px}.restore-banner-ago{display:none}}.tour-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1090;pointer-events:none}.tour-overlay[hidden]{display:none}.tour-overlay:before{content:"";position:absolute;top:var(--tour-top-safe, 0);left:0;right:0;bottom:0;background:#1414148c;pointer-events:auto}.tour-cutout{position:absolute;border-radius:8px;box-shadow:0 0 0 9999px #1414148c,0 0 0 3px #f6416c inset;background:transparent;pointer-events:none;transition:left .25s,top .25s,width .25s,height .25s}.tour-cutout[hidden]{display:none}.tour-card{position:absolute;width:380px;max-width:calc(100vw - 32px);background:#fff;border-radius:12px;padding:18px 20px 16px;box-shadow:0 14px 40px #00000052;pointer-events:auto;transition:left .22s,top .22s}.tour-progress{font-size:11px;color:#f6416c;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.tour-title{margin:4px 0 6px;font-size:18px;font-weight:700;color:#111}.tour-body{margin:0 0 14px;font-size:14px;line-height:1.5;color:#333}.tour-actions{display:flex;align-items:center;justify-content:space-between;gap:12px}.tour-skip{-webkit-appearance:none;appearance:none;background:transparent;border:0;color:#888;font-size:12px;cursor:pointer;padding:6px 4px}.tour-skip:hover{color:#222}.tour-nav{display:flex;gap:8px}.tour-prev,.tour-next{-webkit-appearance:none;appearance:none;border:0;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;padding:8px 14px;transition:background .15s}.tour-prev{background:transparent;color:#444;border:1px solid rgba(0,0,0,.12)}.tour-prev:hover:not(:disabled){background:#0000000a}.tour-prev:disabled{opacity:.4;cursor:not-allowed}.tour-next{background:#f6416c;color:#fff}.tour-next:hover{background:#db305a}
/*# sourceMappingURL=/cdn/shop/t/174/assets/calc.css.map */
