/* ===========================
   FONTS
   =========================== */

/* Elza Regular (400) */
@font-face {
  font-family: "elza";
  src: url("/wp-content/themes/freevesto/fonts/Elza-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
}

/* Elza Medium (500) */
@font-face {
  font-family: "elza";
  src: url("/wp-content/themes/freevesto/fonts/Elza-Medium.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
}

/* Elza SemiBold (600) */
@font-face {
  font-family: "elza";
  src: url("/wp-content/themes/freevesto/fonts/Elza-Semibold.woff2") format("woff2");
  font-weight: 600;
  font-style: normal;
}

/* Elza Bold (700) */
@font-face {
  font-family: "elza";
  src: url("/wp-content/themes/freevesto/fonts/Elza-Bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
}

/* ===========================
   MISC
   =========================== */

.page .entry-title {
    display: none;
}

.main-navigation {
    display: none;
}

.site-info {
    display: none;
}

.edit-link {
	display: none;
}

body {
	margin: 0;
}

/* ===========================
   CONTAINERS
   =========================== */
.container {
  margin: 0 auto;
  width: 100%;
}

@media (min-width: 680px) {
  .container { margin: 0 auto; }
}

@media (min-width: 1024px) {
  .container { max-width: 928px; margin: 0 auto; }
}

@media (min-width: 1280px) {
  .container { max-width: 1216px; margin: 0 auto; }
}

@media (min-width: 1920px) {
  .container { max-width: 1840px; margin: 0 auto; }
}

.container-fluid {
  width: 100%;
  margin-left: 1rem;
  margin-right: 1rem;
}

@media (min-width: 680px) {
  .container-fluid { margin-left: 2rem; margin-right: 2rem; }
}

@media (min-width: 1024px) {
  .container-fluid { margin-left: 3rem; margin-right: 3rem; }
}

@media (min-width: 1280px) {
  .container-fluid { margin-left: 2rem; margin-right: 2rem; }
}

@media (min-width: 1920px) {
  .container-fluid { margin-left: 2.5rem; margin-right: 2.5rem; }
}


/* ===========================
   GRID WRAPPER
   =========================== */
.grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 1rem; /* S default gutter */
  margin: 0 1rem;	

}

@media (min-width: 680px) {
	.grid { 
		gap: 2rem; 
  		margin: 0 2rem;
		}
}

@media (min-width: 1024px) {
  	.grid { 
		gap: 2rem; 
  		margin: 0 3rem;
	}
}

@media (min-width: 1280px) {
  .grid { 
		gap: 2rem; 
  		margin: 0 2rem;
		}
}

@media (min-width: 1920px) {
  .grid { 
		gap: 2rem; 
  		margin: 0 2.5rem;
		}
}


/* ===========================
   COLUMNS
   =========================== */

/* Base (<680px) */

/*[class*="col-span-"] { grid-column: span 12; }*/

.col-span-1  { grid-column-end: span 1; }
.col-span-2  { grid-column-end: span 2; }
.col-span-3  { grid-column-end: span 3; }
.col-span-4  { grid-column-end: span 4; }
.col-span-5  { grid-column-end: span 5; }
.col-span-6  { grid-column-end: span 6; }
.col-span-7  { grid-column-end: span 7; }
.col-span-8  { grid-column-end: span 8; }
.col-span-9  { grid-column-end: span 9; }
.col-span-10 { grid-column-end: span 10; }
.col-span-11 { grid-column-end: span 11; }
.col-span-12 { grid-column-end: span 12; }

.start-1  { grid-column-start: 1; }
.start-2  { grid-column-start: 2; }
.start-3  { grid-column-start: 3; }
.start-4  { grid-column-start: 4; }
.start-5  { grid-column-start: 5; }
.start-6  { grid-column-start: 6; }
.start-7  { grid-column-start: 7; }
.start-8  { grid-column-start: 8; }
.start-9  { grid-column-start: 9; }
.start-10 { grid-column-start: 10; }
.start-11 { grid-column-start: 11; }
.start-12 { grid-column-start: 12; }

/* M (>=680px) */
@media (min-width: 680px) {
  .m-col-span-1  { grid-column-end: span 1; }
  .m-col-span-2  { grid-column-end: span 2; }
  .m-col-span-3  { grid-column-end: span 3; }
  .m-col-span-4  { grid-column-end: span 4; }
  .m-col-span-5  { grid-column-end: span 5; }
  .m-col-span-6  { grid-column-end: span 6; }
  .m-col-span-7  { grid-column-end: span 7; }
  .m-col-span-8  { grid-column-end: span 8; }
  .m-col-span-9  { grid-column-end: span 9; }
  .m-col-span-10 { grid-column-end: span 10; }
  .m-col-span-11 { grid-column-end: span 11; }
  .m-col-span-12 { grid-column-end: span 12; }
	
  .m-start-1  { grid-column-start: 1; }
  .m-start-2  { grid-column-start: 2; }
  .m-start-3  { grid-column-start: 3; }
  .m-start-4  { grid-column-start: 4; }
  .m-start-5  { grid-column-start: 5; }
  .m-start-6  { grid-column-start: 6; }
  .m-start-7  { grid-column-start: 7; }
  .m-start-8  { grid-column-start: 8; }
  .m-start-9  { grid-column-start: 9; }
  .m-start-10 { grid-column-start: 10; }
  .m-start-11 { grid-column-start: 11; }
  .m-start-12 { grid-column-start: 12; }
	
}

/* L (>=1024px) */
@media (min-width: 1024px) {
  .l-col-span-1  { grid-column-end: span 1; }
  .l-col-span-2  { grid-column-end: span 2; }
  .l-col-span-3  { grid-column-end: span 3; }
  .l-col-span-4  { grid-column-end: span 4; }
  .l-col-span-5  { grid-column-end: span 5; }
  .l-col-span-6  { grid-column-end: span 6; }
  .l-col-span-7  { grid-column-end: span 7; }
  .l-col-span-8  { grid-column-end: span 8; }
  .l-col-span-9  { grid-column-end: span 9; }
  .l-col-span-10 { grid-column-end: span 10; }
  .l-col-span-11 { grid-column-end: span 11; }
  .l-col-span-12 { grid-column-end: span 12; }
	
  .l-start-1  { grid-column-start: 1; }
  .l-start-2  { grid-column-start: 2; }
  .l-start-3  { grid-column-start: 3; }
  .l-start-4  { grid-column-start: 4; }
  .l-start-5  { grid-column-start: 5; }
  .l-start-6  { grid-column-start: 6; }
  .l-start-7  { grid-column-start: 7; }
  .l-start-8  { grid-column-start: 8; }
  .l-start-9  { grid-column-start: 9; }
  .l-start-10 { grid-column-start: 10; }
  .l-start-11 { grid-column-start: 11; }
  .l-start-12 { grid-column-start: 12; }
}

/* XL (>=1280px) */
@media (min-width: 1280px) {
  .xl-col-span-1  { grid-column-end: span 1; }
  .xl-col-span-2  { grid-column-end: span 2; }
  .xl-col-span-3  { grid-column-end: span 3; }
  .xl-col-span-4  { grid-column-end: span 4; }
  .xl-col-span-5  { grid-column-end: span 5; }
  .xl-col-span-6  { grid-column-end: span 6; }
  .xl-col-span-7  { grid-column-end: span 7; }
  .xl-col-span-8  { grid-column-end: span 8; }
  .xl-col-span-9  { grid-column-end: span 9; }
  .xl-col-span-10 { grid-column-end: span 10; }
  .xl-col-span-11 { grid-column-end: span 11; }
  .xl-col-span-12 { grid-column-end: span 12; }
	
  .xl-start-1  { grid-column-start: 1; }
  .xl-start-2  { grid-column-start: 2; }
  .xl-start-3  { grid-column-start: 3; }
  .xl-start-4  { grid-column-start: 4; }
  .xl-start-5  { grid-column-start: 5; }
  .xl-start-6  { grid-column-start: 6; }
  .xl-start-7  { grid-column-start: 7; }
  .xl-start-8  { grid-column-start: 8; }
  .xl-start-9  { grid-column-start: 9; }
  .xl-start-10 { grid-column-start: 10; }
  .xl-start-11 { grid-column-start: 11; }
  .xl-start-12 { grid-column-start: 12; }
}

/* XXL (>=1920px) */
@media (min-width: 1920px) {
  .xxl-col-span-1  { grid-column-end: span 1; }
  .xxl-col-span-2  { grid-column-end: span 2; }
  .xxl-col-span-3  { grid-column-end: span 3; }
  .xxl-col-span-4  { grid-column-end: span 4; }
  .xxl-col-span-5  { grid-column-end: span 5; }
  .xxl-col-span-6  { grid-column-end: span 6; }
  .xxl-col-span-7  { grid-column-end: span 7; }
  .xxl-col-span-8  { grid-column-end: span 8; }
  .xxl-col-span-9  { grid-column-end: span 9; }
  .xxl-col-span-10 { grid-column-end: span 10; }
  .xxl-col-span-11 { grid-column-end: span 11; }
  .xxl-col-span-12 { grid-column-end: span 12; }
	
  .xxl-start-1  { grid-column-start: 1; }
  .xxl-start-2  { grid-column-start: 2; }
  .xxl-start-3  { grid-column-start: 3; }
  .xxl-start-4  { grid-column-start: 4; }
  .xxl-start-5  { grid-column-start: 5; }
  .xxl-start-6  { grid-column-start: 6; }
  .xxl-start-7  { grid-column-start: 7; }
  .xxl-start-8  { grid-column-start: 8; }
  .xxl-start-9  { grid-column-start: 9; }
  .xxl-start-10 { grid-column-start: 10; }
  .xxl-start-11 { grid-column-start: 11; }
  .xxl-start-12 { grid-column-start: 12; }
}


/* ====================================
   LANDING-PAGE STYLING BASE & S <680px
   ==================================== */

/* legal */

.legal_wrapper {
background: #ffffff;
padding-bottom: 2.5rem;
}

.legal_inner_wrapper {
background: #000000;
padding: 2.5rem 0;
margin-bottom: 1.25rem;
}

.legal_h1 {
font-family: "elza", sans-serif;
font-style: normal;
font-weight: 700;
font-size: 1.75rem;
line-height: 1.75rem;
display: block;
color: #ffffff;
text-align: left;
}

/* datenschutz */

.datenschutz_wrapper p {
font-family: "elza", sans-serif;
font-style: normal;
font-weight: 500;
font-size: 1rem;
line-height: 1.5rem;
color: #000000;
margin: 0 0 1.25rem 0;
}

.datenschutz_wrapper h2 {
font-family: "elza", sans-serif;
font-style: normal;
font-size: 1.5rem;
line-height: 1.5rem;
font-weight: 600;
margin: 0 0 1.25rem 0;
}

.datenschutz_wrapper h3 {
font-family: "elza", sans-serif;
font-style: normal;
font-size: 1.25rem;
line-height: 1.25rem;
font-weight: 600;
margin: 0 0 0.625rem 0;
}

.datenschutz_wrapper h4 {
font-family: "elza", sans-serif;
font-style: normal;
font-size: 1rem;
line-height: 1.25rem;
font-weight: 600;
margin: 0 0 0.3125rem 0;
}

.datenschutz_wrapper ul li {
font-family: "elza", sans-serif;
font-style: normal;
font-weight: 500;
font-size: 1rem;
line-height: 1.5rem;
color: #000000;
}


.datenschutz_wrapper br {
font-family: "elza", sans-serif;
font-style: normal;
font-weight: 500;
font-size: 1rem;
line-height: 1.5rem;
color: #000000;
}

/* impressum */

.impressum_wrapper p {
font-family: "elza", sans-serif;
font-style: normal;
font-weight: 500;
font-size: 1rem;
line-height: 1.5rem;
color: #000000;
margin: 0 0 1.25rem 0;
}

.impressum_wrapper h2 {
font-family: "elza", sans-serif;
font-style: normal;
font-size: 1.125rem;
line-height: 1.25rem;
font-weight: 600;
margin: 0 0 0.3125rem 0;
}

/* Misc */

.page-id-247 .container_style { 
min-height: 100dvh; 
display:flex; 
flex-direction:column; 
}

.page-id-247 .legal_wrapper {
flex: 1;
}

.page-id-249 .container_style { 
min-height: 100dvh; 
display:flex; 
flex-direction:column; 
}

.page-id-249 .legal_wrapper {
flex: 1;
}


.page-id-8, .page-id-247, .page-id-249 {
background: #D8D8D8;
}

.container_style {
background: #000000;
box-shadow: 4px 4px 4px rgba(0,0,0,0.24);
}

.color_green {
color: #58FCA2;
}

.color_black {
color: #000000;
}

.blink {
  animation: fadeBlink 2s ease-in-out infinite;
}

@keyframes fadeBlink {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
}

.bg_222222 {
background: #222222;
}

/* Header */

.header_style {
padding: 0.75rem 0;
}

.header_inner_wrapper {
display: flex;
justify-content: space-between;
align-items: center;
}

.header_wrapper {
border-bottom: 1px solid rgba(255,255,255,0.24);
background: #000000;
}

.header_logo {
width: 6.25rem;
height: auto;
transform: translateY(-0.125rem);
}

.header_button {
padding: 0.375rem 0.75rem;
border: 2px solid #58FCA2;
border-radius: 3rem;
font-size: 0.75rem;
line-height: 0.75rem;
font-weight: 500;
font-family: "elza", sans-serif;
font-style: normal;
color: #ffffff;
background: #000000;
display: flex;
align-items: center;
}

.header_button_display {
display: none;
}

.header_button_icon {
width: 0.796875rem;
height: 1.03125rem;
margin-left: 0.25rem;
margin-top: 0.125rem;
}

.header_button_wrapper {
display: flex;
align-items: center;
justify-content: space-between;
gap: 1rem;	
}

.header_button:hover {
border-color: #ffffff;
color: #58FCA2;
}

.header_button:hover .header_button_icon {
  content: url("/wp-content/uploads/2025/10/Arrow_Icon_Up_green_now_2x.png");
}

/* Hero */

.hero_wrapper {
position: relative;
}

.hero_style {
padding: 2.5rem 0 0 0;
}

.hero_p {
font-size: 1rem;
line-height: 1.375rem;
font-weight: 400;
margin: 0 0 2.5rem 0;
font-family: "elza", sans-serif;
font-style: normal;
color: #D8D8D8;
text-align: center;
}

.hero_h1 {
font-size: 3.5rem;
line-height: 3.25rem;
font-weight: 700;
letter-spacing: -1px;
margin: 0 0 1rem 0;
font-family: "elza", sans-serif;
font-style: normal;
color: #ffffff;
}

.hero_h1 { text-align: center; }
.s-m-l-hero_h1 { display: inline; }
.xl-xxl-hero_h1 { display: none; }

.hero_qr_code_wrapper_xl, .hero_qr_code_wrapper_xxl {
display: none;
}

.hero_qr_code_inner_wrapper {
border: 2px solid #58FCA2;
}

.hero_qr_code_headline {
color: #58FCA2;
text-align: center;
}

.hero_device_s {
height: 20.5625rem;
position: relative;
bottom: 0px;
display: block;
margin: auto;
}

/* Logo Carousel */

.hero_logo_carousel {
height: 4rem;
}

.logo_cell_m_l, .logo_cell_xl, .logo_cell_xxl {
display: none;
}

.logo_cell {
align-items: center;
justify-content: center;
display: flex;
height: 100%;
}

.logo_img { 
height: 1rem; 
}

/* Copy */

.copy {
font-size: 1.25rem;
line-height: 1.375rem;
font-weight: 600;
letter-spacing: -0.4px;
padding: 2.5rem 0;
font-family: "elza", sans-serif;
font-style: normal;
color: #d8d8d8;
text-align: center;
}

/* Banner */

.banner {
width: 100%;
height: 50vw;
background: center center / cover no-repeat url("/wp-content/uploads/2025/10/freevesto_Banner.png");
display: flex;
align-items: center;
justify-content: center;
font-size: 15vw;
line-height: 15vw;
font-weight: 700;
letter-spacing: -2px;
font-family: "elza", sans-serif;
font-style: normal;
color: #ffffff;
}

/* FAQ */

.faq-section {
  font-family: "Elza", sans-serif;
}

.faq_style {
padding: 2.5rem 0;
}

.faq-title {
font-size: 1.25rem;
font-weight: 600;
margin-bottom: 0.625rem;
text-align: center;
color: #ffffff;
}

.faq-item {
  border-bottom: 1px solid rgba(255, 255, 255, 0.24);
  padding: 0;
}

/* Fragezeile */

.faq-question {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: 1.25rem 0;
  cursor: pointer;
  list-style: none;
  font-size: 0.875rem;
  font-weight: 400;
  color: #d8d8d8;
  /* Wichtig: Das ganze summary ist der Klickbereich */
  user-select: none;
  -webkit-user-select: none; /* Safari */
  -ms-user-select: none;     /* älteres Edge */
}

.faq-text {
  pointer-events: none; /* Klicks nur auf summary */
}

/* Entfernt das kleine native Pfeilchen von <summary> */
.faq-question::-webkit-details-marker,
.faq-question::marker {
  display: none;
}

/* Für visuelles Feedback (optional) */
.faq-question:hover {
  background-color: rgba(255, 255, 255, 0.04);
}

/* Das Icon rechts */
.faq-icon {
  position: relative;
  width: 0.875rem;
  height: 0.875rem;
  flex-shrink: 0;
}

/* Plus-Icon erstellen (zwei Linien über ::before/::after) */
.faq-icon::before,
.faq-icon::after {
  content: "";
  position: absolute;
  background-color: #58FCA2;
  top: 50%;
  left: 0;
  width: 100%;
  height: 1.25px;
  transition: transform 0.3s ease, opacity 0.3s ease;
  transform-origin: center;
}

.faq-icon::after {
  transform: rotate(90deg);
}

/* Wenn geöffnet → Plus zu X animieren */
.faq-item[open] .faq-icon::before {
  transform: rotate(45deg);
}

.faq-item[open] .faq-icon::after {
  transform: rotate(-45deg);
}

/* Antwort */
.faq-answer {
  padding: 0 0 1.25rem 0;
  color: #ffffff;
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.125rem;
  animation: fadeIn 0.3s ease;
}

/* kleine Animation beim Öffnen */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(-0.25rem); }
  to { opacity: 1; transform: translateY(0); }
}

