.elementor-widget-shortcode:has(.nb-site-home),
.elementor-widget-shortcode:has(.nb-home-editorial-hero),
.elementor-widget-shortcode:has(.nb-catalog) {
  margin: 0;
}

.elementor-widget-shortcode:has(.nb-site-home) .elementor-widget-container,
.elementor-widget-shortcode:has(.nb-home-editorial-hero) .elementor-widget-container,
.elementor-widget-shortcode:has(.nb-catalog) .elementor-widget-container {
  margin: 0;
  padding: 0;
}

.elementor-section:has(.nb-site-home),
.e-con:has(.nb-site-home),
.elementor-section:has(.nb-catalog),
.e-con:has(.nb-catalog) {
  padding: 0;
}

.nb-hero-editorial {
  align-items: stretch;
  background-color: var(--nb-black);
  background-position: center;
  background-size: cover;
  color: var(--nb-white);
  display: flex;
  flex-direction: column;
  isolation: isolate;
  justify-content: flex-end;
  min-height: 100vh;
  min-height: 100svh;
  overflow: hidden;
  position: relative;
  width: 100%;
}

.elementor .nb-hero-editorial {
  align-items: stretch;
  justify-content: flex-end;
}

.nb-hero-editorial::before {
  background:
    linear-gradient(90deg, rgba(7, 7, 7, 0.42) 0%, rgba(7, 7, 7, 0.18) 42%, rgba(7, 7, 7, 0.06) 100%),
    linear-gradient(180deg, rgba(7, 7, 7, 0.22) 0%, rgba(7, 7, 7, 0.04) 42%, rgba(7, 7, 7, 0.42) 100%);
  content: "";
  inset: 0;
  pointer-events: none;
  position: absolute;
  z-index: 0;
}

.nb-hero-editorial__overlay {
  background: rgba(7, 7, 7, 0.06);
  inset: 0;
  pointer-events: none;
  position: absolute;
  z-index: 1;
}

.nb-hero-editorial__content {
  align-self: flex-end;
  background: transparent;
  color: var(--nb-white);
  margin: 0;
  max-width: 980px;
  padding: clamp(132px, 18vh, 210px) var(--nb-space-page-x) clamp(58px, 9vw, 112px);
  position: relative;
  width: 100%;
  z-index: 2;
}

.nb-hero-editorial__content > .e-con-inner {
  margin: 0;
  max-width: 760px;
  padding: 0;
}

.nb-hero-editorial__title,
.nb-hero-editorial__text,
.nb-hero-editorial__button {
  background: transparent;
  box-shadow: none;
  margin-left: 0;
  margin-right: 0;
  padding: 0;
}

.elementor .nb-hero-editorial .nb-hero-editorial__title {
  text-align: left !important;
}

.nb-hero-editorial__title .elementor-heading-title,
.nb-hero-editorial .nb-hero-editorial__title .elementor-heading-title {
  color: var(--nb-white);
  font-family: var(--nb-font-heading);
  font-size: clamp(58px, 9vw, 136px);
  font-weight: var(--nb-font-heading-weight);
  letter-spacing: 0;
  line-height: 0.94;
  margin: 0;
}

.nb-hero-editorial__text,
.nb-hero-editorial__text p,
.nb-hero-editorial .nb-hero-editorial__text p {
  color: rgba(255, 255, 255, 0.74);
  font-family: var(--nb-font-body);
  font-size: clamp(16px, 1.2vw, 19px);
  line-height: 1.7;
  max-width: 560px;
}

.nb-hero-editorial__text,
.nb-hero-editorial__text p {
  margin: 28px 0 0;
}

.nb-hero-editorial__button {
  display: block;
  line-height: 1;
  margin-top: 36px;
  width: auto;
}

.nb-hero-editorial__button .elementor-widget-container,
.nb-hero-editorial__button .elementor-button-wrapper {
  background: transparent;
  box-shadow: none;
  display: inline-flex;
  margin: 0;
  padding: 0;
  width: auto;
}

.nb-hero-editorial__button .elementor-button,
.nb-hero-editorial .nb-hero-editorial__button .elementor-button {
  align-items: center;
  background: var(--nb-white);
  border: 1px solid var(--nb-white);
  border-radius: 0;
  box-shadow: none;
  color: var(--nb-black);
  display: inline-flex;
  font-family: var(--nb-font-body);
  font-size: 11px;
  font-weight: var(--nb-font-nav-weight);
  justify-content: center;
  letter-spacing: 0.14em;
  line-height: 1;
  margin: 0;
  min-height: 46px;
  padding: 0 22px;
  text-decoration: none;
  text-transform: uppercase;
  width: auto;
}

.nb-hero-editorial__button .elementor-button-content-wrapper,
.nb-hero-editorial__button .elementor-button-text {
  align-items: center;
  background: transparent;
  color: inherit;
  display: inline-flex;
  line-height: 1;
}

