/*!
Theme Name: Pixy Theme Child
Theme URI: https://bslthemes.com/
Author: bslthemes
Author URI: https://themeforest.net/user/bslthemes
Description: Pixy - Creative Portfolio WordPress Theme
Version: 1.1.9
License: General Public License
License URI: http://www.gnu.org/licenses/gpl.html
Template: pixy-theme
Text Domain: pixy-theme-child
Tags: full-width-template, editor-style, featured-images, sticky-post, threaded-comments, translation-ready, theme-options
*/

/* ==========================================================================
   TABLE OF CONTENTS
   ==========================================================================
   1. CSS Variables
   2. Global Fixes (ScrollSmoother, Animations)
   3. Header & Navigation
   4. Typography & Text Styles
   5. Buttons - Common Styles
   6. Buttons - Stylized (Square with arrow)
   7. Buttons - Pill (Rounded)
   8. Services Section
   9. Portfolio Grid
   10. Team Section
   11. Blog Cards & Grid
   12. Blog Single Post
   13. Footer
   14. CTA Sections
   15. Decorative Elements (Waves)
   16. Responsive - Tablet (max 1024px)
   17. Responsive - Mobile (max 767px)
   18. Responsive - Small Mobile (max 500px)
   19. SVG Icon Fixes
   20. Mobile Menu Styling
   ========================================================================== */


/* ==========================================================================
   1. CSS VARIABLES
   ========================================================================== */
:root {
    /* Brand Colors */
    --tw-purple: #B8A8D0;
    --tw-purple-light: #c5b4d8;
    --tw-purple-dark: #cac9e2;
    --tw-blue: #6599cc;
    --tw-pink: #f6bed9;
    --tw-gray: #D8D8D8;
    --tw-dark: #353639;

    /* Gradients */
    --tw-gradient: linear-gradient(90deg, var(--tw-blue) 0%, var(--tw-purple-light) 50%, var(--tw-pink) 100%);
    --tw-gradient-text: linear-gradient(90deg, var(--tw-blue) 0%, var(--tw-pink) 100%);

    /* Blog */
    --tw-blog-img-radius: 24px;

    /* Pagination */
    --tw-pag-size: 54px;
    --tw-pag-gap: 14px;
    --tw-pag-bg: var(--tw-gray);
    --tw-pag-active: var(--tw-purple);
    --tw-pag-hover: var(--tw-purple-light);
    --tw-pag-text: #fff;

    /* Navigation */
    --tw-nav-bg: var(--tw-gray);
    --tw-nav-bg-hover: var(--tw-purple-light);
    --tw-nav-text: #fff;
    --tw-nav-h: 44px;
    --tw-nav-radius: 999px;

    /* Assets */
    --tw-arrow-icon: url("https://threewaves.agency/wp-content/uploads/2025/11/0056_2025_10_button_strzalka-1.svg");
}


/* ==========================================================================
   2. GLOBAL FIXES
   ========================================================================== */
/* Safety: when native scroll is enabled, do not allow team image scale transforms */
body.tw-native-scroll .mil-scale-img,
body.tw-native-scroll .mil-scale-img img {
    transform: none !important;
    will-change: auto !important;
}


/* Hero wave placeholder - gradient background shown while image loads
   Prevents visual "pop" when wave image appears */
.elementor-element-b223da5 {
    background: linear-gradient(135deg,
        rgba(101, 153, 204, 0.15) 0%,
        rgba(197, 180, 216, 0.2) 50%,
        rgba(246, 190, 217, 0.15) 100%);
}

/* ScrollSmoother - Pre-apply styles to prevent layout shift
   Exclude Elementor editor to allow scrolling when editing */
body:not(.elementor-editor-active) #smooth-wrapper {
    position: fixed;
    inset: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

body:not(.elementor-editor-active) #smooth-content {
    width: 100%;
    overflow: visible;
}

/* Native scroll mode - disable ScrollSmoother fixed positioning on mobile */
body.tw-native-scroll #smooth-wrapper {
    position: static !important;
    overflow: visible !important;
    width: auto !important;
    height: auto !important;
    inset: auto !important;
}

body.tw-native-scroll #smooth-content {
    overflow: visible !important;
    width: auto !important;
    height: auto !important;
    transform: none !important;
}

/* Nested mil-up fix - Elements processed by JS to prevent double animation */
.mil-up-nested {
    opacity: 1 !important;
    transform: none !important;
}

/* Override theme's global opacity:0 for animations */
.mil-mb60 {
    margin-bottom: 24px;
}


/* ==========================================================================
   3. HEADER & NAVIGATION
   ========================================================================== */


/* Header hide-on-scroll behavior */
.mil-top-panel-2,
.mil-top-panel {
    will-change: transform;
}

.mil-top-panel-2.tw-header-hidden,
.mil-top-panel.tw-header-hidden {
    transform: translateY(-110%);
}

/* Logo link fix - prevent shrinking when link is added in Elementor
   Elementor has: .elementor-widget-image a img[src$=".svg"] { width: 48px }
   This forces SVG logos to 48px. Override with !important. */
.mil-top-panel .elementor-widget-image a img,
.mil-top-panel-2 .elementor-widget-image a img {
    width: auto !important;
    height: auto !important;
    max-height: 80px;
}

/* Header base state */
.mil-top-panel,
.mil-wrapper-header,
.mil-top-panel-2 {
    background: transparent;
    transition: background-color .25s ease, box-shadow .25s ease, backdrop-filter .25s ease, transform .3s ease;
    backdrop-filter: none;
}

/* Header scrolled state */
html.is-scrolled .mil-top-panel,
html.is-scrolled .mil-wrapper-header,
html.is-scrolled .mil-top-panel-2 {
    background: #ffffff;
    box-shadow: 0 8px 24px rgba(0, 0, 0, .06);
    backdrop-filter: none;
}

html.is-scrolled .mil-top-panel .mil-logo,
html.is-scrolled .mil-top-panel .mil-buttons-tp-frame {
    background: transparent;
}

/* Custom navigation menu [tw_menu] */
.tw-nav {
    display: flex;
    gap: 40px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.tw-nav a {
    font-family: "Poppins", sans-serif;
    font-size: clamp(11px, 1vw, 18px);
    font-weight: 500;
    letter-spacing: 0;
    text-transform: none;
    text-decoration: none;
    color: var(--tw-dark);
}

.tw-nav a:hover,
.tw-nav a:focus {
    color: var(--tw-purple-light);
    outline: none;
}

.tw-nav .current-menu-item > a,
.tw-nav .current_page_item > a,
.tw-nav .current-menu-ancestor > a,
.tw-nav a[aria-current="page"] {
    color: var(--tw-purple-light);
}

/* Header CTA button */
.tw-cta-btn,
.tw-cta-btn * {
    box-sizing: border-box;
}

.tw-cta-btn {
    --purple: var(--tw-purple);
    --grad-pill: linear-gradient(90deg, var(--tw-blue) 0%, var(--tw-purple-light) 100%);
    --grad-circle: linear-gradient(90deg, var(--tw-purple-light) 0%, var(--tw-pink) 100%);

    position: relative;
    display: inline-flex;
    align-items: center;
    padding: clamp(10px, 1.4vw, 22px);
    border-radius: 999px;
    background: var(--purple);
    color: #fff;
    font-size: clamp(11px, 1vw, 16px);
    font-weight: 500;
    line-height: 1;
    font-family: inherit;
    text-decoration: none;
    cursor: pointer;
    overflow: visible;
    transition: transform .15s ease;
}

/* Gradient overlay for pill - opacity transition for smooth effect */
.tw-cta-btn::before {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--grad-pill);
    opacity: 0;
    transition: opacity 0.4s ease;
    z-index: 0;
    border-radius: 999px;
}

.tw-cta-btn__text {
    position: relative;
    z-index: 1;
    white-space: nowrap;
}

.tw-cta-btn__circle {
    position: absolute;
    right: calc(-1 * clamp(34px, 3.8vw, 64px));
    top: 50%;
    transform: translateY(-50%);
    width: clamp(34px, 3.8vw, 64px);
    height: clamp(34px, 3.8vw, 64px);
    border-radius: 999px;
    background: var(--purple);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

/* Gradient overlay for circle - opacity transition for smooth effect */
.tw-cta-btn__circle::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 999px;
    background: var(--grad-circle);
    opacity: 0;
    transition: opacity 0.4s ease;
    z-index: 0;
}

