:root{
  --bg:#070b18; --bg2:#0a1022; --panel:rgba(255,255,255,.06); --panel2:rgba(255,255,255,.10);
  --panel3:rgba(255,255,255,.14); --text:#edf2ff; --muted:#aeb9d6; --line:rgba(255,255,255,.14);
  --accent:#4ea3ff; --accent2:#91d7ff; --ocean:#0d1730; --land:#1b2a4d; --land-hover:#284070;
  --confirmed:#35b979; --future:#32bfd1; --partial:#e8b34b; --expiring:#a277ff;
  --unknown:#9aa3bd; --tender:#4ea3ff; --no_data:#59627a; --danger:#e46d82;
  --radius:14px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--bg)}
body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  background:radial-gradient(circle at 14% -8%,#1c356b 0,var(--bg) 46%),linear-gradient(135deg,#060a15,#0a1022);
  background-color:var(--bg);background-attachment:fixed;color:var(--text);min-height:100vh}
a{color:var(--accent2);text-decoration:none}
a:hover{text-decoration:underline}
button,input,select,textarea{font-family:inherit;font-size:14px;color:var(--text)}
/* Тёмный фон по умолчанию для любых полей (в т.ч. в строках админ-таблиц,
   которые не обёрнуты в .field) — иначе светлый текст на белом не виден. */
input,select,textarea{background:var(--panel2);border:1px solid var(--line);
  border-radius:9px;padding:8px 10px}
