/*
Theme Name: Huepferli-Segel.DE
Theme URI: https://winning-solutions.de/
Author: Winning Solutions
Author URI: https://winning-solutions.de
Description:  The WordPress theme based
Version: 1.0.4
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: ws
Tags: one-page, custom-menu, featured-images, custom-background, theme-options, full-width-template
*/

/* html { font-size: 26px; } */
@media screen and (min-width:1921px) { html { font-size: 20px; } }
@media screen and (max-width:1920px) { html { font-size: 16px; } }
/*  base colors */
body {
    --text: #545454;
    --heading: #153470;
	--dark-text: #232323;
	--akzent-red: #E83725;
	--accent-blue: #153470;
    --accent-green: #5D8A53;
	--grey-bgr: #F2F0EE;
    --border: rgba(11, 11, 11, 0.15);
    --light-grey: #D5D7DA;
    --dark-grey: #393532;
    --white: #fff;
    --grey-transparent: rgba(11, 11, 11, 0.05);
    --grey: #6F6862;
}

body {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
	font-smooth: never;
}

audio,
canvas,
progress,
video {
  display: inline-block;
  vertical-align: baseline;
}

audio:not([controls]) {
  display: none;
  height: 0;
}

a {
  background-color: transparent;
  color: var(--accent-blue);
  text-decoration: none;
  cursor: pointer;
  transition: color .5s
}
a:active,
a:hover {
  outline: 0;
  text-decoration:none;
  color:var(--dark-text);
}

dfn {
  font-style: italic;
}

mark {
  background: #ff0;
  color: #000;
}

img {
  border: 0;
}

svg:not(:root) {
  overflow: hidden;
}


button[disabled],
html input[disabled] {
  cursor: default;
}

input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

input {
  line-height: normal;
}

fieldset {
  border: 1px solid var(--border);
  margin: 0 2px;
  padding: 0.75rem 0.625rem 0.75rem;
}

legend {
  border: 0;
}

optgroup {
  font-weight: 400;
}


td,
th {
  padding: 0;
}
strong, b, dt {
	/* font-weight:bolder; */
    font-weight: 500;
}

