/* guides */

/*
font-family: "Montserrat", serif;
font-family: "Inter", serif;
color: #2c0a39; (dark blue)
color: #c167c4; (violet)
color: #fff6ff; (light grey)
color: #aac47d; (green)
-webkit-transition: all .2s ease-out;
-moz-transition: all .2s ease-out;
-o-transition: all .2s ease-out;
transition: all .2s ease-out;
*/

/* important */

@media (max-width: 991px) {
  .d-none-for-xs {
    display: none !important;
  }
}

/* general */

html {
  height: 100%;
}

body {
  width: 100%;
  height: 100%;
  font-family: "Montserrat", serif;
}

section {
  padding: 6rem 0;
}

.btn {
  padding: .75rem 2rem;
  color: #fff;
  background-color: #c167c4;
  border: 2px solid #c167c4;
  border-radius: 30px;
  -webkit-transition: all .2s ease-out;
  -moz-transition: all .2s ease-out;
  -o-transition: all .2s ease-out;
  transition: all .2s ease-out;
}

.btn:hover {
  color: #fff;
  background-color: #2c0a39;
  border: 2px solid #2c0a39;
}

.btn-light {
  color: #8f4592;
  background-color: #f6eaf6;
  border: 2px solid #f6eaf6;
}

.btn-light:hover {
  color: #fff;
  background-color: #c167c4;
  border: 2px solid #c167c4;
}

/* navigation */

.navbar {
  padding-top: 3rem;
  padding-bottom: 3rem;
  box-shadow: none;
  background-color: transparent;
  -webkit-transition: all .2s ease-out;
  -moz-transition: all .2s ease-out;
  -o-transition: all .2s ease-out;
  transition: all .2s ease-out;
}

.navbar.navbar-shrink {
  padding-top: 1.5rem;
  padding-bottom: 1.5rem;
  background-color: #fff6ff;
}

.navbar .navbar-brand img {
  height: 50px;
  width: auto;
}

.navbar .navbar-nav .nav-item.dropdown .dropdown-menu {
  margin-top: 0;
  padding-top: .5rem;
  padding-bottom: .5rem;
  background-color: transparent;
  border: 0;
}

.navbar .navbar-nav .nav-item.dropdown:hover .dropdown-menu {
  display: block;
}

.navbar .navbar-nav .nav-item.dropdown .dropdown-menu li {
  background-color: #fff;
}

.navbar .navbar-nav .nav-item.dropdown .dropdown-menu li:first-child {
  padding-top: 1rem;
  border-top-left-radius: 1rem;
  border-top-right-radius: 1rem;
}

.navbar .navbar-nav .nav-item.dropdown .dropdown-menu li:last-child {
  padding-bottom: 1rem;
  border-bottom-left-radius: 1rem;
  border-bottom-right-radius: 1rem;
}

.navbar .navbar-nav .nav-item .nav-link {
  padding: 0 1.5rem;
  color: #2c0a39;
  font-family: "Inter", serif;
  font-weight: 400;
  font-size: 0.9rem;
  cursor: pointer;
  -webkit-transition: all .2s ease-out;
  -moz-transition: all .2s ease-out;
  -o-transition: all .2s ease-out;
  transition: all .2s ease-out;
}

.navbar .navbar-nav .nav-item:last-child .nav-link {
  padding-right: 0;
}

.navbar .navbar-nav .nav-item .nav-link:hover,
.navbar .navbar-nav .nav-item .nav-link:active,
.navbar .navbar-nav .nav-item .nav-link.active {
  color: #c167c4;
}

.navbar .navbar-nav .nav-item .nav-link i {
  margin-left: .75rem;
}

.navbar .navbar-nav .nav-item .nav-link.nav-link-contacts {
  padding: .75rem 2rem;
  color: #c167c4;
  border: 2px solid #c167c4;
  border-radius: 30px;
}

.navbar .navbar-nav .nav-item .nav-link.nav-link-contacts:hover {
  color: #fff;
  background-color: #c167c4;
}

.navbar .navbar-nav .nav-item .nav-link.nav-link-login {
  padding: .75rem 2rem;
  color: #fff;
  background-color: #aac47d;
  border: 2px solid #aac47d;
  border-radius: 30px;
}

.navbar .navbar-nav .nav-item .nav-link.nav-link-login:hover {
  background-color: #8db051;
  border: 2px solid #8db051;
}

@media (min-width: 1200px) and (max-width: 1399px) {
  .navbar .navbar-nav .nav-item .nav-link {
    padding: 0 1.25rem;
  }
}

