@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-Bold.woff2) format('woff2'),url(fonts/Montserrat-Bold.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-SemiBold.woff2) format('woff2'),url(fonts/Barlow-SemiBold.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}: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}.formularz,.form-fields,.form-field{position:relative}.form-fields{z-index:2}.form-fields.hidden{opacity:0;visibility:hidden}.form-error{background:var(--col1);color:#fff;font-size:14px;position:absolute;z-index:999;line-height:normal;padding:4px 8px;border-radius:5px;left:-10px;display:none}.form-error:not(.error-zgoda){bottom:-35px}.form-error:not(.error-zgoda):after{bottom:100%;left:50%;border:solid transparent;content:" ";height:0;width:0;position:absolute;pointer-events:none;border-color:rgba(146,63,45,0);border-bottom-color:var(--col1);border-width:5px;margin-left:-5px}.field-zgoda{text-align:justify}.field-zgoda a{color:var(--col1)}.error-zgoda{top:-30px}.error-zgoda:after{top:100%;left:16px;border:solid transparent;content:" ";height:0;width:0;position:absolute;pointer-events:none;border-color:rgba(146,63,45,0);border-top-color:var(--col1);border-width:5px;margin-left:-5px}.formularz .form-success{position:absolute;z-index:1;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;opacity:0;transition:all .5s ease;text-align:center;background:var(--darker)}.formularz .form-success.visible{opacity:1}.success-icon{width:50px;height:50px;border-radius:100%;color:#fff;background:var(--col1);margin-bottom:15px}.success-icon i{line-height:50px;font-size:25px;color:var(--dark)}.success-message{font-size:105%}@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) {
    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; }

  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: 8px 8px !important;
  }

  footer .footer-widgets .logo {
    display: none !important;
  }

  footer .footer-widgets h3 {
    margin-bottom: 6px !important;
    padding-bottom: 4px !important;
    font-size: 16px !important;
    line-height: 1.15 !important;
  }

  footer .footer-widgets p {
    margin: 0 0 8px !important;
    line-height: 1.34 !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: 1px 0 !important;
    font-size: 15px !important;
    line-height: 1.28 !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: 5px 8px !important;
  }

  footer .footer-widgets h3 {
    font-size: 14px !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-card {
  position: relative;
}

footer .footer-widgets .footer-map-link {
  display: block;
  overflow: hidden;
  border: 1px solid rgba(32, 30, 30, 0.1);
  border-radius: 9px;
  box-shadow: none;
  background: #f3f3f3;
  position: relative;
}

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.18 / 1;
  object-fit: cover;
  transition: none;
}

footer .footer-widgets .footer-map-link:hover img {
  transform: none;
}

footer .footer-widgets .footer-map-link::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(32, 30, 30, 0) 55%, rgba(32, 30, 30, 0.14) 100%);
  pointer-events: none;
}

footer .footer-widgets .footer-map-actions {
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 12px;
  width: auto;
  margin-top: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  transform: none;
  z-index: 2;
}

footer .footer-widgets .footer-map-actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-width: 0;
  min-height: 32px;
  padding: 6px 8px;
  border: 1px solid rgba(32, 30, 30, 0.88);
  border-radius: 999px;
  background: rgba(32, 30, 30, 0.9);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
  color: #fff;
  font-size: 12px;
  line-height: 1.2;
  white-space: nowrap;
}

footer .footer-widgets .footer-map-actions a:hover,
footer .footer-widgets .footer-map-actions a:focus-visible {
  border-color: var(--col1);
  background: var(--col1);
  color: #fff;
}

footer .footer-widgets .logo {
  display: block;
  height: auto;
  margin-bottom: 15px;
  padding-top: 2px;
  padding-bottom: 7px;
  border-bottom-width: 1px !important;
  border-bottom-color: rgba(225, 17, 20, 0.9) !important;
}

footer .footer-widgets .logo img {
  height: 37px;
  width: auto;
}

footer .footer-widgets p i {
  width: 24px;
  margin-right: 10px;
  position: relative;
  top: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  line-height: 1;
  color: var(--col1);
}

footer .footer-widgets .fa-map-marker,
footer .footer-widgets .fa-phone,
footer .footer-widgets .fa-envelope {
  font-family: 'FontAwesome' !important;
  font-style: normal !important;
  font-variant: normal !important;
  font-weight: 400 !important;
}

