/*
Theme Name: Delicato Coffeee
Theme URI: https://www.delicato.io/
Author: Patrick
Author URI: https://wppatrickk.com/
Description: Custom Theme for Delicato Coffeee
Version: 1.0.0
Text Domain: delicato
*/

/*--------------------------------------------------------------
# Normalize
--------------------------------------------------------------*/


* {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
font,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-weight: inherit;
	font-style: inherit;
	font-size: 100%;
	font-family: inherit;
	vertical-align: baseline;
}

:focus {
	outline: 0;
}

body {
	line-height: 1;
	color: black;
	background: white;
}

ol, ul {
	list-style: none;
}

table {
	border-collapse: separate;
	border-spacing: 0;
}

caption,
th,
td {
	text-align: left;
	font-weight: normal;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
	content: "";
}

blockquote,
q {
	quotes: "" "";
}

/*--------------------------------------------------------------
# WP Core Styles
--------------------------------------------------------------*/


/* Sofia Sans */
@font-face {
    font-family: 'Sofia Sans';
    src: url('./fonts/Yq6R-LCVXSLy9uPBwlATrOF6kjouQb4.woff2') format('woff2');
    font-weight: 100 900;
    font-style: normal;
    font-display: swap;
}

/* Sofia Sans Extra Condensed */
@font-face {
    font-family: 'Sofia Sans Extra Condensed';
    src: url('./fonts/raxoHjafvdAIOju4GcIfJH0i7zi50X3zRtuLNiMS0fSuJk52kCel.woff2') format('woff2');
    font-weight: 100 900;
    font-style: normal;
    font-display: swap;
}

/* Work Sans */
@font-face {
    font-family: 'Work Sans';
    src: url('./fonts/QGYsz_wNahGAdqQ43Rh_fKDptfpA4Q.woff2') format('woff2');
    font-weight: 100 900;
    font-style: normal;
    font-display: swap;
}

.alignnone {
    margin: 5px 20px 20px 0;
}

.aligncenter,
div.aligncenter {
    display: block;
    margin: 25px auto;
}

.alignright {
    float:right;
    margin: 5px 0 20px 20px;
}

.alignleft {
    float: left;
    margin: 5px 20px 20px 0;
}

a img.alignright {
    float: right;
    margin: 5px 0 20px 20px;
}

a img.alignnone {
    margin: 5px 20px 20px 0;
}

a img.alignleft {
    float: left;
    margin: 5px 20px 20px 0;
}

a img.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

/* Text meant only for screen readers. */
.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	position: absolute !important;
	white-space: nowrap;
	height: 1px;
	width: 1px;
	overflow: hidden;
}

.screen-reader-text:focus {
	background-color: #f1f1f1;
	border-radius: 3px;
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto !important;
	color: #21759b;
	display: block;
	font-size: 14px;
	font-size: 0.875rem;
	font-weight: bold;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000; /* Above WP toolbar. */
}

/*--------------------------------------------------------------
# Predefined Styles
--------------------------------------------------------------*/

:root {
	--dark: #14110b;
  	--coffee: #5f4127;
  	--yellow: #cd9e4f;
    --red: #dc1f25;
    --cream: #fdefd1;
    --coffee-black: #070604;
  	--main-transition-value: cubic-bezier(0.4, 0, 0, 1);
}

body {
	background: var(--dark);
	font-family: "Sofia Sans", sans-serif;
	font-weight: 400;
	font-size: 18px;
	color: var(--cream);
}

a {
	color: var(--yellow);
	text-decoration: none;
	-webkit-transition: all 0.2s linear 0s;
	transition: all 0.2s linear 0s;
}

a:hover {
	text-decoration: none;
}

strong {
	font-weight: 700;
}

em {
	font-style: italic;
}

hr {
	border: none 0;
	border-bottom: 1px solid #E0E0E0;
	height: 1px;
	margin: 10px 0;
}

.inner {
	width: 100%;
	max-width: 1920px;
    padding: 0 64px;
	margin: 0 auto;
}

.clear {
	clear: both;
}

h1, h2, h3, h4, h5, h6, .h5 {
    font-family: "Sofia Sans Extra Condensed", sans-serif;
	font-weight: 900;
	line-height: 1;
	margin-bottom: 10px;
    color: var(--cream);
    text-transform: uppercase;
}

h1,
h2.h1 {
	font-size: 120px;
}

h2,
h1.h2 {
	font-size: 96px;
}

h3 {
	font-size: 64px;
}

h4 {
	font-size: 48px;
    line-height: 1.3;
}

h5,
.h5 {
    font-size: 32px;
    padding-top: 24px;
    line-height: 1.1;
}

h6 {
    font-size: 28px;
}

p {
	line-height: 1.5;
	margin-bottom: 20px;
}

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

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

input[type="text"], input[type="email"], input[type="tel"], input[type="number"], textarea, select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background: none;
	width: 100%;
    padding: 24px 28px;
    border: 1px solid #FDEFD1;
    color: #FDEFD1;
    font-family: "Sofia Sans", sans-serif;
    font-weight: 400;
    font-size: 18px;
}

input[type=number]::-webkit-outer-spin-button,
input[type=number]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

input[type=number] {
    -moz-appearance: textfield;
    appearance: textfield;
}

.select-wrapper {
    position: relative;
}

