@import url('https://fonts.googleapis.com/css2?family=Albert+Sans:ital,wght@0,100..900;1,100..900&family=Forum&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans:ital,wght@0,100..900;1,100..900&display=swap');

/*** GENERIC CSS ***/
html, body {
	font-family: "Albert Sans", sans-serif;
}

body {
	font-size: 18px;
	background: #fff;
	color: #001428;
}

a {
	-webkit-transition: all ease 0.5s;
	transition: all ease 0.5s;
	text-decoration: none;
	color: #001428;
}

a:hover {
	text-decoration: none;
	color: #FF28B4;
}

a:focus {
	text-decoration: none;
}

button {
	outline: 0 !important;
	-webkit-box-shadow: none;
	box-shadow: none;
	border: none;
}

button:focus {
	-webkit-box-shadow: none;
	box-shadow: none;
}

.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6 {
	color:#001428;
	font-weight: 400;
	font-family: "Forum", serif;
}

h1, .h1 {
	font-size: 100px;
	line-height: 0.8;
}

h2, .h2 {
	font-size: 80px;
	line-height: 1;
}

h3, .h3 {
	font-size: 60px;
	line-height: 1.33;
}

h4, .h4 {
	font-size: 54px;
	line-height: 1;
}

h5, .h5 {
	font-size: 35px;
	line-height: 1;
}

h6, .h6 {
	font-size: 26px;
	line-height: 1.5;
}

p {
	font-size: 18px;
	font-weight: 400;
	line-height: 1.33;
}

p.big {
	font-size: 20px;
	font-weight: 600;
	line-height: 1.65;
}

p.small {
	font-size: 14px;
	font-weight: 400;
	line-height: 1.5;
}

p:last-child {
	margin-bottom: 0;
}

img {
	max-width: 100%;
	height: auto;
}

.section-title h2, .section-title {
	margin-bottom: 50px;
}

.section-title.text-white h2 {
	color: #fff;
}

h3 span, h2 span {
	color: #46DC46;
}

.btn-default {
	background:#FF28B4;
	padding: 16px 35px;
	text-transform: uppercase;
	color: #fff;
	font-family: "Forum", sans-serif;
	font-size: 18px;
	font-style: normal;
	font-weight: 700;
	line-height: 1;
	display: inline-block;
	letter-spacing:1px;
}

.btn-default:hover {
	background:#46DC46;
	color: #001428;
}

/*** HEADER ***/
.header {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 9;
	padding: 60px 0px;
}

.header .navbar {
	padding: 0px;
}

.header .navbar-brand {
	margin: 0;
}

.header .navbar-brand img {
	max-height: 37px;
}

.header .navbar-nav>.nav-item {
	padding: 0px 20px;
}

.header .navbar-nav>.nav-item>.nav-link {
	color: #FFF;
	font-size: 18px;
	font-weight: 600;
	padding: 5px 0px;
	position: relative;
	border-bottom: 1px solid transparent;
	font-family: "Albert Sans", sans-serif;
}

.header .navbar-nav>.nav-item:hover>.nav-link,
.header .navbar-nav>.nav-item.active>.nav-link {
	color: #46DC46;
	border-color: #46DC46;
}

/*.header .navbar-nav>.nav-item.current-menu-item>.nav-link {
color: #46DC46;
border-color: #46DC46;
}*/

.side-menu ul.main-menu.navbar-nav li.current-menu-item>a {
	background: none;
	color: #FF28B4;
}

.menu-btn {
	color: #fff !important;
	min-width: 40px;
	min-height: 60px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	font-size: 12px;
	font-weight: 500;
}

.menu-btn span {
	display: block;
	width: 100%;
	-webkit-transform: translate3d(0, 0, 0);
	-moz-transform: translate3d(0, 0, 0);
	-ms-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0);
	background: #fff !important;
	height: 2px;
	margin: 2.5px 0px;
	border-radius: 5px;
	transition: all .3s;
	float: left;
}

.menu-btn div {
	position: relative;
	top: 0px;
	vertical-align: middle;
	width: 30px;
}

.side-menu {
	background:#fff;
	position:fixed;
	top:0px;
	left:-600px;
	width: 340px;
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
	height:100%;
	z-index:9999999;
	padding: 55px 35px;
	overflow:hidden;
	overflow-y:auto;
	left: -150%;
	box-shadow: 0px 0px 6px 0px rgba(0, 0, 0, 0.15);
}

.side-menu .logo img {
	max-height: 48px;
	margin-top: 40px;
	margin-bottom: 20px;
}

.side-menu.intro {
	left:0px;
}

.side-menu ul.main-menu {
	padding-left:0px;
	margin-top:50px;
}

.side-menu ul.main-menu ul {
	padding: 0;
}

.side-menu ul.main-menu li {
	list-style:none;
	display:inline-block;
	width:100%;
}

.side-menu ul.main-menu li a {
	display: inline-block;
	width: 100%;
	letter-spacing: 1px;
	text-transform: uppercase;
	color: #000;
	font-size: 17px;
	padding: 7px 0px;
	-webkit-transition: 0.2s all ease;
	transition: 0.2s all ease;
	font-weight: 500;
}

