html {
  scroll-behavior: smooth;
  background: rgb(47, 47, 49);
}

body {
  margin: 0 !important;
  width: auto !important;
  min-width: 1320px;
  overflow-x: auto;
  overflow-y: auto;
  background: rgb(47, 47, 49);
  color: #fff;
  font-family: Arial, Helvetica, sans-serif;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  background: rgb(47, 47, 49);
  z-index: -2;
}

#publication-root {
  position: relative !important;
  left: auto !important;
  top: auto !important;
  margin: 0 auto;
  width: 1320px !important;
  min-height: 5648px;
  transform: none !important;
  -webkit-transform: none !important;
  -ms-transform: none !important;
}

.scroll-target {
  position: absolute;
  left: 0;
  width: 1px;
  height: 1px;
  pointer-events: none;
}
#top-anchor { top: 0; }
#benefits-anchor { top: 815px; }
#courses-anchor { top: 4492px; }
#booking-anchor { top: 5330px; }
#footer-anchor { top: 5461px; }

#_idContainer023,
#_idContainer087 {
  cursor: pointer;
}

#_idContainer023:focus-visible,
#_idContainer087:focus-visible,
.menu-link:focus-visible,
.close-menu:focus-visible {
  outline: 3px solid #4aa3df;
  outline-offset: 4px;
}

#_idContainer081,
#_idContainer082,
#_idContainer087 {
  position: fixed !important;
  transform: none !important;
  -webkit-transform: none !important;
  -ms-transform: none !important;
  z-index: 140;
}
#_idContainer081 { left: calc(50% - 660px + 0px) !important; top: 0 !important; }
#_idContainer082 { left: calc(50% - 660px + 282.58px) !important; top: 0 !important; }
#_idContainer087 { left: calc(50% - 660px + 1207.5px) !important; top: 28px !important; z-index: 150; }

.sticky-headline {
  position: fixed;
  top: 96px;
  left: 50%;
  width: 1320px;
  height: 64px;
  transform: translateX(-50%);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.18s ease;
  z-index: 120;
  overflow: hidden;
}
.sticky-headline.is-visible { opacity: 1; }
.sticky-headline .sticky-inner {
  position: relative;
  width: 1320px;
  height: 64px;
}
.sticky-headline .sticky-inner > div,
.sticky-headline .sticky-inner > svg {
  position: absolute !important;
  inset: 0 auto auto 0;
  width: 1320px !important;
  height: 64px !important;
  transform: none !important;
  -webkit-transform: none !important;
  -ms-transform: none !important;
  background-size: 100% 100% !important;
  background-repeat: no-repeat !important;
  background-position: left top !important;
  box-shadow: none !important;
}
.sticky-headline .sticky-inner svg { width: 100% !important; height: 100% !important; }

.site-menu-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease;
  z-index: 210;
}
.site-menu-panel {
  position: fixed;
  top: 0;
  right: 0;
  width: min(360px, 92vw);
  height: 100vh;
  background: rgba(10, 10, 10, 0.96);
  box-shadow: -8px 0 30px rgba(0,0,0,0.35);
  transform: translateX(100%);
  transition: transform 0.25s ease;
  z-index: 220;
  display: flex;
  flex-direction: column;
  padding: 28px 28px 36px;
  box-sizing: border-box;
}
body.menu-open .site-menu-overlay { opacity: 1; pointer-events: auto; }
body.menu-open .site-menu-panel { transform: translateX(0); }
body.menu-open { overflow: hidden; }
.menu-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 28px; }
.menu-title { font-size: 22px; font-weight: 700; letter-spacing: 0.03em; }
.close-menu { appearance: none; border: 1px solid rgba(255,255,255,0.25); background: transparent; color: #fff; border-radius: 999px; padding: 8px 12px; cursor: pointer; font-size: 14px; }
.site-menu-nav { display: flex; flex-direction: column; gap: 10px; }
.menu-link { color: #fff; text-decoration: none; font-size: 20px; font-weight: 700; line-height: 1.25; padding: 12px 14px; border-radius: 10px; background: rgba(255,255,255,0.04); transition: background 0.2s ease, transform 0.2s ease; }
.menu-link:hover, .menu-link.is-active { background: rgba(74,163,223,0.18); transform: translateX(-2px); }
.menu-note { margin-top: auto; font-size: 14px; line-height: 1.5; color: rgba(255,255,255,0.72); }

.site-footer-content {
  position: absolute;
  left: 60px;
  top: 5558px;
  width: 1200px;
  min-height: 64px;
  z-index: 85;
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 18px 40px;
  align-items: start;
  color: #fff;
}
.footer-brand { font-size: 24px; font-weight: 700; letter-spacing: 0.04em; }
.footer-links { display: flex; justify-content: flex-end; flex-wrap: wrap; gap: 12px 18px; font-size: 18px; font-weight: 700; }
.footer-links span { display: inline-flex; align-items: center; padding: 8px 14px; border-radius: 999px; background: rgba(255, 255, 255, 0.08); border: 1px solid rgba(255, 255, 255, 0.12); }
.footer-note { grid-column: 1 / -1; margin: 0; max-width: 1000px; font-size: 14px; line-height: 1.45; color: rgba(255, 255, 255, 0.82); }
