/**
 * Landing Page - First Section
 * Profesjonalne oświetlenie imitujące światło dzienne
 * Pixel-perfect implementation from Figma
 * Fonts loaded via wp_head preload (functions.php) - no @import to avoid CLS
 */

 aside#sidebar {
     display: none;
 }

/*
 * Landing: wyłączenie sticky/fixed na głównym nagłówku i menu.
 * Jeśli motyw używa innej klasy niż poniżej, dopisz selektor w tym bloku.
 */
body.multiled-landing #masthead,
body.multiled-landing .site-header,
body.multiled-landing header.site-header,
body.multiled-landing #header,
body.multiled-landing .header,
body.multiled-landing header[role="banner"],
body.multiled-landing .navbar-fixed-top,
body.multiled-landing header.page-header,
body.multiled-landing .page-header,
body.multiled-landing .page-header__row,
body.page-template-landing-php #masthead,
body.page-template-landing-php .site-header,
body.page-template-landing-php header.site-header,
body.page-template-landing-php #header,
body.page-template-landing-php .header,
body.page-template-landing-php header[role="banner"],
body.page-template-landing-php .navbar-fixed-top,
body.page-template-landing-php header.page-header,
body.page-template-landing-php .page-header,
body.page-template-landing-php .page-header__row {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    width: 100% !important;
    max-width: none !important;
    transform: none !important;
    z-index: auto !important;
}

/*
 * Landing: uproszczony pasek — tylko logo (link do strony głównej), wyśrodkowane.
 * Ukrywane są typowe bloki menu / CTA / hamburger (dopisz selektory, jeśli motyw ma inne klasy).
 */
body.multiled-landing .site-header .header-container,
body.multiled-landing header[role="banner"] .header-container,
body.page-template-landing-php .site-header .header-container,
body.page-template-landing-php header[role="banner"] .header-container {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
}

body.multiled-landing .site-header .site-branding,
body.multiled-landing .site-header .header-logo,
body.page-template-landing-php .site-header .site-branding,
body.page-template-landing-php .site-header .header-logo {
    margin-left: auto !important;
    margin-right: auto !important;
    text-align: center !important;
}

/* Blankslate / typowy układ: nawigacja obok logo */
body.multiled-landing .site-header .main-navigation,
body.multiled-landing .site-header .menu-toggle,
body.multiled-landing .site-header .header-cta-button,
body.page-template-landing-php .site-header .main-navigation,
body.page-template-landing-php .site-header .menu-toggle,
body.page-template-landing-php .site-header .header-cta-button {
    display: none !important;
}

/* Wariant z osobnymi blokami menu / przyciskiem / mobile */
body.multiled-landing .site-header .header-menu,
body.multiled-landing .site-header .header-menu--desktop,
body.multiled-landing .site-header .header-button,
body.multiled-landing .site-header .nav-toggle,
body.multiled-landing .site-header .nav-overlay,
body.page-template-landing-php .site-header .header-menu,
body.page-template-landing-php .site-header .header-menu--desktop,
body.page-template-landing-php .site-header .header-button,
body.page-template-landing-php .site-header .nav-toggle,
body.page-template-landing-php .site-header .nav-overlay {
    display: none !important;
}

/* #masthead (Twenty itp.): ukryj nawigację, zostaw branding */
body.multiled-landing #masthead .main-navigation,
body.multiled-landing #masthead #site-navigation,
body.multiled-landing #masthead nav.navigation,
body.page-template-landing-php #masthead .main-navigation,
body.page-template-landing-php #masthead #site-navigation,
body.page-template-landing-php #masthead nav.navigation {
    display: none !important;
}

body.multiled-landing #masthead .site-branding,
body.page-template-landing-php #masthead .site-branding {
    margin-left: auto !important;
    margin-right: auto !important;
    float: none !important;
    text-align: center !important;
}

/* Navbar bootstrapowy */
body.multiled-landing header[role="banner"] .navbar-collapse,
body.multiled-landing header[role="banner"] .navbar-toggler,
body.page-template-landing-php header[role="banner"] .navbar-collapse,
body.page-template-landing-php header[role="banner"] .navbar-toggler {
    display: none !important;
}

body.multiled-landing header[role="banner"] .navbar .navbar-brand,
body.page-template-landing-php header[role="banner"] .navbar .navbar-brand {
    margin-left: auto !important;
    margin-right: auto !important;
}

/*
 * Nagłówek typu header.page-header (np. multiled): rząd z logo + ikonami (szukaj, pomoc, „Napisz do nas”, MENU).
 * CSS — ukrywanie typowych utility; dopełnienie: inline JS w functions.php (największe img = logo).
 */
body.multiled-landing header.page-header,
body.page-template-landing-php header.page-header {
    position: relative !important;
    border-bottom: 0;
}

body.multiled-landing header.page-header .page-header__row,
body.page-template-landing-php header.page-header .page-header__row {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    width: 100% !important;
}

body.multiled-landing header.page-header .page-header__logo,
body.multiled-landing header.page-header .site-branding,
body.multiled-landing header.page-header .custom-logo-link,
body.page-template-landing-php header.page-header .page-header__logo,
body.page-template-landing-php header.page-header .site-branding,
body.page-template-landing-php header.page-header .custom-logo-link {
    margin-left: auto !important;
    margin-right: auto !important;
    float: none !important;
}

body.multiled-landing header.page-header .page-header__actions,
body.multiled-landing header.page-header .page-header__tools,
body.multiled-landing header.page-header .page-header__icons,
body.multiled-landing header.page-header .page-header__utilities,
body.multiled-landing header.page-header .page-header__extras,
body.multiled-landing header.page-header .header-actions,
body.multiled-landing header.page-header .header-icons,
body.multiled-landing header.page-header .header-toolbar,
body.multiled-landing header.page-header [class*="header-action"],
body.multiled-landing header.page-header [class*="header-icon"],
body.multiled-landing header.page-header [class*="search-trigger"],
body.multiled-landing header.page-header [class*="SearchTrigger"],
body.multiled-landing header.page-header [class*="mobile-nav"],
body.multiled-landing header.page-header [class*="MobileNav"],
body.multiled-landing header.page-header [class*="hamburger"],
body.multiled-landing header.page-header [class*="menu-toggle"],
body.page-template-landing-php header.page-header .page-header__actions,
body.page-template-landing-php header.page-header .page-header__tools,
body.page-template-landing-php header.page-header .page-header__icons,
body.page-template-landing-php header.page-header .page-header__utilities,
body.page-template-landing-php header.page-header .page-header__extras,
body.page-template-landing-php header.page-header .header-actions,
body.page-template-landing-php header.page-header .header-icons,
body.page-template-landing-php header.page-header .header-toolbar,
body.page-template-landing-php header.page-header [class*="header-action"],
body.page-template-landing-php header.page-header [class*="header-icon"],
body.page-template-landing-php header.page-header [class*="search-trigger"],
body.page-template-landing-php header.page-header [class*="SearchTrigger"],
body.page-template-landing-php header.page-header [class*="mobile-nav"],
body.page-template-landing-php header.page-header [class*="MobileNav"],
body.page-template-landing-php header.page-header [class*="hamburger"],
body.page-template-landing-php header.page-header [class*="menu-toggle"] {
    display: none !important;
}