.side-menu ul.main-menu li a:hover,
.side-menu ul.main-menu li.active>a {
	background:none;
	color:#FF28B4;
}

.side-menu ul.main-menu .btn-default {
	padding: 16px 15px;
	color: #fff;
}

a.CloseBtn {
	float: right;
	color: #fff;
	background: #FF28B4;
	font-size: 22px;
	margin: 0;
	position: relative;
	z-index: 99;
	cursor: pointer;
	position: absolute;
	top: 0;
	right: 0;
	min-width: 40px;
	min-height: 40px;
	border-radius: 0px 0px 0px 5px;
}

a.CloseBtn:before,
a.CloseBtn:after {
	content: '';
	display: block;
	width: 15px;
	height: 2px;
	background-color: currentColor;
	position: absolute;
	left: 50%;
	top: 50%;
}

a.CloseBtn:before {
	-webkit-transform: translate(-50%, -50%) rotate(45deg);
	-moz-transform: translate(-50%, -50%) rotate(45deg);
	-ms-transform: translate(-50%, -50%) rotate(45deg);
	transform: translate(-50%, -50%) rotate(45deg);
}

a.CloseBtn:after {
	-webkit-transform: translate(-50%, -50%) rotate(-45deg);
	-moz-transform: translate(-50%, -50%) rotate(-45deg);
	-ms-transform: translate(-50%, -50%) rotate(-45deg);
	transform: translate(-50%, -50%) rotate(-45deg);
}

.side-menu ul.main-menu.navbar-nav {
	margin-top:30px;
}

.side-menu ul.main-menu.navbar-nav li {
	margin: 0;
}

.side-menu ul.main-menu.navbar-nav li:last-child a {
	border: none;
}

.side-menu ul.main-menu.navbar-nav li a:hover {
	background:none;
	color: #FF28B4;
}

.side-menu ul.main-menu.navbar-nav li .sub-menu a {
	padding: 10px 15px;
	font-size: 12px;
	background: #ebebeb;
	color: #000;
}

.side-menu .menu-item-has-children {
	cursor: pointer;
}

.side-menu .menu-item-has-children>a {
	pointer-events: none;
	cursor: pointer;
	position: relative;
}

.side-menu .menu-item-has-children:hover>a {
	color: #FF28B4 !important;
}

.side-menu .menu-item-has-children>a:after {
	content: '';
	width: 25px;
	height: 25px;
	background: #FF28B4;
	display: inline-block;
	position: absolute;
	top: 0;
	right: 0;
	top: 50%;
	transform: translate(0px, -50%);
}

.side-menu .menu-item-has-children>a:before {
	position: absolute;
	top: 0;
	right: 0;
	color: #fff;
	font-size: 27px;
	z-index: 99;
	top: 51%;
	transform: translate(0px, -50%);
	right: 6px;
	content: "\f067";
	display: inline-block;
	font: normal normal normal 14px / 1 FontAwesome;
}

.side-menu .menu-item-has-children.current>a:before {
	content: "\f068";
}

.side-menu ul.navbar-nav li a:hover {
	background:none;
	color:#000;
	border-bottom-color: rgba(11, 23, 23, .2);
}

.side-menu li.menu-item-has-children ul.sub-menu {
	opacity: 1;
	visibility: visible !important;
	position: relative !important;
	left: 0 !important;
	-webkit-transform: translateY(0) !important;
	-ms-transform: translateY(0) !important;
	transform: translateY(0) !important;
	background: #ccc;
	padding: 0px 0px !important;
	display: none !important;
	top: 0 !important;
}

.side-menu ul li.current ul.sub-menu {
	display: block !important;
	pointer-events: auto;
}

.side-menu ul.navbar-nav li ul.sub-menu li {
	margin: 0;
}

.side-menu ul.navbar-nav li ul.sub-menu li:hover a,
.side-menu ul.navbar-nav li ul.sub-menu li.current_page_item>a,
.side-menu ul.navbar-nav li ul.sub-menu li.active>a {
	background: #FF28B4 !important;
	color: #fff !important;
}

.side-menu ul li.current ul.sub-menu {
	display: block !important;
	pointer-events: auto;
}

.side-menu ul.main-menu.navbar-nav li {
	margin: 0;
	padding: 0;
	margin-bottom: 10px;
}

/*** BANNER ***/
.banner {
	background: linear-gradient(0deg, rgba(0, 20, 40, 0.80) 0%, rgba(0, 20, 40, 0.80) 100%),url(../img/modernes-wohnzimmer-beiges-sofa-fischgraetboden-vorhänge.webp) 50% 50% no-repeat;
	background-size: cover;
	padding: 270px 0px 180px 0px;
}

.banner .kicker {
	display: flex;
	padding: 0px 10px;
	justify-content: center;
	align-items: center;
	gap: 10px;
	max-width: fit-content;
	border-radius: 90px;
	background: rgba(255, 255, 255, 0.10) !important;
	color: #fff;
	font-size: 18px;
	font-weight: 500;
	line-height: 32px;
	margin-bottom: 50px;
	font-family: "Albert Sans", sans-serif;
}