.tw-cta-btn__circle img {
    position: relative;
    z-index: 1;
    width: clamp(12px, 1.1vw, 18px);
    height: clamp(12px, 1.1vw, 18px);
    display: block;
    transition: transform .25s ease;
    filter: brightness(0) invert(1);
}

.tw-cta-btn:hover {
    transform: translateY(-1px);
}

.tw-cta-btn:hover::before {
    opacity: 1;
}

.tw-cta-btn:hover .tw-cta-btn__circle::before {
    opacity: 1;
}

.tw-cta-btn:hover .tw-cta-btn__circle img {
    transform: translateX(2px);
}

.cmplz-cookiebanner,
.cmplz-cookiebanner-container,
.cmplz-manage-consent,
.cmplz-consent,
.cmplz-overlay,
.cmplz-soft-cookiewall,
.cmplz-soft-cookiewall-overlay {
    z-index: 2147483647 !important;
}

/* ==========================================================================
   4. TYPOGRAPHY & TEXT STYLES
   ========================================================================== */

.line {
    display: block;
}

/* Hero text styles */
.tw-hero-accent {
    font-style: italic;
    font-weight: 600;
    font-size: clamp(44px, 6.5vw, 110px);
    display: inline-block;
}

.tw-hero-caption {
    font-size: clamp(20px, 3vw, 54px);
    font-weight: 300;
}

.tw-hero-caption-2 {
    font-size: clamp(18px, 2.0vw, 28px);
    font-weight: 300;
    display: inline-block;
    line-height: 1.45;
    margin-top: 22px;
}

.tw-hero-title {
    font-weight: 600;
    font-style: italic;
    display: inline;
}

.tw-hero-info {
    font-weight: 700;
    font-style: italic;
    display: inline-block;
}

.tw-industries {
    font-weight: 800;
    font-style: italic;
    display: inline-block;
}

/* Gradient text styles */
.gradient-h2 {
    background: var(--tw-gradient-text);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    display: inline-block;
    font-style: italic;
    font-weight: 800;
    padding-left: .08em;
    padding-right: .08em;
    padding-bottom: .08em;
    margin-left: -.08em;
}

.gradient-h3 {
    background: var(--tw-gradient-text);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    display: inline-block;
    font-style: italic;
}

.gradient-cta2 {
    background: var(--tw-gradient-text);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    display: inline-block;
    font-style: italic;
    font-weight: 600;
}

.team-hover {
    background: var(--tw-gradient-text);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    display: inline-block;
}

/* Size styles */
@media (max-width: 768px) {
    .mil-head1 {
        font-size: 32px;
    }
    .mil-head2 {
        font-size: 30px;
    }
    .mil-head3 {
        font-size: 28px;
    }
}

/* ==========================================================================
   5. BUTTONS - COMMON STYLES
   ========================================================================== */

/* Arrow icon mixin - used by multiple button types */


/* ==========================================================================
   6. BUTTONS - STYLIZED (Square with arrow)
   Common styles for services, blog, portfolio, footer buttons
   ========================================================================== */

/* Base stylized button */
.mil-service-item .mil-stylized-btn,
.mil-service-card-lg .mil-stylized-btn,
.mil-blog-card .mil-stylized-btn,
.mil-footer-contact .mil-stylized-btn,
.mil-work-card .mil-hover-overlay .mil-stylized-btn.mil-a1 {
    position: relative;
    padding: 16px;
    border-radius: 16px;
    background: var(--tw-purple);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-start;
    transition: background .25s ease, transform .2s ease;
}

/* Size variations */
.mil-service-item .mil-stylized-btn,
.mil-service-card-lg .mil-stylized-btn,
.mil-work-card .mil-hover-overlay .mil-stylized-btn.mil-a1 {
    width: 140px;
    height: 140px;
}

/* Portfolio button - only round inner corner (bottom-right), square on card edges */
/* Gray background instead of purple (like footer "Kontakt" button) */
.mil-work-card .mil-hover-overlay .mil-stylized-btn.mil-a1 {
    border-radius: 0 0 16px 0 !important;
    background: var(--tw-gray) !important;
}

/* Service card "Zobacz ofertę" button - gray background */
.mil-service-card-lg .mil-stylized-btn {
    background: var(--tw-gray) !important;
}

/* Also fix the gradient overlay pseudo-element */
.mil-work-card .mil-hover-overlay .mil-stylized-btn.mil-a1::before {
    border-radius: 0 0 16px 0 !important;
}

.mil-blog-card .mil-stylized-btn {
    width: 120px;
    height: 120px;
    padding: 14px;
}

.mil-footer-contact .mil-stylized-btn {
    width: 160px;
    height: 160px;
    padding: 20px;
    border-radius: 18px;
}

/* Button text */
.mil-service-item .mil-stylized-btn span,
.mil-service-card-lg .mil-stylized-btn span,
.mil-blog-card .mil-stylized-btn span,
.mil-footer-contact .mil-stylized-btn span,
.mil-work-card .mil-hover-overlay .mil-stylized-btn.mil-a1 span {
    padding: 0;
    width: auto;
    text-transform: none;
    line-height: 1.1;
    color: #fff;
}

.mil-service-item .mil-stylized-btn span {
    font-size: 20px;
    font-weight: 600;
}

.mil-service-card-lg .mil-stylized-btn span,
.mil-blog-card .mil-stylized-btn span,
.mil-work-card .mil-hover-overlay .mil-stylized-btn.mil-a1 span {
    font-size: 16px;
    font-weight: 300;
}

.mil-blog-card .mil-stylized-btn span {
    line-height: 1.2;
    font-family: inherit;
    letter-spacing: 0;
}

.mil-footer-contact .mil-stylized-btn span {
    font-size: 22px;
    font-weight: 300;
}

/* Hide FontAwesome icons */
.mil-service-item .mil-stylized-btn i,
.mil-service-card-lg .mil-stylized-btn i,
.mil-blog-card .mil-stylized-btn i,
.mil-footer-contact .mil-stylized-btn i,
.mil-work-card .mil-hover-overlay .mil-stylized-btn.mil-a1 i {
    display: none;
}

/* Arrow icon */
.mil-service-item .mil-stylized-btn::after,
.mil-service-card-lg .mil-stylized-btn::after,
.mil-blog-card .mil-stylized-btn::after,
.mil-footer-contact .mil-stylized-btn::after,
.mil-work-card .mil-hover-overlay .mil-stylized-btn.mil-a1::after {
    content: "";
    position: absolute;
    top: 8px;
    right: 2px;
    background: var(--tw-arrow-icon) no-repeat center / contain;
    transform-origin: center center;
    transform: rotate(-45deg);
    transition: transform .25s ease;
    z-index: 2;
}

.mil-service-item .mil-stylized-btn::after,
.mil-service-card-lg .mil-stylized-btn::after,
.mil-work-card .mil-hover-overlay .mil-stylized-btn.mil-a1::after {
    width: 50px;
    height: 50px;
}

.mil-blog-card .mil-stylized-btn::after {
    width: 40px;
    height: 40px;
    right: 4px;
}

.mil-footer-contact .mil-stylized-btn::after {
    width: 60px;
    height: 60px;
    top: 10px;
    right: 6px;
}

/* Gradient overlay for smooth hover transition */
.mil-service-item .mil-stylized-btn::before,
.mil-service-card-lg .mil-stylized-btn::before,
.mil-blog-card .mil-stylized-btn::before,
.mil-footer-contact .mil-stylized-btn::before,
.mil-work-card .mil-hover-overlay .mil-stylized-btn.mil-a1::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: var(--tw-gradient);
    opacity: 0;
    transition: opacity 0.4s ease;
    z-index: 0;
}

