/* mobile-phase12.css — фазы 1–2 мобильной адаптации kzm.info (2026-06) */
/* ЛК / cabinet + публичные разделы, 320–480px, embed + mobile web */

:root {
  --page-gutter: 14px;
  --m12-touch: 44px;
  --m12-gap: 10px;
  --m12-radius: 14px;
  --m12-page-pad: var(--page-gutter);
}

/* =========================================================
   Единый gutter портала (мобильная версия)
   Один отступ от края экрана — публичные страницы и ЛК
   ========================================================= */

@media (max-width: 768px) {
  :root {
    --gutter: var(--page-gutter);
  }

  .container,
  .app-main.container,
  main.app-main.container,
  .app-main > .container,
  .user-ui.profile-page.profile-cabinet-page .container,
  .user-ui.profile-page > .container {
    padding-left: calc(var(--page-gutter) + env(safe-area-inset-left, 0px));
    padding-right: calc(var(--page-gutter) + env(safe-area-inset-right, 0px));
    box-sizing: border-box;
  }

  /* Внутренние обёртки ЛК — без второго горизонтального padding */
  .user-ui.profile-page.profile-cabinet-page .profile-main > .users-page,
  .users-page.users-balance-history,
  .users-page.users-balance-index,
  .users-page.users-balance-deposit,
  .users-vpn-index.users-page,
  .users-vpn-history.users-page,
  .users-vpn-instruction.users-page,
  .user-ui.finance-page,
  .users-balance-history,
  .users-balance-index,
  .users-balance-deposit {
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: 0;
    margin-right: 0;
    max-width: 100%;
  }

  .users-page {
    padding-left: 0;
    padding-right: 0;
    max-width: 100%;
  }

  .site-header .top-bar {
    padding-left: calc(var(--page-gutter) + env(safe-area-inset-left, 0px));
    padding-right: calc(var(--page-gutter) + env(safe-area-inset-right, 0px));
  }

  .search-bar {
    padding-left: calc(var(--page-gutter) + env(safe-area-inset-left, 0px));
    padding-right: calc(var(--page-gutter) + env(safe-area-inset-right, 0px));
  }

  .ui-page,
  .page-wrap,
  .content {
    padding-left: 0;
    padding-right: 0;
  }
}

.user-ui.profile-page.profile-cabinet-page .profile-main,
.user-ui.profile-page .profile-main {
  min-width: 0;
}

.user-ui.profile-page.profile-cabinet-page .container,
.user-ui.profile-page > .container {
  max-width: min(720px, 100%);
}

/* Компактный топбар — одна строка */
.user-ui.profile-page .profile-topbar--compact {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  min-width: 0;
}

