/**
 * КодГор — слой адаптивности и производительности.
 * Не убирает контент, не меняет логику и анимации.
 */

/* ——— База: вёрстка и переполнение ——— */
html {
  scroll-padding-top: max(76px, calc(env(safe-area-inset-top) + 56px));
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body {
  overflow-x: clip;
  text-rendering: optimizeLegibility;
}

.page,
.admin-page {
  overflow-x: clip;
  max-width: 100%;
}

img,
video,
svg {
  max-width: 100%;
  height: auto;
}

img {
  height: auto;
}

video {
  object-fit: contain;
}

/* ——— Формы на iOS: без зума при фокусе ——— */
@media (max-width: 768px) {
  input:not([type='checkbox']):not([type='radio']),
  select,
  textarea {
    font-size: max(16px, 1rem);
  }
}

/* ——— Плавный скролл (уважение reduced-motion в event-premium) ——— */
@media (prefers-reduced-motion: no-preference) {
  html {
    scroll-behavior: smooth;
  }
}

/* ——— Крупные экраны: читаемость ——— */
@media (min-width: 1280px) {
  :root {
    --container-width: 1180px;
  }

  .section__subtitle,
  .hero__subtitle {
    max-width: 42rem;
  }
}

/* ——— Шапка и навигация ——— */
@media (max-width: 900px) {
  .logo__tagline {
    display: none;
  }
}

@media (max-width: 768px) {
  .header__inner {
    padding-top: max(10px, env(safe-area-inset-top));
    gap: 10px;
  }

  .logo__img {
    height: clamp(34px, 9vw, 42px);
  }

  .logo__text--header {
    font-size: clamp(1rem, 4.2vw, 1.15rem);
  }

  .nav {
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
  }
}

/* ——— Типографика: fluid без ломки десктопа ——— */
@media (max-width: 768px) {
  .hero__title {
    font-size: clamp(1.35rem, 5.5vw, 1.65rem);
    overflow-wrap: anywhere;
  }

  .section__title {
    font-size: clamp(1.2rem, 4.5vw, 1.5rem);
  }

  .section__subtitle,
  .hero__subtitle {
    font-size: clamp(0.875rem, 3.5vw, 0.95rem);
  }
}

/* ——— Кнопки и чипы: удобнее на тач ——— */
@media (max-width: 768px) {
  .btn {
    max-width: 100%;
    white-space: normal;
    text-align: center;
    line-height: 1.25;
  }

  .chip {
    min-height: 40px;
    display: inline-flex;
    align-items: center;
  }
}

/* ——— Расписание ——— */
@media (max-width: 600px) {
  .schedule--daygrid {
    grid-template-columns: 1fr;
  }

  .filters__chips {
    flex-wrap: wrap;
    max-width: 100%;
  }
}

/* ——— Юридические страницы ——— */
@media (max-width: 768px) {
  .legal-main {
    padding: 88px max(16px, env(safe-area-inset-left)) 40px max(16px, env(safe-area-inset-right));
  }

  .legal-card {
    padding: 20px 16px;
  }

  .legal-card__title {
    font-size: clamp(1.25rem, 5vw, 1.5rem);
  }
}

/* ——— Билеты / мероприятие ——— */
.event-page {
  overflow-x: clip;
}

@media (max-width: 960px) {
  .event-split {
    gap: 20px;
  }

  .event-pass-panel {
    order: -1;
  }

  .event-pass-panel__glass {
    max-width: 100%;
  }
}

@media (max-width: 768px) {
  .event-hero__inner {
    padding-left: max(16px, env(safe-area-inset-left));
    padding-right: max(16px, env(safe-area-inset-right));
  }

  .event-hero__title {
    font-size: clamp(1.35rem, 5.5vw, 1.75rem);
    overflow-wrap: anywhere;
  }

  .event-hall-toolbar {
    flex-wrap: wrap;
    gap: 8px;
    padding: 10px 12px;
  }

  .event-hall-toolbar__venue {
    width: 100%;
    font-size: 12px;
  }

  .event-hall-toolbar__controls {
    flex-wrap: wrap;
  }

  .event-hall-zoom-btn {
    min-width: 44px;
    min-height: 44px;
  }

  .event-hall-legend {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    gap: 8px;
    padding-bottom: 6px;
    scrollbar-width: thin;
    overscroll-behavior-x: contain;
  }

  .event-hall-legend__btn {
    flex: 0 0 auto;
    white-space: nowrap;
  }

  .event-seat-list {
    max-height: min(40vh, 280px);
    -webkit-overflow-scrolling: touch;
  }

  .event-seat-list__btn {
    min-height: 48px;
    padding: 12px 14px;
  }

  .event-form input,
  .event-form textarea,
  .event-btn-submit {
    min-height: 48px;
  }

  .event-consent {
    align-items: flex-start;
    gap: 10px;
  }

  .event-consent input {
    margin-top: 4px;
    min-width: 20px;
    min-height: 20px;
  }
}

@media (max-width: 520px) {
  .event-hall-scrollpad {
    height: min(400px, 50dvh);
  }

  .hall-row__meta {
    font-size: 10px;
    gap: 6px;
  }

  .event-countdown__cell {
    padding: 12px 8px;
  }

  .event-sticky-cta {
    font-size: 12px;
    min-height: 50px;
    padding: 0 20px;
  }
}

/* Декоративные слои: изоляция перерисовки (анимации не трогаем) */
.event-hero__bg-mesh,
.event-hero__bg-orbs,
.event-hero__bg-grid,
.event-cinematic-banner__bg,
.event-deco-ticket {
  contain: layout style paint;
}

/* Телефон: карточки в колонку (см. event-premium.css) */
@media (max-width: 768px) {
  .event-hero__visual {
    overflow: visible;
  }

  .event-float-stack .event-float-card,
  .event-float-stack .event-float-pass {
    contain: none;
  }
}

.event-hall-canvas {
  backface-visibility: hidden;
}

/* ——— Админка ——— */
@media (max-width: 768px) {
  .admin-header__inner {
    flex-wrap: wrap;
    gap: 8px;
    padding: 12px max(16px, env(safe-area-inset-left));
  }

  .admin-tabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    flex-wrap: nowrap;
    max-width: 100%;
    scrollbar-width: thin;
  }

  .admin-tab {
    flex: 0 0 auto;
    white-space: nowrap;
    min-height: 44px;
  }

  .admin-table-wrap {
    margin: 0 -4px;
    padding-bottom: 4px;
  }

  .scanner-reader {
    min-height: min(50vh, 360px);
  }

  .scanner-controls .btn {
    flex: 1 1 auto;
    min-width: 0;
  }
}

/* ——— Подвал: safe area ——— */
.footer {
  padding-bottom: max(24px, env(safe-area-inset-bottom));
}

/* ——— Таблицы и длинный текст ——— */
.admin-table-wrap,
.table-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  max-width: 100%;
}

.legal-card p,
.event-host-card__bio,
.event-program-step p {
  overflow-wrap: break-word;
}

/* ——— Hover только там, где есть мышь ——— */
@media (hover: none) and (pointer: coarse) {
  .btn--primary:hover,
  .btn--ghost:hover,
  .event-reason-card:hover {
    transform: none;
  }
}

/* ——— Широкие экраны: схема зала ——— */
@media (min-width: 1024px) {
  .event-split {
    grid-template-columns: minmax(0, 1.5fr) minmax(320px, 420px);
  }

  .event-hall-scrollpad {
    height: min(560px, 58vh);
  }
}
