@font-face {
    font-family: 'Bender';
    src: url('/wp-content/themes/lmf/assets/fonts/jovanny_lemonad_-_bender-black-webfont.woff2') format('woff2'),
         url('/wp-content/themes/lmf/assets/fonts/jovanny_lemonad_-_bender-black-webfont.woff') format('woff');
    font-weight: 900;
    font-style: normal;

}

@font-face {
    font-family: 'Bender';
    src: url('/wp-content/themes/lmf/assets/fonts/jovanny_lemonad_-_bender-bold-webfont.woff2') format('woff2'),
         url('/wp-content/themes/lmf/assets/fonts/jovanny_lemonad_-_bender-bold-webfont.woff') format('woff');
    font-weight: 600;
    font-style: normal;

}

@font-face {
    font-family: 'Bender';
    src: url('/wp-content/themes/lmf/assets/fonts/jovanny_lemonad_-_bender-light-webfont.woff2') format('woff2'),
         url('/wp-content/themes/lmf/assets/fonts/jovanny_lemonad_-_bender-light-webfont.woff') format('woff');
    font-weight: 200;
    font-style: normal;

}

@font-face {
    font-family: 'Bender';
    src: url('/wp-content/themes/lmf/assets/fonts/jovanny_lemonad_-_bender-webfont.woff2') format('woff2'),
         url('/wp-content/themes/lmf/assets/fonts/jovanny_lemonad_-_bender-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;

}

html,
body {
    font-family: "Inter", sans-serif;
    box-sizing: border-box;
    background: #6F6F6F;
    color: #000;
    z-index: 1;
    overflow-x: hidden;
}

*,
*:after,
*:before {
    box-sizing: border-box;
    outline: none;
    color: #000;
    text-rendering: optimizeLegibility ;
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

* {
    scroll-margin-top: 100px;
    font-family: "Inter", sans-serif;
}

video::-webkit-media-controls,
video::-webkit-media-controls-start-playback-button{
  display:none !important;
  -webkit-appearance:none;
}

body.woocommerce {
    margin-bottom: 0 !important;
    margin-top: 0 !important;
}

body {
    position: relative;
    background:  #fff;   
    color: #000;
    width: 100%;
    margin: 0;
    padding: 60px 0 0 0;
    overflow-x: hidden;
    z-index:  1;
}

.no-scroll {
    overflow: hidden !important;
}

a {
    text-decoration: none;
}

.btn {
    transition: 300ms;
}

b,
strong {
    font-weight: 600 !important;
}

i {
    font-style: italic !important;
}

.loader {
    display: none;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.6);
    z-index: 9999;
}

.loader svg {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 50px;
    height: 50px;
}

.flex-container {
    display: flex;
    display: -ms-flexbox;
    -ms-flex-align: stretch;
    align-items: stretch;
    -ms-flex-pack: center;
    justify-content: center;
}

.flex-container.align-center {
    -ms-flex-align: center;
    align-items: center;
}

.flex-container.wrap {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.flex-container.no-center {
    -ms-flex-pack: start;
    justify-content: flex-start;
}

.flex-container>.half {
    width: 50%;
}

[data-fancybox] {
    cursor: pointer;
}

.container {
    padding:  0 40px;
    width:  100%;
    max-width:  1440px;
    margin:  0 auto;
}

.fancybox-button svg path {
	fill: #fff !important;
}

#breadcrumbs {
    margin: 40px auto;
}

#breadcrumbs>span {
    display: flex;
    align-items: center;
    gap:16px;
}

#breadcrumbs>span span:not(.breadcrumb_last),
#breadcrumbs>span span:not(.breadcrumb_last) a {
    color: #757575;
    font-family: "Space Grotesk";
    font-size: 15px;
    font-style: normal;
    font-weight: 400;
    line-height: 97%; /* 14.55px */
}

