/*
Theme Name: Starter Block Theme v3
Theme URI: https://jakson.co/
Author: Jakson
Author URI: https://jakson.co/
Description: 
Requires at least: 6.7
Tested up to: 6.7
Requires PHP: 7.4
Version: 3.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: starter-block-theme-v3
Tags: Block Editor Patterns, Site Editor

/*  Smoot Scroll */
html {
  scroll-behavior: smooth;
}

html.menu-active, body.menu-active { overflow-y: hidden; scrollbar-width: auto;}


/*  Reduced motion prefs  */
@media screen and (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
}

/*  Navigation Block Breakpoint. Credit: https://wpdocs.io/ */
body .wp-block-navigation__responsive-container-open:not(.always-shown) {
  display: block !important;
}

body .wp-block-navigation__responsive-container:not(.hidden-by-default):not(.is-menu-open) {
  display: none !important;
}

/* Change the width to the breakpoit of the Nav */
@media (min-width: 782px) {
  body .wp-block-navigation__responsive-container-open:not(.always-shown) {
    display: none !important;
  }

  body .wp-block-navigation__responsive-container:not(.hidden-by-default):not(.is-menu-open) {
    display: block !important;
  }
}

/* end nav break point */

/* Nicley wrapped headlines */
h1,
h2,
h3,
h4 {
  text-wrap: balance;
}


p strong {
	font-weight: 600;
}

/* I've no idea why when you add a backgroud colour to a column, WP by default adds padding to it... so weird - this get's rid of that */
:where(.wp-block-columns.has-background) {
  padding: initial;
}

/* Pull Quote */
.wp-block-pullquote blockquote {
  display: grid;
  gap: 20px;
}

.wp-block-pullquote cite {
  font-size: 80%;
  font-weight: 600;
}

/* Search Block */
.wp-block-search__input {
  border: 1px solid;
}

.wp-block-search__button {
  box-shadow: none;
  border: 1px solid var(--wp--preset--color--custom-off-black);
  border-radius: 0;
  color: white;
  padding: 0.4rem 1rem 0.5rem 1rem;
  font-weight: 500;
}

/* Comments */
.comment-form-cookies-consent {
  font-size: 14px;
  line-height: 2;
}

/* Keep our titles link the off black color*/
.wp-block-post-title :where(a) {
  color: var(--wp--preset--color--custom-off-black);
}

/* Button hover state  - core button block still does not have this and I can't figure out how to do it in theme.json! */
.wp-block-button__link,
a {
  transition: 0.3s;
}

.wp-block-button.is-style-fill .wp-block-button__link:hover,
#commentform .form-submit.wp-block-button input:hover {
  background: var(--wp--preset--color--custom-white);
  color: var(--wp--preset--color--custom-off-black);
}

.wp-block-button .wp-block-button__link:hover {
  background: var(--wp--preset--color--custom-custom-white);
  color: var(--wp--preset--color--off-black);
  border-color: var(--wp--preset--color--custom-off-black);
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
  background: var(--wp--preset--color--custom-off-black);
  color: var(--wp--preset--color--custom-white);
  border-color: var(--wp--preset--color--custom-off-black);
}

/* CTA Call to Action */
.call-to-action-btn-yellow a {
	font-size: 1.75rem;
}
.call-to-action-btn-yellow a i.icon  {
	margin-right: 8px;
	vertical-align: middle;
	font-size: 32px;
	margin-top: -4px;
}

@media (max-width: 781px) {
	.call-to-action-btn-yellow a {
		font-size: 1rem;
	}
}

a:hover:not(.wp-block-site-title a, .wp-block-button__link.wp-element-button) {
  text-decoration: underline !important;
}



:root {	
	--sk-gelb: var(--wp--preset--color--custom-sk-gelb);
	--sk-blau: var(--wp--preset--color--custom-sk-blau);
	--sk-hellblau: var(--wp--preset--color--custom-sk-hellblau);
	--header-height-large: 100px;
	--header-height-small: 40px;
	--header-height-large-mobile: 90px;
	--header-height-small-mobile: 40px;
	--logo-height: 70px;
	--logo-height-mobile: 60px;
	--icon-height: 32px;
	--transition-speed: 0.45s;
	--transition-speed-inner: 0.35s;
	--transition-speed-reverse: 0.3s;
	--header-shadow: 0 10px 28px rgba(0, 0, 0, 0.25);
}


body > div.wp-site-blocks {
	padding-top: 0;
}

main {
	margin-block-start: 0;
    margin-block-end: 40px;
	margin-top: var(--header-height-large);
}
main.top-line-active {
	margin-top: calc(35px + var(--header-height-large));
}
@media (max-width: 781px) {
	main {
		margin-top: var(--header-height-large-mobile);
	}
	main.top-line-active {
		margin-top: calc(35px + var(--header-height-large-mobile));
	}
}


/* Header */

.site-header {
	position: fixed;
	top: 0;
	right: 0;
	left: 0;
	z-index: 1000;
	background: var(--sk-gelb);
	box-shadow: 0 10px 28px rgba(0, 0, 0, 0.25);
	transition: all .6s ease-in-out;
}

.site-header .header-top-line {
	color:  var(--sk-hellblau);
	background: var(--sk-blau);
	height: 35px;
	font-size: 1rem;
	overflow: hidden;
}
.site-header .header-top-line > div {
	width: 100%;
}
.site-header .header-main {
	height: var(--header-height-large);
	margin: 0;
	transition: all .4s ease-in-out;
}
@media (max-width: 781px) {
	.site-header .header-main {
		height: var(--header-height-large-mobile);
	}
}

.site-header.is-shrunk .header-main > div {
	color: var(--sk-blau);
	transition: all .1s ease-in-out;
}

.site-header .header-logo img {
	height: var(--logo-height);
	width: auto;
	transition: height 0.7s ease-in-out;
	position: absolute;
	top: 15px;
}
body.top-line-active .site-header .header-logo img {
	top: 50px;
}

@media (max-width: 781px) {
	.site-header .header-logo img {
		height: var(--logo-height-mobile);
		
	}
}

.site-header .header-icon img {
	height: 0;
	width: auto;
	opacity: 0;
}


.site-header.is-shrunk .header-nav,
.site-header .header-small-nav {
	display: none;
	transition: all .2s ease-in-out;
}
.site-header .header-nav,
.site-header.is-shrunk .header-small-nav {
	display: inherit;	
	transition: all .2s ease-in-out;
}