code {
    font-family: inherit;
    font-weight: 500;
}
/*--------------------------------------------------------------
# Fonts
--------------------------------------------------------------*/
@font-face {
    font-family: 'Bespoke Serif';
    src: local('Bespoke Serif Regular'), local('BespokeSerif-Regular'),
        url('inc/assets/fonts/BespokeSerif-Regular.woff2') format('woff2'),
        url('inc/assets/fonts/BespokeSerif-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Tanker';
    src: local('Tanker Regular'), local('Tanker-Regular'),
        url('inc/assets/fonts/Tanker-Regular.woff2') format('woff2'),
        url('inc/assets/fonts/Tanker-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
  font-family: 'Hanken Grotesk';
  src:  url('./inc/assets/fonts/HankenGrotesk-VariableFont_wght.woff2') format('woff2');
       font-weight: 300 900;
       font-display: swap;
       font-style: normal;
}

@font-face {
  font-family: 'Hanken Grotesk';
  src: url('./inc/assets/fonts/HankenGrotesk-Italic-VariableFont_wght.woff2') format('woff2');
       font-weight: 300 900;
       font-display: swap;
       font-style: italic;
}

@supports not (font-variation-settings: normal) {
	@font-face {
		font-family: 'Hanken Grotesk';
		src: local('Hanken Grotesk Bold'), local('HankenGrotesk-Bold'),
			url('inc/assets/fonts/HankenGrotesk-Bold.woff2') format('woff2'),
			url('inc/assets/fonts/HankenGrotesk-Bold.woff') format('woff');
		font-weight: bold;
		font-style: normal;
		font-display: swap;
	}

	@font-face {
		font-family: 'Hanken Grotesk';
		src: local('Hanken Grotesk SemiBold Italic'), local('HankenGrotesk-SemiBoldItalic'),
			url('inc/assets/fonts/HankenGrotesk-SemiBoldItalic.woff2') format('woff2'),
			url('inc/assets/fonts/HankenGrotesk-SemiBoldItalic.woff') format('woff');
		font-weight: 600;
		font-style: italic;
		font-display: swap;
	}

	@font-face {
		font-family: 'Hanken Grotesk';
		src: local('Hanken Grotesk Italic'), local('HankenGrotesk-Italic'),
			url('inc/assets/fonts/HankenGrotesk-Italic.woff2') format('woff2'),
			url('inc/assets/fonts/HankenGrotesk-Italic.woff') format('woff');
		font-weight: normal;
		font-style: italic;
		font-display: swap;
	}

	@font-face {
		font-family: 'Hanken Grotesk';
		src: local('Hanken Grotesk Regular'), local('HankenGrotesk-Regular'),
			url('inc/assets/fonts/HankenGrotesk-Regular.woff2') format('woff2'),
			url('inc/assets/fonts/HankenGrotesk-Regular.woff') format('woff');
		font-weight: normal;
		font-style: normal;
		font-display: swap;
	}

	@font-face {
		font-family: 'Hanken Grotesk';
		src: local('Hanken Grotesk SemiBold'), local('HankenGrotesk-SemiBold'),
			url('inc/assets/fonts/HankenGrotesk-SemiBold.woff2') format('woff2'),
			url('inc/assets/fonts/HankenGrotesk-SemiBold.woff') format('woff');
		font-weight: 600;
		font-style: normal;
		font-display: swap;
	}

	@font-face {
		font-family: 'Hanken Grotesk';
		src: local('Hanken Grotesk Bold Italic'), local('HankenGrotesk-BoldItalic'),
			url('inc/assets/fonts/HankenGrotesk-BoldItalic.woff2') format('woff2'),
			url('inc/assets/fonts/HankenGrotesk-BoldItalic.woff') format('woff');
		font-weight: bold;
		font-style: italic;
		font-display: swap;
	}

	@font-face {
		font-family: 'Hanken Grotesk';
		src: local('Hanken Grotesk Medium Italic'), local('HankenGrotesk-MediumItalic'),
			url('inc/assets/fonts/HankenGrotesk-MediumItalic.woff2') format('woff2'),
			url('inc/assets/fonts/HankenGrotesk-MediumItalic.woff') format('woff');
		font-weight: 500;
		font-style: italic;
		font-display: swap;
	}

	@font-face {
		font-family: 'Hanken Grotesk';
		src: local('Hanken Grotesk Medium'), local('HankenGrotesk-Medium'),
			url('inc/assets/fonts/HankenGrotesk-Medium.woff2') format('woff2'),
			url('inc/assets/fonts/HankenGrotesk-Medium.woff') format('woff');
		font-weight: 500;
		font-style: normal;
		font-display: swap;
	}

}

/*--------------------------------------------------------------
# Typography
--------------------------------------------------------------*/

h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h6, .h5 {
    font-family: 'Bespoke Serif', serif;
    font-weight: 400;
    line-height: 1.1;
    color: var(--heading);
    clear: both;
    /* margin-bottom: 1.5rem; */
}
h1,.h1 {
    letter-spacing: -0.09rem;
    margin-bottom: 1rem;
}
h2, .h2 {
    letter-spacing: -0.065rem;
    margin-bottom: 1rem;
}
h3, .h3 {
    letter-spacing: -0.055rem;
    margin-bottom: 1.5rem;
}

h4, .h4 {
    line-height: 1.30;
    letter-spacing: -0.045rem;
    margin-bottom: 1.25rem;
}
h5, .h5 {
    line-height: 1.4;
    letter-spacing: -0.04rem;
    margin-bottom: 1rem;
}
h6, .entry-content h6, .entry-content h6 a,.h6 {
    line-height: 1.4;
    letter-spacing: -0.0275rem;
    margin-bottom: 1rem;
}

@media (min-width: 320px) and (max-width:1599px) {
    h1,.h1 {
        font-size: clamp(2rem, calc(2rem + (2.5rem * ((100vw - 320px) / 1280px))), 4.5rem);
    }
    h2, .h2 {
        font-size: clamp(1.75rem, calc(1.75rem + (1.5rem * ((100vw - 320px) / 1280px))), 3.25rem);
    }
    h3, .h3, .woocommerce div.product h1.product_title {
        font-size: clamp(1.5rem, calc(1.5rem + (1.25rem * ((100vw - 320px) / 1280px))), 2.75rem);
    }
    h4, .h4 {
        font-size: clamp(1.375rem, calc(1.375rem + (.875rem * ((100vw - 320px) / 1280px))), 2.25rem);
    }
    h5, .h5 {
        font-size: clamp(1.25rem, calc(1.25rem + (.75rem * ((100vw - 320px) / 1280px))), 2rem);
    }
    h6, .entry-content h6, .entry-content h6 a,.h6 {
        font-size: clamp(1.125rem, calc(1.125rem + (.2rem * ((100vw - 320px) / 1280px))), 1.375rem);
    }
    .tagline {
        font-size: clamp(1rem, calc(1rem + (.25rem * ((100vw - 320px) / 1280px))), 1.25rem);
    }
    .py-small {
        padding-top: clamp(1.75rem, calc(1.75rem + (1.25rem * ((100vw - 320px) / 1280px))), 3rem);
        padding-bottom: clamp(1.75rem, calc(1.75rem + (1.25rem * ((100vw - 320px) / 1280px))), 3rem);
    }
    .pt-small {
        padding-top: clamp(1.75rem, calc(1.75rem + (1.25rem * ((100vw - 320px) / 1280px))), 3rem);
    }
    .pb-small {
        padding-bottom: clamp(1.75rem, calc(1.75rem + (1.25rem * ((100vw - 320px) / 1280px))), 3rem);
    }
    .mb-xxsmall, .wpb-content-wrapper .vc_row {
        margin-bottom: clamp(1.125rem, calc(.125rem + (.375rem * ((100vw - 320px) / 1280px))), 1.5rem);
    }
    .mb-xsmall {
        margin-bottom: clamp(1.25rem, calc(1.25rem + (.75rem * ((100vw - 320px) / 1280px))), 2rem);
    }
    .mt-xsmall {
        margin-top: clamp(1.25rem, calc(1.25rem + (.75rem * ((100vw - 320px) / 1280px))), 2rem);
    }
    .pt-xsmall {
        padding-top: clamp(1.25rem, calc(1.25rem + (.75rem * ((100vw - 320px) / 1280px))), 2rem);
    }
    .pb-xsmall {
        padding-bottom: clamp(1.25rem, calc(1.25rem + (.75rem * ((100vw - 320px) / 1280px))), 2rem);
    }
    .mt-small, .wpb-content-wrapper .vc_row {
        margin-top: clamp(1.75rem, calc(1.75rem + (1.25rem * ((100vw - 320px) / 1280px))), 3rem);
    }
    .mb-small {
        margin-bottom: clamp(1.75rem, calc(1.75rem + (1.25rem * ((100vw - 320px) / 1280px))), 3rem);
    }
    .pt-small-plus {
        padding-top: clamp(1.5rem, calc(1.5rem + (2.5rem * ((100vw - 320px) / 1280px))), 4rem);
    }
    .pb-small-plus {
        padding-bottom: clamp(1.5rem, calc(1.5rem + (2.5rem * ((100vw - 320px) / 1280px))), 4rem);
    }
    .pt-large {
        padding-top: clamp(3.5rem, calc(3.5rem + (3.5rem * ((100vw - 320px) / 1280px))), 7rem);
    }
    .pt-medium {
        padding-top: clamp(2.5rem, calc(2.5rem + (2.5rem * ((100vw - 320px) / 1280px))), 5rem);
    }
    .pb-medium {
        padding-bottom: clamp(2.5rem, calc(2.5rem + (2.5rem * ((100vw - 320px) / 1280px))), 5rem);
    }
    .mt-medium {
        margin-top: clamp(2.5rem, calc(2.5rem + (2.5rem * ((100vw - 320px) / 1280px))), 5rem);
    }
    .mb-medium {
        margin-bottom: clamp(2.5rem, calc(2.5rem + (2.5rem * ((100vw - 320px) / 1280px))), 5rem);
    }
    .large_text {
        font-size: clamp(1.125rem, calc(1.125rem + (.2rem * ((100vw - 320px) / 1280px))), 1.375rem);
    }
    h1:not(:first-child),.h1:not(:first-child), h2:not(:first-child), .h2:not(:first-child),
    h3:not(:first-child), .h3:not(:first-child), h4:not(:first-child), .h4:not(:first-child) {
        margin-top: clamp(1.75rem, calc(.75rem + (.75rem * ((100vw - 320px) / 1280px))), 2.5rem);
    }
    h5:not(:first-child), .h5:not(:first-child), h6:not(:first-child), .h6:not(:first-child) {
        margin-top: clamp(1.5rem, calc(1.5rem + (.75rem * ((100vw - 320px) / 1280px))), 2.25rem);
    }

}

@media (min-width: 1600px) {
    h1,.h1 {
        font-size: 4rem;
    }
    h2, .h2 {
        font-size: 3.25rem;
    }
    h3, .h3, .woocommerce div.product h1.product_title {
        font-size: 2.75rem;
    }
    h4, .h4 {
        font-size: 2.25rem;
    }
    h5, .h5 {
        font-size: 2rem;
    }
    h6, .entry-content h6, .entry-content h6 a,.h6 {
        font-size: 1.375rem;
    }
    .tagline {
        font-size: 1.25rem;
    }
    .py-small {
        padding-top: 3rem;
        padding-bottom: 3rem
    }
    .pt-small {
        padding-top: 3rem;
    }
    .pb-small {
        padding-bottom: 3rem
    }
    .pt-xsmall {
        padding-top: 2rem
    }
    .pb-xsmall {
        padding-bottom: 2rem
    }
    .mt-xsmall {
        margin-top: 2rem
    }
    .mb-xsmall {
        margin-bottom: 2rem
    }
    .mb-xxsmall {
        margin-bottom: 1.5rem
    }
    .mt-small, .wpb-content-wrapper .vc_row {
        margin-top: 3rem;
    }
    .mb-small, .wpb-content-wrapper .vc_row {
        margin-bottom: 3rem
    }
    .pt-small-plus {
        padding-top: 4rem;
    }
    .pb-small-plus {
        padding-bottom: 4rem;
    }
    .pt-large {
        padding-top: 7rem
    }
    .pt-medium {
        padding-top: 5rem
    }
    .pb-medium {
        padding-bottom: 5rem
    }
    .mt-medium {
        margin-top: 5rem;
    }
    .mb-medium {
        margin-bottom: 5rem;
    }
    .large_text {
        font-size: 1.375rem;
    }
    h1:not(:first-child),.h1:not(:first-child), h2:not(:first-child), .h2:not(:first-child),
    h3:not(:first-child), .h3:not(:first-child), h4:not(:first-child), .h4:not(:first-child) {
        margin-top: 2.5rem
    }
    h5:not(:first-child), .h5:not(:first-child), h6:not(:first-child), .h6:not(:first-child) {
        margin-top: 2.25rem
    }

}
.tagline {
    color: var(--akzent-red);
    font-family: 'Tanker', sans-serif;
    font-weight: 400;
    line-height: 1.5;
    letter-spacing: 0.1rem;
    margin-bottom: .5rem;
}
.large_text {
    font-family: 'Hanken Grotesk',sans-serif;
}
.large_text.title_type {
    font-family: 'Bespoke Serif', serif;
}
.bigger_text {
    font-family: 'Hanken Grotesk',sans-serif;
    font-size: 1.125rem;
}
/*
.medium_text {
    font-family: 'Hanken Grotesk',sans-serif;
    font-size: 1.25rem;
    line-height: 1.5;
}
.large_text {
    font-family: 'Hanken Grotesk',sans-serif;
    font-size: 1.875rem;
    font-weight: 500;
    line-height: 1.35;
} */
.body-text {
    font-family: 'Hanken Grotesk',sans-serif;
    font-size: 1rem;
}
.body-font-size {
    font-size: 1rem;
}
p {
    margin-bottom: 1rem
}
/**/

.width-768 {
    width: 768px;
    max-width: 100%;
    margin-left:auto;
    margin-right: auto;
}
.ws-featured-text a, .text-two-images-block a {
    text-decoration: underline;
    color: inherit;
}
.ws-featured-text a:hover, .text-two-images-block a:hover {
    color: var(--accent-blue);
}
/*--------------------------------------------------------------
# Elements
--------------------------------------------------------------*/
body {
    font-family: 'Hanken Grotesk',sans-serif;
    font-weight: 400;
    font-size: 1rem;
    line-height: 1.5;
    color: var(--text);
    overflow-x: hidden;
    background-color: var(--grey-bgr);
}
.container {
    margin-left: auto !important;
    margin-right: auto !important;
}
.container {
    padding-left: 15px;
    padding-right: 15px;
}
.container48 {
    max-width: 48rem;
    margin-left: auto !important;
    margin-right: auto !important;
}
.container40 {
    max-width: 40rem;
    margin-left: auto !important;
    margin-right: auto !important;
}
img {
  height: auto;
  max-width: 100%;
}

figure {
  margin-top: 1rem;
}

table {
  margin: 0 0 1.5em;
  width: 100%;
}

pre {
    background: #eee;
    font-family: "Courier 10 Pitch",Courier,monospace;
    margin-bottom: 1.6em;
    overflow: auto;
    max-width: 100%;
    padding: 1.6em;
}

ul { padding-left: 1.5rem; margin-bottom: 1.25rem}

.site-main ul {
    margin-bottom: 1.5rem;
}
ul.white-check, ul.green-check {
    list-style-type: none;
    padding: 0;
}
ul.green-check {
    padding-left: 1rem
}
ul.white-check li, ul.green-check li {
    list-style-type: none;
    position: relative;
    display: flex;
    align-items: flex-start;
    font-size: 1rem;
}
ul.white-check li {
    color: var(--white);
}
ul.green-check li {
    color: var(--heading);
}
ul.green-check li:not(:last-child) {
    margin-bottom: .75rem
}
ul.white-check li:not(:last-child) {
    margin-bottom: 1rem
}
ul.white-check li div.li-subtitle {
    color: var(--text);
    font-size: .875rem;
    margin-top: .3rem;
}
ul.white-check li div.li-subtitle {
    color: var(--light-text);
}
ul.green-check li:before,
ul.white-check li:before {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 1.5rem;
    flex-shrink: 0;
    height: 1.5rem;
    margin-right: .75rem;
    border-radius: 100%;
    line-height: 1;
}
ul.green-check li:before {
    content:'\e900';
    font-family: 'huepferli';
    font-size: 1.25rem;
    width: 1.25rem;
    color: var(--green);
}
ul.white-check li:before {
    content:'✓';
    font-family: 'Hanken Grotesk';
    font-size: .75rem;
    font-weight: 600;
    background: var(--white);
    color: var(--black);
}

#content ul ul {
    padding-top:18px;
    padding-left: 30px;
    margin-bottom:0
}
#content ul li:last-child {
    padding-bottom: 0
}