.select-wrapper::after {
    content: '';
    position: absolute;
    right: 28px;
    top: 50%;
    transform: translateY(-50%);
    width: 20px;
    height: 12px;
    background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="20" height="12" viewBox="0 0 20 12" fill="none"><path d="M2 2L10 10L18 2" stroke="%23FDEFD1" stroke-width="2.4" stroke-linecap="round" stroke-linejoin="round"/></svg>') no-repeat center;
    pointer-events: none;
}

.button,
input[type="submit"] {
    display: inline-block;
    background-color: var(--red);
	padding: 20px 28px;
    color: var(--cream);
    font-family: 'Work Sans';
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 0.32px;
    text-transform: uppercase;
    position: relative;
    overflow: hidden;
}

.default-state,
.hover-state {
    transition: all 0.3s ease-in-out 0s;
    width: 100%;
}

.hover-state {
	color: var(--coffee-black);
	position: absolute;
	top: 50%;
	width: 100%;
	left: 0;
	display: block;
	text-align: center;
	transform: translateY(70%);
    opacity: 0;
}

.button:hover > .default-state {
    transform: translateY(-70%);
    opacity: 0;
    position: absolute;
    left: 0;
    text-align: center;
}

.button:hover > .hover-state {
	transform: translateY(0);
    opacity: 1;
    position: relative;
}

.button::before {
	width: 120%;
	height: 100%;
	position: absolute;
	left: -10%;
	bottom: -140%;
	background-color: var(--yellow);
	content: "";
	transform: rotate(7deg);
    opacity: 0;
    transition: all 0.3s ease-in-out 0s;
}

.button:hover::before {
    transform: rotate(0);
    opacity: 1;
    bottom: 0;
}

.button.secondary {
    background-color: var(--cream);
    color: var(--dark);
}

input[type="submit"]:hover {
	background: #222;
}

.cwrap {
    display: flex;
    justify-content: space-between;
}

.cols {
    flex-wrap: wrap;
    margin: 0 -25px;
    justify-content: start;
}

.valign {
    align-items: center;
}

.col {
    flex: 1 1 50%;
    max-width: 50%;
    padding: 0 25px;
}

.col3 {
    flex: 1 1 33.33%;
    max-width: 33.33%;
    padding: 0 25px;
}

.col23 {
    flex: 1 1 66.67%;
    max-width: 66.67%;
    padding: 0 25px;
}

/*--------------------------------------------------------------
# Loader Styles
--------------------------------------------------------------*/


/*--------------------------------------------------------------
# Header Styles
--------------------------------------------------------------*/