@media (max-width: 781px) {
	.site-header .header-nav,
	.site-header.is-shrunk .header-nav {
		display: none!important;
	}

}


.site-header .header-nav,
.site-header.is-shrunk .header-small-nav {
	display: inherit;	
}

.site-header .header-nav a,
.site-header .header-nav .wp-block-navigation .wp-block-navigation-item__content.wp-block-navigation-item__content {
	color: var(--sk-blau);
}


.site-header .header-nav a:hover,
.site-header .header-small-nav a:hover {
	text-decoration: none!important;
}

.site-header .header-nav a:where(:not(.wp-element-button)) {
	font-weight: 700;
}

.site-header .header-nav li:hover > a {
	color: #000!important;
}
.site-header .header-small-nav li:hover > a {
	color: var(--sk-gelb);
}

.site-header .header-nav a:where(:not(.wp-element-button)),
.site-header .header-small-nav a:where(:not(.wp-element-button)) {
	font-family: initial!important;
	text-decoration: none!important;
}

.site-header .header-nav > ul {
	gap: 30px;
}

.site-header .header-nav-small > ul > .has-child,
.site-header .header-nav > ul > .has-child {
	margin-right: -6px;
}


.site-header .header-nav .wp-block-navigation__submenu-container {
	background: var(--sk-gelb);
	border-color: var(--sk-gelb);
}

.site-header .header-nav-small .wp-block-navigation__submenu-container {
	background: var(--sk-blau);
	border-color: var(--sk-blau);
	color: white;
}

.site-header .header-nav .wp-block-navigation__submenu-container li {
	border-bottom: 1px solid var(--sk-blau);
}

.site-header .header-nav .wp-block-navigation__submenu-container,
.site-header .header-nav .wp-block-navigation__submenu-container li:last-child {
	border-bottom-left-radius: 8px !important;
    border-bottom-right-radius: 8px !important;
	border-bottom: 0;
}

.site-header .header-nav .wp-block-navigation__submenu-container,
.site-header .header-nav-small .wp-block-navigation__submenu-container {
	margin-left: -15px;
}

.site-header .header-nav .wp-block-navigation__submenu-container > li > a,
.site-header .header-nav-small .wp-block-navigation__submenu-container > li > a {
	padding-left: 15px!important;
	text-wrap: nowrap;
}


.site-header .nav-btn-top-bar-text-before,
.site-header .nav-btn-top-bar,
.site-header .btn-contact-top-bar,
.site-header .btn-faq-top-bar {
	display: none;
}

.site-header.is-shrunk .btn-faq-top-bar, 
.site-header.is-shrunk .btn-faq-top-bar a,
.site-header.is-shrunk .btn-contact-top-bar, 
.site-header.is-shrunk .btn-contact-top-bar a {
	font-size: 26px;
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-right: var(--wp--style--root--padding-right);
	transition: all var(--transition-speed) ease-in-out;
}
.site-header.is-shrunk .btn-faq-top-bar,
.site-header.is-shrunk .btn-faq-top-bar a,
.site-header.is-shrunk .btn-contact-top-bar a { color: inherit; margin-right: 0; }
.site-header.is-shrunk .btn-faq-top-bar a {
	font-size: 22px;
	margin-right: 4px;
}

.site-header.is-shrunk .header-nav-small, 
.site-header.is-shrunk .header-nav-small * {
	color: white!important;
}
@media (max-width: 781px) {
	
	.site-header:not(.site-header.is-shrunk) {
		color: var(--sk-blau);
	}
	.site-header .header-nav-small ul li:first-child {
		display: none;
	}
	.site-header .header-nav-small ul {
		gap: 15px;
	}
	
	.site-header .header-nav-small > ul > .has-child {
		margin-right: 0px;
	}

	.site-header .nav-btn-top-bar {
		position: relative;
		display: inline-flex;
		font-size: 48px;
		align-items: center;
		justify-content: center;
		margin-right: var(--wp--style--root--padding-right);
	}
	.site-header .btn-faq-top-bar, 
	.site-header .btn-faq-top-bar a,
	.site-header .btn-contact-top-bar, 
	.site-header .btn-contact-top-bar a {
		font-size: 40px;
		position: relative;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		margin-right: var(--wp--style--root--padding-right);
		transition: all var(--transition-speed) ease-in-out;
	}
	.site-header .btn-faq-top-bar a { font-size: 32px; }
	.site-header .btn-faq-top-bar,
	.site-header .btn-faq-top-bar a,
	.site-header .btn-contact-top-bar a { margin-right: 2px; }
	.site-header .btn-faq-top-bar a { margin-right: 0; }
	.site-header.is-shrunk .btn-faq-top-bar,
	.site-header.is-shrunk .btn-contact-top-bar {
		display: none;
		opacity: 0;
		font-size: 0!important;
		transition: all var(--transition-speed-inner) ease-in-out;
	}
	
	.site-header .nav-btn-top-bar-text-before,
	.site-header .header-nav-small .wp-block-navigation {
		font-size: 13px!important;
	}
	.site-header.is-shrunk .header-small-nav {
		margin-left: calc(-10px - var(--wp--style--root--padding-left))!important;
	}
	.site-header.is-shrunk .header-main {
		gap: 0px;
		
	}
	.site-header.is-shrunk .header-main > div:first-child {
		margin-left: -4px;
		
	}
	.site-header.is-shrunk .header-main > div:last-child {
		/*margin-right: 12px;*/
		
	}
	.site-header .header-main,
	.site-header.is-shrunk .header-main > div {
		
	}
}



.site-header.is-shrunk {
	background: var(--sk-blau);
	transition: all 1.2s ease-in-out;	
}
.site-header.is-shrunk .header-main {
	height: var(--header-height-small);
	color: white;
	transition: height var(--transition-speed-reverse) ease-in-out;
}
.site-header.is-shrunk .header-main > div {
	color: white;
	/*transition: color .2s ease-in-out;*/
}
.site-header.is-shrunk .header-logo img {
	height: 0px;
	/*opacity: 0;*/
	transition: height 350ms ease-in-out;	
}
.site-header.is-shrunk .header-icon {	
	transition: all 200ms ease-in-out;
	transition-delay: 150ms;	
	margin-left: -40px;
}
.site-header.is-shrunk .header-icon img {
	height: var(--icon-height);
	opacity: 1;
	transition: all 200ms ease-in-out;		
	/*transition-delay: 200ms;*/
}
.site-header.is-shrunk .header-nav-small {
	transition: all 450ms ease-in-out;	
	transition-delay: 50ms;
}
.site-header.is-shrunk .header-top-line {
	height: 0;
	transition: all 300ms ease-in-out;	
}



