/* ============================================================
   DISARM Module · qdev — поверх AV Design System 3.6.0 (Light)
   Использует канонические компоненты DS:
   .avds-pill-tabs, .avds-page-header, .avds-section-head,
   .avds-kpi-grid, .avds-search-hero, .avds-tool-card,
   .avds-export-btn, .avds-theme-chip, .avds-empty-state,
   .avds-masthead, .avds-popular-queries
   ============================================================ */

* { box-sizing: border-box; }

html, body {
  margin: 0; padding: 0;
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  -webkit-font-smoothing: antialiased;
}
body { min-height: 100vh; display: flex; flex-direction: column; }
main { flex: 1 0 auto; }

a { color: var(--color-accent); text-decoration: none; transition: color var(--motion-duration-fast); }
a:hover { color: var(--color-accent-hover); }

h1, h2, h3, h4 {
  margin: 0;
  font-family: var(--font-display, var(--font-sans));
  font-weight: 600;
  letter-spacing: -.01em;
  line-height: var(--leading-tight, 1.25);
  color: var(--color-text);
}
h1 { font-size: var(--text-3xl); font-weight: 700; letter-spacing: -.02em; }
h2 { font-size: var(--text-2xl); }
h3 { font-size: var(--text-xl); }
h4 { font-size: var(--text-lg); }

.mono { font-family: var(--font-mono); font-size: .92em; }

/* ============================================================
   LAYOUT — единый ритм
   ============================================================ */
.container {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 var(--space-6);
}
.site-main {
  padding-top: var(--space-6);
  padding-bottom: var(--space-12);
}

/* ============================================================
   MASTHEAD (поверх .avds-masthead)
   ============================================================ */
.site-masthead {
  margin-bottom: 0;
  padding-top: var(--space-8);
  padding-bottom: var(--space-6);
  background: var(--color-surface);
}
.masthead-brand-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-8);
  flex-wrap: wrap;
  margin-bottom: var(--space-5);
}
.masthead-brand { display: flex; align-items: center; gap: var(--space-4); }
.masthead-logo {
  width: 48px; height: 48px;
  padding: 8px;
  background: var(--color-accent-subtle, #eff6ff);
  border-radius: var(--radius-lg);
  color: var(--color-accent);
  flex-shrink: 0;
}
.masthead-title { font-size: var(--text-3xl); font-weight: 700; }
.masthead-vs { color: var(--color-text-muted); font-weight: 500; }

.masthead-meta-strip {
  display: grid;
  grid-template-columns: repeat(5, auto);
  gap: var(--space-6);
  align-items: center;
}
.masthead-meta-strip .meta-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
  text-align: right;
}
.masthead-meta-strip .meta-label {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 600;
}
.masthead-meta-strip .meta-val {
  font-family: var(--font-display, var(--font-sans));
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--color-text);
  line-height: 1;
  letter-spacing: -.02em;
}
.masthead-lede {
  margin: 0;
  max-width: 80ch;
  color: var(--color-text-muted);
  font-size: var(--text-base);
  line-height: 1.6;
}
.masthead-lede b { color: var(--color-text); }

/* ============================================================
   BREADCRUMBS
   ============================================================ */
.site-breadcrumbs {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-5);
}
.site-breadcrumbs a {
  color: var(--color-text-muted);
  font-weight: 500;
}
.site-breadcrumbs a:hover { color: var(--color-accent); }
.site-breadcrumbs .sep { color: var(--color-text-faint); }
.site-breadcrumbs .current { color: var(--color-text); font-weight: 600; }

/* ============================================================
   TABS BAR (использует .avds-pill-tabs)
   ============================================================ */
.tabbar-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}
.tabbar-row .avds-pill-tabs {
  flex: 0 0 auto;
}
#status-badge {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
}

/* ============================================================
   TABPANELS
   ============================================================ */
.tabpanel { display: none; }
.tabpanel.active { display: block; }

/* ============================================================
   PAGE HEADER tweaks (avds-page-header)
   ============================================================ */
