/**
 * MZ Informatique — Styles spécifiques aux types de pages
 */

/* Section avec image */
.section-visual {
  margin-top: var(--space-xl);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.section-visual img {
  width: 100%;
  height: auto;
  display: block;
}

/* Page d'accueil — blocs */
.home-services-intro {
  margin-bottom: var(--space-2xl);
}

.home-connect3s-section .section-title {
  margin-top: 0;
}

/* Section intro */
.section-intro {
  font-size: var(--font-size-lg);
  color: var(--color-text-muted);
  text-align: center;
  margin-bottom: 0;
}

/* Page Services — séparation Expertises MZ / Connect 3S */
.services-section-label {
  font-size: var(--font-size-sm);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-primary);
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-sm);
  border-bottom: 2px solid var(--color-primary);
}

.services-section-label--connect3s {
  color: var(--c3s-text);
  border-bottom-color: #6366F1;
}

.services-section + .services-section {
  margin-top: var(--space-3xl);
}

/* Page article blog */
.article-header {
  margin-bottom: var(--space-2xl);
}

.article-title {
  margin-bottom: var(--space-sm);
}

.article-date-category {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.article-body h2 {
  margin-top: var(--space-2xl);
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--color-border);
}

.article-body h3 {
  margin-top: var(--space-xl);
}

.article-body p,
.article-body ul,
.article-body ol {
  margin-bottom: var(--space-md);
}

.article-cta {
  margin-top: var(--space-2xl);
  padding: var(--space-xl);
  background: var(--color-bg-alt);
  border-radius: var(--radius-lg);
}

/* Page contact */
.contact-intro {
  margin-bottom: var(--space-2xl);
}

.contact-info-block h2 {
  margin-bottom: var(--space-lg);
  margin-top: 0;
}

.contact-grid {
  display: grid;
  gap: var(--space-2xl);
}

.contact-coords {
  min-width: 0;
}

.contact-cards {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.contact-card {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  transition: box-shadow var(--transition-base), border-color var(--transition-base);
}

.contact-card:hover {
  border-color: var(--color-primary-light);
  box-shadow: var(--shadow-sm);
}

.contact-card--urgent {
  border-left: 4px solid var(--color-accent);
}

.contact-card-label {
  display: block;
  font-size: var(--font-size-sm);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text-muted);
  margin-bottom: var(--space-sm);
}

.contact-card-value {
  margin: 0;
  font-size: var(--font-size-lg);
}

.contact-card-value a {
  font-weight: 500;
}

.contact-card-link {
  display: inline-block;
  margin-top: var(--space-sm);
  font-size: var(--font-size-sm);
  font-weight: 600;
}

.contact-map-wrap {
  min-width: 0;
}

.contact-map-frame {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 75%;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--color-bg-alt);
  border: 1px solid var(--color-border);
}

.contact-map-frame iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  min-height: 280px;
}

.contact-map-open {
  margin-top: var(--space-md);
  margin-bottom: 0;
}

@media (min-width: 768px) {
  .contact-grid {
    grid-template-columns: 1fr 1.2fr;
    align-items: start;
  }

  .contact-map-frame {
    padding-bottom: 60%;
    min-height: 320px;
  }
}

/* Page légale */
.legal-content h2 {
  margin-top: var(--space-2xl);
  font-size: var(--font-size-xl);
}

.legal-content h3 {
  margin-top: var(--space-xl);
  font-size: var(--font-size-lg);
}

.legal-content p,
.legal-content ul {
  margin-bottom: var(--space-md);
}

.legal-content ul {
  padding-left: 1.5em;
}

.legal-updated {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-xl);
}

/* Page cybersecurite - image plus grande */
.page-cybersecurite .hero-visual {
  max-width: 900px;
}

.page-cybersecurite .hero-visual img {
  max-height: 450px;
}
