.app{background:var(--bg-color);width:100%;max-width:480px;height:100%;margin:0 auto;position:relative;overflow:hidden}.welcome-container{text-align:center;flex-direction:column;justify-content:center;align-items:center;height:100%;padding:40px 24px;animation:.6s fadeIn;display:flex}.welcome-illustration{margin-bottom:24px;animation:3s ease-in-out infinite float}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.welcome-title{letter-spacing:-.5px;color:var(--text-primary);margin-bottom:8px;font-size:28px;font-weight:700}.welcome-subtitle{color:var(--text-secondary);margin-bottom:40px;font-size:15px}.welcome-features{flex-direction:column;gap:14px;width:100%;max-width:260px;margin-bottom:48px;display:flex}.feature-item{background:var(--card-bg);box-shadow:var(--shadow);color:var(--text-primary);transition:var(--transition);border-radius:12px;align-items:center;gap:12px;padding:12px 16px;font-size:14px;display:flex}.feature-item:hover{transform:translate(4px);box-shadow:0 4px 16px #0000001a}.feature-icon{text-align:center;width:32px;font-size:20px}.start-btn{background:var(--accent-color);color:#fff;box-shadow:0 4px 20px color-mix(in srgb, var(--accent-color) 40%, transparent);transition:var(--transition);letter-spacing:.5px;border-radius:50px;padding:16px 56px;font-size:17px;font-weight:600}.start-btn:hover{box-shadow:0 6px 28px color-mix(in srgb, var(--accent-color) 50%, transparent);transform:translateY(-2px)}.start-btn:active{transform:translateY(0)}.welcome-note{color:var(--text-secondary);margin-top:20px;font-size:12px}.camera-container{background:#000;flex-direction:column;width:100%;height:100%;display:flex;position:relative}.camera-video{object-fit:cover;width:100%;height:100%}.camera-video.mirrored{transform:scaleX(-1)}.camera-overlay{object-fit:cover;pointer-events:none;z-index:1;width:100%;height:100%;position:absolute;inset:0}.camera-overlay.mirrored{transform:scaleX(-1)}.scan-indicator{animation:1.5s ease-in-out infinite pulse}.recording-indicator{color:#fff;background:#dc2626e6;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:600;animation:1.5s ease-in-out infinite pulse-rec;display:flex;position:absolute;top:16px;right:16px}.recording-dot{background:#fff;border-radius:50%;width:8px;height:8px;animation:1s ease-in-out infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}@keyframes pulse-rec{0%,to{opacity:1}50%{opacity:.7}}.model-status{backdrop-filter:blur(8px);color:var(--text-secondary);background:#ffffffe6;border-radius:20px;align-items:center;gap:8px;padding:8px 14px;font-size:12px;display:flex;position:absolute;top:16px;left:16px}.model-status.ready{color:#16a34a}.model-status.error{color:#92400e;background:#fef3c7f2}.camera-error-panel{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:40px 24px;animation:.4s fadeIn;display:flex;position:absolute;inset:0}.camera-error-panel .error-icon{opacity:.6;font-size:48px}.camera-error-panel .error-message{color:var(--text-secondary);white-space:pre-line;max-width:280px;font-size:14px;line-height:1.6}.camera-error-panel .retry-btn{background:var(--accent-color);color:#fff;transition:var(--transition);border-radius:50px;margin-top:8px;padding:12px 32px;font-size:14px;font-weight:600}.camera-error-panel .retry-btn:hover{opacity:.85}.processing-overlay{backdrop-filter:blur(4px);color:#fff;z-index:10;background:#000000b3;flex-direction:column;justify-content:center;align-items:center;gap:16px;font-size:16px;animation:.3s fadeIn;display:flex;position:absolute;inset:0}.processing-overlay .loading-spinner.large{border-color:#ffffff4d}.processing-stage{margin-top:4px;font-size:16px;font-weight:600}.progress-bar{background:#fff3;border-radius:3px;width:200px;height:6px;margin-top:8px;overflow:hidden}.progress-fill{background:#fff;border-radius:3px;height:100%;transition:width .3s}.progress-fill.indeterminate{animation:1.2s ease-in-out infinite indeterminate;width:30%!important}@keyframes indeterminate{0%{transform:translate(-100%)}to{transform:translate(400%)}}.progress-text{opacity:.7;margin-top:6px;font-family:SF Mono,Fira Code,monospace;font-size:13px}.processing-hint{opacity:.5;margin-top:12px;font-size:11px}.camera-controls{background:linear-gradient(#0000,#00000080);justify-content:center;align-items:center;gap:40px;padding:32px 24px 48px;display:flex;position:absolute;bottom:0;left:0;right:0}.control-btn{backdrop-filter:blur(8px);color:#fff;width:48px;height:48px;transition:var(--transition);background:#fff3;border-radius:50%;justify-content:center;align-items:center;display:flex}.control-btn:hover{background:#ffffff4d;transform:scale(1.05)}.control-btn.album-btn svg{stroke:#fff;fill:none}.edit-btn{border:1px solid var(--border-color);cursor:pointer;transition:var(--transition);text-align:center;background:0 0;border-radius:8px;min-width:40px;padding:6px 12px;font-size:20px}.edit-btn:hover{background:var(--card-bg)}.edit-btn.done{border-color:var(--accent-color);color:var(--accent-color);font-size:18px;font-weight:700}.eraser-canvas{object-fit:contain;touch-action:none;cursor:crosshair;max-width:100%;max-height:100%}.eraser-controls{flex-direction:column;gap:10px;padding:16px;display:flex}.eraser-hint{text-align:center;color:var(--text-secondary);margin:0;font-size:13px}.switch-btn svg{stroke:#fff}.shutter-btn{width:72px;height:72px;transition:var(--transition);background:#fff;border-radius:50%;justify-content:center;align-items:center;display:flex;box-shadow:0 0 0 4px #ffffff4d}.shutter-btn:hover{transform:scale(1.05)}.shutter-btn:active{transform:scale(.95)}.shutter-inner{border:3px solid var(--accent-color);width:58px;height:58px;transition:var(--transition);background:#fff;border-radius:50%}.shutter-btn:active .shutter-inner{width:50px;height:50px}.record-btn{width:52px;height:52px}.record-inner{width:24px;height:24px;transition:var(--transition);background:#dc2626;border-radius:50%}.record-btn.recording .record-inner{background:#dc2626;border-radius:4px;width:18px;height:18px}.preview-container{background:var(--bg-color);flex-direction:column;height:100%;animation:.4s slideUp;display:flex}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.preview-header{background:var(--card-bg);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.preview-header h2{font-size:16px;font-weight:600}.back-btn{color:var(--accent-color);transition:var(--transition);padding:4px 8px;font-size:14px;font-weight:500}.back-btn:hover{opacity:.7}.preview-canvas{flex:none;justify-content:center;align-items:center;padding:12px;display:flex;overflow:hidden}.border-controls{background:var(--card-bg);border-radius:12px;flex-direction:column;gap:12px;margin:0 12px;padding:12px 16px;display:flex}.control-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.control-label{color:var(--text-secondary);white-space:nowrap;min-width:60px;font-size:13px}.color-presets{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.color-dot{cursor:pointer;width:28px;height:28px;transition:var(--transition);background:0 0;border:2px solid #0000;border-radius:50%;padding:0}.color-dot.active{border-color:var(--text-primary);transform:scale(1.15)}.color-dot:hover{transform:scale(1.1)}.color-custom{cursor:pointer;position:relative}.color-custom input[type=color]{opacity:0;cursor:pointer;width:28px;height:28px;position:absolute}.color-custom-icon{font-size:20px;line-height:28px}.slider-wrap{flex:1;align-items:center;gap:8px;display:flex}.border-slider{appearance:none;background:var(--border-color);border-radius:2px;outline:none;flex:1;height:4px}.border-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent-color);cursor:pointer;border-radius:50%;width:20px;height:20px}.slider-value{color:var(--text-secondary);text-align:right;min-width:32px;font-size:12px}.checkerboard-bg{border-radius:var(--radius);background-image:linear-gradient(45deg,#e8e8e8 25%,#0000 25%),linear-gradient(-45deg,#e8e8e8 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#e8e8e8 75%),linear-gradient(-45deg,#0000 75%,#e8e8e8 75%);background-position:0 0,0 10px,10px -10px,-10px 0;background-size:20px 20px;justify-content:center;align-items:center;width:100%;height:100%;display:flex;overflow:hidden}.preview-image{object-fit:contain;max-width:100%;max-height:100%}.original-compare{align-items:center;gap:12px;padding:12px 20px;display:flex}.compare-label{color:var(--text-secondary);white-space:nowrap;font-size:12px}.original-thumb{object-fit:cover;border:2px solid var(--border-color);border-radius:8px;width:56px;height:56px}.color-info{background:var(--card-bg);box-shadow:var(--shadow);border-radius:12px;align-items:center;gap:12px;margin:0 16px;padding:12px 20px;display:flex}.color-swatch{border:2px solid var(--border-color);width:36px;height:36px;transition:var(--transition);border-radius:50%;flex-shrink:0}.color-details{flex-direction:column;gap:2px;display:flex}.color-hex{font-family:SF Mono,Fira Code,monospace;font-size:14px;font-weight:600}.color-rgb{color:var(--text-secondary);font-size:12px}.color-fallback{color:#f59e0b;font-size:11px}.preview-actions{flex-shrink:0;gap:12px;padding:16px 20px 40px;display:flex}.preview-scroll{-webkit-overflow-scrolling:touch;flex:1;overflow:hidden auto}.text-controls{background:var(--card-bg);border-radius:12px;flex-direction:column;gap:12px;margin:8px 12px 0;padding:12px 16px;display:flex}.toggle-btn{border:2px solid var(--border-color);color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border-radius:20px;padding:6px 16px;font-size:13px;font-weight:500}.toggle-btn.active{border-color:var(--accent-color);background:var(--accent-color);color:#fff}.color-dot.small{width:22px;height:22px}.text-input-row{display:block}.text-input{border:1px solid var(--border-color);background:var(--bg-color);width:100%;color:var(--text-primary);box-sizing:border-box;border-radius:10px;outline:none;padding:10px 14px;font-size:15px}.text-input:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent-color) 15%, transparent)}.slider-label-sm{color:var(--text-secondary);white-space:nowrap;font-size:11px}.action-btn{transition:var(--transition);text-align:center;border-radius:12px;flex:1;padding:14px;font-size:15px;font-weight:600}.action-btn.primary{background:var(--accent-color);color:#fff;box-shadow:0 4px 16px color-mix(in srgb, var(--accent-color) 30%, transparent)}.action-btn.primary:hover{box-shadow:0 6px 20px color-mix(in srgb, var(--accent-color) 40%, transparent);transform:translateY(-1px)}.action-btn.secondary{background:var(--card-bg);color:var(--text-primary);border:1px solid var(--border-color)}.action-btn.secondary:hover{background:#f8f8f8}.hidden{display:none!important}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (width<=380px){.welcome-title{font-size:24px}.welcome-features{gap:10px}.camera-controls{gap:28px}.shutter-btn{width:64px;height:64px}.shutter-inner{width:50px;height:50px}}@media (width>=481px){.app{border-radius:0;max-width:480px;margin-top:0;box-shadow:0 0 60px #0000001a}}.save-menu-overlay{z-index:100;background:#00000080;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.save-menu{background:var(--bg-color);border-radius:20px 20px 0 0;flex-direction:column;gap:8px;width:100%;max-width:480px;padding:20px;animation:.3s slideUp;display:flex}.save-menu-title{text-align:center;color:var(--text-secondary);margin-bottom:4px;font-size:15px;font-weight:600}.save-menu-item{background:var(--card-bg);cursor:pointer;text-align:left;transition:var(--transition);border:none;border-radius:12px;align-items:center;gap:14px;padding:14px 16px;display:flex}.save-menu-item:hover{opacity:.85}.save-menu-item.primary{background:var(--accent-color)}.save-menu-item.primary .save-item-title,.save-menu-item.primary .save-item-desc{color:#fff}.save-icon{font-size:24px}.save-item-title{color:var(--text-primary);font-size:15px;font-weight:600;display:block}.save-item-desc{color:var(--text-secondary);margin-top:2px;font-size:12px;display:block}.save-menu-item.cancel{color:var(--text-secondary);background:0 0;justify-content:center;margin-top:4px;padding:10px;font-size:15px}.gallery-container{background:var(--bg-color);flex-direction:column;height:100%;animation:.4s fadeIn;display:flex}.gallery-header{background:var(--card-bg);border-bottom:1px solid var(--border-color);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.gallery-header h2{font-size:16px;font-weight:600}.gallery-loading{color:var(--text-secondary);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;display:flex}.gallery-empty{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:40px;display:flex}.gallery-empty .empty-icon{opacity:.5;font-size:56px}.gallery-empty p{color:var(--text-secondary);font-size:15px}.gallery-empty .empty-hint{opacity:.6;font-size:13px}.gallery-grid{-webkit-overflow-scrolling:touch;flex:1;grid-template-columns:repeat(3,1fr);align-content:start;gap:8px;padding:12px;display:grid;overflow-y:auto}.gallery-item{aspect-ratio:1;cursor:pointer;transition:var(--transition);background:var(--card-bg);border-radius:12px;position:relative;overflow:hidden}.gallery-item:active{transform:scale(.95)}.gallery-item-inner{box-sizing:border-box;width:100%;height:100%;padding:4px}.gallery-item-inner .checkerboard-bg{border-radius:8px}.gallery-thumb{object-fit:contain;max-width:100%;max-height:100%}.gallery-delete-btn{color:#fff;cursor:pointer;opacity:0;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:14px;line-height:1;transition:opacity .2s;display:flex;position:absolute;top:4px;right:4px}.gallery-item:hover .gallery-delete-btn,.gallery-item:active .gallery-delete-btn{opacity:1}.gallery-share-btn{color:#fff;cursor:pointer;opacity:0;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:14px;line-height:1;transition:opacity .2s;display:flex;position:absolute;bottom:4px;right:4px}.gallery-item:hover .gallery-share-btn,.gallery-item:active .gallery-share-btn{opacity:1}.album-badge{color:#fff;text-align:center;pointer-events:none;background:#ff4757;border-radius:9px;min-width:18px;height:18px;padding:0 4px;font-size:11px;font-weight:700;line-height:18px;position:absolute;top:-4px;right:-4px}.float-overlay{backdrop-filter:blur(6px);z-index:20;pointer-events:none;opacity:0;background:#0009;flex-direction:column;justify-content:center;align-items:center;transition:opacity .4s;display:flex;position:absolute;inset:0}.float-overlay.show{opacity:1}.float-sticker{max-width:60%;max-height:60%;transition:transform .6s cubic-bezier(.34,1.56,.64,1);transform:scale(.5)translateY(80px)}.float-overlay.show .float-sticker{transform:scale(1)translateY(0)}.float-img{object-fit:contain;max-width:100%;max-height:100%}.float-text{color:#fff;opacity:0;margin-top:16px;font-size:16px;font-weight:600;transition:all .4s .3s;transform:translateY(10px)}.float-overlay.show .float-text{opacity:1;transform:translateY(0)}.gallery-edit-container{background:var(--bg-color);flex-direction:column;height:100%;display:flex}.gallery-fab{backdrop-filter:blur(8px);color:#fff;cursor:pointer;z-index:5;width:44px;height:44px;transition:var(--transition);background:#fff3;border:none;border-radius:12px;justify-content:center;align-items:center;display:flex;position:absolute;top:16px;right:16px}.gallery-fab:active{transform:scale(.92)}.gallery-fab-badge{color:#fff;text-align:center;pointer-events:none;background:#ff4757;border-radius:10px;min-width:20px;height:20px;padding:0 5px;font-size:11px;font-weight:700;line-height:20px;position:absolute;top:-5px;right:-5px}.control-btn.upload-btn{position:relative}.control-btn.upload-btn svg{stroke:#fff;fill:none}:root{--bg-color:#f5f5f5;--text-primary:#1a1a1a;--text-secondary:#666;--accent-color:#708090;--accent-color-rgb:112, 128, 144;--accent-color-bg:#70809015;--accent-color-light:#70809040;--border-color:#e0e0e0;--card-bg:#fff;--shadow:0 2px 12px #0000000f;--radius:16px;--transition:all .3s cubic-bezier(.4, 0, .2, 1);color:var(--text-primary);background:var(--bg-color);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,sans-serif;font-size:16px;line-height:1.5}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}button{cursor:pointer;font:inherit;color:inherit;background:0 0;border:none;outline:none}button:disabled{opacity:.4;cursor:not-allowed}img{max-width:100%;display:block}.loading-spinner{border:2px solid var(--border-color);border-top-color:var(--accent-color);border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}.loading-spinner.large{border-width:3px;width:40px;height:40px}@keyframes spin{to{transform:rotate(360deg)}}
