@font-face{font-family:Fraunces;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/85fcf895b86d74a6-s.12xb_oat076h..woff2?dpl=dpl_66xkVc1Go2PVEVnY241VEr9z2mGH)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Fraunces;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5307092570128b5a-s.0dld-t76zw9ln.woff2?dpl=dpl_66xkVc1Go2PVEVnY241VEr9z2mGH)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Fraunces;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/b67966e0b83b2cd0-s.p.04y9-s23ppywx.woff2?dpl=dpl_66xkVc1Go2PVEVnY241VEr9z2mGH)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Fraunces Fallback;src:local(Times New Roman);ascent-override:84.71%;descent-override:22.09%;line-gap-override:0.0%;size-adjust:115.45%}.fraunces_8a17d72c-module__Z3q2rG__className{font-family:Fraunces,Fraunces Fallback;font-style:normal}.fraunces_8a17d72c-module__Z3q2rG__variable{--font-display:"Fraunces", "Fraunces Fallback"}
@font-face{font-family:Hanken Grotesk;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/91bd2e40df15814e-s.0eq-h7p0~f2-i.woff2?dpl=dpl_66xkVc1Go2PVEVnY241VEr9z2mGH)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Hanken Grotesk;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/a63431c4ac64ea8b-s.0-m28h~k~95g~.woff2?dpl=dpl_66xkVc1Go2PVEVnY241VEr9z2mGH)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Hanken Grotesk;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8b4ed0a90d903ab5-s.18283yqfiehau.woff2?dpl=dpl_66xkVc1Go2PVEVnY241VEr9z2mGH)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Hanken Grotesk;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/c47649aa31f9e140-s.p.11uo_35nso9mn.woff2?dpl=dpl_66xkVc1Go2PVEVnY241VEr9z2mGH)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Hanken Grotesk Fallback;src:local(Arial);ascent-override:99.07%;descent-override:30.02%;line-gap-override:0.0%;size-adjust:100.94%}.hanken_grotesk_29967d0a-module__tcVLJG__className{font-family:Hanken Grotesk,Hanken Grotesk Fallback;font-style:normal}.hanken_grotesk_29967d0a-module__tcVLJG__variable{--font-body:"Hanken Grotesk", "Hanken Grotesk Fallback"}
:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--paper:#efe9dd;--surface:#fdfbf6;--surface-2:#f6f1e7;--ink:#1d2b26;--ink-soft:#65726b;--line:#e4ddcc;--line-strong:#d2c9b3;--spruce:#1f4d41;--spruce-deep:#14362d;--spruce-tint:#e3ece6;--brass:#a07440;--brass-soft:#f1e6d3;--clay:#b75a37;--danger:#a13d31;--radius-lg:18px;--radius-md:12px;--radius-sm:9px;--shadow-frame:0 1px 2px #1d2b260d, 0 24px 70px -18px #1d2b2638;--shadow-lift:0 10px 30px -12px #1d2b2640;--font-serif:var(--font-display), "Iowan Old Style", Georgia, serif;--font-sans:var(--font-body), ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif}*{box-sizing:border-box}html,body{min-height:100%;margin:0}body{background:radial-gradient(70rem 40rem at 85% -10%, #a074401a, transparent 60%), radial-gradient(60rem 38rem at -10% 110%, #1f4d411f, transparent 55%), var(--paper);color:var(--ink);font-family:var(--font-sans);-webkit-font-smoothing:antialiased}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed}a{color:inherit}::selection{background:#1f4d412e}.app-shell{min-height:100vh;padding:28px 22px 48px}.app-shell.embed{background:0 0;min-height:auto;padding:0}.viz-frame{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);width:min(1680px,100%);box-shadow:var(--shadow-frame);margin:0 auto;position:relative;overflow:hidden}.embed .viz-frame{border-radius:var(--radius-md);width:100%;box-shadow:0 1px 2px #1d2b260f}.viz-frame:after{content:"";pointer-events:none;opacity:.5;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 0.45 0 0 0 0 0.42 0 0 0 0 0.36 0 0 0 0.05 0'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E");position:absolute;inset:0}.topbar{background:linear-gradient(180deg, #1f4d410b, transparent 70%), var(--surface);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:18px 28px;padding:24px 32px 20px;display:flex}.brand-lockup{gap:3px;display:grid}.brand-eyebrow{color:var(--brass);letter-spacing:.16em;text-transform:uppercase;font-size:11px;font-weight:700}.brand-name{font-family:var(--font-serif);letter-spacing:-.01em;margin:0;font-size:28px;font-weight:580;line-height:1.1}.credit-panel{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.credit-pill{border:1px solid var(--line);background:var(--surface-2);white-space:nowrap;border-radius:999px;align-items:center;gap:8px;padding:9px 14px;font-size:13px;font-weight:600;display:inline-flex}.credit-pill i{background:var(--spruce);border-radius:50%;width:7px;height:7px}.credit-pill.empty i{background:var(--clay)}.code-form{border:1px solid var(--line);background:var(--surface);border-radius:999px;transition:border-color .15s,box-shadow .15s;display:flex;overflow:hidden}.code-form:focus-within{border-color:var(--spruce);box-shadow:0 0 0 3px #1f4d411f}.code-form input{background:0 0;border:0;outline:none;width:120px;padding:9px 4px 9px 15px;font-size:13px}.code-form button{color:var(--spruce);background:0 0;border:0;padding:0 15px;font-size:13px;font-weight:700}.code-form button:hover{color:var(--spruce-deep);text-decoration:underline}.wizard-bar{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--surface-2);justify-content:center;align-items:center;gap:14px;padding:14px 32px;display:flex}.wizard-step{color:var(--ink-soft);background:0 0;border:0;border-radius:999px;align-items:center;gap:9px;padding:8px 12px;transition:color .15s,background .15s;display:inline-flex}.wizard-step:hover:not(:disabled){color:var(--ink)}.wizard-step:disabled{opacity:.45}.wizard-step.active{background:var(--surface);color:var(--ink);box-shadow:0 1px 5px #1d2b261f}.wizard-num{border:1px solid var(--line-strong);background:var(--surface);width:26px;height:26px;font-family:var(--font-serif);color:var(--brass);border-radius:50%;place-items:center;font-size:13px;font-style:italic;display:inline-grid}.wizard-step.active .wizard-num{border-color:var(--spruce);background:var(--spruce);color:#fff}.wizard-label{white-space:nowrap;font-size:13.5px;font-weight:700}.wizard-line{background:var(--line-strong);width:42px;height:1px}.step-done{background:var(--spruce);color:#fff;border-radius:50%;flex:none;place-items:center;width:18px;height:18px;display:inline-grid}.step-done svg{width:10px;height:10px}.photo-step,.direction-step,.result-stage{animation:.45s cubic-bezier(.2,.7,.3,1) backwards rise}@keyframes rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.photo-step{background:linear-gradient(0deg, #fdfbf6eb, #fdfbf6f7), repeating-linear-gradient(0deg, var(--line) 0 1px, transparent 1px 56px), repeating-linear-gradient(90deg, var(--line) 0 1px, transparent 1px 56px), var(--surface);justify-items:center;padding:44px 32px 56px;display:grid}.photo-intro{text-align:center;justify-items:center;margin-bottom:26px;display:grid}.photo-intro h2{font-family:var(--font-serif);letter-spacing:-.015em;margin:12px 0 8px;font-size:clamp(28px,3.2vw,44px);font-weight:580;line-height:1.06}.photo-intro p{color:var(--ink-soft);max-width:520px;margin:0;font-size:15px;line-height:1.55}.upload-zone{border:1.5px dashed var(--line-strong);border-radius:var(--radius-md);background:var(--surface);place-items:center;transition:border-color .15s,background .15s;display:grid;position:relative;overflow:hidden}.upload-zone.hero{width:min(880px,100%);min-height:400px}.upload-zone:hover{border-color:var(--spruce);background:#fff}.upload-zone.has-image{border-style:solid;border-color:var(--line);background:var(--spruce-deep);min-height:0;display:block}.upload-input{opacity:0;cursor:pointer;position:absolute;inset:0}.upload-copy{text-align:center;pointer-events:none;justify-items:center;gap:12px;padding:26px;display:grid}.upload-mark{background:var(--spruce-tint);width:56px;height:56px;color:var(--spruce);border-radius:50%;place-items:center;font-size:26px;font-weight:600;line-height:1;display:grid}.upload-copy strong{font-size:17px;font-weight:700}.upload-copy span{color:var(--ink-soft);max-width:280px;font-size:13.5px;line-height:1.5}.preview-image{object-fit:contain;width:100%;max-height:520px;display:block}.crop-editor{gap:14px;width:min(880px,100%);display:grid}.crop-stage{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--spruce-deep);cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;place-items:center;width:100%;max-height:620px;display:grid;position:relative;overflow:hidden}.crop-stage:active{cursor:grabbing}.crop-canvas{object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;display:block}.change-photo-inline{color:var(--spruce);cursor:pointer;flex:none;font-size:12.5px;font-weight:800;position:relative}.change-photo-inline:hover{text-decoration:underline}.change-photo-inline input{opacity:0;cursor:pointer;position:absolute;inset:0}.change-pill{pointer-events:none;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#14362dd1;border-radius:999px;padding:8px 16px;font-size:12.5px;font-weight:700;position:absolute;bottom:14px;left:50%;transform:translate(-50%)}.preview-meta{color:var(--ink-soft);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:10px;font-size:12.5px;display:flex}.preview-meta.center{width:min(880px,100%)}.preview-meta span:first-child{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.photo-actions{justify-items:center;gap:10px;margin-top:28px;display:grid}.next-button{width:auto;min-width:300px;padding:0 30px}.error-box{color:var(--danger);border-radius:var(--radius-sm);background:#a13d3112;border:1px solid #a13d314d;margin:0 0 12px;padding:11px 13px;font-size:13px;line-height:1.45}.error-box.center-box{width:min(880px,100%);margin-top:14px}.direction-step{grid-template-columns:320px minmax(0,1fr);align-items:start;display:grid}.direction-side{border-right:1px solid var(--line);background:var(--surface-2);gap:16px;padding:28px 26px 32px;display:grid;position:sticky;top:0}.photo-chip{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface);margin:0;overflow:hidden}.photo-chip img{object-fit:cover;background:var(--spruce-deep);width:100%;max-height:230px;display:block}.photo-chip-empty{height:140px;color:var(--ink-soft);place-items:center;font-size:13px;display:grid}.photo-chip figcaption{border-top:1px solid var(--line);justify-content:space-between;align-items:center;gap:10px;padding:9px 12px;display:flex}.photo-chip figcaption span{letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);font-size:11px;font-weight:800}.photo-chip figcaption button{color:var(--spruce);background:0 0;border:0;padding:0;font-size:13px;font-weight:700}.photo-chip figcaption button:hover{text-decoration:underline}.side-field{gap:7px;display:grid}.field-label{letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);font-size:11px;font-weight:800;display:block}.label-soft{text-transform:none;letter-spacing:0}.side-field textarea{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);resize:vertical;outline:none;width:100%;min-height:110px;padding:11px 12px;font-size:14px;line-height:1.5;transition:border-color .15s,box-shadow .15s}.side-field textarea:focus{border-color:var(--spruce);box-shadow:0 0 0 3px #1f4d411f}.direction-main{background:var(--surface);min-width:0;padding:28px 36px 40px}.direction-head h2{font-family:var(--font-serif);letter-spacing:-.01em;margin:0 0 6px;font-size:26px;font-weight:600}.direction-head p{color:var(--ink-soft);margin:0 0 18px;font-size:14px;line-height:1.5}.direction-tabs{border:1px solid var(--line);background:var(--surface-2);border-radius:999px;gap:4px;margin-bottom:20px;padding:4px;display:inline-flex}.direction-tabs button{color:var(--ink-soft);background:0 0;border:0;border-radius:999px;padding:9px 20px;font-size:14px;font-weight:700;transition:background .15s,color .15s,box-shadow .15s}.direction-tabs button:hover{color:var(--ink)}.direction-tabs button.active{background:var(--spruce);color:#fff;box-shadow:0 2px 8px -2px #14362d73}.package-grid{scroll-snap-type:x proximity;scrollbar-color:var(--line-strong) transparent;gap:12px;padding:2px 2px 10px;display:flex;overflow-x:auto}.package-card{scroll-snap-align:start;text-align:left;border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface);flex:0 0 200px;align-content:start;justify-items:start;gap:8px;min-height:0;padding:10px;transition:border-color .15s,box-shadow .15s,transform .15s;display:grid;overflow:hidden}.package-card:hover{border-color:var(--line-strong);box-shadow:var(--shadow-lift);transform:translateY(-2px)}.package-card[aria-pressed=true]{border-color:var(--spruce);background:linear-gradient(180deg, #1f4d410d, transparent 65%), var(--surface);box-shadow:0 0 0 2px #1f4d4147}.package-preview{aspect-ratio:4/3;border-radius:calc(var(--radius-md) - 3px);background:var(--spruce-deep);width:100%;display:block;overflow:hidden}.package-preview img{object-fit:cover;width:100%;height:100%;display:block}.package-title-row{justify-content:space-between;align-items:center;gap:10px;width:100%;padding:3px 2px 0;display:flex}.package-title-row .style-tag{white-space:nowrap;flex:none}.package-name{font-family:var(--font-serif);letter-spacing:-.005em;font-size:19px;font-weight:600}.package-desc{color:var(--ink-soft);-webkit-line-clamp:2;-webkit-box-orient:vertical;padding:0 2px;font-size:12.5px;line-height:1.45;display:-webkit-box;overflow:hidden}.product-browser{gap:14px;display:grid}.product-browser-tools{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.product-browser-tabs{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-2);gap:4px;padding:4px;display:inline-flex}.product-browser-tabs button{min-height:36px;color:var(--ink-soft);background:0 0;border:0;border-radius:6px;padding:0 14px;font-size:13px;font-weight:700;transition:background .15s,color .15s,box-shadow .15s}.product-browser-tabs button:hover{color:var(--ink)}.product-browser-tabs button.active{background:var(--spruce);color:#fff;box-shadow:0 2px 8px -2px #14362d73}.product-search-input{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);outline:none;flex:1;min-width:220px;min-height:44px;padding:0 13px;font-size:14px;transition:border-color .15s,box-shadow .15s}.product-search-input:focus{border-color:var(--spruce);box-shadow:0 0 0 3px #1f4d411f}.category-row{flex-wrap:wrap;flex:1;gap:7px;display:flex}.category-pill{border:1px solid var(--line);background:var(--surface);border-radius:999px;align-items:center;gap:7px;padding:8px 13px;font-size:12.5px;font-weight:700;transition:border-color .15s,background .15s;display:inline-flex}.category-pill:hover{border-color:var(--spruce)}.category-pill.active{border-color:var(--spruce);background:var(--spruce-tint)}.category-pill i{color:var(--ink-soft);font-size:11px;font-style:normal;font-weight:800}.selected-tray{flex-wrap:wrap;gap:6px;display:flex}.selected-chip{background:var(--spruce-tint);max-width:100%;color:var(--spruce-deep);border:1px solid #1f4d4138;border-radius:999px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:7px;padding:6px 9px 6px 11px;font-size:12px;font-weight:700;display:inline-grid}.selected-chip span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.selected-chip i{font-style:normal;line-height:1}.product-empty-note{color:var(--ink-soft);margin:0;font-size:12.5px;line-height:1.45}.catalog-grid{scrollbar-color:var(--line-strong) transparent;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;max-height:64vh;padding:2px 4px 8px 2px;display:grid;overflow:auto}.product-tile{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface);text-align:left;flex-direction:column;width:100%;padding:0;display:flex;position:relative;overflow:hidden}button.product-tile{cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .15s}button.product-tile:hover{border-color:var(--line-strong);box-shadow:var(--shadow-lift);transform:translateY(-2px)}.product-tile[aria-pressed=true]{border-color:var(--spruce);box-shadow:0 0 0 2px #1f4d4147}.product-tile-img{aspect-ratio:4/5;border-bottom:1px solid var(--line);background:#fff;width:100%;display:block;position:relative}.product-tile-img img{object-fit:contain;width:100%;height:100%;padding:14px;position:absolute;inset:0}.product-tile-img-empty{background:repeating-linear-gradient(45deg, var(--surface-2) 0 8px, var(--surface) 8px 16px);position:absolute;inset:0}.product-tile-check{background:var(--spruce);color:#fff;opacity:0;border-radius:50%;place-items:center;width:26px;height:26px;transition:opacity .15s,transform .15s;display:grid;position:absolute;top:8px;right:8px;transform:scale(.6);box-shadow:0 4px 12px #14362d66}.product-tile-check svg{width:13px;height:13px}.product-tile[aria-pressed=true] .product-tile-check{opacity:1;transform:scale(1)}.product-tile-body{flex:1;align-content:start;justify-items:start;gap:4px;padding:10px 12px 12px;display:grid}.product-tile-kicker{color:var(--ink-soft);letter-spacing:.08em;text-transform:uppercase;font-size:10.5px;font-weight:800}.product-tile-name{color:var(--ink);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:13.5px;font-weight:750;line-height:1.25;display:-webkit-box;overflow:hidden}.product-tile-meta{color:var(--ink-soft);-webkit-line-clamp:1;-webkit-box-orient:vertical;font-size:12px;line-height:1.3;display:-webkit-box;overflow:hidden}.product-tile-link{color:var(--spruce);font-size:12.5px;font-weight:800;text-decoration:none}.product-tile-link:hover{text-decoration:underline}.style-tag{background:var(--brass-soft);color:#7c5526;letter-spacing:.05em;text-transform:capitalize;text-overflow:ellipsis;white-space:nowrap;border-radius:999px;justify-self:start;max-width:100%;padding:4px 9px;font-size:11px;font-weight:800;overflow:hidden}.generate-button{border-radius:var(--radius-sm);background:linear-gradient(180deg, var(--spruce), var(--spruce-deep));color:#fff;letter-spacing:.01em;border:0;width:100%;min-height:52px;font-size:16px;font-weight:700;transition:transform .12s,box-shadow .12s,filter .12s;box-shadow:0 10px 24px -10px #14362d8c,inset 0 1px #ffffff24}.generate-button:hover:not(:disabled){filter:brightness(1.06);transform:translateY(-1px);box-shadow:0 14px 28px -10px #14362d99,inset 0 1px #ffffff24}.generate-button:active:not(:disabled){transform:translateY(0)}.generate-button:disabled{box-shadow:none;background:#b9c4be}.generate-hint{text-align:center;color:var(--ink-soft);margin:0;font-size:12.5px;line-height:1.45}.generate-code-form{width:min(100%,360px);margin:2px auto 0}.generate-code-form input{flex:1;width:auto;min-width:0}.result-stage{width:min(1240px,100%);margin:0 auto;padding:28px 32px 40px}.result-stage.full{width:100%}.stage-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.stage-tools{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.status-chip{border-radius:999px;align-items:center;gap:8px;padding:7px 13px;font-size:13px;font-weight:700;display:inline-flex}.status-chip i{background:currentColor;border-radius:50%;width:7px;height:7px}.status-chip.working{background:var(--brass-soft);color:#7c5526}.status-chip.working i{animation:1.1s ease-in-out infinite pulse}.status-chip.ready{background:var(--spruce-tint);color:var(--spruce-deep)}.status-chip.failed{color:var(--danger);background:#a13d311a}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.72)}}.view-toggle{border:1px solid var(--line);background:var(--surface-2);border-radius:999px;gap:3px;padding:3px;display:inline-flex}.view-toggle button{color:var(--ink-soft);background:0 0;border:0;border-radius:999px;padding:6px 13px;font-size:12.5px;font-weight:700;transition:all .15s}.view-toggle button.active{background:var(--surface);color:var(--ink);box-shadow:0 1px 4px #1d2b2624}.compare-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.image-tile{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface);margin:0;transition:box-shadow .2s;overflow:hidden}.image-tile:hover{box-shadow:var(--shadow-lift)}.image-tile figcaption{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:10px;min-height:46px;padding:8px 12px;font-size:13px;font-weight:800;display:flex}.tile-tag{letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);font-size:11px;font-weight:800}.tile-select{appearance:none;cursor:pointer;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2365726b' stroke-width='1.6' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") right 2px center/10px no-repeat;border:0;border-radius:4px;outline:none;width:100%;padding:6px 18px 6px 0;font-size:13px;font-weight:700}.tile-select:focus-visible{box-shadow:0 0 0 3px #1f4d4126}.tile-stage{aspect-ratio:4/5;background:var(--spruce-deep);position:relative}.tile-stage img{object-fit:contain;width:100%;height:100%;position:absolute;inset:0}.tile-working{color:#e9efe9;background:radial-gradient(40rem 22rem at 50% 120%,#a0744038,#0000 60%),linear-gradient(#15302a,#102420);place-content:center;justify-items:center;gap:12px;display:grid;position:absolute;inset:0;overflow:hidden}.tile-working:before{content:"";background:linear-gradient(100deg,#0000 38%,#ffffff21 50%,#0000 62%);animation:1.9s ease-in-out infinite sweep;position:absolute;inset:-40%}@keyframes sweep{0%{transform:translate(-45%)}to{transform:translate(45%)}}.tile-working strong{font-family:var(--font-serif);letter-spacing:.01em;font-size:19px;font-weight:580}.tile-working span{color:#e9efe9a8;font-size:12.5px}.working-dots{gap:6px;display:flex}.working-dots i{background:var(--brass-soft);border-radius:50%;width:6px;height:6px;animation:1.1s ease-in-out infinite pulse}.working-dots i:nth-child(2){animation-delay:.18s}.working-dots i:nth-child(3){animation-delay:.36s}.comparison-shell{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface);overflow:hidden}.comparison-stage{aspect-ratio:8/5;background:var(--spruce-deep);cursor:ew-resize;touch-action:none;-webkit-user-select:none;user-select:none;width:100%;position:relative;overflow:hidden}.comparison-stage.dragging{cursor:grabbing}.comparison-image{object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute;inset:0}.comparison-image.top{z-index:2}.comparison-divider{z-index:3;pointer-events:none;border-left:2px solid #ffffffe6;width:0;position:absolute;top:0;bottom:0;transform:translate(-1px)}.comparison-divider span{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#14362dd9;border:1.5px solid #ffffffe6;border-radius:50%;grid-auto-flow:column;place-items:center;gap:3px;width:36px;height:36px;display:grid;position:absolute;top:50%;left:0;transform:translate(-50%,-50%);box-shadow:0 8px 22px #0000004d}.comparison-divider span:before,.comparison-divider span:after{content:"";border-top:1.5px solid #fff;border-left:1.5px solid #fff;width:7px;height:7px}.comparison-divider span:before{transform:rotate(-45deg)}.comparison-divider span:after{transform:rotate(135deg)}.comparison-tag{z-index:4;pointer-events:none;color:#fff;letter-spacing:.08em;text-transform:uppercase;text-overflow:ellipsis;white-space:nowrap;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#14362dc7;border-radius:999px;max-width:44%;padding:6px 11px;font-size:11px;font-weight:800;position:absolute;top:12px;overflow:hidden}.comparison-tag.left{left:12px}.comparison-tag.right{right:12px}.comparison-range{width:calc(100% - 28px);accent-color:var(--spruce);margin:13px 14px;display:block}.result-summary{gap:16px;margin-top:20px;display:grid}.plan-note{color:var(--ink-soft);margin:0;font-size:13.5px;line-height:1.5}.summary-block h3{font-family:var(--font-serif);margin:0 0 10px;font-size:17px;font-weight:600}.product-card-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:12px;margin:0;padding:0;list-style:none;display:grid}.product-card-grid li{display:flex}.result-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.primary-button,.secondary-button{border-radius:var(--radius-sm);justify-content:center;align-items:center;min-height:44px;padding:0 18px;font-size:14px;font-weight:700;text-decoration:none;transition:all .15s;display:inline-flex}.primary-button{background:linear-gradient(180deg, var(--spruce), var(--spruce-deep));color:#fff;border:0;box-shadow:0 8px 20px -8px #14362d80}.primary-button:hover{filter:brightness(1.07);transform:translateY(-1px)}.secondary-button{border:1px solid var(--line-strong);background:var(--surface);color:var(--ink)}.secondary-button:hover{border-color:var(--spruce);color:var(--spruce-deep)}.footer-note{color:var(--ink-soft);margin:0;font-size:12px;line-height:1.5}@media (max-width:1100px){.direction-step{grid-template-columns:280px minmax(0,1fr)}.direction-main{padding:24px 24px 32px}}@media (max-width:900px){.app-shell{padding:14px 10px 26px}.direction-step{grid-template-columns:1fr}.direction-side{border-right:0;border-bottom:1px solid var(--line);grid-template-columns:140px minmax(0,1fr);align-items:start;gap:14px 16px;position:static}.direction-side .photo-chip{grid-row:1/4}.photo-chip img{max-height:150px}.wizard-bar{gap:8px;padding:12px 14px}.wizard-line{width:18px}.wizard-label{font-size:12.5px}}@media (max-width:640px){.topbar{padding:18px 16px 14px}.brand-name{font-size:23px}.photo-step{padding:28px 16px 36px}.upload-zone.hero{min-height:280px}.crop-stage{max-height:460px}.direction-step{flex-direction:column;display:flex}.direction-side{border-bottom:0;border-top:1px solid var(--line);order:2;grid-template-columns:1fr;padding:20px 16px 24px}.direction-main{order:1}.direction-side .photo-chip{grid-row:auto}.direction-main{padding:20px 16px 28px}.result-stage{padding:20px 14px 30px}.compare-grid{grid-template-columns:1fr}.catalog-grid,.product-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.wizard-label{display:none}.next-button{width:100%;min-width:0}}.plan-panel{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface);gap:14px;margin-top:16px;padding:16px;display:grid}.plan-panel.compact{margin-top:0;padding:12px}.plan-panel.loading{color:var(--ink-soft);font-size:14px}.plan-panel-head,.swap-drawer-head,.field-section-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.plan-kicker{color:var(--ink-soft);letter-spacing:.1em;text-transform:uppercase;font-size:11px;font-weight:800;display:block}.plan-panel h3,.field-section-head h2{font-family:var(--font-serif);margin:0;font-size:21px}.plan-category-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:10px;display:grid}.plan-category-card{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-2);gap:8px;padding:10px;display:grid}.plan-category-label{color:var(--ink-soft);letter-spacing:.08em;text-transform:uppercase;font-size:10.5px;font-weight:800}.plan-empty{border:1px dashed var(--line-strong);border-radius:var(--radius-md);color:var(--ink-soft);align-content:start;gap:6px;padding:12px;font-size:12.5px;line-height:1.3;display:grid}.mini-swap-button,.swap-drawer-head button{border:1px solid var(--line);background:var(--surface);color:var(--spruce);border-radius:999px;justify-self:start;padding:7px 12px;font-size:12px;font-weight:800}.swap-drawer{border-top:1px solid var(--line);gap:10px;padding-top:12px;display:grid}.swap-grid{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:9px;max-height:360px;padding-right:2px;display:grid;overflow:auto}.swap-grid .product-tile-img{aspect-ratio:5/4}.field-shell{background:var(--page);align-content:start;gap:14px;min-height:100svh;padding:14px;display:grid}.field-topbar{z-index:8;background:color-mix(in srgb, var(--page) 92%, transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);justify-content:space-between;align-items:center;gap:12px;padding:12px 2px 8px;display:flex;position:sticky;top:0}.field-topbar h1{font-family:var(--font-serif);margin:0;font-size:24px;line-height:1.1}.field-camera-card,.field-styles,.field-plan-card,.field-code-row{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface);padding:12px}.field-preview{aspect-ratio:3/2;border-radius:calc(var(--radius-md) - 3px);background:var(--spruce-deep);overflow:hidden}.field-preview video,.field-preview img{object-fit:cover;width:100%;height:100%;display:block}.field-actions{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.field-actions .primary-button,.field-actions .secondary-button,.field-section-head .primary-button,.field-plan-card>.primary-button,.field-code-row .secondary-button{min-height:40px;padding-inline:13px;font-size:13px}.file-button{cursor:pointer;position:relative}.file-button input{opacity:0;cursor:pointer;position:absolute;inset:0}.field-note{color:var(--ink-soft);margin:8px 0 0;font-size:12.5px;line-height:1.45}.field-style-strip{scroll-snap-type:x proximity;grid-auto-columns:minmax(132px,42%);grid-auto-flow:column;gap:10px;padding:10px 1px 2px;display:grid;overflow-x:auto}.field-style-card{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);color:var(--ink);text-align:left;scroll-snap-align:start;gap:7px;padding:8px;display:grid}.field-style-card[aria-pressed=true]{border-color:var(--spruce);box-shadow:0 0 0 2px #1f4d4133}.field-style-card img{aspect-ratio:4/3;object-fit:cover;border-radius:6px;width:100%}.field-style-card span{font-family:var(--font-serif);font-size:16px;font-weight:700}.field-plan-list{gap:12px;display:grid}.field-plan-card{gap:10px;display:grid}.field-result{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-2);margin:0;overflow:hidden}.field-result img{width:100%;display:block}.field-result figcaption{color:var(--ink-soft);padding:9px 10px;font-size:12px;line-height:1.4}.field-code-row{grid-template-columns:minmax(0,1fr) auto;gap:8px;display:grid}.field-code-row input{border:1px solid var(--line);border-radius:var(--radius-sm);min-width:0;padding:0 12px;font-size:14px}@media (min-width:760px){.field-shell{max-width:840px;margin:0 auto}}@media (max-width:640px){.plan-category-grid,.swap-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.angle-editors{grid-template-columns:1fr;gap:18px;width:min(100%,920px);margin:0 auto;display:grid}.angle-card{border:1px solid var(--line);border-radius:var(--radius-sm);background:#fffdf7;flex-direction:column;gap:10px;padding:14px;display:flex}.angle-card-head{justify-content:space-between;align-items:center;gap:10px;display:flex}.angle-card-tools{align-items:center;gap:10px;display:flex}.angle-remove{border:1px solid var(--line);width:28px;height:28px;color:var(--ink-soft);cursor:pointer;background:#fff;border-radius:50%;font-size:17px;line-height:1}.angle-remove:hover{color:#a4332a;border-color:#d8b1ad}.upload-zone.add-angle{border-style:dashed;min-height:120px}.photo-chip-stack{gap:4px;display:grid}.photo-chip-stack.multi{grid-template-columns:1fr 1fr}.photo-chip-stack img{object-fit:cover;border-radius:6px;width:100%;height:100%;display:block}.angle-stack{flex-direction:column;gap:26px;display:flex}.angle-block{flex-direction:column;gap:10px;display:flex}.angle-block-head{align-items:center;gap:12px;display:flex}.angle-status{color:var(--ink-soft);font-size:13px}.compare-wrap{position:relative}.corner-pick{z-index:6;position:absolute;bottom:12px}.corner-pick.left{left:12px}.corner-pick.right{right:12px}.corner-pick-btn{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:var(--ink);cursor:pointer;background:#fffdf7db;border:1px solid #ffffff8c;border-radius:999px;align-items:center;gap:7px;max-width:220px;padding:7px 11px;font-size:12.5px;font-weight:600;display:inline-flex;box-shadow:0 4px 14px #17201d38}.corner-pick-btn svg{flex:none;width:14px;height:14px}.corner-pick-btn span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.corner-pick-btn:hover{background:#fffdf7f7}.picker-backdrop{z-index:7;background:0 0;position:fixed;inset:0}.version-pop{z-index:8;border:1px solid var(--line);background:#fffdf7;border-radius:12px;flex-direction:column;gap:2px;min-width:230px;max-height:280px;padding:6px;display:flex;position:absolute;bottom:calc(100% + 8px);overflow-y:auto;box-shadow:0 12px 34px #17201d3d}.corner-pick.left .version-pop{left:0}.corner-pick.right .version-pop{right:0}.version-row{border-radius:8px;align-items:center;gap:4px;display:flex}.version-row.active{background:#3660501a}.version-choose{cursor:pointer;text-align:left;color:var(--ink);background:0 0;border:0;flex:1;align-items:center;gap:9px;min-width:0;padding:5px 7px;font-size:13px;display:flex}.version-choose img{object-fit:cover;border:1px solid var(--line);background:#fff;border-radius:5px;flex:none;width:44px;height:30px}.version-choose span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.version-rename{width:26px;height:26px;color:var(--ink-soft);cursor:pointer;background:0 0;border:0;border-radius:6px;flex:none;justify-content:center;align-items:center;display:inline-flex}.version-rename:hover{color:var(--ink);background:#3660501f}.version-rename svg{width:13px;height:13px}.rename-input{border:1px solid var(--line);border-radius:6px;flex:1;min-width:0;padding:4px 7px;font-size:13px}@media (min-width:860px){.angle-editors.two{grid-template-columns:1fr 1fr}}.slot-board{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface-2);gap:14px;padding:16px;display:grid}.slot-board-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.slot-board-head h3{font-family:var(--font-serif);margin:0;font-size:19px}.slot-add-form{grid-template-columns:minmax(140px,auto) minmax(0,1fr) auto;align-items:center;gap:8px;display:grid}.slot-add-form select,.slot-add-form input{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);min-height:38px;padding:0 10px;font-size:13.5px}.slot-add-form .mini-swap-button:disabled{opacity:.45}.slot-rows{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:8px;display:grid}.slot-row{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface);align-items:center;gap:11px;padding:8px 10px;transition:border-color .15s,box-shadow .15s;display:flex}.slot-row.kept{background:linear-gradient(90deg, #1f4d410f, transparent 65%), var(--surface)}.slot-row.drag-over{border-color:var(--spruce);box-shadow:0 0 0 2px #1f4d414d}.pick-thumb{border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff;flex:none;place-items:center;width:52px;height:52px;display:grid;overflow:hidden}.pick-thumb img{object-fit:contain;width:100%;height:100%;padding:4px}.slot-thumb-button{cursor:pointer;padding:0}.slot-thumb-button:hover{border-color:var(--spruce)}.slot-thumb-mark{color:var(--ink-soft);font-size:19px;font-weight:700}.slot-row.kept .slot-thumb-mark{color:var(--spruce)}.pick-info{flex:1;gap:2px;min-width:0;display:grid}.pick-info strong{color:var(--ink);text-overflow:ellipsis;white-space:nowrap;font-size:13.5px;font-weight:700;line-height:1.25;overflow:hidden}.pick-info small{color:var(--ink-soft);text-overflow:ellipsis;white-space:nowrap;font-size:11.5px;line-height:1.3;overflow:hidden}.pick-info .product-tile-kicker{align-items:center;gap:7px;display:inline-flex}.slot-angle-badge{color:var(--spruce);letter-spacing:.04em;white-space:nowrap;text-transform:none;background:#1f4d411a;border-radius:999px;padding:2px 7px;font-size:9.5px;font-style:normal;font-weight:800}.slot-row-actions{flex:none;align-items:center;gap:6px;display:inline-flex}.slot-remove{border:1px solid var(--line);background:var(--surface);width:26px;height:26px;color:var(--ink-soft);cursor:pointer;border-radius:50%;font-size:15px;line-height:1}.keep-toggle.active{border-color:var(--spruce);background:var(--spruce);color:#fff}.pick-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:8px;max-height:380px;padding-right:2px;display:grid;overflow-y:auto}.pick-row{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface);text-align:left;cursor:pointer;align-items:center;gap:11px;padding:7px 10px;transition:border-color .15s,box-shadow .15s;display:flex}.pick-row:hover{border-color:var(--line-strong);box-shadow:var(--shadow-lift)}.pick-row[aria-pressed=true]{border-color:var(--spruce);box-shadow:0 0 0 2px #1f4d4140}.found-pending{text-align:center;color:var(--ink-soft);margin:0;font-size:12.5px;font-style:italic}.found-chips{flex-wrap:wrap;justify-content:center;align-items:center;gap:5px;display:flex}.found-label{color:var(--ink-soft);letter-spacing:.06em;text-transform:uppercase;font-size:11px;font-weight:800}.found-chip{border:1px solid var(--line);background:var(--surface);color:var(--ink);white-space:nowrap;border-radius:999px;padding:3px 9px;font-size:11.5px;font-weight:600}@media (max-width:640px){.slot-rows,.pick-grid,.slot-add-form{grid-template-columns:1fr}}.slot-pick-hint{color:var(--ink-soft);margin:0;font-size:12.5px;font-style:italic}.placement-clear{border:1px solid var(--line);background:var(--surface);width:18px;height:18px;color:var(--ink-soft);cursor:pointer;vertical-align:middle;border-radius:50%;margin-left:5px;font-size:11px;line-height:1}.slot-board-actions{flex-wrap:wrap;align-items:center;gap:7px;display:flex}.style-pick{position:relative}.style-menu{z-index:9;border:1px solid var(--line);background:#fffdf7;border-radius:12px;flex-direction:column;gap:2px;width:290px;max-height:380px;padding:6px;display:flex;position:absolute;top:calc(100% + 8px);right:0;overflow-y:auto;box-shadow:0 12px 34px #17201d3d}.style-menu-item{text-align:left;cursor:pointer;background:0 0;border:0;border-radius:8px;align-items:center;gap:10px;padding:6px 8px;display:flex}.style-menu-item:hover{background:#36605014}.style-menu-item.active{background:#3660501f}.style-menu-item img{object-fit:cover;border-radius:6px;flex:none;width:58px;height:40px}.style-menu-item strong{color:var(--ink);font-size:13.5px;display:block}.style-menu-item small{color:var(--ink-soft);font-size:11.5px}.style-confirm{gap:10px;padding:12px;display:grid}.style-confirm p{color:var(--ink);margin:0;font-size:13px;line-height:1.45}.style-confirm-actions{gap:8px;display:flex}.slot-board-body{gap:14px;display:grid}.slot-board-body.split{grid-template-columns:minmax(0,1fr) 320px;align-items:start}.slot-board-body.split .slot-rows{scrollbar-color:var(--line-strong) transparent;grid-template-columns:1fr;max-height:470px;padding-right:4px;overflow-y:auto}.slot-board-main{gap:12px;min-width:0;display:grid}.products-panel{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface);gap:10px;padding:12px;display:grid}.products-panel .product-search-input{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-2);width:100%;min-height:38px;padding:0 12px;font-size:13.5px}.panel-results{scrollbar-color:var(--line-strong) transparent;gap:6px;max-height:360px;padding-right:2px;display:grid;overflow-y:auto}.panel-hint{color:var(--ink-soft);text-align:center;margin:0;font-size:11.5px;font-style:italic}@media (max-width:860px){.slot-board-body.split{grid-template-columns:1fr}.products-panel{order:-1}}.products-panel .category-row{scrollbar-color:var(--line-strong) transparent;flex-wrap:nowrap;gap:6px;padding-bottom:4px;display:flex;overflow-x:auto}.products-panel .category-pill{white-space:nowrap;flex:none}.keep-pin{border:1px solid var(--line);background:var(--surface);width:27px;height:27px;color:var(--ink-soft);cursor:pointer;border-radius:50%;flex:none;place-items:center;transition:border-color .15s,background .15s,color .15s;display:inline-grid}.keep-pin svg{width:13px;height:13px}.keep-pin:hover{border-color:var(--spruce);color:var(--spruce)}.keep-pin.active{border-color:var(--spruce);background:var(--spruce);color:#fff}.slot-row.drag-target{border-color:var(--spruce);background:linear-gradient(90deg, #1f4d4112, transparent 70%), var(--surface);box-shadow:0 0 0 2px #1f4d412e}.photo-chip-frame{min-width:0;display:block;position:relative}.photo-chip-frame img{display:block}.fixture-box{opacity:0;cursor:pointer;background:#1f4d410d;border:1.5px solid #1f4d41e6;border-radius:4px;transition:opacity .12s,background .12s;position:absolute}.photo-chip-frame:hover .fixture-box{opacity:.4}.fixture-box.on,.photo-chip-frame:hover .fixture-box:hover{opacity:1;background:#1f4d4129;box-shadow:0 0 0 1px #fffdf7b3}.slot-row.hover-link{border-color:var(--spruce);box-shadow:0 0 0 2px #1f4d412e}.camera-cta{border:1px solid var(--line);background:var(--surface);color:var(--spruce);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;gap:8px;margin:10px auto 0;padding:11px 18px;font-size:13.5px;font-weight:700;display:inline-flex;position:relative;overflow:hidden}.camera-cta:hover{border-color:var(--spruce)}.camera-cta svg{width:16px;height:16px}.add-angle-stack{justify-items:center;display:grid}@media (max-width:900px){body:has(.app-shell:not(.embed)){overscroll-behavior:none;height:100dvh;overflow:hidden}.app-shell:not(.embed){height:100dvh;min-height:0;padding:0;overflow:hidden}.app-shell:not(.embed) .viz-frame{width:100%;height:100%;box-shadow:none;border:0;border-radius:0;flex-direction:column;display:flex}.app-shell:not(.embed) .topbar{flex-wrap:nowrap;flex:none;gap:10px;padding:10px 16px}.app-shell:not(.embed) .topbar .code-form{display:none}.app-shell:not(.embed) .brand-name{font-size:19px}.app-shell:not(.embed) .credit-pill{padding:7px 11px;font-size:12px}.app-shell:not(.embed) .wizard-bar{flex:none;padding:8px 10px}.app-shell:not(.embed) .photo-step,.app-shell:not(.embed) .direction-step,.app-shell:not(.embed) .result-stage{-webkit-overflow-scrolling:touch;flex:1;min-height:0;overflow-y:auto}}body.mshell-lock{overscroll-behavior:none;height:100dvh;overflow:hidden}.mshell{background:var(--paper);height:100dvh;font-family:var(--font-sans);position:fixed;inset:0;overflow:hidden}.mstage{padding:calc(64px + env(safe-area-inset-top)) 12px calc(96px + env(safe-area-inset-bottom));justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.mstage-bg{filter:blur(34px)saturate(1.05);opacity:.45;background-position:50%;background-size:cover;position:absolute;inset:-48px}.mstage-bg:after{content:"";background:#fdfbf673;position:absolute;inset:0}.mphoto,.mcompare{border-radius:20px;width:100%;max-height:100%;position:relative;overflow:visible;box-shadow:0 18px 50px -18px #1d2b2673}.mphoto img{object-fit:cover;border-radius:20px;width:100%;height:100%;display:block}.mphoto .fixture-box.tappable{cursor:pointer;opacity:1;background:#fdfbf614;border:1.5px solid #fffdf7d9;border-radius:10px;outline:1.5px solid #1f4d418c;padding:0;position:absolute}.mphoto .fixture-box.tappable span{color:var(--spruce-deep);letter-spacing:.02em;white-space:nowrap;background:#fdfbf6e0;border-radius:999px;padding:2px 7px;font-size:10.5px;font-weight:700;position:absolute;bottom:4px;left:4px}.mreading{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--ink-soft);white-space:nowrap;background:#fdfbf6e6;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:600;position:absolute;top:10px;left:50%;transform:translate(-50%)}.mworking{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--spruce-deep);text-align:center;background:#fdfbf69e;border-radius:20px;flex-direction:column;justify-content:center;align-items:center;gap:6px;display:flex;position:absolute;inset:0}.mworking strong{font-family:var(--font-serif);font-size:19px}.mworking span{color:var(--ink-soft);font-size:13px}.mcompare .comparison-shell{background:0 0;border:0;border-radius:20px;height:100%}.mcompare .comparison-stage{aspect-ratio:auto;background:0 0;border-radius:20px;height:100%}.mcompare .comparison-image{object-fit:cover}.mcompare .comparison-range{display:none}.mcompare .corner-pick{bottom:10px}.mtop{z-index:10;padding:calc(10px + env(safe-area-inset-top)) 14px 10px;justify-content:space-between;align-items:center;gap:10px;display:flex;position:absolute;top:0;left:0;right:0}.mtop-brand{font-family:var(--font-serif);color:var(--spruce-deep);text-shadow:0 1px 8px #fdfbf6cc;font-size:17px;font-weight:600}.mshell-cam .mtop-brand{color:#fffdf7;text-shadow:0 1px 10px #14201b99}.mtop-btn{-webkit-backdrop-filter:blur(14px)saturate(1.3);backdrop-filter:blur(14px)saturate(1.3);width:40px;height:40px;color:var(--spruce-deep);background:#fdfbf6c7;border:1px solid #fffdf780;border-radius:999px;justify-content:center;align-items:center;font-size:19px;display:inline-flex;box-shadow:0 4px 16px #17201d2e}.mtop-btn svg{width:18px;height:18px}.mcredits{-webkit-backdrop-filter:blur(14px)saturate(1.3);backdrop-filter:blur(14px)saturate(1.3);color:var(--spruce-deep);white-space:nowrap;background:#fdfbf6c7;border:1px solid #fffdf780;border-radius:999px;padding:7px 12px;font-size:12.5px;font-weight:700;box-shadow:0 4px 16px #17201d2e}.mcredits.empty{color:var(--danger)}.mangle-chips{-webkit-backdrop-filter:blur(14px)saturate(1.3);backdrop-filter:blur(14px)saturate(1.3);background:#fdfbf6b3;border-radius:999px;gap:6px;padding:4px;display:flex;box-shadow:0 4px 16px #17201d29}.mangle-chip{color:var(--ink-soft);background:0 0;border:1.5px solid #0000;border-radius:999px;align-items:center;gap:6px;padding:3px 10px 3px 3px;font-size:12.5px;font-weight:700;display:inline-flex;position:relative}.mangle-chip img{object-fit:cover;border-radius:999px;width:28px;height:28px}.mangle-chip.active{border-color:var(--spruce);color:var(--spruce-deep);background:#fffdf7}.mdock{left:10px;right:10px;bottom:calc(10px + env(safe-area-inset-bottom));z-index:10;-webkit-backdrop-filter:blur(18px)saturate(1.4);backdrop-filter:blur(18px)saturate(1.4);background:#fdfbf6c7;border:1px solid #fffdf78c;border-radius:22px;align-items:stretch;gap:8px;padding:8px;display:flex;position:absolute;box-shadow:0 14px 40px -10px #17201d59}.mdock-btn{text-align:left;background:#ffffff8c;border:0;border-radius:15px;flex-direction:column;flex:1;align-items:flex-start;gap:1px;min-width:0;padding:9px 12px;display:flex}.mdock-btn:disabled{opacity:.45}.mdock-btn strong{color:var(--spruce-deep);font-size:13.5px}.mdock-btn small{width:100%;color:var(--ink-soft);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.mdock-gen{background:linear-gradient(160deg, var(--spruce), var(--spruce-deep));color:#fdfbf4;letter-spacing:.01em;border:0;border-radius:15px;flex:none;padding:9px 18px;font-size:14.5px;font-weight:700;box-shadow:0 8px 20px -8px #14362db3}.mdock-gen:disabled{opacity:.5;box-shadow:none}.mtoast{top:calc(64px + env(safe-area-inset-top));z-index:12;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--danger);background:#fdf5f2f0;border:1px solid #a13d3159;border-radius:14px;padding:10px 14px;font-size:13px;position:absolute;left:14px;right:14px;box-shadow:0 10px 26px -10px #17201d4d}.msheet-backdrop{z-index:18;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#1d2b262e;position:fixed;inset:0}.msheet{z-index:19;-webkit-backdrop-filter:blur(22px)saturate(1.35);backdrop-filter:blur(22px)saturate(1.35);background:#fdfbf6f0;border:1px solid #fffdf799;border-bottom:0;border-radius:24px 24px 0 0;flex-direction:column;max-height:78dvh;animation:.26s cubic-bezier(.32,.9,.4,1) msheet-up;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -18px 50px -16px #17201d66}@keyframes msheet-up{0%{opacity:.4;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}.msheet-head{flex:none;justify-content:space-between;align-items:center;gap:8px;padding:16px 14px 10px;display:flex;position:relative}.msheet-head:before{content:"";background:var(--line-strong);border-radius:999px;width:38px;height:4px;position:absolute;top:7px;left:50%;transform:translate(-50%)}.msheet-head h3{font-family:var(--font-serif);text-align:center;white-space:nowrap;text-overflow:ellipsis;flex:1;margin:0;font-size:17px;overflow:hidden}.msheet-nav{text-align:left;min-width:64px;color:var(--spruce);background:0 0;border:0;flex:none;padding:5px 0;font-size:13px;font-weight:700}.msheet-nav-spacer{flex:none;min-width:64px}.msheet-close{background:var(--surface-2);width:30px;height:30px;color:var(--ink-soft);border:0;border-radius:999px;flex:none;margin-left:34px;font-size:18px;line-height:1}.msheet-nav+h3+.msheet-close,.msheet-nav-spacer+h3+.msheet-close{margin-left:0}.msheet-body{-webkit-overflow-scrolling:touch;min-height:0;padding:4px 14px calc(16px + env(safe-area-inset-bottom));flex-direction:column;flex:1;gap:10px;display:flex;overflow-y:auto}.msheet-actions{justify-content:flex-end;gap:8px;display:flex}.msheet-styles{flex-direction:column;gap:6px;display:flex}.msheet-styles .style-menu-item{border:1px solid var(--line);background:#fffdf7;border-radius:14px}.msheet-styles .style-menu-item.active{border-color:var(--spruce);background:var(--spruce-tint)}.msheet .slot-row{background:#fffdf7}.msheet .slot-info-button{text-align:left;background:0 0;border:0;flex-direction:column;flex:1;align-items:flex-start;gap:2px;min-width:0;padding:0;display:flex}.msheet .slot-info-button strong{font-size:13.5px}.msheet .slot-info-button small{color:var(--ink-soft);font-size:11.5px}.msheet-gen{flex-direction:column;gap:10px;display:flex}.msheet-gen textarea{border:1px solid var(--line);resize:vertical;background:#fffdf7;border-radius:14px;min-height:84px;padding:11px 13px}.msheet-gen .generate-button{width:100%}.msheet-gen .generate-hint{text-align:center;margin:0}.msheet-summary .product-card-grid{grid-template-columns:1fr 1fr;gap:10px;margin:0;padding:0;list-style:none;display:grid}.msheet-summary .result-actions{flex-direction:column;gap:8px;margin-top:12px;display:flex}.mshell-cam{background:#141d19}.mcam{position:absolute;inset:0}.mcam-video{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.mcam-starting{color:#fffdf7d9;justify-content:center;align-items:center;font-size:14px;font-weight:600;display:flex;position:absolute;inset:0}.mcam-flash{z-index:9;pointer-events:none;background:#fffdf7;animation:.24s ease-out forwards mcam-flash;position:absolute;inset:0}@keyframes mcam-flash{0%{opacity:.9}to{opacity:0}}.mcam-controls{left:0;right:0;bottom:calc(18px + env(safe-area-inset-bottom));z-index:8;justify-content:space-between;align-items:center;padding:0 34px;display:flex;position:absolute}.mcam-gallery{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fffdf7;cursor:pointer;background:#fdfbf638;border:1px solid #fffdf773;border-radius:14px;justify-content:center;align-items:center;width:46px;height:46px;display:inline-flex}.mcam-gallery svg{width:21px;height:21px}.mcam-gallery input{display:none}.mcam-shutter{background:#fffdf72e;border:4px solid #fffdf7;border-radius:999px;justify-content:center;align-items:center;width:74px;height:74px;padding:0;display:inline-flex}.mcam-shutter span{background:#fffdf7;border-radius:999px;width:56px;height:56px;transition:transform .12s}.mcam-shutter:active span{transform:scale(.86)}.mcam-shutter:disabled{opacity:.45}.mcam-side-spacer{width:46px;height:46px}.mcam-tray{left:0;right:0;bottom:calc(108px + env(safe-area-inset-bottom));z-index:8;flex-direction:column;align-items:center;gap:9px;padding:0 20px;display:flex;position:absolute}.mcam-thumbs{gap:8px;display:flex}.mcam-thumb{border:2px solid #fffdf7e6;border-radius:12px;width:56px;height:56px;position:relative;box-shadow:0 6px 18px #0a120f73}.mcam-thumb img{object-fit:cover;border-radius:10px;width:100%;height:100%;display:block}.mcam-thumb button{width:22px;height:22px;color:var(--ink);background:#fffdf7;border:0;border-radius:999px;font-size:14px;line-height:1;position:absolute;top:-8px;right:-8px;box-shadow:0 3px 8px #0a120f66}.mcam-hint{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fffdf7f2;text-align:center;background:#141d1966;border-radius:999px;padding:6px 13px;font-size:12.5px;font-weight:600}.mcam-continue{background:linear-gradient(160deg, var(--spruce), var(--spruce-deep));color:#fdfbf4;border:0;border-radius:999px;padding:11px 22px;font-size:14.5px;font-weight:700;box-shadow:0 10px 26px -8px #0a120fa6}.mcam-fallback{text-align:center;background:radial-gradient(40rem 26rem at 80% -10%, #a074401f, transparent 60%), var(--paper);color:var(--ink);flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:28px;display:flex;position:absolute;inset:0}.mcam-fallback h2{font-family:var(--font-serif);margin:0;font-size:23px}.mcam-fallback p{color:var(--ink-soft);margin:0 0 10px;font-size:14px}.mcam-fb-btn{border:1px solid var(--line-strong);width:min(300px,100%);color:var(--spruce-deep);cursor:pointer;background:#fffdf7;border-radius:16px;padding:13px 18px;font-size:15px;font-weight:700;display:block}.mcam-fb-btn.primary{background:linear-gradient(160deg, var(--spruce), var(--spruce-deep));color:#fdfbf4;border:0}.mcam-fb-btn input{display:none}.style-card-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;display:grid}.style-card{border:1.5px solid var(--line);border-radius:var(--radius-md);background:var(--surface);cursor:pointer;text-align:center;flex-direction:column;align-items:stretch;gap:8px;padding:8px;transition:border-color .12s,box-shadow .12s;display:flex}.style-card:hover{border-color:var(--line-strong)}.style-card.active{border-color:var(--spruce);box-shadow:0 0 0 2px var(--spruce-tint)}.style-card img{aspect-ratio:4/3;object-fit:cover;border-radius:var(--radius-sm);width:100%;display:block}.style-card-name{font-family:var(--font-serif);color:var(--ink);font-size:14.5px;font-weight:600}.code-redeem-form{margin-top:10px;position:relative}.code-redeem-form .code-msg{color:var(--ink-soft);margin-top:6px;font-size:12.5px;display:block}