footer .footer-widgets .fa-map-marker:before,
footer .footer-widgets .fa-phone:before,
footer .footer-widgets .fa-envelope:before {
  font-family: 'FontAwesome' !important;
  font-style: normal !important;
  font-variant: normal !important;
  font-weight: 400 !important;
  text-transform: none !important;
  line-height: 1 !important;
}

footer .footer-widgets .fa-map-marker:before {
  content: "\f041" !important;
}

footer .footer-widgets .fa-phone:before {
  content: "\f095" !important;
}

footer .footer-widgets .fa-envelope:before {
  content: "\f0e0" !important;
}

footer .footer-widgets h3 {
  display: block;
  margin-bottom: 15px;
  padding-top: 20px;
  padding-bottom: 7px;
  font-size: 17px;
  line-height: 1.1;
  font-weight: 400;
  text-transform: none !important;
  border-bottom-width: 1px !important;
  border-bottom-color: rgba(225, 17, 20, 0.9) !important;
}

footer .footer-widgets p,
footer .footer-menu a {
  font-size: 16px;
  line-height: 1.36;
}

footer .footer-menu a {
  padding: 2px 0;
}

footer .footer-links-stack {
  display: flex;
  flex-direction: column;
}

footer .footer-links-stack > .footer-menu--nav-wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-content: flex-start;
  gap: 8px 16px;
  max-width: 350px;
}

footer .footer-links-stack > .footer-menu--nav-wrap a {
  display: inline-flex;
  align-items: center;
  padding: 0;
  line-height: 1.28;
}

footer .footer-seo-heading {
  display: block;
  margin-top: 0 !important;
  margin-bottom: 15px;
  padding-top: 22px;
  padding-bottom: 7px;
  font-size: 14px;
  line-height: 1.18;
  font-weight: 400;
  text-transform: none !important;
  opacity: 0.64;
}

footer .footer-menu--seo-muted {
  margin-top: 2px;
  columns: 2 110px;
  column-gap: 20px;
}

footer .footer-menu--seo-muted a {
  font-size: clamp(12px, 0.8vw, 12px);
  line-height: 1.22;
  color: rgba(32, 30, 30, 0.54);
}

footer .footer-widgets .col:first-child p {
  margin: 0 0 14px;
  line-height: 1.36;
}

footer .footer-widgets .col:first-child p:last-child {
  margin-bottom: 0;
}

footer .footer-contact-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

footer .footer-contact-line {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 0;
}

footer .footer-contact-line i {
  flex: 0 0 24px;
  width: 24px;
  margin-right: 0;
}

footer .footer-contact-line a {
  padding: 0 !important;
}

footer .footer-contact-line--address .footer-contact-text {
  display: block;
}

footer .footer-contact-line--address .footer-contact-street,
footer .footer-contact-line--address .footer-contact-city {
  display: block;
}

@media (max-width: 1000px) {
  footer .footer-widgets .footer-map-actions a {
    min-height: 32px;
    padding: 6px 8px;
  }

  footer .footer-widgets p i {
    width: 22px;
    margin-right: 8px;
    font-size: 16px;
  }

  footer .footer-links-stack > .footer-menu--nav-wrap {
    gap: 8px 14px;
    max-width: none;
  }
}