/* CTA */

.cta_style {
display: flex;
align-items: center;
justify-content: center;
padding: 1.25rem 0;
}

.cta_h2 {
font-size: 2.5rem;
line-height: 2.5rem;
font-weight: 700;
letter-spacing: -1px;
font-family: "elza", sans-serif;
font-style: normal;
color: #ffffff;
text-align: center;
}

/* Footer */

.footer_wrapper_alt {
border-top: 1px solid rgba(255,255,255,0.24);
padding: 2.5rem 0;
}

.footer_wrapper {
border-top: 1px solid rgba(255,255,255,0.24);
margin-top: 1.25rem;
padding: 2.5rem 0;
}

.footer_buttons {
display: flex;
gap: 0.5rem;
justify-content: center;
align-items: center;
margin-bottom: 1.5rem;
}

.footer_buttons a img {
height: 2.5rem;
display: block;
}

.footer_h3 {
font-size: 0.875rem;
line-height: 0.875rem;
font-weight: 500;
letter-spacing: 0;
font-family: "elza", sans-serif;
font-style: normal;
color: #ffffff;
text-align: center;
margin-bottom: 0.75rem;
}

.footer_copyright_text {
font-size: 0.75rem;
line-height: 0.75rem;
font-weight: 400;
letter-spacing: 0;
font-family: "elza", sans-serif;
font-style: normal;
color: rgba(255,255,255,0.64);
text-align: center;
}

