:root {
  --bg: #070809;
  --panel: #111417;
  --panel-2: #171b20;
  --line: #2a3038;
  --text: #f7f7f4;
  --muted: #a5adb8;
  --soft: #d9dee5;
  --orange: #ff6a00;
  --orange-2: #ff8a2a;
  --green: #30d158;
  --red: #ff4d4f;
  --shadow: 0 18px 60px rgba(0, 0, 0, .35);
}

* { box-sizing: border-box; }

* {
  scrollbar-width: thin;
  scrollbar-color: rgba(255,106,0,.42) rgba(255,255,255,.045);
}

*::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

*::-webkit-scrollbar-track {
  background: rgba(255,255,255,.035);
  border-radius: 999px;
}

*::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, rgba(255,106,0,.52), rgba(145,151,164,.42));
  border: 2px solid rgba(10,12,15,.85);
  border-radius: 999px;
}

*::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, rgba(255,145,48,.82), rgba(190,198,214,.62));
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:
    linear-gradient(120deg, rgba(255, 106, 0, .12), transparent 34%),
    radial-gradient(circle at 70% 10%, rgba(255, 255, 255, .06), transparent 26%),
    var(--bg);
  color: var(--text);
}

button, input, select {
  font: inherit;
}

button {
  border: 1px solid var(--line);
  background: #1d2229;
  color: var(--text);
  border-radius: 8px;
  min-height: 40px;
  padding: 9px 12px;
  cursor: pointer;
  transition: border-color .18s ease, background .18s ease, transform .18s ease, box-shadow .18s ease;
}

button:hover {
  border-color: rgba(255, 106, 0, .75);
  background: #242a32;
}

button.primary {
  background: var(--orange);
  color: #120a03;
  border-color: var(--orange);
  font-weight: 800;
}

button.accent {
  background: linear-gradient(180deg, #ffb15f, #ff7a16);
  border-color: #ff9a3d;
  color: #120a03;
  font-weight: 900;
  box-shadow: 0 8px 24px rgba(255,106,0,.22);
}

button.accent:hover {
  background: linear-gradient(180deg, #ffc27a, #ff8424);
  box-shadow: 0 10px 30px rgba(255,106,0,.34);
}

.icon-button {
  width: 42px;
  height: 42px;
  min-height: 42px;
  padding: 0;
  display: inline-grid;
  place-items: center;
}

.icon-button svg {
  width: 18px;
  height: 18px;
  display: block;
  fill: currentColor;
}

.icon-button svg text {
  fill: currentColor;
  font-size: 8px;
  font-weight: 900;
  font-family: Inter, ui-sans-serif, system-ui, sans-serif;
}

.icon-button.primary {
  width: 46px;
  height: 46px;
  min-height: 46px;
}

button.ghost { background: transparent; }
button.danger { border-color: rgba(255,77,79,.6); color: #ffd6d6; }

input, select {
  width: 100%;
  border: 1px solid var(--line);
  background: #0d1014;
  color: var(--text);
  border-radius: 8px;
  min-height: 40px;
  padding: 9px 11px;
  outline: none;
}

label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: .86rem;
}

.login-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(380px, .82fr);
  background:
    radial-gradient(circle at 82% 16%, rgba(255,106,0,.18), transparent 28%),
    linear-gradient(135deg, #050607 0%, #090b0e 50%, #1d0d03 100%);
  overflow: hidden;
}

.login-panel {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: clamp(24px, 4vw, 58px);
  position: relative;
  isolation: isolate;
}

.login-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(255,106,0,.08), transparent 26%),
    radial-gradient(circle at 42% 36%, rgba(255,255,255,.07), transparent 18%);
  pointer-events: none;
  z-index: -1;
}

.login-card {
  width: min(100%, 430px);
  display: grid;
  gap: 24px;
  padding: clamp(26px, 4vw, 42px);
  border: 1px solid rgba(255,255,255,.11);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.025)),
    rgba(9, 11, 14, .78);
  box-shadow: 0 34px 100px rgba(0,0,0,.48), 0 0 44px rgba(255,106,0,.08);
  backdrop-filter: blur(22px);
  animation: loginPanelIn .55s ease both;
}

.login-logo {
  width: min(220px, 70%);
  justify-self: center;
  filter: drop-shadow(0 18px 34px rgba(0,0,0,.48));
}

.login-card-heading {
  display: grid;
  gap: 8px;
  text-align: center;
}

.login-card-heading span {
  color: var(--orange-2);
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.login-card-heading h2 {
  margin: 0;
  font-size: clamp(1.55rem, 2vw, 2.05rem);
  line-height: 1.05;
}

.login-visual {
  min-height: 100vh;
  display: grid;
  grid-template-columns: minmax(300px, .82fr) minmax(280px, 1fr);
  align-items: center;
  gap: clamp(22px, 4vw, 58px);
  padding: clamp(32px, 5vw, 72px);
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(105deg, rgba(0,0,0,.9) 0%, rgba(0,0,0,.63) 44%, rgba(0,0,0,.18) 100%),
    radial-gradient(circle at 75% 24%, rgba(255,106,0,.25), transparent 27%),
    linear-gradient(180deg, rgba(0,0,0,.1), rgba(0,0,0,.58)),
    url("/img/pitch.png") center / cover no-repeat,
    linear-gradient(135deg, #10141a 0%, #050608 56%, #281104 100%);
}

.login-visual::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 68% 52%, rgba(255,106,0,.17), transparent 24%),
    repeating-linear-gradient(90deg, transparent 0 72px, rgba(255,255,255,.022) 73px),
    linear-gradient(180deg, transparent, rgba(0,0,0,.24));
  pointer-events: none;
}

.login-hero-copy,
.login-hero-brand {
  position: relative;
  z-index: 1;
}

.login-hero-copy {
  display: grid;
  gap: 16px;
  animation: loginHeroIn .6s ease both;
}

.login-hero-copy h1 {
  max-width: 430px;
  margin: 0;
  font-size: clamp(2.1rem, 4vw, 4.1rem);
  line-height: 1;
  letter-spacing: 0;
}

.login-hero-copy p {
  max-width: 390px;
  margin: 0;
  color: var(--soft);
  font-size: 1.05rem;
  line-height: 1.55;
}

.login-hero-brand {
  min-height: 430px;
  display: grid;
  place-items: center;
}

.login-hero-brand img {
  width: min(560px, 92%);
  max-height: 280px;
  object-fit: contain;
  filter: drop-shadow(0 30px 74px rgba(0,0,0,.72)) drop-shadow(0 0 28px rgba(255,106,0,.18));
  animation: loginBrandFloat 5.5s ease-in-out infinite;
}

.login-pitch-frame {
  position: absolute;
  inset: 56px 10px 40px 10px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  background:
    radial-gradient(circle at center, rgba(255,106,0,.13), transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,.035), rgba(255,106,0,.04));
  box-shadow: inset 0 0 68px rgba(255,106,0,.08), 0 34px 80px rgba(0,0,0,.45);
  z-index: -1;
}

.login-card label {
  color: var(--soft);
  font-weight: 800;
}