.site-header {
    background: linear-gradient(180deg, #14110B 40%, rgba(20, 17, 11, 0.00) 100%);
    backdrop-filter: blur(0);
    padding: 8px 0;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 40;
}

.site-header:after,
.site-bottom:after {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    content: "";
    background: url('images/pattern_background.svg') no-repeat center / cover;
}

.site-bottom:after {
    transform: rotate(-180deg);
    top: 22px;
}

.site-bottom .inner {
	position: relative;
	z-index: 1;
}

.header {
    justify-content: center;
    position: relative;
    z-index: 10;
}

.site-branding {
    margin-right: auto;
}

.site-branding img {
	max-width: 132px;
}

.site-menu ul.primary-menu {
	display: flex;
    gap: 40px;
}

.site-menu ul li {
    padding: 60px 0;
}

.site-menu ul li a {
	font-family: "Work Sans", sans-serif;
    font-weight: 500;
    text-transform: uppercase;
    color: var(--cream);
}

.site-menu ul li.has-sub-menu > a {
    position: relative;
    padding-right: 18px;
}

.site-menu ul li.has-sub-menu > a svg {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    content: "";
}

.site-menu ul li:hover > a {
    color: var(--yellow);
}

.sub-menu {
    display: none;
    position: absolute;
    top: 135px;
    left: 0;
    width: 100%;
    background-color: var(--dark);
}

.site-menu ul li:hover .sub-menu {
    display: block;
}

.sub-menu-inner {
    position: relative;
    padding: 10px 0 80px;
}

.sub-menu-inner:before {
    width: 500%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    left: -250%;
    background-color: var(--dark);
    content: "";
}

.sub-menu .cols {
    margin: 0 -10px;
}

.sub-menu-products {
    flex: 1 1 60%;
    max-width: 60%;
    padding: 0 10px;
}

.sub-menu-products .col3 {
    padding: 0 10px;
}

.sub-menu-products .pimage {
    padding: 30px 20px;
    max-height: 320px;
}

.sub-menu-products h4 {
    font-size: 28px;
    line-height: 1.1;
}

.sub-menu-products .ptags {
    display: none;
}

.sub-menu-cta {
    flex: 1 1 40%;
    max-width: 40%;
    padding: 0 10px;
}

.sub-menu-bg {
    position: relative;
    height: 100%;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    position: relative;
}

.sub-menu-bg:before {
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: linear-gradient(180deg, rgba(7, 6, 4, 0.00) 0%, rgba(7, 6, 4, 0.40) 20%, rgba(7, 6, 4, 0.80) 100%);
    content: "";
    position: absolute;
}

.sub-menu-content {
    position: absolute;
    bottom: 0;
    padding: 40px 80px;
}

.menu-heading {
    line-height: 1.1;
}

.site-button {
    margin-left: auto;
}

/*--------------------------------------------------------------
# Mobile Menu Styles
--------------------------------------------------------------*/

.mobile-slide {
	position: relative;
    width: 48px;
	height: 48px;
	display: none;
	background-color: var(--red);
	cursor: pointer;
    align-items: center;
    justify-content: center;
}

.mobile-slide span {
	background-color: var(--cream);
	display: block;
    width: 24px;
	height: 2px;
	position: relative;
	transition: background .2s ease-out;
	width: 24px;
	transition: all .3s ease-out;
}

.mobile-slide span::before,
.mobile-slide span::after {
	background-color: var(--cream);
	content: '';
	display: block;
	height: 100%;
	position: absolute;
	transition: all .2s ease-out;
	width: 100%;
}

.mobile-slide span::before {
	top: 8px;
}

.mobile-slide span::after {
	top: -8px;
}

.menu-opened .mobile-slide span {
    background: transparent;
}

.menu-opened .mobile-slide span:before,
.menu-opened .mobile-slide span:after {
	top: 0;
}

.menu-opened .mobile-slide span:before {
	transform: rotate(-45deg);
}

.menu-opened .mobile-slide span:after {
	transform: rotate(45deg);
}

.mobile-menu {
    position: fixed;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: rgba(7, 6, 4, 0.75);
    -webkit-backdrop-filter: blur(20px);
    backdrop-filter: blur(20px);
    z-index: 30;
    padding: 0 20px;
    display: none;
    flex-direction: column;
    align-items: center;
    padding: 160px 20px 80px;
}

.menu-holder ul {
    padding-bottom: 80px;
}

.menu-holder a {
    display: block;
    font-size: 28px;
    text-transform: uppercase;
    font-weight: 500;
    color: var(--cream);
    line-height: 42px;
    margin-bottom: 15px;
    text-align: center;
}

.mobile-menu .site-button {
    margin-left: 0;
    margin-top: auto;
}

/*--------------------------------------------------------------
# Content Styles
--------------------------------------------------------------*/

.site-content {
    overflow: hidden;
}

.single-product .site-content {
    overflow: visible;
}

.section {
    padding: 160px 0;
    position: relative;
}

.section-pattern:before,
.section-pattern:after {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 160px;
    content: "";
    background: url('images/pattern_bg_2.png') repeat-x center / contain var(--dark);
}

.section .inner {
    position: relative;
    z-index: 5;
}

.section-pattern:after {
    bottom: auto;
    top: 5px;
    background: url('images/pattern_bg_3.png') repeat-x center / contain var(--dark);
}

.homepage-header {
    position: relative;
    overflow: hidden;
}

.homepage-header:before,
.homepage-header:after {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 160px;
    content: "";
    background: url('images/pattern_bg_2.png') repeat-x center / contain var(--dark);
}

.homepage-header:before {
    background: var(--dark);
}

.homepage-header:after {
    z-index: 5;
}

.homepage-header .inner {
    padding-right: 0;
}

.homepage-header .col:first-child {
    padding-top: 280px;
    flex: 1 1 55%;
    max-width: 55%;
    position: relative;
    z-index: 10;
}

.header-buttons {
    padding-top: 24px;
}

.header-buttons a:first-child {
    margin-right: 16px;
}

.homepage-header .col:last-child {
    padding-right: 0;
    flex: 1 1 45%;
    max-width: 45%;
}

.header-image {
    position: relative;
}

.header-image-mobile {
    display: none;
}

.header-image .wp-post-image {
	position: absolute;
	left: -30%;
	max-width: 430px;
	bottom: 8%;
	z-index: 10;
	transform: rotate(10deg);
}

.product-teaser {
    overflow: hidden;
}

.section-heading {
    text-align: center;
    margin-bottom: 0;
    padding-bottom: 64px;
}

.product-slider .slick-track {
    display: flex;
}

.product-slider .slick-list {
    margin: 0 -16px;
}

.product-slider .slick-slide {
    padding: 0 16px;
    height: inherit;
}

.pcard {
    position: relative;
    height: 100%;
}

.pcard a,
span.disabled-link {
    display: flex;
    flex-direction: column;
    background-color: var(--coffee-black);
    padding: 20px 0;
    border-radius: 8px;
    overflow: hidden;
    position: relative;
    height: 100%;
}

.pimage {
    padding: 50px 30px 80px;
    height: 560px;
    display: flex;
    justify-content: center;
    align-items: center;
}

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

.pdata {
    padding: 0 40px;
}

.pdata h4 {
    margin-bottom: 0;
}

.ptags {
    display: block;
    padding: 16px 0 20px;
}

.tag {
    background-color: var(--red);
    padding: 4px 12px;
    border-radius: 4px;
    font-family: "Work Sans", sans-serif;
    display: inline-block;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 0.24px;
    color: var(--cream);
    margin-right: 8px;
    margin-bottom: 8px;
    line-height: 150%;
}

.poverlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--coffee-black);
    padding: 40px;
    display: none;
}

.poverlay-inner {
    display: flex;
    flex-direction: column;
    position: relative;
    height: 100%;
}

.poverlay-inner h3 {
    padding-right: 60px;
}

