@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap');

:root{
  --blue:#0057d9;
  --blue-2:#0b6ff2;
  --navy:#03142f;
  --navy-2:#061f47;
  --text:#061a3a;
  --muted:#72809a;
  --line:#dce5f2;
  --bg:#f5f8fd;
  --card:#ffffff;
  --shadow:0 18px 45px rgba(6, 26, 58, .10);
  --shadow-soft:0 10px 26px rgba(6, 26, 58, .08);
  --radius:24px;
  --radius-sm:16px;
  --container:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Manrope', Arial, sans-serif;
  color:var(--text);
  background:#fff;
  line-height:1.5;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,textarea{font:inherit}

.container{
  width:min(var(--container), calc(100% - 48px));
  margin:0 auto;
}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:
    radial-gradient(circle at 7% 0%, rgba(255,255,255,.14), transparent 28%),
    linear-gradient(135deg, #03142f 0%, #052b66 55%, #021126 100%);
  color:#fff;
  box-shadow:0 8px 30px rgba(0,0,0,.18);
}
.site-header--transparent{position:absolute;left:0;right:0;background:linear-gradient(180deg, rgba(3,20,47,.94), rgba(3,20,47,.65), rgba(3,20,47,0));box-shadow:none}
.header-row{
  height:86px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:30px;
}
.logo{
  display:flex;
  align-items:center;
  gap:14px;
  min-width:210px;
}
.logo-mark{
  width:58px;
  height:58px;
  display:grid;
  place-items:center;
  position:relative;
  color:#fff;
  font-size:46px;
  font-family:Georgia, serif;
  font-weight:700;
}
.logo-mark:before{
  content:"★★";
  position:absolute;
  top:-9px;
  left:8px;
  font-size:13px;
  letter-spacing:4px;
  font-family:Arial, sans-serif;
}
.logo-text{
  font-weight:800;
  line-height:1.05;
  letter-spacing:.02em;
  font-size:22px;
}
.logo-city{
  display:block;
  font-size:13px;
  font-weight:700;
  opacity:.88;
  margin-top:2px;
}
.nav{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:42px;
  font-weight:600;
  font-size:15px;
}
.nav a{
  opacity:.92;
  position:relative;
  padding:32px 0;
}
.nav a:hover,.nav a.active{opacity:1}
.nav a.active:after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:21px;
  height:3px;
  border-radius:10px;
  background:#fff;
}
.phone{
  font-weight:800;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
  min-width:190px;
}
.burger{display:none}

.hero{
  min-height:720px;
  color:#fff;
  background:
    linear-gradient(180deg, rgba(0,12,29,.12), rgba(0,12,29,.65)),
    url('img/hero-school.svg') center/cover no-repeat;
  display:flex;
  align-items:center;
  position:relative;
  overflow:hidden;
}
.hero:after{
  content:"";
  position:absolute;
  inset:auto 0 0 0;
  height:120px;
  background:linear-gradient(180deg, transparent, rgba(255,255,255,1));
}
.hero-content{
  position:relative;
  z-index:2;
  padding-top:90px;
  text-align:center;
  width:100%;
}
.hero-kicker{
  display:inline-flex;
  gap:10px;
  align-items:center;
  padding:9px 16px;
  border-radius:999px;
  background:rgba(255,255,255,.13);
  border:1px solid rgba(255,255,255,.22);
  backdrop-filter:blur(10px);
  margin-bottom:26px;
  font-weight:700;
}
.hero-title{
  font-size:clamp(54px, 8vw, 128px);
  line-height:.9;
  margin:0;
  letter-spacing:-.04em;
  text-shadow:0 10px 30px rgba(0,0,0,.25);
}
.hero-subtitle{
  margin:18px auto 0;
  font-size:clamp(22px, 3vw, 38px);
  line-height:1.15;
  font-weight:800;
  text-transform:uppercase;
  max-width:780px;
}
.hero-actions{
  display:flex;
  gap:22px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:42px;
}
.slider-dots{
  display:flex;
  gap:10px;
  justify-content:center;
  margin-top:56px;
}
.dot{
  width:11px;
  height:11px;
  border-radius:50%;
  background:#fff;
  opacity:.65;
}
.dot.active{background:var(--blue-2);opacity:1}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:52px;
  padding:0 28px;
  border-radius:12px;
  border:1px solid transparent;
  font-weight:800;
  cursor:pointer;
  transition:.18s ease;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn-blue{
  background:linear-gradient(180deg, var(--blue-2), var(--blue));
  color:#fff;
  box-shadow:0 12px 25px rgba(0,87,217,.28);
}
.btn-white{
  background:#fff;
  color:var(--text);
  box-shadow:0 14px 25px rgba(0,0,0,.14);
}
.btn-outline{
  border-color:rgba(255,255,255,.6);
  color:#fff;
  background:rgba(255,255,255,.08);
  backdrop-filter:blur(10px);
}
.btn-ghost{
  border-color:#b7c9e5;
  color:var(--blue);
  background:#fff;
}
.btn-dark{
  background:var(--navy);
  color:#fff;
}
.btn-wide{width:100%}