.banner p {
	color: #F0F0F0;
	font-size: 26px;
	line-height: 42px;
	font-weight: 400;
	margin-bottom: 80px;
}

.banner .h1 {
	color: #FFF;
	font-weight: 400;
	margin-bottom: 50px;
	letter-spacing: -3px;
	font-size:84px;
	line-height: 0.8;
}

.banner .banner-right {
	display: flex;
	flex-direction:column;
	gap: 24px;
}

.banner .bg {
	display: flex;
	padding: 24px 27px;
	flex-direction: column;
	justify-content: space-between;
	align-items: flex-start;
	flex-shrink: 0;
	border-radius: 20px;
	background: rgba(0, 0, 0, 0.40);
	aspect-ratio: 1 / 1.25;
}

.banner .bg p {
	color: #FFF;
	font-size: 14px;
	font-weight: 500;
	line-height: 20px;
	margin: 0;
}

.banner .bg p span {
	font-size: 26px;
	font-weight: 700;
	line-height: 28px;
	padding-bottom: 10px;
	display: inline-block;
}

.banner .bg p.text {
	color: #FFF;
	font-size: 16px;
	font-weight: 700;
	line-height: 28px;
	margin: 0;
}

.banner .img-slider .item img {
	width: 100%;
	object-fit: cover;
	aspect-ratio: 1 / 1.25;
	border-radius: 20px;
}

.banner .owl-dots {
	position: absolute;
	top:105%;
	left: 30%;
	width: 40%;
}

.banner .owl-theme .owl-dots .owl-dot.active span, 
.banner .owl-theme .owl-dots .owl-dot:hover span {
	opacity: 1;
}

.banner .owl-theme .owl-dots .owl-dot span {
	width: 18px;
	height: 5px;
	margin: 5px 3px;
	background: #fff;
	opacity: .2;
	display: block;
	-webkit-backface-visibility: visible;
	transition: opacity .2s ease;
	border-radius: 0px;
}

.banner .custom-owl-nav-wrapper {
	margin-top:17px;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.banner .custom-owl-nav-wrapper .arrow-btn {
	width: 36px;
	height: 36px;
	border-radius: 36px !important;
	background: rgba(255, 255, 255, 0.10) !important;
	display: inline-block;
	margin: 0px 12px;
	line-height: 32px;
	text-align: center;
	cursor: pointer;
}

.banner .custom-owl-nav-wrapper .arrow-btn img {
	width: 18px;
}

.banner .custom-owl-nav-wrapper .arrow-btn:hover {
	background: #fff !important;
}

/*** ABOUT ***/
.about {
	padding: 150px 0px;
	background: #F6F6F6 url(../img/minimalistisches-buero-skizze-schreibtisch-regal-pflanze.webp) center right no-repeat;
	background-size: cover;
}

.about .bg {
	padding: 50px 25px;
	background: #FFF;
	box-shadow: 0 4px 22px 0 rgba(0, 20, 40, 0.05);
	margin-bottom: 20px;
	height:100%;
}

/*** TEAM ***/
.team {
	padding: 150px 0px 130px 0px;
	background: linear-gradient(0deg, rgba(0, 20, 40, 0.60) 0%, rgba(0, 20, 40, 0.60) 100%), url(../img/futuristische-architektur-geometrische-formen-modern.webp) 50% 50% no-repeat;
	background-size: cover;
	position: relative;
	overflow: hidden;
}

.team blockquote {
	padding: 20px 60px;
	border-left: 1px solid #46DC46;
	color: #fff;
	margin-bottom: 60px;
}

.team-box {
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 20px;
	height: 100%;
	color: #fff;
}

.team-box .text h3 {
	color: #FFF;
	margin-bottom: 20px;
}

.team-box .text {
	width: 40%;
	position: relative;
	padding: 60px 40px 70px 0px;
	height: 100%;
}

.team-box .text:before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	opacity: 0.5;
}

.team-box .text:after {
	content: '';
	position: absolute;
	top: 0;
	left: -100vw;
	width: 100vw;
	height: 100%;
	opacity: 0.5;
}

.team-box .text * {
	position: relative;
	z-index: 1;
}

.team-box .img {
	width: 60%;
	height: 100%;
}

.team-box .img img {
	height: 100%;
	width: 100%;
	object-fit: cover;
	object-position: center;
}

.team-box .text.greenbg {
	padding: 60px 20px 70px 40px;
}

.team-box .text.greenbg:before {
	opacity: 0.5;
}

.team-box .text.greenbg:after {
	left: auto;
	right: -100vw;
	width: 100vw;
}

.team-box .btn-default {
	margin-top:10px;
}

/*** BLOG ***/
.blog {
	padding: 150px 0px;
	background: #fff url(../img/stadtmodell-drahtfitter-architektur-visualisierung-3d.webp) 50% 50% no-repeat;
	background-size: cover;
	position: relative;
	overflow: hidden;
}