ol {
	padding-left: 25px;
	margin-bottom: 25px
}
ol li{
    margin-bottom: 5px;
	padding-left: 5px;
}
a.button, .button, input[type="submit"] {
    display: inline-flex!important;
    justify-content: center;
    align-items: center;
    padding: 0.75rem 1.5rem!important;
    background-color: var(--dark-grey);
    border: 1px solid var(--dark-grey);
    color: #fff;
    font-family: 'Tanker', sans-serif;
    font-weight: 400!important;
    letter-spacing: 0.09rem;
    font-size: 1.125rem!important;
    border-radius: 0!important;
    line-height: 1!important;
    text-align: center;
    cursor: pointer;
    text-decoration: none;
    position: relative;
    z-index: 1;
    transition: all .5s;
}
a.button.bigger-button, .button.bigger-button {
    padding: 0.98rem 1.25rem 0.99rem;
}
a.button.smaller-button, .button.smaller-button {
    padding: 0.72rem 1.25rem 0.73rem;
}

a.button.grey-button, .button.grey-button, input[type="submit"].grey-button {
    background-color: var(--grey-transparent)!important;
    backdrop-filter: blur(6px);
    border-color: var(--grey-transparent)!important;
    color: var(--grey)!important;
}


a.button.white-button, .button.white-button, input[type="submit"].white-button {
    background: var(--white) !important;
    border-color: var(--border) !important;
    color: var(--text) !important;
}
a.button.transparent-button , .button.transparent-button {
    background: transparent!important;
    border-color: transparent!important;
    color: var(--white)!important;
}
a.button.bordered-transparent-button , .button.bordered-transparent-button {
    background: transparent!important;
    border-color: var(--border)!important;
    color: var(--text)!important;
}
a.button:hover, a.button:focus,
.button:hover, .button:focus,
input[type="submit"]:hover, input[type="submit"]:focus {
    background-color: var(--white);
    border-color: var(--dark-grey);
    color: var(--dark-grey);
}
a.button.white-button:hover, .button.white-button:hover, input[type="submit"].white-button:hover,
a.button.white-button:focus, .button.white-button:focus, input[type="submit"].white-button:focus{
    background-color: var(--accent-blue)!important;
    border-color: var(--accent-blue)!important;
    color: #fff!important;
}
a.button.transparent-button:hover, .button.transparent-button:hover,
a.button.transparent-button:focus, .button.transparent-button:focus {
    background: transparent!important;
    border-color: transparent!important;
    color: var(--light-grey)!important;
}