.poverlay-icon {
    width: 48px;
    height: 48px;
    position: absolute;
    top: 0;
    right: 0;
    border-radius: 50%;
    background: url('images/dark-arrow.png') no-repeat center / 18px var(--yellow);
}

.poverlay p {
    color: var(--cream);
    font-size: 20px;
}

.overlay-table {
    margin-top: auto;
    display: flex;
    flex-direction: column;
    gap: 20px;
    font-family: "Sofia Sans Extra Condensed", sans-serif;
    font-size: 28px;
    font-weight: 600;
    color: var(--cream);
}

.table-row {
    display: flex;
    gap: 15px;
}

.slick-slider {
    padding-bottom: 60px;
}

.slick-arrow {
    position: absolute;
    top: 50%;
    left: -48px;
    transform: translateY(-50%);
    width: 96px;
    height: 96px;
    border-radius: 50%;
    border: 1.5px solid var(--coffee);
    background: url('images/slide-arrow.png') no-repeat center / 36px;
    background-color: var(--dark);
    text-indent: -9999px;
    z-index: 10;
    cursor: pointer;
}

.slick-prev {
    transform: translateY(-50%) rotate(180deg);
}

.slick-arrow:hover {
	background-image: url('images/dark-arrow.png');
    background-size: 30px;
    background-color: var(--yellow);
	transform: translateY(-50%) rotate(45deg);
}

.slick-arrow.slick-prev:hover {
    transform: translateY(-50%) rotate(-135deg);
}

.slick-next {
    left: auto;
    right: -48px;
}

.slick-dots {
    position: absolute;
    bottom: 0;
    left: 0;
    display: flex;
    justify-content: center;
    gap: 12px;
    width: 100%;
}

.slick-dots button {
    width: 12px;
    height: 12px;
    padding: 0;
    margin: 0;
    border-radius: 50%;
    background-color: var(--coffee);
    border: 0;
    cursor: pointer;
    text-indent: -9999px;
    -webkit-appearance: none;
    appearance: none;
    display: block;
    line-height: 0;
}

.slick-active button {
    background-color: var(--yellow);
}

.teaser-button {
    padding-top: 64px;
    text-align: center;
}

.service-slider {
    padding: 80px 0;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    position: relative;
}

.service-slider:before {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.30) 0%, rgba(0, 0, 0, 0.50) 100%);
    content: "";
}

.service-slider-bg {
    position: relative;
    z-index: 5;
}

.service-slides {
    display: flex;
    flex-wrap: wrap;
    margin: 0 -25px;
}

.service-slide {
    flex: 1 1 33.33%;
    max-width: 33.33%;
    padding: 280px 25px 160px;
    text-align: center;
}

.service-slide img {
    display: none;
}

.service-slide h2 {
    text-transform: uppercase;
    padding-bottom: 32px;
    margin-bottom: 0;
}

.active-slide h2 {
    color: var(--yellow);
}

.service-slide p {
    font-size: 20px;
    color: var(--cream);
    display: none;
}

.service-slide.active-slide p {
    display: block;
}

.testimonials {
    overflow: hidden;
}

.testimonials:before {
    display: none;
}

.review-header {
    flex: 1 1 35%;
    max-width: 35%;
    padding: 0 25px;
}

.review-header h2 {
    text-transform: uppercase;
}

.review-header p {
    padding: 24px 0 38px;
    max-width: 500px;
}

.reviews .slick-arrow {
    position: static;
    transform: translateY(0);
}

.reviews .slick-prev {
	transform: translateY(0) rotate(180deg);
    margin-right: 24px;
}

.reviews .slick-arrow:hover {
    transform: translateY(0) rotate(45deg);
}

.reviews .slick-arrow.slick-prev:hover {
    transform: translateY(0) rotate(-135deg);
}

.review-content .slick-list {
    margin: 0 -16px;
}

.review-content .slick-track {
    display: flex;
}

.review-content .slick-slide {
    margin: 0 16px;
    height: inherit;
}

.review-content {
    flex: 1 1 65%;
    max-width: 65%;
    padding: 0 25px;
}

.review-card {
    padding: 40px 40px 80px 40px;
    border-radius: 24px;
    background: var(--coffee-black);
    position: relative;
    height: 100%;
    overflow: hidden;
}

.review-card:after {
    position: absolute;
    left: 0;
    bottom: -5px;
    width: 100%;
    height: 80px;
    content: "";
    background: url('images/pattern-bg_4.png') repeat-x center / contain;
}

.testimonial {
    font-size: 28px;
    margin-bottom: 0;
    padding: 64px 0;
    font-weight: 500;
    line-height: 1.4;
}

.name {
    margin-bottom: 0;
    font-weight: 700;
    line-height: 150%;
    letter-spacing: 0.18px;
}

.title {
    font-weight: 400;
    line-height: 150%;
    letter-spacing: 0.18px;
    min-height: 24px;
}

.cta {
    background-color: var(--red);
    text-align: center;
    overflow: hidden;
}

.cta img {
    position: absolute;
    left: 0;
    bottom: -30px;
    max-height: 500px;
}

.cta img.left-image {
    transform: rotate(10deg);
}

.cta img.right-image {
    left: auto;
    right: -40px;    
    bottom: -100px;
}

.cta h2 {
    margin-bottom: 0;
}