@media (min-width: 992px) and (max-width: 1199px) {
  .navbar .navbar-nav .nav-item .nav-link {
    padding: 0 .75rem;
  }

  .navbar .navbar-nav .nav-item .nav-link.nav-link-login i {
    display: none;
  }
}

@media (max-width: 991px) {
  .navbar {
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
    background-color: #fff6ff;
  }

  .navbar .navbar-nav .nav-item .nav-link {
    padding: 0.75rem 0;
  }

  .navbar .navbar-nav .nav-item .nav-link.nav-link-contacts,
  .navbar .navbar-nav .nav-item .nav-link.nav-link-login {
    display: inline-block;
  }

  .navbar .navbar-nav .nav-item.dropdown:hover .dropdown-menu {
    text-align: center;
    padding-top: 1rem;
    padding-bottom: 1rem;
  }
}

/* front page cover */

.front-page-cover {
  position: relative;
  height: 100vh;
  padding-top: 156px;
  padding-bottom: 0;
  background-color: #fff6ff;
  background-image: url("../images/cover.png");
  background-repeat: no-repeat;
  background-attachment: scroll;
  background-size: 70%;
  background-position: center;
  background-position-x: 100%;
}

.front-page-cover h1 {
  color: #2c0a39;
  font-family: "Montserrat", serif;
  font-size: 3.5rem;
  font-weight: 700;
}

.front-page-cover p {
  width: 80%;
  color: #2c0a39;
  font-size: 1rem;
}

.front-page-cover .front-page-cover-div {
  padding-bottom: 88px;
}

@media (min-width: 1200px) and (max-width: 1399px) {
  .front-page-cover {
    background-size: 85%;
  }

  .front-page-cover h1 {
    font-size: 2.5rem;
  }

  .front-page-cover p {
    width: 70%;
  }
}

@media (min-width: 992px) and (max-width: 1199px) {
  .front-page-cover {
    background-size: 100%;
  }

  .front-page-cover .front-page-cover-div {
    padding-bottom: 40px;
  }

  .front-page-cover .front-page-cover-div > div:first-child {
    display: flex;
    align-items: flex-end;
  }

  .front-page-cover h1 {
    font-size: 2.5rem;
  }

  .front-page-cover p {
    width: 70%;
    margin-bottom: -52px !important;
    color: #fff;
    font-size: .95rem;
  }
}

@media (max-width: 991px) {
  .front-page-cover {
    padding-top: 108px;
    background-image: none;
  }

  .front-page-cover h1 {
    font-size: 2.25rem;
  }

  .front-page-cover p {
    width: 100%;
    font-size: .95rem;
  }

  .front-page-cover .front-page-cover-div {
    padding-bottom: 0;
  }
}

/* front page intro */

.front-page-intro {
  position: relative;
  margin-top: -88px;
  padding-top: 0;
  padding-bottom: 0;
  z-index: 1;
}

.front-page-intro .individual-intro-block {
  padding: 3rem 2rem;
  background-color: #e5daea;
  border-radius: 20px;
}

.front-page-intro .individual-intro-block img {
  width: 40px;
  height: 40px;
}

.front-page-intro .individual-intro-block p {
  color: #8f4592;
  text-transform: uppercase;
}

@media (min-width: 992px) and (max-width: 1199px) {
  .front-page-intro .individual-intro-block {
    padding: 3rem 1.5rem;
  }

  .front-page-intro .individual-intro-block p {
    font-size: .9rem;
  }
}

@media (max-width: 991px) {
  .front-page-intro {
    margin-top: 0;
    padding-top: 0;
    padding-bottom: 0;
    background-color: #e5daea;
  }

  .front-page-intro .individual-intro-block {
    padding-bottom: 0;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
  }

  .front-page-intro .col-12:first-child .individual-intro-block {
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
  }

  .front-page-intro .col-12:last-child .individual-intro-block {
    padding-bottom: 3rem;
    border-bottom-left-radius: 20px;
    border-bottom-right-radius: 20px;
  }
}

/* front page services */

.front-page-services {
  margin-top: -88px;
  padding-bottom: calc(6rem + 100px);
  background-color: #2c0a39;
}

.front-page-services .description-div {
  margin-top: 88px;
  margin-bottom: 72px;
}

.front-page-services h2 {
  margin-top: 2.25rem;
  margin-bottom: 2.25rem;
  color: #fff;
  font-weight: 700;
  text-transform: uppercase;
}

.front-page-services p {
  margin-bottom: 3rem;
  color: #fff;
}

.front-page-services img {
  width: 60px;
  height: auto;
}

