/*
Theme Name: Aleksandra
Author: Aleksandra
Author URI: https://wp-content.co/
Description: Custom theme
Version: 1.0
Tested upto: 6.5
*/

body {
  background: #FFFFFF;
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  margin: 0;
  color: #585859;
}

h1, h2, h3, h4, h5, h6, .heading {
  font-family: 'Playfair Display', serif;
  font-weight: 400;
  margin: 0;
  color: #2B2A29;
}

p {
  line-height: 150%;
}

h1 {
  font-size: 54px;
}

h2 {
  font-size: 48px;
}

h3 {
  font-size: 40px;
}

h4 {
  font-size: 32px;
  margin: 8px 0;
}

h5 {
  font-size: 26px;
}

h6 {
  font-size: 18px;
}

a {
  text-decoration: none;
}

@media (max-width: 768px) {
  h2 {
    font-size: 40px;
  }

  h3 {
    font-size: 36px;
  }
}

#site-header,
#site-footer,
#main {
  width: 100%;
  max-width: 1440px;
  margin: 0 auto;
}

/* Site header */

#site-header {
  display: flex;
  justify-content: space-between;
  padding: 24px 32px;
  box-sizing: border-box;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  z-index: 100;
}

#logo-wrapper,
#nav-wrapper {
  display: flex;
  align-items: center;
}

#logo-wrapper .logo {
  height: 85px;
}

#nav-wrapper > div {
  margin-right: 32px;
}

#nav-wrapper .menu {
  padding: 0;
}

#nav-wrapper .menu-item {
  display: inline-block;
  padding: 0 24px;
}

#nav-wrapper .menu-item a,
#mobile-menu-wrapper .menu-item a {
  color: #382B25;
  font-size: 17px;
  font-weight: 500;
  transition: color .4s;
  white-space: nowrap;
}

#nav-wrapper .menu-item a:hover,
#mobile-menu-wrapper .menu-item a:hover {
  color: #A2705D;
}

@media (max-width: 1300px) {
  #nav-wrapper .menu-item {
    padding: 0 16px;
  }

  #logo-wrapper .logo {
    height: 50px;
  }
}

@media (max-width: 1024px) {
  #site-header {
    background: #FFFFFF;
  }

  #nav-wrapper {
    display: none;
  }

  #site-header {
    padding: 24px 20px;
  }
}


/* Mobile menu */

#mobile-menu-controls {
  display: none;
}

#mobile-menu-button {
  cursor: pointer;
  font-size: 36px;
}

#mobile-menu-wrapper {
  display: none;
  position: absolute;
  top: 98px;
  left: 0;
  width: 100%;
  z-index: 200;
  background: #F6F4F1;
  text-align: center;
  padding: 40px 16px;
}

#mobile-menu-wrapper.active {
  display: block;
}

#mobile-menu-wrapper .menu {
  margin: 0;
  padding: 0;
}

#mobile-menu-wrapper .menu-item {
  display: block;
}

#mobile-menu-wrapper .menu-item:not(:last-child) {
  padding-bottom: 32px;
}

@media (max-width: 1024px) {
  #mobile-menu-controls {
    display: flex;
    align-items: center;
  }
}

/* Hero header */

#hero-header {
  display: flex;
  position: relative;
}

#hero-header .left,
#hero-header .right {
  position: relative;
  display: flex;
  align-items: center;
  width: 50%;
  height: 756px;
}

#hero-header .left {
  padding-right: 140px;
}

#hero-header .left .inner {
  padding-top: 80px;
  padding-left: 40px;
}

#hero-header .right {
  align-items: flex-end;
  justify-content: end;
}

#hero-header .right .front {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}

#hero-header .right .front img {
  max-width: 420px;
}

#hero-header .right .background {
  width: calc(200% / 3 + 30px);
  height: 100%;
  background-size: cover;
  background-position: center;
}

#hero-header .left p {
  padding-right: 80px;
  padding-bottom: 16px;
}

@media (max-width: 1024px) {
  #hero-header .left {
    padding-right: 0;
  }

  #hero-header .left .inner h1 {
    font-size: 40px;
  }

  #hero-header .right .front-image {
    width: 300px;
  }
}