.cta p {
    padding: 24px 0 40px;
    max-width: 1100px;
    margin: 0 auto;
}

.sub-header.section {
    padding: 360px 0 40px;
}

.sub-header.section-pattern::before {
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.25) 10%, rgba(0, 0, 0, 0.00) 50%, #14110B 90%);
    height: 100%;
    z-index: 3;
}

.sub-header-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    z-index: 2;
}

.sub-header h1 {
    text-align: center;
    text-transform: uppercase;
    margin-bottom: 0;
}

.product-grid .col3 {
    padding-top: 30px;
    padding-bottom: 30px;
    position: relative;
}

.product-img-holder {
    position: relative;
    height: 100%;
    border-radius: 8px;
    overflow: hidden;
}

.product-img,
.divider-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    box-shadow: 0 0 160px 64px #14110B inset;
}

.divider {
    height: 100vh;
}

.product-img-col {
    flex: 1 1 66.67%;
    max-width: 66.67%;
}

.product-section {
    padding-bottom: 200px;
}

.product-section::after {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 160px;
    content: "";
    background: url('images/pattern_bg_2.png') repeat-x center / contain var(--dark);
}

.product-section .cwrap {
    margin: 0 -60px;
}

.product-section .col {
    padding: 0 60px;
}

.product-sticky {
    position: sticky;
    top: 180px;
}

.product-gallery {
    background-color: var(--coffee-black);
    padding: 100px 60px 140px;
}

.product-image img {
    max-height: 700px;
    margin: 0 auto;
    display: block;
}

.product-gallery .slick-prev {
    left: 32px;
}

.product-gallery .slick-next {
    right: 32px;
}

.product-gallery .slick-dots {
    bottom: 60px;
}

.product-data {
    padding-right: 80px;
}

.product-data h1,
.product-data h4 {
    margin-bottom: 0;
}

.product-data .ptags {
    padding: 20px 0 32px;
}

.product-description {
    padding-bottom: 32px;
}

.product-description ul,
.product-description ol {
    padding: 0 0 20px 20px;
}

.product-description ul li,
.product-description ol li {
    list-style: disc outside none;
    line-height: 1.4;
    margin-bottom: 8px;
}

.product-description ol li {
    list-style-type: decimal;
}

.product-table,
.product-faqs {
    padding-top: 80px;
}

.product-data h4 {
    padding-bottom: 32px;
}

.product-table-rows {
    padding: 40px;
    background-color: var(--coffee-black);
    border-radius: 8px;
}

.product-row {
    font-size: 28px;
    font-family: "Sofia Sans Extra Condensed", sans-serif;
    font-weight: 600;
    display: table;
    table-layout: fixed;
    width: 100%;
}

.product-row .label,
.product-row .value {
    display: table-cell;
    vertical-align: top;
    padding: 10px 16px;
}

.product-row .label {
    padding-left: 0;
}

.product-row .value {
    padding-right: 0;
}

.faq-item {
    background-color: var(--coffee-black);
    border-radius: 8px;
    margin-bottom: 20px;
    overflow: hidden;
    position: relative;
}

.faq-item::after {
	position: absolute;
	bottom: -12px;
	left: 0;
	width: 100%;
	height: 40px;
	content: "";
	background: url('images/faq-pattern.svg') repeat-x center / contain;
}

.faq-item.faq-item-opened::after {
	bottom: 0;
}

.faq-item:last-child {
    margin-bottom: 0;
}

.faq-question {
    position: relative;
    padding: 24px 100px 24px 40px;
    font-size: 28px;
    font-family: "Sofia Sans Extra Condensed", sans-serif;
    font-weight: 600;
    line-height: 110%;
    letter-spacing: 0.56px;
    cursor: pointer;
    z-index: 1;
}

.faq-question:before {
    width: 48px;
    height: 48px;
    position: absolute;
    top: 50%;
    right: 40px;
    background: url('images/faq-icon.png') no-repeat right center / contain;
    content: "";
    transform: translateY(-50%);
    transition: all 0.3s var(--main-transition-value) 0s;
}

.faq-question.faq-opened::before {
    transform: translateY(-50%) rotate(45deg);
}

.faq-answer {
    display: none;
    padding: 0 40px 64px;
}

.faq-answer a {
    text-decoration: underline;
}

.related-products {
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}

.related-products::before {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    content: "";
    background: linear-gradient(180deg, rgba(7, 6, 4, 0.80) 0%, rgba(7, 6, 4, 0.00) 100%);
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
}

.related-grid {
    max-width: 1240px;
    margin: 0 auto;
    position: relative;
}

.static-content .inner {
    max-width: 800px;
}

.related-grid .cols {
    margin: 0 -16px;
}

.related-grid .col {
    padding: 0 16px;
}

.related-icon {
    position: absolute;
    width: 96px;
    height: 96px;
    top: 50%;
    left: 50%;
    display: block;
    border-radius: 50%;
    transform: translate(-50%, -50%);
    z-index: 10;
    background: url('images/related-icon.png') no-repeat center / 80px var(--yellow);
}

.service-wrap {
    padding: 40px 80px;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: stretch;
}

.service-grid h2 {
    margin-bottom: 0;
}

.service-left,
.service-right {
    display: flex;
    flex-direction: column;
}

.service-left {
    padding-right: 120px;
    padding-top: 240px;
}