.footer_link_group {
display: flex;
justify-content: center;
gap: 1rem;
margin-bottom: 0.75rem;
}

.footer_link {
font-size: 0.75rem;
line-height: 0.75rem;
font-weight: 400;
letter-spacing: 0;
font-family: "elza", sans-serif;
font-style: normal;
color: rgba(255,255,255,0.64);
text-decoration: none;
}

/* ==================================
   LANDING-PAGE STYLING M, L, XL, XXL
   ================================== */

/* M (>=680px) */
@media (min-width: 680px) {
	
/* legal */
	
.legal_wrapper {
padding-bottom: 3rem;
}
	
.legal_h1 {
font-size: 2.5rem;
line-height: 2.5rem;
}

/* header */
	
.hero_h1_m {
font-size: 5rem;
line-height: 4.5rem;
font-weight: 700;
letter-spacing: -2px;
margin: 0 0 1.5rem 0;
}

.m-l-header_style {
padding: 0.75rem 0;
}

.m-l-xl-header_logo {
width: 7.5rem;
height: auto;
transform: translateY(-0.2rem);
}
	
.header_button_display {
display: flex;
}
	
.m-l-xl-header_button {
padding: 0.5rem 1rem;
border: 2px solid #58FCA2;
border-radius: 3rem;
font-size: 0.875rem;
line-height: 0.875rem;
font-weight: 500;
}
	
.m-l-xl-header_button_icon {
width: 0.941875rem;
height: 1.21875rem;
margin-left: 0.25rem;
margin-top: 0.1875rem;
}
	
.header_button:hover .m-l-xl-header_button_icon {
  content: url("/wp-content/uploads/2025/10/Arrow_Icon_Up_green_now_2x.png");
}
	
/* hero */
	
.hero_style_m {
padding: 4rem 0 0 0;
}
	
.hero_device_m {
height: 34.5625rem;
position: relative;
bottom: 0px;
display: block;
margin: auto;
}
	
.hero_p_m {
font-size: 1.125rem;
line-height: 1.5rem;
margin: 0 0 4rem 0;
}
	
/* Logo Carousel */
	
.hero_logo_carousel_m {
height: 5rem;
}
	
.logo_img { 
height: 1.25rem; 
}
	
.logo_cell_m_l {
display: block;
}

/* Copy */

.copy_m {
font-size: 2.25rem;
line-height: 2.25rem;
letter-spacing: -0.4px;
padding: 4rem 0;
font-family: "elza", sans-serif;
font-style: normal;
color: #d8d8d8;
text-align: center;
}
	
/* Banner */

.banner_m {
letter-spacing: -3px;
}
	
/* FAQ */
	
.faq_style {
padding: 4rem 0;
}
	
.faq-question {
font-size: 1rem;
padding: 1.5rem 0;
}
	
.faq-answer {
padding: 0 0 1.5rem 0;
font-size: 1rem;
line-height: 1.25rem;
}

.faq-icon {
width: 1rem;
height: 1rem;
}
	
.faq-title {
font-size: 2.25rem;
line-height: 2.25rem;
margin-bottom: 0.75rem;
}
	
/* CTA */

.cta_h2 {
font-size: 3.5rem;
line-height: 3.5rem;
letter-spacing: -2px;
}
	

.cta_style {
padding: 2rem 0;
}
	
/* Footer */
	
.footer_wrapper_alt {
padding: 3rem 0;
}

.footer_wrapper {
padding: 3rem 0;
margin-top: 1.5rem;
}

.footer_buttons {
margin-bottom: 1.75rem;
}

.footer_h3 {
margin-bottom: 1rem;
font-size: 1rem;
}

.footer_link_group {
margin-bottom: 1rem;
}
	
.footer_copyright_text {
font-size: 0.875rem;
line-height: 0.875rem;
}
.footer_link {
font-size: 0.875rem;
line-height: 0.875rem;
}
	
}