#breadcrumbs>span span.breadcrumb_last,
#breadcrumbs>span span.breadcrumb_last * {
    color: #000;
    font-family: "Space Grotesk";
    font-size: 15px;
    font-style: normal;
    font-weight: 400;
    line-height: 97%; /* 14.55px */
}

.module {
    color: #6FCFA3;
    font-family: "Space Grotesk";
    font-size: 15px;
    font-style: normal;
    font-weight: 400;
    line-height: 111%; /* 16.65px */
    text-transform: uppercase;
    margin: 0 auto 37px auto;
}

.module span {
    color: #6FCFA3;
    font-family: "Space Grotesk";
    font-size: 15px;
    font-style: normal;
    font-weight: 400;
    line-height: 111%; /* 16.65px */
    text-transform: uppercase;
    margin-left: 60px;
}

header.top {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: auto;
    padding: 10px 0;
    background: #fff;
    z-index: 9999;
}

header .in {
    padding-bottom: 10px;
    border-bottom: 1px solid #000;
}

header .flex-container {
    justify-content: space-between;
    align-items: center;
}

header .left {
    width: 220px;
}

header .left a img {
    width: 84px;
    height: auto;
}

header .right {
    width: calc(100% - 100px);
}

header .right ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: 0;
    align-items: center;
    justify-content: end;
        margin-bottom: -16px;
}

header .right ul li {
    
}

header .right ul li a:not(.button):not(.close) {
    display: flex;
    justify-content: space-between;
    gap:20px;
    padding: 20px 25px;
    border-top: 1px solid #000;
    border-left: 1px solid #000;
    transition: 300ms;
}

header .right ul li a:not(.button):not(.close) span {
    color: #000;

    font-family: "Space Grotesk";
    font-size: 15px;
    font-style: normal;
    font-weight: 400;
    line-height: 111%; /* 16.65px */
    letter-spacing: -0.3px;
    text-transform: uppercase;
    transition: 300ms;
}

header .right ul li a.search svg path,
header .right ul li a.search svg circle,
header .right ul li a:not(.button) svg path {
    transition: 300ms;
}

@media only screen and (min-width: 1066px) {
    header .right ul li a:not(.button):hover {
        background: #000;
    }

    header .right ul li a:not(.button):hover span {
        color: #fff;
    }

    header .right ul li a:not(.button):hover svg path {
        fill: #fff;
    }

    header .right ul li a.search:hover svg path,
    header .right ul li a.search:hover svg circle {
        stroke: #fff;
    }
}

header .right ul li a.search {
    border-right: 1px solid #000;
    padding: 18px 20px !important;
}

header .right ul li a.search svg {
    width: 20px;
    height: 20px;
}

header .right ul li a.lang span {
    transition: 300ms;
}

header .right ul li a.lang {
    position: relative;
    border-right: 1px solid #000;
    gap: 15px;
}

header .right ul li a.lang span:last-of-type {
    opacity: 0;
}

header .right ul li a.lang.en span:last-of-type {
    opacity: 1;
}

header .right ul li a.lang.en span:first-of-type {
    opacity: 0;
}

header .right ul li a.lang:after {
    content: " ";
    display: block;
    position: absolute;
    width: 13px;
    height: 13px;
    top: 50%;
    right: 25px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    background: #000;
    transition: 300ms;
}

header .right ul li a.lang.en:after {
    right: 60px;
}

@media only screen and (min-width: 1066px) {
    header .right ul li a.lang:hover:after {
        background: #fff;
        right: 60px;
    }

    header .right ul li a.lang:hover span:last-of-type {
        opacity: 1;
    }

    header .right ul li a.lang:hover span:first-of-type {
        opacity: 0;
    }
}

header .right ul li.open a.search {
    display: none;
}

header .right ul li.open form {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    border-top: 1px solid #000;
    border-right: 1px solid #000;
    border-left: 1px solid #000;
    border-bottom: none;
    padding: 15px 25px 14.5px 25px;
    transition: 300ms;
}

