/*
Theme Name: Halmtak reparation
Theme URI: https://halmtak-reparation.se
Description: Default website theme of Halmtak reparation.
Author: Digitalform
Author URI: https://digitalform.hu
Version: 1.0
*/

*{
margin: 0;
padding: 0;
border: 0;
flex-wrap: wrap;
text-decoration: none; 
}

@font-face { 
	font-family: 'Suisse Intl'; 
	src: url("fonts/suisseintl-regular.woff2") format('woff2');
	font-weight: 400; 
	font-style: normal;
	font-stretch: normal;
	font-display: swap;
}

@font-face { 
	font-family: 'Suisse Intl'; 
	src: url("fonts/suisseintl-bold.woff2") format('woff2');
	font-weight: 700; 
	font-style: normal;
	font-stretch: normal;
	font-display: swap;
}

@font-face { 
	font-family: 'Grifo M'; 
	src: url("fonts/grifom-regular.woff2") format('woff2');
	font-weight: 400; 
	font-style: normal;
	font-stretch: normal;
	font-display: swap;
}

*, 
*:after, 
*::before { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }

:root { 
	--max-width: 1920px;
	
	--color-dark: #201d19;
	--color-sand: #f4efeb;
	--color-dark-sand: #d3c6ad;
	--color-orange: #e95d2a;
	--color-red: #f55534;
}

html { background: var(--color-dark-sand); overflow-x: hidden; }
body { margin: auto; font-family: 'Suisse Intl', sans-serif; font-size: 18px; font-weight: 400; line-height: 30px; }
body.rwd_menu__opened { overflow-y: unset; }

textarea, input, select, button { font-family: 'Suisse Intl', sans-serif; font-size: 16px; outline: none; }

h1, h2, h3, h4 { font-weight: normal; line-height: 100%; }

img.alignleft { margin: 0 20px 5px 0; float: left; }
img.alignright { margin: 0 0 5px 20px; float: right; }
img.aligncenter { margin: 0 auto 20px auto; display: block; }

hr { margin: 20px 0; border-top: 2px solid var(--color-sand); }

/* Classes */
.left { float: left; }
.right { float: right; }
.clear { clear: both; }
.inner { max-width: 1280px; margin-left: auto; margin-right: auto; position: relative; }
.inner_800 { max-width: 800px; }
.inner_960 { max-width: 960px; }
.vertical_middle { top: 50%; position: relative; transform: translateY(-50%); }
.hide { display: none !important; }
.red { color: var(--color-red); }
.b_r_3 { -webkit-border-radius: 3px; -moz-border-radius: 3px; border-radius: 3px; }
.b_r_50p { -webkit-border-radius: 50%; -moz-border-radius: 50%; border-radius: 50%; }

.sec_font { font-family: 'Grifo M', sans-serif; font-weight: 400; }
.center { text-align: center; }
.uppercase { text-transform: uppercase; }

/* Animation */
.anim, :before, :after { transition: all 0.2s ease-out; }
.anim_cubic { transition: all 1s cubic-bezier(0.19, 1, 0.22, 1); }

/* Button */
.button { height: 70px; padding: 4px 30px 0; font-size: 20px !important; font-weight: 400; text-decoration: none !important; color: white !important; line-height: 20px; background: var(--color-orange); display: inline-flex; align-content: center; justify-content: center; position: relative; cursor: pointer; border-radius: 35px; transition: all 0.2s ease-out; }
.button:hover { background-color: var(--color-dark); }

