*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --primary:#8B5CF6;--primary-dim:rgba(139,92,246,.12);
  --secondary:#A78BFA;--accent:#34D399;--accent-dim:rgba(52,211,153,.12);
  --bg:#0F0A1A;--surface:#1A1128;--surface2:#231838;
  --border:rgba(139,92,246,.1);--text:#F5F3FF;--text-dim:#C4B5FD;
  --radius:12px;--font:'Inter',system-ui,sans-serif;--mono:'Fira Code',monospace;
  --transition:250ms ease;
}
html{font-size:16px;scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--font);line-height:1.6;min-height:100vh}
.header{position:sticky;top:0;z-index:100;backdrop-filter:blur(16px);background:rgba(15,10,26,.8);border-bottom:1px solid var(--border)}
.header-inner{max-width:900px;margin:0 auto;padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}
.logo{display:flex;align-items:center;gap:.5rem}
.logo-icon{font-size:1.25rem}
.logo h1{font-size:1.1rem;font-weight:700;background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.header-right{display:flex;gap:.5rem;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:.3rem;padding:.45rem .85rem;border:none;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all var(--transition);font-family:var(--font)}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff}
.btn-primary:hover{filter:brightness(1.15);transform:translateY(-1px)}
.btn-sm{background:var(--surface2);color:var(--text-dim);border:1px solid var(--border)}
.btn-sm:hover{border-color:var(--primary);color:var(--primary)}
.main{max-width:900px;margin:0 auto;padding:1.5rem}
.glass-card{background:rgba(26,17,40,.6);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:1.25rem}
.section-title{font-size:.9rem;font-weight:700;margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}
.section-title::before{content:'';width:4px;height:18px;background:linear-gradient(to bottom,var(--primary),var(--secondary));border-radius:2px}
.msg-block{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:.75rem;margin-bottom:.5rem}
.msg-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}
.msg-role{display:flex;align-items:center;gap:.4rem}
.msg-role select{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:.25rem .5rem;color:var(--accent);font-family:var(--font);font-size:.75rem;font-weight:600;outline:none}
.msg-del{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:.8rem}
.msg-textarea{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.5rem;color:var(--text);font-family:var(--mono);font-size:.8rem;outline:none;resize:vertical;min-height:60px}
.msg-textarea:focus{border-color:var(--primary)}
.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.25rem}
.stat-card{background:rgba(26,17,40,.6);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;text-align:center}
.stat-val{font-size:1.5rem;font-weight:700;color:var(--primary)}
.stat-label{font-size:.65rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.var-field{display:flex;gap:.5rem;margin-bottom:.4rem;align-items:center}
.var-field label{font-size:.75rem;color:var(--accent);font-weight:600;min-width:80px}
.var-field input{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.4rem;color:var(--text);font-size:.8rem;outline:none}
.saved-item{display:flex;justify-content:space-between;align-items:center;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:.5rem .75rem;margin-bottom:.3rem;cursor:pointer;transition:border-color var(--transition)}
.saved-item:hover{border-color:var(--primary)}
.saved-item .si-name{font-size:.8rem;font-weight:600}
.saved-item .si-date{font-size:.65rem;color:var(--text-dim)}
.saved-item button{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:.75rem}
.tpl-item{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:.6rem .75rem;margin-bottom:.4rem;cursor:pointer;transition:border-color var(--transition)}
.tpl-item:hover{border-color:var(--accent)}
.tpl-item .ti-name{font-size:.8rem;font-weight:700;color:var(--accent)}
.tpl-item .ti-desc{font-size:.7rem;color:var(--text-dim)}
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:200;align-items:center;justify-content:center;padding:1rem}
.modal-overlay.show{display:flex}
.modal{max-width:500px;width:100%;max-height:80vh;overflow-y:auto}
.modal-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:.75rem}
.toast{position:fixed;bottom:2rem;left:50%;transform:translateX(-50%) translateY(100px);background:var(--surface2);color:var(--text);padding:.6rem 1.25rem;border-radius:var(--radius);font-size:.8rem;font-weight:500;border:1px solid var(--primary);box-shadow:0 8px 32px rgba(0,0,0,.4);transition:transform 300ms ease;z-index:9999;pointer-events:none}
.toast.show{transform:translateX(-50%) translateY(0)}
@media(max-width:600px){.stats-row{grid-template-columns:1fr}.main{padding:1rem}}