.service-right {
    padding-left: 120px;
    padding-top: 80px;
}

.timeline-block {
    padding-bottom: 160px;
}

.service-image {
    position: relative;
    margin-bottom: 32px;
}

.service-image:before {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    content: "";
    box-shadow: 0 0 160px 64px #14110B inset;
}

.service-image span {
    position: absolute;
    font-size: 120px;
    color: var(--yellow);
    font-family: "Sofia Sans Extra Condensed", sans-serif;
    font-weight: 900;
    line-height: 100%;
    text-transform: uppercase;
    left: 40px;
    bottom: 30px;
}

.timeline-block h4 {
    line-height: 1.1;
}

.timeline-block p {
    font-size: 24px;
    line-height: 1.4;
}

.service-timeline {
    width: 32px;
    position: relative;
}

.timeline-bar,
.timeline-filled {
    width: 1px;
    margin: 0 auto;
    position: relative;
    height: 100%;
    display: block;
    background-color: var(--coffee);
}

.timeline-filled {
    position: absolute;
    background-color: var(--yellow);
    height: 20%;
    z-index: 1;
    top: 0;
    left: 0;
    right: 0;
}

.timeline-circle {
    position: absolute;
    width: 32px;
    height: 32px;
    background-color: var(--yellow);
    border-radius: 50%;
    top: 20%;
    display: block;
}

.bilder-content-2 .cols {
    margin: 0;
}

.bilder-content-2 .col {
    padding: 0;
    height: 100vh;
}

.bilder-block {
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    position: relative;
    height: 100%;
    padding: 160px 64px;
}

.bilder-block::before {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    content: "";
    background: linear-gradient(316deg, rgba(7, 6, 4, 0.00) 25%, rgba(7, 6, 4, 0.80) 75%);
    filter: blur(30px);
    z-index: 1;
}

.bilder-block::after {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 60%;
	content: "";
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(40px);
	background: rgba(0, 0, 0, 0.25);
	z-index: 2;
	-webkit-mask-image: linear-gradient(to bottom, 
		rgba(0,0,0,1) 0%, 
		rgba(0,0,0,1) 60%, 
		rgba(0,0,0,0) 100%);
	mask-image: linear-gradient(to bottom, 
		rgba(0,0,0,1) 0%, 
		rgba(0,0,0,1) 60%, 
		rgba(0,0,0,0) 100%);
}

.bilder-content-2 .col:last-child .bilder-block::after {
    top: auto;
    bottom: 0;
	height: 70%;
    -webkit-mask-image: linear-gradient(to top, 
        rgba(0,0,0,1) 0%, 
        rgba(0,0,0,1) 60%, 
        rgba(0,0,0,0) 100%);
    mask-image: linear-gradient(to top, 
        rgba(0,0,0,1) 0%, 
        rgba(0,0,0,1) 60%, 
        rgba(0,0,0,0) 100%);
}

.bilder-content-3 .bilder-block::after {
    display: none;
}

.bilder-content {
    position: absolute;
    width: 100%;
    z-index: 3;
    max-width: 576px;
    top: 160px;
}

.bilder-content-2 .col:last-child .bilder-content {
    top: auto;
    bottom: 160px;
}

.bilder-content p {
    font-size: 20px;
    margin-bottom: 0;
}

.faqs h2,
.faqs h4 {
    margin-bottom: 0;
}

.faqs .faq-list {
    padding: 64px 0 120px;
}

.faqs h4 {
    padding-bottom: 32px;
    line-height: 1.4;
}

.bilder-3-heading {
    max-width: 800px;
    padding-bottom: 120px;
}

.bilder-3-heading h2 {
    margin-bottom: 0;
    padding-bottom: 24px;
}

.bilder-3-heading p {
    font-size: 24px;
    line-height: 1.4;
}

.bilder-3-content {
    position: relative;
    height: 100%;
    display: flex;
    flex-direction: column;
}

.bilder-3-content .bilder-block {
    padding: 0;
    height: auto;
    border-radius: 8px;
    overflow: hidden;
}

.bilder-3-content h4 {
    padding-top: 40px;
    text-transform: uppercase;
}

.bilder-3-content p {
    margin-top: auto;
}

.content-404 .inner {
    max-width: 1000px;
}

/*--------------------------------------------------------------
# Footer Styles
--------------------------------------------------------------*/

.site-footer,
.site-bottom {
    padding: 160px 0 40px;
    background-color: var(--coffee-black);
    color: var(--cream);
    overflow: hidden;
}

.footer-content {
    flex: 1 1 70%;
    max-width: 70%;
    padding: 0 25px;
}

.footer-content p {
    font-size: 32px;
}

.footer-menu,
.footer-contact {
    flex: 1 1 15%;
    max-width: 15%;
    padding: 0 25px;
}

.footer-menu a {
    color: var(--cream);
    font-size: 20px;
    font-weight: 500;
    line-height: 150%;
    letter-spacing: 0.2px;
    display: inline-block;
    margin-bottom: 20px;
}

.footer-contact p {
    position: relative;
    padding-left: 40px;
    margin-bottom: 24px;
}

.footer-contact p:before {
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    position: absolute;
    content: "";
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 24px;
    height: 24px;
}

.footer-contact p.address:before {
    background-image: url('images/pin.png');
}