@media (max-width: 991px) {
  .front-page-services {
    margin-top: 0;
    padding-top: 3rem;
    padding-bottom: 3rem;
  }

  .front-page-services .description-div {
    margin-top: 0;
    margin-bottom: 0;
  }
}

/* front page advantages */

.front-page-advantages {
  position: relative;
  margin-top: -100px;
  padding-top: 0;
  z-index: 1;
  background-color: #fff6ff;
}

.front-page-advantages h2 {
  margin-top: 1.5rem;
  margin-bottom: 2.25rem;
  color: #2c0a39;
  font-size: 2rem;
  font-weight: 700;
  text-transform: uppercase;
}

.front-page-advantages h2 span {
  display: block;
  margin-bottom: .75rem;
  font-size: 5rem;
}

.front-page-advantages p {
  width: 85%;
  margin-bottom: 0;
  color: #2c0a39;
}

.front-page-advantages .advantages-div {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  padding: 4.5rem;
  background-color: #9f66a1;
}

.front-page-advantages .advantages-div .individual-advantage {
  flex: 1 1 calc(50% - 0.75rem);
  width: calc(50% - 0.75rem);
  max-width: calc(50% - 0.75rem);
  min-width: calc(50% - 0.75rem);
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 1.5rem;
}

.front-page-advantages .advantages-div .individual-advantage span {
  display: inline-block;
  flex: 1 1 60px;
  max-width: 60px;
  min-width: 60px;
  width: 60px;
  height: 60px;
  text-align: center;
  color: #2c0a39;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 60px;
  background-color: #fff;
  border-radius: 50px;
}

.front-page-advantages .advantages-div .individual-advantage p {
  width: 100%;
  margin-bottom: 0;
  color: #fff;
}

.front-page-advantages .rectangle-1 {
  position: absolute;
  top: -35px;
  left: 0;
  height: 100%;
  width: 37.5%;
  background-color: #f6eaf6;
  transform: rotate(84deg);
  z-index: -1;
}

.front-page-advantages .rectangle-2 {
  position: absolute;
  top: 0;
  right: 0;
  height: calc(100% - 6rem);
  width: 50%;
  background-color: #9f66a1;
  z-index: -1;
}

.front-page-advantages .rectangle-3 {
  height: 20%;
  background-color: #2c0a39;
  transform: rotate(0deg);
  z-index: -2;
}

.front-page-advantages .rectangle-4 {
  top: -100px;
  width: 40%;
  height: 120%;
  background-color: #e5daea;
  transform: rotate(70deg);
  z-index: -2;
}

@media (min-width: 1200px) and (max-width: 1399px) {
  .front-page-advantages .rectangle-1 {
    width: 47.5%;
  }

  .front-page-advantages .rectangle-4 {
    top: -140px;
    left: -80px;
    height: 120%;
  }
}

@media (min-width: 992px) and (max-width: 1199px) {
  .front-page-advantages .advantages-div {
    padding: 3rem;
  }

  .front-page-advantages .rectangle-1 {
    width: 65%;
  }

  .front-page-advantages .rectangle-4 {
    top: 0;
    left: -200px;
    width: 67%;
    height: 100%;
  }
}

@media (max-width: 991px) {
  .front-page-advantages {
    margin-top: 0;
    padding-top: 3rem;
    padding-bottom: 3rem;
  }

  .front-page-advantages h2 {
    margin-top: 0;
    font-size: calc(1.325rem + 0.9vw);
  }

  .front-page-advantages h2 span {
    margin-top: -1rem;
  }

  .front-page-advantages p {
    width: 100%;
    margin-bottom: 3rem;
  }

  .front-page-advantages .advantages-div {
    padding: 3rem 2rem;
  }

  .front-page-advantages .advantages-div .individual-advantage {
    flex: 1 1 100%;
    width: 100%;
    max-width: 100%;
    min-width: 100%;
  }

  .front-page-advantages .advantages-div .individual-advantage span {
    display: inline-block;
    flex: 1 1 45px;
    max-width: 45px;
    min-width: 45px;
    width: 45px;
    height: 45px;
    font-size: 1rem;
    line-height: 45px;
  }

  .front-page-advantages .rectangle-1,
  .front-page-advantages .rectangle-2,
  .front-page-advantages .rectangle-3,
  .front-page-advantages .rectangle-4 {
    display: none;
  }
}

/* front page partners */

.front-page-partners {
  padding-top: 0;
  background-color: #fff6ff;
}

