.slick-prev:before{content:'\2190'}.slick-next{right:-25px}@font-face{font-family:Montserrat;font-weight:400;font-display:optional;src:url(fonts/Montserrat-Regular.woff2) format('woff2'),url(fonts/Montserrat-Regular.ttf) format('truetype')}@font-face{font-family:Montserrat;font-weight:500;font-display:optional;src:url(fonts/Montserrat-Regular.woff2) format('woff2'),url(fonts/Montserrat-Regular.ttf) format('truetype')}@font-face{font-family:Montserrat;font-weight:600;font-display:optional;src:url(fonts/Montserrat-SemiBold.woff2) format('woff2'),url(fonts/Montserrat-SemiBold.ttf) format('truetype')}@font-face{font-family:Montserrat;font-weight:700;font-display:optional;src:url(fonts/Montserrat-SemiBold.woff2) format('woff2'),url(fonts/Montserrat-SemiBold.ttf) format('truetype')}@font-face{font-family:Barlow;font-weight:400;font-display:optional;src:url(fonts/Barlow-Regular.woff2) format('woff2'),url(fonts/Barlow-Regular.ttf) format('truetype')}@font-face{font-family:Barlow;font-weight:600;font-display:optional;src:url(fonts/Barlow-Regular.woff2) format('woff2'),url(fonts/Barlow-Regular.ttf) format('truetype')}@font-face{font-family:'FontAwesome';font-display:swap;src:url(https://www.zip-floors.pl/node_modules/font-awesome/fonts/fontawesome-webfont.woff2) format('woff2'),url(https://www.zip-floors.pl/node_modules/font-awesome/fonts/fontawesome-webfont.woff) format('woff');font-weight:400;font-style:normal}.fa{display:inline-block;font:normal normal normal 14px/1 FontAwesome;font-size:inherit;text-rendering:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.fa-map-marker:before{content:"\f041"}.fa-phone:before{content:"\f095"}.fa-envelope:before{content:"\f0e0"}.fa-bars:before{content:"\f0c9"}.fa-users:before{content:"\f0c0"}.fa-truck:before{content:"\f0d1"}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.sr-only-focusable:active,.sr-only-focusable:focus{position:static;width:auto;height:auto;margin:0;overflow:visible;clip:auto}img.lazyload{opacity:0;transition:opacity .3s}img.lazyloaded{opacity:1}.slick-slider{position:relative;display:block;box-sizing:border-box;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none;-khtml-user-select:none;-ms-touch-action:pan-y;touch-action:pan-y;-webkit-tap-highlight-color:transparent}.slick-list{position:relative;display:block;overflow:hidden;margin:0;padding:0}.slick-list:focus{outline:none}.slick-list.dragging{cursor:pointer;cursor:hand}.slick-slider .slick-track,.slick-slider .slick-list{-webkit-transform:translate3d(0,0,0);-moz-transform:translate3d(0,0,0);-ms-transform:translate3d(0,0,0);-o-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}.slick-track{position:relative;top:0;left:0;display:block;margin-left:auto;margin-right:auto}.slick-track:before,.slick-track:after{display:table;content:''}.slick-track:after{clear:both}.slick-loading .slick-track{visibility:hidden}.slick-slide{display:none;float:left;height:100%;min-height:1px}[dir='rtl'] .slick-slide{float:right}.slick-slide img{display:block}.slick-slide.slick-loading img{display:none}.slick-slide.dragging img{pointer-events:none}.slick-initialized .slick-slide{display:block}.slick-loading .slick-slide{visibility:hidden}.slick-vertical .slick-slide{display:block;height:auto;border:1px solid transparent}.slick-arrow.slick-hidden{display:none}@charset 'UTF-8';.slick-loading .slick-list{background:#fff url(https://www.zip-floors.pl/node_modules/slick-carousel/slick/ajax-loader.gif) center center no-repeat}.slick-prev,.slick-next{font-size:0;line-height:0;position:absolute;top:50%;display:block;width:20px;height:20px;padding:0;-webkit-transform:translate(0,-50%);-ms-transform:translate(0,-50%);transform:translate(0,-50%);cursor:pointer;color:transparent;border:none;outline:none;background:transparent}.slick-prev:hover,.slick-prev:focus,.slick-next:hover,.slick-next:focus{color:transparent;outline:none;background:transparent}.slick-prev:hover:before,.slick-prev:focus:before,.slick-next:hover:before,.slick-next:focus:before{opacity:1}.slick-prev.slick-disabled:before,.slick-next.slick-disabled:before{opacity:.25}.slick-prev:before,.slick-next:before{font-family:'slick';font-size:20px;line-height:1;opacity:.75;color:#fff;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.slick-prev{left:-25px}[dir='rtl'] .slick-prev{right:-25px;left:auto}.slick-prev:before{content:'\2190'}[dir='rtl'] [dir='rtl'] .slick-next{right:auto;left:-25px}.slick-next:before{content:'\2192'}[dir='rtl'] .slick-next:before{content:'\2190'}.slick-dotted.slick-slider{margin-bottom:30px}.slick-dots{position:absolute;bottom:-25px;display:block;width:100%;padding:0;margin:0;list-style:none;text-align:center}.slick-dots li{position:relative;display:inline-block;width:20px;height:20px;margin:0 5px;padding:0;cursor:pointer}.slick-dots li button{font-size:0;line-height:0;display:block;width:20px;height:20px;padding:5px;cursor:pointer;color:transparent;border:0;outline:none;background:transparent}.slick-dots li button:hover,.slick-dots li button:focus{outline:none}.slick-dots li button:hover:before,.slick-dots li button:focus:before{opacity:1}.slick-dots li button:before{font-family:'slick';font-size:6px;line-height:20px;position:absolute;top:0;left:0;width:20px;height:20px;content:'\2022';text-align:center;opacity:.25;color:#000;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.slick-dots li.slick-active button:before{opacity:.75;color:#000}
:root{--col1:#e11114;--text:#201E1E;--borbis:#fff}*{box-sizing:border-box}body,html{overflow-x:hidden}body{background:#fff;min-height:100vh;display:flex;flex-direction:column;justify-content:flex-start}body,input,textarea,select,button{font-family:Barlow,sans-serif;font-size:18px;line-height:1.65;font-weight:400;color:var(--text);margin:0;-webkit-font-smoothing:antialiased;background:#fff}a{text-decoration:none;color:var(--text);transition:.3s;outline:none}a:hover{color:var(--col1)}a:active,a:focus{outline:0;border:none;-moz-outline-style:none}h1,h2,h3,h4,h5,h6,header nav ul li a{font-family:Montserrat,sans-serif;margin:0;font-weight:600;line-height:1.35}h1,h2,h3{text-transform:uppercase}h1{font-size:52px}h2{font-size:42px}h3{font-size:32px}h4,.fancytext h1{font-weight:600;font-size:23px}.single-producent .page-container h4,.intro{font-size:20px}h4 .reg{font-weight:400}p{margin:0 0 25px;text-align:justify}p:last-child{margin-bottom:0}.bottom_space{margin-bottom:15px!important}.large_bottom_space{margin-bottom:35px!important}.top_space{margin-top:15px!important}.center,.center p{text-align:center}b,strong{font-weight:600}:focus{outline:none}img{max-width:100%;height:auto;display:block}iframe{display:block}img.center{margin-left:auto;margin-right:auto}.container{width:90%;margin:0 auto}.page-container{padding:40px 0}.intro{padding-left:40px;border-left:4px solid;margin-bottom:25px;text-align:justify}.abs-link{position:absolute;top:0;left:0;width:100%;height:100%;z-index:100}input[type=text],input[type=email],input[type=password],input[type=tel],input[type=url],input[type=search],input[type=date],textarea,select{padding:10px 15px;border:2px solid #ddd;transition:.3s ease;width:100%;display:block}textarea{resize:none;height:150px}input[type=text]:focus,textarea:focus,input[type=email]:focus,input[type=search]:focus,input[type=password]:focus,input[type=tel]:focus,input[type=url]:focus,input[type=date]:focus,select:focus{border-color:var(--col1);box-shadow:0 0 10px rgba(0,0,0,.1)}select{padding:14px 15px}label input[type=checkbox]{margin-right:5px}.row{display:flex;flex-wrap:wrap;margin:0 -15px}.row.unwrap{flex-wrap:nowrap;justify-content:flex-start}.row.middle{align-items:center}.row.centered{justify-content:center}.row.nospace{margin:0}.row.bigspace{margin:0 -25px}.row.smallspace{margin:0 -10px}.col.shrink{flex-shrink:99999}.col{width:100%;padding:15px;position:relative}.row.unwrap .col{width:auto}.row.nospace .col{padding:0}.row.bigspace .col{padding:15px 25px}.row.smallspace .col{padding:10px}.col_inner{padding:35px 50px}.spread-row{display:flex;justify-content:space-between;align-items:center;position:relative}header .spread-row{position:initial}.bg{background-size:cover;background-repeat:no-repeat;background-position:center}.paralax{height:56.25vh;background-attachment:fixed}@media(min-width:1001px){.col_9{width:75%}.col_8{width:66.6666%}.col_7{width:60%}.col_6{width:50%}.col_5{width:40%}.col_4{width:33.3333%}.col_3{width:25%}.col_24{width:20%}.col_2{width:16.6666%}.spread-row{flex-wrap:nowrap}.menu-toggle{display:none}}@media(max-width:1000px){.norwd{display:none!important}}.button,input[type=submit],button{text-transform:uppercase;font-weight:500;font-family:Montserrat,sans-serif;color:#fff;font-size:105%;padding:10px 20px;transition:.4s ease;border:0;cursor:pointer}.button:not(.transparent),input[type=submit]:not(.transparent),button:not(.transparent){background:var(--text)}.button:hover,input[type=submit]:hover,button:hover,.fancybox:hover .button{background:var(--col1);color:#fff}.button-container{margin:10px -10px -10px}.button-container .button{margin:10px;display:inline-block}header{padding:20px 0;background:#fff;position:fixed;z-index:999;top:0;left:0;width:100%;transition:.3s ease;box-shadow:0 0 20px rgba(0,0,0,.1)}.header-space{height:85px}.logo{height:45px}.logo img{height:100%;width:auto}header nav ul{margin:0 -15px;padding:0;list-style:none;display:flex;align-items:center}header nav ul li{position:relative}header nav ul li a{display:block}header nav>ul>li>a{font-size:105%;line-height:35px;padding:0 15px}header nav ul li a.active,header nav ul li:hover>a,header nav ul li a:hover{color:var(--col1)}@media(min-width:1001px){nav li .submenu-container{position:absolute;left:0;top:calc(100% + 20px);transition:.5s top ease,.5s opacity ease,0s transform .5s ease;opacity:0;transform:scale(0);padding:25px 10px 0}nav li:hover>.submenu-container{top:100%;opacity:1;transform:scale(1);transition:top .3s ease,opacity .3s ease}nav li .submenu{background:#fff;box-shadow:0 10px 10px rgba(0,0,0,.1);width:200px}nav li .submenu a{padding:10px 15px;font-size:95%;border-radius:2px;position:relative}nav li .submenu a:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:var(--col1);transition:.3s ease;transform-origin:0 0;transform:scaleX(0)}nav li .submenu a span{color:var(--text);position:relative;z-index:2;transition:.3s ease}nav li .submenu a:hover span,nav li .submenu a.active span{color:#fff}nav li .submenu a:hover:after,nav li .submenu a.active:after{transform:scaleX(1)}}.slide,.slide-bg{position:relative}.slide-bg-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#fff;opacity:.65}.slide-content-container{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;padding:0 5%;align-items:center}.slide-content{text-align:right;margin-left:auto;text-transform:uppercase}.slide-content h2{font-weight:700}.slide-content h3{font-size:42px;font-weight:400}.slide-content h2 span{background:var(--col1);color:#fff;padding:5px 10px;display:inline-block}.slick-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:10;padding:20px;cursor:pointer;font-size:30px;transition:.3s ease;opacity:0}.slider:hover .slick-arrow{opacity:.5}.slider .slick-arrow:hover{opacity:1}.left-arrow{left:0}.right-arrow{right:0}.slick-arrow:before{position:relative}.left-arrow:before{left:-4px}.right-arrow:before{right:-4px}.fancybox{position:relative;color:#fff;padding:20%;overflow:hidden;height:100%}.fancybox-bg{position:absolute;top:0;left:0;width:100%;height:100%;transition:.4s ease}.fancybox-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:var(--text);opacity:.3;transition:.4s ease}.fancybox-content{position:relative}.fancybox h2{margin-bottom:10px}.fancybox .button{transition:.4s ease}.fancybox:not(.nohover):hover .fancybox-bg,.fancybox:not(.nohover):hover .fancybox-overlay{transform:scale(.9)}.fancybox:not(.nohover):hover .fancybox-overlay{opacity:.15}.fo-white{background:#fff;opacity:.75}.fo-red{background:var(--col1);opacity:.75}.fo-strong-red{background:var(--col1);opacity:1}.fancybox:not(.nohover):hover .fo-strong-red{opacity:1;background:var(--text)}.fancytext{height:100%;background:var(--text);color:#fff;display:flex;justify-content:center;align-items:center;padding:30px 15%;flex-direction:column}.fancytext h1{text-transform:none}.fancytext h4{padding-bottom:30px;position:relative}.fancytext h4:after{content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:42%;height:2px;background:var(--col1)}.fancybox p{font-family:Montserrat,sans-serif;line-height:1.5;margin-bottom:30px}.logotypy{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;margin:20px -10px;}.logotyp{padding:10px;}.logotyp img{max-width:100%;height:auto;display:block;max-height:50px;}footer{margin-top:auto}.footer-widgets{padding:5px 0;background:#f1f1f1}.footer-widgets h3,.footer-widgets .logo{margin-bottom:15px;border-bottom:2px solid var(--col1);padding-bottom:5px}.footer-widgets .logo{height:37px;padding-bottom:10px}.footer-widgets p:not(:last-child){margin-bottom:20px}.footer-widgets p i{width:20px;margin-right:8px;position:relative;top:1px;display:inline-block;color:var(--col1)}.footer-menu a{display:block}.mapa{display:block;overflow:hidden;box-shadow:0 0 10px rgba(0,0,0,.1)}.mapa img{transition:.4s ease}.mapa img:hover{transform:scale(1.3)}.footer-copyright{background:var(--text);padding:12px 0;font-size:90%;color:rgba(255,255,255,.7);text-align:center}.footer-copyright .copyright-text a{color:var(--borbis)}.page-title{padding:50px 0;color:#fff;position:relative}.cta-overlay,.page-title-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:var(--text);opacity:.6}.page-title .container{position:relative}.breadcrumbs{color:#ddd}.breadcrumbs a:not(:hover){color:#fff}.top-image{float:right;margin-left:50px;margin-top:-90px;position:relative;box-shadow:20px 20px 30px rgba(0,0,0,.25);border:3px solid var(--col1)}.cta{position:relative;color:#fff;padding:40px 0}.cta-overlay{opacity:.3}.producent{height:100%;display:flex;justify-content:center;align-items:center;padding:20px;position:relative;border:2px solid #ddd;transition:.4s cubic-bezier(.4,0,.2,1)}.producent:hover{transform:scale(1.1);box-shadow:0 0 20px rgba(0,0,0,.1)}.producent:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:#fff;z-index:2}.producent:after{content:"";position:absolute;top:-2px;left:-2px;width:100%;height:100%;border:2px solid #ddd;transition:.4s cubic-bezier(.4,0,.2,1);border-color:var(--col1);transform:scale(0);transform-origin:0 0;z-index:1}.producent:hover:after{transform:scale(1)}.producent img{position:relative;z-index:3}.usluga{flex-direction:column;padding:50px 20px;text-align:center}.usluga i{font-size:60px;color:var(--col1);margin-bottom:30px}.usluga i,.usluga h4{position:relative;z-index:3}.subpage-img{max-height:100px;margin-top:-45px}.katalogi{display:flex;flex-wrap:wrap;justify-content:center;margin:-20px}.katalogi a{display:block;padding:20px}.katalogi a img{max-width:200px;box-shadow:5px 5px 0 rgb(32 30 30 / .2);transition:.3s ease}.katalogi a:hover img{box-shadow:5px 5px 0 var(--col1),5px 5px 20px rgb(0 0 0 / .1);transform:scale(1.05) translateY(-5px)}.table-container{overflow-x:auto}table{width:100%;border-spacing:0;background:#fff}tr:nth-child(odd) td{background:#f1f1f1}td{padding:10px}td:last-child{font-weight:700;text-align:right}.iconbox:not(:last-child){margin-bottom:15px}.iconbox i{font-size:30px;color:var(--col1)}.page-container+.page-container{border-top:2px solid #ddd}@media(max-width:1600px){.fancybox{padding:20% 15%}.fancytext{padding:30px 10%}}@media(max-width:1400px){.fancybox{padding:20% 5%}.fancytext{padding:30px 5%}body,input,textarea,select,button{font-size:17px}h1,.slide-content h3{font-size:40px}h2{font-size:50px}h3{font-size:30px}h4,.fancytext h1{font-size:22px}.single-producent .page-container h4,.intro{font-size:19px}.logotyp{padding:20px}}@media(max-width:1200px){.fancybox{padding:20% 10px}body,input,textarea,select,button{font-size:16px}h1,.slide-content h3{font-size:35px}h2{font-size:45px}h3{font-size:27px}h4,.fancytext h1{font-size:20px}.single-producent .page-container h4,.intro{font-size:18px}.logotyp{padding:20px 10px}}@media(max-width:1000px){.menu{position:absolute;top:100%;left:0;width:100%;transform-origin:0 0;transition:.4s ease;transform:scaleY(0)}.menu.active{transform:scaleY(1)}header nav ul{margin:0;display:block;background:#f1f1f1;padding:10px 5%}header nav>ul>li>a{padding:5px 0;line-height:1.5}.submenu-container{padding-left:5%;display:none}.submenu-container a{font-size:95%;padding:3px 0}header nav ul li:hover>a,header nav ul li a:hover{color:var(--text)}.logo{height:25px}header{padding:15px 0}.header-space{height:55px}.fancybox,.fancytext{padding:30px}.logotypy{flex-wrap:wrap;justify-content:center}.logotyp img{max-height:25px}.slick-arrow{opacity:1;font-size:20px;padding:2%}.slick-slide img{height:250px;max-width:unset}.top-image{float:none;margin:0 0 20px;box-shadow:10px 10px 20px rgba(0,0,0,.15);border:2px solid var(--col1)}.subpage-img{margin-top:-15px}.col_6:last-child>.top-image{margin:10px 0 0}.page-title{padding:40px 0}body,input,textarea,select,button{font-size:15px}h1,.slide-content h3{font-size:30px}h2{font-size:40px}h3{font-size:25px}h4,.fancytext h1{font-size:18px}.single-producent .page-container h4,.intro{font-size:16px}}@media(max-width:800px){.slide-content h2{font-weight:600}.slide-content-container{padding:0 40px}.slide-content{text-align:center;margin:0 auto}}@media(max-width:600px){.slick-arrow{font-size:18px}.page-title{padding:30px 0}body,input,textarea,select,button{font-size:14px}h1,.slide-content h3{font-size:25px}h2{font-size:30px}h3{font-size:22px}h4,.fancytext h1{font-size:17px}.single-producent .page-container h4,.intro{font-size:15px}}.social-side-icons{position:fixed;z-index:99999;left:0;top:310px}.social-side-icons a{display:block;width:35px;height:35px;margin-bottom:5px;background-size:contain;background-repeat:no-repeat;background-position:right;border-radius:0;transition:.3s ease}.social-side-icons a:hover{width:50px}.social-side-icons .fb{background-image:url(img/soc/fb.png);background-color:#3a559f}.home .social-side-icons{top:100px}@media(max-width:1000px){.social-side-icons{top:220px}.social-side-icons a{width:30px;height:30px}.home .social-side-icons{top:64px}}@media(max-width:600px){.social-side-icons{top:180px}.social-side-icons a{width:20px;height:20px}}

@media(min-width:1001px){.logotyp img{max-width:150px;height:auto;}}
.logotypy {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    margin: 20px -10px;
}

.logotyp {
    padding: 10px;
    flex: 1 1 120px; /* Allow flexibility and wrapping */
    max-width: 244px; /* Ensure max width constraint */
}

.logotyp img {
    max-width: 100%;
    height: auto; /* Maintain aspect ratio */
    display: block;
}

.logotypy {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    margin: 20px -10px;
}

.logotyp {
    padding: 10px;
    flex: 1 1 120px; /* Allow flexibility and wrapping */
    max-width: 244px; /* Ensure max width constraint */
}

.logotyp img {
    max-width: 100%;
    height: auto; /* Maintain aspect ratio */
    display: block;
    max-height: 50px; /* Adjust this value as needed */
    object-fit: contain; /* Ensure images maintain their aspect ratio */
}

/* Styl dla slajdera */
.slider {
    margin-top: 50px; /* Adjust if needed */
    max-height: max(250px, 28.645833333vw);
    overflow-y: hidden;
    position: relative;
    width: 100%;
}

.slide {
    position: relative;
    width: 100%;
}

.slide-bg {
    position: relative;
    width: 100%;
    height: auto;
    display: flex;
    justify-content: center;
    align-items: center;
}

.slide-bg img {
    width: 100%;
    height: auto;
}

.slide-bg-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.3); /* Optional overlay */
}

.slide-content-container {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
    text-align: center;
    color: #fff; /* Optional text color */
}

.bottom_space {
    margin-bottom: 20px; /* Optional spacing under heading */
}

@media (max-width: 600px) {
    .slider {
    margin-top: 50px; /* Adjust if needed */
        max-height: 250px;
    }
    .slide-content-container h1,
    .slide-content-container h2 {
        font-size: 1.2em; /* Reduce font size on mobile */
    }
}

/* Styl dla paralaksu */
.bg {
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}

.paralax {
    height: 56.25vh;
    background-attachment: fixed;
}

@media (max-width: 600px) {
    .paralax {
        background-attachment: scroll;
    }
}

@media screen and (orientation: landscape) and (max-width: 1024px) {
    .paralax {
        background-size: cover;
        background-attachment: scroll;
        height: 56.25vh;
    }
}

@media screen and (orientation: portrait) and (max-width: 600px) {
    .paralax {
        background-size: cover;
        background-attachment: scroll;
        height: 56.25vh;
    }
}

.slick-slide img {
  display: block;
  width: 100%;
  height: auto;
}

.slick-slide.slick-loading img {
  display: none;
  width: 100%;
  height: auto;
}

.slider {
    margin-top: 50px; /* Adjust if needed */
  position: relative;
  max-height: 550px; /* Match image height attribute */
  overflow: hidden;
}

.slide-bg {
  height: 100%; /* Background should fill slider height */
  width: 100%; /* Background should fill slider width */
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}

.slide-content-container {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: auto;
}

.slide-bg-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5); /* Semi-transparent overlay */
}

