:root{
  --bg: #020617;
  --accent:#22c55e;
  --accent-soft: rgba(34,197,94,0.15);
  --text:#e5e7eb;
  --muted:#9ca3af;
  --border: rgba(148,163,184,0.25);
  --card: rgba(15,23,42,0.95);
  --ui-scale: 1.15;
  --content-max-w: 1100px;
}

/* Убираем скачок ширины при появлении/исчезновении вертикального скролла */
html{
  overflow-y: scroll;
}

*{box-sizing:border-box;}

body.manualfc-body{
  margin:0;
  font-family:"Segoe UI",system-ui,-apple-system,sans-serif;
  background:
    radial-gradient(circle at 0% 0%, rgba(34,197,94,0.20) 0%, transparent 55%),
    radial-gradient(circle at 100% 0%, rgba(22,163,74,0.25) 0%, transparent 60%),
    linear-gradient(to bottom, #020617 0%, #020617 60%, #02130b 100%);
  background-attachment: fixed;
  background-repeat: no-repeat;
  background-size: cover;
  color: var(--text);
  min-height:100vh;
  /* Global UI scale (Chrome/Edge/Firefox-friendly in practice) */
  zoom: var(--ui-scale);
}

/* NAV (shared) */
.nav{
  position:sticky;
  top:0;
  z-index:50;
  overflow:visible;
  --nav-control-h: 52px;
  --nav-banner-max-h: 100px;
  min-height: calc(var(--nav-banner-max-h) + 6px);
  background: linear-gradient(to bottom, rgba(2,6,23,0.82), rgba(2,6,23,0.42));
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(34,197,94,0.28);
}
/* Шапка на всю ширину окна; центр — баннер; ссылки «внутрь» от краёв к центру */
.nav-inner{
  width:100%;
  max-width:none;
  margin:0;
  padding:6px clamp(14px, 3vw, 40px) 0;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);
  align-items:flex-end;
  min-height: calc(var(--nav-banner-max-h) + 6px);
  gap:12px 16px;
}
.nav-cluster{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  min-height: var(--nav-control-h, 52px);
  margin-bottom: calc((var(--nav-banner-max-h) - var(--nav-control-h, 52px)) / 2);
  gap:8px;
}
.nav-cluster--left{
  justify-content:flex-end;
}
.nav-cluster--right{
  justify-content:flex-start;
}
.nav-brand-center{
  justify-self:center;
  flex-shrink:0;
  font-weight:700;
  font-size:1rem;
}
.nav-left{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:700;
  font-size:1rem;
}
.nav-left-actions{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:6px;
}
.nav-home-link{
  color:inherit;
  text-decoration:none;
  display:flex;
  align-items:center;
  gap:10px;
}
/* Для центрального бренда логотипы вплотную к тексту */
.nav-home-link.nav-brand-center{
  gap:0;
  cursor:pointer;
  touch-action:manipulation;
  align-items:flex-end;
  line-height:0;
}
.nav-home-link.nav-brand-center img{
  user-select:none;
  -webkit-user-drag:none;
}
.nav-brand-side-logo{
  width:78px;
  height:78px;
  object-fit:contain;
  position:relative;
  top:14px;
  margin:0;
  filter:drop-shadow(0 0 10px rgba(34,197,94,.7));
}
.nav-brand-text{
  margin:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  line-height:1;
  gap:4px;
  transform:translateY(4px);
  pointer-events:none;
}
.nav-brand-text-top{
  display:block;
  font-weight:700;
  letter-spacing:0.02em;
}
.nav-brand-text-main{
  display:block;
  font-size:1.1rem;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:#86efac;
  text-shadow:0 0 12px rgba(34,197,94,.6);
}
.nav-header-banner{
  display:block;
  width:auto;
  max-width:min(994px, 74vw);
  max-height:var(--nav-banner-max-h, 100px);
  height:auto;
  margin:0;
  object-fit:contain;
  object-position: bottom center;
  vertical-align:bottom;
  filter:drop-shadow(0 0 10px rgba(34,197,94,.45));
}
.nav-header-banner--mobile{
  max-width:min(414px, 74vw);
  max-height:61px;
}
.nav-right{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:flex-end;
  align-items:center;
}
.logo-ball{
  width:26px;
  height:26px;
  border-radius:50%;
  border:2px solid var(--accent);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:.9rem;
  color:var(--accent);
  box-shadow:0 0 12px rgba(34,197,94,0.55);
}
.nav-link{
  box-sizing:border-box;
  height:var(--nav-control-h, 52px);
  min-height:var(--nav-control-h, 52px);
  max-height:var(--nav-control-h, 52px);
  padding:0 14px;
  border-radius:999px;
  font-size:.82rem;
  line-height:1.1;
  text-decoration:none;
  color:var(--muted);
  border:1px solid transparent;
  transition:.15s ease;
  white-space:nowrap;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
/* Шапка: один рост по высоте (не даём line-height/emoji раздувать кнопки) */
header.nav .nav-link,
header.nav .nav-btn.nav-link{
  height:var(--nav-control-h);
  min-height:var(--nav-control-h);
  max-height:var(--nav-control-h);
  padding:0 14px;
  line-height:1.1;
}
header.nav #nav-bell-btn.nav-link{
  font-size:1.05rem;
  line-height:1;
}
header.nav #nav-user-block{
  display:inline-flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
}
header.nav a.nav-nick-link{
  box-sizing:border-box;
  height:var(--nav-control-h);
  min-height:var(--nav-control-h);
  max-height:var(--nav-control-h);
  padding:0 14px;
  line-height:1.1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
header.nav #nav-team-pill > a{
  box-sizing:border-box;
  height:var(--nav-control-h);
  min-height:var(--nav-control-h);
  max-height:var(--nav-control-h);
  padding:0 14px;
  line-height:1.1;
}
.nav-link:hover{
  color:var(--accent);
  border-color:rgba(34,197,94,.5);
  background:var(--accent-soft);
}
.nav-link-primary{
  color:#0b1120;
  background:var(--accent);
  border-color:var(--accent);
  font-weight:700;
}
.nav-link-primary:hover{
  background:#16a34a;
  border-color:#16a34a;
  color:#e5e7eb;
}
.nav-link-active{
  color:var(--accent);
  border-color:rgba(34,197,94,.45);
  background:rgba(34,197,94,.10);
}
.nav-btn{
  background:none;
  border:none;
  cursor:pointer;
  font:inherit;
}

