/* ============================================================
   Activate — "Luxe" skin (2026-07)
   Loaded AFTER app.css / test-lifecycle.css / wm-copilot.css.
   Re-skins the token layer + core shell components; screens that
   consume the CSS variables inherit the look automatically.
   Design refs: Syncthing/Idea 1-3 (porcelain canvas, floating
   cards, coral action color, ink pill nav, pastel data hues).
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

:root {
  /* type */
  --font: 'Inter', 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  /* palette */
  --accent: #4180f2;
  --accent-light: #6ba1f7;
  --accent-soft: rgba(65, 128, 242, 0.09);
  --bg-page: #f4f4fa;
  --bg-secondary: #f5f5fb;
  --bg-input: #f6f7fc;
  --bg-hover: rgba(65, 128, 242, 0.05);
  --bg-sidebar: rgba(250, 250, 254, 0.82);
  --bg-sidebar-hover: rgba(37, 51, 120, 0.05);
  --bg-sidebar-active: #1d2554;
  --text-sidebar-active: #ffffff;
  --border: rgba(37, 51, 120, 0.09);
  --border-light: rgba(37, 51, 120, 0.06);

  /* geometry */
  --radius: 14px;
  --radius-sm: 9px;
  --radius-lg: 18px;

  /* elevation — layered, soft, "floating" */
  --shadow-sm: 0 1px 2px rgba(23, 26, 63, 0.05);
  --shadow: 0 1px 2px rgba(23, 26, 63, 0.04), 0 6px 20px -8px rgba(37, 51, 120, 0.10);
  --shadow-md: 0 2px 6px rgba(23, 26, 63, 0.05), 0 12px 28px -10px rgba(37, 51, 120, 0.14);
  --shadow-lg: 0 4px 12px rgba(23, 26, 63, 0.06), 0 24px 48px -16px rgba(37, 51, 120, 0.20);

  /* motion — one luxury curve everywhere */
  --ease-luxe: cubic-bezier(0.22, 1, 0.36, 1);
  --transition: 0.28s var(--ease-luxe);
}

/* ===== CANVAS — soft lavender/blue washes behind floating content ===== */
body {
  background:
    radial-gradient(900px 600px at 88% -10%, rgba(122, 110, 228, 0.10), transparent 60%),
    radial-gradient(800px 560px at -8% 100%, rgba(83, 152, 246, 0.09), transparent 60%),
    radial-gradient(600px 400px at 55% 115%, rgba(245, 88, 25, 0.045), transparent 60%),
    var(--bg-page);
  letter-spacing: -0.006em;
}

.main-content { background: transparent; }
.content-area { padding: 26px 28px; }

/* content enters with a soft rise on every screen change */
@keyframes luxe-enter {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.content-area > * { animation: luxe-enter 0.36s var(--ease-luxe) both; }

/* ===== SIDEBAR — frosted panel, ink pill for active item ===== */
.sidebar {
  background: var(--bg-sidebar);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border-right: 1px solid rgba(37, 51, 120, 0.07);
}

.sidebar-header { border-bottom: 1px solid rgba(37, 51, 120, 0.06); }

.nav-item {
  border-left: none;
  border-radius: 10px;
  margin: 1px 4px;
  padding: 5px 10px;
  transition: background var(--transition), color var(--transition), box-shadow var(--transition);
}

.nav-item:hover { background: var(--bg-sidebar-hover); }

.nav-item .icon {
  transition: transform 0.3s var(--ease-luxe), opacity 0.3s var(--ease-luxe);
}
.nav-item:hover .icon { transform: translateX(2px) scale(1.08); opacity: 0.9; }

.nav-item.active {
  background: linear-gradient(135deg, #232b63, #1a2150);
  color: #fff;
  border-left: none;
  box-shadow: 0 4px 14px -4px rgba(29, 37, 84, 0.45);
}
.nav-item.active .icon { opacity: 1; color: #fff; }
.nav-item.active .badge { background: rgba(255, 255, 255, 0.18); color: #cfe0ff; }

.nav-item .badge { border-radius: 999px; }

.nav-section-label { color: rgba(37, 51, 120, 0.42); letter-spacing: 1.2px; }

.sidebar-footer { border-top: 1px solid rgba(37, 51, 120, 0.06); }
.sidebar-footer .env-badge { border-radius: 999px; }

.sidebar-toggle {
  border-radius: 999px;
  box-shadow: var(--shadow-sm);
  transition: transform 0.25s var(--ease-luxe), background 0.25s var(--ease-luxe);
}
.sidebar-toggle:hover { transform: scale(1.12); }

/* ===== HEADER — frosted, blends with canvas ===== */
.header {
  background: rgba(255, 255, 255, 0.62);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(37, 51, 120, 0.06);
}

.header-title { font-weight: 700; letter-spacing: -0.02em; }

.header-actions .env-tag {
  background: linear-gradient(135deg, #2a3475, #1c2452);
  border-radius: 999px;
  box-shadow: 0 3px 10px -3px rgba(29, 37, 84, 0.4);
}

/* ===== CARDS — floating, lift + accent sweep on hover ===== */
.stat-card,
.section-card,
.progress-section {
  border-color: var(--border-light);
  box-shadow: var(--shadow);
}

.stat-card {
  border-radius: var(--radius);
  position: relative;
  overflow: hidden;
  transition: transform 0.35s var(--ease-luxe), box-shadow 0.35s var(--ease-luxe), border-color 0.35s var(--ease-luxe);
}

/* hairline gradient sweep along the top edge, revealed on hover */
.stat-card::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--accent), rgba(122, 110, 228, 0.9), transparent);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.5s var(--ease-luxe);
  pointer-events: none;
}

.stat-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-lg);
  border-color: rgba(65, 128, 242, 0.22);
}
.stat-card:hover::after { transform: scaleX(1); }