.login-card input {
  min-height: 48px;
  border-color: rgba(255,255,255,.1);
  background: rgba(255,255,255,.045);
  transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.login-card input:focus {
  border-color: rgba(255,106,0,.82);
  background: rgba(255,255,255,.065);
  box-shadow: 0 0 0 4px rgba(255,106,0,.13), 0 14px 36px rgba(0,0,0,.28);
}

.login-submit {
  min-height: 50px;
  margin-top: 4px;
  background: linear-gradient(180deg, #ffb15f, #ff6a00);
  border-color: rgba(255,138,42,.9);
  box-shadow: 0 18px 44px rgba(255,106,0,.28);
  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
}

.login-submit:hover {
  transform: translateY(-1px);
  filter: saturate(1.08);
  box-shadow: 0 22px 58px rgba(255,106,0,.38);
}

@keyframes loginHeroIn {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes loginPanelIn {
  from { opacity: 0; transform: translateY(16px) scale(.98); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes loginBrandFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}

.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 900;
  letter-spacing: 0;
}

.mark {
  width: 42px;
  height: 42px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  background: var(--orange);
  color: #111;
  font-weight: 1000;
}

.brand small { display: block; color: var(--muted); font-weight: 600; margin-top: 2px; }
h1, h2, h3, p { margin-top: 0; }
h1 { font-size: clamp(2rem, 5vw, 4.8rem); line-height: .96; letter-spacing: 0; margin-bottom: 18px; }
h2 { font-size: 1.2rem; }
h3 { font-size: 1rem; }
p { color: var(--muted); line-height: 1.55; }

.app-shell {
  display: grid;
  grid-template-columns: 255px minmax(0, 1fr);
  min-height: 100vh;
}

.app-shell.sidebar-collapsed {
  grid-template-columns: 76px minmax(0, 1fr);
}

.app-shell.analysis-shell {
  grid-template-columns: minmax(0, 1fr);
}

.app-shell.physical-analysis-shell {
  grid-template-columns: minmax(0, 1fr);
}

.analysis-shell .sidebar,
.physical-analysis-shell .sidebar {
  display: none;
}

.analysis-shell .main,
.physical-analysis-shell .main {
  padding-left: 18px;
}

.sidebar {
  border-right: 1px solid rgba(255,255,255,.08);
  background:
    radial-gradient(circle at 30% 4%, rgba(255,106,0,.12), transparent 24%),
    linear-gradient(180deg, rgba(255,255,255,.035), transparent 34%),
    rgba(7, 9, 12, .96);
  padding: 24px 18px;
  position: sticky;
  top: 0;
  height: 100vh;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.sidebar-brand img {
  width: 136px;
  max-height: 38px;
  object-fit: contain;
  filter: drop-shadow(0 10px 26px rgba(0,0,0,.34));
}

.sidebar-brand {
  justify-content: space-between;
}

.sidebar-toggle {
  width: 36px;
  height: 36px;
  min-height: 36px;
  padding: 0;
  flex: 0 0 auto;
}

.sidebar-toggle svg,
.nav-button svg,
.sidebar-field svg,
.sidebar-section-label svg {
  width: 17px;
  height: 17px;
  fill: currentColor;
  flex: 0 0 auto;
}

.analysis-shell .sidebar {
  padding: 14px;
  gap: 12px;
  overflow: hidden;
}

.nav-group { display: grid; gap: 7px; }
.nav-button {
  text-align: left;
  background: transparent;
  border-color: transparent;
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--muted);
  min-height: 38px;
}
.nav-button.active, .nav-button:hover {
  background: rgba(255,255,255,.045);
  color: var(--text);
  border-color: rgba(255,255,255,.08);
  box-shadow: inset 3px 0 0 var(--orange), 0 10px 28px rgba(0,0,0,.18);
}
.sidebar label {
  color: var(--muted);
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.sidebar-field {
  display: grid;
  grid-template-columns: 17px minmax(0, 1fr);
  align-items: center;
  column-gap: 8px;
  row-gap: 7px;
}

.sidebar-field > svg {
  grid-column: 1;
  align-self: center;
}

.sidebar-field > span {
  grid-column: 2;
  display: inline-flex;
  align-items: center;
  min-height: 17px;
  line-height: 1;
}

.sidebar-field > select {
  grid-column: 1 / -1;
}

.sidebar-section-label span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.sidebar select {
  margin-top: 7px;
  background: rgba(255,255,255,.035);
  border-color: rgba(255,255,255,.08);
}

.sidebar-footer {
  margin-top: auto;
  color: var(--muted);
  font-size: .84rem;
  border-top: 1px solid rgba(255,255,255,.08);
  padding-top: 14px;
}

.sidebar-user {
  display: grid;
  gap: 3px;
  margin-bottom: 10px;
}

.sidebar-user b {
  color: var(--text);
  font-size: .9rem;
}

.sidebar-user span {
  color: var(--muted);
  font-size: .78rem;
}

.logout-nav {
  width: 100%;
  justify-content: flex-start;
}

.sidebar-collapsed .sidebar {
  padding: 20px 12px;
  align-items: center;
}

.sidebar-collapsed .sidebar-brand {
  justify-content: center;
}

.sidebar-collapsed .sidebar-brand img,
.sidebar-collapsed .nav-button span,
.sidebar-collapsed .sidebar-field span,
.sidebar-collapsed .sidebar-field select,
.sidebar-collapsed .sidebar-section-label span,
.sidebar-collapsed .sidebar-user {
  display: none;
}

.sidebar-collapsed .nav-group,
.sidebar-collapsed .sidebar-footer {
  width: 100%;
}

.sidebar-collapsed .nav-button,
.sidebar-collapsed .sidebar-field,
.sidebar-collapsed .sidebar-section-label,
.sidebar-collapsed .logout-nav {
  width: 100%;
  justify-content: center;
  padding-left: 0;
  padding-right: 0;
}

.sidebar-collapsed .sidebar-field {
  min-height: 38px;
  display: grid;
  place-items: center;
  border: 1px solid transparent;
  border-radius: 8px;
  padding: 0;
}

.main {
  padding: 22px;
  min-width: 0;
}

.home-shell .main {
  padding-top: 14px;
}

.analysis-shell .main {
  padding: 12px 14px;
}

.topbar {
  min-height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.analysis-shell .topbar {
  min-height: 58px;
  margin-bottom: 12px;
}

.analysis-shell .topbar h2 {
  margin-bottom: 0;
  font-size: 1rem;
}

.analysis-topbar {
  display: grid;
  grid-template-columns: minmax(300px, 1fr) auto minmax(44px, 1fr);
  align-items: center;
  gap: 14px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255,106,0,.09), transparent 36%),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  box-shadow: 0 18px 58px rgba(0,0,0,.24);
}

.analysis-brandline {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.analysis-brandline img {
  width: 116px;
  max-height: 34px;
  object-fit: contain;
  filter: drop-shadow(0 0 14px rgba(255,106,0,.14));
}

.analysis-match-title {
  min-width: 0;
  display: grid;
  grid-template-columns: auto minmax(0, auto) auto;
  align-items: center;
  gap: 8px;
}

.analysis-match-title span {
  color: var(--muted);
  font-size: .76rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.analysis-match-title b {
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.analysis-match-title small {
  border: 1px solid rgba(255,106,0,.26);
  border-radius: 999px;
  padding: 4px 8px;
  color: var(--orange-2);
  background: rgba(255,106,0,.08);
  font-weight: 900;
}

.analysis-header-actions {
  justify-content: flex-end;
}

.badge, .pill {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 6px 10px;
  color: var(--muted);
  background: rgba(255,255,255,.03);
  font-size: .82rem;
}

.grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 14px;
}

.card {
  background: linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.015));
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
  box-shadow: var(--shadow);
  min-width: 0;
}

.span-3 { grid-column: span 3; }
.span-4 { grid-column: span 4; }
.span-5 { grid-column: span 5; }
.span-6 { grid-column: span 6; }
.span-7 { grid-column: span 7; }
.span-8 { grid-column: span 8; }
.span-12 { grid-column: span 12; }

.metric strong { color: var(--muted); font-size: .82rem; }
.metric b { display: block; font-size: 1.75rem; margin-top: 8px; }
.metric small { color: var(--muted); }

.hero-strip {
  min-height: 280px;
  background:
    linear-gradient(90deg, rgba(0,0,0,.82), rgba(0,0,0,.34)),
    linear-gradient(135deg, #20252c 0%, #0c0e11 56%, #3b1a04 100%);
  display: flex;
  align-items: end;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
}

.action-card {
  min-height: 170px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.action-card h2 { font-size: 1.55rem; margin-bottom: 8px; }

.home-hero-premium {
  min-height: 235px;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 8px;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(330px, 1.05fr);
  gap: 22px;
  padding: 16px 26px;
  position: relative;
  background:
    linear-gradient(105deg, rgba(0,0,0,.92) 0%, rgba(0,0,0,.68) 42%, rgba(0,0,0,.24) 100%),
    radial-gradient(circle at 78% 16%, rgba(255,106,0,.24), transparent 24%),
    linear-gradient(180deg, rgba(0,0,0,.12), rgba(0,0,0,.52)),
    url("/img/pitch.png") center / cover no-repeat,
    linear-gradient(135deg, #10141a 0%, #050608 56%, #281104 100%);
  box-shadow: 0 36px 110px rgba(0,0,0,.48);
}

.home-hero-premium::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 68% 50%, rgba(255,106,0,.15), transparent 26%),
    repeating-linear-gradient(90deg, transparent 0 70px, rgba(255,255,255,.02) 71px),
    linear-gradient(180deg, transparent, rgba(0,0,0,.22));
  pointer-events: none;
}

.home-hero-content,
.home-hero-visual {
  position: relative;
  z-index: 1;
}

.home-hero-content {
  display: grid;
  align-content: center;
  justify-items: start;
  gap: 10px;
  min-height: 190px;
}

.hero-kicker {
  color: var(--orange-2);
  font-size: .72rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .14em;
}

.home-hero-content h1 {
  max-width: 430px;
  margin: 0;
  font-size: clamp(1.65rem, 2.5vw, 2.55rem);
  line-height: 1;
  letter-spacing: 0;
}

.home-hero-content p {
  max-width: 440px;
  font-size: 1.08rem;
  color: var(--soft);
}

.premium-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.premium-badges span,
.secondary-brand {
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 999px;
  background: rgba(255,255,255,.045);
  color: var(--muted);
  padding: 5px 8px;
  font-size: .72rem;
  font-weight: 800;
}

.secondary-brand {
  color: var(--orange-2);
  border-color: rgba(255,106,0,.26);
  background: rgba(255,106,0,.08);
}

.home-hero-visual {
  min-height: 190px;
}

.get-visual-logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(430px, 82%);
  max-height: 150px;
  object-fit: contain;
  opacity: .96;
  filter: drop-shadow(0 28px 70px rgba(0,0,0,.7)) drop-shadow(0 0 24px rgba(255,106,0,.16));
  z-index: 2;
}

.pitch-orbit {
  position: absolute;
  inset: 10px 18px 10px 8px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  background:
    radial-gradient(circle at center, rgba(255,106,0,.13), transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,.035), rgba(255,106,0,.04));
  box-shadow: inset 0 0 60px rgba(255,106,0,.08), 0 34px 80px rgba(0,0,0,.42);
}

.floating-card {
  position: absolute;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px;
  background: rgba(10,13,18,.82);
  backdrop-filter: blur(18px);
  padding: 13px;
  box-shadow: 0 18px 58px rgba(0,0,0,.35);
}

.floating-card.primary {
  top: 36px;
  right: 22px;
  width: 190px;
}

.floating-card.secondary {
  left: 8px;
  bottom: 26px;
  width: 175px;
}

.floating-card span {
  color: var(--muted);
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.floating-card b {
  display: block;
  color: var(--orange-2);
  font-size: 2rem;
  line-height: 1;
  margin: 8px 0 4px;
}

.floating-card small {
  color: var(--muted);
}

.mini-bars {
  position: absolute;
  right: 42px;
  bottom: 42px;
  width: 190px;
  display: grid;
  gap: 8px;
}

.mini-bars i {
  height: 9px;
  width: var(--w);
  border-radius: 999px;
  background: linear-gradient(90deg, var(--orange), #ffd0a6);
  box-shadow: 0 0 20px rgba(255,106,0,.25);
}

.home-section,
.home-modules,
.admin-shell {
  margin-top: 14px;
}

.home-modules {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.module-card,
.match-card {
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255,106,0,.055), transparent 44%),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.012));
  box-shadow: var(--shadow);
  min-width: 0;
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.module-card:hover,
.match-card:hover {
  transform: translateY(-3px);
  border-color: rgba(255,106,0,.38);
  box-shadow: 0 28px 80px rgba(0,0,0,.42), 0 0 34px rgba(255,106,0,.09);
}

.module-card {
  min-height: 230px;
  padding: 18px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.module-card.disabled {
  opacity: .58;
}

.module-card h2 {
  font-size: 1.55rem;
  margin: 14px 0 8px;
}

.module-card button:disabled {
  cursor: not-allowed;
  opacity: .8;
}

.section-heading {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 12px;
}

.section-heading h2,
.section-heading p {
  margin-bottom: 4px;
}

.match-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 11px;
}

.match-card {
  padding: 12px;
  display: grid;
  gap: 9px;
  position: relative;
  overflow: hidden;
}

@keyframes skeletonPulse {
  0%, 100% { opacity: .35; transform: translateX(-6px); }
  50% { opacity: .85; transform: translateX(6px); }
}

.match-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, transparent 49%, rgba(255,255,255,.045) 50%, transparent 51%),
    radial-gradient(circle at 50% 45%, transparent 0 16%, rgba(255,255,255,.055) 17%, transparent 18%);
  opacity: .36;
  pointer-events: none;
}

