/* =====================================
   INFRASTRUCTURE FACILITIES
===================================== */

.infra-section{
    max-width:1200px;
    margin:60px auto;
    padding:0 20px;
}

.infra-section .section-title{
    text-align:center;
    font-size:34px;
    color:#800020;
    font-weight:700;
    margin-bottom:10px;
    font-family:'Poppins', sans-serif;
}

.infra-subtitle{
    text-align:center;
    color:#666;
    font-size:16px;
    margin-bottom:35px;
}

.infra-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(350px,1fr));
    gap:28px;
}

.infra-card{
    background:#fff;
    border-radius:20px;
    overflow:hidden;
    box-shadow:0 10px 28px rgba(0,0,0,0.08);
    border:1px solid #ececec;
    transition:0.35s ease;
}

.infra-card:hover{
    transform:translateY(-8px);
    box-shadow:0 18px 35px rgba(128,0,32,0.16);
}

.infra-slider{
    position:relative;
    height:240px;
    overflow:hidden;
}

.infra-slide{
    position:absolute;
    inset:0;
    opacity:0;
    transition:opacity 1s ease;
}

.infra-slide.active{
    opacity:1;
    z-index:2;
}

.infra-slide img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}

.infra-content{
    padding:25px;
}

.infra-content h3{
    margin:0 0 15px;
    color:#800020;
    font-size:24px;
    font-weight:700;
}

.infra-content p{
    margin:0;
    color:#444;
    line-height:1.8;
    font-size:15px;
    text-align:justify;
}

@media (max-width:768px){

    .infra-section .section-title{
        font-size:28px;
    }

    .infra-grid{
        grid-template-columns:1fr;
        gap:20px;
    }

    .infra-slider{
        height:220px;
    }

    .infra-content{
        padding:20px;
    }

    .infra-content h3{
        font-size:21px;
    }

    .infra-content p{
        font-size:14px;
    }
}