.site-header.is-shrunk .nav-btn-top-bar-text-before {
	display: inehrit;
	font-size: smaller;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
}
.site-header.is-shrunk .nav-btn-top-bar {
	display: inherit;
	font-size: 32px;
	transition: all var(--transition-speed-inner) ease-in-out;
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	/*justify-content: unset;*/
	margin-right: 15px;
}
/*
@media (max-width: 781px) {
	.site-header.is-shrunk .nav-btn-top-bar {
		margin-right: 5px;
	}
}*/

.site-header .nav-btn-top-bar i.icon {
	cursor: pointer;
	position: absolute!important;
	/*inset: 0;
	margin: auto;*/
	transition: opacity 200ms ease-in-out, transform 200ms ease-in-out;
}
.site-header .nav-btn-top-bar.active {
	transform: rotate(360deg);
	transition: all 650ms ease-in-out, transform 650ms ease-in-out;
}
.site-header .nav-btn-top-bar .menu-sharp {
	opacity: 1;
	transform: scale(1);
}
.site-header .nav-btn-top-bar .close-sharp {
	opacity: 0;
	transform: scale(0.9);
}
.site-header .nav-btn-top-bar.active .menu-sharp {
	opacity: 0;
	transform: scale(0.9);
}
.site-header .nav-btn-top-bar.active .close-sharp {
	opacity: 1;
	transform: scale(1);
}


.mega-menu {
	position: fixed;
	max-width: 100vw;
	background: var(--sk-gelb);
	height: 100%;
    left: 0;
    right: 0;
    visibility: hidden;
    opacity: 0;
    overflow-y: scroll;
    scrollbar-width: none;
	transition: all 750ms ease-in-out;
    z-index: 99999999999;
}

.mega-menu .nav-btn-close {
	cursor: pointer;
	font-weight: 400!important;
	border-radius: 8px;
	border: 1px solid var(--sk-gelb);
	/*display: inline-block;*/
	
}

.mega-menu .nav-btn-close i.icon  {
	font-size: 32px;
	vertical-align: middle;
}

.mega-menu.active {
	visibility: visible;
    opacity: 1;
    transform: translateY(0);
    transition: all var(--transition-speed-inner) ease-in-out;
    pointer-events: auto;
	border-top: 3px solid var(--sk-blau);
}

.mega-menu > div {
	padding-top: 40px;
}

.mega-menu nav > ul.wp-block-navigation__container {
	gap: 12px;
}
.mega-menu nav > ul.wp-block-navigation__container > li > a,
.mega-menu nav > ul.wp-block-navigation__container > li > button {
	font-weight: 600!important;
	font-family: var(--wp--preset--font-family--pt-serif-caption)!important;
	color: var(--sk-blau)!important;
	font-size: 1.5rem;
}

.mega-menu nav > ul.wp-block-navigation__container .wp-block-navigation__submenu-container {
	color: var(--sk-gelb);
	background: var(--sk-blau);
	border: 0;
}

.mega-menu .wp-block-navigation .wp-block-navigation__submenu-icon svg {
	transform: scale(2);
    margin-left: 15px;
}

.mega-menu .wp-block-navigation-submenu__toggle[aria-expanded=true]~.wp-block-navigation__submenu-icon svg {
	transform: rotate(180deg)  scale(2)!important;
}

.mega-menu nav > ul.wp-block-navigation__container .wp-block-navigation__submenu-container a {
	text-wrap: nowrap;
	font-weight: 400;
	font-size: 1.75rem;
}

@media (max-width: 781px) {
	.mega-menu > div {
		padding-top: 20px;
	}

	.mega-menu {
		padding-right: var(--wp--style--root--padding-right);
		padding-left: var(--wp--style--root--padding-left);
	}
	
	.mega-menu nav > ul.wp-block-navigation__container > li > a,
	.mega-menu nav > ul.wp-block-navigation__container > li > button {
		font-size: 2rem;
	}
	.mega-menu .wp-block-navigation .wp-block-navigation__submenu-icon svg {
		margin-left: 5px;
		transform: scale(2.5)!important;
	}
	.mega-menu .wp-block-navigation-submenu__toggle[aria-expanded=true]~.wp-block-navigation__submenu-icon svg {
		transform: rotate(180deg)  scale(2.5)!important;
	}

	.mega-menu nav > ul.wp-block-navigation__container .wp-block-navigation__submenu-container a {
		font-size: 1.25rem;
	}
}

.mega-menu nav > ul.wp-block-navigation__container > li > a.current, 
.site-header .header-nav a.current {
	color: black!important;
}
.site-header.is-shrunk .header-nav-small a.current,
.site-header.is-shrunk .header-nav-small a.current > span {
	color: var(--sk-gelb)!important;
}



@media (min-width: 782px) and (max-width: 1024px) {
	.site-header .header-nav > ul {
		gap: 20px;
	}
	
	.site-header .header-nav ul > li:first-child {
		display: none;
	}
	.site-header .header-nav  {
			font-size: 0.95rem;
		}

}


/* Footer */

.site-footer {
	margin-top: 0!important;
}

.site-footer .partner-logos {	
    opacity: 0.7;
    mix-blend-mode: multiply;
    filter: grayscale(100%);
	transition: all .25s ease-in-out;
}

.site-footer .partner-logos:hover {	
    opacity: 1;
    mix-blend-mode: multiply;
    filter: none;
	transition: all .25s ease-in-out;
}
.site-footer .partner-logos figure.size-full {
	width: 100%;
}



@media (max-width: 781px) {
    .site-footer .partner-logos > div .wp-block-column {
        padding-top: 20px!important;
    }
	.site-footer .partner-logos > div .wp-block-column:first-child,
	.site-footer .partner-logos > div .wp-block-column:last-child {
		padding-top: 0!important;
	}
}

.site-footer .copyright-info {
	margin-top: 70px;
	padding-top: 20px;
	border-top-width: 5px;
    border-top-style: dashed;
    border-top-color: #d8d8d8;
}

