.elementor-2281 .elementor-element.elementor-element-c76d3ad{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-2281 .elementor-element.elementor-element-2d670d0{--display:flex;}.elementor-theme-builder-content-area{height:400px;}.elementor-location-header:before, .elementor-location-footer:before{content:"";display:table;clear:both;}@media(max-width:767px){.elementor-2281 .elementor-element.elementor-element-c76d3ad{--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-2281 .elementor-element.elementor-element-2d670d0{--align-items:center;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--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-2281 .elementor-element.elementor-element-3a791da{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}}/* Start custom CSS for container, class: .elementor-element-c76d3ad */.sf-footer {
  background: #050505;
  color: #ffffff;
}

.sf-footer-inner {
  width: 100%;
  margin: 0 auto;
}



.sf-footer-wrap {
  padding: 86px clamp(32px, 5vw, 10px) 34px;
}


.sf-footer-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 36px;
}


.sf-footer-cta h2 {
  margin: 0;
  max-width: none;
  font-family: "Poppins", sans-serif;
  font-size: clamp(59px, 5.9vw, 90px);
  line-height: 0.96;
  font-weight: 900;
  color: #ffffff;
}


.sf-footer-cta h2 span {
  display: block;
  white-space: nowrap;
}



.sf-footer-logo-link {
  position: relative;
  display: inline-flex;
  flex: 0 0 auto;
  width: clamp(270px, 30vw, 520px);
  aspect-ratio: 1 / 1;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  overflow: visible;
}


.sf-footer-logo-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  transition: opacity 0.25s ease, transform 0.35s ease;
}

.sf-footer-logo-link::after {
  content: "";
  position: absolute;
  inset: -10%;
  z-index: 2;
  background: linear-gradient(
    90deg,
    #29c8ff 0%,
    #3b39ff 18%,
    #d93bdb 36%,
    #ffd400 58%,
    #9be400 78%,
    #21cdb8 100%
  );
  background-size: 300% 100%;
  opacity: 0;
  mix-blend-mode: screen;
  pointer-events: none;
  transition: opacity 0.25s ease;
  -webkit-mask-image: url("https://storyframe.hu/wp-content/uploads/2026/05/StoryFrame_logo_fekete-feher.webp");
  mask-image: url("https://storyframe.hu/wp-content/uploads/2026/05/StoryFrame_logo_fekete-feher.webp");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
}


.sf-footer-logo-link:hover::after {
  opacity: 0.95;
  animation: sfFooterLogoFlow 1.1s linear infinite;
}


@keyframes sfFooterLogoFlow {
  0% {
    background-position: 100% 50%;
  }

  100% {
    background-position: 0% 50%;
  }
}


.sf-footer-line {
  height: 6px;
  margin: 58px 0;
  background: linear-gradient(90deg, #29c8ff, #3b39ff, #d93bdb, #ffd400, #9be400, #21cdb8);
}

.sf-footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 0.7fr 0.9fr 0.9fr;
  gap: 42px;
}

.sf-footer-brand {
  display: inline-block;
  margin-bottom: 20px;
  font-family: "Poppins", sans-serif;
  font-size: clamp(42px, 5vw, 74px);
  line-height: 1;
  font-weight: 900;
  color: #ffffff;
  text-decoration: none;
}

.sf-footer-brand:hover {
  background: linear-gradient(90deg, #29c8ff, #3b39ff, #d93bdb, #ffd400, #9be400, #21cdb8);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.sf-footer-brand-col p {
  max-width: 420px;
  margin: 0;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 17px;
  line-height: 1.65;
  color: rgba(255,255,255,0.68);
}

.sf-footer-col h3 {
  margin: 0 0 18px;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.44);
}

.sf-footer-col a,
.sf-footer-bottom a {
  display: block;
  width: max-content;
  margin-bottom: 12px;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: rgba(255,255,255,0.82);
  text-decoration: none;
  transition: color 0.2s ease, text-shadow 0.2s ease;
}

.sf-footer-col a:hover,
.sf-footer-bottom a:hover {
  color: #ffffff;
  text-shadow: 0 0 18px rgba(217,59,219,0.55);
}

.sf-footer-socials {
  display: flex;
  align-items: center;
  gap: 26px;
  margin-top: 28px;
}

.sf-footer-socials a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  height: auto;
  margin: 0;
  padding: 0;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0;
  text-decoration: none;
}