body.multiled-landing header.page-header nav:not(.skip-link),
body.page-template-landing-php header.page-header nav:not(.skip-link) {
    display: none !important;
}

body.multiled-landing header.page-header .menu-label,
body.page-template-landing-php header.page-header .menu-label {
    display: none !important;
}

 /* ===== Main Content ===== */
 .lp-main {
     display: flex;
     flex-direction: column;
     align-items: center;
     padding: 232px 108px 128px;
     gap: 56px;
     isolation: isolate;
     width: 100%;
     max-width: 1815px;
     margin: 0 auto;
     background: #FFFFFF;
     position: relative;
     box-sizing: border-box;
 }

 /* ===== Sekcja 1 Wersja 2 ===== */
 .lp-main-v2 {
     display: flex;
     flex-direction: row;
     align-items: center;
     padding: 0 108px 0 108px;
     gap: 24px;
     background: linear-gradient(180deg, #FFFFFF 0%, #FFFCF2 100%);
     max-width: 1815px;
     justify-content: center;
 }

 .lp-content-section-v2 {
     display: flex;
     flex-direction: row;
     align-items: center;
     padding: 0;
     gap: 24px;
     flex: 1;
 }

 .lp-container-v2 {
     display: flex;
     flex-direction: row;
     align-items: center;
     padding: 0;
     gap: 24px;
     flex: 1;
 }

 .lp-text-col-v2 {
     display: flex;
     flex-direction: column;
     justify-content: center;
     align-items: flex-start;
     padding: 0;
     gap: 32px;
     /* width: 600px; */
     max-width: 100%;
     flex: none;
 }

 .lp-hero-image-v2 {
     flex: none;
     width: 604px;
     height: 795px;
     max-width: 50%;
     background-size: contain;
     background-position: center;
     background-repeat: no-repeat;
 }

 @media (max-width: 1200px) {
     .lp-main-v2 {
         padding: 56px 48px;
     }

     .lp-hero-image-v2 {
         width: 400px;
         height: 520px;
     }
 }

 @media (max-width: 992px) {
     .lp-main-v2 {
         flex-direction: column;
         padding: 48px 24px;
     }

     .lp-container-v2 {
         flex-direction: column;
     }

     .lp-text-col-v2 {
         width: 100%;
     }

     .lp-hero-image-v2 {
         width: 100%;
         max-width: 100%;
         height: 400px;
     }
 }

 /* Kotwica „Napisz do nas” → formularz u góry landingu */
 #lp-formularz {
     scroll-margin-top: 96px;
 }

 /* ===== Sekcja 2 Wersja 2 (hero + formularz) ===== */
 .lp-v2-form-section {
     position: relative;
     display: flex;
     flex-direction: column;
     align-items: center;
     padding: 232px 108px 128px;
     gap: 56px;
     isolation: isolate;
     width: 100%;
     max-width: 1815px;
     margin: 0 auto;
     /* min-height: 1073px; */
     background: #FFFFFF;
     box-sizing: border-box;
 }

 .lp-v2-form-hero {
     position: absolute;
     width: 100%;
     max-width: 1815px;
     height: 512px;
     left: 0;
     top: 0;
     background-size: cover;
     background-position: center;
     background-repeat: no-repeat;
     z-index: 0;
 }

 .lp-v2-form-gradient {
     position: absolute;
     width: 100%;
     max-width: 1815px;
     height: 360px;
     left: 0;
     top: 152px;
     background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, #FFFFFF 100%);
     pointer-events: none;
     z-index: 1;
 }

 .lp-v2-form-container {
     position: relative;
     display: flex;
     flex-direction: row;
     align-items: center;
     justify-content: center;
    padding: 0;
    gap: 24px;
    z-index: 2;
 }

.lp-v2-form-section .lp-v2-form-box {
    max-width: 100%;
}

 @media (max-width: 1200px) {
     .lp-v2-form-section {
         padding: 180px 48px 96px;
     }

     .lp-v2-form-hero {
         height: 400px;
     }

     .lp-v2-form-gradient {
         height: 280px;
         top: 120px;
     }
 }

 @media (max-width: 768px) {
     .lp-v2-form-section {
         padding: 140px 24px 64px;
         gap: 40px;
     }

     .lp-v2-form-hero {
         height: 320px;
     }

     .lp-v2-form-gradient {
         height: 200px;
         top: 120px;
     }

     .lp-v2-form-section .lp-v2-form-box {
         padding: 32px 24px;
     }
 }

 @media (max-width: 480px) {
     .lp-v2-form-section {
         padding: 120px 16px 48px;
     }
 }
 
 /* ===== Hero Section ===== */
 .lp-hero {
     position: absolute;
     width: 100%;
     max-width: 1815px;
     height: 512px;
     left: 0;
     top: 0;
     flex: none;
     order: 0;
     flex-grow: 0;
     z-index: 0;
     overflow: hidden;
 }
 
 .lp-hero-bg {
     position: absolute;
     width: 100%;
     height: 512px;
     left: 0;
     top: 0;
     background-size: cover;
     background-position: top;
     background-repeat: no-repeat;
 }
 
 /* Hero Background - gradient overlay */
 .lp-hero-gradient {
     position: absolute;
     width: 100%;
     max-width: 1815px;
     height: 360px;
     left: 0;
     top: 152px;
     background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, #FFFFFF 100%);
     pointer-events: none;
 }
 
 /* ===== Content Section ===== */
 .lp-content-section {
     display: flex;
     flex-direction: row;
     align-items: center;
     padding: 0;
     gap: 24px;
     width: 100%;
     max-width: 1224px;
     flex: none;
     order: 1;
     flex-grow: 0;
     z-index: 1;
 }
 
 .lp-container {
     display: flex;
     flex-direction: row;
     align-items: center;
     padding: 0;
     gap: 24px;
     width: 100%;
     max-width: 1224px;
 }
 
 /* ===== Left Column - Text ===== */
 .lp-text-col {
     display: flex;
     flex-direction: column;
     justify-content: center;
     align-items: flex-start;
     padding: 0;
     gap: 32px;
     max-width: 50%;
     flex: none;
     align-self: stretch;
     flex-grow: 0;
 }
 
 /* Title Container */
 .lp-title-wrap {
     display: flex;
     flex-direction: column;
     justify-content: center;
     align-items: flex-start;
     padding: 0;
     width: 100%;
 }
 
 .lp-title {
     width: 100%;
     font-family: 'Raleway', sans-serif;
     font-style: normal;
     font-weight: 400;
     font-size: 48px;
     line-height: 60px;
     color: #1B1B1B;
     margin: -12px 0;
 }
 
 .lp-subtitle {
     width: 100%;
     max-width: 519px;
     font-family: 'Playfair Display', serif;
     font-style: italic;
     font-weight: 400;
     font-size: 48px;
     line-height: 60px;
     color: #FFC900;
     margin: 0;
 }
 
 /* Description Container */
 .lp-desc-wrap {
     display: flex;
     flex-direction: column;
     align-items: flex-start;
     padding: 0;
     gap: 24px;
     width: 100%;
 }
 
 .lp-desc-intro {
     width: 75%;
     font-family: 'Open Sans', sans-serif;
     font-style: normal;
     font-weight: 600;
     font-size: 24px;
     line-height: 33px;
     color: #494949;
     margin: 0;
 }
 
 .lp-desc-text {
     display: flex;
     flex-direction: column;
     align-items: flex-start;
     padding: 0;
     gap: 8px;
     width: 100%;
 }
 
 .lp-desc-text p {
     width: 100%;
     font-family: 'Open Sans', sans-serif;
     font-style: normal;
     font-weight: 600;
     font-size: 16px;
     line-height: 24px;
     color: #494949;
     margin: 0;
 }
 
 /* Features list */