a.button.grey-button:hover, .button.grey-button:hover, input[type="submit"].grey-button:hover,
a.button.grey-button:focus, .button.grey-button:focus, input[type="submit"].grey-button:focus {
    background-color: var(--white)!important;
    border-color: var(--white)!important;
}
a.button.bordered-transparent-button:hover, .button.bordered-transparent-button:hover,
a.button.bordered-transparent-button:focus, .button.bordered-transparent-button:focus {
    background: var(--white)!important;
    border-color: var(--border)!important;
    color: var(--text)!important;
}



button:focus {
    outline: none;
}
.button.align-center {
    display: table!important;
    margin-left: auto!important;
    margin-right: auto!important;
}
.back-button {
    font-size: .875rem;
    font-weight: 600;
    color: var(--dark-grey);
    display: inline-flex;
    align-items: center;
    padding: .25rem 0;
    margin-left: .25rem;
    transition: margin-left .3s
}
.back-button svg {
    margin-right: .75rem;
    margin-left: -.25rem;
    transition: margin-right .3s
}
.back-button:hover {
    margin-left: 0;
}
.back-button:hover svg {
    margin-right: 1rem;
}
.nowrap {
    white-space:nowrap;
}

/*--------------------------------------------------------------
# Navigation
--------------------------------------------------------------*/
#page {
    z-index: 1;
    position: relative;
    padding-top: 6rem;
}
.page-template-page-home #page {
    padding-top: 4rem;
}
a.page-scroller {
  color: #333;
  font-size: 2.6rem;
  display: inline-block;
  margin-top: 2rem;
}

