:root{
    --primary:#1a3e72;
    --secondary:#ff7d00;
    --accent:#ffaa45;
    --light:#f8f9fa;
    --dark:#212529;
    --gray:#6c757d;
    --white:#fff;
    --success:#28a745;
    --shadow:0 4px 20px rgb(0 0 0 / 36%);
    --radius:12px;
    --transition:all .3s ease
}
*{
    margin:0;
    padding:0;
    box-sizing:border-box
}
body{
    font-family:Poppins,sans-serif;
    line-height:1.6;
    color:var(--dark);
    background-color:var(--light);
    overflow-x:hidden;
    padding-top:80px
}
h1,h2,h3,h4{
    font-weight:700;
    line-height:1.2;
    margin-bottom:1rem;
    color:var(--primary)
}
h1{
    font-size:2.5rem
}
h2{
    font-size:2rem
}
h3{
    font-size:1.75rem
}
h2:before{
    content:'';
    width:100px;
    height:10px;
    background:#ff7d00;
    display:block;
    margin:0 auto;
    margin-bottom:16px
}
a{
    text-decoration:none;
    color:var(--secondary);
    transition:var(--transition)
}
.container{
    width:100%;
    max-width:1200px;
    margin:0 auto;
    padding:0 20px
}
header{
    background-color:var(--white);
    box-shadow:var(--shadow);
    position:fixed;
    width:100%;
    top:0;
    z-index:1000;
    padding:15px 0
}
.header-container{
    display:flex;
    justify-content:space-between;
    align-items:center
}
.logo{
    font-family:Poppins,sans-serif;
    font-size:2rem;
    font-weight:900;
    font-style:italic
}
.logo span:first-child{
    color:var(--primary);
    margin-right:-5px
}
.logo span:last-child{
    color:var(--secondary)
}
nav ul{
    display:flex;
    list-style:none;
    gap:30px
}
nav a{
    color:var(--dark);
    font-weight:500;
    position:relative;
    padding:5px 0
}
nav a:after{
    content:'';
    position:absolute;
    width:0;
    height:2px;
    bottom:0;
    left:0;
    background-color:var(--secondary);
    transition:var(--transition)
}
nav a:hover:after{
    width:100%
}
.cta-button{
    display:inline-flex;
    align-items:center;
    gap:8px;
    background-color:var(--secondary);
    color:var(--white);
    padding:12px 24px;
    border-radius:50px;
    font-weight:600;
    transition:var(--transition);
    box-shadow:0 4px 15px rgba(255,125,0,.3);
    text-shadow:1px 1px #0000006b
}
.cta-button:hover{
    background-color:var(--accent);
    transform:translateY(-2px);
    box-shadow:0 6px 20px rgba(255,125,0,.4)
}
.phone-cta{
    animation:pulse 2s infinite
}
@keyframes pulse{
    0%{
        transform:scale(1)
    }
    50%{
        transform:scale(1.05)
    }
    100%{
        transform:scale(1)
    }
}