.row.nospace {
    margin: 0;
    }

/* Optymalizacja CSS */
img {
    max-width: 100%;
    height: auto;
    display: block;
}

/* Disable lazy loading above the fold */
img[alt="Drzwi wewnetrzne i zewnetrzne Poznan"] {
    loading: auto;
}

/* Mobile slider hotfix: remove extra gray gaps around hero. */
.slider {
  margin-top: 0 !important;
}

@media (max-width: 1000px) {
  .slider {
    height: 250px !important;
    max-height: 250px !important;
    overflow: hidden !important;
  }

  .slider .slick-list,
  .slider .slick-track,
  .slider .slick-slide,
  .slider .slide,
  .slider .slide-bg {
    height: 250px !important;
    min-height: 250px !important;
  }

  .slider .slick-slide img,
  .slider .slide-bg img {
    width: 100% !important;
    height: 250px !important;
    max-width: none !important;
    object-fit: cover !important;
    object-position: center center !important;
  }

  .slider .slide-content-container {
    top: 0 !important;
    left: 0 !important;
    transform: none !important;
    width: 100% !important;
    height: 100% !important;
  }

  .slider .slick-arrow {
    top: 50% !important;
    transform: translateY(-50%) !important;
  }
}

/* Contact page mobile readability fixes. */
@media (max-width: 600px) {
  .field-zgoda {
    text-align: left;
  }

  .field-zgoda label {
    display: block;
    line-height: 1.45;
  }

  .field-zgoda label input[type="checkbox"] {
    margin-right: 8px;
    vertical-align: top;
    position: relative;
    top: 0.2em;
  }

  .field-zgoda a {
    margin: 0;
    padding: 0;
    min-width: 0;
    min-height: 0;
    display: inline;
    font-size: inherit;
    line-height: inherit;
  }

  .cta .spread-row {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  .cta .button {
    margin: 0;
  }
}

/* Global text flow fix: avoid stretched spaces in justified paragraphs. */
p,
.intro,
.field-zgoda {
  text-align: left;
  text-justify: auto;
}

/* Home tiles redesign on mobile: cleaner order, spacing and readability. */
@media (max-width: 1000px) {
  .home .home-tiles {
    width: 92%;
    margin: 24px auto;
    gap: 12px;
    min-height: 0 !important;
    overflow: visible !important;
    background: transparent;
  }

  .home .home-tiles > .col {
    width: 100%;
    padding: 0;
  }

  .home .home-tiles .tile-service,
  .home .home-tiles .tile-intro,
  .home .home-tiles .tile-side-left,
  .home .home-tiles .tile-side-right {
    display: none;
  }

  .home .home-tiles .tile-floors {
    order: 1;
  }

  .home .home-tiles .tile-doors {
    order: 2;
  }

  .home .home-tiles .tile-terraces {
    order: 3;
  }

  .home .home-tiles .fancybox {
    min-height: 240px;
    padding: 0;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 8px 22px rgba(0, 0, 0, 0.16);
  }

  .home .home-tiles .fancybox-bg,
  .home .home-tiles .fancybox-bg img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
  }

  .home .home-tiles .fancybox-overlay {
    opacity: 1;
    background: linear-gradient(180deg, rgba(14, 14, 16, 0.18) 0%, rgba(14, 14, 16, 0.76) 100%);
  }

  .home .home-tiles .fancybox-content {
    min-height: 240px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-start;
    text-align: left;
    padding: 18px 16px;
  }

  .home .home-tiles .fancybox h2 {
    font-size: 42px;
    line-height: 1;
    margin-bottom: 6px;
    letter-spacing: 0.01em;
  }

  .home .home-tiles .fancybox p {
    margin: 0 0 12px;
    max-width: 24ch;
    line-height: 1.3;
    font-size: 16px;
    text-align: left;
  }

  .home .home-tiles .fancybox .button {
    margin: 0;
    padding: 10px 16px;
    min-width: 0;
    min-height: 0;
    font-size: 14px;
    letter-spacing: 0.02em;
  }

  .home .social-side-icons {
    display: none;
  }
}