/* Hover state - fade in gradient */
.mil-service-item .mil-stylized-btn:hover::before,
.mil-service-item .mil-stylized-btn:focus-visible::before,
.mil-service-card-lg .mil-stylized-btn:hover::before,
.mil-service-card-lg .mil-stylized-btn:focus-visible::before,
.mil-blog-card .mil-stylized-btn:hover::before,
.mil-blog-card .mil-stylized-btn:focus-visible::before,
.mil-footer-contact .mil-stylized-btn:hover::before,
.mil-footer-contact .mil-stylized-btn:focus-visible::before,
.mil-work-card .mil-hover-overlay .mil-stylized-btn.mil-a1:hover::before,
.mil-work-card .mil-hover-overlay .mil-stylized-btn.mil-a1:focus-visible::before {
    opacity: 1;
}

/* Keep text and arrow above gradient overlay */
.mil-service-item .mil-stylized-btn span,
.mil-service-card-lg .mil-stylized-btn span,
.mil-blog-card .mil-stylized-btn span,
.mil-footer-contact .mil-stylized-btn span,
.mil-work-card .mil-hover-overlay .mil-stylized-btn.mil-a1 span {
    position: relative;
    z-index: 1;
}

.mil-service-item .mil-stylized-btn:hover,
.mil-service-item .mil-stylized-btn:focus-visible,
.mil-service-card-lg .mil-stylized-btn:hover,
.mil-service-card-lg .mil-stylized-btn:focus-visible,
.mil-blog-card .mil-stylized-btn:hover,
.mil-blog-card .mil-stylized-btn:focus-visible,
.mil-footer-contact .mil-stylized-btn:hover,
.mil-footer-contact .mil-stylized-btn:focus-visible {
    transform: translateY(-2px);
}

.mil-service-item .mil-stylized-btn:hover::after,
.mil-service-item .mil-stylized-btn:focus-visible::after,
.mil-service-card-lg .mil-stylized-btn:hover::after,
.mil-service-card-lg .mil-stylized-btn:focus-visible::after,
.mil-blog-card .mil-stylized-btn:hover::after,
.mil-blog-card .mil-stylized-btn:focus-visible::after,
.mil-footer-contact .mil-stylized-btn:hover::after,
.mil-footer-contact .mil-stylized-btn:focus-visible::after,
.mil-work-card .mil-hover-overlay .mil-stylized-btn.mil-a1:hover::after,
.mil-work-card .mil-hover-overlay .mil-stylized-btn.mil-a1:focus-visible::after {
    transform: rotate(0deg);
}


/* ==========================================================================
   7. BUTTONS - PILL (Rounded)
   ========================================================================== */

/* Common pill button styles */
a.mil-btn.mil-btn-border.mil-c-gone.mil-m4,
a.mil-btn.mil-btn-border.mil-c-gone.mil-m1,
a.mil-btn.mil-a2.mil-c-gone,
.mil-btn.mil-btn-border.mil-c-gone.mil-m1,
.mil-btn.mil-a2.mil-c-gone {
    position: relative;
    height: 44px;
    padding: 30px 10px 30px 30px;
    border-radius: 999px;
    border: none;
    box-shadow: none;
    text-transform: none;
    letter-spacing: 0;
    font-size: 18px;
    font-weight: 400;
    line-height: 1;
    font-family: inherit;
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    transform: none;
    filter: none;
    overflow: hidden;
}

a.mil-btn.mil-btn-border.mil-c-gone.mil-m4,
a.mil-btn.mil-btn-border.mil-c-gone.mil-m1 {
    background: var(--tw-purple-dark);
}

/* Pill buttons with <a> tag and span - use CSS ::before overlay */
a.mil-btn.mil-a2.mil-c-gone,
a.mil-btn.mil-btn-border.mil-c-gone.mil-m1 {
    background: var(--tw-purple);
}

/* Pill buttons without span (div.mil-btn) - handled by JS in functions.php
   JS adds .tw-pill-purple and .tw-pill-gradient layers */
div.mil-btn.mil-a2.mil-c-gone {
    background: transparent;
}

/* Gradient overlay for pill buttons with span */
a.mil-btn.mil-a2.mil-c-gone::before,
a.mil-btn.mil-btn-border.mil-c-gone.mil-m4::before,
a.mil-btn.mil-btn-border.mil-c-gone.mil-m1::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 999px;
    background: var(--tw-gradient);
    opacity: 0;
    transition: opacity 0.4s ease;
    z-index: 0;
}

/* Hover - show gradient */
a.mil-btn.mil-a2.mil-c-gone:hover::before,
a.mil-btn.mil-btn-border.mil-c-gone.mil-m4:hover::before,
a.mil-btn.mil-btn-border.mil-c-gone.mil-m1:hover::before {
    opacity: 1;
}

/* Text stays above gradient (for buttons with span) */
a.mil-btn.mil-a2.mil-c-gone span,
a.mil-btn.mil-btn-border.mil-c-gone.mil-m4 span,
a.mil-btn.mil-btn-border.mil-c-gone.mil-m1 span {
    position: relative;
    z-index: 1;
}

/* Arrow for pill buttons */
a.mil-btn.mil-btn-border.mil-c-gone.mil-m4::after,
a.mil-btn.mil-btn-border.mil-c-gone.mil-m1::after,
a.mil-btn.mil-a2.mil-c-gone::after,
.mil-btn.mil-btn-border.mil-c-gone.mil-m1::after,
.mil-btn.mil-a2.mil-c-gone::after {
    content: "";
    position: relative;
    z-index: 1;
    width: 36px;
    height: 36px;
    display: inline-block;
    margin-left: 8px;
    background: var(--tw-arrow-icon) no-repeat center/contain;
    filter: brightness(0) invert(1);
    transition: transform .2s ease;
}

/* Arrow hover - move right */
a.mil-btn.mil-btn-border.mil-c-gone.mil-m4:hover::after,
a.mil-btn.mil-btn-border.mil-c-gone.mil-m1:hover::after,
a.mil-btn.mil-a2.mil-c-gone:hover::after,
.mil-btn.mil-btn-border.mil-c-gone.mil-m1:hover::after,
.mil-btn.mil-a2.mil-c-gone:hover::after {
    transform: translateX(2px);
}

/* MetForm submit button - styled like mil-btn with arrow
   Uses .tw-contact-button class added in Elementor for higher specificity
   Arrow is added via JS in functions.php (CSS ::after doesn't work with MetForm) */
.tw-contact-button .metform-btn.metform-submit-btn {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    padding: 14px 10px 14px 20px !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, 0.3) !important;
    color: #fff !important;
    font-size: 20px !important;
    font-weight: 500 !important;
    line-height: 1 !important;
    font-family: inherit !important;
    text-decoration: none !important;
    text-transform: none !important;
    cursor: pointer !important;
    overflow: hidden !important;
    transition: transform .15s ease !important;
    border: none !important;
    box-shadow: none !important;
    width: auto !important;
}

.tw-contact-button .mf-btn-wraper {
    width: auto !important;
    display: inline-block !important;
}

.tw-contact-button .metform-btn.metform-submit-btn:hover {
    transform: translateY(-1px) !important;
    filter: none !important;
}

/* Elementor pill buttons with solid background - use .tw-gradient-hover class
   Add this class in Elementor to buttons that should have gradient hover effect */
.elementor-widget-button.tw-gradient-hover .elementor-button,
.elementor-widget-button .elementor-button.tw-gradient-hover {
    position: relative;
    overflow: hidden;
}

.elementor-widget-button.tw-gradient-hover .elementor-button::before,
.elementor-widget-button .elementor-button.tw-gradient-hover::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: var(--tw-gradient);
    opacity: 0;
    transition: opacity 0.4s ease;
    z-index: 0;
}

.elementor-widget-button.tw-gradient-hover .elementor-button .elementor-button-content-wrapper,
.elementor-widget-button .elementor-button.tw-gradient-hover .elementor-button-content-wrapper {
    position: relative;
    z-index: 1;
}

.elementor-widget-button.tw-gradient-hover .elementor-button:hover::before,
.elementor-widget-button .elementor-button.tw-gradient-hover:hover::before {
    opacity: 1;
}


/* ==========================================================================
   8. SERVICES SECTION
   ========================================================================== */

/* Icon box */
.mil-iconbox img,
.mil-iconbox svg {
    width: 500px;
    height: auto;
}

