/* service-detail.css - Styles pour les pages de détails de services */

.service-hero { 
    padding: 160px 0 80px; 
    background: radial-gradient(circle at top right, var(--primary-light) 0%, var(--bg-alt) 60%);
    position: relative;
    overflow: hidden;
    text-align: center;
}

.service-hero h1 { 
    font-size: clamp(34px, 5vw, 54px); 
    font-weight: var(--weight-extra); 
    color: var(--primary-dark); 
    letter-spacing: -2px;
    line-height: 1.05;
    max-width: 900px;
    margin-inline: auto;
}

/* Effet de dégradé sur le mot clé (Toulouse) */
.service-hero h1 span {
    background: linear-gradient(135deg, var(--primary-blue), var(--primary-dark));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    font-weight: var(--weight-extra);
    display: block;
}

.service-intro { 
    font-size: 19px; 
    color: var(--text-muted); 
    max-width: 700px; 
    margin: 0 auto 30px; 
    line-height: 1.6;
    font-weight: var(--weight-normal);
}
.service-hero-ctas { display: flex; gap: 14px; justify-content: center; margin-bottom: 20px; }
.service-hero-badges { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

.service-details { padding: 80px 0; background: var(--bg-alt); }

.details-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.detail-card { 
    padding: 40px 30px; 
    background: var(--surface); 
    border: 1px solid var(--border-soft); 
    border-radius: var(--radius-lg); 
    transition: var(--transition); 
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    box-shadow: var(--shadow-subtle);
}
.detail-card:hover { box-shadow: var(--shadow-card); transform: translateY(-5px); border-color: var(--primary-blue); }
.detail-icon { font-size: 44px; display: block; margin-bottom: 20px; transition: var(--transition); }
.detail-card:hover .detail-icon { transform: scale(1.1); }
.detail-card h3 { font-size: 19px; font-weight: var(--weight-extra); margin-bottom: 12px; color: var(--primary-dark); }
.detail-card p { font-size: 15px; color: var(--text-muted); line-height: 1.7; margin: 0; }

.service-benefits { padding: 80px 0; background: var(--primary-light); }
.benefits-list { max-width: 700px; margin: 0 auto; display: flex; flex-direction: column; gap: 16px; }
.benefit-item { display: flex; gap: 16px; align-items: flex-start; background: var(--surface); padding: 20px; border-radius: var(--radius-lg); box-shadow: var(--shadow-subtle); }
.benefit-check { flex-shrink: 0; width: 32px; height: 32px; background: var(--primary-blue); color: var(--surface); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: var(--weight-black); font-size: 16px; }
.benefit-item strong { display: block; color: var(--primary-dark); margin-bottom: 2px; }
.benefit-item p { font-size: 14px; color: var(--text-muted); margin: 0; line-height: 1.5; }

.service-pricing-strip { padding: 60px 0; background: var(--primary-blue); }
.pricing-strip-inner { display: flex; justify-content: space-between; align-items: center; gap: 30px; }
.pricing-strip-inner .section-title { color: var(--surface); padding-bottom: 0; margin-bottom: 4px; }
.pricing-strip-inner .section-title::after { display: none; }
.pricing-strip-inner p { color: rgba(255,255,255,0.8); font-size: 15px; }
.pricing-strip-price { text-align: right; }
.strip-gross { display: block; font-size: 18px; color: rgba(255,255,255,0.6); text-decoration: line-through; }
.strip-net { display: block; font-size: 40px; font-weight: var(--weight-black); color: var(--surface); line-height: 1.1; }
.strip-note { font-size: 13px; color: rgba(255,255,255,0.8); }

.service-faq { padding: 80px 0; background: var(--bg-alt); }

.related-services { padding: 80px 0; background: var(--primary-light); }
.related-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 16px; }
.related-card { display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 24px; background: var(--surface); border-radius: var(--radius-lg); text-decoration: none; color: var(--primary-dark); border: 1px solid var(--border-soft); transition: var(--transition); text-align: center; box-shadow: var(--shadow-subtle); }
.related-card:hover { border-color: var(--primary-blue); box-shadow: var(--shadow-card); }
.related-card span { font-size: 28px; }
.related-card strong { font-size: 14px; }

.service-final-cta { padding: 80px 0; background: var(--bg-alt); }

@media (max-width: 1024px) {
    .details-grid { grid-template-columns: repeat(2, 1fr); }
    .pricing-strip-inner { flex-direction: column; text-align: center; }
    .pricing-strip-price { text-align: center; }
}

@media (max-width: 640px) {
    .service-hero { padding: 120px 0 40px; }
    .service-hero-ctas { flex-direction: column; align-items: stretch; }
    .service-hero-ctas .btn-primary,
    .service-hero-ctas .btn-secondary { text-align: center; justify-content: center; display: flex; }
    .service-details, .service-benefits, .service-faq, .service-final-cta, .related-services { padding: 50px 0; }
    .details-grid { grid-template-columns: 1fr; }
    .detail-card { padding: 28px 20px; }
    .service-hero-badges { flex-direction: column; align-items: center; }
}