/* Desktop-only full header (mobile uses compact bar + drawer). */
@media (max-width: 768px) {
  body.manualfc-body {
    zoom: 1;
  }

  .page-wrap,
  main.page-wrap.manualfc-main-grow {
    max-width: none;
    width: 100%;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box;
  }

  .nav {
    min-height: 0;
    --nav-banner-max-h: 61px;
  }

  .nav-desktop-only {
    display: none !important;
  }

  .nav-mobile-bar {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 10px;
    width: 100%;
    padding: 6px clamp(12px, 3vw, 20px) 0;
    min-height: calc(var(--nav-banner-max-h) + 6px);
    box-sizing: border-box;
  }

  .nav-drawer-toggle {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    height: 40px;
    margin-bottom: 2px;
    padding: 0 12px;
    border-radius: 999px;
    border: 1px solid rgba(34, 197, 94, 0.45);
    background: rgba(2, 6, 23, 0.75);
    color: var(--text, #e5e7eb);
    font: inherit;
    font-size: 0.82rem;
    font-weight: 700;
    cursor: pointer;
    touch-action: manipulation;
  }

  .nav-drawer-toggle-icon {
    font-size: 1.1rem;
    line-height: 1;
  }

  .nav-mobile-brand {
    flex: 1;
    min-width: 0;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    gap: 6px;
    text-decoration: none;
    color: inherit;
    font-weight: 800;
    font-size: 0.78rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    touch-action: manipulation;
    line-height: 0;
  }

  .nav-mobile-brand img,
  .nav-mobile-brand .nav-header-banner {
    width: auto;
    height: auto;
    max-height: var(--nav-banner-max-h, 61px);
    object-fit: contain;
    object-position: bottom center;
    filter: drop-shadow(0 0 8px rgba(34, 197, 94, 0.55));
  }

  .nav-mobile-brand-text {
    display: flex;
    flex-direction: column;
    align-items: center;
    line-height: 1.05;
    color: #86efac;
    text-shadow: 0 0 10px rgba(34, 197, 94, 0.45);
  }

  .nav-mobile-slot {
    flex-shrink: 0;
    width: 40px;
    margin-bottom: 2px;
  }

  .nav-mobile-hide {
    display: none !important;
  }

  .nav-drawer-backdrop {
    position: fixed;
    inset: 0;
    z-index: 199;
    border: none;
    margin: 0;
    padding: 0;
    background: rgba(0, 0, 0, 0.62);
    backdrop-filter: blur(2px);
    cursor: pointer;
  }

  .nav-drawer-backdrop[hidden] {
    display: none !important;
  }

  .nav-drawer {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 200;
    width: min(86vw, 320px);
    max-width: 320px;
    height: 100%;
    height: 100dvh;
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    background: linear-gradient(180deg, rgba(2, 8, 4, 0.98), rgba(2, 6, 23, 0.98));
    border-right: 1px solid rgba(34, 197, 94, 0.35);
    box-shadow: 8px 0 40px rgba(0, 0, 0, 0.55);
    transform: translateX(-105%);
    transition: transform 0.22s ease;
    overflow: hidden;
  }

  html.nav-drawer-open .nav-drawer {
    transform: translateX(0);
  }

  .nav-drawer-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 14px 10px;
    padding-top: max(14px, env(safe-area-inset-top));
    border-bottom: 1px solid rgba(34, 197, 94, 0.22);
  }

  .nav-drawer-title {
    font-size: 0.85rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #86efac;
  }

  .nav-drawer-close {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    border: 1px solid rgba(148, 163, 184, 0.35);
    background: rgba(15, 23, 42, 0.8);
    color: #e5e7eb;
    font-size: 1.35rem;
    line-height: 1;
    cursor: pointer;
  }

  .nav-drawer-links {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 12px 10px;
    overflow-y: auto;
    flex: 1;
  }

  .nav-drawer-link {
    display: block;
    padding: 12px 14px;
    border-radius: 10px;
    text-decoration: none;
    color: #cbd5e1;
    font-size: 0.92rem;
    font-weight: 600;
    border: 1px solid transparent;
  }

  .nav-drawer-link:hover,
  .nav-drawer-link:focus-visible {
    color: var(--accent, #22c55e);
    border-color: rgba(34, 197, 94, 0.35);
    background: rgba(34, 197, 94, 0.08);
  }

  .nav-drawer-link.nav-link-active {
    color: #bbf7d0;
    border-color: rgba(34, 197, 94, 0.5);
    background: rgba(34, 197, 94, 0.14);
  }

  .nav-drawer-user {
    padding: 12px 10px 16px;
    padding-bottom: max(16px, env(safe-area-inset-bottom));
    border-top: 1px solid rgba(34, 197, 94, 0.22);
    display: flex;
    flex-direction: column;
    gap: 6px;
  }

  .nav-drawer-btn {
    width: 100%;
    text-align: left;
    cursor: pointer;
    font: inherit;
    background: rgba(15, 23, 42, 0.6);
  }

  .nav-drawer-link--profile {
    color: #ccfbf1;
    font-weight: 800;
    border-color: rgba(45, 212, 191, 0.35);
    background: rgba(8, 47, 73, 0.35);
  }

  html.nav-drawer-open {
    overflow: hidden;
  }
}

@media (min-width: 769px) {
  .nav-mobile-bar,
  .nav-drawer,
  .nav-drawer-backdrop {
    display: none !important;
  }
}

@media (min-width: 769px) and (max-width: 1100px) {
  .nav-inner {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
  }
  .nav-cluster--left,
  .nav-cluster--right {
    justify-content: center;
  }
  .nav-brand-center {
    order: -1;
  }
}

/* Старый двухколоночный вариант (страницы без nav.js до обновления разметки) */
.nav-inner--legacy{
  display:flex;
  justify-content:space-between;
  max-width:1300px;
  margin:0 auto;
}
.nav-inner--legacy .nav-right{
  justify-content:flex-end;
}
@media(max-width:640px){
  .nav-inner--legacy{
    flex-direction:column;
    align-items:flex-start;
  }
  .nav-inner--legacy .nav-right{
    justify-content:flex-start;
  }
}

/* Бета: плашка «в разработке» (assets/beta-wip.js) */
.nav-wip-badge{
  display:inline-block;
  margin-left:4px;
  padding:1px 6px;
  border-radius:999px;
  font-size:.58rem;
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
  vertical-align:middle;
  color:#fde68a;
  border:1px solid rgba(251,191,36,.45);
  background:rgba(251,191,36,.12);
  box-shadow:0 0 10px rgba(251,191,36,.15);
}
.nav-wip-link{
  opacity:.88;
}
.nav-wip-hidden{
  display:none !important;
}
.beta-wip-overlay{
  position:fixed;
  inset:0;
  z-index:45;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px 16px 32px;
  background:rgba(2,6,23,.88);
  backdrop-filter:blur(8px);
}
header.nav{z-index:50;}
.beta-wip-card{
  width:min(480px,100%);
  padding:24px 20px 20px;
  border-radius:18px;
  border:1px solid rgba(251,191,36,.35);
  background:
    radial-gradient(circle at top left, rgba(251,191,36,.12), transparent 55%),
    rgba(15,23,42,.97);
  box-shadow:0 24px 60px rgba(0,0,0,.65);
  text-align:center;
}
.beta-wip-badge-large{
  display:inline-block;
  margin-bottom:12px;
  padding:5px 12px;
  border-radius:999px;
  font-family:"Share Tech Mono",ui-monospace,monospace;
  font-size:.68rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#fde68a;
  border:1px solid rgba(251,191,36,.45);
  background:rgba(251,191,36,.08);
}
.beta-wip-title{
  margin:0 0 10px;
  font-size:1.35rem;
  color:#fef3c7;
}
.beta-wip-lead{
  margin:0 0 18px;
  font-size:.9rem;
  line-height:1.65;
  color:#cbd5e1;
}
.beta-wip-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:center;
}
.beta-wip-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 16px;
  border-radius:999px;
  font-size:.88rem;
  font-weight:700;
  text-decoration:none;
  cursor:pointer;
  border:1px solid transparent;
  font-family:inherit;
}
.beta-wip-btn-primary{
  color:#022c22;
  background:linear-gradient(135deg,#10b981,#22c55e);
  box-shadow:0 12px 24px rgba(16,185,129,.25);
}
.beta-wip-btn-outline{
  color:#bbf7d0;
  border-color:rgba(74,222,128,.45);
  background:rgba(2,6,23,.55);
}
.beta-wip-btn-ghost{
  color:#fde68a;
  border-color:rgba(251,191,36,.35);
  background:transparent;
}
html.beta-wip-active .manualfc-main-grow,
html.beta-wip-active main:not(header.nav),
html.beta-wip-active .page-wrap,
html.beta-wip-active .hero-wrap,
html.beta-wip-active .container{
  pointer-events:none;
  user-select:none;
}

/* Счёт и пенальти — двузначные значения (12:3 и т.д.) */
input.score-in[type="number"],
.score-in[type="number"]{
  width:3.4rem;
  min-width:3.4rem;
  max-width:4.2rem;
  padding:5px 6px;
  border-radius:7px;
  border:1px solid var(--border);
  background:#020617;
  color:var(--text);
  font-size:0.9rem;
  outline:none;
  text-align:center;
  box-sizing:border-box;
}
input.score-in[type="number"]:focus,
.score-in[type="number"]:focus{
  border-color:rgba(34,197,94,0.5);
  box-shadow:0 0 0 1px rgba(34,197,94,0.22);
}