.lp-features {
     display: flex;
     flex-direction: column;
     align-items: flex-start;
     padding: 0;
     gap: 24px;
     width: 75%;
}
 
 .lp-feature {
     display: flex;
     flex-direction: row;
     align-items: center;
     padding: 0;
     gap: 16px;
     width: 100%;
 }
 
 .lp-feature-icon {
     width: 32px;
     height: 32px;
     flex-shrink: 0;
     object-fit: contain;
 }
 
 .lp-feature-text {
     font-family: 'Open Sans', sans-serif;
     font-style: normal;
     font-weight: 700;
     font-size: 16px;
     line-height: 24px;
     color: #3B2F2B;
     margin: 0;
     flex: 1;
 }
 
 .lp-feature:nth-child(2) .lp-feature-text {
     line-height: 22px;
 }
 
 /* ===== Right Column - Form ===== */
 .lp-form-col {
     flex: none;
     order: 1;
     flex-grow: 0;
 }
 
 .lp-form-box {
     display: flex;
     flex-direction: column;
     align-items: flex-start;
     padding: 48px;
     gap: 32px;
     width: 600px;
     max-width: 100%;
     background: #FFFFFF;
     box-shadow: 0px 16px 32px 8px rgba(0, 0, 0, 0.12);
     border-radius: 0;
     box-sizing: border-box;
 }
 
 .lp-form-title {
     width: 100%;
     font-family: 'Open Sans', sans-serif;
     font-style: normal;
     font-weight: 600;
     font-size: 24px;
     line-height: 33px;
     color: #494949;
     margin: 0;
 }
 
 .lp-form {
     display: flex;
     flex-direction: column;
     align-items: flex-start;
     padding: 0;
     gap: 24px;
     width: 100%;
 }
 
 .lp-field {
     display: flex;
     flex-direction: column;
     align-items: flex-start;
     padding: 0;
     gap: 12px;
     width: 100%;
 }
 
 .lp-label {
     width: 100%;
     font-family: 'Open Sans', sans-serif;
     font-style: normal;
     font-weight: 700;
     font-size: 16px;
     line-height: 22px;
     color: #494949;
     margin: 0;
 }
 
 .lp-input {
     box-sizing: border-box;
     display: flex;
     flex-direction: row;
     align-items: center;
     padding: 16px 24px;
     gap: 8px;
     width: 100%;
     height: 54px;
     background: #FFFFFF;
     border: 1px solid #EAEAEA;
     font-family: 'Open Sans', sans-serif;
     font-weight: 600;
     font-size: 16px;
     line-height: 22px;
     color: #494949;
 }
 
 .lp-input::placeholder {
     color: #494949;
     opacity: 0.56;
 }
 
 .lp-input:focus {
     outline: none;
     border-color: #FFC900;
 }
 
 .lp-select {
     appearance: none;
     background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Cpath fill='%23A2A2A1' d='M4 6l4 4 4-4z'/%3E%3C/svg%3E");
     background-repeat: no-repeat;
     background-position: right 16px center;
     padding-right: 44px;
     justify-content: space-between;
     cursor: pointer;
 }
 
 .lp-select option {
     color: #494949;
 }
 
 /* Consent */
 .lp-consent {
     display: flex;
     flex-direction: row;
     align-items: flex-start;
     padding: 0;
     gap: 16px;
     width: 100%;
 }
 
 .lp-checkbox {
     box-sizing: border-box;
     width: 32px;
     height: 32px;
     min-width: 32px;
     background: #FFFFFF;
     border: 1px solid #EAEAEA;
     cursor: pointer;
     margin: 0;
     accent-color: #FFC900;
 }
 
 .lp-consent-text {
     width: 100%;
     font-family: 'Open Sans', sans-serif;
     font-style: normal;
     font-weight: 600;
     font-size: 12px;
     line-height: 16px;
     color: #3B2F2B;
     opacity: 0.56;
     margin: 0;
     cursor: pointer;
 }
 
 /* Submit Button */
 .lp-submit {
     display: flex;
     flex-direction: row;
     justify-content: center;
     align-items: center;
     padding: 24px 32px;
     gap: 8px;
     width: 100%;
     height: 80px;
     background: #FFC900;
     border: none;
     border-radius: 0;
     font-family: 'Raleway', sans-serif;
     font-style: normal;
     font-weight: 700;
     font-size: 24px;
     line-height: 32px;
     letter-spacing: 0.04em;
     color: #1B1B1B;
     cursor: pointer;
     transition: background 0.2s ease, transform 0.1s ease;
 }
 
 .lp-submit:hover {
     background: #e6b500;
 }
 
 .lp-submit:active {
     transform: scale(0.98);
 }
 
 /* ===== Responsive ===== */
 @media (max-width: 1200px) {
     .lp-main {
         padding: 180px 48px 96px;
     }
 
     .lp-container {
         flex-direction: column;
         align-items: stretch;
     }
 
     .lp-text-col {
         width: 100%;
     }
 
     .lp-form-box {
         width: 100%;
     }
 }
 
 @media (max-width: 992px) {
     .lp-main {
         padding: 140px 48px 64px;
         gap: 40px;
     }
 
     .lp-hero {
         height: 400px;
     }
 
     .lp-hero-bg {
         height: 400px;
     }
 
     .lp-hero-gradient {
         height: 280px;
         top: 120px;
     }
 
     .lp-title,
     .lp-subtitle {
         font-size: 36px;
         line-height: 1.2;
     }
 
     .lp-desc-intro {
         font-size: 20px;
     }
 }
 
 @media (max-width: 768px) {
     .lp-main {
         padding: 120px 24px 48px;
         gap: 32px;
     }
 
     .lp-hero {
         height: 320px;
     }
 
     .lp-hero-bg {
         height: 320px;
     }
 
     .lp-hero-gradient {
         height: 200px;
         top: 120px;
     }
 
     .lp-title,
     .lp-subtitle {
         font-size: 28px;
     }
 
    .lp-form-box {
        padding: 32px 24px;
    }

   .lp-submit {
        height: 52px;
        font-size: 14px;
    }

    .lp-text-col {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: flex-start;
        padding: 0;
        gap: 32px;
        max-width: 100%;
        flex: none;
        align-self: stretch;
        flex-grow: 0;
    }

    .lp-content-section {
        display: flex;
        flex-direction: row;
        align-items: center;
        padding: 0;
        gap: 24px;
        width: 100%;
        max-width: 1224px;
        flex: none;
        order: 1;
        flex-grow: 0;
        z-index: 1;
        margin-top: 0;
    }
}