#content {
    position: relative;
    z-index: 1;
}
body:not(.single.single-post) #content {
    overflow-x: clip;
}

/**/
.site-main .comment-navigation,
.site-main .posts-navigation,
.site-main .post-navigation {
  margin: 0 0 1.5em;
  overflow: hidden;
}

.comment-navigation .nav-previous,
.posts-navigation .nav-previous,
.post-navigation .nav-previous {
  float: left;
  width: 50%;
}

.comment-navigation .nav-next,
.posts-navigation .nav-next,
.post-navigation .nav-next {
  float: right;
  text-align: right;
  width: 50%;
}
.comment-content.card-block {
  padding: 20px;
}

.navigation.post-navigation {
  padding-top: 1.875rem;
}

.post-navigation .nav-previous a,
.post-navigation .nav-next a {
  border: 1px solid #ddd;
  border-radius: 0.938rem;
  display: inline-block;
  padding: 0.313rem 0.875rem;
  text-decoration: none;
}

.post-navigation .nav-next a::after {
  content: " \2192";
}

.post-navigation .nav-previous a::before {
  content: "\2190 ";
}

.post-navigation .nav-previous a:hover,
.post-navigation .nav-next a:hover {
  background: #eee none repeat scroll 0 0;
}

/*--------------------------------------------------------------
# Accessibility
--------------------------------------------------------------*/
/* Text meant only for screen readers. */
.screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute !important;
  height: 1px;
  width: 1px;
  overflow: hidden;
  word-wrap: normal !important;
  /* Many screen reader and browser combinations announce broken words as they would appear visually. */
}
.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: 400;
  height: auto;
  left: 0.313rem;
  line-height: normal;
  padding: 0.938rem 1.438rem 0.875rem;
  text-decoration: none;
  top: 0.313rem;
  width: auto;
  z-index: 100000;
  /* Above WP toolbar. */
}