.hero{
    background:linear-gradient(rgba(0,0,0,.7),rgba(0,0,0,.7)),url('./hero-image.webp') no-repeat center/cover;
    color:var(--white);
    text-align:center;
    padding:100px 0
}
.hero h1{
    font-size:3rem;
    margin-bottom:20px;
    color:var(--white)
}
.hero p{
    font-size:1.2rem;
    max-width:700px;
    margin:0 auto 30px;
    opacity:.9
}
.hero-buttons{
    display:flex;
    gap:20px;
    justify-content:center;
    flex-wrap:wrap
}
.service-map{
    background-color:var(--primary);
    color:var(--white);
    padding:60px 0;
    position:relative;
    overflow:hidden
}
.service-map h3{
    color:var(--secondary);
    text-align:center;
    margin-bottom:30px;
    font-size:1.8rem
}
.service-area{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
    gap:15px;
    list-style:none;
    padding:0;
    max-width:800px;
    margin:0 auto
}
.service-area li{
    background:rgba(255,255,255,.1);
    padding:12px 15px;
    border-radius:6px;
    text-align:center;
    transition:var(--transition);
    display:flex;
    align-items:center;
    justify-content:center;
    height:70px
}
.service-area li:hover{
    background:rgba(255,255,255,.2);
    transform:translateY(-3px)
}
.services{
    padding:80px 0
}
.services h2{
    text-align:center;
    margin-bottom:50px;
    position:relative
}
.service-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
    gap:30px
}
.service-card{
    background:var(--white);
    border-radius:var(--radius);
    padding:30px;
    box-shadow:var(--shadow);
    transition:var(--transition);
    text-align:center;
    border-bottom:4px solid transparent;
  display: flex;
  flex-direction: column;
  height: 100%; /* Ważne - kontener musi mieć określoną wysokość */
  position: relative; /* Dla starszych przeglądarek */
}
.service-card:hover{
    transform:translateY(-10px);
    box-shadow:0 15px 30px rgba(0,0,0,.1);
    border-bottom-color:var(--secondary)
}
.service-icon{
    font-size:2.5rem;
    color:var(--secondary);
    margin-bottom:20px
}
.service-card h3{
    font-size:1.4rem;
    margin-bottom:15px
}
.service-card p{margin-bottom:15px;}
.service-card .cta-button{  margin: auto;align-self: anchor-center;width: fit-content;}
.emergency-banner{
	background: linear-gradient(135deg, #ff7d00ed, #ffaa45d6), url(./hero-image.webp) no-repeat center / cover;
    color:var(--white);
    padding:80px 0;
    text-align:center;
    margin:20px 0
}
.emergency-banner h3{
    font-size:1.8rem;
    margin-bottom:10px;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:10px
}
.emergency-phone{
    font-size:1.8rem;
    font-weight:700;
    display:inline-flex;
    align-items:center;
    gap:10px;
    margin-top:15px;
    background:#1a3e72;
    padding:10px 25px;
    border-radius:50px;
    transition:var(--transition)
}
.emergency-phone:hover{
    background:rgba(0,0,0,.3);
    transform:scale(1.05)
}
.triangle{
    font-size:3em;
    margin-bottom:15px;
    color:var(--primary)
}
.about{
    padding:80px 0;
    background:var(--white)
}
.about-us-box{    
background: var(--primary);
padding:60px 0;
color:#fff;
}
.about-us-box h3{color:var(--secondary);}
.about-us-box div.about-us-boxes{
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 40px;
	width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;	
}
.about-container{
    display:flex;
    align-items:center;
    gap:50px
}
.about-img{
    flex:1;
    border-radius:var(--radius);
    overflow:hidden;
    box-shadow:var(--shadow)
}
.about-img img{
    width:100%;
    height:auto;
    display:block;
    transition:var(--transition)
}
.about-img:hover img{
    transform:scale(1.03)
}
.about-content{
    flex:1
}
.about-content ul{
    list-style:none;
    margin:30px 0
}
.about-content li{
    position:relative;
    padding-left:35px;
    margin-bottom:15px;
    font-size:1.1rem
}
.about-content li:before{
    content:'\f00c';
    font-family:'Font Awesome 6 Free';
    font-weight:900;
    position:absolute;
    left:0;
    top:0;
    color:var(--secondary)
}

.testimonials{
    padding:80px 0;
    background:var(--light)
}
.testimonials h2{
    text-align:center;
    margin-bottom:50px
}
.testimonial-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
    gap:30px
}
.testimonial-card{
    background:var(--white);
    padding:30px;
    border-radius:var(--radius);
    box-shadow:var(--shadow);
    position:relative;
	text-align:center;
}
.testimonial-card:before{
    content:'\201C';
    font-family:Georgia,serif;
    font-size:5rem;
    color:var(--secondary);
    opacity:.2;
    position:absolute;
    top:10px;
    left:15px;
    line-height:1
}
.testimonial-card p{
    position:relative;
    z-index:1;
    font-style:italic;
    margin-bottom:20px
}
.testimonial-author{
    display:inline-block;
    align-items:center
}
.testimonial-author img{
    width:60px;
    height:60px;
    border-radius:50%;
    object-fit:cover;
    margin-right:15px;
    border:3px solid var(--secondary)
}
.author-info em{
    margin-bottom:5px;
    font-size:1.1rem;
	font-style:normal;
	font-weight:bold;

}
.rating{
    color:var(--accent);
	margin-bottom:15px;
}
.contact{
    padding:30px 0;
    background:var(--white)
}
.contact h2{
    text-align:center;
    margin-bottom:50px
}
.contact-container{
    display:flex;
    gap:30px;
    align-items:stretch
}
.contact-info-box{
    flex:1;
    display:flex;
    flex-direction:column;
    gap:20px
}
.map-box{
    flex:1;
    min-height:400px;
    border-radius:var(--radius);
    overflow:hidden
}
.contact-method{
    display:flex;
    align-items:flex-start;
    gap:20px;
    padding:25px;
    background:var(--light);
    border-radius:var(--radius);
    transition:var(--transition);
    flex:1
}
.contact-icon{
    font-size:1.8rem;
    color:var(--secondary);
    min-width:50px;
    text-align:center;
    margin-top:5px
}
.contact-details h3{
    margin-bottom:10px;
    font-size:1.3rem
}
.contact-details p{
    margin-left:25px
}
.phone-highlight{
    font-size:1.5rem;
    font-weight:700;
    color:var(--secondary);
    display:inline-block;
    margin:10px 0
}
footer{
    background:var(--primary);
    color:var(--white);
    padding:60px 0 0;
	margin-top:40px;
}
.footer-container{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
    gap:40px;
    margin-bottom:40px
}
.footer-logo{
    font-family:Poppins,sans-serif;
    font-size:1.8rem;
    font-weight:900;
    font-style:italic;
    margin-bottom:10px
}
.footer-logo span:first-child{
    color:#fff
}
.footer-logo span:last-child{
    color:var(--secondary)
}
.footer-logo+p{
    opacity:.8;
    line-height:1.7;
    font-family:Poppins,sans-serif;
    font-size:1rem;
    font-weight:400;
    font-style:normal
}
.footer-social{
    display:flex;
    gap:15px;
    margin-top:20px
}
.social-icon{
    width:40px;
    height:40px;
    border-radius:50%;
    background:rgba(255,255,255,.1);
    display:flex;
    align-items:center;
    justify-content:center;
    transition:var(--transition)
}
.social-icon:hover{
    background:var(--secondary);
    transform:translateY(-3px)
}
.footer-title{
    font-size:1.2rem;
    margin-bottom:20px;
    color:var(--white);
    position:relative;
    padding-bottom:10px
}
.footer-title:after{
    content:'';
    position:absolute;
    bottom:0;
    left:0;
    width:40px;
    height:2px;
    background:var(--secondary)
}
.footer-links{
    list-style:none
}
.footer-links li{
    margin-bottom:10px
}
.footer-links a{
    color:rgba(255,255,255,.7);
    transition:var(--transition);
    padding:5px 5px
}
.footer-links a:hover{
    color:var(--white);
    transform:translateX(5px)
}
.copyright{
    text-align:center;
    padding:20px 0;
    border-top:1px solid rgba(255,255,255,.1);
    font-size:.9rem;
    opacity:.7
}

@media (max-width:992px){
    .about-container{
        flex-direction:column
    }
    .hero h1{
        font-size:2.5rem
    }
}
@media (max-width:900px){

	.logo{display:inline-block;}
	.header-container nav{display:none;}
    nav ul{
        gap:15px;
        flex-wrap:wrap;
        justify-content:center
    }
    .hero{
        padding:120px 0 60px;
		
    }
    .hero h1{
        font-size:2rem
    }
    .hero-buttons{
        flex-direction:column;
        align-items:center
    }
    .contact-method{
        flex-direction:column;
        text-align:center
    }
}
@media (max-width:576px){
    .service-area{
        grid-template-columns:1fr 1fr
    }
    .emergency-phone{
        font-size:1.4rem;
        padding:8px 15px
    }
    .phone-highlight{
        font-size:1.4rem
    }
}

@media (max-width:480px){
    .logo{font-size: 1.3rem;}
}

#privacy-policy{padding:50px 0;}
#privacy-policy h2{font-size: 1.5rem;}
#privacy-policy p{margin-left:23px;}
#privacy-policy h2:before{display:none;}
#privacy-policy ul{margin:0 0 30px 43px;}
#privacy-policy h2	{margin-top:20px;}
