/* RESET */

html {

  font-family: sans-serif;

  -ms-text-size-adjust: 100%;

  -webkit-text-size-adjust: 100%;

}



body {

  margin: 0;

  padding: 0;

}



article,

aside,

details,

figcaption,

figure,

footer,

header,

hgroup,

main,

nav,

section,

summary {

  display: block;

  margin: 0;

}



audio,

canvas,

progress,

video {

  display: inline-block;

  vertical-align: baseline;

}



img {

  vertical-align: middle;

}



body {

  -webkit-animation-name: fadeIn;

  -webkit-animation-duration: 2s;

  animation-name: fadeIn;

  animation-duration: 3s;

  font-family: 'Roboto', sans-serif;

  font-weight: 200;

  font-size: 20px;

}



@-webkit-keyframes fadeIn {

  0% {

    opacity: 0;

  }



  100% {

    opacity: 1;

  }

}



@keyframes fadeIn {

  0% {

    opacity: 0;

  }



  100% {

    opacity: 1;

  }

}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: inherit;
  margin-bottom: 15px;
  font-family: "Teko", sans-serif;
  margin-top: 0;
  letter-spacing: 2px;
  font-weight: 400;
}
h2 {
  font-size: 48px;
  line-height: 1.25em;
}
h3 {
  font-size: 40px;
}
h4 {
  font-size: 34px;
}
h5 {
  font-size: 30px;
}
h6 {
  font-size: 26px;
}

p {
  margin-top: 0;
  line-height: 36px;
}

img {
  max-width: max-content;
  height: max-content;
}

a {
  text-decoration: none !important;
  transition: .3s;
  color: #1e1f26;
}



a:hover {

  color: #009FE3;

}



.pbtn {

  background-color: #009FE3;

  border: 1px solid #009FE3;

  color: #fff;

  display: inline-block;

  padding: 15px 25px 10px 25px;

  text-transform: uppercase;

  font-family: "Teko", sans-serif;

  font-size: 18px;

  letter-spacing: 2px;

  line-height: 24px;

}



.pbtn:hover {

  background-color: transparent;

  color: #009FE3;

  box-shadow: 0px 0px 7px rgba(0, 0, 0, 0.4);

}



.ovrhdn {

  overflow: hidden;

}



.logo {

  font-size: 10px;

  line-height: 50px;

  letter-spacing: 2px;

  margin-bottom: 0;

  padding-top: 50px;

}



.logo span {

  color: #009FE3;

}



.text-justify {

  text-align: justify;

}



.text-left {

  text-align: left;

}



.text-center {

  text-align: center;

}



.text-right {

  text-align: right;

}



.m-top {

  margin-top: 100px;

}



main {

  padding-top: 100px;

}



/* HEADER MENU BUTTON */

#nav-icon {

  width: 30px;

  height: 30px;

  -webkit-transform: rotate(0deg);

  transform: rotate(0deg);

  -webkit-transition: 1s ease-in-out;

  transition: .5s ease-in-out;

  cursor: pointer;

  z-index: 999999;

  position: relative;

  display: none;
  overflow: hidden;

}



#nav-icon span {

  display: block;

  position: absolute;

  height: 3px;

  width: 100%;

  background: #000;

  opacity: 1;

  left: 0;

  -webkit-transform: rotate(0deg);

  transform: rotate(0deg);

  -webkit-transition: .5s ease-in-out;

  transition: .25s ease-in-out;

}



#nav-icon span:nth-child(1) {

  top: 0px;

}



#nav-icon span:nth-child(2),

#nav-icon span:nth-child(3) {

  top: 10px;

}



#nav-icon span:nth-child(4) {

  top: 20px;

}



#nav-icon.open span:nth-child(1) {

  top: 180px;

  width: 0%;

  left: 50%;

}



#nav-icon.open span:nth-child(2) {

  -webkit-transform: rotate(45deg);

  transform: rotate(45deg);

}



#nav-icon.open span:nth-child(3) {

  -webkit-transform: rotate(-45deg);

  transform: rotate(-45deg);

}



#nav-icon.open span:nth-child(4) {

  top: 18px;

  width: 0%;

  left: 50%;

}



/* @ @ @ HEADER @ @ @ */

.header {

  position: fixed;

  left: 0;

  top: 0;

  width: 100%;

  background-color: #fff;

  padding-top: 20px;

  padding-bottom: 20px;

  z-index: 600;

  box-shadow: 0px 0px 10px rgba(0, 0, 0, .5);

}



.header__menu ul {

  display: flex;

  justify-content: space-between;

  list-style-type: none;

  padding: 0px;

  margin: 0px;

}



/* header menu */

.header__menu {

  display: flex;

  align-items: center;

}



