
/* v28: spacing, mobile navigation, and responsive user management cleanup. */

/* Global breathing room: less compressed, still professional. */
:root {
  --v28-gap-section: clamp(72px, 8vw, 128px);
  --v28-gap-card: clamp(24px, 3vw, 42px);
}

main > .section,
.section {
  margin-top: var(--v28-gap-section) !important;
}

.dashboard-card,
.user-management-card-v26,
.admin-form-card-v26 {
  margin-bottom: 30px !important;
}

.dashboard-section-title,
.admin-list-head-v25,
.admin-list-head-v26,
.stacked-title {
  margin-bottom: 24px !important;
  gap: 18px !important;
}

.eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  margin-bottom: 12px !important;
  line-height: 1.35 !important;
}

.eyebrow + h1,
.eyebrow + h2,
.eyebrow + h3 {
  margin-top: 0 !important;
}

.dashboard-section-title h3,
.admin-list-head-v25 h3,
.admin-list-head-v26 h3 {
  margin-top: 6px !important;
  margin-bottom: 12px !important;
}

/* Reduce title scale further: sober / ThrustMe-like, not billboard-like. */
.hero h1,
.hero-premium h1 {
  font-size: clamp(1.9rem, 3.05vw, 3.25rem) !important;
  line-height: 1.07 !important;
  letter-spacing: -0.035em !important;
  max-width: 15ch !important;
}

.page-hero h1 {
  font-size: clamp(1.75rem, 2.55vw, 2.75rem) !important;
  line-height: 1.09 !important;
  max-width: 18ch !important;
}

.auth-card h1,
.auth-context-card h2 {
  font-size: clamp(1.55rem, 2.25vw, 2.35rem) !important;
  line-height: 1.12 !important;
}

.section h2,
.product-card h3 {
  font-size: clamp(1.35rem, 1.85vw, 2.05rem) !important;
  line-height: 1.16 !important;
}

.dashboard-topbar h1 {
  font-size: clamp(1.35rem, 1.45vw, 1.85rem) !important;
}

.hero-lead,
.page-hero p {
  font-size: clamp(.94rem, .25vw + .88rem, 1.02rem) !important;
  line-height: 1.75 !important;
}

/* Team / partners: real separation with whitespace and an elegant rule. */
.ecosystem,
.ecosystem-v18 {
  margin-top: clamp(72px, 8vw, 112px) !important;
  padding-top: clamp(56px, 7vw, 82px) !important;
  border-top: 1px solid rgba(148,163,184,.26) !important;
}

.ecosystem::before,
.ecosystem-v18::before {
  top: -1px !important;
  width: min(420px, 56vw) !important;
}

/* Public mobile menu: opens below the header, not off-screen at the bottom. */
@media (max-width: 1120px) {
  .site-nav-v24 {
    position: fixed !important;
    left: 12px !important;
    right: 12px !important;
    top: 76px !important;
    bottom: auto !important;
    width: auto !important;
    max-height: calc(100dvh - 96px) !important;
    overflow-y: auto !important;
    transform: translateY(-10px) scale(.985) !important;
    border-radius: 18px !important;
    padding: 12px !important;
    z-index: 1200 !important;
  }

  .site-nav-v24.is-open {
    transform: translateY(0) scale(1) !important;
  }

  .site-nav-v24 > a,
  .site-nav-v24 .nav-cta {
    min-height: 44px !important;
    border-radius: 12px !important;
    padding: 11px 13px !important;
    font-size: .92rem !important;
  }
}

.mobile-nav-controls-v28 {
  display: none;
}

@media (max-width: 760px) {
  .header-tools-v24 > .language-switcher-v23,
  .header-tools-v24 > .theme-switch-v24 {
    display: none !important;
  }

  .mobile-nav-controls-v28 {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 10px !important;
    padding: 6px 4px 4px !important;
  }

  .mobile-nav-controls-v28 .language-switcher-v23,
  .mobile-nav-controls-v28 .theme-switch-v24 {
    display: inline-grid !important;
  }

  .site-header-v24 {
    width: calc(100% - 20px) !important;
  }
}

/* Dashboard / user management: use a burger off-canvas menu on narrow layouts, not horizontal tabs. */
.dashboard-menu-button-v28 {
  display: none;
  width: 36px;
  height: 36px;
  min-width: 36px;
  border-radius: 10px;
  border: 1px solid rgba(148,163,184,.22);
  background: rgba(255,255,255,.07);
  color: inherit;
  place-items: center;
  padding: 0;
}

.dashboard-menu-button-v28 .hamburger {
  width: 17px;
  display: grid;
  gap: 4px;
}

.dashboard-menu-button-v28 .hamburger span {
  height: 2px;
  border-radius: 999px;
  background: currentColor;
}

