*{box-sizing:border-box}:root{color-scheme:light;font-size:clamp(14px,.8rem + .35vw,18px);font-family:Segoe UI,Helvetica Neue,sans-serif;background:radial-gradient(circle at top left,#1b2433,#0f141c 45%,#0b0f14);color:#e6f0ff}body{margin:0;min-height:100vh;text-size-adjust:100%;-webkit-text-size-adjust:100%}#root{min-height:100vh}.app{--fullscreen-aspect-w: 4;--fullscreen-aspect-h: 3;--fullscreen-integer-w: 640px;--fullscreen-integer-h: 480px;display:flex;flex-direction:column;gap:clamp(12px,2vw,24px);padding:clamp(12px,2vw,24px)}.app__header{display:flex;align-items:center;justify-content:space-between;gap:16px}.app__subtitle{margin:6px 0 0;color:#94a4b8}.app__status{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.status__label{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#94a4b8}.status__value{padding:6px 12px;border-radius:999px;background:#1a2533;border:1px solid #2a3b52;font-weight:600}.status__value--ready{background:#1e3324;border-color:#2f5740;color:#bfe6c1}.status__value--error{background:#3b1e21;border-color:#5e2b34;color:#f2b8be}.status__value--loading{background:#2d3340;border-color:#4a5568;color:#fbbf24}.status__value--waiting{background:#2d3340;border-color:#4a5568;color:#94a4b8}.app__panel{position:relative;z-index:1;border-radius:20px;padding:16px;background:#0f1620;border:1px solid #1f2a3a;box-shadow:0 24px 60px #0006}.app__canvas{width:100%;height:min(60dvh,900px);min-height:240px;display:block;border-radius:16px;background:#0b0f14;touch-action:none}.app__canvas--pixelated{image-rendering:pixelated}.app__panel:fullscreen,.app__panel:-webkit-full-screen{padding:0;border:none;border-radius:0;background:#000;display:flex;align-items:center;justify-content:center}.app--fullscreen-aspect-lock .app__panel:fullscreen .app__canvas,.app--fullscreen-aspect-lock .app__panel:-webkit-full-screen .app__canvas{width:min(100vw,calc(100dvh * (var(--fullscreen-aspect-w) / var(--fullscreen-aspect-h))))!important;height:min(100dvh,calc(100vw * (var(--fullscreen-aspect-h) / var(--fullscreen-aspect-w))))!important;min-height:0!important;border-radius:0}.app--fullscreen-aspect-free .app__panel:fullscreen .app__canvas,.app--fullscreen-aspect-free .app__panel:-webkit-full-screen .app__canvas{width:100vw!important;height:100dvh!important;min-height:0!important;border-radius:0}.app--fullscreen-integer .app__panel:fullscreen .app__canvas,.app--fullscreen-integer .app__panel:-webkit-full-screen .app__canvas{width:var(--fullscreen-integer-w)!important;height:var(--fullscreen-integer-h)!important}.app__panel:fullscreen .app__warning,.app__panel:fullscreen .app__error,.app__panel:-webkit-full-screen .app__warning,.app__panel:-webkit-full-screen .app__error{display:none}.app__warning,.app__error{margin-top:12px;padding:12px 16px;border-radius:12px;background:#231d11;color:#f2e5b5}.app__error{background:#2c1518;color:#f2b8be}.app__details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;padding:12px 16px;border-radius:16px;background:#0f1620;border:1px solid #1f2a3a}.detail__label{display:block;font-size:12px;color:#94a4b8;text-transform:uppercase;letter-spacing:.08em}.detail__value{font-size:14px;font-weight:600}@media (max-width: 720px){.app{padding-bottom:max(12px,env(safe-area-inset-bottom))}.app__header{flex-direction:column;align-items:flex-start}.app__status{align-items:flex-start}.app__canvas{height:52dvh;min-height:220px}.button-group{gap:6px}.divider{display:none}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#0f1620;border:1px solid #1f2a3a;border-radius:16px;box-shadow:0 24px 60px #0009;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.opfs-tool-modal{min-width:800px;min-height:500px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #1f2a3a}.modal-header h2{margin:0;font-size:20px;font-weight:600;color:#e6f0ff}.modal-close{background:none;border:none;color:#94a4b8;font-size:28px;line-height:1;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s}.modal-close:hover{background:#1f2a3a;color:#e6f0ff}.modal-body{flex:1;overflow:hidden;display:flex;flex-direction:column;padding:24px}.opfs-error{padding:12px 16px;border-radius:8px;background:#2c1518;color:#f2b8be;margin-bottom:16px;font-size:14px}.opfs-toolbar{display:flex;gap:12px;margin-bottom:20px}.opfs-content{flex:1;display:flex;gap:24px;overflow:hidden;min-height:0}.opfs-file-list-container{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.opfs-file-list-container h3{margin:0 0 12px;font-size:16px;font-weight:600;color:#e6f0ff}.opfs-loading,.opfs-empty{padding:24px;text-align:center;color:#94a4b8;font-size:14px}.opfs-file-list{flex:1;overflow-y:auto;border:1px solid #1f2a3a;border-radius:8px;background:#0b0f14;padding:8px}.opfs-file-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:6px;margin-bottom:4px;transition:background .2s}.opfs-file-item:hover{background:#1a2533}.opfs-file-item.dir{opacity:.7}.opfs-file-info{flex:1;display:flex;align-items:center;gap:12px;min-width:0}.opfs-file-path{flex:1;font-size:13px;color:#e6f0ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:Consolas,Monaco,monospace}.opfs-file-size{font-size:12px;color:#94a4b8;white-space:nowrap}.opfs-file-actions{display:flex;gap:8px;flex-shrink:0}.action-btn{padding:6px 12px;min-height:36px;border-radius:6px;border:1px solid #2a3b52;background:#1a2533;color:#e6f0ff;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.action-btn:hover:not(:disabled){background:#2a3b52;border-color:#3a4b62}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn.secondary{background:#2c1e23;border-color:#4a2b34;color:#f2b8be}.action-btn.secondary:hover:not(:disabled){background:#3a2e33;border-color:#5a3b44}.action-btn.secondary.active{background:#1f3042;border-color:#3e6387;color:#d6eaff}.action-btn.small{padding:4px 8px;font-size:12px}.action-btn.toggled-off{background:#1a1a1a;border-color:#333;color:#666;opacity:.7}.action-btn.toggled-off:hover:not(:disabled){background:#252525;border-color:#444;color:#888}.opfs-file-viewer{flex:1;display:flex;flex-direction:column;min-width:0;border:1px solid #1f2a3a;border-radius:8px;background:#0b0f14;overflow:hidden}.opfs-viewer-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #1f2a3a}.opfs-viewer-header h3{margin:0;font-size:14px;font-weight:600;color:#e6f0ff;font-family:Consolas,Monaco,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.opfs-file-content{flex:1;overflow:auto;padding:16px;margin:0;font-family:Consolas,Monaco,monospace;font-size:12px;line-height:1.6;color:#e6f0ff;background:#0b0f14;white-space:pre-wrap;word-wrap:break-word}@media (max-width: 1000px){.opfs-tool-modal{min-width:600px}.opfs-content{flex-direction:column}.opfs-file-viewer{max-height:300px}}.debug-overlay{position:relative;z-index:10;margin-bottom:16px;padding:16px;border-radius:16px;background:#0f1620;border:1px solid #1f2a3a;box-shadow:0 8px 24px #0000004d}.status-panel{display:flex;gap:12px;margin-bottom:12px;flex-wrap:wrap}.status-item{display:flex;align-items:center;gap:6px;font-size:12px}.status-item .label{color:#94a4b8}.status-item .value{padding:4px 8px;border-radius:4px;background:#1a2533;border:1px solid #2a3b52;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em}.status-item .value.status-ready{background:#1e3324;border-color:#2f5740;color:#bfe6c1}.status-item .value.status-pending{background:#2d3340;border-color:#4a5568;color:#94a4b8}.status-item .value.status-error{background:#3b1e21;border-color:#5e2b34;color:#f2b8be}.status-item .value.status-loading{background:#2d3340;border-color:#4a5568;color:#fbbf24}.status-item .value.status-waiting{background:#2d3340;border-color:#4a5568;color:#94a4b8}.control-panel{margin-top:12px}.error-toast{margin-top:12px;padding:12px 16px;border-radius:8px;background:#2c1518;color:#f2b8be;font-size:14px}.button-group{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.divider{width:1px;height:20px;background:#2a3b52;margin:0 4px}.pause-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;font-weight:600;background:#1e3324;border-color:#2f5740;color:#bfe6c1;position:relative;overflow:hidden}.pause-btn:hover:not(:disabled){background:#2a4a35;border-color:#3f6a50;transform:translateY(-1px);box-shadow:0 2px 8px #2f57404d}.pause-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 4px #2f574033}.pause-btn.paused{background:#2c1e23;border-color:#4a2b34;color:#f2b8be}.pause-btn.paused:hover:not(:disabled){background:#3a2e33;border-color:#5a3b44;box-shadow:0 2px 8px #4a2b344d}.pause-icon{font-size:14px;line-height:1;display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px}.pause-text{font-size:13px}.pause-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.settings-modal{width:min(640px,92vw)}.settings-grid{display:grid;gap:12px}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:16px;color:#e6f0ff}.settings-row select{min-width:240px;border-radius:8px;border:1px solid #2a3b52;background:#1a2533;color:#e6f0ff;padding:8px 10px}.settings-row input[type=checkbox]{width:18px;height:18px}.settings-hint{margin:16px 0 0;color:#94a4b8;font-size:13px}
