@charset "UTF-8";:root{--primary: #6366f1;--primary-600: #4f46e5;--primary-700: #4338ca;--primary-soft: #eef2ff;--accent: #8b5cf6;--grad: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--grad-soft: linear-gradient(135deg, #eef2ff 0%, #f5f3ff 100%);--bg: #f6f7fb;--surface: #ffffff;--surface-2: #fbfbfd;--text: #0f172a;--muted: #64748b;--faint: #94a3b8;--border: #e8eaf0;--border-strong: #d7dae3;--success: #10b981;--success-soft: #ecfdf5;--danger: #ef4444;--danger-soft: #fef2f2;--warning: #f59e0b;--warning-soft: #fffbeb;--info: #3b82f6;--info-soft: #eff6ff;--r-sm: 8px;--r: 12px;--r-lg: 16px;--r-xl: 22px;--r-pill: 999px;--shadow-xs: 0 1px 2px rgba(15, 23, 42, .04);--shadow-sm: 0 1px 3px rgba(15, 23, 42, .06), 0 1px 2px rgba(15, 23, 42, .04);--shadow: 0 4px 12px rgba(15, 23, 42, .07), 0 2px 4px rgba(15, 23, 42, .04);--shadow-lg: 0 12px 32px rgba(15, 23, 42, .12), 0 4px 8px rgba(15, 23, 42, .05);--shadow-glow: 0 8px 24px rgba(99, 102, 241, .35);--t: .16s cubic-bezier(.4, 0, .2, 1);--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif}*{box-sizing:border-box}lucide-icon{display:inline-flex;align-items:center;line-height:0;flex:0 0 auto}html,body{height:100%}body{margin:0;font-family:var(--font);font-size:14px;line-height:1.55;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}h1,h2,h3,h4{margin:0;font-weight:700;letter-spacing:-.02em;color:var(--text)}h2{font-size:1.5rem}h3{font-size:1.05rem}p{margin:0}a{color:var(--primary-600);text-decoration:none}a:hover{text-decoration:underline}button{font:inherit}.btn,button.btn,.ok,.warn,.danger,.ghost,.primary{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.6rem 1rem;border:1px solid transparent;border-radius:var(--r-sm);font-weight:600;font-size:.875rem;cursor:pointer;white-space:nowrap;transition:transform var(--t),box-shadow var(--t),background var(--t),border-color var(--t)}.btn:active,.ok:active,.warn:active,.danger:active,.ghost:active,.primary:active{transform:translateY(1px)}.primary,.btn-primary{background:var(--grad);color:#fff;box-shadow:var(--shadow-sm)}.primary:hover,.btn-primary:hover{box-shadow:var(--shadow-glow)}.ok{background:var(--success);color:#fff}.ok:hover{filter:brightness(1.05);box-shadow:0 6px 16px #10b9814d}.warn{background:var(--primary);color:#fff}.warn:hover{background:var(--primary-600)}.danger{background:#fff;color:var(--danger);border-color:var(--border-strong)}.danger:hover{background:var(--danger-soft);border-color:var(--danger)}.ghost{background:var(--surface);color:var(--text);border-color:var(--border-strong)}.ghost:hover{background:var(--surface-2);border-color:var(--faint)}button:disabled,.btn:disabled{opacity:.55;cursor:not-allowed;transform:none!important;box-shadow:none}input,textarea,select{width:100%;padding:.62rem .8rem;font:inherit;color:var(--text);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-sm);transition:border-color var(--t),box-shadow var(--t)}input::placeholder,textarea::placeholder{color:var(--faint)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f12e}label{font-weight:600;font-size:.82rem;color:var(--muted)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--t),transform var(--t)}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.15rem .55rem;border-radius:var(--r-pill);font-size:.72rem;font-weight:700;letter-spacing:.01em;background:#eef0f5;color:var(--muted)}.err{color:var(--danger);background:var(--danger-soft);border:1px solid #fecaca;border-radius:var(--r-sm);padding:.6rem .8rem;font-size:.85rem;font-weight:500}.empty{color:var(--muted);text-align:center;padding:2.5rem 1rem;border:1.5px dashed var(--border-strong);border-radius:var(--r-lg);background:var(--surface-2)}.page-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.page-head .subtitle{color:var(--muted);font-size:.9rem;margin-top:.15rem}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.fade-in{animation:fadeInUp .35s var(--t) both}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#d2d6e0;border-radius:var(--r-pill);border:2px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:var(--faint)}
