/*
Theme Name: Termomodernizacja Toruń
Theme URI: https://termomodernizacja-torun.pl/
Author: ChatGPT
Description: Lekki motyw firmowy dla strony termomodernizacja-torun.pl z podstronami: Strona główna, O nas, Usługi, Kontakt.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
Text Domain: termomodernizacja-torun
*/

:root{--green:#28713d;--dark:#22252a;--muted:#606873;--footer:#565a60;--bg:#f3faf5;--line:#dbe7de}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,Arial,Helvetica,sans-serif;color:var(--dark);background:#fff;line-height:1.55}a{color:inherit}.container{width:min(1120px,calc(100% - 40px));margin-inline:auto}.site-header{height:88px;background:#fff;display:flex;align-items:center;border-bottom:1px solid #e7ece8;position:sticky;top:0;z-index:50}.header-inner{display:flex;align-items:center;justify-content:space-between}.logo{font-size:22px;font-weight:800;color:var(--green);text-decoration:none;letter-spacing:-.02em}.main-nav{display:flex;gap:46px;align-items:center}.main-nav a{text-decoration:none;font-size:15px;color:#17191d;padding:8px 0;border-bottom:2px solid transparent}.main-nav a:hover,.main-nav a[aria-current="page"],body.home .main-nav a[href$="/"]{border-bottom-color:#17191d}.nav-toggle{display:none;border:0;background:transparent;font-size:28px}.section{padding:90px 0}.section-soft{background:#ffffff}.hero{min-height:690px;background:linear-gradient(rgba(20,31,43,.62),rgba(20,31,43,.62)),url('assets/images/dom_tlo.JPG') center/cover no-repeat;display:flex;align-items:center;text-align:center;color:#fff;padding:70px 0 0}.hero .container{display:flex;flex-direction:column;align-items:center}.hero h1{font-size:clamp(44px,5.4vw,72px);line-height:1.17;margin:0 0 20px;font-weight:800;max-width:760px}.hero p{font-size:15px;font-weight:700;margin:0 0 50px}.btn{display:inline-flex;align-items:center;justify-content:center;border:1px solid currentColor;border-radius:999px;padding:16px 42px;text-decoration:none;font-weight:700;min-width:170px}.btn-green{background:var(--green);color:#fff;border-color:var(--green)}.hero-cards{width:min(1040px,100%);display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:70px}.hero-card{background:rgba(255,255,255,.22);padding:34px 20px;min-height:130px}.hero-card h3{margin:0 0 10px;font-size:20px}.hero-card p{margin:0;font-size:15px}.intro h2,.page-title{font-size:48px;line-height:1.1;margin:0 0 50px;letter-spacing:-.03em}.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px}.intro-grid h3{margin:0 0 16px;font-size:17px}.intro-grid p,.text-block p{color:var(--muted);font-size:15px;text-align:justify}.wide-image{margin-top:70px;border-radius:16px;overflow:hidden}.wide-image img{width:100%;height:360px;object-fit:cover;display:block}.services-dark{background:#565a60;color:#fff;text-align:center;padding:80px 0 100px}.services-dark h2{font-size:44px;margin:0 0 10px}.services-dark>p{font-weight:700;margin-bottom:85px}.service-home-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;text-align:left}.service-home-card{background:#fff;color:var(--dark)}.service-home-card img{width:100%;height:230px;object-fit:cover;display:block}.service-home-card div{padding:36px 42px}.service-home-card h3{margin:0 0 16px;font-size:19px}.service-home-card p{color:#626972;margin:0}.split{display:grid;grid-template-columns:1fr 1.15fr;gap:90px;align-items:center}.split img{width:100%;border-radius:16px;display:block}.about-hero{padding:110px 0 70px}.about-hero .text-block{max-width:420px}.about-hero h1{font-size:44px;margin:0 0 36px}.mission{padding:70px 0 100px}.mission .split{grid-template-columns:1.1fr 1fr}.image-stack{position:relative;min-height:410px}.image-stack .main-img{width:78%;height:410px;object-fit:cover;border-radius:16px}.image-stack .over-img{position:absolute;right:0;bottom:38px;width:52%;height:260px;object-fit:cover;border-radius:14px;box-shadow:0 10px 30px rgba(0,0,0,.18)}.mission h2{font-size:42px;margin:0 0 55px}.gallery h2{text-align:center;font-size:42px;margin:0 0 80px}.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.gallery-grid img{width:100%;height:260px;object-fit:cover;border-radius:14px;display:block}.services-page{background:#ffffff;padding:95px 0 120px}.services-page .page-title{text-align:center;margin-bottom:16px}.subtitle{text-align:center;color:var(--muted);margin:0 0 70px}.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:85px 22px}.service-item img{width:100%;height:230px;object-fit:cover;border-radius:14px;display:block;margin-bottom:22px}.service-item h3{font-size:19px;margin:0 0 12px}.service-item p{font-size:16px;color:#59616b;margin:0}.contact-page{padding:80px 0 60px}.contact-page .page-title{text-align:center;margin-bottom:16px}.contact-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:90px;margin-top:80px;align-items:start}.contact-details{display:grid;grid-template-columns:1fr 1fr;gap:42px 60px}.contact-details h3{font-size:17px;margin:0 0 18px}.contact-details p{color:#4f5661;margin:0}.legal{grid-column:1/-1;margin-top:36px!important}.contact-form{background:#f1faf4;border-radius:18px;padding:42px}.contact-form label{display:block;font-size:14px;margin-bottom:16px}.contact-form input,.contact-form textarea{display:block;width:100%;margin-top:8px;border:1px solid #acb8c8;border-radius:8px;padding:16px 18px;font:inherit;background:#fff}.contact-form textarea{height:120px;resize:vertical}.map{margin-top:70px}.map iframe{width:100%;height:420px;border:0;display:block}.site-footer{background:var(--footer);color:#fff;padding:52px 0}.footer-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:110px}.footer-grid h2{margin:0 0 48px;font-size:30px}.footer-grid p{font-weight:700}.socials{display:flex;gap:34px;font-size:26px;margin-top:35px}.footer-contact h3{text-transform:uppercase;text-decoration:underline;font-size:15px;margin:0 0 22px}.footer-contact p{line-height:1.6}.notice{background:#e8f6ed;color:#206136;padding:12px 16px;border-radius:8px;margin-bottom:20px}.error404{text-align:center;padding:120px 0}@media(max-width:900px){.site-header{height:auto;padding:18px 0}.header-inner{flex-wrap:wrap;gap:14px}.nav-toggle{display:block}.main-nav{display:none;width:100%;flex-direction:column;gap:10px;align-items:flex-start;padding-top:12px}.main-nav.open{display:flex}.hero{min-height:auto;padding:90px 0 60px}.hero-cards,.intro-grid,.service-home-grid,.split,.mission .split,.gallery-grid,.services-grid,.contact-grid,.footer-grid{grid-template-columns:1fr}.hero-cards{margin-top:45px}.section{padding:65px 0}.wide-image img{height:260px}.services-dark>p{margin-bottom:45px}.image-stack{min-height:auto}.image-stack .main-img,.image-stack .over-img{position:static;width:100%;height:auto;margin-bottom:16px}.contact-details{grid-template-columns:1fr}.contact-form{padding:28px}.main-nav a[aria-current="page"],body.home .main-nav a[href$="/"]{border-bottom-color:transparent}} 


/* MENU FIX */
.main-nav a{
    border-bottom:2px solid transparent !important;
}
.main-nav a:hover{
    border-bottom-color:#17191d !important;
}
.main-nav a[aria-current="page"]{
    border-bottom-color:#17191d !important;
}

/* FOOTER FIX */
.footer-contact p,
.footer-contact a {
    font-weight:400 !important;
}

.footer-contact h3 {
    font-weight:700 !important;
}

.site-footer p {
    font-weight:400 !important;
}
.energy-banner{
    background:#fff;
    padding:70px 0;
    text-align:center;
}

.energy-banner img{
    max-width:420px;
    width:100%;
    height:auto;
    display:block;
    margin:0 auto;
}

@media (max-width:768px){
    .energy-banner{
        padding:50px 20px;
    }

    .energy-banner img{
        max-width:280px;
    }
}

.energy-banner{
    background:#fff;
    padding:70px 0;
}

.energy-content{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:80px;
}

.energy-image img{
    max-width:520px;
    width:100%;
    height:auto;
    display:block;
}

.energy-list{
    max-width:520px;
    text-align:left;
}

.energy-list h2{
    color:#28713d;
    font-size:36px;
    margin:0 0 30px;
    text-align:left;
}

.energy-list ul{
    list-style:none;
    padding:0;
    margin:0;
}

.energy-list li{
    font-size:22px;
    line-height:1.5;
    margin-bottom:18px;
    position:relative;
    padding-left:35px;
    text-align:left;
}

.energy-list li:before{
    content:"✓";
    position:absolute;
    left:0;
    top:0;
    color:#28713d;
    font-weight:700;
}

@media(max-width:900px){

    .energy-content{
        flex-direction:column;
        gap:40px;
    }

    .energy-image{
        text-align:center;
    }

    .energy-list{
        max-width:100%;
        text-align:left;
    }

    .energy-list h2{
        text-align:left;
    }

    .energy-list li{
        font-size:18px;
        padding-left:35px;
        text-align:left;
    }

    .energy-list li:before{
        position:absolute;
        left:0;
        top:0;
    }
}


/* Kontakt - tekst rejestrowy */
.contact-page .legal{
    text-align: justify;
    line-height: 1.8;
    font-size: 15px;
    color: #4f5661;
    max-width: 540px;
}


/* Kontakt */
.contact-grid{
    grid-template-columns: 1.1fr 1fr !important;
}

.contact-details a{
    white-space: nowrap;
}

.contact-details{
    min-width: 400px;
}

/* Zdjęcie na glownej */
.wide-image{
    display:flex;
    justify-content:center;
    margin:40px 0;
}

.wide-image img{
    width:65%;
    max-width:850px;
    height:auto;
    border-radius:24px;
    box-shadow:0 12px 35px rgba(0,0,0,.12);
}


/* Zdjęcie na glownej nasze uslugi */
.service-home-card{
    background:#e5e8e7;
    border:1px solid #cfd6d3;
    border-radius:18px;
    overflow:hidden;
    transition:all .3s ease;
    box-shadow:0 6px 20px rgba(0,0,0,.08);
}

.service-home-card:hover{
    transform:translateY(-8px);
    box-shadow:0 15px 35px rgba(0,0,0,.18);
}

.service-home-card img{
    width:100%;
    height:280px;
    object-fit:cover;
    display:block;
}




/* Zdjęcie uslugi */
.services-grid{
    gap:30px;
}

.service-item{
    background:#fff;
    border-radius:18px;
    overflow:hidden;
    box-shadow:0 6px 20px rgba(0,0,0,.08);
    transition:all .3s ease;
}

.service-item:hover{
    transform:translateY(-8px);
    box-shadow:0 18px 40px rgba(0,0,0,.18);
}

.service-item img{
    width:100%;
    height:260px;
    object-fit:cover;
    display:block;
}

.service-item h3{
    padding:24px 24px 12px;
    margin:0;
}

.service-item p{
    padding:0 24px 24px;
    margin:0;
    line-height:1.6;
}