@media (max-width: 768px) {
  #hero-header {
    flex-direction: column-reverse;
    flex-wrap: wrap;
    padding-bottom: 40px;
  }

  #hero-header .left .inner {
    padding: 0 20px;
  }

  #hero-header .left,
  #hero-header .right {
    width: 100%;
    height: auto;
  }

  #hero-header .right {
    margin-top: 98px;
    height: 310px;
    align-items: flex-start;
  }

  #hero-header .right .background {
    width: 100%;
    height: 188px;
  }

  #hero-header .right .front {
    left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);
  }

  #hero-header .right .front-image {
    width: 247px;
  }

  #hero-header .left p {
    padding-right: 0;
    padding-bottom: 12px;
  }
}

/* Contact Details */

#contact-details {
  display: flex;
  margin: 10px 0;
}

#contact-details > div {
  display: flex;
  width: calc(100% / 3);
  padding: 10px 0;
}

#contact-details > .phone {
  padding: 10px 20px;
}

#contact-details .inner {
  width: 100%;
  padding: 40px;
}

#contact-details .inner p {
  font-weight: 500;
  margin: 0;
}

#contact-details .inner a {
  color: #585859;
}

#contact-details i {
  font-size: 36px;
}

#contact-details .address .inner {
  background: linear-gradient(171deg, #F2EFEB 0%, #E3DAD1 100%);
}

#contact-details .phone .inner {
  background: linear-gradient(171deg, #F0EAE5 0%, #DDC7B2 100%);
}

#contact-details .mail .inner {
  background: linear-gradient(171deg, #F5E9DF 0%, #D0B9AE 100%);
}

@media (max-width: 1300px) {
  #contact-details {
    flex-wrap: wrap;
    justify-content: center;
  }

  #contact-details > .address,
  #contact-details > .phone,
  #contact-details > .mail {
    padding: 5px 10px;
    box-sizing: border-box;
  }

  #contact-details > .address,
  #contact-details > .phone {
    width: 50%;
  }

  #contact-details > .mail {
    width: 100%;
  }
}

@media (max-width: 768px) {
  #contact-details > .address,
  #contact-details > .phone {
    width: 100%;
  }

  #contact-details > .mail {
    width: 100%;
  }

  #contact-details > .mail p {
    font-size: 13px;
  }

  #contact-details .inner {
    padding: 24px;
  }

  #contact-details .inner h4 {
    font-size: 30px;
  }
}

/* Services */

#services {
  position: relative;
  display: flex;
  background: linear-gradient(180deg, #87776F 0%, #48342B 100%);
  color: #FFFFFF;
}

#services .left,
#services .right {
  padding: 40px;
}

#services .left i {
  position: absolute;
  font-size: 200px;
  opacity: .1;
  top: 10px;
  left: 10px;
}

#services h4 {
  position: relative;
  color: #FFFFFF;
}

.services-list {
  list-style-type: circle;
  opacity: .8;
  column-count: 2;
  column-gap: 100px;
}

.services-list li {
  padding: 4px 0;
}

@media (max-width: 1300px) {
  #services {
    margin: 0 10px;
  }
}

@media (max-width: 768px) {
  #services {
    flex-wrap: wrap;
  }

  #services .left,
  #services .right {
    width: 100%;
  }

  #services .left {
    padding-bottom: 20px;
  }

  #services .right {
    padding-top: 0;
  }

  .services-list {
    column-count: 1;
    padding-left: 0;
    margin: 0;
  }
}

/* About */

.about {
  display: flex;
  padding: 80px 60px 40px 60px;
}

.about.about-gallery {
  padding-bottom: 80px;
}

.about > div {
  padding: 20px 10px;
}

.about > div:first-child {
  width: 40%;
}

.about > div:first-child img {
  max-width: 100%;
}

.about > div:last-child {
  width: 60%;
}

.about.size-reverse > div:first-child {
  width: 60%;
}

.about.size-reverse > div:last-child {
  width: 40%;
}

.about .indicator {
  margin-bottom: 24px;
}

.about img {
  display: block;
  margin: auto;
}

.about .mini-gallery {
  display: flex;
  padding-left: 30px;
}

.about .mini-gallery img {
  width: 50%;
  padding: 0 10px;
}

@media (max-width: 768px) {
  .about.about-gallery {
    flex-direction: column-reverse;
  }

  .about .mini-gallery {
    flex-wrap: wrap;
    padding-left: 10px;
    padding-bottom: 0;
  }

  .about .mini-gallery img {
    width: auto;
    padding: 10px 0;
  }

  .about {
    flex-wrap: wrap;
    padding: 40px 30px;
  }

  .about > div:first-child,
  .about > div:last-child,
  .about.size-reverse > div:first-child,
  .about.size-reverse > div:last-child {
    width: 100%;
    padding-left: 0;
    padding-right: 0;
  }

  .about h2 {
    font-size: 42px;
  }
}