.header__menu>div {

  width: 100%;

}



.header__menu ul li a {

  font-size: 22px;

  font-family: "Teko", sans-serif;

  text-transform: uppercase;

  letter-spacing: 2px;

}



.header__menu ul li.current-menu-item a {

  color: #009FE3;

}



/* @ @ @ FRONT PAGE @ @ @ */

.baner {

  height: 60vh;
  min-height: 400px;

  background-repeat: no-repeat !important;

  background-size: cover !important;

  background-position: center center !important;

  display: flex !important;

  flex-direction: column;

  justify-content: center;

}



.baner h1 {
  font-size: 82px;
  line-height: 82px;
  letter-spacing: 2px;
  color: #fff;
  text-align: center;
  margin-bottom: 22px;
  text-shadow: 0px 0px 3px rgba(0,0,0, .4);
}



.baner p {

  color: #fff;
  text-align: center;
  font-size: 18px;

}



/* PHOTO BANERS */
.photo-baners__text {
  padding-right: 10px;
}

.photo-baners__text h3 {
  font-size: 36px;
  line-height: 40px;
}

.photo-baners__img img {
  width: 100%;
}

.photo-baners__box {
  position: absolute;
  right: 15px;
  left: 60px;
  bottom: 60px;
  font-weight: 600;
  padding: 30px 30px;
  background-color: #009FE3;
  color: #fff;
  transition: .3s;
  font-size: 36px;
  line-height: 40px;
}

.photo-baners__box:hover {
  background-color: #000;
  color: #fff;
}

.photo-baners__box h3 {
  margin: 0;
}

/* ICONS */

.icons-box i {
  font-size: 100px;
  color: #009FE3;
}

.icons-box p {
  font-size: 20px;
  margin-top: 10px;
  font-weight: 500;
  line-height: 24px;
}



/* CHESS */
.subpage__chess {
  margin-top: 30px;
}
.chess:nth-child(odd) {
  flex-direction: row-reverse;
}

.chess__text {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 60px 40px;
}

.chess__text h3 {
  font-size: 40px;
  line-height: -6;
  margin-bottom: 60px;
}

.chess__text p {
  font-size: 18px;
  line-height: 24px;
  margin-bottom: 50px;
}

.chess__img img {
  width: 100%;
  height: 100%;
  object-fit: contain;

}

.subpage__chess .chess__text h3 {
  font-weight: 500;
  font-size: 36px;
  line-height: 38px;
}

/* CONTACT */
.contact {
  background-color: #000;
  padding: 80px 0;
  color: #fff;
}

.contact h2 {
  font-size: 70px;
  line-height: 70px;
  margin-bottom: 20px;
}

.contact p {
  font-size: 18px;
}
.contact-txt {
  margin-bottom: 30px;
}

.contact-map {
  width: 100%;
  height: 450px;
}

/* @ @ @  FOOTER @ @ @  */
.footer {
  padding-top: 30px;
  border-top: 1px solid #e0e0e0;
}
.page-template-page-contact .footer {
  margin-top: 0 !important;
}
.footer h3 {
  font-size: 28px;
}

.footer__list {
  padding-bottom: 20px;
  margin-bottom: 10px;
  margin: 0;
  padding: 0;
  list-style-type: none;
}



.footer__list li {

  margin: 5px 0;

  font-size: 17px;

}



.footer .logo {

  color: #fff;

  margin-bottom: 0;

}



.footer__copyright {

  color: #a0a0a0;

  font-size: 14px;

  margin-top: 20px;

  padding-top: 30px;

  padding-bottom: 20px;


}



/* SUBPAGES */

.subbaner {

  height: 21vw;

  min-height: 240px;

  max-height: 500px;

  display: flex;

  align-items: center;
  background-attachment: fixed;
  background-repeat: no-repeat;
  background-size: cover;

}

.subbaner__title {
  padding-top: 60px;
}
.subbaner h1 {
  letter-spacing: 2px;
  font-size: 72px;
  line-height: 82px;
  color: #fff;
}



.harmo {

  background-color: #f5f5f5;

  padding: 20px;

}



.harmo h3 {

  font-size: 32px;

  line-height: 34px;

  padding: 15px 40px 10px 10px;

  margin-bottom: 0;

  cursor: pointer;

  position: relative;

}



.harmo__content {

  padding: 0 20px;

  display: none;

  margin-top: 20px;

  font-size: 18px;

}



.harmo__content p {

  font-size: 20px;

}



.closed .vertical {

  transition: all 1.5s ease-in-out;

  transform: rotate(-90deg);

}



.closed .horizontal {

  transition: all 1.5s ease-in-out;

  transform: rotate(-90deg);

  opacity: 1;

}



.circle-plus.opened {

  opacity: 1;

}