.footer-contact p.phone:before {
    background-image: url('images/smartphone.png');
}

.footer-contact p.email:before {
    background-image: url('images/paper-plane.png');
}

.footer-contact p a,
.bottom-menu a {
    color: var(--cream);
}

.site-bottom {
    padding: 40px 0;
    position: relative;
}

.bottom-menu ul {
    display: flex;
    gap: 24px;
}

/*--------------------------------------------------------------
# Responsive Styles
--------------------------------------------------------------*/

@media screen and (max-width : 1600px) {
    .bilder-block {
        padding: 80px 64px;
    }

    .bilder-content {
        top: 80px;
    }

    .bilder-content-2 .col:last-child .bilder-content {
	    top: auto;
	    bottom: 80px;
    }

    .inner {
        padding: 0 40px;
    }

    .slick-prev {
        left: -28px;
    }

    .slick-next {
        right: -28px;
    }
    
    h1,
    h2.h1 {
	    font-size: 88px;
    }

    h2,
    h1.h2 {
        font-size: 72px;
    }

    h3 {
        font-size: 56px;
    }

    h4 {
        font-size: 40px;
    }

    h5,
    .h5,
    .product-row,
    .faq-question {
        font-size: 32px;
    }

    h6 {
        font-size: 24px;
    }

    body {
        font-size: 16px;
    }

    .product-section .col:last-child {
        padding-left: 30px;
    }

    .product-section .col:first-child {
        padding-right: 30px;
    }

    .product-data {
        padding-right: 0;
    }

    .review-content .slick-track {
	    display: block;
    }

    .review-details {
        position: relative;
    }

    .testimonial {
        height: 400px;
        overflow: hidden;
        position: relative;
    }

    .review-details.truncated::after {
        content: "";
        position: absolute;
        bottom: 22px;
        left: 0;
        width: 100%;
        height: 30px;
        display: flex;
        align-items: flex-end;
        justify-content: center;
        cursor: pointer;
        background: url('images/faq-icon.png') no-repeat right center / contain;
        color: #fff;
    }

    .truncated .testimonial::before {
        content: "";
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 40px;
        display: flex;
        align-items: flex-end;
        justify-content: center;
        padding-bottom: 16px;
        cursor: pointer;
        background: linear-gradient(
            to top,
            rgba(0,0,0,1) 0%,
            rgba(0,0,0,0.7) 50%,
            rgba(0,0,0,0.5) 100%
        );
        color: #fff;
    }

    .expanded .testimonial {
        height: auto;
    }

    .expanded .testimonial::before,
    .review-details.truncated.expanded::after {
        display: none;
    }
}

@media screen and (max-width : 1024px) {
    .inner {
	    padding: 0 25px;
    }
    
    .site-menu,
    .site-button {
        display: none;
    }

    .site-branding img {
	    max-width: 96px;
    }

    .mobile-slide {
        display: flex;
    }

    .tablet-columns .col,
    .service-slide,
    .review-header,
    .review-content,
    .footer-content,
    .contact-info,
    .checkout-section,
    .bilder-content-2 .col {
        flex: 1 1 100% !important;
        max-width: 100% !important;
    }

    .bilder-content-2 .col {
        height: 80vh;
        padding: 20px 0 0;
    }

    .bilder-content-2 .col:last-child {
        padding-bottom: 20px;
    }

    .footer-menu, .footer-contact {
        flex: 1 1 50%;
        max-width: 50%;
    }

    .product-section .cwrap {
        margin: 0 -30px;
    }

    .tablet-columns .col:first-child,
    .review-header,
    .footer-content,
    .contact-info {
        margin-bottom: 40px;
    }

    .product-section .col:first-child {
	    padding-left: 30px;
    }

    .homepage-header::before, .homepage-header::after {
        display: none;
    }

    .homepage-header .col:first-child {
        padding-top: 140px;
    }

    .homepage-header .col:last-child {
        padding-left: 0;
    }

    .header-image-desktop {
        display: none;
    }

    .header-image-mobile {
        display: block;
    }

    .section {
        padding: 80px 0;
    }

    .section-pattern::after {
        top: 0;
    }

    .pimage {
        height: 360px;
        padding: 20px 30px 40px;
    }

    .pdata {
	    padding: 0 24px;
    }

    .slick-arrow {
        width: 64px;
        height: 64px;
        left: -20px;
        top: 30%;
        background-size: 28px;
    }

    .slick-next {
        left: auto;
        right: -20px;
    }

    .service-slide {
        padding: 60px 40px;
    }

    .teaser-button {
        padding-top: 40px;
    }

    .service-slider .teaser-button {
        padding-top: 0;
    }

    .review-arrows {
        text-align: right;
    }

    .review-header p {
        margin-bottom: 0;
        padding: 16px 0 20px;
    }

    .cta {
        padding-bottom: 320px;
    }

    .cta img {
        max-height: 366px;
    }

    .product-grid .col3 {
        flex: 1 1 50%;
        max-width: 50%;
    }

    .divider {
        height: 60vh;
    }

    .product-image img {
        max-height: 400px;
    }

    .site-footer {
        padding-top: 40px;
    }

    .site-bottom {
        padding-top: 0;
    }

    .site-bottom .cwrap {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }

    .site-bottom p {
        margin-bottom: 40px;
    }

    .service-wrap {
        padding: 40px 20px;
        display: block;
    }

    .service-left,
    .service-right {
        padding: 0;
    }

    .service-image span {
        left: 20px;
        bottom: 10px;
    }

    .service-timeline {
        display: none;
    }

    .timeline-block {
	    padding-bottom: 80px;
    }

    .slick-arrow:hover {
        background-size: 24px;
    }
}