@media (max-width: 480px) {
    .lp-main {
        padding: 100px 16px 32px;
    }

    .lp-title,
    .lp-subtitle {
        font-size: 32px;
    }

    .lp-form-title {
        font-size: 18px;
        line-height: 28px;
    }

    .lp-form {
        gap: 12px;
    }

    .lp-field {
        gap: 8px;
    }

    .lp-label {
        font-size: 12px;
        line-height: 22px;
    }

    .lp-input {
        padding: 12px 24px;
        height: 46px;
        font-size: 12px;
        line-height: 22px;
    }
}

/* ===== Why Choose Us Section ===== */
.lp-why-wrap {
    width: 100%;
    background: #FFFCF2;
}

.lp-why {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 112px 108px;
    gap: 56px;
    width: 100%;
    max-width: 1815px;
    margin: 0 auto;
    background: #FFFCF2;
    border-radius: 0;
    box-sizing: border-box;
}

.lp-why-content {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 0;
    gap: 56px;
    width: 100%;
    max-width: 1224px;
    margin: 0 auto;
}

/* Footer Content / Header row */
.lp-why-header {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    padding: 0;
    gap: 16px;
    width: 100%;
}

.lp-why-title-wrap {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    padding: 0;
    flex: 1;
}

.lp-why-title {
    font-family: 'Raleway', sans-serif;
    font-style: normal;
    font-weight: 400;
    font-size: 48px;
    line-height: 60px;
    color: #1B1B1B;
    margin: -12px 0 0;
}

.lp-why-subtitle {
    font-family: 'Playfair Display', serif;
    font-style: italic;
    font-weight: 400;
    font-size: 48px;
    line-height: 60px;
    color: #FFC900;
    margin: 0;
}

.lp-why-desc {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 0;
    gap: 8px;
    width: 604px;
    min-width: 0;
    flex: 1;
}

.lp-why-desc p {
    width: 100%;
    font-family: 'Open Sans', sans-serif;
    font-style: normal;
    font-weight: 600;
    font-size: 16px;
    line-height: 24px;
    color: #494949;
    margin: 0;
}


/* Footer Links Container - Grid of cards (2x2 + 1 left) */
.lp-why-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    width: 100%;
    max-width: 1224px;
}

.lp-why-card {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 48px;
    gap: 32px;
    min-height: 305px;
    box-sizing: border-box;
    background: #FFFFFF;
    border: 1px solid #EAEAEA;
}

.lp-why-card-single {
    grid-column: 1;
}

.lp-why-card-icon {
    width: 88px;
    height: 88px;
    flex-shrink: 0;
}

.lp-why-card-icon img {
    width: 88px;
    height: 88px;
    object-fit: contain;
}

.lp-why-card-text {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 0;
    gap: 8px;
    flex: 1;
    min-width: 0;
}

.lp-why-card-title {
    width: 100%;
    font-family: 'Open Sans', sans-serif;
    font-style: normal;
    font-weight: 600;
    font-size: 24px;
    line-height: 33px;
    color: #494949;
    margin: 0;
}

.lp-why-card-desc {
    width: 100%;
    font-family: 'Open Sans', sans-serif;
    font-style: normal;
    font-weight: 600;
    font-size: 16px;
    line-height: 24px;
    color: #A2A2A1;
    margin: 0;
}

/* Why section responsive */
@media (max-width: 1200px) {
    .lp-why {
        padding: 80px 48px;
    }

    .lp-why-header {
        flex-direction: column;
        gap: 24px;
    }

    .lp-why-title-wrap,
    .lp-why-desc {
        width: 100%;
    }

    .lp-why-card-single {
        grid-column: 1 / -1;
    }
}

@media (max-width: 768px) {
    .lp-why {
        padding: 64px 24px;
        gap: 40px;
    }

    .lp-why-grid {
        grid-template-columns: 1fr;
    }

    .lp-why-card-single {
        grid-column: 1;
    }

    .lp-why-title,
    .lp-why-subtitle {
        font-size: 36px;
        line-height: 1.2;
    }

    .lp-why-card-title {
        font-size: 20px;
        line-height: 24px;
    }
}

@media (max-width: 480px) {
    .lp-why {
        padding: 48px 16px;
    }

    .lp-why-title,
    .lp-why-subtitle {
        font-size: 28px;
    }

    .lp-why-card {
        padding: 32px 24px;
    }
}

/* ===== Testimonials Section ===== */
.lp-testimonials-wrap {
    width: 100%;
    background: #FFFFFF;
}

.lp-testimonials {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 160px 108px;
    gap: 64px;
    width: 100%;
    max-width: 1815px;
    margin: 0 auto;
    background: #FFFFFF;
    border-radius: 0;
    box-sizing: border-box;
}

.lp-testimonials-inner {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 64px;
    width: 100%;
    /* max-width: 1224px; */
    margin: 0 auto;
}

.lp-testimonials-header {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-end;
    padding: 0;
    width: 100%;
}

.lp-testimonials-title-wrap {
    display: flex;
    flex-direction: row;
    align-items: baseline;
    padding: 0;
    gap: 12px;
}

.lp-testimonials-title {
    font-family: 'Raleway', sans-serif;
    font-style: normal;
    font-weight: 400;
    font-size: 48px;
    line-height: 60px;
    color: #1B1B1B;
    margin: 0;
}

.lp-testimonials-subtitle {
    font-family: 'Playfair Display', serif;
    font-style: italic;
    font-weight: 400;
    font-size: 48px;
    line-height: 60px;
    color: #FFC900;
}

.lp-testimonials-nav {
    display: flex;
    flex-direction: row;
    align-items: center;
    padding: 0;
    gap: 0;
}

.lp-testimonials-btn {
    box-sizing: border-box;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    padding: 16px;
    width: 72px;
    height: 72px;
    background: transparent;
    border: 1px solid #FECC08;
    cursor: pointer;
    color: #1B1B1B;
    transition: background 0.2s, border-color 0.2s;
}

.lp-testimonials-btn:hover {
    background: rgba(255, 204, 0, 0.1);
}

.lp-testimonials-btn-active {
    background: #FFC900;
    border-color: #FFC900;
}

.lp-testimonials-btn-active:hover {
    background: #e6b500;
    border-color: #e6b500;
}

.lp-testimonials-viewport {
    width: 100%;
    overflow: hidden;
    touch-action: pan-y;
}

.lp-testimonials-track {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    gap: 32px;
    transition: transform 0.4s ease;
}

.lp-testimonial-card {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 48px;
    gap: 32px;
    flex: 0 0 520px;
    min-width: 520px;
    max-width: 520px;
    box-sizing: border-box;
    background: #FFFFFF;
    border: 1px solid #EAEAEA;
}

.lp-testimonial-quote-wrap {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    padding: 0;
    gap: 4px;
    width: 100%;
}