.match-card > * {
  position: relative;
  z-index: 1;
}

.match-card-head,
.match-meta,
.file-state-row {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}

.match-tile-main {
  display: grid;
  gap: 10px;
}

.match-card h2 {
  font-size: 1.22rem;
  margin: 0;
  display: flex;
  align-items: center;
  gap: 7px;
  flex-wrap: wrap;
  line-height: 1.16;
  font-weight: 900;
  color: var(--text);
}

.match-card h2 span {
  color: var(--orange-2);
  font-size: .82rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.match-card h2 strong {
  color: var(--orange-2);
  font-size: 1.38rem;
  line-height: 1;
  text-shadow: 0 0 22px rgba(255,106,0,.2);
}

.scoreline {
  color: var(--orange-2);
  font-size: 1.7rem;
  font-weight: 900;
  line-height: 1;
  text-shadow: 0 0 22px rgba(255,106,0,.18);
}

.match-meta {
  color: var(--muted);
  font-size: .78rem;
}

.status-badge {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 5px 8px;
  font-size: .76rem;
  font-weight: 800;
}

.premium-cta {
  box-shadow: 0 12px 34px rgba(255,106,0,.18);
  min-height: 34px;
  padding: 7px 10px;
}

.premium-cta:hover {
  transform: translateY(-1px);
  box-shadow: 0 18px 44px rgba(255,106,0,.28);
}

.status-badge.ok {
  color: #d8ffe2;
  border-color: rgba(48,209,88,.38);
  background: rgba(48,209,88,.1);
}

.status-badge.pending {
  color: #ffd8bd;
  border-color: rgba(255,138,42,.36);
  background: rgba(255,106,0,.1);
}

.file-state-row.compact {
  gap: 5px;
}

.admin-shell {
  display: grid;
  gap: 14px;
}

.admin-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 7px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(0,0,0,.18);
}

.admin-nav button {
  min-height: 34px;
  color: var(--muted);
  background: transparent;
}

.admin-nav button.active {
  background: var(--orange);
  border-color: var(--orange);
  color: #120a03;
  font-weight: 900;
}

.admin-table b,
.assignment-row b {
  display: block;
  color: var(--text);
}

.admin-table small,
.assignment-row small {
  display: block;
  color: var(--muted);
  margin-top: 4px;
  line-height: 1.35;
}

.row-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.assignment-stack {
  display: grid;
  gap: 8px;
}

.assignment-row {
  width: 100%;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  text-align: left;
  background: #101318;
}

.assignment-row:hover {
  background: #171c23;
  transform: translateY(-1px);
}

.admin-modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 900;
  background: rgba(3,5,8,.68);
  backdrop-filter: blur(12px);
  display: flex;
  justify-content: flex-end;
}

.admin-modal {
  width: min(520px, 100%);
  height: 100%;
  overflow: auto;
  padding: 18px;
  border-left: 1px solid var(--line);
  background: #0b0e12;
  box-shadow: -20px 0 70px rgba(0,0,0,.45);
}

.assignment-checks {
  display: grid;
  gap: 8px;
}

.assignment-checks label {
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  background: rgba(255,255,255,.03);
}

.assignment-checks input[type="checkbox"] {
  width: 18px;
  min-height: 18px;
}

.assignment-checks span {
  color: var(--text);
  font-weight: 800;
}

.assignment-checks small {
  display: block;
  color: var(--muted);
  font-weight: 500;
  margin-top: 3px;
}

.tabs, .filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.tabs button, .filters button {
  min-height: 34px;
  padding: 7px 10px;
  color: var(--muted);
}
.tabs button.active, .filters button.active {
  background: var(--orange);
  border-color: var(--orange);
  color: #120a03;
  font-weight: 800;
}

.filter-stack button {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.filter-stack button b {
  font-variant-numeric: tabular-nums;
  font-size: .78rem;
}

.filter-audit, .event-detail, .advanced-filters {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(0,0,0,.18);
  padding: 12px;
  margin: 12px 0;
}

.filter-audit p, .event-detail p { margin: 6px 0; }
.filter-audit code {
  display: block;
  white-space: pre-wrap;
  word-break: break-word;
  color: #ffd8bd;
  background: rgba(255,106,0,.08);
  border: 1px solid rgba(255,106,0,.22);
  border-radius: 8px;
  padding: 9px;
  margin-top: 8px;
}

.audit-values, .mini-grid, .detail-grid {
  display: grid;
  gap: 8px;
}

.audit-values span, .mini-grid span, .detail-grid span {
  color: var(--muted);
  font-size: .84rem;
}

.detail-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-bottom: 10px;
}

.detail-grid b {
  display: block;
  color: var(--text);
  margin-bottom: 3px;
}

.advanced-filters summary {
  cursor: pointer;
  color: var(--text);
  font-weight: 800;
}

.advanced-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 12px;
}

.raw-fields {
  display: grid;
  gap: 6px;
  max-height: 320px;
  overflow: auto;
  margin-top: 10px;
}

.raw-fields div {
  display: grid;
  grid-template-columns: 145px minmax(0, 1fr);
  gap: 8px;
  border-bottom: 1px solid rgba(255,255,255,.07);
  padding: 6px 0;
}

.raw-fields b { color: var(--orange-2); font-size: .8rem; }
.raw-fields span { color: var(--muted); word-break: break-word; font-size: .84rem; }

.json-preview {
  max-height: 320px;
  overflow: auto;
  white-space: pre-wrap;
  word-break: break-word;
  color: #d5d9df;
  background: rgba(0,0,0,.24);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
}

.compact-toolbar > h2, .compact-toolbar > h3 { margin: 0; flex: 1 1 auto; }

.explorer-table table { min-width: 1280px; }
.explorer-table th { white-space: nowrap; }
.explorer-table td { font-size: .82rem; }

.unique-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.unique-grid details {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  background: rgba(0,0,0,.15);
}

.unique-grid summary { cursor: pointer; font-weight: 800; }

.analysis-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 380px);
  gap: 14px;
  align-items: start;
}

.analysis-workstation {
  display: grid;
  grid-template-columns: minmax(250px, 300px) minmax(540px, 1fr) minmax(340px, 420px);
  gap: 12px;
  align-items: start;
}

.match-analysis-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 7px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(0,0,0,.18);
  margin-bottom: 12px;
}

.match-analysis-tabs.header-tabs {
  justify-self: center;
  margin-bottom: 0;
  padding: 5px;
  background: rgba(0,0,0,.22);
}

.match-analysis-tabs button {
  min-height: 34px;
  color: var(--muted);
  background: transparent;
}

.match-analysis-tabs button.active {
  background: var(--orange);
  border-color: var(--orange);
  color: #120a03;
  font-weight: 900;
}

.match-tab-panel {
  display: none;
}

.match-tab-panel.active {
  display: block;
}

.video-stage,
.tactical-nav-panel {
  position: sticky;
  top: 70px;
}

