/* RESPONSIVE */
@media (max-width: 1024px) {
  .hero-grid,
  .grid-panels,
  .news-grid,
  .dashboard-cards {
    grid-template-columns: 1fr;
  }

  .section-heading {
    align-items: flex-start;
    flex-direction: column;
  }

  .section-heading p {
    text-align: left;
  }
}

@media (max-width: 980px) {
  .forum-layout,
  .messages-layout,
  .profile-layout {
    grid-template-columns: 1fr;
  }

  .profile-shell--wide {
    padding: 24px 18px;
  }
}

@media (max-width: 820px) {
  .header-inner {
    flex-wrap: wrap;
  }

  .user-chip {
    max-width: 100%;
  }

  .profile-summary {
    grid-template-columns: 1fr;
  }

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

  .admin-topbar__nav {
    width: 100%;
  }

  .admin-topbar__nav a {
    flex: 1 1 auto;
  }

  .admin-quicknav {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 920px) {
  .contact-grid,
  .message-detail-grid {
    grid-template-columns: 1fr;
  }

  .admin-message-row {
    grid-template-columns: 1fr;
  }

  .admin-message-row__meta {
    justify-items: start;
    min-width: 0;
  }

  .admin-message-row__date {
    text-align: left;
  }
}

@media (max-width: 780px) {
  .site-footer {
    margin-top: 40px;
    padding-bottom: 22px;
  }

  .site-footer__inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }

  .site-footer__links {
    width: 100%;
    justify-content: flex-start;
  }
}

@media (max-width: 768px) {
  h1 {
    font-size: clamp(26px, 7vw, 34px);
  }

  h2 {
    font-size: clamp(20px, 5vw, 26px);
  }

  p {
    font-size: 14px;
  }

  .glass,
  .panel,
  .card {
    border-radius: 18px;
  }

  .primary-btn,
  .secondary-btn {
    width: 100%;
    min-height: 46px;
  }

  input,
  textarea,
  select {
    font-size: 16px; /* iOS zoom fix */
  }
}

@media (max-width: 640px) {
  .container {
    padding: 0 16px;
  }

  .landing-page {
    padding: 18px 0 60px;
  }

  .header-inner {
    padding: 12px 16px;
    min-height: auto;
  }

  .brand img {
    height: 52px;
  }

  .menu-toggle {
    width: 46px;
    height: 46px;
  }

  .nav a,
  .nav .nav-item,
  .nav .nav-link-btn,
  .nav .nav-logout-btn {
    padding: 9px 12px;
    min-height: 42px;
  }

  .hero-shell {
    padding: 26px 20px;
    border-radius: 24px;
  }

  .hero-card {
    padding: 30px 20px;
  }

  .hero-copy h1 {
    line-height: 1.04;
  }

  .hero-copy p {
    font-size: 16px;
  }

  .hero-actions {
    flex-direction: column;
  }

  .hero-actions a,
  .hero-actions button {
    width: 100%;
  }

  .panel,
  .news-section,
  .dashboard-card {
    padding: 22px 18px;
    border-radius: 22px;
  }

  .news-card {
    padding: 20px;
    border-radius: 20px;
  }

  .auth-shell,
  .profile-shell {
    margin: 20px auto;
    padding: 22px 18px;
    border-radius: 24px;
  }

  .profile-panel {
    padding: 20px 18px;
    border-radius: 20px;
  }

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

  .auth-actions {
    flex-direction: column;
  }

  .auth-actions .primary-btn,
  .auth-actions .secondary-btn,
  .auth-actions button {
    width: 100%;
  }

  .nav-wrap {
    gap: 14px;
  }

  .user-chip {
    width: 100%;
    justify-content: space-between;
  }

  .user-chip-label {
    max-width: none;
  }

  .page-shell,
  .page-shell--narrow {
    width: min(100% - 24px, 1200px);
  }

  .admin-message-row {
    padding: 18px;
  }

  .admin-message-row__top {
    flex-direction: column;
    align-items: flex-start;
  }

  .message-detail-card {
    padding: 18px;
  }

  .profile-delete-block {
    max-width: 100%;
  }
}