/**
 * Affichage mobile / petite tablette — colonnes, confort tactile, safe areas.
 * Chargé après ui-harmony pour compléter home.css et les pages.
 */

:root {
  --kp-mobile-section-y: clamp(2.75rem, 8vw, 4rem);
}

@media (max-width: 767px) {
  body.kp-body {
    padding-bottom: env(safe-area-inset-bottom, 0px);
  }

  /* Surcharge les py-* Tailwind sur mobile (sauf hero qui gère son propre rythme) */
  body.kp-body main > section:not(#hero) {
    padding-top: var(--kp-mobile-section-y) !important;
    padding-bottom: var(--kp-mobile-section-y) !important;
  }

  .container.mx-auto.px-4 {
    padding-left: max(1rem, env(safe-area-inset-left, 0px));
    padding-right: max(1rem, env(safe-area-inset-right, 0px));
  }

  .section-title {
    font-size: clamp(1.65rem, 5.8vw, 2.05rem);
    margin-bottom: 1.65rem;
    line-height: 1.15;
    padding-inline: 0.25rem;
  }

  .card-bg {
    padding: 1.05rem;
  }

  .btn-primary,
  .btn-secondary {
    min-height: 44px;
    padding-top: 0.65rem;
    padding-bottom: 0.65rem;
  }

  .btn-learn-more {
    min-height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  /* Accueil : cartes compactes en 2 colonnes */
  #highlights .grid > article.card-bg img {
    height: 7rem;
  }

  #actualites .grid > article.card-bg img {
    height: 6.5rem;
  }

  #highlights .card-bg h3,
  #actualites .card-bg h3 {
    font-size: 0.95rem;
    line-height: 1.25;
  }

  #highlights .card-bg p,
  #actualites .card-bg p {
    font-size: 0.8rem;
    line-height: 1.45;
  }

  .portfolio-buttons-container {
    flex-direction: row !important;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.65rem !important;
    margin-top: 2rem !important;
  }

  .portfolio-buttons-container .btn-primary {
    flex: 1 1 calc(50% - 0.5rem);
    min-width: 140px;
    justify-content: center;
    text-align: center;
  }

  .open-community-section h2 {
    font-size: clamp(1.45rem, 5vw, 2rem);
  }

  .open-community-section h3 {
    font-size: clamp(1.15rem, 4vw, 1.5rem);
  }

  .services-section .section-title {
    font-size: clamp(1.45rem, 5vw, 2rem);
  }

  .services-section .service-item h4 {
    font-size: 1rem;
  }

  .services-section .service-item p {
    font-size: 0.85rem;
    line-height: 1.45;
  }

  #expertises .service-item {
    padding: 1rem;
  }

  #expertises .service-item .icon-box {
    width: 52px;
    height: 52px;
    margin-bottom: 0.65rem;
  }

  #expertises .service-item .icon-box i {
    font-size: 22px;
  }

  #expertises .service-item .btn-learn-more {
    font-size: 0.72rem;
    padding: 0.45rem 0.75rem;
  }

  /* Page expertises (liste complète) */
  #expertises .service-item {
    padding: 1rem;
  }

  #expertises .service-item .icon-box {
    width: 52px;
    height: 52px;
  }

  #expertises .service-item .icon-box i {
    font-size: 22px;
  }

  #expertises .service-item h3 {
    font-size: 1.05rem;
  }

  #expertises .service-item p {
    font-size: 0.85rem;
    line-height: 1.45;
  }

  #formations .service-item h3 {
    font-size: 1.05rem;
  }

  #formations .service-item p,
  #formations .service-item li {
    font-size: 0.82rem;
  }

  .value-card {
    padding: 1.05rem;
  }

  .value-card h4 {
    font-size: 1.05rem;
  }

  .value-card p {
    font-size: 0.88rem;
    line-height: 1.45;
  }

  .elegant-script-text {
    font-size: 1.55rem;
    padding-inline: 0.5rem;
  }

  #call-to-action h2 {
    font-size: clamp(1.5rem, 5vw, 2rem);
    padding-inline: 0.25rem;
  }

  #faq article.card-bg h3 {
    font-size: 1rem;
  }

  #faq article.card-bg p {
    font-size: 0.82rem;
  }
}

/* Très petits écrans : une colonne pour les listes denses */
@media (max-width: 380px) {
  .portfolio-grid {
    grid-template-columns: 1fr !important;
    gap: 1rem !important;
  }

  #highlights .grid[class*='grid-cols-2'],
  #actualites .grid[class*='grid-cols-2'] {
    grid-template-columns: 1fr;
  }
}