#scrollToTopBtn {
    transition: all 0.3s ease;
    opacity: 0;
    transform: translateY(20px);
    color: #1165af;
    background: transparent;
    position: fixed;
    right: 0;
    left: 0;
    bottom: 38px;
    z-index: 1;
    justify-content: center;
    align-items: center;
    padding: 0 0 15px 0;
    border-radius: 8px;
    border: 0;
    cursor: pointer;
}
#scrollToTopBtn i.icon {
	font-size: 32px;
}
#scrollToTopBtn.visible {
  opacity: 1;
  transform: translateY(0);
}
#scrollToTopBtn:hover {
    transform: translateY(-5px);
     text-shadow: 0 4px 30px rgba(0,0,0,0.2);
    color: #333;
}
.chevron-animation {
    animation: bounceBtn 3s infinite;
}
@keyframes bounceBtn {
    0%, 20%, 50%, 80%, 100% {transform: translateY(0);}
    40% {transform: translateY(-8px);}
    60% {transform: translateY(-4px);}
}

.chevron-animation-reverse {
    animation: bounceBtnReverse 2.5s infinite;
}
@keyframes bounceBtnReverse {
    0%, 20%, 50%, 80%, 100% {transform: translateY(0);}
    40% {transform: translateY(8px);}
    60% {transform: translateY(4px);}
}


.site-footer .fixed-footer {
	position: fixed;
    bottom: 0px;
    left: 0px;
    right: 0px;
    background-color: #fff;
    text-align: left;
    border-top-width: 1px;
    border-top-style: solid;
    border-top-color: #7f7f7f;
    z-index: 9999;
    box-shadow: 0px -15px 30px rgba(255, 255, 255, 0.81);
	font-size: 1rem;
}

.site-footer .footer-content-row {
	height: 40px;
	display: flex;
	width: 100%;
	flex-direction: row;
	align-items: stretch;
	justify-content: center;
}
.site-footer .footer-content-row a {
	text-decoration: none;
}
.site-footer .footer-content-row i.icon {
	font-size: 32px;
	vertical-align: middle;
}

.site-footer .footer-content-row > div:first-child i.icon,
.site-footer .footer-content-row > div:last-child i.icon {
	margin-right: 5px;
	font-size: 24px;
}
.site-footer .footer-content-row > div {
	width: 20%;
	align-items: center;
	flex-direction: row;
	display: flex;
	justify-content: center;
}
.site-footer .footer-content-row > div:first-child,
.site-footer .footer-content-row > div:last-child {
	width: 40%;
}

.site-footer .footer-content-row > div:first-child {
	border-right: 1px solid #d8d8d8;
}
.site-footer .footer-content-row > div:last-child {
	width: 40%;
	border-left: 1px solid #d8d8d8;
}

@media (max-width: 781px) {
	.site-footer .fixed-footer {
		font-size: 13px;
	}
	.site-footer .footer-content-row {
		gap: 20px;
	}
	
	.site-footer .footer-content-row > div {
		width: auto;
	}
	.site-footer .footer-content-row > div:first-child,
	.site-footer .footer-content-row > div:last-child {
		width: 45%;
	}
	
	.site-footer .footer-content-row i.icon {
		font-size: 24px;
	}
	.site-footer .footer-content-row > div:first-child i.icon,
	.site-footer .footer-content-row > div:last-child i.icon {
		font-size: 18px;
	}
}



/* Page Stuff */

.hero-container {
	
}

.hero-content {
	position: relative;
}

.weil-alles-circle {
	transform: rotate(15deg);
    background-color: var(--sk-gelb);
    border-radius: 100px;
    text-align: left;
    align-items: center;
    justify-content: center;
    height: 150px;
    width: 150px;
    position: absolute;
    top: -10px;
    right: 0px;
    z-index: 1010;
	border: 5px solid #d8d8d8;
    box-shadow: -5px -4px 35px #606e79;
    aspect-ratio: 1;
	display: flex;
    flex-wrap: nowrap;
    flex-direction: column;
}

html.menu-active .weil-alles-circle, 
html.menu-active .scroll_info {
	display: none;
}

main.is-shrunk .weil-alles-circle {
	opacity: 0;
	height: 0;
	width: 0;
	transition: all .2s linear;
}

.weil-alles-circle > p {	
    color: var(--sk-blau);
    padding-top: 10px;
    padding-left: 10px;
    padding-right: 10px;
    padding-bottom: 10px;
    text-align: center;
    font-weight: 700;
	font-size: .9rem;
}


@media (max-width: 781px) {
	.hero-container {
		min-height: 30vh!important;
		background-position: center 0%!important;
	}
	
	.weil-alles-circle {
		height: 120px;
		width: 120px;
		border-width: 3px;
		top: -8px;
	}
	.weil-alles-circle p {
		font-size: .85rem;
	}
}




.big-blue-buttons-container {
	gap: 20px!important;
}
/*
.big-blue-buttons-container > div > div {
	justify-content: center;
}

.big-blue-buttons-container > div > div p {
	text-align: center;
}*/

.big-blue-buttons-container a.big-blue-button {
	background: var(--sk-blau);
	color: var(--sk-gelb);
	border-radius: 8px;
	height: 115px;
	display: block;
	position: relative;
	text-align: center;
}

.big-blue-buttons-container a.big-blue-button:hover {
	background: var(--sk-gelb);
	color: var(--sk-blau);
}

.big-blue-buttons-container a.big-blue-button i.icon {
	font-size: 40px;
}
.big-blue-buttons-container a.big-blue-button.ebay i.icon {
	font-size: 64px;
}
.big-blue-buttons-container a.big-blue-button i.icon.link-external {
	position: absolute;
    opacity: 0.35;
    top: 18px;
    right: 16px;
    color: #d4e3f1;
	font-size: 20px;
}

.big-blue-buttons-container a.big-blue-button:hover i.icon.link-external {
	color: var(--sk-blau);
}

.big-blue-buttons-container a.big-blue-button > span {
	left: 0;
    right: 0;
    display: block;
	position: absolute;
	top: 20px;
	display: block;
	/*padding-bottom: 5px;*/
}
.big-blue-buttons-container a.big-blue-button.ebay > span {
	top: 10px;
}
.big-blue-buttons-container a.big-blue-button > span.icon-text {
	top: auto;
	bottom: 15px;
	/*font-size: 1rem;*/
	
	/*padding-bottom: 5px;*/
}

@media (min-width: 782px) {
	body.home .big-blue-buttons-container {
		margin-top: -70px !important;
	}
	body.home .mega-menu  .big-blue-buttons-container {
		margin-top: 0px !important;
	}
	body.home .big-blue-buttons-container a.big-blue-button {
		box-shadow: rgb(96, 110, 121) 0px -6px 18px;
        border-width: 1px;
        border-style: solid;
        border-color: rgb(255, 255, 255);
        border-image: initial;
	}
}