.user-ui.profile-page .profile-topbar__back {
  flex: 0 0 auto;
  min-height: var(--m12-touch);
  padding: 0 12px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.user-ui.profile-page .profile-topbar__title {
  flex: 1 1 auto;
  min-width: 0;
  margin: 0;
  font-size: 1.05rem;
  font-weight: 800;
  line-height: 1.25;
  color: var(--ui-text, #0f172a);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.user-ui.profile-page .profile-topbar__trail,
.user-ui.profile-page .profile-topbar__left:not(.profile-topbar__back) {
  display: none;
}

/* Навигация ЛК — горизонтальный скролл */
.user-ui.profile-page .profile-cabinet-nav {
  scrollbar-width: none;
  scroll-snap-type: x proximity;
  padding-bottom: 10px;
  margin-bottom: 8px;
}

.user-ui.profile-page .profile-cabinet-nav::-webkit-scrollbar {
  display: none;
}

.user-ui.profile-page .profile-cabinet-nav__item {
  min-height: 38px;
  scroll-snap-align: start;
}

/* Кнопки действий — колонка на узких экранах */
@media (max-width: 520px) {
  .user-ui.profile-page .profile-topbar.profile-topbar--compact {
    display: flex;
    flex-direction: row;
    align-items: center;
    grid-template-columns: unset;
  }

  .user-ui .users-page-actions,
  .user-ui.profile-page .users-head-actions,
  .users-page .users-page-actions,
  .users-page .users-head-actions {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
    width: 100%;
  }

  .user-ui .users-page-actions .users-btn,
  .user-ui .users-page-actions .ui-btn,
  .user-ui.profile-page .users-head-actions .users-btn,
  .users-page .users-page-actions .users-btn,
  .users-page .users-head-actions .users-btn {
    width: 100%;
    min-height: var(--m12-touch);
    justify-content: center;
  }

  .user-ui.profile-page {
    padding-bottom: calc(var(--bottom-nav-h, 60px) + 20px + env(safe-area-inset-bottom));
  }

  .user-ui .ui-card,
  .user-ui .u-card,
  .users-page .users-card,
  .users-deposit-card {
    border-radius: var(--m12-radius);
    padding: 12px;
  }

  .user-ui.profile-page .profile-cabinet-nav__item {
    padding: 10px 14px;
    font-size: 14px;
  }
}

/* Таблицы ЛК → карточки (общее правило; история баланса — отдельные карточки) */
@media (max-width: 640px) {
  .users-page:not(.users-balance-history) .users-table-wrap {
    overflow-x: visible;
  }

  .users-page:not(.users-balance-history) .users-table {
    min-width: 0;
  }

  .users-page:not(.users-balance-history) .users-table thead {
    display: none;
  }

  .users-page:not(.users-balance-history) .users-table,
  .users-page:not(.users-balance-history) .users-table tbody,
  .users-page:not(.users-balance-history) .users-table tr,
  .users-page:not(.users-balance-history) .users-table td {
    display: block;
    width: 100%;
  }

  .users-page:not(.users-balance-history) .users-table tr {
    margin-bottom: 10px;
    padding: 10px 12px;
    border: 1px solid var(--ub-border, rgba(148, 163, 184, 0.28));
    border-radius: var(--m12-radius);
    background: rgba(255, 255, 255, 0.92);
  }

  .users-page:not(.users-balance-history) .users-table td {
    padding: 5px 0;
    border: 0;
    display: flex;
    justify-content: space-between;
    gap: 10px;
    text-align: left;
  }

  .users-page:not(.users-balance-history) .users-table td[data-label]::before {
    content: attr(data-label);
    flex: 0 0 auto;
    min-width: 88px;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--ub-muted, #64748b);
    font-weight: 800;
  }
}

/* Баланс — главная */
@media (max-width: 520px) {
  .users-balance-index .users-balance-hero,
  .users-balance-index .users-balance-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .users-balance-index .users-balance-stat {
    padding: 12px;
  }

  .users-balance-index .users-withdraw-form .users-field-row {
    flex-direction: column;
    align-items: stretch;
  }
}

/* VPN */
@media (max-width: 640px) {
  .users-vpn-index .vpn-index-head,
  .users-vpn-index .vpn-plans-grid,
  .users-vpn-index .vpn-status-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .users-vpn-index .vpn-plan-card,
  .users-vpn-index .vpn-status-card {
    padding: 12px;
    border-radius: var(--m12-radius);
  }

  .users-vpn-index .users-title {
    font-size: 1.25rem;
  }

  .users-vpn-instruction .vpn-steps {
    grid-template-columns: 1fr;
  }
}

/* Уведомления */
@media (max-width: 520px) {
  .user-ui.profile-page .profile-section .item-row,
  .user-notifications-page .notification-item {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }

  .user-ui.profile-page .profile-section .item-actions,
  .user-notifications-page .notification-actions {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }
}

/* Store orders в ЛК */
@media (max-width: 640px) {
  .users-store-orders .order-card,
  .users-store-orders-index .users-order-row {
    flex-direction: column;
    align-items: stretch;
  }

  .users-store-orders .order-card__actions {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
  }
}

/* Профиль — сетка статистики */
@media (max-width: 520px) {
  .user-ui.profile-page .profile-stats,
  .user-ui.profile-page .profile-shortcuts {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .user-ui.profile-page .profile-stats__item,
  .user-ui.profile-page .profile-shortcut {
    min-height: var(--m12-touch);
    padding: 10px 8px;
  }
}

@media (max-width: 360px) {
  .user-ui.profile-page .profile-stats,
  .user-ui.profile-page .profile-shortcuts {
    grid-template-columns: 1fr;
  }
}

/* Embed — дополнительно к responsive.css */
.is-embed .user-ui.profile-page .profile-topbar__back-label {
  display: none;
}

.is-embed .user-ui.profile-page .profile-topbar__back {
  min-width: var(--m12-touch);
  justify-content: center;
  padding: 0;
}

/* =========================================================
   PHASE 2 — Публичные разделы
   ========================================================= */

@media (max-width: 768px) {
  .app-main.container,
  main.app-main,
  .app-main > .container {
    padding-bottom: calc(var(--bottom-nav-h, 64px) + 12px + env(safe-area-inset-bottom));
    min-width: 0;
  }

  .site-header .top-bar {
    padding-top: 8px;
    padding-bottom: 8px;
    gap: 8px;
    min-width: 0;
  }

  .site-header .header-left,
  .site-header .header-right {
    min-width: 0;
    flex-shrink: 1;
  }

  .site-header .logo-img {
    max-height: 34px;
    width: auto;
  }

  .site-header .header-icon-btn,
  .site-header .burger,
  .site-header .open-chat-btn {
    min-width: var(--m12-touch);
    min-height: var(--m12-touch);
  }

  .site-header .weather-widget {
    font-size: 0.85rem;
  }

  .search-form {
    flex-wrap: wrap;
    gap: 8px;
  }

  .search-form .search-input,
  .search-form .search-select {
    min-width: 0;
    flex: 1 1 120px;
    font-size: 16px;
  }

  .search-form .search-btn {
    min-height: var(--m12-touch);
    flex: 1 1 auto;
  }
}

@media (max-width: 520px) {
  .page-title,
  .ui-page-title,
  .section-title {
    font-size: 1.25rem;
    line-height: 1.25;
    margin-bottom: 10px;
  }
}

/* Главная */
@media (max-width: 768px) {
  .home-portal .home-layout,
  .home-portal .home-grid {
    grid-template-columns: 1fr !important;
    gap: 12px;
  }

  .home-portal .home-sidebar {
    order: 2;
  }

  .home-portal .home-main {
    order: 1;
  }

  .home-portal .home-block {
    border-radius: var(--m12-radius);
    padding: 12px;
  }

  .home-portal .home-block-pinned_news .pinned-layout {
    flex-direction: column;
  }

  .home-portal .home-block-pinned_news .pinned-thumb {
    width: 100%;
    max-height: 200px;
  }

  .home-portal .home-block-pinned_news .pinned-thumb img {
    width: 100%;
    height: auto;
    max-height: 200px;
    object-fit: cover;
  }
}

/* Новости */
@media (max-width: 640px) {
  .news-page .news-list,
  .news-page .news-grid {
    grid-template-columns: 1fr !important;
    gap: 10px;
  }

  .news-page .news-card,
  .news-page .news-item {
    border-radius: var(--m12-radius);
    overflow: hidden;
  }

  .news-page .news-card__body,
  .news-page .news-item__body {
    padding: 12px;
  }

  .news-single .news-hero img,
  .news-page .article-cover img {
    max-height: 220px;
    object-fit: cover;
    width: 100%;
  }
}

/* Афиша */
@media (max-width: 640px) {
  .events-page .events-grid,
  .events-page .events-list {
    grid-template-columns: 1fr !important;
    gap: 10px;
  }

  .events-page .event-card,
  .events-page .events-item {
    border-radius: var(--m12-radius);
  }

  .event-single .event-poster img {
    width: 100%;
    max-height: 280px;
    object-fit: cover;
  }

  .events-page .events-filters,
  .events-page .events-toolbar {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    gap: 8px;
    padding-bottom: 4px;
  }

  .events-page .events-filters::-webkit-scrollbar {
    display: none;
  }
}

/* Объявления */
@media (max-width: 720px) {
  .board-page .board-grid,
  .board-page .ads-grid,
  .board-ui .board-list {
    grid-template-columns: 1fr !important;
    gap: 10px;
  }

  .board-page .board-card,
  .board-ui .ad-card {
    border-radius: var(--m12-radius);
  }

  .board-page .board-filters,
  .board-ui .board-toolbar,
  .board-ui .filters-row {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    gap: 8px;
    padding-bottom: 4px;
  }

  .board-page .board-filters::-webkit-scrollbar,
  .board-ui .board-toolbar::-webkit-scrollbar {
    display: none;
  }

  .board-ui .board-floating-actions {
    bottom: calc(var(--bottom-nav-h, 64px) + 12px + env(safe-area-inset-bottom));
  }
}

/* Организации */
@media (max-width: 768px) {
  .org-ui.orgs-list .orgs-headline {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }

  .org-ui.orgs-list .orgs-headline__right {
    width: 100%;
  }

  .org-ui.orgs-list .orgs-promo-grid {
    grid-template-columns: 1fr;
  }

  .org-ui.orgs-list .orgs-quickchips {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding-bottom: 4px;
  }

  .org-ui.orgs-list .orgs-quickchips::-webkit-scrollbar {
    display: none;
  }

  .org-ui.orgs-list .org-card,
  .org-ui.orgs-categories .org-cat-card {
    border-radius: var(--m12-radius);
  }

  .org-ui.org-single .org-hero,
  .org-ui.org-single .org-gallery {
    border-radius: var(--m12-radius);
    overflow: hidden;
  }
}

/* Транспорт / контакты / идеи / проблемы */
@media (max-width: 640px) {
  .mobility-page .route-list,
  .contacts-page .contacts-grid,
  .ideas-page .ideas-grid,
  .problems-page .problems-grid {
    grid-template-columns: 1fr !important;
    gap: 10px;
  }

  .mobility-page .route-card,
  .contacts-page .contact-card,
  .ideas-page .idea-card,
  .problems-page .problem-card {
    border-radius: var(--m12-radius);
    padding: 12px;
  }
}

/* Достопримечательности */
@media (max-width: 640px) {
  .attractions-page .attractions-grid {
    grid-template-columns: 1fr !important;
    gap: 10px;
  }
}

/* Общие карточки ui-kit */
@media (max-width: 520px) {
  .ui-card,
  .card,
  .u-card {
    border-radius: var(--m12-radius);
  }

  .ui-btn,
  .btn,
  .users-btn {
    min-height: var(--m12-touch);
  }

  .pagination,
  .ui-pagination {
    flex-wrap: wrap;
    gap: 6px;
    justify-content: center;
  }

  .modal-content,
  .ui-modal__dialog {
    width: min(100vw - 16px, 480px);
    max-height: calc(100dvh - 24px);
    margin: 12px auto;
    border-radius: var(--m12-radius);
  }
}

/* Очень узкие экраны */
@media (max-width: 360px) {
  :root {
    --page-gutter: 12px;
  }

  .site-header .logo-img {
    max-height: 30px;
  }

  .user-ui.profile-page .profile-topbar__title {
    font-size: 0.98rem;
  }
}