/* Do not show the outline on the skip link target. */
#content[tabindex="-1"]:focus {
  outline: 0;
}

/*--------------------------------------------------------------
# Alignments
--------------------------------------------------------------*/
.text-right {
    text-align: right;
}
.text-center {text-align: center}

.alignleft {
  display: inline;
  float: left;
  margin-right: 1.5em;
}

.alignright {
  display: inline;
  float: right;
  margin-left: 1.5em;
}

.aligncenter {
  clear: both;
  display: block;
  margin-left: auto;
  margin-right: auto;
}
/* single post styles */
body.single.single-post {
    overflow-x: unset
}
body.single.single-post #page {
    overflow-y: unset;
}
/* with toc */
.single-container2 {
    display: flex;
    align-items: flex-start;
    position: relative;
}
.single-container2 .ws-toc:not(:empty) {
    flex-basis: 20rem;
    flex-shrink: 0;
    margin-right: 5rem;
    top: 6rem;
    left:0;
    position: -webkit-sticky;
    position: sticky;
    z-index: 0;
}
.single-container2 .ws-single-with-toc {
    width: calc(100% - 25rem);
    max-width: 48rem
}
.ws_toc_wrap {
    padding: 0 0 2rem 0;
}
a.ws_toc_item {
    display: block;
    color: var(--dark-text);
    text-decoration: none;
    font-size: 1.25rem;
	font-weight: 400;
    line-height: 1.2;
    padding: 0.75rem 1rem;
    border: 1px solid transparent;
    margin-bottom: 0;
    position: relative;
    display: inline-block;
    font-weight: 400;
    transition: font-weight 0.4s ease;
}
a.ws_toc_item:hover, a.ws_toc_item.active {
    color: var(--dark-text);
    font-weight: 700;
}
a.ws_toc_item.active {
    background-color: rgba(255, 255, 255, 0.20);
    border-color: var(--border);
}
.ws-single-with-toc .ws-header-1 {
    margin-top:0!important
}
@media (max-width: 991px) and (min-width: 768px) {
    .single-container2 .ws-toc:not(:empty) {
        flex-basis: 15rem;
        margin-right: 2rem;
    }
    .single-container2 .ws-single-with-toc {
        max-width: calc(100% - 17rem);
    }
}
@media  (min-width: 768px) {
}
@media (max-width: 767px) {
    .single-container2 {
        flex-direction: column;
    }
    .single-container2 .ws-toc:not(:empty) {
        /* flex-basis: 0;
        width: 0; */
		top: 4rem;
        flex-basis: 100%;
        width: 100%;
		z-index: 1;
        margin-right: 0;
        margin-bottom: 1.75rem;
    }
    .single-container2 .ws-toc .ws_toc_wrap {
        width: 100%;
		background-color: #fff;
		padding: 1rem;
		border: 1px solid var(--border);
    }
    .ws_toc-title {
        font-size: 1rem;
        color: var(--dark-text);
    }
    .ws_toc_wrap:not(.hidden) .ws_toc-title .hficon-chevron-down {
        transform: rotate(180deg);
    }
    .ws_toc-items {
        max-height:2000px;
        opacity: 1;
        visibility: visible;
		display: table;
        width: 100%;
		padding-bottom:0;
        padding-top: 1rem;
        transition: all .5s
    }
    a.ws_toc_item {
        font-size: 1rem;
        padding: 0.5rem .75rem;
    }
    .single-container2 .ws-toc .ws_toc_wrap.hidden .ws_toc-items {
        max-height:0;
        opacity: 0;
        padding-top:0;
		display: block;
        visibility: hidden;
		overflow: hidden;
    }
    .single-container2 .ws-single-with-toc {
        width: 100%;
    }

}
/* end toc */

/**/
.single-post-meta {
    font-size: 1rem
}
.ws-post-meta-title {
    color: var(--text);
}
.ws-post-meta-data {
    color: var(--dark-text);
    font-weight: 500
}
.ws-single-img {
    aspect-ratio: 2.133;
    position: relative;
}
.ws-single-img img {
    position: absolute;
    top:0; left:0;
    width:100%; height: 100%;
    object-fit: cover;
    object-position: center;
}
/**/
blockquote {
    padding: 2.25rem 1.25rem;
    margin-bottom: 0;
    font-size: 1.25rem;
    font-style: italic;
    font-weight: 400;
    color: var(--dark-text)
}