/* Service icons */
.mil-services-list .service-ico,
.service-grid-icon {
    width: 160px;
    height: auto;
    display: block;
    justify-self: start;
}

/* Services list layout */
.mil-services-list .mil-service-item {
    display: grid;
    grid-template-columns: 180px 1fr 128px;
    gap: 100px;
    align-items: center;
    padding: 48px 24px;
}

.mil-services-list .mil-service-item + .mil-service-item {
    border-top: 1px solid rgba(0, 0, 0, .08);
}

/* Service headings gradient */
.mil-services-list .mil-item-text .mil-head3,
.mil-services-list .mil-item-text .mil-head3 span,
.mil-service-card-lg .mil-head3 {
    background: var(--tw-gradient-text);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    display: inline-block;
    font-style: italic;
    font-weight: 700;
}

.mil-services-list .mil-item-text .mil-head3,
.mil-services-list .mil-item-text .mil-head3 span {
    font-variation-settings: "wght" 800;
    letter-spacing: .2px;
}

/* Service card large */
.mil-service-card-lg .mil-text-md.mil-shortened {
    min-height: 260px;
}

/* ==========================================================================
   9. PORTFOLIO GRID
   ========================================================================== */

.mil-work-card {
    border-radius: 22px;
    overflow: hidden;
    cursor: pointer;
}

/* Hover overlay */
.mil-work-card .mil-hover-overlay,
.mil-work-card.mil-stl .mil-hover-overlay {
    --a: .6;
    background-image: none;
    background-color: transparent;
    background: linear-gradient(
        90deg,
        rgba(101, 153, 204, var(--a)) 0%,
        rgba(197, 180, 216, var(--a)) 50%,
        rgba(246, 190, 217, var(--a)) 100%
    );
}

/* Portfolio title gradient */
.elementor-widget-pixy-portfolio-grid .mil-work-card .mil-hover-overlay .mil-descr .mil-head4 {
    background: var(--tw-gradient-text);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    display: inline-block;
    font-style: italic;
    font-weight: 700;
    font-size: 30px;
}

/* Mobile: always show bottom bar, but no overlay background */
@media (max-width: 768px) {
    .mil-work-card .mil-hover-overlay {
        opacity: 1 !important;
        background: transparent !important;
    }
    .mil-work-card .mil-hover-overlay .mil-descr {
        transform: none !important;
    }
}

/* Gallery carousel */
.mil-project-img,
.mil-project-img > a {
    border-radius: 24px;
    overflow: hidden;
    display: block;
}

.mil-project-img img.mil-scale-img {
    border-radius: 24px;
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}


/* ==========================================================================
   10. TEAM SECTION
   ========================================================================== */

.mil-team-card {
    border-radius: 22px;
    overflow: hidden;
}

.mil-team-card .mil-hover-overlay,
.mil-team-card.mil-stl .mil-hover-overlay {
    --a: .6;
    background-image: none;
    background-color: transparent;
    background: linear-gradient(
        90deg,
        rgba(101, 153, 204, var(--a)) 0%,
        rgba(197, 180, 216, var(--a)) 50%,
        rgba(246, 190, 217, var(--a)) 100%
    );
    
}


.mil-team-card .mil-hover-frame {
    border-radius: 22px;
    overflow: hidden;
}

.mil-team-card .mil-hover-frame img {
    border-radius: inherit;
}

/* ==========================================================================
   11. BLOG CARDS & GRID
   ========================================================================== */

/* Blog card image */
.mil-blog-card .mil-cover {
    border-radius: var(--tw-blog-img-radius);
    overflow: hidden;
}

.mil-blog-card .mil-cover .mil-hover-frame,
.mil-blog-card .mil-cover .mil-hover-frame img {
    border-radius: var(--tw-blog-img-radius);
}

/* Badges */
.mil-blog-card .mil-cover .mil-badges div.mil-category {
    background: var(--tw-gradient);
    color: #fff;
    border: none;
}

.mil-blog-card .mil-cover .mil-badges div.mil-date {
    background: rgba(255, 255, 255, 0.98);
    color: var(--tw-dark);
    border: none;
}

/* Date badge - smaller on narrow mobile screens */
@media (max-width: 480px) {
    .mil-blog-card .mil-cover .mil-badges div.mil-date {
        font-size: 13px !important;
        padding: 0 10px !important;
    }
}

/* Pagination */
.mil-blog-pagination {
    display: flex;
    justify-content: center;
    gap: var(--tw-pag-gap);
}

.mil-blog-pagination .page-numbers {
    width: var(--tw-pag-size);
    height: var(--tw-pag-size);
    border-radius: 999px;
    background: var(--tw-pag-bg);
    color: var(--tw-pag-text);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-transform: none;
    letter-spacing: 0;
    font-size: 18px;
    font-weight: 400;
    line-height: 1;
    box-shadow: none;
    transform: none;
    transition: background .2s ease, transform .2s ease;
}

.mil-blog-pagination .page-numbers.current {
    background: var(--tw-pag-active);
}

.mil-blog-pagination a.page-numbers:hover {
    background: var(--tw-pag-hover);
    transform: none;
}

.mil-blog-pagination .page-numbers.dots {
    background: transparent;
    width: auto;
    padding: 0 6px;
}

/* Prev/Next arrows */
.mil-blog-pagination a.prev,
.mil-blog-pagination a.next {
    font-size: 0;
}

.mil-blog-pagination a.prev i,
.mil-blog-pagination a.next i {
    display: none;
}

.mil-blog-pagination a.prev::after,
.mil-blog-pagination a.next::after {
    content: "";
    width: 30px;
    height: 30px;
    display: block;
    background: var(--tw-arrow-icon) no-repeat center/contain;
    filter: brightness(0) invert(1);
    transition: transform .2s ease;
}

.mil-blog-pagination a.prev::after {
    transform: rotate(180deg);
}

.mil-blog-pagination a.next:hover::after {
    transform: translateX(2px);
}

.mil-blog-pagination a.prev:hover::after {
    transform: rotate(180deg) translateX(2px);
}


/* ==========================================================================
   12. BLOG SINGLE POST
   ========================================================================== */

body.single-post .tw-blog-hero {
    position: relative;
    height: clamp(240px, 28vw, 420px);
    overflow: hidden;
    margin-top: 198px;
}

@media (max-width: 767px) {
    body.single-post .tw-blog-hero {
        margin-top: 100px;
    }
}

body.single-post .tw-blog-hero-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

body.single-post .tw-blog-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(0,0,0,.50) 0%, rgba(0,0,0,.22) 55%, rgba(0,0,0,0) 100%);
}

body.single-post .tw-blog-hero-inner {
    position: relative;
    height: 100%;
    display: flex;
    align-items: flex-end;
    padding-bottom: clamp(22px, 4vw, 44px);
}

body.single-post .tw-blog-hero-title {
    color: #fff;
    font-size: clamp(34px, 4.6vw, 86px);
    line-height: 1.05;
    font-weight: 200;
    max-width: 980px;
    margin: 0;
}

/* Post meta */
body.single-post .tw-post-meta {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
    padding: 26px 0;
}

body.single-post .tw-single-post .tw-post-meta,
body.single-post .tw-single-post .tw-post-meta * {
    color: #111;
    opacity: 1;
}

body.single-post .tw-meta-label {
    font-size: 30px;
    opacity: .55;
    margin-bottom: 8px;
    font-weight: 500;
}

body.single-post .tw-meta-value {
    font-size: 18px;
    font-weight: 300;
    opacity: .9;
}

body.single-post .tw-post-meta-sep {
    height: 1px;
    background: rgba(0,0,0,.12);
    margin-bottom: 56px;
}

/* Post wrapper */
body.single-post .tw-single-post {
    position: relative;
    overflow: hidden;
    padding-bottom: 90px;
}

body.single-post .tw-single-post::after {
    content: "";
    position: absolute;
    right: -560px;
    top: 240px;
    width: 2560px;
    height: 1069px;
    pointer-events: none;
    background: url("https://threewaves.agency/wp-content/uploads/2025/11/0056_2025_10_fala-w-tle-scaled.png") no-repeat center/contain;
}

