.elementor-2519 .elementor-element.elementor-element-6a7210e{--display:flex;--padding-top:15px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2519 .elementor-element.elementor-element-16abe80{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2519 .elementor-element.elementor-element-16abe80.e-con{--align-self:center;}.elementor-2519 .elementor-element.elementor-element-476b831{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;}.elementor-2519 .elementor-element.elementor-element-f3e35b6.elementor-element{--align-self:center;}.elementor-2519 .elementor-element.elementor-element-6bc917b.elementor-element{--align-self:center;}.elementor-2519 .elementor-element.elementor-element-492b491.elementor-element{--align-self:center;}.elementor-2519 .elementor-element.elementor-element-6a574b0{--display:flex;}.elementor-2519 .elementor-element.elementor-element-c1b794a{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--justify-content:flex-end;--z-index:999999999;}.elementor-2519 .elementor-element.elementor-element-c1b794a.e-con{--align-self:center;}.elementor-2519 .elementor-element.elementor-element-623f31d.elementor-element{--align-self:center;}.elementor-2519 .elementor-element.elementor-element-623f31d{z-index:99999999;}.elementor-2519 .elementor-element.elementor-element-98239c5{--display:flex;}.elementor-2519 .elementor-element.elementor-element-98239c5.e-con{--flex-grow:0;--flex-shrink:0;}.elementor-2519 .elementor-element.elementor-element-ff18af3{--display:flex;}.elementor-2519 .elementor-element.elementor-element-769572d{--display:flex;}.elementor-2519 .elementor-element.elementor-element-e126917.elementor-element{--align-self:center;}@media(max-width:1024px){.elementor-2519 .elementor-element.elementor-element-98239c5{--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;}.elementor-2519 .elementor-element.elementor-element-88a3a99.elementor-element{--align-self:flex-start;}.elementor-2519 .elementor-element.elementor-element-769572d.e-con{--align-self:center;}.elementor-2519 .elementor-element.elementor-element-e126917.elementor-element{--align-self:flex-end;}}@media(min-width:768px){.elementor-2519 .elementor-element.elementor-element-6a7210e{--content-width:95%;}.elementor-2519 .elementor-element.elementor-element-16abe80{--width:100%;}.elementor-2519 .elementor-element.elementor-element-476b831{--width:50%;}.elementor-2519 .elementor-element.elementor-element-6a574b0{--width:20%;}.elementor-2519 .elementor-element.elementor-element-c1b794a{--width:50%;}}@media(max-width:767px){.elementor-2519 .elementor-element.elementor-element-98239c5{--width:100%;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2519 .elementor-element.elementor-element-ff18af3{--width:45%;--padding-top:10px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-2519 .elementor-element.elementor-element-88a3a99 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-2519 .elementor-element.elementor-element-88a3a99.elementor-element{--align-self:flex-start;}.elementor-2519 .elementor-element.elementor-element-769572d{--width:52%;--margin-top:11px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:10px;--padding-bottom:10px;--padding-left:0px;--padding-right:0px;}.elementor-2519 .elementor-element.elementor-element-769572d.e-con{--align-self:center;}.elementor-2519 .elementor-element.elementor-element-e126917 > .elementor-widget-container{margin:0px 0px 0px 0px;}.elementor-2519 .elementor-element.elementor-element-e126917.elementor-element{--align-self:flex-end;}}/* Start custom CSS for html, class: .elementor-element-f3e35b6 *//* Make the anchor the button */
.btn {
  position: relative;
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 1.3em;
  display: inline-flex;                 /* centers content nicely */
  align-items: center;
  justify-content: center;
  padding: 17px 25px 14px 25px;
  border: none;
  background-color: #262626;
  color: #fff;
  font-weight: 600;
  border-radius: 350px;
  overflow: hidden;
  transition: color 0.2s ease;
  cursor: pointer;
  text-decoration: none;
  isolation: isolate;                   /* clean stacking for ::before */
}

/* Focus style for accessibility */
.btn:focus-visible {
  outline: 2px solid #BFFF00;
  outline-offset: 3px;
}

/* Sliding text container */
.btn .button-text {
  position: relative;
  z-index: 2;
  display: block;
  height: 1em;                          /* view window for the slide */
  line-height: 1;
  overflow: hidden;
  color: inherit;
}

/* The two text states */
.btn .text-original,
.btn .text-hover {
  display: block;
  transition: transform 0.2s ease;
  color: inherit;
}

/* Hover text starts below, slides up on hover */
.btn .text-hover {
  position: absolute;
  left: 0;
  top: 100%;
  width: 100%;
}

/* The lime overlay that slides up */
.btn::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -100%;
  height: 100%;
  background-color: #BFFF00;
  z-index: 1;                           /* behind text, above bg */
  transition: bottom 0.2s ease;
}

/* Hover states */
.btn:hover::before { bottom: 0; }
.btn:hover .text-original { transform: translateY(-100%); }
.btn:hover .text-hover   { transform: translateY(-100%); }
.btn:hover { color: #000; }/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-6bc917b *//* Make the anchor the button */
.btn {
  position: relative;
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 1.3em;
  display: inline-flex;                 /* centers content nicely */
  align-items: center;
  justify-content: center;
  padding: 17px 25px 14px 25px;
  border: none;
  background-color: #262626;
  color: #fff;
  font-weight: 600;
  border-radius: 350px;
  overflow: hidden;
  transition: color 0.2s ease;
  cursor: pointer;
  text-decoration: none;
  isolation: isolate;                   /* clean stacking for ::before */
}

/* Focus style for accessibility */
.btn:focus-visible {
  outline: 2px solid #BFFF00;
  outline-offset: 3px;
}

/* Sliding text container */
.btn .button-text {
  position: relative;
  z-index: 2;
  display: block;
  height: 1em;                          /* view window for the slide */
  line-height: 1;
  overflow: hidden;
  color: inherit;
}

/* The two text states */
.btn .text-original,
.btn .text-hover {
  display: block;
  transition: transform 0.2s ease;
  color: inherit;
}

/* Hover text starts below, slides up on hover */
.btn .text-hover {
  position: absolute;
  left: 0;
  top: 100%;
  width: 100%;
}

/* The lime overlay that slides up */
.btn::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -100%;
  height: 100%;
  background-color: #BFFF00;
  z-index: 1;                           /* behind text, above bg */
  transition: bottom 0.2s ease;
}

/* Hover states */
.btn:hover::before { bottom: 0; }
.btn:hover .text-original { transform: translateY(-100%); }
.btn:hover .text-hover   { transform: translateY(-100%); }
.btn:hover { color: #000; }/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-492b491 *//* Make the anchor the button */
.btn {
  position: relative;
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 1.3em;
  display: inline-flex;                 /* centers content nicely */
  align-items: center;
  justify-content: center;
  padding: 17px 25px 14px 25px;
  border: none;
  background-color: #262626;
  color: #fff;
  font-weight: 600;
  border-radius: 350px;
  overflow: hidden;
  transition: color 0.2s ease;
  cursor: pointer;
  text-decoration: none;
  isolation: isolate;                   /* clean stacking for ::before */
}

/* Focus style for accessibility */
.btn:focus-visible {
  outline: 2px solid #BFFF00;
  outline-offset: 3px;
}

/* Sliding text container */
.btn .button-text {
  position: relative;
  z-index: 2;
  display: block;
  height: 1em;                          /* view window for the slide */
  line-height: 1;
  overflow: hidden;
  color: inherit;
}

/* The two text states */
.btn .text-original,
.btn .text-hover {
  display: block;
  transition: transform 0.2s ease;
  color: inherit;
}

/* Hover text starts below, slides up on hover */
.btn .text-hover {
  position: absolute;
  left: 0;
  top: 100%;
  width: 100%;
}

/* The lime overlay that slides up */
.btn::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -100%;
  height: 100%;
  background-color: #BFFF00;
  z-index: 1;                           /* behind text, above bg */
  transition: bottom 0.2s ease;
}

/* Hover states */
.btn:hover::before { bottom: 0; }
.btn:hover .text-original { transform: translateY(-100%); }
.btn:hover .text-hover   { transform: translateY(-100%); }
.btn:hover { color: #000; }/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-623f31d *//* ===== Base Button Styles (Slide-Up Animation & Color Swap) ===== */
.btn2 {
  position: relative;
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 1.3em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 18px 25px 15px 25px;
  border: none;
  background-color: #BFFF00;   /* Lime default */
  color: #000;                /* Black text */
  font-weight: 600;
  border-radius: 350px;
  overflow: hidden;           /* Needed for slide animation */
  transition: color 0.2s ease, background-color 0.2s ease;
  cursor: pointer;
  text-decoration: none;
  isolation: isolate;         /* For pseudo-element layering */
  z-index: 1;
}

/* Focus style for accessibility */
.btn2:focus-visible {
  outline: 2px solid #262626;
  outline-offset: 3px;
}

/* Sliding text container */
.btn2 .button-text {
  position: relative;
  z-index: 2;
  display: block;
  height: 1em;
  line-height: 1;
  overflow: hidden;
  color: inherit;
}

/* Text states */
.btn2 .text-original,
.btn2 .text-hover {
  display: block;
  transition: transform 0.2s ease;
  color: inherit;
}

/* Hover text starts below */
.btn2 .text-hover {
  position: absolute;
  left: 0;
  top: 100%;
  width: 100%;
}

/* Black overlay slides up */
.btn2::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -100%;
  height: 100%;
  background-color: #262626;
  z-index: 1;
  transition: bottom 0.2s ease;
}

/* Hover states */
.btn2:hover {
  color: #fff;
  background-color: #262626; /* Fix green edge issue */
}
.btn2:hover::before { bottom: 0; }
.btn2:hover .text-original { transform: translateY(-100%); }
.btn2:hover .text-hover   { transform: translateY(-100%); }

/* ===== Floating Sticky on Top-Right ===== */
.btn2-float-top {
  position: fixed;
  top: 30px;    /* Distance from top */
  right: 24px;  /* Distance from right */
  z-index: 9999;
  box-shadow: 0 8px 24px rgba(0,0,0,0.15);
}

/* Mobile adjustment: move to center top */
@media (max-width: 767px) {
  .btn2-float-top {
    right: 50%;
    transform: translateX(50%);
    top: 16px;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-e126917 */.elementor-2519 .elementor-element.elementor-element-e126917 {
  position: relative;
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 1.3em;
  display: inline-block;
  padding: 17px 5px 8px 25px;
  border: none;
  background-color: #BFFF00;
  color: #000; /* stays black by default */
  font-weight: 600;
  border-radius: 350px;
  overflow: hidden;
  transition: color 0.2s ease;
  cursor: pointer;
  text-decoration: none; /* prevent link underline */
}

.elementor-2519 .elementor-element.elementor-element-e126917 .button-text {
  display: inline-block;
  position: relative;
  z-index: 2;
  height: 1em;
  overflow: hidden;
  line-height: 1em;
  color: #000; /* force black text */
}

.elementor-2519 .elementor-element.elementor-element-e126917 .text-original,
.elementor-2519 .elementor-element.elementor-element-e126917 .text-hover {
  display: block;
  transition: transform 0.2s ease;
  color: inherit;
}

.elementor-2519 .elementor-element.elementor-element-e126917 .text-hover {
  position: absolute;
  left: 0;
  top: 100%;
  width: 100%;
}

.elementor-2519 .elementor-element.elementor-element-e126917::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: -100%;
  width: 100%;
  height: 100%;
  background-color: #262626;
  z-index: 1;
  transition: bottom 0.2s ease;
}

.elementor-2519 .elementor-element.elementor-element-e126917:hover::before {
  bottom: 0;
}

/* keep text black until hover animation triggers */
.elementor-2519 .elementor-element.elementor-element-e126917:hover .button-text {
  color: #FFF; /* turns white only when hovered */
}

.elementor-2519 .elementor-element.elementor-element-e126917:hover .text-original {
  transform: translateY(-100%);
}

.elementor-2519 .elementor-element.elementor-element-e126917:hover .text-hover {
  transform: translateY(-100%);
}

/* Responsive styles */
@media (max-width: 1024px) {
  .elementor-2519 .elementor-element.elementor-element-e126917 {
    font-size: 1.1em;
    font-weight: 400;
    padding: 14px 20px 6px 20px;
  }
}

@media (max-width: 600px) {
  .elementor-2519 .elementor-element.elementor-element-e126917 {
    font-size: 1em;
    font-weight: 400;
    padding: 12px 16px 5px 16px;
    border-radius: 200px;
  }
}/* End custom CSS */