@media screen and (max-width : 767px) {
    .inner {
        padding: 0 15px;
    }

    .site-branding img {
	    max-width: 64px;
    }

    .homepage-header .col:first-child {
	    padding-top: 120px;
    }

    .header-buttons a {
        margin-bottom: 12px;
    }

    .slick-arrow {
        width: 44px;
        height: 44px;
        left: -10px;
        top: 30%;
        background-size: 20px;
    }

    .slick-next {
        left: auto;
        right: -10px;
    }

    .section,
    .service-slider {
        padding: 40px 0;
    }

    .service-slide {
	    padding: 20px;
    }

    .service-slide h2 {
        padding-bottom: 8px;
    }

    .service-slider .teaser-button {
        padding-top: 20px;
    }

    .section-heading {
        padding-bottom: 20px;
    }

    .reviews .slick-prev {
        margin-right: 8px;
    }

    .tablet-columns .col:first-child, .review-header, .footer-content, .contact-info {
	    margin-bottom: 20px;
    }

    .review-card {
        padding: 20px 20px 60px 20px;
    }

    .testimonial {
        padding: 20px 0;
        font-size: 16px;
    }

    .name,
    .title {
        font-size: 14px;
    }

    .cta {
	    padding-bottom: 280px;
    }

    .cta p {
        padding: 12px 0 24px;
    }

    .cta img {
        max-height: 260px;
    }

    .sub-header.section {
        padding-top: 200px;
    }

    .product-data {
        padding-right: 0;
    }

    .footer-content h2.h1 {
        font-size: 40px;
    }

    .footer-content p {
	    font-size: 16px;
    }

    .footer-menu a {
        font-size: 28px;
        margin-bottom: 12px;
    }

    .footer-menu, .footer-contact,
    .product-grid .col3,
    .related-product.col,
    .bilder-content-2 .col,
    .bilder-content-3 .col3 {
	    flex: 1 1 100%;
	    max-width: 100%;
    }

    .bilder-content-2 .col {
        height: 100vh;
    }

    .related-product.col:last-child,
    .bilder-content-3 .col3 {
        padding-top: 30px;
    }

    .product-grid .col3 {
        padding-top: 8px;
        padding-bottom: 8px;
    }

    .product-img-holder {
        height: 300px;
    }

    .product-table, .product-faqs {
        padding-top: 28px;
    }

    .product-data h4 {
        padding-bottom: 8px;
    }

    .product-table-rows {
        padding: 20px;
    }

    .faq-question {
        padding: 20px 60px 20px 20px;
    }

    .faq-question::before {
        width: 28px;
        height: 28px;
        right: 20px;
    }

    .related-icon {
        width: 56px;
        height: 56px;
        background-size: 36px;
        top: calc(50% + 12px);
        transform: translate(-50%, 0);
    }

    .faq-answer {
        padding: 0 20px 30px;
    }

    .pdata {
	    padding: 0 20px;
    }

    .footer-menu {
        margin-bottom: 20px;
    }

    .timeline-block {
	    padding-bottom: 40px;
    }

    .bilder-block {
        padding: 100px 20px 20px;
    }

    .bilder-3-heading {
        padding-bottom: 20px;
    }

    .bilder-3-content h4 {
        padding-top: 20px;
    }

    .product-section .cwrap {
	    margin: 0;
    }

    .product-gallery {
        padding: 100px 30px 60px;
    }

    .product-section .col:last-child,
    .product-section .col:first-child {
        padding: 0;
    }

    .product-section .col:first-child {
        padding-bottom: 20px;
    }

    .product-row {
        display: block;
    }

    .product-row .label,
    .product-row .value {
	    padding: 8px 5px;
    }

    .product-row .label {
        padding-left: 0;
    }
    
    .product-row .value {
        padding-right: 0;
    }

    .bilder-content {
        width: 90%;
    }

    .service-image:before {
        box-shadow: none;
    }

    .slick-arrow:hover {
        background-size: 18px;
    }

    .review-card:after {
        height: 60px;
    }

    h1,
    h2.h1,
    .service-image span {
	    font-size: 64px;
    }

    h2,
    h1.h2 {
        font-size: 56px;
    }

    h3 {
        font-size: 48px;
    }

    h4 {
        font-size: 32px;
    }

    h5, .product-row, .faq-question {
        font-size: 32px;
    }

    h6 {
        font-size: 24px;
    }

    body,
    .bilder-3-heading p {
        font-size: 16px;
    }
}

@media screen and (max-width : 430px) {
    h1,
    h2.h1 {
	    font-size: 44px;
    }

    h2,
    h1.h2 {
        font-size: 40px;
    }

    h3 {
        font-size: 32px;
    }

    h4 {
        font-size: 28px;
    }

    h5, .product-row, .faq-question {
        font-size: 24px;
    }

    h6 {
        font-size: 20px;
    }
}