header .right ul li form input {
    color: #000;
    border: none;
    background: none;
    width: 150px;
    font-family: "Space Grotesk";
    font-size: 15px;
    font-style: normal;
    font-weight: 400;
    line-height: 111%; /* 16.65px */
    letter-spacing: -0.3px;
    text-transform: uppercase;
    transition: 300ms;
}

header .right ul li form input::placeholder {
    color: #757575;

    font-family: "Space Grotesk";
    font-size: 15px;
    font-style: normal;
    font-weight: 400;
    line-height: 111%; /* 16.65px */
    letter-spacing: -0.3px;
    text-transform: uppercase;
    transition: 300ms;
}

header .right ul li form a svg path {
    transition: 300ms;
}

@media only screen and (min-width: 1066px) {
    header .right ul li form:hover {
        background: #000;
    }

    header .right ul li form:hover a svg path {
        stroke: #fff;
    }

    header .right ul li form:hover input,
    header .right ul li form:hover input::placeholder {
        color: #fff;
    }
}

header .right ul li a.button {
    display: inline-block;
    border-radius: 900px;
    border: 1px solid #000;
    padding: 0 25px;
    color: #000;
    line-height: 55px;
    font-size: 15px;
    font-style: normal;
    font-weight: 400;
    transition: 300ms;
}

@media only screen and (min-width: 1066px) {
    header .right ul li a.button:hover {
        background: #000;
        color: #fff;
    }
}

header .right ul li a.sub svg {
    transition: 300ms;
}

header .right ul li ul.submenu {
    display: none;
}

/* Pokazuj submenu, gdy kursor jest na całym elemencie li.has-submenu */
header .right ul li.has-submenu:hover > ul.submenu {
    display: block;
    position: absolute;
    width: 100%;
    left: 0;
    /* Poprawka: usunięto spację w "73 px" */
    top: 73px; 
    background: #fff;
    z-index: 99999999;
}

@media only screen and (min-width: 1066px) {
    /* Obracaj strzałkę, gdy kursor jest na całym elemencie li.has-submenu */
    header .right ul li.has-submenu:hover>a svg {
        transform: rotateX(180deg);
    }

    header .right ul li.has-submenu:hover>a svg path {
        fill: #fff;
    }

    header .right ul li.has-submenu:hover>a {
        background: #000;
        color: #fff;
    }

    header .right ul li.has-submenu:hover>a span {
        color: #fff;
    }
}

/* Ten kod pozostaje bez zmian, ale upewnij się, że go masz */
header .right ul li a svg {
 transition: 300ms;
}

header .right ul li ul.submenu li {
    border: none !important;
}