@media (max-width: 600px) {
  .home .home-tiles {
    width: 94%;
    margin: 18px auto 22px;
    gap: 10px;
  }

  .home .home-tiles .fancybox,
  .home .home-tiles .fancybox-content {
    min-height: 220px;
    border-radius: 10px;
  }

  .home .home-tiles .fancybox h2 {
    font-size: 34px;
  }

  .home .home-tiles .fancybox p {
    font-size: 15px;
    max-width: 25ch;
  }
}

/* Mobile readability and local hero polish. */
.page-title h1 {
  max-width: 24ch;
  text-wrap: balance;
}

.page-title-subtitle {
  margin-top: 10px;
  color: rgba(255, 255, 255, 0.92);
  font-family: Montserrat, sans-serif;
  font-size: 17px;
  line-height: 1.45;
  max-width: 46ch;
}

@media (max-width: 1000px) {
  .page-title {
    padding: 30px 0;
  }

  .page-title h1 {
    font-size: 34px;
    line-height: 1.14;
    text-transform: none;
    margin-bottom: 4px;
  }

  .page-title-subtitle {
    font-size: 15px;
    line-height: 1.4;
  }

  .breadcrumbs {
    margin-top: 8px;
    font-size: 13px;
    line-height: 1.35;
  }

  .home .slide-content h2 {
    text-transform: none;
    line-height: 1.15;
    max-width: 16ch;
  }

  .home .slide-content h3 {
    font-size: 24px;
    line-height: 1.2;
  }

  .page-container h2 {
    text-transform: none;
    line-height: 1.2;
    letter-spacing: 0;
    margin-bottom: 14px;
  }

  .home .page-container h1 {
    text-transform: none;
    line-height: 1.18;
    font-size: 34px;
  }

  .page-container p,
  .page-container li {
    line-height: 1.72;
  }
}