@media (max-width: 760px) {
  footer .footer-widgets .col:nth-child(3),
  footer .footer-widgets .col:nth-child(4) {
    width: 100% !important;
  }

  footer .footer-widgets .col:first-child {
    padding-top: 10px !important;
    padding-bottom: 2px !important;
  }

  footer .footer-widgets .col:nth-child(2) {
    padding-top: 0 !important;
  }

  footer .footer-contact-card {
    margin-top: 4px;
    padding: 12px 14px 10px;
    border: 1px solid rgba(32, 30, 30, 0.06);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.38);
    gap: 10px;
  }

  footer .footer-contact-line {
    gap: 8px;
  }

  footer .footer-contact-line,
  footer .footer-contact-line a {
    font-size: 14px !important;
    line-height: 1.26 !important;
  }

  footer .footer-contact-line i {
    flex-basis: 18px;
    width: 18px;
    font-size: 15px !important;
    margin-top: 2px;
  }

  footer .footer-contact-line--address .footer-contact-text {
    display: flex;
    flex-wrap: wrap;
    gap: 0 4px;
  }

  footer .footer-contact-line--address .footer-contact-street,
  footer .footer-contact-line--address .footer-contact-city {
    display: inline;
  }

  footer .footer-contact-line--address .footer-contact-city {
    white-space: nowrap;
  }

  footer .footer-contact-line--address .footer-contact-city::before {
    content: ", ";
  }

  footer .footer-widgets h3,
  footer .footer-seo-heading {
    margin-bottom: 10px !important;
    padding-bottom: 5px !important;
    font-size: 14px !important;
    line-height: 1.14 !important;
  }

  footer .footer-widgets h3 {
    border-bottom-color: rgba(225, 17, 20, 0.82) !important;
  }

  footer .footer-seo-heading {
    margin-top: 2px !important;
    opacity: 0.62;
  }

  footer .footer-widgets .footer-map-link img {
    aspect-ratio: 2 / 1;
  }

  footer .footer-widgets .footer-map-actions {
    bottom: 8px;
    left: 8px;
    right: 8px;
    width: auto;
    gap: 6px;
  }

  footer .footer-widgets .footer-map-actions a {
    min-height: 28px;
    padding: 5px 7px;
    font-size: 11px;
    border-color: rgba(32, 30, 30, 0.8);
    background: rgba(32, 30, 30, 0.88);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
  }

  footer .footer-menu--seo-muted {
    columns: 2 120px !important;
    column-gap: 14px !important;
    margin-top: 0 !important;
  }

  footer .footer-menu--seo-muted a {
    display: block;
    break-inside: avoid-column;
    padding: 0 0 2px !important;
    font-size: 11px !important;
    line-height: 1.14 !important;
    color: rgba(32, 30, 30, 0.5) !important;
  }

  footer .footer-links-stack > .footer-menu--nav-wrap {
    gap: 5px 10px !important;
  }

  footer .footer-links-stack > .footer-menu--nav-wrap a {
    font-size: 14px !important;
    line-height: 1.22 !important;
    white-space: nowrap;
  }

  footer .footer-links-stack > .footer-menu--nav-wrap a:not(:last-child)::after {
    content: "\2022";
    margin-left: 8px;
    color: rgba(32, 30, 30, 0.34);
    font-size: 0.82em;
    line-height: 1;
  }
}

/* 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: normal;
    word-wrap: normal;
    word-break: normal;
    -webkit-hyphens: none;
    -ms-hyphens: none;
    hyphens: none;
    max-width: 100%;
  }

  .container p,
  .container li,
  .intro,
  .field-zgoda {
    text-align: left;
  }
}

/* Final heading scale normalization (desktop + mobile)
   Keeps homepage slider hero untouched. */
body:not(.home) .page-title h1 {
  font-size: clamp(20px, 1.35vw, 25px) !important;
  line-height: 1.18 !important;
  letter-spacing: 0.005em !important;
  max-width: 36ch !important;
  text-transform: none !important;
  text-wrap: pretty;
}

body:not(.home) .page-container h1,
body:not(.home) .container.extra-margin-top h1,
body:not(.home) .container.bigspace.left h1,
body:not(.home) .container .row > .col > h1,
body:not(.home) .container .row > h1 {
  font-size: clamp(24px, 1.85vw, 32px) !important;
  line-height: 1.18 !important;
  margin-bottom: 14px !important;
  text-transform: none !important;
}

body:not(.home) .page-container h2,
body:not(.home) .container.extra-margin-top h2,
body:not(.home) .container.bigspace.left h2,
body:not(.home) .container .row > .col > h2,
body:not(.home) .container .row > h2 {
  font-size: clamp(20px, 1.45vw, 27px) !important;
  line-height: 1.22 !important;
  margin-bottom: 12px !important;
  text-transform: none !important;
}

body:not(.home) .page-container h3,
body:not(.home) .container.extra-margin-top h3,
body:not(.home) .container.bigspace.left h3,
body:not(.home) .container .row > .col > h3,
body:not(.home) .container .row > h3 {
  font-size: clamp(18px, 1.15vw, 22px) !important;
  line-height: 1.24 !important;
  margin-bottom: 10px !important;
  text-transform: none !important;
}

body:not(.home) .page-container h4,
body:not(.home) .container.extra-margin-top h4,
body:not(.home) .container.bigspace.left h4,
body:not(.home) .container .row > .col > h4,
body:not(.home) .container .row > h4 {
  font-size: clamp(16px, 0.95vw, 19px) !important;
  line-height: 1.28 !important;
  text-transform: none !important;
}

/* Homepage content typography (not slider hero) */
  font-size: clamp(17px, 1.2vw, 20px) !important;
}

