/* Storyframe Proless Bridge
   Extracted Elementor custom CSS from the Storyframe export so it can keep rendering when Elementor Pro is inactive.
   Generated: 2026-05-21T08:37:35
*/


/* Source: storyframe-audit/elementor/content/page/2761.json | element: 7acc0157 */
/* Ajánlatkérés form - 320px mobil finomhangolás */
@media (max-width: 340px) {
  .elementor-element-7acc0157 {
    overflow: visible !important;
  }

  .elementor-element-7acc0157 .sf-quote-copy,
  .elementor-element-7acc0157 .sf-quote-card {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 22px !important;
    padding-right: 22px !important;
    box-sizing: border-box !important;
    overflow: visible !important;
  }

  .elementor-element-7acc0157 .sf-quote-copy h1,
  .elementor-element-7acc0157 .sf-quote-copy h2,
  .elementor-element-7acc0157 .sf-quote-copy h3 {
    max-width: 100% !important;
    font-size: 27px !important;
    line-height: 1.05 !important;
    letter-spacing: 0 !important;
    white-space: normal !important;
    overflow-wrap: break-word !important;
    word-break: normal !important;
  }

  .elementor-element-7acc0157 .sf-quote-copy p {
    font-size: 15px !important;
    line-height: 1.45 !important;
  }

  .elementor-element-7acc0157 .sf-quote-form .elementor-field-label {
    font-size: 22px !important;
    line-height: 1.05 !important;
    letter-spacing: 0 !important;
  }

  .elementor-element-7acc0157 .sf-quote-form .elementor-field-subgroup {
    gap: 9px !important;
  }

  .elementor-element-7acc0157 .sf-quote-form .elementor-field-option {
    display: flex !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    gap: 7px !important;
    width: fit-content !important;
    max-width: 100% !important;
  }

  .elementor-element-7acc0157 .sf-quote-form .elementor-field-option label {
    display: inline-flex !important;
    align-items: center !important;
    width: fit-content !important;
    max-width: none !important;
    padding: 8px 10px !important;
    font-size: 12px !important;
    line-height: 1 !important;
    white-space: nowrap !important;
  }

  .elementor-element-7acc0157 .sf-quote-form .elementor-field-option input {
    flex: 0 0 auto !important;
    width: 13px !important;
    height: 13px !important;
    margin: 0 !important;
  }

  .elementor-element-7acc0157 .sf-quote-form textarea {
    min-height: 130px !important;
  }
}

/* Ajánlatkérés - tablet kétoszlopos elrendezés */
@media (min-width: 768px) and (max-width: 1024px) {
  body .sf-quote-section {
    padding: 72px 18px 88px !important;
  }

  body .sf-quote-inner {
    width: min(96vw, 980px) !important;
  }

  body .sf-quote-layout {
    grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr) !important;
    gap: 22px !important;
    align-items: stretch !important;
    margin-top: 38px !important;
  }

  body .sf-quote-copy {
    position: relative !important;
    padding: 30px !important;
    border-radius: 20px !important;
    overflow: hidden !important;
  }

  body .sf-quote-copy::after {
    left: 30px !important;
    right: 30px !important;
  }

  body .sf-quote-copy-block {
    width: 100% !important;
    min-height: 100% !important;
    display: block !important;
    padding-bottom: 0 !important;
  }

  body .sf-quote-eyebrow {
    margin-bottom: 15px !important;
  }

  body .sf-quote-copy h3 {
    font-size: clamp(30px, 3.7vw, 38px) !important;
  }

  body .sf-quote-copy p {
    font-size: 15px !important;
    line-height: 1.45 !important;
  }

  body .sf-quote-contact {
    gap: 10px !important;
    margin-top: 26px !important;
  }

  body .sf-quote-contact a {
    padding: 14px 16px !important;
    border-radius: 14px !important;
    font-size: 14px !important;
  }

  body .sf-quote-logo-link {
    position: absolute !important;
    left: 50% !important;
    right: auto !important;
    top: auto !important;
    bottom: -315px !important;
    width: clamp(260px, 34vw, 360px) !important;
    max-width: calc(100% - 42px) !important;
    margin: 0 !important;
    transform: translateX(-50%) !important;
  }

  body .sf-quote-logo-img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
  }

  body .sf-quote-card {
    padding: 28px !important;
    border-radius: 20px !important;
  }
}