.lp-testimonial-quote {
    flex: 1;
    font-family: 'Open Sans', sans-serif;
    font-style: italic;
    font-weight: 400;
    font-size: 24px;
    line-height: 32px;
    color: #494949;
    margin: 0;
    min-width: 0;
}

.lp-testimonial-quote-mark {
    flex-shrink: 0;
    width: 34px;
    height: 26px;
    font-size: 48px;
    line-height: 1;
    color: #FFC900;
    font-family: Georgia, serif;
}

.lp-testimonial-author {
    display: flex;
    flex-direction: row;
    align-items: center;
    padding: 0;
    gap: 16px;
}

.lp-testimonial-avatar {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background-color: #FFC900;
    background-size: cover;
    background-position: center;
    flex-shrink: 0;
}

/* Neutralny awatar (bez zdjęć): żółte koło + biała sylwetka */
.lp-testimonial-avatar--neutral {
    display: flex;
    align-items: center;
    justify-content: center;
    background-image: none !important;
    box-sizing: border-box;
}

.lp-testimonial-avatar--neutral .lp-testimonial-avatar-icon {
    width: 62%;
    height: 62%;
    display: block;
    flex-shrink: 0;
}

.lp-testimonial-author-info {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 0;
    gap: 4px;
}

.lp-testimonial-name {
    font-family: 'Open Sans', sans-serif;
    font-weight: 700;
    font-size: 16px;
    line-height: 22px;
    color: #494949;
}

.lp-testimonial-company {
    font-family: 'Open Sans', sans-serif;
    font-weight: 600;
    font-size: 16px;
    line-height: 22px;
    color: #494949;
}

/* Testimonials responsive */
@media (max-width: 1200px) {
    .lp-testimonials {
        padding: 80px 48px;
    }

    .lp-testimonial-card {
        flex: 0 0 400px;
        min-width: 400px;
        max-width: 400px;
    }
}

@media (max-width: 768px) {
    .lp-testimonials {
        padding: 64px 24px;
        gap: 40px;
    }

    .lp-testimonials-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 24px;
    }

    .lp-testimonials-title,
    .lp-testimonials-subtitle {
        font-size: 36px;
        line-height: 1.2;
    }

    .lp-testimonial-card {
        flex: 0 0 100%;
        min-width: 100%;
        max-width: 100%;
    }

    .lp-testimonials-btn {
        width: 60px;
        height: 60px;
        padding: 16px;
    }
}

@media (max-width: 480px) {
    .lp-testimonials {
        padding: 48px 16px;
    }

    .lp-testimonials-title,
    .lp-testimonials-subtitle {
        font-size: 28px;
    }

    .lp-testimonial-card {
        padding: 32px 24px;
    }
}

/* ===== Projects Section ===== */
.lp-projects-wrap {
    width: 100%;
    background: #1B1B1B;
}

.lp-projects {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 112px 108px;
    gap: 64px;
    width: 100%;
    max-width: 1815px;
    margin: 0 auto;
    background: #1B1B1B;
    border-radius: 0;
    box-sizing: border-box;
}

.lp-projects-inner {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 64px;
    width: 100%;
    max-width: 1442px;
    margin: 0 auto;
}

.lp-projects-header {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-end;
    padding: 0;
    width: 100%;
}

.lp-projects-title {
    font-family: 'Raleway', sans-serif;
    font-style: normal;
    font-weight: 400;
    font-size: 48px;
    line-height: 60px;
    color: #FFFFFF;
    margin: 0;
}

.lp-projects-nav {
    display: flex;
    flex-direction: row;
    align-items: center;
    padding: 0;
    gap: 0;
}

.lp-projects-btn {
    box-sizing: border-box;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    padding: 16px;
    width: 72px;
    height: 72px;
    background: transparent;
    border: 1px solid #FECC08;
    cursor: pointer;
    color: #FFFFFF;
    transition: background 0.2s, border-color 0.2s;
}

.lp-projects-btn:hover {
    background: rgba(255, 204, 0, 0.2);
}

.lp-projects-btn-active {
    background: #FFC900;
    border-color: #FFC900;
    color: #1B1B1B;
}

.lp-projects-btn-active:hover {
    background: #e6b500;
    border-color: #e6b500;
}

.lp-projects-viewport {
    width: 100%;
    max-width: 1442px;
    overflow: hidden;
}

