.color-swatch{position:relative;display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.5rem 0}.color-swatch-trigger{display:flex;align-items:center;gap:.75rem;cursor:pointer;flex:1;background:none;border:none;padding:.375rem;border-radius:8px;transition:background .15s}.color-swatch-trigger:hover{background:#ffffff0a}.color-swatch-circle{width:28px;height:28px;border-radius:50%;border:2px solid rgba(255,255,255,.12);flex-shrink:0;transition:transform .15s ease,box-shadow .15s ease}.color-swatch-trigger:hover .color-swatch-circle{transform:scale(1.1);box-shadow:0 0 8px #ffffff1a}.color-swatch-info{display:flex;flex-direction:column;gap:.125rem;text-align:left}.color-swatch-label{font-size:.8125rem;font-weight:500;color:var(--color-text-primary)}.color-swatch-hex{font-size:.6875rem;font-family:SF Mono,Fira Code,Cascadia Code,monospace;color:var(--color-text-secondary);text-transform:uppercase}.color-swatch-popover{position:absolute;top:100%;right:0;z-index:200;background:var(--color-surface-raised);border:1px solid var(--color-border-hover);border-radius:12px;padding:.75rem;min-width:220px;box-shadow:0 12px 40px #00000080;animation:scaleIn .2s cubic-bezier(.22,1,.36,1);transform-origin:top right}.color-swatch-presets{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:.75rem}.color-swatch-preset{width:32px;height:32px;border-radius:6px;border:2px solid transparent;cursor:pointer;transition:transform .15s,border-color .15s;padding:0;background:none}.color-swatch-preset:hover{transform:scale(1.15);border-color:#ffffff4d}.color-swatch-preset.selected{border-color:var(--color-accent);box-shadow:0 0 8px var(--color-accent-glow)}.color-swatch-custom{display:flex;align-items:center;gap:.5rem;padding-top:.5rem;border-top:1px solid var(--color-border)}.color-swatch-custom-label{font-size:.75rem;color:var(--color-text-secondary);white-space:nowrap}.color-swatch-custom input[type=color]{width:40px;height:28px;min-width:40px;min-height:28px;border:1px solid var(--color-border-hover);border-radius:6px;cursor:pointer;background:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0}.color-swatch-custom input[type=color]::-webkit-color-swatch-wrapper{padding:0}.color-swatch-custom input[type=color]::-webkit-color-swatch{border:none;border-radius:4px}.color-swatch-custom input[type=color]::-moz-color-swatch{border:none;border-radius:4px}@media (max-width: 768px){.color-swatch-popover{right:auto;left:0;min-width:200px}.color-swatch-presets{grid-template-columns:repeat(5,1fr);gap:5px}.color-swatch-preset{width:28px;height:28px}}.controls{position:fixed;top:calc(64px + .75rem);right:.75rem;background:var(--color-surface);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-panel);border-top:2px solid var(--color-accent);border-left:1px solid var(--color-border);border-right:1px solid var(--color-border);border-bottom:1px solid var(--color-border);padding:1rem;min-width:250px;max-width:280px;box-shadow:var(--shadow-panel);z-index:100;max-height:calc(100vh - 124px - 1.5rem);overflow-y:auto;overflow-x:hidden;-webkit-user-select:none;user-select:none;transition:var(--transition-panel, all .35s cubic-bezier(.22, 1, .36, 1));will-change:transform,opacity;animation:slideUp .3s ease-out}.controls.collapsed{min-width:auto;max-width:none;width:auto;padding:12px 16px;overflow:hidden}.controls-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.5rem}.controls h2{margin:0;font-size:1rem;font-weight:600;color:var(--color-text-primary);flex:1}.controls.collapsed h2{font-size:1rem;margin:0}.collapse-button{background:transparent;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);border-radius:4px;transition:background-color .2s,color .2s;flex-shrink:0}.collapse-button:hover{background:#ffffff0f;color:var(--color-text-primary)}.collapse-button:active{background:#ffffff1a}.controls-content{margin-top:20px}.controls.collapsed .controls-content{display:none}.control-group{margin-bottom:.25rem}.controls-presets{margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-border)}.controls-presets-label{font-size:.6875rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.controls-presets-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.375rem}.controls-preset-btn{display:flex;align-items:center;gap:.375rem;padding:.375rem .5rem;background:#ffffff0a;border:1px solid var(--color-border);border-radius:8px;color:var(--color-text-primary);font-size:.6875rem;font-weight:500;cursor:pointer;transition:all .15s ease;min-height:auto;min-width:auto}.controls-preset-btn:hover{background:#ffffff14;border-color:var(--color-border-hover);transform:scale(1.02)}.controls-preset-btn:active{transform:scale(.97)}.controls-preset-dots{display:flex;gap:2px}.controls-preset-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.controls-swatches-label{font-size:.6875rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.375rem}@media (min-width: 769px) and (max-width: 1024px){.controls{top:calc(64px + 1rem);right:1rem;padding:1rem;max-width:300px}}@media (max-width: 768px){.controls{position:fixed;top:auto;bottom:50px;left:.5rem;right:.5rem;width:calc(100vw - 1rem);max-width:none;min-width:auto;padding:.875rem;max-height:calc(40vh - 60px);border-radius:12px;box-shadow:0 -4px 24px #0006}.controls h2{font-size:.9375rem;margin-bottom:.375rem}.collapse-button{min-width:40px;min-height:40px;padding:.5rem;touch-action:manipulation}}@media (max-width: 480px){.controls{padding:.75rem;bottom:44px;left:.5rem;right:.5rem;width:calc(100vw - 1rem);max-height:calc(35vh - 50px)}.controls h2{font-size:.875rem;margin-bottom:.375rem}.collapse-button{min-width:36px;min-height:36px;padding:.375rem}}@media (max-width: 768px) and (orientation: landscape){.controls{max-height:calc(60vh - 80px);bottom:50px}}.controls::-webkit-scrollbar{width:5px}.controls::-webkit-scrollbar-track{background:transparent}.controls::-webkit-scrollbar-thumb{background:#e67e2240;border-radius:3px}.controls::-webkit-scrollbar-thumb:hover{background:#e67e2266}.design-form{position:fixed;top:calc(64px + .75rem);left:.75rem;width:280px;max-height:calc(100vh - 124px - 1.5rem);overflow-y:auto;overflow-x:hidden;background:var(--color-surface);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-panel);border-top:2px solid var(--color-accent);border-left:1px solid var(--color-border);border-right:1px solid var(--color-border);border-bottom:1px solid var(--color-border);padding:1rem;color:var(--color-text-primary);box-shadow:var(--shadow-panel);z-index:100;animation:slideUp .3s ease-out;will-change:transform,opacity}.design-form h3{margin-bottom:.75rem;font-size:1rem;font-weight:600}.design-form label{display:flex;flex-direction:column;gap:.375rem;font-size:.8125rem;color:var(--color-text-secondary);margin-bottom:.75rem}.design-form input,.design-form textarea{padding:.625rem .875rem;min-height:40px;border-radius:var(--radius-input);border:1px solid var(--color-border);background:#00000059;color:var(--color-text-primary);font-size:.875rem;touch-action:manipulation;transition:border-color .2s,box-shadow .2s,background-color .2s}.design-form input:focus,.design-form textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 8px var(--color-accent-glow);background:#00000073}.design-form textarea{resize:vertical;min-height:70px}.config-color-dots{display:flex;align-items:center;gap:.375rem;margin-bottom:.5rem}.config-color-dots-label{font-size:.6875rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;font-weight:600;margin-right:.25rem}.config-color-dot{width:16px;height:16px;border-radius:50%;border:1.5px solid rgba(255,255,255,.12);flex-shrink:0;transition:transform .15s}.config-color-dot:hover{transform:scale(1.2)}.price-summary{margin:.75rem 0;padding:.875rem;background:#00000040;border-radius:8px;border:1px solid var(--color-border)}.price-row{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.8125rem;color:var(--color-text-secondary)}.price-row.total{margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(230,126,34,.3);font-weight:700;font-size:1.0625rem;color:var(--color-accent)}.price-note{margin-top:8px;font-size:.75rem;color:var(--color-text-secondary);font-style:italic}.design-form button[type=submit]{width:100%;margin-top:.5rem;padding:.75rem 1rem;min-height:42px;border-radius:var(--radius-input);border:none;background:var(--color-accent);color:#000;font-weight:700;font-size:.875rem;cursor:pointer;touch-action:manipulation;transition:transform .2s,box-shadow .2s;-webkit-tap-highlight-color:transparent;display:flex;align-items:center;justify-content:center;gap:.5rem}.design-form button[type=submit]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 0 20px var(--color-accent-glow)}.design-form button[type=submit]:active:not(:disabled){transform:translateY(0);box-shadow:0 0 8px var(--color-accent-glow)}.design-form button[type=submit]:disabled{cursor:not-allowed;opacity:.7}.btn-spinner{width:16px;height:16px;border:2px solid rgba(0,0,0,.2);border-top-color:#000;border-radius:50%;animation:spin .6s linear infinite}.design-form .status{margin-top:12px;font-size:.8rem;color:var(--color-success)}.design-form .status.error{color:var(--color-error)}.design-form::-webkit-scrollbar{width:5px}.design-form::-webkit-scrollbar-track{background:transparent}.design-form::-webkit-scrollbar-thumb{background:#e67e2240;border-radius:3px}.design-form::-webkit-scrollbar-thumb:hover{background:#e67e2266}@media (min-width: 769px) and (max-width: 1024px){.design-form{top:calc(64px + 1rem);left:1rem;padding:1rem;max-width:300px}}@media (max-width: 768px){.design-form{position:fixed;top:auto;bottom:50px;left:.5rem;right:.5rem;width:calc(100vw - 1rem);max-width:none;max-height:calc(40vh - 60px);padding:.875rem;border-radius:12px;box-shadow:0 -4px 24px #0006}.design-form h3{font-size:.9375rem;margin-bottom:.5rem}.design-form label{font-size:.8125rem;margin-bottom:.625rem;gap:.375rem}.design-form input,.design-form textarea{padding:.625rem .75rem;font-size:16px;min-height:40px;touch-action:manipulation}.design-form textarea{min-height:70px}.design-form button[type=submit]{padding:.75rem;min-height:40px;font-size:.875rem;touch-action:manipulation}.price-summary{margin:.75rem 0;padding:.75rem}}@media (max-width: 480px){.design-form{top:auto;bottom:44px;left:.5rem;right:.5rem;width:calc(100vw - 1rem);padding:.75rem;max-height:calc(35vh - 50px)}.design-form h3{font-size:.875rem;margin-bottom:.5rem}.design-form label{font-size:.75rem;margin-bottom:.5rem}.design-form input,.design-form textarea{padding:.5rem .625rem;font-size:16px;min-height:36px}.design-form textarea{min-height:60px}.design-form button[type=submit]{padding:.625rem;min-height:36px;font-size:.8125rem}.price-summary{margin:.625rem 0;padding:.625rem}}@media (max-width: 768px) and (orientation: landscape){.design-form{max-height:calc(50vh - 60px);bottom:50px}}.navbar{position:fixed;top:0;left:0;right:0;height:64px;background:var(--color-surface);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);z-index:1000;border-bottom:1px solid var(--color-border);box-shadow:0 2px 12px #0006;will-change:transform}.navbar-content{display:flex;align-items:center;gap:1.618rem;height:100%;padding:0 1.618rem;max-width:100%}.navbar-buttons{display:flex;gap:.75rem;align-items:center;margin-left:auto;flex-wrap:nowrap}.navbar-button{padding:.625rem 1.25rem;min-height:44px;background:var(--color-surface-hover);border:1px solid var(--color-border);color:var(--color-text-primary);font-size:.875rem;font-weight:500;cursor:pointer;border-radius:8px;transition:all .25s cubic-bezier(.22,1,.36,1);touch-action:manipulation;white-space:nowrap;-webkit-tap-highlight-color:transparent;display:flex;align-items:center;justify-content:center;gap:.5rem}.navbar-button:hover{background:#ffffff14;border-color:var(--color-border-hover)}.navbar-button.active{background:var(--color-accent);color:#000;border-color:var(--color-accent);box-shadow:0 0 12px var(--color-accent-glow);font-weight:600}.navbar-button-icon{display:flex;align-items:center;flex-shrink:0}.navbar-button-text{display:inline}.navbar-logo{display:flex;align-items:center;height:100%}.navbar-logo img{height:40px;width:auto;object-fit:contain}@media (min-width: 769px) and (max-width: 1024px){.navbar-content{padding:0 1.25rem;gap:1.25rem}.navbar-button{padding:.625rem 1rem;font-size:.8125rem}}@media (max-width: 768px){.navbar{height:56px}.navbar-content{padding:0 1rem;gap:.75rem}.navbar-buttons{gap:.5rem}.navbar-button{padding:.5rem .75rem;font-size:.75rem;min-height:44px;touch-action:manipulation;white-space:nowrap}.navbar-logo img{height:28px}}@media (max-width: 480px){.navbar{height:52px}.navbar-content{padding:0 .75rem;gap:.5rem}.navbar-buttons{gap:.375rem}.navbar-button{padding:.5rem .625rem;font-size:.6875rem;min-height:44px}.navbar-logo img{height:24px}}@media (max-width: 360px){.navbar-button{padding:.5rem .625rem}.navbar-button-text{display:none}}.footer{position:fixed;bottom:0;left:0;right:0;background:var(--color-surface);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);color:var(--color-text-secondary);padding:.625rem 1rem;z-index:1000;text-align:center;border-top:1px solid var(--color-border)}.footer-content{max-width:1200px;margin:0 auto}.footer p{margin:0;font-size:.8125rem}@media (max-width: 768px){.footer{padding:.5rem .75rem}.footer p{font-size:.75rem}}@media (max-width: 480px){.footer{padding:.375rem .5rem}.footer p{font-size:.6875rem}}:root{--spacing-base: 1rem;--spacing-golden-1: calc(var(--spacing-base) * 1.618);--spacing-golden-2: calc(var(--spacing-base) * 2.618);--spacing-golden-3: calc(var(--spacing-base) * 4.236)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulseGlow{0%,to{box-shadow:0 0 12px var(--color-accent-glow)}50%{box-shadow:0 0 24px var(--color-accent-glow)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.app{width:100%;height:100vh;height:100dvh;position:relative;background:#080810;overflow:hidden;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column}.canvas-container{width:100%;height:100%;position:absolute;top:0;left:0;touch-action:none;will-change:transform;transform:translateZ(0)}@media (min-width: 769px) and (max-width: 1024px){.app,.canvas-container{height:100vh}}@media (max-width: 768px){.app,.canvas-container{height:100vh;height:100dvh;min-height:-webkit-fill-available}}@media (max-width: 480px){.app,.canvas-container{height:100vh;height:100dvh;min-height:-webkit-fill-available}}@media (max-width: 768px) and (orientation: landscape){.app,.canvas-container{height:100vh;height:100dvh}}.checkout-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;display:flex;align-items:center;justify-content:center;background:#000000bf;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);animation:fadeIn .3s ease-out}.checkout-message{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-panel);padding:2rem 2rem 1.5rem;max-width:26rem;width:90%;text-align:center;color:var(--color-text-primary);box-shadow:var(--shadow-panel);animation:scaleIn .35s cubic-bezier(.22,1,.36,1)}.checkout-message.success{border-top:4px solid var(--color-success)}.checkout-message.canceled{border-top:4px solid var(--color-error)}.checkout-icon{margin-bottom:1rem}.checkout-message h2{font-size:1.375rem;font-weight:700;margin:0 0 .625rem}.checkout-message p{font-size:.9rem;color:var(--color-text-secondary);margin:0 0 1.5rem;line-height:1.6}.checkout-message button{background:var(--color-accent);color:#000;border:none;border-radius:var(--radius-input);padding:.75rem 1.75rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.checkout-message button:hover{transform:translateY(-2px);box-shadow:0 0 20px var(--color-accent-glow)}.checkout-message button:active{transform:translateY(0)}.checkout-message.success button{background:var(--color-success)}.checkout-message.canceled button{background:var(--color-accent)}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.canvas-container{image-rendering:-webkit-optimize-contrast}}*{margin:0;padding:0;box-sizing:border-box}:root{font-size:16px;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--color-surface: rgba(12, 12, 16, .92);--color-surface-raised: rgba(22, 22, 30, .95);--color-surface-hover: rgba(32, 32, 42, .95);--color-border: rgba(255, 255, 255, .06);--color-border-hover: rgba(255, 255, 255, .12);--color-accent: #e67e22;--color-accent-glow: rgba(230, 126, 34, .25);--color-text-primary: #f0f0f0;--color-text-secondary: rgba(255, 255, 255, .55);--color-success: #2ecc71;--color-error: #e74c3c;--radius-panel: 16px;--radius-input: 10px;--shadow-panel: 0 8px 32px rgba(0, 0, 0, .4), 0 0 1px rgba(255, 255, 255, .05)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;width:100%;height:100vh;height:100dvh;overflow:hidden;touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-font-feature-settings:"kern" 1;font-feature-settings:"kern" 1;font-kerning:normal}#root{width:100%;height:100%}@media (max-width: 480px){:root{font-size:14px}}@media (min-width: 1025px){:root{font-size:17px}}button,a,input[type=button],input[type=submit],input[type=color],input[type=range]{min-height:44px;min-width:44px}button:active:not(:disabled){transform:scale(.97)}*:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:4px}*{scroll-behavior:smooth}img{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;max-width:100%;height:auto}.no-select{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}input,textarea,select{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0000001a;border-radius:4px}::-webkit-scrollbar-thumb{background:#0000004d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#00000080}@media (max-width: 768px){input,textarea,select{font-size:16px!important}button,a{padding:.75rem 1rem}body{-webkit-text-size-adjust:100%;text-size-adjust:100%}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}