.section{
  padding:90px 0;
}
.section-soft{
  background:
    radial-gradient(circle at 86% 22%, rgba(0,87,217,.08), transparent 22%),
    linear-gradient(180deg, #fff 0%, #f5f8fd 100%);
}
.section-title{
  font-size:clamp(34px, 4vw, 48px);
  line-height:1.08;
  margin:0 0 34px;
  letter-spacing:-.035em;
  font-weight:800;
}
.section-title:before{
  content:"";
  display:block;
  width:56px;
  height:4px;
  border-radius:10px;
  background:var(--blue);
  margin-bottom:20px;
}
.section-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:32px;
  margin-bottom:34px;
}
.lead{
  font-size:18px;
  color:#52627a;
  margin:0;
  max-width:680px;
}

.schedule-grid{
  display:grid;
  grid-template-columns:minmax(0, 1.05fr) minmax(300px, .95fr);
  gap:70px;
  align-items:center;
}
.schedule-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:20px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.schedule-table{
  width:100%;
  border-collapse:collapse;
  min-width:640px;
}
.schedule-table th,.schedule-table td{
  padding:18px 16px;
  text-align:center;
  border-bottom:1px solid var(--line);
  font-size:15px;
}
.schedule-table th{
  color:var(--blue);
  font-weight:800;
  background:#f7faff;
}
.schedule-table td:first-child,.schedule-table th:first-child{
  text-align:left;
  font-weight:800;
  color:var(--blue);
}
.table-scroll{overflow:auto}
.player-card{
  min-height:520px;
  border-radius:var(--radius);
  background:
    radial-gradient(circle at 70% 25%, rgba(0,87,217,.16), transparent 28%),
    linear-gradient(135deg, #fff 0%, #eef6ff 100%);
  position:relative;
  overflow:hidden;
  box-shadow:inset 0 0 0 1px rgba(0,87,217,.08);
}
.player-card:before{
  content:"Д";
  position:absolute;
  right:20px;
  top:-70px;
  font-family:Georgia, serif;
  font-size:520px;
  color:#0b55bc;
  opacity:.045;
  line-height:1;
}
.player-card:after{
  content:"";
  position:absolute;
  right:80px;
  bottom:70px;
  width:320px;
  height:320px;
  background:url('img/kids-training.svg') center/cover no-repeat;
  border-radius:50%;
  box-shadow:0 28px 60px rgba(0,87,217,.16);
}
.speed-lines{
  position:absolute;
  left:70px;
  top:190px;
  width:420px;
  height:210px;
  background:
    linear-gradient(135deg, transparent 30%, rgba(0,87,217,.16) 31%, rgba(0,87,217,.16) 34%, transparent 35%),
    linear-gradient(135deg, transparent 44%, rgba(0,87,217,.25) 45%, rgba(0,87,217,.25) 49%, transparent 50%);
  transform:skewX(-18deg);
}

.contact-grid{
  display:grid;
  grid-template-columns:.82fr 1.18fr;
  gap:64px;
  align-items:center;
}
.contact-card,.map-card,.white-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  box-shadow:var(--shadow);
}
.contact-card{
  padding:34px;
}
.contact-card h3{
  margin:0 0 10px;
  font-size:26px;
  color:var(--blue);
}
.contact-card p{margin:0 0 16px;color:#52627a}
.socials{display:flex;gap:10px;margin:18px 0 28px}
.socials a{
  width:42px;height:42px;
  display:grid;place-items:center;
  background:var(--blue);
  color:#fff;
  border-radius:11px;
  font-weight:800;
}
.map-card{
  overflow:hidden;
  min-height:330px;
}
.map-card img{width:100%;height:100%;object-fit:cover}

.site-footer{
  background:
    radial-gradient(circle at 87% 58%, rgba(255,255,255,.10), transparent 18%),
    linear-gradient(135deg, #020917 0%, #04234f 65%, #010711 100%);
  color:#fff;
  padding:56px 0 24px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr repeat(3, 1fr);
  gap:70px;
  padding-bottom:45px;
}
.footer-logo{
  display:flex;
  flex-direction:column;
  gap:18px;
  color:rgba(255,255,255,.8);
}
.footer-logo .logo-mark{width:76px;height:76px;font-size:62px}
.footer-col h4{
  margin:0 0 20px;
  font-size:16px;
}
.footer-col a,.footer-col p{
  display:block;
  margin:0 0 12px;
  color:rgba(255,255,255,.68);
  font-size:14px;
}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.12);
  padding-top:22px;
  display:flex;
  justify-content:space-between;
  gap:25px;
  flex-wrap:wrap;
  color:rgba(255,255,255,.55);
  font-size:13px;
}
.footer-links{display:flex;gap:28px;flex-wrap:wrap}

