@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.isolate{isolation:isolate}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.rounded{border-radius:.25rem}.border{border-style:var(--tw-border-style);border-width:1px}.uppercase{text-transform:uppercase}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.grayscale{--tw-grayscale:grayscale(100%);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.sepia{--tw-sepia:sepia(100%);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}}*,:before,:after{box-sizing:border-box}body{-webkit-user-select:none;user-select:none}input,textarea,[contenteditable]{-webkit-user-select:text;user-select:text}img,canvas{-webkit-user-drag:none;user-drag:none;pointer-events:none}.upload-area,.upload-area img,.cam-viewport img,.cam-viewport canvas{pointer-events:auto}:root{--bg:#f8f6f2;--surface:#fff;--text:#2c2417;--text-muted:#8a7b6a;--border:#e4dbd0;--accent:#b5614b;--accent-hover:#c97b67;--accent-soft:#f6ece8;--radius:10px;--shadow:0 2px 8px #2c24170f}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;margin:0;font-family:-apple-system,Segoe UI,system-ui,sans-serif;font-size:14px;line-height:1.5}.landing{flex-direction:column;min-height:100dvh;display:flex}.landing-nav{align-items:center;padding:16px 32px;display:flex}.landing-logo{color:var(--accent);letter-spacing:-.5px;font-size:18px;font-weight:800}.hero{text-align:center;padding:60px 32px 48px}.hero-content{max-width:600px;margin:0 auto}.hero h1{letter-spacing:-1.5px;color:var(--text);margin:0 0 16px;font-size:44px;font-weight:900;line-height:1.1}.hero-sub{color:var(--text-muted);margin:0;font-size:18px;line-height:1.6}.tools-section{padding:0 32px 48px}.tools-container{max-width:800px;margin:0 auto}.section-title{text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin:0 0 16px;font-size:14px;font-weight:700}.tool-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;transition:box-shadow .2s,transform .2s;position:relative;overflow:hidden;box-shadow:0 2px 12px #2c241712}.tool-card-featured{cursor:pointer;margin-bottom:16px}.tool-card-featured:hover{transform:translateY(-2px);box-shadow:0 8px 28px #b5614b26}.tool-card-badge{text-transform:uppercase;letter-spacing:.5px;background:var(--accent);color:#fff;border-radius:0 0 8px;padding:4px 12px;font-size:11px;font-weight:700;display:inline-block;position:absolute;top:0;left:0}.badge-soon{background:var(--border);color:var(--text-muted)}.tool-card-body{align-items:flex-start;gap:20px;padding:32px 28px 28px;display:flex}.tool-card-icon{color:var(--accent);flex-shrink:0}.tool-card-icon.muted{color:var(--text-muted);opacity:.5}.tool-card-text{flex:1}.tool-card-text h3{margin:0 0 6px;font-size:20px;font-weight:800}.tool-card-text p{color:var(--text-muted);margin:0;font-size:14px;line-height:1.6}.tool-card-action{flex-shrink:0;align-self:center}.tool-cta{color:var(--accent);white-space:nowrap;font-size:14px;font-weight:700}.tool-card-featured:hover .tool-cta{text-decoration:underline}.tool-cards-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.tool-card-soon{opacity:.7}.tool-card-soon .tool-card-body{flex-direction:column;gap:12px;padding:28px 20px 20px}.tool-card-soon .tool-card-text h3{font-size:16px}.tool-card-soon .tool-card-text p{font-size:13px}.feedback-section{background:var(--surface);border-top:1px solid var(--border);text-align:center;padding:48px 32px}.feedback-container{max-width:520px;margin:0 auto}.feedback-sub{color:var(--text-muted);margin:8px 0 24px;font-size:15px;line-height:1.5}.feedback-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:10px 28px;font-size:14px;font-weight:700;text-decoration:none;transition:opacity .15s;display:inline-block}.feedback-btn:hover{opacity:.85}.feedback-btn:disabled{opacity:.5;cursor:not-allowed}.feedback-form{flex-direction:column;align-items:center;gap:12px;display:flex}.feedback-input{border:1px solid var(--border);resize:vertical;width:100%;color:var(--text);background:#fff;border-radius:8px;padding:12px;font-family:inherit;font-size:14px}.feedback-input:focus{border-color:var(--accent);outline:none}.feedback-thanks{color:var(--accent);font-size:15px;font-weight:600}.feedback-error{color:#d32f2f;margin:0;font-size:13px}.captcha-row{align-self:flex-start;align-items:center;gap:10px;display:flex}.captcha-label{color:var(--text-muted);white-space:nowrap;font-size:14px}.captcha-input{border:1px solid var(--border);text-align:center;width:56px;color:var(--text);background:#fff;border-radius:6px;padding:6px 10px;font-family:inherit;font-size:14px}.captcha-input:focus{border-color:var(--accent);outline:none}.steps{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.step{text-align:center}.step-num{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;margin:0 auto 12px;font-size:18px;font-weight:800;display:flex}.step h4{margin:0 0 6px;font-size:15px;font-weight:700}.step p{color:var(--text-muted);margin:0;font-size:13px;line-height:1.5}.landing-footer{border-top:1px solid var(--border);align-items:center;gap:16px;margin-top:auto;padding:24px 32px;display:flex}.footer-text{color:var(--text-muted);font-size:13px}@media(max-width:600px){.hero{padding:40px 20px 32px}.hero h1{font-size:30px}.hero-sub{font-size:15px}.tools-section,.feedback-section{padding-left:20px;padding-right:20px}.tool-card-body{flex-direction:column;gap:12px}.tool-card-action{align-self:flex-start}.tool-cards-row{grid-template-columns:1fr}.steps{grid-template-columns:1fr;gap:20px}.landing-footer{flex-direction:column;align-items:flex-start;gap:4px}}.app{flex-direction:column;height:100dvh;display:flex;overflow:hidden}.app-header{background:var(--accent);color:#fff;flex-shrink:0;align-items:center;gap:12px;padding:10px 20px;display:flex}.app-header h1{letter-spacing:-.5px;margin:0;font-size:20px;font-weight:800}.header-home{color:#fff;letter-spacing:-.5px;cursor:pointer;opacity:.85;background:0 0;border:none;padding:0;font-size:18px;font-weight:800;transition:opacity .15s}.header-home:hover{opacity:1}.header-divider{opacity:.4;font-size:20px;font-weight:300}.subtitle{opacity:.75;font-size:13px}.header-btn{color:#fff;cursor:pointer;background:#fff3;border:1px solid #ffffff4d;border-radius:6px;margin-left:auto;padding:5px 14px;font-family:inherit;font-size:12px;font-weight:600}.header-btn:hover{background:#ffffff4d}.app-main{flex:1;overflow:hidden auto}.btn{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:var(--radius);cursor:pointer;justify-content:center;align-items:center;padding:8px 18px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s;display:inline-flex}.btn:hover{background:#f0ebe3}.btn:disabled{opacity:.4;cursor:default}.btn-sm{padding:5px 12px;font-size:12px}.btn-generate{background:var(--accent);color:#fff;border-color:var(--accent);border-radius:var(--radius);width:100%;margin-top:8px;padding:14px;font-size:16px;font-weight:700}.btn-generate:hover{background:var(--accent-hover)}.btn-generate:disabled{background:var(--accent)}.btn-export{background:var(--accent);color:#fff;border-color:var(--accent)}.link-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:4px 0;font-family:inherit;font-size:13px;font-weight:600;text-decoration:underline}.chip{border:1px solid var(--border);background:var(--surface);cursor:pointer;color:var(--text-muted);border-radius:20px;align-items:center;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s;display:inline-flex}.chip:hover{border-color:var(--accent);color:var(--accent)}.chip-active{background:var(--accent);color:#fff;border-color:var(--accent)}.chip-sm{padding:3px 9px;font-size:11px}.toggle{cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.toggle input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px}.toggle-hint{color:var(--text-muted);font-size:11px}.toggle-compact{gap:5px;font-size:12px}.upload-screen{max-width:520px;margin:0 auto;padding:40px 20px}.upload-area{border:2px dashed var(--border);background:var(--surface);cursor:pointer;text-align:center;border-radius:16px;flex-direction:column;align-items:center;padding:48px 24px;transition:all .2s;display:flex}.upload-area:hover{border-color:var(--accent);background:var(--accent-soft)}.upload-icon{background:var(--accent-soft);width:56px;height:56px;color:var(--accent);border-radius:50%;justify-content:center;align-items:center;margin-bottom:16px;font-size:28px;font-weight:700;display:flex}.upload-area h2{margin:0 0 4px;font-size:22px;font-weight:800}.upload-area p{color:var(--text-muted);margin:0;font-size:14px}.upload-hint{font-weight:600;color:var(--accent)!important;margin-top:12px!important;font-size:12px!important}.tips{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);margin-top:32px;padding:20px}.tips h3{color:var(--text-muted);margin:0 0 8px;font-size:14px;font-weight:700}.tips ul{margin:0;padding-left:20px}.tips li{color:var(--text-muted);margin-bottom:4px;font-size:13px}.how-it-works{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);margin-top:32px;padding:20px}.how-it-works h3{color:var(--text-muted);margin:0 0 16px;font-size:14px;font-weight:700}.how-it-works .steps{gap:16px}.how-it-works .step-num{width:32px;height:32px;font-size:14px}.how-it-works .step h4{font-size:13px}.how-it-works .step p{font-size:12px}.maker-screen{max-width:800px;margin:0 auto;padding:20px}.maker-layout{align-items:flex-start;gap:20px;display:flex}.preview-card{flex-direction:column;flex-shrink:0;gap:8px;display:flex}.source-image{object-fit:cover;border:1px solid var(--border);width:200px;height:200px;box-shadow:var(--shadow);border-radius:12px}.prepare-canvas-wrap{border:1px solid var(--border);box-shadow:var(--shadow);border-radius:12px;line-height:0;display:inline-block;overflow:hidden}.prepare-zoom-bar{color:var(--text-secondary);align-items:center;gap:8px;font-size:.8rem;display:flex}.settings-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);flex:1;padding:20px}.settings-card h3{margin:0 0 16px;font-size:18px;font-weight:800}.setting{flex-direction:column;gap:4px;margin-bottom:16px;display:flex}.setting-label{color:var(--text);justify-content:space-between;font-size:13px;font-weight:600;display:flex}.setting-label strong{color:var(--accent)}.setting input[type=range]{width:100%;accent-color:var(--accent)}.setting-hint{color:var(--text-muted);font-size:11px}.setting-toggles{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.fabric-chips{gap:4px;margin:6px 0;display:flex}.view-screen{flex-direction:column;height:100%;display:flex}.view-toolbar{background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:8px 16px;display:flex}.view-toolbar-right{align-items:center;gap:12px;display:flex}.zoom-label{color:var(--text-muted);align-items:center;gap:6px;font-size:12px;display:flex}.zoom-label input[type=range]{width:80px;accent-color:var(--accent)}.view-body{flex:1;display:flex;overflow:hidden}.view-sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:260px;display:flex;overflow:hidden}.legend-header{padding:14px 16px 8px}.legend-header h3{margin:0;font-size:15px;font-weight:800}.legend-subtitle{color:var(--text-muted);font-size:11px}.fabric-size{border-bottom:1px solid var(--border);flex-direction:column;gap:4px;padding:0 16px 10px;display:flex}.fabric-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.fabric-result{color:var(--accent);font-size:14px;font-weight:700}.legend-list{flex:1;padding:4px 0;overflow-y:auto}.legend-row{cursor:pointer;border-left:3px solid #0000;align-items:center;gap:10px;padding:6px 16px;transition:background .1s;display:flex}.legend-row:hover{background:#faf7f2}.legend-row.legend-active{background:var(--accent-soft);border-left-color:var(--accent)}.legend-num{border:1px solid #0000001a;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:11px;font-weight:800;display:flex}.legend-details{flex-direction:column;flex:1;min-width:0;display:flex}.legend-name{font-size:13px;font-weight:700}.legend-color-name{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.legend-count{color:var(--text-muted);background:var(--bg);border-radius:4px;flex-shrink:0;padding:2px 7px;font-size:11px;font-weight:600}.legend-row-all .legend-name{font-size:12px}.view-grid-area{flex:1;justify-content:center;align-items:flex-start;display:flex;overflow:hidden}.view-grid-scroll{max-width:100%;max-height:100%;padding:16px;overflow:auto}.pattern-canvas{box-shadow:var(--shadow);border:1px solid var(--border);image-rendering:pixelated;display:block}.legend-list::-webkit-scrollbar{width:6px;height:6px}.view-grid-scroll::-webkit-scrollbar{width:6px;height:6px}.app-main::-webkit-scrollbar{width:6px;height:6px}.legend-list::-webkit-scrollbar-track{background:0 0}.view-grid-scroll::-webkit-scrollbar-track{background:0 0}.app-main::-webkit-scrollbar-track{background:0 0}.legend-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.view-grid-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.app-main::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.svg-preview{box-shadow:var(--shadow);border:1px solid var(--border);background:#fff}.svg-preview svg{width:100%;height:100%;display:block}.layer-toggle{cursor:pointer;flex-shrink:0}.layer-toggle input[type=checkbox]{accent-color:var(--accent);cursor:pointer;width:14px;height:14px}.legend-row-hidden{opacity:.4}.layer-preview-3d{flex-direction:column;justify-content:center;align-items:center;min-height:400px;padding:60px 20px 20px;display:flex;position:relative}.layer-slice{cursor:pointer;border-radius:4px;width:360px;max-width:90%;margin-top:-8px;transition:opacity .2s,transform .2s;position:relative;overflow:hidden}.layer-slice:first-child{margin-top:0}.layer-slice svg{width:100%;height:auto;display:block}.view-mode-tabs{background:var(--bg);border:1px solid var(--border);border-radius:6px;gap:2px;padding:2px;display:flex}.view-mode-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 12px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s}.view-mode-tab:hover{color:var(--text)}.view-mode-tab-active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px #00000014}.assembly-guide{border-top:1px solid var(--border);margin-top:16px;padding-top:16px}.assembly-guide h3{margin-bottom:12px;font-size:14px;font-weight:700}.assembly-guide h4{color:var(--text-muted);margin-bottom:8px;font-size:12px;font-weight:600}.spacer-chips{gap:6px;margin:8px 0;display:flex}.chip-active{background:var(--accent-soft)!important;border-color:var(--accent)!important;color:var(--accent)!important}.assembly-stats{grid-template-columns:repeat(3,1fr);gap:8px;margin:12px 0;display:grid}.assembly-stat{background:var(--bg);border-radius:6px;flex-direction:column;align-items:center;padding:8px;font-size:11px;display:flex}.assembly-stat strong{color:var(--text);font-size:16px}.assembly-stat-label{color:var(--text-muted);margin-top:2px;font-size:10px}.assembly-guide-list ol{color:var(--text-muted);padding-left:20px;font-size:12px;line-height:1.6}.assembly-guide-list li{margin-bottom:4px}.palette-options{flex-direction:column;gap:6px;margin-top:6px;display:flex}.palette-option{border:1.5px solid var(--border);cursor:pointer;background:var(--surface);border-radius:8px;align-items:flex-start;gap:8px;padding:10px 12px;transition:all .15s;display:flex}.palette-option:hover{border-color:var(--accent)}.palette-option-active{border-color:var(--accent);background:var(--accent-soft)}.palette-radio{accent-color:var(--accent);margin-top:2px}.palette-option-body{flex-direction:column;gap:2px;min-width:0;display:flex}.palette-option-name{color:var(--text);font-size:13px;font-weight:700}.palette-option-desc{color:var(--text-muted);font-size:11px}.palette-option-swatches{flex-wrap:wrap;align-items:center;gap:2px;margin-top:4px;display:flex}.palette-swatch{border:1px solid #0000001a;border-radius:3px;flex-shrink:0;width:14px;height:14px}.palette-swatch-more{color:var(--text-muted);margin-left:2px;font-size:10px;font-weight:600}.cam-main{background:#000;flex-direction:column;flex:1;display:flex;overflow:hidden}.cam-viewport{flex:1;gap:0;min-height:0;display:flex;position:relative;overflow:hidden}.cam-video{object-fit:cover;background:#111;flex:1;min-width:0}.cam-preview-canvas{object-fit:contain;image-rendering:pixelated;background:#1a1a1a;flex:1;min-width:0}.cam-controls{background:var(--surface);border-top:1px solid var(--border);flex-direction:column;flex-shrink:0;align-items:center;gap:10px;padding:12px 20px 16px;display:flex}.cam-mode-tabs{background:var(--bg);border:1px solid var(--border);border-radius:8px;gap:2px;padding:2px;display:flex}.cam-sliders{width:100%;max-width:300px}.cam-slider{color:var(--text-muted);align-items:center;gap:10px;font-size:13px;display:flex}.cam-slider input[type=range]{flex:1}.cam-slider strong{color:var(--text);text-align:right;min-width:20px}.cam-actions{justify-content:center;align-items:center;gap:24px;display:flex}.cam-capture-btn{background:var(--accent);width:64px;height:64px;box-shadow:0 0 0 2px var(--accent);cursor:pointer;border:4px solid #fff;border-radius:50%;transition:transform .1s}.cam-capture-btn:active{transform:scale(.92)}.cam-capture-btn:disabled{opacity:.4;cursor:default}.cam-switch-btn{width:40px;height:40px;color:var(--text);cursor:pointer;background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;transition:background .15s;display:flex}.cam-switch-btn:hover{background:#ffffff40}.cam-error{text-align:center;color:var(--text);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:40px 20px;display:flex}.cam-error h2{font-size:20px}.cam-error p{color:var(--text-muted);max-width:400px}.cam-captured-overlay{z-index:10;background:#000000d9;flex-direction:column;justify-content:center;align-items:center;gap:20px;display:flex;position:absolute;inset:0}.cam-captured-img{border-radius:var(--radius);max-width:80%;max-height:60%;box-shadow:0 4px 20px #00000080}.cam-captured-actions{align-items:center;gap:12px;display:flex}@media(max-width:700px){.cam-viewport{flex-direction:column}.cam-capture-btn{width:56px;height:56px}}.box-maker-layout{gap:20px;height:100%;padding:20px;display:flex}.box-preview{border-radius:var(--radius);border:1px solid var(--border);background:#f9f9f9;flex:1;justify-content:center;align-items:center;min-height:0;padding:20px;display:flex;overflow:auto}.box-preview>div{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.box-preview svg{width:100%;height:auto;max-height:100%}.box-settings{flex-shrink:0;width:320px;overflow-y:auto}.dimension-inputs{flex-direction:column;gap:12px;display:flex}.dimension-input{align-items:center;gap:8px;display:flex}.dimension-input label{width:60px;font-size:13px;font-weight:600}.dimension-input input[type=number]{border:1px solid var(--border);border-radius:6px;width:80px;padding:6px 10px;font-size:14px}.style-chips{flex-wrap:wrap;gap:6px;margin:8px 0;display:flex}.box-style-options{grid-template-columns:repeat(3,1fr);gap:8px;margin:8px 0;display:grid}.box-style-option{border:1.5px solid var(--border);background:var(--surface);cursor:pointer;border-radius:8px;flex-direction:column;align-items:center;gap:4px;padding:8px 4px 6px;font-family:inherit;transition:all .15s;display:flex}.box-style-option:hover{border-color:var(--accent)}.box-style-option-active{border-color:var(--accent);background:var(--accent-soft)}.box-style-option svg{display:block}.box-style-name{color:var(--text);text-align:center;font-size:11px;font-weight:600;line-height:1.2}.preset-chips{flex-wrap:wrap;gap:6px;margin:8px 0;display:flex}.material-info{color:var(--text-muted);background:var(--bg);border-radius:6px;margin:12px 0;padding:10px;font-size:12px}@media(max-width:700px){.maker-layout{flex-direction:column}.source-image{width:100%;height:auto;max-height:200px}.view-sidebar{width:200px}.box-maker-layout{flex-direction:column}.box-settings{width:100%}}.admin-gate{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.admin-gate-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);text-align:center;width:100%;max-width:360px;padding:40px}.admin-gate-card h2{color:var(--text);margin:0 0 20px;font-size:22px}.admin-password-input{border:1px solid var(--border);border-radius:6px;outline:none;width:100%;margin-bottom:10px;padding:10px 14px;font-size:15px}.admin-password-input:focus{border-color:var(--accent)}.admin-error{color:#c44;margin:4px 0 8px;font-size:13px}.admin-login-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;width:100%;padding:10px;font-size:15px}.admin-login-btn:hover{background:var(--accent-hover)}.admin-dashboard{background:var(--bg);min-height:100vh}.admin-nav{background:var(--surface);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 24px;display:flex}.admin-logo{color:var(--accent);font-size:16px;font-weight:700}.admin-content{max-width:800px;margin:0 auto;padding:32px 20px}.admin-content h1{margin:0 0 28px;font-size:26px}.admin-section{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:24px;padding:24px}.admin-section h2{margin:0 0 8px;font-size:18px}.admin-section h3{color:var(--text-muted);margin:16px 0 8px;font-size:14px}.admin-desc{color:var(--text-muted);margin:0 0 16px;font-size:13px}.admin-buttons{flex-wrap:wrap;gap:10px;display:flex}.btn-export{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-size:13px}.btn-export:hover{background:var(--accent-hover)}.sidebar-order-cta{border-top:1px solid var(--border);flex-shrink:0;padding:12px 16px 16px}.btn-order-print{color:#fff;border-radius:var(--radius);cursor:pointer;background:#2e7d32;border:none;width:100%;padding:10px 14px;font-family:inherit;font-size:13px;font-weight:700;transition:background .15s}.btn-order-print:hover{background:#388e3c}.sidebar-order-hint{color:var(--text-muted);text-align:center;margin:6px 0 0;font-size:11px}.shop-waitlist{background:var(--accent-soft);border-bottom:1px solid var(--border);text-align:center;padding:32px}.shop-waitlist-inner{max-width:520px;margin:0 auto}.shop-waitlist-title{color:var(--accent);letter-spacing:-.5px;margin:0 0 8px;font-size:24px;font-weight:900}.shop-waitlist-sub{color:var(--text-muted);margin:0 0 16px;font-size:15px;line-height:1.5}.shop-waitlist-form{justify-content:center;gap:8px;display:flex}.shop-waitlist-input{border:1px solid var(--border);color:var(--text);background:#fff;border-radius:8px;width:260px;max-width:100%;padding:10px 14px;font-family:inherit;font-size:14px}.shop-waitlist-input:focus{border-color:var(--accent);outline:none}.shop-waitlist-btn{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:700;transition:opacity .15s}.shop-waitlist-btn:hover{opacity:.85}.shop-waitlist-thanks{color:var(--accent);margin:0;font-size:15px;font-weight:600}.shop-waitlist-count{color:var(--text-muted);margin:12px 0 0;font-size:13px}.shop-hero{text-align:center;padding:48px 32px 32px}.shop-hero-inner{max-width:600px;margin:0 auto}.shop-hero h2{letter-spacing:-1px;color:var(--text);margin:0 0 12px;font-size:32px;font-weight:900;line-height:1.15}.shop-hero-sub{color:var(--text-muted);margin:0;font-size:15px;line-height:1.6}.shop-tiers{padding:0 32px 48px}.shop-tiers-inner{max-width:840px;margin:0 auto}.shop-tier-cards{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.shop-tier-card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:14px;flex-direction:column;padding:24px 20px;transition:box-shadow .2s,transform .2s;display:flex;position:relative}.shop-tier-card:hover{transform:translateY(-1px);box-shadow:0 4px 16px #2c24171a}.shop-tier-featured{border-color:var(--accent);box-shadow:0 4px 20px #b5614b26}.shop-tier-badge{text-transform:uppercase;letter-spacing:.5px;background:var(--accent);color:#fff;border-radius:0 14px 0 8px;padding:4px 12px;font-size:11px;font-weight:700;position:absolute;top:0;right:0}.shop-tier-name{color:var(--text);margin:0 0 4px;font-size:20px;font-weight:800}.shop-tier-size{color:var(--accent);margin:0;font-size:14px;font-weight:700}.shop-tier-subtitle{color:var(--text-muted);margin:2px 0 16px;font-size:13px}.shop-tier-prices{border-top:1px solid var(--border);border-bottom:1px solid var(--border);flex-direction:column;gap:6px;margin-bottom:12px;padding:12px 0;display:flex}.shop-tier-price-row{justify-content:space-between;align-items:center;display:flex}.shop-tier-price-label{color:var(--text-muted);font-size:13px}.shop-tier-price-value{color:var(--text);font-size:15px;font-weight:800}.shop-tier-desc{color:var(--text-muted);flex:1;margin:0 0 16px;font-size:13px;line-height:1.5}.shop-tier-btn{background:var(--bg);width:100%;color:var(--text-muted);border:1px solid var(--border);cursor:not-allowed;border-radius:8px;padding:10px;font-family:inherit;font-size:13px;font-weight:700}.shop-how{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:48px 32px}.shop-how-inner{text-align:center;max-width:720px;margin:0 auto}.shop-steps{grid-template-columns:repeat(4,1fr);gap:24px;display:grid}.shop-order{text-align:center;padding:48px 32px}.shop-order-inner{max-width:520px;margin:0 auto}.shop-order-sub{color:var(--text-muted);margin:8px 0 24px;font-size:15px;line-height:1.5}.shop-order-form{text-align:left;flex-direction:column;gap:16px;display:flex}.shop-order-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.shop-order-label{color:var(--text);flex-direction:column;gap:4px;font-size:13px;font-weight:600;display:flex}.shop-order-input{border:1px solid var(--border);color:var(--text);background:#fff;border-radius:8px;padding:10px 12px;font-family:inherit;font-size:14px}.shop-order-input:focus{border-color:var(--accent);outline:none}.shop-order-textarea{border:1px solid var(--border);resize:vertical;color:var(--text);background:#fff;border-radius:8px;padding:10px 12px;font-family:inherit;font-size:14px}.shop-order-textarea:focus{border-color:var(--accent);outline:none}.shop-order-file{color:var(--text-muted);font-size:13px}.shop-order-filename{color:var(--accent);font-size:12px;font-weight:600}.shop-order-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;align-self:flex-start;padding:12px 28px;font-family:inherit;font-size:14px;font-weight:700;transition:opacity .15s}.shop-order-btn:hover{opacity:.85}.shop-order-thanks{background:var(--accent-soft);border-radius:var(--radius);padding:24px}.shop-order-thanks-title{color:var(--accent);margin:0 0 8px;font-size:18px;font-weight:800}.shop-order-thanks-text{color:var(--text-muted);margin:0;font-size:14px}@media(max-width:700px){.maker-layout{flex-direction:column}.source-image{width:100%;height:auto;max-height:200px}.view-sidebar{width:200px}.box-maker-layout{flex-direction:column}.box-settings{width:100%}.shop-tier-cards{grid-template-columns:1fr}.shop-steps{grid-template-columns:repeat(2,1fr)}.shop-order-row{grid-template-columns:1fr}.shop-waitlist-form{flex-direction:column;align-items:center}.shop-waitlist-input{width:100%}.shop-hero h2{font-size:24px}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
