:root{
  --bg:#0b0f14; --card:#101722; --line:#1f2a34; --text:#e6edf3; --muted:#9fb4c7;
  --brand:#7dd3fc; --accent:#a78bfa;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;background:var(--bg);color:var(--text);font:16px/1.45 system-ui,Segoe UI,Roboto,Arial,sans-serif}
header{padding:16px 20px;border-bottom:1px solid var(--line)}
.title{display:flex;align-items:center;gap:12px}
.title .logo{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--brand),var(--accent));display:grid;place-items:center;color:#0b0f14;font-weight:700}
.sub{color:var(--muted);margin:.25rem 0 0}
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.tab{padding:8px 12px;border:1px solid var(--line);border-radius:10px;color:var(--text);text-decoration:none}
.tab.active,.tab:hover{border-color:var(--brand);box-shadow:0 0 0 1px color-mix(in srgb,var(--brand),transparent 60%) inset}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.chip{padding:6px 10px;border:1px dashed var(--line);border-radius:999px;color:var(--muted);font-size:.9rem}
main{padding:14px}
.panel{max-width:1100px;margin:0 auto}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px;position:relative}
.badge{position:absolute;top:10px;right:10px;background:var(--accent);color:#0b0f14;font-weight:700;font-size:.75rem;padding:2px 8px;border-radius:999px}
.row{display:flex;gap:8px;flex-wrap:wrap}
input[type="file"],input[type="text"],input[type="number"],select,textarea,button{background:#0d1420;border:1px solid var(--line);border-radius:10px;color:var(--text);padding:8px;min-height:38px}
textarea{min-height:130px;width:100%}
/* Primary buttons */
button{cursor:pointer;background:var(--brand);color:#0b0f14;border:none;border-radius:10px;padding:10px 16px;font-weight:600;transition:background .2s,transform .1s}
button:hover{background:var(--accent);transform:translateY(-2px)}
button:active{transform:translateY(0)}
/* Secondary buttons */
button.secondary{background:#1f2a34;color:var(--text);border:1px solid var(--line);opacity:1}
button.secondary:hover{background:#293645}
.drop{border:2px dashed var(--line);border-radius:12px;padding:16px;text-align:center}
.drop.drag{border-color:var(--brand);background:#0c1624}
.preview{background:#0c1320;border:1px solid var(--line);border-radius:10px;padding:12px;max-height:280px;overflow:auto}
.preview.hidden{display:none}
.log{margin-top:10px;background:#0c1320;border:1px solid var(--line);border-radius:10px;padding:10px;white-space:pre-wrap;max-height:180px;overflow:auto;font-family:ui-monospace,Consolas,monospace}
footer{border-top:1px solid var(--line);padding:18px 20px;color:var(--muted)}
.footer-nav a{color:var(--muted);text-decoration:none}
.small{font-size:.9rem;color:var(--muted)}

/* Progress bar */
.progress{width:100%;height:10px;border-radius:999px;background:#0c1320;border:1px solid var(--line);overflow:hidden;margin-top:8px}
.progress>.bar{height:100%;width:0%;background:linear-gradient(90deg,var(--brand),var(--accent));transition:width .15s linear}
.progress-label{margin-top:6px;color:var(--muted);font-size:.9rem}