.circle-plus.opened .vertical {

  transition: all 1.5s ease-in-out;

  transform: rotate(90deg);

}



.circle-plus.opened .horizontal {

  transition: all 1.5s ease-in-out;

  transform: rotate(90deg);

  opacity: 0;

}



.circle-plus {

  position: absolute;

  right: 10px;

  top: 15px;

}



.circle-plus .circle {

  position: relative;

  width: 30px;

  height: 30px;

  border-radius: 100%;

  display: flex;

  justify-content: center;

  align-items: center;

}



.circle-plus .circle .horizontal {

  position: absolute;

  background-color: #000;

  width: 16px;

  height: 2px;

}



.circle-plus .circle .vertical {

  position: absolute;

  background-color: #000;

  width: 2px;

  height: 16px;

}

.about__desc {
  padding: 0;
  margin: 20px 0 0 0;
  display: flex;
  flex-wrap: wrap;
  text-align: left;
  list-style: none;
}
.about__desc li {
  max-width: 50%;
  flex: 0 0 50%;
  padding: 0 15px;
  margin: 8px 0;
}
.about__desc li i {
  color: #0097E3;
  margin-right: 5px;
  font-size: 18px;
}


.cf {

  background-color: #000;

  padding: 40px 60px;

  color: #fff;

}



.cf a {

  color: #fff;

}



.cf textarea,

.cf input:not([type='checkbox']):not([type='submit']) {

  font-family: "Teko", sans-serif;

  font-size: 20px;

  letter-spacing: 1px;

  padding: 10px 10px 5px 10px;

  margin: 5px 0;

  border: none;

  border-bottom: 1px solid #fff;

  width: 100%;

  border-radius: 0;

  outline: none;

  background-color: transparent;

  resize: none;
  color: #fff;

}



.cf textarea::placeholder,

.cf input:not([type='checkbox']):not([type='submit'])::placeholder {

  color: #fff;

}



.cf input[type='submit'] {

  padding: 10px 35px 10px 35px;

  color: #fff;

  background-color: #009FE3;

  border: 1px solid #009FE3;

  transition: .3s;

  cursor: pointer;

  margin-top: 20px;

  font-size: 20px;

}



.cf input[type='submit']:hover {

  background-color: transparent;

  color: #009FE3;

}



.cf .wpcf7-acceptance .wpcf7-list-item {

  margin-left: 0;

  font-size: 13px;

  line-height: 16px;

}



/* @ @ @ MEDIA @ @ @ */

@media (min-width: 600px) {

  .container {

    max-width: 1200px;

  }

}



@media (max-width: 600px) {

  .photo-baners__text {

    padding-right: 60px;

  }

}



@media (max-width: 300px) {

  .photo-baners__text {

    padding-right: 65px;

  }



  .photo-baners__img {

    height: 65%;

    left: -75px;

  }

}



@media (max-width: 300px) {

  .photo-baners__img {

    position: relative;

    top: 0;

    left: 0;

  }

}



@media(max-width: 400px) {

  .marg-top {

    margin-top: 80px;

  }



  .baner h1 {

    font-size: 74px;

    line-height: 74px;

  }



  .chess__text h3 {

    font-size: 60px;

    line-height: 62px;

  }



  .contact h2 {

    font-size: 60px;

    line-height: 62px;

  }

}

@media(max-width: 992px) {
  header {
    padding-top: 10px;
    padding-bottom: 10px;
  }
  main {
    padding-top: 72px;
  }
  #nav-icon {
    display: block;
  }
  .header__logo {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .header__logo img {
    width: 160px;
  }
  .header__menu {
    position: fixed;
    left: -150vw;
    top: 75px;
    width: 100%;
    height: 100%;
    background-color: #fff;
    align-items: flex-start;
    transition: .6s;
  }
  .header__menu ul {
    flex-direction: column;
    padding: 40px;
  }
  .header__menu ul li a {
    font-size: 32px;
  }
  .menuopened .header__menu {
    left: 0;
  }

  .m-top {
    margin-top: 60px;
  }

  .baner .m-top {
    margin-top: 0;
  }
  .baner h1 {
    font-size: 49px;
    line-height: 45px;
  }
  .baner p {
    font-size: 16px;
    line-height: 21px;
  }
  .subbaner h1 {
    font-size: 58px;
    line-height: 60px;
    padding-top: 60px;
  }

  .about h2 {
    font-size: 34px;
  }
  .about__desc li {
    max-width: 100%;
    flex: 0 0 100%;
  }
  .photo-baners__box {
    bottom: -60px;
  }
  .photo-baners__box h3 {
    font-size: 24px;
  }
  .contact h2 {
    font-size: 60px;
    line-height: 60px;
  }
}