/* Source: storyframe-audit/elementor/content/page/2761.json | element: b284eb6 */
@media (max-width: 374px) {
  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option {
    display: grid !important;
    grid-template-columns: 14px minmax(0, 1fr) !important;
    column-gap: 8px !important;
    row-gap: 0 !important;
    align-items: flex-start !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option input {
    width: 14px !important;
    height: 14px !important;
    margin: 3px 0 0 !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option label {
    display: block !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: 100% !important;
    min-height: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    white-space: normal !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    line-height: 1.35 !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option label a {
    display: inline !important;
    width: auto !important;
    max-width: none !important;
    white-space: nowrap !important;
    overflow-wrap: normal !important;
    word-break: keep-all !important;
  }
}

@media (max-width: 430px) {
  body .sf-quote-section .sf-quote-inner .sf-quote-copy h3 {
    font-size: 27px !important;
    line-height: 1.08 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
    text-wrap: balance;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-group-field_6cde44b {
    position: relative;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-group-field_6cde44b input::placeholder {
    color: transparent !important;
    opacity: 0 !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-group-field_6cde44b::after {
    content: "Facebook / Instagram / Google / Ajánlás / TikTok / Egyéb";
    display: block;
    margin-top: 8px;
    padding-left: 2px;
    font-family: "Inter", "Poppins", sans-serif;
    font-size: 11px;
    line-height: 1.35;
    font-weight: 600;
    color: rgba(0, 0, 0, 0.46);
  }
}

@media (max-width: 340px) {
  body .sf-quote-section .sf-quote-inner .sf-quote-layout .sf-quote-copy {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-layout .sf-quote-copy h3 {
    font-size: 23px !important;
    line-height: 1.08 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
    text-wrap: balance;
  }
}

/* Source: storyframe-audit/elementor/content/page/2761.json | element: 1bf283ca */
.sf-quote-section {
  padding: 90px 20px 110px;
  background: #ffffff;
}

.sf-quote-inner {
  width: min(92vw, 1420px);
  margin: 0 auto;
}

.sf-quote-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 34px;
  align-items: stretch;
  margin-top: 52px;
}

.sf-quote-copy,
.sf-quote-card {
  border-radius: 24px;
}

.sf-quote-copy {
  padding: 46px;
  background: #111111;
  color: #ffffff;
  overflow: hidden;
  position: relative;
}

.sf-quote-copy::after {
  content: "";
  position: absolute;
  left: 46px;
  right: 46px;
  bottom: 0;
  height: 6px;
  background: linear-gradient(90deg, #29c8ff, #3b39ff, #d93bdb, #ffd400, #9be400, #21cdb8);
}

.sf-quote-logo-link {
  position: relative;
  display: flex;
  width: clamp(200px, 21vw, 320px);
  aspect-ratio: 1 / 1;
  align-items: center;
  justify-content: center;
  margin: 34px auto 0;
  text-decoration: none;
  overflow: visible;
}


.sf-quote-logo-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.sf-quote-logo-link::after {
  content: "";
  position: absolute;
  inset: -10%;
  z-index: 2;
  background: linear-gradient(
    90deg,
    #29c8ff 0%,
    #29c8ff 12%,
    #3b39ff 20%,
    #3b39ff 28%,
    #d93bdb 36%,
    #d93bdb 44%,
    #ffd400 54%,
    #ffd400 62%,
    #9be400 72%,
    #9be400 80%,
    #21cdb8 90%,
    #21cdb8 100%
  );
  background-size: 170% 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-quote-logo-link:hover::after {
  opacity: 0.95;
  animation: sfQuoteLogoFlow 1.1s linear infinite;
}

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

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



.sf-quote-eyebrow {
  margin: 0 0 18px;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.sf-quote-copy h3 {
  margin: 0 0 24px;
  font-family: "Poppins", sans-serif;
  font-size: 44px;
  line-height: 1.05;
  font-weight: 900;
}

.sf-quote-copy p {
  margin: 0 0 18px;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 18px;
  line-height: 1.4;
  color: rgba(255,255,255,0.78);
}

.sf-quote-contact {
  display: grid;
  gap: 12px;
  margin-top: 34px;
}

.sf-quote-contact a {
  display: block;
  padding: 18px 20px;
  border-radius: 16px;
  color: #ffffff;
  text-decoration: none;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.14);
  font-family: "Inter", "Poppins", sans-serif;
  font-weight: 700;
}

.sf-quote-contact span {
  display: block;
  margin-bottom: 4px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}

.sf-quote-card {
  padding: 42px;
  background:
    linear-gradient(#ffffff, #ffffff) padding-box,
    linear-gradient(135deg, #29c8ff, #3b39ff, #d93bdb, #ffd400, #9be400, #21cdb8) border-box;
  border: 4px solid transparent;
  box-shadow: 0 24px 80px rgba(0,0,0,0.10);
}

.sf-quote-form .elementor-field-label {
  margin-bottom: 8px;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 13px;
  font-weight: 800;
  color: #151515;
}

.sf-quote-form .elementor-field-textual {
  min-height: 52px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,0.12);
  background: #f7f7f7;
  padding: 14px 16px;
  font-family: "Inter", "Poppins", sans-serif;
}

.sf-quote-form textarea.elementor-field-textual {
  min-height: 140px;
  resize: vertical;
}

.sf-quote-form .elementor-field-subgroup {
  display: flex;
  flex-wrap: wrap;
  gap: 13px;
}

.sf-quote-form .elementor-field-option label {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 10px 14px;
  border-radius: 999px;
  background: #f7f7f7;
  border: 1px solid rgba(0,0,0,0.10);
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
}

.sf-quote-form .elementor-field-option input {
  margin-right: 10px;
}

.sf-quote-form .elementor-field-type-acceptance {
  margin-top: 16px;
  margin-bottom: 24px;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-subgroup {
  display: block !important;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-option {
  display: flex !important;
  align-items: flex-start;
  gap: 10px;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-option input {
  flex: 0 0 auto;
  margin: 4px 0 0 !important;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-option label {
  display: block !important;
  min-height: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 12px;
  line-height: 1.55;
  font-weight: 500;
  color: rgba(0,0,0,0.62);
}

.sf-quote-form .elementor-field-type-acceptance a {
  color: #151515;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 3px;
}


.sf-quote-form .elementor-field-type-submit {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
  margin: 0 !important;
  padding: 0 !important;
}

.sf-quote-form .elementor-field-type-html {
  width: 100% !important;
  flex-basis: 100% !important;
}

.sf-quote-submit-row {
  display: flex !important;
  justify-content: center !important;
  width: 100% !important;
  margin-top: 10px;
}

.sf-quote-submit-row .sf-cta-wrap {
  width: auto !important;
  max-width: max-content !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.sf-quote-submit-row .sf-cta {
  width: auto !important;
}




@media (max-width: 1024px) {
  .sf-quote-section {
    padding: 78px 20px 92px;
  }

  .sf-quote-inner {
    width: min(94vw, 920px);
  }

  .sf-quote-layout {
    grid-template-columns: 1fr;
    gap: 26px;
    margin-top: 42px;
  }

  .sf-quote-copy {
    padding: 40px;
  }

  .sf-quote-copy h3 {
    font-size: 38px;
  }

  .sf-quote-card {
    padding: 36px;
  }
}

@media (max-width: 767px) {
  .sf-quote-section {
    padding: 64px 18px 78px;
  }

  .sf-quote-inner {
    width: 100%;
  }

  .sf-quote-layout {
    margin-top: 34px;
    gap: 20px;
  }

  .sf-quote-copy {
    padding: 30px 24px 34px;
    border-radius: 20px;
  }

  .sf-quote-copy::after {
    left: 24px;
    right: 24px;
  }

  .sf-quote-copy h3 {
    font-size: 31px;
  }

  .sf-quote-copy p {
    font-size: 15px;
  }

  .sf-quote-card {
    padding: 24px;
    border-radius: 20px;
  }

  .sf-quote-form .elementor-field-group {
    width: 100% !important;
  }

  .sf-quote-form .elementor-field-option label {
    font-size: 13px;
    min-height: 40px;
  }
  
    .sf-quote-logo-link {
    width: 190px;
    margin: 0 auto 24px;
  }



}

.elementor-element-1bf283ca .sf-quote-submit-row {
  width: 100% !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  margin: 28px 0 0 !important;
}

.elementor-element-1bf283ca .sf-quote-submit-row .sf-cta-wrap {
  width: fit-content !important;
  padding: 10px 14px !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.72) !important;
  border: 1px solid rgba(0, 0, 0, 0.08) !important;
  box-shadow:
    0 12px 35px rgba(0, 0, 0, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.9) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
}

.elementor-element-1bf283ca .sf-quote-submit-row .sf-cta {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 54px !important;
  padding: 0 10px !important;
  text-decoration: none !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  overflow: visible !important;
  cursor: pointer !important;
}

.elementor-element-1bf283ca .sf-quote-submit-row .sf-cta span {
  position: relative !important;
  z-index: 1 !important;
  display: inline-block !important;
  font-family: "Poppins", sans-serif !important;
  font-size: 19px !important;
  font-weight: 800 !important;
  line-height: 1.1 !important;
  color: #151515 !important;
  text-shadow: none !important;
  transition: opacity 0.25s ease !important;
}

.elementor-element-1bf283ca .sf-quote-submit-row .sf-cta::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Poppins", sans-serif;
  font-size: 19px;
  font-weight: 800;
  line-height: 1.1;
  white-space: nowrap;

  background: linear-gradient(
    90deg,
    #29c8ff 0%,
    #3b39ff 18%,
    #d93bdb 36%,
    #ffd400 58%,
    #9be400 78%,
    #21cdb8 100%
  );
  background-size: 25% 100%;
  background-position: 100% 50%;

  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;

  opacity: 0;
  transition: opacity 0.25s ease;
}

.elementor-element-1bf283ca .sf-quote-submit-row .sf-cta:hover span {
  opacity: 0 !important;
}

.elementor-element-1bf283ca .sf-quote-submit-row .sf-cta:hover::after {
  opacity: 1 !important;
  animation: sfQuoteTextFlow 1.6s linear infinite;
}

.elementor-element-1bf283ca .sf-quote-submit-row .sf-cta-wrap:hover {
  box-shadow:
    0 16px 45px rgba(0, 0, 0, 0.12),
    0 0 35px rgba(41, 200, 255, 0.10),
    inset 0 1px 0 rgba(255, 255, 255, 1) !important;
}

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

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

@media (max-width: 767px) {
  .elementor-element-1bf283ca .sf-quote-submit-row .sf-cta {
    min-height: 46px !important;
  }

  .elementor-element-1bf283ca .sf-quote-submit-row .sf-cta span,
  .elementor-element-1bf283ca .sf-quote-submit-row .sf-cta::after {
    font-size: 14px !important;
    white-space: nowrap !important;
  }
}

/* Source: storyframe-audit/elementor/content/page/2757.json | element: 63b9a667 */
/* Ajánlatkérés form - 320px mobil finomhangolás */
@media (max-width: 340px) {
  .elementor-element-63b9a667 {
    overflow: visible !important;
  }

  .elementor-element-63b9a667 .sf-quote-copy,
  .elementor-element-63b9a667 .sf-quote-card {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 22px !important;
    padding-right: 22px !important;
    box-sizing: border-box !important;
    overflow: visible !important;
  }

  .elementor-element-63b9a667 .sf-quote-copy h1,
  .elementor-element-63b9a667 .sf-quote-copy h2,
  .elementor-element-63b9a667 .sf-quote-copy h3 {
    max-width: 100% !important;
    font-size: 27px !important;
    line-height: 1.05 !important;
    letter-spacing: 0 !important;
    white-space: normal !important;
    overflow-wrap: break-word !important;
    word-break: normal !important;
  }

  .elementor-element-63b9a667 .sf-quote-copy p {
    font-size: 15px !important;
    line-height: 1.45 !important;
  }

  .elementor-element-63b9a667 .sf-quote-form .elementor-field-label {
    font-size: 22px !important;
    line-height: 1.05 !important;
    letter-spacing: 0 !important;
  }

  .elementor-element-63b9a667 .sf-quote-form .elementor-field-subgroup {
    gap: 9px !important;
  }

  .elementor-element-63b9a667 .sf-quote-form .elementor-field-option {
    display: flex !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    gap: 7px !important;
    width: fit-content !important;
    max-width: 100% !important;
  }

  .elementor-element-63b9a667 .sf-quote-form .elementor-field-option label {
    display: inline-flex !important;
    align-items: center !important;
    width: fit-content !important;
    max-width: none !important;
    padding: 8px 10px !important;
    font-size: 12px !important;
    line-height: 1 !important;
    white-space: nowrap !important;
  }

  .elementor-element-63b9a667 .sf-quote-form .elementor-field-option input {
    flex: 0 0 auto !important;
    width: 13px !important;
    height: 13px !important;
    margin: 0 !important;
  }

  .elementor-element-63b9a667 .sf-quote-form textarea {
    min-height: 130px !important;
  }
}

/* Ajánlatkérés - tablet kétoszlopos elrendezés */
@media (min-width: 768px) and (max-width: 1024px) {
  body .sf-quote-section {
    padding: 72px 18px 88px !important;
  }

  body .sf-quote-inner {
    width: min(96vw, 980px) !important;
  }

  body .sf-quote-layout {
    grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr) !important;
    gap: 22px !important;
    align-items: stretch !important;
    margin-top: 38px !important;
  }

  body .sf-quote-copy {
    position: relative !important;
    padding: 30px !important;
    border-radius: 20px !important;
    overflow: hidden !important;
  }

  body .sf-quote-copy::after {
    left: 30px !important;
    right: 30px !important;
  }

  body .sf-quote-copy-block {
    width: 100% !important;
    min-height: 100% !important;
    display: block !important;
    padding-bottom: 0 !important;
  }

  body .sf-quote-eyebrow {
    margin-bottom: 15px !important;
  }

  body .sf-quote-copy h3 {
    font-size: clamp(30px, 3.7vw, 38px) !important;
  }

  body .sf-quote-copy p {
    font-size: 15px !important;
    line-height: 1.45 !important;
  }

  body .sf-quote-contact {
    gap: 10px !important;
    margin-top: 26px !important;
  }

  body .sf-quote-contact a {
    padding: 14px 16px !important;
    border-radius: 14px !important;
    font-size: 14px !important;
  }

  body .sf-quote-logo-link {
    position: absolute !important;
    left: 50% !important;
    right: auto !important;
    top: auto !important;
    bottom: -315px !important;
    width: clamp(260px, 34vw, 360px) !important;
    max-width: calc(100% - 42px) !important;
    margin: 0 !important;
    transform: translateX(-50%) !important;
  }

  body .sf-quote-logo-img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
  }

  body .sf-quote-card {
    padding: 28px !important;
    border-radius: 20px !important;
  }
}

/* Source: storyframe-audit/elementor/content/page/2757.json | element: 47f5f1a3 */
@media (max-width: 374px) {
  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option {
    display: grid !important;
    grid-template-columns: 14px minmax(0, 1fr) !important;
    column-gap: 8px !important;
    row-gap: 0 !important;
    align-items: flex-start !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option input {
    width: 14px !important;
    height: 14px !important;
    margin: 3px 0 0 !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option label {
    display: block !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: 100% !important;
    min-height: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    white-space: normal !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    line-height: 1.35 !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option label a {
    display: inline !important;
    width: auto !important;
    max-width: none !important;
    white-space: nowrap !important;
    overflow-wrap: normal !important;
    word-break: keep-all !important;
  }
}

@media (max-width: 430px) {
  body .sf-quote-section .sf-quote-inner .sf-quote-copy h3 {
    font-size: 27px !important;
    line-height: 1.08 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
    text-wrap: balance;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-group-field_6cde44b {
    position: relative;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-group-field_6cde44b input::placeholder {
    color: transparent !important;
    opacity: 0 !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-group-field_6cde44b::after {
    content: "Facebook / Instagram / Google / Ajánlás / TikTok / Egyéb";
    display: block;
    margin-top: 8px;
    padding-left: 2px;
    font-family: "Inter", "Poppins", sans-serif;
    font-size: 11px;
    line-height: 1.35;
    font-weight: 600;
    color: rgba(0, 0, 0, 0.46);
  }
}

@media (max-width: 340px) {
  body .sf-quote-section .sf-quote-inner .sf-quote-layout .sf-quote-copy {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-layout .sf-quote-copy h3 {
    font-size: 23px !important;
    line-height: 1.08 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
    text-wrap: balance;
  }
}

/* Source: storyframe-audit/elementor/content/page/2757.json | element: 4db4cd00 */
.sf-quote-section {
  padding: 90px 20px 110px;
  background: #ffffff;
}

.sf-quote-inner {
  width: min(92vw, 1420px);
  margin: 0 auto;
}

.sf-quote-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 34px;
  align-items: stretch;
  margin-top: 52px;
}

.sf-quote-copy,
.sf-quote-card {
  border-radius: 24px;
}

.sf-quote-copy {
  padding: 46px;
  background: #111111;
  color: #ffffff;
  overflow: hidden;
  position: relative;
}

.sf-quote-copy::after {
  content: "";
  position: absolute;
  left: 46px;
  right: 46px;
  bottom: 0;
  height: 6px;
  background: linear-gradient(90deg, #29c8ff, #3b39ff, #d93bdb, #ffd400, #9be400, #21cdb8);
}

.sf-quote-logo-link {
  position: relative;
  display: flex;
  width: clamp(200px, 21vw, 320px);
  aspect-ratio: 1 / 1;
  align-items: center;
  justify-content: center;
  margin: 34px auto 0;
  text-decoration: none;
  overflow: visible;
}


.sf-quote-logo-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.sf-quote-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-quote-logo-link:hover::after {
  opacity: 0.95;
  animation: sfQuoteLogoFlow 1.1s linear infinite;
}

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

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



.sf-quote-eyebrow {
  margin: 0 0 18px;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.sf-quote-copy h3 {
  margin: 0 0 24px;
  font-family: "Poppins", sans-serif;
  font-size: 44px;
  line-height: 1.05;
  font-weight: 900;
}

.sf-quote-copy p {
  margin: 0 0 18px;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 18px;
  line-height: 1.4;
  color: rgba(255,255,255,0.78);
}

.sf-quote-contact {
  display: grid;
  gap: 12px;
  margin-top: 34px;
}

.sf-quote-contact a {
  display: block;
  padding: 18px 20px;
  border-radius: 16px;
  color: #ffffff;
  text-decoration: none;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.14);
  font-family: "Inter", "Poppins", sans-serif;
  font-weight: 700;
}

.sf-quote-contact span {
  display: block;
  margin-bottom: 4px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}

.sf-quote-card {
  padding: 42px;
  background:
    linear-gradient(#ffffff, #ffffff) padding-box,
    linear-gradient(135deg, #29c8ff, #3b39ff, #d93bdb, #ffd400, #9be400, #21cdb8) border-box;
  border: 4px solid transparent;
  box-shadow: 0 24px 80px rgba(0,0,0,0.10);
}

.sf-quote-form .elementor-field-label {
  margin-bottom: 8px;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 13px;
  font-weight: 800;
  color: #151515;
}

.sf-quote-form .elementor-field-textual {
  min-height: 52px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,0.12);
  background: #f7f7f7;
  padding: 14px 16px;
  font-family: "Inter", "Poppins", sans-serif;
}

.sf-quote-form textarea.elementor-field-textual {
  min-height: 140px;
  resize: vertical;
}

.sf-quote-form .elementor-field-subgroup {
  display: flex;
  flex-wrap: wrap;
  gap: 13px;
}

.sf-quote-form .elementor-field-option label {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 10px 14px;
  border-radius: 999px;
  background: #f7f7f7;
  border: 1px solid rgba(0,0,0,0.10);
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
}

.sf-quote-form .elementor-field-option input {
  margin-right: 10px;
}

.sf-quote-form .elementor-field-type-acceptance {
  margin-top: 16px;
  margin-bottom: 24px;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-subgroup {
  display: block !important;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-option {
  display: flex !important;
  align-items: flex-start;
  gap: 10px;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-option input {
  flex: 0 0 auto;
  margin: 4px 0 0 !important;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-option label {
  display: block !important;
  min-height: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 12px;
  line-height: 1.55;
  font-weight: 500;
  color: rgba(0,0,0,0.62);
}

.sf-quote-form .elementor-field-type-acceptance a {
  color: #151515;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 3px;
}


.sf-quote-form .elementor-field-type-submit {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
  margin: 0 !important;
  padding: 0 !important;
}

.sf-quote-form .elementor-field-type-html {
  width: 100% !important;
  flex-basis: 100% !important;
}

.sf-quote-submit-row {
  display: flex !important;
  justify-content: center !important;
  width: 100% !important;
  margin-top: 10px;
}

.sf-quote-submit-row .sf-cta-wrap {
  width: auto !important;
  max-width: max-content !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.sf-quote-submit-row .sf-cta {
  width: auto !important;
}




@media (max-width: 1024px) {
  .sf-quote-section {
    padding: 78px 20px 92px;
  }

  .sf-quote-inner {
    width: min(94vw, 920px);
  }

  .sf-quote-layout {
    grid-template-columns: 1fr;
    gap: 26px;
    margin-top: 42px;
  }

  .sf-quote-copy {
    padding: 40px;
  }

  .sf-quote-copy h3 {
    font-size: 38px;
  }

  .sf-quote-card {
    padding: 36px;
  }
}

@media (max-width: 767px) {
  .sf-quote-section {
    padding: 64px 18px 78px;
  }

  .sf-quote-inner {
    width: 100%;
  }

  .sf-quote-layout {
    margin-top: 34px;
    gap: 20px;
  }

  .sf-quote-copy {
    padding: 30px 24px 34px;
    border-radius: 20px;
  }

  .sf-quote-copy::after {
    left: 24px;
    right: 24px;
  }

  .sf-quote-copy h3 {
    font-size: 31px;
  }

  .sf-quote-copy p {
    font-size: 15px;
  }

  .sf-quote-card {
    padding: 24px;
    border-radius: 20px;
  }

  .sf-quote-form .elementor-field-group {
    width: 100% !important;
  }

  .sf-quote-form .elementor-field-option label {
    font-size: 13px;
    min-height: 40px;
  }
  
    .sf-quote-logo-link {
    width: 190px;
    margin: 0 auto 24px;
  }



}

.elementor-element-4db4cd00 .sf-quote-submit-row {
  width: 100% !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  margin: 28px 0 0 !important;
}

.elementor-element-4db4cd00 .sf-quote-submit-row .sf-cta-wrap {
  width: fit-content !important;
  padding: 10px 14px !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.72) !important;
  border: 1px solid rgba(0, 0, 0, 0.08) !important;
  box-shadow:
    0 12px 35px rgba(0, 0, 0, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.9) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
}

.elementor-element-4db4cd00 .sf-quote-submit-row .sf-cta {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 54px !important;
  padding: 0 10px !important;
  text-decoration: none !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  overflow: visible !important;
  cursor: pointer !important;
}

.elementor-element-4db4cd00 .sf-quote-submit-row .sf-cta span {
  position: relative !important;
  z-index: 1 !important;
  display: inline-block !important;
  font-family: "Poppins", sans-serif !important;
  font-size: 19px !important;
  font-weight: 800 !important;
  line-height: 1.1 !important;
  color: #151515 !important;
  text-shadow: none !important;
  transition: opacity 0.25s ease !important;
}

.elementor-element-4db4cd00 .sf-quote-submit-row .sf-cta::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Poppins", sans-serif;
  font-size: 19px;
  font-weight: 800;
  line-height: 1.1;
  white-space: nowrap;

  background: linear-gradient(
    90deg,
    #29c8ff 0%,
    #3b39ff 18%,
    #d93bdb 36%,
    #ffd400 58%,
    #9be400 78%,
    #21cdb8 100%
  );
  background-size: 25% 100%;
  background-position: 100% 50%;

  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;

  opacity: 0;
  transition: opacity 0.25s ease;
}

.elementor-element-4db4cd00 .sf-quote-submit-row .sf-cta:hover span {
  opacity: 0 !important;
}

.elementor-element-4db4cd00 .sf-quote-submit-row .sf-cta:hover::after {
  opacity: 1 !important;
  animation: sfQuoteTextFlow 1.6s linear infinite;
}

.elementor-element-4db4cd00 .sf-quote-submit-row .sf-cta-wrap:hover {
  box-shadow:
    0 16px 45px rgba(0, 0, 0, 0.12),
    0 0 35px rgba(41, 200, 255, 0.10),
    inset 0 1px 0 rgba(255, 255, 255, 1) !important;
}

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

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

@media (max-width: 767px) {
  .elementor-element-4db4cd00 .sf-quote-submit-row .sf-cta {
    min-height: 46px !important;
  }

  .elementor-element-4db4cd00 .sf-quote-submit-row .sf-cta span,
  .elementor-element-4db4cd00 .sf-quote-submit-row .sf-cta::after {
    font-size: 14px !important;
    white-space: nowrap !important;
  }
}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 721fd9ab */
:root {
  --sf-section-padding-desktop: 35px;
  --sf-section-padding-tablet: 25px;
  --sf-section-padding-mobile: 15px;
}



.sf-section-space {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  padding-top: var(--sf-section-padding-desktop) !important;
  padding-bottom: var(--sf-section-padding-desktop) !important;
}

@media (max-width: 1024px) {
  .sf-section-space {
    padding-top: var(--sf-section-padding-tablet) !important;
    padding-bottom: var(--sf-section-padding-tablet) !important;
  }
}

@media (max-width: 767px) {
  .sf-section-space {
    padding-top: var(--sf-section-padding-mobile) !important;
    padding-bottom: var(--sf-section-padding-mobile) !important;
  }
}
html,
body {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
}

.elementor,
.elementor-location-footer,
.elementor-section,
.e-con,
.e-con-inner {
  max-width: 100%;
}

img,
video,
iframe {
  max-width: 100%;
}

.sf-section-space.sf-section-tight {
  padding-top: 7px !important;
  padding-bottom: 0px !important;
}

@media (max-width: 1024px) {
  .sf-section-space.sf-section-tight {
    padding-top: 10px !important;
    padding-bottom: 0px !important;
  }
}

@media (max-width: 767px) {
  .sf-section-space.sf-section-tight {
    padding-top: 0px !important;
    padding-bottom: 0px !important;
  }
}

@media (max-width: 340px) {
  :root {
    --sf-section-padding-mobile: 26px;
  }

  .sf-section-space {
    padding-top: 26px !important;
    padding-bottom: 26px !important;
  }

  .rainbow-social {
    display: none !important;
  }

  .sf-quote-copy,
  .sf-quote-card {
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  .sf-quote-copy h3 {
    font-size: 26px !important;
    line-height: 1.05 !important;
    overflow-wrap: anywhere;
  }

  .sf-quote-copy p {
    font-size: 14px !important;
    line-height: 1.45 !important;
  }

  .sf-quote-form .elementor-field-label {
    font-size: 22px !important;
    line-height: 1.05 !important;
  }

  .sf-quote-form .elementor-field-subgroup {
    gap: 9px !important;
  }

  .sf-quote-form .elementor-field-option label {
    max-width: 100%;
    white-space: normal !important;
    line-height: 1.25 !important;
    font-size: 13px !important;
    padding: 9px 12px !important;
  }

  .sf-quote-form .elementor-field-option {
    align-items: flex-start;
  }
}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 2b24bf8b */
.hero-video {
position: relative;
width: 100%;
height: 50vh;
overflow: hidden;
    
}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 1f005d2 */
.elementor-element-1f005d2{
  position: relative;
  overflow: visible;
}

.elementor-element-1f005d2 .sf-simple-title{
  position: absolute;
  left: 50px;
  bottom: -20px;
  z-index: 10;
  line-height: 1.5;
}

.elementor-element-1f005d2 .sf-simple-title .sf-line{
  display: block;
  width: fit-content;
  max-width: 100%;
  position: relative;
  background: #ffffff;
  color: #222222;
  padding: 14px 18px 18px 18px;
  margin: 0;
  font-weight: 800;
  font-size: 2rem;
}

.elementor-element-1f005d2 .sf-simple-title .sf-line + .sf-line{
  margin-top: -4px;
}

.elementor-element-1f005d2 .sf-simple-title .sf-line::after{
  content: "";
  position: absolute;
  left: 18px;
  bottom: 10px;
  height: 10px;
}

.elementor-element-1f005d2 .sf-simple-title .sf-line-1::after{
  width: calc(100% - 30px);
  background: linear-gradient(
    to right,
    #18bdf2 0%,
    #18bdf2 33%,
    #2a1fd6 33%,
    #2a1fd6 66%,
    #d63ac7 66%,
    #d63ac7 100%
  );
}

.elementor-element-1f005d2 .sf-simple-title .sf-line-2::after{
  width: calc(100% - 30px);
  background: linear-gradient(
    to right,
    #f3c400 0%,
    #f3c400 33%,
    #97d700 33%,
    #97d700 66%,
    #3fd05f 66%,
    #10b7a7 100%
  );
}
/* TABLET */
@media (max-width: 1024px){
  .elementor-element-1f005d2 .sf-simple-title{
    left: 32px;
    bottom: -18px;
  }

  .elementor-element-1f005d2 .sf-simple-title .sf-line{
    font-size: 1.6rem;
    padding: 12px 16px 16px 16px;
  }

  .elementor-element-1f005d2 .sf-simple-title .sf-line::after{
    left: 16px;
    bottom: 9px;
    height: 9px;
  }

  .elementor-element-1f005d2 .sf-simple-title .sf-line-1::after,
  .elementor-element-1f005d2 .sf-simple-title .sf-line-2::after{
    width: calc(100% - 28px);
  }
}


/* MOBILE */
@media (max-width: 767px){
  .elementor-element-1f005d2 .sf-simple-title{
    left: 21px;
    right: 18px;
    bottom: 13px;
  }

  .elementor-element-1f005d2 .sf-simple-title .sf-line{
    font-size: 0.8rem;
    padding: 10px 12px 14px 13px;
    max-width: fit-content;
  }

  .elementor-element-1f005d2 .sf-simple-title .sf-line + .sf-line{
    margin-top: -3px;
  }

  .elementor-element-1f005d2 .sf-simple-title .sf-line::after{
    left: 13px;
    bottom: 8px;
    height: 7px;
  }

  .elementor-element-1f005d2 .sf-simple-title .sf-line-1::after,
  .elementor-element-1f005d2 .sf-simple-title .sf-line-2::after{
    width: calc(100% - 24px);
  }
}

/* XS MOBILE - 320px javítás */
@media (max-width: 340px){
  .elementor-element-1f005d2 .sf-simple-title{
    left: 16px;
    right: 16px;
    bottom: 12px;
    max-width: calc(100% - 32px);
  }

  .elementor-element-1f005d2 .sf-simple-title .sf-line{
    white-space: nowrap;
    max-width: none;
    font-size: 0.66rem;
    line-height: 1.15;
    padding: 8px 10px 12px 10px;
  }

  .elementor-element-1f005d2 .sf-simple-title .sf-line-1{
    font-size: 0.59rem;
  }

  .elementor-element-1f005d2 .sf-simple-title .sf-line + .sf-line{
    margin-top: -2px;
  }

  .elementor-element-1f005d2 .sf-simple-title .sf-line::after{
    left: 10px;
    bottom: 7px;
    height: 5px;
    width: calc(100% - 20px);
  }

  .elementor-element-1f005d2 .sf-simple-title .sf-line-1::after,
  .elementor-element-1f005d2 .sf-simple-title .sf-line-2::after{
    width: calc(100% - 20px);
  }
}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 1e4c24d */
/* 320px FIX - Intro dupla CTA ne nyúljon teljes szélességre */
@media (max-width: 340px) {
  .elementor-17 .elementor-element.elementor-element-307196b {
    align-items: center !important;
  }

  .elementor-17 .elementor-element.elementor-element-307196b > .elementor-element,
  .elementor-17 .elementor-element.elementor-element-307196b .elementor-widget-html {
    width: fit-content !important;
    max-width: max-content !important;
    flex-grow: 0 !important;
    flex-shrink: 0 !important;
    align-self: center !important;
  }

  .elementor-17 .elementor-element.elementor-element-307196b .sf-cta-wrap {
    width: fit-content !important;
    max-width: max-content !important;
    min-width: 0 !important;
    margin-left: auto !important;
    margin-right: auto !important;
    display: inline-flex !important;
  }

  .elementor-17 .elementor-element.elementor-element-307196b .sf-cta {
    width: auto !important;
    max-width: max-content !important;
  }
}

/* 320px - intro CTA arányok finomhangolása */
@media (max-width: 340px) {
  .elementor-17 .elementor-element.elementor-element-307196b {
    --cta-font: 15px;
    --cta-short-width: 165px;
    --cta-tall-width: 205px;
    --cta-height: 58px;
    --cta-padding-x: 14px;
  }

  .elementor-17 .elementor-element.elementor-element-307196b .sf-cta-wrap {
    min-height: var(--cta-height) !important;
    padding: 8px var(--cta-padding-x) !important;
    justify-content: center !important;
  }

  .elementor-17 .elementor-element.elementor-element-307196b > .elementor-element:first-child .sf-cta-wrap {
    min-width: var(--cta-short-width) !important;
  }

  .elementor-17 .elementor-element.elementor-element-307196b > .elementor-element:nth-child(2) .sf-cta-wrap {
    min-width: var(--cta-tall-width) !important;
  }

  .elementor-17 .elementor-element.elementor-element-307196b .sf-cta span,
  .elementor-17 .elementor-element.elementor-element-307196b .sf-cta::after {
    font-size: var(--cta-font) !important;
    line-height: 1.1 !important;
  }
}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 730953a7 */
.sf-cta-wrap {
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
  align-items: center;
}

.sf-cta {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  padding: 0 6px;
  text-decoration: none;
  background: transparent;
  border: none;
  box-shadow: none;
  overflow: visible;

}

.sf-cta span {
  position: relative;
  z-index: 1;
  display: inline-block;
  font-size: 19px;
  font-weight: 800;
  line-height: 1.1;
  color: #ffffff;
  transition: opacity 0.25s ease;
  text-shadow: 0 0 6px rgba(0,0,0,0.4);
}

.sf-cta::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 19px;
  font-weight: 800;
  line-height: 1.1;
  white-space: nowrap;



  background: linear-gradient(
    90deg,
    #29c8ff 0%,
    #3b39ff 18%,
    #d93bdb 36%,
    #ffd400 58%,
    #9be400 78%,
    #21cdb8 100%
  );
  background-size:
  25% 100%;
  background-position: 100% 50%;

  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;

  opacity: 0;
  transition: opacity 0.25s ease;
}

.sf-cta:hover span {
  opacity: 0;
}

.sf-cta:hover::after {
  opacity: 1;
  animation: sfTextFlow 1.6s linear infinite;
}

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


.sf-cta {
  position: relative;
}

.sf-cta::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: -4px;
  width: 100%;
  height: 2px;


  opacity: 0.35;
}


.sf-cta-wrap {
  width: fit-content;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(0, 0, 0, 0.08);
  box-shadow:
    0 12px 35px rgba(0, 0, 0, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.sf-cta span {
  color: #151515;
  text-shadow: none;
}

.sf-cta {
  padding: 0 10px;
}

.sf-cta-wrap:hover {
  box-shadow:
    0 16px 45px rgba(0, 0, 0, 0.12),
    0 0 35px rgba(41, 200, 255, 0.10),
    inset 0 1px 0 rgba(255, 255, 255, 1);
}
@media (max-width: 767px) {
  .sf-cta-wrap {
    gap: 1px;
  }

  .sf-cta span,
  .sf-cta::after {
    font-size: 13px;
  }
}

/* 320px - dupla CTA kompakt mobil verzió */
@media (max-width: 340px){
  .elementor-17 .elementor-element.elementor-element-34b418d{
    width: calc(100vw - 34px) !important;
    max-width: calc(100vw - 34px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .elementor-17 .elementor-element.elementor-element-34b418d .sf-cta-wrap{
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    width: fit-content !important;
    max-width: 100% !important;
    padding: 9px 11px !important;
  }

  .elementor-17 .elementor-element.elementor-element-34b418d .sf-cta{
    padding: 0 4px !important;
    min-height: 42px !important;
    white-space: nowrap !important;
  }

  .elementor-17 .elementor-element.elementor-element-34b418d .sf-cta span,
  .elementor-17 .elementor-element.elementor-element-34b418d .sf-cta::after{
    font-size: 14px !important;
    white-space: nowrap !important;
  }
}

/* 320px - CTA kapszula ne nyúljon teljes szélességre */
@media (max-width: 340px){
  .sf-cta-wrap {
    width: fit-content !important;
    max-width: max-content !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .sf-cta {
    width: auto !important;
    max-width: max-content !important;
    white-space: nowrap !important;
  }

  .sf-cta span,
  .sf-cta::after {
    white-space: nowrap !important;
  }
}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 733c0613 */
/* FLOATING SOCIAL - ALAP */
.rainbow-social .elementor-social-icon {
  position: relative;
  width: 48px;
  height: 48px;
  background: rgba(255,255,255,0.92) !important;
  border: 1px solid rgba(0,0,0,0.28);
  border-radius: 999px;
  overflow: visible;
  box-shadow: 0 10px 28px rgba(0,0,0,0.08);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

/* régi overlay teljes kikapcsolása */
.rainbow-social .elementor-social-icon::before,
.rainbow-social .elementor-social-icon::after {
  display: none !important;
  content: none !important;
}

/* ikon alap */
.rainbow-social .elementor-social-icon i,
.rainbow-social .elementor-social-icon svg {
  position: relative;
  z-index: 2;
  color: #050505 !important;
  fill: #050505 !important;
  background: transparent !important;
  box-shadow: none !important;
  opacity: 1 !important;
  transition: transform 0.25s ease, color 0.25s ease, fill 0.25s ease, filter 0.25s ease;
}

/* svg belső path biztosan kövesse a színt */
.rainbow-social .elementor-social-icon svg path {
  fill: currentColor !important;
}

/* hover: csak az ikon világít, a kör nem töltődik ki */
.rainbow-social .elementor-social-icon:hover {
  transform: translateY(-1px);
  border-color: rgba(0,0,0,0.34);
  box-shadow: 0 14px 36px rgba(0,0,0,0.12);
}

.rainbow-social .elementor-social-icon:hover i,
.rainbow-social .elementor-social-icon:hover svg {
  transform: scale(1.12);
  animation: sfFloatingSocialIconGlow 1s linear infinite;
}

/* intenzívebb, footer-socialhoz hasonló színváltás */
@keyframes sfFloatingSocialIconGlow {
  0% {
    color: #29c8ff;
    fill: #29c8ff;
    filter: drop-shadow(0 0 3px #29c8ff) drop-shadow(0 0 12px #29c8ff);
  }

  20% {
    color: #3b39ff;
    fill: #3b39ff;
    filter: drop-shadow(0 0 3px #3b39ff) drop-shadow(0 0 14px #3b39ff);
  }

  40% {
    color: #d93bdb;
    fill: #d93bdb;
    filter: drop-shadow(0 0 3px #d93bdb) drop-shadow(0 0 15px #d93bdb);
  }

  60% {
    color: #ffd400;
    fill: #ffd400;
    filter: drop-shadow(0 0 3px #ffd400) drop-shadow(0 0 14px #ffd400);
  }

  80% {
    color: #9be400;
    fill: #9be400;
    filter: drop-shadow(0 0 3px #9be400) drop-shadow(0 0 14px #9be400);
  }

  100% {
    color: #21cdb8;
    fill: #21cdb8;
    filter: drop-shadow(0 0 3px #21cdb8) drop-shadow(0 0 12px #21cdb8);
  }
}

/* MOBIL */
@media (max-width: 767px) {
  .rainbow-social .elementor-social-icon {
    width: 40px !important;
    height: 40px !important;
    font-size: 18px !important;
    line-height: 40px !important;
  }

  .rainbow-social .elementor-social-icon i {
    font-size: 18px !important;
  }

  .rainbow-social .elementor-social-icon svg {
    width: 18px !important;
    height: 18px !important;
  }
}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 4390fda2 */
.elementor-element-4390fda2 {
  align-items: stretch;
}

.elementor-element-4390fda2 > .e-con:not(:first-child) {
  height: 100%;
  min-height: 650px;
  display: flex;
  flex-direction: column;
}

.elementor-element-4390fda2 > .e-con:not(:first-child) .sf-cta-widget {
  margin-top: auto;
  align-self: center;
  width: fit-content;
  max-width: 100%;
}

.elementor-element-4390fda2 > .e-con:not(:first-child) .sf-cta-wrap {
  margin-left: auto;
  margin-right: auto;
}

@media (min-width: 1150px) and (max-width: 1270px) {
  .elementor-element-4390fda2 {
    align-items: stretch !important;
  }

  .elementor-element-4390fda2 > .e-con {
    display: flex !important;
    flex-direction: column !important;
    height: auto !important;
    min-height: 0 !important;
    position: relative !important;
    padding-bottom: 42px !important;
  }

  .elementor-element-4390fda2 > .e-con .sf-cta-widget {
    position: static !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    transform: none !important;
    margin-top: auto !important;
    align-self: center !important;
    width: fit-content !important;
    max-width: 100% !important;
  }

  .elementor-element-4390fda2 > .e-con .sf-cta-wrap {
    position: static !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    transform: none !important;
    margin: 0 auto !important;
  }
}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 5e12741 */
.elementor-element-5e12741 {
  display: block;
  width: fit-content;
  position: relative;
  background: #ffffff;
  color: #222222;
  padding: 14px 18px 18px 18px;
  margin: 0;
  font-weight: 800;
  font-size: 27px;
}

.elementor-element-5e12741::after {
  content: '';
  position: absolute;
  left: 18px;
  bottom: 10px;
  height: 10px;
  width: calc(100% - 30px);
  background: linear-gradient(to right, #18bdf2 0%, #18bdf2 33%, #2a1fd6 33%, #2a1fd6 66%, #d63ac7 66%, #d63ac7 100%);
}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 1bd97da1 */
.elementor-element-1bd97da1 {
  display: block;
  width: fit-content;
  position: relative;
  background: #ffffff;
  color: #222222;
  padding: 14px 18px 18px 18px;
  margin: 0;
  font-weight: 800;
    font-size: 27px;

}

.elementor-element-1bd97da1::after {
  content: '';
  position: absolute;
  left: 18px;
  bottom: 10px;
  height: 10px;
  width: calc(100% - 30px);
  background: linear-gradient(to right, #f3c400 0%, #f3c400 33%, #97d700 33%, #97d700 66%, #3fd05f 66%, #10b7a7 100%);
}

/* 320px - szolgáltatás cím ne törjön két sorba */
@media (max-width: 340px){
  .elementor-element-1bd97da1{
    white-space: nowrap;
    font-size: 27px;
    padding-left: 10px;
    padding-right: 10px;
    width: fit-content;
    max-width: none;
  }

  .elementor-element-1bd97da1::after{
    left: 10px;
    width: calc(100% - 20px);
  }
}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 49015024 */
.elementor-element-49015024 {
  display: block;
  width: fit-content;
  position: relative;
  background: #ffffff;
  color: #222222;
  padding: 14px 18px 18px 18px;
  margin: 0;
  font-weight: 800;
  font-size: 27px;
}

.elementor-element-49015024::after {
  content: '';
  position: absolute;
  left: 18px;
  bottom: 10px;
  height: 10px;
  width: calc(100% - 30px);
  background: linear-gradient(to right, #18bdf2 0%, #18bdf2 33%, #2a1fd6 33%, #2a1fd6 66%, #d63ac7 66%, #d63ac7 100%);
}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 5a7aca98 */
.elementor-element-5a7aca98 {
  display: block;
  width: fit-content;
  position: relative;
  background: #ffffff;
  color: #222222;
  padding: 14px 18px 18px 18px;
  margin: 0;
  font-weight: 800;
    font-size: 27px;

}

.elementor-element-5a7aca98::after {
  content: '';
  position: absolute;
  left: 18px;
  bottom: 10px;
  height: 10px;
  width: calc(100% - 30px);
  background: linear-gradient(to right, #f3c400 0%, #f3c400 33%, #97d700 33%, #97d700 66%, #3fd05f 66%, #10b7a7 100%);
}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 34d2129a */
/* ALAP állapot */
.rainbow-hover {
  position: relative;
  background: rgba(255,255,255,0.85);
  border: 1px solid rgba(0,0,0,0.08);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: all 0.3s ease;
  overflow: hidden;
}

/* belső content (pl. text / icon) */
.rainbow-hover > * {
  position: relative;
  z-index: 2;
  transition: opacity 0.2s ease;
}

/* GRADIENT overlay */
.rainbow-hover::after {
  content: "";
  position: absolute;
  inset: 0;

  background: linear-gradient(
    90deg,
    #29c8ff 0%,
    #3b39ff 18%,
    #d93bdb 36%,
    #ffd400 58%,
    #9be400 78%,
    #21cdb8 100%
  );

  background-size: 20% 100%;
  background-position: 20% 50%;

  opacity: 0;
  transition: opacity 0.25s ease;
}

/* hover */
.rainbow-hover:hover::after {
  opacity: 0.5;
  animation: sfIconFlow 1.5s linear infinite;
}

/* animáció */
@keyframes sfIconFlow {
  0% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}


@media (max-width: 1024px) and (min-width: 768px) {
    /* Kényszerítjük a tárolót a törésre */
    .elementor-element-34d2129a .swiper-wrapper {
        display: flex !important;
        flex-wrap: wrap !important;
        transform: translate3d(0px, 0px, 0px) !important;
        width: 100% !important;
    }

    /* Beállítjuk a 2x2-es szélességet */
    .elementor-element-34d2129a .swiper-slide {
        width: calc(50% - 10px) !important; /* 10px a köztes hézag miatt */
        margin-right: 10px !important;
        margin-bottom: 20px !important;
        flex-shrink: 0 !important;
    }

    /* Minden második elem után ne legyen margó */
    .elementor-element-34d2129a .swiper-slide:nth-child(2n) {
        margin-right: 0 !important;
    }

    /* Elrejtjük a felesleges navigációt */
    .elementor-element-34d2129a .elementor-swiper-button, 
    .elementor-element-34d2129a .swiper-pagination {
        display: none !important;
    }
}
/* Mobil: Egymás alá (1 oszlop) */
@media (max-width: 767px) {
    .elementor-element-34d2129a .swiper-wrapper {
        display: flex !important;
        flex-wrap: wrap !important;
        transform: translate3d(0px, 0px, 0px) !important;
    }
    .elementor-element-34d2129a .swiper-slide {
        width: 100% !important;
        margin-bottom: 20px !important;
    }
}

/* Ismétlődés és navigáció elrejtése */
.elementor-element-34d2129a .swiper-slide-duplicate {
    display: none !important;
}
.elementor-element-34d2129a .elementor-swiper-button, 
.elementor-element-34d2129a .swiper-pagination {
    display: none !important;
}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 164dd18 */
@media (max-width: 340px) {
  html,
  body {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
  }

  .elementor-17 .elementor-element.elementor-element-91d7bdf,
  .elementor-17 .elementor-element.elementor-element-c480396 {
    --width: 100% !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .elementor-17 .elementor-element.elementor-element-34b418d {
    width: calc(100vw - 32px) !important;
    max-width: calc(100vw - 32px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    --container-widget-width: calc(100vw - 32px) !important;
  }

  .elementor-17 .elementor-element.elementor-element-34b418d .sf-cta-wrap {
    width: auto !important;
    max-width: 100% !important;
    justify-content: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .rainbow-social {
    display: none !important;
  }

  img.about-image,
  .about-image.e-b47806d-2292fc0 {
    width: min(76vw, 240px) !important;
    max-width: min(76vw, 240px) !important;
    height: auto !important;
    max-height: none !important;
    object-fit: contain !important;
    object-position: center center !important;
  }

  .why-mobile-list {
    width: calc(100vw - 48px) !important;
    max-width: 272px !important;
    gap: 12px !important;
    align-items: stretch !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .why-mobile-list p,
  .why-mobile-list .e-paragraph-base {
    width: 100% !important;
    font-size: 15px !important;
    line-height: 1.32 !important;
    letter-spacing: 0.06em !important;
    padding-left: 24px !important;
    text-indent: -24px !important;
    margin: 0 !important;
  }

  .sf-quote-form .elementor-field-label {
    font-size: 18px !important;
    line-height: 1.15 !important;
  }

  .sf-quote-form .elementor-field-option label {
    font-size: 12px !important;
    padding: 8px 10px !important;
    line-height: 1.2 !important;
  }
}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 2d57dff4 */
.sf-section-title-snake {
  position: relative;
  display: inline-block;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
  padding: 14px 28px;
  color: #000;
  background:
    linear-gradient(#fff, #fff) padding-box,
    linear-gradient(
      90deg,
      #18bdf2,
      #2a1fd6,
      #d63ac7,
      #ff7a1a,
      #f4d03f,
      #7ac943,
      #18bdf2
    ) border-box;
  border: 5px solid transparent;
  border-radius: 8px;
  background-size: 100% 100%, 300% 300%;
  animation: sf-border-flow 4s linear infinite;
  z-index: 1;
}

@keyframes sf-border-flow {
  0% {
    background-position: 0 0, 0% 50%;
  }

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

@media (max-width: 767px) {
  .rainbow-social {
    --icon-size: 17px !important;
  }

  .rainbow-social .elementor-social-icon {
    --icon-padding: .55em !important;
  }

  .sf-section-title-snake {
    box-sizing: border-box !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;

    width: min(295px, calc(100vw - 80px)) !important;
    max-width: min(295px, calc(100vw - 80px)) !important;

    margin-left: auto !important;
    margin-right: auto !important;
    transform: none !important;

    padding: 8px 10px !important;
    border-width: 3px !important;

    font-size: clamp(1.55rem, 8vw, 1.9rem) !important;
    letter-spacing: 0 !important;
    line-height: 1.05 !important;
    text-align: center !important;
    white-space: normal !important;
  }

  .sf-section-title-snake.sf-title-long,
  .sf-section-title-snake.sf-selfie-title-responsive {
    font-size: clamp(1.33rem, 7vw, 1.7rem) !important;
    line-height: 1.08 !important;
    padding-left: 6px !important;
    padding-right: 6px !important;
  }
}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 447c41fc */
.elementor-element-447c41fc {
  display: block;
  width: fit-content;
  position: relative;
  background: #ffffff;
  color: #222222;
  padding: 14px 18px 18px 18px;
  margin: 0;
  font-weight: 800;
  font-size: 33px;
}

.elementor-element-447c41fc::after {
  content: '';
  position: absolute;
  left: 16px;
  bottom: 10px;
  height: 10px;
  width: calc(100% - 30px);
  background: linear-gradient(to right, #18bdf2 0%, #18bdf2 33%, #2a1fd6 33%, #2a1fd6 66%, #d63ac7 66%, #d63ac7 100%);
}

/* 901–1024px: desktopos "Miért mi?" jelenjen meg */
@media (min-width: 901px) and (max-width: 1024px) {
  .elementor-element-447c41fc {
    display: block !important;
    margin-left: -30px;
  }

  .why-tablet-section {
    display: none !important;
  }

  .why-desktop-title,
  .why-desktop-list {
    display: block !important;
    margin-left: -35px;
  }
}

/* 768–900px: külön tabletes "Miért mi?" szekció jelenjen meg */
@media (min-width: 768px) and (max-width: 900px) {
  .elementor-element-447c41fc {
    display: none !important;
  }

  .why-tablet-section {
    display: flex !important;
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .why-desktop-title,
  .why-desktop-list {
    display: none !important;
  }
}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 550514ac */
.elementor-element-550514ac {
  display: block;
  width: fit-content;
  position: relative;
  background: #ffffff;
  color: #222222;
  padding: 14px 18px 18px 18px;
  margin: 0;
  margin-left: 0; /* EZ FONTOS */
  font-weight: 800;
  font-size: 33px;
}

.elementor-element-550514ac::after {
  content: '';
  position: absolute;
  left: 16px;
  bottom: 10px;
  height: 10px;
  width: calc(100% - 30px);
  background: linear-gradient(to right, #18bdf2 0%, #18bdf2 33%, #2a1fd6 33%, #2a1fd6 66%, #d63ac7 66%, #d63ac7 100%);
}

/* 901–1024px finomhangolás */
@media (min-width: 901px) and (max-width: 1024px) {
  .elementor-element-550514ac {
    margin-left: -60px; /* EZT PRÓBÁLGASD */
  }
}

/* tablet méret */
@media (max-width: 900px) {
  .elementor-element-550514ac {
    transform: translateX(0px) translateY(0px);
    font-size: 45px;
    padding: 12px 16px 16px 16px;
    margin-left: auto;
    margin-right: auto;
  }

  .elementor-element-550514ac::after {
    left: 16px;
    bottom: 8px;
    height: 8px;
    width: calc(100% - 30px);
  }
}

/* MOBIL: 0–767px */
@media (max-width: 767px) {
    
      .elementor-element-550514ac {
    font-size: 32px;
    padding: 10px 14px 14px 14px;
    width: fit-content;
    max-width: calc(100vw - 96px);
    margin-left: auto;
    margin-right: auto;
    transform: none;
  }

  .elementor-element-550514ac::after {
    left: 14px;
    bottom: 7px;
    height: 7px;
    width: calc(100% - 28px);
  }


  /* csak a mobil/tablet verzió látszódjon */
  .why-mobile-section {
    display: flex !important;
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  /* pipás lista középre */
  @media (max-width: 767px) {
  .why-mobile-list {
    width: min(76vw, 300px) !important;
    max-width: calc(100vw - 104px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    align-items: flex-start !important;
    gap: 18px !important;
  }

  .why-mobile-list p,
  .why-mobile-list .e-paragraph-base {
    font-size: 18px !important;
    line-height: 1.35 !important;
    letter-spacing: 0.12em !important;
    text-align: left !important;
    margin: 0 !important;
    padding-left: 34px !important;
    text-indent: -34px !important;
  }
}



  /* desktopos elemek eltüntetése */
  .why-desktop-title,
  .why-desktop-list {
    display: none !important;
  }
}

/* 901-1024px: csak a desktopos Miért mi látszódjon */
@media (min-width: 901px) and (max-width: 1024px) {
  .why-mobile-section {
    display: none !important;
  }

  .why-desktop-title,
  .why-desktop-list {
    display: block !important;
  }
}

/* 901-1024px: a tablet/mobil Miért mi blokk ne látszódjon */
@media (min-width: 901px) and (max-width: 1024px) {
  .elementor-17 .elementor-element.elementor-element-7496316 {
    display: none !important;
  }

  .why-desktop-title,
  .why-desktop-list {
    display: block !important;
  }
}

/* 0-900px: a desktop Miért mi blokk ne látszódjon */
@media (max-width: 900px) {
  .why-desktop-title,
  .why-desktop-list {
    display: none !important;
  }
}
@media (max-width: 425px) {
  .sf-xs-title .elementor-heading-title,
  .sf-xs-title {
    font-size: 32px !important;
    line-height: 1.02 !important;
  }
}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 4b4de130 */
@media (min-width: 901px) and (max-width: 1024px) {
  .sf-selfie-title-responsive {
    max-width: calc(100vw - 170px);
    margin-left: 90px !important;
    margin-right: auto !important;
    white-space: normal;
    line-height: 1.08;
    text-align: center;
  }
}

@media (min-width: 768px) and (max-width: 900px) {
  .sf-selfie-title-responsive {
    max-width: calc(100vw - 130px);
    margin-left: 82px !important;
    margin-right: auto !important;
    white-space: normal;
    line-height: 1.08;
    text-align: center;
  }
}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 15cb5606 */
.elementor-element-15cb5606 .elementor-posts-container {
  display: grid !important;
  grid-template-columns: minmax(0, 1.45fr) minmax(0, 0.95fr) !important;
  grid-template-rows: repeat(2, 260px) !important;
  gap: 24px !important;
  width: 100% !important;
  height: auto !important;
  position: relative !important;
  align-items: stretch !important;
}

/* Minden kártya alapállapota */
.elementor-element-15cb5606 .elementor-posts-container > article.elementor-post,
.elementor-element-15cb5606 .elementor-posts-container > div[role="list"] {
  position: relative !important;
  left: auto !important;
  top: auto !important;
  width: auto !important;
  height: auto !important;
  min-height: 260px !important;
  transform: none !important;
  overflow: hidden !important;
  border-radius: 16px !important;
  background: #151515 !important;
  isolation: isolate !important;
}

/* Ha Elementor mégis becsomagolna egy posztot */
.elementor-element-15cb5606 .elementor-posts-container > div[role="list"] > article.elementor-post:empty {
  display: none !important;
}

.elementor-element-15cb5606 .elementor-posts-container > div[role="list"] > article.elementor-post:not(:empty) {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  overflow: hidden !important;
}

/* 1. poszt: nagy bal oldali kártya */
.elementor-element-15cb5606 .elementor-posts-container > article.elementor-post:nth-child(1),
.elementor-element-15cb5606 .elementor-posts-container > div[role="list"]:nth-child(1) {
  grid-column: 1 !important;
  grid-row: 1 / span 2 !important;
  min-height: 544px !important;
}

/* 2. poszt: jobb felső */
.elementor-element-15cb5606 .elementor-posts-container > article.elementor-post:nth-child(2),
.elementor-element-15cb5606 .elementor-posts-container > div[role="list"]:nth-child(2) {
  grid-column: 2 !important;
  grid-row: 1 !important;
}

/* 3. poszt: jobb alsó */
.elementor-element-15cb5606 .elementor-posts-container > article.elementor-post:nth-child(3),
.elementor-element-15cb5606 .elementor-posts-container > div[role="list"]:nth-child(3) {
  grid-column: 2 !important;
  grid-row: 2 !important;
}

/* Képek teljes kártyára húzása */
.elementor-element-15cb5606 .elementor-post__thumbnail__link,
.elementor-element-15cb5606 .elementor-post__thumbnail {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
}

.elementor-element-15cb5606 .elementor-post__thumbnail img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transform: scale(1.03);
  transition: transform 0.45s ease;
}

.elementor-element-15cb5606 .elementor-posts-container > article.elementor-post:hover .elementor-post__thumbnail img,
.elementor-element-15cb5606 .elementor-posts-container > div[role="list"]:hover .elementor-post__thumbnail img {
  transform: scale(1.09);
}

/* Sötét overlay */
.elementor-element-15cb5606 .elementor-posts-container > article.elementor-post::before,
.elementor-element-15cb5606 .elementor-posts-container > div[role="list"]::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    180deg,
    rgba(0,0,0,0.04) 0%,
    rgba(0,0,0,0.34) 45%,
    rgba(0,0,0,0.86) 100%
  );
  pointer-events: none;
}

/* Színes alsó csík */
.elementor-element-15cb5606 .elementor-posts-container > article.elementor-post::after,
.elementor-element-15cb5606 .elementor-posts-container > div[role="list"]::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 4px;
  z-index: 3;
  background: linear-gradient(90deg, #29c8ff, #3b39ff, #d93bdb, #ffd400, #9be400, #21cdb8);
  transform: scaleX(0.25);
  transform-origin: left;
  transition: transform 0.35s ease;
  pointer-events: none;
}

.elementor-element-15cb5606 .elementor-posts-container > article.elementor-post:hover::after,
.elementor-element-15cb5606 .elementor-posts-container > div[role="list"]:hover::after {
  transform: scaleX(1);
}

/* Szöveg */
.elementor-element-15cb5606 .elementor-post__text {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  z-index: 2 !important;
  padding: 26px !important;
}

.elementor-element-15cb5606 .elementor-post__title {
  margin: 0 !important;
}

.elementor-element-15cb5606 .elementor-post__title a {
  color: #ffffff !important;
  font-family: "Poppins", sans-serif !important;
  font-size: 24px !important;
  line-height: 1.14 !important;
  font-weight: 900 !important;
  text-decoration: none !important;
}

.elementor-element-15cb5606 .elementor-posts-container > article.elementor-post:nth-child(1) .elementor-post__title a,
.elementor-element-15cb5606 .elementor-posts-container > div[role="list"]:nth-child(1) .elementor-post__title a {
  font-size: 36px !important;
}

.elementor-element-15cb5606 .elementor-post__excerpt {
  display: none !important;
}

/* TABLET */
@media (max-width: 1024px) {
  .elementor-element-15cb5606 .elementor-posts-container {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    grid-template-rows: 430px 300px !important;
    gap: 20px !important;
  }

  .elementor-element-15cb5606 .elementor-posts-container > article.elementor-post:nth-child(1),
  .elementor-element-15cb5606 .elementor-posts-container > div[role="list"]:nth-child(1) {
    grid-column: 1 / span 2 !important;
    grid-row: 1 !important;
    min-height: 430px !important;
  }

  .elementor-element-15cb5606 .elementor-posts-container > article.elementor-post:nth-child(2),
  .elementor-element-15cb5606 .elementor-posts-container > div[role="list"]:nth-child(2) {
    grid-column: 1 !important;
    grid-row: 2 !important;
    min-height: 300px !important;
  }

  .elementor-element-15cb5606 .elementor-posts-container > article.elementor-post:nth-child(3),
  .elementor-element-15cb5606 .elementor-posts-container > div[role="list"]:nth-child(3) {
    grid-column: 2 !important;
    grid-row: 2 !important;
    min-height: 300px !important;
  }

  .elementor-element-15cb5606 .elementor-posts-container > article.elementor-post:nth-child(1) .elementor-post__title a,
  .elementor-element-15cb5606 .elementor-posts-container > div[role="list"]:nth-child(1) .elementor-post__title a {
    font-size: 31px !important;
  }

  .elementor-element-15cb5606 .elementor-post__title a {
    font-size: 22px !important;
  }

  .elementor-element-15cb5606 .elementor-post__text {
    padding: 24px !important;
  }
}

/* MOBIL */
@media (max-width: 767px) {
  .elementor-element-15cb5606 > .elementor-widget-container {
    margin: 0 !important;
    padding: 0 !important;
  }

  .elementor-element-15cb5606 .elementor-posts-container {
    display: flex !important;
    flex-direction: column !important;
    grid-template-columns: none !important;
    grid-template-rows: none !important;
    gap: 20px !important;
    width: min(100%, 440px) !important;
    max-width: calc(100vw - 40px) !important;
    height: auto !important;
    margin: 0 auto !important;
    align-items: stretch !important;
  }

  .elementor-element-15cb5606 .elementor-posts-container > article.elementor-post,
  .elementor-element-15cb5606 .elementor-posts-container > div[role="list"] {
    display: flex !important;
    flex-direction: column !important;
    grid-column: auto !important;
    grid-row: auto !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    border-radius: 16px !important;
    overflow: hidden !important;
    background: #111111 !important;
  }

  .elementor-element-15cb5606 .elementor-posts-container > div[role="list"] > article.elementor-post:not(:empty) {
    position: relative !important;
    inset: auto !important;
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
  }

  .elementor-element-15cb5606 .elementor-posts-container > article.elementor-post:nth-child(1),
  .elementor-element-15cb5606 .elementor-posts-container > div[role="list"]:nth-child(1),
  .elementor-element-15cb5606 .elementor-posts-container > article.elementor-post:nth-child(2),
  .elementor-element-15cb5606 .elementor-posts-container > div[role="list"]:nth-child(2),
  .elementor-element-15cb5606 .elementor-posts-container > article.elementor-post:nth-child(3),
  .elementor-element-15cb5606 .elementor-posts-container > div[role="list"]:nth-child(3) {
    grid-column: auto !important;
    grid-row: auto !important;
    min-height: 0 !important;
  }

  .elementor-element-15cb5606 .elementor-post__thumbnail__link {
    position: relative !important;
    inset: auto !important;
    display: block !important;
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 16 / 10 !important;
    margin: 0 !important;
    overflow: hidden !important;
  }

  .elementor-element-15cb5606 .elementor-post__thumbnail {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  .elementor-element-15cb5606 .elementor-post__thumbnail img {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transform: scale(1.02) !important;
  }

  .elementor-element-15cb5606 .elementor-posts-container > article.elementor-post::before,
  .elementor-element-15cb5606 .elementor-posts-container > div[role="list"]::before {
    display: none !important;
  }

  .elementor-element-15cb5606 .elementor-post__text {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    z-index: 2 !important;
    padding: 17px 18px 19px !important;
    background: #111111 !important;
  }

  .elementor-element-15cb5606 .elementor-post__title a,
  .elementor-element-15cb5606 .elementor-posts-container > article.elementor-post:nth-child(1) .elementor-post__title a,
  .elementor-element-15cb5606 .elementor-posts-container > div[role="list"]:nth-child(1) .elementor-post__title a {
    font-size: clamp(18px, 5.3vw, 22px) !important;
    line-height: 1.12 !important;
    font-weight: 900 !important;
    letter-spacing: 0 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
    text-wrap: balance;
  }
}

@media (max-width: 374px) {
  .elementor-element-15cb5606 .elementor-posts-container {
    max-width: calc(100vw - 48px) !important;
    gap: 18px !important;
  }

  .elementor-element-15cb5606 .elementor-post__thumbnail__link {
    aspect-ratio: 16 / 11 !important;
  }

  .elementor-element-15cb5606 .elementor-post__text {
    padding: 15px 16px 17px !important;
  }

  .elementor-element-15cb5606 .elementor-post__title a,
  .elementor-element-15cb5606 .elementor-posts-container > article.elementor-post:nth-child(1) .elementor-post__title a,
  .elementor-element-15cb5606 .elementor-posts-container > div[role="list"]:nth-child(1) .elementor-post__title a {
    font-size: 18px !important;
    line-height: 1.12 !important;
  }
}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 26569fc1 */
.sf-reviews-section {
  padding: 100px 20px;
  background: #ffffff;
}

.sf-reviews-inner {
  width: min(92vw, 1400px);
  margin: 0 auto;
}

.sf-reviews {
  display: grid;
  grid-template-columns: 0.75fr 1.25fr;
  gap: 56px;
  align-items: center;
}

.sf-reviews-head p {
  margin: 0 0 14px;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.14em;
  color: #151515;
}

.sf-reviews-head h2 {
  margin: 0;
  font-family: "Poppins", sans-serif;
  font-size: clamp(42px, 6vw, 88px);
  line-height: 0.95;
  font-weight: 900;
  color: #050505;
}

.sf-reviews-slider {
  overflow: hidden;
}

.sf-reviews-track {
  display: flex;
  transition: transform 0.45s ease;
}

.sf-review-card {
  position: relative;
  flex: 0 0 100%;
  min-height: 280px;
  padding: 58px 52px 44px;
  border-radius: 22px;
  background: rgba(255,255,255,0.88);
  border: 1px solid rgba(0,0,0,0.08);
  box-shadow: 0 24px 80px rgba(0,0,0,0.10);
  overflow: hidden;
}

.sf-review-card::before {
  content: "“";
  position: absolute;
  top: 22px;
  left: 36px;
  font-family: Georgia, serif;
  font-size: 100px;
  line-height: 1;
  background: linear-gradient(90deg, #29c8ff, #3b39ff, #d93bdb, #ffd400, #9be400, #21cdb8);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  opacity: 0.95;
}

.sf-review-card::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 38%;
  height: 5px;
  background: linear-gradient(90deg, #29c8ff, #3b39ff, #d93bdb, #ffd400, #9be400, #21cdb8);
}

.sf-review-card p {
  position: relative;
  z-index: 2;
  margin: 0;
  font-family: "Poppins", sans-serif;
  font-size: 28px;
  line-height: 1.28;
  font-weight: 700;
  color: #111111;
}

.sf-reviews-controls {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 18px;
  margin-top: 24px;
}

.sf-review-arrow {
  position: relative;
  z-index: 4;
  width: 54px;
  height: 54px;
  border: 0px solid rgba(0,0,0,0.12);
  border-radius: 999px;
  background: rgba(255,255,255,0.86);
  box-shadow: 0 14px 34px rgba(0,0,0,0.14);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  cursor: pointer;
  overflow: hidden;
  padding: 0;
}

.sf-review-arrow::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    90deg,
    #29c8ff 0%,
    #3b39ff 18%,
    #d93bdb 36%,
    #ffd400 58%,
    #9be400 78%,
    #21cdb8 100%
  );
  background-size: 300% 100%;
  opacity: 0;
  transition: opacity 0.25s ease;
}

.sf-review-arrow span {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  color: #111111;
  font-size: 38px;
  line-height: 1;
  font-weight: 800;
  transform: translateY(-1px);
}

.sf-review-arrow:hover::before {
  opacity: 2;
  animation: sfReviewArrowFlow 1s linear infinite;
}


.sf-review-arrow:hover span {
  color: #ffffff;
}

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

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


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

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



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

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



@media (max-width: 1024px) {
  .sf-reviews {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .sf-review-card {
    min-height: 320px;
    padding: 68px 46px 48px;
  }

  .sf-review-card p {
    font-size: 25px;
  }
}

@media (max-width: 767px) {
  .sf-reviews-section {
    padding: 70px 18px;
  }

  .sf-reviews-inner {
    width: 100%;
  }

  .sf-reviews-head h2 {
    font-size: 46px;
  }

  .sf-review-card {
    min-height: 330px;
    padding: 64px 26px 38px;
    border-radius: 18px;
  }

  .sf-review-card::before {
    left: 20px;
    top: 18px;
    font-size: 112px;
  }

  .sf-review-card p {
    font-size: 21px;
    line-height: 1.32;
  }

.sf-reviews-controls {
  justify-content: center;
  gap: 18px;
}

}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 650d3993 */
@media (max-width: 374px) {
  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option {
    display: grid !important;
    grid-template-columns: 14px minmax(0, 1fr) !important;
    column-gap: 8px !important;
    row-gap: 0 !important;
    align-items: flex-start !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option input {
    width: 14px !important;
    height: 14px !important;
    margin: 3px 0 0 !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option label {
    display: block !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: 100% !important;
    min-height: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    white-space: normal !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    line-height: 1.35 !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option label a {
    display: inline !important;
    width: auto !important;
    max-width: none !important;
    white-space: nowrap !important;
    overflow-wrap: normal !important;
    word-break: keep-all !important;
  }
}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 6ba21f0f */
/* Ajánlatkérés form - 320px mobil finomhangolás */
@media (max-width: 340px) {
  .elementor-element-6ba21f0f {
    overflow: visible !important;
  }

  .elementor-element-6ba21f0f .sf-quote-copy,
  .elementor-element-6ba21f0f .sf-quote-card {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 22px !important;
    padding-right: 22px !important;
    box-sizing: border-box !important;
    overflow: visible !important;
  }

  .elementor-element-6ba21f0f .sf-quote-copy h1,
  .elementor-element-6ba21f0f .sf-quote-copy h2,
  .elementor-element-6ba21f0f .sf-quote-copy h3 {
    max-width: 100% !important;
    font-size: 27px !important;
    line-height: 1.05 !important;
    letter-spacing: 0 !important;
    white-space: normal !important;
    overflow-wrap: break-word !important;
    word-break: normal !important;
  }

  .elementor-element-6ba21f0f .sf-quote-copy p {
    font-size: 15px !important;
    line-height: 1.45 !important;
  }

  .elementor-element-6ba21f0f .sf-quote-form .elementor-field-label {
    font-size: 22px !important;
    line-height: 1.05 !important;
    letter-spacing: 0 !important;
  }

  .elementor-element-6ba21f0f .sf-quote-form .elementor-field-subgroup {
    gap: 9px !important;
  }

  .elementor-element-6ba21f0f .sf-quote-form .elementor-field-option {
    display: flex !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    gap: 7px !important;
    width: fit-content !important;
    max-width: 100% !important;
  }

  .elementor-element-6ba21f0f .sf-quote-form .elementor-field-option label {
    display: inline-flex !important;
    align-items: center !important;
    width: fit-content !important;
    max-width: none !important;
    padding: 8px 10px !important;
    font-size: 12px !important;
    line-height: 1 !important;
    white-space: nowrap !important;
  }

  .elementor-element-6ba21f0f .sf-quote-form .elementor-field-option input {
    flex: 0 0 auto !important;
    width: 13px !important;
    height: 13px !important;
    margin: 0 !important;
  }

  .elementor-element-6ba21f0f .sf-quote-form textarea {
    min-height: 130px !important;
  }
}

/* Ajánlatkérés - tablet kétoszlopos elrendezés */
@media (min-width: 768px) and (max-width: 1024px) {
  body .sf-quote-section {
    padding: 72px 18px 88px !important;
  }

  body .sf-quote-inner {
    width: min(96vw, 980px) !important;
  }

  body .sf-quote-layout {
    grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr) !important;
    gap: 22px !important;
    align-items: stretch !important;
    margin-top: 38px !important;
  }

  body .sf-quote-copy {
    position: relative !important;
    padding: 30px !important;
    border-radius: 20px !important;
    overflow: hidden !important;
  }

  body .sf-quote-copy::after {
    left: 30px !important;
    right: 30px !important;
  }

  body .sf-quote-copy-block {
    width: 100% !important;
    min-height: 100% !important;
    display: block !important;
    padding-bottom: 0 !important;
  }

  body .sf-quote-eyebrow {
    margin-bottom: 15px !important;
  }

  body .sf-quote-copy h3 {
    font-size: clamp(30px, 3.7vw, 38px) !important;
  }

  body .sf-quote-copy p {
    font-size: 15px !important;
    line-height: 1.45 !important;
  }

  body .sf-quote-contact {
    gap: 10px !important;
    margin-top: 26px !important;
  }

  body .sf-quote-contact a {
    padding: 14px 16px !important;
    border-radius: 14px !important;
    font-size: 14px !important;
  }

  body .sf-quote-logo-link {
    position: absolute !important;
    left: 50% !important;
    right: auto !important;
    top: auto !important;
    bottom: -315px !important;
    width: clamp(260px, 34vw, 360px) !important;
    max-width: calc(100% - 42px) !important;
    margin: 0 !important;
    transform: translateX(-50%) !important;
  }

  body .sf-quote-logo-img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
  }

  body .sf-quote-card {
    padding: 28px !important;
    border-radius: 20px !important;
  }
}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 63a1d9ed */
@media (max-width: 374px) {
  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option {
    display: grid !important;
    grid-template-columns: 14px minmax(0, 1fr) !important;
    column-gap: 8px !important;
    row-gap: 0 !important;
    align-items: flex-start !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option input {
    width: 14px !important;
    height: 14px !important;
    margin: 3px 0 0 !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option label {
    display: block !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: 100% !important;
    min-height: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    white-space: normal !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    line-height: 1.35 !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option label a {
    display: inline !important;
    width: auto !important;
    max-width: none !important;
    white-space: nowrap !important;
    overflow-wrap: normal !important;
    word-break: keep-all !important;
  }
}

@media (max-width: 430px) {
  body .sf-quote-section .sf-quote-inner .sf-quote-copy h3 {
    font-size: 27px !important;
    line-height: 1.08 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
    text-wrap: balance;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-group-field_6cde44b {
    position: relative;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-group-field_6cde44b input::placeholder {
    color: transparent !important;
    opacity: 0 !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-group-field_6cde44b::after {
    content: "Facebook / Instagram / Google / Ajánlás / TikTok / Egyéb";
    display: block;
    margin-top: 8px;
    padding-left: 2px;
    font-family: "Inter", "Poppins", sans-serif;
    font-size: 11px;
    line-height: 1.35;
    font-weight: 600;
    color: rgba(0, 0, 0, 0.46);
  }
}

@media (max-width: 340px) {
  body .sf-quote-section .sf-quote-inner .sf-quote-layout .sf-quote-copy {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-layout .sf-quote-copy h3 {
    font-size: 23px !important;
    line-height: 1.08 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
    text-wrap: balance;
  }
}

/* Source: storyframe-audit/elementor/content/page/17.json | element: 304cbcc */
.sf-quote-section {
  padding: 90px 20px 110px;
  background: #ffffff;
}

.sf-quote-inner {
  width: min(92vw, 1420px);
  margin: 0 auto;
}

.sf-quote-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 34px;
  align-items: stretch;
  margin-top: 52px;
}

.sf-quote-copy,
.sf-quote-card {
  border-radius: 24px;
}

.sf-quote-copy {
  padding: 46px;
  background: #111111;
  color: #ffffff;
  overflow: hidden;
  position: relative;
}

.sf-quote-copy::after {
  content: "";
  position: absolute;
  left: 46px;
  right: 46px;
  bottom: 0;
  height: 6px;
  background: linear-gradient(90deg, #29c8ff, #3b39ff, #d93bdb, #ffd400, #9be400, #21cdb8);
}

.sf-quote-logo-link {
  position: relative;
  display: flex;
  width: clamp(200px, 21vw, 320px);
  aspect-ratio: 1 / 1;
  align-items: center;
  justify-content: center;
  margin: 34px auto 0;
  text-decoration: none;
  overflow: visible;
}


.sf-quote-logo-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.sf-quote-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-quote-logo-link:hover::after {
  opacity: 0.95;
  animation: sfQuoteLogoFlow 1.1s linear infinite;
}

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

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



.sf-quote-eyebrow {
  margin: 0 0 18px;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.sf-quote-copy h3 {
  margin: 0 0 24px;
  font-family: "Poppins", sans-serif;
  font-size: 44px;
  line-height: 1.05;
  font-weight: 900;
}

.sf-quote-copy p {
  margin: 0 0 18px;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 18px;
  line-height: 1.4;
  color: rgba(255,255,255,0.78);
}

.sf-quote-contact {
  display: grid;
  gap: 12px;
  margin-top: 34px;
}

.sf-quote-contact a {
  display: block;
  padding: 18px 20px;
  border-radius: 16px;
  color: #ffffff;
  text-decoration: none;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.14);
  font-family: "Inter", "Poppins", sans-serif;
  font-weight: 700;
}

.sf-quote-contact span {
  display: block;
  margin-bottom: 4px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}

.sf-quote-card {
  padding: 42px;
  background:
    linear-gradient(#ffffff, #ffffff) padding-box,
    linear-gradient(135deg, #29c8ff, #3b39ff, #d93bdb, #ffd400, #9be400, #21cdb8) border-box;
  border: 4px solid transparent;
  box-shadow: 0 24px 80px rgba(0,0,0,0.10);
}

.sf-quote-form .elementor-field-label {
  margin-bottom: 8px;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 13px;
  font-weight: 800;
  color: #151515;
}

.sf-quote-form .elementor-field-textual {
  min-height: 52px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,0.12);
  background: #f7f7f7;
  padding: 14px 16px;
  font-family: "Inter", "Poppins", sans-serif;
}

.sf-quote-form textarea.elementor-field-textual {
  min-height: 140px;
  resize: vertical;
}

.sf-quote-form .elementor-field-subgroup {
  display: flex;
  flex-wrap: wrap;
  gap: 13px;
}

.sf-quote-form .elementor-field-option label {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 10px 14px;
  border-radius: 999px;
  background: #f7f7f7;
  border: 1px solid rgba(0,0,0,0.10);
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
}

.sf-quote-form .elementor-field-option input {
  margin-right: 10px;
}

.sf-quote-form .elementor-field-type-acceptance {
  margin-top: 16px;
  margin-bottom: 24px;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-subgroup {
  display: block !important;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-option {
  display: flex !important;
  align-items: flex-start;
  gap: 10px;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-option input {
  flex: 0 0 auto;
  margin: 4px 0 0 !important;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-option label {
  display: block !important;
  min-height: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 12px;
  line-height: 1.55;
  font-weight: 500;
  color: rgba(0,0,0,0.62);
}

.sf-quote-form .elementor-field-type-acceptance a {
  color: #151515;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 3px;
}


.sf-quote-form .elementor-field-type-submit {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
  margin: 0 !important;
  padding: 0 !important;
}

.sf-quote-form .elementor-field-type-html {
  width: 100% !important;
  flex-basis: 100% !important;
}

.sf-quote-submit-row {
  display: flex !important;
  justify-content: center !important;
  width: 100% !important;
  margin-top: 10px;
}

.sf-quote-submit-row .sf-cta-wrap {
  width: auto !important;
  max-width: max-content !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.sf-quote-submit-row .sf-cta {
  width: auto !important;
}




@media (max-width: 1024px) {
  .sf-quote-section {
    padding: 78px 20px 92px;
  }

  .sf-quote-inner {
    width: min(94vw, 920px);
  }

  .sf-quote-layout {
    grid-template-columns: 1fr;
    gap: 26px;
    margin-top: 42px;
  }

  .sf-quote-copy {
    padding: 40px;
  }

  .sf-quote-copy h3 {
    font-size: 38px;
  }

  .sf-quote-card {
    padding: 36px;
  }
}

@media (max-width: 767px) {
  .sf-quote-section {
    padding: 64px 18px 78px;
  }

  .sf-quote-inner {
    width: 100%;
  }

  .sf-quote-layout {
    margin-top: 34px;
    gap: 20px;
  }

  .sf-quote-copy {
    padding: 30px 24px 34px;
    border-radius: 20px;
  }

  .sf-quote-copy::after {
    left: 24px;
    right: 24px;
  }

  .sf-quote-copy h3 {
    font-size: 31px;
  }

  .sf-quote-copy p {
    font-size: 15px;
  }

  .sf-quote-card {
    padding: 24px;
    border-radius: 20px;
  }

  .sf-quote-form .elementor-field-group {
    width: 100% !important;
  }

  .sf-quote-form .elementor-field-option label {
    font-size: 13px;
    min-height: 40px;
  }
  
    .sf-quote-logo-link {
    width: 190px;
    margin: 0 auto 24px;
  }



}

.elementor-element-304cbcc .sf-quote-submit-row {
  width: 100% !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  margin: 28px 0 0 !important;
}

.elementor-element-304cbcc .sf-quote-submit-row .sf-cta-wrap {
  width: fit-content !important;
  padding: 10px 14px !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.72) !important;
  border: 1px solid rgba(0, 0, 0, 0.08) !important;
  box-shadow:
    0 12px 35px rgba(0, 0, 0, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.9) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
}

.elementor-element-304cbcc .sf-quote-submit-row .sf-cta {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 54px !important;
  padding: 0 10px !important;
  text-decoration: none !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  overflow: visible !important;
  cursor: pointer !important;
}

.elementor-element-304cbcc .sf-quote-submit-row .sf-cta span {
  position: relative !important;
  z-index: 1 !important;
  display: inline-block !important;
  font-family: "Poppins", sans-serif !important;
  font-size: 19px !important;
  font-weight: 800 !important;
  line-height: 1.1 !important;
  color: #151515 !important;
  text-shadow: none !important;
  transition: opacity 0.25s ease !important;
}

.elementor-element-304cbcc .sf-quote-submit-row .sf-cta::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Poppins", sans-serif;
  font-size: 19px;
  font-weight: 800;
  line-height: 1.1;
  white-space: nowrap;

  background: linear-gradient(
    90deg,
    #29c8ff 0%,
    #3b39ff 18%,
    #d93bdb 36%,
    #ffd400 58%,
    #9be400 78%,
    #21cdb8 100%
  );
  background-size: 25% 100%;
  background-position: 100% 50%;

  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;

  opacity: 0;
  transition: opacity 0.25s ease;
}

.elementor-element-304cbcc .sf-quote-submit-row .sf-cta:hover span {
  opacity: 0 !important;
}

.elementor-element-304cbcc .sf-quote-submit-row .sf-cta:hover::after {
  opacity: 1 !important;
  animation: sfQuoteTextFlow 1.6s linear infinite;
}

.elementor-element-304cbcc .sf-quote-submit-row .sf-cta-wrap:hover {
  box-shadow:
    0 16px 45px rgba(0, 0, 0, 0.12),
    0 0 35px rgba(41, 200, 255, 0.10),
    inset 0 1px 0 rgba(255, 255, 255, 1) !important;
}

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

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

@media (max-width: 767px) {
  .elementor-element-304cbcc .sf-quote-submit-row .sf-cta {
    min-height: 46px !important;
  }

  .elementor-element-304cbcc .sf-quote-submit-row .sf-cta span,
  .elementor-element-304cbcc .sf-quote-submit-row .sf-cta::after {
    font-size: 14px !important;
    white-space: nowrap !important;
  }
}

/* Source: storyframe-audit/elementor/content/page/2759.json | element: 75ffb06d */
/* Ajánlatkérés form - 320px mobil finomhangolás */
@media (max-width: 340px) {
  .elementor-element-75ffb06d {
    overflow: visible !important;
  }

  .elementor-element-75ffb06d .sf-quote-copy,
  .elementor-element-75ffb06d .sf-quote-card {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 22px !important;
    padding-right: 22px !important;
    box-sizing: border-box !important;
    overflow: visible !important;
  }

  .elementor-element-75ffb06d .sf-quote-copy h1,
  .elementor-element-75ffb06d .sf-quote-copy h2,
  .elementor-element-75ffb06d .sf-quote-copy h3 {
    max-width: 100% !important;
    font-size: 27px !important;
    line-height: 1.05 !important;
    letter-spacing: 0 !important;
    white-space: normal !important;
    overflow-wrap: break-word !important;
    word-break: normal !important;
  }

  .elementor-element-75ffb06d .sf-quote-copy p {
    font-size: 15px !important;
    line-height: 1.45 !important;
  }

  .elementor-element-75ffb06d .sf-quote-form .elementor-field-label {
    font-size: 22px !important;
    line-height: 1.05 !important;
    letter-spacing: 0 !important;
  }

  .elementor-element-75ffb06d .sf-quote-form .elementor-field-subgroup {
    gap: 9px !important;
  }

  .elementor-element-75ffb06d .sf-quote-form .elementor-field-option {
    display: flex !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    gap: 7px !important;
    width: fit-content !important;
    max-width: 100% !important;
  }

  .elementor-element-75ffb06d .sf-quote-form .elementor-field-option label {
    display: inline-flex !important;
    align-items: center !important;
    width: fit-content !important;
    max-width: none !important;
    padding: 8px 10px !important;
    font-size: 12px !important;
    line-height: 1 !important;
    white-space: nowrap !important;
  }

  .elementor-element-75ffb06d .sf-quote-form .elementor-field-option input {
    flex: 0 0 auto !important;
    width: 13px !important;
    height: 13px !important;
    margin: 0 !important;
  }

  .elementor-element-75ffb06d .sf-quote-form textarea {
    min-height: 130px !important;
  }
}

/* Ajánlatkérés - tablet kétoszlopos elrendezés */
@media (min-width: 768px) and (max-width: 1024px) {
  body .sf-quote-section {
    padding: 72px 18px 88px !important;
  }

  body .sf-quote-inner {
    width: min(96vw, 980px) !important;
  }

  body .sf-quote-layout {
    grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr) !important;
    gap: 22px !important;
    align-items: stretch !important;
    margin-top: 38px !important;
  }

  body .sf-quote-copy {
    position: relative !important;
    padding: 30px !important;
    border-radius: 20px !important;
    overflow: hidden !important;
  }

  body .sf-quote-copy::after {
    left: 30px !important;
    right: 30px !important;
  }

  body .sf-quote-copy-block {
    width: 100% !important;
    min-height: 100% !important;
    display: block !important;
    padding-bottom: 0 !important;
  }

  body .sf-quote-eyebrow {
    margin-bottom: 15px !important;
  }

  body .sf-quote-copy h3 {
    font-size: clamp(30px, 3.7vw, 38px) !important;
  }

  body .sf-quote-copy p {
    font-size: 15px !important;
    line-height: 1.45 !important;
  }

  body .sf-quote-contact {
    gap: 10px !important;
    margin-top: 26px !important;
  }

  body .sf-quote-contact a {
    padding: 14px 16px !important;
    border-radius: 14px !important;
    font-size: 14px !important;
  }

  body .sf-quote-logo-link {
    position: absolute !important;
    left: 50% !important;
    right: auto !important;
    top: auto !important;
    bottom: -315px !important;
    width: clamp(260px, 34vw, 360px) !important;
    max-width: calc(100% - 42px) !important;
    margin: 0 !important;
    transform: translateX(-50%) !important;
  }

  body .sf-quote-logo-img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
  }

  body .sf-quote-card {
    padding: 28px !important;
    border-radius: 20px !important;
  }
}

/* Source: storyframe-audit/elementor/content/page/2759.json | element: 52f26872 */
@media (max-width: 374px) {
  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option {
    display: grid !important;
    grid-template-columns: 14px minmax(0, 1fr) !important;
    column-gap: 8px !important;
    row-gap: 0 !important;
    align-items: flex-start !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option input {
    width: 14px !important;
    height: 14px !important;
    margin: 3px 0 0 !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option label {
    display: block !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: 100% !important;
    min-height: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    white-space: normal !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    line-height: 1.35 !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option label a {
    display: inline !important;
    width: auto !important;
    max-width: none !important;
    white-space: nowrap !important;
    overflow-wrap: normal !important;
    word-break: keep-all !important;
  }
}

@media (max-width: 430px) {
  body .sf-quote-section .sf-quote-inner .sf-quote-copy h3 {
    font-size: 27px !important;
    line-height: 1.08 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
    text-wrap: balance;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-group-field_6cde44b {
    position: relative;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-group-field_6cde44b input::placeholder {
    color: transparent !important;
    opacity: 0 !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-group-field_6cde44b::after {
    content: "Facebook / Instagram / Google / Ajánlás / TikTok / Egyéb";
    display: block;
    margin-top: 8px;
    padding-left: 2px;
    font-family: "Inter", "Poppins", sans-serif;
    font-size: 11px;
    line-height: 1.35;
    font-weight: 600;
    color: rgba(0, 0, 0, 0.46);
  }
}

@media (max-width: 340px) {
  body .sf-quote-section .sf-quote-inner .sf-quote-layout .sf-quote-copy {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-layout .sf-quote-copy h3 {
    font-size: 23px !important;
    line-height: 1.08 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
    text-wrap: balance;
  }
}

/* Source: storyframe-audit/elementor/content/page/2759.json | element: 2ffefe73 */
.sf-quote-section {
  padding: 90px 20px 110px;
  background: #ffffff;
}

.sf-quote-inner {
  width: min(92vw, 1420px);
  margin: 0 auto;
}

.sf-quote-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 34px;
  align-items: stretch;
  margin-top: 52px;
}

.sf-quote-copy,
.sf-quote-card {
  border-radius: 24px;
}

.sf-quote-copy {
  padding: 46px;
  background: #111111;
  color: #ffffff;
  overflow: hidden;
  position: relative;
}

.sf-quote-copy::after {
  content: "";
  position: absolute;
  left: 46px;
  right: 46px;
  bottom: 0;
  height: 6px;
  background: linear-gradient(90deg, #29c8ff, #3b39ff, #d93bdb, #ffd400, #9be400, #21cdb8);
}

.sf-quote-logo-link {
  position: relative;
  display: flex;
  width: clamp(200px, 21vw, 320px);
  aspect-ratio: 1 / 1;
  align-items: center;
  justify-content: center;
  margin: 34px auto 0;
  text-decoration: none;
  overflow: visible;
}


.sf-quote-logo-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.sf-quote-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-quote-logo-link:hover::after {
  opacity: 0.95;
  animation: sfQuoteLogoFlow 1.1s linear infinite;
}

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

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



.sf-quote-eyebrow {
  margin: 0 0 18px;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.sf-quote-copy h3 {
  margin: 0 0 24px;
  font-family: "Poppins", sans-serif;
  font-size: 44px;
  line-height: 1.05;
  font-weight: 900;
}

.sf-quote-copy p {
  margin: 0 0 18px;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 18px;
  line-height: 1.4;
  color: rgba(255,255,255,0.78);
}

.sf-quote-contact {
  display: grid;
  gap: 12px;
  margin-top: 34px;
}

.sf-quote-contact a {
  display: block;
  padding: 18px 20px;
  border-radius: 16px;
  color: #ffffff;
  text-decoration: none;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.14);
  font-family: "Inter", "Poppins", sans-serif;
  font-weight: 700;
}

.sf-quote-contact span {
  display: block;
  margin-bottom: 4px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}

.sf-quote-card {
  padding: 42px;
  background:
    linear-gradient(#ffffff, #ffffff) padding-box,
    linear-gradient(135deg, #29c8ff, #3b39ff, #d93bdb, #ffd400, #9be400, #21cdb8) border-box;
  border: 4px solid transparent;
  box-shadow: 0 24px 80px rgba(0,0,0,0.10);
}

.sf-quote-form .elementor-field-label {
  margin-bottom: 8px;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 13px;
  font-weight: 800;
  color: #151515;
}

.sf-quote-form .elementor-field-textual {
  min-height: 52px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,0.12);
  background: #f7f7f7;
  padding: 14px 16px;
  font-family: "Inter", "Poppins", sans-serif;
}

.sf-quote-form textarea.elementor-field-textual {
  min-height: 140px;
  resize: vertical;
}

.sf-quote-form .elementor-field-subgroup {
  display: flex;
  flex-wrap: wrap;
  gap: 13px;
}

.sf-quote-form .elementor-field-option label {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 10px 14px;
  border-radius: 999px;
  background: #f7f7f7;
  border: 1px solid rgba(0,0,0,0.10);
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
}

.sf-quote-form .elementor-field-option input {
  margin-right: 10px;
}

.sf-quote-form .elementor-field-type-acceptance {
  margin-top: 16px;
  margin-bottom: 24px;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-subgroup {
  display: block !important;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-option {
  display: flex !important;
  align-items: flex-start;
  gap: 10px;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-option input {
  flex: 0 0 auto;
  margin: 4px 0 0 !important;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-option label {
  display: block !important;
  min-height: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 12px;
  line-height: 1.55;
  font-weight: 500;
  color: rgba(0,0,0,0.62);
}

.sf-quote-form .elementor-field-type-acceptance a {
  color: #151515;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 3px;
}


.sf-quote-form .elementor-field-type-submit {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
  margin: 0 !important;
  padding: 0 !important;
}

.sf-quote-form .elementor-field-type-html {
  width: 100% !important;
  flex-basis: 100% !important;
}

.sf-quote-submit-row {
  display: flex !important;
  justify-content: center !important;
  width: 100% !important;
  margin-top: 10px;
}

.sf-quote-submit-row .sf-cta-wrap {
  width: auto !important;
  max-width: max-content !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.sf-quote-submit-row .sf-cta {
  width: auto !important;
}




@media (max-width: 1024px) {
  .sf-quote-section {
    padding: 78px 20px 92px;
  }

  .sf-quote-inner {
    width: min(94vw, 920px);
  }

  .sf-quote-layout {
    grid-template-columns: 1fr;
    gap: 26px;
    margin-top: 42px;
  }

  .sf-quote-copy {
    padding: 40px;
  }

  .sf-quote-copy h3 {
    font-size: 38px;
  }

  .sf-quote-card {
    padding: 36px;
  }
}

@media (max-width: 767px) {
  .sf-quote-section {
    padding: 64px 18px 78px;
  }

  .sf-quote-inner {
    width: 100%;
  }

  .sf-quote-layout {
    margin-top: 34px;
    gap: 20px;
  }

  .sf-quote-copy {
    padding: 30px 24px 34px;
    border-radius: 20px;
  }

  .sf-quote-copy::after {
    left: 24px;
    right: 24px;
  }

  .sf-quote-copy h3 {
    font-size: 31px;
  }

  .sf-quote-copy p {
    font-size: 15px;
  }

  .sf-quote-card {
    padding: 24px;
    border-radius: 20px;
  }

  .sf-quote-form .elementor-field-group {
    width: 100% !important;
  }

  .sf-quote-form .elementor-field-option label {
    font-size: 13px;
    min-height: 40px;
  }
  
    .sf-quote-logo-link {
    width: 190px;
    margin: 0 auto 24px;
  }



}

.elementor-element-2ffefe73 .sf-quote-submit-row {
  width: 100% !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  margin: 28px 0 0 !important;
}

.elementor-element-2ffefe73 .sf-quote-submit-row .sf-cta-wrap {
  width: fit-content !important;
  padding: 10px 14px !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.72) !important;
  border: 1px solid rgba(0, 0, 0, 0.08) !important;
  box-shadow:
    0 12px 35px rgba(0, 0, 0, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.9) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
}

.elementor-element-2ffefe73 .sf-quote-submit-row .sf-cta {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 54px !important;
  padding: 0 10px !important;
  text-decoration: none !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  overflow: visible !important;
  cursor: pointer !important;
}

.elementor-element-2ffefe73 .sf-quote-submit-row .sf-cta span {
  position: relative !important;
  z-index: 1 !important;
  display: inline-block !important;
  font-family: "Poppins", sans-serif !important;
  font-size: 19px !important;
  font-weight: 800 !important;
  line-height: 1.1 !important;
  color: #151515 !important;
  text-shadow: none !important;
  transition: opacity 0.25s ease !important;
}

.elementor-element-2ffefe73 .sf-quote-submit-row .sf-cta::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Poppins", sans-serif;
  font-size: 19px;
  font-weight: 800;
  line-height: 1.1;
  white-space: nowrap;

  background: linear-gradient(
    90deg,
    #29c8ff 0%,
    #3b39ff 18%,
    #d93bdb 36%,
    #ffd400 58%,
    #9be400 78%,
    #21cdb8 100%
  );
  background-size: 25% 100%;
  background-position: 100% 50%;

  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;

  opacity: 0;
  transition: opacity 0.25s ease;
}

.elementor-element-2ffefe73 .sf-quote-submit-row .sf-cta:hover span {
  opacity: 0 !important;
}

.elementor-element-2ffefe73 .sf-quote-submit-row .sf-cta:hover::after {
  opacity: 1 !important;
  animation: sfQuoteTextFlow 1.6s linear infinite;
}

.elementor-element-2ffefe73 .sf-quote-submit-row .sf-cta-wrap:hover {
  box-shadow:
    0 16px 45px rgba(0, 0, 0, 0.12),
    0 0 35px rgba(41, 200, 255, 0.10),
    inset 0 1px 0 rgba(255, 255, 255, 1) !important;
}

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

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

@media (max-width: 767px) {
  .elementor-element-2ffefe73 .sf-quote-submit-row .sf-cta {
    min-height: 46px !important;
  }

  .elementor-element-2ffefe73 .sf-quote-submit-row .sf-cta span,
  .elementor-element-2ffefe73 .sf-quote-submit-row .sf-cta::after {
    font-size: 14px !important;
    white-space: nowrap !important;
  }
}

/* Source: storyframe-audit/elementor/content/page/2755.json | element: 5f5d067c */
.elementor-element-5f5d067c {
  width: 100% !important;
  max-width: none !important;
  overflow: visible;
}

.elementor-element-5f5d067c > .e-con-inner {
  width: min(1320px, calc(100vw - 96px)) !important;
  max-width: min(1320px, calc(100vw - 96px)) !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}


.elementor-element-5f5d067c,
.elementor-element-5f5d067c > .e-con-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(24px, 3vw, 46px);
  overflow: visible;
}


.elementor-element-5f5d067c .sf-if-intro-copy {
  flex: 0 1 47%;
  max-width: 690px;
  position: relative;
  padding-left: 24px;
}

.elementor-element-5f5d067c .sf-if-intro-copy::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  bottom: 8px;
  width: 6px;
  border-radius: 999px;
  background: linear-gradient(
    180deg,
    #18bdf2,
    #2a1fd6,
    #d63ac7,
    #ff7a1a,
    #f4d03f,
    #7ac943
  );
  background-size: 100% 260%;
  animation: sfIfTextLight 5s linear infinite;
}

.elementor-element-5f5d067c .sf-if-intro-copy p,
.elementor-element-5f5d067c .sf-if-intro-copy .elementor-widget-container {
  margin: 0;
  font-family: "Poppins", sans-serif;
  font-size: clamp(21px, 1.55vw, 27px);
  font-weight: 700;
  line-height: 1.42;
  color: #151515;
  letter-spacing: 0;
}

.elementor-element-5f5d067c .sf-if-intro-copy p + p {
  margin-top: 24px;
}

.elementor-element-5f5d067c .sf-if-intro-visual {
  position: relative;
  flex: 0 1 45%;
  max-width: 560px;
  overflow: visible;
}

.elementor-element-5f5d067c .sf-if-intro-visual .elementor-widget-html,
.elementor-element-5f5d067c .sf-if-intro-visual .elementor-widget-container {
  width: 100%;
  overflow: visible;
}

.elementor-element-5f5d067c .sf-if-image-combo {
  position: relative;
  width: min(500px, 100%);
  margin: 0 auto;
  overflow: visible;
}

.elementor-element-5f5d067c .sf-if-image-combo::before {
  content: "";
  position: absolute;
  z-index: 0;
  left: -44px;
  right: -54px;
  top: 20%;
  height: 38%;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    #18bdf2,
    #2a1fd6,
    #d63ac7,
    #ff7a1a,
    #f4d03f,
    #7ac943,
    #18bdf2
  );
  background-size: 300% 100%;
  animation: sfIfLightLeak 5s linear infinite;
  transform: rotate(-7deg);
  opacity: 0.9;
}

.elementor-element-5f5d067c .sf-if-main-image,
.elementor-element-5f5d067c .sf-if-corner-image {
  margin: 0;
  background: #fff;
}

.elementor-element-5f5d067c .sf-if-main-image {
  position: relative;
  z-index: 1;
  width: 100%;
  padding: 0;
  border: 0;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 22px 55px rgba(0, 0, 0, 0.12);
}

.elementor-element-5f5d067c .sf-if-main-image img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 8px;
}

.elementor-element-5f5d067c .sf-if-corner-image {
  position: absolute;
  z-index: 3;
  right: -54px;
  bottom: -32px;
  width: clamp(135px, 32%, 185px);
  padding: 7px;
  border: 3px solid #000;
  border-radius: 8px;
  transform: rotate(4deg);
  overflow: hidden;
  transition: transform 0.3s ease;
}

.elementor-element-5f5d067c .sf-if-corner-image img {
  display: block;
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  object-position: center;
  border-radius: 5px;
  filter: grayscale(100%) contrast(1.08);
  transition: filter 0.35s ease, transform 0.35s ease;
}

.elementor-element-5f5d067c .sf-if-corner-image::after {
  content: "";
  position: absolute;
  inset: 7px;
  border-radius: 5px;
  background: linear-gradient(
    135deg,
    rgba(24, 189, 242, 0.9),
    rgba(214, 58, 199, 0.75),
    rgba(255, 122, 26, 0.65),
    rgba(122, 201, 67, 0.75)
  );
  mix-blend-mode: color;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.35s ease;
}

.elementor-element-5f5d067c .sf-if-corner-image:hover {
  transform: rotate(1deg) translateY(-4px);
}

.elementor-element-5f5d067c .sf-if-corner-image:hover img {
  transform: scale(1.03);
}

.elementor-element-5f5d067c .sf-if-corner-image:hover::after {
  opacity: 1;
}

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

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

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

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

@media (max-width: 1024px) {
  .elementor-element-5f5d067c > .e-con-inner {
    width: min(100%, calc(100vw - 40px)) !important;
    max-width: min(100%, calc(100vw - 40px)) !important;
  }

  .elementor-element-5f5d067c,
  .elementor-element-5f5d067c > .e-con-inner {
    gap: 38px;
  }

  .elementor-element-5f5d067c .sf-if-intro-copy {
    flex-basis: 48%;
  }

  .elementor-element-5f5d067c .sf-if-intro-visual {
    flex-basis: 44%;
    max-width: 470px;
  }

  .elementor-element-5f5d067c .sf-if-image-combo {
    width: min(430px, 100%);
  }

  .elementor-element-5f5d067c .sf-if-corner-image {
    right: -34px;
    bottom: -28px;
    width: clamp(125px, 32%, 170px);
  }
}

@media (max-width: 767px) {
  .elementor-element-5f5d067c > .e-con-inner {
    width: min(100%, calc(100vw - 32px)) !important;
    max-width: min(100%, calc(100vw - 32px)) !important;
  }

  .elementor-element-5f5d067c,
  .elementor-element-5f5d067c > .e-con-inner {
    flex-direction: column;
    align-items: stretch;
    gap: 44px;
  }

  .elementor-element-5f5d067c .sf-if-intro-copy,
  .elementor-element-5f5d067c .sf-if-intro-visual {
    flex: none;
    width: 100%;
    max-width: 100%;
  }

  .elementor-element-5f5d067c .sf-if-intro-copy {
    padding-left: 20px;
  }

  .elementor-element-5f5d067c .sf-if-intro-copy p,
  .elementor-element-5f5d067c .sf-if-intro-copy .elementor-widget-container {
    font-size: 18px;
    line-height: 1.48;
  }

  .elementor-element-5f5d067c .sf-if-image-combo {
    width: min(340px, 100%);
  }

  .elementor-element-5f5d067c .sf-if-image-combo::before {
    left: -24px;
    right: -24px;
  }

  .elementor-element-5f5d067c .sf-if-corner-image {
    right: -10px;
    bottom: -28px;
    width: 44%;
  }
}

.elementor-element-5f5d067c > .e-con-inner {
  width: min(1340px, calc(100vw - 88px)) !important;
  max-width: min(1340px, calc(100vw - 88px)) !important;
}

.elementor-element-5f5d067c,
.elementor-element-5f5d067c > .e-con-inner {
  gap: clamp(24px, 3vw, 48px) !important;
}

.elementor-element-5f5d067c .sf-if-intro-copy {
  flex: 0 1 50% !important;
  max-width: 690px !important;
}

.elementor-element-5f5d067c .sf-if-intro-visual {
  flex: 0 1 42% !important;
  max-width: 540px !important;
}

.elementor-element-5f5d067c .sf-if-image-combo {
  width: min(480px, 100%) !important;
}

.elementor-element-5f5d067c .sf-if-copy-stack {
  display: grid;
  gap: 20px;
}

.elementor-element-5f5d067c .sf-if-copy-stack p {
  margin: 0 !important;
  font-family: "Poppins", sans-serif !important;
  color: #151515 !important;
  letter-spacing: 0 !important;
}

.elementor-element-5f5d067c .sf-if-copy-stack .sf-if-lead {
  font-size: clamp(22px, 1.55vw, 27px) !important;
  font-weight: 800 !important;
  line-height: 1.32 !important;
}

.elementor-element-5f5d067c .sf-if-copy-stack > p:not(.sf-if-lead) {
  font-size: clamp(17px, 1.12vw, 20px) !important;
  font-weight: 600 !important;
  line-height: 1.52 !important;
}

.elementor-element-5f5d067c .sf-if-uses {
  position: relative;
  width: fit-content;
  max-width: 100%;
  padding: 18px 22px 18px 24px;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.08);
  overflow: hidden;
}

.elementor-element-5f5d067c .sf-if-uses::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 7px;
  background: linear-gradient(
    180deg,
    #18bdf2,
    #2a1fd6,
    #d63ac7,
    #ff7a1a,
    #f4d03f,
    #7ac943
  );
  background-size: 100% 260%;
  animation: sfIfTextLight 5s linear infinite;
}

.elementor-element-5f5d067c .sf-if-uses-title {
  margin: 0 0 12px !important;
  font-size: 18px !important;
  font-weight: 900 !important;
  line-height: 1.1 !important;
}

.elementor-element-5f5d067c .sf-if-uses ul {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.elementor-element-5f5d067c .sf-if-uses li {
  padding: 8px 12px;
  border: 2px solid #000;
  border-radius: 999px;
  font-family: "Poppins", sans-serif;
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
  color: #000;
  background: #fff;
}

.elementor-element-5f5d067c .sf-if-close {
  max-width: 620px;
}

@media (max-width: 767px) {
  .elementor-element-5f5d067c > .e-con-inner {
    width: min(100%, calc(100vw - 32px)) !important;
    max-width: min(100%, calc(100vw - 32px)) !important;
  }

  .elementor-element-5f5d067c .sf-if-copy-stack {
    gap: 18px;
  }

  .elementor-element-5f5d067c .sf-if-uses {
    width: 100%;
  }

  .elementor-element-5f5d067c .sf-if-uses li {
    font-size: 13px;
  }

  .elementor-element-5f5d067c .sf-if-image-combo {
    width: min(340px, 100%) !important;
  }
}



/* Image film intro - javított arányok, nem kifelé szélesítve */

.elementor-element-5f5d067c {
  --sf-intro-max-width: 1260px;
  --sf-intro-side-space: 80px;
  --sf-column-gap: clamp(30px, 3vw, 55px);

  --sf-copy-gap: clamp(20px, 2.5vw, 40px);
  --sf-lead-line-height: 1.6;
  --sf-text-line-height: 1.9;

  --sf-uses-padding-y: 13px;
  --sf-uses-padding-x: 13px;
  --sf-uses-title-gap: 22px;
  --sf-pill-gap-x: 10px;
  --sf-pill-gap-y: 10px;

  --sf-image-width: 550px;
  --sf-corner-image-size: clamp(130px, 30%, 180px);

  width: 100% !important;
  max-width: none !important;
  box-sizing: border-box !important;
  padding-left: max(32px, calc(var(--sf-intro-side-space) / 2)) !important;
  padding-right: max(32px, calc(var(--sf-intro-side-space) / 2)) !important;
  overflow: visible !important;
}

.elementor-element-5f5d067c > .e-con-inner {
  width: min(var(--sf-intro-max-width), 100%) !important;
  max-width: min(var(--sf-intro-max-width), 100%) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.elementor-element-5f5d067c,
.elementor-element-5f5d067c > .e-con-inner {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 0.9fr) !important;
  align-items: center !important;
  gap: var(--sf-column-gap) !important;
  overflow: visible !important;
}

.elementor-element-5f5d067c .sf-if-intro-copy {
  position: relative !important;
  min-width: 0 !important;
  max-width: 100% !important;
  padding-left: 28px !important;
}

.elementor-element-5f5d067c .sf-if-intro-copy::before {
  left: 0 !important;
}

.elementor-element-5f5d067c .sf-if-copy-stack {
  display: grid !important;
  gap: var(--sf-copy-gap) !important;
}

.elementor-element-5f5d067c .sf-if-copy-stack .sf-if-lead {
  line-height: var(--sf-lead-line-height) !important;
}

.elementor-element-5f5d067c .sf-if-copy-stack > p:not(.sf-if-lead),
.elementor-element-5f5d067c .sf-if-close {
  line-height: var(--sf-text-line-height) !important;
}

.elementor-element-5f5d067c .sf-if-uses {
  padding: var(--sf-uses-padding-y) var(--sf-uses-padding-x) !important;
}

.elementor-element-5f5d067c .sf-if-copy-stack .sf-if-uses .sf-if-uses-title {
  display: block !important;
  margin: 0 !important;
  padding: 0 0 var(--sf-uses-title-gap) !important;
}

.elementor-element-5f5d067c .sf-if-copy-stack .sf-if-uses ul {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: var(--sf-pill-gap-y) var(--sf-pill-gap-x) !important;
  margin: 0 !important;
  padding: 0 !important;
}

.elementor-element-5f5d067c .sf-if-intro-visual {
  min-width: 0 !important;
  max-width: 100% !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  overflow: visible !important;
}

.elementor-element-5f5d067c .sf-if-image-combo {
  width: min(var(--sf-image-width), 100%) !important;
  max-width: 100% !important;
  overflow: visible !important;
}

.elementor-element-5f5d067c .sf-if-corner-image {
  width: var(--sf-corner-image-size) !important;
  right: -26px !important;
  bottom: -28px !important;
}

@media (max-width: 1024px) {
  .elementor-element-5f5d067c {
    --sf-intro-side-space: 56px;
    --sf-column-gap: 34px;
    --sf-copy-gap: 28px;
    --sf-image-width: 430px;
    --sf-uses-title-gap: 26px;
  }
}

@media (max-width: 767px) {
  .elementor-element-5f5d067c {
    --sf-intro-side-space: 32px;
    --sf-copy-gap: 24px;
    --sf-lead-line-height: 1.38;
    --sf-text-line-height: 1.55;
    --sf-uses-padding-y: 22px;
    --sf-uses-padding-x: 22px;
    --sf-uses-title-gap: 22px;
    --sf-pill-gap-x: 10px;
    --sf-pill-gap-y: 10px;
    --sf-image-width: 340px;
  }

  .elementor-element-5f5d067c,
  .elementor-element-5f5d067c > .e-con-inner {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 42px !important;
  }

  .elementor-element-5f5d067c .sf-if-corner-image {
    right: -10px !important;
    bottom: -28px !important;
    width: 44% !important;
  }
}


/* Image film intro - felhasználható címkék törése 1100-1400 között */

.elementor-element-5f5d067c {
  --sf-uses-label-gap: 22px;
}

/* A Felhasználható: és a címkék közti valódi távolság */
.elementor-element-5f5d067c .sf-if-copy-stack .sf-if-uses .sf-if-uses-title {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
}

.elementor-element-5f5d067c .sf-if-copy-stack .sf-if-uses ul {
  margin-top: var(--sf-uses-label-gap) !important;
}

/* 1100-1400px között fix 2 + 2 elrendezés */
@media (min-width: 1100px) and (max-width: 1400px) {
  .elementor-element-5f5d067c {
    --sf-uses-label-gap: 24px;
    --sf-pill-gap-x: 18px;
    --sf-pill-gap-y: 14px;
    --sf-image-width: 570px;
  }

  .elementor-element-5f5d067c .sf-if-copy-stack .sf-if-uses {
    width: fit-content !important;
    max-width: 100% !important;
  }

  .elementor-element-5f5d067c .sf-if-copy-stack .sf-if-uses ul {
    display: grid !important;
    grid-template-columns: max-content max-content !important;
    column-gap: var(--sf-pill-gap-x) !important;
    row-gap: var(--sf-pill-gap-y) !important;
    align-items: center !important;
  }

  .elementor-element-5f5d067c .sf-if-copy-stack .sf-if-uses li {
    width: fit-content !important;
    white-space: nowrap !important;
  }
}

/* Tablet: rendezett 2 + 2 */
@media (min-width: 768px) and (max-width: 1099px) {
  .elementor-element-5f5d067c {
    --sf-uses-label-gap: 22px;
    --sf-pill-gap-x: 14px;
    --sf-pill-gap-y: 12px;
  }

  .elementor-element-5f5d067c .sf-if-copy-stack .sf-if-uses ul {
    display: grid !important;
    grid-template-columns: max-content max-content !important;
    column-gap: var(--sf-pill-gap-x) !important;
    row-gap: var(--sf-pill-gap-y) !important;
  }

  .elementor-element-5f5d067c .sf-if-copy-stack .sf-if-uses li {
    width: fit-content !important;
    white-space: nowrap !important;
  }
}

/* Mobilon ne erőltessük a 2 oszlopot */
@media (max-width: 767px) {
  .elementor-element-5f5d067c {
    --sf-uses-label-gap: 18px;
  }

  .elementor-element-5f5d067c .sf-if-copy-stack .sf-if-uses ul {
    display: flex !important;
    flex-wrap: wrap !important;
  }
}

/* Source: storyframe-audit/elementor/content/page/2755.json | element: 9a65b6b */
.sf-if-hero,
.sf-if-main {
  background: #fff;
  color: #000;
  font-family: Inter, Poppins, Arial, sans-serif;
  padding: 92px 24px;
}

.sf-if-wrap {
  width: min(1280px, 100%);
  margin: 0 auto;
}

.sf-if-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(420px, 1.05fr);
  gap: 56px;
  align-items: center;
}

.sf-if-hero-copy h1 {
  display: inline-block;
  margin: 0 0 32px;
  padding: 14px 24px;
  border: 5px solid transparent;
  border-radius: 8px;
  background: linear-gradient(#fff, #fff) padding-box,
    linear-gradient(90deg, #18b8ee, #3527d8, #d63cc7, #ffba00, #73d600, #23c6a5) border-box;
  font-family: Poppins, Arial, sans-serif;
  font-size: 76px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0;
}

.sf-if-hero-copy p,
.sf-if-story-box p {
  max-width: 760px;
  margin: 0 0 22px;
  color: #2d2d2d;
  font-size: 21px;
  line-height: 1.55;
}

.sf-if-hero-media {
  position: relative;
}

.sf-if-main-photo,
.sf-if-float-photo,
.sf-if-werk figure {
  margin: 0;
  background: #fff;
}

.sf-if-main-photo {
  padding: 10px;
  border: 4px solid transparent;
  border-radius: 8px;
  background: linear-gradient(#fff, #fff) padding-box,
    linear-gradient(135deg, #18b8ee, #3527d8, #d63cc7, #ffba00, #73d600, #23c6a5) border-box;
}

.sf-if-main-photo img,
.sf-if-float-photo img,
.sf-if-werk img {
  display: block;
  width: 100%;
  object-fit: cover;
  border-radius: 6px;
}

.sf-if-main-photo img {
  aspect-ratio: 16 / 10;
}

.sf-if-float-photo {
  position: absolute;
  right: -18px;
  bottom: -46px;
  width: 34%;
  padding: 8px;
  border: 3px solid #000;
  border-radius: 8px;
  transform: rotate(3deg);
}

.sf-if-float-photo img {
  aspect-ratio: 3 / 4;
}

.sf-if-info-grid {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 28px;
  align-items: stretch;
}

.sf-if-uses-box,
.sf-if-story-box {
  border: 3px solid #000;
  border-radius: 8px;
  background: #fff;
  padding: 34px;
}

.sf-if-uses-box h2 {
  margin: 0 0 24px;
  font-family: Poppins, Arial, sans-serif;
  font-size: 44px;
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: 0;
}

.sf-if-uses-box ul {
  display: grid;
  gap: 14px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.sf-if-uses-box li {
  position: relative;
  padding-left: 26px;
  color: #2d2d2d;
  font-size: 20px;
  line-height: 1.35;
}

.sf-if-uses-box li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.62em;
  width: 14px;
  height: 4px;
  border-radius: 99px;
  background: linear-gradient(90deg, #18b8ee, #3527d8, #d63cc7);
}

.sf-if-story-box {
  display: flex;
  align-items: center;
}

.sf-if-story-box p {
  margin: 0;
  font-family: Poppins, Arial, sans-serif;
  font-size: 34px;
  font-weight: 900;
  line-height: 1.16;
  color: #000;
}

.sf-if-werk {
  display: grid;
  grid-template-columns: 0.8fr 1.1fr 1.1fr;
  gap: 24px;
  margin-top: 64px;
  align-items: stretch;
}

.sf-if-werk figure {
  padding: 8px;
  border: 3px solid transparent;
  border-radius: 8px;
  background: linear-gradient(#fff, #fff) padding-box,
    linear-gradient(135deg, #18b8ee, #3527d8, #d63cc7, #ffba00, #73d600, #23c6a5) border-box;
}

.sf-if-werk img {
  height: 100%;
  min-height: 360px;
}

.sf-if-werk-tall {
  grid-row: span 2;
}

.sf-if-videos {
  background: #fff;
  color: #000;
  padding: 80px 24px 110px;
}

.sf-if-video-layout {
  width: min(1320px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 26px;
}

.sf-if-video-card.is-featured {
  grid-column: 1 / -1;
}

.sf-if-video-open {
  display: block;
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  text-align: left;
}

.sf-if-video-thumb {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: #000;
  border-radius: 8px;
}

.sf-if-video-thumb img,
.sf-if-video-thumb iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
}

.sf-if-video-thumb img {
  z-index: 1;
  object-fit: cover;
  transition: opacity 0.2s ease, transform 0.35s ease;
}

.sf-if-video-thumb iframe {
  z-index: 2;
  border: 0;
  opacity: 0;
  pointer-events: none;
}

.sf-if-video-card.is-previewing .sf-if-video-thumb iframe {
  opacity: 1;
}

.sf-if-video-card.is-previewing .sf-if-video-thumb img {
  opacity: 0;
  transform: scale(1.03);
}

.sf-if-play-mark {
  position: absolute;
  z-index: 3;
  left: 18px;
  bottom: 18px;
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.72);
  box-shadow: 0 0 0 2px #fff;
}

.sf-if-play-mark::before {
  content: "";
  position: absolute;
  left: 23px;
  top: 17px;
  border-left: 17px solid #fff;
  border-top: 12px solid transparent;
  border-bottom: 12px solid transparent;
}

.sf-if-video-card.is-previewing .sf-if-play-mark {
  opacity: 0;
}

.sf-if-video-card h3 {
  margin: 0;
  padding: 16px 2px 0;
  font-family: Poppins, Arial, sans-serif;
  font-size: clamp(20px, 1.7vw, 30px);
  font-weight: 900;
  line-height: 1.08;
  color: #000;
  letter-spacing: 0;
}

.sf-if-video-modal {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(0, 0, 0, 0.86);
}

.sf-if-video-modal[aria-hidden="false"] {
  display: flex;
}

.sf-if-video-modal-inner {
  position: relative;
  width: min(1180px, 100%);
  aspect-ratio: 16 / 9;
  background: #000;
  border-radius: 8px;
  overflow: hidden;
}

.sf-if-video-modal-inner iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.sf-if-video-close {
  position: fixed;
  top: 22px;
  right: 22px;
  z-index: 100000;
  width: 48px;
  height: 48px;
  border: 2px solid #fff;
  border-radius: 50%;
  background: #000;
  cursor: pointer;
}

.sf-if-video-close::before,
.sf-if-video-close::after {
  content: "";
  position: absolute;
  left: 13px;
  top: 22px;
  width: 20px;
  height: 3px;
  background: #fff;
  border-radius: 99px;
}

.sf-if-video-close::before {
  transform: rotate(45deg);
}

.sf-if-video-close::after {
  transform: rotate(-45deg);
}

@media (max-width: 1024px) {
  .sf-if-hero-grid,
  .sf-if-info-grid {
    grid-template-columns: 1fr 1fr;
  }

  .sf-if-video-layout {
    grid-template-columns: repeat(2, 1fr);
  }

  .sf-if-hero-copy h1 {
    font-size: 58px;
  }

  .sf-if-werk {
    grid-template-columns: 1fr;
  }

  .sf-if-werk-tall {
    grid-row: auto;
  }
}

@media (max-width: 767px) {
  .sf-if-hero,
  .sf-if-main {
    padding: 58px 20px;
  }

  .sf-if-videos {
    padding: 58px 20px 84px;
  }

  .sf-if-hero-grid,
  .sf-if-info-grid,
  .sf-if-video-layout {
    grid-template-columns: 1fr;
  }

  .sf-if-hero-copy h1 {
    font-size: 42px;
    line-height: 1;
  }

  .sf-if-hero-copy p,
  .sf-if-story-box p {
    font-size: 18px;
  }

  .sf-if-uses-box,
  .sf-if-story-box {
    padding: 26px;
  }

  .sf-if-uses-box h2 {
    font-size: 32px;
  }

  .sf-if-story-box p {
    font-size: 26px;
  }

  .sf-if-float-photo {
    position: relative;
    right: auto;
    bottom: auto;
    width: 58%;
    margin: -34px 18px 0 auto;
  }

  .sf-if-werk {
    grid-template-columns: 1fr;
    margin-top: 36px;
  }

  .sf-if-werk img {
    min-height: 260px;
  }

  .sf-if-video-layout {
    gap: 28px;
  }

  .sf-if-video-card h3 {
    font-size: 21px;
  }

  .sf-if-video-modal {
    padding: 16px;
  }

  .sf-if-video-close {
    top: 14px;
    right: 14px;
  }
}

.sf-if-loop-section {
  background: #fff !important;
  color: #000 !important;
  padding: 80px 0 110px !important;
  overflow: hidden !important;
}

.sf-if-loop-marquee {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  overflow: hidden;
}

.sf-if-loop-track {
  display: flex;
  width: max-content;
  animation: sfIfLoopMove 75s linear infinite;
  will-change: transform;
}

.sf-if-loop-marquee:hover .sf-if-loop-track {
  animation-play-state: paused;
}

.sf-if-loop-card {
  flex: 0 0 clamp(340px, 33.333vw, 620px);
  background: #fff;
}

.sf-if-loop-open {
  display: block;
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
}

.sf-if-loop-thumb {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: #000;
}

.sf-if-loop-thumb img,
.sf-if-loop-thumb iframe {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
}

.sf-if-loop-thumb img {
  z-index: 1;
  object-fit: cover;
  transition: opacity 0.22s ease, transform 0.35s ease;
}

.sf-if-loop-thumb iframe {
  z-index: 2;
  border: 0;
  opacity: 0;
  pointer-events: none;
}

.sf-if-loop-card.is-previewing .sf-if-loop-thumb iframe {
  opacity: 1;
}

.sf-if-loop-card.is-previewing .sf-if-loop-thumb img {
  opacity: 0;
  transform: scale(1.03);
}

.sf-if-loop-play {
  position: absolute;
  z-index: 3;
  left: 18px;
  bottom: 18px;
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.72);
  box-shadow: 0 0 0 2px #fff;
  transition: opacity 0.2s ease;
}

.sf-if-loop-play::before {
  content: "";
  position: absolute;
  left: 23px;
  top: 17px;
  border-left: 17px solid #fff;
  border-top: 12px solid transparent;
  border-bottom: 12px solid transparent;
}

.sf-if-loop-card.is-previewing .sf-if-loop-play {
  opacity: 0;
}

.sf-if-loop-card h3 {
  margin: 0;
  padding: 18px 18px 0;
  font-family: Poppins, Arial, sans-serif;
  font-size: clamp(20px, 1.7vw, 30px);
  font-weight: 900;
  line-height: 1.08;
  color: #000;
  letter-spacing: 0;
}

.sf-if-loop-modal {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(0, 0, 0, 0.86);
}

.sf-if-loop-modal[aria-hidden="false"] {
  display: flex;
}

.sf-if-loop-modal-inner {
  position: relative;
  width: min(1180px, 100%);
  aspect-ratio: 16 / 9;
  background: #000;
  border-radius: 8px;
  overflow: hidden;
}

.sf-if-loop-modal-inner iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.sf-if-loop-close {
  position: fixed;
  top: 22px;
  right: 22px;
  z-index: 100000;
  width: 48px;
  height: 48px;
  border: 2px solid #fff;
  border-radius: 50%;
  background: #000;
  cursor: pointer;
}

.sf-if-loop-close::before,
.sf-if-loop-close::after {
  content: "";
  position: absolute;
  left: 13px;
  top: 22px;
  width: 20px;
  height: 3px;
  background: #fff;
  border-radius: 99px;
}

.sf-if-loop-close::before {
  transform: rotate(45deg);
}

.sf-if-loop-close::after {
  transform: rotate(-45deg);
}

@keyframes sfIfLoopMove {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-50%);
  }
}

@media (max-width: 767px) {
  .sf-if-loop-section {
    padding: 58px 0 84px !important;
  }

  .sf-if-loop-track {
    animation-duration: 58s;
  }

  .sf-if-loop-card {
    flex-basis: 82vw;
  }

  .sf-if-loop-card h3 {
    padding: 14px 14px 0;
    font-size: 21px;
  }

  .sf-if-loop-modal {
    padding: 16px;
  }

  .sf-if-loop-close {
    top: 14px;
    right: 14px;
  }
}

.sf-if-video-container,
.sf-if-video-container.e-con,
.sf-if-video-container .e-con-inner,
.sf-if-video-container .elementor-widget-html,
.sf-if-video-container .elementor-widget-container {
  width: 100% !important;
  max-width: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.sf-if-loop-section {
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.sf-if-loop-marquee {
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.sf-if-loop-card h3 {
  padding: 20px 18px 10px !important;
  line-height: 1.18 !important;
  overflow: visible !important;
}

/* Source: storyframe-audit/elementor/content/page/2755.json | element: ac6bf0 */
/* Ajánlatkérés form - 320px mobil finomhangolás */
@media (max-width: 340px) {
  .elementor-element-ac6bf0 {
    overflow: visible !important;
  }

  .elementor-element-ac6bf0 .sf-quote-copy,
  .elementor-element-ac6bf0 .sf-quote-card {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 22px !important;
    padding-right: 22px !important;
    box-sizing: border-box !important;
    overflow: visible !important;
  }

  .elementor-element-ac6bf0 .sf-quote-copy h1,
  .elementor-element-ac6bf0 .sf-quote-copy h2,
  .elementor-element-ac6bf0 .sf-quote-copy h3 {
    max-width: 100% !important;
    font-size: 27px !important;
    line-height: 1.05 !important;
    letter-spacing: 0 !important;
    white-space: normal !important;
    overflow-wrap: break-word !important;
    word-break: normal !important;
  }

  .elementor-element-ac6bf0 .sf-quote-copy p {
    font-size: 15px !important;
    line-height: 1.45 !important;
  }

  .elementor-element-ac6bf0 .sf-quote-form .elementor-field-label {
    font-size: 22px !important;
    line-height: 1.05 !important;
    letter-spacing: 0 !important;
  }

  .elementor-element-ac6bf0 .sf-quote-form .elementor-field-subgroup {
    gap: 9px !important;
  }

  .elementor-element-ac6bf0 .sf-quote-form .elementor-field-option {
    display: flex !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    gap: 7px !important;
    width: fit-content !important;
    max-width: 100% !important;
  }

  .elementor-element-ac6bf0 .sf-quote-form .elementor-field-option label {
    display: inline-flex !important;
    align-items: center !important;
    width: fit-content !important;
    max-width: none !important;
    padding: 8px 10px !important;
    font-size: 12px !important;
    line-height: 1 !important;
    white-space: nowrap !important;
  }

  .elementor-element-ac6bf0 .sf-quote-form .elementor-field-option input {
    flex: 0 0 auto !important;
    width: 13px !important;
    height: 13px !important;
    margin: 0 !important;
  }

  .elementor-element-ac6bf0 .sf-quote-form textarea {
    min-height: 130px !important;
  }
}

/* Ajánlatkérés - tablet kétoszlopos elrendezés */
@media (min-width: 768px) and (max-width: 1024px) {
  body .sf-quote-section {
    padding: 72px 18px 88px !important;
  }

  body .sf-quote-inner {
    width: min(96vw, 980px) !important;
  }

  body .sf-quote-layout {
    grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr) !important;
    gap: 22px !important;
    align-items: stretch !important;
    margin-top: 38px !important;
  }

  body .sf-quote-copy {
    position: relative !important;
    padding: 30px !important;
    border-radius: 20px !important;
    overflow: hidden !important;
  }

  body .sf-quote-copy::after {
    left: 30px !important;
    right: 30px !important;
  }

  body .sf-quote-copy-block {
    width: 100% !important;
    min-height: 100% !important;
    display: block !important;
    padding-bottom: 0 !important;
  }

  body .sf-quote-eyebrow {
    margin-bottom: 15px !important;
  }

  body .sf-quote-copy h3 {
    font-size: clamp(30px, 3.7vw, 38px) !important;
  }

  body .sf-quote-copy p {
    font-size: 15px !important;
    line-height: 1.45 !important;
  }

  body .sf-quote-contact {
    gap: 10px !important;
    margin-top: 26px !important;
  }

  body .sf-quote-contact a {
    padding: 14px 16px !important;
    border-radius: 14px !important;
    font-size: 14px !important;
  }

  body .sf-quote-logo-link {
    position: absolute !important;
    left: 50% !important;
    right: auto !important;
    top: auto !important;
    bottom: -315px !important;
    width: clamp(260px, 34vw, 360px) !important;
    max-width: calc(100% - 42px) !important;
    margin: 0 !important;
    transform: translateX(-50%) !important;
  }

  body .sf-quote-logo-img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
  }

  body .sf-quote-card {
    padding: 28px !important;
    border-radius: 20px !important;
  }
}

/* Source: storyframe-audit/elementor/content/page/2755.json | element: 2b0efee1 */
@media (max-width: 374px) {
  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option {
    display: grid !important;
    grid-template-columns: 14px minmax(0, 1fr) !important;
    column-gap: 8px !important;
    row-gap: 0 !important;
    align-items: flex-start !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option input {
    width: 14px !important;
    height: 14px !important;
    margin: 3px 0 0 !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option label {
    display: block !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: 100% !important;
    min-height: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    white-space: normal !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    line-height: 1.35 !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option label a {
    display: inline !important;
    width: auto !important;
    max-width: none !important;
    white-space: nowrap !important;
    overflow-wrap: normal !important;
    word-break: keep-all !important;
  }
}

@media (max-width: 430px) {
  body .sf-quote-section .sf-quote-inner .sf-quote-copy h3 {
    font-size: 27px !important;
    line-height: 1.08 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
    text-wrap: balance;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-group-field_6cde44b {
    position: relative;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-group-field_6cde44b input::placeholder {
    color: transparent !important;
    opacity: 0 !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-group-field_6cde44b::after {
    content: "Facebook / Instagram / Google / Ajánlás / TikTok / Egyéb";
    display: block;
    margin-top: 8px;
    padding-left: 2px;
    font-family: "Inter", "Poppins", sans-serif;
    font-size: 11px;
    line-height: 1.35;
    font-weight: 600;
    color: rgba(0, 0, 0, 0.46);
  }
}

@media (max-width: 340px) {
  body .sf-quote-section .sf-quote-inner .sf-quote-layout .sf-quote-copy {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-layout .sf-quote-copy h3 {
    font-size: 23px !important;
    line-height: 1.08 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
    text-wrap: balance;
  }
}

/* Source: storyframe-audit/elementor/content/page/2755.json | element: 492a9b8a */
.sf-quote-section {
  padding: 90px 20px 110px;
  background: #ffffff;
}

.sf-quote-inner {
  width: min(92vw, 1420px);
  margin: 0 auto;
}

.sf-quote-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 34px;
  align-items: stretch;
  margin-top: 52px;
}

.sf-quote-copy,
.sf-quote-card {
  border-radius: 24px;
}

.sf-quote-copy {
  padding: 46px;
  background: #111111;
  color: #ffffff;
  overflow: hidden;
  position: relative;
}

.sf-quote-copy::after {
  content: "";
  position: absolute;
  left: 46px;
  right: 46px;
  bottom: 0;
  height: 6px;
  background: linear-gradient(90deg, #29c8ff, #3b39ff, #d93bdb, #ffd400, #9be400, #21cdb8);
}

.sf-quote-logo-link {
  position: relative;
  display: flex;
  width: clamp(200px, 21vw, 320px);
  aspect-ratio: 1 / 1;
  align-items: center;
  justify-content: center;
  margin: 34px auto 0;
  text-decoration: none;
  overflow: visible;
}


.sf-quote-logo-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.sf-quote-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-quote-logo-link:hover::after {
  opacity: 0.95;
  animation: sfQuoteLogoFlow 1.1s linear infinite;
}

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

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



.sf-quote-eyebrow {
  margin: 0 0 18px;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.sf-quote-copy h3 {
  margin: 0 0 24px;
  font-family: "Poppins", sans-serif;
  font-size: 44px;
  line-height: 1.05;
  font-weight: 900;
}

.sf-quote-copy p {
  margin: 0 0 18px;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 18px;
  line-height: 1.4;
  color: rgba(255,255,255,0.78);
}

.sf-quote-contact {
  display: grid;
  gap: 12px;
  margin-top: 34px;
}

.sf-quote-contact a {
  display: block;
  padding: 18px 20px;
  border-radius: 16px;
  color: #ffffff;
  text-decoration: none;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.14);
  font-family: "Inter", "Poppins", sans-serif;
  font-weight: 700;
}

.sf-quote-contact span {
  display: block;
  margin-bottom: 4px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}

.sf-quote-card {
  padding: 42px;
  background:
    linear-gradient(#ffffff, #ffffff) padding-box,
    linear-gradient(135deg, #29c8ff, #3b39ff, #d93bdb, #ffd400, #9be400, #21cdb8) border-box;
  border: 4px solid transparent;
  box-shadow: 0 24px 80px rgba(0,0,0,0.10);
}

.sf-quote-form .elementor-field-label {
  margin-bottom: 8px;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 13px;
  font-weight: 800;
  color: #151515;
}

.sf-quote-form .elementor-field-textual {
  min-height: 52px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,0.12);
  background: #f7f7f7;
  padding: 14px 16px;
  font-family: "Inter", "Poppins", sans-serif;
}

.sf-quote-form textarea.elementor-field-textual {
  min-height: 140px;
  resize: vertical;
}

.sf-quote-form .elementor-field-subgroup {
  display: flex;
  flex-wrap: wrap;
  gap: 13px;
}

.sf-quote-form .elementor-field-option label {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 10px 14px;
  border-radius: 999px;
  background: #f7f7f7;
  border: 1px solid rgba(0,0,0,0.10);
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
}

.sf-quote-form .elementor-field-option input {
  margin-right: 10px;
}

.sf-quote-form .elementor-field-type-acceptance {
  margin-top: 16px;
  margin-bottom: 24px;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-subgroup {
  display: block !important;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-option {
  display: flex !important;
  align-items: flex-start;
  gap: 10px;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-option input {
  flex: 0 0 auto;
  margin: 4px 0 0 !important;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-option label {
  display: block !important;
  min-height: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 12px;
  line-height: 1.55;
  font-weight: 500;
  color: rgba(0,0,0,0.62);
}

.sf-quote-form .elementor-field-type-acceptance a {
  color: #151515;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 3px;
}


.sf-quote-form .elementor-field-type-submit {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
  margin: 0 !important;
  padding: 0 !important;
}

.sf-quote-form .elementor-field-type-html {
  width: 100% !important;
  flex-basis: 100% !important;
}

.sf-quote-submit-row {
  display: flex !important;
  justify-content: center !important;
  width: 100% !important;
  margin-top: 10px;
}

.sf-quote-submit-row .sf-cta-wrap {
  width: auto !important;
  max-width: max-content !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.sf-quote-submit-row .sf-cta {
  width: auto !important;
}




@media (max-width: 1024px) {
  .sf-quote-section {
    padding: 78px 20px 92px;
  }

  .sf-quote-inner {
    width: min(94vw, 920px);
  }

  .sf-quote-layout {
    grid-template-columns: 1fr;
    gap: 26px;
    margin-top: 42px;
  }

  .sf-quote-copy {
    padding: 40px;
  }

  .sf-quote-copy h3 {
    font-size: 38px;
  }

  .sf-quote-card {
    padding: 36px;
  }
}

@media (max-width: 767px) {
  .sf-quote-section {
    padding: 64px 18px 78px;
  }

  .sf-quote-inner {
    width: 100%;
  }

  .sf-quote-layout {
    margin-top: 34px;
    gap: 20px;
  }

  .sf-quote-copy {
    padding: 30px 24px 34px;
    border-radius: 20px;
  }

  .sf-quote-copy::after {
    left: 24px;
    right: 24px;
  }

  .sf-quote-copy h3 {
    font-size: 31px;
  }

  .sf-quote-copy p {
    font-size: 15px;
  }

  .sf-quote-card {
    padding: 24px;
    border-radius: 20px;
  }

  .sf-quote-form .elementor-field-group {
    width: 100% !important;
  }

  .sf-quote-form .elementor-field-option label {
    font-size: 13px;
    min-height: 40px;
  }
  
    .sf-quote-logo-link {
    width: 190px;
    margin: 0 auto 24px;
  }



}

.elementor-element-492a9b8a .sf-quote-submit-row {
  width: 100% !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  margin: 28px 0 0 !important;
}

.elementor-element-492a9b8a .sf-quote-submit-row .sf-cta-wrap {
  width: fit-content !important;
  padding: 10px 14px !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.72) !important;
  border: 1px solid rgba(0, 0, 0, 0.08) !important;
  box-shadow:
    0 12px 35px rgba(0, 0, 0, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.9) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
}

.elementor-element-492a9b8a .sf-quote-submit-row .sf-cta {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 54px !important;
  padding: 0 10px !important;
  text-decoration: none !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  overflow: visible !important;
  cursor: pointer !important;
}

.elementor-element-492a9b8a .sf-quote-submit-row .sf-cta span {
  position: relative !important;
  z-index: 1 !important;
  display: inline-block !important;
  font-family: "Poppins", sans-serif !important;
  font-size: 19px !important;
  font-weight: 800 !important;
  line-height: 1.1 !important;
  color: #151515 !important;
  text-shadow: none !important;
  transition: opacity 0.25s ease !important;
}

.elementor-element-492a9b8a .sf-quote-submit-row .sf-cta::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Poppins", sans-serif;
  font-size: 19px;
  font-weight: 800;
  line-height: 1.1;
  white-space: nowrap;

  background: linear-gradient(
    90deg,
    #29c8ff 0%,
    #3b39ff 18%,
    #d93bdb 36%,
    #ffd400 58%,
    #9be400 78%,
    #21cdb8 100%
  );
  background-size: 25% 100%;
  background-position: 100% 50%;

  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;

  opacity: 0;
  transition: opacity 0.25s ease;
}

.elementor-element-492a9b8a .sf-quote-submit-row .sf-cta:hover span {
  opacity: 0 !important;
}

.elementor-element-492a9b8a .sf-quote-submit-row .sf-cta:hover::after {
  opacity: 1 !important;
  animation: sfQuoteTextFlow 1.6s linear infinite;
}

.elementor-element-492a9b8a .sf-quote-submit-row .sf-cta-wrap:hover {
  box-shadow:
    0 16px 45px rgba(0, 0, 0, 0.12),
    0 0 35px rgba(41, 200, 255, 0.10),
    inset 0 1px 0 rgba(255, 255, 255, 1) !important;
}

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

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

@media (max-width: 767px) {
  .elementor-element-492a9b8a .sf-quote-submit-row .sf-cta {
    min-height: 46px !important;
  }

  .elementor-element-492a9b8a .sf-quote-submit-row .sf-cta span,
  .elementor-element-492a9b8a .sf-quote-submit-row .sf-cta::after {
    font-size: 14px !important;
    white-space: nowrap !important;
  }
}

/* Source: storyframe-audit/elementor/content/page/35.json | element: 37455201 */
/* Ajánlatkérés form - 320px mobil finomhangolás */
@media (max-width: 340px) {
  .elementor-element-37455201 {
    overflow: visible !important;
  }

  .elementor-element-37455201 .sf-quote-copy,
  .elementor-element-37455201 .sf-quote-card {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 22px !important;
    padding-right: 22px !important;
    box-sizing: border-box !important;
    overflow: visible !important;
  }

  .elementor-element-37455201 .sf-quote-copy h1,
  .elementor-element-37455201 .sf-quote-copy h2,
  .elementor-element-37455201 .sf-quote-copy h3 {
    max-width: 100% !important;
    font-size: 27px !important;
    line-height: 1.05 !important;
    letter-spacing: 0 !important;
    white-space: normal !important;
    overflow-wrap: break-word !important;
    word-break: normal !important;
  }

  .elementor-element-37455201 .sf-quote-copy p {
    font-size: 15px !important;
    line-height: 1.45 !important;
  }

  .elementor-element-37455201 .sf-quote-form .elementor-field-label {
    font-size: 22px !important;
    line-height: 1.05 !important;
    letter-spacing: 0 !important;
  }

  .elementor-element-37455201 .sf-quote-form .elementor-field-subgroup {
    gap: 9px !important;
  }

  .elementor-element-37455201 .sf-quote-form .elementor-field-option {
    display: flex !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    gap: 7px !important;
    width: fit-content !important;
    max-width: 100% !important;
  }

  .elementor-element-37455201 .sf-quote-form .elementor-field-option label {
    display: inline-flex !important;
    align-items: center !important;
    width: fit-content !important;
    max-width: none !important;
    padding: 8px 10px !important;
    font-size: 12px !important;
    line-height: 1 !important;
    white-space: nowrap !important;
  }

  .elementor-element-37455201 .sf-quote-form .elementor-field-option input {
    flex: 0 0 auto !important;
    width: 13px !important;
    height: 13px !important;
    margin: 0 !important;
  }

  .elementor-element-37455201 .sf-quote-form textarea {
    min-height: 130px !important;
  }
}

/* Ajánlatkérés - tablet kétoszlopos elrendezés */
@media (min-width: 768px) and (max-width: 1024px) {
  body .sf-quote-section {
    padding: 72px 18px 88px !important;
  }

  body .sf-quote-inner {
    width: min(96vw, 980px) !important;
  }

  body .sf-quote-layout {
    grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr) !important;
    gap: 22px !important;
    align-items: stretch !important;
    margin-top: 38px !important;
  }

  body .sf-quote-copy {
    position: relative !important;
    padding: 30px !important;
    border-radius: 20px !important;
    overflow: hidden !important;
  }

  body .sf-quote-copy::after {
    left: 30px !important;
    right: 30px !important;
  }

  body .sf-quote-copy-block {
    width: 100% !important;
    min-height: 100% !important;
    display: block !important;
    padding-bottom: 0 !important;
  }

  body .sf-quote-eyebrow {
    margin-bottom: 15px !important;
  }

  body .sf-quote-copy h3 {
    font-size: clamp(30px, 3.7vw, 38px) !important;
  }

  body .sf-quote-copy p {
    font-size: 15px !important;
    line-height: 1.45 !important;
  }

  body .sf-quote-contact {
    gap: 10px !important;
    margin-top: 26px !important;
  }

  body .sf-quote-contact a {
    padding: 14px 16px !important;
    border-radius: 14px !important;
    font-size: 14px !important;
  }

  body .sf-quote-logo-link {
    position: absolute !important;
    left: 50% !important;
    right: auto !important;
    top: auto !important;
    bottom: -315px !important;
    width: clamp(260px, 34vw, 360px) !important;
    max-width: calc(100% - 42px) !important;
    margin: 0 !important;
    transform: translateX(-50%) !important;
  }

  body .sf-quote-logo-img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
  }

  body .sf-quote-card {
    padding: 28px !important;
    border-radius: 20px !important;
  }
}

/* Source: storyframe-audit/elementor/content/page/35.json | element: 490c7167 */
@media (max-width: 374px) {
  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option {
    display: grid !important;
    grid-template-columns: 14px minmax(0, 1fr) !important;
    column-gap: 8px !important;
    row-gap: 0 !important;
    align-items: flex-start !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option input {
    width: 14px !important;
    height: 14px !important;
    margin: 3px 0 0 !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option label {
    display: block !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: 100% !important;
    min-height: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    white-space: normal !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    line-height: 1.35 !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-type-acceptance .elementor-field-option label a {
    display: inline !important;
    width: auto !important;
    max-width: none !important;
    white-space: nowrap !important;
    overflow-wrap: normal !important;
    word-break: keep-all !important;
  }
}

@media (max-width: 430px) {
  body .sf-quote-section .sf-quote-inner .sf-quote-copy h3 {
    font-size: 27px !important;
    line-height: 1.08 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
    text-wrap: balance;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-group-field_6cde44b {
    position: relative;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-group-field_6cde44b input::placeholder {
    color: transparent !important;
    opacity: 0 !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-form .elementor-field-group-field_6cde44b::after {
    content: "Facebook / Instagram / Google / Ajánlás / TikTok / Egyéb";
    display: block;
    margin-top: 8px;
    padding-left: 2px;
    font-family: "Inter", "Poppins", sans-serif;
    font-size: 11px;
    line-height: 1.35;
    font-weight: 600;
    color: rgba(0, 0, 0, 0.46);
  }
}

@media (max-width: 340px) {
  body .sf-quote-section .sf-quote-inner .sf-quote-layout .sf-quote-copy {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  body .sf-quote-section .sf-quote-inner .sf-quote-layout .sf-quote-copy h3 {
    font-size: 23px !important;
    line-height: 1.08 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
    text-wrap: balance;
  }
}

/* Source: storyframe-audit/elementor/content/page/35.json | element: 1b8b2e39 */
.sf-quote-section {
  padding: 90px 20px 110px;
  background: #ffffff;
}

.sf-quote-inner {
  width: min(92vw, 1420px);
  margin: 0 auto;
}

.sf-quote-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 34px;
  align-items: stretch;
  margin-top: 52px;
}

.sf-quote-copy,
.sf-quote-card {
  border-radius: 24px;
}

.sf-quote-copy {
  padding: 46px;
  background: #111111;
  color: #ffffff;
  overflow: hidden;
  position: relative;
}

.sf-quote-copy::after {
  content: "";
  position: absolute;
  left: 46px;
  right: 46px;
  bottom: 0;
  height: 6px;
  background: linear-gradient(90deg, #29c8ff, #3b39ff, #d93bdb, #ffd400, #9be400, #21cdb8);
}

.sf-quote-logo-link {
  position: relative;
  display: flex;
  width: clamp(200px, 21vw, 320px);
  aspect-ratio: 1 / 1;
  align-items: center;
  justify-content: center;
  margin: 34px auto 0;
  text-decoration: none;
  overflow: visible;
}


.sf-quote-logo-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.sf-quote-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-quote-logo-link:hover::after {
  opacity: 0.95;
  animation: sfQuoteLogoFlow 1.1s linear infinite;
}

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

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



.sf-quote-eyebrow {
  margin: 0 0 18px;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.sf-quote-copy h3 {
  margin: 0 0 24px;
  font-family: "Poppins", sans-serif;
  font-size: 44px;
  line-height: 1.05;
  font-weight: 900;
}

.sf-quote-copy p {
  margin: 0 0 18px;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 18px;
  line-height: 1.4;
  color: rgba(255,255,255,0.78);
}

.sf-quote-contact {
  display: grid;
  gap: 12px;
  margin-top: 34px;
}

.sf-quote-contact a {
  display: block;
  padding: 18px 20px;
  border-radius: 16px;
  color: #ffffff;
  text-decoration: none;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.14);
  font-family: "Inter", "Poppins", sans-serif;
  font-weight: 700;
}

.sf-quote-contact span {
  display: block;
  margin-bottom: 4px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}

.sf-quote-card {
  padding: 42px;
  background:
    linear-gradient(#ffffff, #ffffff) padding-box,
    linear-gradient(135deg, #29c8ff, #3b39ff, #d93bdb, #ffd400, #9be400, #21cdb8) border-box;
  border: 4px solid transparent;
  box-shadow: 0 24px 80px rgba(0,0,0,0.10);
}

.sf-quote-form .elementor-field-label {
  margin-bottom: 8px;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 13px;
  font-weight: 800;
  color: #151515;
}

.sf-quote-form .elementor-field-textual {
  min-height: 52px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,0.12);
  background: #f7f7f7;
  padding: 14px 16px;
  font-family: "Inter", "Poppins", sans-serif;
}

.sf-quote-form textarea.elementor-field-textual {
  min-height: 140px;
  resize: vertical;
}

.sf-quote-form .elementor-field-subgroup {
  display: flex;
  flex-wrap: wrap;
  gap: 13px;
}

.sf-quote-form .elementor-field-option label {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 10px 14px;
  border-radius: 999px;
  background: #f7f7f7;
  border: 1px solid rgba(0,0,0,0.10);
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
}

.sf-quote-form .elementor-field-option input {
  margin-right: 10px;
}

.sf-quote-form .elementor-field-type-acceptance {
  margin-top: 16px;
  margin-bottom: 24px;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-subgroup {
  display: block !important;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-option {
  display: flex !important;
  align-items: flex-start;
  gap: 10px;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-option input {
  flex: 0 0 auto;
  margin: 4px 0 0 !important;
}

.sf-quote-form .elementor-field-type-acceptance .elementor-field-option label {
  display: block !important;
  min-height: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  font-family: "Inter", "Poppins", sans-serif;
  font-size: 12px;
  line-height: 1.55;
  font-weight: 500;
  color: rgba(0,0,0,0.62);
}

.sf-quote-form .elementor-field-type-acceptance a {
  color: #151515;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 3px;
}


.sf-quote-form .elementor-field-type-submit {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
  margin: 0 !important;
  padding: 0 !important;
}

.sf-quote-form .elementor-field-type-html {
  width: 100% !important;
  flex-basis: 100% !important;
}

.sf-quote-submit-row {
  display: flex !important;
  justify-content: center !important;
  width: 100% !important;
  margin-top: 10px;
}

.sf-quote-submit-row .sf-cta-wrap {
  width: auto !important;
  max-width: max-content !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.sf-quote-submit-row .sf-cta {
  width: auto !important;
}




@media (max-width: 1024px) {
  .sf-quote-section {
    padding: 78px 20px 92px;
  }

  .sf-quote-inner {
    width: min(94vw, 920px);
  }

  .sf-quote-layout {
    grid-template-columns: 1fr;
    gap: 26px;
    margin-top: 42px;
  }

  .sf-quote-copy {
    padding: 40px;
  }

  .sf-quote-copy h3 {
    font-size: 38px;
  }

  .sf-quote-card {
    padding: 36px;
  }
}

@media (max-width: 767px) {
  .sf-quote-section {
    padding: 64px 18px 78px;
  }

  .sf-quote-inner {
    width: 100%;
  }

  .sf-quote-layout {
    margin-top: 34px;
    gap: 20px;
  }

  .sf-quote-copy {
    padding: 30px 24px 34px;
    border-radius: 20px;
  }

  .sf-quote-copy::after {
    left: 24px;
    right: 24px;
  }

  .sf-quote-copy h3 {
    font-size: 31px;
  }

  .sf-quote-copy p {
    font-size: 15px;
  }

  .sf-quote-card {
    padding: 24px;
    border-radius: 20px;
  }

  .sf-quote-form .elementor-field-group {
    width: 100% !important;
  }

  .sf-quote-form .elementor-field-option label {
    font-size: 13px;
    min-height: 40px;
  }
  
    .sf-quote-logo-link {
    width: 190px;
    margin: 0 auto 24px;
  }



}

.elementor-element-1b8b2e39 .sf-quote-submit-row {
  width: 100% !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  margin: 28px 0 0 !important;
}

.elementor-element-1b8b2e39 .sf-quote-submit-row .sf-cta-wrap {
  width: fit-content !important;
  padding: 10px 14px !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.72) !important;
  border: 1px solid rgba(0, 0, 0, 0.08) !important;
  box-shadow:
    0 12px 35px rgba(0, 0, 0, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.9) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
}

.elementor-element-1b8b2e39 .sf-quote-submit-row .sf-cta {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 54px !important;
  padding: 0 10px !important;
  text-decoration: none !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  overflow: visible !important;
  cursor: pointer !important;
}

.elementor-element-1b8b2e39 .sf-quote-submit-row .sf-cta span {
  position: relative !important;
  z-index: 1 !important;
  display: inline-block !important;
  font-family: "Poppins", sans-serif !important;
  font-size: 19px !important;
  font-weight: 800 !important;
  line-height: 1.1 !important;
  color: #151515 !important;
  text-shadow: none !important;
  transition: opacity 0.25s ease !important;
}

.elementor-element-1b8b2e39 .sf-quote-submit-row .sf-cta::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Poppins", sans-serif;
  font-size: 19px;
  font-weight: 800;
  line-height: 1.1;
  white-space: nowrap;

  background: linear-gradient(
    90deg,
    #29c8ff 0%,
    #3b39ff 18%,
    #d93bdb 36%,
    #ffd400 58%,
    #9be400 78%,
    #21cdb8 100%
  );
  background-size: 25% 100%;
  background-position: 100% 50%;

  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;

  opacity: 0;
  transition: opacity 0.25s ease;
}

.elementor-element-1b8b2e39 .sf-quote-submit-row .sf-cta:hover span {
  opacity: 0 !important;
}

.elementor-element-1b8b2e39 .sf-quote-submit-row .sf-cta:hover::after {
  opacity: 1 !important;
  animation: sfQuoteTextFlow 1.6s linear infinite;
}

.elementor-element-1b8b2e39 .sf-quote-submit-row .sf-cta-wrap:hover {
  box-shadow:
    0 16px 45px rgba(0, 0, 0, 0.12),
    0 0 35px rgba(41, 200, 255, 0.10),
    inset 0 1px 0 rgba(255, 255, 255, 1) !important;
}

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

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

@media (max-width: 767px) {
  .elementor-element-1b8b2e39 .sf-quote-submit-row .sf-cta {
    min-height: 46px !important;
  }

  .elementor-element-1b8b2e39 .sf-quote-submit-row .sf-cta span,
  .elementor-element-1b8b2e39 .sf-quote-submit-row .sf-cta::after {
    font-size: 14px !important;
    white-space: nowrap !important;
  }
}

/* Source: storyframe-audit/elementor/templates/2281.json | element: 17027ab2 */
.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;
  }
}

/* Intro video/title restoration without Elementor Pro */
.sf-section-tight .hero-video {
  position: relative !important;
  width: 100vw !important;
  max-width: none !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  min-height: clamp(480px, 36vw, 690px) !important;
  overflow: hidden !important;
  --sf-intro-video-height: clamp(480px, 36vw, 690px);
}

.sf-section-tight .hero-video .e-youtube-base,
.sf-section-tight .hero-video iframe {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  height: 100% !important;
  min-height: inherit !important;
}

.sf-section-tight .hero-video .e-youtube-base {
  position: absolute !important;
  inset: 0 !important;
  overflow: hidden !important;
}

.sf-section-tight .hero-video iframe {
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  width: max(100vw, calc(var(--sf-intro-video-height, 690px) * 1.7778)) !important;
  min-width: 100vw !important;
  height: max(100%, calc(100vw * 0.5625)) !important;
  min-height: 100% !important;
  transform: translate(-50%, -50%) !important;
}

.sf-section-tight .hero-video > .sf-video-wrap.elementor-widget-html {
  position: absolute !important;
  inset: 0 auto auto 0 !important;
  z-index: 10 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  pointer-events: none;
}

.sf-section-tight .hero-video .sf-simple-title {
  position: absolute;
  left: 50px;
  bottom: -20px;
  z-index: 10;
  line-height: 1.5;
  pointer-events: none;
}

.sf-section-tight .hero-video .sf-simple-title .sf-line {
  display: block;
  width: fit-content;
  max-width: 100%;
  position: relative;
  background: #ffffff;
  color: #222222 !important;
  padding: 14px 18px 18px 18px;
  margin: 0;
  font-weight: 800;
  font-size: 2rem;
  overflow: visible;
}

.sf-section-tight .hero-video .sf-simple-title .sf-line + .sf-line {
  margin-top: -4px;
}

.sf-section-tight .hero-video .sf-simple-title .sf-line::after {
  content: "";
  position: absolute;
  left: 18px;
  bottom: 10px;
  height: 10px;
  z-index: 2;
}

.sf-section-tight .hero-video .sf-simple-title .sf-line-1::after {
  width: calc(100% - 30px);
  background: linear-gradient(
    to right,
    #18bdf2 0%,
    #18bdf2 33%,
    #2a1fd6 33%,
    #2a1fd6 66%,
    #d63ac7 66%,
    #d63ac7 100%
  );
}

.sf-section-tight .hero-video .sf-simple-title .sf-line-2::after {
  width: calc(100% - 30px);
  background: linear-gradient(
    to right,
    #f3c400 0%,
    #f3c400 33%,
    #97d700 33%,
    #97d700 66%,
    #3fd05f 66%,
    #10b7a7 100%
  );
}

@media (max-width: 1024px) {
  .sf-section-tight .hero-video {
    min-height: clamp(410px, 50vw, 560px) !important;
  }

  .sf-section-tight .hero-video iframe {
    width: max(100vw, 996px) !important;
    height: max(100%, 56.25vw) !important;
  }

  .sf-section-tight .hero-video .sf-simple-title {
    left: 32px;
    bottom: -18px;
  }

  .sf-section-tight .hero-video .sf-simple-title .sf-line {
    font-size: 1.6rem;
    padding: 12px 16px 16px 16px;
  }

  .sf-section-tight .hero-video .sf-simple-title .sf-line::after {
    left: 16px;
    bottom: 9px;
    height: 9px;
  }

  .sf-section-tight .hero-video .sf-simple-title .sf-line-1::after,
  .sf-section-tight .hero-video .sf-simple-title .sf-line-2::after {
    width: calc(100% - 28px);
  }
}

@media (max-width: 767px) {
  .sf-section-tight .hero-video {
    min-height: 320px !important;
  }

  .sf-section-tight .hero-video iframe {
    width: max(100vw, 570px) !important;
    height: max(100%, 56.25vw) !important;
  }

  .sf-section-tight .hero-video .sf-simple-title {
    left: 21px;
    right: 18px;
    bottom: 13px;
  }

  .sf-section-tight .hero-video .sf-simple-title .sf-line {
    font-size: 0.8rem;
    padding: 10px 12px 14px 13px;
    max-width: fit-content;
  }

  .sf-section-tight .hero-video .sf-simple-title .sf-line + .sf-line {
    margin-top: -3px;
  }

  .sf-section-tight .hero-video .sf-simple-title .sf-line::after {
    left: 13px;
    bottom: 8px;
    height: 7px;
  }

  .sf-section-tight .hero-video .sf-simple-title .sf-line-1::after,
  .sf-section-tight .hero-video .sf-simple-title .sf-line-2::after {
    width: calc(100% - 24px);
  }
}

@media (max-width: 340px) {
  .sf-section-tight .hero-video .sf-simple-title {
    left: 16px;
    right: 16px;
    bottom: 12px;
    max-width: calc(100% - 32px);
  }

  .sf-section-tight .hero-video .sf-simple-title .sf-line {
    white-space: nowrap;
    max-width: none;
    font-size: 0.66rem;
    line-height: 1.15;
    padding: 8px 10px 12px 10px;
  }

  .sf-section-tight .hero-video .sf-simple-title .sf-line-1 {
    font-size: 0.59rem;
  }

  .sf-section-tight .hero-video .sf-simple-title .sf-line + .sf-line {
    margin-top: -2px;
  }

  .sf-section-tight .hero-video .sf-simple-title .sf-line::after {
    left: 10px;
    bottom: 7px;
    height: 5px;
    width: calc(100% - 20px);
  }

  .sf-section-tight .hero-video .sf-simple-title .sf-line-1::after,
  .sf-section-tight .hero-video .sf-simple-title .sf-line-2::after {
    width: calc(100% - 20px);
  }
}

/* Stable final intro override: cover-cropped YouTube + pseudo title strips */
.sf-section-tight .hero-video {
  position: relative !important;
  width: 100vw !important;
  max-width: none !important;
  min-height: clamp(500px, 36vw, 690px) !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  overflow: hidden !important;
  background: #000 !important;
}

.sf-section-tight .hero-video > .sf-video-wrap.elementor-widget-html {
  display: none !important;
}

.sf-section-tight .hero-video .e-youtube-base {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  overflow: hidden !important;
}

.sf-section-tight .hero-video .e-youtube-base iframe {
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  width: 100vw !important;
  min-width: 100% !important;
  height: 56.25vw !important;
  min-height: 100% !important;
  max-width: none !important;
  transform: translate(-50%, -50%) !important;
}

.sf-section-tight .hero-video::before,
.sf-section-tight .hero-video::after {
  position: absolute;
  left: 92px;
  z-index: 20;
  display: block;
  width: max-content;
  max-width: calc(100vw - 184px);
  color: #222222;
  font-family: "Poppins", sans-serif;
  font-size: 2rem;
  font-weight: 800;
  line-height: 1.15;
  white-space: nowrap;
  pointer-events: none;
}

.sf-section-tight .hero-video::before {
  content: "Céges rendezvények és image filmek";
  bottom: 96px;
  padding: 14px 18px 18px 18px;
  background:
    linear-gradient(to right, #18bdf2 0%, #18bdf2 33%, #2a1fd6 33%, #2a1fd6 66%, #d63ac7 66%, #d63ac7 100%) 18px calc(100% - 10px) / calc(100% - 30px) 10px no-repeat,
    #ffffff;
}

.sf-section-tight .hero-video::after {
  content: "Profi fotó- és videókészítés";
  bottom: 18px;
  padding: 14px 18px 18px 18px;
  background:
    linear-gradient(to right, #f3c400 0%, #f3c400 33%, #97d700 33%, #97d700 66%, #3fd05f 66%, #10b7a7 100%) 18px calc(100% - 10px) / calc(100% - 30px) 10px no-repeat,
    #ffffff;
}

@media (max-width: 1024px) {
  .sf-section-tight .hero-video {
    min-height: clamp(430px, 50vw, 560px) !important;
  }

  .sf-section-tight .hero-video::before,
  .sf-section-tight .hero-video::after {
    left: 48px;
    max-width: calc(100vw - 96px);
    font-size: 1.6rem;
  }

  .sf-section-tight .hero-video::before {
    bottom: 82px;
    padding: 12px 16px 16px 16px;
    background:
      linear-gradient(to right, #18bdf2 0%, #18bdf2 33%, #2a1fd6 33%, #2a1fd6 66%, #d63ac7 66%, #d63ac7 100%) 16px calc(100% - 9px) / calc(100% - 28px) 9px no-repeat,
      #ffffff;
  }

  .sf-section-tight .hero-video::after {
    bottom: 16px;
    padding: 12px 16px 16px 16px;
    background:
      linear-gradient(to right, #f3c400 0%, #f3c400 33%, #97d700 33%, #97d700 66%, #3fd05f 66%, #10b7a7 100%) 16px calc(100% - 9px) / calc(100% - 28px) 9px no-repeat,
      #ffffff;
  }
}

@media (max-width: 767px) {
  .sf-section-tight .hero-video {
    min-height: 320px !important;
  }

  .sf-section-tight .hero-video .e-youtube-base iframe {
    width: 178% !important;
    min-width: 178% !important;
    height: 100% !important;
    min-height: 100% !important;
  }

  .sf-section-tight .hero-video::before,
  .sf-section-tight .hero-video::after {
    left: 21px;
    max-width: calc(100vw - 42px);
    font-size: 0.8rem;
  }

  .sf-section-tight .hero-video::before {
    bottom: 54px;
    padding: 10px 12px 14px 13px;
    background:
      linear-gradient(to right, #18bdf2 0%, #18bdf2 33%, #2a1fd6 33%, #2a1fd6 66%, #d63ac7 66%, #d63ac7 100%) 13px calc(100% - 8px) / calc(100% - 24px) 7px no-repeat,
      #ffffff;
  }

  .sf-section-tight .hero-video::after {
    bottom: 13px;
    padding: 10px 12px 14px 13px;
    background:
      linear-gradient(to right, #f3c400 0%, #f3c400 33%, #97d700 33%, #97d700 66%, #3fd05f 66%, #10b7a7 100%) 13px calc(100% - 8px) / calc(100% - 24px) 7px no-repeat,
      #ffffff;
  }
}

@media (max-width: 340px) {
  .sf-section-tight .hero-video::before,
  .sf-section-tight .hero-video::after {
    left: 16px;
    max-width: calc(100vw - 32px);
    font-size: 0.66rem;
    line-height: 1.15;
  }

  .sf-section-tight .hero-video::before {
    font-size: 0.59rem;
    bottom: 45px;
    padding: 8px 10px 12px 10px;
    background:
      linear-gradient(to right, #18bdf2 0%, #18bdf2 33%, #2a1fd6 33%, #2a1fd6 66%, #d63ac7 66%, #d63ac7 100%) 10px calc(100% - 7px) / calc(100% - 20px) 5px no-repeat,
      #ffffff;
  }

  .sf-section-tight .hero-video::after {
    bottom: 12px;
    padding: 8px 10px 12px 10px;
    background:
      linear-gradient(to right, #f3c400 0%, #f3c400 33%, #97d700 33%, #97d700 66%, #3fd05f 66%, #10b7a7 100%) 10px calc(100% - 7px) / calc(100% - 20px) 5px no-repeat,
      #ffffff;
  }
}



@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;

}}

/* Source: storyframe-audit/elementor/templates/22.json | element: 1d178f3c */
.elementor-element-1d178f3c .elementor-nav-menu--main .sub-menu {
  background: #050505 !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  border-radius: 0 0 16px 16px !important;
  padding: 14px 0 !important;
  min-width: 250px !important;
  box-shadow: 0 24px 70px rgba(0,0,0,0.28) !important;
}

.elementor-element-1d178f3c .elementor-nav-menu--main .sub-menu li {
  background: transparent !important;
}

.elementor-element-1d178f3c .elementor-nav-menu--main .sub-menu a {
  display: block !important;
  padding: 14px 22px !important;
  background: transparent !important;
  color: rgba(255,255,255,0.82) !important;
  font-family: "Inter", "Poppins", sans-serif !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  letter-spacing: 0.04em !important;
  line-height: 1.2 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}

.elementor-element-1d178f3c .elementor-nav-menu--main .sub-menu a:hover {
  color: #ffffff !important;
  background: rgba(255,255,255,0.07) !important;
  text-shadow: 0 0 16px rgba(217,59,219,0.55);
}

.elementor-element-1d178f3c .elementor-nav-menu--dropdown {
  background: #050505 !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
}

.elementor-element-1d178f3c .elementor-nav-menu--dropdown a {
  background: transparent !important;
  color: rgba(255,255,255,0.86) !important;
  font-family: "Inter", "Poppins", sans-serif !important;
  font-weight: 800 !important;
  letter-spacing: 0.04em !important;
}

.elementor-element-1d178f3c .elementor-nav-menu--dropdown a:hover {
  color: #ffffff !important;
  background: rgba(255,255,255,0.07) !important;
}

@media (min-width: 1025px) {
  .elementor-element-1d178f3c .elementor-nav-menu--main .sub-menu a {
    font-family: "Poppins", "Inter", sans-serif !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    letter-spacing: 0.12em !important;
    text-transform: uppercase !important;
    line-height: 1.2 !important;
    color: rgba(255,255,255,0.86) !important;
    background: transparent !important;
  }

  .elementor-element-1d178f3c .elementor-nav-menu--main .sub-menu a:hover {
    color: #ffffff !important;
    background: rgba(255,255,255,0.07) !important;
    text-shadow: 0 0 16px rgba(217,59,219,0.55);
  }
}

@media (min-width: 1025px) and (max-width: 1330px) {
  .elementor-element-1d178f3c .elementor-nav-menu--main .elementor-nav-menu {
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0 !important;
  }

  .elementor-element-1d178f3c .elementor-nav-menu--main .elementor-nav-menu > li {
    flex: 0 0 auto !important;
    white-space: nowrap !important;
  }

  .elementor-element-1d178f3c .elementor-nav-menu--main .elementor-nav-menu > li > a {
    white-space: nowrap !important;
    padding-left: 13px !important;
    padding-right: 13px !important;
    font-size: 12px !important;
    letter-spacing: 0.11em !important;
    line-height: 1 !important;
  }

  .elementor-element-1d178f3c .elementor-nav-menu--main .elementor-nav-menu > li > a .sub-arrow {
    margin-left: 6px !important;
    padding: 0 !important;
  }
}

/* Source: storyframe-audit/elementor/templates/22.json | element: 3ac7efcf */
.sf-menu-cta {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 18px;
  min-height: 54px;
  padding: 0 26px;
  border-radius: 999px;
  background: black;
  text-decoration: none;
  overflow: hidden;
}

.sf-menu-cta span {
  position: relative;
  z-index: 2;
  font-size: 22px;
  font-weight: 800;
  line-height: 1;
  color: #ffffff;
  white-space: nowrap;
  transition: opacity 0.25s ease;
}

.sf-menu-cta::after {
  content: attr(data-text);
  position: absolute;
  left: 26px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 22px;
  font-weight: 800;
  white-space: nowrap;

  background: linear-gradient(
    90deg,
    #29c8ff 0%,
    #3b39ff 18%,
    #d93bdb 36%,
    #ffd400 58%,
    #9be400 78%,
    #21cdb8 100%
  );
  background-size: 300% 100%;
  background-position: 100% 50%;

  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;

  opacity: 0;
  transition: opacity 0.25s ease;
}

.sf-menu-cta:hover span:first-child {
  opacity: 0;
}

.sf-menu-cta:hover::after {
  opacity: 1;
  animation: sfTextFlow 1.15s linear infinite;
}

.sf-menu-arrow {
  font-size: 42px !important;
  font-weight: 300 !important;
  line-height: 1 !important;
  color: #ffffff !important;
  opacity: 1 !important;
  transform: translateY(-1px);
}

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

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

.sf-menu-arrow {
  transition: transform 0.25s ease;
}

.sf-menu-cta:hover .sf-menu-arrow {
  transform: scale(1.2) translateX(4px);
}

/* Proless native header/footer shell */
body:not(.elementor-editor-active) > .site-header,
body:not(.elementor-editor-active) > .site-footer {
  display: none !important;
}

.sf-proless-header {
  position: relative;
  z-index: 1000;
  display: grid;
  grid-template-columns: 170px minmax(0, 1fr) auto;
  align-items: center;
  gap: 26px;
  min-height: 120px;
  padding: 0 24px;
  background: #000;
  color: #fff;
}

.sf-proless-header__logo {
  display: inline-flex;
  width: 140px;
  height: 98px;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}

.sf-proless-header__logo img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.sf-proless-header__nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(34px, 4.4vw, 70px);
}

.sf-proless-header__link,
.sf-proless-header__submenu a {
  font-family: "Poppins", "Inter", sans-serif;
  text-decoration: none;
}

.sf-proless-header__link {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 54px;
  color: #fff;
  font-size: clamp(14px, 1.03vw, 18px);
  font-weight: 800;
  letter-spacing: 0.2em;
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
}

.sf-proless-header__link::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 7px;
  height: 2px;
  background: linear-gradient(90deg, #29c8ff, #3b39ff, #d93bdb, #ffd400, #21cdb8);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 0.25s ease;
}

.sf-proless-header__link:hover {
  color: #fff;
}

.sf-proless-header__link:hover::after {
  transform: scaleX(1);
}

.sf-proless-header__dropdown {
  position: relative;
}

.sf-proless-header__submenu {
  position: absolute;
  left: 0;
  top: calc(100% - 4px);
  min-width: 260px;
  padding: 12px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 0;
  background: #000;
  box-shadow: 0 20px 45px rgba(0, 0, 0, 0.26);
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
}

.sf-proless-header__dropdown:hover .sf-proless-header__submenu,
.sf-proless-header__dropdown:focus-within .sf-proless-header__submenu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.sf-proless-header__submenu a {
  display: block;
  padding: 13px 14px;
  color: #fff;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.04em;
}

.sf-proless-header__submenu a:hover {
  color: #000;
  background: #fff;
}

.sf-proless-header__cta {
  justify-self: end;
  min-width: 300px;
  padding-left: 26px;
  padding-right: 10px;
}

.sf-proless-header__cta span {
  font-size: 20px;
}

.sf-proless-header__toggle {
  display: none;
  width: 46px;
  height: 46px;
  align-items: center;
  justify-content: center;
  gap: 5px;
  flex-direction: column;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  background: transparent;
  color: #fff;
}

.sf-proless-header__toggle span {
  display: block;
  width: 20px;
  height: 2px;
  background: currentColor;
}

.sf-proless-footer {
  display: block;
  width: 100%;
  background: #000 !important;
  color: #fff !important;
}

.sf-proless-footer *,
.sf-proless-footer a,
.sf-proless-footer p,
.sf-proless-footer h2,
.sf-proless-footer h3,
.sf-proless-footer span {
  color: #fff !important;
}

.sf-proless-footer .sf-footer-line {
  background: linear-gradient(90deg, #29c8ff, #3b39ff, #d93bdb, #ffd400, #9be400, #21cdb8) !important;
}

@media (max-width: 1180px) {
  .sf-proless-header {
    grid-template-columns: 150px minmax(0, 1fr) auto;
    gap: 22px;
    padding: 0 22px;
  }

  .sf-proless-header__nav {
    gap: 28px;
  }

  .sf-proless-header__cta {
    min-width: 250px;
  }

  .sf-proless-header__cta span {
    font-size: 17px;
  }
}

/* Footer hover effects restored for the Proless shell */
.sf-proless-footer .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("/wp-content/uploads/2026/05/StoryFrame_logo_fekete-feher.webp");
  mask-image: url("/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-proless-footer .sf-footer-logo-link:hover::after {
  opacity: 0.95;
  animation: sfFooterLogoFlow 1.1s linear infinite;
}

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

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

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

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

.sf-proless-footer .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 sfFooterLogoFlow {
  0% {
    background-position: 100% 50%;
  }

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

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

  20% {
    fill: #3b39ff;
  }

  40% {
    fill: #d93bdb;
  }

  60% {
    fill: #ffd400;
  }

  80% {
    fill: #9be400;
  }

  100% {
    fill: #21cdb8;
  }
}

@media (max-width: 1024px) {
  .sf-proless-header {
    grid-template-columns: auto 1fr auto;
    min-height: 92px;
  }

  .sf-proless-header__logo {
    width: 110px;
    height: 78px;
  }

  .sf-proless-header__toggle {
    display: inline-flex;
    grid-column: 3;
  }

  .sf-proless-header__nav,
  .sf-proless-header__cta {
    display: none !important;
  }

  .sf-proless-header.is-open .sf-proless-header__nav {
    position: absolute;
    left: 0;
    right: 0;
    top: 92px;
    display: flex !important;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 0;
    padding: 16px 24px 24px;
    background: #000;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
  }

  .sf-proless-header__link {
    min-height: 48px;
    font-size: 16px;
  }

  .sf-proless-header__dropdown {
    display: block;
  }

  .sf-proless-header__submenu {
    position: static;
    min-width: 0;
    padding: 0 0 8px 16px;
    border: 0;
    box-shadow: none;
    opacity: 1;
    visibility: visible;
    transform: none;
  }
}

@media (max-width: 767px) {
  .sf-proless-header {
    min-height: 82px;
    padding: 0 16px;
  }

  .sf-proless-header__logo {
    width: 92px;
    height: 66px;
  }

  .sf-proless-header.is-open .sf-proless-header__nav {
    top: 82px;
  }
}

/* Proless intro video: final tweakable overlay controls.
   Override these custom properties from Appearance > Customize > Additional CSS. */
.sf-section-tight .hero-video {
  --sf-intro-title-left: 92px;
  --sf-intro-title-bottom: 18px;
  --sf-intro-title-gap: -4px;
  --sf-intro-title-font: 2rem;
  --sf-intro-title-pad-top: 14px;
  --sf-intro-title-pad-x: 18px;
  --sf-intro-title-pad-bottom: 18px;
  --sf-intro-stripe-h: 10px;
  --sf-intro-stripe-bottom: 10px;
  --sf-intro-video-height: clamp(500px, 36vw, 690px);
  position: relative !important;
  min-height: var(--sf-intro-video-height) !important;
  overflow: hidden !important;
  background: #000 !important;
}

.sf-section-tight .hero-video::before,
.sf-section-tight .hero-video::after {
  content: none !important;
  display: none !important;
}

.sf-section-tight .hero-video > .sf-video-wrap.elementor-widget-html,
.sf-section-tight .hero-video .sf-simple-title {
  display: none !important;
}

.sf-section-tight .hero-video .e-youtube-base {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  overflow: hidden !important;
}

.sf-section-tight .hero-video .e-youtube-base iframe {
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  width: 100vw !important;
  height: 56.25vw !important;
  min-width: 100% !important;
  min-height: 100% !important;
  max-width: none !important;
  transform: translate(-50%, -50%) !important;
}

.sf-proless-intro-title {
  position: absolute;
  left: var(--sf-intro-title-left);
  bottom: var(--sf-intro-title-bottom);
  z-index: 30;
  line-height: 1.5;
  pointer-events: none;
}

.sf-proless-intro-title .sf-line {
  position: relative;
  display: block;
  width: fit-content;
  max-width: calc(100vw - (var(--sf-intro-title-left) * 2));
  margin: 0;
  padding: var(--sf-intro-title-pad-top) var(--sf-intro-title-pad-x) var(--sf-intro-title-pad-bottom);
  background: #fff;
  color: #222 !important;
  font-family: "Poppins", sans-serif;
  font-size: var(--sf-intro-title-font);
  font-weight: 800;
  line-height: 1.15;
  white-space: nowrap;
}

.sf-proless-intro-title .sf-line + .sf-line {
  margin-top: var(--sf-intro-title-gap);
}

.sf-proless-intro-title .sf-line::after {
  content: "";
  position: absolute;
  left: var(--sf-intro-title-pad-x);
  bottom: var(--sf-intro-stripe-bottom);
  width: calc(100% - (var(--sf-intro-title-pad-x) * 2));
  height: var(--sf-intro-stripe-h);
}

.sf-proless-intro-title .sf-line-1::after {
  background: linear-gradient(
    to right,
    #18bdf2 0%,
    #18bdf2 33%,
    #2a1fd6 33%,
    #2a1fd6 66%,
    #d63ac7 66%,
    #d63ac7 100%
  );
}

.sf-proless-intro-title .sf-line-2::after {
  background: linear-gradient(
    to right,
    #f3c400 0%,
    #f3c400 33%,
    #97d700 33%,
    #97d700 66%,
    #3fd05f 66%,
    #10b7a7 100%
  );
}

@media (max-width: 1024px) {
  .sf-section-tight .hero-video {
    --sf-intro-title-left: 48px;
    --sf-intro-title-bottom: 16px;
    --sf-intro-title-font: 1.6rem;
    --sf-intro-title-pad-top: 12px;
    --sf-intro-title-pad-x: 16px;
    --sf-intro-title-pad-bottom: 16px;
    --sf-intro-stripe-h: 9px;
    --sf-intro-stripe-bottom: 9px;
    --sf-intro-video-height: clamp(430px, 50vw, 560px);
  }
}

@media (max-width: 767px) {
  .sf-section-tight .hero-video {
    --sf-intro-title-left: 21px;
    --sf-intro-title-bottom: 13px;
    --sf-intro-title-gap: -3px;
    --sf-intro-title-font: 0.8rem;
    --sf-intro-title-pad-top: 10px;
    --sf-intro-title-pad-x: 13px;
    --sf-intro-title-pad-bottom: 14px;
    --sf-intro-stripe-h: 7px;
    --sf-intro-stripe-bottom: 8px;
    --sf-intro-video-height: 320px;
  }

  .sf-section-tight .hero-video .e-youtube-base iframe {
    width: 178% !important;
    min-width: 178% !important;
    height: 100% !important;
    min-height: 100% !important;
  }

  .sf-proless-intro-title .sf-line {
    max-width: calc(100vw - 42px);
  }
}

@media (max-width: 340px) {
  .sf-section-tight .hero-video {
    --sf-intro-title-left: 16px;
    --sf-intro-title-bottom: 12px;
    --sf-intro-title-font: 0.66rem;
    --sf-intro-title-pad-top: 8px;
    --sf-intro-title-pad-x: 10px;
    --sf-intro-title-pad-bottom: 12px;
    --sf-intro-stripe-h: 5px;
    --sf-intro-stripe-bottom: 7px;
  }

  .sf-proless-intro-title .sf-line {
    max-width: calc(100vw - 32px);
  }

  .sf-proless-intro-title .sf-line-1 {
    font-size: 0.59rem;
  }
}