.avds-page-header h2 {
  font-size: var(--text-2xl);
  margin: var(--space-2) 0 var(--space-2);
}
.avds-page-header__subtitle {
  margin: 0;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  line-height: 1.55;
  max-width: 80ch;
}
.avds-page-header .avds-export-bar {
  flex: 0 0 auto;
  margin-top: 0;
  margin-left: auto;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-2);
}

/* ============================================================
   INPUT (поверх DS)
   ============================================================ */
.ds-input {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  padding: 8px 12px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--color-text);
  transition: border-color var(--motion-duration-fast), box-shadow var(--motion-duration-fast);
  min-width: 220px;
}
.ds-input:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px var(--color-accent-subtle);
}

/* ============================================================
   OVERVIEW — KPI grid + cards + phases
   ============================================================ */
.avds-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--space-3);
  margin: var(--space-3) 0 var(--space-8);
}
.avds-kpi-grid .avds-stat-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5);
  text-align: left;
}
.avds-kpi-grid .avds-stat-card__value {
  font-family: var(--font-display, var(--font-sans));
  font-size: var(--text-2xl);
  font-weight: 700;
  letter-spacing: -.02em;
  color: var(--color-accent);
  line-height: 1;
}
.avds-kpi-grid .avds-stat-card__label {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--color-text-muted);
  margin-top: var(--space-2);
}

.overview-fwcards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}
.overview-card {
  display: flex !important;
  align-items: flex-start !important;
  gap: var(--space-4) !important;
  padding: var(--space-5) var(--space-5) !important;
  min-height: 0 !important;
}
.overview-card .card-badge {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: .08em;
  padding: 4px 10px;
  border-radius: var(--radius-full);
  flex-shrink: 0;
}
.overview-card .card-badge.red {
  background: var(--p-rose-500); color: #fff;
}
.overview-card .card-badge.blue {
  background: var(--p-blue-600); color: #fff;
}
.overview-card .card-title {
  font-weight: 600;
  font-size: var(--text-lg);
  color: var(--color-text);
  margin-bottom: var(--space-2);
}
.overview-card .card-desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.5;
  margin-bottom: var(--space-3);
}
.overview-card .card-cta {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-accent);
}
.overview-card--red:hover { border-color: var(--p-rose-500) !important; background: #fff5f5 !important; }
.overview-card--blue:hover { border-color: var(--p-blue-600) !important; background: var(--color-accent-subtle) !important; }

/* Phases list */
.phase-list {
  list-style: none; padding: 0; margin: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-3);
  margin-bottom: var(--space-8);
  counter-reset: phase;
}
.phase-list li {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-left: 3px solid var(--color-accent);
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5);
  position: relative;
  counter-increment: phase;
}
.phase-list li::before {
  content: counter(phase);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--color-accent);
  position: absolute;
  top: var(--space-3);
  right: var(--space-4);
  background: var(--color-accent-subtle);
  width: 22px; height: 22px;
  border-radius: var(--radius-full);
  display: flex; align-items: center; justify-content: center;
}
.phase-list .ph-name {
  font-weight: 600;
  font-size: var(--text-base);
  margin-bottom: var(--space-2);
  padding-right: 28px;
}
.phase-list .ph-sum {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.5;
}

/* ============================================================
   MATRIX (Red & Blue)
   ============================================================ */