@media (max-width: 600px) {
  .page-title {
    padding: 24px 0;
  }

  .page-title h1 {
    font-size: 29px;
  }

  .page-title-subtitle {
    font-size: 14px;
  }

  .breadcrumbs {
    display: none;
  }

  .home .slide-content h2 {
    font-size: 25px;
    max-width: 12ch;
  }

  .home .slide-content h3 {
    display: block;
    font-size: 15px;
    line-height: 1.25;
    margin-top: 8px;
  }

  .home .slide-content h3 .fo-strong-red {
    display: inline-block;
    padding: 4px 8px;
  }

  .page-container h2 {
    font-size: 28px;
  }

  .home .page-container h1 {
    font-size: 30px;
  }
}

/* Slider arrows + mobile hero text visibility fix */
.slider .slick-arrow {
  color: #fff !important;
  z-index: 20 !important;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.55);
}

@media (max-width: 1000px) {
  .slider .left-arrow {
    left: 10px !important;
  }

  .slider .right-arrow {
    right: 10px !important;
  }

  .slider .slick-arrow {
    opacity: 1 !important;
    font-size: 24px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
  }
}
/* Slider final visibility fix */
.slider .slick-arrow {
  opacity: 0.92 !important;
}

.slider i.left-arrow,
.slider i.right-arrow {
  display: block !important;
}

@media (max-width: 1000px) {
  .home .slider .slide-content h3 {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
  }

  .home .slider .slide-content h3 .fo-strong-red {
    white-space: nowrap;
  }
}
/* Hard slider arrows/text visibility fix (desktop + mobile) */
.slider .slick-arrow {
  opacity: 1 !important;
}

.slider .hero-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 30;
  width: 42px;
  height: 42px;
  border: 0;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.45);
  color: #fff;
  font-size: 28px;
  line-height: 42px;
  text-align: center;
  cursor: pointer;
  padding: 0;
  text-shadow: none;
}