@media (max-width: 1000px) {
  body:not(.home) .page-title h1 {
    font-size: clamp(20px, 5.2vw, 25px) !important;
    line-height: 1.2 !important;
  }

  body:not(.home) .page-container h1,
  body:not(.home) .container.extra-margin-top h1,
  body:not(.home) .container.bigspace.left h1,
  body:not(.home) .container .row > .col > h1,
  body:not(.home) .container .row > h1 {
    font-size: clamp(21px, 5.8vw, 27px) !important;
    line-height: 1.2 !important;
  }

  body:not(.home) .page-container h2,
  body:not(.home) .container.extra-margin-top h2,
  body:not(.home) .container.bigspace.left h2,
  body:not(.home) .container .row > .col > h2,
  body:not(.home) .container .row > h2 {
    font-size: clamp(19px, 5vw, 23px) !important;
    line-height: 1.24 !important;
  }

  body:not(.home) .page-container h3,
  body:not(.home) .container.extra-margin-top h3,
  body:not(.home) .container.bigspace.left h3,
  body:not(.home) .container .row > .col > h3,
  body:not(.home) .container .row > h3 {
    font-size: clamp(17px, 4.4vw, 20px) !important;
    line-height: 1.26 !important;
  }

  body:not(.home) .page-container h4,
  body:not(.home) .container.extra-margin-top h4,
  body:not(.home) .container.bigspace.left h4,
  body:not(.home) .container .row > .col > h4,
  body:not(.home) .container .row > h4 {
    font-size: clamp(15px, 3.8vw, 18px) !important;
  }

  .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 */
body:not(.home) .page-title {
  min-height: clamp(165px, 10.5vw, 210px);
  padding: clamp(10px, 1vw, 16px) 0 !important;
  display: flex;
  align-items: center;
  background-size: cover;
  background-position: center center;
}

body:not(.home) .page-title[data-src*="header_drzwi"] {
  background-position: center 35%;
}

body:not(.home) .page-title[data-src*="header_podlogi"] {
  background-position: center 38%;
}

body:not(.home) .page-title[data-src*="header_tarasy"] {
  background-position: center 42%;
}

body:not(.home) .page-title .container {
  position: relative;
  z-index: 2;
}

body:not(.home) .page-title-subtitle {
  margin-top: 6px;
  font-size: clamp(13px, 0.82vw, 16px);
  line-height: 1.4;
  max-width: 56ch;
}

body:not(.home) .breadcrumbs {
  margin-top: 8px;
  font-size: clamp(12px, 0.72vw, 14px);
  line-height: 1.35;
  color: rgba(255, 255, 255, 0.88);
}

body:not(.home) .container.extra-margin-top {
  margin-top: 30px !important;
}

@media (min-width: 1001px) {
.contact-page .contact-text p,
.contact-page .contact-map-summary span,
.contact-form-section .field-zgoda,
.contact-form-server-error {
    text-align: left;
    text-wrap: pretty;
    overflow-wrap: normal;
    word-wrap: normal;
    word-break: normal;
    -webkit-hyphens: none;
    -ms-hyphens: none;
    hyphens: none;
  }
}

@media (max-width: 1000px) {
  body:not(.home) .page-title {
    min-height: clamp(120px, 28vw, 160px);
    padding: clamp(8px, 2vw, 12px) 0 !important;
  }

  body:not(.home) .page-title h1 {
    font-size: clamp(17px, 3.8vw, 22px) !important;
    line-height: 1.2 !important;
    max-width: 28ch !important;
  }

  body:not(.home) .page-title-subtitle {
    margin-top: 4px;
    font-size: clamp(11px, 1.8vw, 13px);
  }

  body:not(.home) .breadcrumbs {
    display: none;
  }

  body:not(.home) .container.extra-margin-top {
    margin-top: 22px !important;
  }

  body:not(.home) .page-title[data-src*="header_drzwi"] {
    background-position: center 32%;
  }

  body:not(.home) .page-title[data-src*="header_podlogi"] {
    background-position: center 35%;
  }

  body:not(.home) .page-title[data-src*="header_tarasy"] {
    background-position: center 38%;
  }
}

/* Contact page: layout/alignment polish */
.contact-page .row.middle {
  align-items: flex-start;
}

@media (min-width: 1001px) {
  .contact-page .row.middle {
    align-items: center;
  }
}

.contact-page .contact-details .large_bottom_space {
  margin-bottom: 22px !important;
}

.contact-page .contact-iconbox {
  margin: 0 0 20px;
  align-items: flex-start;
}

.contact-page .contact-iconbox:last-child {
  margin-bottom: 0;
}

.contact-page .contact-iconbox .contact-icon {
  flex: 0 0 48px;
  width: 48px;
  max-width: 48px;
  padding: 0 10px 0 0;
  display: flex;
  justify-content: flex-start;
}

.contact-page .contact-iconbox .contact-text {
  flex: 1 1 auto;
  min-width: 0;
  padding: 0;
}

.contact-page .contact-icon i {
  font-size: 36px;
  line-height: 1;
  margin-top: 2px;
}

.contact-page .contact-icon .fa-map-marker,
.contact-page .contact-icon .fa-phone,
.contact-page .contact-icon .fa-envelope {
  font-family: "FontAwesome" !important;
  font-style: normal !important;
  font-variant: normal !important;
  font-weight: 400 !important;
}

.contact-page .contact-icon .fa-map-marker::before,
.contact-page .contact-icon .fa-phone::before,
.contact-page .contact-icon .fa-envelope::before {
  font-family: "FontAwesome" !important;
  font-style: normal !important;
  font-variant: normal !important;
  font-weight: 400 !important;
  line-height: 1 !important;
}

.contact-page .contact-icon .fa-map-marker::before {
  content: "\f041" !important;
}

.contact-page .contact-icon .fa-phone::before {
  content: "\f095" !important;
}

.contact-page .contact-icon .fa-envelope::before {
  content: "\f0e0" !important;
}

.contact-page .contact-text h4,
.contact-page .contact-text .contact-label {
  margin: 0 0 6px;
  line-height: 1.2;
  text-transform: none;
}

.contact-page .contact-text p {
  margin: 0;
  line-height: 1.45;
  text-align: left;
}

.contact-page .contact-map a,
.contact-page .contact-map img {
  display: block;
  width: 100%;
  height: auto;
}

.contact-form-section #contact-form {
  max-width: 980px;
  margin: 0 auto 30px;
  padding: clamp(18px, 2.3vw, 28px);
  border: 1px solid #e4e5e8;
  border-radius: 14px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfbfc 100%);
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.08);
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.contact-form-section #contact-form .form-field {
  margin: 0;
}