.blog-box figure {
	margin: 0;
}

.blog-box figure img {
	aspect-ratio: 1 / 0.51;
	object-fit: cover;
	object-position: center;
}

.blog-box.box-2 figure img {
	object-position:bottom center;
}

.blog-box {
	display: inline-block;
	width: 100%;
	padding: 27px;
	background: #fff;
	box-shadow: 0 4px 22px 0 rgba(0, 20, 40, 0.05);
	border: 3px solid #fff;
	height: calc(100% - 20px);
	margin-bottom: 20px;
}

.blog-box .blog-details {
	display: flex;
	flex-direction: column;
	gap: 20px;
	justify-content: space-between;
	height: 100%;
	flex-wrap: wrap;
}

.blog-box .blog-title {
	color: #001428;
	font-family: "Forum", serif;
	font-size: 35px;
	font-weight: 400;
	line-height: 28px;
}

.blog-box .blog-details p {
	color: #001428;
}

.blog-box .blog-details .btn-default {
	width: fit-content;
}

.blog-box:hover {
	border: 3px solid #fff;
	box-shadow: 0 4px 22px 0 rgba(0, 20, 40, 0.05);
}

.blog-box:hover .blog-details .btn-default {
	background: #46DC46 !important;
	color: #fff;
}



/*** COMING SOON ***/
.coming-soon {
	background: linear-gradient(0deg, rgba(0, 20, 40, 0.80) 0%, rgba(0, 20, 40, 0.80) 100%), url(../img/wohnzimmer-minimalistisch-sessel-beige-marmor-tisch-deko-ideen.webp) 50% 50% no-repeat;
	background-size: cover;
	height: 110vh;    
}

.coming-soon h2 {
	font-size: 120px;
	font-style: normal;
	font-weight: 400;
	line-height: 130px; /* 108.333% */
}

.coming-soon .section-title {
	position: relative;
}

.coming-soon p {
	max-width: 350px;
	position: absolute;
	bottom: 35px;
	right: 150px;
}

/*** SERVICES ***/
.services {
	padding: 150px 0px;
	background: #F7F7F7;
}

.services .spech2 {
	opacity: 0.05;
	color: #000;
	text-align: center;
	font-family: "Forum", sans-serif;
	font-size: 170px;
	font-style: normal;
	font-weight: 400;
	line-height: 0px; /* 47.059% */
}

.mt-100 {
	margin-top: 100px;
}

.services .accordion {
	margin-top: 50px;
	border: none;
	border-radius: 0;
}

.services .accordion-button {
	border: none !important;
	font-size: 20px;
	font-weight: 600;
	box-shadow: none !important;
	padding:30px;
	background-color: #fff !important;
	color: #001428;
	font-family: "Forum", sans-serif;
	font-size: 35px;
	font-style: normal;
	font-weight: 400;
	line-height: 28px;
	margin-bottom: 0px;
	padding-bottom: 0px;
	border-radius: 0px !important;
}

.services .accordion-button h3 {
	font-size: 28px;
}

.services .accordion .accordion-item {
	border: none !important;
	border-radius: 0px !important;
	border-bottom: 1px solid #D9D9D9 !important;
	margin-bottom: 0px;
	padding-bottom: 0px;
	background: none;
}

.services .accordion-body {
	padding:20px 75px 40px 30px;
	border: none !important;
	color: #001428;
	background: #fff;
}

.services .accordion-body .d-flex {
	gap: 20px;
}

.services .accordion-body .d-flex img {
	aspect-ratio:1 / 0.6;
	object-fit:cover;
	object-position:bottom;
}

.services .accordion-body h3 {
	color: #001428;
}

.services .accordion-button.collapsed {
	background-color: transparent !important;
	padding:30px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.28) !important;
}

.services .accordion-button::after {
	width: 50px;
	height: 50px;
	border: none !important;    
	background: url(../img/icon-faq-accordion-arrow.svg) 50% 50% no-repeat;
	background-size: contain;
	transform: rotate(-180deg);
	right: 0px;
	margin-right: 0px;
	filter: invert(1) brightness(1);    
	right: 20px;
	margin-right: 0px;
}

.services .accordion-button.collapsed::after {
	background: url(../img/icon-faq-accordion-arrow.svg) 50% 50% no-repeat;
	background-size: contain;
	transform: rotate(0deg);
	filter: invert(1) brightness(1);   
}

.services .accordion-button h3 {
	color: #001428 !important;
	margin-bottom: 0;
}

.services .accordion-button.collapsed h3 {
	color: #001428 !important;
	margin-bottom: 0px;
}

.services .accordion-body ul li, .faqs .accordion-body p {
	color: #001428;
	font-family: "Albert Sans", sans-serif;
	font-size:18px;
	font-style: normal;
	font-weight: 400;
	line-height: 1.44; /* 130% */
}

.services .accordion-body a {
	text-decoration: underline;
}

/*** LIVING LIFE ***/
.living-life {
	padding: 150px 0px;
	background: #001428;
}