.slider .hero-arrow:hover {
  background: rgba(0, 0, 0, 0.65);
}

.slider .left-arrow.hero-arrow { left: 10px; }
.slider .right-arrow.hero-arrow { right: 10px; }

@media (max-width: 1000px) {
  .home .slider .slide-content {
    max-width: 88%;
    margin: 0 auto;
    text-align: center;
  }

  .home .slider .slide-content h2 {
    font-size: 24px;
    line-height: 1.15;
    margin-bottom: 8px;
  }

  .home .slider .slide-content h3 {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    font-size: 16px !important;
    line-height: 1.2;
    margin-top: 8px;
  }

  .home .slider .slide-content h3 .fo-strong-red {
    display: inline-block;
    white-space: nowrap;
    padding: 4px 8px;
  }

  .slider .hero-arrow {
    width: 36px;
    height: 36px;
    font-size: 24px;
    line-height: 36px;
  }

  .slider .left-arrow.hero-arrow { left: 8px; }
  .slider .right-arrow.hero-arrow { right: 8px; }
}

/* Active slider arrows force-fix (desktop + mobile) */
.slider .slick-prev,
.slider .slick-next,
.slider .slick-arrow,
.slider .hero-arrow {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  opacity: 1 !important;
  visibility: visible !important;
  font-size: 34px !important;
  line-height: 1 !important;
  color: #fff !important;
  width: 44px !important;
  height: 44px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: rgba(0, 0, 0, 0.55) !important;
  text-shadow: none !important;
  z-index: 40 !important;
}

.slider .slick-prev:before,
.slider .slick-next:before {
  content: '' !important;
}

.slider .left-arrow { left: 10px !important; }
.slider .right-arrow { right: 10px !important; }

.home .slider .slide-content h3 {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

@media (max-width: 1000px) {
  .slider .slick-prev,
  .slider .slick-next,
  .slider .slick-arrow,
  .slider .hero-arrow {
    width: 36px !important;
    height: 36px !important;
    font-size: 26px !important;
  }

  .slider .left-arrow { left: 8px !important; }
  .slider .right-arrow { right: 8px !important; }
}

/* Final slider controls + mobile caption stability fix */
.slider .slick-prev,
.slider .slick-next {
  left: auto;
  right: auto;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  opacity: 1 !important;
  visibility: visible !important;
  z-index: 60 !important;
}

.slider .slick-prev {
  left: 12px !important;
  right: auto !important;
}

.slider .slick-next {
  right: 12px !important;
  left: auto !important;
}

.slider .slick-prev:before,
.slider .slick-next:before {
  content: none !important;
}

@media (max-width: 1000px) {
  .home .slider .slide-content-container {
    top: auto !important;
    bottom: 14px !important;
    left: 0 !important;
    right: 0 !important;
    transform: none !important;
    width: 100% !important;
    height: auto !important;
    padding: 0 52px !important;
    align-items: flex-end !important;
    justify-content: center !important;
  }

  .home .slider .slide-content {
    margin: 0 auto !important;
    max-width: 100% !important;
    text-align: center !important;
  }

  .home .slider .slide-content h2 {
    margin: 0 0 6px !important;
    font-size: 20px !important;
    line-height: 1.15 !important;
  }

  .home .slider .slide-content h3 {
    display: block !important;
    margin: 0 !important;
    font-size: 14px !important;
    line-height: 1.15 !important;
    visibility: visible !important;
    opacity: 1 !important;
  }

  .home .slider .slide-content h3 .fo-strong-red {
    display: inline-block !important;
    padding: 4px 8px !important;
  }
}

/* Homepage hero: final, clean caption and arrows layout (desktop + mobile) */
.home .slider {
  margin-top: 0 !important;
  position: relative;
}

.home .slider .slide-content-container {
  position: absolute !important;
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  left: 0 !important;
  transform: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  padding: 0 5vw !important;
  z-index: 5 !important;
}

.home .slider .slide-content {
  margin: 0 !important;
  max-width: min(70vw, 900px) !important;
  text-align: right !important;
  text-transform: uppercase !important;
}

.home .slider .slide-content h2 {
  margin: 0 0 10px !important;
  font-size: clamp(36px, 3.2vw, 58px) !important;
  font-weight: 700 !important;
  line-height: 1.08 !important;
  letter-spacing: 0.01em !important;
  text-transform: uppercase !important;
}

.home .slider .slide-content h3 {
  display: block !important;
  margin: 0 !important;
  font-size: clamp(24px, 2.2vw, 42px) !important;
  font-weight: 500 !important;
  line-height: 1.1 !important;
  text-transform: uppercase !important;
  visibility: visible !important;
  opacity: 1 !important;
}

.home .slider .slide-content h3 .fo-strong-red {
  display: inline-block !important;
  padding: 4px 10px !important;
  white-space: normal !important;
  background: #e11114 !important;
  color: #fff !important;
}

.home .slider .slick-prev,
.home .slider .slick-next,
.home .slider .hero-arrow {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  opacity: 1 !important;
  visibility: visible !important;
  z-index: 80 !important;
  width: 44px !important;
  height: 44px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: rgba(0, 0, 0, 0.55) !important;
  color: #fff !important;
  font-size: 32px !important;
  line-height: 1 !important;
  text-shadow: none !important;
}

.home .slider .slick-prev {
  left: 12px !important;
  right: auto !important;
}

.home .slider .slick-next {
  right: 12px !important;
  left: auto !important;
}

.home .slider .slick-prev:before,
.home .slider .slick-next:before {
  content: none !important;
}

@media (max-width: 1000px) {
  .home .slider .slide-content-container {
    align-items: flex-end !important;
    justify-content: center !important;
    padding: 0 56px 14px !important;
  }

  .home .slider .slide-content {
    max-width: 100% !important;
    text-align: center !important;
  }

  .home .slider .slide-content h2 {
    margin: 0 auto 7px !important;
    max-width: 16ch !important;
    font-size: clamp(24px, 7.2vw, 34px) !important;
    line-height: 1.06 !important;
    text-transform: uppercase !important;
  }

  .home .slider .slide-content h3 {
    font-size: clamp(14px, 4vw, 19px) !important;
    line-height: 1.12 !important;
    text-transform: uppercase !important;
  }

  .home .slider .slide-content h3 .fo-strong-red {
    padding: 4px 8px !important;
    white-space: normal !important;
  }

  .home .slider .slick-prev,
  .home .slider .slick-next,
  .home .slider .hero-arrow {
    width: 36px !important;
    height: 36px !important;
    font-size: 24px !important;
  }

  .home .slider .slick-prev {
    left: 8px !important;
  }

  .home .slider .slick-next {
    right: 8px !important;
  }
}

@media (max-width: 600px) {
  .home .slider .slide-content-container {
    padding: 0 54px 12px !important;
  }

  .home .slider .slide-content h2 {
    font-size: clamp(21px, 6.8vw, 30px) !important;
    max-width: 17ch !important;
    line-height: 1.08 !important;
  }

  .home .slider .slide-content h3 {
    font-size: clamp(13px, 3.8vw, 16px) !important;
    line-height: 1.14 !important;
  }
}

/* Homepage producer logos: mobile compact strip without JS carousel */
.home .logos-hint-mobile {
  display: none;
}

@media (max-width: 1000px) {
  .home .logos-hint-mobile {
    display: block !important;
    margin: 6px 12px 10px !important;
    font-size: 13px !important;
    line-height: 1.25 !important;
    color: rgba(32, 30, 30, 0.65) !important;
    text-align: center !important;
    text-transform: none !important;
  }

  .home .logotypy {
    display: flex !important;
    flex-wrap: nowrap !important;
    justify-content: flex-start !important;
    align-items: center !important;
    gap: 10px !important;
    margin: 12px 0 16px !important;
    padding: 0 12px 6px !important;
    overflow-x: auto !important;
    overscroll-behavior-x: contain;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: none;
  }

  .home .logotyp {
    flex: 0 0 auto !important;
    width: 112px !important;
    max-width: 112px !important;
    padding: 4px !important;
    scroll-snap-align: none;
  }

  .home .logotyp img {
    width: 100% !important;
    height: 38px !important;
    max-height: 38px !important;
    object-fit: contain !important;
    margin: 0 auto !important;
  }

  .home .logotypy::-webkit-scrollbar {
    height: 5px;
  }

  .home .logotypy::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0.2);
    border-radius: 999px;
  }
}