.stat-card .stat-value { letter-spacing: -0.03em; font-weight: 800; }
.stat-card .stat-label { letter-spacing: 0.8px; font-size: 11px; }

/* status cards keep their signal, softened to a 3px inset bar */
.stat-card.pass, .stat-card.fail, .stat-card.pending, .stat-card.total { border-left-width: 3px; }

.section-card {
  border-radius: var(--radius-lg);
  transition: box-shadow 0.35s var(--ease-luxe), transform 0.35s var(--ease-luxe);
}
.section-card:hover { box-shadow: var(--shadow-md); }

.section-card-header { letter-spacing: -0.01em; }

/* ===== BUTTONS — pills with a sheen sweep ===== */
.btn-primary,
.btn-secondary {
  border-radius: 999px;
  text-transform: none;
  letter-spacing: 0;
  font-weight: 600;
  padding: 8px 18px;
  position: relative;
  overflow: hidden;
  transition: transform 0.25s var(--ease-luxe), box-shadow 0.25s var(--ease-luxe), background 0.25s var(--ease-luxe), border-color 0.25s var(--ease-luxe);
}

.btn-primary {
  background: linear-gradient(135deg, #ff6b2e, #f04e0e);
  box-shadow: 0 4px 14px -4px rgba(245, 88, 25, 0.45);
}

.btn-primary::after,
.btn-secondary::after {
  content: '';
  position: absolute;
  top: 0; left: -70%;
  width: 45%; height: 100%;
  background: linear-gradient(105deg, transparent, rgba(255, 255, 255, 0.4), transparent);
  transform: skewX(-20deg);
  transition: left 0.6s var(--ease-luxe);
  pointer-events: none;
}

.btn-primary:hover {
  background: linear-gradient(135deg, #ff7a42, #f5581c);
  transform: translateY(-1px);
  box-shadow: 0 8px 22px -6px rgba(245, 88, 25, 0.55);
}
.btn-primary:hover::after, .btn-secondary:hover::after { left: 130%; }
.btn-primary:active { transform: translateY(0) scale(0.98); }

.btn-secondary { border-color: rgba(65, 128, 242, 0.35); }
.btn-secondary:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 16px -6px rgba(65, 128, 242, 0.35);
  border-color: var(--accent);
}

/* filter chips → pills with a gentle lift */
.filter-btn {
  border-radius: 999px;
  padding: 6px 15px;
  transition: transform 0.25s var(--ease-luxe), background 0.25s var(--ease-luxe), color 0.25s var(--ease-luxe), border-color 0.25s var(--ease-luxe), box-shadow 0.25s var(--ease-luxe);
}
.filter-btn:hover { transform: translateY(-1px); box-shadow: var(--shadow-sm); }
.filter-btn.active { box-shadow: 0 4px 12px -4px rgba(65, 128, 242, 0.5); }

/* ===== INPUTS — soft fill, glowing focus ring ===== */
.search-input {
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.85);
  transition: border-color 0.25s var(--ease-luxe), box-shadow 0.25s var(--ease-luxe), background 0.25s var(--ease-luxe);
}
.search-input:focus {
  background: #fff;
  border-color: var(--accent);
  box-shadow: 0 0 0 4px rgba(65, 128, 242, 0.13), 0 4px 14px -6px rgba(65, 128, 242, 0.25);
}