@media (max-width: 781px) {
	.big-blue-buttons-container:not(.mega-menu  .big-blue-buttons-container) {
		grid-template-columns: repeat(2, minmax(0, 1fr))!important;
		gap: 15px!important;
		margin-top: -20px!important;
	}
	.big-blue-buttons-container a.big-blue-button > span.icon-text:not(.mega-menu  .big-blue-buttons-container) {
		font-size: 11px;
		font-weight: 400;
        text-transform: uppercase;
	}

}



.scroll_info  {
	font-size: 10px;
	font-weight: 600;
	padding-top: 0;
	margin-top: 20px;
	margin-bottom: -20px;
	animation: bounceBtnReverse 2.5s infinite;
	position: relative;
	z-index: 999;
	cursor: pointer;
}
.scroll_info i.icon {
	transform: rotate(180deg);
	font-size: 24px;
}

@media (max-width: 781px) {
	.scroll_info  {
		font-size: 14px;
		font-weight: 100;
		margin-top: 40px;
	}
}

.seiten-symbol {
	position: absolute;
	right: 2px;
	top: 105px;
}
.seiten-symbol i.icon {
	color: var(--sk-hellblau);
	font-size: 120px;
}
@media (max-width: 781px) {
	.seiten-symbol i.icon {
		font-size: 60px;
	}
}

h1.wp-block-post-title {
	display: inline-block;
	font-size: 28px!important;
	text-wrap: unset;
}

@media (max-width: 781px) {
	h1.wp-block-post-title {
	}
}




/* Lauftext */

/* ===== Marquee Keyframes ===== */
@keyframes marquee-left {
	0%   { transform: translateX(100%); }
	100% { transform: translateX(-100%); }
}

/* ===== Marquee Container ===== */
.marquee-container {
	overflow: hidden;
	white-space: nowrap;
	position: relative;
	width: 100%;
}

/* ===== Variante 1: Links laufend ===== */
.marquee-left .marquee-content {
	display: inline-block;
	animation: marquee-left 10s linear infinite;
}

/* ===== Hover Pause für alle ===== */
.marquee-left .marquee-content:hover,
.marquee-right .marquee-content:hover,
.marquee-bounce .marquee-content:hover {
	animation-play-state: paused;
}

/* ===== Fade Edges ===== */
.fade-edges {
	-webkit-mask-image: linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
	mask-image: linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
}



.light-blue-box {
    padding-top: 10px;
    padding-left: 10px;
    padding-right: 10px;
    margin-top: 20px;
    padding-bottom: 10px;
    background-color: var(--sk-hellblau);	
	border: 5px dotted var(--sk-gelb);
}

.light-blue-box i.icon {
	vertical-align: middle;
	font-size: 56px;
	margin-right: 10px;
}

.light-blue-box a {
	text-decoration: none;
}

.light-blue-box p:not(.light-blue-box p:first-child) {
	font-size: 1rem!important;
	margin-top: 10px!important;
	line-height: 1.6;
}



.keine-vor-tuer {
	background: var(--sk-hellblau);
	text-align: center;
    font-weight: 600;
	font-size: 1rem;
    letter-spacing: 5px;
    /*margin-top: 1.5rem;
    margin-bottom: 2rem;*/
    padding-top: 10px;
    padding-right: 4em;
    padding-bottom: 10px;
    padding-left: 4em;
}



@media (max-width: 781px) {
    .keine-vor-tuer {
        padding-right: 1.5em;
        padding-top: 8px;
        padding-bottom: 8px;
        font-size: 80%;
        letter-spacing: 3px;
        line-height: 155%;
        padding-left: 1.5em;
    }
}








/* Cookie Banner Anpassungen */

.ccm-root {
	font-size: 13px!important;
	font-family: var(--wp--preset--font-family--open-sans)!important;
}

.ccm-widget--text .ccm-widget--title {
	font-size: 15px!important;
	font-family: var(--wp--preset--font-family--pt-serif)!important;
}

.ccm-widget.ccm--alignment--bottom .ccm-inner-overflow {
	text-align: center!important;
}

.ccm-root .ccm-widget--buttons .button, 
.ccm-root .ccm-widget--buttons button, 
.ccm-root .button, .ccm-root button:not(.ccm-widget--purposes button.ccm-info-button) {
	font-weight: 500!important;
	font-size: 13px!important;
	min-height: 32px!important;
	padding: 3px 10px 1px 10px!important;
}
.ccm-root button.ccm-info-button,
.ccm-widget--purposes button.ccm-info-button {
	color: var(--sk-blau)!important;
	background: var(--sk-gelb)!important;
}

.ccm-widget .ccm-modal--footer {
	padding-top: 15px!important;
	justify-content: center!important;
	color: var(--sk-hellblau)!important;
}

.ccm-widget .ccm-modal--footer>:not(:last-child) {
	display: none;
}

.ccm-widget .ccm-powered-by a:link, .ccm-widget .ccm-powered-by a:visited {
	font-size: 11px;
}


.wp-block-post-date__modified-date time::before {
    content: "Letze Änderung: ";
}


.btn-cookie-settings {
	position: absolute;
	z-index: 999;
	left: 0;
	top: calc(15px + var(--header-height-large));
	background: rgba(255,255,255,0.8);
	color: #000;
	font-size: 1rem;
	padding: 0!important;
	border-radius: 0 4px 4px 0;
	border-style: solid;
	border-color: #e0e0e0;
	border-width: 1px 1px 1px 0;
}
body.top-line-active .btn-cookie-settings {
	top: calc(50px + var(--header-height-large));
}


.btn-cookie-settings i.icon {
	font-size: 30px;
	vertical-align: middle;
}

.btn-cookie-settings p {
	padding-top: 6px;
	padding-bottom: 6px;
	padding-left:4px;
	padding-right: 4px;
}
.btn-cookie-settings p strong {
	display: none;
	cursor: pointer;
}

.btn-cookie-settings p:hover strong {
	display: inline-block;
	padding-left: 4px;
	padding-right: 6px;
}
.btn-cookie-settings p strong:hover {
	color: var(--sk-blau);
}



@media (max-width: 781px) {
	
	.btn-cookie-settings i.icon {
		font-size: 25px;
	}
	
	.btn-cookie-settings {
		top: calc(15px + var(--header-height-large-mobile));
	}
	body.top-line-active .btn-cookie-settings {
		top: calc(50px + var(--header-height-large-mobile));
	}

}




/* FAQs */
/* Accordion mit Details Block CSS */