.tactical-nav-panel {
  max-height: calc(100vh - 84px);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.action-station {
  position: sticky;
  top: 70px;
  max-height: calc(100vh - 84px);
  display: flex;
  flex-direction: column;
}

.analysis-layout > .card:first-child {
  position: sticky;
  top: 14px;
}

.tactical-sidebar {
  position: sticky;
  top: 14px;
  max-height: calc(100vh - 28px);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

video {
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #000;
  border: 1px solid var(--line);
  border-radius: 8px;
  display: block;
}

.video-wrap {
  position: relative;
}

.segment-loader {
  position: absolute;
  left: 14px;
  bottom: 14px;
  z-index: 3;
  max-width: min(430px, calc(100% - 28px));
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 8px;
  background: rgba(8,10,13,.82);
  color: var(--text);
  padding: 8px 11px;
  font-size: .86rem;
  font-weight: 800;
  box-shadow: 0 10px 34px rgba(0,0,0,.38);
  opacity: 0;
  transform: translateY(6px);
  pointer-events: none;
  transition: opacity .16s ease, transform .16s ease;
}

.segment-loader.visible {
  opacity: 1;
  transform: translateY(0);
}

.event-list {
  max-height: 670px;
  overflow: auto;
  display: grid;
  gap: 8px;
  padding-right: 4px;
  scroll-behavior: smooth;
}

.main-action-list {
  max-height: calc(100vh - 170px);
  margin-top: 10px;
}

.action-list-panel {
  margin-top: 0;
  min-height: 0;
}

.event-row {
  width: 100%;
  display: grid;
  grid-template-columns: 88px minmax(0, 1fr);
  gap: 12px;
  text-align: left;
  background: #101318;
  min-height: 76px;
  align-items: center;
  position: relative;
  overflow: hidden;
}
.event-row:hover {
  background: #171c23;
  transform: translateY(-1px);
}
.event-row.active {
  border-color: var(--orange);
  background: rgba(255,106,0,.12);
  box-shadow: 0 0 0 1px rgba(255,106,0,.25) inset;
}
.event-row.active::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 3px;
  background: var(--orange);
}
.time {
  color: var(--orange-2);
  font-variant-numeric: tabular-nums;
  font-weight: 900;
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.time svg {
  width: 15px;
  height: 15px;
  fill: var(--orange);
}
.event-title { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.event-meta { color: var(--muted); font-size: .82rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.event-description { display:flex; flex-wrap:wrap; gap:6px; color:#d5d9df; font-size:.82rem; margin-top:6px; line-height:1.35; }
.football-row { grid-template-columns: 82px minmax(0, 1fr); }

.result-badge, .duration-badge {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 3px 7px;
  background: rgba(255,255,255,.04);
  color: var(--muted);
  font-size: .76rem;
  font-weight: 800;
}

.result-badge.goal { color: #111; background: var(--green); border-color: var(--green); }
.result-badge.shot { color: #ffd8bd; border-color: rgba(255,138,42,.45); background: rgba(255,106,0,.14); }
.result-badge.recovery { color: #d8ffe2; border-color: rgba(48,209,88,.4); background: rgba(48,209,88,.12); }
.result-badge.cross { color: #dbeafe; border-color: rgba(96,165,250,.4); background: rgba(96,165,250,.12); }
.result-badge.clearance { color: #f3e8ff; border-color: rgba(192,132,252,.4); background: rgba(192,132,252,.12); }
.result-badge.duel { color: #fef3c7; border-color: rgba(245,158,11,.42); background: rgba(245,158,11,.12); }
.result-badge.card { color: #111; border-color: #ffd60a; background: #ffd60a; }

.segmented {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
  background: rgba(0,0,0,.2);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 5px;
  margin: 10px 0 12px;
}

.segmented button {
  min-height: 34px;
  border-color: transparent;
  background: transparent;
}

.segmented button.active {
  background: var(--orange);
  color: #120a03;
  border-color: var(--orange);
  font-weight: 800;
}

.client-filters {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin: 12px 0;
}

.tactical-filter-panel {
  margin-top: 12px;
  overflow: auto;
  padding-right: 4px;
  scroll-behavior: smooth;
  min-height: 0;
}

.analysis-shell .tactical-filter-panel {
  flex: 1 1 auto;
  margin-top: 0;
}

.tactical-tree {
  display: grid;
  gap: 8px;
  margin-top: 0;
}

.tree-phase {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(0,0,0,.16);
  overflow: hidden;
}

.tree-phase > button,
.tree-children button {
  width: 100%;
  min-height: 34px;
  border: 0;
  border-radius: 0;
  background: transparent;
  display: flex;
  justify-content: space-between;
  align-items: center;
  text-align: left;
  color: var(--muted);
}

.tree-phase > button {
  color: var(--text);
  font-weight: 900;
  background: rgba(255,255,255,.035);
}

.tree-children {
  display: grid;
  gap: 1px;
}

.tree-children button {
  padding-left: 22px;
  font-size: .86rem;
}

.tree-phase button:hover,
.tree-phase button.active {
  background: rgba(255,106,0,.14);
  color: var(--text);
}

.tree-phase button b {
  min-width: 30px;
  text-align: right;
  color: var(--orange-2);
  font-variant-numeric: tabular-nums;
}

.tree-select-wrap {
  padding: 8px;
}

.tree-select-wrap select {
  min-height: 36px;
  background: #0d1014;
}

.football-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 10px 0 12px;
}

.football-summary span {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 6px 9px;
  color: var(--muted);
  background: rgba(255,255,255,.03);
  font-size: .82rem;
}

.football-summary b { color: var(--text); }

.table-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; }
th, td {
  text-align: left;
  padding: 11px 10px;
  border-bottom: 1px solid var(--line);
  vertical-align: top;
  font-size: .9rem;
}
th { color: var(--muted); font-weight: 700; }

.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.form-grid .full { grid-column: 1 / -1; }

.split {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.empty {
  border: 1px dashed var(--line);
  border-radius: 8px;
  padding: 18px;
  color: var(--muted);
}

.notice {
  background: rgba(255,106,0,.12);
  border: 1px solid rgba(255,106,0,.38);
  color: #ffd8bd;
  border-radius: 8px;
  padding: 12px;
}

.kpi-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.bar {
  height: 9px;
  border-radius: 999px;
  overflow: hidden;
  background: #262c34;
}
.bar span {
  display: block;
  height: 100%;
  background: var(--orange);
  width: var(--w, 0%);
}

.toolbar {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}
.toolbar > * { flex: 1 1 160px; }
.toolbar button { flex: 0 0 auto; }

.toolbar-spacer {
  flex: 1 1 auto !important;
}

.playback-toolbar {
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(0,0,0,.18);
}

.playback-toolbar > * { flex: 0 0 auto; }
.playback-toolbar .pill {
  min-height: 34px;
  justify-content: center;
}

#syncTimeLabel { flex: 0 1 190px; }

.action-insight-panel {
  margin-top: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(0,0,0,.2);
  padding: 11px;
}

.action-insight-panel h2,
.action-insight-panel h3 {
  margin-bottom: 8px;
}

.insight-kpis {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
}

.insight-kpis span {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255,255,255,.03);
  padding: 8px 9px;
  color: var(--muted);
  font-size: .78rem;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.insight-kpis b {
  display: block;
  color: var(--text);
  margin-bottom: 4px;
  font-size: .74rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.action-team-analysis {
  margin-top: 10px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  background: rgba(255,255,255,.025);
  padding: 10px 11px;
}

.action-team-analysis b {
  display: block;
  color: var(--orange-2);
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .04em;
  margin-bottom: 4px;
}

.action-team-analysis p {
  margin: 0;
  color: var(--soft);
  font-size: .88rem;
  line-height: 1.45;
}

.insight-copy p {
  margin-bottom: 8px;
}

.compact-notice {
  margin-top: 8px;
}

.physical-dashboard {
  display: grid;
  gap: 14px;
}

.tactical-dashboard {
  display: grid;
  gap: 14px;
}

.tactical-hero-panel {
  min-height: 118px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 18px 20px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px;
  background:
    radial-gradient(circle at 78% 25%, rgba(255,106,0,.2), transparent 30%),
    linear-gradient(135deg, rgba(255,106,0,.12), transparent 38%),
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.02)),
    rgba(5,7,11,.92);
  box-shadow: var(--shadow);
}

.tactical-hero-panel h2 {
  margin: 4px 0 6px;
  font-size: clamp(1.35rem, 2vw, 2rem);
}

.tactical-hero-panel p {
  max-width: 760px;
  margin: 0;
  color: var(--muted);
  font-size: .88rem;
}

.tactical-score-context {
  min-width: 132px;
  text-align: right;
}

.tactical-score-context strong {
  display: block;
  color: var(--orange);
  font-size: 2rem;
  line-height: 1;
}

.tactical-score-context small {
  color: var(--muted);
  font-size: .75rem;
}

.tactical-kpi-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, .8fr);
  gap: 14px;
}

.tactical-header-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.tactical-head-metric {
  display: grid;
  gap: 5px;
  min-height: 72px;
  text-align: left;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px;
  padding: 12px;
  color: var(--text);
  background:
    linear-gradient(135deg, rgba(255,106,0,.1), transparent 44%),
    rgba(255,255,255,.035);
  cursor: pointer;
}

.tactical-head-metric small {
  color: var(--muted);
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.tactical-head-metric b {
  font-size: 1.3rem;
}

.tactical-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 14px;
}

.tactical-panel,
.tactical-possession-card,
.tactical-context-card {
  background:
    linear-gradient(135deg, rgba(255,106,0,.06), transparent 38%),
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.015));
}

.native-summary-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.native-summary-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 24px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  min-height: 104px;
  background:
    linear-gradient(135deg, rgba(255,106,0,.08), transparent 44%),
    rgba(255,255,255,.025);
}

.native-summary-card > small {
  grid-column: 1 / -1;
  color: var(--muted);
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.native-summary-card div {
  display: grid;
  gap: 3px;
}

.native-summary-card div.right {
  text-align: right;
}

.native-summary-card b {
  color: var(--text);
  font-size: 1.55rem;
  line-height: 1;
}

.native-summary-card span {
  overflow: hidden;
  color: var(--muted);
  font-size: .72rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.native-summary-card > i {
  height: 1px;
  background: linear-gradient(90deg, var(--orange), rgba(229,234,242,.7));
}

.native-event-list,
.native-timeline,
.native-map-stack,
.native-ranking-grid {
  display: grid;
  gap: 12px;
}

.native-event-row {
  display: grid;
  grid-template-columns: minmax(160px, .42fr) minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  padding: 11px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  background: rgba(0,0,0,.16);
}

.native-event-row b,
.native-timeline h3,
.native-map-stack h3,
.native-ranking-grid h3,
.native-team-ranking h4 {
  margin: 0;
  color: var(--soft);
  font-size: .86rem;
}

.native-event-row small {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: .7rem;
}

.native-dual-bars {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) minmax(0, 1fr) 42px;
  gap: 8px;
  align-items: center;
}

.native-dual-bars span:last-child {
  text-align: right;
}

.native-dual-bars i,
.native-team-ranking i {
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(255,177,95,.2), var(--orange));
  width: var(--w);
  min-width: 4px;
}

.native-dual-bars .home {
  justify-self: end;
}

.native-dual-bars .away {
  background: linear-gradient(90deg, rgba(229,234,242,.88), rgba(148,163,184,.18));
}

.timeline-buckets {
  display: grid;
  grid-template-columns: repeat(8, minmax(0, 1fr));
  gap: 6px;
}

.timeline-bucket {
  display: grid;
  gap: 5px;
}

.timeline-bucket small {
  color: var(--muted);
  font-size: .62rem;
}

.timeline-bucket span {
  display: flex;
  align-items: end;
  gap: 2px;
  height: 54px;
  padding: 4px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 7px;
  background: rgba(0,0,0,.18);
}

.timeline-bucket i {
  flex: 1;
  height: var(--h);
  min-height: 4px;
  border-radius: 4px 4px 1px 1px;
  background: var(--orange);
}

.timeline-bucket i.away {
  background: rgba(229,234,242,.72);
}

.native-mini-pitch {
  position: relative;
  height: 116px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px;
  background:
    linear-gradient(90deg, transparent 49.5%, rgba(255,255,255,.12) 49.5%, rgba(255,255,255,.12) 50.5%, transparent 50.5%),
    linear-gradient(90deg, rgba(255,106,0,.1), rgba(255,255,255,.03)),
    rgba(4,7,10,.72);
}

.native-mini-pitch::before {
  content: "";
  position: absolute;
  inset: 14px 8%;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 6px;
}

.native-mini-pitch i {
  position: absolute;
  left: var(--x);
  top: var(--y);
  width: 7px;
  height: 7px;
  border-radius: 999px;
  transform: translate(-50%, -50%);
  background: var(--orange);
  box-shadow: 0 0 12px rgba(255,106,0,.4);
}

.native-mini-pitch i.away {
  background: rgba(229,234,242,.9);
  box-shadow: 0 0 12px rgba(229,234,242,.2);
}

.native-team-rankings {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.native-team-ranking {
  display: grid;
  gap: 7px;
}

.native-team-ranking div:not(.empty) {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(50px, .45fr) 34px;
  gap: 8px;
  align-items: center;
  color: var(--muted);
  font-size: .74rem;
}

.native-team-ranking span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.native-team-ranking b {
  color: var(--text);
  text-align: right;
}

.possession-split {
  display: grid;
  gap: 9px;
}

.possession-board {
  display: grid;
  gap: 10px;
}

.possession-board-head,
.possession-board-values {
  display: grid;
  grid-template-columns: 1fr minmax(86px, .42fr) 1fr;
  gap: 8px;
  align-items: center;
  text-align: center;
}

.possession-board-head span:first-child,
.possession-board-values strong:first-child,
.possession-board-values small:nth-of-type(1) {
  text-align: left;
}

.possession-board-head span:last-child,
.possession-board-values strong:nth-child(3),
.possession-board-values small:nth-of-type(3) {
  text-align: right;
}

.possession-board-head {
  color: var(--soft);
  font-size: .82rem;
  font-weight: 800;
}

.possession-board-head b {
  color: var(--muted);
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .05em;
}

.possession-broadcast-bar {
  display: flex;
  height: 22px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  background: rgba(0,0,0,.28);
}

.possession-broadcast-bar i {
  width: var(--w);
  min-width: 4px;
  height: 100%;
}

.possession-broadcast-bar .team-1 {
  background: linear-gradient(90deg, rgba(255,106,0,.96), rgba(255,177,95,.72));
  box-shadow: 0 0 18px rgba(255,106,0,.3);
}

.possession-broadcast-bar .dead {
  background: repeating-linear-gradient(135deg, rgba(148,163,184,.34), rgba(148,163,184,.34) 5px, rgba(229,234,242,.18) 5px, rgba(229,234,242,.18) 10px);
}

.possession-broadcast-bar .team-2 {
  background: linear-gradient(90deg, rgba(229,234,242,.74), rgba(148,163,184,.92));
  box-shadow: 0 0 18px rgba(229,234,242,.12);
}

.possession-board-values {
  color: var(--text);
}

.possession-board-values small {
  color: var(--muted);
  font-size: .75rem;
}

.possession-team {
  position: relative;
  min-height: 48px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 12px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 8px;
  padding: 10px 12px;
  background: rgba(255,255,255,.025);
}

.possession-team::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: var(--w);
  background: linear-gradient(90deg, rgba(255,106,0,.4), rgba(255,177,95,.16));
  opacity: .9;
}

.possession-team.team-2::before {
  background: linear-gradient(90deg, rgba(229,234,242,.32), rgba(148,163,184,.12));
}

.possession-team > * {
  position: relative;
  z-index: 1;
}

.possession-team span,
.possession-team b {
  color: var(--text);
}

.possession-team small,
.dead-time-row span {
  color: var(--muted);
}

.dead-time-row {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto;
  gap: 10px;
  align-items: center;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,.08);
  font-size: .82rem;
}

.tactical-mini-kpis {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.tactical-mini-kpis span,
.territory-values span {
  display: grid;
  gap: 4px;
  padding: 11px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  background: rgba(0,0,0,.18);
}

.tactical-mini-kpis small,
.territory-values small {
  color: var(--muted);
  font-size: .72rem;
}

.tactical-mini-kpis b,
.territory-values b {
  color: var(--text);
  font-size: 1.25rem;
}

.phase-dashboard-list,
.professional-metrics,
.pass-network-grid,
.efficacy-list,
.tactical-insights,
.tactical-comparison-grid {
  display: grid;
  gap: 12px;
}

.phase-dashboard-block {
  display: grid;
  gap: 9px;
}

.phase-dashboard-block h3,
.territory-card h3 {
  margin: 0;
  color: var(--soft);
  font-size: .88rem;
}

.phase-metric-row,
.professional-metric-row,
.efficacy-row,
.tactical-compare-metric,
.territory-card {
  display: grid;
  gap: 8px;
  padding: 11px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  background: rgba(255,255,255,.025);
}

.professional-metric-row {
  grid-template-columns: minmax(190px, .72fr) minmax(0, 1.4fr) minmax(118px, .4fr);
  align-items: center;
  width: 100%;
  color: var(--text);
  text-align: left;
  cursor: pointer;
}

.professional-metric-row:hover,
.pass-link-row:hover,
.tactical-head-metric:hover {
  border-color: rgba(255,106,0,.38);
  background:
    linear-gradient(135deg, rgba(255,106,0,.12), transparent 46%),
    rgba(255,255,255,.045);
}

.professional-metric-copy {
  display: grid;
  gap: 3px;
}

.professional-metric-copy b {
  color: var(--text);
  font-size: .9rem;
}

.professional-metric-copy small {
  color: var(--muted);
  font-size: .72rem;
  line-height: 1.25;
}

.dual-bar-row {
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr) 96px;
  gap: 9px;
  align-items: center;
  color: var(--muted);
  font-size: .75rem;
}

.dual-bar-row span:last-child {
  text-align: right;
}

.dual-bar {
  position: relative;
  height: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 999px;
  background: rgba(0,0,0,.24);
}

.dual-bar::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  border-left: 1px solid rgba(255,255,255,.18);
}

.dual-bar i {
  position: absolute;
  top: 0;
  bottom: 0;
  width: calc(var(--w) / 2);
}

.dual-bar .home {
  right: 50%;
  background: linear-gradient(90deg, rgba(255,177,95,.24), rgba(255,106,0,.95));
}

.dual-bar .away {
  left: 50%;
  background: linear-gradient(90deg, rgba(229,234,242,.92), rgba(148,163,184,.22));
}

.professional-metric-values {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
  text-align: right;
}

.professional-metric-values strong {
  color: var(--orange);
  font-size: 1rem;
}

.professional-metric-values .team-2 {
  color: var(--soft);
}

.professional-metric-values small {
  display: block;
  color: var(--muted);
  font-size: .68rem;
}

.pass-network-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.pass-network-team {
  display: grid;
  gap: 10px;
}

.pass-network-team h3 {
  margin: 0;
  color: var(--soft);
  font-size: .9rem;
}

.pass-network-list {
  display: grid;
  gap: 8px;
}

.pass-link-row {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr) auto;
  gap: 9px;
  align-items: center;
  width: 100%;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  padding: 9px;
  color: var(--text);
  text-align: left;
  background: rgba(0,0,0,.18);
  cursor: pointer;
}

.pass-link-row > b {
  color: var(--orange);
}

.pass-link-row span {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 34px minmax(0, 1fr);
  gap: 7px;
  align-items: center;
  min-width: 0;
}

.pass-link-row strong {
  overflow: hidden;
  color: var(--soft);
  font-size: .74rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.pass-link-row i {
  height: 2px;
  background: linear-gradient(90deg, var(--orange), rgba(229,234,242,.7));
  box-shadow: 0 0 12px rgba(255,106,0,.28);
}

.pass-link-row em {
  color: var(--muted);
  font-size: .72rem;
  font-style: normal;
  white-space: nowrap;
}

.validation-kpis {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.validation-kpis.compact {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.validation-kpis span {
  display: grid;
  gap: 4px;
  padding: 12px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  background: rgba(0,0,0,.18);
}

.validation-kpis small {
  color: var(--muted);
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.validation-kpis b {
  color: var(--orange);
  font-size: 1.1rem;
}

.validation-kpis em {
  color: var(--muted);
  font-size: .76rem;
  font-style: normal;
}

.validation-table td {
  vertical-align: top;
}

.validation-discard-list {
  display: grid;
  gap: 8px;
}

.validation-discard-list div:not(.empty) {
  display: grid;
  gap: 3px;
  padding: 9px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  background: rgba(255,255,255,.025);
}

.validation-discard-list b {
  color: var(--orange);
  font-size: .78rem;
}

.validation-discard-list span {
  color: var(--soft);
  font-size: .78rem;
}

.phase-metric-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.phase-metric-head b,
.efficacy-row > b,
.tactical-compare-metric > b {
  color: var(--text);
  font-size: .86rem;
}

.phase-metric-head em {
  color: var(--orange);
  font-size: .74rem;
  font-style: normal;
}

.phase-team-line,
.efficacy-team {
  display: grid;
  grid-template-columns: 112px minmax(0, 1fr) 44px 76px;
  gap: 8px;
  align-items: center;
  color: var(--muted);
  font-size: .76rem;
}

.phase-team-line i,
.efficacy-team i {
  height: 7px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--orange), rgba(255,177,95,.28));
  width: var(--w);
  min-width: 4px;
  box-shadow: 0 0 16px rgba(255,106,0,.25);
}

.phase-team-line.team-2 i,
.efficacy-team.team-2 i,
.compare-bar-row.team-2 .compare-bar i {
  background: linear-gradient(90deg, rgba(229,234,242,.92), rgba(148,163,184,.25));
  box-shadow: 0 0 14px rgba(229,234,242,.12);
}

.phase-team-line b,
.efficacy-team strong {
  color: var(--text);
  text-align: right;
}

.phase-team-line small,
.efficacy-team small {
  color: var(--muted);
  text-align: right;
}

.tactical-insight {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  padding: 11px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  background: rgba(0,0,0,.18);
}

.tactical-insight b {
  color: var(--orange);
}

.tactical-insight span {
  color: var(--soft);
  line-height: 1.35;
}

.territory-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.mini-pitch {
  position: relative;
  height: 96px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px;
  background:
    linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px) 50% 0 / 25% 100%,
    linear-gradient(90deg, rgba(255,106,0,.16), rgba(255,255,255,.03)),
    rgba(5,8,12,.74);
}

.mini-pitch::before {
  content: "";
  position: absolute;
  inset: 18px 8%;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 6px;
}

.pitch-dot {
  position: absolute;
  top: 50%;
  left: var(--x);
  width: 12px;
  height: 12px;
  border-radius: 999px;
  transform: translate(-50%, -50%);
  background: var(--orange);
  box-shadow: 0 0 18px rgba(255,106,0,.58);
}

.pitch-dot.recovery {
  top: 32%;
  background: #30d158;
  box-shadow: 0 0 18px rgba(48,209,88,.35);
}

.pitch-dot.final {
  top: 68%;
  background: #ffd60a;
  box-shadow: 0 0 18px rgba(255,214,10,.35);
}

.territory-values {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.tactical-comparison-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.physical-kpi-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.physical-showdown {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 180px minmax(0, 1fr);
  align-items: stretch;
  gap: 12px;
}

.showdown-team,
.physical-scoreboard {
  border: 1px solid var(--line);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255,106,0,.1), transparent 42%),
    rgba(255,255,255,.035);
  padding: 14px;
}

.showdown-team {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
}

.showdown-team.right {
  direction: rtl;
}

.showdown-team.right * {
  direction: ltr;
}

.showdown-team small,
.physical-scoreboard span,
.physical-scoreboard small {
  color: var(--muted);
  font-size: .76rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.showdown-team h3 {
  margin: 3px 0 0;
  font-size: 1.24rem;
}

.showdown-team > strong {
  color: var(--orange-2);
  font-size: 1.7rem;
  line-height: 1;
  white-space: nowrap;
}

.showdown-metrics {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 7px;
}

.showdown-metrics span {
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  background: rgba(0,0,0,.14);
  padding: 8px;
  color: var(--muted);
  font-size: .76rem;
}

.showdown-metrics b {
  display: block;
  color: var(--text);
  font-size: .96rem;
}

.physical-scoreboard {
  display: grid;
  place-items: center;
  text-align: center;
  background: rgba(0,0,0,.22);
}

.physical-scoreboard b {
  color: var(--text);
  font-size: 2rem;
  line-height: 1;
  margin: 4px 0;
}

.physical-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 14px;
}

.physical-panel {
  min-height: 0;
}

.physical-main-panel {
  background:
    linear-gradient(135deg, rgba(255,106,0,.1), transparent 44%),
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.018));
}

