/* Mobile-first улучшения для страницы аналитики
   - Одна колонка карточек
   - Крупные элементы управления
   - Мягкие тени и закругления
   - Безопасные отступы с учетом вырезов (safe-area)
   - Шимер для лоадеров
*/

:root {
  --m-gap-1: 6px;
  --m-gap-2: 10px;
  --m-gap-3: 14px;
  --m-gap-4: 18px;
  --m-radius: 14px;
  --m-shadow: 0 8px 24px rgba(15, 23, 42, 0.12);
  --m-card-bg: #ffffff;
  --m-text: #0f172a;
  --m-muted: #64748b;
  --m-accent: #0d6efd;
  --m-accent-2: #15a34a;
  --m-surface: #f8fafc;
}

@media (prefers-color-scheme: dark) {
  :root {
    --m-card-bg: #121826;
    --m-text: #f1f5f9;
    --m-muted: #94a3b8;
    --m-surface: #0b1220;
    --m-shadow: 0 10px 30px rgba(2, 6, 23, 0.4);
  }
}

@media (max-width: 768px) {
  html, body {
    background: radial-gradient(1200px 600px at 100% -20%, rgba(13,110,253,0.08), transparent 60%),
                radial-gradient(900px 500px at -10% 120%, rgba(21,163,74,0.08), transparent 60%),
                var(--m-surface);
    color: var(--m-text);
    font-size: 16px;
    -webkit-tap-highlight-color: transparent;
    overscroll-behavior-y: contain;
  }

  main {
    padding: calc(env(safe-area-inset-top) + 8px) 12px calc(env(safe-area-inset-bottom) + 96px);
  }

  .main-menu-wrapper {
    display: grid;
    gap: var(--m-gap-4);
  }

  /* Заголовки секций */
  .technicians-section h2,
  .main-menu-right h2,
  #technicianDetailsSection h2 {
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 0.2px;
    margin: 0;
  }

  /* Верхние панели управления в секциях - в столбик на мобилке */
  .technicians-section h2 + div,
  .main-menu-right h2 + div,
  #technicianDetailsSection h2 + button {
    display: flex;
    flex-direction: column;
    align-items: stretch !important;
    gap: var(--m-gap-2) !important;
  }

  /* Селект месяца и кнопки обновления */
  #monthSelector {
    width: 100%;
    padding: 12px 14px !important;
    border-radius: 12px !important;
    border: 1px solid rgba(148,163,184,0.35) !important;
    background: var(--m-card-bg) !important;
    color: var(--m-text) !important;
    -webkit-text-fill-color: var(--m-text) !important; /* фикс для iOS/Safari */
    box-shadow: var(--m-shadow);
  }
  .technicians-section button,
  .main-menu-right button,
  #technicianDetailsSection button {
    width: 100%;
    padding: 12px 14px !important;
    border-radius: 12px !important;
    font-weight: 700;
    letter-spacing: 0.2px;
    box-shadow: var(--m-shadow);
    transform: translateZ(0);
  }
  .technicians-section button:active,
  .main-menu-right button:active,
  #technicianDetailsSection button:active {
    transform: scale(0.98);
    opacity: 0.95;
  }

  /* Сетка техников -> одна колонка карточек */
  .technicians-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: var(--m-gap-3) !important;
  }

  /* Карточка техника */
  .technician-card {
    background: var(--m-card-bg);
    border: 1px solid rgba(148,163,184,0.25);
    border-radius: var(--m-radius);
    padding: 14px;
    box-shadow: var(--m-shadow);
    position: relative;
    overflow: hidden;
  }
  .technician-card.clickable { cursor: pointer; }
  .technician-card.clickable:active { transform: translateY(1px); }

  .technician-status {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: var(--m-accent-2);
    box-shadow: 0 0 0 6px rgba(21,163,74,0.12);
  }

  .technician-header {
    display: flex;
    align-items: center;
    gap: var(--m-gap-3);
    margin-bottom: 10px;
  }
  .technician-avatar {
    width: 48px; height: 48px;
    min-width: 48px;
    border-radius: 12px;
    display: grid; place-items: center;
    color: #fff;
    font-weight: 800;
    letter-spacing: 0.4px;
  }
  .technician-info .technician-name {
    font-size: 17px; font-weight: 800;
  }
  .technician-info .technician-role {
    font-size: 13px; color: var(--m-muted);
    text-transform: capitalize;
  }

  .technician-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--m-gap-2);
    margin-top: 6px;
  }
  .technician-stats .stat-item {
    background: linear-gradient(180deg, rgba(13,110,253,0.06), transparent);
    border: 1px solid rgba(148,163,184,0.25);
    border-radius: 12px;
    padding: 10px;
    text-align: center;
  }
  .technician-stats .stat-value {
    font-size: 18px;
    font-weight: 800;
    color: var(--m-text);
  }
  .technician-stats .stat-label {
    font-size: 12px;
    color: var(--m-muted);
  }

  /* Детальная аналитика техника */
  .technician-details-section {
    background: var(--m-card-bg);
    border: 1px solid rgba(148,163,184,0.25);
    border-radius: var(--m-radius);
    padding: 14px;
    box-shadow: var(--m-shadow);
  }

  .details-summary {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--m-gap-2);
    margin-top: var(--m-gap-2);
  }
  .details-card {
    background: linear-gradient(180deg, rgba(21,163,74,0.06), transparent);
    border: 1px solid rgba(148,163,184,0.25);
    border-radius: 12px;
    padding: 12px;
    text-align: center;
  }
  .details-number {
    font-size: 20px;
    font-weight: 800;
  }
  .details-label {
    font-size: 12px;
    color: var(--m-muted);
  }

  .details-section {
    margin-top: var(--m-gap-3);
  }
  .details-section h3 {
    font-size: 16px;
    margin-bottom: var(--m-gap-2);
  }
  .objects-list, .task-item {
    display: grid;
    gap: var(--m-gap-2);
  }

  /* Прокручування списків у деталях на мобільних, щоб контент не «їхав» вниз */
  .technician-details-section .objects-list {
    max-height: 60vh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding-right: 4px; /* невеликий зазор під скролбар */
    overscroll-behavior: contain;
  }

  .maintenance-item, .task-item {
    border: 1px solid rgba(148,163,184,0.25);
    border-radius: 12px;
    padding: 12px;
    background: var(--m-card-bg);
  }
  .maintenance-item.primary { border-left: 4px solid var(--m-accent-2); }
  .maintenance-item.secondary { border-left: 4px solid var(--m-accent); }

  .item-header {
    display: flex; justify-content: space-between; gap: 12px;
    margin-bottom: 8px;
  }
  .item-title { font-weight: 700; }
  .item-time { font-size: 12px; color: var(--m-muted); white-space: nowrap; }

  .maintenance-info {
    display: flex; gap: 8px; flex-wrap: wrap; align-items: center;
    margin-bottom: 6px;
  }
  .duration-badge, .status-badge {
    border-radius: 999px;
    padding: 4px 10px;
    font-size: 12px;
    background: rgba(13,110,253,0.1);
    color: var(--m-text);
  }
  .duration-badge.pending { background: rgba(244, 180, 0, 0.15); }

  /* Активность пользователей как «таймлайн» */
  #activityContent {
    display: grid;
    gap: var(--m-gap-2);
  }
  /* Ограниченная область со скроллом для мобильных */
  #activityContent.activity-scroll {
    max-height: 60vh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding-right: 4px; /* небольшой зазор под скроллбар */
  }
  .activity-item {
    position: relative;
    padding: 12px 12px 12px 16px;
    background: var(--m-card-bg);
    border: 1px solid rgba(148,163,184,0.25);
    border-radius: 12px;
    box-shadow: var(--m-shadow);
  }
  .activity-item::before {
    content: "";
    position: absolute; left: 0; top: 12px; bottom: 12px;
    width: 3px; border-radius: 3px;
    background: linear-gradient(180deg, var(--m-accent), var(--m-accent-2));
    opacity: 0.7;
  }
  .activity-meta {
    display: flex; gap: 10px; flex-wrap: wrap;
    font-size: 12px; color: var(--m-muted); margin-bottom: 6px;
  }
  .activity-title { font-weight: 700; }
  .activity-description { font-size: 14px; color: var(--m-text); opacity: 0.9; }

  /* Лоадеры: шимер */
  .loading, .loading-events {
    position: relative;
    overflow: hidden;
    border-radius: 12px;
    min-height: 56px;
    background: linear-gradient(90deg, rgba(148,163,184,0.15), rgba(148,163,184,0.25), rgba(148,163,184,0.15));
    background-size: 200% 100%;
    animation: shimmer 1.2s infinite linear;
  }
  @keyframes shimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
  }

  .no-data {
    background: var(--m-card-bg);
    border: 1px solid rgba(148,163,184,0.25);
    border-radius: 12px;
    padding: 18px;
    text-align: center;
    color: var(--m-muted);
    box-shadow: var(--m-shadow);
  }

  /* FAB — плавающая кнопка обновления */
  .fab {
    position: fixed;
    right: max(16px, env(safe-area-inset-right));
    bottom: max(16px, calc(env(safe-area-inset-bottom) + 16px));
    width: 56px; height: 56px;
    border-radius: 999px;
    border: none;
    background: radial-gradient(120% 120% at 30% 30%, #2dd4bf, transparent 60%),
                linear-gradient(180deg, var(--m-accent), #2563eb);
    color: #fff;
    font-size: 22px;
    font-weight: 800;
    box-shadow: 0 14px 34px rgba(13,110,253,0.35);
    display: grid; place-items: center;
    z-index: 999;
    cursor: pointer;
    transition: transform 0.18s ease, box-shadow 0.18s ease, opacity 0.18s ease;
  }
  .fab:active, .fab.active {
    transform: scale(0.96);
    box-shadow: 0 10px 24px rgba(13,110,253,0.28);
    opacity: 0.95;
  }

  /* Отступ снизу, чтобы FAB не перекрывала последний блок */
  .technicians-section,
  .technician-details-section,
  .main-menu-right {
    scroll-margin-top: 80px;
  }
}

/* Маленькие экраны */
@media (max-width: 420px) {
  .technician-stats {
    grid-template-columns: 1fr 1fr;
  }
  .details-summary {
    grid-template-columns: 1fr;
  }
}
