/* ─── Reset & Base ─────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:          #080720;
  --bg-card:     #13123a;
  --bg-card-alt: #1c1a50;
  --border:      rgba(255,255,255,.1);
  --accent:      #2763e1;
  --accent-2:    #4f8ef7;
  --success:     #22c55e;
  --warning:     #eab308;
  --danger:      #ef4444;
  --text:        #e8eaf6;
  --text-muted:  #8b93b8;
  --nav-h:       60px;
  --radius:      12px;
  --shadow:      0 4px 32px rgba(0,0,0,.6);
  --font:        'Inter', system-ui, -apple-system, sans-serif;
}

html { font-size: 16px; scroll-behavior: smooth; }

body {
  font-family: var(--font);
  background: var(--bg);
  background-image:
    radial-gradient(ellipse 80% 50% at 20% 10%, rgba(39,99,225,.18) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 80% 80%, rgba(79,142,247,.1) 0%, transparent 55%);
  color: var(--text);
  min-height: 100vh;
}

a { color: inherit; text-decoration: none; }

/* ─── Top Nav ────────────────────────────────────────────────────── */
.topnav {
  position: sticky; top: 0; z-index: 100;
  height: var(--nav-h);
  background: rgba(2,0,62,.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 0;
  padding: 0 2rem;
}

.topnav__logo {
  display: flex; align-items: center; gap: .6rem;
  font-weight: 700; font-size: 1.1rem; letter-spacing: -.3px;
  margin-right: 2.5rem;
}

.topnav__logo-icon {
  width: 32px; height: 32px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: .9rem;
}

.topnav__links { display: flex; gap: .25rem; }

.topnav__link {
  padding: .45rem .9rem;
  border-radius: 8px;
  font-size: .9rem;
  color: var(--text-muted);
  transition: background .15s, color .15s;
  cursor: pointer;
}

.topnav__link:hover, .topnav__link.router-link-active {
  background: var(--bg-card);
  color: var(--text);
}

.topnav__link.router-link-active { color: var(--accent); }


/* ═══════════════════════════════════════════════════════════════
   Coverage Matrix  —  faithful replica of the original design
   blue-dark: #02003e  |  blue-light: #16164d  |  blue-select: #2763e1
   ═══════════════════════════════════════════════════════════════ */

.cm-root {
  display: flex; flex-direction: column;
  flex: 1; overflow: hidden; min-height: 0;
  background: #02003e;
  color: #fff;
  font-family: var(--font);
}

/* ── Header (Sportradar logo + Media API Coverage Matrix) ─────── */
.cm-header {
  flex-shrink: 0;
  background: #16164d;
  padding: .65rem 1.5rem .65rem 2rem;
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem;
}
.cm-header__logos {
  display: flex; align-items: center; gap: 1.75rem;
}
.cm-header__sr-logo {
  height: 30px; width: auto;
}
.cm-header__cm-logo {
  height: 26px; width: auto;
}

/* ── Top bar (logo + title area) ─────────────────────────────── */
.cm-topbar {
  flex-shrink: 0;
  background: #16164d;
  padding: .6rem 1.5rem .6rem 2rem;
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem;
}

.cm-topbar__brand {
  display: flex; align-items: center; gap: 1.25rem;
}

.cm-topbar__logo {
  display: flex; align-items: center; gap: .5rem;
  font-weight: 800; font-size: 1rem; letter-spacing: -.2px; color: #fff;
}

.cm-topbar__logo-mark {
  width: 28px; height: 28px;
  background: linear-gradient(135deg,#4f8ef7,#7c5af5);
  border-radius: 6px; display: flex; align-items: center; justify-content: center;
  font-size: .85rem;
}

.cm-topbar__title {
  font-size: 1.5rem; font-weight: 800; color: #fff; letter-spacing: -.3px;
}

.cm-topbar__export {
  background: transparent; border: none; color: #fff;
  cursor: pointer; display: flex; align-items: center; gap: .4rem;
  font-size: .85rem; font-family: var(--font);
  opacity: .75; transition: opacity .15s;
}
.cm-topbar__export:hover { opacity: 1; }

/* Export dropdown menu */
.cm-export-menu {
  position: absolute; top: 100%; right: 0; margin-top: .4rem;
  background: #1e1e4a; border: 1px solid rgba(255,255,255,.15);
  border-radius: 10px; padding: .35rem; min-width: 260px;
  box-shadow: 0 8px 32px rgba(0,0,0,.5); z-index: 100;
}
.cm-export-menu__item {
  display: flex; align-items: center; gap: .5rem;
  width: 100%; padding: .6rem .75rem; border: none;
  background: transparent; color: rgba(255,255,255,.85);
  font-size: .85rem; font-family: var(--font);
  border-radius: 7px; cursor: pointer; text-decoration: none;
  transition: background .15s;
}
.cm-export-menu__item:hover {
  background: rgba(255,255,255,.1); color: #fff;
}

/* ── Controls bar ────────────────────────────────────────────── */
.cm-controls {
  flex-shrink: 0;
  background: #02003e;
  padding: .75rem 2rem 1rem;
  display: flex; flex-wrap: wrap; align-items: flex-end; gap: 1rem;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.cm-control-group {
  display: flex; flex-direction: column; gap: .25rem;
}
.cm-control-group--grow { flex: 1; min-width: 180px; }

.cm-label {
  font-size: .7rem; color: #9ca3af; letter-spacing: .07em; text-transform: uppercase;
}

/* Red package select — matches original bg-red-700 */
.cm-select--pkg {
  background: #b91c1c; color: #fff;
  border: none; border-radius: 4px;
  padding: .4rem .65rem; font-size: .85rem; cursor: pointer; outline: none;
}
.cm-select--pkg:focus { box-shadow: 0 0 0 2px #f87171; }

/* Slate tier select — matches original bg-slate-500 */
.cm-select--tier {
  background: #64748b; color: #fff;
  border: none; border-radius: 4px;
  padding: .4rem .65rem; font-size: .85rem; cursor: pointer; outline: none;
}
.cm-select--tier:focus { box-shadow: 0 0 0 2px #94a3b8; }

.cm-input {
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15);
  color: #fff; border-radius: 4px;
  padding: .4rem .7rem; font-size: .85rem; outline: none; width: 100%;
}
.cm-input:focus { border-color: rgba(255,255,255,.4); }
.cm-input::placeholder { color: #9ca3af; }

/* ── Table wrapper ────────────────────────────────────────────── */
.cm-table-wrap {
  flex: 1; overflow: auto;
  background: #02003e; /* navy shows in right-padding area, rows have their own bg */
  padding-right: 1.5rem;
}

.cm-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .82rem;
}

/* ── Sticky header rows ──────────────────────────────────────── */
.cm-table thead { position: sticky; top: 0; z-index: 10; }

.cm-thead-labels {
  background: #02003e;
}

.cm-thead-filters {
  background: #02003e;
  border-bottom: 2px solid rgba(255,255,255,.12);
}

.cm-th {
  padding: .5rem .75rem;
  color: #fff; font-weight: 600; font-size: .82rem;
  vertical-align: bottom; white-space: nowrap;
  border-bottom: 1px solid rgba(255,255,255,.1);
  position: relative; text-align: left;
}

.cm-th--wide  { min-width: 130px; }
.cm-th--id    { min-width: 110px; font-size: .75rem; }
.cm-th--date  { min-width: 85px; }
.cm-th--cov   {
  min-width: 50px; max-width: 50px; width: 50px;
  padding: .5rem 0; text-align: center;
  border-left: 1px solid rgba(255,255,255,.1);
  vertical-align: bottom;
}

/* Coverage property labels — vertical writing mode (no overflow clipping issues) */
.cm-cov-label-wrap {
  display: flex; align-items: flex-end; justify-content: center;
  padding-bottom: 6px;
}
.cm-cov-label {
  writing-mode: vertical-rl;
  transform: rotate(210deg);
  white-space: nowrap;
  font-size: .72rem; font-weight: 600; color: #fff;
}

/* ── Tooltip ──────────────────────────────────────────────────── */
.cm-tooltip {
  display: none; position: absolute; z-index: 200;
  background: #000; border: 2px solid #6b7280;
  border-radius: 4px; padding: .4rem .6rem;
  font-size: .72rem; color: #d1d5db; font-weight: 400;
  white-space: normal; min-width: 200px; max-width: 200px;
  pointer-events: none;
  top: calc(100% + 2px); left: -150px;
}
.cm-th:hover .cm-tooltip { display: block; }

/* ── Sort arrows ─────────────────────────────────────────────── */
.cm-sort-arrows {
  display: inline-flex; flex-direction: column;
  vertical-align: middle; margin-left: 3px;
}
.cm-arrow {
  background: none; border: none; cursor: pointer;
  color: rgba(255,255,255,.3); font-size: .55rem; line-height: 1; padding: 0;
  transition: color .15s;
}
.cm-arrow:hover     { color: rgba(255,255,255,.7); }
.cm-arrow--active   { color: #4f8ef7 !important; }

/* ── Filter row cells ────────────────────────────────────────── */
.cm-td-filter {
  padding: 3px 2px; text-align: center; vertical-align: middle;
}
.cm-filter-cell {
  display: inline-flex; align-items: center; gap: 2px;
}

/* ── Coverage dot ────────────────────────────────────────────── */
.cm-dot {
  display: inline-block;
  width: 12px; height: 12px; border-radius: 50%;
  vertical-align: middle; flex-shrink: 0;
}
.cm-dot--green  { background: #22c55e; }
.cm-dot--yellow { background: #eab308; }
.cm-dot--red    { background: #ef4444; }
.cm-dot--none   { background: #fff; border: 1.5px solid #d1d5db; }

/* ── Property column header controls (sort + filter dropdown) ── */
.cm-th-controls {
  display: flex; align-items: center; justify-content: center; gap: 4px;
  margin-top: 3px;
}

/* ── Dot filter dropdown ─────────────────────────────────────── */
.cm-dot-dd { position: relative; display: inline-flex; }

.cm-dot-dd__trigger {
  background: none; border: 1px solid rgba(255,255,255,.2);
  border-radius: 4px; cursor: pointer;
  padding: 1px 3px; display: inline-flex; align-items: center; gap: 2px;
  transition: background .15s, border-color .15s;
}
.cm-dot-dd__trigger:hover { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.4); }
.cm-dot-dd__chevron { font-size: .65rem; color: rgba(255,255,255,.55); line-height: 1; }

.cm-dot-dd__menu {
  position: absolute; z-index: 300;
  top: calc(100% + 3px); left: 50%; transform: translateX(-50%);
  background: #fff; border: 1px solid #d1d5db;
  border-radius: 6px; overflow: hidden;
  box-shadow: 0 6px 16px rgba(0,0,0,.22);
  min-width: 110px;
}
.cm-dot-dd__item {
  display: flex; align-items: center; gap: .45rem;
  width: 100%; padding: .38rem .65rem;
  background: none; border: none;
  color: #111; font-size: .8rem; cursor: pointer; text-align: left;
  transition: background .12s;
}
.cm-dot-dd__item:hover         { background: #f3f4f6; }
.cm-dot-dd__item--active       { background: #eff6ff; font-weight: 600; }
.cm-dot-dd__label              { color: #374151; font-size: .78rem; }

/* ── Table body rows ─────────────────────────────────────────── */
.cm-row { border-bottom: 1px solid #e5e7eb; }
.cm-row:nth-child(even) { background: #f9fafb; }
.cm-row:nth-child(odd)  { background: #fff; }
.cm-row:hover           { background: #dbeafe; }

.cm-td {
  padding: .45rem .75rem;
  color: #111827; vertical-align: middle; white-space: nowrap;
}
.cm-td--name { white-space: normal; max-width: 200px; }
.cm-td--id   { font-size: .75rem; color: #111827; font-family: 'JetBrains Mono','Fira Mono',monospace; }
.cm-td--dot  { text-align: center; padding: .45rem 4px; border-left: 1px solid #e5e7eb; }

/* ── Loading / empty states ──────────────────────────────────── */
.cm-state-cell { padding: 3rem; text-align: center; color: #6b7280; }
.cm-loading { display: flex; flex-direction: column; align-items: center; gap: .75rem; }
.cm-spinner {
  width: 32px; height: 32px;
  border: 3px solid #e5e7eb; border-top-color: #4f8ef7;
  border-radius: 50%; animation: spin .7s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.cm-empty { font-size: .9rem; }

/* ── Footer ──────────────────────────────────────────────────── */
.cm-footer {
  flex-shrink: 0;
  background: #02003e;
  border-top: 1px solid rgba(255,255,255,.08);
  padding: .65rem 2rem;
  display: flex; flex-wrap: wrap; align-items: center;
  justify-content: space-between; gap: .75rem;
}

/* Pagination */
.cm-pagination {
  display: flex; align-items: center; gap: .4rem; flex-wrap: wrap;
}
.cm-pagination-info { color: #9ca3af; font-size: .8rem; }
.cm-pag-select {
  background: rgba(255,255,255,.1); color: #fff; border: 1px solid rgba(255,255,255,.2);
  border-radius: 4px; padding: .25rem .4rem; font-size: .8rem; cursor: pointer; outline: none;
}
.cm-page-btn {
  min-width: 28px; height: 28px; padding: 0 .4rem;
  border-radius: 5px; border: 1px solid rgba(255,255,255,.2);
  background: transparent; color: #d1d5db;
  font-size: .78rem; cursor: pointer;
  transition: background .15s, color .15s;
}
.cm-page-btn:hover:not(:disabled) { background: rgba(255,255,255,.1); color: #fff; }
.cm-page-btn--active { background: #2763e1; color: #fff; border-color: #2763e1; }
.cm-page-btn:disabled { opacity: .3; cursor: default; }
.cm-page-ellipsis { color: #9ca3af; padding: 0 .2rem; font-size: .8rem; }

/* Legend */
.cm-legend {
  display: flex; align-items: center; gap: 1rem; flex-wrap: wrap;
}
.cm-legend-item {
  display: flex; align-items: center; gap: .35rem;
  font-size: .78rem; color: #d1d5db;
}

/* ── Filter toggle button ─────────────────────────────────────── */
.cm-filter-toggle {
  display: flex; align-items: center; gap: .4rem;
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2);
  color: #fff; border-radius: 4px; padding: .35rem .75rem;
  font-size: .82rem; cursor: pointer; font-family: var(--font);
  transition: background .15s;
}
.cm-filter-toggle:hover { background: rgba(255,255,255,.18); }

.cm-filter-badge {
  background: #b91c1c; color: #fff;
  border-radius: 99px; font-size: .68rem; font-weight: 700;
  padding: .1rem .42rem; min-width: 16px; text-align: center;
}

/* ── Filter panel ────────────────────────────────────────────── */
.cm-filter-panel {
  flex-shrink: 0;
  background: #0e0c3a;
  border-bottom: 1px solid rgba(255,255,255,.1);
  padding: .85rem 2rem;
}
.cm-filter-panel__header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: .65rem;
}
.cm-filter-panel__title {
  font-size: .75rem; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; color: #9ca3af;
}
.cm-filter-clear {
  background: none; border: 1px solid rgba(255,255,255,.2);
  color: #9ca3af; border-radius: 4px; padding: .2rem .55rem;
  font-size: .75rem; cursor: pointer; transition: color .15s, border-color .15s;
}
.cm-filter-clear:hover { color: #fff; border-color: rgba(255,255,255,.5); }
.cm-filter-grid {
  display: flex; flex-wrap: wrap; gap: .5rem .75rem;
}
.cm-filter-item {
  display: flex; align-items: center; gap: .5rem;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 6px; padding: .3rem .55rem;
}
.cm-filter-item__label {
  font-size: .78rem; color: #d1d5db; white-space: nowrap; cursor: default;
}
.cm-filter-dots { display: flex; gap: 2px; }
.cm-fdot-btn {
  background: none; border: 2px solid transparent;
  border-radius: 50%; padding: 2px; cursor: pointer;
  display: flex; align-items: center; transition: border-color .12s;
}
.cm-fdot-btn:hover   { border-color: rgba(255,255,255,.3); }
.cm-fdot-btn--active { border-color: #4f8ef7 !important; }

/* ── Small dot ───────────────────────────────────────────────── */
.cm-dot--sm { width: 9px; height: 9px; }

/* ── Dot strip ───────────────────────────────────────────────── */
.cm-td--strip { padding: .45rem .75rem; }
.cm-dot-strip {
  display: flex; flex-wrap: wrap; gap: 3px; align-items: center;
  max-width: 300px;
}

/* ── Chevron ─────────────────────────────────────────────────── */
.cm-td--chevron { padding: 0 .35rem 0 .6rem; text-align: center; }
.cm-chevron {
  display: inline-block; font-size: 1rem; color: #9ca3af;
  line-height: 1; transition: transform .18s;
}
.cm-chevron--open { transform: rotate(90deg); color: #4f8ef7; }

/* ── Expanded detail row ─────────────────────────────────────── */
.cm-row-detail { background: #eef2ff !important; }
.cm-row-detail:hover { background: #eef2ff !important; }

.cm-detail-cell {
  padding: .75rem 1rem 1rem 2.5rem !important;
  border-bottom: 2px solid #c7d2fe;
}

.cm-detail-panel { animation: fadeUp .15s ease; }

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}

.cm-detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(155px, 1fr));
  gap: .35rem .6rem;
}

.cm-detail-item {
  display: flex; align-items: center; gap: .45rem;
  padding: .3rem .5rem;
  background: #fff; border: 1px solid #e0e7ff; border-radius: 6px;
}
.cm-detail-item__text { display: flex; flex-direction: column; min-width: 0; }
.cm-detail-item__name {
  font-size: .77rem; font-weight: 600; color: #374151;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.cm-detail-item__val { font-size: .68rem; color: #9ca3af; margin-top: 1px; }


/* ── View toggle (Compact / Classic) ─────────────────────────── */
.cm-view-toggle {
  display: flex; align-items: center;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 6px; overflow: hidden;
}
.cm-view-btn {
  background: none; border: none;
  color: rgba(255,255,255,.6); font-family: var(--font);
  font-size: .8rem; font-weight: 500;
  padding: .3rem .75rem; cursor: pointer;
  transition: background .15s, color .15s;
  white-space: nowrap;
}
.cm-view-btn:first-child { border-right: 1px solid rgba(255,255,255,.15); }
.cm-view-btn:hover { background: rgba(255,255,255,.1); color: #fff; }
.cm-view-btn--active { background: #2763e1; color: #fff; }

/* ── Filter modal ────────────────────────────────────────────── */
.cm-modal-backdrop {
  position: absolute; inset: 0; z-index: 300;
  display: flex; align-items: flex-start; justify-content: flex-end;
  padding: 3.5rem 1.5rem 0 0;
  pointer-events: none;
}
.cm-modal {
  pointer-events: all;
  background: #16164d;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 10px;
  width: min(560px, 94vw);
  max-height: calc(100vh - 200px);
  display: flex; flex-direction: column;
  box-shadow: 0 8px 40px rgba(0,0,0,.6);
  overflow: hidden;
}
.cm-modal__header {
  display: flex; align-items: center; justify-content: space-between;
  padding: .85rem 1.1rem;
  border-bottom: 1px solid rgba(255,255,255,.1);
  background: #1c1a5e;
  flex-shrink: 0;
}
.cm-modal__title {
  font-size: .85rem; font-weight: 700; color: #fff; letter-spacing: .02em;
}
.cm-modal__close {
  background: none; border: 1px solid rgba(255,255,255,.2);
  color: rgba(255,255,255,.7); border-radius: 5px;
  width: 26px; height: 26px; cursor: pointer; font-size: .8rem;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s;
}
.cm-modal__close:hover { background: rgba(255,255,255,.1); color: #fff; }
.cm-modal__body {
  padding: .85rem 1.1rem;
  overflow-y: auto;
}
.cm-modal__sort-info {
  margin-top: .85rem;
  padding-top: .75rem;
  border-top: 1px solid rgba(255,255,255,.08);
  font-size: .8rem; color: #9ca3af;
}
.cm-modal__sort-info strong { color: #e8eaf6; }

/* Modal transition */
.cm-modal-fade-enter-active, .cm-modal-fade-leave-active {
  transition: opacity .15s, transform .15s;
}
.cm-modal-fade-enter-from, .cm-modal-fade-leave-to {
  opacity: 0; transform: translateY(-6px);
}