.physical-team-card h3,
.physical-panel h2 {
  margin-bottom: 12px;
}

.physical-card-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.physical-card-metrics.single {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin: 12px 0;
}

.physical-card-metrics span {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255,255,255,.03);
  padding: 9px;
  color: var(--muted);
  font-size: .8rem;
}

.physical-card-metrics b {
  display: block;
  color: var(--text);
  font-size: .98rem;
  margin-bottom: 4px;
  overflow-wrap: anywhere;
}

.control-stack {
  display: flex;
  min-height: 78px;
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
  background: rgba(0,0,0,.22);
}

.control-segment {
  flex: var(--w, 0) 0 0;
  min-width: 72px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 4px;
  padding: 8px;
  background: rgba(255,106,0,.72);
  color: #120a03;
  font-weight: 900;
  text-align: center;
}

.control-segment:nth-child(2) {
  background: rgba(245,245,245,.82);
}

.control-segment.contest {
  background: rgba(120,130,145,.55);
  color: var(--text);
}

.control-segment span {
  font-size: .78rem;
}

.control-segment b {
  font-size: 1rem;
}

.speed-zone-chart {
  display: grid;
  gap: 12px;
  width: 100%;
  min-height: 160px;
  padding-top: 4px;
}

.distance-donut-layout {
  display: grid;
  grid-template-columns: 210px minmax(0, 1fr);
  gap: 20px;
  align-items: center;
}