img.alignright, .wp-caption.alignright {
  margin: 0 0 1.5rem 1.5rem!important;
}
img.alignleft, .wp-caption.alignleft {
  margin: 0 1.5rem 1.5rem 0!important;
}
img.alignnone, .wp-caption.alignnone,
img.aligncenter, .wp-caption.aligncenter {
  margin: 3rem auto;
}

img.alignright:first-child, .wp-caption.alignright:first-child,
img.alignleft:first-child, .wp-caption.alignleft:first-child,
img.alignnone:first-child, .wp-caption.alignnone:first-child,
img.aligncenter:first-child, .wp-caption.aligncenter:first-child {
  margin-top: 0;
}

@media (max-width: 767px) {
    blockquote {
        padding: 1rem;
    }
    img.alignnone, .wp-caption.alignnone,
    img.aligncenter, .wp-caption.aligncenter {
      margin: 2rem auto;
    }

}

/* search form on page search results */
.shop-search-form {
    width: 100%;
    position: relative;
}
.shop-search-form input {
    flex-basis: 100%;
    border-width: 0 0 1px 0;
    height: 3.65rem;
    line-height: 1;
    padding: 0 .5rem .75rem 3rem;
    background: url('inc/assets/images/search.svg') no-repeat left center;
    background-size: 2rem;
    margin: 0;
}
.shop-search-form input:focus {
    box-shadow: none!important
}
.shop-search-form .hficon-clear {
    position: absolute;
    right: 0;
    width: 2rem;
    padding-left: .5rem;
    font-size: 1.5rem;
    color: #c5c5c5;
    top: 50%;
    transform: translateY(-50%);
    cursor: pointer;
    background-color: var(--grey-bgr);
}
.shop-search-form .hficon-clear:hover {
    color: var(--dark-text);
}

/*--------------------------------------------------------------
# Clearings
--------------------------------------------------------------*/
.clear:before,
.clear:after,
.entry-content:before,
.entry-content:after,
.comment-content:before,
.comment-content:after,
.site-header:before,
.site-header:after,
.site-content:before,
.site-content:after,
.site-footer:before,
.site-footer:after {
  content: "";
  display: table;
  table-layout: fixed;
}

.clear:after,
.entry-content:after,
.comment-content:after,
.site-header:after,
.site-content:after,
.site-footer:after {
  clear: both;
}

/*--------------------------------------------------------------
# Widgets
--------------------------------------------------------------*/
.widget select {
  max-width: 100%;
}

.widget_search .search-form input[type="submit"] {
  display: none;
}
/* widget menu */
.widget_nav_menu ul {
    padding-left: 0;
    padding-top: 5px;
}
.widget_nav_menu ul li {
    margin-bottom:10px;
    list-style-type: none
}
.widget_nav_menu ul li a {
    font-family: 'Hanken Grotesk',sans-serif;
    font-weight: 400;
    color: var(--accent-blue);
    padding: 0;
}

/*--------------------------------------------------------------
# Content
--------------------------------------------------------------*/
/*--------------------------------------------------------------
## Posts and pages
--------------------------------------------------------------*/

.single .byline,
.group-blog .byline {
  display: inline;
}

.page-links {
  clear: both;
  margin: 0 0 1.5em;
}

.page-template-blank-page .entry-content,
.blank-page-with-container .entry-content {
  margin-top: 0;
}

.posted-on, .byline, .comments-link {
  color: #9a9a9a;
}

.entry-title > a {
  color: inherit;
}
/**/

/*--------------------------------------------------------------
## Comments
--------------------------------------------------------------*/
.comment-content a {
  word-wrap: break-word;
}

.bypostauthor {
  display: block;
}

.comment-body .pull-left {
  padding-right: 0.625rem;
}

.comment-list .comment {
  display: block;
}

.comment-list {
  padding-left: 0;
}

.comments-title {
  font-size: 1.125rem;
}

.comment-list .pingback {
  border-top: 1px solid rgba(0, 0, 0, 0.125);
  padding: 0.563rem 0;
}

.comment-list .pingback:first-child {
  border: medium none;
}

/*--------------------------------------------------------------
# Media
--------------------------------------------------------------*/
.page-content .wp-smiley,
.entry-content .wp-smiley,
.comment-content .wp-smiley {
  border: none;
  margin-bottom: 0;
  margin-top: 0;
  padding: 0;
}

/* Make sure embeds and iframes fit their containers. */
embed,
iframe,
object {
  max-width: 100%;
}

/*--------------------------------------------------------------
## Captions
--------------------------------------------------------------*/
.wp-caption {
  text-align: center;
  max-width: 100%;
}
.wp-caption img[class*="wp-image-"] {
  border: 0 none;
  height: auto;
  margin: 0;
  max-width: 100%;
  padding: 0;
  width: auto;
}
.wp-caption figcaption, .wpb_single_image .vc_figure-caption {
  font-size: .875rem!important;
  line-height: 1.2;
  color: var(--dark-text);
  margin: .5rem 0 0!important;
  text-align: left;
}

