/**
 * Mobile / tablette — site vitrine, panel client & owner, modales
 */

/* —— Panel owner — perf interactions —— */
.panel-body--owner .btn,
.panel-body--owner .btn-primary,
.panel-body--owner .owner-btn,
.panel-body--owner .panel-nav__link,
.panel-body--owner .admin-clients-row {
  touch-action: manipulation;
}

.panel-body--owner .card,
.panel-body--owner .stat-card,
.panel-body--owner .admin-clients-table-wrap,
.panel-body--owner .owner-client-project-card,
.panel-body--owner .owner-chat-thread {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

/* —— Panel mobile : perf (blur GPU) + fond uni —— */
@media (max-width: 900px) {
  .panel-body--client .card,
  .panel-body--client .stat-card,
  .panel-body--client .project-card,
  .panel-body--client .chat-list-item,
  .panel-body--client .type-option,
  .panel-body--client .settings-panel,
  .panel-body--client .chat-main,
  .panel-body--client .chat-aside {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  .panel-body .panel-background-layers .panel-particles {
    display: none !important;
  }
}

/* —— Panel : sidebar drawer (client + owner) —— */
@media (max-width: 900px) {
  .panel-body {
    padding-left: env(safe-area-inset-left, 0px);
    padding-right: env(safe-area-inset-right, 0px);
  }

  .panel-body--client .panel-layout,
  .panel-body--owner .panel-layout {
    flex-direction: row;
    min-height: 100dvh;
  }

  .panel-body--client .panel-sidebar,
  .panel-body--owner .panel-sidebar {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 55;
    width: min(300px, 88vw);
    height: 100dvh;
    height: 100vh;
    max-height: 100dvh;
    flex-shrink: 0;
    border-right: 1px solid var(--border);
    border-bottom: none;
    transform: translateX(-105%);
    transition: transform 0.3s ease;
    box-shadow: 8px 0 32px rgba(0, 0, 0, 0.45);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding-top: env(safe-area-inset-top, 0px);
    padding-bottom: env(safe-area-inset-bottom, 0px);
  }

  .panel-body--client .panel-sidebar.is-open,
  .panel-body--owner .panel-sidebar.is-open {
    transform: translateX(0);
  }

  .panel-body--client .panel-mobile-toggle,
  .panel-body--owner .panel-mobile-toggle {
    display: flex;
    z-index: 45;
    top: max(12px, env(safe-area-inset-top, 0px));
    left: max(12px, env(safe-area-inset-left, 0px));
    transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s ease;
  }

  body.panel-menu-open .panel-mobile-toggle {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: scale(0.92);
  }

  .panel-body--client .panel-sidebar-backdrop,
  .panel-body--owner .panel-sidebar-backdrop {
    display: none;
  }

  .panel-body--client .panel-sidebar-backdrop:not([hidden]),
  .panel-body--owner .panel-sidebar-backdrop:not([hidden]) {
    display: block;
  }

  .panel-body--client .panel-main,
  .panel-body--owner .panel-main {
    width: 100%;
    min-width: 0;
    padding: 56px 14px 20px;
    padding-top: max(56px, calc(12px + env(safe-area-inset-top, 0px) + 44px));
    padding-left: max(14px, env(safe-area-inset-left, 0px));
    padding-right: max(14px, env(safe-area-inset-right, 0px));
    padding-bottom: max(20px, env(safe-area-inset-bottom, 0px));
    box-sizing: border-box;
  }

  body.panel-menu-open {
    overflow: hidden;
  }

  /* Contenu : laisser la place au bouton menu (masqué quand la sidebar est ouverte) */
  body:not(.panel-menu-open) .panel-welcome,
  body:not(.panel-menu-open) .panel-header,
  body:not(.panel-menu-open) .panel-main > .admin-clients-header,
  body:not(.panel-menu-open) .panel-main > .owner-page-header {
    padding-left: 52px;
    box-sizing: border-box;
  }

  /* —— Settings mobile —— */
  .panel-body.panel-page-settings .panel-layout {
    min-height: 100dvh;
    max-height: none;
    overflow: visible;
  }

  .panel-page-settings .panel-main {
    overflow-x: hidden;
    overflow-y: auto;
    display: block;
    min-height: 0;
  }

  .panel-page-settings .settings-page {
    max-width: none;
    gap: 20px;
    padding-bottom: 28px;
  }

  .panel-page-settings .settings-page__prefs-grid {
    grid-template-columns: 1fr !important;
    gap: 14px;
  }

  .panel-page-settings .settings-panel {
    padding: 16px !important;
    min-height: 0;
    overflow: visible;
  }

  .panel-page-settings .settings-panel--account {
    padding: 16px !important;
  }

  .panel-page-settings .settings-panel__account-top {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  .panel-page-settings .settings-panel__account-meta {
    min-height: 0;
    width: 100%;
    align-items: stretch;
  }

  .panel-page-settings .settings-panel__account-meta .btn-secondary {
    width: 100%;
    justify-content: center;
  }

  .panel-page-settings .settings-account-grid,
  .panel-page-settings .settings-panel__fields {
    grid-template-columns: 1fr !important;
  }

  .panel-page-settings .settings-field--wide {
    grid-column: 1 / -1;
  }

  .panel-page-settings .settings-panel__actions {
    width: 100%;
    flex-direction: column;
    align-items: stretch;
  }

  .panel-page-settings .settings-panel .btn-primary,
  .panel-page-settings .settings-panel .btn-danger-outline,
  .panel-page-settings .settings-account-form__submit {
    width: 100%;
    align-self: stretch;
    justify-content: center;
    min-height: 44px;
  }

  .panel-page-settings .toggle-row {
    gap: 12px;
    align-items: center;
  }

  .panel-page-settings .toggle-row > span {
    flex: 1;
    min-width: 0;
    font-size: 0.9rem;
    line-height: 1.35;
  }

  .panel-page-settings .settings-panel--language {
    z-index: auto;
  }

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

  .panel-header__row .btn {
    width: 100%;
    justify-content: center;
  }

  .panel-page-overview .platform-stats,
  .panel-body .platform-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .admin-project-grid,
  .owner-client-project-grid {
    grid-template-columns: 1fr !important;
  }

  .admin-clients-header__row {
    flex-direction: column;
    align-items: stretch;
  }

  .admin-clients-header .admin-clients-search {
    min-width: 0;
    max-width: none;
    width: 100%;
  }

  .admin-clients-table-wrap,
  .panel-table-scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    margin: 0 -4px;
    padding: 0 4px;
  }

  .admin-clients-table {
    min-width: 520px;
  }

  .owner-chat-workspace {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto minmax(240px, 1fr) auto !important;
    gap: 12px !important;
  }

  .owner-chat-detail {
    grid-column: 1 / -1 !important;
    max-height: none;
  }

  .owner-chat-members {
    max-height: 160px;
    overflow-y: auto;
  }

  .panel-page-chats .panel-chats-body,
  .panel-page-chats .owner-chats-list {
    min-height: 0;
  }

  .chat-layout {
    grid-template-columns: 1fr !important;
    min-height: 0;
  }

  .chat-layout__thread {
    min-height: min(70dvh, 560px);
  }

  .chat-members {
    max-height: 140px;
    overflow-y: auto;
  }

  .chat-input-row {
    flex-wrap: wrap;
    gap: 8px;
  }

  .chat-input-row .btn,
  .chat-input-row .input {
    min-height: 44px;
  }

  .owner-detail-meta,
  .owner-detail-meta--page {
    grid-template-columns: 1fr !important;
  }

  .owner-project-layout,
  .admin-project-layout {
    flex-direction: column !important;
    height: auto !important;
    max-height: none !important;
  }

  .owner-portfolio-modal__dialog,
  .owner-modal__dialog {
    width: calc(100% - 20px) !important;
    max-height: min(92dvh, calc(100dvh - 24px)) !important;
    margin: 10px;
  }

  .owner-portfolio-form__grid {
    grid-template-columns: 1fr !important;
  }

  .owner-portfolio-card {
    grid-template-columns: 80px 1fr !important;
  }

  .owner-reviews-filters {
    flex-direction: column;
    align-items: stretch;
  }

  .filter-pills {
    flex-wrap: wrap;
    justify-content: flex-start;
  }
}

@media (max-width: 520px) {
  .panel-page-overview .platform-stats,
  .panel-body .platform-stats {
    grid-template-columns: 1fr !important;
  }

  .owner-portfolio-card {
    grid-template-columns: 1fr !important;
  }

  .owner-portfolio-card__thumb {
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 9;
  }

  .stat-card__num {
    font-size: clamp(1.5rem, 8vw, 2rem);
  }
}

/* Annule le empilement sidebar panel.css @768 pour mobile drawer */
@media (max-width: 900px) {
  .panel-sidebar {
    width: min(300px, 88vw) !important;
  }
}

/* —— Auth modal —— */
@media (max-width: 767px) {
  .auth-modal-overlay {
    padding: max(8px, env(safe-area-inset-top, 0px)) max(8px, env(safe-area-inset-right, 0px))
      max(8px, env(safe-area-inset-bottom, 0px)) max(8px, env(safe-area-inset-left, 0px));
    align-items: flex-end;
  }

  .auth-modal {
    max-height: min(94dvh, calc(100dvh - 16px));
    border-radius: 18px 18px 12px 12px;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  .auth-modal__form-side {
    padding: 18px 16px 12px;
    overflow-y: auto;
    max-height: min(94dvh, calc(100dvh - 16px));
  }

  .auth-modal__close {
    top: max(8px, env(safe-area-inset-top, 0px));
    right: max(8px, env(safe-area-inset-right, 0px));
  }

  .auth-form .input,
  .auth-form input[type="email"],
  .auth-form input[type="password"],
  .auth-form input[type="text"] {
    font-size: 16px;
  }
}

/* —— Site vitrine —— */
@media (max-width: 620px) {
  .project-modal__footer {
    flex-direction: column;
    align-items: stretch;
  }

  .project-modal__footer .btn {
    width: 100%;
    justify-content: center;
    text-align: center;
  }

  .project-modal__body {
    max-height: 42vh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  .toast-container {
    left: max(12px, env(safe-area-inset-left, 0px));
    right: max(12px, env(safe-area-inset-right, 0px));
    bottom: max(12px, env(safe-area-inset-bottom, 0px));
    max-width: none;
  }
}

/* iOS : évite le zoom auto sur focus */
@media (max-width: 900px) {
  .panel-main input,
  .panel-main select,
  .panel-main textarea,
  .auth-modal input,
  .auth-modal select,
  .auth-modal textarea {
    font-size: 16px;
  }
}

/* Onboarding */
@media (max-width: 720px) {
  .onboarding-shell {
    padding: 16px;
    padding-top: max(16px, env(safe-area-inset-top, 0px));
    padding-bottom: max(16px, env(safe-area-inset-bottom, 0px));
  }

  .onboarding-card {
    padding: 20px 16px;
  }

  .onboarding-type-grid {
    grid-template-columns: 1fr !important;
  }
}