.distance-donut {
  width: 190px;
  aspect-ratio: 1;
  border-radius: 50%;
  display: grid;
  place-items: center;
  justify-self: center;
  background:
    radial-gradient(circle at center, #10141a 0 49%, transparent 50%),
    conic-gradient(var(--orange) 0 var(--a), #79a7ff var(--a) 100%);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.08),
    0 0 34px rgba(255,106,0,.18),
    inset 0 0 24px rgba(0,0,0,.45);
}

.distance-donut::before {
  content: "";
  position: absolute;
}

.distance-donut div {
  width: 118px;
  aspect-ratio: 1;
  border-radius: 999px;
  display: grid;
  place-items: center;
  align-content: center;
  background:
    radial-gradient(circle at center, rgba(255,255,255,.04), transparent 62%),
    rgba(7,9,13,.96);
  border: 1px solid rgba(255,255,255,.1);
  text-align: center;
}

.distance-donut-copy {
  display: grid;
  gap: 10px;
}

.distance-share,
.distance-delta {
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  background: rgba(0,0,0,.14);
  padding: 11px;
}

.distance-share {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
}

.distance-share span {
  color: var(--muted);
}

.distance-share b {
  color: var(--orange-2);
  font-size: 1.25rem;
}

.distance-share.team-b b {
  color: #b8ccff;
}

.distance-share small {
  grid-column: 1 / -1;
  color: var(--muted);
}

.distance-delta {
  display: grid;
  gap: 5px;
  background:
    linear-gradient(135deg, rgba(255,106,0,.13), transparent 48%),
    rgba(0,0,0,.2);
  border-color: rgba(255,106,0,.24);
  box-shadow: 0 12px 38px rgba(0,0,0,.18);
}

.distance-delta span {
  color: var(--orange-2);
  font-size: .76rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.distance-delta b {
  color: var(--text);
  font-size: 1.35rem;
  line-height: 1;
}

.distance-delta strong {
  color: var(--orange-2);
  font-size: 1.05rem;
}

.distance-delta small {
  color: var(--muted);
}

.zone-mini-list {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 12px;
}

.zone-mini-list span {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 5px 8px;
  color: var(--muted);
  font-size: .76rem;
}

.speed-zone-team {
  display: grid;
  gap: 9px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  padding: 10px;
  background: rgba(0,0,0,.12);
}

.speed-zone-team h3 {
  margin: 6px 0 2px;
}

.comparative-zones {
  gap: 10px;
  overflow: visible;
}

.comparative-zones .speed-zone-row {
  display: grid;
  grid-template-columns: 86px minmax(0, 1fr) 120px;
  gap: 10px;
  align-items: center;
  padding: 9px 0;
  border-bottom: 1px solid rgba(255,255,255,.07);
  color: var(--muted);
  font-size: .82rem;
  min-height: 42px;
  width: 100%;
}

.comparative-zones .speed-zone-row:last-of-type {
  border-bottom: 0;
}

.zone-versus {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  min-width: 0;
  width: 100%;
}

.zone-side {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 7px;
  align-items: center;
  min-width: 0;
  width: 100%;
}

.zone-side.right {
  grid-template-columns: minmax(0, 1fr) 72px;
}

.zone-side b {
  color: var(--text);
  font-size: .78rem;
  white-space: nowrap;
}

.zone-side.left b {
  text-align: right;
}

.zone-side i {
  display: block;
  height: 12px;
  width: var(--w, 0%);
  min-width: 0;
  max-width: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, #ff6a00, #ffb15f);
  box-shadow: 0 0 18px rgba(255,106,0,.2);
}

.zone-side i[data-has-value="true"] {
  min-width: 4px;
}

.zone-side i[data-has-value="false"] {
  opacity: 0;
}

.zone-side.left i {
  justify-self: end;
}

.zone-side.right i {
  background: linear-gradient(90deg, #79a7ff, #d8e4ff);
  box-shadow: 0 0 18px rgba(121,167,255,.18);
}

.comparative-zones .speed-zone-row > strong {
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 999px;
  background: rgba(255,255,255,.04);
  padding: 5px 8px;
  color: var(--orange-2);
  font-size: .78rem;
  text-align: right;
  white-space: nowrap;
}

.zone-labels {
  display: grid;
  grid-template-columns: 86px minmax(0, 1fr) 120px;
  color: var(--muted);
  font-size: .76rem;
}

.zone-labels span:first-child {
  grid-column: 2;
  text-align: left;
}

.zone-labels span:last-child {
  grid-column: 3;
  text-align: right;
}

.team-bars,
.player-compare-bars {
  display: grid;
  gap: 12px;
}

.team-bar-group,
.player-metric-compare {
  display: grid;
  gap: 7px;
}

.team-bar-group strong {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

.team-bar-group strong em {
  color: var(--orange-2);
  font-style: normal;
  font-size: .78rem;
  text-align: right;
}

.compare-bar-row,
.player-metric-compare div {
  display: grid;
  grid-template-columns: 95px minmax(0, 1fr) 90px;
  gap: 8px;
  align-items: center;
  color: var(--muted);
  font-size: .82rem;
}

.compare-bar,
.player-metric-compare div i {
  height: 9px;
  border-radius: 999px;
  overflow: hidden;
  background: #262c34;
}

.compare-bar i,
.player-metric-compare div i {
  display: block;
  width: var(--w, 0%);
  height: 100%;
  background: var(--orange);
}

.player-metric-compare div i {
  min-width: 2px;
}

.compare-selects {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}

.physical-interpretation {
  margin: 12px 0 0;
}

.physical-ranking table tr.active td {
  background: rgba(255,106,0,.1);
}

.physical-ranking tbody tr {
  cursor: pointer;
}

.physical-ranking small {
  display: block;
  color: var(--muted);
}

.table-sort {
  min-height: 28px;
  padding: 4px 7px;
  border-radius: 8px;
  background: transparent;
  color: var(--muted);
}

.table-sort.active {
  background: var(--orange);
  border-color: var(--orange);
  color: #120a03;
  font-weight: 900;
}

.basic-rankings {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.ranking-block {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(0,0,0,.16);
  padding: 10px;
}

.ranking-block h3 {
  margin-bottom: 8px;
}

.ranking-row {
  display: grid;
  grid-template-columns: 26px minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  padding: 8px 0;
  border-bottom: 1px solid rgba(255,255,255,.07);
}

.ranking-row:last-child {
  border-bottom: 0;
}

.ranking-row > b {
  color: var(--orange-2);
}

.ranking-row span {
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ranking-row small {
  display: block;
  color: var(--muted);
  margin-top: 2px;
}

.ranking-row strong {
  color: var(--text);
  white-space: nowrap;
}

.compact-compare-selects {
  max-width: 780px;
}

.player-h2h {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 260px minmax(0, 1fr);
  gap: 14px;
  align-items: stretch;
  margin-bottom: 14px;
}

.player-profile-card,
.player-radar-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(0,0,0,.16);
  padding: 14px;
}

.player-profile-card {
  display: grid;
  gap: 8px;
}

.player-photo-placeholder {
  width: 46px;
  height: 46px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: var(--orange);
  color: #120a03;
  font-weight: 1000;
}

.player-profile-card.player-b .player-photo-placeholder {
  background: #79a7ff;
  color: #07101f;
}

.player-profile-card small {
  color: var(--muted);
}

.player-profile-card h3 {
  margin: 0;
}

.player-profile-card.player-a h3,
.player-profile-card.player-a .player-profile-summary b {
  color: var(--orange-2);
}

.player-profile-card.player-b h3,
.player-profile-card.player-b .player-profile-summary b {
  color: #b8ccff;
}

.player-profile-summary {
  display: grid;
  gap: 8px;
  min-height: 106px;
  align-content: start;
}

.player-profile-summary b {
  font-size: .92rem;
}

.player-profile-summary p {
  margin: 0;
  font-size: .82rem;
  line-height: 1.45;
}

.player-profile-summary div {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.player-profile-summary span {
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 999px;
  padding: 5px 7px;
  color: var(--muted);
  font-size: .72rem;
  background: rgba(255,255,255,.035);
}

.player-radar-card {
  display: grid;
  place-items: center;
  text-align: center;
}

.player-radar-card p {
  font-size: .82rem;
  margin: 6px 0 0;
}

.player-radar {
  width: 190px;
  max-width: 100%;
  height: auto;
}

.radar-grid {
  fill: rgba(255,255,255,.025);
  stroke: rgba(255,255,255,.14);
  stroke-width: 1;
}

.radar-a {
  fill: rgba(255,106,0,.24);
  stroke: var(--orange);
  stroke-width: 2;
}

.radar-b {
  fill: rgba(121,167,255,.22);
  stroke: #79a7ff;
  stroke-width: 2;
}

.player-radar text {
  fill: var(--muted);
  font-size: 9px;
}

.radar-legend {
  display: flex;
  justify-content: center;
  gap: 12px;
  color: var(--muted);
  font-size: .76rem;
}

.radar-legend span:first-child::before,
.radar-legend span:last-child::before {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  margin-right: 5px;
  background: var(--orange);
}

.radar-legend span:last-child::before {
  background: #79a7ff;
}

.player-comparison-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.player-compare-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(0,0,0,.15);
  padding: 12px;
  display: grid;
  gap: 9px;
}

.player-compare-card strong {
  color: var(--text);
}

.player-compare-card em {
  font-style: normal;
  font-size: .84rem;
  border-radius: 999px;
  padding: 7px 9px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  background: rgba(255,255,255,.045);
  border: 1px solid rgba(255,255,255,.08);
  font-weight: 900;
}

.player-compare-card em span {
  color: var(--muted);
  font-size: .72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.player-compare-card em.player-a {
  color: var(--orange-2);
  border-color: rgba(255,106,0,.28);
  background: rgba(255,106,0,.09);
}

.player-compare-card em.player-b {
  color: #b8ccff;
  border-color: rgba(121,167,255,.28);
  background: rgba(121,167,255,.09);
}

.player-compare-row {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr) 92px;
  gap: 8px;
  align-items: center;
  color: var(--muted);
  font-size: .82rem;
}

.player-compare-row.player-a span,
.player-compare-row.player-a b {
  color: var(--orange-2);
}

.player-compare-row.player-b span,
.player-compare-row.player-b b {
  color: #b8ccff;
}

.player-compare-row i {
  height: 9px;
  width: var(--w, 0%);
  min-width: 2px;
  border-radius: 999px;
  background: var(--orange);
}

.player-compare-row.player-b i {
  background: #79a7ff;
}

.player-compare-row b {
  text-align: right;
  color: var(--text);
}

.frame-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background:
    radial-gradient(circle at 80% 18%, rgba(255,106,0,.16), transparent 28%),
    rgba(3,5,8,.9);
  backdrop-filter: blur(22px);
  opacity: 0;
  transform: scale(.985);
  transition: opacity .18s ease, transform .18s ease;
  padding: 14px;
}

.frame-modal.open {
  opacity: 1;
  transform: scale(1);
}

.frame-modal-shell {
  width: 100%;
  height: 100%;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255,106,0,.06), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.018)),
    #07090d;
  box-shadow: 0 24px 90px rgba(0,0,0,.55);
  display: grid;
  grid-template-columns: 302px minmax(0, 1fr);
  grid-template-rows: auto minmax(0, 1fr) auto;
  position: relative;
  overflow: hidden;
}

.frame-modal-header {
  grid-column: 1 / -1;
  min-height: 72px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--line);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 16px;
  background: rgba(0,0,0,.18);
}

.frame-modal-header h2 {
  margin: 4px 0 3px;
  font-size: 1.2rem;
}

.frame-modal-header p {
  margin: 0;
  color: var(--muted);
  font-size: .86rem;
}

.frame-actions button {
  display: inline-flex;
  align-items: center;
  gap: 7px;
}

.frame-actions svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
}