body.single-post .tw-single-post .container {
    max-width: 1260px;
}

body.single-post .tw-single-post .col-lg-8 {
    flex: 0 0 100%;
    max-width: 100%;
}

/* Post content - override theme opacity animations */
body.single-post .single-post-text p,
body.single-post .single-post-text li,
body.single-post .single-post-text h1,
body.single-post .single-post-text h2,
body.single-post .single-post-text h3,
body.single-post .single-post-text h4,
body.single-post .single-post-text h5,
body.single-post .single-post-text h6 {
    opacity: 1 !important;
    transform: none !important;
}

body.single-post .single-post-text {
    font-size: 18px;
    line-height: 1.8;
}

/* Post navigation */
body.single-post .tw-post-nav {
    display: flex;
    gap: 18px;
    justify-content: space-between;
    width: 100%;
    align-items: center;
    margin-top: 56px;
}

body.single-post .tw-nav-btn {
    height: var(--tw-nav-h);
    padding: 0 22px;
    border-radius: var(--tw-nav-radius);
    background: var(--tw-nav-bg);
    color: var(--tw-nav-text);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    font-size: 14px;
    font-weight: 500;
    line-height: 1;
}

body.single-post a.tw-nav-btn:hover {
    background: var(--tw-nav-bg-hover);
}

body.single-post .tw-nav-all {
    min-width: 180px;
}

body.single-post .tw-nav-ico {
    width: 20px;
    height: 20px;
    display: inline-block;
    background: var(--tw-arrow-icon) no-repeat center/contain;
    filter: brightness(0) invert(1);
}

body.single-post .tw-nav-prev .tw-nav-ico {
    transform: rotate(180deg);
}

body.single-post .tw-nav-btn.is-disabled {
    opacity: .55;
    cursor: default;
}


/* ==========================================================================
   13. FOOTER
   ========================================================================== */

.mil-footer-menu-frame .tw-social-icon {
    width: 36px;
    height: auto;
}

.mil-footer-menu-frame .mil-social li {
    margin: 0;
    padding: 0;
}

.mil-footer-menu-frame .mil-social {
    display: flex;
    column-gap: 8px;
}


/* ==========================================================================
   14. CTA SECTIONS
   ========================================================================== */

.elementor-widget-pixy-cta-one .mil-text-box.mil-g-m1::before {
    background: var(--tw-gradient-text);
}

.elementor-widget-pixy-cta-one .mil-display3 .cta-em {
    font-style: italic;
    font-weight: 700;
    display: inline-block;
}


/* ==========================================================================
   15. DECORATIVE ELEMENTS (Waves)
   ========================================================================== */

.tw-waves-section {
    position: relative;
    overflow: hidden;
    --wave-size: clamp(300px, 36vw, 700px);
    --left-out: 20vw;
    --right-out: 14vw;
    --left-y: 0%;
    --right-y: 100%;

    background-image:
        url("https://threewaves.agency/wp-content/uploads/2025/11/0056_2025_10_team_fala-mala2.png"),
        url("https://threewaves.agency/wp-content/uploads/2025/11/0056_2025_10_team_fala-mala1.png");
    background-repeat: no-repeat, no-repeat;
    background-size: var(--wave-size), var(--wave-size);
    background-position:
        calc(0% - var(--left-out)) var(--left-y),
        calc(100% + var(--right-out)) var(--right-y);
}

.tw-waves-section > * {
    position: relative;
    z-index: 1;
}


/* ==========================================================================
   15b. WAVE RESPONSIVE ADJUSTMENTS
   ========================================================================== */

/*
 * Wave responsive positioning - shifts wave image to prevent
 * covering text across different screen sizes.
 *
 * Naming convention: tw-wave-{page}
 * - tw-wave-home (strona główna)
 * - tw-wave-about (o nas)
 * - tw-wave-offer (oferta)
 * - tw-wave-portfolio
 * - tw-wave-contact (kontakt)
 * - tw-wave-blog
 */

/* -------------------------------------------------------------------------
   HOME PAGE WAVE (tw-wave-home)
   Values tested and approved on 2025-01-15
   ------------------------------------------------------------------------- */

/* Full HD and larger (1920px+) - no shift needed */
@media (min-width: 1920px) {
    .tw-wave-home img {
        transform: translate(0, 0);
    }
}

/* Large desktop (1700px - 1919px) */
@media (min-width: 1700px) and (max-width: 1919px) {
    .tw-wave-home img {
        transform: translate(80px, 80px);
    }
}

/* Desktop (1500px - 1699px) */
@media (min-width: 1500px) and (max-width: 1699px) {
    .tw-wave-home img {
        transform: translate(120px, 180px);
    }
}

/* Desktop (1440px - 1499px) */
@media (min-width: 1440px) and (max-width: 1499px) {
    .tw-wave-home img {
        transform: translate(110px, 240px);
    }
}

/* Medium desktop (1200px - 1439px) */
@media (min-width: 1200px) and (max-width: 1439px) {
    .tw-wave-home img {
        transform: translate(120px, 320px);
    }
}

/* Small desktop (1024px - 1099px) */
@media (min-width: 1024px) and (max-width: 1099px) {
    .tw-wave-home img {
        transform: translate(110px, 420px);
    }
}

/* Nest Hub Max (~1152px) */
@media (min-width: 1100px) and (max-width: 1199px) {
    .tw-wave-home img {
        transform: translate(80px, 350px);
    }
}

/* Tablet (768px - 1023px) - column layout like mobile */
@media (min-width: 768px) and (max-width: 1023px) {
    /* Make the wave+description container stack vertically */
    .elementor-element-3663df9 {
        flex-direction: column !important;
    }

    /* Make description container full width */
    .elementor-element-e55e1a7 {
        width: 100% !important;
        max-width: 100% !important;
    }

    /* Wave below text - no negative margin */
    .tw-wave-home {
        margin-top: 0 !important;
    }

    /* Shift wave image left like mobile */
    .tw-wave-home img {
        transform: translate(-30px, 0) !important;
    }
}

/* Mobile (below 768px) - shift wave right */
@media (max-width: 767px) {
    .tw-wave-home img {
        transform: translate(30px, 0);
    }
}

/* Galaxy Z Fold 5 and very small screens (below 280px) */
@media (max-width: 280px) {
    .tw-wave-home img {
        transform: translate(50px, 0);
    }
}

/* -------------------------------------------------------------------------
   ABOUT PAGE WAVES (tw-wave-about-left, tw-wave-about-right)
   Values tested and approved on 2025-01-16
   ------------------------------------------------------------------------- */

/* Large desktop (1700px - 1919px) */
@media (min-width: 1700px) and (max-width: 1919px) {
    .tw-wave-about-left img {
        transform: translate(0, 50px);
    }
}

/* Desktop (1500px - 1699px) */
@media (min-width: 1500px) and (max-width: 1699px) {
    .tw-wave-about-left img {
        transform: translate(0, 50px);
    }
}

/* Desktop (1440px - 1499px) */
@media (min-width: 1440px) and (max-width: 1499px) {
    .tw-wave-about-left img {
        transform: translate(70px, 70px);
    }
}

/* Medium desktop (1200px - 1439px) */
@media (min-width: 1200px) and (max-width: 1439px) {
    .tw-wave-about-left img {
        transform: translate(130px, 80px);
    }
}

/* Small desktop (1024px - 1199px) */
@media (min-width: 1024px) and (max-width: 1199px) {
    .tw-wave-about-left img {
        transform: translate(280px, 80px);
    }
    .tw-wave-about-right img {
        transform: translate(0, 130px);
    }
}

/* Tablet (768px - 1023px) */
@media (min-width: 768px) and (max-width: 1023px) {
    .tw-wave-about-left img {
        transform: translate(600px, 50px) scale(0.5);
    }
    .tw-wave-about-right img {
        transform: translate(0, 150px);
    }
}

/* -------------------------------------------------------------------------
   OFFER PAGE WAVES (tw-wave-offer-left, tw-wave-offer-right)
   Values tested and approved on 2025-01-16
   ------------------------------------------------------------------------- */