/* L (>=1024px) */

@media (min-width: 1024px) {
	
/* legal */
	
.legal_wrapper {
padding-bottom: 4rem;
}
	
/* hero */
	
.hero_device_l {
height: 47rem;
position: relative;
bottom: 0px;
display: block;
margin: auto;
}
	
.hero_h1_l {
font-size: 6rem;
line-height: 5.5rem;
font-weight: 700;
letter-spacing: -2.5px;
margin: 0 0 2rem 0;
}
	
.hero_style_l {
padding: 5rem 0 0 0;
}
	
.hero_p_l {
font-size: 1.25rem;
line-height: 1.625rem;
margin: 0 0 5rem 0;
}
	
/* Logo Carousel */
	
.l-xl-hero_logo_carousel {
height: 6rem;
}

/* Copy */

.copy_l {
font-size: 2.5rem;
line-height: 2.625rem;
letter-spacing: -0.4px;
padding: 5rem 0;
font-family: "elza", sans-serif;
font-style: normal;
color: #d8d8d8;
text-align: center;
}
	
/* Banner */

.banner_l {
height: 25rem;
font-size: 8.75rem;
line-height: 8.75rem;
letter-spacing: -4px;
}
	
/* FAQ */
	
.faq_style {
padding: 5rem 0;
}
	
.faq-question {
font-size: 1.125rem;
padding: 2.25rem 0;
}
	
.faq-answer {
padding: 0 0 2.25rem 0;
font-size: 1.125rem;
line-height: 1.5rem;
}

.faq-icon {
width: 1.125rem;
height: 1.125rem;
}
	
.faq-title {
font-size: 2.5rem;
line-height: 2.5rem;
margin-bottom: 1.125rem;
}
	
/* CTA */

.cta_h2 {
font-size: 4.5rem;
line-height: 4.5rem;
}
	

.cta_style {
padding: 3rem 0;
}
	
/* Footer */
	
.footer_wrapper_alt {
padding: 4rem 0;
}

.footer_wrapper {
padding: 4rem 0;
margin-top: 2rem;
}

.footer_buttons {
margin-bottom: 2rem;
}
	
}