/* ===== TABLES — airy rows, accent bar slides in on hover ===== */
.issues-table th, .adopt-data-table thead th {
  letter-spacing: 0.7px;
  font-size: 11px;
}
.issues-table tr, .adopt-data-table tbody tr { transition: background 0.22s var(--ease-luxe), box-shadow 0.22s var(--ease-luxe); }
.issues-table tr:hover td,
.adopt-data-table tbody tr:hover td {
  background: linear-gradient(90deg, rgba(65, 128, 242, 0.055), rgba(65, 128, 242, 0.015));
}
.issues-table tbody tr:hover,
.adopt-data-table tbody tr:hover {
  box-shadow: inset 3px 0 0 var(--accent);
}

/* ===== PER-SCREEN CARDS — screens inject their own <style> with
   hardcoded radii/hover, so these need #content-area specificity ===== */
#content-area .dash-card,
#content-area .ac-card,
#content-area .pu-card,
#content-area .ta-stat-card,
#content-area .ta-chart-card,
#content-area .sup-chart-card,
#content-area .sup-stat-card,
#content-area .rg-card,
#content-area .dap-rule-card,
#content-area .dap-stat-card,
#content-area .dap-settings-card,
#content-area .brand-card,
#content-area .report-gauge-card,
#content-area .pse-card,
#content-area .mig-summary-card,
#content-area .lms-stat-card,
#content-area .ext-example-card,
#content-area .ais-card,
#content-area .vl-card,
#content-area .trace-stat-card,
#content-area .persona-card,
#content-area .adm-card,
#content-area .comms-cal-card,
#content-area .tt-card {
  border-radius: var(--radius);
  border-color: var(--border-light);
  box-shadow: var(--shadow);
  transition: transform 0.32s var(--ease-luxe), box-shadow 0.32s var(--ease-luxe), border-color 0.32s var(--ease-luxe);
}

#content-area .dash-card:hover,
#content-area .ac-card:hover,
#content-area .pu-card:hover,
#content-area .ta-stat-card:hover,
#content-area .ta-chart-card:hover,
#content-area .sup-chart-card:hover,
#content-area .sup-stat-card:hover,
#content-area .rg-card:hover,
#content-area .dap-rule-card:hover,
#content-area .dap-stat-card:hover,
#content-area .dap-settings-card:hover,
#content-area .brand-card:hover,
#content-area .report-gauge-card:hover,
#content-area .pse-card:hover,
#content-area .mig-summary-card:hover,
#content-area .lms-stat-card:hover,
#content-area .ext-example-card:hover,
#content-area .ais-card:hover,
#content-area .vl-card:hover,
#content-area .trace-stat-card:hover,
#content-area .persona-card:hover,
#content-area .adm-card:hover,
#content-area .comms-cal-card:hover,
#content-area .tt-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: rgba(65, 128, 242, 0.20);
}

/* clickable dashboard cards get the stronger lift */
#content-area .dash-card-click:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-lg);
  border-color: rgba(65, 128, 242, 0.28);
}

/* ===== SCROLLBARS — slim, rounded, quiet ===== */
::-webkit-scrollbar { width: 9px; height: 9px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: rgba(37, 51, 120, 0.16);
  border-radius: 999px;
  border: 2px solid transparent;
  background-clip: content-box;
}
::-webkit-scrollbar-thumb:hover { background: rgba(37, 51, 120, 0.30); background-clip: content-box; }

/* ===== CHAT PANEL (Tiva) ===== */
.chat-panel { border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); }

/* ===== LOGIN — align the standalone login screen with the skin ===== */
._lp { font-family: var(--font); background: #f4f4fa; }
._card { border-radius: 22px; box-shadow: 0 2px 6px rgba(23,26,63,0.04), 0 28px 60px -20px rgba(37, 51, 120, 0.18); }
._btn {
  background: linear-gradient(135deg, #ff6b2e, #f04e0e);
  border-radius: 999px;
  box-shadow: 0 4px 14px -4px rgba(245, 88, 25, 0.45);
  position: relative;
  overflow: hidden;
}
._btn:hover { background: linear-gradient(135deg, #ff7a42, #f5581c); box-shadow: 0 8px 22px -6px rgba(245, 88, 25, 0.55); }
._iw { border-radius: 999px; }
._iw input { padding-left: 44px; }
._ms { border-radius: 999px; }

/* ===== ACCESSIBILITY ===== */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