@media (max-width: 600px) {
  .home .logos-hint-mobile {
    margin: 6px 12px 8px !important;
    font-size: 12px !important;
  }

  .home .logotyp {
    width: 96px !important;
    max-width: 96px !important;
  }

  .home .logotyp img {
    height: 32px !important;
    max-height: 32px !important;
  }
}

/* Mobile footer compaction */
@media (max-width: 1000px) {
  footer .footer-widgets {
    padding: 0 !important;
  }

  footer .footer-widgets .row.bigspace {
    margin: 0 -8px !important;
  }

  footer .footer-widgets .col {
    padding: 10px 8px !important;
  }

  footer .footer-widgets .logo {
    display: none !important;
  }

  footer .footer-widgets h3 {
    margin-bottom: 8px !important;
    padding-bottom: 4px !important;
    font-size: 16px !important;
    line-height: 1.15 !important;
  }

  footer .footer-widgets p {
    margin: 0 0 10px !important;
    line-height: 1.4 !important;
  }

  footer .footer-widgets .mapa img {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 2 / 1;
    object-fit: cover !important;
  }

  footer .footer-menu a {
    display: block !important;
    padding: 2px 0 !important;
    font-size: 16px !important;
    line-height: 1.35 !important;
  }

  footer .footer-widgets .col:nth-child(3),
  footer .footer-widgets .col:nth-child(4) {
    width: 50% !important;
  }

  footer .footer-copyright {
    padding: 8px 0 !important;
    font-size: 85% !important;
  }
}

@media (max-width: 600px) {
  footer .footer-widgets .col {
    padding: 8px 8px !important;
  }

  footer .footer-widgets h3 {
    font-size: 15px !important;
  }

  footer .footer-widgets .mapa img {
    aspect-ratio: 16 / 9;
    height: auto !important;
  }

  footer .footer-menu a {
    font-size: 15px !important;
  }
}

/* Footer map (static preview) */
footer .footer-widgets .footer-map-link {
  display: block;
  overflow: hidden;
  border: 1px solid #ddd;
  border-radius: 8px;
  box-shadow: none;
  background: #f5f5f5;
}

footer .footer-widgets .footer-map-link picture {
  display: block;
}

footer .footer-widgets .footer-map-link img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 2 / 1;
  object-fit: cover;
  transition: none;
}

footer .footer-widgets .footer-map-link:hover img {
  transform: none;
}

footer .footer-widgets .footer-map-actions {
  margin-top: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

footer .footer-widgets .footer-map-actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 10px;
  border: 1px solid #d4d4d4;
  border-radius: 6px;
  background: #fff;
  font-size: 14px;
  line-height: 1.2;
}

footer .footer-widgets .footer-map-actions a:hover {
  border-color: var(--col1);
  color: var(--col1);
}

@media (max-width: 1000px) {
  footer .footer-widgets .footer-map-actions a {
    flex: 1 1 calc(50% - 4px);
    min-height: 34px;
  }
}

@media (max-width: 760px) {
  footer .footer-widgets .col:nth-child(3),
  footer .footer-widgets .col:nth-child(4) {
    width: 100% !important;
  }

  footer .footer-widgets .footer-map-link img {
    aspect-ratio: 16 / 9;
  }

  footer .footer-widgets .footer-map-actions a {
    flex: 1 1 100%;
  }
}

/* Mobile overflow guard for all subpages (DRE and similar long headings/text) */
.row > .col { min-width: 0; }

/* Legacy templates: allow direct text nodes inside .row without flex overflow */
.row > h1,
.row > h2,
.row > h3,
.row > h4,
.row > h5,
.row > h6,
.row > p,
.row > ul,
.row > ol {
  flex: 0 0 100%;
  max-width: 100%;
  min-width: 0;
}

@media (max-width: 1000px) {
  .row > h2 {
    font-size: clamp(28px, 7.2vw, 34px);
    line-height: 1.15;
    margin-bottom: 12px;
  }

  .row > h3 {
    font-size: clamp(22px, 5.8vw, 28px);
    line-height: 1.2;
  }

  .extra-margin-top {
    margin-top: 24px !important;
  }

  .large_bottom_space {
    margin-bottom: 20px !important;
  }

  .page-title h1,
  .page-title-subtitle,
  .container h1,
  .container h2,
  .container h3,
  .container p,
  .container li,
  .breadcrumbs {
    overflow-wrap: anywhere;
    word-break: break-word;
    hyphens: auto;
    max-width: 100%;
  }

  .container p,
  .container li,
  .intro,
  .field-zgoda {
    text-align: left;
  }
}

/* Final heading scale normalization (desktop + mobile)
   Keeps homepage slider hero untouched. */

/* Homepage content typography (not slider hero) */
.home .container.page-container {
  max-width: 1240px;
}

