@font-face {
  font-family: 'MyWebFont';
  src:  url('../fonts/fonts/Juergen.woff2') format('woff2'),
        url('../fonts/fonts/Juergen.woff') format('woff');
  font-display: swap;
}

.mt-h {
  margin-top: 1.75rem;
}
.img400 {
  height: 400px;
  width: auto;
}
.tm {
  margin-top: 6rem;
}
.bg-overlay {
  background: url("../img/placeholders/hero-webp.webp");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  color: #fff;
  height: 450px;
  padding-top: 100px;
}
.minus {
  margin-top: -2rem;
}


.gvgh {
  font-family: 'MyWebFont', Fallback, sans-serif !important;
  font-size: 3rem; 
  color: #a1c332;                                      
}
.gvgh-2 {
  font-family: 'MyWebFont', Fallback, sans-serif !important;
  font-size: 3rem;
  color: #964b7d;                            
}



.beth-ellen-regular {
  font-family: "Beth Ellen", cursive;
  color: #964b7d; 
}

.green {
  color: #a1c332 !important;  
}

.highlight {
    --gvgh-purple: #964b7d;
    margin: 1rem 0;
    color: var(--gvgh-purple);
    border: 0;
    border-top: 2px solid;
    width: 100px;
  }
  .highlight.center {
    margin: 1rem auto
  }
.wide {
  width: 100% !important;
}

.simplyB {
  max-height: 75px;
}
.slider {
  min-height: 550px;
}
/* Cookie Notice */
#cookies{
  z-index: 9999;
  display: none;
}
/*===== Back to Top Button =====*/
#btn-back-to-top {
  position: fixed;
  bottom: 20px;
  right: 20px;
  display: none;
}

/*===== WhatsApp Button =====*/
.float{
	position:fixed;
	bottom:20px;
	left:20px;
  z-index:1;
}

.content-space-t-3 {
  padding-top: 7.5rem !important;
}
.content-space-b-2 {
  padding-bottom: 5rem !important;
}

@media (min-width: 768px) {
  .content-space-t-md-4 {
    padding-top: 10rem !important;
  }
  .content-space-t-md-0 {
    padding-top: 0 !important;
  }
  .content-space-b-md-3 {
    padding-bottom: 7.5rem !important;
  }
  .mt-md-n5 {
    margin-top: -2rem !important;
  }
  .w-md-75 {
    width: 75% !important;
  }
  .position-md-absolute {
    position: absolute !important;
  }
}


@media (min-width: 992px) {
  .content-space-t-lg-3 {
    padding-top: 5.5rem !important;
  }
  .m-icon-l {
    margin-left: 7rem;
  }
  .m-icon-r {
    margin-right: 7rem;
  }
}



@media (min-width: 1200px) {
  .content-space-b-xl-5 {
    padding-bottom: 12.5rem !important;
  }
}

.team {
  max-width: 640px;
}








.start-icon {
  left: -4.25rem !important;
}

.card.overflow-hidden, .tiny-slider.overflow-hidden {
  will-change: transform;
}

.arrow-round [data-controls] {
  border-radius: 50%;
}
.arrow-blur [data-controls] {
  -webkit-backdrop-filter: blur(5px);
          backdrop-filter: blur(5px);
  background: rgba(0, 0, 0, 0.4) !important;
}
.arrow-blur [data-controls]:hover {
  -webkit-backdrop-filter: blur(0px);
          backdrop-filter: blur(0px);
  background: rgba(0, 0, 0, 0.4) !important;
}
.arrow-blur.arrow-white [data-controls] {
  background-color: rgba(var(--bs-body-bg-rgb), 0.2) !important;
  color: #fff;
}

.card.card-element-hover .hover-element {
  visibility: hidden;
  opacity: 0;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
  z-index: 9;
}
.card.card-element-hover:hover .hover-element {
  visibility: visible;
  opacity: 1;
}


.card-overlay-hover:before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  height: 100%;
  width: 100%;
  opacity: 0;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
  background-color: #0b0a12;
  display: block;
}

.card-overlay-hover:hover:before {
  opacity: 0.5;
}


.tns-outer {
  position: relative;
}

.tns-item {
  -ms-touch-action: pan-y;
      touch-action: pan-y;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}

.tiny-slider .item {
  position: relative;
}

.tns-controls [data-controls] {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 50px;
  height: 50px;
  line-height: 50px;
  border-radius: 0.5rem;
  display: block;
  z-index: 9;
  text-align: center;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
  background: rgba(255, 255, 255, 0.3);
  color: #fff;
  border: none;
  margin: 0 10px;
}
.tns-controls [data-controls]:hover {
  background-color: var(--bs-primary);
  color: #fff;
}
.tns-controls [data-controls] i {
  line-height: inherit;
}

.tns-controls [data-controls=prev] {
  left: 0;
}

.tns-controls [data-controls=next] {
  right: 0;
}


.card-bg-img-single {
  background-image: url(../img/svg/single.svg);
  background-repeat: no-repeat;
  background-size: 25%;
  position: absolute;
  background-position-x: calc(100% - 1rem);
  background-position-y: 100%;
}

.card-bg-img-double {
  background-image: url(../img/svg/double.svg);
  background-repeat: no-repeat;
  background-size: 25%;
  position: absolute;
  background-position-x: calc(100% - 1rem);
  background-position-y: 100%;
}

.card-bg-img-single-2 {
  background-image: url(../img/svg/single.svg);
  background-repeat: no-repeat;
  background-size: 25%;
  position: absolute;
  background-position-x: calc(100% - 1rem);
  background-position-y: calc(50% - 2rem);
}

