:root{--bg-1: #0b1020;--bg-2: #131a33;--surface: rgba(255, 255, 255, .06);--surface-strong: rgba(255, 255, 255, .1);--border: rgba(255, 255, 255, .12);--text: #e7ecff;--text-muted: #9aa4c7;--accent: #7c5cff;--accent-2: #22d3ee;--danger: #ff5d73;--success: #34d399;--radius: 14px;--shadow: 0 10px 30px rgba(0, 0, 0, .35);--gradient: linear-gradient(135deg, #7c5cff 0%, #22d3ee 100%)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--text);background:radial-gradient(1200px 600px at 10% -10%,rgba(124,92,255,.25),transparent 60%),radial-gradient(900px 500px at 110% 10%,rgba(34,211,238,.18),transparent 60%),linear-gradient(180deg,var(--bg-1),var(--bg-2));background-attachment:fixed;min-height:100vh;-webkit-font-smoothing:antialiased}.app-shell{max-width:100%;margin:0 auto;padding:32px 32px 80px}.header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:28px}.brand{display:flex;align-items:center;gap:12px}.brand-logo{width:42px;height:42px;border-radius:12px;background:var(--gradient);display:grid;place-items:center;font-weight:800;color:#0b1020;box-shadow:var(--shadow)}.brand-title{font-size:20px;font-weight:700;letter-spacing:.2px}.brand-sub{font-size:12px;color:var(--text-muted)}.stats{display:flex;gap:10px;flex-wrap:wrap}.nav{display:flex;gap:6px;padding:4px;border-radius:999px;background:var(--surface);border:1px solid var(--border)}.nav-link{padding:8px 14px;border-radius:999px;font-size:13px;font-weight:600;color:var(--text-muted);text-decoration:none;transition:color .12s ease,background .12s ease}.nav-link:hover{color:var(--text)}.nav-link.active{color:#0b1020;background:var(--gradient);box-shadow:0 6px 16px #7c5cff4d}.stat-pill{padding:8px 14px;border-radius:999px;background:var(--surface);border:1px solid var(--border);font-size:13px;color:var(--text-muted)}.stat-pill strong{color:var(--text);margin-right:4px}.form-page{max-width:640px;margin:0 auto}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:var(--shadow)}.card-header{padding:18px 20px;border-bottom:1px solid var(--border)}.card-title{margin:0;font-size:16px;font-weight:700}.card-sub{margin:4px 0 0;font-size:13px;color:var(--text-muted)}.card-body{padding:20px}.form{display:flex;flex-direction:column;gap:14px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px}.input,.textarea{width:100%;padding:11px 13px;border-radius:10px;border:1px solid var(--border);background:#00000040;color:var(--text);font-size:14px;transition:border-color .12s ease,box-shadow .12s ease}.input:focus,.textarea:focus{outline:none;border-color:#7c5cff99;box-shadow:0 0 0 3px #7c5cff2e}.textarea{min-height:84px;resize:vertical}.file{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;border:1px dashed var(--border);background:#0000002e}.file input{color:var(--text-muted);font-size:13px}.file-name{color:var(--text);font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:220px}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;cursor:pointer;padding:11px 16px;border-radius:10px;font-weight:600;font-size:14px;color:#0b1020;background:var(--gradient);transition:transform 80ms ease,opacity .12s ease,box-shadow .12s ease;box-shadow:0 6px 20px #7c5cff59;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border);box-shadow:none}.alert{margin-top:6px;padding:10px 12px;border-radius:10px;font-size:13px;background:#ff5d731f;color:var(--danger);border:1px solid rgba(255,93,115,.35)}.alert-success{background:#34d3991f;color:var(--success);border-color:#34d39959}.dashboard-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:18px}.dashboard-title{margin:0;font-size:18px;font-weight:700}.toolbar{display:flex;gap:8px;align-items:center}.search{padding:9px 12px;border-radius:10px;border:1px solid var(--border);background:#00000040;color:var(--text);font-size:13px;min-width:220px}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow-x:auto}.artist-table{width:100%;border-collapse:separate;border-spacing:0;table-layout:auto}.artist-table thead th{text-align:left;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted);padding:14px 18px;background:#ffffff0a;border-bottom:1px solid var(--border)}.artist-table tbody td{padding:16px 18px;border-bottom:1px solid var(--border);vertical-align:middle;font-size:14px;color:var(--text)}.artist-table tbody tr:last-child td{border-bottom:none}.artist-table tbody tr{transition:background .12s ease}.artist-table tbody tr:hover{background:#7c5cff0f}.cell-artist{display:flex;align-items:center;gap:12px}.avatar{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:var(--gradient);color:#0b1020;font-weight:800;flex-shrink:0}.avatar-sm{width:36px;height:36px;border-radius:10px;font-size:13px}.cell-name{font-weight:700;font-size:14px}.cell-id{font-size:11px;color:var(--text-muted);margin-top:2px}.role-pill{display:inline-block;padding:3px 10px;font-size:11px;color:var(--accent-2);background:#22d3ee1f;border:1px solid rgba(34,211,238,.35);border-radius:999px;letter-spacing:.3px;text-transform:capitalize}.cell-audio{width:22%;min-width:200px}.cell-date{color:var(--text-muted);font-size:12.5px;white-space:nowrap}.cell-analysis{width:22%;min-width:200px}.cell-dim{color:var(--text-muted);font-size:12.5px}.cell-error{color:var(--danger);font-size:11.5px}.genre-cell{display:flex;flex-direction:column;gap:6px;min-width:220px}.chip-group{display:flex;flex-wrap:wrap;gap:6px}.chip{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;padding:6px 12px;font-size:12px;font-weight:600;border-radius:999px;border:1px solid var(--border);background:#ffffff0a;color:var(--text-muted);transition:background .12s ease,color .12s ease,border-color .12s ease,transform 80ms ease}.chip:hover:not(:disabled){color:var(--text);border-color:#7c5cff73}.chip-active{color:#0b1020;background:var(--gradient);border-color:transparent;box-shadow:0 4px 14px #7c5cff4d}.chip-pending{opacity:.6}.chip:disabled{cursor:wait}.chip-group-sm .chip{padding:4px 10px;font-size:11.5px}.cell-desc{color:var(--text-muted);width:28%;min-width:220px;line-height:1.5;white-space:pre-wrap;overflow-wrap:anywhere;font-size:13px}.pill-row{display:flex;flex-wrap:wrap;gap:6px}.tag{display:inline-block;padding:3px 9px;font-size:11px;border-radius:999px;border:1px solid var(--border);background:#ffffff0a;color:var(--text);letter-spacing:.2px;text-transform:capitalize}.tag-voice{color:#c4b5fd;background:#7c5cff26;border-color:#7c5cff66}.tag-gender{color:#fca5d3;background:#f472b61f;border-color:#f472b659}.tag-pitch{color:var(--accent-2);background:#22d3ee1f;border-color:#22d3ee59}.tag-tone{color:#fde68a;background:#fbbf241a;border-color:#fbbf244d}.tag-dim{color:var(--text-muted)}.field-hint{color:var(--text-muted);font-size:11px;font-weight:500;text-transform:none;letter-spacing:normal}.field p.field-hint{margin:6px 0 0}audio{width:100%;height:34px;filter:invert(.92) hue-rotate(180deg);border-radius:8px}.empty{padding:48px 24px;text-align:center;color:var(--text-muted);border:1px dashed var(--border);border-radius:var(--radius);background:var(--surface)}.empty h3{margin:0 0 6px;color:var(--text)}.skeleton-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.skeleton{height:180px;border-radius:var(--radius);background:linear-gradient(90deg,#ffffff0a,#ffffff1a,#ffffff0a);background-size:200% 100%;animation:shimmer 1.4s infinite linear;border:1px solid var(--border)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}