.front-page-partners h3 {
  color: #8f4592;
  font-size: 1.6rem;
  font-weight: 700;
  text-transform: uppercase;
}

.front-page-partners img {
  height: 90px;
  width: auto;
}

.front-page-partners .partners-div {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 2rem;
}

@media (max-width: 991px) {
  .front-page-partners {
    padding-top: 1.5rem;
    padding-bottom: 3rem;
  }

  .front-page-partners .partners-div {
    flex-direction: column;
    gap: 0;
  }
}

/* front page news */

.front-page-news {
  padding-top: 0;
  padding-bottom: 9rem;
  background-color: #fff6ff;
}

.front-page-news h2 {
  margin-bottom: 3rem;
  color: #2c0a39;
  font-size: 2rem;
  font-weight: 700;
  text-transform: uppercase;
}

.front-page-news h3 {
  margin-bottom: 1.5rem;
  width: 80%;
  color: #2c0a39;
  font-size: 1.3rem;
  font-weight: 700;
  text-transform: uppercase;
  -webkit-transition: all .2s ease-out;
  -moz-transition: all .2s ease-out;
  -o-transition: all .2s ease-out;
  transition: all .2s ease-out;
}

.front-page-news .individual-new:hover h3 {
  color: #c167c4;
}

.front-page-news p {
  margin-bottom: 1.5rem;
  min-height: 96px;
  color: #2c0a39;
}

.front-page-news a {
  color: #8f4592 !important;
  font-size: .9rem;
  text-decoration: none;
}

.front-page-news a i {
  margin-left: .5rem;
}

.front-page-news .individual-new {
  position: relative;
  padding: 3rem 2.5rem;
  background-color: #f6eaf6;
  border-radius: 20px;
  cursor: pointer;
}

.front-page-news .individual-new span {
  position: absolute;
  top: 3rem;
  right: 2.5rem;
}

@media (min-width: 1200px) and (max-width: 1399px) {
  .front-page-news h3 {
    min-height: 100px;
  }

  .front-page-news p {
    min-height: 120px;
  }
}

@media (min-width: 992px) and (max-width: 1199px) {
  .front-page-news p {
    min-height: 168px;
  }
}

@media (max-width: 991px) {
  .front-page-news {
    padding-top: 1.5rem;
    padding-bottom: 3rem;
  }

  .front-page-news h2 {
    margin-bottom: 2.25rem;
    font-size: 1.6rem;
  }

  .front-page-news h3 {
    width: 75%;
    font-size: 1rem;
  }

  .front-page-news p {
    min-height: 0;
  }

  .front-page-news .individual-new span {
    font-size: .8rem;
  }
}

/* footer */

footer {
  position: relative;
  padding-top: 4.5rem;
  padding-bottom: 4.5rem;
  background-color: #2c0a39;
  z-index: 0;
}

footer h3 {
  margin-bottom: 2.25rem;
  color: #fff;
  font-size: 1rem;
  font-family: "Montserrat", serif;
  font-weight: 700;
  text-transform: uppercase;
}

footer p {
  margin-bottom: 1.5rem;
  color: #fff;
  font-size: .95rem;
  line-height: 1.75rem;
}

footer p a {
  color: #8f4592;
  text-decoration: none;
  -webkit-transition: all .2s ease-out;
  -moz-transition: all .2s ease-out;
  -o-transition: all .2s ease-out;
  transition: all .2s ease-out;
}

footer p a:hover {
  color: #fff;
  text-decoration: none;
}

footer p i {
  font-size: 1.25rem;
}

footer ul {
  list-style-type: none;
  padding-inline-start: 0;
  margin-bottom: 0;
}

footer ul li {
  padding-top: .5rem;
  padding-bottom: .5rem;
}

footer ul li:first-child {
  padding-top: 0;
}

footer ul li:last-child {
  padding-bottom: 0;
}

footer ul li a {
  color: #fff;
  font-size: .95rem;
  text-decoration: none;
  text-transform: uppercase;
  -webkit-transition: all .2s ease-out;
  -moz-transition: all .2s ease-out;
  -o-transition: all .2s ease-out;
  transition: all .2s ease-out;
}

footer ul li a:hover {
  color: #c167c4;
  text-decoration: none;
}

footer .rectangle-1 {
  position: absolute;
  top: auto;
  bottom: 80px;
  left: -30px;
  height: 80%;
  width: 35%;
  background-color: #e5daea;
  transform: rotate(160deg);
  z-index: -2;
}

@media (max-width: 991px) {
  footer {
    padding-top: 3rem;
    padding-bottom: 3rem;
  }
}

/* */