/* External */

.external {
  display: flex;
  padding: 40px 60px;
  background: linear-gradient(171deg, #F2EFEB 0%, #E3DAD1 100%);
}

.external > div {
  padding: 20px 10px;
}

.external > div:first-child {
  width: 55%;
  padding-right: 40px;
}

.external > div h4 {
  margin: 0;
}

.external > div p {
  margin-bottom: 24px;
}

.external > div:last-child {
  width: 45%;
}

@media (max-width: 768px) {
  .external,
  .external.flex-reverse {
    flex-wrap: wrap;
    flex-direction: column-reverse;
    padding: 40px 24px;
  }

  .external > div:first-child,
  .external > div:last-child {
    width: 100%;
  }

  .external > div:first-child {
    padding-right: 10px;
    box-sizing: border-box;
  }

  .external .quote h5 {
    font-size: 22px;
  }
}

/* Quote */

.quote {
  border-left: 2px solid #A2705D;
  padding: 20px 32px;
}

.quote i {
  display: block;
  margin-bottom: 20px;
  font-size: 32px;
}

/* Pricing */

#pricing {
  padding: 100px 0;
  background: linear-gradient(170deg, #FCFBFA 0%, #F6F4F1 100%, #F0EEEB 100%);
}

#pricing h2 {
  text-align: center;
}

#pricing .pricing-inner {
  display: flex;
  margin: 36px 155px;
  background-color: #D0B9AE;
}

#pricing .pricing-inner > div {
  width: 50%;
  background: #ffffff;
  margin: 2px;
  padding: 60px;
}

#pricing .pricing-inner .left {
  margin-right: 1px;
}

#pricing .pricing-inner .right {
  margin-left: 1px;
}

#pricing .pricing-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 0;
}

#pricing .pricing-item:first-child {
  padding-top: 0;
}

#pricing .pricing-item:last-child {
  padding-bottom: 0;
}

#pricing .pricing-item h6:last-child {
  padding-left: 12px;
  border-left: 1px solid #2B2A29;
  margin-left: 8px;
}

@media (max-width: 1300px) {
  #pricing .pricing-inner {
    margin: 36px 55px;
  }

  #pricing .pricing-inner .left,
  #pricing .pricing-inner .right {
    padding: 40px;
  }
}

@media (max-width: 768px) {
  #pricing {
    padding: 60px 0;
  }

  #pricing .pricing-inner {
    flex-wrap: wrap;
    margin: 24px 20px;
  }

  #pricing .pricing-inner .left,
  #pricing .pricing-inner .right {
    padding: 24px;
  }

  #pricing .pricing-inner > div {
    width: 100%;
  }

  #pricing .pricing-inner .left {
    margin-right: 2px;
    margin-bottom: 0;
    padding-bottom: 0;
  }

  #pricing .pricing-inner .right {
    margin-left: 2px;
    margin-top: -1px;
    padding-top: 0;
  }

  #pricing .left .pricing-item:last-child {
    padding-bottom: 16px;
  }

  #pricing .right .pricing-item:first-child {
    padding-top: 16px;
  }

  #pricing h6 {
    font-size: 16px;
  }
}

/* Testimonials */

#testimonials {
  position: relative;
  padding-top: 100px;
  padding-bottom: 60px;
}

#testimonials .top {
  display: flex;
  justify-content: space-between;
  padding-left: 155px;
}

#testimonials .controls {
  display: flex;
  align-items: center;
  padding: 0 40px;
}

#testimonials .slick-arrow,
#testimonials .bottom i {
  display: inline-block;
  font-size: 0;
  width: 48px;
  height: 48px;
  border: 0;
  color: #FFFFFF;
  background: #382B25;
  border: 2px solid #382B25;
  border-radius: 100%;
  margin-left: 16px;
  font-family: 'icomoon' !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  transition: all .4s;
}

#testimonials .bottom i {
  width: auto;
  height: auto;
  padding: 8px;
}

#testimonials .bottom i:first-child {
  margin-left: 0;
}

#testimonials .slick-arrow:before {
  font-size: 32px;
  content: "\e909";
}

#testimonials .bottom i:before {
  font-size: 32px;
}

#testimonials .slick-arrow.slick-next:before {
  content: "\e908";
}