.frame-canvas-stage {
  min-width: 0;
  min-height: 0;
  padding: 14px;
  display: grid;
}

.frame-canvas-wrap {
  min-height: 0;
  display: grid;
  place-items: center;
  padding: 16px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.035), rgba(255,255,255,.012)),
    rgba(0,0,0,.28);
}

#tacticalCanvas {
  max-width: 100%;
  max-height: 100%;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.14);
  background: #000;
  box-shadow: 0 20px 70px rgba(0,0,0,.45);
  cursor: crosshair;
  touch-action: none;
}

.drawing-toolbar {
  min-height: 0;
  overflow: auto;
  padding: 14px;
  border-right: 1px solid rgba(255,255,255,.08);
  background:
    linear-gradient(180deg, rgba(255,106,0,.06), transparent 28%),
    rgba(5,7,10,.68);
  display: grid;
  align-content: start;
  gap: 12px;
}

.tool-group {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px;
}

.tool-section {
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  background: rgba(255,255,255,.025);
}

.tool-section > b {
  color: var(--soft);
  font-size: .72rem;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.tool-group:last-child {
  border-right: 0;
  padding-right: 0;
}

.drawing-toolbar button {
  min-height: 34px;
  padding: 7px 8px;
  display: flex;
  align-items: center;
  gap: 7px;
  border-radius: 8px;
  justify-content: flex-start;
  min-width: 0;
}

.drawing-toolbar button svg {
  width: 16px;
  height: 16px;
  flex: 0 0 auto;
  fill: currentColor;
}

.drawing-toolbar button span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: .74rem;
}