.lp-projects-track {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    gap: 8px;
    min-height: 540px;
    transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.lp-projects-slide {
    position: relative;
    overflow: hidden;
    flex-shrink: 0;
    min-height: 540px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    display: block;
    box-sizing: border-box;
    text-decoration: none;
    color: inherit;
    cursor: pointer;
    outline-offset: 4px;
}

.lp-projects-slide:focus-visible {
    outline: 2px solid #FFC900;
}

.lp-projects-slide-hover {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-start;
    padding: 40px 36px;
    gap: 10px;
    background: linear-gradient(180deg, rgba(27, 27, 27, 0) 0%, rgba(27, 27, 27, 0.55) 45%, rgba(27, 27, 27, 0.88) 100%);
    opacity: 0;
    transition: opacity 0.35s ease;
    pointer-events: none;
}

.lp-projects-slide:hover .lp-projects-slide-hover,
.lp-projects-slide:focus-visible .lp-projects-slide-hover {
    opacity: 1;
}

.lp-projects-slide-title {
    font-family: 'Open Sans', sans-serif;
    font-style: normal;
    font-weight: 600;
    font-size: 22px;
    line-height: 1.35;
    color: #FFFFFF;
    margin: 0;
    max-width: 100%;
}

.lp-projects-slide-cta {
    font-family: 'Raleway', sans-serif;
    font-style: normal;
    font-weight: 700;
    font-size: 13px;
    line-height: 1.2;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #FFC900;
    margin: 0;
}

@media (max-width: 768px) {
    .lp-projects-slide-hover {
        padding: 24px 20px;
        gap: 8px;
    }

    .lp-projects-slide-title {
        font-size: 18px;
    }

    .lp-projects-slide-cta {
        font-size: 12px;
    }
}

/* Projects responsive */
@media (max-width: 1200px) {
    .lp-projects {
        padding: 80px 48px;
    }

    .lp-projects-track,
    .lp-projects-slide {
        min-height: 375px;
    }
}

@media (max-width: 768px) {
    .lp-projects {
        padding: 64px 24px;
        gap: 40px;
    }

    .lp-projects-title {
        font-size: 36px;
        line-height: 1.2;
    }

    .lp-projects-btn {
        width: 60px;
        height: 60px;
        padding: 16px;
    }

    .lp-projects-track,
    .lp-projects-slide {
        min-height: 263px;
    }
}

@media (max-width: 480px) {
    .lp-projects {
        padding: 48px 16px;
    }

    .lp-projects-title {
        font-size: 28px;
    }

    .lp-projects-track,
    .lp-projects-slide {
        min-height: 210px;
    }
}

/* ===== Contact Section ===== */
.lp-contact {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 160px 108px;
    gap: 56px;
    min-height: 608px;
    background-color: #1B1B1B;
    background-image: linear-gradient(rgba(27, 27, 27, 0.75), rgba(27, 27, 27, 0.75));
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.lp-contact-inner {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 48px;
    max-width: 1224px;
    width: 100%;
}

.lp-contact-header {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 16px;
    text-align: center;
}

.lp-contact-title {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 12px;
    margin: 0;
    font-size: 48px;
    line-height: 60px;
}

.lp-contact-title-white {
    font-family: 'Raleway', sans-serif;
    font-style: normal;
    font-weight: 400;
    color: #FFFFFF;
}

.lp-contact-title-yellow {
    font-family: 'Playfair Display', serif;
    font-style: italic;
    font-weight: 400;
    color: #FFC900;
}

.lp-contact-subtitle {
    font-family: 'Open Sans', sans-serif;
    font-style: normal;
    font-weight: 600;
    font-size: 24px;
    line-height: 32px;
    text-align: center;
    color: #A2A2A1;
    margin: 0;
    max-width: 560px;
}

.lp-contact-btns {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: flex-start;
    justify-content: center;
    gap: 23px;
    width: 100%;
}

.lp-contact-btn-col {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    max-width: 100%;
}

.lp-contact-btn-copy-email {
    appearance: none;
    -webkit-appearance: none;
    border: none;
    font: inherit;
    cursor: pointer;
    text-align: center;
}

.lp-contact-btn-copy-email:focus {
    outline: 2px solid #FFFFFF;
    outline-offset: 3px;
}

.lp-copy-toast {
    position: fixed;
    bottom: 28px;
    left: 50%;
    z-index: 1000001;
    max-width: min(420px, calc(100% - 32px));
    padding: 14px 22px;
    box-sizing: border-box;
    font-family: 'Open Sans', sans-serif;
    font-weight: 600;
    font-size: 15px;
    line-height: 1.35;
    text-align: center;
    color: #E8E8E7;
    background: #1B1B1B;
    border: 1px solid #FFC900;
    box-shadow: 0 10px 32px rgba(0, 0, 0, 0.45);
    transform: translateX(-50%) translateY(12px);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.28s ease, transform 0.28s ease, visibility 0.28s;
}

.lp-copy-toast.lp-copy-toast--visible {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
}

.lp-contact-btn {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    padding: 24px 32px;
    gap: 8px;
    min-width: 392px;
    height: 80px;
    box-sizing: border-box;
    font-family: 'Raleway', sans-serif;
    font-style: normal;
    font-weight: 700;
    font-size: 24px;
    line-height: 32px;
    letter-spacing: 0.04em;
    text-decoration: none;
    transition: background 0.2s, border-color 0.2s, color 0.2s;
}

.lp-contact-btn-primary {
    background: #FFC900;
    border: none;
    color: #1B1B1B;
}

.lp-contact-btn-primary:hover {
    background: #e6b500;
}

.lp-contact-btn-outline,
.lp-contact-btn-outline:link,
.lp-contact-btn-outline:visited {
    background: transparent;
    border: 1px solid #FFC900;
    color: #FFFFFF;
}

.lp-contact-btn-outline:hover {
    background: rgba(255, 204, 0, 0.15);
    color: #FFFFFF;
}

/* Contact responsive */
@media (max-width: 1200px) {
    .lp-contact {
        padding: 120px 48px;
    }

    .lp-contact-btn {
        min-width: 280px;
    }
}

@media (max-width: 768px) {
    .lp-contact {
        padding: 80px 24px;
        gap: 40px;
    }

    .lp-contact-title {
        font-size: 36px;
        line-height: 1.2;
    }

    .lp-contact-subtitle {
        font-size: 20px;
    }

    .lp-contact-btns {
        flex-direction: column;
        flex-wrap: nowrap;
        align-items: center;
        justify-content: center;
        width: 100%;
        gap: 28px;
    }

    .lp-contact-btn-col {
        width: 100%;
        max-width: 392px;
    }

    .lp-contact-btn {
        min-width: 0;
        width: 100%;
        max-width: 392px;
    }
}

@media (max-width: 480px) {
    .lp-contact {
        padding: 64px 16px;
    }

    .lp-contact-title {
        font-size: 32px;
        column-gap: 8px;
        row-gap: 0;
    }

    .lp-contact-subtitle {
        font-size: 18px;
    }

    .lp-contact-btn {
        height: 54px;
        font-size: 16px;
    }
}

/* ===== Process Section ===== */
.lp-process {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-start;
    padding: 128px 108px;
    gap: 56px;
    isolation: isolate;
    background: #FFFCF2;
    overflow: hidden;
}

.lp-process-diagram {
    position: absolute;
    width: 635px;
    height: 320px;
    right: 0;
    top: -16px;
    background-size: contain;
    background-position: right top;
    background-repeat: no-repeat;
    transform: scaleX(-1);
    z-index: 2;
}

.lp-process-inner {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    gap: 56px;
    width: 100%;
    max-width: 1224px;
    margin: 0 auto;
}

.lp-process-header {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
}

.lp-process-title-wrap {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 24px;
}

.lp-process-title {
    display: flex;
    flex-direction: row;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 12px;
    margin: -8px 0 0;
    font-size: 48px;
    line-height: 24px;
    max-width: 70%;
}

.lp-process-title-brown {
    font-family: 'Raleway', sans-serif;
    font-style: normal;
    font-weight: 400;
    color: #3B2F2B;
}

.lp-process-title-yellow {
    font-family: 'Playfair Display', serif;
    font-style: italic;
    font-weight: 400;
    font-size: 48px;
    line-height: 60px;
    color: #FFC900;
}

.lp-process-subtitle {
    font-family: 'Open Sans', sans-serif;
    font-style: normal;
    font-weight: 600;
    font-size: 24px;
    line-height: 33px;
    color: #494949;
    margin: 0;
}

.lp-process-steps {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    gap: 0;
    width: 100%;
}

.lp-process-step {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    padding: 48px;
    gap: 32px;
    flex: 1;
    min-height: 380px;
    background: #FFFFFF;
    border: 1px solid #EAEAEA;
}

.lp-process-step-num {
    font-family: 'Open Sans', sans-serif;
    font-style: normal;
    font-weight: 300;
    font-size: 96px;
    line-height: 128px;
    color: #FFC900;
}

.lp-process-step-content {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
}

.lp-process-step-title {
    font-family: 'Open Sans', sans-serif;
    font-style: normal;
    font-weight: 600;
    font-size: 24px;
    line-height: 32px;
    color: #494949;
    margin: 0;
}

.lp-process-step-desc {
    font-family: 'Open Sans', sans-serif;
    font-style: normal;
    font-weight: 600;
    font-size: 16px;
    line-height: 24px;
    color: #A2A2A1;
    margin: 0;
}

/* Process responsive */
@media (max-width: 1200px) {
    .lp-process {
        padding: 80px 48px;
    }

    .lp-process-diagram {
        width: 400px;
        height: 200px;
    }
}

@media (max-width: 992px) {
    .lp-process-steps {
        flex-wrap: wrap;
    }

    .lp-process-step {
        flex: 1 1 calc(50% - 1px);
        min-width: 280px;
    }

    .lp-process-diagram {
        opacity: 1;
    }
}

@media (max-width: 768px) {
    .lp-process {
        padding: 64px 24px;
        gap: 40px;
    }

    .lp-process-title {
        font-size: 36px;
        line-height: 1.2;
    }

    .lp-process-title-yellow {
        font-size: 36px;
        line-height: 1.2;
    }

    .lp-process-subtitle {
        font-size: 20px;
    }

    .lp-process-step {
        flex: 1 1 100%;
        min-height: auto;
        padding: 32px 24px;
    }

    .lp-process-step-num {
        font-size: 72px;
        line-height: 1;
    }

    .lp-process-diagram {
        width: 55%;
        height: auto;
        min-height: 140px;
    }
}

@media (max-width: 480px) {
    .lp-process {
        padding: 48px 16px;
    }

    .lp-process-title {
        font-size: 32px;
        gap: 0;
    }

    .lp-process-title-yellow {
        font-size: 32px;
    }

    .lp-process-subtitle {
        font-size: 18px;
    }
}

/* ===== Consultation Section ===== */
.lp-consult {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    padding: 112px 108px;
    gap: 56px;
    isolation: isolate;
    background: #F8F8F8;
    overflow: hidden;
}

.lp-consult-ellipse-white {
    position: absolute;
    width: 1239px;
    height: 1239px;
    left: 101px;
    top: -505px;
    background: #FFFFFF;
    filter: blur(128px);
    z-index: 0;
}

.lp-consult-inner {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    gap: 56px;
    width: 100%;
    max-width: 1224px;
    margin: 0 auto;
}

.lp-consult-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    width: 100%;
}

.lp-consult-title {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 12px;
    margin: 0;
    font-size: 48px;
    line-height: 60px;
}

.lp-consult-title-dark {
    font-family: 'Raleway', sans-serif;
    font-style: normal;
    font-weight: 400;
    color: #1B1B1B;
}

.lp-consult-title-yellow {
    font-family: 'Playfair Display', serif;
    font-style: italic;
    font-weight: 400;
    color: #FFC900;
}

.lp-consult-subtitle {
    font-family: 'Open Sans', sans-serif;
    font-style: normal;
    font-weight: 600;
    font-size: 24px;
    line-height: 33px;
    text-align: center;
    color: #494949;
    margin: 0;
}

.lp-consult-content {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: 56px;
    width: 100%;
}

.lp-consult-form-wrap {
    flex: none;
    z-index: 2;
}

.lp-consult-form-box {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 48px;
    gap: 32px;
    width: 600px;
    background: #FFFFFF;
    box-shadow: 0px 16px 32px 8px rgba(0, 0, 0, 0.12);
}

.lp-consult-form-title {
    font-family: 'Open Sans', sans-serif;
    font-style: normal;
    font-weight: 600;
    font-size: 24px;
    line-height: 33px;
    color: #494949;
    margin: 0;
}

.lp-consult-form {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 32px;
    width: 100%;
}

.lp-consult-fields {
    display: flex;
    flex-direction: column;
    gap: 24px;
    width: 100%;
}

.lp-consult-field {
    display: flex;
    flex-direction: column;
    gap: 12px;
    width: 100%;
}

.lp-consult-label {
    font-family: 'Open Sans', sans-serif;
    font-style: normal;
    font-weight: 700;
    font-size: 16px;
    line-height: 22px;
    color: #494949;
}

.lp-consult-input {
    box-sizing: border-box;
    display: flex;
    align-items: center;
    padding: 16px 24px;
    width: 100%;
    height: 54px;
    background: #FFFFFF;
    border: 1px solid #EAEAEA;
    font-family: 'Open Sans', sans-serif;
    font-weight: 600;
    font-size: 16px;
    line-height: 22px;
    color: #494949;
}

.lp-consult-input::placeholder {
    color: #494949;
    opacity: 0.56;
}

.lp-consult-input:focus {
    outline: none;
    border-color: #FFC900;
}

.lp-consult-select {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Cpath fill='%23A2A2A1' d='M4 6l4 4 4-4z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 16px center;
    padding-right: 44px;
}

.lp-consult-consent {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: 16px;
    width: 100%;
}

.lp-consult-checkbox {
    box-sizing: border-box;
    width: 32px;
    height: 32px;
    min-width: 32px;
    background: #FFFFFF;
    border: 1px solid #EAEAEA;
    cursor: pointer;
    margin: 0;
    accent-color: #FFC900;
}

.lp-consult-consent-text {
    font-family: 'Open Sans', sans-serif;
    font-style: normal;
    font-weight: 600;
    font-size: 12px;
    line-height: 16px;
    color: #3B2F2B;
    opacity: 0.56;
    margin: 0;
    cursor: pointer;
}

.lp-consult-submit {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    padding: 24px 32px;
    width: 100%;
    height: 72px;
    background: #FFC900;
    border: none;
    font-family: 'Raleway', sans-serif;
    font-weight: 700;
    font-size: 24px;
    line-height: 24px;
    letter-spacing: 0.04em;
    color: #1B1B1B;
    cursor: pointer;
    transition: background 0.2s ease;
}

.lp-consult-submit:hover {
    background: #e6b500;
}

.lp-consult-image-wrap {
    position: relative;
    flex: 1;
    min-height: 536px;
    min-width: 400px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.lp-consult-ellipse-yellow {
    position: absolute;
    width: 512px;
    height: 512px;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    background: #FFC900;
    border-radius: 50%;
}

.lp-consult-image {
    position: relative;
    width: 512px;
    height: 536px;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    z-index: 1;
}

/* Consultation responsive */
@media (max-width: 1200px) {
    .lp-consult {
        padding: 80px 48px;
    }

    .lp-consult-content {
        flex-direction: column;
        align-items: center;
    }

    .lp-consult-image-wrap {
        min-width: 100%;
        min-height: 400px;
    }

    .lp-consult-ellipse-yellow {
        width: 400px;
        height: 400px;
    }

    .lp-consult-image {
        width: 100%;
        max-width: 512px;
        height: 400px;
    }
}

@media (max-width: 768px) {
    .lp-consult {
        padding: 64px 24px;
        gap: 40px;
    }

    .lp-consult-content {
        flex-direction: column-reverse;
        align-items: center;
    }

    .lp-consult-form-box {
        width: 100%;
        padding: 32px 24px;
    }

    .lp-consult-title {
        font-size: 36px;
        line-height: 1.2;
    }

    .lp-consult-title-yellow {
        font-size: 36px;
    }

    .lp-consult-subtitle {
        font-size: 20px;
    }

    .lp-consult-image-wrap {
        min-height: 300px;
    }

    .lp-consult-ellipse-yellow {
        width: 300px;
        height: 300px;
    }

    .lp-consult-image {
        height: 300px;
    }

    /* Jak formularz u góry (.lp-submit) */
    .lp-consult-submit {
        height: 52px;
        font-size: 14px;
    }
}

@media (max-width: 480px) {
    .lp-consult {
        padding: 48px 16px;
    }

    .lp-consult-title {
        font-size: 28px;
    }

    .lp-consult-title-yellow {
        font-size: 28px;
    }

    .lp-consult-subtitle {
        font-size: 18px;
    }

    /* Jak formularz hero (.lp-form-title, .lp-form, .lp-field, .lp-label, .lp-input) */
    .lp-consult-form-title {
        font-size: 18px;
        line-height: 28px;
    }

    .lp-consult-form {
        gap: 12px;
    }

    .lp-consult-fields {
        gap: 12px;
    }

    .lp-consult-field {
        gap: 8px;
    }

    .lp-consult-label {
        font-size: 12px;
        line-height: 22px;
    }

    .lp-consult-input {
        padding: 12px 24px;
        height: 46px;
        font-size: 12px;
        line-height: 22px;
    }

    .lp-consult-submit {
        height: 52px;
        font-size: 14px;
    }
}

/* ===== Modal potwierdzenia wysłania ===== */
.lp-modal {
	position: fixed;
	inset: 0;
	z-index: 1000000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
	box-sizing: border-box;
}

.lp-modal[hidden] {
	display: none !important;
}

.lp-modal-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(27, 27, 27, 0.6);
	cursor: pointer;
}

.lp-modal-content {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 48px;
	gap: 24px;
	max-width: 480px;
	width: 100%;
	background: #FFFFFF;
	box-shadow: 0px 16px 32px 8px rgba(0, 0, 0, 0.12);
	border-radius: 0;
	box-sizing: border-box;
}

.lp-modal-close {
	position: absolute;
	top: 16px;
	right: 16px;
	width: 40px;
	height: 40px;
	padding: 0;
	background: transparent;
	border: none;
	font-size: 28px;
	line-height: 1;
	color: #494949;
	cursor: pointer;
	transition: color 0.2s ease;
}

.lp-modal-close:hover {
	color: #1B1B1B;
}

.lp-modal-title {
	font-family: 'Raleway', sans-serif;
	font-weight: 400;
	font-size: 32px;
	line-height: 1.2;
	color: #1B1B1B;
	margin: 0;
	text-align: center;
}

.lp-modal-text {
	font-family: 'Open Sans', sans-serif;
	font-weight: 600;
	font-size: 16px;
	line-height: 24px;
	color: #494949;
	margin: 0;
	text-align: center;
}

.lp-modal-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 16px 48px;
	min-width: 160px;
	height: 56px;
	background: #FFC900;
	border: none;
	font-family: 'Raleway', sans-serif;
	font-weight: 700;
	font-size: 18px;
	line-height: 24px;
	letter-spacing: 0.02em;
	color: #1B1B1B;
	cursor: pointer;
	transition: background 0.2s ease;
}

