/*
 * responsive.css - complète style.css uniquement sous les breakpoints.
 * Aucune règle hors media query : le rendu ≥1024px reste celui de style.css.
 */

@media (max-width: 1023px) {
  .aboutSplit {
    grid-template-columns: 1fr;
    gap: 1.75rem;
  }

  .aboutFigure {
    max-width: min(420px, 100%);
    margin-inline: auto;
  }

  .portfolioGrid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .footerGrid {
    grid-template-columns: 1fr 1fr;
  }

  .contactLayout {
    grid-template-columns: 1fr;
  }

  .ctaLayout {
    flex-direction: column;
    align-items: stretch;
  }
}

@media (max-width: 767px) {
  .portfolioGrid {
    grid-template-columns: 1fr;
  }

  .footerGrid {
    grid-template-columns: 1fr;
  }

  .formRow {
    grid-template-columns: 1fr;
  }

  .heroShell {
    padding-top: 5.5rem;
    padding-bottom: 2.5rem;
    padding-left: max(1.15rem, env(safe-area-inset-left, 0px));
    padding-right: max(1.15rem, env(safe-area-inset-right, 0px));
  }

  .heroBranding {
    padding: 1rem max(0.75rem, env(safe-area-inset-left, 0px)) 1rem
      max(0.75rem, env(safe-area-inset-right, 0px));
    width: 100%;
    max-width: 100%;
    margin-inline: auto;
    box-sizing: border-box;
    text-align: center;
  }

  .heroBranding h1 {
    text-align: center;
    text-wrap: balance;
    max-width: 100%;
    margin-inline: auto;
    font-size: clamp(1.85rem, 1.1rem + 5.5vw, 4rem);
    line-height: 1.14;
    overflow-wrap: break-word;
    word-wrap: break-word;
  }

  .heroText {
    max-width: 100%;
    margin-inline: auto;
    text-align: center;
  }

  .heroLogoLarge {
    width: min(132px, 38vw);
  }

  .navbar {
    padding: 0.85rem 1.15rem;
    backdrop-filter: none;
  }

  .navbar .logo {
    width: min(78px, 26vw);
  }

  .navBurger {
    display: inline-flex;
  }

  .navDrawerBackdrop {
    display: block;
    position: fixed;
    inset: 0;
    z-index: 51;
    background: rgba(0, 0, 0, 0.55);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.25s ease, visibility 0.25s ease;
  }

  .navbar.nav-open .navDrawerBackdrop {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  .navDrawer {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    z-index: 52;
    width: min(300px, 88vw);
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    padding: env(safe-area-inset-top, 0) 0 env(safe-area-inset-bottom, 0);
    background: var(--sectionBg);
    border-left: 1px solid var(--panelBorder);
    box-shadow: -8px 0 32px rgba(0, 0, 0, 0.4);
    transform: translateX(100%);
    visibility: hidden;
    transition: transform 0.28s ease, visibility 0.28s ease;
  }

  .navbar.nav-open .navDrawer {
    transform: translateX(0);
    visibility: visible;
  }

  .navDrawerTop {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.85rem 1.15rem;
    border-bottom: 1px solid var(--panelBorder);
    flex-shrink: 0;
  }

  .navDrawerClose {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    margin: 0;
    padding: 0;
    border: 1px solid var(--panelBorder);
    border-radius: 10px;
    background: rgba(0, 0, 0, 0.25);
    color: var(--white);
    font-size: 1.5rem;
    line-height: 1;
    cursor: pointer;
    transition: background-color 0.2s ease, border-color 0.2s ease;
  }

  .navDrawerClose:hover,
  .navDrawerClose:focus-visible {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.25);
  }

  .navDrawer .navLinks {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    width: 100%;
    flex: 1;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  .navDrawer .navItem a {
    display: block;
    padding: 1.05rem 1.25rem;
    border-bottom: 1px solid var(--panelBorder);
  }

  .navDrawer .navLinks a::after {
    display: none;
  }

  .navDrawer .navLinks a:hover,
  .navDrawer .navLinks a:focus-visible {
    background: rgba(255, 255, 255, 0.06);
  }

  .navbar.nav-open .navBurgerLine:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
  }

  .navbar.nav-open .navBurgerLine:nth-child(2) {
    opacity: 0;
  }

  .navbar.nav-open .navBurgerLine:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
  }
}

@media (max-width: 767px) and (prefers-reduced-motion: reduce) {
  .navDrawer,
  .navDrawerBackdrop,
  .navBurgerLine {
    transition: none;
  }
}

/* Callout devis (services) : éviter le trou vertical (flex-grow + space-between en colonne) */
@media (max-width: 640px) {
  .pricingDevisCallout {
    justify-content: flex-start;
  }

  .pricingDevisCalloutText {
    flex: 0 1 auto;
  }
}
