*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%;background:#0a0d14;color:#e0e0e0;font-family:system-ui,-apple-system,Segoe UI,Yu Gothic UI,Hiragino Sans,sans-serif;line-height:1.4}button,input,textarea{font-family:inherit}.btn{font-size:13px;padding:6px 14px;border-radius:4px;border:1px solid #4488cc;background:#1d3050;color:#fff;cursor:pointer}.btn:hover{background:#2a4570}.btn:disabled{opacity:.5;cursor:default}.btn-primary{background:#369;border-color:#6af}.btn-primary:hover{background:#48c}.btn-secondary{background:#2a2f3d;border-color:#556}.btn-secondary:hover{background:#3a3f4d}.btn-warn{background:#533;border-color:#a66}.btn-warn:hover{background:#644}.btn.active{background:#48c;border-color:#8cf}.seg{display:inline-flex;border:1px solid #4488cc;border-radius:4px;overflow:hidden}.seg-btn{background:#1d3050;color:#8ac;border:none;padding:4px 10px;font-size:13px;cursor:pointer;font-family:inherit;border-right:1px solid #2a4570}.seg-btn:last-child{border-right:none}.seg-btn:hover{background:#2a4570;color:#cce6ff}.seg-btn.active{background:#48c;color:#fff}.btn-tiny{font-size:10px;padding:2px 8px}.link-btn{background:transparent;border:none;color:#6af;cursor:pointer;text-decoration:underline;padding:0}.link-btn:hover{color:#8cf}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;color:#8ac}.loading-screen>:first-child{font-size:28px;color:#ffd28a;margin-bottom:8px}.loading-sub{color:#57a;font-size:14px}.auth-screen{display:flex;align-items:center;justify-content:center;height:100vh;padding:16px;background:linear-gradient(180deg,#0a0d14,#11151f)}.auth-card{background:#11151f;border:1px solid #1f2530;border-radius:8px;padding:32px;width:100%;max-width:380px;box-shadow:0 6px 32px #0009}.auth-card h1{margin:0 0 24px;font-size:22px;color:#fff}.auth-card-sub{font-size:14px;color:#8ac;font-weight:400;margin-left:8px}.auth-card label{display:block;margin-bottom:14px;font-size:12px;color:#8ac}.auth-card label small{display:block;color:#579;font-size:10px;margin-top:4px}.auth-card input[type=text],.auth-card input[type=email],.auth-card input[type=password]{display:block;width:100%;padding:8px 10px;margin-top:4px;background:#060810;border:1px solid #1f2530;border-radius:4px;color:#fff;font-size:14px}.auth-card input:focus{outline:none;border-color:#48c}.auth-card button[type=submit]{width:100%;padding:10px;margin-top:8px;font-size:14px}.auth-error{background:#4a2222;border:1px solid #aa5555;color:#fcc;padding:8px 10px;border-radius:4px;font-size:13px;margin-bottom:14px}.auth-switch{margin-top:20px;text-align:center;color:#8ac;font-size:13px}.project-screen{min-height:100vh;background:#0a0d14;display:flex;flex-direction:column}.project-header{display:flex;align-items:center;justify-content:space-between;padding:18px 32px;background:#11151f;border-bottom:1px solid #1f2530}.project-header h1{margin:0;font-size:20px;color:#ffd28a}.project-user{display:flex;align-items:center;gap:12px;color:#cce0ff;font-size:14px}.project-main{flex:1;padding:32px;max-width:960px;margin:0 auto;width:100%}.project-create{background:#11151f;border:1px solid #1f2530;border-radius:8px;padding:18px 22px;margin-bottom:24px}.project-create h2{margin:0 0 12px;font-size:16px;color:#fff}.project-create-row{display:flex;gap:10px}.project-create input{flex:1;padding:8px 12px;background:#060810;border:1px solid #1f2530;border-radius:4px;color:#fff;font-size:14px}.project-create small{display:block;margin-top:6px;color:#579;font-size:11px}.project-error{background:#4a2222;border:1px solid #aa5555;color:#fcc;padding:10px 14px;border-radius:4px;font-size:13px;margin-bottom:16px}.project-list h2{margin:0 0 12px;font-size:16px;color:#8ac}.project-empty,.project-loading{padding:32px;text-align:center;color:#579;font-style:italic}.project-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.project-card{background:#11151f;border:1px solid #1f2530;border-radius:6px;display:flex;flex-direction:column;overflow:hidden}.project-card-body{padding:14px 16px;cursor:pointer;flex:1}.project-card-body:hover{background:#17202c}.project-card-name{font-size:16px;color:#ffd28a;margin-bottom:6px}.project-card-meta{font-size:11px;color:#579;font-family:monospace;margin:2px 0}.project-card-actions{padding:10px 14px;border-top:1px solid #1f2530;display:flex;justify-content:space-between;gap:8px;background:#0e1219}.studio-app{display:flex;flex-direction:column;height:100vh}.toolbar{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:#11151f;border-bottom:1px solid #1f2530;height:48px;flex-shrink:0}.toolbar-title{display:flex;align-items:center;gap:10px;font-size:14px}.toolbar-back{background:transparent;border:1px solid #4488cc;color:#8cf;font-size:16px;width:30px;height:28px;border-radius:4px;cursor:pointer;padding:0}.toolbar-back:hover{background:#1d3050}.toolbar-title strong{color:#ffd28a;font-size:16px}.toolbar-project{color:#79b}.toolbar-dirty{color:#fa6;font-size:18px}.toolbar-user{display:flex;align-items:center;gap:6px;color:#8ac;font-size:12px;margin-left:8px}.toolbar-actions{display:flex;align-items:center;gap:8px}.studio-main{display:grid;grid-template-columns:240px 1fr 460px;flex:1;min-height:0}.studio-main.no-preview{grid-template-columns:240px 1fr}.studio-top-preview{height:38vh;max-height:420px;min-height:180px;display:flex;background:#000;border-bottom:1px solid #1f2530;flex-shrink:0;overflow:hidden}.studio-top-preview .test-play{flex:1;min-width:0;min-height:0}.studio-top-preview .log.log-top{width:320px;height:100%;border-left:1px solid #1f2530;border-top:none;flex-shrink:0;overflow-y:auto}@media(max-width:1100px){.studio-top-preview .log.log-top{width:200px}}@media(max-width:900px){.studio-top-preview .log.log-top{display:none}}.pane{display:flex;flex-direction:column;background:#0e1219;border-right:1px solid #1f2530;min-height:0;overflow:hidden}.pane-right{border-right:none}.pane-header{padding:6px 12px;background:#11151f;border-bottom:1px solid #1f2530;font-size:12px;color:#8ac;font-family:monospace;flex-shrink:0}.pane-body{flex:1;overflow:hidden;min-height:0}.left-tabs{display:flex;background:#11151f;border-bottom:1px solid #1f2530;flex-shrink:0}.left-tab{flex:1;padding:8px 4px;background:transparent;border:none;color:#57a;font-size:11px;font-weight:600;letter-spacing:.1em;cursor:pointer;border-bottom:2px solid transparent}.left-tab:hover{color:#8ac}.left-tab.active{color:#ffd28a;border-bottom-color:#ffd28a}.file-tree{font-size:13px;flex:1;overflow-y:auto}.file-tree-header{padding:8px 12px;font-size:11px;letter-spacing:.1em;color:#57a;text-transform:uppercase;border-bottom:1px solid #1f2530}.file-tree ul{list-style:none;margin:0;padding:0}.file-tree li{padding:6px 12px;cursor:pointer;color:#cce0ff}.file-tree li:hover{background:#1a2030}.file-tree li.active{background:#246;color:#fff;font-weight:500}.ft-icon{display:inline-block;width:18px;color:#579}.asset-panel{display:flex;flex-direction:column;height:100%;overflow:hidden}.asset-drop{margin:10px;padding:18px 10px;border:2px dashed #4488cc;border-radius:6px;text-align:center;font-size:12px;color:#8ac;cursor:pointer;user-select:none;flex-shrink:0}.asset-drop:hover,.asset-drop.drag-over{background:#1a2230;color:#cce6ff}.asset-drop-icon{font-size:22px;margin-bottom:4px}.asset-toolbar{display:flex;align-items:center;justify-content:space-between;padding:4px 10px 8px;font-size:11px;color:#579;flex-shrink:0}.asset-count{font-family:monospace}.asset-list{flex:1;overflow-y:auto;padding:0 10px 10px}.asset-empty{color:#456;font-size:12px;text-align:center;padding:24px 8px;font-style:italic}.asset-group{margin-bottom:12px}.asset-group-title{font-size:10px;letter-spacing:.12em;color:#57a;font-weight:700;padding:6px 2px 4px;border-bottom:1px solid #1f2530;margin-bottom:6px}.asset-grid{display:grid;grid-template-columns:1fr;gap:6px}.asset-card{background:#11151f;border:1px solid #1f2530;border-radius:4px;display:flex;flex-direction:column;overflow:hidden}.asset-thumb{height:60px;background:#060810;display:flex;align-items:center;justify-content:center;overflow:hidden}.asset-thumb img{max-width:100%;max-height:100%;object-fit:contain}.asset-thumb-fallback{font-size:28px;opacity:.4}.asset-meta{padding:6px 8px;font-size:11px}.asset-path{font-family:monospace;color:#cce6ff;font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.asset-info{color:#579;font-size:10px;margin:2px 0 4px}.asset-actions{display:flex;gap:4px}.pane-header-with-tabs{display:flex;align-items:center;justify-content:space-between;padding:0 12px}.pane-filename{font-family:monospace;font-size:12px;color:#8ac}.center-tabs{display:flex;gap:2px}.center-tab{padding:6px 14px;background:transparent;border:none;color:#57a;font-size:11px;font-weight:600;letter-spacing:.1em;cursor:pointer;border-bottom:2px solid transparent}.center-tab:hover{color:#8ac}.center-tab.active{color:#ffd28a;border-bottom-color:#ffd28a}.scene-grid-wrap{height:100%;overflow:auto;background:#0a0d14}.grid-error{padding:20px;color:#faa}.grid-error pre{background:#1a0e0e;padding:8px;border-radius:4px;font-size:11px;white-space:pre-wrap}.grid-empty{padding:32px;text-align:center;color:#579;font-style:italic}.scene-grid{width:100%;border-collapse:collapse;font-size:11px;font-family:Yu Gothic UI,Hiragino Sans,system-ui,sans-serif}.scene-grid thead th{background:#11151f;color:#ffd28a;font-weight:700;font-size:10px;letter-spacing:.08em;padding:6px 4px;text-align:center;border-bottom:2px solid #2a3550;border-right:1px solid #1f2530;position:sticky;top:0;z-index:5;white-space:nowrap}.scene-grid .col-num{width:28px;min-width:28px;text-align:center;color:#579;font-family:monospace}.scene-grid .col-state{width:50px;min-width:50px;text-align:center}.scene-grid .col-bgm{width:120px;min-width:120px}.scene-grid .col-se{width:70px;min-width:70px}.scene-grid .col-bg{width:70px;min-width:70px;text-align:center}.scene-grid .col-chara{width:52px;min-width:52px;text-align:center}.scene-grid .col-msg{min-width:280px}.scene-grid .col-label{width:180px;min-width:180px}.scene-grid tbody tr{cursor:pointer}.scene-grid tbody tr:nth-child(2n){background:#0e1219}.scene-grid tbody tr:nth-child(odd){background:#11151f}.scene-grid tbody tr:hover{background:#1a2540}.scene-grid tbody tr.active{background:#246;outline:1px solid #66aaff}.scene-grid tbody tr.marker-row{background:#1a1d2a}.scene-grid tbody td{padding:4px 6px;border-bottom:1px solid #1a1f2a;border-right:1px solid #14181f;vertical-align:middle;color:#cce0ff}.scene-grid tbody td.carry{color:#57a;opacity:.6}.empty{color:#2a3344}.state-tag{display:inline-block;padding:2px 6px;border-radius:3px;font-size:11px;font-weight:700;background:#1d3050;color:#ffd28a}.state-tag.tag-jump{background:#2a4570;color:#fc6}.state-tag.tag-end{background:#533;color:#faa}.state-tag.tag-choice{background:#369;color:#fff}.se-flash{background:#f84;color:#11151f;padding:2px 6px;border-radius:3px;font-weight:700;font-size:10px}.thumb{width:56px;height:38px;background:#060810;border:1px solid #2a3344;border-radius:2px;position:relative;overflow:hidden;margin:0 auto}.thumb img{width:100%;height:100%;object-fit:cover}.thumb-chara img{object-fit:contain;background:#11151f}.thumb-overlay{position:absolute;bottom:0;left:0;right:0;background:#000000bf;color:#ffd28a;font-size:8px;text-align:center;padding:1px 0;font-family:monospace}.thumb-label{color:#8ac;font-size:10px;font-family:monospace}.msg-cell{padding:2px 4px;border-radius:3px}.msg-cell.editable{cursor:text}.msg-cell.editable:hover{background:#2a3550;outline:1px solid #66aaff}.msg-speaker{font-weight:700;font-size:11px;margin-bottom:2px}.msg-text{color:#fff;white-space:pre-wrap;word-break:break-word;line-height:1.4}.choices-cell{background:#1a2440;border-left:3px solid #66aaff;padding:2px 4px 2px 8px}.choice-line{display:flex;align-items:center;gap:4px;font-size:11px;padding:1px 0}.choice-bullet{color:#57a}.choice-text{color:#fff;flex:1}.choice-arrow{color:#8ac}.choice-target{color:#ffd28a;font-family:monospace;font-size:10px}.choice-cond{color:#8f8;font-family:monospace;font-size:10px;margin-left:6px}.label-cell{font-family:monospace;font-size:10px;line-height:1.4}.label-marker{color:#ffd28a}.label-varop{color:#8f8}.modal-backdrop{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#11151f;border:1px solid #2a3550;border-radius:8px;padding:24px;width:520px;max-width:92vw;max-height:90vh;overflow-y:auto;box-shadow:0 6px 32px #000c}.modal h2{margin:0 0 18px;color:#ffd28a;font-size:18px}.modal label{display:block;margin:12px 0;color:#8ac;font-size:12px}.modal label small{color:#579;font-size:10px;margin-left:4px}.modal-checkbox{display:flex;align-items:center;gap:8px;margin-bottom:14px;color:#cce0ff;font-size:13px;cursor:pointer}.modal-checkbox input[type=checkbox]{margin:0}.modal input[type=text],.modal textarea{display:block;width:100%;margin-top:6px;padding:8px 10px;background:#060810;border:1px solid #1f2530;border-radius:4px;color:#fff;font-family:inherit;font-size:14px;resize:vertical;line-height:1.5}.modal textarea{min-height:120px;font-family:Yu Gothic UI,Hiragino Sans,system-ui,monospace}.modal input:focus,.modal textarea:focus{outline:none;border-color:#48c}.modal-hint{margin-top:8px;padding:8px 10px;background:#060810;border-left:3px solid #4488cc;border-radius:3px;color:#8ac;font-size:11px}.modal-hint code{background:#1a2030;color:#ffd28a;padding:1px 5px;border-radius:2px;font-size:10px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.test-play{flex:1;display:flex;flex-direction:column;background:#000;min-height:0}.test-play-bar{padding:4px 12px;background:#11151f;border-bottom:1px solid #1f2530;font-size:11px;color:#6ac;font-family:monospace}.test-play-status{display:inline-block}.test-play iframe{flex:1;width:100%;border:0;background:#000;display:block;overflow:hidden}.log{height:200px;flex-shrink:0;overflow-y:auto;background:#060810;border-top:1px solid #1f2530;font-family:monospace;font-size:11px;color:#8ac;padding:8px 12px}.log-empty{color:#456;font-style:italic}.log-line{padding:2px 0;white-space:pre-wrap;word-break:break-word}