.faq-accordion h4.faq-category-title {
  padding-top: 0;
  border: 0;
  margin-bottom: 0;
}

.faq-accordion .toggle-accordion {
  position: absolute;
  right: 0;
  cursor: pointer;
  font-size: 80%;
  background: #c0c0c0;
  color: #fff;
  text-shadow: 0 -1px 5px rgba(0, 0, 0, 0.4);
  border-radius: 4px;
  padding: 3px 8px;
  text-transform: uppercase;
  transition: all 0.4s ease-in-out;
}
.faq-accordion .toggle-accordion:hover {
  color: #000;
  background: #eee;
}
.accordion-group {
  padding-padding: 5px;
  border-bottom: 5px solid #f2f2f2;
}

.accordion-group details {
	margin-top: 0;
}
.accordion-group details .details-content {
	padding-bottom: 15px;
}

.accordion-group .details-content {
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transition: max-height 0.3s ease-in-out, opacity 0.7s ease-in-out;
}
.block-editor-iframe__body .accordion-group .details-content,
body.wp-admin .accordion-group .details-content {
  overflow: initial;
  max-height: initial;
  opacity: 1;
  transition: max-height 0.3s ease-in-out, opacity 0.7s ease-in-out;
}
details[open] .details-content {
  display: block;
}

.wp-block-details summary::marker,
.wp-block-details summary::-webkit-details-marker {
    display: none !important;
    content: "";
}

.wp-block-details summary {
  display: flex;
  justify-content: space-between;
  font-size: 2rem;
  line-height: 2.75rem;
  margin-bottom: 15px;
  padding-right: 75px;
  color: #333;
  position: relative;
  padding-top: 15px;
  border-top: 5px solid #f2f2f2;
}
@media (max-width: 781px) {
  .wp-block-details summary {
    font-size: 2rem;
  }
  
}

.wp-block-details summary::after {
  content: "";
  display: inline-block;
  width: 16px;
  height: 12px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  padding-left: 30px;
  margin-top: -6px;
  position: absolute;
  top: 50%;
  right: 1%;
  background-image: url(https://sozialkaufhaus-stormarn.de/wp-content/uploads/2025/12/chevron-direction-bottom-icon.svg);
}

.accordion-title[open] summary::after {
    rotate: 180deg;
}

.accordion-group .details-content {
    margin-block-start: 0 !important;
    /* fix for jumpyness */
}






/* Anpassungen für Popup FAQ etc. */

.pum-content h4 {
	margin-left:0!important;
}
.pum-content .toggle-accordion {
	top: -40px;
}
.pum-content .accordion-group summary {
	font-size: 1.5rem;
}




/* CAROUSEL */

/* Arrows */
.wp-block-splide-carousel .splide__arrow {
    align-items: center;
    background: var(--sk-blau);
    border: 0;
    border-radius: 0;
    cursor: pointer;
    display: flex;
    height: 2em;
    justify-content: center;
    opacity: .95;
    padding: 0;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 2em;
    z-index: 1;
}
.wp-block-splide-carousel .splide__arrow svg {
    fill: var(--sk-gelb);
}
.wp-block-splide-carousel .splide__arrow:disabled {
    opacity: .5;
}



@media screen and (max-width: 781px) {
	.wp-block-splide-carousel .splide__slide img {
		height: 220px!important;
	}
	
}.wp-block-splide-carousel .splide__arrows--ltr .splide__arrow--prev {
		/*left: calc(-2em - 30px);*/
		left: initial;
	}
	.wp-block-splide-carousel .splide__arrows--ltr .splide__arrow--next {
		/*right: calc(-2em - 30px);*/
		right: 0;
	}
@media screen and (min-width: 782px) {
	
	.wp-block-splide-carousel .splide__pagination {
		bottom: -35px;
	}
}




/* Produkte */

.pad-left {
	margin-right: 0px!important;
	margin-left: 0px!important;
	/*padding-left: calc((100vw - var(--wp--style--global--wide-size)) / 2);*/
	padding:0;
}

.pad-left figure.wp-block-splide-carousel {
    margin-right: 0px;
    cursor: ew-resize;
}

@media (max-width: 781px) {
  .pad-left {
		margin-right: 0!important;
		/*margin-left: 0!important;*/
		/*padding-left: 20px;*/
        overflow:hidden;
	}
  .pad-left .wp-block-splide-carousel__container {
    margin-top: 0!important;
	
	}
  .pad-left figure.wp-block-splide-carousel {
    margin-top: 0!important;
    margin-right: -40px;
    /*margin-left: 20px;*/
    padding-bottom: 26px;
  }
  
  .pad-left figure.wp-block-splide-carousel .splide__pagination {
    bottom:0;
    margin-left: -30px;
  }
  
}
/*
.pad-left #splide01-list {
	padding-right: 20%!important;
}*/

.pad-left .splide__arrow {
  align-items: center;
  background: #ccc;
  border: 0;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  height: 3.5rem;
  justify-content: center;
  opacity: .7;
  padding: 12px;
  width: 3.5rem;
  z-index: 1;
  transition: all .5s;
}

.pad-left .custom-arrows-top, 
.pad-left .custom-arrows {
  display: flex;
  gap: 20px;
  padding-left: 0!important;
  align-items: center;
  margin-left: 35px;
}
.pad-left .custom-arrows-top .arrows-text-mobil {
    display: none!important;
}

@media (max-width: 781px) {
    .pad-left .custom-arrows-top .arrows-text, 
	.pad-left .custom-arrows-top .splide__arrows {
		display:none!important;
	}
  .pad-left .custom-arrows-top .arrows-text-mobil {
      display: block!important;
    padding-bottom: 8px;
    /*margin-left: -10px;*/
  }
}


.pad-left .custom-arrows-top .splide__arrows, 
.pad-left .custom-arrows .splide__arrows {
  display: flex;
  gap: 10px;
}

.pad-left .splide__arrows button:first-child {
	transform: rotate(180deg);
}

.pad-left button:disabled {
    opacity: .3;
}

.pad-left .splide__slide figure {
  position: relative;
  display: block;
  max-width: 100%;
  border-radius: 7px;
  margin: 0 1em 0 0;
}

.pad-left .splide__slide figure img {
  border-radius: 4px;
  height: 280px;
}
@media (max-width: 781px) {
  .pad-left .splide__slide figure img {
    height: 330px;
  }
}

.pad-left  .splide__slide figure::after {
	content: "";
	position: absolute;
	top: 3px;
	left: 3px;
	right: 3px;
	bottom: 3px;
	border: 2px solid rgba(255,255,255,0.5);
	border-radius: 4px;
	pointer-events: none;
}


#productsCarousel  .splide__slide figure img {
	border-radius: 6px;
}
#productsCarousel .splide__slide figure::after {
	border-color: rgba(255, 223, 35, 0.8);
	border-width: 3px;
	border-radius: 5px;
}
#productsCarousel .splide__slide figure::before {
	content: "";
	position: absolute;
	top: 1px;
	left: 1px;
	right: 1px;
	bottom: 1px;
	border: 7px solid rgba(17, 101, 175, 0.9);
	border-radius: 6px;
	pointer-events: none;
}
#productsCarousel .splide__slide .desc-text {
	position: absolute;
	top: 14px;
	left: -7px;
	background: rgba(255, 223, 35, .85);
	color: #222;
	padding: 1px 8px 1px 11px;
	border-radius: 10px;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.05rem;
	text-transform: uppercase;
	border: 1px solid #111;
	box-shadow: 3px 3px 5px 2px #555;
}