/* inner pages */
.page-main{
  background:
    radial-gradient(circle at 90% 6%, rgba(0,87,217,.08), transparent 22%),
    linear-gradient(180deg, #fff 0%, #f7faff 100%);
  padding:132px 0 0;
}
.breadcrumbs{
  display:flex;
  align-items:center;
  gap:9px;
  margin:0 0 34px;
  color:#8090a8;
  font-weight:700;
  font-size:14px;
}
.breadcrumbs a{color:var(--blue)}
.content-layout{
  display:grid;
  grid-template-columns:minmax(0, 1fr) 360px;
  gap:36px;
  align-items:start;
}
.article-list{
  display:grid;
  gap:42px;
}
.post-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  overflow:hidden;
  box-shadow:var(--shadow-soft);
}
.post-card__image{
  height:310px;
  background:#dce8f8 center/cover no-repeat;
}
.post-card__content{padding:28px 32px 34px}
.meta{
  display:flex;
  align-items:center;
  gap:18px;
  color:#7b8ba3;
  font-size:14px;
  margin-bottom:18px;
  font-weight:700;
}
.badge{
  display:inline-flex;
  align-items:center;
  height:34px;
  padding:0 14px;
  border-radius:9px;
  background:var(--blue);
  color:#fff;
  font-size:13px;
  font-weight:800;
}
.post-card h2,.article h1{
  margin:0 0 18px;
  font-size:30px;
  line-height:1.18;
  letter-spacing:-.03em;
}
.post-card p,.article p{
  color:#52627a;
  margin:0 0 22px;
}
.sidebar{
  position:sticky;
  top:112px;
}
.sidebar-box{
  background:rgba(255,255,255,.82);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
  padding:28px;
  backdrop-filter:blur(10px);
}
.sidebar-box h3{
  margin:0 0 24px;
  font-size:28px;
  letter-spacing:-.03em;
}
.event-mini{
  display:flex;
  gap:16px;
  align-items:center;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  padding:18px;
  margin-bottom:16px;
}
.event-mini h4{
  margin:0 0 6px;
  font-size:15px;
  line-height:1.25;
}
.event-mini p{
  margin:0 0 8px;
  font-size:13px;
  color:#697a94;
}
.event-mini a{
  color:var(--blue);
  font-weight:800;
  font-size:13px;
}
.event-thumb{
  width:72px;height:72px;border-radius:50%;
  background:center/cover no-repeat;
  flex:0 0 auto;
  box-shadow:inset 0 0 0 4px #eef5ff;
}
.article{
  max-width:760px;
}
.article-hero{
  height:310px;
  border-radius:var(--radius-sm);
  background:center/cover no-repeat;
  box-shadow:var(--shadow-soft);
  margin-bottom:24px;
}
.article h1{
  font-size:36px;
  color:var(--text);
}
.article p{
  font-size:17px;
  line-height:1.75;
  margin-bottom:28px;
}
.cta-stack{
  display:grid;
  gap:22px;
}
.cta-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  box-shadow:var(--shadow-soft);
  padding:26px;
}
.cta-icon{
  width:58px;height:58px;
  display:grid;place-items:center;
  border-radius:50%;
  background:var(--blue);
  color:#fff;
  font-size:24px;
  margin-bottom:18px;
}
.cta-card h3{
  margin:0 0 8px;
  font-size:22px;
  line-height:1.14;
}
.cta-card p{margin:0 0 18px;color:#65758f;font-size:14px}
.card-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:28px;
}
.event-card,.rent-card,.review-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  overflow:hidden;
  box-shadow:var(--shadow-soft);
}
.event-card__img,.rent-card__img{
  height:170px;
  background:center/cover no-repeat;
}
.event-card__body,.rent-card__body{padding:20px}
.event-card h3,.rent-card h3{
  margin:12px 0 10px;
  font-size:20px;
  line-height:1.2;
}
.event-card p,.rent-card p{
  margin:0 0 16px;
  color:#66758e;
  font-size:14px;
}
.text-link{
  color:var(--blue);
  font-weight:800;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.arena-hero{
  padding:132px 0 56px;
  background:
    radial-gradient(circle at 90% 0%, rgba(0,87,217,.12), transparent 30%),
    linear-gradient(180deg, #fff 0%, #f4f8ff 100%);
}
.info-strip{
  background:var(--blue);
  color:#fff;
  text-align:center;
  font-weight:700;
  padding:10px;
}
.arena-top{
  display:grid;
  grid-template-columns:1.3fr .8fr;
  gap:44px;
  align-items:center;
}
.arena-top h1,.landing-hero h1{
  margin:0 0 22px;
  font-size:clamp(42px, 5vw, 68px);
  line-height:1.05;
  letter-spacing:-.045em;
}
.media-frame{
  border-radius:var(--radius-sm);
  overflow:hidden;
  box-shadow:var(--shadow);
  background:#fff;
  border:1px solid var(--line);
}
.media-frame img{width:100%;height:100%;object-fit:cover}
.benefits-card{
  padding:34px;
  background:#fff;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  border-radius:var(--radius-sm);
}
.benefits-card h2{
  margin:0 0 22px;
  font-size:25px;
  line-height:1.2;
}
.check-list{
  list-style:none;
  padding:0;
  margin:0 0 26px;
}
.check-list li{
  position:relative;
  padding-left:28px;
  margin-bottom:13px;
  color:#52627a;
}
.check-list li:before{
  content:"";
  position:absolute;left:0;top:5px;
  width:16px;height:16px;border-radius:50%;
  background:var(--blue);
}
.check-list li:after{
  content:"";
  position:absolute;left:5px;top:9px;
  width:6px;height:3px;
  border-left:2px solid #fff;
  border-bottom:2px solid #fff;
  transform:rotate(-45deg);
}
.event-strip{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:28px;
  align-items:center;
  padding:24px;
  background:linear-gradient(135deg, #edf5ff, #fff);
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  box-shadow:var(--shadow-soft);
}
.promo-banner{
  min-height:145px;
  border-radius:18px;
  background:
    linear-gradient(90deg, rgba(3,20,47,.92), rgba(0,87,217,.75)),
    url('img/flags.svg') center/cover no-repeat;
  color:#fff;
  padding:28px;
  display:flex;
  align-items:center;
  font-size:30px;
  font-weight:800;
}
.feature-row{
  display:grid;
  grid-template-columns:.85fr .75fr 1fr;
  gap:34px;
  align-items:center;
}
.feature-list{
  background:#f0f6ff;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  padding:26px;
  display:grid;
  gap:18px;
}
.feature-list div{
  display:flex;
  gap:14px;
  align-items:flex-start;
  color:#52627a;
}
.feature-list b{color:var(--text)}
.rent-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:22px;
}
.rent-card__body{padding:18px}
.rent-card__body h3{font-size:17px}
.price{
  color:var(--text);
  font-weight:800;
  margin:10px 0 16px;
}
.corporate{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:28px;
  background:
    radial-gradient(circle at 60% 50%, rgba(255,255,255,.14), transparent 22%),
    linear-gradient(135deg, #03142f, #063b85);
  color:#fff;
  padding:34px;
  border-radius:var(--radius-sm);
  overflow:hidden;
}
.corporate h2{
  margin:0 0 14px;
  font-size:34px;
  text-transform:uppercase;
}
.corporate p{color:rgba(255,255,255,.78)}
.steps{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:18px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  box-shadow:var(--shadow-soft);
  padding:28px;
}
.step{
  text-align:center;
  position:relative;
}
.step-num{
  width:44px;height:44px;border-radius:50%;
  background:var(--blue);
  color:#fff;
  display:grid;place-items:center;
  font-weight:800;
  margin:0 auto 12px;
}
.step h3{
  margin:0 0 8px;
  font-size:15px;
}
.step p{font-size:13px;color:#66758e;margin:0}
.landing-hero{
  min-height:650px;
  padding:150px 0 80px;
  color:#fff;
  background:
    linear-gradient(90deg, rgba(1,9,22,.82), rgba(1,9,22,.35)),
    url('img/flag-football.svg') center/cover no-repeat;
}
.landing-hero .breadcrumbs{color:rgba(255,255,255,.68)}
.landing-hero .breadcrumbs a{color:#fff}
.landing-hero h1{max-width:730px;color:#fff}
.landing-actions{display:flex;gap:18px;flex-wrap:wrap;margin-top:34px}
.two-col{
  display:grid;
  grid-template-columns:1fr 360px;
  gap:56px;
  align-items:start;
}
.content-text h2{
  margin:0 0 10px;
  font-size:42px;
  line-height:1.08;
  letter-spacing:-.035em;
}
.content-text h3{
  color:var(--blue);
  margin:26px 0 10px;
  font-size:25px;
}
.content-text p{color:#394960;font-size:17px}
.booking-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  box-shadow:var(--shadow);
  padding:28px;
}
.booking-row{
  display:flex;
  justify-content:space-between;
  gap:18px;
  border-bottom:1px solid var(--line);
  padding:14px 0;
  color:#52627a;
}
.booking-row b{color:var(--text)}
.manager{
  display:flex;
  align-items:center;
  gap:14px;
  margin-top:22px;
}
.avatar{
  width:62px;height:62px;border-radius:50%;
  background:linear-gradient(135deg, #082b61, #c8d7ef);
  position:relative;
}
.avatar:after{content:"";position:absolute;left:20px;top:14px;width:22px;height:22px;border-radius:50%;background:#fff}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.gallery-img{
  height:210px;
  border-radius:var(--radius-sm);
  background:url('img/arena-interior.svg') center/cover no-repeat;
  box-shadow:var(--shadow-soft);
}
.review-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.review-card{padding:24px}
.review-head{display:flex;gap:14px;align-items:center;margin-bottom:14px}
.stars{color:var(--blue);letter-spacing:4px;margin-top:14px;font-weight:800}
.preview-page{
  padding:130px 0 80px;
}
.preview-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
}
.preview-link{
  display:block;
  padding:28px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  box-shadow:var(--shadow-soft);
}
.preview-link h2{margin:0 0 8px}
.preview-link p{margin:0;color:#66758e}

@media (max-width: 1024px){
  .container{width:min(100% - 32px, var(--container))}
  .nav{display:none}
  .phone{display:none}
  .burger{display:flex;flex-direction:column;gap:5px;background:transparent;border:0;padding:8px}
  .burger span{width:28px;height:2px;background:#fff;border-radius:10px}
  .header-row{height:74px}
  .site-header--transparent{position:sticky;background:linear-gradient(135deg, #03142f, #052b66)}
  .schedule-grid,.contact-grid,.content-layout,.arena-top,.feature-row,.corporate,.two-col{grid-template-columns:1fr}
  .sidebar{position:static}
  .card-grid,.rent-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .gallery-grid,.review-grid{grid-template-columns:1fr 1fr}
}

@media (max-width: 640px){
  .hero{min-height:650px}
  .hero-actions,.landing-actions{flex-direction:column}
  .btn{width:100%}
  .section{padding:64px 0}
  .card-grid,.rent-grid,.steps,.footer-grid,.gallery-grid,.review-grid,.preview-grid{grid-template-columns:1fr}
  .event-strip{grid-template-columns:1fr}
  .post-card__image,.article-hero{height:230px}
  .article h1{font-size:30px}
  .footer-bottom{display:block}
  .footer-links{margin-bottom:16px}
}