.drawing-toolbar button.active {
  background: var(--orange);
  border-color: var(--orange);
  color: #120a03;
}

.tool-group.colors button {
  width: 24px;
  height: 24px;
  min-height: 24px;
  padding: 0;
  border-radius: 999px;
  background: var(--tool-color);
  border: 2px solid rgba(255,255,255,.35);
}

.tool-group.colors {
  display: flex;
  flex-wrap: wrap;
}

.tool-group.colors button.active {
  box-shadow: 0 0 0 3px rgba(255,106,0,.32);
  border-color: #fff;
}

.preset-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
}

.preset-row button {
  min-height: 28px;
  justify-content: center;
  padding: 5px 7px;
  font-size: .68rem;
}

.preset-row button.active {
  background: rgba(255,106,0,.18);
  border-color: rgba(255,106,0,.62);
  color: #ffb15f;
}

.width-control {
  display: grid;
  gap: 2px;
  font-size: .72rem;
  color: var(--muted);
}

.width-control input {
  min-height: 22px;
  padding: 0;
}

.text-size-control {
  margin-top: 2px;
}

.toggle-control {
  min-height: 30px;
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--muted);
  font-size: .72rem;
}

.toggle-control input {
  width: 15px;
  height: 15px;
  accent-color: var(--orange);
}

.frame-modal-footer {
  grid-column: 1 / -1;
  min-height: 58px;
  padding: 10px 14px;
  border-top: 1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.2);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.frame-modal-footer > span {
  color: var(--muted);
  font-size: .82rem;
}

@media (max-width: 980px) {
  .login-shell, .app-shell, .analysis-layout, .split, .home-modules, .match-card-grid { grid-template-columns: 1fr; }
  .login-shell {
    overflow: auto;
  }
  .login-visual,
  .login-panel {
    min-height: auto;
  }
  .login-visual {
    grid-template-columns: 1fr;
    padding: 34px 24px;
  }
  .login-hero-brand {
    min-height: 250px;
  }
  .login-pitch-frame {
    inset: 28px 8px 20px;
  }
  .login-panel {
    padding: 24px;
  }
  .sidebar {
    height: auto;
    position: static;
  }
  .main { padding: 14px; }
  .span-3, .span-4, .span-5, .span-6, .span-7, .span-8 { grid-column: span 12; }
  .kpi-row { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .analysis-workstation, .physical-kpi-grid, .physical-showdown, .player-h2h { grid-template-columns: 1fr; }
  .home-hero-premium {
    grid-template-columns: 1fr;
    min-height: 0;
    padding: 18px;
  }
  .frame-modal-shell {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto minmax(0, 1fr) auto;
  }
  .drawing-toolbar {
    border-right: 0;
    border-bottom: 1px solid rgba(255,255,255,.08);
    max-height: 240px;
  }
  .tool-group {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .home-hero-content {
    min-height: 0;
  }
  .home-hero-visual {
    min-height: 150px;
  }
  .analysis-topbar {
    grid-template-columns: 1fr auto;
  }
  .analysis-topbar .header-tabs {
    grid-column: 1 / -1;
    justify-self: stretch;
  }
  .analysis-brandline img {
    width: 104px;
  }
  .physical-grid > * { grid-column: span 12; }
  .tactical-header-metrics,
  .tactical-kpi-grid,
  .native-summary-grid,
  .pass-network-grid,
  .native-team-rankings,
  .territory-grid,
  .tactical-comparison-grid {
    grid-template-columns: 1fr;
  }
  .tactical-grid > * {
    grid-column: span 12;
  }
  .tactical-hero-panel {
    align-items: flex-start;
    flex-direction: column;
  }
  .tactical-score-context {
    text-align: left;
  }
  .phase-team-line,
  .efficacy-team {
    grid-template-columns: 92px minmax(0, 1fr) 38px;
  }
  .professional-metric-row {
    grid-template-columns: 1fr;
  }
  .professional-metric-values {
    text-align: left;
  }
  .native-event-row {
    grid-template-columns: 1fr;
  }
  .timeline-buckets {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  .phase-team-line small,
  .efficacy-team small {
    grid-column: 2 / -1;
  }
  .insight-kpis, .physical-card-metrics { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .basic-rankings, .player-comparison-grid { grid-template-columns: 1fr; }
  .physical-scoreboard { order: -1; }
}

@media (max-width: 620px) {
  .login-visual {
    padding: 26px 18px;
  }
  .login-hero-copy h1 {
    font-size: 2.25rem;
  }
  .login-hero-brand {
    min-height: 180px;
  }
  .login-hero-brand img {
    width: min(360px, 94%);
  }
  .login-card {
    padding: 24px 18px;
  }
  .form-grid, .kpi-row, .advanced-grid, .detail-grid, .unique-grid, .client-filters, .insight-kpis, .physical-card-metrics, .physical-card-metrics.single, .compare-selects { grid-template-columns: 1fr; }
  .topbar { align-items: stretch; flex-direction: column; }
  .home-hero-premium {
    padding: 14px;
  }
  .frame-modal {
    padding: 8px;
  }
  .frame-modal-header,
  .frame-modal-footer {
    align-items: stretch;
    grid-template-columns: 1fr;
  }
  .frame-modal-footer {
    flex-direction: column;
  }
  .tool-group {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .home-hero-content h1 {
    font-size: 1.85rem;
  }
  .home-hero-visual {
    display: none;
  }
  .analysis-topbar {
    display: grid;
  }
  .analysis-brandline {
    align-items: flex-start;
    flex-direction: column;
    gap: 8px;
  }
  .analysis-match-title {
    grid-template-columns: 1fr auto;
    width: 100%;
  }
  .analysis-match-title span {
    grid-column: 1 / -1;
  }
  .event-row { grid-template-columns: 94px minmax(0, 1fr); }
  .raw-fields div { grid-template-columns: 1fr; }
  .compare-bar-row, .player-metric-compare div { grid-template-columns: 76px minmax(0, 1fr); }
  .compare-bar-row b, .player-metric-compare div b { grid-column: 2; }
  .distance-donut-layout { grid-template-columns: 1fr; }
  .showdown-team, .showdown-team.right { direction: ltr; grid-template-columns: 1fr; }
  .showdown-team > strong { font-size: 1.45rem; }
  .showdown-metrics { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .possession-board-head,
  .possession-board-values {
    grid-template-columns: 1fr;
    text-align: left;
  }
  .possession-board-head span:last-child,
  .possession-board-values strong:nth-child(3),
  .possession-board-values small:nth-of-type(3) {
    text-align: left;
  }
  .dual-bar-row,
  .native-dual-bars,
  .pass-link-row,
  .pass-link-row span {
    grid-template-columns: 1fr;
  }
  .native-dual-bars span:last-child {
    text-align: left;
  }
  .native-dual-bars .home {
    justify-self: start;
  }
  .dual-bar-row span:last-child {
    text-align: left;
  }
  .comparative-zones .speed-zone-row { grid-template-columns: 1fr; }
  .zone-versus { grid-template-columns: 1fr; }
  .zone-side, .zone-side.right { grid-template-columns: 68px minmax(0, 1fr); }
  .zone-side.left b { text-align: left; }
  .zone-side.left i { justify-self: start; }
  .zone-labels { display: none; }
  .comparative-zones .speed-zone-row > strong { text-align: left; }
  .player-compare-row { grid-template-columns: 24px minmax(0, 1fr); }
  .player-compare-row b { grid-column: 2; text-align: left; }
}