html[data-theme="light"] .dashboard-menu-button-v28 {
  background: #fff;
  border-color: rgba(15,23,42,.12);
}

@media (max-width: 980px) {
  .dashboard-page {
    display: block !important;
  }

  .dashboard-menu-button-v28 {
    display: grid !important;
  }

  .dashboard-page .sidebar {
    position: fixed !important;
    z-index: 1500 !important;
    left: 12px !important;
    top: 12px !important;
    bottom: 12px !important;
    width: min(310px, calc(100vw - 24px)) !important;
    min-height: 0 !important;
    transform: translateX(calc(-100% - 24px)) !important;
    transition: transform .24s ease !important;
    border: 1px solid rgba(148,163,184,.20) !important;
    border-radius: 18px !important;
    box-shadow: 0 30px 90px rgba(0,0,0,.38) !important;
    overflow-y: auto !important;
  }

  .dashboard-page .sidebar.is-open {
    transform: translateX(0) !important;
  }

  .dashboard-page.dashboard-menu-open::before {
    content: "" !important;
    position: fixed !important;
    inset: 0 !important;
    z-index: 1490 !important;
    background: rgba(2,6,14,.46) !important;
    backdrop-filter: blur(6px) !important;
  }

  .dashboard-page .sidebar-nav {
    display: grid !important;
    gap: 10px !important;
    overflow: visible !important;
    padding: 0 !important;
  }

  .dashboard-page .sidebar-nav a,
  .dashboard-page .logout-form button {
    width: 100% !important;
    white-space: normal !important;
    min-height: 44px !important;
    border-radius: 12px !important;
  }

  .dashboard-main {
    padding: 18px !important;
  }
}

/* User tables: at reduced width, values use the full card width. No two-column squeeze. */
@media (max-width: 1020px) {
  .users-table-wrap-v25,
  .users-table-wrap-v26 {
    overflow: visible !important;
  }

  .users-table-v25,
  .users-table-v25 tbody,
  .users-table-v25 tr,
  .users-table-v25 td,
  .users-table-v26,
  .users-table-v26 tbody,
  .users-table-v26 tr,
  .users-table-v26 td {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  .users-table-v25 thead,
  .users-table-v26 thead {
    display: none !important;
  }

  .users-table-v25 tr,
  .users-table-v26 tr {
    margin: 0 0 18px !important;
    padding: 18px !important;
    border-radius: 14px !important;
    border: 1px solid rgba(148,163,184,.18) !important;
    background: #fff !important;
  }

  html[data-theme="dark"] .users-table-v25 tr,
  html[data-theme="dark"] .users-table-v26 tr {
    background: #081325 !important;
    border-color: rgba(170,205,255,.14) !important;
  }

  .users-table-v25 td,
  .users-table-v26 td {
    display: block !important;
    padding: 12px 0 !important;
    border: 0 !important;
    min-height: 0 !important;
    overflow: visible !important;
  }

  .users-table-v25 td + td,
  .users-table-v26 td + td {
    border-top: 1px solid rgba(148,163,184,.12) !important;
  }

  .users-table-v25 td::before,
  .users-table-v26 td::before {
    content: attr(data-label) !important;
    display: block !important;
    width: auto !important;
    margin: 0 0 7px !important;
    padding: 0 !important;
    background: transparent !important;
    color: #125fe8 !important;
    font-size: .68rem !important;
    line-height: 1.25 !important;
    letter-spacing: .10em !important;
    text-transform: uppercase !important;
    font-weight: 900 !important;
  }

  html[data-theme="dark"] .users-table-v25 td::before,
  html[data-theme="dark"] .users-table-v26 td::before {
    color: #67ddff !important;
  }

  .users-table-v25 td[data-label="Dernière connexion"],
  .users-table-v26 td[data-label="Dernière connexion"] {
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: anywhere !important;
    font-size: .9rem !important;
  }

  .user-cell-v25,
  .user-cell-v26 {
    width: 100% !important;
  }

  .row-actions-v25,
  .row-actions-v26 {
    display: flex !important;
    gap: 10px !important;
    flex-wrap: wrap !important;
  }

  .row-actions-v25 .button,
  .row-actions-v25 button,
  .row-actions-v26 .button,
  .row-actions-v26 button {
    width: auto !important;
    flex: 0 0 auto !important;
  }
}

@media (max-width: 560px) {
  .dashboard-main {
    padding: 14px !important;
  }

  .user-management-card-v25,
  .user-management-card-v26,
  .admin-form-card-v25,
  .admin-form-card-v26 {
    padding: 18px !important;
  }

  .users-table-v25 tr,
  .users-table-v26 tr {
    padding: 16px !important;
  }
}
