.contact-section{

    padding:140px 20px 80px;

    background:
radial-gradient(circle at top left,#dff6ff 0%,transparent 35%),
radial-gradient(circle at bottom right,#fff2b0 0%,transparent 25%),
#f8fafc;

    background-repeat:no-repeat;

    background-position:center top;

    background-size:cover;

}

.contact-header{
    text-align:center;
    margin-bottom:40px;
}

.contact-header h1{
    margin:0;
    font-size:60px;
    font-weight:800;
    color:#0b1d5c;
}

.contact-header p{
    margin-top:15px;
    font-size:20px;
    color:#555;
}

/* LIGNES */

.contact-row-1,
.contact-row-2,
.contact-row-3{

    max-width:1400px;

    margin:0 auto 20px;

    display:grid;

    gap:20px;

}

.contact-row-1{
    grid-template-columns:380px 1fr 320px;
}

.contact-row-2{
    grid-template-columns:1fr 2fr; 
}

.contact-row-3{
    grid-template-columns:1fr 1fr 1fr;
}

.contact-info-card{

    display:grid;

    grid-template-columns:320px 1fr;

    gap:20px;

    align-items:center;

}

.contact-info-map iframe{

    width:100%;

    height:240px;

    border:none;

    border-radius:10px;

}

/* CARTES */

.contact-image-card,
.contact-form-card,
.contact-phone-card,
.weather-card,
.contact-info-card,
.map-card,
.feature-card{

    background:#fff;

    border-radius:16px;

    box-shadow:
    0 4px 20px rgba(0,0,0,.08);

    overflow:hidden;
}

/* IMAGE */

.contact-image-card img{

    width:100%;

    display:block;

    height:100%;

    

}

/* FORMULAIRE */

.contact-form-card{

    padding:30px;

}

.contact-form-card h2{

    text-align:center;

    color:#0b1d5c;

    margin-bottom:25px;

}

.contact-form-card form{

    display:flex;

    flex-direction:column;

    gap:15px;

}

.contact-form-card input,
.contact-form-card select,
.contact-form-card textarea{

    padding:14px;

    border:1px solid #ddd;

    border-radius:10px;

    font-size:15px;

}

.contact-form-card textarea{

    min-height:140px;

    resize:none;

}

.contact-form-card button{

    background:#ffd600;

    border:none;

    padding:15px;

    border-radius:10px;

    font-weight:700;

    cursor:pointer;

}

/* TELEPHONE */

.contact-phone-card{

    background:#fff;

    border-radius:12px;

    padding:30px 25px;

    text-align:center;

    min-height:420px;

    display:flex;

    flex-direction:column;

    align-items:center;

}

.contact-phone-card h2{

    font-size:16px;

    font-weight:800;

    color:#071a63;

    margin-bottom:15px;

}

.phone-icon{

    width:120px;

    height:120px;

    border:2px solid #42a5ff;

    border-radius:50%;

    display:flex;

    align-items:center;

    justify-content:center;

    font-size:52px;

    color:#ffd600;

    margin:10px auto 25px;

}

.phone-number{

    font-size:28px;

    font-weight:800;

    color:#071a63;

    line-height:1.2;

    margin-bottom:20px;

}

.phone-button{

    width:100%;

    max-width:240px;

    height:50px;

    display:flex;

    align-items:center;

    justify-content:center;

    background:#ffd600;

    color:#000;

    text-decoration:none;

    border-radius:8px;

    font-weight:700;

    margin-bottom:35px;

    transition:.2s;

}

.phone-button:hover{

    transform:translateY(-2px);

}

.phone-info{

    margin-top:auto;

    width:100%;

}

.phone-info:before{

    content:"";

    display:block;

    width:60px;

    height:2px;

    background:#d8dde8;

    margin:0 auto 20px;

}

.phone-info{

    font-size:14px;

    color:#071a63;

    font-weight:700;

}

.phone-info strong{

    display:block;

    margin-top:8px;

    font-size:20px;

    color:#071a63;

}

/* METEO */

.weather-card{

    padding:25px;

}

.weather-temp{

    font-size:60px;

    font-weight:800;

    color:#0b1d5c;

}

.weather-days{

    display:grid;

    grid-template-columns:repeat(5,1fr);

    gap:10px;

    margin-top:20px;

}

.weather-days div{

    text-align:center;

    padding:10px;
 
    border:1px solid #ddd;

    border-radius:8px;

}

.weather-current{

    display:flex;

    align-items:center;

    gap:20px;

}

#weatherIcon{

    width:70px;

    height:70px;

}

.weather-extra{

    margin-top:10px;

    font-size:14px;

}

.weather-forecast{

    display:grid;

    grid-template-columns:
    repeat(5,1fr);

    gap:10px;

    margin-top:20px;

}

.weather-day{

    background:#f8f9fc;

    border:1px solid #dfe5ef;

    border-radius:10px;

    min-height:110px;

    padding:12px;

    display:flex;

    flex-direction:column;

    justify-content:center;

    align-items:center;

}

.weather-day img{

    width:50px;

    height:50px;

    margin:5px 0;

}

.weather-current{

    display:flex;

    justify-content:space-between;

    align-items:center;

}

.weather-left{

    display:flex;

    align-items:center;

    gap:15px;

}

.weather-right{

    display:flex;

    flex-direction:column;

    gap:10px;

}

#weatherIcon{

    width:80px !important;

    height:80px !important;

    object-fit:contain !important;

    background:none !important;

    border:none !important;

    border-radius:0 !important;

    box-shadow:none !important;

}

#weatherTemp{

    font-size:60px;

    font-weight:800;

    color:#071a63;

}

#weatherDesc{

    color:#444;

}

.weather-date{

    margin-top:10px;

    font-size:14px;

    font-weight:700;

    text-transform:uppercase;

    color:#071a63;

}

/* INFOS */

.contact-info-card{

    padding:25px;

}

.contact-info-card h2{

    color:#0b1d5c;

}

.contact-info-card a{

    display:inline-block;

    margin-top:20px;

    text-decoration:none;

    border:2px solid #0b1d5c;

    padding:10px 20px;

    border-radius:10px;

    color:#0b1d5c;

}

/* MAP */

.map-card iframe{

    width:100%;

    height:100%;

    min-height:320px;

    border:none;

}

/* AVANTAGES */

.feature-card{

    padding:25px;

    text-align:center;

}

.feature-card h3{

    color:#0b1d5c;

}

/* RESPONSIVE */

@media(max-width:1200px){

    .contact-row-1{
        grid-template-columns:1fr;
    }

    .contact-row-2{
        grid-template-columns:1fr;
    }

    .contact-row-3{
        grid-template-columns:1fr;
    }

}

@media(max-width:768px){

    .contact-header h1{
        font-size:38px;
    }

    .contact-header p{
        font-size:16px;
    }

}