.sf-footer-socials svg {
  display: block;
  width: 26px;
  height: 26px;
  fill: #ffffff;
  transition: transform 0.25s ease, filter 0.25s ease;
}

.sf-footer-socials a:hover svg {
  transform: translateY(-2px) scale(1.08);
  filter: drop-shadow(0 0 12px rgba(217,59,219,0.65));
  animation: sfFooterSocialGlow 1s linear infinite;
}

@keyframes sfFooterSocialGlow {
  0% {
    fill: #29c8ff;
  }

  20% {
    fill: #3b39ff;
  }

  40% {
    fill: #d93bdb;
  }

  60% {
    fill: #ffd400;
  }

  80% {
    fill: #9be400;
  }

  100% {
    fill: #21cdb8;
  }
}



@keyframes sfFooterSocialFlow {
  0% {
    background-position: 100% 50%;
  }

  100% {
    background-position: 0% 50%;
  }
}


.sf-footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  margin-top: 60px;
  padding-top: 26px;
  border-top: 1px solid rgba(255,255,255,0.12);
}

.sf-footer-bottom p {
  margin: 0;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 13px;
  color: rgba(255,255,255,0.48);
}

.sf-footer-bottom div {
  display: flex;
  gap: 22px;
}

.sf-footer-bottom a {
  margin: 0;
  font-size: 13px;
}


@media (max-width: 1024px) {
  .sf-footer-inner {
    width: min(94vw, 920px);
  }

  .sf-footer-wrap {
    padding: 76px 0 32px;
  }

  .sf-footer-cta {
    align-items: flex-start;
    flex-direction: column;
  }

  .sf-footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: 38px 34px;
  }

  .sf-footer-brand-col {
    grid-column: span 2;
  }
  .sf-footer-logo-link {
  width: 360px;
}
.sf-footer-cta {
  text-align: center;
  align-items: center;
}

.sf-footer-cta h2 {
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}

.sf-footer-logo-link {
  margin-left: auto;
  margin-right: auto;
}
.sf-footer-grid {
  grid-template-columns: 1fr;
  text-align: center;
  justify-items: center;
}

.sf-footer-brand-col {
  grid-column: auto;
}

.sf-footer-brand-col p {
  margin-left: auto;
  margin-right: auto;
}

.sf-footer-col {
  text-align: center;
}

.sf-footer-col a,
.sf-footer-bottom a {
  margin-left: auto;
  margin-right: auto;
}

.sf-footer-socials {
    justify-content: center;
    gap: 24px;
  }

  .sf-footer-socials i {
    font-size: 24px;
  }

.sf-footer-bottom {
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.sf-footer-bottom div {
  justify-content: center;
}



}


@media (max-width: 767px) {
  .sf-footer-inner {
    width: 100%;
    padding-left: 18px;
    padding-right: 18px;
  }

  .sf-footer-wrap {
    padding: 64px 0 28px;
  }

 .sf-footer-cta {
  text-align: center;
  align-items: center;
}

.sf-footer-cta h2 {
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  font-size: clamp(30px, 9vw, 36px);
  line-height: 1;
}

.sf-footer-cta h2 span {
  white-space: nowrap;
}



.sf-footer-logo-link {
  margin-left: auto;
  margin-right: auto;
}

.sf-footer-grid {
  text-align: center;
}

.sf-footer-brand-col p {
  margin-left: auto;
  margin-right: auto;
}

.sf-footer-col a,
.sf-footer-bottom a {
  margin-left: auto;
  margin-right: auto;
}

.sf-footer-socials {
    justify-content: center;
    gap: 22px;
  }

  .sf-footer-socials i {
    font-size: 23px;
  }


  .sf-footer-line {
    margin: 42px 0;
  }

  .sf-footer-grid {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .sf-footer-brand-col {
    grid-column: auto;
  }

  .sf-footer-brand {
    font-size: 44px;
  }

  .sf-footer-bottom {
    align-items: flex-start;
    flex-direction: column;
    margin-top: 42px;
  }

  .sf-footer-bottom div {
    flex-direction: column;
    gap: 10px;
  }
  .sf-footer-logo-link {
  width: 260px;

}}/* End custom CSS */