.living-grid {
	margin-bottom: 60px;
}

.ratio-2x3 img {
	aspect-ratio: 1 / 1.12;
	margin-bottom: 8px;
	object-fit: cover;
	object-position: center;
}

.ratio-1x3 img {
	aspect-ratio: 1 / 0.625;
	object-fit: cover;
	object-position: center;
	margin-bottom: 8px;
}

.ratio-1x3x2 img {
	aspect-ratio: 1 / 1.285;
	object-fit: cover;
	object-position: center;
	margin-bottom: 8px;
}

.ratio-1x2 img {
	aspect-ratio: 1 / 0.875;
	object-fit: cover;
	object-position: center;
	margin-bottom: 8px;
}

.ratio-1x3x2 .d-flex img {
	width: calc(50% - 5px);
	margin-right: 10px;
}

.living-life p {
	color: #fff;
}

/*** INDIVIDUAL ***/
.individual {
	position: relative;
	overflow: hidden;
}

.individual .align {
	position: absolute;
	bottom: 100px;
	left: 0;
	width: 100%;
	z-index: 2;
}

.individual .section-title h2 {
	text-transform: uppercase;
	margin-bottom: 30px;
	color:#fff;
}

.individual .section-title {
	margin: 0px;
}

.individual .mainimg {
	aspect-ratio:1 / 0.65;
	object-fit:cover;
	object-position:center;
}

/*** GALLERY ***/
.gallery {
	padding: 150px 0px 75px 0px;
	background: #001428;
}

.gallery .custom-owl-nav-wrapper {
	margin-top: 60px;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.gallery .custom-owl-nav .arrow-btn {
	width: 36px;
	height: 36px;
	border-radius: 36px !important;
	background: rgba(255, 255, 255, 0.10) !important;
	display: inline-block;
	margin: 0px 12px;
	line-height: 32px;
	text-align: center;
	cursor: pointer;
}

.gallery .custom-owl-nav .arrow-btn img {
	width: 18px;
}

.gallery .custom-owl-nav .arrow-btn:hover {
	background: #46DC46 !important;
}

.gallery p {
	color: #fff;
	margin-bottom: 0px;
}

.gallery .owl-carousel .owl-item img {
	aspect-ratio:1 / 1.12;
	object-fit:cover;
	object-position:center;
}

/*** BRANDS ***/
.brands {
	padding: 150px 0px;
	background: #F7F7F7;
}

.brands .item figure {
	background: #fff;
	width: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	height:100px;
	aspect-ratio: 1 / 0.5;
	object-fit: contain;
	object-position: center;
	padding:30px;
}

.brands .item {
	height:100px;
}

/*** TESTIMONIALS ***/
.testimonials {
	background: #001428;
	padding: 150px 0px;
}

.testimonials .quote-carousel .owl-item {
	height:100%;
}

.testimonials .quote-carousel .item {
	background: #FFF;
	box-shadow: 0 4px 22px 0 rgba(0, 20, 40, 0.05);
	padding:50px;
	height:100%;
}

.testimonials .quote-carousel .item img {
	width: 88px;
	height: 88px;
	padding: 24px;
	background-color: #001428;
	border-radius: 88px;
	display: inline-block;
	margin-bottom: 50px;
}

.testimonials .quote-carousel .item h3, .testimonials .quote-carousel .item p.big, .testimonials .quote-carousel .item .rating {  
	margin-bottom: 50px;
}

.testimonials .quote-carousel .item p.big {
	font-weight: 600;
}

.testimonials .quote-carousel .item p {
	font-weight: 700;
}

.testimonials .quote-carousel .rating i {
	color: #FF28B4;
	margin: 0px 5px;
	font-size: 28px;
}


/*** INTERIOR HOUR ***/
.interior-hour {
	background: #F7F7F7;
	padding: 150px 0px;
}

.interior-hour img {
	aspect-ratio: 1 / 0.9;
	object-fit: cover;
	object-position: center;
}

.interior-hour-details {
	background: #FFF;
	padding: 30px 40px;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}

.interior-hour-details p, .interior-hour-details ul.list li {
	line-height: 1.44;
	font-size: 18px;;
}

.interior-hour-details ul.list {
	margin: 0px 0px 0px 15px;
	padding: 0px;
}

.interior-hour-details ul.list li { 
	line-height: 2.55;
	margin-bottom: 10px;
}

.interior-hour-details .btn-default {
	margin-top: 28px;
}

.interior-hour-details h3 {
	margin-bottom: 28px;
}


/*** FAQS ***/
.faqs {
	padding: 150px 0px;
	background: #001428;
}

.faqs .accordion {
	border: none;
	border-radius: 0;
}

.faqs .accordion-button {
	border: none !important;
	font-size: 20px;
	font-weight: 600;
	box-shadow: none !important;
	padding:30px;
	background-color: #fff !important;
	color: #001428;
	font-family: "Forum", sans-serif;
	font-size: 35px;
	font-style: normal;
	font-weight: 400;
	line-height: 28px;
	margin-bottom: 0px;
	padding-bottom: 0px;
	border-radius: 0px !important;
}

.faqs .accordion-button h3 {
	font-size: 28px;
}

.faqs .accordion .accordion-item {
	border: none !important;
	border-radius: 0px !important;
	border-bottom: 1px solid rgba(0, 0, 0, 0.28) !important;
	margin-bottom: 20px;
	padding-bottom: 0px;
	background: none;
}

.faqs .accordion-body {
	padding:20px 75px 20px 30px;
	border: none !important;
	color: #001428;
	background: #fff;
}

.faqs .accordion-body h3 {
	color: #001428;
}

.faqs .accordion-button.collapsed {
	background-color: transparent !important;
	padding:30px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.28) !important;
}