.contact-form-section #contact-form .field-imie,
.contact-form-section #contact-form .field-email,
.contact-form-section #contact-form .field-tel {
  grid-column: span 1;
}

.contact-form-section #contact-form .field-message,
.contact-form-section #contact-form .h-captcha,
.contact-form-section #contact-form .field-zgoda,
.contact-form-section #contact-form .contact-submit {
  grid-column: 1 / -1;
}

.contact-form-section #contact-form input[type="text"],
.contact-form-section #contact-form input[type="email"],
.contact-form-section #contact-form input[type="tel"],
.contact-form-section #contact-form textarea {
  border: 1px solid #d7d9df;
  border-radius: 10px;
  padding: 13px 14px;
  background: #fff;
  line-height: 1.45;
}

.contact-form-section #contact-form input[type="text"]::placeholder,
.contact-form-section #contact-form input[type="email"]::placeholder,
.contact-form-section #contact-form input[type="tel"]::placeholder,
.contact-form-section #contact-form textarea::placeholder {
  color: #777d86;
}

.contact-form-section #contact-form input[type="text"]:focus,
.contact-form-section #contact-form input[type="email"]:focus,
.contact-form-section #contact-form input[type="tel"]:focus,
.contact-form-section #contact-form textarea:focus {
  border-color: var(--col1);
  box-shadow: 0 0 0 4px rgba(225, 17, 20, 0.14);
}

.contact-form-section #contact-form .field-message textarea {
  min-height: 180px;
  resize: vertical;
}

.contact-form-section #contact-form .h-captcha {
  margin: 2px 0 0;
  min-height: 86px;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  overflow: visible;
  position: relative;
  z-index: 2;
  opacity: 1;
  visibility: visible;
}

.contact-form-section #contact-form .h-captcha > div,
.contact-form-section #contact-form .h-captcha iframe {
  max-width: 100%;
}

.contact-form-section #contact-form .h-captcha > div {
  min-width: 303px;
  min-height: 78px;
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
}

.contact-form-section #contact-form .h-captcha iframe {
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
}

.contact-form-section #contact-form .h-captcha * {
  opacity: 1 !important;
  visibility: visible !important;
}

.contact-form-section #contact-form .h-captcha > div,
.contact-form-section #contact-form .h-captcha > div > div {
  display: block !important;
  overflow: visible !important;
  min-height: 78px;
}