.card-bg-img-double-2 {
  background-image: url(../img/svg/double.svg);
  background-repeat: no-repeat;
  background-size: 25%;
  position: absolute;
  background-position-x: calc(100% - 1rem);
  background-position-y: calc(50% - 2rem);
}

.card-bg-img-shuttle {
  background-image: url(../img/webp/shuttle-driver.webp);
  background-repeat: no-repeat;
  background-size: 25%;
  position: absolute;
  background-position-x: calc(100% - 1rem);
  background-position-y: calc(50% - 2rem);
}

li::marker {
  color: var(--bs-secondary);
}

.dropdown:hover .dropdown-menu {
  display: block;
}

/* Modal Content Styling */
.modal-content {
  position: relative;
  overflow: hidden;
  background-image: url('../img/popups/background-winter.svg'); /* Adjust path */
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  color: white;
  border-radius: 1rem;
}
.modal-aspect-ratio {
    aspect-ratio: 1920 / 1500;
    width: 90%;
    max-width: 100%;
    height: auto;
  }

/* Aspect Ratio for Desktop */
@media (min-width: 992px) {
  .modal-aspect-ratio {
    aspect-ratio: 1920 / 1500;
    width: 90%;
    max-width: 100%;
    height: auto;
  }
}

/* Fallback for Older Browsers */
@supports not (aspect-ratio: 1) {
  .modal-aspect-ratio::before {
    content: "";
    display: block;
    padding-top: 78.125%; /* 1500 / 1920 * 100 */
  }

  .modal-aspect-ratio > * {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
  }

  .modal-aspect-ratio {
    position: relative;
    width: 90%;
    max-width: 100%;
    overflow: hidden;
  }
}

/* Snowflake Animation Base */
.heart {
  position: absolute;
  width: 50px;
  opacity: 0;
  animation: floatDown 5s ease-in-out infinite;
  pointer-events: none;
}

/* Individual Snowflake Positions and Delays */
.heart-1 { width: 40px; height: 40px; top: 10%; left: 15%; animation-delay: 0s; animation-duration: 6s; }
.heart-2 { width: 20px; height: 20px; top: 20%; left: 80%; animation-delay: 1s; animation-duration: 5s; }
.heart-3 { width: 10px; height: 10px; top: 50%; left: 10%; animation-delay: 2s; animation-duration: 7s; animation-name: floatDownRotate; }
.heart-4 { width: 30px; height: 30px; top: 70%; left: 75%; animation-delay: 3s; animation-duration: 6.5s; }
.heart-5 { width: 25px; height: 25px; top: 30%; left: 50%; animation-delay: 1.5s; animation-duration: 5.5s; }
.heart-6 { width: 20px; height: 20px; top: 60%; left: 30%; animation-delay: 2.5s; animation-duration: 7.5s; animation-name: floatDownRotate; }
.heart-7 { width: 10px; height: 10px; top: 40%; left: 85%; animation-delay: 0.5s; animation-duration: 4.5s; }

/* Float Down Animation */
@keyframes floatDown {
  0%   { transform: translateY(-100px) scale(1); opacity: 0; }
  50%  { opacity: 1; }
  100% { transform: translateY(0) scale(1.2); opacity: 0; }
}

/* Float Down with Rotation */
@keyframes floatDownRotate {
  0%   { transform: translateY(-100px) rotate(0deg) scale(1); opacity: 0; }
  50%  { opacity: 1; }
  100% { transform: translateY(0) rotate(360deg) scale(1.2); opacity: 0; }
}


/* Responsive Adjustments for Smaller Screens */
@media (max-width: 768px) {
  .heart {
    width: 30px;
  }

  .heart-1 { top: 5%; left: 10%; }
  .heart-2 { top: 15%; left: 70%; }
  .heart-3 { top: 45%; left: 5%; }
  .heart-4 { top: 65%; left: 70%; }
  .heart-5 { top: 25%; left: 45%; }
  .heart-6 { top: 55%; left: 25%; }
  .heart-7 { top: 35%; left: 75%; }
}

/* ---------- CTA overlay (matches artwork) ---------- */
:root{
  /* easy fine-tuning if your background shifts a bit */
  --ctaW: 42%;   /* width of the button vs. banner width */
  --ctaH: 10%;  /* height of the button vs. banner height */
  --ctaBottom: 10%; /* distance from bottom of banner */
}

/* keep .modal-content positioned (you already have this) */
.modal-content{ position:relative; }

/* wrapper positions the whole CTA */
.cta-wrap{
  position:absolute;
  left:50%;
  bottom:var(--ctaBottom);
  width:var(--ctaW);
  height:var(--ctaH);
  transform:translateX(-50%);
}

/* front button */
.cta-btn{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  height:100%;
  background:#307324;
  color:#fff;
  text-decoration:none;
  text-transform:uppercase;
  font-weight:800;
  letter-spacing:.08em;
  font-size:clamp(1rem, 1.2vw + .55rem, 1.7rem);
  /* trapezoid with narrower top, flat bottom */
  clip-path:polygon(6% 0, 94% 0, 100% 100%, 0 100%);
  box-shadow: rgba(0, 0, 0, 0.25) 0px 13px 27px -5px, rgba(0, 0, 0, 0.3) 0px 8px 16px -8px;
  border:0;
}

.cta-btn:focus-visible{ outline:3px solid #fff; outline-offset:3px; }
.cta-btn:hover{ filter:brightness(1.06); }
.cta-btn:active{ transform:translateY(2px); box-shadow:0 3px 0 rgba(0,0,0,.16); }

/* small screens: make it a touch wider & a tad higher */
@media (max-width: 576px){
  :root{
    --ctaW: 58%;
    --ctaH: 11%;
    --ctaBottom: 8%;
  }
}