input::placeholder,textarea::placeholder{color:var(--muted);opacity:1}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent)}
/* Список опций выпадающих меню (нативный рендер ОС бывает белым) */
select option,select optgroup{background:#0e1530;color:var(--text)}

/* ---------- Топ-меню ---------- */
.topbar{display:flex;align-items:center;gap:18px;padding:12px 26px;border-bottom:1px solid var(--line);
  background:rgba(7,11,24,.72);backdrop-filter:blur(8px);position:sticky;top:0;z-index:50}
.brand{font-weight:800;letter-spacing:-.02em;font-size:18px;white-space:nowrap;color:#fff}
.brand small{display:block;font-weight:500;font-size:11px;color:var(--muted);letter-spacing:0}
.nav{display:flex;gap:4px;flex-wrap:wrap;flex:1}
.nav a{padding:8px 12px;border-radius:9px;color:var(--muted);font-size:13.5px;font-weight:600}
.nav a:hover{background:var(--panel);color:var(--text);text-decoration:none}
.nav a.active{background:var(--panel2);color:#fff}
.topbar .search{position:relative}
.topbar .search input{width:240px;padding:9px 12px 9px 34px;border-radius:999px;border:1px solid var(--line);
  background:var(--panel);color:var(--text)}
.topbar .search svg{position:absolute;left:11px;top:9px;opacity:.6}
.userbox{display:flex;align-items:center;gap:10px;white-space:nowrap}
.userbox .role{font-size:11px;padding:3px 8px;border-radius:999px;background:var(--panel2);color:var(--muted)}
.userbox .role.admin{background:rgba(78,163,255,.2);color:#bcdcff}

/* ---------- Общие ---------- */
.wrap{padding:24px 26px;max-width:1500px;margin:0 auto}
h1{font-size:clamp(24px,3vw,38px);letter-spacing:-.03em;margin:0 0 6px}
h2{font-size:20px;margin:26px 0 12px;letter-spacing:-.02em}
.muted{color:var(--muted)}
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 15px;border-radius:10px;border:1px solid var(--line);
  background:var(--panel2);color:var(--text);cursor:pointer;font-weight:600;font-size:13.5px;transition:.15s}
.btn:hover{background:var(--panel3);text-decoration:none}
.btn.primary{background:linear-gradient(135deg,#4ea3ff,#3b6fe0);border-color:transparent;color:#fff}
.btn.primary:hover{filter:brightness(1.08)}
.btn.danger{background:rgba(228,109,130,.18);border-color:rgba(228,109,130,.4);color:#ffc4ce}
.btn.sm{padding:5px 10px;font-size:12.5px}
.row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.spacer{flex:1}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.grid{display:grid;gap:14px}

/* ---------- Бейджи статусов ---------- */
.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:12px;
  font-weight:600;border:1px solid var(--line);background:var(--panel2);white-space:nowrap}
.dot{width:9px;height:9px;border-radius:50%;display:inline-block}

/* ---------- Формы / фильтры ---------- */
.filters{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;margin:14px 0}
.field{display:flex;flex-direction:column;gap:4px}
.field label{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.field input,.field select,.field textarea{padding:9px 11px;border-radius:9px;border:1px solid var(--line);
  background:var(--panel);color:var(--text);min-width:150px}
.field textarea{min-height:70px;resize:vertical;width:100%}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent)}

/* ---------- Таблицы ---------- */
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:var(--radius);background:rgba(10,16,34,.5)}
table{border-collapse:collapse;width:100%;font-size:13px}
th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:top}
th{position:sticky;top:0;background:#0e1530;font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;
  color:var(--muted);font-weight:700;z-index:1;white-space:nowrap}
th a{color:var(--muted)}
tbody tr:hover{background:rgba(255,255,255,.04)}
td .small{font-size:11.5px;color:var(--muted)}

/* ---------- Flash ---------- */
.flash{padding:11px 16px;border-radius:10px;margin-bottom:14px;font-weight:600;font-size:13.5px}
.flash.ok{background:rgba(53,185,121,.15);border:1px solid rgba(53,185,121,.4);color:#aef0cf}
.flash.error{background:rgba(228,109,130,.15);border:1px solid rgba(228,109,130,.4);color:#ffc4ce}

/* ---------- Логин ---------- */
.login-page{display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-height:100vh;padding:20px}
.login-card{width:380px;max-width:100%;background:var(--panel);border:1px solid var(--line);
  border-radius:18px;padding:34px}
.login-card h1{font-size:26px}
.login-card .field{margin-bottom:14px}
.login-card .field input{width:100%}
/* Вкладки Вход / Регистрация */
.auth-tabs{display:flex;gap:6px;margin-top:18px;background:var(--panel);border:1px solid var(--line);
  border-radius:11px;padding:4px}
.auth-tab{flex:1;padding:9px 12px;border:0;border-radius:8px;background:transparent;color:var(--muted);
  font-weight:600;cursor:pointer;transition:.15s}
.auth-tab:hover{color:var(--text)}
.auth-tab.active{background:var(--panel3);color:#fff}
.auth-panel{margin-top:16px}
/* Слот под сообщение: резервирует место, чтобы карточка не «прыгала» */
.flash-slot{margin-top:14px}
.flash-slot:empty{display:none}
.flash-slot .flash{margin-bottom:0}

/* ---------- Главная ---------- */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin:20px 0}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px}
.stat .n{font-size:30px;font-weight:800;letter-spacing:-.03em}
.stat .l{color:var(--muted);font-size:12.5px;margin-top:2px}
.sport-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}
.sport-card{display:block;background:linear-gradient(135deg,rgba(78,163,255,.12),var(--panel));
  border:1px solid var(--line);border-radius:var(--radius);padding:22px;transition:.15s}
.sport-card:hover{border-color:var(--accent);transform:translateY(-2px);text-decoration:none}
.sport-card .ico{font-size:34px}
.sport-card h3{margin:10px 0 4px;font-size:20px;color:#fff}

/* ---------- Карта ---------- */
.map-layout{display:grid;grid-template-columns:1fr 380px;gap:18px;align-items:start}
.map-box{position:relative;background:var(--ocean);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;min-height:540px}
.map-box svg{width:100%;height:auto;max-height:78vh;display:block}
.country{fill:var(--land);stroke:#0a1226;stroke-width:1.2;cursor:pointer;transition:fill .15s,filter .15s}
.country:hover{filter:brightness(1.25)}
.country.dim{opacity:.28}
.country.sel{stroke:#fff;stroke-width:2.4}
.clabel{font-size:14px;fill:#dfe8ff;pointer-events:none;font-weight:600;text-shadow:0 1px 3px #000;
  paint-order:stroke;stroke:#070b18;stroke-width:3px}
.legend{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.legend .badge{cursor:pointer}
.legend .badge.off{opacity:.4}

/* Карточка страны */
.country-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;position:sticky;top:78px;max-height:calc(100vh - 96px);overflow:auto}
.country-card .empty{color:var(--muted);text-align:center;padding:40px 10px}
.cc-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.cc-head h3{margin:0;font-size:22px}
.cc-rec{border:1px solid var(--line);border-radius:11px;padding:12px;margin-top:10px;background:var(--panel2)}
.cc-rec .comp{font-weight:700;font-size:14.5px;margin-bottom:6px}
.cc-rec dl{display:grid;grid-template-columns:auto 1fr;gap:3px 10px;margin:0;font-size:12.5px}
.cc-rec dt{color:var(--muted)}
.cc-rec dd{margin:0}

/* QR-код 2FA: белая подложка, SVG масштабируется внутрь рамки */
.qr-code{background:#fff;display:inline-block;padding:10px;border-radius:10px;
  margin:6px 0;max-width:100%;line-height:0}
.qr-code svg{display:block;width:200px;height:200px;max-width:100%}

/* Тонкая прокрутка */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:6px}
::-webkit-scrollbar-track{background:transparent}

@media (max-width:1080px){
  .map-layout{grid-template-columns:1fr}
  .country-card{position:static;max-height:none}
  .topbar .search input{width:160px}
}
