:root{
  --ice:#eaf4fb; --ice-2:#d6e9f6; --navy:#0b2a4a; --navy-2:#163e63;
  --accent:#1e7fc2; --accent-dark:#155f93; --text:#1c2733; --muted:#5b6b7b;
  --line:#d8e3ec; --white:#fff; --radius:12px; --shadow:0 4px 18px rgba(11,42,74,.08);
}
*{box-sizing:border-box}
body{margin:0;font-family:"Segoe UI",system-ui,-apple-system,sans-serif;
  color:var(--text);background:var(--ice);line-height:1.55}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.container{width:min(1180px,92%);margin:0 auto}
img{max-width:100%}

/* Header */
.site-header{background:var(--navy);color:#fff;position:sticky;top:0;z-index:50}
.header-inner{display:flex;align-items:center;gap:24px;padding:14px 0;flex-wrap:wrap}
.logo{display:flex;align-items:center;gap:10px;color:#fff;font-weight:700;font-size:18px}
.logo:hover{text-decoration:none}
.logo-mark{font-size:26px}
.logo-img{height:90px;width:auto;display:block}
.logo-text{max-width:260px}
.main-nav{display:flex;flex-wrap:wrap;gap:6px 4px;flex:1}
.main-nav a{color:#cfe2f1;padding:8px 12px;border-radius:8px;font-size:14px;white-space:nowrap}
.main-nav a:hover{background:var(--navy-2);color:#fff;text-decoration:none}
.header-account{margin-left:auto}
.nav-toggle{display:none;background:none;border:0;color:#fff;font-size:24px;cursor:pointer}

.btn{display:inline-block;background:var(--accent);color:#fff;padding:10px 18px;
  border-radius:8px;border:0;cursor:pointer;font-size:15px}
.btn:hover{background:var(--accent-dark);text-decoration:none}
.btn-sm{padding:7px 14px;font-size:14px}
.btn-outline{background:transparent;border:1px solid #4f7ea3;color:#fff}
.btn-outline:hover{background:var(--navy-2)}

/* Layout */
.page{padding:32px 0 56px;min-height:60vh}
h1{color:var(--navy);font-size:30px;margin:0 0 18px}
h2{color:var(--navy);font-size:22px}
.lead{color:var(--muted);font-size:18px}
.section-title{display:flex;align-items:baseline;justify-content:space-between;
  border-bottom:2px solid var(--ice-2);padding-bottom:10px;margin-bottom:22px}

/* Hero */
.hero{background:linear-gradient(135deg,var(--navy),var(--accent));color:#fff;
  border-radius:var(--radius);padding:48px 40px;margin-bottom:36px}
.hero h1{color:#fff;font-size:34px}
.hero p{color:#dcebf7;font-size:18px;max-width:680px}

/* Cards / grid */
.grid{display:grid;gap:20px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column}
.card .card-body{padding:18px}
.card img{width:100%;height:180px;object-fit:cover}
.card h3{margin:0 0 8px;font-size:18px;color:var(--navy)}
.meta{color:var(--muted);font-size:13px}

/* Lists / tables */
.list{list-style:none;padding:0;margin:0}
.list li{background:#fff;border:1px solid var(--line);border-radius:10px;
  padding:14px 18px;margin-bottom:10px;display:flex;justify-content:space-between;
  gap:16px;align-items:center;flex-wrap:wrap}
table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow)}
th,td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--line)}
th{background:var(--ice-2);color:var(--navy);font-size:14px}
tr:hover td{background:var(--ice)}

/* Filters / forms */
.filters{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:22px}
.filters input,.filters select,.form input,.form select,.form textarea{
  padding:10px 12px;border:1px solid var(--line);border-radius:8px;font:inherit}
.form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;max-width:480px;box-shadow:var(--shadow)}
.form label{display:block;font-weight:600;margin:14px 0 6px;color:var(--navy)}
.form input,.form select,.form textarea{width:100%}
.form .helptext,.form .errorlist{font-size:13px;color:var(--muted);margin:4px 0}
.form .errorlist{color:#c0392b;list-style:none;padding:0}

.messages{margin-top:16px}
.message{padding:12px 16px;border-radius:8px;margin-bottom:8px;background:var(--ice-2)}
.message.success{background:#dff3e4;color:#1d6a3a}
.message.error{background:#fde4e1;color:#a3271b}
.message.warning{background:#fcefd6;color:#8a5b00}

.badge{display:inline-block;font-size:12px;padding:3px 9px;border-radius:999px;
  background:var(--ice-2);color:var(--navy)}
.empty{color:var(--muted);text-align:center;padding:48px;background:#fff;
  border:1px dashed var(--line);border-radius:var(--radius)}
.pagination{display:flex;gap:8px;justify-content:center;margin-top:28px}
.pagination a,.pagination span{padding:8px 14px;border:1px solid var(--line);
  border-radius:8px;background:#fff}
.prose{background:#fff;padding:30px;border-radius:var(--radius);
  box-shadow:var(--shadow);max-width:880px}
.prose h2{margin-top:28px}
.prose-wide{max-width:none}

/* Документы — карточки */
.doc-cat{margin:34px 0 16px;color:var(--navy)}
.doc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.doc-card{display:flex;flex-direction:column;gap:14px;padding:26px;
  min-height:220px;border-radius:16px;color:#fff;text-decoration:none;
  background:linear-gradient(140deg,var(--navy) 0%,var(--navy-2) 45%,var(--accent) 100%);
  box-shadow:0 8px 22px rgba(11,42,74,.18);
  transition:transform .15s ease,box-shadow .15s ease}
.doc-card:hover{transform:translateY(-4px);text-decoration:none;
  box-shadow:0 14px 30px rgba(11,42,74,.28)}
.doc-ico{width:48px;height:48px;border-radius:12px;background:rgba(255,255,255,.12);
  display:flex;align-items:center;justify-content:center}
.doc-title{font-size:18px;font-weight:700;text-transform:uppercase;
  letter-spacing:.3px;line-height:1.3}
.doc-date{font-size:15px;color:#dcebf7}
.doc-card-green{background:linear-gradient(140deg,#0c3b2b 0%,#13684b 45%,#1f9d6b 100%)}
.doc-card-green:hover{box-shadow:0 14px 30px rgba(12,59,43,.32)}
.doc-updated{font-size:13px;font-weight:600;color:#ff6b6b}
.doc-desc{font-size:14px;color:#bcd3e6;margin-top:auto;line-height:1.5}
@media(max-width:980px){.doc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.doc-grid{grid-template-columns:1fr}}

/* Ссылки соревнования: табло и трансляции */
.event-links{display:flex;flex-wrap:wrap;gap:14px;margin:24px 0}
.event-link{display:flex;align-items:center;gap:12px;padding:14px 22px;
  background:#fff;border:1px solid var(--line);border-radius:12px;
  font-weight:600;color:var(--navy);box-shadow:var(--shadow)}
.event-link:hover{text-decoration:none;border-color:var(--accent);
  transform:translateY(-2px);transition:.15s}
.event-link img,.event-link svg{flex:none}
.event-link.scoreboard{border-left:4px solid #e8453c}
.event-link.broadcast{border-left:4px solid var(--accent)}

/* Аккордеон (раскрывающиеся секции) */
.acc{background:#fff;border:1px solid var(--line);border-radius:12px;
  margin:14px 0;box-shadow:var(--shadow);overflow:hidden}
.acc>summary{cursor:pointer;list-style:none;padding:16px 22px;
  font-weight:700;color:var(--navy);font-size:18px;background:var(--ice-2);
  display:flex;align-items:center;justify-content:space-between;gap:14px}
.acc>summary::-webkit-details-marker{display:none}
.acc>summary::after{content:"+";font-size:22px;color:var(--accent);
  font-weight:700;line-height:1}
.acc[open]>summary{border-bottom:1px solid var(--line)}
.acc[open]>summary::after{content:"\2013"}
.acc>summary:hover{background:var(--ice)}
.acc .acc-body{padding:18px 22px}
.acc .acc-body>:first-child{margin-top:0}
.acc .acc-body>:last-child{margin-bottom:0}
.acc-body table.req{box-shadow:none}
.acc-body table.req th{width:34%;white-space:nowrap;vertical-align:top;
  font-weight:600}

/* Страница «Федерация» */
.fed-intro{display:flex;gap:26px;align-items:flex-start;margin-bottom:8px}
.fed-intro img{width:130px;height:130px;object-fit:contain;flex:none}
.prose .fed-lead{font-size:18px;color:var(--muted)}
.prose table.req th{width:38%;white-space:nowrap;vertical-align:top}
.fed-people{list-style:none;padding:0;margin:0}
.fed-people li{padding:10px 0;border-bottom:1px solid var(--line)}
.fed-people li:last-child{border-bottom:0}
.fed-people .role{color:var(--muted);font-size:14px}
@media(max-width:640px){.fed-intro{flex-direction:column;gap:16px}
  .fed-intro img{width:96px;height:96px}}

/* Шапка соревнования */
.event-head{display:flex;align-items:center;gap:22px}
.event-logo{width:192px;height:192px;object-fit:contain;flex:none}
@media(max-width:640px){.event-logo{width:128px;height:128px}}

/* Footer */
.site-footer{background:var(--navy);color:#bcd3e6;margin-top:40px}
.footer-inner{padding:36px 0;display:grid;gap:18px}
.footer-links{display:flex;gap:18px}
.footer-links a{color:#cfe2f1}
.footer-bottom{border-top:1px solid var(--navy-2);padding-top:16px;font-size:13px}

@media(max-width:980px){
  html,body{overflow-x:hidden}
  .grid-3{grid-template-columns:1fr 1fr}
  .header-inner{gap:12px}
  .logo{flex:1;min-width:0;font-size:15px;order:1}
  .logo-img{height:54px}
  .logo-text{max-width:none;font-size:15px;line-height:1.2}
  .nav-toggle{display:block;order:2;font-size:28px;padding:4px 8px}
  .header-account{order:3;margin-left:0}
  .main-nav{display:none;order:4;flex-basis:100%;width:100%;
    flex-direction:column;gap:2px;background:var(--navy-2);
    border-radius:10px;padding:8px;margin-top:6px}
  body.nav-open .main-nav{display:flex}
  .main-nav a{display:block;width:100%;padding:12px 14px;font-size:15px}
}
@media(max-width:640px){
  .grid-3,.grid-2{grid-template-columns:1fr}
  .hero{padding:32px 22px}
  h1{font-size:25px}
  .logo-img{height:46px}
  .logo-text{font-size:14px}
  /* Реквизиты: на телефоне — стопкой (заголовок над значением) */
  table.req,table.req tbody,table.req tr,
  table.req th,table.req td{display:block;width:100%}
  table.req{box-shadow:none}
  table.req tr{border:1px solid var(--line);border-radius:10px;
    background:#fff;margin-bottom:10px;overflow:hidden}
  table.req th{white-space:normal;width:auto;text-align:left;
    background:var(--ice-2);color:var(--navy);font-weight:600;
    padding:8px 14px;border:0}
  table.req td{padding:10px 14px;border:0;
    word-break:break-word;overflow-wrap:anywhere}
  table.table-cards{box-shadow:none;background:transparent}
  table.table-cards thead{display:none}
  table.table-cards,table.table-cards tbody,
  table.table-cards td{display:block;width:100%}
  table.table-cards tr{display:flex;flex-direction:column;
    margin-bottom:14px;border:1px solid var(--line);
    border-radius:12px;background:#fff;box-shadow:var(--shadow);
    padding:0 0 6px;overflow:hidden;width:100%}
  table.table-cards td{border:0;border-bottom:1px solid var(--ice-2);
    padding:10px 16px;display:flex;justify-content:space-between;
    align-items:flex-start;gap:14px;text-align:right}
  table.table-cards td:last-child{border-bottom:0}
  table.table-cards td::before{content:attr(data-label);font-weight:600;
    color:var(--navy);text-align:left;flex:none;max-width:45%}
  /* название события — заголовком наверху карточки */
  table.table-cards td[data-label="Событие"]{order:-1;display:block;
    text-align:left;font-size:17px;font-weight:700;
    background:var(--ice-2);padding:12px 16px;border-bottom:0}
  table.table-cards td[data-label="Событие"]::before{display:none}
  table.table-cards td[data-label="Событие"] a{color:var(--navy)}
  table.table-cards tr:hover td{background:inherit}
  table.table-cards td[data-label="Событие"]:hover{background:var(--ice-2)}
}
