.cells {
  align-items: center;
}
@media only screen and (min-width: 0) and (max-width: 767px) {
  .cells.mob {
    flex-wrap: wrap;
  }
  .cells.mob > div {
    flex: 1 1 100% !important;
  }
  .cells.mob > div:empty {
    display: none;
  }
}
.size-10 {
  width: 10px;
  height: 10px;
}
.size-12 {
  width: 12px;
  height: 12px;
}
.size-14 {
  width: 14px;
  height: 14px;
}
.size-16 {
  width: 16px;
  height: 16px;
}
.size-18 {
  width: 18px;
  height: 18px;
}
.size-08em {
  width: 0.8em;
  height: 0.8em;
}
.size-09em {
  width: 0.9em;
  height: 0.9em;
}
.size-1em {
  width: 1em;
  height: 1em;
}
.size-11em {
  width: 1.1em;
  height: 1.1em;
}
.size-12em {
  width: 1.2em;
  height: 1.2em;
}
.size-14em {
  width: 1.3em;
  height: 1.3em;
}
.size-2em {
  width: 2em;
  height: 2em;
}
.size-3em {
  width: 3em;
  height: 3em;
}
svg {
  color: currentColor;
  width: 1em;
  height: 1em;
}
.btn,
a.btn {
  --site-btn-color: #ffffff;
  --site-btn-border-bolor: var(--site-btn-color);
  --site-btn-hover-color: var(--site-btn-color);
  --site-btn-border: 1px solid var(--site-btn-border-color);
  --site-btn-back: #ffffff00;
  --site-btn-hover-back: #ffffff44;
  display: inline-flex;
  gap: 0 0.5em;
  align-items: center;
  justify-content: center;
  padding: 0.7em 2.6em;
  border: var(--site-btn-border);
  border-radius: 1.7em;
  text-align: center;
  white-space: nowrap;
  text-decoration: none;
  color: var(--site-btn-color);
  background: var(--site-btn-back);
  transition: all 0.5s;
}
.btn:hover,
a.btn:hover,
.btn:active,
a.btn:active {
  color: var(--site-btn-hover-color);
  background: var(--site-btn-hover-back);
}
.btn-glass,
a.btn-glass {
  --site-btn-color: #78C4FF;
  --site-btn-hover-color: #78C4FF;
  --site-btn-back: linear-gradient(135deg, black, transparent, transparent);
  --site-btn-hover-back: linear-gradient(35deg, black, transparent, transparent);
  --site-btn-border-color: #78C4FF;
  --site-btn-back: linear-gradient(169deg, #82c2f1, transparent, #0000004f);
  --site-btn-hover-back: linear-gradient(99deg, #66cde5, transparent, transparent);
}
.layout-container > header .container-box {
  padding: 1em;
  border: none;
}
.layout-container .landing .container-box {
  padding: 1em;
  border: none;
}
.legion-site .ui-widget-overlay {
  background: #8b3b00b3;
  opacity: 1;
}
.legion-site .ui-dialog {
  width: 30em !important;
  border-radius: 1em;
  overflow: hidden;
  box-shadow: 0 0 1em #00000033;
}
.legion-site .ui-dialog,
.legion-site .ui-dialog .ui-widget-header,
.legion-site .ui-dialog .ui-dialog-buttonpane {
  background: #e4e4e4;
  border: none;
}
.legion-site .js-form-item label {
  font-size: 0.94em;
  font-weight: 500;
  display: block;
}
.legion-site .js-form-item .iti {
  width: 100%;
}
.legion-site .js-form-item input,
.legion-site .js-form-item select {
  font-size: 1.3em;
}
.clickable-icon {
  cursor: pointer;
}
.clickable-icon svg {
  width: 2em;
  height: 2em;
}
.big-banner-box .big-banner {
  background-image: url('/legion/images/soldier-banner.png');
  background-repeat: no-repeat;
  margin-right: auto;
  margin-left: auto;
  zoom: 1;
  height: 46em;
  background-size: 100%;
  background-position: center;
}
.big-banner-box .big-banner:before,
.big-banner-box .big-banner:after {
  content: '\0020';
  display: block;
  overflow: hidden;
  visibility: hidden;
  width: 0;
  height: 0;
}
.big-banner-box .big-banner:after {
  clear: both;
}
.big-banner-box .info {
  padding-top: 5em;
}
.header-box {
  --site-header-back-trans: opacity(var(--site-background), 0.3);
  --site-header-back: var(--site-background);
  position: relative;
  z-index: 1;
}
.header-box .header {
  background: #ffffff22;
  position: fixed;
  left: 0;
  right: 0;
  z-index: 2;
}
.header-box .header-line {
  margin-right: auto;
  margin-left: auto;
  zoom: 1;
  width: 1440px;
  padding-left: 1em;
  padding-right: 1em;
  display: flex;
  gap: 0 0.3em;
  align-items: center;
  padding: 1em 0;
}
.header-box .header-line:before,
.header-box .header-line:after {
  content: '\0020';
  display: block;
  overflow: hidden;
  visibility: hidden;
  width: 0;
  height: 0;
}
.header-box .header-line:after {
  clear: both;
}
@media only screen and (min-width: 0) and (max-width: 767px) {
  .header-box .header-line {
    width: 100%;
  }
}
@media only screen and (min-width: 768px) and (max-width: 991px) {
  .header-box .header-line {
    width: 768px;
  }
}
@media only screen and (min-width: 992px) and (max-width: 1269px) {
  .header-box .header-line {
    width: 992px;
  }
}
@media only screen and (min-width: 1270px) and (max-width: 1439px) {
  .header-box .header-line {
    width: 1270px;
  }
}
@media only screen and (min-width: 1440px) {
  .header-box .header-line {
    width: 1440px;
  }
}
@media only screen and (min-width: 0) and (max-width: 767px) {
  .header-box .header-line {
    padding-left: 0.5em;
    padding-right: 0.5em;
  }
}
.header-box .menu-box {
  flex: 1 1 auto;
}
.header-box .logo {
  width: 4em;
  height: 4em;
}
.header-box .header-menu {
  display: none;
}
.footer-box .footer {
  display: grid;
  gap: 0.5em;
  grid-template-rows: auto;
  grid-template-columns: auto 1fr auto;
  grid-template-areas: "detop detop detop" "brand menu contact" "official menu contact" "name menu policy" "debot debot debot" "copyright copyright social";
}
.footer-box a:not(.btn) {
  display: block;
  color: #858B91;
  padding: 0.4em 0;
}
.footer-box a.title,
.footer-box a.phone,
.footer-box a.email {
  color: #fff;
}
.footer-box .title,
.footer-box a.phone,
.footer-box a.email {
  font-size: 1.04em;
  margin-bottom: 0.4em;
}
.footer-box .brand-box {
  grid-area: brand;
}
.footer-box .brand-box svg {
  width: 5em;
  height: 5em;
}
.footer-box .menu-box {
  grid-area: menu;
  display: flex;
  align-items: center;
  justify-items: center;
  justify-content: center;
  gap: 0.4em;
}
.footer-box .menu-set {
  flex: 0 0 25%;
  padding: 0 1em;
}
.footer-box .contact-box {
  grid-area: contact;
}
.footer-box .name-box {
  grid-area: name;
}
.footer-box .official-box {
  grid-area: official;
}
.footer-box .policy-box {
  grid-area: policy;
}
.footer-box .social-box {
  grid-area: social;
}
.footer-box .copyright-box {
  grid-area: copyright;
}
.footer-box .delimiter-top {
  grid-area: detop;
}
.footer-box .delimiter-bottom {
  grid-area: debot;
}
.footer-box .delimiter-top,
.footer-box .delimiter-bottom {
  border-top: 1px solid #ffffff18;
  height: 0;
  margin: 1.3em 0;
}
.burger-button {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 2.4em;
  height: 2.4em;
  padding: 0.3em;
  gap: 0.4em;
  border: none;
  background: none;
  cursor: pointer;
  transition: all 0.5s;
}
.burger-button span {
  display: block;
  width: 100%;
  height: 3px;
  background: #fa7c1f;
  border-radius: 3px;
}
.burger-button:hover span {
  background: #e86300;
}
.round-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none !important;
  outline: 0 !important;
  padding: 0.4em 2em;
  border-radius: 1em;
  gap: 0.6em;
  background: #333;
  color: #fff;
  cursor: pointer;
  transition: all 0.5s;
  border: 1px solid #1a1a1a;
}
.round-button:hover {
  background: #000000;
}
.round-button.orange,
.round-button.primary {
  background: #fa7c1f;
  color: #fff;
  cursor: pointer;
  transition: all 0.5s;
  border: 1px solid #e16205;
}
.round-button.orange:hover,
.round-button.primary:hover {
  background: #7d3703;
}
.header-box11 {
  background: #fff;
}
.header-box11 .logo-line {
  box-shadow: none;
  border: none;
}
.header-box11 .logo-line .logo img {
  height: 3em;
}
.header-box11 .menu-line {
  box-sizing: border-box;
  box-shadow: 0 5px 6px #00000059;
  border: 1px solid #848484;
  border-bottom: 7px solid #5e5e5e;
  border-radius: 0.5em 0.5em 5px 5px;
  background: linear-gradient(180deg, #dbdbdb, #a5a5a5);
  padding: 1em;
  margin-bottom: -6px;
}
.header-box11 .menu {
  display: flex;
  align-items: center;
  gap: 1em 2em;
}
.header-box11 .menu a {
  color: #333;
  text-decoration: none;
  transition: all 0.5s;
  outline: 0 !important;
}
.header-box11 .menu a:hover {
  text-decoration: underline;
  color: #ae4a00;
}
.header-box11 .top-line {
  position: fixed;
  left: 0;
  right: 0;
  background: #4f4f4f;
  z-index: 5000;
  top: -250px;
  transition: top 0.5s;
}
.header-box11 .top-line.sticked {
  top: var(--drupal-displace-offset-top, 0);
  left: var(--drupal-displace-offset-left, 0);
}
.header-box11 .top-cells {
  padding: 1em;
  gap: 1em;
}
.header-box11 .big-banner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5em;
  justify-content: center;
  min-height: 24em;
  background-size: cover;
  background-position: center;
}
.header-box11 .big-banner .logo {
  display: inline-block;
  margin-bottom: 1em;
  width: 60%;
}
.header-box11 .big-banner .logo img {
  width: 100%;
  height: auto;
}
@media only screen and (min-width: 768px) and (max-width: 991px) {
  .header-box11 .big-banner .logo {
    width: 85%;
  }
}
@media only screen and (min-width: 0) and (max-width: 767px) {
  .header-box11 .menu-line {
    padding: 0;
    border-radius: 0.5em;
    font-size: 1.2em;
    overflow: hidden;
    height: auto;
    max-height: 0;
    transition: maxHeight 0.5s;
  }
  .header-box11 .menu-line.opened {
    max-height: 100em;
  }
  .header-box11 .menu {
    flex-wrap: wrap;
    gap: 0;
  }
  .header-box11 .menu a {
    width: 100%;
    flex: 1 1 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1em;
  }
  .header-box11 .menu a:hover {
    background: #efefef;
  }
  .header-box11 .menu a + a {
    border-top: 1px solid #cecece;
  }
  .header-box11 .big-banner .logo {
    width: 90%;
  }
}
.card-box {
  display: flex;
  gap: 1em;
  width: 100%;
  align-items: center;
  padding: 0.2em;
}
.card-box .icon {
  flex: 0 0 auto;
  font-size: 1em;
  color: #8f8f8f;
}
.card-box .info {
  flex: 1 1 auto;
}
.card-box.phones .info {
  color: #acacac;
}
.footer-box11 {
  background: #535353;
  color: #fff;
}
.footer-box11 a {
  color: #acacac;
  text-decoration: none;
  transition: all 0.5s;
}
.footer-box11 a:hover {
  color: #f8af79;
  text-decoration: underline;
}
.footer-box11 .container-box {
  border-color: #383838;
  background: #454545;
}
.footer-box11 .address-line {
  padding: 1em;
}
.footer-box11 .links-line {
  background: #3a3a3a;
  padding: 1em;
}
.footer-box11 .copyrights-line {
  color: #947c6b;
  font-size: 0.8em;
  padding: 1em;
}
.footer-box11 .contact {
  color: #acacac;
  font-weight: 200;
}
.footer-box11 .contact b,
.footer-box11 .contact strong {
  font-weight: 500;
  color: #dfdfdf;
}
.footer-box11 .address {
  color: #bba797;
}
.footer-box11 .links-cells {
  gap: 1em;
}
.footer-box11 .links-cells .menu {
  display: flex;
  gap: 2em;
}
.footer-box11 .copyrights {
  gap: 1em;
}
.footer-box11 .go-top {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #606060;
  color: #ddd;
  border-radius: 0.3em;
  font-size: 1.4em;
  padding: 0;
  width: 1.5em;
  height: 1.5em;
  text-decoration: none !important;
  outline: 0 !important;
}
.footer-box11 .go-top:hover {
  background: #fa7c1f;
}
.footer-box11 .phone-number img {
  width: 14em;
  opacity: 0.3;
}
@media only screen and (min-width: 0) and (max-width: 767px) {
  .footer-box11 .links-cells {
    flex-wrap: wrap;
  }
  .footer-box11 .links-cells .menu {
    flex: 1 1 100%;
    margin-bottom: 1em;
  }
  .footer-box11 .links-cells .menu > a,
  .footer-box11 .links-cells .menu > div {
    flex: 1 1 auto;
  }
  .footer-box11 .links-cells .logos {
    flex: 1 1 auto;
  }
  .footer-box11 .links-cells .fill {
    display: none;
  }
  .footer-box11 .links-cells .topper {
    flex: 0 0 auto;
  }
}
.services-box .list {
  display: flex;
  flex-direction: column;
  gap: 1em;
  margin-bottom: 2em;
}
.services-box .list .service {
  width: 100%;
}
.services-box .service {
  display: flex;
  flex-direction: row;
  gap: 1em;
}
.services-box .service .intro,
.services-box .service .list {
  padding: 1em;
}
.services-box .service img {
  width: 100%;
  height: auto;
}
.services-box .service .intro {
  order: 2;
  flex: 0 0 30%;
  background: #efefef;
  border-radius: 1em;
  box-shadow: 1px 2px 9px #00000033;
  border: 1px solid #cecece;
}
.services-box .service .intro h2,
.services-box .service .intro h3,
.services-box .service .intro .title {
  font-size: 1.8em;
  color: #964b13;
}
.services-box .service .list {
  order: 5;
  flex: 1 1 auto;
  font-size: 0.94em;
}
.services-box .service .serv h2,
.services-box .service .serv h3,
.services-box .service .serv .title {
  font-size: 1.3em;
  color: #515151;
  padding: 0;
  margin: 0;
  margin-bottom: 1em;
}
.services-box .service.alt1 .intro {
  order: 5;
}
.services-box .service.alt1 .list {
  order: 3;
}
.services-box .service + .service {
  border-top: 2px solid #fa7c1f;
  padding-top: 2em;
  margin-top: 1em;
}
@media only screen and (min-width: 0) and (max-width: 767px) {
  .services-box .service {
    flex-wrap: wrap;
  }
  .services-box .service .intro {
    flex: 1 1 100%;
    padding-left: 35%;
    position: relative;
    min-height: 2em;
  }
  .services-box .service .intro img {
    position: absolute;
    left: 2em;
    width: 11em;
    top: 2em;
  }
}
@media only screen and (min-width: 0) and (max-width: 460px) {
  .services-box .service {
    flex-wrap: wrap;
  }
  .services-box .service .intro {
    flex: 1 1 100%;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 1em;
  }
  .services-box .service .intro > h2,
  .services-box .service .intro > h3,
  .services-box .service .intro > div {
    flex: 1 1 100%;
  }
  .services-box .service .intro img {
    width: 90%;
    left: unset;
    right: unset;
    position: relative;
    display: inline-block;
  }
}
.contacts-box {
  background: #535353;
}
.contacts-box .container-box {
  background: #e0e0e0;
}
.contacts-box .contact {
  display: flex;
}
.contacts-box .contact .info {
  order: 1;
  flex: 0 0 50%;
  display: flex;
  flex-direction: column;
  font-size: 1.3em;
  padding: 3em;
}
.contacts-box .contact .info h2,
.contacts-box .contact .info h3,
.contacts-box .contact .info .title {
  font-size: 2em;
  color: #a16437;
}
.contacts-box .contact .info ul,
.contacts-box .contact .info .options {
  padding: 0;
  margin: 0;
  padding-left: 2em;
}
.contacts-box .contact .info ul li,
.contacts-box .contact .info .options li {
  margin-bottom: 1em;
}
.contacts-box .contact .inform {
  flex: 1 1 auto;
  order: 3;
}
.contacts-box .form-box {
  background: #ffb279;
  border: 1px solid #d0844c;
  box-shadow: -2px 7px 9px #00000033;
  border-radius: 1em;
  position: relative;
  margin-top: -3em;
  padding: 0;
  display: block;
  box-sizing: border-box;
}
.contacts-box .form-box .header {
  background: #efefef;
  padding: 1.5em;
  border-radius: 1em 1em 0 0;
}
.contacts-box .form-box .header h2,
.contacts-box .form-box .header h3,
.contacts-box .form-box .header .title {
  margin: 0;
  margin-bottom: 1em;
}
.contacts-box .form-box .form {
  padding: 1.5em;
}
.contacts-box .form-box input,
.contacts-box .form-box textarea,
.contacts-box .form-box select {
  background: #b88966;
  border: 1px solid #eda977;
  padding: 0.3em 1em;
  border-radius: 0.8em;
}
.contacts-box .form-box input:focus,
.contacts-box .form-box textarea:focus,
.contacts-box .form-box select:focus {
  outline: 3px solid #ff9342;
}
.contacts-box .form-box input:placeholder,
.contacts-box .form-box textarea:placeholder,
.contacts-box .form-box select:placeholder {
  color: #e2b18e;
  font-weight: 200 !important;
  font-size: 1.2rem !important;
}
.contacts-box .form-box input[type=submit],
.contacts-box .form-box input[type=reset] {
  border: 1px solid #c75a0a;
  padding: 0.5em 2.2em;
  border-radius: 1.3em;
  background: #fa7c1f;
  color: #fffefc;
  transition: all 0.5s;
}
.contacts-box .form-box input[type=submit]:hover,
.contacts-box .form-box input[type=reset]:hover {
  background: #be5f18;
}
.contacts-box .form-box input[type=submit]:focus,
.contacts-box .form-box input[type=reset]:focus {
  outline: 0;
}
.contacts-box .form-box .form-item label {
  display: block;
}
@media only screen and (min-width: 0) and (max-width: 767px) {
  .contacts-box .contact {
    flex-wrap: wrap;
  }
  .contacts-box .contact .info,
  .contacts-box .contact .inform {
    display: flex;
    flex: 1 1 100%;
  }
  .contacts-box .contact .inform {
    order: 3;
  }
  .contacts-box .contact .info {
    order: 10;
    padding: 1em;
  }
  .contacts-box .form-box input[type=submit],
  .contacts-box .form-box input[type=reset] {
    display: block;
    width: 100%;
    padding: 1em;
  }
}
.stacks-box {
  background: #351c0a;
}
.stacks-box .container-box {
  background: #ececec;
}
.stacks-box .stacks {
  display: flex;
  flex-wrap: wrap;
}
.stacks-box .stacks .stack-item {
  flex: 1 1 50%;
  max-width: 48.6%;
  display: block;
  padding: 0.5em;
}
.stacks-box .stack {
  display: block;
  border: 1px solid #bcbcbc;
  background: #ffffff;
  border-radius: 1em;
  padding: 1em;
  box-shadow: 0 0 4px #00000033;
}
.stacks-box .stack .title {
  display: block;
}
.stacks-box .icons {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5em;
}
.stacks-box .icons .icon {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  gap: 0.4em;
}
.stacks-box .icons .icon img {
  display: inline-block;
  width: auto;
  height: 2.5em;
}
.stacks-box .icons .icon .name {
  font-size: 0.6em;
  color: #acacac;
}
@media only screen and (min-width: 0) and (max-width: 767px) {
  .stacks-box .stacks .stack-item {
    flex: 1 1 100%;
    max-width: 100%;
  }
}