/* TABS */

.tab-container {
	margin-top: 70px;
}

.tab-container .wp-block-button a {
	background-color: none!important;
	background: none!important;
	border: 0;
	border-radius: 0!important;
	box-shadow: none;
	border-bottom: 3px solid white;
	margin-bottom: 0px;
	font-weight: 700;
	font-family: var(--wp--preset--font-family--pt-serif);
	text-wrap: nowrap;
}
@media (max-width: 781px) {
	.tab-container .wp-block-button a {
		font-size: 14px;
		padding-right: 14px;
		padding-left: 14px;
	}
}
.tab-container .wp-block-button a:hover {
	border-color: none;
	color: var(--sk-blau)!important;
	border-bottom: 3px solid var(--sk-blau)!important;
}
.tab-container .wp-block-button.tab-active a {
	background: var(--sk-hellblau)!important;
	border-bottom: 3px solid var(--sk-blau)!important;
	color: var(--sk-blau)!important;
}

body.page .tab-container .tab-content-container > div  {
	display: none;
}

body.page .tab-container .tab-content-container > div.tab-active {
	display: block!important;
}


.tab-container .wp-block-buttons {
	border-bottom: 1px solid var(--sk-blau);
}

figure.map-image-desktop,
figure.map-image-mobile  {
	position: relative;
}
figure.map-image-desktop:after,
figure.map-image-mobile:after {
	content: 'Copyright OpenStreetMap';
	cursor: help;
	position: absolute;
    right: 0;
    bottom: 0;
	padding: 2px 5px;
	background: rgba(255,255,255, 0.7);
	font-size: x-small;
	font-weight: 700;
	color: var(--sk-blau);
}


@media (max-width: 781px) {
	
	.map-image-desktop {
		display: none;
	}
	.map-image-mobile {
		margin-top: 0;
	}
}
@media (min-width: 782px) {
	.map-image-mobile {
		display: none;
	}
}
.route-btn-link i.icon {
	font-size: 100px;
	vertical-align: middle;
	margin-bottom: 10px;
}


.call-phone-link a {
	text-wrap: nowrap;
	font-size: 1.75rem;
	text-decoration: none;
}
.call-phone-link i.icon {
	font-size: 48px;
	vertical-align: middle;
	margin-right: 10px;
	margin-top: -5px;
}



.kundenkarte-image img {
	width: 45%;
    border-right: 2px solid var(--sk-blau);
    border-left: 2px solid var(--sk-blau);
}
@media (max-width: 781px) {
	.kundenkarte-image img {
		width: 100%;
		border: 0;
	}
}

ul.even-odd-liste {
  list-style: none;
  padding-left: 0;
}

ul.even-odd-liste li {
	padding: 12px 20px 12px 25px;
	display: flex;
    flex-direction: row;
    align-items: center;
}
ul.even-odd-liste li.odd {
	/*background: var(--sk-hellblau);*/
	background: #eceeef;
}


ul.even-odd-liste li i.icon {
  display: inline-block;
  margin-right: 30px;
  /*font-size: 24px!important;*/
  vertical-align: middle;
  margin-top: -12px;
}

ul.even-odd-liste li i.icon:before {
	height: 32px;
	width: 32px;
}


/*
ul.even-odd-liste li:before {
  content: '✓';
  font-weight: bold;
  display: inline-block;
  margin-right: 25px;
  font-size: 1.5rem;
}

ul.even-odd-liste li.icon-check:before {
	display: none;
}*/
































:root {
  --button-background-color: #000;
  --button-border-radius: 8px;
  --button-border: 2px solid #000;
  --button-box-shadow: none;
  --button-color: #fff;
  --button-font-family: inherit;
  --button-font-size: inherit;
  --button-font-weight: inherit;
  --button-hover-background-color: inherit;
  --button-hover-border-radius: 8px;
  --button-hover-border: 2px solid #000;
  --button-hover-box-shadow: none;
  --button-hover-color: #000;
  --button-hover-padding: 5px 20px;
  --button-letter-spacing: 1px;
  --button-margin-top: 1rem;
  --button-padding: 5px 20px;
  --button-text-transform: uppercase;
  --button-transition-duration: 300ms;
  --checkbox-gap: 2px 20px;
  --form-color: inherit;
  --input-background: #f3f3f3;
  --input-border: 2px solid #f3f3f3;
  --input-border-radius: 0;
  --input-box-shadow: none;
  --input-color: #000;
  --input-focus-background: transparent;
  --input-focus-border: 2px solid #000;
  --input-focus-border-radius: 0;
  --input-focus-box-shadow: none;
  --input-focus-color: #000;
  --input-font-family: inherit;
  --input-font-size: inherit;
  --input-padding: 8px 12px;
  --input-placeholder-color: #333;
  --input-placeholder-opacity: 0.8;
  --label-color: #000;
  --link-color: #00f;
}

/* Stop touching the code!!! */
/* #region Button Design */
form.wpcf7-form input.wpcf7-submit {
  background-color: var(--button-background-color);
  border-radius: var(--button-border-radius);
  border: var(--button-border);
  box-shadow: var(--button-box-shadow);
  cursor: pointer;
  color: var(--button-color);
  font-family: var(--button-font-family);
  font-size: var(--button-font-size);
  font-weight: var(--button-font-weight);
  letter-spacing: var(--button-letter-spacing);
  margin-top: var(--button-margin-top);
  padding: var(--button-padding);
  text-transform: var(--button-text-transform);
  transition: all var(--button-transition-duration) ease;
}
form.wpcf7-form input.wpcf7-submit:hover {
  background-color: var(--button-hover-background-color);
  border-radius: var(--button-hover-border-radius, var(--button-border-radius));
  border: var(--button-hover-border, var(--button-border));
  box-shadow: var(--button-hover-box-shadow, var(--button-box-shadow));
  color: var(--button-hover-color, var(--button-color));
  padding: var(--button-hover-padding, var(--button-padding));
}