.contact-form-section #contact-form .h-captcha iframe[src*="hcaptcha"] {
  min-height: 78px !important;
  background: #fff !important;
}

.contact-form-section #contact-form .field-zgoda {
  padding: 12px 14px;
  border: 1px solid #ebebee;
  border-radius: 10px;
  background: #f8f8fa;
  text-align: left;
}

.contact-form-section #contact-form .field-zgoda label {
  display: block;
  line-height: 1.45;
}

.contact-form-section #contact-form .field-zgoda input[type="checkbox"] {
  display: inline-block;
  vertical-align: text-top;
  margin: 2px 8px 0 0;
  width: 18px;
  height: 18px;
  accent-color: var(--col1);
}

.contact-form-section #contact-form .contact-submit {
  margin-top: 2px;
  margin-bottom: 0;
}

.contact-form-section #contact-form .contact-submit input[type=submit] {
  min-width: 220px;
  border-radius: 999px;
  padding: 13px 28px;
  letter-spacing: 0.02em;
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.16);
}

/* On contact page this global section separator is visually redundant. */
.contact-form-section {
  border-top: 0 !important;
}

.contact-page + .contact-form-section {
  padding-top: 34px;
}

.contact-form-section h2.large_bottom_space {
  margin-bottom: 22px !important;
}

@media (min-width: 1001px) {
  .contact-page .row.middle {
    align-items: stretch;
  }

  .contact-page .contact-details,
  .contact-page .contact-map {
    display: flex;
  }

  .contact-page .contact-details {
    flex-direction: column;
    justify-content: center;
    min-height: 100%;
    padding: 20px 22px;
    border: 1px solid #ececef;
    border-radius: 14px;
    background: linear-gradient(180deg, #ffffff 0%, #fbfbfc 100%);
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.04);
  }

  .contact-page .contact-map {
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
    overflow: hidden;
    border-radius: 14px;
  }

  .contact-page .contact-details .large_bottom_space {
    margin-bottom: 18px !important;
  }

  .contact-page .contact-iconbox {
    margin-bottom: 18px;
  }

  .contact-page .contact-iconbox .contact-icon {
    flex-basis: 42px;
    width: 42px;
    max-width: 42px;
    padding-right: 8px;
  }

  .contact-page .contact-icon i {
    font-size: 32px;
  }

  .contact-page .contact-text .contact-label {
    margin-bottom: 4px;
    font-size: 14px;
    color: #6b7178;
  }

  .contact-page .contact-text p {
    line-height: 1.38;
  }

  .contact-page + .contact-form-section {
    padding-top: 28px;
  }

  .contact-form-section h2.large_bottom_space {
    margin-bottom: 18px !important;
  }

  .contact-form-section #contact-form {
    max-width: 940px;
    margin-bottom: 26px;
    padding: 20px 22px;
    gap: 12px;
    border-radius: 12px;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.06);
  }

  .contact-form-section #contact-form .field-message textarea {
    min-height: 158px;
  }

  .contact-form-section #contact-form .field-zgoda {
    padding: 10px 12px;
  }

  .contact-form-section #contact-form .contact-submit input[type=submit] {
    min-width: 208px;
    padding: 12px 24px;
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.14);
  }

  .contact-page .contact-map .contact-map-facade {
    width: 100%;
    height: 100%;
    border-radius: 14px;
  }
}

/* /kontakt: use one already-needed family in the first viewport to trim font surface. */
body.contact-page-view header nav ul li a,
body.contact-page-view h1,
body.contact-page-view h2,
body.contact-page-view h3,
body.contact-page-view h4,
body.contact-page-view h5,
body.contact-page-view h6,
body.contact-page-view .contact-page .contact-map .contact-map-trigger,
body.contact-page-view .contact-page .contact-map .contact-map-summary,
body.contact-page-view .contact-page .contact-map .contact-map-summary span,
body.contact-page-view .contact-page .contact-map .contact-map-chip,
body.contact-page-view .contact-page .contact-map .contact-map-summary strong,
body.contact-page-view .contact-form-section #contact-form .contact-submit input[type=submit],
body.contact-page-view .contact-form-section .cta .button {
  font-family: Barlow, sans-serif;
}

.contact-form-section .cta {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-top: 24px;
  padding: 38px 0;
  border-radius: 0;
  content-visibility: auto;
  contain-intrinsic-size: 340px;
}

.contact-form-section .cta .container {
  width: min(90%, 1240px);
}

.contact-form-section .cta .spread-row {
  gap: 18px;
}