/* XL (>=1280px) */

@media (min-width: 1280px) {
	
/* header */
	
.xl-xxl-header_style {
padding: 1rem 0;
}

.header_wrapper {
border-bottom: 2px solid rgba(255,255,255,0.24);
}
	
/* hero */
	
.hero_style_xl {
padding: 7.5rem 0;
}
	
.hero_h1 { text-align: left; }
.s-m-l-hero_h1 { display: none; }
.xl-xxl-hero_h1 { display: inline; }
	
.hero_device_xl {
height: 39.8125rem;
position: absolute;
bottom: 0px;
right: 8.1875rem;
}

.hero_h1_xl {
font-size: 5rem;
line-height: 5rem;
font-weight: 700;
letter-spacing: -2px;
margin: 0 0 2rem 0;
}

.hero_p_xl {
font-size: 1.125rem;
line-height: 1.5rem;
letter-spacing: 0px;
margin: 0 0 2rem 0;
text-align: left;
}

.hero_qr_code_wrapper_xl {
width: 9.25rem;
display: block;
}
	
.hero_qr_code_inner_wrapper_xl {
padding: 0.75rem;
}

.hero_qr_code_xl {
width: 7.5rem;
height: 7.5rem;
background: center / contain no-repeat url("/wp-content/uploads/2025/10/freevest_QR_Code_test.png");
}
	
.hero_qr_code_headline_xl {
font-family: "elza", sans-serif;
font-size: 1.125rem;
line-height: 1.125rem;
font-weight: 600;
letter-spacing: 0.2px;
margin: 0 0 0.75rem 0;
filter: drop-shadow(3px 3px 1px rgba(189,189,189,0.32));
}
	
/* Logo Carousel */

.logo_cell_xl {
display: block;
}
	
.logo_img { 
height: 1.5rem; 
}
	
/* Copy */

.copy_xl {
font-size: 2.75rem;
line-height: 2.875rem;
font-weight: 600;
letter-spacing: -0.4px;
padding: 7.5rem 0;
font-family: "elza", sans-serif;
font-style: normal;
color: #d8d8d8;
text-align: center;
}
	
/* Banner */

.banner_xl {
height: 31.25rem;
font-size: 12.25rem;
line-height: 12.25rem;
letter-spacing: -8px;
}
	
/* FAQ */
	
.faq_style {
padding: 7.5rem 0;
}
	
.faq-question {
font-size: 1.25rem;
padding: 2.5rem 0;
}
	
.faq-answer {
padding: 0 0 2.5rem 0;
font-size: 1.25rem;
line-height: 1.625rem;
}

.faq-icon {
width: 1.25rem;
height: 1.25rem;
}
	
.faq-title {
font-size: 2.75rem;
line-height: 2.75rem;
font-weight: 600;
margin-bottom: 1.25rem;
}
	
.faq-item {
border-bottom: 2px solid rgba(255, 255, 255, 0.24);
}

.faq-icon::before,
.faq-icon::after {
height: 2px;
}
	
/* CTA */

.cta_style {
justify-content: space-between;
padding: 4rem 0;
}

.cta_h2 {
font-size: 5rem;
line-height: 5rem;
text-align: left;
}
	
/* Footer */
	
.footer_wrapper_alt {
border-top: 2px solid rgba(255,255,255,0.24);
padding: 4rem 0;
}

.footer_wrapper {
border-top: 2px solid rgba(255,255,255,0.24);
padding: 4rem 0;
margin-top: 2rem;
}

.footer_buttons {
margin-bottom: 2rem;
}
	
}

