:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;font-weight:400;color:var(--color-text-primary);background-color:var(--color-body-background);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color-scheme:light;--color-text-primary: #0f172a;--color-text-muted: #475569;--color-text-subtle: #64748b;--color-text-tertiary: #94a3b8;--color-panel-bg: #ffffff;--color-panel-border: #e2e8f0;--shadow-panel: 0 6px 18px rgba(15, 23, 42, .06);--shadow-toggle: 0 4px 12px rgba(15, 23, 42, .18);--color-input-border: #cbd5f5;--color-input-bg: #f8fafc;--color-filename: #334155;--color-hint: #64748b;--color-secondary-button-bg: #e2e8f0;--color-secondary-button-text: #0f172a;--color-secondary-button-border: #cbd5f5;--color-link: #6366f1;--color-error: #ef4444;--color-preview-border: rgba(99, 102, 241, .2);--color-viewport-bg: #0f172a;--color-viewport-overlay: rgba(15, 23, 42, .45);--color-crosshair-center: rgba(15, 23, 42, .7);--color-gif-border: #e2e8f0;--color-accent: #6366f1;--color-toggle-track: rgba(148, 163, 184, .28);--color-toggle-border: rgba(148, 163, 184, .55);--color-toggle-thumb: #ffffff;--color-toggle-icon: #0f172a;--color-body-background: #f3f4f6;--color-body-gradient-start: #f8fafc;--color-body-gradient-end: #e2e8f0}[data-theme=dark]{color-scheme:dark;--color-text-primary: #f1f5f9;--color-text-muted: #cbd5f5;--color-text-subtle: #94a3b8;--color-text-tertiary: #64748b;--color-panel-bg: #0f172a;--color-panel-border: #1e293b;--shadow-panel: 0 12px 28px rgba(15, 23, 42, .45);--shadow-toggle: 0 6px 18px rgba(15, 23, 42, .6);--color-input-border: #1e293b;--color-input-bg: rgba(30, 41, 59, .75);--color-filename: #e2e8f0;--color-hint: #94a3b8;--color-secondary-button-bg: #1f2937;--color-secondary-button-text: #e2e8f0;--color-secondary-button-border: #334155;--color-link: #a5b4fc;--color-error: #fca5a5;--color-preview-border: rgba(99, 102, 241, .45);--color-viewport-bg: #111827;--color-viewport-overlay: rgba(15, 23, 42, .55);--color-crosshair-center: rgba(15, 23, 42, .85);--color-gif-border: #1f2937;--color-toggle-track: rgba(148, 163, 184, .2);--color-toggle-border: rgba(148, 163, 184, .35);--color-toggle-thumb: #e2e8f0;--color-toggle-icon: #e2e8f0;--color-body-background: #0b1120;--color-body-gradient-start: #0f172a;--color-body-gradient-end: #111827}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background-color:var(--color-body-background);background-image:linear-gradient(135deg,var(--color-body-gradient-start) 0%,var(--color-body-gradient-end) 100%)}#root{min-height:100vh}a{color:inherit;text-decoration:none}input,button,select{font:inherit}.app-shell{max-width:1200px;margin:0 auto;padding:32px 20px 64px;display:flex;flex-direction:column;gap:24px}.app-header{display:flex;flex-direction:column;gap:8px}.header-top{display:flex;align-items:center;justify-content:space-between;gap:16px}.app-header h1{margin:0 0 4px;font-size:2.4rem;color:var(--color-text-primary)}.app-header p{margin:0;color:var(--color-text-muted)}.theme-toggle{position:relative;width:60px;height:32px;border-radius:999px;border:none;padding:0;background:transparent;cursor:pointer}.theme-toggle:focus-visible{outline:2px solid var(--color-accent);outline-offset:4px}.theme-toggle .toggle-track{position:relative;width:100%;height:100%;border-radius:inherit;background:var(--color-toggle-track);border:1px solid var(--color-toggle-border);transition:background .2s ease,border-color .2s ease}.theme-toggle .toggle-thumb{position:absolute;top:50%;left:4px;width:24px;height:24px;border-radius:999px;background:var(--color-toggle-thumb);transform:translateY(-50%);transition:transform .25s ease;box-shadow:var(--shadow-toggle)}.theme-toggle.is-dark .toggle-thumb{transform:translate(24px,-50%)}.theme-toggle .toggle-icon{position:absolute;top:50%;transform:translateY(-50%);font-size:.85rem;color:var(--color-toggle-icon);opacity:.75;transition:opacity .2s ease}.theme-toggle .toggle-icon.sun{left:10px}.theme-toggle .toggle-icon.moon{right:10px}.theme-toggle.is-dark .toggle-icon.sun{opacity:.4}.theme-toggle:not(.is-dark) .toggle-icon.moon{opacity:.4}.panel{background:var(--color-panel-bg);border:1px solid var(--color-panel-border);border-radius:14px;padding:18px 20px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow-panel)}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.panel-header h3{margin:0;font-size:1.05rem;font-weight:600;color:var(--color-text-primary)}.panel-body{display:flex;flex-direction:column;gap:12px}.frame-manager{position:sticky;top:16px;z-index:9;width:min(100%,760px);margin:0 auto 16px}.frame-manager .panel-body{padding-top:4px}.frame-manager.is-floating .panel{box-shadow:0 18px 38px #0f172a2e}.frame-manager.is-floating{transform:translateZ(0)}.frame-manager.is-collapsed .frame-carousel-track{min-height:110px}.frame-manager.is-collapsed .panel{padding:14px 16px}.frame-manager.is-collapsed .panel-body{padding-top:0}.frame-header-actions{display:inline-flex;align-items:center;gap:10px}.frame-count{font-size:.85rem;color:var(--color-text-subtle)}.carousel-toggle{padding-inline:10px;font-weight:600}.frame-carousel{overflow-x:auto;padding-bottom:6px}.frame-carousel.is-collapsed{padding-bottom:2px}.frame-carousel.is-floating .frame-carousel-track{transform:scale(.94);transform-origin:top left}.frame-carousel::-webkit-scrollbar{height:6px}.frame-carousel::-webkit-scrollbar-thumb{background:#6366f140;border-radius:999px}.frame-carousel-track{display:flex;align-items:stretch;gap:12px;min-height:172px;padding-bottom:4px;position:relative}.frame-carousel.is-collapsed .frame-carousel-track{gap:8px}.frame-card{position:relative;min-width:220px;display:flex;flex-direction:column;gap:12px;padding:12px;border-radius:12px;border:1px solid var(--color-panel-border);background:var(--color-panel-bg);cursor:pointer;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.frame-card.is-floating{transition:transform .2s ease}.frame-card.is-floating:not(.is-compact){min-width:200px}.frame-card.is-floating .frame-card-preview{aspect-ratio:16 / 9}.frame-card.is-compact{min-width:140px;padding:10px;gap:8px}.frame-card:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px}.frame-card.is-active{border-color:var(--color-accent);box-shadow:0 0 0 2px #6366f12e}.frame-card.is-pinned{position:sticky;left:0;z-index:2;box-shadow:0 6px 18px #6366f133;border-color:#6366f199}.frame-card.is-pinned:after{content:"Pinned";position:absolute;top:10px;right:12px;font-size:.72rem;font-weight:600;color:var(--color-accent)}.frame-card.is-compact .frame-card-preview{aspect-ratio:1 / 1;height:72px}.frame-card.is-compact .frame-card-meta{gap:2px;align-items:center;justify-content:center;text-align:center}.frame-card.is-compact .frame-card-title{font-size:.82rem}.frame-card.is-compact .frame-card-filename,.frame-card.is-compact .frame-card-actions{display:none}.frame-card.is-empty .frame-card-preview{background:repeating-conic-gradient(#e2e8f080 0 25%,#f1f5f980 0 50%) 50% / 16px 16px;color:var(--color-text-subtle)}.frame-card.is-drag-over{border-color:var(--color-accent);box-shadow:0 8px 24px #6366f12e}.frame-card-preview{position:relative;border-radius:10px;overflow:hidden;aspect-ratio:4 / 3;display:flex;align-items:center;justify-content:center;background:var(--color-input-bg);border:1px solid var(--color-input-border)}.frame-card-preview img{width:100%;height:100%;object-fit:cover}.frame-card-body{display:flex;flex-direction:column;gap:10px}.frame-card-meta{display:flex;flex-direction:column;gap:6px}.frame-card-title{font-weight:600;color:var(--color-text-primary)}.frame-card-filename{font-size:.82rem;color:var(--color-text-subtle);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.frame-card-filename.muted{color:var(--color-text-tertiary)}.frame-card-actions{display:flex;flex-wrap:wrap;gap:8px}.frame-card .chip{border-radius:999px;border:1px solid var(--color-input-border);background:var(--color-input-bg);color:var(--color-text-primary);padding:6px 12px;font-size:.8rem}.frame-card.is-compact .chip{display:none}.frame-card .chip:hover{background:#6366f114;border-color:#6366f138}.frame-card .chip.is-active{background:#6366f133;border-color:#6366f173;color:var(--color-accent)}.frame-card .chip.danger{border-color:#ef444459;color:var(--color-error);background:#ef444414}.frame-card .chip:disabled,.frame-card .chip[aria-disabled=true]{opacity:.5;cursor:not-allowed}.frame-card-input{display:none}.frame-card.add-frame{min-width:180px;justify-content:center;align-items:center;text-align:center;border:1px dashed var(--color-input-border);background:transparent;color:var(--color-text-subtle);font-weight:600;gap:6px}.frame-card.add-frame:hover{border-color:var(--color-accent);color:var(--color-accent)}.frame-card.add-frame .add-frame-icon{font-size:1.25rem}.workspace{display:flex;flex-direction:column;gap:20px}.frame-card.is-compact.add-frame{min-width:120px;padding:8px;font-size:.85rem}.canvas-toolbar .toolbar-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.preset-buttons{display:flex;flex-wrap:wrap;gap:8px;grid-column:1 / -1}.control-row{display:flex;flex-direction:column;gap:6px;font-size:.92rem;color:var(--color-text-primary)}.control-row.checkbox{flex-direction:row;align-items:center;gap:10px}.control-row input[type=range]{width:100%}.control-row select{border:1px solid var(--color-input-border);background:var(--color-input-bg);border-radius:8px;padding:8px 12px;color:var(--color-text-primary)}.control-inputs{display:grid;gap:8px}.number-input{display:inline-flex;align-items:center;border:1px solid var(--color-input-border);background:var(--color-input-bg);border-radius:8px;overflow:hidden}.number-input input{width:80px;padding:6px 8px;border:none;outline:none;background:transparent;font-size:.92rem;color:var(--color-text-primary)}.number-input input[type=range]{width:140px;padding:0}.number-input span{display:inline-flex;align-items:center;padding:0 8px;font-size:.85rem;color:var(--color-text-subtle)}.viewport-panel{gap:10px}.viewport-header{display:flex;justify-content:space-between;align-items:baseline;font-size:.9rem;color:var(--color-text-primary)}.viewport-meta{font-size:.8rem;color:var(--color-text-subtle)}.viewport-meta.muted{color:var(--color-text-tertiary)}.viewport-canvas{position:relative;width:100%;border-radius:16px;border:2px solid transparent;background:var(--color-viewport-bg);min-height:240px;overflow:hidden;cursor:crosshair;outline:1px dashed rgba(148,163,184,.35)}.viewport-canvas:after{content:"";position:absolute;inset:0;pointer-events:none;box-shadow:inset 0 0 0 1px #0f172a14}.viewport-canvas.is-empty{background:repeating-conic-gradient(#e2e8f099 0 25%,#f1f5f999 0 50%) 50% / 22px 22px}.viewport-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--color-text-subtle);font-size:.98rem;background:var(--color-viewport-overlay)}.viewport-image{position:absolute;top:50%;left:50%;max-width:unset;max-height:unset;transform-origin:center;will-change:transform;-webkit-user-select:none;user-select:none;pointer-events:none;z-index:2}.viewport-image.reference-frame{opacity:.32;filter:saturate(.8);mix-blend-mode:screen;z-index:6}.viewport-image.primary-frame{z-index:4}.crosshair{position:absolute;width:0;height:0;pointer-events:none;z-index:7}.crosshair-vertical,.crosshair-horizontal{position:absolute;background:#caff00d9}.crosshair-vertical{width:1px;height:120%;left:-.5px;top:-10%}.crosshair-horizontal{height:1px;width:120%;top:-.5px;left:-10%}.crosshair-center{position:absolute;width:10px;height:10px;border-radius:50%;border:2px solid #fcd34d;top:-6px;left:-6px;background:var(--color-crosshair-center)}.control-grid{display:flex;flex-direction:column;gap:14px}.editor-grid{display:grid;gap:20px;grid-template-columns:minmax(0,3fr) minmax(0,2fr);align-items:start}.editor-controls,.editor-viewport{display:flex;flex-direction:column;gap:16px}.export-controls{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.export-output{display:flex;flex-direction:column;gap:12px}.export-output img,.export-output video{width:100%;max-height:320px;object-fit:contain;border-radius:12px;border:1px solid var(--color-panel-border);background:var(--color-viewport-bg)}.export-output video{background:#000}.button-row{display:flex;flex-wrap:wrap;gap:12px}.chip{display:inline-flex;align-items:center;justify-content:center;padding:6px 12px;border-radius:999px;border:1px solid var(--color-input-border);background:var(--color-input-bg);font-size:.82rem;color:var(--color-text-primary);cursor:pointer;transition:background .2s ease,border-color .2s ease,color .2s ease}.chip:hover{background:#6366f11f;border-color:#6366f13d}.chip:disabled{opacity:.5;cursor:not-allowed}button.primary,a.primary{border:none;border-radius:10px;padding:10px 18px;font-weight:600;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;cursor:pointer;text-align:center}button.secondary{border-radius:10px;background:var(--color-secondary-button-bg);color:var(--color-secondary-button-text);border:1px solid var(--color-secondary-button-border);padding:10px 18px;font-weight:600;cursor:pointer}button.secondary:disabled{opacity:.5;cursor:not-allowed}.link{background:none;border:none;color:var(--color-link);cursor:pointer;padding:0}.error-message{margin:8px 0 0;color:var(--color-error);font-size:.9rem}@media(max-width:960px){.editor-grid{grid-template-columns:1fr}.frame-carousel-track{min-height:180px}}.gif-output img{width:100%;border-radius:12px;border:1px solid var(--color-gif-border)}.preview-section{display:flex;flex-direction:column;gap:12px;align-items:center}.wiggle-preview{position:relative;margin:0 auto;width:100%;max-width:720px;border-radius:18px;overflow:hidden;border:2px solid var(--color-preview-border);background:var(--color-viewport-bg);min-height:240px}.wiggle-preview.empty{display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);font-size:1rem}.wiggle-frame{position:absolute;top:50%;left:50%;transform-origin:center;will-change:opacity,transform;opacity:0;transition:opacity .18s ease-in-out}.wiggle-frame.visible{opacity:1}@media(max-width:1024px){.viewport-row{flex-direction:column}}@media(max-width:720px){.app-shell{padding:24px 16px 48px}.canvas-toolbar .toolbar-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.viewport-canvas{min-height:200px}}