.lp-modal-btn:hover {
	background: #e6b500;
}

/* Modal z pełnym formularzem lead (strona główna) */
.lp-modal--form .lp-modal-content--form {
	max-width: 560px;
	align-items: stretch;
	max-height: min(90vh, 900px);
	overflow-y: auto;
	padding: 40px 40px 48px;
}

.lp-modal--form .lp-form-box--modal {
	width: 100%;
	max-width: none;
	box-shadow: none;
	border: none;
	padding: 0;
	margin: 0;
}

.lp-modal--form .lp-form-title {
	text-align: left;
	margin-bottom: 8px;
}

/* ===== Clients Section ===== */
.lp-clients {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 112px 0;
    gap: 24px;
    background: #FFFFFF;
}

.lp-clients-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
    width: 100%;
    max-width: 1225px;
    margin: 0 auto;
}

.lp-clients-title {
    font-family: 'Open Sans', sans-serif;
    font-style: normal;
    font-weight: 600;
    font-size: 24px;
    line-height: 32px;
    text-align: center;
    color: #494949;
    margin: 0;
}

.lp-clients-content {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 107px;
    width: 100%;
}

.lp-clients-item {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 8px;
    gap: 8px;
    flex: 1;
    max-width: 316px;
}

.lp-clients-logo {
    width: 256px;
    height: 97px;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    opacity: 0.8;
}