.contact-form-section .cta h4,
.contact-form-section .cta .cta-heading {
  margin: 0;
  line-height: 1.25;
}

@media (max-width: 1000px) {
  .contact-page .contact-map {
    margin-top: 10px;
  }

  .contact-page .contact-iconbox .contact-icon {
    flex-basis: 44px;
    width: 44px;
    max-width: 44px;
  }

  .contact-page .contact-icon i {
    font-size: 32px;
  }

  .contact-form-section #contact-form {
    margin-bottom: 24px;
    padding: 16px;
    border-radius: 12px;
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .contact-page + .contact-form-section {
    padding-top: 20px;
  }

  .contact-form-section #contact-form .field-imie,
  .contact-form-section #contact-form .field-email,
  .contact-form-section #contact-form .field-tel {
    grid-column: 1 / -1;
  }

  .contact-form-section #contact-form .contact-submit input[type=submit] {
    width: 100%;
    min-width: 0;
  }

  .contact-form-section .cta {
    margin-top: 18px;
    padding: 28px 0;
  }

  .contact-form-section .cta .spread-row {
    gap: 12px;
  }
}

/* Subpage hero final balancing:
   - desktop: wider, less wrapped headline and stable proportions
   - mobile: keep compact layout
   (homepage slider H1 remains untouched) */
body:not(.home) .page-title {
  background-size: cover;
  background-repeat: no-repeat;
}

@media (min-width: 1001px) {
  body:not(.home) .page-title {
    height: clamp(260px, 21vw, 420px);
    min-height: 0;
    padding: clamp(16px, 1.3vw, 26px) 0 !important;
  }

  body:not(.home) .page-title h1 {
    max-width: min(40ch, 72%);
    font-size: clamp(30px, 2.2vw, 44px) !important;
    line-height: 1.08 !important;
    text-wrap: pretty;
  }

  body:not(.home) .page-title-subtitle {
    max-width: min(78ch, 78%);
    font-size: clamp(15px, 1vw, 20px);
  }

  body:not(.home) .breadcrumbs {
    font-size: clamp(13px, 0.78vw, 15px);
  }
}

/* Contact map: performant facade + click-to-load interactive map */
.contact-page .contact-map .contact-map-facade {
  position: relative;
  border: 1px solid rgba(32, 30, 30, 0.1);
  border-radius: 10px;
  overflow: hidden;
  box-shadow: none;
  background: #f3f3f3;
}

.contact-page .contact-map .contact-map-trigger {
  display: block;
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  position: relative;
  cursor: pointer;
  text-align: left;
  line-height: 0;
}

.contact-page .contact-map .contact-map-trigger:focus-visible {
  outline: 3px solid var(--col1);
  outline-offset: 2px;
}

.contact-page .contact-map .contact-map-trigger::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(32, 30, 30, 0.08) 0%, rgba(32, 30, 30, 0) 44%, rgba(32, 30, 30, 0.18) 100%);
  pointer-events: none;
}

.contact-page .contact-map .contact-map-trigger img {
  display: block;
  width: 100%;
  height: clamp(220px, 29vw, 400px);
  object-fit: cover;
  object-position: center;
}

@media (min-width: 1001px) {
  .contact-page .contact-map .contact-map-facade {
    aspect-ratio: 16 / 9;
  }

  .contact-page .contact-map .contact-map-trigger img {
    height: 100%;
  }

  .contact-page .contact-map .contact-map-facade iframe {
    height: 100%;
  }
}

@media (min-width: 1400px) {
  .contact-page {
    max-width: 1320px;
  }

  .contact-page .row.middle {
    align-items: stretch;
  }

  .contact-page .contact-details.col_3 {
    width: 30%;
  }

  .contact-page .contact-map.col_9 {
    width: 70%;
  }

  .contact-page .contact-map .contact-map-facade {
    aspect-ratio: auto;
  }

  .contact-page .contact-map .contact-map-trigger img,
  .contact-page .contact-map .contact-map-facade iframe {
    height: clamp(300px, 20vw, 360px);
  }
}

.contact-page .contact-map .contact-map-trigger picture {
  display: block;
}

.contact-page .contact-map .contact-map-summary {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 2;
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
  max-width: min(430px, calc(100% - 116px));
  padding: 10px 12px;
  border: 1px solid rgba(255, 255, 255, 0.55);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.08);
  line-height: 1.25;
}

.contact-page .contact-map .contact-map-summary strong {
  display: block;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.03em;
  color: var(--text);
}