.faqs .accordion-button::after {
	width: 50px;
	height: 50px;
	border: none !important;    
	background: url(../img/icon-faq-accordion-arrow.svg) 50% 50% no-repeat;
	background-size: contain;
	transform: rotate(-180deg);
	right: 0px;
	margin-right: 0px;
	filter: invert(1) brightness(1);    
	right: 20px;
	margin-right: 0px;
}

.faqs .accordion-button.collapsed::after {
	background: url(../img/icon-faq-accordion-arrow.svg) 50% 50% no-repeat;
	background-size: contain;
	transform: rotate(0deg);
	filter: none;
}

.faqs .accordion-button h3 {
	color: #001428 !important;
	margin-bottom: 0;
}

.faqs .accordion-button.collapsed h3 {
	color: #fff !important;
	margin-bottom: .5rem;
}

.faqs .accordion-body ul li, .faqs .accordion-body p {
	color: #001428;
	font-family: "Albert Sans", sans-serif;
	font-size:18px;
	font-style: normal;
	font-weight: 400;
	line-height: 1.44; /* 130% */
}

.faqs .accordion-body a {
	text-decoration: underline;
}

/*** CONTACT FORM ***/
.contact-form {
	background: #F7F7F7;
	padding: 150px 0px;
}

.contact-details {
	background: #FFF;
	padding: 70px;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}

.contact-details p {
	font-size: 24px;
	line-height: 1.5;
}

/*** FOOTER ***/
.footer {
	background: #001428;
	padding: 110px 0px 58px 0px;
}

.footer * {
	color: #fff;
}

.footer .h6 {
	margin-bottom: 16px;
	font-size:22px;
}

.foot-menu {
	margin: 0px;
	padding: 0px;
	list-style: none;
}

.foot-menu li {
	margin-bottom: 8px;
}

.foot-menu li a {
	font-size: 14px;
	line-height: 1.5;
}

.footer .social-links a {
	margin-right: 20px;
}

.footer hr {
	border-color: #fff;
	margin: 75px 0px 40px 0px;
	opacity: 0.10;
}

.footer .privacy-menu {
	margin: 0px;
	padding: 0px;
	list-style:none;
}

.footer .privacy-menu li {
	display: inline-block;
	margin: 0px 12px;
}

.footer .privacy-menu li a {
	text-decoration: underline;
}

/*** PAGE-BANNER ***/
.page-banner {
	height: auto;
	padding: 250px 0px 0px 0px;
}

.page-banner .breadcrumb {
	color: rgba(255, 255, 255, 0.5);
	margin-top: 180px;
}

.page-banner .breadcrumb span {
	padding: 0px 15px;
}

.page-banner .breadcrumb a, .page-banner h1 {
	color: #fff;
}

/*** PARTNER PAGE ***/
.partners {
	background: #F7F7F7;
	padding: 150px 0px;
}

.partners .section-title {
	margin-bottom: 60px;
}

.partners .section-title h2 {
	margin-bottom: 5px;
}

.partner-box {
	background: #FFF;
	padding: 30px 20px;
	flex-direction: column;
	height: calc(100% - 30px);
	margin-bottom: 30px;
	text-align: center;
}

.partner-box .img {
	margin-bottom: 30px;
}

.partner-box h5, .partner-box .h5 {
	margin: 30px 0px;
}

.partner-box p {
	margin: 0px 0px 15px 0px;
}

.partner-box p a {
	color: #001428;
	text-decoration: underline;
}

.partner-box p a:hover {
	color: #FF28B4;
	text-decoration: none;
}

.partner-box p a {
	word-break: break-all;
}

/*** CONTACT PAGE ***/
.contact-form.contactpage .bg-form {
	padding: 35px 35px 45px 35px;
	background: #fff;
	box-shadow: 0px 0px 5px 0px rgba(0,0,0,.1);
	margin-bottom: 40px;
}

.contact-form.contactpage .section-title h2 {
	margin-bottom: 0px;
}

.contact-form.contactpage .contact-details {
	height: calc(100% - 40px);
	margin-bottom: 40px;
}

.contact-form.contactpage .bg-form h3 {
	font-family: "Albert Sans", sans-serif;
	font-weight: 600;
	font-size: 28px;
	margin-bottom: 35px;
}