header .right ul li ul.submenu li a {
    border: none !important;
    padding: 23px 40px;
    color: #fff;
    background: #000;
    font-family: "Space Grotesk";
    font-size: 40px;
    font-style: normal;
    font-weight: 400;
    line-height: 111%; /* 44.4px */
    letter-spacing: -0.8px;
    text-transform: capitalize;
    transition: 300ms;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

header .right ul li>ul.submenu li a:not(.button):not(.close) span {
    color: #fff;
    font-family: "Space Grotesk";
    font-size: 40px;
    font-style: normal;
    font-weight: 400;
    line-height: 111%; /* 44.4px */
    letter-spacing: -0.8px;
    text-transform: capitalize;
    transition: 300ms;
}

header .right ul li ul.submenu li a div {
    display: flex; 
    gap: 28px;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: 300ms;
}

@media only screen and (min-width: 1066px) {
    header .right ul li ul.submenu li a:hover div {
        opacity: 1;
    }
}

header .right ul li ul.submenu li a div svg {
    width: 30px;
    height: 30px;
}

header .right ul li ul.submenu li a div svg path {
    transition: 300ms;
}

@media only screen and (min-width: 1066px) {
    header .right ul li ul.submenu li:nth-child(1) a:hover,
    header .right ul li ul.submenu li:nth-child(6) a:hover {
        background: #C4EE7A;
    }

    header .right ul li ul.submenu li:nth-child(2) a:hover,
    header .right ul li ul.submenu li:nth-child(7) a:hover {
        background: #FEDE3F;
    }

    header .right ul li ul.submenu li:nth-child(3) a:hover,
    header .right ul li ul.submenu li:nth-child(8) a:hover {
        background: #F9724E;
    }   

    header .right ul li ul.submenu li:nth-child(4) a:hover,
    header .right ul li ul.submenu li:nth-child(9) a:hover {
        background: #6FCFA3;
    }

    header .right ul li ul.submenu li:nth-child(5) a:hover,
    header .right ul li ul.submenu li:nth-child(10) a:hover {
        background: #F79B40;
    }

    header .right ul li ul.submenu li a:hover span {
        color: #000 !important;
    }

    header .right ul li ul.submenu li a:hover div svg path {
        fill: #000;
    }

    header .right ul li ul.submenu li a:hover {
        color: #fff;
        background: #000;
    }
}

header .right ul li form {
    display: none;
}

.menu_mobile {
    display: none;
    position: fixed;
    top: 73px;
    left: 0;
    padding:0;
    background: #fff;
    height: calc(100dvh - 75px);
    width: 100%;
    overflow-y: auto;
    z-index: 9999;
}

.menu_mobile ul {
    list-style: none;
    padding: 0 20px;
    margin: 0 auto;
}

.menu_mobile ul li {

}

.menu_mobile ul li a {
    padding: 17px 0;
    display: flex;
    align-items: center;
    gap: 25px;
}

.menu_mobile ul li a span {
    color: #000;
    leading-trim: both;
    text-edge: cap;
    font-family: "Space Grotesk";
    font-size: 40px;
    font-style: normal;
    font-weight: 600;
    line-height: 111%; /* 44.4px */
    letter-spacing: -0.8px;
    text-transform: uppercase;
}

.menu_mobile ul li a.open>svg {
    transition: 300ms;
}

.menu_mobile ul li a.open>svg {
    transform: rotate(180deg);
}

.menu_mobile ul li ul.submenu {
    padding: 0;
    display: none;
}

.menu_mobile ul li ul.submenu li a {
    position: relative;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.menu_mobile ul li ul.submenu li a:after {
    position: absolute;
    content: " ";
    display: block;
    width: calc(100% + 40px);
    height: 1px;
    background: #000;
    left: -20px;
    bottom: 0;
}

.menu_mobile ul li ul.submenu li a span {
    color: #000;
    leading-trim: both;
    text-edge: cap;
    font-family: "Space Grotesk";
    font-size: 20px;
    font-style: normal;
    font-weight: 400;
    line-height: 111%; /* 22.2px */
    letter-spacing: -0.4px;
    text-transform: uppercase;
}

.mobile_search {
    display: none;
    position: fixed;
    top: 73px;
    left: 0;
    padding:0;
    background: #fff;
    height: calc(100dvh - 75px);
    width: 100%;
    overflow-y: auto;
}

.mobile_search input {
    width: calc(100% - 80px);
    position: absolute;
    top: 30%;
    left: 50%;
    transform: translate(-50%, -50%);
    border: none;
    color: #000;
    border-bottom: 1px solid #000;
    font-family: "Space Grotesk";
    font-size: 15px;
    font-style: normal;
    font-weight: 400;
    line-height: 111%; /* 16.65px */
    letter-spacing: -0.3px;
    text-transform: uppercase;
    padding: 12px 0;
    text-align: center;
}

.mobile_search input::placeholder {
    color: #757575;
}

header .right.mobile {
    display: none;
}

header .right.mobile ul li a.mobile {
    position: relative;
}

header .right.mobile ul li a.mobile svg:nth-child(1) {
    opacity: 1;
    transition: 300ms;
}

header .right.mobile ul li a.mobile svg:nth-child(2) {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    opacity: 0;
    transition: 300ms;
}

header .right.mobile ul li a.mobile.is-active svg:nth-child(1) {
    opacity: 0;
}

header .right.mobile ul li a.mobile.is-active svg:nth-child(2) {
    opacity: 1;
}

header .right.mobile ul li {
    transition: 300ms;
}

header .right.mobile.open ul li:nth-child(1),
header .right.mobile.open ul li:nth-child(2) {
    opacity: 0;
}

header .right.mobile.open ul li a {
    border-left: none;
}

/* Kontener paralaksy: trzyma wysokość sekcji i maskuje obraz */
.parallax-container {
  position: relative;
  height: 80dvh; /* można zmienić */
  overflow: hidden;
}

/* Obrazek: rozciągnięty, wycentrowany, pod treścią */
.parallax-image {
  position: absolute;
  inset: 0;                /* top/right/bottom/left: 0 */
  margin: auto;
  min-width: 100%;
  min-height: 100%;
  width: 100%;
  height: 120%;            /* trochę większy, aby brakowało mniej przy przesuwaniu */
  object-fit: cover;       /* jeżeli to <img>; ignorowane dla <div> */
  z-index: 0;             /* pod treścią kontenera */
  will-change: transform;  /* podpowiedź dla GPU */
  pointer-events: none;    /* obraz nie blokuje interakcji na treści */
  transform: translate3d(0,0,0);
  top:0;
  transition: transform 0.06s linear; /* odrobina wygładzenia mikro-szarpnięć */
   pointer-events:none; 
}

/* Jeżeli stosujesz <div class="parallax-image" style="background-image: url(...);"> */
.parallax-image.is-bg {
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}

/* Preferencje dostępności */
@media (prefers-reduced-motion: reduce) {
  .parallax-image {
    transition: none;
  }
}


footer {
    padding: 78px 0 0 0;
    background: #D3FF82;
}

footer .flex-container {
    justify-content: space-between;
}

footer .logo img {
    width: 230px;
    height: auto;
	margin-top: 10px;
}

footer .email a {
    display: block;
    margin: 90px auto 37px auto;
    color: #000;
    font-family: "Space Grotesk";
    font-size: 120px;
    font-style: normal;
    font-weight: 500;
}

footer .copy {
    display: block;
    color: #000;
    margin: 0;
    padding: 15px 0 26px 0;
    border-top: 1px solid #000;
    text-align: right;
    font-family: "Space Grotesk";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 34px;
}

footer .column p:not(.title) {
    color: #000;
    margin: 0 auto;
    font-family: "Space Grotesk";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 23px;
}

footer .column p.title {
    color: #000;
    margin: 0 auto 10px auto;
    font-family: "Space Grotesk";
    font-size: 20px;
    font-style: normal;
    font-weight: 700;
    line-height: 34px; /* 170% */
    text-transform: uppercase;
}

footer .column ul + p.title {
    margin-top: 70px;
}

footer .column ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: block;
}

footer .column ul li {
    display: block;
}

footer .column ul li + li {
    margin-top: 5px;
}

footer .column ul li a {
    color: #000;

    font-family: "Space Grotesk";
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 34px; 
}

footer .column .social a + a {
    margin-left: 15px;
}

.polityka_prywatnosci {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.8);
    transition: 300ms;
    opacity: 0;
    display: none;
    z-index: 999999;
}

