:root{color:#1f2937;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f7fb;font-family:Arial,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}html,body,#app{min-height:100%;margin:0}body{background:#f5f7fb;min-height:100vh}button,input{font:inherit}button{color:#fff;cursor:pointer;background:#2563eb;border:0;border-radius:10px;padding:10px 14px;font-weight:600}button[disabled]{cursor:not-allowed;background:#b7c4df}#app{width:100%}.page{grid-template-rows:minmax(0,1fr) 280px;gap:16px;min-height:100vh;padding:20px;display:grid}.main-grid{grid-template-columns:360px minmax(0,1fr);gap:16px;min-height:0;display:grid}.panel{background:#fff;border:1px solid #d9dfeb;border-radius:14px;padding:16px;overflow:auto}h1,h2,p{margin:0}h1{margin-bottom:12px;font-size:24px}h2{margin-bottom:12px;font-size:16px}.help{color:#5b6473;margin-bottom:16px;font-size:13px}.upload-box{background:#fafcff;border:2px dashed #b9c4d8;border-radius:12px;padding:18px}.upload-box input[type=file]{width:100%;margin-bottom:12px}.upload-actions{align-items:center;gap:10px;display:flex}.upload-state{color:#475569;min-height:20px;font-size:13px;font-weight:700}.error-text{color:#b91c1c;min-height:20px;margin-top:10px;font-size:13px;font-weight:600}.deck-list{gap:10px;margin-bottom:16px;display:grid}.deck-row{border:1px solid #e2e8f0;border-radius:12px;padding:10px 12px}.deck-head{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px;display:flex}.deck-name{color:#0f172a;font-weight:700}.deck-message{color:#64748b;font-size:12px}.deck-actions{gap:8px;display:flex}.small-btn{padding:6px 10px;font-size:12px}.download-btn{background:#7c3aed}.progress-track{background:#edf2f7;border-radius:999px;height:10px;overflow:hidden}.progress-bar{background:linear-gradient(90deg,#2563eb,#22c55e);width:0;height:100%;transition:width .25s}.status-line{color:#4b5563;justify-content:space-between;gap:12px;margin-top:6px;font-size:12px;display:flex}.right-panel{flex-direction:column;display:flex}.preview-wrap{background:#fff;border:1px solid #d9dfeb;border-radius:12px;flex:1;min-height:280px;overflow:hidden}.preview-wrap iframe{border:0;width:100%;height:100%}.log-box{color:#dbeafe;white-space:pre-wrap;background:#0f172a;border-radius:10px;height:100%;padding:12px;font-family:Menlo,Monaco,Consolas,monospace;font-size:12px;line-height:1.5;overflow:auto}@media (width<=960px){.page{grid-template-rows:auto 280px}.main-grid{grid-template-columns:1fr}.preview-wrap{min-height:360px}}