label {
	color: #000;
	font-family: "Albert Sans", sans-serif;
	font-weight: 400;
	font-size: 15px;
	margin-bottom: 5px;
}

.form-control {
	height: 35px;
	border-radius: 0px;
	border: 1px solid #000 !important;
	font-family: "Albert Sans", sans-serif;
	font-weight: 400;
	font-size: 14px;
	margin-bottom: 20px;
	box-shadow: none !important;
}

textarea.form-control {
	height: 125px;
	margin-bottom: 30px;
}

input.wpcf7-form-control.wpcf7-not-valid{
	border: 2px solid #f00 !important;
}
span.wpcf7-not-valid-tip{
	display:none;
}
div.wpcf7-validation-errors, div.wpcf7-acceptance-missing{
	display:inline-block !important; 
}

.wpcf7-response-output.wpcf7-display-none.wpcf7-mail-sent-ok{
	display:inline-block !important;
}
.wpcf7 form.init .wpcf7-response-output, .wpcf7 form.resetting .wpcf7-response-output, .wpcf7 form.submitting .wpcf7-response-output{
	display:none !important;
}
.wpcf7 form .wpcf7-response-output{
	display:inline-block !important;
}

.contact-form.contactpage textarea {
	resize: none;
}

.page-banner .breadcrumb {
	margin-top: 200px;
	margin-bottom: 25px;
}

.page-banner .breadcrumb span {
	padding: 0px 15px;
	color: #fff;
}

.contact-form.contactpage .section-title {
	margin-bottom: 60px;
}

.contact-form.contactpage .bg-form {
	padding: 50px 40px;
}

.contact-form.contactpage .form-control {
	height: 40px;
	color: rgba(0, 0, 0, 1);
	font-family: "Noto Sans", sans-serif;
	padding-left: 15px;
	font-size: 16px;
	font-weight: 300;
}

.contact-form.contactpage .form-control::-webkit-input-placeholder {
	color: rgba(0, 0, 0, 0.30);
}

.contact-form.contactpage textarea.form-control {
	height: 140px;
	padding-top: 13px;
}


/*** ACCESSIBILITY FOOTER BAR ***/
.accessibility-hover {
	padding:24px;
	border-radius: 12px;
	background: #F5F5F5;
	position: fixed;
	bottom: 20px;
	right: 130px;
	width: 490px;
	display:none;
}

.accessibility-hover::before {
	content:'';
	position:absolute;
	bottom: 35px;
	right: -15px;
	width: 32px;
	height: 32px;
	transform: rotate(45deg);
	background: #f5f5f5;
}

.accessibility-hover h4, .accessibility-hover p {
	line-height:1.5;
	margin-bottom:10px;
}

.accessibility-hover h4 {
	margin-bottom:5px;
}

#accessibility-toolbar {
	position: fixed;
	bottom: 20px;
	right: 20px;
	z-index: 9999;
	font-family: Arial, sans-serif;
}

#accessibility-toolbar:hover .accessibility-hover {
	display:inline-block;
}

.toolbar-toggle {
	background: #FF28B4;
	color: white;
	border: none;
	border-radius: 50%;
	width: 50px;
	height: 50px;
	cursor: pointer;
	font-size: 20px;
	box-shadow: 0 2px 5px rgba(0,0,0,0.2);
	transition: all 0.3s ease;
	margin-right:11px;
}

.toolbar-toggle:hover {
	background: #46DC46;
}

.toolbar-options {
	display: none;
	position: absolute;
	bottom: 60px;
	right: 0;
	background: white;
	border-radius: 5px;
	box-shadow: 0 2px 10px rgba(0,0,0,0.2);
	padding: 10px;
}

.toolbar-options button {
	background: #f5f5f5;
	border: none;
	border-radius: 3px;
	padding: 8px 12px;
	margin: 5px;
	cursor: pointer;
	font-size: 14px;
	transition: all 0.2s ease;
	height:58px;
	width:42px;
}

.toolbar-options button:hover {
	background: #e0e0e0;
}

.toolbar-options button.active, .toolbar-options button:hover { 
	background:#000 !important;
	color:#fff !important;
}

/* HIGH CONTRAST TOOLBAR */
.high-contrast section a:not([class]) {
	color:#7D02B5;
}

.high-contrast .stats .social-box.box-1 p.big, .high-contrast .stats .social-box.box-1 .number,
.high-contrast .stats .social-box.box-3 p.big, .high-contrast .stats .social-box.box-3 .number {
	color:#000 !important;
}

.high-contrast .stats .social-box.box-1 .btn-link em img, .high-contrast .stats .social-box.box-3 .btn-link em img {
	filter:invert(1) !important;
}

.high-contrast .stats .social-box * {
	color:#fff !important;
}

.high-contrast .btn-default, .high-contrast .bto-teaser .bto-tags li a.active, .high-contrast .bto-teaser .bto-tags li a {
	color:#000 !important;
}

.high-contrast .btn-default:hover, .high-contrast .bto-teaser .bto-tags li:hover a {
	text-decoration:underline !important;
	color:#000 !important;
	opacity:1 !important;
}