.polityka_prywatnosci.active {
    opacity: 1;
}

.polityka_prywatnosci .in {
    position: absolute;
    width: 100%;
    height: 100dvh;
    max-width: 785px;
    top: 0;
    right: -100%;
    background: #000;
    padding: 100px 40px 40px 40px;
    transition: 300ms;
}

.polityka_prywatnosci .in.active {
    right: 0;
}

.polityka_prywatnosci .in .close {
    position: absolute;
    top: 31px;
    right: 39px;
}

.polityka_prywatnosci .in .content {
    height: 100%;
    overflow-y: auto;
    scrollbar-width: none; 
    -ms-overflow-style: none;  
}

.polityka_prywatnosci .in .content::-webkit-scrollbar {
    display: none;
}

.polityka_prywatnosci .in .content * {
    color: #FFF;
    font-family: Space Grotesk;
    font-size: 15px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
}

.polityka_prywatnosci .in .content h2 {
    color: #FFF;
    margin: 0 auto 40px auto;
    font-family: "Space Grotesk";
    font-size: 60px;
    font-style: normal;
    font-weight: 600;
    line-height: normal;
}

.animated-arrow {
  display: inline-block;
  width: 61px;
  height: 61px;
  overflow: hidden;
  cursor: pointer;
  vertical-align: middle;
}

