/* ── Reset ───────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-font-smoothing:antialiased}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;background:transparent;color:var(--text-1);line-height:1.6;transition:color .2s}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font:inherit}
img{max-width:100%;display:block}
input,select,textarea{font:inherit}

/* ── Theme Variables ─────────────────────────────────────────────────── */
:root {
  /* Layout */
  --sidebar-w: 220px;
  --topbar-h: 56px;

  /* Sidebar — matches ScoutRadar navbar dark */
  --sidebar-bg: #1a1a2e;
  --sidebar-hover: #1E293B;
  --sidebar-active: #1E293B;
  --sidebar-text: #94A3B8;
  --sidebar-text-active: #F1F5F9;
  --sidebar-accent: #2563eb;

  /* Primary — ScoutRadar blue */
  --color-primary: #2563eb;
  --color-primary-hover: #1d4ed8;
  --primary: #2563eb;
  --primary-h: #1d4ed8;

  /* Backgrounds — glass on animated gradient */
  --bg: transparent;
  --bg-card: rgba(255,255,255,0.65);
  --bg-card-header: rgba(255,255,255,0.4);
  --bg-input: rgba(255,255,255,0.7);
  --surface: rgba(255,255,255,0.65);
  --surface-2: rgba(255,255,255,0.4);
  --bg-table-header: rgba(248,250,252,0.6);

  /* Glass */
  --glass-blur: blur(16px);
  --glass-border: 1px solid rgba(255,255,255,0.4);

  /* Borders */
  --border: rgba(203,213,225,0.7);
  --border-2: #CBD5E1;
  --border-color: rgba(203,213,225,0.7);

  /* Text */
  --text-1: #1a1a2e;
  --text-2: #475569;
  --text-3: #94A3B8;
  --text-primary: #1a1a2e;
  --text-secondary: #475569;
  --text-muted: #94A3B8;
  --text-link: var(--color-primary);

  /* Status */
  --success: #10B981;
  --success-bg: #ECFDF5;
  --success-text: #065F46;
  --warning: #F59E0B;
  --warning-bg: #FFFBEB;
  --danger: #EF4444;
  --danger-bg: #FEF2F2;
  --info: #3B82F6;
  --info-bg: #EFF6FF;
  --purple: #8B5CF6;
  --purple-bg: #F5F3FF;

  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --shadow: 0 4px 16px rgba(0,0,0,.08);
  --shadow-card: 0 4px 30px rgba(0,0,0,.08);
  --shadow-lg: 0 8px 32px rgba(0,0,0,.12);

  /* Misc */
  --radius: 8px;
  --radius-lg: 12px;
  --transition: 150ms ease;
  --navbar-bg: #1a1a2e;
}

[data-theme="dark"] {
  --color-primary: #3b82f6;
  --color-primary-hover: #2563eb;
  --primary: #3b82f6;
  --primary-h: #2563eb;

  --bg: transparent;
  --bg-card: rgba(31,41,55,0.55);
  --bg-card-header: rgba(31,41,55,0.4);
  --bg-input: rgba(55,65,81,0.6);
  --surface: rgba(31,41,55,0.55);
  --surface-2: rgba(31,41,55,0.4);
  --bg-table-header: rgba(30,40,55,0.6);

  --glass-border: 1px solid rgba(255,255,255,0.08);

  --border: rgba(255,255,255,0.08);
  --border-2: #4b5563;
  --border-color: #4b5563;

  --text-1: #e5e7eb;
  --text-2: #9ca3af;
  --text-3: #6b7280;
  --text-primary: #e5e7eb;
  --text-secondary: #9ca3af;
  --text-muted: #6b7280;

  --shadow-card: 0 4px 30px rgba(0,0,0,.3);
  --shadow-lg: 0 8px 32px rgba(0,0,0,.4);

  --sidebar-bg: #0f172a;
  --sidebar-accent: #3b82f6;

  --success-bg: #064e3b;
  --success-text: #6ee7b7;
  --warning-bg: #1c1400;
  --danger-bg: #450a0a;
  --info-bg: #1e3a5f;
  --purple-bg: #2e1065;
}

