*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0c0c10;--surface: #13131a;--surface2: #1a1a24;--border: rgba(255,255,255,.07);--text: #e8e8f0;--muted: #6b6b80;--radius: 14px;--radius-sm: 8px;--shadow: 0 4px 24px rgba(0,0,0,.4)}html,body,#root{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}.root-shell{display:flex;flex-direction:column;min-height:100vh}.launcher-header{display:flex;align-items:center;justify-content:space-between;padding:0 32px;border-bottom:1px solid #e4e9ef;background:#fff;position:sticky;top:0;z-index:10;height:60px}.header-logo{display:flex;align-items:center;gap:16px}.header-logo-img{height:26px;width:auto;display:block}.header-divider{width:1px;height:20px;background:#d6e0ea}.header-title{font-size:15px;font-weight:600;letter-spacing:-.2px;color:#1a2b3c}.header-count{font-size:12px;color:#6b7b8d;background:#f2f4f7;padding:4px 12px;border-radius:20px;border:1px solid #e4e9ef;font-weight:500}.launcher-main{flex:1;padding:36px 32px;max-width:1200px;width:100%;margin:0 auto}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px;display:flex;flex-direction:column;gap:14px;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;cursor:default}.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:#ffffff21}.card--launching{opacity:.7;pointer-events:none}.card-top{display:flex;align-items:center;justify-content:space-between}.card-badge{font-size:11px;font-weight:600;font-family:Courier New,monospace;padding:3px 8px;border-radius:6px;letter-spacing:.5px}.card-body{flex:1}.card-title{font-size:15px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px;letter-spacing:-.2px}.card-filename{font-size:12px;color:var(--muted);font-family:Courier New,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:9px 16px;border:none;border-radius:var(--radius-sm);background:var(--accent, #6366f1);color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .15s ease,transform .1s ease;letter-spacing:.2px}.card-btn:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.card-btn:active:not(:disabled){transform:translateY(0)}.card-btn:disabled{cursor:not-allowed;opacity:.5}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:12px;text-align:center;color:var(--muted)}.empty-icon{font-size:52px;margin-bottom:8px}.empty-state h2{font-size:20px;color:var(--text);font-weight:600}.empty-state p{font-size:14px;line-height:1.6}.empty-state code{font-family:Courier New,monospace;background:var(--surface2);border:1px solid var(--border);padding:2px 6px;border-radius:4px;font-size:13px;color:#a5b4fc}.global-error{display:flex;align-items:center;gap:12px;background:#ef44441f;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-sm);margin:16px 32px 0;padding:12px 16px;font-size:13px;color:#fca5a5}.global-error strong{font-weight:600;color:#f87171;white-space:nowrap}.global-error span{flex:1}.global-error button{background:none;border:none;color:var(--muted);cursor:pointer;font-size:16px;padding:2px 6px;border-radius:4px;transition:color .1s}.global-error button:hover{color:var(--text)}.frame-shell{display:flex;flex-direction:column;height:100vh;overflow:hidden}.frame-bar{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:52px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.back-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:6px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s ease,border-color .15s ease;width:80px}.back-btn:hover{background:var(--surface2);border-color:#ffffff26}.frame-bar-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text)}.frame-bar-icon{font-size:16px}.frame-bar-file{font-family:Courier New,monospace;font-size:12px;color:var(--muted);font-weight:400}.frame-content{flex:1;overflow:auto;background:#fff}.frame-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:12px;text-align:center;padding:40px;color:#444}.frame-error-icon{font-size:48px}.frame-error h2{font-size:20px;font-weight:600;color:#222}.frame-error pre{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:8px;padding:12px 20px;font-size:13px;color:#ef4444;max-width:600px;word-break:break-word;white-space:pre-wrap}.frame-error p{font-size:13px;color:#6b7280}