.high-contrast .btn-default em img {
	filter:invert(1);
}

.high-contrast .btn-black, .high-contrast .bto-teaser .btn-default, .high-contrast .bto-teaser .bto-tags li a.active, .high-contrast .bto-teaser .bto-tags li:hover a {
	color:#fff !important;
}

.high-contrast .btn-black em img, .high-contrast .bto-teaser .btn-default em img {
	filter:brightness(0) invert(1) !important;
}

.high-contrast .btn-black:hover em img {
	filter:invert(1) !important;
}

.high-contrast .btn-white em img {
	filter:brightness(0) !important;
}

.high-contrast .btn-white:hover em img {
	filter:britghtness(0) !important;
}

.high-contrast .copyrights .social a, .high-contrast .copyrights .social a:hover, .high-contrast .copyrights .btn-white:hover {
	background:#fff !important;
	color:#000 !important;
	text-decoration:underline !important;
}

.high-contrast .history .btn-loadmore,.high-contrast .video-box .btn-default.black {
	color:#fff !important;
}

.high-contrast .video-box .btn-default.black em img {
	filter:none !important;
}

.high-contrast .term-life .nav-tabs button {
	color:#000 !important;
	border-color:#000 !important;
}

.high-contrast .term-life .nav-tabs button.active {
	color:#FF7C01 !important;
	border-color:#FF7C01 !important;
}

.high-contrast .tarif-details th:nth-child(4n) .btn-default, .high-contrast.postid-973 .tarif-details th .btn-default {
	color:#fff !important;
}

.high-contrast .tarif-details th:nth-child(4n) .btn-default em img, .postid-973 .tarif-details th .btn-default em img, .high-contrast .seal .btn-default img, .high-contrast .steps-to-follow .btn-default.btn-orange img {
	filter:invert(0) !important;
}

.high-contrast .cta h2, .high-contrast .cta h3, .high-contrast .job-position-cta .no-position-title, .high-contrast .job-position-cta p.big,
.high-contrast .stats.custom-service .bg .kicker, .high-contrast .stats.custom-service .bg h2, .high-contrast .blog-sidebar .cat-clouds li a {
	color:#000 !important;
}

.high-contrast .contact-form .career-list.evb li .btn-default em img {
	filter:unset !important;
}

.high-contrast .wokevent-gallery.awards .btn-loadmore, .high-contrast .wokevent-gallery.awards .btn-loadless {
	color:#fff !important;
}

.high-contrast .term-life .nav-tabs button {
	border-color:#606B7B !important;
	color: #606B7B !important;
}

.high-contrast .term-life .nav-tabs button.active {
	border-color: #000 !important;
	color: #000 !important;
} 

.high-contrast .agency-team .team-box p, .high-contrast .agency-team-carousel .details p, .high-contrast .blog-sidebar .author p.grey {
	color: #606B7B;
} 

/* UNDERLINE TOOLBAR */
body.underline-links a {
	text-decoration: underline !important;
}

.smaller-text {
	font-size: 90% !important;
}

/* A+ TOOLBAR */
body.larger-text .kicker {
	font-size:24px !important;
	line-height:36px !important;
}

body.larger-text p.small, body.larger-text .footer .footer-menu li a,  body.larger-text p {
	font-size:26px !important;
	line-height:38px !important;
	word-wrap: break-word;
}

body.larger-text p.big, body.larger-text .latest-faqs .accordion-header {
	font-size:32px !important;
	line-height:44px !important;
}

body.larger-text .company-location .locations>.row .col-lg-6, body.larger-text .company-location .locations figure img {
	width:100% !important;
}

body.larger-text .company-location .details>.row .col-lg-6 {
	width:50% !important;
}

body.larger-text .locations .details p.big {
	margin-bottom:30px !important;
}

body.larger-text .perfect-profile-box {
	height:425px;
}

body.larger-text .copyrights p {	
	font-size: 14px !important;
	line-height: 22px !important;
}

body.larger-text .review-widgets .bgs .kicker span {
	font-size:16px !important;
	line-height:24px !important;
}

body.larger-text .info .hover-card .link em {
	height:36px;
}

body.larger-text .info .hover-card:hover .link em img {
	margin-top:-72px;
}

/*** KEYBOARD ACCESSIBILITY OPTIONS ***/
.skip-link {
	position: absolute;
	top: -40px;
	left: 0;
	background: #000;
	color: #fff;
	padding: 8px 16px;
	z-index: 100;
}

.skip-link:focus {
	top: 0;
}

a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible,
a:focus-visible, button:focus-visible, input:focus-visible {
	outline: 3px solid #dc143c !important;
	outline-offset: 2px !important;
}

.screen-reader-text {
	position: absolute !important;
	width: 1px;
	height: 1px;
	padding: 0;
	overflow: hidden;
	clip: rect(1px, 1px, 1px, 1px);
	white-space: nowrap;
	border: 0;
}

.screen-reader-text:focus-visible {
	position: static !important;
	width: auto;
	height: auto;
	clip: auto;
	white-space: normal;
}