.button:disabled, 
.button:disabled:hover { color: white !important; background-color: #ccc !important; }

.button.button_h60 { height: 60px; padding-left: 20px; padding-right: 20px; }

.button.button_has_arrow { padding-left: 80px; }
.button.button_has_arrow:hover { padding-left: 30px; padding-right: 80px; }
.button.button_has_arrow:before, 
.button.button_has_arrow:after { width: 50px; height: 50px; left: 10px; top: 10px; background: white url(images/icon_arrow_right_dark.svg) no-repeat center; background-size: auto 20px; position: absolute; content: ''; border-radius: 25px; }
.button.button_has_arrow:after { left: auto; right: 10px; transform: scale(0); }
.button.button_has_arrow:hover:before { transform: scale(0); }
.button.button_has_arrow:hover:after { transform: scale(100%); }

.button.button_has_arrow.arrow_down:before, 
.button.button_has_arrow.arrow_down:after { background-image: url(images/icon_arrow_down_dark.svg); }

/* Checkbox and radio */
input[type="checkbox"], 
input[type="radio"] { width: 24px; height: 24px; margin: -4px 4px 0 0 !important; padding: 0 !important; text-align: center !important; background-color: white; border: 1px solid #ddd; clear: none; cursor: pointer; display: inline-block; line-height: 0; outline: 0; vertical-align: middle !important; -webkit-appearance: none; -webkit-box-shadow: none; box-shadow: none; -webkit-transition: .05s border-color ease-in-out; transition: .05s border-color ease-in-out; }
input[type="radio"] { -webkit-border-radius: 50%; -moz-border-radius: 50%; border-radius: 50%; }

input[type="radio"]:hover, 
input[type="checkbox"]:hover, 
input[type="radio"]:checked, 
input[type="checkbox"]:checked { border-color: #aaa99f; }

input[type="radio"]:checked:before { width: 14px; height: 14px; left: 4px; top: 4px; text-align: center; background: var(--color-red); position: relative; border-radius: 8px; display: block; content: ''; }
input[type="checkbox"]:checked:before { width: 14px; height: 14px; left: 4px; top: 4px; text-align: center; color: var(--color-green); line-height: 14px; position: relative; display: block; content: '✓'; }


/*
---------------
	WEBSITE
---------------
*/
#website { max-width: var(--max-width); background: white; margin: auto; }


/*
------------------
	NAVIGATION
------------------
*/
#rwd_menu { width: 100%; left: 0; top: 0; bottom: 0; background: rgba(0 0 0 / 20%); position: fixed; z-index: 1000; visibility: hidden; opacity: 0; } 
#rwd_menu .rwd_menu_wrap { width: 480px; height: 100%; right: -100%; top: 0; background: var(--color-sand); position: absolute; overflow-x: hidden; overflow-y: auto; } 

#rwd_menu .rwd_menu_section h5 { margin-bottom: 10px; font-size: 14px; text-transform: uppercase; color: rgba(0 0 0 / 50%); }

/* RWD menu header */
#rwd_menu .rwd_header { height: 100px; position: relative; }
#rwd_menu .rwd_header img { width: 104px; height: 50px; left: 50px; display: block; position: absolute; }
#rwd_menu .rwd_header .rwd_button { width: 50px; height: 50px; right: 50px; background: var(--color-dark); position: absolute; z-index: 2; cursor: pointer; border-radius: 50%; }
#rwd_menu .rwd_header .rwd_button .burg { width: 20px; height: 2px; left: 15px; top: calc(50% - 1px); background: transparent; display: block; position: absolute; transition: 0.2s; }

#rwd_menu .rwd_header .rwd_button .burg:before, 
#rwd_menu .rwd_header .rwd_button .burg:after { width: 20px; height: 2px; background: white; position: absolute; content: ''; -moz-transition: 0.2s; -o-transition: 0.2s; -webkit-transition: 0.2s; transition: 0.2s; }
#rwd_menu .rwd_header .rwd_button .burg:before { top: 0; left: 0; -webkit-transform: rotate(45deg); }
#rwd_menu .rwd_header .rwd_button .burg:after { top: 0; right: 0; -webkit-transform: rotate(-45deg); }

/* Contacts */
#rwd_menu .rwd_menu_section.contacts { padding: 0 50px; }
#rwd_menu .rwd_menu_section.contacts .contacts_wrap { padding-bottom: 30px; border-bottom: 1px solid rgba(0 0 0 / 20%); }
#rwd_menu .rwd_menu_section.contacts .contacts_wrap .button { width: 100%; padding: 0 10px; }

/* Menu */
#rwd_menu .rwd_menu_section.menu { padding: 30px 50px; }

#rwd_menu ul { margin-bottom: 0; list-style: none; }
#rwd_menu ul li a { color: var(--color-dark); display: block; }

/* Primary menu */
#rwd_menu ul.primary_menu li { border-bottom: 1px solid rgba(0 0 0 / 20%); }
#rwd_menu ul.primary_menu li a { padding: 15px 0; font-size: 20px; font-weight: 700; line-height: 100%; display: block; position: relative; }
#rwd_menu ul.primary_menu li a:hover { text-decoration: underline; text-decoration-thickness: 1px; }

#rwd_menu ul.primary_menu li.menu-item-has-children > a:after { width: 16px; height: 16px; right: 0; top: calc(50% - 8px); background: url(images/icon_arrow_down.svg) no-repeat center; background-size: auto 100%; position: absolute; content: ''; }
#rwd_menu ul.primary_menu li.menu-item-has-children.open > a:after { ms-transform: rotate(180deg); -webkit-transform: rotate(180deg); transform: rotate(180deg); }

#rwd_menu ul.primary_menu li ul { margin-left: -50px; margin-right: -50px; background: white; display: none; }
#rwd_menu ul.primary_menu li ul li { border-bottom-color: rgba(0 0 0 / 7%); }
#rwd_menu ul.primary_menu li ul li:last-child { border-bottom: none; }
#rwd_menu ul.primary_menu li ul li a { left: auto !important; padding: 15px 50px 15px; font-size: 17px; color: var(--color-dark) !important; line-height: 20px; opacity: 100% !important; }
#rwd_menu ul.primary_menu li ul li.menu-item-has-children > a:after { width: 20px; height: 20px; right: 20px; top: calc(50% - 10px); background: url(images/icon_arrow_down_small.svg) no-repeat center; background-size: 12px; position: absolute; content: ''; }
#rwd_menu ul.primary_menu li ul li.open > a:before { display: none; }

#rwd_menu ul.primary_menu li ul li ul { background: #eef0f4; }
#rwd_menu ul.primary_menu li ul li ul li { border-bottom: none; }
#rwd_menu ul.primary_menu li ul li ul li a { padding: 10px 20px; }

/* Secondary menu */
#rwd_menu .rwd_menu_section.useful_info { padding: 30px 50px; }

#rwd_menu ul.secondary_menu li { margin-bottom: 5px; }
#rwd_menu ul.secondary_menu li a { font-size: 18px; font-weight: 400; }
#rwd_menu ul.secondary_menu li a:hover { text-decoration: underline; }

body.rwd_menu__opened #rwd_menu { visibility: visible; opacity: 100%; }
body.rwd_menu__opened #rwd_menu .rwd_menu_wrap { right: 0; }


/*
--------------
	HEADER
--------------
*/
#header { height: 160px; padding: 0 100px; background: var(--color-sand); border-top: 10px solid var(--color-dark); border-bottom: 1px solid transparent; }
#header .header_wrap { max-width: none; height: 100%; }

/* Logo */
#header .logo { width: min-content; left: 50%; top: 50%; color: var(--color-dark); display: flex; justify-content: center; position: absolute; transform: translate(-50%, -50%); z-index: 2; }
#header .logo h1 { width: max-content; margin-top: 10px; padding: 0 25px; font-size: 22px; text-transform: uppercase; display: inline-block; position: relative; }
#header .logo h1:before, 
#header .logo h1:after { width: 10px; height: 10px; left: 0; top: calc(50% - 5px); background: var(--color-orange); position: absolute; content: ''; border-radius: 50%; }
#header .logo h1:after { left: auto; right: 0; }
#header .logo br { height: 0; flex-basis: 100%; }

/* Menu */
#header .menu { width: 100%; top: 50%; display: flex; justify-content: space-between; position: absolute; transform: translateY(-50%); z-index: 1; }
#header .menu ul { display: flex; list-style: none; }
#header .menu ul li { margin: 0 15px; }
#header .menu ul li:first-child { margin-left: 0; }
#header .menu ul li:last-child { margin-right: 0; }
#header .menu ul li a { padding: 0 10px; font-size: 20px; color: var(--color-dark); line-height: 100%; position: relative; }
#header .menu ul li a:after { width: 0; height: 5px; left: 50%; bottom: 0; background: var(--color-dark-sand); position: absolute; content: ''; }
#header .menu ul li a:hover:after { width: 100%; left: 0; }
#header .menu ul li.current-menu-item a:after { width: 100%; left: 0; background: var(--color-orange); }

/* RWD button */
#header .rwd_button { height: 50px; right: 0; padding-left: 50px; padding-right: 15px; padding-top: 2px; font-size: 14px; text-transform: uppercase; color: white; line-height: 50px; background: var(--color-dark); display: inline-block; position: absolute; cursor: pointer; border-radius: 25px; }
#header .rwd_button .burg { width: 40px; height: 40px; top: 5px; left: 5px; position: absolute; }

#header .rwd_button .burg:before, 
#header .rwd_button .burg:after { width: 20px; height: 1px; background: white; position: absolute; content: ''; -moz-transition: 0.2s; -o-transition: 0.2s; -webkit-transition: 0.2s; transition: 0.2s; }

#header .rwd_button .burg:before { top: calc(50% - 2px); left: 10px; }
#header .rwd_button .burg:after { top: calc(50% + 2px); right: 10px; }

body.rwd_menu__opened #header .rwd_button .burg:before { top: 50%; -webkit-transform: rotate(45deg); }
body.rwd_menu__opened #header .rwd_button .burg:after { top: 50%; -webkit-transform: rotate(-45deg); }

/* Fixed menu */
body.fixed_menu #header { height: 100px; left: calc((100% - var(--max-width)) /2); right: calc((100% - var(--max-width)) /2); top: 0; border-top: none; border-bottom-color: var(--color-dark-sand); position: fixed; z-index: 100; }
body.fixed_menu #header .logo h1 { display: none; }
body.fixed_menu #header .logo img { width: auto !important; height: 60px !important; }

/* Special pages */
body.page-template-contact #header { border-bottom-color: var(--color-dark-sand); }
body.page-template-reviews #header { border-bottom-color: var(--color-dark-sand); }


/*
--------------
	SLIDER
--------------
*/
#slider { padding: 0 100px; background-color: var(--color-sand); position: relative; z-index: 0; }
#slider .slide_text_wrap { width: 100%; margin: 100px 0; display: inline-block; position: relative; }
#slider .slide_text_wrap .slide_text { max-width: 60%; font-size: clamp(50px, 6vw, 70px); color: var(--color-dark); line-height: 100%; }
#slider .slide_text_wrap .button { right: 0; bottom: 0; position: absolute; }

#slider .slide_image { position: relative; }
#slider .slide_image:before, 
#slider .slide_image:after { width: 100px; height: 100px; left: -100px; bottom: 0; background: white; position: absolute; content: ''; }
#slider .slide_image:after { left: auto; right: -100px; }
#slider .slide_image img { width: 100%; height: auto; display: block; }

#slider .floral-a { width: 240px; height: 460px; right: 0; top: 0; background: url(images/floral-a.svg) no-repeat right top; background-size: 100% auto; position: absolute; content: ''; z-index: -1; }


/*
----------------
	ABOUT US
----------------
*/
#aboutus { padding: 50px 100px 0; }
#aboutus .aboutus_text { width: calc(100% - 500px); }
#aboutus .aboutus_text a { text-decoration: underline; color: var(--color-dark); }
#aboutus .aboutus_text a:hover { color: var(--color-orange); }

/* Contact box */
#aboutus .contact_box { width: 320px; right: 0; bottom: 0; padding: 30px 40px; background: var(--color-sand); border-bottom: 10px solid var(--color-dark); position: absolute; }
#aboutus .contact_box p { margin-bottom: 10px; }
#aboutus .contact_box h4 { margin-bottom: 10px; font-size: 14px; font-weight: 700; color: var(--color-orange); line-height: 100%; }
#aboutus .contact_box .button { width: 100%; }


/*
-----------
	USP
-----------
*/
#usp { padding: 100px 0; position: relative; z-index: 0; }
#usp .usp_wrap { display: flex; }
#usp .usp_wrap .usp { width: 33.3333333333%; margin-top: 50px; padding: 0 20px; display: flex; justify-content: center; align-items: start; align-content: start; }
#usp .usp_wrap .usp:nth-child(-n+3) { margin-top: 0; }
#usp .usp_wrap .usp .icon { height: 50px; margin-bottom: 10px; }
#usp .usp_wrap .usp .icon img { width: auto; height: 100%; display: block; }
#usp .usp_wrap .usp .title { width: 100%; min-height: 70px; font-size: 34px !important; line-height: 90%; }

#usp .floral-b { width: 240px; height: 460px; left: 0; bottom: -30%; background: url(images/floral-b.svg) no-repeat right top; background-size: 100% auto; position: absolute; content: ''; z-index: -1; }


/*
---------------
	REVIEWS
---------------
*/
#reviews { height: calc(100vh - 100px); color: white; background-color: var(--color-dark); background-repeat: no-repeat; background-position: center; background-size: cover; position: relative; }
#reviews .slick-list { height: 100%; background: rgba(32 29 25 / 40%); }
#reviews .slick-track { height: 100%; position: relative; }
#reviews .reviews_single { height: 100%; display: flex; align-items: center; align-content: center; }
#reviews .reviews_single .reviews_single_inner { max-width: 800px; margin: auto; }
#reviews .reviews_single .reviews_single_inner .reviews_text { font-size: 40px; text-shadow: 2px 2px rgba(0 0 0 / 20%); line-height: 120%; }
#reviews .reviews_single .reviews_single_inner .reviews_author { margin-top: 20px; }

#reviews ul.slick-dots { width: 100%; left: 0; bottom: 50px; display: flex; justify-content: center; position: absolute; list-style: none; }
#reviews ul.slick-dots li { margin: 0 10px; }
#reviews ul.slick-dots li button { width: 20px; height: 20px; font-size: 0; background: rgba(255 255 255 / 50%); cursor: pointer; border-radius: 50%; }
#reviews ul.slick-dots li button:hover { background: rgba(255 255 255 / 70%); }
#reviews ul.slick-dots li.slick-active button { background: var(--color-orange); }

#review_grid_wrap { -moz-column-count: 3; -webkit-column-count: 3; column-count: 3; -moz-column-gap: 50px; -webkit-column-gap: 50px; column-gap: 50px; } 
#review_grid_wrap .grid_item { width: 100%; margin-bottom: 50px; padding: 30px; vertical-align: top; background: white; border-bottom: 5px solid var(--color-dark); display: inline-block; position: relative; }
#review_grid_wrap .grid_item .grid_item_entry { font-size: 24px; }
#review_grid_wrap .grid_item .grid_item_author { margin-top: 20px; font-size: 14px; font-weight: 700; }


/*
-----------
	FAQ
-----------
*/
#faq { padding: 100px 0; background: var(--color-sand); }
#faq h2 { margin-bottom: 30px; font-size: 60px; color: var(--color-dark); line-height: 100%; }

.faq_wrap { border-top: 1px solid var(--color-dark); }
.faq_wrap .faq_main { border-bottom: 1px solid var(--color-dark); }
.faq_wrap .faq_main .faq_header { padding: 25px 0; font-size: 40px; line-height: 100%; position: relative; cursor: pointer; }
.faq_wrap .faq_main .faq_header:after { width: 50px; height: 50px; top: 20px; right: 0; background: var(--color-dark-sand) url(images/icon_arrow_down_dark.svg) no-repeat center; background-size: auto 20px; position: absolute; content: ''; border-radius: 50%; }
.faq_wrap .faq_main.active .faq_header:after { transform: rotate(180deg); }
.faq_wrap .faq_main .faq_content { display: none; }
.faq_wrap .faq_main .faq_content p { margin-bottom: 20px; }


/*
----------------------
	BEFORE CONTENT
----------------------
*/
.rank-math-breadcrumb { width: max-content; margin-bottom: 20px; padding: 0 20px; font-size: 14px; color: var(--color-dark); background: white; border: 1px solid var(--color-dark-sand); border-radius: 18px; }
.rank-math-breadcrumb p { margin-bottom: 0 !important; display: flex; }
.rank-math-breadcrumb a { padding-top: 4px; text-decoration: underline; color: var(--color-orange); }
.rank-math-breadcrumb a:hover { color: var(--color-dark); }
.rank-math-breadcrumb span { padding-top: 4px; }
.rank-math-breadcrumb .separator { height: 100%; margin: 0 10px; font-size: 0; border-right: 1px solid var(--color-sand); display: block; }

body.page-template-flexible-content .rank-math-breadcrumb { margin-left: auto; margin-right: auto; }


/*
---------------
	CONTENT
---------------
*/
body.fixed_menu #container { padding-top: 100px; }
body.page-template-contact #container { background: var(--color-sand); }
body.page-template-reviews #container { background: var(--color-sand); }

#content { padding: 50px 0; }
#content p { margin-bottom: 30px; }
#content a { text-decoration: underline; color: var(--color-orange); }
#content a:hover { color: var(--color-dark); }

#content h1 { margin-bottom: 30px; font-size: 70px; line-height: 90%; }
#content h3 { margin-bottom: 20px; font-size: 40px; color: var(--color-orange); line-height: 100%; }

#content ul { margin-bottom: 30px; margin-left: 30px; }
#content ul.gallery { margin-left: -10px !important; margin-right: -10px; list-style: none; display: flex; }
#content ul.gallery li { width: calc(25% - 20px); margin: 20px 10px 0; }
#content ul.gallery li:nth-child(-n+4) { margin-top: 0; }
#content ul.gallery li a { display: block; outline: 3px solid var(--color-sand); border-radius: 3px; outline-offset: 2px; }
#content ul.gallery li a:hover { outline-color: var(--color-dark-sand); }
#content ul.gallery li a img { width: 100%; height: auto; display: block; }

#content .gallery_wrap { margin-bottom: 50px; padding-bottom: 30px; border-bottom: 1px solid var(--color-dark-sand); }
#content .gallery_wrap:last-child { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }

/* Contact */
#content .contact_wrap { display: flex; }
#content .contact_wrap .wrap_left { width: 45%; padding-right: 100px; }
#content .contact_wrap .wrap_left p { margin-bottom: 20px !important; }
#content .contact_wrap .wrap_left p:last-child { margin-bottom: 0 !important; }
#content .contact_wrap .wrap_left > div { margin-bottom: 20px; padding-left: 60px; padding-bottom: 20px; border-bottom: 1px solid var(--color-dark-sand); position: relative; }
#content .contact_wrap .wrap_left > div:before { width: 40px; height: 40px; left: 0; top: -7px; background-color: var(--color-orange); background-repeat: no-repeat; background-position: center; background-size: auto 20px; position: absolute; content: ''; border-radius: 50%; }
#content .contact_wrap .wrap_left > div.address:before { background-image: url(images/icon_marker_white.svg); }
#content .contact_wrap .wrap_left > div.phone:before { background-image: url(images/icon_phone_white.svg); }
#content .contact_wrap .wrap_left > div.email:before { background-image: url(images/icon_mail_white.svg); }

#content .contact_wrap .wrap_right { width: 55%; padding: 70px; background: white; border-bottom: 10px solid var(--color-dark); }
#content .contact_wrap .wrap_right h3 { margin-bottom: 10px !important; }

/* Flexible content */
.flexible_content h3 { width: 100%; }

.flexible_content .paragraph { margin: 70px 0; font-weight: 400; }
.flexible_content .paragraph .title { margin: 20px 0; font-size: 50px; font-weight: 700; line-height: 100%; }

.flexible_content .fullwidth_image { height: 600px; color: white; background-color: #292d35; background-repeat: no-repeat; background-position: center; background-size: cover; position: relative; }
.flexible_content .fullwidth_image .cover { height: 100%; background: linear-gradient(to right, rgba(32 29 25 / 0%) 0%, rgba(32 29 25 / 80%) 50%, rgba(32 29 25 / 80%) 100%); }
.flexible_content .fullwidth_image .cover .inner { height: 100%; display: flex; justify-content: end; }
.flexible_content .fullwidth_image .cover .text { width: 50%; height: 100%; display: flex; flex-wrap: wrap; align-items: center; align-content: center; }
.flexible_content .fullwidth_image .cover .text p { width: 100%; }
.flexible_content .fullwidth_image .cover .text p:last-child { margin-bottom: 0 !important; }
.flexible_content .fullwidth_image .cover .text a { text-decoration: underline !important; color: #ffffff !important; }
.flexible_content .fullwidth_image .cover .text a:hover { text-decoration: none !important; }
.flexible_content .fullwidth_image .cover .text .title { margin: 20px 0; font-size: 40px; line-height: 100%; }

.flexible_content .usp { margin: 70px 0; }
.flexible_content .usp .usp_wrap { display: flex; }
.flexible_content .usp .usp_wrap .item { width: 33.3333333333%; margin-top: 50px; padding: 0 20px; display: flex; justify-content: center; align-items: start; align-content: start; }
.flexible_content .usp .usp_wrap .item:nth-child(-n+3) { margin-top: 0; }
.flexible_content .usp .usp_wrap .item .icon { height: 50px; margin-bottom: 10px; }
.flexible_content .usp .usp_wrap .item .icon img { width: auto; height: 100%; display: block; }
.flexible_content .usp .usp_wrap .item .title { width: 100%; min-height: 70px; font-size: 34px !important; line-height: 90%; }

.flexible_content .image_text { margin: 70px 0; }
.flexible_content .image_text p:last-child { margin-bottom: 0 !important; }
.flexible_content .image_text .image_text_wrap { display: flex; flex-wrap: wrap; }
.flexible_content .image_text .image_text_wrap .wrap_left { width: 50%; position: relative; }
.flexible_content .image_text .image_text_wrap .wrap_left img { width: 100%; height: 100%; display: block; }
.flexible_content .image_text .image_text_wrap .wrap_left .image { height: 100%; background-repeat: no-repeat; background-position: center; background-size: cover; }
.flexible_content .image_text .image_text_wrap .wrap_left .image:before { padding-top: 80%; display: block; content: ''; }
.flexible_content .image_text .image_text_wrap .wrap_right { width: 50%; padding: 70px 0 70px 50px; display: flex; align-items: center; align-content: center; }

.flexible_content .image_text.has_background { padding: 70px 0; }
.flexible_content .image_text.inverse .image_text_wrap .wrap_left { order: 2; }
.flexible_content .image_text.inverse .image_text_wrap .wrap_right { order: 1; padding: 70px 50px 70px 0; }

.flexible_content .fixed_images { position: relative; }
.flexible_content .fixed_images_wrap { min-height: 100vh; display: flex; position: relative; z-index: 2; }
.flexible_content .fixed_images_wrap .wrap_left.images { width: 50%; height: calc(100vh - 100px); top: 100px; display: flex; align-items: center; align-content: center; position: sticky; }
.flexible_content .fixed_images_wrap .wrap_left.images img { max-width: 100%; height: auto; top: 50%; position: absolute; /*mix-blend-mode: multiply;*/ transform: translateY(-50%); opacity: 0; z-index: 1; }
.flexible_content .fixed_images_wrap .wrap_left.images img.active { opacity: 100%; z-index: 2; }
.flexible_content .fixed_images_wrap .wrap_left.images img:first-child { opacity: 100%; }

.flexible_content .fixed_images_wrap .wrap_right.content { width: 50%; }
.flexible_content .fixed_images_wrap .wrap_right.content .fixed_image_content { min-height: 100vh; padding-left: 50px; display: flex; align-items: center; align-content: center; }


/*
--------------
	FOOTER
--------------
*/
#footer { padding: 100px 0; color: white; background: var(--color-dark); border-bottom: 10px solid var(--color-orange); }
#footer h4 { margin-bottom: 10px; font-size: 14px; font-weight: 700; text-transform: uppercase; color: var(--color-orange); line-height: 100%; }
#footer a { color: white; }
#footer p { margin-bottom: 20px; }
#footer ul { border-top: 1px solid rgba(255 255 255 / 20%); list-style: none; }
#footer ul li { padding: 12px 20px 10px; border-bottom: 1px solid rgba(255 255 255 / 20%); }
#footer ul li a { padding-left: 25px; position: relative; }
#footer ul li a:hover { text-decoration: underline; }
#footer ul li a:before { width: 10px; height: 10px; left: 0; top: 8px; background: var(--color-orange); position: absolute; content: ''; border-radius: 50%; }

#footer .footer_wrap { display: flex; justify-content: space-between; }
#footer .footer_wrap .wrap_left { width: calc(33.3333333333% - 40px); }
#footer .footer_wrap .wrap_left.contact { display: flex; align-content: space-between; }
#footer .footer_wrap .wrap_left.contact .email a { font-size: 30px; text-decoration: underline; text-decoration-thickness: 1px; }
#footer .footer_wrap .wrap_left.contact .phone a { font-size: 30px; }
#footer .footer_wrap .wrap_left.pages { padding-top: 100px; }


/*
------------
	FORM
------------
*/
.form_row { width: 100%; margin-bottom: 10px; position: relative; }
.form_row.form_row_first { width: calc(50% - 10px); }
.form_row.form_row_last { width: calc(50% - 10px); }
.form_row.form_row_wide { width: 100%; }

.form_row p { margin-bottom: 0 !important; }
.form_row br { display: none !important; }
.form_row label { font-size: 14px; font-weight: 400; text-transform: uppercase; color: var(--color-dark); display: block; }

.form_row .wpcf7-list-item { margin: 0; position: relative; }
.form_row .wpcf7-list-item label { top: auto; padding-left: 35px; line-height: 20px; display: block; position: relative; }
.form_row .wpcf7-list-item input[type=checkbox] { left: 0; top: 1px; position: absolute; }

.form_row select, 
.form_row textarea, 
.form_row input[type=tel], 
.form_row input[type=text], 
.form_row input[type=email] { width: 100%; height: 50px; padding-left: 10px; font-size: 17px; background: white; border: 1px solid rgba(0 0 0 / 10%); outline: 3px solid transparent; }

.form_row select:focus, 
.form_row textarea:focus, 
.form_row input[type=tel]:focus, 
.form_row input[type=text]:focus, 
.form_row input[type=email]:focus { border-color: rgba(0 0 0 / 20%); outline-color: rgba(0 0 0 / 5%); }

.form_row textarea { min-height: 150px; padding: 10px; resize: vertical; }

.wpcf7 .wpcf7-form { display: flex; flex-wrap: wrap; justify-content: space-between; }
.wpcf7 .wpcf7-acceptance label { font-weight: 400; text-transform: none; }


/*
-------------------
	RWD DESIGN
-------------------
*/
@media only screen and (max-width: 1920px) { 

	/* HEADER: Fixed menu */
	body.fixed_menu #header { left: 0; right: 0; }
}

@media only screen and (max-width: 1600px) { 

	/* HEADER */
	#header { padding: 0 50px; }
	
	/* SLIDER */
	#slider { padding: 0 50px; }
}

@media only screen and (max-width: 1440px) { 

	/* HEADER */
	#header { padding: 0 20px; }
	
	/* SLIDER */
	#slider { padding: 0 20px; }
}

@media only screen and (max-width: 1280px) { 

	/* DISPLAY: None */
	.hide_in_1280 { display: none !important; }
	
	/* DEFAULT */
	.p_l_20 { padding-left: 20px; }
	.p_r_20 { padding-right: 20px; }

	/* HEADER */
	#header { height: 140px; }
	
	/* HEADER: Menu */
	#header .menu ul li { margin: 0 10px; }
	#header .menu ul li a { padding: 0 5px; font-size: 18px; }
	
	/* SLIDER */
	#slider .slide_text_wrap { margin: 50px 0; }
	
	/* ABOUT US */
	#aboutus { padding: 50px 20px 0; }
	#aboutus .aboutus_text { width: 100%; }
	
	/* USP */
	#usp .usp_wrap .usp .title { width: 100%; min-height: 70px; font-size: 30px !important; }
	
	/* REVIEWS */
	#reviews .reviews_single { padding: 0 20px; }
	#reviews .reviews_single .reviews_single_inner .reviews_text { font-size: 36px; }
	
	#review_grid_wrap { -moz-column-gap: 40px; -webkit-column-gap: 40px; column-gap: 40px; } 
	#review_grid_wrap .grid_item { margin-bottom: 40px; }
	
	/* CONTENT */
	#content h1 { font-size: 60px; }
	#content h3 { font-size: 30px; }
	
	/* CONTENT: Contact */
	#content .contact_wrap .wrap_left { width: 100%; margin-bottom: 30px; padding-right: 0; }
	#content .contact_wrap .wrap_right { width: 100%; padding: 50px; }
	
	/* FOOTER */
	#footer .footer_wrap .wrap_left { width: calc(50% - 40px); }
	#footer .footer_wrap .wrap_left.contact { width: 100%; margin-bottom: 50px; }
	#footer .footer_wrap .wrap_left.pages { padding-top: 0; }
}

@media only screen and (max-width: 960px) { 

	/* DISPLAY: None */
	.hide_in_960 { display: none !important; }
	
	/* DISPLAY: Block */
	.show_in_960 { display: block !important; }
	.show_in_960_flex { display: inline-flex !important; }
	
	/* DEFAULT: Button */
	.button { height: 60px; padding: 4px 20px 0; font-size: 18px !important; }
	
	.button.button_has_arrow { padding-left: 60px; }
	.button.button_has_arrow:hover { padding-left: 20px; padding-right: 60px; }
	.button.button_has_arrow:before, 
	.button.button_has_arrow:after { width: 40px; height: 40px; }
	
	/* HEADER */
	#header { height: 120px; }
	
	/* HEADER: Logo */
	#header .logo { left: 0; transform: translate(0, -50%); }
	#header .logo img { width: auto !important; height: 60px !important; }
	
	/* HEADER: Fixed menu */
	body.fixed_menu #header { height: 120px; }
	body.fixed_menu #header .logo h1 { display: block; }
	
	/* SLIDER */
	#slider .slide_text_wrap .slide_text { max-width: none; }
	#slider .slide_text_wrap .button { right: auto; bottom: auto; margin-top: 30px; position: relative; }
	
	/* ABOUT US */
	#aboutus { padding-top: 30px; }
	
	/* USP */
	#usp { padding: 50px 0; }
	#usp .usp_wrap .usp { width: 50%; }
	#usp .usp_wrap .usp:nth-child(3) { margin-top: 50px; }
	
	/* REVIEWS */
	#reviews { height: 80vh; }
	#reviews .reviews_single .reviews_single_inner .reviews_text { font-size: 30px; }
	
	#review_grid_wrap { -moz-column-count: 2; -webkit-column-count: 2; column-count: 2; -moz-column-gap: 20px; -webkit-column-gap: 20px; column-gap: 20px; } 
	#review_grid_wrap .grid_item { margin-bottom: 20px; }
	
	/* FAQ */
	#faq { padding: 50px 0; }
	#faq h2 { font-size: 50px; }

	.faq_wrap .faq_main .faq_header { font-size: 36px; }
	
	/* CONTENT */
	#content { padding: 30px 0; }
	#content h1 { font-size: 50px; }
	
	#content ul.gallery li { width: calc(33.3333333333% - 20px); }
	#content ul.gallery li:nth-child(4) { margin-top: 20px; }
	
	/* CONTENT: Flexible content */
	.flexible_content .paragraph { margin: 50px 0; }
	.flexible_content .paragraph .title { font-size: 45px; }

	.flexible_content .fullwidth_image { height: auto; }
	.flexible_content .fullwidth_image .cover { background: rgba(32 29 25 / 80%); }
	.flexible_content .fullwidth_image .cover .text { width: 100%; min-height: 300px; padding: 50px 0; }

	.flexible_content .usp { margin: 50px 0; }

	.flexible_content .image_text { margin: 50px 0; }
	.flexible_content .image_text .image_text_wrap .wrap_right { width: 50%; padding: 50px 0 50px 50px; }
	.flexible_content .image_text.has_background { padding: 50px 0; }
	.flexible_content .image_text.inverse .image_text_wrap .wrap_right { padding: 50px 50px 50px 0; }
	
	.flexible_content .fixed_images_wrap { min-height: auto; padding: 50px 20px; }
	.flexible_content .fixed_images_wrap .wrap_right.content { width: 100%; max-width: 600px; margin: auto; }
	.flexible_content .fixed_images_wrap .wrap_right.content .fixed_image_content { min-height: auto; margin-bottom: 50px; padding-left: 0; padding-bottom: 50px; border-bottom: 1px solid var(--color-dark-sand); }
	.flexible_content .fixed_images_wrap .wrap_right.content .fixed_image_content:last-child { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }
	.flexible_content .fixed_images_wrap .wrap_right.content .fixed_image_content img { width: 100%; height: auto; margin-bottom: 30px; display: block; }
	
	/* FOOTER */
	#footer { padding: 50px 0; }
}

@media only screen and (max-width: 768px) { 

	/* DISPLAY: None */
	.hide_in_960 { display: none !important; }
	
	/* HEADER */
	#header { width: 100%; height: 100px; left: 0; top: 0; border-top: none; position: fixed; z-index: 100; }
	
	/* HEADER: Logo */
	#header .logo { left: 0; transform: translate(0, -50%); }
	#header .logo h1 { margin-top: 5px; padding: 0; font-size: 20px; }
	#header .logo h1:before, 
	#header .logo h1:after { display: none; }
	#header .logo img { height: 50px !important; }
	
	/* HEADER: Fixed menu */
	body.fixed_menu #header { height: 100px; }
	body.fixed_menu #header .logo img { height: 50px !important; }
	
	/* FAQ */
	.faq_wrap .faq_main .faq_header { font-size: 30px; }
	.faq_wrap .faq_main .faq_header:after { top: 16px; }
	
	/* CONTENT */
	#container { padding-top: 100px; }
	
	/* CONTENT: Flexible content */
	.flexible_content .paragraph .title { font-size: 40px; }

	.flexible_content .usp .usp_wrap .item { width: 33.3333333333%; padding: 20px; font-size: 15px; flex-grow: inherit; flex-basis: auto; }
	.flexible_content .usp .usp_wrap .item img { height: 60px !important; }

	.flexible_content .image_text .image_text_wrap .wrap_left { width: 100%; }
	.flexible_content .image_text .image_text_wrap .wrap_left .image { height: auto; }
	.flexible_content .image_text .image_text_wrap .wrap_left .image:before { padding-top: 50%; display: block; content: ''; }
	.flexible_content .image_text .image_text_wrap .wrap_right { width: 100%; padding: 20px 0; }

	.flexible_content .image_text.has_background { padding: 20px 0; }
	.flexible_content .image_text.inverse .image_text_wrap .wrap_left { order: 1; }
	.flexible_content .image_text.inverse .image_text_wrap .wrap_right { order: 2; padding: 20px 0; }
}

@media only screen and (max-width: 640px) { 

	/* DISPLAY: None */
	.hide_in_640 { display: none !important; }

	/* USP */
	#usp .usp_wrap .usp { width: 100%; text-align: left; justify-content: start; }
	#usp .usp_wrap .usp:nth-child(2) { margin-top: 50px; }
	#usp .usp_wrap .usp .title { min-height: auto; margin-bottom: 20px; }
	
	/* REVIEWS */
	#review_grid_wrap { -moz-column-count: 1; -webkit-column-count: 1; column-count: 1; -moz-column-gap: 0; -webkit-column-gap: 0; column-gap: 0; } 
	
	/* FAQ */
	.faq_wrap .faq_main .faq_header { padding-right: 100px; }
	
	#content ul.gallery li { width: calc(50% - 20px); }
	#content ul.gallery li:nth-child(3) { margin-top: 20px; }
	
	/* FOOTER */
	#footer .footer_wrap .wrap_left { width: 100%; }
	#footer .footer_wrap .wrap_left.pages:last-child ul { border-top: none; }

	/* FORM */
	.form_row.form_row_first, 
	.form_row.form_row_last { width: 100%; }
}

@media only screen and (max-width: 480px) { 

	/* NAVIGATION */
	#rwd_menu .rwd_menu_wrap { width: calc(100% - 20px); }

	/* NAVIGATION: RWD menu header */
	#rwd_menu .rwd_header img { left: 20px; }
	#rwd_menu .rwd_header .rwd_button { right: 20px; }
	
	/* NAVIGATION: Contacts */
	#rwd_menu .rwd_menu_section.contacts { padding: 0 20px; }
	
	/* NAVIGATION: Menu */
	#rwd_menu .rwd_menu_section.menu { padding: 30px 20px; }
	
	/* NAVIGATION: Secondary menu */
	#rwd_menu .rwd_menu_section.useful_info { padding: 30px 20px; }

	/* CONTENT: Contact */
	#content .contact_wrap .wrap_right { padding: 30px 20px; }
	
	/* FORM */
	.form_row .button { width: 100%; }
}