.matrix-wrap {
  overflow-x: auto;
  margin-top: var(--space-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
}
.matrix {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(180px, 1fr);
  gap: 0;
}
.matrix-col {
  display: flex;
  flex-direction: column;
  border-right: 1px solid var(--color-border);
  min-width: 0;
}
.matrix-col:last-child { border-right: none; }

.matrix-col-head {
  padding: var(--space-3) var(--space-4);
  background: #0f141c;
  color: #fff;
  border-bottom: 2px solid #2563eb;
  position: sticky;
  top: 0;
  z-index: 1;
  cursor: default;
}
.matrix-col-head .mc-id {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  color: #93c5fd;
  font-weight: 600;
  letter-spacing: .04em;
  display: block;
  margin-bottom: 3px;
}
.matrix-col-head {
  font-size: var(--text-sm);
  font-weight: 600;
  line-height: 1.3;
}

.matrix-cell {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-divider, #f1f5f9);
  cursor: pointer;
  transition: background var(--motion-duration-fast);
  font-size: var(--text-sm);
  position: relative;
  border-left: 2px solid transparent;
}
.matrix-cell:hover { background: var(--color-accent-subtle, #eff6ff); }
.matrix-cell .mc-id {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  color: var(--color-text-faint, #94a3b8);
  font-weight: 500;
  display: block;
  margin-bottom: 3px;
  letter-spacing: .04em;
}
.matrix-cell .mc-name {
  font-weight: 500;
  color: var(--color-text);
  line-height: 1.35;
  display: block;
  word-break: break-word;
  overflow-wrap: anywhere;
}
.matrix-cell.hidden { display: none; }

.matrix-cell.subtech { padding-left: var(--space-7); }
.matrix-cell.subtech::before {
  content: '↳';
  position: absolute;
  left: var(--space-4);
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-text-faint);
  font-size: var(--text-xs);
  font-weight: 500;
}
.matrix-cell.subtech .mc-id { color: var(--color-text-muted); }

/* Red/Blue tinting */
.tabpanel[data-panel="red"] .matrix-cell:hover { border-left-color: var(--p-rose-500); }
.tabpanel[data-panel="blue"] .matrix-cell:hover { border-left-color: var(--p-blue-600); }

/* ---- Heatmap ---- */
.matrix-cell.heat-on.h1 { background: #fef2f2; border-left-color: #fecaca; }
.matrix-cell.heat-on.h2 { background: #fee2e2; border-left-color: #fca5a5; }
.matrix-cell.heat-on.h3 { background: #fecaca; border-left-color: #f87171; }
.matrix-cell.heat-on.h4 { background: #fca5a5; border-left-color: #ef4444; }
.matrix-cell.heat-on.h5 {
  background: #ef4444;
  border-left-color: #b91c1c;
  color: #fff;
}
.matrix-cell.heat-on.h5 .mc-id,
.matrix-cell.heat-on.h5 .mc-name { color: #fff; }
.matrix-cell .heat-count {
  position: absolute;
  top: 4px; right: 6px;
  background: var(--color-text);
  color: #fff;
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  padding: 1px 6px;
  border-radius: var(--radius-full);
  font-weight: 700;
  line-height: 1.2;
}
.matrix-cell.heat-on.h5 .heat-count { background: #fff; color: #b91c1c; }

#red-heatmap-toggle.active {
  background: var(--p-rose-500);
  color: #fff;
  border-color: var(--p-rose-600);
}
#red-heatmap-toggle.active .dot { background: #fff; }
#red-heatmap-toggle .dot {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--p-rose-500);
}

.matrix-legend {
  margin: var(--space-3) 0;
  padding: var(--space-3) var(--space-4);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
  font-size: var(--text-sm);
}
.legend-label { font-weight: 600; color: var(--color-text); }
.legend-scale {
  display: flex;
  align-items: center;
  gap: 1px;
  flex: 1 1 240px;
  max-width: 360px;
  border-radius: var(--radius-sm);
  overflow: hidden;
}
.legend-scale .ls {
  flex: 1 1 0;
  padding: 6px 8px;
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  text-align: center;
  font-weight: 700;
}
.legend-scale .ls.h1 { background: #fef2f2; color: #b91c1c; }
.legend-scale .ls.h2 { background: #fee2e2; }
.legend-scale .ls.h3 { background: #fecaca; }
.legend-scale .ls.h4 { background: #fca5a5; color: #fff; }
.legend-scale .ls.h5 { background: #ef4444; color: #fff; }
.legend-hint { color: var(--color-text-muted); font-size: var(--text-sm); margin-left: auto; }

/* ============================================================
   EXPORT BUTTONS — кастомные dot, primary
   ============================================================ */
.avds-export-btn {
  font-size: var(--text-sm);
}
.pb-btn-primary {
  background: var(--color-accent) !important;
  color: #fff !important;
  border-color: var(--color-accent) !important;
}
.pb-btn-primary:hover {
  background: var(--color-accent-hover, #1d4ed8) !important;
  color: #fff !important;
}

/* ============================================================
   SEARCH (avds-search-hero overrides)
   ============================================================ */
.avds-search-hero {
  margin-bottom: var(--space-5);
}
.avds-search-hero__input {
  width: 100%;
  padding: 14px 16px 14px 46px;
  font-size: var(--text-base);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
  font-family: var(--font-sans);
  transition: border-color var(--motion-duration-fast), box-shadow var(--motion-duration-fast);
}
.avds-search-hero__input:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px var(--color-accent-subtle);
}
.avds-search-hero__filters {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
}

.search-type-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: var(--text-sm);
  cursor: pointer;
  background: var(--color-surface);
  user-select: none;
  transition: all var(--motion-duration-fast);
}
.search-type-chip input { display: none; }
.search-type-chip:has(input:checked) {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: #fff;
}
.search-type-chip:hover { border-color: var(--color-accent); }
.search-type-chip:has(input:checked):hover {
  background: var(--color-accent-hover, #1d4ed8);
}

.popular-q {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  padding: 4px 10px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  background: var(--color-surface);
  cursor: pointer;
  color: var(--color-text-muted);
  transition: all var(--motion-duration-fast);
}
.popular-q:hover {
  background: var(--color-accent-subtle);
  border-color: var(--color-accent);
  color: var(--color-accent);
}

.search-results {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-2);
  margin-top: var(--space-4);
}
.result {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  cursor: pointer;
  transition: all var(--motion-duration-fast);
}
.result:hover {
  border-color: var(--color-accent);
  background: var(--color-accent-subtle);
}
.result-h {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-1);
  flex-wrap: wrap;
}
.result-id {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  font-weight: 600;
}
.result-name {
  font-weight: 600;
  color: var(--color-text);
  flex: 1;
  min-width: 0;
}
.result-type {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  background: var(--color-accent-subtle);
  color: var(--color-accent);
  font-weight: 600;
}
.result-type.tech { background: #fee2e2; color: #b91c1c; }
.result-type.counter { background: #dbeafe; color: #1d4ed8; }
.result-type.incident { background: #fef3c7; color: #92400e; }
.result-type.tactic { background: #ede9fe; color: #6d28d9; }
.result-type.tool { background: #cffafe; color: #155e75; }
.result-type.detection { background: #d1fae5; color: #047857; }
.result-type.task { background: #fce7f3; color: #be185d; }

.result-summary {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.5;
}

.pb-empty {
  text-align: center;
  padding: var(--space-8) var(--space-4);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  font-style: italic;
}

/* ============================================================
   INCIDENTS
   ============================================================ */
.incident-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--space-3);
}
.incident-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  cursor: pointer;
  transition: all var(--motion-duration-fast);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.incident-card:hover {
  border-color: var(--color-accent);
  box-shadow: 0 4px 12px rgba(15, 23, 41, 0.08);
}
.incident-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
}
.incident-id {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  color: var(--color-text-muted);
  font-weight: 600;
}
.incident-year, .incident-country {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  font-weight: 600;
}
.incident-year { background: #fef3c7; color: #92400e; }
.incident-country { background: #ede9fe; color: #6d28d9; }
.incident-name {
  font-weight: 600;
  font-size: var(--text-base);
  line-height: 1.35;
  color: var(--color-text);
}
.incident-summary {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.5;
}
.incident-techs {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: var(--space-2);
  padding-top: var(--space-2);
  border-top: 1px solid var(--color-divider, #f1f5f9);
}
.incident-tech-tag {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  padding: 2px 6px;
  background: #fee2e2;
  color: #991b1b;
  border-radius: var(--radius-sm);
  font-weight: 600;
}

/* ============================================================
   PLAYBOOK
   ============================================================ */
.pb-coverage-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-6);
  padding: var(--space-4) var(--space-5);
  background: var(--color-accent-subtle, #eff6ff);
  border: 1px solid #bfdbfe;
  border-radius: var(--radius-md);
  margin: var(--space-2) 0 var(--space-5);
  font-size: var(--text-sm);
}
.pb-coverage-bar.empty {
  color: var(--color-text-muted);
  background: var(--color-surface);
  border-color: var(--color-border);
  font-style: italic;
  padding: var(--space-3) var(--space-5);
}
.cov-stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.cov-num {
  font-family: var(--font-display, var(--font-sans));
  font-weight: 700;
  font-size: var(--text-xl);
  color: var(--color-accent);
  line-height: 1;
  letter-spacing: -.02em;
}
.cov-lbl {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: .06em;
  font-weight: 600;
}
.cov-bar {
  flex: 1 1 200px;
  height: 8px;
  background: #dbeafe;
  border-radius: var(--radius-full);
  overflow: hidden;
  min-width: 160px;
}
.cov-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, #3b82f6, #2563eb);
  transition: width 360ms var(--motion-ease-standard);
}

.playbook-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-5);
}
.pb-col {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  min-height: 480px;
}
.pb-col-head h4 {
  margin: var(--space-1) 0 0;
  font-size: var(--text-base);
}
.pb-list, .pb-counters {
  flex: 1 1 auto;
  overflow-y: auto;
  max-height: 600px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.pb-list-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background var(--motion-duration-fast);
  font-size: var(--text-sm);
}
.pb-list-item:hover { background: var(--color-bg, #f8fafc); }
.pb-list-item.selected {
  background: var(--color-accent-subtle);
}
.pb-list-item input[type=checkbox] {
  flex-shrink: 0;
  margin: 0;
  accent-color: var(--color-accent);
}
.pb-list-item .pb-id,
.pb-counter-item .pb-id {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  color: var(--color-text-muted);
  font-weight: 600;
  flex-shrink: 0;
  min-width: 56px;
}
.pb-list-item .pb-name,
.pb-counter-item .pb-name {
  flex: 1;
  min-width: 0;
  color: var(--color-text);
}

.pb-counter-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background var(--motion-duration-fast);
  font-size: var(--text-sm);
}
.pb-counter-item:hover { background: var(--color-accent-subtle); }
.pb-counter-item .pb-coverage {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  background: var(--color-accent);
  color: #fff;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  font-weight: 700;
  flex-shrink: 0;
}

/* ============================================================
   MODAL
   ============================================================ */
.modal { position: fixed; inset: 0; z-index: 100; display: block; }
.modal[hidden] { display: none; }
.modal-backdrop {
  position: absolute; inset: 0;
  background: rgba(15, 23, 41, 0.5);
  backdrop-filter: blur(4px);
}
.modal-card {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  width: min(720px, calc(100% - 32px));
  max-height: calc(100vh - 64px);
  overflow-y: auto;
  box-shadow: 0 24px 64px rgba(15, 23, 41, 0.32);
  padding: var(--space-6);
}
.modal-close {
  position: absolute;
  top: var(--space-3); right: var(--space-3);
  width: 32px; height: 32px;
  border: none;
  background: transparent;
  font-size: var(--text-2xl);
  cursor: pointer;
  color: var(--color-text-muted);
  border-radius: var(--radius-sm);
  display: flex; align-items: center; justify-content: center;
  line-height: 1;
}
.modal-close:hover { background: var(--color-bg, #f1f5f9); color: var(--color-text); }

.obj-id {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  font-weight: 600;
  letter-spacing: .04em;
  margin-bottom: var(--space-1);
}
.modal-body h2 {
  font-size: var(--text-2xl);
  margin: 0 0 var(--space-3);
}
.obj-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
  align-items: center;
}
.obj-meta .avds-chip,
.modal-body .avds-chip {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  background: var(--color-bg, #f1f5f9);
  color: var(--color-text-muted);
  border: 1px solid var(--color-border);
  font-weight: 500;
}
.obj-meta .avds-chip.chip-warn {
  background: #fff7ed;
  color: #c2410c;
  border-color: #fed7aa;
}
.obj-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin: var(--space-3) 0;
  padding: var(--space-3) 0;
  border-top: 1px solid var(--color-divider, #f1f5f9);
  border-bottom: 1px solid var(--color-divider, #f1f5f9);
}
.obj-summary {
  font-size: var(--text-base);
  line-height: 1.6;
  color: var(--color-text);
  margin-bottom: var(--space-4);
}
.obj-section {
  margin-top: var(--space-5);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-divider, #f1f5f9);
}
.obj-section h4 {
  font-size: var(--text-base);
  margin-bottom: var(--space-3);
}
.obj-link-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.obj-link {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: 6px 10px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: var(--text-sm);
  transition: background var(--motion-duration-fast);
}
.obj-link:hover { background: var(--color-accent-subtle); }
.obj-link-id {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  color: var(--color-text-muted);
  min-width: 64px;
  font-weight: 600;
}
.obj-link-name {
  flex: 1;
  min-width: 0;
  color: var(--color-text);
}

/* ============================================================
   ABOUT
   ============================================================ */
.about-content {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-6) var(--space-8);
  max-width: 80ch;
}
.about-content h3 {
  margin-top: var(--space-6);
  margin-bottom: var(--space-3);
  font-size: var(--text-lg);
}
.about-content h3:first-child { margin-top: 0; }
.about-content p {
  margin: 0 0 var(--space-3);
  line-height: 1.7;
  color: var(--color-text);
}
.about-content .object-list {
  margin: 0 0 var(--space-4);
  padding-left: var(--space-5);
  line-height: 1.7;
}
.about-content .object-list li { margin-bottom: var(--space-2); }
.links-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: var(--space-3);
  margin-top: var(--space-5);
  max-width: none;
}

/* avds-tool-card override */
.avds-tool-card .card-title {
  font-weight: 600;
  font-size: var(--text-base);
  color: var(--color-text);
  margin-bottom: var(--space-1);
}
.avds-tool-card .card-desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
  margin-top: var(--space-8);
  padding: var(--space-8) 0 var(--space-6);
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
  align-items: start;
}
.footer-brand {
  font-family: var(--font-display, var(--font-sans));
  font-weight: 700;
  font-size: var(--text-lg);
  color: var(--color-text);
  margin-bottom: var(--space-2);
}
.footer-meta {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-3);
}
.footer-links {
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
}
.footer-links a {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  text-decoration: underline;
  text-decoration-color: var(--color-border);
  text-underline-offset: 3px;
}
.footer-links a:hover {
  color: var(--color-accent);
  text-decoration-color: var(--color-accent);
}
.footer-col-title {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--color-text-muted);
  margin-bottom: var(--space-3);
}
.ecosystem-nav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2) var(--space-5);
}
.ecosystem-nav a {
  font-size: var(--text-sm);
  color: var(--color-text);
  padding: 4px 0;
  border-bottom: 1px solid transparent;
  transition: all var(--motion-duration-fast);
  width: fit-content;
}
.ecosystem-nav a:hover {
  color: var(--color-accent);
  border-bottom-color: var(--color-accent);
}
.ecosystem-nav a[aria-current=page] {
  color: var(--color-accent);
  font-weight: 600;
  border-bottom-color: var(--color-accent);
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px) {
  .overview-fwcards,
  .playbook-grid,
  .footer-grid {
    grid-template-columns: 1fr;
  }
  .masthead-meta-strip { grid-template-columns: repeat(5, 1fr); }
}

@media (max-width: 760px) {
  .container { padding: 0 var(--space-4); }
  .site-masthead { padding-top: var(--space-6); }
  .masthead-brand-row { flex-direction: column; align-items: flex-start; }
  .masthead-meta-strip {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-3) var(--space-5);
    width: 100%;
  }
  .masthead-meta-strip .meta-item { text-align: left; }
  .tabbar-row { flex-direction: column; align-items: stretch; gap: var(--space-3); }
  .avds-page-header { flex-direction: column; align-items: stretch; }
  .avds-page-header .avds-export-bar { margin-left: 0; width: 100%; }
  .avds-page-header .avds-export-bar .ds-input { flex: 1 1 auto; min-width: 0; }
  .matrix-wrap { overflow-x: visible; border: none; background: transparent; }
  .matrix { display: block; }
  .matrix-col {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-3);
    background: var(--color-surface);
    overflow: hidden;
  }
  .matrix-col-head {
    cursor: pointer;
    user-select: none;
    position: relative;
    padding-right: var(--space-8);
  }
  .matrix-col-head::after {
    content: '▾';
    position: absolute;
    right: var(--space-4);
    top: 50%;
    transform: translateY(-50%);
    transition: transform var(--motion-duration-fast);
  }
  .matrix-col.collapsed .matrix-col-head::after { transform: translateY(-50%) rotate(-90deg); }
  .matrix-col.collapsed .matrix-cell { display: none; }
  .ecosystem-nav { grid-template-columns: 1fr; }
}

/* =============================================================
   Annotations panel (in modal)
   ============================================================= */
.ann-panel {
  margin-top: var(--space-5);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  overflow: hidden;
}
.ann-summary {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  cursor: pointer;
  user-select: none;
  background: var(--color-surface-alt, #f8fafc);
}
.ann-summary::-webkit-details-marker { display: none; }
.ann-summary::before {
  content: '▸';
  display: inline-block;
  margin-right: var(--space-2);
  color: var(--color-text-muted);
  transition: transform 120ms ease;
}
.ann-panel[open] > .ann-summary::before { transform: rotate(90deg); }
.ann-summary__label {
  font-weight: 600;
  font-size: var(--text-sm);
  color: var(--color-text);
  flex: 1;
}
.ann-summary__hint {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}
.ann-body {
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.ann-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  flex: 1 1 auto;
  min-width: 0;
}
.ann-field__label {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: .04em;
}
.ann-note {
  resize: vertical;
  min-height: 64px;
  font-family: inherit;
  font-size: var(--text-sm);
  line-height: 1.45;
}
.ann-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  align-items: flex-start;
}
.ann-field--score { flex: 1 1 240px; }
.ann-field--color { flex: 0 0 auto; }
.ann-score {
  width: 100%;
  accent-color: var(--p-blue-600, #3b82f6);
}
.ann-score-value {
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  color: var(--color-text);
}
.ann-swatches {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.ann-swatch {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 2px solid var(--color-border);
  background: var(--color-surface);
  cursor: pointer;
  padding: 0;
  transition: transform 120ms ease, box-shadow 120ms ease;
  position: relative;
}
.ann-swatch:hover { transform: scale(1.1); }
.ann-swatch.is-selected {
  box-shadow: 0 0 0 2px var(--color-surface), 0 0 0 4px var(--p-blue-600, #3b82f6);
}
.ann-swatch--clear {
  background:
    linear-gradient(45deg, transparent 45%, var(--p-rose-500, #f43f5e) 45%, var(--p-rose-500, #f43f5e) 55%, transparent 55%);
  background-size: 100% 100%;
}
.ann-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-3);
  margin-top: var(--space-2);
}
.ann-clear {
  font-size: var(--text-xs);
  padding: 6px 12px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text-muted);
  cursor: pointer;
  transition: background 120ms ease, color 120ms ease;
}
.ann-clear:hover { background: var(--p-rose-50, #fff1f2); color: var(--p-rose-600, #e11d48); }
.ann-saved-hint {
  font-size: var(--text-xs);
  color: var(--p-emerald-600, #059669);
  opacity: 0;
  transition: opacity 200ms ease;
}
.ann-saved-hint.is-visible { opacity: 1; }

/* =============================================================
   Annotation indicator on matrix cells
   ============================================================= */
.matrix-cell.has-score {
  background: var(--ann-tint);
}
.matrix-cell .ann-dot {
  position: absolute;
  top: 6px;
  right: 8px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.6);
  box-shadow: 0 0 0 1px rgba(0,0,0,.08);
  pointer-events: none;
}
.matrix-cell.has-ann {
  border-left-color: var(--p-amber-500, #f59e0b);
}