.contact-page .contact-map .contact-map-summary span {
  display: block;
  font-size: 12px;
  color: rgba(32, 30, 30, 0.78);
}

.contact-page .contact-map .contact-map-chip {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 2;
  background: rgba(32, 30, 30, 0.9);
  color: #fff;
  padding: 7px 11px;
  border-radius: 999px;
  border: 1px solid rgba(32, 30, 30, 0.88);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
  font-size: 12px;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: 0.01em;
}

.contact-page .contact-map .contact-map-facade iframe {
  display: block;
  width: 100%;
  height: clamp(220px, 29vw, 400px);
}

.contact-page .contact-map .contact-map-actions {
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 14px;
  z-index: 3;
  width: auto;
  margin-top: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.contact-page .contact-map .contact-map-actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-width: 0;
  min-height: 34px;
  padding: 6px 8px;
  border: 1px solid rgba(32, 30, 30, 0.88);
  border-radius: 999px;
  background: rgba(32, 30, 30, 0.9);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;
}

.contact-page .contact-map .contact-map-actions a:hover,
.contact-page .contact-map .contact-map-actions a:focus-visible {
  border-color: var(--col1);
  background: var(--col1);
  color: #fff;
}

@media (max-width: 1000px) {
  .contact-page .contact-map .contact-map-trigger img {
    height: clamp(220px, 56vw, 290px);
  }

  .contact-page .contact-map .contact-map-facade iframe {
    height: clamp(220px, 56vw, 290px);
  }

  .contact-page .contact-map .contact-map-summary {
    top: 10px;
    left: 10px;
    max-width: calc(100% - 20px);
    padding: 9px 10px;
  }

  .contact-page .contact-map .contact-map-summary strong {
    font-size: 12px;
  }

  .contact-page .contact-map .contact-map-summary span {
    font-size: 11px;
  }

  .contact-page .contact-map .contact-map-chip {
    top: auto;
    right: auto;
    left: 10px;
    bottom: 54px;
    font-size: 11px;
    padding: 6px 9px;
  }

  .contact-page .contact-map .contact-map-actions {
    left: 10px;
    right: 10px;
    bottom: 10px;
    gap: 8px;
  }

  .contact-page .contact-map .contact-map-actions a {
    min-height: 32px;
    font-size: 11px;
    padding: 6px 7px;
  }
}


/* 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;
}

footer .footer-widgets {
  content-visibility: auto;
  contain-intrinsic-size: 980px;
}

footer .footer-copyright {
  content-visibility: auto;
  contain-intrinsic-size: 52px;
}

/* Runtime stability overrides: avoid broad transitions on first paint */
a {
  transition: color 0.3s ease;
}

input[type=text],
input[type=email],
input[type=password],
input[type=tel],
input[type=url],
input[type=search],
input[type=date],
textarea,
select {
  transition: border-color 0.3s ease, box-shadow 0.3s ease, color 0.3s ease, background-color 0.3s ease;
}

.button,
input[type=submit],
button {
  transition: background-color 0.4s ease, color 0.4s ease, opacity 0.4s ease, transform 0.4s ease;
}

header {
  transition: background-color 0.3s ease, box-shadow 0.3s ease, opacity 0.3s ease, transform 0.3s ease;
}

nav li .submenu a:after {
  transition: transform 0.3s ease;
}

nav li .submenu a span {
  transition: color 0.3s ease;
}

.slick-arrow {
  transition: opacity 0.3s ease;
}

.fancybox-bg {
  transition: transform 0.4s ease;
}

.fancybox-overlay {
  transition: opacity 0.4s ease, transform 0.4s ease;
}

.fancybox .button {
  transition: background-color 0.4s ease, color 0.4s ease, opacity 0.4s ease, transform 0.4s ease;
}

.mapa img {
  transition: transform 0.4s ease;
}

/* Keep whole words together across contact-page content instead of auto-hyphenating. */
body:not(.home) .page-title h1,
body:not(.home) .page-title-subtitle,
body:not(.home) .container h1,
body:not(.home) .container h2,
body:not(.home) .container h3,
body:not(.home) .container p,
body:not(.home) .container li,
body:not(.home) .container a,
body:not(.home) .breadcrumbs {
  overflow-wrap: normal !important;
  word-wrap: normal !important;
  word-break: normal !important;
  -webkit-hyphens: none !important;
  -ms-hyphens: none !important;
  hyphens: none !important;
}

.katalogi a img {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.formularz .form-success {
  transition: opacity 0.5s ease;
}