.home .container.page-container h1 {
  font-size: clamp(20px, 1.6vw, 28px) !important;
  line-height: 1.2 !important;
  margin-bottom: 12px !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

.home .container.page-container h2 {
  font-size: clamp(18px, 1.35vw, 24px) !important;
  line-height: 1.22 !important;
  margin-bottom: 10px !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

.home .container.page-container h3 {
  font-size: clamp(17px, 1.15vw, 21px) !important;
  line-height: 1.24 !important;
  margin-bottom: 10px !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

.home .container.page-container h4 {
  font-size: clamp(16px, 1vw, 19px) !important;
  line-height: 1.28 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

.home .container.page-container .intro {
  font-size: clamp(17px, 1.2vw, 20px) !important;
}

@media (max-width: 1000px) {
  

  

  

  

  

  .home .container.page-container h1 {
    font-size: clamp(20px, 5.2vw, 26px) !important;
    line-height: 1.22 !important;
    margin-bottom: 10px !important;
    text-transform: none !important;
  }

  .home .container.page-container h2 {
    font-size: clamp(18px, 4.8vw, 22px) !important;
    line-height: 1.24 !important;
    margin-bottom: 8px !important;
    text-transform: none !important;
  }

  .home .container.page-container h3 {
    font-size: clamp(17px, 4.4vw, 20px) !important;
    line-height: 1.26 !important;
    text-transform: none !important;
  }

  .home .container.page-container h4 {
    font-size: clamp(16px, 4vw, 18px) !important;
    text-transform: none !important;
  }

  .home .container.page-container .intro {
    font-size: clamp(16px, 4.2vw, 18px) !important;
  }
}

/* Subpage hero section: image crop + spacing + proportions */

@media (max-width: 1000px) {
  

  

  

  

  

  

  

  
}

/* Home slider runtime classes (home-lite.js) */
.home .slider > .slide { display: none; }
.home .slider > .slide.is-active { display: block; }
.home .slider > .slide:first-child { display: block; }

/* === Homepage visual stabilization (final override) === */
.home .slider {
  margin-top: 0 !important;
  height: clamp(260px, 28.645833333vw, 550px) !important;
  max-height: 550px !important;
  overflow: hidden !important;
  background: #1f1f22;
}

.home .slider .slick-list,
.home .slider .slick-track,
.home .slider .slick-slide,
.home .slider .slide,
.home .slider .slide-bg {
  height: 100% !important;
  min-height: 100% !important;
}

.home .slider .slide-bg img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
}

.home .slider .slide-bg-overlay {
  opacity: 1 !important;
  background: linear-gradient(
    90deg,
    rgba(0, 0, 0, 0.38) 0%,
    rgba(0, 0, 0, 0.28) 40%,
    rgba(0, 0, 0, 0.24) 100%
  ) !important;
}

.home .slider .slide-content-container {
  position: absolute !important;
  inset: 0 !important;
  transform: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  padding: 0 clamp(52px, 4.5vw, 92px) !important;
  z-index: 10 !important;
}

.home .slider .slide-content {
  margin: 0 !important;
  max-width: min(64vw, 840px) !important;
  text-align: right !important;
  text-transform: uppercase !important;
}

.home .slider .slide-content h2 {
  margin: 0 0 10px !important;
  font-size: clamp(34px, 3.2vw, 56px) !important;
  line-height: 1.08 !important;
  letter-spacing: 0.01em !important;
  text-transform: uppercase !important;
}

.home .slider .slide-content h3 {
  margin: 0 !important;
  font-size: clamp(20px, 2.1vw, 38px) !important;
  line-height: 1.12 !important;
  text-transform: uppercase !important;
}

.home .slider .slide-content h3 .fo-strong-red {
  display: inline-block !important;
  padding: 4px 10px !important;
  background: #e11114 !important;
  color: #fff !important;
}

.home .slider .hero-arrow {
  z-index: 90 !important;
  width: 42px !important;
  height: 42px !important;
  font-size: 30px !important;
  line-height: 1 !important;
  background: rgba(0, 0, 0, 0.54) !important;
}

.home .slider .left-arrow.hero-arrow {
  left: 10px !important;
}

.home .slider .right-arrow.hero-arrow {
  right: 10px !important;
}

@media (max-width: 1000px) {
  .home .slider {
    height: 250px !important;
    max-height: 250px !important;
  }

  .home .slider .slide-content-container {
    align-items: flex-end !important;
    justify-content: center !important;
    padding: 0 56px 12px !important;
  }

  .home .slider .slide-content {
    max-width: 100% !important;
    text-align: center !important;
  }

  .home .slider .slide-content h2 {
    margin: 0 auto 6px !important;
    max-width: 16ch !important;
    font-size: clamp(22px, 6.3vw, 30px) !important;
    line-height: 1.08 !important;
    text-transform: uppercase !important;
  }

  .home .slider .slide-content h3 {
    font-size: clamp(13px, 3.5vw, 16px) !important;
    line-height: 1.15 !important;
    text-transform: uppercase !important;
  }

  .home .slider .slide-content h3 .fo-strong-red {
    padding: 4px 8px !important;
  }

  .home .slider .hero-arrow {
    width: 34px !important;
    height: 34px !important;
    font-size: 22px !important;
  }
}

.home .home-tiles {
  margin-top: 0 !important;
}

.home .home-tiles .fancybox-bg img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

@media (min-width: 1001px) {
  .home .home-tiles .tile-doors .fancybox,
  .home .home-tiles .tile-terraces .fancybox,
  .home .home-tiles .tile-floors .fancybox {
    min-height: 300px;
  }

  .home .home-tiles .fancybox-content p {
    max-width: 24ch;
    margin-left: auto;
    margin-right: auto;
  }
}

.home .container.page-container {
  max-width: 1160px;
}

.home .container.page-container p,
.home .container.page-container li {
  line-height: 1.7;
}

/* === Homepage hero CTA + top-aligned text === */
.home .slider-container {
  position: relative;
}

.home .slider .slide-content-container {
  align-items: flex-start !important;
  padding-top: clamp(18px, 3vw, 54px) !important;
  padding-bottom: 0 !important;
}

.home .slider .slide-content {
  margin-top: 0 !important;
}

.home .home-hero-cta {
  position: absolute;
  left: 50%;
  bottom: 14px;
  transform: translateX(-50%);
  z-index: 95;
  display: flex;
  gap: 10px;
}

.home .home-hero-cta .hero-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 176px;
  padding: 10px 16px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.38);
  background: rgba(0, 0, 0, 0.58);
  color: #fff;
  font-family: Montserrat, sans-serif;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: 0.01em;
  text-transform: uppercase;
}

.home .home-hero-cta .hero-cta:hover {
  background: #e11114;
  border-color: #e11114;
  color: #fff;
}

.home .home-mobile-float-cta {
  display: none;
}

@media (max-width: 1000px) {
  .home .slider .slide-content-container {
    display: block !important;
    padding: 16px 58px 0 !important;
    text-align: center !important;
  }

  .home .slider .slide-content {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    text-align: center !important;
  }

  .home .slider .slide-content h2,
  .home .slider .slide-content h3 {
    width: 100% !important;
    text-align: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .home .slider .slide-content h2 {
    max-width: 13ch !important;
  }

  .home .slider .slide-content h3 {
    max-width: 18ch !important;
  }

  .home .slider .slide-content h2 strong,
  .home .slider .slide-content h3 span {
    display: inline-block;
  }

  .home .home-hero-cta {
    display: none;
  }

  .home .home-mobile-float-cta {
    display: flex;
    position: fixed;
    right: 0;
    top: auto !important;
    bottom: max(86px, env(safe-area-inset-bottom));
    transform: none !important;
    z-index: 998;
    align-items: center;
    justify-content: flex-end;
  }

  .home .home-mobile-float-cta .float-cta-toggle {
    position: relative;
    z-index: 2;
    width: 28px;
    height: 52px;
    border: 0;
    border-radius: 14px 0 0 14px;
    background: rgba(32, 30, 30, 0.88);
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.24);
  }

  .home .home-mobile-float-cta .float-cta-toggle-icon {
    font-size: 22px;
    line-height: 1;
    transform: translateX(1px) rotate(0deg);
    transition: transform 0.25s ease;
  }

  .home .home-mobile-float-cta .float-cta-panel {
    position: absolute;
    right: calc(100% + 6px);
    top: 50%;
    display: flex;
    flex-direction: column;
    gap: 8px;
    transform: translateY(-50%) translateX(14px);
    opacity: 0;
    pointer-events: none;
    transition: transform 0.25s ease, opacity 0.2s ease;
  }

  .home .home-mobile-float-cta.is-open .float-cta-panel {
    transform: translateY(-50%) translateX(0);
    opacity: 1;
    pointer-events: auto;
  }

  .home .home-mobile-float-cta.is-open .float-cta-toggle-icon {
    transform: translateX(-1px) rotate(180deg);
  }

  .home .home-mobile-float-cta .float-cta {
    min-width: 92px;
    padding: 9px 11px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.28);
    background: rgba(0, 0, 0, 0.78);
    color: #fff;
    font-family: Montserrat, sans-serif;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    text-align: center;
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.24);
  }

  .home .home-mobile-float-cta .float-cta-measure {
    background: rgba(225, 17, 20, 0.92);
    border-color: #e11114;
  }
}

@media (max-width: 600px) {
  .home .home-mobile-float-cta {
    bottom: max(82px, env(safe-area-inset-bottom));
  }

  .home .home-mobile-float-cta .float-cta-toggle {
    width: 26px;
    height: 48px;
  }

  .home .home-mobile-float-cta .float-cta {
    min-width: 84px;
    font-size: 11px;
    padding: 8px 9px;
  }
}

/* Mobile homepage hero caption: center vertically + horizontally */
@media (max-width: 1000px) {
  body.home .slider .slide-content-container {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 58px !important;
    text-align: center !important;
  }

  body.home .slider .slide-content {
    width: 100% !important;
    max-width: min(84vw, 360px) !important;
    margin: 0 auto !important;
    text-align: center !important;
  }
}