/* ── Animated Background (matches ScoutRadar exactly) ────────────────── */
#glass-bg {
  position: fixed;
  inset: 0;
  z-index: -1;
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--color-primary) 12%, white) 0%,
    color-mix(in srgb, var(--color-primary) 5%, #f5f7fa) 25%,
    color-mix(in srgb, var(--color-primary) 20%, white) 50%,
    color-mix(in srgb, var(--color-primary) 10%, #d0e1f0) 75%,
    color-mix(in srgb, var(--color-primary) 8%, #fef1f6) 100%);
  background-size: 400% 400%;
  animation: glass-bg-shift 20s ease infinite;
}
[data-theme="dark"] #glass-bg {
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--color-primary) 12%, #0f172a) 0%,
    color-mix(in srgb, var(--color-primary) 8%, #1a1025) 25%,
    color-mix(in srgb, var(--color-primary) 18%, #0f172a) 50%,
    color-mix(in srgb, var(--color-primary) 8%, #1a1025) 75%,
    color-mix(in srgb, var(--color-primary) 6%, #150a20) 100%);
  background-size: 400% 400%;
}
@keyframes glass-bg-shift {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* ── Layout ──────────────────────────────────────────────────────────── */
.app-shell{display:flex;min-height:100vh}

/* Sidebar */
.sidebar {
  width: var(--sidebar-w);
  background: var(--sidebar-bg);
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 0; left: 0; bottom: 0;
  z-index: 200;
  transition: transform var(--transition);
  overflow-y: auto;
  overflow-x: hidden;
}
.sidebar::-webkit-scrollbar{width:4px}
.sidebar::-webkit-scrollbar-track{background:transparent}
.sidebar::-webkit-scrollbar-thumb{background:#334155;border-radius:2px}

.sidebar-brand {
  display: flex; align-items: center; gap: 10px;
  padding: 18px 20px 16px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
  flex-shrink: 0;
}
.sidebar-brand-icon{width:28px;height:28px;background:var(--sidebar-accent);border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sidebar-brand-icon svg{width:16px;height:16px;fill:white}
.sidebar-brand-name{color:#F1F5F9;font-weight:700;font-size:15px;line-height:1.2}
.sidebar-brand-sub{color:var(--sidebar-text);font-size:11px;letter-spacing:.3px}

.sidebar-nav{padding:12px 0;flex:1}

.nav-section-label{
  color:#475569;font-size:10.5px;font-weight:600;letter-spacing:.8px;
  text-transform:uppercase;padding:12px 20px 4px;margin-top:4px;
}

.nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 20px; margin: 1px 8px; border-radius: 7px;
  color: var(--sidebar-text); font-size: 14px; font-weight: 500;
  transition: background var(--transition), color var(--transition);
  white-space: nowrap; overflow: hidden;
}
.nav-item:hover{background:var(--sidebar-hover);color:var(--sidebar-text-active)}
.nav-item.active{background:var(--sidebar-active);color:#FFF;border-left:3px solid var(--sidebar-accent);padding-left:17px}
.nav-item svg{width:16px;height:16px;flex-shrink:0;opacity:.8}
.nav-item.active svg{opacity:1}

.sidebar-footer{
  padding: 16px 20px;
  border-top: 1px solid rgba(255,255,255,0.07);
  flex-shrink: 0;
}
.sidebar-footer-user{font-size:12px;color:var(--sidebar-text);margin-bottom:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sidebar-footer-user strong{display:block;color:#CBD5E1;font-size:13px}

/* Theme toggle inside sidebar footer */
.theme-toggle {
  background: none;
  border: none;
  color: var(--sidebar-text);
  cursor: pointer;
  font-size: 1rem;
  padding: 0.2rem;
  line-height: 1;
  transition: color 0.15s;
  margin-bottom: 6px;
}
.theme-toggle:hover { color: #fff; }

.btn-logout{
  display:flex;align-items:center;gap:6px;width:100%;
  padding:7px 10px;border-radius:6px;border:none;
  background:rgba(255,255,255,0.05);color:var(--sidebar-text);font-size:13px;
  transition:background var(--transition),color var(--transition);
}
.btn-logout:hover{background:rgba(255,255,255,0.1);color:#F1F5F9}
.btn-logout svg{width:14px;height:14px}

/* Main wrapper */
.main-wrapper{
  margin-left: var(--sidebar-w);
  flex: 1; display: flex; flex-direction: column; min-width: 0;
}

/* Topbar — glass matching cards */
.topbar {
  height: var(--topbar-h);
  background: rgba(255,255,255,0.7);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: var(--glass-border);
  display: flex; align-items: center; gap: 16px;
  padding: 0 24px;
  position: sticky; top: 0; z-index: 100;
  transition: background .2s;
}
[data-theme="dark"] .topbar {
  background: rgba(15,23,42,0.75);
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
.topbar-title{font-size:17px;font-weight:700;color:var(--text-1);flex:1}
[data-theme="dark"] .topbar-title{color:#e5e7eb}
.topbar-actions{display:flex;align-items:center;gap:8px}

.page-content{padding:24px;flex:1}

/* ── Cards — glass matching ScoutRadar ───────────────────────────────── */
.card{
  background: var(--bg-card);
  border: var(--glass-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
}
.card-header{
  padding: 16px 20px;
  border-bottom: var(--glass-border);
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  background: var(--bg-card-header);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.card-title{font-size:15px;font-weight:600;color:var(--text-1)}
.card-body{padding:20px}
.card-footer{
  padding: 12px 20px;
  border-top: var(--glass-border);
  background: var(--bg-card-header);
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
}

/* ── Stat Cards ──────────────────────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}
.stat-card{
  background: var(--bg-card);
  border: var(--glass-border);
  border-radius: var(--radius-lg);
  padding: 20px; position: relative; overflow: hidden;
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  box-shadow: var(--shadow-card);
}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--stat-color,var(--primary))}
.stat-label{font-size:12px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.stat-value{font-size:28px;font-weight:700;color:var(--text-1);line-height:1}
.stat-sub{font-size:13px;color:var(--text-2);margin-top:6px}
.stat-card.green{--stat-color:var(--success)}
.stat-card.amber{--stat-color:var(--warning)}
.stat-card.blue{--stat-color:var(--info)}
.stat-card.purple{--stat-color:var(--purple)}
.stat-card.red{--stat-color:var(--danger)}

/* ── Buttons ─────────────────────────────────────────────────────────── */
.btn{
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px; border-radius: 7px; border: none;
  font-size: 14px; font-weight: 500;
  transition: background var(--transition), box-shadow var(--transition), opacity var(--transition);
  white-space: nowrap;
}
.btn svg{width:15px;height:15px}
.btn:disabled{opacity:.55;cursor:not-allowed}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover:not(:disabled){background:var(--primary-h)}
.btn-secondary{background:rgba(255,255,255,0.65);color:var(--text-2);border:var(--glass-border)}
.btn-secondary:hover:not(:disabled){background:rgba(255,255,255,0.85)}
[data-theme="dark"] .btn-secondary{background:rgba(55,65,81,0.6);color:#e5e7eb;border:1px solid rgba(255,255,255,0.1)}
[data-theme="dark"] .btn-secondary:hover:not(:disabled){background:rgba(75,85,99,0.7)}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover:not(:disabled){background:#DC2626}
.btn-success{background:var(--success);color:#fff}
.btn-success:hover:not(:disabled){background:#059669}
.btn-sm{padding:5px 12px;font-size:13px}
.btn-sm svg{width:13px;height:13px}
.btn-xs{padding:3px 9px;font-size:12px;border-radius:5px}
.btn-icon{padding:7px;border-radius:7px;background:transparent;border:var(--glass-border);color:var(--text-2)}
.btn-icon:hover{background:var(--surface-2)}
.btn-icon svg{width:15px;height:15px}

/* ── Badges ──────────────────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}
.badge::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}
.badge-active,.badge-completed{background:var(--success-bg);color:#065F46}
[data-theme="dark"] .badge-active,[data-theme="dark"] .badge-completed{color:#6ee7b7}
.badge-draft{background:rgba(241,245,249,0.7);color:#475569}
[data-theme="dark"] .badge-draft{background:rgba(30,41,59,0.7);color:#94a3b8}
.badge-paused,.badge-queued_concurrent_limit{background:var(--warning-bg);color:#92400E}
[data-theme="dark"] .badge-paused,[data-theme="dark"] .badge-queued_concurrent_limit{color:#fcd34d}
.badge-archived,.badge-cancelled{background:rgba(241,245,249,0.7);color:#64748B}
[data-theme="dark"] .badge-archived,[data-theme="dark"] .badge-cancelled{background:rgba(30,41,59,0.7);color:#94a3b8}
.badge-failed{background:var(--danger-bg);color:#991B1B}
[data-theme="dark"] .badge-failed{color:#fca5a5}
.badge-no_answer{background:rgba(241,245,249,0.7);color:#64748B}
.badge-voicemail{background:var(--purple-bg);color:#5B21B6}
[data-theme="dark"] .badge-voicemail{color:#c4b5fd}
.badge-queued,.badge-dialing{background:var(--info-bg);color:#1E40AF}
[data-theme="dark"] .badge-queued,[data-theme="dark"] .badge-dialing{color:#93c5fd}
.badge-in_progress{background:var(--info-bg);color:#1D4ED8}
[data-theme="dark"] .badge-in_progress{color:#60a5fa}
.badge-dnc_blocked{background:var(--danger-bg);color:#991B1B}
.badge-trial{background:rgba(254,243,199,0.8);color:#92400E}
.badge-suspended{background:var(--danger-bg);color:#991B1B}
.badge-positive,.badge-interested{background:var(--success-bg);color:#065F46}
[data-theme="dark"] .badge-positive,[data-theme="dark"] .badge-interested{color:#6ee7b7}
.badge-negative,.badge-not_interested{background:var(--danger-bg);color:#991B1B}
[data-theme="dark"] .badge-negative,[data-theme="dark"] .badge-not_interested{color:#fca5a5}
.badge-neutral,.badge-unknown{background:rgba(241,245,249,0.7);color:#475569}
[data-theme="dark"] .badge-neutral,[data-theme="dark"] .badge-unknown{background:rgba(30,41,59,0.7);color:#94a3b8}
.badge-callback_requested,.badge-follow_up_needed{background:var(--info-bg);color:#1E40AF}

/* ── Tables ──────────────────────────────────────────────────────────── */
.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:var(--glass-border)}
table{width:100%;border-collapse:collapse;font-size:14px}
thead{background:var(--bg-table-header)}
th{padding:11px 16px;text-align:left;font-size:12px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;border-bottom:var(--glass-border)}
td{padding:13px 16px;border-bottom:var(--glass-border);color:var(--text-2);vertical-align:middle}
tr:last-child td{border-bottom:none}
tbody tr:hover{background:rgba(255,255,255,0.3)}
[data-theme="dark"] tbody tr:hover{background:rgba(255,255,255,0.05)}
tbody tr.clickable{cursor:pointer}
.td-name{color:var(--text-1);font-weight:500}
.td-mono{font-family:ui-monospace,monospace;font-size:13px}
.td-muted{color:var(--text-3);font-size:13px}

/* ── Forms ───────────────────────────────────────────────────────────── */
.form-group{margin-bottom:16px}
.form-group:last-child{margin-bottom:0}
.form-label{display:block;font-size:13px;font-weight:600;color:var(--text-2);margin-bottom:5px}
.form-label .req{color:var(--danger);margin-left:2px}
.form-control{
  width:100%;padding:9px 12px;border-radius:7px;
  border:1px solid var(--border-2);
  background:var(--bg-input);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color:var(--text-1);font-size:14px;
  transition:border-color var(--transition),box-shadow var(--transition);
  outline:none;
}
.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.form-control::placeholder{color:var(--text-3)}
textarea.form-control{resize:vertical;min-height:100px}
select.form-control{cursor:pointer}
.form-hint{font-size:12px;color:var(--text-3);margin-top:4px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-error{font-size:12px;color:var(--danger);margin-top:4px}
.form-check{display:flex;align-items:center;gap:8px;cursor:pointer}
.form-check input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}
.form-check-label{font-size:14px;color:var(--text-2)}

/* ── Modal ───────────────────────────────────────────────────────────── */
.modal-backdrop{
  position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:400;
  display:flex;align-items:center;justify-content:center;padding:16px;
  opacity:0;pointer-events:none;transition:opacity var(--transition);
}
.modal-backdrop.open{opacity:1;pointer-events:all}
.modal{
  background:var(--bg-card);
  backdrop-filter:var(--glass-blur);
  -webkit-backdrop-filter:var(--glass-blur);
  border:var(--glass-border);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  width:100%;max-width:560px;
  transform:scale(.96);transition:transform var(--transition);
  max-height:90vh;overflow-y:auto;
}
.modal-backdrop.open .modal{transform:scale(1)}
.modal-header{
  padding:20px 24px 16px;
  border-bottom:var(--glass-border);
  display:flex;align-items:center;justify-content:space-between;
  background:var(--bg-card-header);
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;
}
.modal-title{font-size:16px;font-weight:700;color:var(--text-1)}
.modal-close{background:none;border:none;color:var(--text-3);padding:4px;border-radius:5px;display:flex}
.modal-close:hover{background:rgba(0,0,0,.06);color:var(--text-1)}
.modal-close svg{width:18px;height:18px}
.modal-body{padding:20px 24px}
.modal-footer{
  padding:16px 24px;
  border-top:var(--glass-border);
  display:flex;justify-content:flex-end;gap:8px;
  background:var(--bg-card-header);
  border-radius:0 0 var(--radius-lg) var(--radius-lg);
}

/* ── Tabs ────────────────────────────────────────────────────────────── */
.tabs{display:flex;gap:2px;border-bottom:var(--glass-border);margin-bottom:20px}
.tab{
  padding:10px 16px;font-size:14px;font-weight:500;color:var(--text-2);
  border:none;background:none;border-bottom:2px solid transparent;
  margin-bottom:-1px;transition:color var(--transition),border-color var(--transition);cursor:pointer;
}
.tab:hover{color:var(--text-1)}
.tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}

/* ── Toasts ──────────────────────────────────────────────────────────── */
#toast-container{position:fixed;bottom:20px;right:20px;z-index:600;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{
  display:flex;align-items:center;gap:10px;
  padding:12px 16px;border-radius:var(--radius);
  background:rgba(26,26,46,0.92);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,0.1);
  color:#F8FAFC;
  font-size:14px;box-shadow:var(--shadow-lg);
  pointer-events:all;min-width:280px;max-width:380px;
  opacity:0;transform:translateX(20px);
  transition:opacity .2s ease,transform .2s ease;
}
.toast.show{opacity:1;transform:translateX(0)}
.toast-success{background:rgba(6,78,59,0.92)}
.toast-error{background:rgba(127,29,29,0.92)}
.toast-warning{background:rgba(120,53,15,0.92)}
.toast svg{width:16px;height:16px;flex-shrink:0}

/* ── Empty State ─────────────────────────────────────────────────────── */
.empty-state{text-align:center;padding:48px 24px;color:var(--text-3)}
.empty-state-icon{width:48px;height:48px;margin:0 auto 16px;opacity:.4}
.empty-state-icon svg{width:48px;height:48px}
.empty-state h3{font-size:16px;font-weight:600;color:var(--text-2);margin-bottom:6px}
.empty-state p{font-size:14px;line-height:1.5}

/* ── Loading ─────────────────────────────────────────────────────────── */
.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}
.skeleton{
  background:linear-gradient(90deg,var(--border) 25%,rgba(255,255,255,0.3) 50%,var(--border) 75%);
  background-size:200%;animation:shimmer 1.2s infinite;border-radius:4px;
}
@keyframes shimmer{0%{background-position:200%}100%{background-position:-200%}}
.loading-row td{padding:20px 16px}

/* ── Progress Bar ────────────────────────────────────────────────────── */
.progress{height:8px;background:var(--border);border-radius:4px;overflow:hidden;margin-top:8px}
.progress-bar{height:100%;border-radius:4px;transition:width .3s ease;background:var(--primary)}
.progress-bar.warning{background:var(--warning)}
.progress-bar.danger{background:var(--danger)}

/* ── Filters Bar ─────────────────────────────────────────────────────── */
.filters-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.filters-bar .form-control{width:auto}
.filters-bar .search-wrap{position:relative;flex:1;min-width:200px;max-width:320px}
.filters-bar .search-wrap svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--text-3);pointer-events:none}
.filters-bar .search-input{padding-left:32px}

/* ── Pagination ──────────────────────────────────────────────────────── */
.pagination{display:flex;align-items:center;gap:6px;margin-top:16px;justify-content:center}
.page-btn{
  padding:6px 12px;border-radius:6px;
  border:var(--glass-border);
  background:var(--bg-card);
  backdrop-filter:blur(8px);
  color:var(--text-2);font-size:13px;
  transition:background var(--transition);
}
.page-btn:hover:not(:disabled){background:rgba(255,255,255,0.85)}
[data-theme="dark"] .page-btn:hover:not(:disabled){background:rgba(55,65,81,0.7)}
.page-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.page-btn:disabled{opacity:.4;cursor:not-allowed}
.page-info{font-size:13px;color:var(--text-3);padding:0 8px}

/* ── Usage Bar ───────────────────────────────────────────────────────── */
.usage-block{
  background:var(--bg-card);
  border:var(--glass-border);
  border-radius:var(--radius-lg);
  padding:20px;margin-bottom:24px;
  backdrop-filter:var(--glass-blur);
  -webkit-backdrop-filter:var(--glass-blur);
}
.usage-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.usage-title{font-size:14px;font-weight:600;color:var(--text-2)}
.usage-nums{font-size:14px;color:var(--text-2)}
.usage-nums strong{color:var(--text-1)}

/* ── Transcript ──────────────────────────────────────────────────────── */
.transcript-wrap{font-size:14px;line-height:1.7;max-height:400px;overflow-y:auto;padding:4px}
.transcript-wrap::-webkit-scrollbar{width:4px}
.transcript-wrap::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:2px}
.transcript-turn{margin-bottom:12px;padding:10px 14px;border-radius:8px}
.transcript-turn.agent{background:var(--info-bg)}
.transcript-turn.user{background:rgba(255,255,255,0.3)}
[data-theme="dark"] .transcript-turn.user{background:rgba(31,41,55,0.5)}
.transcript-speaker{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.transcript-turn.agent .transcript-speaker{color:var(--info)}
.transcript-turn.user .transcript-speaker{color:var(--text-3)}
.transcript-plain{white-space:pre-wrap;color:var(--text-2);background:rgba(255,255,255,0.3);padding:14px;border-radius:8px}
[data-theme="dark"] .transcript-plain{background:rgba(31,41,55,0.5)}

/* ── Detail Page ─────────────────────────────────────────────────────── */
.detail-grid{display:grid;grid-template-columns:1fr 340px;gap:20px;align-items:start}
.detail-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:var(--glass-border);font-size:14px}
.detail-row:last-child{border-bottom:none}
.detail-key{color:var(--text-3);font-weight:500}
.detail-val{color:var(--text-1);font-weight:500;text-align:right}
.back-link{display:inline-flex;align-items:center;gap:6px;font-size:14px;color:var(--text-2);margin-bottom:16px}
.back-link:hover{color:var(--text-1)}
.back-link svg{width:14px;height:14px}

/* ── Sentiment ───────────────────────────────────────────────────────── */
.sentiment-bar{display:flex;gap:6px;align-items:center}
.sentiment-dot{width:10px;height:10px;border-radius:50%}

/* ── Chart Wrappers ──────────────────────────────────────────────────── */
.chart-wrap{position:relative;height:240px}
.chart-wrap canvas{max-height:240px}

/* ── Token / Code Blocks ─────────────────────────────────────────────── */
.token-block{
  display:flex;align-items:center;gap:8px;
  background:rgba(255,255,255,0.3);
  border:var(--glass-border);
  border-radius:7px;padding:10px 14px;
  backdrop-filter:blur(8px);
}
[data-theme="dark"] .token-block{background:rgba(31,41,55,0.5)}
.token-text{font-family:ui-monospace,monospace;font-size:13px;color:var(--text-1);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.copy-btn{background:none;border:none;color:var(--text-3);padding:4px;border-radius:4px;display:flex;flex-shrink:0}
.copy-btn:hover{color:var(--primary);background:rgba(0,0,0,.05)}
.copy-btn svg{width:14px;height:14px}

/* ── Alert Banners ───────────────────────────────────────────────────── */
.alert{padding:12px 16px;border-radius:var(--radius);font-size:14px;display:flex;align-items:flex-start;gap:10px}
.alert svg{width:16px;height:16px;flex-shrink:0;margin-top:1px}
.alert-info{background:var(--info-bg);color:#1E40AF;border:1px solid #BFDBFE}
.alert-warning{background:var(--warning-bg);color:#92400E;border:1px solid #FDE68A}
.alert-danger{background:var(--danger-bg);color:#991B1B;border:1px solid #FECACA}
.alert-success{background:var(--success-bg);color:var(--success-text);border:1px solid #A7F3D0}

/* ── Integrations ────────────────────────────────────────────────────── */
.integration-card{
  display:flex;align-items:center;gap:16px;padding:16px;
  border:var(--glass-border);border-radius:var(--radius-lg);
  background:rgba(255,255,255,0.4);
  backdrop-filter:blur(8px);margin-bottom:12px;
}
[data-theme="dark"] .integration-card{background:rgba(31,41,55,0.4)}
.integration-icon{width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,0.5);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:20px}
[data-theme="dark"] .integration-icon{background:rgba(55,65,81,0.6)}
.integration-info{flex:1;min-width:0}
.integration-name{font-size:14px;font-weight:600;color:var(--text-1)}
.integration-status{font-size:12px;color:var(--text-3);margin-top:2px}
.integration-status.connected{color:var(--success)}
.integration-actions{display:flex;gap:6px;flex-shrink:0}

/* ── Admin ───────────────────────────────────────────────────────────── */
.admin-metric{font-size:13px;font-weight:500}

/* ── Responsive ──────────────────────────────────────────────────────── */
.sidebar-toggle{display:none;background:none;border:none;padding:6px;border-radius:6px;color:var(--text-2)}
.sidebar-toggle:hover{background:rgba(0,0,0,.05)}
.sidebar-toggle svg{width:20px;height:20px}

@media(max-width:768px){
  .sidebar-toggle{display:flex;align-items:center}
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .main-wrapper{margin-left:0}
  .form-row{grid-template-columns:1fr}
  .detail-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .page-content{padding:16px}
}
