@import url("https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap");:root{--color-primary:#2563eb;--color-primary-light:#3b82f6;--color-primary-dark:#1d4ed8;--color-accent:#06b6d4;--color-accent-light:#22d3ee;--color-bg-start:#e8f4fd;--color-bg-mid:#f0f7ff;--color-bg-end:#ffffff;--color-surface:rgba(255,255,255,0.72);--color-surface-hover:rgba(255,255,255,0.88);--color-surface-strong:rgba(255,255,255,0.92);--color-surface-solid:#ffffff;--color-text:#0f172a;--color-text-secondary:#475569;--color-text-muted:#94a3b8;--color-text-inverse:#ffffff;--color-border:rgba(148,163,184,0.25);--color-border-strong:rgba(148,163,184,0.4);--color-border-soft:rgba(148,163,184,0.15);--color-hover:rgba(37,99,235,0.06);--color-hover-strong:rgba(37,99,235,0.1);--color-tint:rgba(37,99,235,0.04);--color-pill-bg:rgba(239,244,255,1);--color-pill-border:rgba(199,210,254,1);--color-pill-text:var(--color-primary);--color-error:#dc2626;--color-error-bg:rgba(220,38,38,0.06);--color-success-start:#059669;--color-success-end:#10b981;--color-secondary-btn:rgba(71,85,105,1);--color-checker-a:#ffffff;--color-checker-b:#cccccc;--shadow-sm:0 1px 3px rgba(0,0,0,0.06),0 1px 8px rgba(0,0,0,0.04);--shadow-md:0 4px 16px rgba(37,99,235,0.08),0 2px 8px rgba(0,0,0,0.04);--shadow-lg:0 8px 40px rgba(37,99,235,0.12),0 4px 16px rgba(0,0,0,0.06);--shadow-xl:0 16px 64px rgba(37,99,235,0.15),0 8px 32px rgba(0,0,0,0.08);--shadow-color-tint:rgba(37,99,235,0.25);--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--backdrop-blur:blur(16px);--backdrop-blur-sm:blur(8px);--header-height:64px;--container-max:960px;color-scheme:light}[data-theme=dark]{--color-primary:#60a5fa;--color-primary-light:#3b82f6;--color-primary-dark:#93c5fd;--color-accent:#22d3ee;--color-accent-light:#67e8f9;--color-bg-start:#0b1220;--color-bg-mid:#0f172a;--color-bg-end:#111827;--color-surface:rgba(22,28,45,0.72);--color-surface-hover:rgba(28,36,56,0.88);--color-surface-strong:rgba(28,36,56,0.95);--color-surface-solid:#131c2e;--color-text:#f1f5f9;--color-text-secondary:#cbd5e1;--color-text-muted:#94a3b8;--color-text-inverse:#0f172a;--color-border:rgba(148,163,184,0.18);--color-border-strong:rgba(148,163,184,0.32);--color-border-soft:rgba(148,163,184,0.1);--color-hover:rgba(96,165,250,0.12);--color-hover-strong:rgba(96,165,250,0.18);--color-tint:rgba(96,165,250,0.06);--color-pill-bg:rgba(96,165,250,0.15);--color-pill-border:rgba(96,165,250,0.35);--color-pill-text:#93c5fd;--color-error:#f87171;--color-error-bg:rgba(248,113,113,0.12);--color-success-start:#10b981;--color-success-end:#34d399;--color-secondary-btn:rgba(71,85,105,0.9);--color-checker-a:#131c2e;--color-checker-b:#1e293b;--shadow-sm:0 1px 3px rgba(0,0,0,0.4),0 1px 8px rgba(0,0,0,0.3);--shadow-md:0 4px 16px rgba(0,0,0,0.4),0 2px 8px rgba(0,0,0,0.3);--shadow-lg:0 8px 40px rgba(0,0,0,0.5),0 4px 16px rgba(0,0,0,0.35);--shadow-xl:0 16px 64px rgba(0,0,0,0.55),0 8px 32px rgba(0,0,0,0.4);--shadow-color-tint:rgba(96,165,250,0.35);color-scheme:dark}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--color-text);min-height:100vh;overflow-x:hidden;background:linear-gradient(145deg,var(--color-bg-start) 0,var(--color-bg-mid) 40%,var(--color-bg-end) 100%);background-attachment:fixed;position:relative;-webkit-font-smoothing:antialiased;transition:color .25s ease,background .4s ease}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse 60% 40% at 10% 5%,rgba(37,99,235,.08) 0,transparent 60%),radial-gradient(ellipse 50% 60% at 85% 15%,rgba(6,182,212,.06) 0,transparent 60%),radial-gradient(ellipse 40% 40% at 70% 85%,rgba(37,99,235,.05) 0,transparent 60%);pointer-events:none;z-index:0}[data-theme=dark] body:before{background:radial-gradient(ellipse 60% 40% at 10% 5%,rgba(96,165,250,.12) 0,transparent 60%),radial-gradient(ellipse 50% 60% at 85% 15%,rgba(34,211,238,.08) 0,transparent 60%),radial-gradient(ellipse 40% 40% at 70% 85%,rgba(96,165,250,.08) 0,transparent 60%)}body:after{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%232563eb' fill-opacity='0.02'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none;z-index:0;opacity:.5}[data-theme=dark] body:after{opacity:.18;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%2360a5fa' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}#__next,main{position:relative;z-index:1}::selection{background:rgba(37,99,235,.2);color:var(--color-primary-dark)}[data-theme=dark] ::selection{background:rgba(96,165,250,.3);color:var(--color-text)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--color-border-soft);border-radius:3px}::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.glass-card{background:var(--color-surface);backdrop-filter:var(--backdrop-blur);-webkit-backdrop-filter:var(--backdrop-blur);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg)}.glass-panel{background:var(--color-surface-hover);backdrop-filter:var(--backdrop-blur-sm);-webkit-backdrop-filter:var(--backdrop-blur-sm);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.fade-in{animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.stagger-1{animation-delay:0s}.stagger-2{animation-delay:80ms}.stagger-3{animation-delay:.16s}.stagger-4{animation-delay:.24s}.stagger-5{animation-delay:.32s}input[type=range]{accent-color:var(--color-primary)}input[type=color]{background-color:var(--color-surface-solid)}button{font-family:inherit}@media (max-width:768px){:root{--header-height:56px}}.app-header{position:-webkit-sticky;position:sticky;top:0;z-index:100;height:var(--header-height);background:var(--color-surface);backdrop-filter:var(--backdrop-blur);-webkit-backdrop-filter:var(--backdrop-blur);border-bottom:1px solid var(--color-border);box-shadow:0 1px 0 var(--color-tint)}.app-header-inner{max-width:var(--container-max);height:100%;margin:0 auto;padding:0 24px;justify-content:space-between;gap:16px}.app-header-inner,.app-logo{display:flex;align-items:center}.app-logo{gap:10px;text-decoration:none;color:inherit;flex-shrink:0}.app-logo-badge{width:36px;height:36px;background:transparent;display:flex;align-items:center;justify-content:center;overflow:hidden}.app-logo-badge-sm{width:28px;height:28px}.app-logo-badge img{display:block;width:100%;height:100%;object-fit:contain}.app-logo-text{font-size:20px;font-weight:700;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.3px}.app-nav-desktop{display:flex;align-items:center;gap:6px}.nav-link{padding:6px 14px;border-radius:8px;font-size:13px;font-weight:500;color:var(--color-text-secondary);text-decoration:none;transition:background .15s,color .15s}.nav-link:hover{background:var(--color-hover);color:var(--color-primary)}.theme-toggle{width:34px;height:34px;border-radius:8px;border:1px solid var(--color-border);background:var(--color-surface-hover);color:var(--color-text-secondary);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .15s,color .15s,border-color .15s;flex-shrink:0}.theme-toggle:hover{background:var(--color-hover);color:var(--color-primary);border-color:var(--color-border-strong)}.lang-button{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;border:1px solid var(--color-border);background:var(--color-surface-hover);cursor:pointer;font-size:13px;font-weight:500;color:var(--color-text-secondary);transition:background .15s,color .15s,border-color .15s;font-family:inherit}.lang-button:hover{background:var(--color-hover);color:var(--color-primary);border-color:var(--color-border-strong)}.lang-label{white-space:nowrap}.lang-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:140px;background:var(--color-surface-strong);backdrop-filter:var(--backdrop-blur);-webkit-backdrop-filter:var(--backdrop-blur);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-xl);overflow:hidden;z-index:200}.lang-option{display:block;width:100%;padding:9px 14px;text-align:left;border:none;background:transparent;color:var(--color-text);font-size:13px;font-weight:400;cursor:pointer;transition:background .1s;font-family:inherit}.lang-option:hover{background:var(--color-hover)}.lang-option-active{background:var(--color-tint);color:var(--color-primary);font-weight:600}.burger{display:none;width:40px;height:40px;border-radius:8px;border:1px solid var(--color-border);background:var(--color-surface-hover);color:var(--color-text);cursor:pointer;align-items:center;justify-content:center;transition:background .15s,color .15s,border-color .15s}.burger:hover{background:var(--color-hover);color:var(--color-primary);border-color:var(--color-border-strong)}.drawer-mask{position:fixed;inset:0;background:rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:opacity .25s ease;z-index:200}[data-theme=dark] .drawer-mask{background:rgba(0,0,0,.65)}.drawer-mask-open{opacity:1;pointer-events:auto}.drawer{position:fixed;top:0;right:0;bottom:0;width:min(86vw,320px);background:var(--color-surface-strong);backdrop-filter:var(--backdrop-blur);-webkit-backdrop-filter:var(--backdrop-blur);border-left:1px solid var(--color-border);box-shadow:var(--shadow-xl);transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:300;display:flex;flex-direction:column;pointer-events:none}.drawer-open{transform:translateX(0);pointer-events:auto}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--color-border);flex-shrink:0}.drawer-close{width:36px;height:36px;border-radius:8px;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.drawer-close:hover{background:var(--color-hover);color:var(--color-text)}.drawer-nav{display:flex;flex-direction:column;padding:12px 10px;gap:2px;flex-shrink:0}.drawer-nav .nav-link{padding:12px 14px;font-size:15px;font-weight:500}.drawer-footer{margin-top:auto;padding:16px 18px 24px;border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:16px}.drawer-action{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 16px;border-radius:10px;border:1px solid var(--color-border);background:var(--color-surface-hover);color:var(--color-text);font-size:14px;font-weight:500;cursor:pointer;font-family:inherit;transition:background .15s,color .15s,border-color .15s}.drawer-action:hover{background:var(--color-hover);color:var(--color-primary);border-color:var(--color-border-strong)}.drawer-lang{display:flex;flex-direction:column;gap:8px}.drawer-lang-label{font-size:12px;color:var(--color-text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.drawer-lang-grid{display:flex;flex-wrap:wrap;gap:6px}.drawer-lang-chip{padding:7px 12px;border-radius:8px;border:1px solid var(--color-border);background:var(--color-surface-hover);color:var(--color-text-secondary);font-size:13px;font-weight:500;cursor:pointer;font-family:inherit;transition:background .15s,color .15s,border-color .15s}.drawer-lang-chip:hover{background:var(--color-hover);color:var(--color-primary);border-color:var(--color-border-strong)}.drawer-lang-chip-active{background:var(--color-tint);color:var(--color-primary);border-color:var(--color-primary)}.app-footer{border-top:1px solid var(--color-border);background:var(--color-surface);backdrop-filter:var(--backdrop-blur);-webkit-backdrop-filter:var(--backdrop-blur);padding:32px 24px 24px;margin-top:40px}.app-footer-inner{max-width:var(--container-max);margin:0 auto}.app-footer-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px}.app-footer-brand{display:inline-flex;align-items:center;gap:8px;font-size:15px;font-weight:700;color:var(--color-text);text-decoration:none}.app-footer-links{display:flex;gap:20px;flex-wrap:wrap}.footer-link{font-size:13px;color:var(--color-text-secondary);text-decoration:none;font-weight:500;transition:color .15s}.footer-link-accent,.footer-link:hover{color:var(--color-primary)}.footer-link-accent:hover{color:var(--color-primary-light)}.app-footer-friend{margin-bottom:16px;display:flex;align-items:center;flex-wrap:wrap;gap:8px}.friend-label{font-size:12px;color:var(--color-text-muted)}.friend-chip{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--color-primary);text-decoration:none;padding:3px 10px;border-radius:6px;background:var(--color-hover);transition:background .15s}.friend-chip:hover{background:var(--color-hover-strong)}.app-footer-copy{border-top:1px solid var(--color-border);padding-top:16px}.app-footer-copy p{font-size:12px;color:var(--color-text-muted);text-align:center}@media (max-width:768px){.app-header-inner{padding:0 16px;gap:8px}.app-logo-text{font-size:17px}.app-logo-badge{width:32px;height:32px}.app-nav-desktop{display:none}.burger{display:inline-flex}.app-footer{padding:24px 16px 20px;margin-top:28px}.app-footer-row{flex-direction:column;align-items:flex-start;gap:14px}.app-footer-links{gap:14px}.app-footer-copy p{font-size:11px}}.app-page{max-width:var(--container-max);margin:0 auto;padding:32px 24px 48px}.app-hero{text-align:center;margin-bottom:32px;animation:fadeIn .5s ease-out}.app-hero-title{font-size:clamp(1.6rem,4vw,2.4rem);font-weight:800;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:10px;letter-spacing:-.5px}.app-hero-subtitle{font-size:15px;color:var(--color-text-secondary);font-weight:500}.card{background:var(--color-surface);backdrop-filter:var(--backdrop-blur);-webkit-backdrop-filter:var(--backdrop-blur);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:24px;margin-bottom:16px;box-shadow:var(--shadow-lg)}.upload-zone{border:2px dashed var(--color-border-strong);border-radius:var(--radius-lg);padding:48px 24px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;position:relative;background:var(--color-tint)}.upload-zone:hover{border-color:var(--color-primary-light);background:var(--color-hover)}.upload-zone-active,.upload-zone:active{border-color:var(--color-primary);background:var(--color-tint)}.upload-zone-input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}.upload-zone-icon{font-size:40px;margin-bottom:12px;display:block}.upload-zone-text{color:var(--color-text-secondary);font-size:14px}.upload-zone-strong{color:var(--color-primary)}.upload-zone-meta{color:var(--color-text-muted)}.controls{gap:16px;align-items:flex-start;margin-top:20px}.control-group,.controls{display:flex;flex-wrap:wrap}.control-group{align-items:center;gap:8px}.control-label{font-size:13px;color:var(--color-text-secondary);font-weight:500;white-space:nowrap}.bg-selector{gap:6px;flex-wrap:wrap}.bg-option,.bg-selector{display:flex;align-items:center}.bg-option{width:34px;height:34px;border-radius:10px;border:2px solid transparent;cursor:pointer;justify-content:center;font-size:12px;font-weight:700;transition:transform .15s,box-shadow .15s;padding:0}.bg-option:hover{transform:scale(1.1)}.bg-option-active{border:2px solid var(--color-primary)!important;box-shadow:0 0 0 2px var(--color-tint);transform:scale(1.05)}.bg-divider{width:1px;height:20px;background:var(--color-border-strong);margin:0 2px}.color-chip{display:inline-flex;align-items:center;gap:4px;background:var(--color-pill-bg);border-radius:20px;padding:3px 8px 3px 4px;border:1px solid var(--color-pill-border);font-size:12px;color:var(--color-text-secondary)}.color-chip-swatch{width:18px;height:18px;border-radius:50%;border:1px solid rgba(0,0,0,.12);flex-shrink:0}.color-chip-remove{background:none;border:none;cursor:pointer;color:var(--color-text-muted);font-size:14px;padding:0 2px;border-radius:50%;line-height:1;font-family:inherit}.color-chip-remove:hover{color:var(--color-text)}.color-input-row{display:flex;align-items:center;gap:8px}.color-input{width:34px;height:34px;border:1px solid var(--color-border-strong);border-radius:10px;cursor:pointer;padding:2px;background:none}.slider-wrap{display:flex;align-items:center;gap:8px}.slider{width:120px;accent-color:var(--color-primary);cursor:pointer}.tolerance-badge{background:var(--color-pill-bg);color:var(--color-pill-text);font-size:12px;font-weight:700;padding:2px 8px;border-radius:20px;min-width:30px;text-align:center}.btn{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));color:var(--color-text-inverse);border:none;padding:10px 24px;border-radius:10px;cursor:pointer;font-size:14px;font-weight:600;font-family:inherit;transition:opacity .2s,transform .2s;display:inline-flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap}.btn:hover:not(.btn-disabled){opacity:.88;transform:translateY(-1px)}.btn-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light))}.btn-primary,.btn-success{color:var(--color-text-inverse)}.btn-success{background:linear-gradient(135deg,var(--color-success-start),var(--color-success-end))}.btn-secondary{background:var(--color-secondary-btn);color:var(--color-text-inverse)}.btn-pill{background:var(--color-pill-bg);color:var(--color-pill-text);border:1px solid var(--color-pill-border);padding:5px 14px;font-size:12px;border-radius:20px}.btn-pill:hover:not(.btn-disabled){background:var(--color-pill-border);transform:none;opacity:1}.btn-sm{padding:7px 16px;font-size:13px;border-radius:8px}.btn-disabled{opacity:.5;cursor:not-allowed;transform:none!important}.progress-text{margin-top:14px;font-size:13px;color:var(--color-text-secondary);display:flex;align-items:center;gap:8px}.progress-bar{height:4px;background:var(--color-border);border-radius:4px;margin-top:8px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));border-radius:4px;transition:width .3s ease}.error-msg{margin-top:10px;font-size:13px;color:var(--color-error);padding:8px 12px;border-radius:8px;background:var(--color-error-bg)}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid var(--color-text-inverse);border-radius:50%;animation:spin .8s linear infinite;display:inline-block;flex-shrink:0}@keyframes spin{to{transform:rotate(1turn)}}.step-row{display:flex;align-items:center;gap:12px;margin-bottom:18px;flex-wrap:wrap}.step-num{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));color:var(--color-text-inverse);font-size:13px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.step-num-success{background:linear-gradient(135deg,var(--color-success-start),var(--color-success-end))}.step-title{font-size:15px;font-weight:600;color:var(--color-text);flex:1 1 auto;min-width:0}.step-actions{margin-left:auto;display:flex;gap:8px;align-items:center;flex-wrap:wrap}.frames-scroll{display:flex;gap:10px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.frame-item{flex-shrink:0;scroll-snap-align:start;display:flex;flex-direction:column;background:var(--color-surface-solid);border-radius:10px;overflow:visible;box-shadow:var(--shadow-sm);transition:transform .15s;position:relative}.frame-item-hover{transform:translateY(-2px)}.frame-canvas{width:120px;height:auto;display:block;object-fit:contain;background-image:linear-gradient(45deg,var(--color-checker-b) 25%,transparent 25%),linear-gradient(-45deg,var(--color-checker-b) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,var(--color-checker-b) 75%),linear-gradient(-45deg,transparent 75%,var(--color-checker-b) 75%);background-size:10px 10px;background-position:0 0,0 5px,5px -5px,-5px 0;background-color:var(--color-checker-a);border-radius:10px 10px 0 0}.frame-label{display:block;text-align:center;padding:5px 6px;font-size:11px;color:var(--color-text-muted);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.frame-view-btn{position:absolute;top:6px;right:6px;width:28px;height:28px;border-radius:50%;background:var(--color-surface-strong);color:var(--color-text-secondary);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity .15s,transform .15s,background .15s,color .15s;box-shadow:var(--shadow-sm);border:none;padding:0;pointer-events:auto}.frame-view-btn:hover{background:var(--color-primary);color:var(--color-text-inverse)}.result-section{text-align:center}.result-preview{display:inline-block;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--color-border);background:var(--color-surface-solid);box-shadow:var(--shadow-md);max-width:100%}.result-img{display:block;max-width:480px;max-height:500px;width:100%;height:auto}.result-actions{margin-top:18px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.result-info{margin-top:12px;font-size:12px;color:var(--color-text-muted)}.dialog-mask{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease-out;padding:16px}[data-theme=dark] .dialog-mask{background:rgba(0,0,0,.75)}.dialog{background:var(--color-surface-solid);border-radius:var(--radius-md);max-width:90vw;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-xl);overflow:hidden;width:100%}.dialog-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--color-border)}.dialog-title{font-weight:600;color:var(--color-text);font-size:14px}.dialog-close{background:none;border:none;cursor:pointer;color:var(--color-text-secondary);padding:4px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;font-family:inherit;transition:background .15s,color .15s}.dialog-close:hover{background:var(--color-hover);color:var(--color-text)}.dialog-body{padding:16px;display:flex;align-items:center;justify-content:center;background-image:linear-gradient(45deg,var(--color-checker-b) 25%,transparent 25%),linear-gradient(-45deg,var(--color-checker-b) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,var(--color-checker-b) 75%),linear-gradient(-45deg,transparent 75%,var(--color-checker-b) 75%);background-size:16px 16px;background-position:0 0,0 8px,8px -8px,-8px 0;background-color:var(--color-checker-a);min-width:0;min-height:240px;overflow:auto}.dialog-canvas{max-width:80vw;max-height:70vh;width:auto;height:auto;object-fit:contain;display:block}.dialog-footer{padding:12px 16px;border-top:1px solid var(--color-border);display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}@media (max-width:768px){.app-page{padding:20px 16px 32px}.card{padding:16px;border-radius:var(--radius-lg)}.app-hero{margin-bottom:20px}.app-hero-title{font-size:clamp(1.4rem,6vw,2rem)}.app-hero-subtitle{font-size:13px}.upload-zone{padding:32px 16px}.controls{gap:12px}.control-group{width:100%}.control-label{width:100%;margin-bottom:2px}.slider{flex:1 1 auto;width:auto;min-width:100px}.step-row{gap:10px}.step-actions{margin-left:0;width:100%;justify-content:flex-end}.result-img{max-width:100%;max-height:60vh}.dialog-mask{padding:8px;align-items:flex-end}.dialog{max-width:100%;max-height:92vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.dialog-canvas{max-width:90vw;max-height:60vh}}@media (max-width:480px){.frame-canvas{width:96px}.btn{padding:9px 18px;font-size:13px}.step-actions .btn{flex:1 1 auto;justify-content:center}}.legal-page{max-width:720px;margin:0 auto;padding:40px 24px 60px}.legal-card{background:var(--color-surface);backdrop-filter:var(--backdrop-blur);-webkit-backdrop-filter:var(--backdrop-blur);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:40px;box-shadow:var(--shadow-lg)}.legal-title{font-size:1.8rem;font-weight:800;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:32px;text-align:center}.legal-section{margin-bottom:28px}.legal-heading{font-size:1.1rem;font-weight:700;color:var(--color-text);margin-bottom:10px}.legal-paragraph{font-size:14px;color:var(--color-text-secondary);line-height:1.8;margin-bottom:8px}@media (max-width:768px){.legal-page{padding:24px 16px 40px}.legal-card{padding:24px 20px;border-radius:var(--radius-lg)}.legal-title{font-size:1.5rem;margin-bottom:24px}}