/* Large desktop (1700px - 1919px) */
@media (min-width: 1700px) and (max-width: 1919px) {
    .tw-wave-offer-left img {
        transform: translate(0, 50px);
    }
    .tw-wave-offer-right img {
        transform: translate(0, -50px);
    }
}

/* Desktop (1500px - 1699px) */
@media (min-width: 1500px) and (max-width: 1699px) {
    .tw-wave-offer-left img {
        transform: translate(0, 50px);
    }
    .tw-wave-offer-right img {
        transform: translate(0, -50px);
    }
}

/* Desktop (1440px - 1499px) */
@media (min-width: 1440px) and (max-width: 1499px) {
    .tw-wave-offer-left img {
        transform: translate(0, 50px);
    }
    .tw-wave-offer-right img {
        transform: translate(0, -50px);
    }
}

/* Medium desktop (1400px - 1439px) */
@media (min-width: 1400px) and (max-width: 1439px) {
    .tw-wave-offer-left img {
        transform: translate(0, 25px);
    }
    .tw-wave-offer-right img {
        transform: translate(0, -5px);
    }
}

/* Medium desktop (1200px - 1399px) */
@media (min-width: 1200px) and (max-width: 1399px) {
    .tw-wave-offer-left img {
        transform: translate(0, -50px);
    }
    .tw-wave-offer-right img {
        transform: translate(0, 50px);
    }
}

/* Small desktop (1024px - 1199px) */
@media (min-width: 1024px) and (max-width: 1199px) {
    .tw-wave-offer-left img {
        transform: translate(200px, 50px);
    }
    .tw-wave-offer-right img {
        transform: translate(80px, 150px);
    }
}

/* Tablet (768px - 1023px) */
@media (min-width: 768px) and (max-width: 1023px) {
    .tw-wave-offer-left img {
        transform: translate(800px, 150px) scale(0.5);
    }
    .tw-wave-offer-right img {
        transform: translate(150px, 200px) scale(1.3);
    }
}

/* Tablet (601px - 767px) */
@media (min-width: 601px) and (max-width: 767px) {
    .tw-wave-offer-left,
    .tw-wave-offer-right {
        position: absolute !important;
    }
    .tw-wave-offer-left {
        top: 0px !important;
        left: -100px !important;
    }
    .tw-wave-offer-right {
        top: 20px !important;
        right: -20px !important;
    }
    .tw-wave-offer-left img {
        transform: translate(-100px, -80px) scale(1.1);
    }
    .tw-wave-offer-right img {
        transform: translate(-50px, -110px) scale(0.7);
    }
}

/* Small tablet (501px - 600px) */
@media (min-width: 501px) and (max-width: 600px) {
    .tw-wave-offer-left,
    .tw-wave-offer-right {
        position: absolute !important;
    }
    .tw-wave-offer-left {
        top: 50px !important;
        left: -20px !important;
    }
    .tw-wave-offer-right {
        top: 95px !important;
        right: 30px !important;
    }
    .tw-wave-offer-left img {
        transform: translate(-100px, -80px) scale(1.1);
    }
    .tw-wave-offer-right img {
        transform: translate(-50px, -110px) scale(0.7);
    }
}

/* Small mobile (below 500px) */
@media (max-width: 500px) {
    .tw-wave-offer-left,
    .tw-wave-offer-right {
        position: absolute !important;
    }
    .tw-wave-offer-left {
        top: 70px !important;
        left: 100px !important;
    }
    .tw-wave-offer-right {
        top: 130px !important;
        right: -80px !important;
    }
    .tw-wave-offer-left img {
        transform: translate(-100px, -80px) scale(1.4) !important;
    }
    .tw-wave-offer-right img {
        transform: translate(-50px, -110px) scale(1.0) !important;
    }
}

/* -------------------------------------------------------------------------
   PORTFOLIO PAGE WAVES (tw-wave-portfolio-left, tw-wave-portfolio-right)
   Values tested and approved on 2025-01-16
   ------------------------------------------------------------------------- */

/* Large desktop (1700px - 1919px) */
@media (min-width: 1700px) and (max-width: 1919px) {
    .tw-wave-portfolio-left img {
        transform: translate(50px, 50px);
    }
    .tw-wave-portfolio-right img {
        transform: translate(70px, -30px);
    }
}

/* Desktop (1500px - 1699px) */
@media (min-width: 1500px) and (max-width: 1699px) {
    .tw-wave-portfolio-left img {
        transform: translate(200px, 70px);
    }
    .tw-wave-portfolio-right img {
        transform: translate(150px, -30px);
    }
}

/* Desktop (1440px - 1499px) */
@media (min-width: 1440px) and (max-width: 1499px) {
    .tw-wave-portfolio-left img {
        transform: translate(200px, 70px);
    }
    .tw-wave-portfolio-right img {
        transform: translate(150px, -30px);
    }
}

/* Medium desktop (1200px - 1439px) */
@media (min-width: 1200px) and (max-width: 1439px) {
    .tw-wave-portfolio-left img {
        transform: translate(250px, 70px);
    }
    .tw-wave-portfolio-right img {
        transform: translate(150px, -30px);
    }
}

/* Small desktop (1024px - 1199px) */
@media (min-width: 1024px) and (max-width: 1199px) {
    .tw-wave-portfolio-left img {
        transform: translate(550px, 100px) scale(0.8);
    }
    .tw-wave-portfolio-right img {
        transform: translate(150px, 0);
    }
}

/* Tablet (768px - 1023px) */
@media (min-width: 768px) and (max-width: 1023px) {
    .tw-wave-portfolio-left img {
        transform: translate(1000px, 120px) scale(0.6);
    }
    .tw-wave-portfolio-right img {
        transform: translate(200px, 150px);
    }
}

/* Mobile (below 768px) */
@media (max-width: 767px) {
    .tw-wave-portfolio-right img {
        transform: translate(70px, -30px);
    }
}

/* -------------------------------------------------------------------------
   KONTAKT PAGE WAVE (tw-wave-contact)
   Values tested and approved on 2025-01-18
   ------------------------------------------------------------------------- */

/* Global z-index for contact wave */
.tw-wave-contact {
    z-index: 9999;
}

/* Small desktop (1024px - 1199px) */
@media (min-width: 1024px) and (max-width: 1199px) {
    .tw-wave-contact img {
        transform: translate(0, 160px) scale(1.2);
    }
}

/* Tablet (768px - 1023px) */
@media (min-width: 768px) and (max-width: 1023px) {
    .tw-wave-contact img {
        transform: translate(70px, 160px) scale(1.2);
    }
}

/* Mobile (below 768px) */
@media (max-width: 767px) {
    .tw-wave-contact img {
        transform: translate(-50px, 50px) scale(1.4);
    }
}

/* -------------------------------------------------------------------------
   BLOG PAGE WAVE (tw-wave-blog)
   Values tested and approved on 2025-01-18
   ------------------------------------------------------------------------- */

/* Small desktop (1024px - 1199px) */
@media (min-width: 1024px) and (max-width: 1199px) {
    .tw-wave-blog img {
        transform: translate(30px, 120px) scale(1.3);
    }
}

/* Tablet (768px - 1023px) */
@media (min-width: 768px) and (max-width: 1023px) {
    .tw-wave-blog img {
        transform: translate(0, 140px);
    }
}

/* Mobile (below 768px) */
@media (max-width: 767px) {
    .tw-wave-blog img {
        transform: translate(0, 30px) scale(0.95);
    }
}


/* ==========================================================================
   16. RESPONSIVE - TABLET (max 1024px)
   ========================================================================== */

@media (max-width: 1024px) {
    .mil-services-list .mil-service-item {
        grid-template-columns: 140px 1fr 112px;
        gap: 32px;
    }

    .mil-services-list .service-ico {
        width: 120px;
    }
}

@media (max-width: 768px) {
    .tw-waves-section {
        --wave-size: clamp(200px, 55vw, 380px);
        --left-out: 7vw;
        --right-out: 6vw;
        --left-y: 28%;
        --right-y: 95%;
    }

    body.single-post .tw-post-meta {
        grid-template-columns: 1fr;
        gap: 18px;
    }

    body.single-post .tw-post-nav {
        flex-direction: column;
    }

    body.single-post .tw-nav-all {
        width: 100%;
        min-width: 0;
    }
}