/* Marquee logotypów (clients-slider): 4 na widok, wolniejszy ruch */
.lp-clients--marquee .lp-clients-inner {
    align-items: flex-start;
    max-width: 100%;
}

.lp-clients--marquee .lp-clients-title {
    text-align: left;
    width: 100%;
    font-size: 24px;
    padding-left: 108px;
    padding-right: 108px;
}

.lp-clients-marquee-view {
    container-type: inline-size;
    container-name: lp-clients-marquee;
    overflow: hidden;
    width: 100%;
    /* max-width: 1225px; */
    align-self: stretch;
    --lp-clients-marquee-gap: 40px;
}

.lp-clients-marquee-track {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    gap: var(--lp-clients-marquee-gap);
    width: max-content;
    will-change: transform;
    animation: lp-clients-marquee-scroll 60s linear infinite;
}

@keyframes lp-clients-marquee-scroll {
    from { transform: translateX(0); }
    to { transform: translateX(-50%); }
}

@media (prefers-reduced-motion: reduce) {
    .lp-clients-marquee-track {
        animation: none;
    }
}

.lp-clients-marquee-item {
    flex: 0 0 auto;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    width: 240px;
    min-width: 0;
}

/* Szerokość „4 na widok” tylko gdy przeglądarka zna cqi — unikamy całkiem nieważnego width w starszych silnikach */
@supports (width: 1cqi) {
    .lp-clients-marquee-item {
        width: calc((100cqi - 3 * var(--lp-clients-marquee-gap)) / 4);
    }
}

.lp-clients-marquee-item .logos-slider__photo {
    max-height: 97px;
    width: auto;
    max-width: 100%;
    height: auto;
    object-fit: contain;
}

/* Clients responsive */
@media (max-width: 1200px) {
    .lp-clients {
        padding: 80px 48px;
    }

    .lp-clients-content {
        gap: 48px;
    }
}

@media (max-width: 768px) {
    .lp-clients {
        padding: 64px 24px;
        gap: 32px;
    }

    .lp-clients-content {
        flex-direction: column;
        gap: 32px;
    }

    .lp-clients-item {
        max-width: 100%;
    }

    .lp-clients-logo {
        width: 200px;
        height: 76px;
    }

    .lp-clients--marquee .lp-clients-title {
        text-align: left;
        width: 100%;
        font-size: 24px;
        padding-left: 0;
        padding-right: 0;
    }
}

@media (max-width: 480px) {
    .lp-clients {
        padding: 48px 16px;
    }

    .lp-clients-title {
        font-size: 20px;
    }

    .lp-clients-logo {
        width: 180px;
        height: 68px;
    }
}

/* Komponent clients-slider (.logos) — nagłówek sekcji */
.logos h2.section-header {
    font-family: 'Open Sans', sans-serif;
    font-style: normal;
    font-weight: 600;
    font-size: 24px;
    line-height: 32px;
    text-align: center;
    color: #494949;
    margin-bottom: 24px;
    margin-top: 100px;
}

.logos-slider__item img {
    max-height: 150px;
    object-fit: contain;
}

.slick-initialized .slick-slide {
    text-align: -webkit-center;
}
