/* ===========================
   VIGIL — Dashboard Styles
   =========================== */

.dashboard-wrap { max-width: 900px; margin: 0 auto; padding: 40px 48px 80px; }

.nav-links { display: flex; gap: 24px; align-items: center; }
.nav-link { font-family: var(--font-head); font-size: 0.8rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-dim); text-decoration: none; transition: color 0.2s; }
.nav-link:hover, .nav-link.active { color: var(--accent); }

.dash-header { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 40px; border-bottom: 1px solid var(--border); padding-bottom: 32px; }
.dash-title { font-family: var(--font-head); font-size: 2.2rem; font-weight: 800; color: var(--text); margin-top: 8px; }

.btn-primary { background: var(--accent); color: #0D0D0D; border: none; padding: 10px 20px; border-radius: 6px; font-family: var(--font-head); font-size: 0.85rem; font-weight: 700; letter-spacing: 0.05em; cursor: pointer; transition: opacity 0.2s; }
.btn-primary:hover { opacity: 0.85; }
.btn-ghost { background: transparent; color: var(--text-dim); border: 1px solid var(--border); padding: 10px 20px; border-radius: 6px; font-family: var(--font-body); font-size: 0.85rem; cursor: pointer; }
.btn-sm { background: var(--surface-2); color: var(--text-dim); border: 1px solid var(--border); padding: 5px 10px; border-radius: 4px; font-size: 0.75rem; cursor: pointer; transition: all 0.15s; }
.btn-sm:hover { background: var(--surface); color: var(--text); }
.btn-check:hover { background: var(--accent-dim); color: var(--accent); border-color: var(--accent); }
.btn-delete:hover { background: rgba(220,38,38,0.15); color: #dc2626; border-color: #dc2626; }

.modal { position: fixed; inset: 0; background: rgba(0,0,0,0.7); display: flex; align-items: center; justify-content: center; z-index: 100; }
.modal-inner { background: var(--surface); border: 1px solid var(--border); border-radius: 12px; padding: 36px; width: 420px; max-width: 90vw; }
.modal-inner h2 { font-family: var(--font-head); font-size: 1.2rem; font-weight: 700; margin-bottom: 24px; }
.modal-inner label { display: block; font-size: 0.8rem; color: var(--text-dim); margin-bottom: 16px; font-family: var(--font-head); letter-spacing: 0.05em; text-transform: uppercase; }
.modal-inner input, .modal-inner select { display: block; width: 100%; margin-top: 6px; background: var(--surface-2); border: 1px solid var(--border); border-radius: 6px; color: var(--text); padding: 10px 12px; font-family: var(--font-body); font-size: 0.9rem; }
.modal-actions { display: flex; gap: 10px; justify-content: flex-end; margin-top: 24px; }

#competitors-list { margin-bottom: 56px; }
.comp-card { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 20px 24px; background: var(--surface); border: 1px solid var(--border); border-radius: 8px; margin-bottom: 8px; transition: border-color 0.2s; }
.comp-card:hover { border-color: rgba(245,158,11,0.25); }
.comp-name { font-family: var(--font-head); font-size: 1rem; font-weight: 700; color: var(--text); margin-bottom: 4px; }
.comp-url a { font-size: 0.8rem; color: var(--accent); text-decoration: none; }
.comp-url a:hover { text-decoration: underline; }
.comp-meta { display: flex; align-items: center; gap: 10px; margin-top: 8px; }
.badge { font-family: var(--font-head); font-size: 0.65rem; font-weight: 700; letter-spacing: 0.1em; padding: 3px 8px; border-radius: 4px; text-transform: uppercase; }
.badge-green { background: rgba(34,197,94,0.15); color: #22c55e; }
.badge-dim { background: var(--surface-2); color: var(--text-dim); }
.interval-badge { font-size: 0.75rem; color: var(--text-dim); font-family: var(--font-head); }
.comp-meta time { font-size: 0.75rem; color: var(--text-dim); }
.comp-actions { display: flex; gap: 6px; flex-shrink: 0; }

.history-section { margin-top: 48px; }
.section-title { font-family: var(--font-head); font-size: 1.1rem; font-weight: 700; color: var(--text); margin-bottom: 20px; padding-bottom: 16px; border-bottom: 1px solid var(--border); }
.change-row { display: flex; align-items: flex-start; gap: 16px; padding: 16px 0; border-bottom: 1px solid var(--border); }
.severity-badge { font-family: var(--font-head); font-size: 0.65rem; font-weight: 700; letter-spacing: 0.1em; padding: 4px 8px; border-radius: 4px; flex-shrink: 0; margin-top: 2px; }
.sev-high { background: rgba(220,38,38,0.15); color: #ef4444; }
.sev-medium { background: rgba(245,158,11,0.15); color: #f59e0b; }
.sev-low { background: rgba(34,197,94,0.12); color: #22c55e; }
.change-comp { font-family: var(--font-head); font-weight: 700; font-size: 0.9rem; color: var(--text); }
.change-summary { font-size: 0.85rem; color: var(--text-dim); margin: 4px 0 6px; line-height: 1.5; }
.change-time { font-size: 0.75rem; color: var(--text-dim); opacity: 0.7; }
.empty { color: var(--text-dim); font-size: 0.9rem; padding: 32px 0; text-align: center; }
.loading { color: var(--text-dim); font-size: 0.9rem; padding: 32px 0; text-align: center; }

.toast { position: fixed; bottom: 24px; right: 24px; background: var(--surface-2); color: var(--text); border: 1px solid var(--border); padding: 12px 20px; border-radius: 8px; font-size: 0.85rem; z-index: 200; animation: slideUp 0.2s ease; }
@keyframes slideUp { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }

@media (max-width: 600px) {
  .dashboard-wrap { padding: 24px 16px; }
  .dash-header { flex-direction: column; align-items: flex-start; gap: 16px; }
  .comp-card { flex-direction: column; align-items: flex-start; }
  .comp-actions { width: 100%; }
}

/* ===========================
   Alert Settings Panel
   =========================== */
.settings-section { margin-bottom: 56px; }
.settings-toggle { display: flex; align-items: center; justify-content: space-between; width: 100%; background: var(--surface); border: 1px solid var(--border); border-radius: 8px; padding: 14px 20px; cursor: pointer; transition: border-color 0.2s; }
.settings-toggle:hover { border-color: rgba(245,158,11,0.25); }
.settings-toggle .section-label { font-family: var(--font-head); font-size: 0.85rem; font-weight: 700; color: var(--text); letter-spacing: 0.05em; }
.chevron { color: var(--text-dim); transition: transform 0.2s; }
.settings-panel { background: var(--surface); border: 1px solid var(--border); border-top: none; border-radius: 0 0 8px 8px; padding: 24px 28px; display: flex; flex-direction: column; gap: 20px; }
.pref-row { display: flex; flex-direction: column; gap: 6px; }
.pref-row label { font-family: var(--font-head); font-size: 0.75rem; font-weight: 700; color: var(--text); letter-spacing: 0.08em; text-transform: uppercase; }
.pref-row select { background: var(--surface-2); border: 1px solid var(--border); border-radius: 6px; color: var(--text); padding: 8px 12px; font-family: var(--font-body); font-size: 0.85rem; cursor: pointer; width: 100%; }
.pref-desc { font-size: 0.78rem; color: var(--text-dim); margin: 0; line-height: 1.4; }
.settings-actions { display: flex; align-items: center; gap: 16px; padding-top: 4px; }
.save-status { font-size: 0.8rem; color: var(--text-dim); font-family: var(--font-head); }