/* ==========================================================================
   17. RESPONSIVE - MOBILE (max 767px)
   ========================================================================== */

@media (max-width: 767px) {
    /* Services list mobile */
    .mil-services-list .mil-service-item {
        grid-template-columns: 1fr auto;
        grid-template-areas:
            "text text"
            "btn  ico";
        gap: 18px 24px;
        align-items: start;
    }

    .mil-services-list .mil-service-item .mil-item-text {
        grid-area: text;
        margin-bottom: 0;
    }

    .mil-services-list .mil-service-item > div.mil-mb30:not(.mil-item-text) {
        grid-area: btn;
        margin-bottom: 0;
        justify-self: start;
        align-self: end;
    }

    .mil-services-list .mil-service-item > img.service-ico {
        grid-area: ico;
        margin-bottom: 0;
        justify-self: end;
        align-self: end;
        width: 140px;
        height: auto;
    }

    .mil-service-item .mil-text-md.mil-max-3row-text{
        overflow: visible;
        text-overflow: clip;
        display: block;
        -webkit-line-clamp: unset;
        line-clamp: unset;
        -webkit-box-orient: unset;
    }

    /* Service card large mobile */
    .mil-service-card-lg {
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
        align-items: flex-end;
    }

    .mil-service-card-lg > h3,
    .mil-service-card-lg > p,
    .mil-service-card-lg > ul {
        width: 100%;
        order: 1;
    }

    .mil-service-card-lg > .mil-mb30:first-child {
        order: 10;
        margin-left: auto;
        margin-bottom: 0;
        display: flex;
        align-items: center;
    }

    .mil-service-card-lg > .mil-mb30:last-child {
        order: 9;
        margin-bottom: 0;
    }

    .mil-service-card-lg .service-grid-icon {
        width: 150px;
        height: auto;
    }

    /* Footer contact button mobile */
    .mil-footer-contact .mil-stylized-btn {
        width: 120px;
        height: 120px;
        padding: 14px;
        border-radius: 16px;
    }

    .mil-footer-contact .mil-stylized-btn span {
        font-size: 16px;
        line-height: 1.2;
        letter-spacing: 0;
    }

    .mil-footer-contact .mil-stylized-btn::after {
        top: 8px;
        right: 4px;
        width: 40px;
        height: 40px;
    }
    
    .tw-imagebox-left .elementor-image-box-wrapper {
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: flex-start !important;
        text-align: left !important;
        gap: 12px !important;
    }

    .tw-imagebox-left .elementor-image-box-img {
        margin: 0 !important;
        flex: 0 0 auto !important;
        align-self: flex-start !important;
    }

    .tw-imagebox-left .elementor-image-box-content {
        flex: 1 1 auto !important;
        min-width: 0 !important;
        text-align: left !important;
    }

}

@media (max-width: 480px) {
    .tw-waves-section {
        --wave-size: clamp(500px, 70vw, 700px);
        --left-out: 80vw;
        --right-out: 48vw;
        --left-y: 0%;
        --right-y: 100%;
    }
}


/* ==========================================================================
   18. RESPONSIVE - SMALL MOBILE (max 500px)
   ========================================================================== */

@media (max-width: 500px) {
    .mil-footer-menu-frame {
        padding: 24px 0 !important;
        align-items: center !important;
        border-top: 0 !important;
        border-bottom: 0 !important;
    }

    .mil-footer-menu-frame .mil-footer-menu {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 16px;
        margin-bottom: 14px !important;
        border-top: 1px solid rgba(53, 54, 57, 0.2);
        border-bottom: 1px solid rgba(53, 54, 57, 0.2);
        padding-top: 14px;
        padding-bottom: 14px;
    }

    .mil-footer-menu-frame .mil-footer-menu li {
        margin: 0 !important;
    }

    .mil-footer-menu-frame .mil-footer-menu li a {
        font-size: 11px !important;
        letter-spacing: 0.6px !important;
        white-space: nowrap;
    }

    .mil-footer-menu-frame .mil-social {
        display: flex;
        justify-content: center;
        gap: 10px;
        margin-top: 14px;
    }
}


/* ==========================================================================
   19. SVG ICON FIXES
   Fix for duplicate SVG gradient IDs causing:
   1. FAQ accordion arrows disappearing after first item
   2. Checkbox icons getting gradient colors instead of white
   ========================================================================== */

/* ----- FAQ ACCORDION ARROWS ----- */

/* Force solid purple color on arrow SVG shapes */
.e-n-accordion-item-title-icon svg path,
.e-n-accordion-item-title-icon svg polygon,
.e-n-accordion-item-title-icon svg rect,
.e-n-accordion-item-title-icon svg circle,
.e-n-accordion-item-title-icon svg line,
.e-n-accordion-item-title-icon svg polyline {
    fill: var(--tw-purple-light) !important;
    stroke: var(--tw-purple-light) !important;
}

/* Override any gradient in arrow SVGs */
.e-n-accordion-item-title-icon svg stop {
    stop-color: var(--tw-purple-light) !important;
}

/* Smooth rotation transition on icon container and SVG */
.e-n-accordion-item-title-icon,
.e-n-accordion-item-title-icon svg,
[class*="accordion"] [class*="title-icon"],
[class*="accordion"] [class*="title-icon"] svg {
    transition: transform 0.3s ease !important;
    transform-origin: center center !important;
}

/* Rotate arrow 180deg when accordion item is OPEN
   Uses custom .tw-arrow-open class added via JS (Elementor overrides CSS-only transforms) */
.tw-arrow-open {
    transform: rotate(180deg) !important;
}

/* Also target SVG inside opened icon */
.e-n-accordion-item-title-icon.tw-arrow-open svg,
[class*="title-icon"].tw-arrow-open svg {
    transform: rotate(180deg) !important;
}

/* ----- CHECKBOX ICONS (Industries section on /oferta/ page) ----- */
/* Target icon lists inside the specific gradient section (elementor-element-67ff17c) */

/* Target by the specific Elementor container with gradient background */
.elementor-element-67ff17c .elementor-icon-list-icon svg linearGradient stop,
.elementor-element-67ff17c .elementor-icon-list-icon svg radialGradient stop {
    stop-color: #ffffff !important;
    stop-opacity: 1 !important;
}

.elementor-element-67ff17c .elementor-icon-list-icon svg path,
.elementor-element-67ff17c .elementor-icon-list-icon svg polygon,
.elementor-element-67ff17c .elementor-icon-list-icon svg rect,
.elementor-element-67ff17c .elementor-icon-list-icon svg circle {
    fill: #ffffff !important;
}

/* Note: Mobile checkbox icons fix is done via JavaScript in functions.php
   SVG clip-path references need to be corrected to use unique IDs */


/* ==========================================================================
   19B. MOBILE HEADER HEIGHT FIX
   Reduce header height when WordPress admin bar is not present
   ========================================================================== */

/* Mobile header - balanced height when not logged in */
@media (max-width: 767px) {
    .elementor-element-b3f671c {
        min-height: 100px !important;
    }

    /* Restore larger height when admin bar is present */
    body.admin-bar .elementor-element-b3f671c {
        min-height: 120px !important;
    }

    /* Reduce hero section margin to match smaller header (homepage) */
    .elementor-element-b223da5 {
        margin-top: 100px !important;
    }

    /* Restore larger margin when admin bar is present */
    body.admin-bar .elementor-element-b223da5 {
        margin-top: 160px !important;
    }
}


/* ==========================================================================
   20. MOBILE MENU STYLING
   Purple background with white text/icons per design mockup
   ========================================================================== */

/* ----- Background - same purple for all sections ----- */
.mil-menu-frame.mil-active {
    background: var(--tw-purple) !important;
}

.mil-menu-frame .mil-menu-window,
.mil-menu-frame .mil-social-section,
.mil-menu-frame .mil-blog-section {
    background-color: var(--tw-purple) !important;
    border: none !important;
}

/* ----- Menu layout - fill viewport, no scroll ----- */
.mil-menu-frame .mil-menu-window {
    display: flex !important;
    flex-direction: column !important;
    height: 100vh !important;
    height: 100dvh !important;
    max-height: 100vh !important;
    max-height: 100dvh !important;
    padding-top: 70px !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
}

