*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #e8e4df;--panel-bg: #ffffff;--text: #1a1a1a;--text-secondary: #6b6b6b;--accent: #8b6914;--border: #e0dcd7;--radius: 12px;--shadow: 0 4px 24px rgba(0, 0, 0, .08);--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1)}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}.app{height:100vh;width:100vw}.viewport{position:relative;width:100%;height:100%}.viewport canvas{display:block}.ovl-title{position:absolute;top:32px;left:36px;z-index:5;pointer-events:none}.ovl-title h1{font-size:1.4rem;font-weight:600;letter-spacing:-.03em;color:var(--text);line-height:1.2;text-shadow:0 1px 8px rgba(255,255,255,.6)}.ovl-title p{font-size:.8rem;color:var(--text-secondary);margin-top:2px;font-weight:300}.ovl-controls{position:absolute;top:32px;right:36px;z-index:5;display:flex;align-items:center;gap:12px}.ovl-icon-btn{width:40px;height:40px;border-radius:50%;background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(0,0,0,.06);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text);transition:transform .2s var(--ease-out),box-shadow .2s var(--ease-out),background .2s;box-shadow:0 2px 8px #00000014}.ovl-icon-btn:hover{transform:scale(1.08);box-shadow:0 4px 16px #0000001f;background:#fffffff2}.ovl-icon-btn:active{transform:scale(.95)}.ovl-toggle{display:flex;align-items:center;cursor:pointer}.ovl-toggle input{display:none}.ovl-toggle__track{width:36px;height:20px;background:#0000001f;border-radius:10px;position:relative;transition:background .2s;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.ovl-toggle__track:after{content:"";position:absolute;width:16px;height:16px;background:#fff;border-radius:50%;top:2px;left:2px;transition:transform .25s var(--ease-out);box-shadow:0 1px 4px #0003}.ovl-toggle input:checked+.ovl-toggle__track{background:var(--accent)}.ovl-toggle input:checked+.ovl-toggle__track:after{transform:translate(16px)}.ovl-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:4;cursor:pointer}.ovl-picker{position:absolute;bottom:60px;left:50%;transform:translate(-50%) translateY(20px);z-index:6;display:flex;flex-direction:column;align-items:center;gap:14px;opacity:0;pointer-events:none;transition:opacity .35s var(--ease-out),transform .4s var(--ease-spring)}.ovl-picker--open{opacity:1;transform:translate(-50%) translateY(0);pointer-events:auto}.ovl-picker__label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:var(--text-secondary);background:#fffc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:4px 14px;border-radius:20px;box-shadow:0 2px 8px #0000000f}.ovl-picker__row{display:flex;gap:28px;align-items:flex-start}.ovl-swatch{display:flex;flex-direction:column;align-items:center;gap:0;background:none;border:none;padding:0;cursor:pointer;-webkit-tap-highlight-color:transparent;opacity:0;transform:translateY(16px) scale(.8);animation:swatchPopIn .45s var(--ease-spring) forwards;animation-delay:calc(var(--i) * .06s)}@keyframes swatchPopIn{to{opacity:1;transform:translateY(0) scale(1)}}.ovl-swatch__ring{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2.5px solid transparent;transition:border-color .3s var(--ease-out),transform .3s var(--ease-out),box-shadow .3s var(--ease-out);background:#fff9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.ovl-swatch:hover .ovl-swatch__ring{transform:scale(1.12);box-shadow:0 6px 24px #0000002e}.ovl-swatch--active .ovl-swatch__ring{border-color:var(--accent);box-shadow:0 0 0 3px #8b691426,0 4px 16px #0000001f}.ovl-swatch:active .ovl-swatch__ring{transform:scale(.92)}.ovl-swatch__color{width:46px;height:46px;border-radius:50%;border:1px solid rgba(0,0,0,.06);box-shadow:inset 0 2px 6px #0000001a,0 2px 6px #00000014}.ovl-swatch__label{font-size:.7rem;font-weight:500;color:var(--text);white-space:nowrap;background:#ffffffe0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:3px 10px;border-radius:6px;box-shadow:0 2px 8px #00000014;max-height:0;opacity:0;overflow:hidden;transform:translateY(-6px);margin-top:0;transition:max-height .3s var(--ease-out),opacity .25s var(--ease-out),transform .3s var(--ease-spring),margin-top .3s var(--ease-out)}.ovl-swatch__label--show{max-height:28px;opacity:1;transform:translateY(0);margin-top:8px}.ovl-hint{position:absolute;bottom:72px;left:50%;transform:translate(-50%);z-index:5;font-size:.78rem;color:var(--text-secondary);background:#ffffffb3;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:8px 20px;border-radius:24px;box-shadow:0 2px 12px #0000000f;white-space:nowrap;pointer-events:none;animation:fadeIn .5s var(--ease-out)}.ovl-branding{position:absolute;bottom:20px;left:50%;transform:translate(-50%);z-index:5;font-size:.68rem;color:var(--text-secondary);opacity:.5;pointer-events:none;white-space:nowrap}.ovl-branding strong{font-weight:600;color:var(--text)}.loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;background:#fff;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease}.loading-content{display:flex;flex-direction:column;align-items:center;gap:24px;max-width:320px;width:100%;padding:40px 24px}.loading-preview{width:240px;height:180px;display:flex;align-items:center;justify-content:center;overflow:hidden}.loading-preview__image{max-width:100%;max-height:100%;object-fit:contain;opacity:.85}.loading-preview__fallback{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:#f9f8f6;border-radius:var(--radius)}.loading-info{text-align:center}.loading-title{font-size:1.2rem;font-weight:600;color:var(--text);letter-spacing:-.02em}.loading-subtitle{font-size:.8rem;color:var(--text-secondary);margin-top:2px}.loading-bar-container{width:100%;display:flex;flex-direction:column;align-items:center;gap:8px}.loading-bar{width:100%;height:3px;background:#e8e4df;border-radius:2px;overflow:hidden}.loading-bar__fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.loading-percent{font-size:.7rem;color:var(--text-secondary);font-variant-numeric:tabular-nums}.ar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.ar-modal{background:#fff;border-radius:20px;padding:40px 36px;max-width:380px;width:90%;display:flex;flex-direction:column;align-items:center;gap:16px;position:relative;box-shadow:0 24px 64px #0003;animation:slideUp .3s ease}.ar-modal__close{position:absolute;top:16px;right:16px;background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:4px;border-radius:8px;transition:background .2s ease}.ar-modal__close:hover{background:#f0ede9;color:var(--text)}.ar-modal__icon{width:64px;height:64px;background:#8b691414;border-radius:16px;display:flex;align-items:center;justify-content:center}.ar-modal h2{font-size:1.2rem;font-weight:600;color:var(--text);letter-spacing:-.02em}.ar-modal>p{font-size:.82rem;color:var(--text-secondary);text-align:center;line-height:1.5}.ar-modal__qr{padding:20px;background:#fff;border:1px solid var(--border);border-radius:16px;margin:4px 0}.ar-modal__steps{display:flex;flex-direction:column;gap:10px;width:100%}.ar-step{display:flex;align-items:center;gap:12px;font-size:.8rem;color:var(--text)}.ar-step__num{width:24px;height:24px;border-radius:50%;background:#8b69141a;color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;flex-shrink:0}.ar-modal__note{font-size:.68rem;color:var(--text-secondary);opacity:.7}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.ovl-title{top:20px;left:20px}.ovl-title h1{font-size:1.1rem}.ovl-controls{top:20px;right:20px}.ovl-picker{bottom:48px}.ovl-picker__row{gap:20px}.ovl-swatch__ring{width:48px;height:48px}.ovl-swatch__color{width:40px;height:40px}.ovl-hint{bottom:56px;font-size:.72rem}}