.animated-arrow .icon-wrapper {
  display: flex;
  width: 200%;
  height: 100%;
  transition: transform 0.4s ease;
}

.animated-arrow .icon-alt path {
  fill: #D3FF82;
}

@media only screen and (min-width: 1066px) {
    .animated-arrow:hover .icon-wrapper {
      transform: translateX(-50%);
    }
}

@media only screen and (max-width: 1200px) {
    footer .flex-container {
        gap: 50px;
    }

    footer .email a {
        font-size: 90px;
    }

    .container {
        padding: 0 20px;
    }
}

@media only screen and (max-width: 1065px) {
    header .right.pc {
        display: none;
    }

    header .right.mobile {
        display: block;
        margin-right: -20px;
    }

    header .right.mobile ul {
        margin-bottom: 0;
    }

    header .right.mobile a {
        border-top: none !important;
        padding: 20px !important;
    }

    header .right.mobile a.search {
        border-right: none !important;
        padding: 20px !important;
    }

    header .right.mobile a.lang {
        padding: 22px 20px !important;
    }

    header .right ul li a:not(.button):not(.close) {
        gap: 15px;
    }

    header {
        padding-top:0;
    }

    header .in {
        padding-bottom: 0;
    }

    header .left a img {
        width: 57px;
    }
}

@media only screen and (max-width: 996px) {
    footer {
        padding-top: 37px;
    }

    .mobile_search {
        z-index: 99999;
    }

    footer .logo img {
        width: 160px;
    }

    footer .flex-container {
        flex-wrap: wrap;
        gap: 0;
        row-gap: 50px;
    }

    footer .email a {
        color: #000;
        font-family: "Space Grotesk";
        font-size: 35px;
        font-style: normal;
        font-weight: 500;
        line-height: 23px; /* 65.714% */
        margin: 40px auto 46px auto;
    }

    footer .social {
        display: none;
    }

    footer .column p.title {
        color: #000;
        font-family: "Space Grotesk";
        font-size: 20px;
        font-style: normal;
        font-weight: 400;
        line-height: 34px; /* 170% */
        text-transform: uppercase;
    }

    footer .flex-container .column:nth-child(1) {
        order: 1;
        width: 100%;
    }

    footer .flex-container .column:nth-child(2) {
        order: 5;
        width: 100%;
    }

    footer .flex-container .column:nth-child(3) {
        order: 2;
        width: 50%;
    }

    footer .flex-container .column:nth-child(4) {
        order: 3;
        width: 50%;
    }

    footer .flex-container .column:nth-child(5) {
        order: 4;
        width: 50%;
    }

    footer .column ul li a {
        font-size: 15px;
    }
	
	header.top {
		padding: 0;
	}
}

/* HOME – przycisk OPEN CALL (link zawiera open-call) */
a.btn[href*="open-call"] {
  background-color: #e4fa70 !important;
  color: #000 !important;
  border: 2px solid #e4fa70 !important;
}

a.btn[href*="open-call"]:hover{
  background-color: transparent !important;
  color: #fff !important;
  border-color: #fff !important;
}