/* Add extra padding when WordPress admin bar is present */
body.admin-bar .mil-menu-frame .mil-menu-window {
    padding-top: 116px !important;
}

.mil-menu-frame .mil-menu-section {
    flex: 1 1 auto !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    padding-top: 20px !important;
    border: none !important;
    box-shadow: none !important;
    overflow: hidden !important;
}

.mil-menu-frame .mil-bottom {
    flex-shrink: 0 !important;
}

/* Hide the inner scroll element that causes scrollbar */
.mil-menu-frame .mil-inner-scroll {
    overflow: hidden !important;
}

/* Remove scrollbar from menu frame */
.mil-menu-frame,
.mil-menu-frame * {
    scrollbar-width: none !important;
    -ms-overflow-style: none !important;
}

.mil-menu-frame::-webkit-scrollbar,
.mil-menu-frame *::-webkit-scrollbar {
    display: none !important;
    width: 0 !important;
}

/* ----- Header when menu is open ----- */
/* Override scroll state white background to transparent/purple when menu is active */
body:has(.mil-menu-frame.mil-active) .mil-top-panel,
body:has(.mil-menu-frame.mil-active) .mil-top-panel-2,
body:has(.mil-menu-frame.mil-active) .mil-wrapper-header {
    background: var(--tw-purple) !important;
    box-shadow: none !important;
    -webkit-box-shadow: none !important;
    border: none !important;
    filter: none !important;
    -webkit-filter: none !important;
}

/* Remove all header/menu separator lines and shadows */
body:has(.mil-menu-frame.mil-active) .mil-top-panel,
body:has(.mil-menu-frame.mil-active) .mil-top-panel *:not(img),
body:has(.mil-menu-frame.mil-active) .mil-top-panel-2,
body:has(.mil-menu-frame.mil-active) .mil-top-panel-2 *:not(img) {
    border: none !important;
    box-shadow: none !important;
    -webkit-box-shadow: none !important;
}

/* Override scrolled state shadow */
html.is-scrolled body:has(.mil-menu-frame.mil-active) .mil-top-panel,
html.is-scrolled body:has(.mil-menu-frame.mil-active) .mil-top-panel-2 {
    box-shadow: none !important;
    -webkit-box-shadow: none !important;
}

.mil-menu-frame .mil-menu-window {
    border: none !important;
    box-shadow: none !important;
}

/* Remove any separator line under header in menu */
.mil-menu-frame .mil-menu-window::before,
.mil-menu-frame .mil-menu-window::after,
.mil-menu-frame .mil-menu-section::before,
.mil-menu-frame .mil-menu-section::after {
    display: none !important;
    content: none !important;
}

/* Hide any header separator when menu is open */
body:has(.mil-menu-frame.mil-active) .mil-top-panel::after,
body:has(.mil-menu-frame.mil-active) .mil-top-panel-2::after {
    display: none !important;
}

/* Menu item spacing */
.mil-menu-frame .mil-main-menu li {
    margin-bottom: 20px !important;
}

/* ----- Logo - make white when menu is open ----- */
body:has(.mil-menu-frame.mil-active) .mil-top-panel img,
body:has(.mil-menu-frame.mil-active) .mil-top-panel-2 img {
    filter: brightness(0) invert(1) !important;
}

/* ----- Menu items - white text, Poppins font ----- */
.mil-menu-frame .mil-main-menu li a {
    color: #ffffff !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding-right: 70px !important;
    position: relative !important;
    font-family: "Poppins", sans-serif !important;
    font-style: normal !important;
    font-weight: 600 !important;
    font-size: 24px !important;
    text-transform: none !important;
}

/* ----- Arrow icons - SVG arrow in circular buttons ----- */
.mil-menu-frame .mil-main-menu li a::after {
    content: '';
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    border: none !important;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.2) !important;
    transition: all 0.3s ease;
}

/* SVG arrow icon inside the circle */
.mil-menu-frame .mil-main-menu li a::before {
    content: '';
    position: absolute;
    right: 10px;
    top: 50%;
    width: 24px;
    height: 24px;
    background: var(--tw-arrow-icon) no-repeat center center !important;
    background-size: contain !important;
    filter: brightness(0) invert(1);
    transform: translateY(-50%);
    z-index: 1;
    transition: all 0.3s ease;
}

.mil-menu-frame .mil-main-menu li a:hover::after {
    background: rgba(255, 255, 255, 0.35) !important;
}

/* ----- Social icons section - full width bottom ----- */
.mil-menu-frame .mil-bottom {
    width: 100% !important;
    padding: 0 30px 20px 30px !important;
    box-sizing: border-box !important;
    background-color: var(--tw-purple) !important;
}

.mil-menu-frame .mil-social-section {
    background-color: var(--tw-purple) !important;
    width: 100% !important;
}

/* Hide blog section in mobile menu */
.mil-menu-frame .mil-blog-section {
    display: none !important;
}

.mil-menu-frame .mil-social {
    border-top: 1px solid rgba(255, 255, 255, 0.3) !important;
    padding-top: 24px !important;
    margin-top: 0 !important;
    width: 100% !important;
    display: flex !important;
    gap: 8px !important;
}

.mil-menu-frame .mil-social li {
    margin: 0 !important;
    padding: 0 !important;
}

.mil-menu-frame .mil-social li a {
    color: #ffffff !important;
}

.mil-menu-frame .mil-social li a i,
.mil-menu-frame .mil-social li a svg {
    color: #ffffff !important;
    font-size: 32px !important;
    width: 32px !important;
    height: 32px !important;
}

.mil-menu-frame .mil-social li a:hover {
    opacity: 0.7;
}

/* ----- Close button (X) - white circular ----- */
/* Remove purple background from all parent wrappers */
.mil-buttons-tp-frame:has(.mil-menu-btn.mil-active),
.mil-tp-btn:has(.mil-menu-btn.mil-active) {
    background-color: transparent !important;
}

/* The button uses span + ::before + ::after to create 3 lines that transform into X */
.mil-menu-btn.mil-active {
    background-color: #ffffff !important;
    border-radius: 50% !important;
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
    width: 56px !important;
    min-width: 56px !important;
    height: 56px !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* Ensure parent containers don't constrain the button */
.mil-tp-btn:has(.mil-menu-btn.mil-active),
.mil-buttons:has(.mil-menu-btn.mil-active) {
    width: auto !important;
    min-width: 56px !important;
}

/* All three line elements need to be styled purple */
.mil-menu-btn.mil-active span,
.mil-menu-btn.mil-active span::before,
.mil-menu-btn.mil-active span::after {
    background-color: var(--tw-purple) !important;
}

/* ----- Hamburger icon - custom PNG image ----- */
/* Hide default CSS lines when not active */
.mil-menu-btn:not(.mil-active) span,
.mil-menu-btn:not(.mil-active) span::before,
.mil-menu-btn:not(.mil-active) span::after {
    display: none !important;
}

/* Show custom hamburger image */
.mil-menu-btn:not(.mil-active) {
    background-image: url('/wp-content/uploads/2026/01/0056_2025_10_ikona_burger_line_white.png') !important;
    background-size: 18px 18px !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    width: 56px !important;
    height: 56px !important;
    min-width: 56px !important;
    border-radius: 50% !important;
    padding: 0 !important;
}

/* Fix oval parent wrappers for hamburger - make them circular */
.mil-tp-btn:has(.mil-menu-btn:not(.mil-active)) {
    width: 56px !important;
    height: 56px !important;
    min-width: 56px !important;
    border-radius: 50% !important;
}

/* Remove background from outer frame - only inner .mil-tp-btn shows purple circle */
.mil-buttons-tp-frame:has(.mil-menu-btn:not(.mil-active)) {
    background: transparent !important;
}

/* ----- Social icons as PNG images ----- */
.mil-menu-frame .mil-social li a img {
    width: 32px !important;
    height: 32px !important;
    transition: opacity 0.2s ease;
}

.mil-menu-frame .mil-social li a:hover img {
    opacity: 0.7;
}
