/* ============================================================
   LinkedMe – Agentic Job CRM Design System
   ============================================================ */

/* --- Design Tokens --- */
:root {
  --bg: #f8f9fc;
  --card: #fff;
  --text: #111827;
  --muted: #6b7280;
  --line: #e5e7eb;
  --primary: #2563eb;
  --primary-hover: #1d4ed8;
  --primary-light: #dbeafe;
  --danger: #dc2626;
  --danger-light: #fef2f2;
  --success: #16a34a;
  --success-light: #dcfce7;
  --warning: #d97706;
  --warning-light: #fef3c7;
  --info: #0891b2;
  --info-light: #ecfeff;
  --radius-sm: 6px;
  --radius: 10px;
  --radius-lg: 14px;
  --radius-xl: 18px;
  --shadow-sm: 0 1px 2px rgba(0,0,0,.05);
  --shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);
  --shadow-md: 0 4px 6px -1px rgba(0,0,0,.08), 0 2px 4px -2px rgba(0,0,0,.04);
  --shadow-lg: 0 10px 15px -3px rgba(0,0,0,.08), 0 4px 6px -4px rgba(0,0,0,.04);
  --transition: 150ms ease;
  --font: 'Inter', ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
  --topbar-h: 60px;
}

/* --- Reset & Base --- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{margin:0 0 .5rem;line-height:1.3;font-weight:700}
h1{font-size:1.75rem}
h2{font-size:1.25rem}
h3{font-size:1.05rem}
p{margin:0 0 .75rem}
a{color:var(--primary);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--primary-hover);text-decoration:underline}
img{max-width:100%;display:block}
hr{border:0;border-top:1px solid var(--line);margin:1.5rem 0}

/* --- Topbar --- */
.topbar{display:flex;justify-content:space-between;align-items:center;padding:0 24px;height:var(--topbar-h);background:#0f172a;color:#fff;position:sticky;top:0;z-index:100;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.brand{font-size:1.1rem;font-weight:800;color:#fff;text-decoration:none;letter-spacing:-.02em}
.brand:hover{color:#fff;text-decoration:none}
.subtitle{color:#94a3b8;margin-left:10px;font-size:.85rem;font-weight:400}
.topbar-left{display:flex;align-items:center;gap:4px}
nav{display:flex;gap:2px;align-items:center}
nav a{color:#cbd5e1;text-decoration:none;font-size:.85rem;padding:6px 12px;border-radius:var(--radius-sm);transition:all var(--transition);font-weight:500}
nav a:hover{color:#fff;background:rgba(255,255,255,.08);text-decoration:none}
nav a.active{color:#fff;background:rgba(255,255,255,.12);font-weight:600}

/* --- Container --- */
.container{max-width:1240px;margin:0 auto;padding:24px 24px 48px}

/* --- Hero / Pagehead --- */
.hero,.pagehead{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.hero h1,.pagehead h1{margin-bottom:4px}
.hero p{font-size:1rem;color:var(--muted);max-width:600px;margin-bottom:0}
.hero-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* --- Grids --- */
.grid{display:grid;gap:16px}
.stats{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));margin-bottom:20px}
.two{grid-template-columns:repeat(2,minmax(0,1fr));margin-bottom:20px}
.three{grid-template-columns:repeat(3,minmax(0,1fr))}
.cards{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}

/* --- Card --- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-xl);padding:20px;box-shadow:var(--shadow-sm);margin-bottom:16px;transition:box-shadow var(--transition),border-color var(--transition)}
.card:hover{box-shadow:var(--shadow);border-color:#d1d5db}
.card h2{margin-bottom:12px}
.card h3{margin-top:16px;margin-bottom:8px}

/* --- Metric --- */
.metric{font-size:2.2rem;font-weight:800;letter-spacing:-.03em;line-height:1.1}
.metric-label{font-size:.8rem;color:var(--muted);font-weight:500;margin-top:4px;text-transform:uppercase;letter-spacing:.04em}

/* --- Muted / Danger --- */
.muted{color:var(--muted);font-size:.875rem}
.danger{color:var(--danger)}

/* --- Tables --- */
.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--line);margin-bottom:16px}
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:10px 14px;border-bottom:1px solid var(--line);vertical-align:middle;font-size:.9rem}
th{font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:600;background:#f9fafb;position:sticky;top:0}
tr:last-child td{border-bottom:0}
tr:hover td{background:#f9fafb}
td.actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center}

/* --- Buttons --- */
.button,button{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid var(--line);background:#fff;color:var(--text);padding:8px 16px;border-radius:var(--radius);text-decoration:none;font-weight:600;font-size:.875rem;cursor:pointer;transition:all var(--transition);line-height:1.4;white-space:nowrap;font-family:inherit}
.button:hover,button:hover{text-decoration:none;background:#f9fafb;border-color:#d1d5db;transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.button:active,button:active{transform:translateY(0)}
.primary,.button.primary,button.primary{background:var(--primary);border-color:var(--primary);color:#fff}
.primary:hover,.button.primary:hover,button.primary:hover{background:var(--primary-hover);border-color:var(--primary-hover);color:#fff}
.btn-sm{padding:5px 10px;font-size:.8rem;border-radius:var(--radius-sm)}
.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}
.btn-danger:hover{background:#b91c1c;border-color:#b91c1c;color:#fff}
.btn-success{background:var(--success);border-color:var(--success);color:#fff}
.btn-success:hover{background:#15803d;border-color:#15803d;color:#fff}
.btn-warning{background:var(--warning);border-color:var(--warning);color:#fff}
.btn-warning:hover{background:#b45309;border-color:#b45309;color:#fff}
.btn-ghost{background:transparent;border-color:transparent;color:var(--muted)}
.btn-ghost:hover{background:rgba(0,0,0,.04);color:var(--text)}
button:disabled{opacity:.5;cursor:not-allowed;transform:none !important;box-shadow:none !important}

/* --- Pills / Badges --- */
.pill{display:inline-flex;align-items:center;border-radius:999px;padding:3px 10px;font-size:.75rem;font-weight:600;letter-spacing:.02em}
.pill.high,.pill.ready{background:#dcfce7;color:#166534}
.pill.medium,.pill.preparing{background:#fef9c3;color:#854d0e}
.pill.low,.pill.not_started{background:#fee2e2;color:#991b1b}
.pill.discovered{background:#eef2ff;color:#3730a3}
.pill.qualified{background:#dbeafe;color:#1e40af}
.pill.prepared{background:#fae8ff;color:#86198f}
.pill.applied{background:#dcfce7;color:#166534}
.pill.interviewing{background:#fef3c7;color:#92400e}
.pill.offer{background:#d1fae5;color:#065f46}
.pill.rejected{background:#fee2e2;color:#991b1b}
.pill.archived{background:#f3f4f6;color:#6b7280}
.pill.remote{background:#dbeafe;color:#1e40af}
.pill.hybrid{background:#fef3c7;color:#92400e}
.pill.onsite{background:#fee2e2;color:#991b1b}
.pill.unknown{background:#f3f4f6;color:#6b7280}
.pill.normal{background:#f3f4f6;color:#6b7280}
.pill.open{background:#dcfce7;color:#166534}
.pill.considering{background:#fef3c7;color:#92400e}
.pill.closed{background:#fee2e2;color:#991b1b}
.pill.done{background:#dcfce7;color:#166534}

/* Warmth badges */
.warmth.cold{background:#eef2ff;color:#3730a3}
.warmth.warm{background:#fef3c7;color:#92400e}
.warmth.hot{background:#fee2e2;color:#991b1b}

/* --- Score --- */
.score{font-weight:800;background:#111827;color:#fff;border-radius:var(--radius-sm);padding:4px 8px;display:inline-block;min-width:36px;text-align:center;font-size:.85rem}
.score-high{background:var(--success)}
.score-mid{background:var(--warning)}
.score-low{background:var(--danger)}
.scorebox{background:#111827;color:#fff;border-radius:var(--radius-lg);padding:16px 24px;text-align:center;display:inline-flex;flex-direction:column;align-items:center}
.scorebox span{font-size:2.5rem;font-weight:900;line-height:1}
.scorebox small{color:#94a3b8;font-size:.85rem}
.score-high-box{background:var(--success)}
.score-high-box small{color:#166534}
.score-mid-box{background:var(--warning)}
.score-mid-box small{color:#854d0e}
.score-low-box{background:var(--danger)}
.score-low-box small{color:#fff}
.score-small{position:absolute;left:8px;top:8px;background:var(--primary);color:#fff;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}

/* --- Forms --- */
.form{display:grid;gap:14px}
.form label{display:grid;gap:5px;font-weight:600;font-size:.875rem}
.form input,.form textarea,.form select{width:100%;border:1px solid var(--line);border-radius:var(--radius);padding:10px 12px;font:inherit;font-size:.9rem;background:#fff;transition:border-color var(--transition),box-shadow var(--transition)}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.form input::placeholder,.form textarea::placeholder{color:#9ca3af}
input,textarea,select{font-family:inherit}
.inline{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.inline input,.inline select{width:auto;min-width:160px}

/* --- Inline Form Row --- */
.form-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.form-row input,.form-row select{flex:1;min-width:140px}

/* --- Filters --- */
.filters{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}
.filters a,.filters .filter-btn{background:#fff;border:1px solid var(--line);border-radius:999px;padding:6px 14px;text-decoration:none;color:var(--text);font-size:.825rem;font-weight:500;transition:all var(--transition)}
.filters a:hover,.filters .filter-btn:hover{background:var(--primary-light);border-color:var(--primary);color:var(--primary);text-decoration:none}
.filters a.active{background:var(--primary);border-color:var(--primary);color:#fff}

/* --- Pre / Code --- */
pre{white-space:pre-wrap;word-break:break-word;background:#f8fafc;border:1px solid var(--line);border-radius:var(--radius);padding:14px;max-height:500px;overflow:auto;font-size:.85rem;line-height:1.5}
code{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:.85em}

/* --- List Item --- */
.listitem{border-bottom:1px solid var(--line);padding:10px 0}
.listitem:last-child{border-bottom:0}

/* --- Board / Pipeline --- */
.board{display:flex;gap:16px;overflow-x:auto;padding-bottom:16px;min-height:400px}
.board .column{min-width:280px;flex:1;background:#f1f5f9;border-radius:var(--radius-lg);padding:14px;display:flex;flex-direction:column;gap:10px;transition:background var(--transition)}
.board .column.drag-over{background:#dbeafe;outline:2px dashed var(--primary)}
.board .column h3{margin:0;font-size:.9rem;display:flex;justify-content:space-between;align-items:center;padding-bottom:8px;border-bottom:1px solid rgba(0,0,0,.08)}
.job-card{position:relative;padding:10px 10px 10px 40px;cursor:grab;transition:transform var(--transition),box-shadow var(--transition)}
.job-card:active{cursor:grabbing}
.job-card.dragging{opacity:.5;transform:rotate(2deg)}
.job-card .card-title{font-weight:600;font-size:.9rem;margin-bottom:2px}
.job-card .card-meta{font-size:.8rem;color:var(--muted)}

/* --- Loading Overlay --- */
.loading-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(15,23,42,.55);z-index:9999;justify-content:center;align-items:center;backdrop-filter:blur(3px)}
.loading-overlay.active{display:flex}
.loading-content{background:#fff;padding:2rem 2.5rem;border-radius:var(--radius-xl);text-align:center;box-shadow:var(--shadow-lg);max-width:360px}
.loading-content p{margin:.75rem 0 0;font-weight:600;color:var(--text)}
.spinner{width:36px;height:36px;border:3px solid #e5e7eb;border-top:3px solid var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}
@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}

/* --- Flash / Toast --- */
.flash-banner{padding:12px 16px;border-radius:var(--radius);margin-bottom:16px;font-weight:500;font-size:.9rem;display:flex;align-items:center;gap:8px;animation:slideDown .3s ease}
.flash-banner.success,.flash-banner:not(.error){background:var(--success-light);border:1px solid #bbf7d0;color:#166534}
.flash-banner.error{background:var(--danger-light);border:1px solid #fecaca;color:#991b1b}
.flash-banner.warning{background:var(--warning-light);border:1px solid #fde68a;color:#92400e}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

/* Toast notifications */
#toast-container{position:fixed;top:calc(var(--topbar-h) + 12px);right:20px;z-index:10000;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:12px 16px;box-shadow:var(--shadow-lg);font-size:.875rem;font-weight:500;pointer-events:auto;animation:toastIn .3s ease;max-width:380px;display:flex;align-items:center;gap:8px}
.toast.success{border-left:3px solid var(--success)}
.toast.error{border-left:3px solid var(--danger)}
.toast.info{border-left:3px solid var(--info)}
.toast-exit{animation:toastOut .3s ease forwards}
@keyframes toastIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
@keyframes toastOut{to{opacity:0;transform:translateX(40px)}}

/* --- Modal --- */
.modal-backdrop{display:none;position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:5000;justify-content:center;align-items:center;backdrop-filter:blur(2px)}
.modal-backdrop.active{display:flex}
.modal{background:#fff;border-radius:var(--radius-xl);padding:24px;max-width:480px;width:90%;box-shadow:var(--shadow-lg);animation:modalIn .2s ease}
.modal h2{margin-bottom:8px}
.modal p{margin-bottom:16px;color:var(--muted)}
.modal-actions{display:flex;gap:8px;justify-content:flex-end}
@keyframes modalIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}

/* --- Detail Header --- */
.detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.detail-header .detail-meta{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:4px}

/* --- Empty State --- */
.empty-state{text-align:center;padding:48px 24px;color:var(--muted)}
.empty-state .empty-icon{font-size:2.5rem;margin-bottom:12px;opacity:.5}
.empty-state p{margin-bottom:16px}

/* --- Section --- */
.section{margin-bottom:20px}
.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}

/* --- Status Banner --- */
.status-banner{padding:14px 18px;border-radius:var(--radius);margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.status-banner.success{background:var(--success-light);border:1px solid #bbf7d0;color:#166534}
.status-banner.warning{background:var(--warning-light);border:1px solid #fde68a;color:#92400e}

/* --- Settings Sections --- */
.settings-section{margin:1.5rem 0}
.settings-section h3{margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.settings-field{margin-bottom:10px}
.settings-field label{display:block;font-weight:600;font-size:.85rem;margin-bottom:4px}
.settings-field input{width:100%;max-width:420px;border:1px solid var(--line);border-radius:var(--radius);padding:8px 12px;font:inherit;font-size:.875rem}
.settings-field input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.settings-status{font-size:.8rem;color:var(--muted);margin-top:2px}
.settings-status .reachable{color:var(--success);font-weight:600}
.settings-status .unreachable{color:var(--danger);font-weight:600}

/* --- Responsive --- */
@media(max-width:1024px){
  .two{grid-template-columns:1fr}
  .three{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .topbar{flex-direction:column;height:auto;padding:12px 16px;gap:8px}
  nav{flex-wrap:wrap;justify-content:center;gap:2px}
  .container{padding:16px 16px 32px}
  .hero,.pagehead{flex-direction:column;align-items:flex-start}
  .stats{grid-template-columns:1fr 1fr}
  .three{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  h1{font-size:1.4rem}
  .metric{font-size:1.6rem}
  .board .column{min-width:260px}
}
@media(max-width:480px){
  .stats{grid-template-columns:1fr}
  .form-row{flex-direction:column;align-items:stretch}
  .form-row input,.form-row select{min-width:0}
}

/* --- Print --- */
@media print{
  .topbar,.loading-overlay,#toast-container,.modal-backdrop{display:none !important}
  .container{max-width:100%;padding:0}
  .card{break-inside:avoid;box-shadow:none;border:1px solid #ddd}
}

/* ============================================================
   Dark Mode
   ============================================================ */
[data-theme="dark"]{
  --bg:#0f172a;--card:#1e293b;--text:#e2e8f0;--muted:#94a3b8;--line:#334155;
  --primary:#60a5fa;--primary-hover:#3b82f6;--primary-light:#1e3a5f;
  --danger:#f87171;--danger-light:#451a1a;--success:#4ade80;--success-light:#14532d;
  --warning:#fbbf24;--warning-light:#451a03;--info:#22d3ee;--info-light:#083344;
}
[data-theme="dark"] .topbar{background:#020617;box-shadow:0 1px 3px rgba(0,0,0,.5)}
[data-theme="dark"] nav a{color:#94a3b8}
[data-theme="dark"] nav a:hover{color:#e2e8f0;background:rgba(255,255,255,.06)}
[data-theme="dark"] nav a.active{color:#e2e8f0;background:rgba(255,255,255,.1)}
[data-theme="dark"] .brand{color:#f1f5f9}
[data-theme="dark"] .subtitle{color:#64748b}
[data-theme="dark"] .button,[data-theme="dark"] button{background:var(--card);color:var(--text);border-color:var(--line)}
[data-theme="dark"] .button:hover,[data-theme="dark"] button:hover{background:#334155;border-color:#475569}
[data-theme="dark"] .primary,[data-theme="dark"] .button.primary,[data-theme="dark"] button.primary{background:var(--primary);border-color:var(--primary);color:#0f172a}
[data-theme="dark"] .primary:hover,[data-theme="dark"] .button.primary:hover,[data-theme="dark"] button.primary:hover{background:var(--primary-hover);border-color:var(--primary-hover);color:#0f172a}
[data-theme="dark"] .btn-ghost{background:transparent;border-color:transparent;color:var(--muted)}
[data-theme="dark"] .btn-ghost:hover{background:rgba(255,255,255,.06);color:var(--text)}
[data-theme="dark"] .btn-danger{background:#dc2626;border-color:#dc2626;color:#fff}
[data-theme="dark"] .btn-success{background:#16a34a;border-color:#16a34a;color:#fff}
[data-theme="dark"] .btn-warning{background:#d97706;border-color:#d97706;color:#fff}
[data-theme="dark"] th{background:#1e293b;color:var(--muted)}
[data-theme="dark"] tr:hover td{background:#1e293b}
[data-theme="dark"] .form input,[data-theme="dark"] .form textarea,[data-theme="dark"] .form select,
[data-theme="dark"] input,[data-theme="dark"] textarea,[data-theme="dark"] select{background:#0f172a;border-color:#334155;color:var(--text)}
[data-theme="dark"] .form input:focus,[data-theme="dark"] .form textarea:focus,[data-theme="dark"] .form select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(96,165,250,.15)}
[data-theme="dark"] pre{background:#0f172a;border-color:#334155;color:#e2e8f0}
[data-theme="dark"] .score{background:#e2e8f0;color:#0f172a}
[data-theme="dark"] .scorebox{background:#e2e8f0;color:#0f172a}
[data-theme="dark"] .scorebox small{color:#64748b}
[data-theme="dark"] .score-small{background:var(--primary);color:#0f172a}
[data-theme="dark"] .score-high{background:#4ade80;color:#0f172a}
[data-theme="dark"] .score-mid{background:#fbbf24;color:#0f172a}
[data-theme="dark"] .score-low{background:#f87171;color:#0f172a}
[data-theme="dark"] .board .column{background:#1e293b}
[data-theme="dark"] .board .column.drag-over{background:#1e3a5f;outline-color:var(--primary)}
[data-theme="dark"] .board .column h3{border-bottom-color:rgba(255,255,255,.08)}
[data-theme="dark"] .loading-content{background:var(--card);color:var(--text)}
[data-theme="dark"] .toast{background:var(--card);border-color:var(--line);color:var(--text)}
[data-theme="dark"] .modal{background:var(--card);color:var(--text)}
[data-theme="dark"] .modal p{color:var(--muted)}
[data-theme="dark"] .filters a,[data-theme="dark"] .filters .filter-btn{background:var(--card);border-color:var(--line);color:var(--text)}
[data-theme="dark"] .filters a:hover,[data-theme="dark"] .filters .filter-btn:hover{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}
[data-theme="dark"] .filters a.active{background:var(--primary);border-color:var(--primary);color:#0f172a}
[data-theme="dark"] .settings-field input{background:#0f172a;border-color:#334155;color:var(--text)}
[data-theme="dark"] .flash-banner:not(.error){background:var(--success-light);border-color:#166534;color:#4ade80}
[data-theme="dark"] .flash-banner.error{background:var(--danger-light);border-color:#991b1b;color:#f87171}
[data-theme="dark"] .table-wrap{border-color:var(--line)}
[data-theme="dark"] .spinner{border-color:#334155;border-top-color:var(--primary)}
[data-theme="dark"] .card:hover{border-color:#475569}
[data-theme="dark"] hr{border-top-color:var(--line)}

/* ============================================================
   Copy-to-Clipboard
   ============================================================ */
.copy-btn{position:absolute;top:8px;right:8px;padding:4px 10px;font-size:.75rem;border-radius:var(--radius-sm);background:var(--card);border:1px solid var(--line);cursor:pointer;opacity:0;transition:opacity var(--transition);z-index:2;font-weight:600;color:var(--muted)}
.copy-btn:hover{background:var(--primary-light);color:var(--primary);border-color:var(--primary)}
pre:hover .copy-btn, .copy-wrap:hover .copy-btn{opacity:1}
.copy-wrap{position:relative}
.copy-wrap .copy-btn{opacity:0}
.copy-wrap:hover .copy-btn{opacity:1}

/* ============================================================
   Dark Mode Toggle
   ============================================================ */
.theme-toggle{background:none;border:1px solid rgba(255,255,255,.15);color:#cbd5e1;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);font-size:1rem;transition:all var(--transition)}
.theme-toggle:hover{background:rgba(255,255,255,.1);color:#fff}

/* ============================================================
   Keyboard Shortcut Hints
   ============================================================ */
.kbd{display:inline-block;padding:2px 6px;font-size:.7rem;font-family:var(--font);background:var(--bg);border:1px solid var(--line);border-radius:4px;color:var(--muted);margin-left:4px;line-height:1.4}

/* ============================================================
   Drag-and-Drop Upload Zone
   ============================================================ */
.drop-zone{border:2px dashed var(--line);border-radius:var(--radius-lg);padding:40px;text-align:center;cursor:pointer;transition:all var(--transition);background:var(--bg)}
.drop-zone:hover,.drop-zone.drag-active{border-color:var(--primary);background:var(--primary-light)}
.drop-zone .drop-icon{font-size:2.5rem;margin-bottom:8px;opacity:.5}
.drop-zone p{color:var(--muted);margin-bottom:4px}

/* ============================================================
   Bulk Action Bar
   ============================================================ */
.bulk-bar{position:sticky;bottom:0;left:0;right:0;background:var(--primary);color:#fff;padding:12px 20px;border-radius:var(--radius-lg) var(--radius-lg) 0 0;display:flex;align-items:center;justify-content:space-between;gap:12px;z-index:50;animation:slideUp .2s ease;box-shadow:var(--shadow-lg)}
.bulk-bar button{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:var(--radius-sm)}
.bulk-bar button:hover{background:rgba(255,255,255,.25)}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* ============================================================
   Notes / Annotations
   ============================================================ */
.notes-list{display:flex;flex-direction:column;gap:8px}
.note-item{padding:10px 14px;background:var(--bg);border-radius:var(--radius);border-left:3px solid var(--primary);font-size:.875rem}
.note-item .note-date{font-size:.75rem;color:var(--muted);margin-top:4px}
.note-form{display:flex;gap:8px;align-items:flex-start}
.note-form textarea{flex:1;min-height:60px;resize:vertical}

/* ============================================================
   Analytics Charts
   ============================================================ */
.chart-bar{display:flex;align-items:flex-end;gap:4px;height:120px;padding-top:8px}
.chart-bar .bar{flex:1;background:var(--primary);border-radius:4px 4px 0 0;transition:height var(--transition);min-width:20px;position:relative}
.chart-bar .bar:hover{background:var(--primary-hover)}
.chart-bar .bar-label{position:absolute;bottom:-20px;left:50%;transform:translateX(-50%);font-size:.65rem;color:var(--muted);white-space:nowrap}
.chart-bar .bar-value{position:absolute;top:-18px;left:50%;transform:translateX(-50%);font-size:.7rem;font-weight:700;color:var(--text)}

/* ============================================================
   Search History
   ============================================================ */
.search-chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.search-chip{display:inline-flex;align-items:center;gap:4px;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:4px 12px;font-size:.8rem;cursor:pointer;transition:all var(--transition)}
.search-chip:hover{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}
.search-chip .chip-remove{cursor:pointer;opacity:.5;font-size:.9rem}
.search-chip .chip-remove:hover{opacity:1}

/* ============================================================
   Command Palette
   ============================================================ */
.palette-backdrop{display:none;position:fixed;inset:0;background:rgba(15,23,42,.55);z-index:6000;justify-content:center;align-items:flex-start;padding-top:12vh;backdrop-filter:blur(3px)}
.palette-backdrop.active{display:flex}
.palette-modal{background:var(--card);border-radius:var(--radius-xl);width:90%;max-width:580px;box-shadow:var(--shadow-lg),0 25px 50px -12px rgba(0,0,0,.25);overflow:hidden;animation:paletteIn .15s ease}
@keyframes paletteIn{from{opacity:0;transform:scale(.96) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}
.palette-input-wrap{position:relative;border-bottom:1px solid var(--line);padding:0}
.palette-input-wrap input{width:100%;border:none;outline:none;padding:16px 16px 16px 48px;font-size:1rem;font-family:var(--font);background:transparent;color:var(--text)}
.palette-search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}
.palette-results{max-height:360px;overflow-y:auto;padding:4px}
.palette-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition)}
.palette-item:hover,.palette-item.selected{background:var(--primary-light)}
.palette-item.selected{outline:2px solid var(--primary)}
.palette-item-icon{font-size:1.1rem;flex-shrink:0;width:28px;text-align:center}
.palette-item-text{display:flex;flex-direction:column;min-width:0}
.palette-item-label{font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.palette-item-sub{font-size:.75rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.palette-empty{padding:24px;text-align:center;color:var(--muted);font-size:.9rem}
.palette-footer{display:flex;gap:16px;padding:8px 14px;border-top:1px solid var(--line);background:var(--bg);font-size:.75rem;color:var(--muted)}
.palette-footer kbd{margin:0 2px}

/* ---- Palette Trigger (in topbar) ---- */
.palette-trigger{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:6px 12px;cursor:pointer;color:#94a3b8;transition:all var(--transition)}
.palette-trigger:hover{background:rgba(255,255,255,.1);color:#e2e8f0;border-color:rgba(255,255,255,.2)}

/* ============================================================
   Notification Badges (in nav)
   ============================================================ */
.nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;border-radius:999px;background:var(--danger);color:#fff;font-size:.6rem;font-weight:700;padding:0 4px;margin-left:4px;vertical-align:middle;line-height:1;position:relative;top:-1px}
.nav-badge.warning{background:var(--warning)}
.nav-badge.info{background:var(--info)}

/* ============================================================
   Quick-Add FAB
   ============================================================ */
.fab{position:fixed;bottom:24px;right:24px;width:52px;height:52px;border-radius:50%;background:var(--primary);color:#fff;border:none;font-size:1.6rem;font-weight:300;cursor:pointer;box-shadow:0 4px 12px rgba(37,99,235,.4);z-index:50;transition:all var(--transition);display:flex;align-items:center;justify-content:center}
.fab:hover{transform:scale(1.08);box-shadow:0 6px 20px rgba(37,99,235,.5);background:var(--primary-hover)}
.fab:active{transform:scale(.95)}

/* ============================================================
   Activity Timeline
   ============================================================ */
.timeline{display:flex;flex-direction:column;gap:0}
.timeline-item{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--line);align-items:flex-start}
.timeline-item:last-child{border-bottom:0}
.timeline-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0;background:var(--bg);border:1px solid var(--line);color:var(--muted)}
.timeline-icon.status_change{background:var(--info-light);border-color:var(--info);color:var(--info)}
.timeline-icon.agent_run{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}
.timeline-icon.application{background:var(--success-light);border-color:var(--success);color:var(--success)}
.timeline-content{flex:1;min-width:0}
.timeline-desc{font-size:.9rem;line-height:1.4}
.timeline-desc a{font-weight:600}
.timeline-meta{display:flex;gap:8px;align-items:center;margin-top:4px;flex-wrap:wrap}

/* ============================================================
   Digest Card
   ============================================================ */
.digest-card h2{margin-bottom:8px}
.digest-card h3{margin:20px 0 8px;color:var(--primary);font-size:1rem}

/* ============================================================
   Dark Mode — New Components
   ============================================================ */
[data-theme="dark"] .palette-modal{background:var(--card);border:1px solid var(--line)}
[data-theme="dark"] .palette-input-wrap{border-bottom-color:var(--line)}
[data-theme="dark"] .palette-input-wrap input{color:var(--text)}
[data-theme="dark"] .palette-item:hover,[data-theme="dark"] .palette-item.selected{background:var(--primary-light)}
[data-theme="dark"] .palette-footer{background:#0f172a;border-top-color:var(--line)}
[data-theme="dark"] .palette-trigger{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.1);color:#64748b}
[data-theme="dark"] .palette-trigger:hover{background:rgba(255,255,255,.08);color:#94a3b8}
[data-theme="dark"] .fab{box-shadow:0 4px 12px rgba(0,0,0,.5)}
[data-theme="dark"] .timeline-icon{background:#1e293b;border-color:#334155}
[data-theme="dark"] .timeline-icon.status_change{background:#083344;border-color:var(--info)}
[data-theme="dark"] .timeline-icon.agent_run{background:#1e3a5f;border-color:var(--primary)}
[data-theme="dark"] .timeline-icon.application{background:#14532d;border-color:var(--success)}

/* ============================================================
   Pagination
   ============================================================ */
.pagination{display:flex;align-items:center;justify-content:center;gap:12px;margin:16px 0;padding:12px}