/* #endregion Button Design */
/* #region Placeholder Pseudo Class */
form.wpcf7-form input[type=email]::-webkit-input-placeholder, form.wpcf7-form input[type=text]::-webkit-input-placeholder, form.wpcf7-form input[type=tel]::-webkit-input-placeholder, form.wpcf7-form input[type=password]::-webkit-input-placeholder, form.wpcf7-form textarea::-webkit-input-placeholder {
  color: var(--input-placeholder-color);
  opacity: var(--input-placeholder-opacity);
}
form.wpcf7-form input[type=email]::-moz-placeholder, form.wpcf7-form input[type=text]::-moz-placeholder, form.wpcf7-form input[type=tel]::-moz-placeholder, form.wpcf7-form input[type=password]::-moz-placeholder, form.wpcf7-form textarea::-moz-placeholder {
  color: var(--input-placeholder-color);
  opacity: var(--input-placeholder-opacity);
}
form.wpcf7-form input[type=email]:-ms-input-placeholder, form.wpcf7-form input[type=text]:-ms-input-placeholder, form.wpcf7-form input[type=tel]:-ms-input-placeholder, form.wpcf7-form input[type=password]:-ms-input-placeholder, form.wpcf7-form textarea:-ms-input-placeholder {
  color: var(--input-placeholder-color);
  opacity: var(--input-placeholder-opacity);
}
form.wpcf7-form input[type=email]:-moz-placeholder, form.wpcf7-form input[type=text]:-moz-placeholder, form.wpcf7-form input[type=tel]:-moz-placeholder, form.wpcf7-form input[type=password]:-moz-placeholder, form.wpcf7-form textarea:-moz-placeholder {
  color: var(--input-placeholder-color);
  opacity: var(--input-placeholder-opacity);
}

/* #endregion */
form.wpcf7-form {
  color: var(--form-color);
  /*font-size: 1rem;*/
}
form.wpcf7-form input[type=email], form.wpcf7-form input[type=text], form.wpcf7-form input[type=tel], form.wpcf7-form input[type=password], form.wpcf7-form textarea {
  background: var(--input-background);
  border: var(--input-border);
  border-radius: var(--input-border-radius);
  box-shadow: var(--input-box-shadow);
  color: var(--input-color);
  font-family: var(--input-font-family);
  font-size: var(--input-font-size);
  padding: var(--input-padding);
  width: 100%;
  box-sizing: border-box;
}
form.wpcf7-form input[type=email]:focus, form.wpcf7-form input[type=text]:focus, form.wpcf7-form input[type=tel]:focus, form.wpcf7-form input[type=password]:focus, form.wpcf7-form textarea:focus {
  background: var(--input-focus-background, var(--input-background));
  border: var(--input-focus-border, var(--input-border));
  border-radius: var(--input-focus-border-radius, var(--input-border-radius));
  box-shadow: var(--input-focus-box-shadow, var(--input-box-shadow));
  color: var(--input-focus-color, var(--input-color));
}
/*
form.wpcf7-form a {
  color: var(--link-color);
}*/
form.wpcf7-form label {
  color: var(--label-color);
}
form.wpcf7-form .wpcf7-checkbox {
  display: flex;
  flex-flow: row wrap;
  gap: var(--checkbox-gap);
}
form.wpcf7-form .wpcf7-checkbox > .wpcf7-list-item {
  margin-left: 0;
}
form.wpcf7-form .dscf7 .wpcf7-checkbox {
  display: inline-block;
}


form.wpcf7-form .form_float {
    width: auto;
    min-width: 180px;
    float: left;
    margin-right: 1%; margin-bottom: 2%;
}
form.wpcf7-form .form_float_last {
    margin-right: 0px;
}
@media (max-width: 767px) {
	form.wpcf7-form .form_float {
	width: 100%;
       float: none;
	}
}

form.wpcf7-form .form_half {
    width: 49.5%;
    float: left;
    margin-right: 1%;margin-bottom: 2%;
}
form.wpcf7-form .form_half_last {
    margin-right: 0px;
}
@media (max-width: 767px) {
	form.wpcf7-form .form_half {
	width: 100%;
	}
}

.wpcf7-not-valid-tip {
  font-size: 1.15rem!important;
  font-weight: bold!important;
  letter-spacing: 1px;
  font-family: monospace!important;
  padding-left: 3px!important;
  padding-top: 2px!important;
}

.wpcf7 form .wpcf7-response-output {
  margin: 1.5em 0em!important;
  padding: 0.4em 0.75em!important;
  border: 0!important;
  background: #1165af!important;
  color: #ffdf23!important;
}

.wpcf7 form .upload_form{
  clear: both;
  float: none;
}
.wpcf7 form .upload_form .wpcf7-form-control-wrap {
  display: block!important;
}

form[data-status="init"] .wpcf7-not-valid-tip{
display: none;
}


/* Response */

.swal2-title {
  font-size: 1rem!important;
}
.swal2-html-container,
.swal2-styled.swal2-confirm{
  font-size: 1.75rem!important;
}

/* if send */

.wpcf7-spinner {
  visibility: hidden;
  display: inline-block;
  background-color: #23282d; /* Dark Gray 800 */
}

form.wpcf7-form input.wpcf7-submit {
  display: none;
}

.button {
  border: none;
  background: #ffdf23;
  color: #1165af;
  padding: 10px 16px;
  position: relative;
  cursor: pointer;
  overflow: hidden;
  border-radius: 5px;
  min-width: 125px;
  width: 100%;
}

.button__progress {
  position: absolute;
  height: 100%;
  width: 0%;
  top: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.2);
  transition: width 1.75s ease-in-out;
}
form.submitting .button__progress {
  width: 100%;
}
form.resetting .button__progress,
form.success .button__progress {
  transition: all 0.5s ease-in-out;
  width: 100%;
}

.button__text {
  position: relative;
}

.required-info {
  background: rgba(255,223,35,0.15);
  border: 1px solid #bbb;
  padding: 5px 10px;
  margin-top: 0; 
  display: inline-block;
  border-radius: 3px;
}
