body {font-family: "brown-pro", sans-serif; font-weight: 400; font-style: normal; font-size: 16px; line-height:29px;}
h1 {font-family: "brown-pro", sans-serif; font-weight: 600; font-style: normal; text-transform: uppercase; font-size: 75px; color: #404041; line-height:70px;}
h2 {font-family: "brown-pro", sans-serif; font-size: 40px; font-weight: 600; margin-bottom: 30px; text-transform: uppercase; color: #000;}
h3 {font-family: "brown-pro", sans-serif; font-size: 40px; font-weight: 300; color: #000; margin-bottom: 30px; line-height: 1.3;}
h6 {font-family: "brown-pro", sans-serif; font-size: 17px; text-transform: uppercase; color: #000;}
span {color: #000; font-weight: 600;}
p {margin-bottom: 20px; color: #000;}
a {text-decoration: none; color: #444; transition: 0.5s;}
img {width: 100%; height: 100%; object-fit: cover;}
ul {margin: 0px;}
li {list-style: none; text-transform: uppercase; line-height: 1.5;}

/*=========================================
General
=========================================*/

.wrapper-sml {max-width: 900px; margin: 0 auto;}
.wrapper {max-width: 80%; margin: 0 auto;}

.button-outline {display: inline-block; border: 1px solid #000; color: #000; padding: 15px 55px; background: none; border-radius: 50px; font-size: 18px; font-weight: 500; font-family: "brown-pro", sans-serif; transition: 0.3s ease-out; background: linear-gradient(to left, #fff 50%, #000 50% ); background-size: 210% 100%; background-position: right bottom; cursor: pointer;}
.button-outline:hover {background-position: left bottom; background-position: left; color: #fff;}

.button-outline.small {padding: 10px 25px;}

.button-outline.hover {padding: 10px 25px; border: 1px solid #fff0; background: none; transition: 0s; font-weight: 200;}
.button-outline.hover:hover {border: 1px solid #000; background: none; color: #000; font-weight: 500;}

.bottom-line {position: relative; width: 100%; color: inherit;}
.bottom-line:hover::before {width: 100%; left: 0%; right: auto;}
.bottom-line::before {content: ""; display: block; height: 2px; width: 0%; position: absolute; bottom: 2px; background: #212121; left: auto; right: 0%; transition: 0.5s; transition: 0.5s;}
.bottom-line.white::before {background: #fff !important;}

.solid {border-bottom: 1px solid #212121; color: inherit;}
.solid-white {border-bottom: 1px solid #fff; color: inherit;}

/*=========================================
Mobile
=========================================*/

.mobile-nav {box-sizing: border-box; position: fixed; display: block; background: #353334; top: env(safe-area-inset-top, 40px); left: -110%; z-index: 99; transition: 0.5s; border-radius: 50%; padding: 40px; width: 100%; height: 100dvh; min-height: -webkit-fill-available;}

.mobile-nav > a {position: relative; color: #1d1f1e; display: inline-block;z-index: 9999; font-size: 60px;font-weight: 600; transition: 0.3s;}

.mobile-nav .wrapper {max-width: 100%; display: flex; flex-direction: column; background: none; margin-top: 0px; align-items: flex-start;}
.mobile-nav figure {position: relative; z-index: 999; margin-bottom: 25px; width: 100%;}
.mobile-nav figure a.logo img {position: relative; top: auto;}
.mobile-nav article {width: 100%;}

.mobile-nav::after {box-sizing: border-box; content: ""; position: absolute; display: block; background: #fff;top: 50%; z-index: 99; transition: 0.5s; height: 95vh; width: 95%; left: -120%; border-radius: 50%; transform: translate(-50%,-50%);}
.mobile-nav.active {left: 0; border-radius: 0; bottom: 0px;}
.mobile-nav.active::after {left: 50%; border-radius: 30px;}

.mobile-nav ul {position: relative; z-index: 999; list-style: none; margin: 0;}
.mobile-nav ul li {width: 100%;}
.mobile-nav ul li a {color: #1d1f1e;text-decoration: none;font-size: 26px;line-height: 1.3;transition: 0.3s ease;display: inline-block;padding: 10px;border:none; outline: none; box-sizing: border-box;}

.mobile-icons {position: relative; z-index: 999; display: flex; padding: 10px; background: #eee; width: 175px; border-radius: 50px; margin: 10px; align-items: center;}
.mobile-icons img {width: 55px; height: 55px; margin-right: 15px;}
.mobile-icons img:last-of-type {width: 25px; height: 50px; margin: 0;}

.no-scroll {height: 100vh; overflow-y: hidden;}

.hamburger {width: 50px; height: 30px; position: absolute; cursor: pointer; right: 50px; top: 50px; transition: 0.3s; z-index: 99999; display: none;}
.hamburger span {height: 4px; background: #353334; width: 100%; position: absolute; opacity: 1; transition: 0.3s; border-radius: 20px;}
.hamburger span:nth-child(1) {top: 0;}
.hamburger span:nth-child(2) {top: 13px;}
.hamburger span:nth-child(3) {bottom: 0;}

.hamburger.active {position: fixed;}

.hamburger.active span:nth-child(2) {opacity: 0; transform: rotate(90deg); top: 15px;}
.hamburger.active span:nth-child(1) {top: 0; transform: rotate(135deg); top: 15px;}
.hamburger.active span:nth-child(3) {bottom: 0; transform: rotate(225deg); top: 15px;}

/*=========================================
Homepage
=========================================*/

header {position: fixed; top: 0px; z-index: 2; width: 100%;}
header .wrapper {display: flex; justify-content: space-between; align-items: center; margin-top: 50px; max-width: 1800px; transition: 0.5s;}

.sticky .wrapper {background: #8a8a8a; border-radius: 50px; padding: 10px 30px;}
.sticky .wrapper .logo img {width: 150px;}
.sticky .wrapper .head-mid #footer-menu {backdrop-filter: none; background: none;}

.logo img {width: 300px; height: auto;}
.head-mid #footer-menu {display: flex; align-items: center; padding: 10px; border-radius: 150px; overflow: hidden; background: #fff4; backdrop-filter: blur(10px);}
.head-mid li {text-transform: none;}
.head-mid a {display: block; border-radius: 50px; overflow: hidden; padding: 7px 25px; transition: 0.5s; font-size: 18px; color: #fff;}
.head-mid a:last-of-type {margin-right: 0px;}
.head-mid a.current {background: #fff; color: #000;}
.head-mid a:hover {color: #000;}
.head-right {display: flex;}
.head-right img, .head-right a img {width: 75px; height: 75px; margin-right: 15px;}
.head-right > img:last-of-type {width: 35px; height: 75px; margin-right: 0px;}

.homeSwiper .swiper-slide img {height: 95vh; border-radius: 0px 0px 7vw 0px; overflow: hidden;}
.homeSwiper .swiper-pagination {text-align: right; right: 130px; bottom: 100px !important; top: auto !important; left: auto !important;}
.homeSwiper .swiper-pagination-bullet-active {background: #fff;}
.homeSwiper .swiper-pagination-bullet {width: 25px; height: 25px; border-radius: 4px; background: #fff;}

.logos {padding: 320px 0px 100px; background: #eee; margin-top: -220px;}
.grid-3 .wrapper {display: grid; grid-template-columns: repeat(3,1fr); grid-gap: 70px;}
.logo-item {text-align: center;}
.logo-item:hover figure {opacity: 0.5;}
.logo-item figure {background: #fff; border-radius: 50px 0px 0px 0px; overflow: hidden; min-height: 450px; position: relative; transition: 0.5s;}
.logo-item img {width: 200px; height: auto; display: inline-block; top: 50%; position: absolute; transform: translate(-50%,-50%);}
.logo-item h6 {text-transform: uppercase; font-size: 1.1vw; font-weight: 500; color: #000; margin-top: 20px;}

.text-block {padding: 100px 0px;}
.text-block .wrapper {max-width: 1280px;}
.text-block h1 {font-family: "brown-pro", sans-serif; font-size: 40px; font-weight: 600; line-height: 29px; margin-bottom: 30px; text-transform: uppercase; color: #000;}
.text-block p {font-size: 20px; line-height: 1.4; font-weight: 100; margin-bottom: 30px;}

.image-bg {position: relative;}
.image-bg figure {background: #000;}
.image-bg img {max-height: 900px; opacity: 0.7; min-height: 900px;}
.overlay-top {position: absolute; top: 150px; left: 150px;}
.overlay-top h4 {color: #fff; font-size: 58px; font-weight: 200; width: 700px; line-height: 1.3;}
.grey-card {position: absolute; bottom: 0px; right: 0px; background: #E3E3E3; max-width: 1020px; border-radius: 50px 0px 0px 0px;}
.grey-card article {padding: 100px;}
.grey-card article p {font-size: 28px; font-weight: 200; line-height: 1.5; margin-bottom: 0px;}

.dark-card {padding: 100px 0px;}
.card-split {padding: 100px 150px; background: #212121; max-width: 1300px; margin: 0 auto; display: flex; border-radius: 30px; align-items: center; justify-content: space-between;}
.card-split article {width: 1000px; margin-top: 20px;}
.card-split h4 {color: #fff; font-size: 58px; font-weight: 300; margin-bottom: 30px; line-height: 1;}
.card-split p {color: #fff; font-size: 28px; font-weight: 100; line-height: 1.5;}
.card-split figure {width: 20%;}
.card-split img {width: 180px; height: auto;}

.contact-form {padding-bottom: 100px;}
.standalone h1, .contact-form h5 {font-size: 36px; line-height: 1.5; font-weight: 200; color: #000; text-align: center; margin-bottom: 50px; text-transform: none;}
.policy a {color: #000; position: relative; display: inline-block;}
.policy a:hover::before {width: 100%; left: 0%; right: auto;}
.policy a::before {content: ""; display: block; height: 2px; width: 0%; position: absolute; bottom: 2px; background: #212121; left: auto; right: 0%; transition: 0.5s; transition: 0.5s;}

.standalone {padding-top: 100px;}

/*=========================================
Testimonials
=========================================*/

.banner-static figure {height: 60vh; border-radius: 0px 0px 7vw 0px; overflow: hidden;}

.testimonials h1 {font-family: "brown-pro", sans-serif; font-size: 40px; font-weight: 600; margin-bottom: 30px; text-transform: uppercase; color: #000; line-height: 29px;}

.testimonialSwiper {height: 950px; margin: 0 -10px;}
.testimonialSwiper .swiper-slide::before {content: '"'; top: 45px; left: 12px; position: absolute; font-size: 40px; color: #000; font-family: "brown-pro"; font-weight: bold; font-style: italic; transform: rotate(180deg);}
.testimonialSwiper .swiper-slide {height: auto !important;}
.testimonialSwiper .swiper-slide::after {content: '"'; bottom: 50px; right: 8px; position: absolute; font-size: 40px; color: #000; font-family: "brown-pro"; font-weight: bold; font-style: italic; transform: rotate(180deg);}
.testimonialSwiper .swiper-slide-next ~ .swiper-slide {opacity: 0.5;}
.testimonialSwiper .swiper-slide article {background: #fafafa; padding: 50px; border-radius: 25px; box-sizing: border-box; margin: 20px 20px 10px;}

.dark-card-full {padding-bottom: 100px;}
.card-full {padding: 100px 150px; background: #212121; max-width: 1300px; margin: 0 auto; display: flex; border-radius: 30px; align-items: center; justify-content: space-between;}
.card-full article {width: 100%; margin-top: 20px;}
.card-full h4 {color: #fff; font-size: 58px; font-weight: 300; margin-bottom: 30px; line-height: 1;}
.card-full p {color: #fff; font-size: 28px; font-weight: 100; line-height: 1.5;}
.card-full li {text-transform: none;}
.card-full li strong {font-weight: 500;}
.card-full li a {color: #fff;}

/*=========================================
Designer Homes / Standard
=========================================*/

.split30-70 {padding: 100px 0px;}
.split30-70 .wrapper {display: grid; grid-template-columns: 1fr 1.5fr; max-width: 1280px; grid-gap: 100px;}
.split-left, .split-right {width: 100%;}
.split-left figure {border-radius: 30px; overflow: hidden; margin-bottom: 30px;}
.split-left-bot {display: flex; align-items: center;}
.split-left-bot p {font-size: 18px; margin: 0px 0px 0px 20px;}
.split-right-top {display: flex; align-items: flex-start; margin-bottom: 50px;}
.split-right-top figure {margin-right: 30px;}
.split-right-top figure img {width: 120px; height: auto;}
.split-right-top article h1 {color: #000; font-size: 45px;}
.split-right-top article h3 {font-size: 34px; margin-bottom: 0px;}
.split-right article p {font-size: 20px; line-height: 1.4; font-weight: 100; margin-bottom: 30px;}

/*=========================================
Footer
=========================================*/

footer {background: #E3E3E3;}
footer .logo img {width: 200px; height: auto;}
footer li {font-size: 18px; font-weight: 200; transition: 0.5s;}
footer li p {margin: 0px;}
footer p a {text-transform: none; color: #000;}
footer a {color: #000;}
footer a:hover {color: #930440;}

.foot-top {display: flex; justify-content: space-between; align-items: center; padding: 100px 0px;}

.foot-right {display: flex;}
.foot-right img, .foot-right a img {width: 90px; height: 90px; margin-right: 20px;}
.foot-right > img:last-of-type {width: 45px; height: 90px; margin-right: 0px;}
.foot-bot {padding: 100px 0px 50px;; border-top: 1px solid #46464626; display: flex; flex-direction: column; align-items: center;}
.foot-bot img {width: 50px; margin-bottom: 20px; transition: 0.5s;}
.foot-bot img:hover {opacity: 0.7;}
.foot-bot p {margin: 0px; font-size: 13px; font-weight: 200;}