/* Core Web Vitals: reserve hero caption space + keep stable hero height after slick init */
body.home .slider,
body.home .slider.slick-initialized {
  height: max(250px, 28.645833333vw) !important;
  overflow: hidden !important;
}

body.home .slider .slide-content h2 {
  min-height: 2.8em;
}

body.home .slider .slide-content h3 {
  min-height: 1.5em;
}

body.home .slider .slide-content {
  min-height: 4.9em;
}

@media (max-width: 1000px) {
  body.home .slider,
  body.home .slider.slick-initialized {
    height: 250px !important;
  }

  body.home .slider .slide-content h2 {
    min-height: 3.8em;
  }

  body.home .slider .slide-content h3 {
    min-height: 1.5em;
  }

  body.home .slider .slide-content {
    min-height: 5.8em;
  }
}

/* Core Web Vitals: keep slick inner wrappers at fixed hero height to avoid CLS */
body.home .slider-container {
  min-height: max(250px, 28.645833333vw);
}

/* Pre-init hero fallback: show first slide before Slick finishes init */
body.home .slider:not(.slick-initialized) {
  position: relative;
  height: max(250px, 28.645833333vw) !important;
  overflow: hidden !important;
}

body.home .slider:not(.slick-initialized) .slide {
  display: none;
  height: 100%;
}

body.home .slider:not(.slick-initialized) .slide:first-child {
  display: block;
}

body.home .slider:not(.slick-initialized) .slide-bg,
body.home .slider:not(.slick-initialized) .slide-content-container {
  height: 100%;
}

body.home .slider .slick-list,
body.home .slider .slick-track,
body.home .slider .slick-slide,
body.home .slider .slide,
body.home .slider .slide-bg {
  height: 100% !important;
}

body.home .slider .slide-bg img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

@media (max-width: 1000px) {
  body.home .slider-container {
    min-height: 250px;
  }

  body.home .slider:not(.slick-initialized) {
    height: 250px !important;
  }
}

/* CWV: avoid loading FontAwesome webfont for common site icons (menu/contact/footer) */
.fa-bars,
.fa-map-marker,
.fa-phone,
.fa-envelope {
  font-family: inherit !important;
  font-style: normal !important;
  font-variant: normal !important;
  font-weight: inherit !important;
}

.fa-bars:before,
.fa-map-marker:before,
.fa-phone:before,
.fa-envelope:before {
  font-family: inherit !important;
  font-style: normal !important;
  font-variant: normal !important;
  text-transform: none !important;
  line-height: 1 !important;
}

.fa-bars:before {
  content: "\2630" !important; /* hamburger */
  font-weight: 700 !important;
}

.fa-phone:before {
  content: "\260E" !important; /* phone */
  font-weight: 400 !important;
}

.fa-envelope:before {
  content: "\2709" !important; /* email */
  font-weight: 400 !important;
}

.fa-map-marker:before {
  content: "\2316" !important; /* location */
  font-weight: 400 !important;
}
/* CLS fix: avoid anchoring full page content to viewport bottom during early render */
body {
  justify-content: flex-start !important;
}

/* Keep sticky footer behavior without shifting main content */
footer {
  margin-top: auto;
}

/* CLS stabilization: producer tiles reserve height before JS equalizer */
@media (min-width: 1001px) {
  .producent {
    aspect-ratio: 1 / 1;
  }
}
/* Preserve homepage visual H1 styling after semantic H1 moved earlier */
.home .container.page-container .home-main-seo-heading {
  font-size: clamp(20px, 1.6vw, 28px) !important;
  line-height: 1.2 !important;
  margin-bottom: 12px !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

@media (max-width: 1000px) {
  .home .container.page-container .home-main-seo-heading {
    font-size: clamp(20px, 5.2vw, 26px) !important;
    line-height: 1.22 !important;
    margin-bottom: 10px !important;
    text-transform: none !important;
  }
}

/* Producer logo grids (doors/floors): reduce visual clutter, prevent overlap, improve mobile layout */
.producers-grid .col.col_24 {
  position: relative;
}

.producers-grid .producent {
  overflow: hidden;
  border-radius: 12px;
  background: #fff;
  padding: 16px 18px;
  box-shadow: 0 1px 0 rgba(0,0,0,.03);
  will-change: transform;
}

.producers-grid .producent img {
  width: auto;
  max-width: 82%;
  max-height: 72px;
  object-fit: contain;
}

.producers-grid .producent:hover {
  transform: translateY(-4px) scale(1.015);
  box-shadow: 0 10px 24px rgba(0,0,0,.08);
}

@media (min-width: 1001px) {
  .producers-grid .producent {
    aspect-ratio: 16 / 9;
    min-height: 132px;
  }
}

@media (max-width: 1000px) {
  .producers-grid .col.col_24 {
    width: 50%;
  }

  .producers-grid .producent {
    aspect-ratio: 2 / 1;
    min-height: 110px;
    padding: 14px;
  }

  .producers-grid .producent img {
    max-width: 84%;
    max-height: 60px;
  }

  .producers-grid .producent:hover {
    transform: none;
    box-shadow: 0 1px 0 rgba(0,0,0,.03);
  }
}

@media (max-width: 520px) {
  .producers-grid .col.col_24 {
    width: 100%;
  }

  .producers-grid .producent {
    aspect-ratio: 2.4 / 1;
    min-height: 96px;
    padding: 12px;
  }

  .producers-grid .producent img {
    max-width: 80%;
    max-height: 52px;
  }
}

/* Producer logo grid v2: override legacy JS square equalizer for doors/floors logo sections */
.row.bigspace.centered.producers-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 14px;
  margin: 10px 0 0 !important;
  align-items: stretch;
}

.row.bigspace.centered.producers-grid > .col,
.row.bigspace.centered.producers-grid > .col.col_24 {
  width: auto !important;
  padding: 0 !important;
  min-width: 0;
}

.row.bigspace.centered.producers-grid .producent {
  height: 100%;
  min-height: 104px !important; /* overrides inline min-height from v22.js */
  aspect-ratio: auto !important;
  padding: 12px 16px;
  border-radius: 10px;
  overflow: hidden;
  transform: none;
}

.row.bigspace.centered.producers-grid .producent:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 18px rgba(0,0,0,.06);
}

.row.bigspace.centered.producers-grid .producent img {
  display: block;
  width: auto;
  max-width: min(88%, 240px);
  max-height: 54px;
  height: auto;
  object-fit: contain;
  margin-left: auto;
  margin-right: auto;
}

@media (max-width: 1200px) {
  .row.bigspace.centered.producers-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 1000px) {
  .row.bigspace.centered.producers-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
  }

  .row.bigspace.centered.producers-grid .producent {
    min-height: 92px !important;
    padding: 10px 12px;
  }

  .row.bigspace.centered.producers-grid .producent:hover {
    transform: none;
    box-shadow: 0 1px 0 rgba(0,0,0,.03);
  }

  .row.bigspace.centered.producers-grid .producent img {
    max-width: min(86%, 190px);
    max-height: 46px;
  }
}

@media (max-width: 700px) {
  .row.bigspace.centered.producers-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  .row.bigspace.centered.producers-grid .producent {
    min-height: 82px !important;
    padding: 8px 10px;
    border-radius: 8px;
  }

  .row.bigspace.centered.producers-grid .producent img {
    max-width: 84%;
    max-height: 40px;
  }
}

@media (max-width: 420px) {
  .row.bigspace.centered.producers-grid {
    grid-template-columns: 1fr;
  }

  .row.bigspace.centered.producers-grid .producent {
    min-height: 74px !important;
  }

  .row.bigspace.centered.producers-grid .producent img {
    max-height: 36px;
  }
}