/*--------------------------------------------------------------
## Galleries
--------------------------------------------------------------*/
.gallery {
  margin-bottom: 1.5em;
}

.gallery-item {
  display: inline-block;
  text-align: center;
  vertical-align: top;
  width: 100%;
}
.gallery-item .gallery-columns-2 {
  max-width: 50%;
}
.gallery-item .gallery-columns-3 {
  max-width: 33.33333%;
}
.gallery-item .gallery-columns-4 {
  max-width: 25%;
}
.gallery-item .gallery-columns-5 {
  max-width: 20%;
}
.gallery-item .gallery-columns-6 {
  max-width: 16.66667%;
}
.gallery-item .gallery-columns-7 {
  max-width: 14.28571%;
}
.gallery-item .gallery-columns-8 {
  max-width: 12.5%;
}
.gallery-item .gallery-columns-9 {
  max-width: 11.11111%;
}

.gallery-caption {
  display: block;
}

.entry-meta {
    font-size: 16px;
    color: rgba(0,0,0,0.5);
    margin-top:10px
}
/**/
/*  404 page */
.error-404 {
    display:flex;
    -webkit-flex-direction: column;
    flex-direction:         column;
    align-items: center;
    justify-content: center;
}
.error-404 .page-content {
    text-align: center;

}

/* shortcodes */
 .ws-social a {
    margin: 0 .75rem;
    color: var(--text);
}
.ws-social a:last-child {
    margin-right: 0;
}
.ws-social a i {
    font-size: 1.5rem
}
.ws-social a i.hficon-facebook {
    font-size: 1.825rem;
    line-height: 1.5rem;
}
/**/
/*--------------------------------------------------------------
# Media Query
--------------------------------------------------------------*/
@media only screen and (max-width: 575px) {
    * {
        word-break: break-word;
        hyphens: auto;
    }
}
@media only screen and (max-width:767px) {
    .container {
        max-width: 100%;
    }
    #page {
        padding-top: 5rem;
    }
    /*a.button, .button,*/ input[type="submit"] {
        padding: 0.5rem 1.25rem;
    }

    .desktop-show { display:none!important}

    .error-404 {
        min-height: 300px;
    }
    a.button, .button, input[type="submit"] {
        padding: 0.75rem 1rem;
		width: 100%;
        height: 3rem;
        font-size: 1rem
    }
    img.alignleft, .wp-caption.alignleft,
    img.alignright, .wp-caption.alignright {
        margin: 0 auto 15px!important;
        display: block;
        float: none;
    }
    .ws-social {
        display: flex;
        flex-wrap: wrap;
    }
    .ws-social a {
        margin: 0 1rem 1rem
    }
    .ws-social a i {
        margin-right: 0
    }
    .single-post article {
        margin: 0;
    }
}
@media only screen and (min-width:768px) {
    .mobile-show { display:none!important}
    .error-404 {
        min-height: 500px;
    }
    .container {
        max-width: calc(100vw - 3rem);
    }
    /* .wpb-content-wrapper > * > .vc_row {
        max-width: calc(100vw - 1rem);
    } */

}
@media only screen and (min-width:768px) and (max-width: 1199px) {
    #content {
        min-height: calc(100vh - 800px);
    }
}

@media only screen and (min-width: 992px) {
    .container {
        width: calc(100vw - 6rem);
        max-width: 84rem
    }

    /* two column text */
    .twocolumn {
        -webkit-column-count: 2;
        -moz-column-count: 2;
        column-count: 2;
        -webkit-column-gap: 30px;
        -moz-column-gap: 30px;
        column-gap: 30px;
        text-align: left;
    }

}

@media only screen and (min-width: 1200px) {
    #content {
        min-height: calc(100vh - 720px);
    }
}

@media screen and (min-width:1921px) {
    .container {
        max-width: 91rem
    }

}

/*  input focus */
input:focus {
    outline-style:none;
    outline:0 !important;
    -webkit-box-shadow: 0 3px 5px 1px rgba(0,0,0,0.1) !important;
    box-shadow: 0 3px 5px 1px rgba(0,0,0,0.1)!important;
 }

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
    -webkit-animation: autofill 0s forwards;
    animation: autofill 0s forwards;
}
@keyframes autofill {
    100% {
        background: #fff;
        color: #707070;
    }
}
@-webkit-keyframes autofill {
    100% {
        background: #fff;
        color: #707070;
    }
}


/* popup maker shift */
html.pum-open.pum-open-overlay {
overflow: visible !important;
}

html.pum-open.pum-open-overlay.pum-open-scrollable .pum-overlay.pum-active {
overflow-y: visible !important;
}

html.pum-open.pum-open-overlay.pum-open-scrollable body .cookiedisallow-fixed-banner.cookiedisallow_position-bottom,
html.pum-open.pum-open-overlay.pum-open-scrollable body .cookiedisallow-fixed-banner.cookiedisallow_position-top,
html.pum-open.pum-open-overlay.pum-open-scrollable body>:not([aria-modal=true]) {
    padding-right: 0!important;
}