#testimonials .slick-arrow:not(.slick-disabled),
#testimonials .bottom i:not(.control-disabled) {
  cursor: pointer;
}

#testimonials .slick-arrow:not(.slick-disabled):hover,
#testimonials .bottom i:not(.control-disabled):hover {
  background: #635048;
  border-color: #635048;
}

#testimonials .slick-arrow.slick-disabled,
#testimonials .bottom i.control-disabled {
  color: #382B25;
  background: #FFFFFF;
  opacity: .6;
}

#testimonials .content {
  overflow: hidden;
  padding-top: 40px;
  margin: 0 20px;
}

#testimonials .slick-track {
  display: flex;
  align-items: flex-start;
}

.testimonial-item {
  display: inline-block;
  background: #FCFBFA;
  border: 1px solid #A2705D;
  margin: 10px;
  padding: 60px 40px 40px 40px;
  max-width: 550px;
}

.testimonial-item i {
  font-size: 36px;
}

.testimonial-item .testimonial-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.testimonial-item .client-name {
  font-size: 20px;
}

#testimonials .background {
  position: absolute;
  width: 100%;
  height: 50%;
  left: 0;
  bottom: 0;
  background: linear-gradient(166.29deg, #F5E9DF 6.33%, #D0B9AE 91.25%);
  z-index: -1;
}

#testimonials .bottom {
  display: none;
  text-align: center;
}

@media (max-width: 1300px) {
  #testimonials .top {
    padding-left: 55px;
  }
}

@media (max-width: 768px) {
  #testimonials {
    padding-top: 60px;
  }

  #testimonials .top {
    padding-left: 20px;
  }

  #testimonials .top .controls {
    display: none;
  }

  #testimonials .bottom {
    display: block;
  }

  .testimonial-item {
    padding: 40px 24px;
  }
}

/* Footer */

#site-footer {
  background: linear-gradient(171deg, #F5E9DF 0%, #D0B9AE 100%);
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

#site-footer .inner {
  display: flex;
  margin: 0 auto;
  width: 100%;
  max-width: 1440px;
  padding: 100px 60px 20px 60px;
  box-sizing: border-box;
}

#site-footer .map {
  margin: 0;
  max-width: 100%;
}

#site-footer .left {
  width: 40%;
  padding-right: 20px;
}

#site-footer .right {
  width: 60%;
  padding-left: 20px;

  h3 {
    margin-bottom: 20px;
  }
}

#site-footer .details div {
  display: flex;
  align-items: flex-start;
  margin-bottom: 25px;
}

#site-footer .details i {
  display: block;
  font-size: 24px;
  margin-right: 16px;
}

#site-footer .bottom {
  border-top: 1px solid #A2705D;
  padding: 5px 0;
  margin-top: 80px;
}

#site-footer .bottom p {
  display: block;
  text-align: center;
  font-size: 14px;
}

#site-footer form {
  font-family: 'Playfair Display', serif;
  color: #2B2A29;
  padding-top: 20px;
}

input[type=text],
input[type=email],
textarea {
  display: block;
  width: 100%;
  max-width: 660px;
  box-sizing: border-box;
  padding: 16px 8px;
  margin-top: 4px;
  border-radius: 4px;
  border: 1px solid #A2705D;
  background: #FCFBFA;
}

input[type=submit] {
  display: inline-block;
  font-size: 16px;
  font-family: 'Inter', sans-serif;
  border-radius: 70px;
  padding: 13px 32px;
  margin-top: 10px;
  background: #382B25;
  color: #FFFFFF;
  border: 0;
}

@media (max-width: 768px) {
  #site-footer .inner {
    flex-wrap: wrap;
    padding: 60px 30px 30px 30px;
  }

  #site-footer .inner .left,
  #site-footer .inner .right {
    width: 100%;
    padding: 0;
  }

  #site-footer .bottom {
    margin-top: 20px;
  }
}

/* Other */

.button {
  display: inline-block;
  border-radius: 70px;
  padding: 13px 32px;
  white-space: nowrap;
  transition: background .4s;
}

.indicator {
  display: inline-block;
  border-radius: 52px;
  padding: 6px 24px;
  color: #A2705D;
  border: 1px solid #A2705D;
}

.brown {
  background: #382B25;
  color: #FFFFFF;
}

.brown:hover {
  background: #635048;
}

.flex-reverse {
  flex-direction: row-reverse;
}