.nb-hero-editorial__button .elementor-button:hover,
.nb-hero-editorial__button .elementor-button:focus {
  background: var(--nb-white);
  color: var(--nb-black);
  opacity: 0.82;
}

@media (min-width: 922px) {
  body.home .elementor .elementor-element.nb-hero-editorial:not(.elementor-motion-effects-element-type-background),
  body.home .elementor .elementor-element.nb-hero-editorial > .elementor-motion-effects-container > .elementor-motion-effects-layer {
    background-attachment: fixed;
    background-position: center center;
    background-size: cover;
  }

  .nb-hero-editorial__content {
    padding-top: clamp(72px, 10vh, 132px);
  }
}

@media (min-width: 1024px) {
  body.home .nb-hero-editorial__content {
    position: static;
  }

  body.home .nb-hero-editorial__text {
    bottom: clamp(130px, 17vh, 190px);
    left: clamp(280px, 17vw, 360px);
    margin: 0;
    max-width: 520px;
    position: absolute;
    right: auto;
    top: auto;
    width: auto;
    z-index: 3;
  }

  body.home .nb-hero-editorial__text p {
    margin: 0;
  }

  body.home .nb-hero-editorial__button {
    bottom: clamp(64px, 9vh, 104px);
    left: clamp(280px, 17vw, 360px);
    margin: 0;
    position: absolute;
    right: auto;
    top: auto;
    width: auto;
    z-index: 3;
  }
}

@media (max-width: 921px) {
  .elementor .elementor-element.nb-hero-editorial:not(.elementor-motion-effects-element-type-background),
  .elementor .elementor-element.nb-hero-editorial > .elementor-motion-effects-container > .elementor-motion-effects-layer {
    background-attachment: scroll;
    background-position: 58% center;
    background-size: cover;
  }

  .nb-hero-editorial {
    min-height: 100svh;
  }

  .nb-hero-editorial::before {
    background:
      linear-gradient(180deg, rgba(7, 7, 7, 0.22) 0%, rgba(7, 7, 7, 0.04) 34%, rgba(7, 7, 7, 0.42) 100%),
      linear-gradient(90deg, rgba(7, 7, 7, 0.24) 0%, rgba(7, 7, 7, 0.06) 100%);
  }

  .nb-hero-editorial__overlay {
    background: rgba(7, 7, 7, 0.04);
  }

  .nb-hero-editorial__content {
    align-self: stretch;
    align-items: flex-start !important;
    display: flex !important;
    flex-direction: column;
    justify-content: flex-end;
    max-width: none;
    padding: 136px 22px 54px;
    text-align: left;
  }

  .nb-hero-editorial__content > .e-con-inner {
    align-items: flex-start;
    margin-left: 0;
    margin-right: 0;
    max-width: min(100%, 560px);
  }

  .nb-hero-editorial__title,
  .nb-hero-editorial__text,
  .nb-hero-editorial__button {
    align-self: flex-start;
    max-width: min(100%, 560px);
    text-align: left;
    width: 100%;
  }

  .nb-hero-editorial__title .elementor-heading-title {
    font-size: clamp(48px, 13vw, 86px);
    line-height: 0.98;
    max-width: 100%;
  }

  .nb-hero-editorial__text,
  .nb-hero-editorial__text p {
    color: var(--nb-white);
    font-size: clamp(14px, 4vw, 17px);
    line-height: 1.55;
    margin-top: 22px;
    max-width: 320px;
  }

  .nb-hero-editorial__button {
    margin-top: 28px;
  }
}

@media (max-width: 544px) {
  .elementor .elementor-element.nb-hero-editorial:not(.elementor-motion-effects-element-type-background),
  .elementor .elementor-element.nb-hero-editorial > .elementor-motion-effects-container > .elementor-motion-effects-layer {
    background-position: 60% center;
  }

  .nb-hero-editorial {
    min-height: 100svh;
  }

  .nb-hero-editorial__content {
    padding: 126px 20px 42px;
  }

  .nb-hero-editorial__title,
  .nb-hero-editorial__text,
  .nb-hero-editorial__button {
    max-width: calc(100vw - 40px);
  }

  .nb-hero-editorial__title {
    left: auto !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    right: auto !important;
    transform: none !important;
    width: calc(100vw - 40px) !important;
  }

  .nb-hero-editorial__title .elementor-heading-title {
    display: block;
    font-size: clamp(25px, 6.5vw, 28px) !important;
    max-width: calc(100vw - 40px);
    overflow-wrap: anywhere !important;
    white-space: normal !important;
    width: 100% !important;
    word-break: normal !important;
  }

  .nb-hero-editorial__button .elementor-button {
    max-width: 100%;
    min-height: 44px;
    padding-left: 18px;
    padding-right: 18px;
  }
}

@media (max-width: 390px) {
  .nb-hero-editorial__title .elementor-heading-title {
    font-size: clamp(24px, 6.4vw, 26px) !important;
  }

  .nb-hero-editorial__text,
  .nb-hero-editorial__text p {
    max-width: 300px;
  }
}