/* XXL (>=1920px) */

@media (min-width: 1920px) {
	
/* legal */
	
.legal_wrapper {
padding-bottom: 5rem;
}
	
/* header */
	
.header_logo_xxl {
width: 9rem;
height: auto;
transform: translateY(-0.25rem);
}

.header_button_xxl {
padding: 0.75rem 1.5rem;
border: 2px solid #58FCA2;
border-radius: 3rem;
font-size: 1rem;
line-height: 1rem;
font-weight: 500;
}

.header_button_icon_xxl {
width: 1.0625rem;
height: 1.375rem;
margin-left: 0.375rem;
margin-top: 0.125rem;
}

.header_button:hover .header_button_icon_xxl {
  content: url("/wp-content/uploads/2025/10/Arrow_Icon_Up_green_now_2x.png");
}

/* hero */

.hero_style_xxl {
padding: 15rem 0;
}
	
.hero_h1_xxl {
font-size: 7.5rem;
line-height: 7.5rem;
font-weight: 700;
letter-spacing: -3px;
margin: 0 0 2.5rem 0;
}

.hero_p_xxl {
font-size: 1.5rem;
line-height: 2rem;
letter-spacing: 0.2px;
margin: 0 0 2.5rem 0;
}
	
.hero_qr_code_wrapper_xxl {
width: 12.25rem;
display: block;
}
	
.hero_qr_code_inner_wrapper_xxl {
padding: 1rem;
}

.hero_qr_code_xxl {
width: 10rem;
height: 10rem;
background: center / contain no-repeat url("/wp-content/uploads/2025/10/freevest_QR_Code_test.png");
}
	
.hero_qr_code_headline_xxl {
font-family: "elza", sans-serif;
font-size: 1.5rem;
line-height: 1.5rem;
font-weight: 600;
letter-spacing: 0.2px;
margin: 0 0 1rem 0;
filter: drop-shadow(4px 4px 1px rgba(189,189,189,0.32));
}
	
.hero_device_xxl {
height: 59.4375rem;
position: absolute;
bottom: 0px;
right: 11.8125rem;
}
	
/* Logo Carousel */
	
.hero_logo_carousel_xxl {
height: 7.5rem;
}
	
.logo_img { 
height: 1.75rem; 
}
	
.logo_cell_xxl {
display: block;
}
	
/* Copy */

.copy_xxl {
font-size: 3.5rem;
line-height: 4rem;
letter-spacing: -1px;
padding: 10rem 0;
font-family: "elza", sans-serif;
font-style: normal;
color: #d8d8d8;
text-align: center;
}
	
/* Banner */

.banner_xxl {
height: 50rem;
font-size: 18.75rem;
line-height: 18.75rem;
letter-spacing: -12px;
}
	
/* FAQ */
	
.faq_style {
padding: 10rem 0;
}
	
.faq-question {
font-size: 1.5rem;
padding: 3rem 0;
}
	
.faq-answer {
padding: 0 0 3rem 0;
font-size: 1.5rem;
line-height: 2rem;
}

.faq-icon {
width: 1.5rem;
height: 1.5rem;
}
	
.faq-title {
font-size: 3.5rem;
line-height: 3.5rem;
margin-bottom: 1.5rem;
}
	
/* CTA */

.cta_style {
padding: 5rem 0;
}

.cta_h2 {
font-size: 6rem;
line-height: 6rem;
}
	
/* Footer */

.footer_wrapper_alt {
padding: 5rem 0;
}

.footer_wrapper {
padding: 5rem 0;
margin-top: 2.5rem;
}

.footer_buttons {
gap: 0.5rem;
margin-bottom: 2.5rem;
}

.footer_buttons a img {
height: 3rem;
}

.footer_h3 {
font-size: 1.25rem;
line-height: 1.25rem;
font-weight: 500;
letter-spacing: 0;
margin-bottom: 1.25rem;
}

.footer_copyright_text {
font-size: 1rem;
line-height: 1rem;
}

.footer_link_group {
gap: 1.25rem;
margin-bottom: 1.25rem;
}

.footer_link {
font-size: 1rem;
line-height: 1rem;
letter-spacing: 0;
}

}
