/* КПКІТП — головна сторінка (home.css)
   Працює з глобальними змінними з header.php:
   --bg, --paper, --text, --muted, --border, --kp-mint, --kp-violet тощо
*/

:root{
  /* НЕ перезаписуємо глобальні --bg/--text, тільки локальні токени сторінки */
  --home-card: rgba(255,255,255,.78);
  --home-card-solid: #ffffff;
  --home-card-border: rgba(59,31,94,.14);
  --home-shadow: 0 14px 34px rgba(16,24,40,.10);
  --home-radius: 18px;

  --home-accent: rgba(59,31,94,.10);
  --home-accent-2: rgba(159,231,221,.28);

  --home-btn: rgba(255,255,255,.70);
  --home-btn-hover: rgba(255,255,255,.88);
  --home-btn-border: rgba(59,31,94,.16);
}

/* База */
*{ box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body{
  /* фон беремо з глобального --bg (з header.php) */
  background: var(--bg);
  color: var(--text);
}

/* Основна сторінка */
.page{
  padding: 16px 0 28px;
}

/* На index.php ти вже перейшов на kp-container, але якщо десь залишиться container — підстрахуємось */
.container{
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 14px;
}

/* Заголовки/текст */
.page-title{
  font-size: 26px;
  line-height: 1.18;
  margin: 10px 0 10px;
  color: var(--kp-violet);
  letter-spacing: .2px;
}
.user-line{
  font-size: 15px;
  color: var(--muted);
  margin: 0 0 16px 0;
}

/* Блок новин */
.news-section{
  background:
    radial-gradient(900px 360px at 10% 0%, rgba(159,231,221,.35) 0%, rgba(159,231,221,.10) 55%, rgba(255,255,255,0) 100%),
    linear-gradient(180deg, rgba(255,255,255,.88) 0%, rgba(255,255,255,.78) 100%);
  border: 1px solid var(--home-card-border);
  border-radius: var(--home-radius);
  box-shadow: var(--home-shadow);
  padding: 16px;
  margin-bottom: 18px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.news-title{
  font-size: 18px;
  color: var(--kp-violet);
  margin: 0 0 10px 0;
  font-weight: 900;
  letter-spacing: .2px;
}
.news-body p{
  font-size: 16px;
  color: rgba(30,27,34,.90);
  margin: 0;
}

/* Список груп */
.groups-title{
  font-size: 20px;
  color: var(--kp-violet);
  margin: 0 0 12px 0;
  font-weight: 900;
  letter-spacing: .2px;
}

.groups-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr)); /* телефон - 2 в ряд */
  gap: 10px;
}

/* Карточка групи */
.group-card{
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;

  padding: 12px 10px;
  min-height: 54px;

  background:
    linear-gradient(180deg, rgba(255,255,255,.86) 0%, rgba(255,255,255,.70) 100%);
  color: var(--kp-violet-2);

  border: 1px solid var(--home-btn-border);
  border-radius: 16px;
  text-decoration: none;

  box-shadow: 0 10px 20px rgba(16,24,40,.10);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  /* Анімація появи */
  opacity: 0;
  transform: translateY(8px);
  transition:
    opacity .45s ease,
    transform .45s ease,
    background-color .25s ease,
    transform .08s ease-in-out,
    border-color .25s ease;
}

.group-card.loaded{
  opacity: 1;
  transform: translateY(0);
}

.group-card:hover{
  background:
    linear-gradient(180deg, rgba(159,231,221,.55) 0%, rgba(255,255,255,.82) 100%);
  border-color: rgba(59,31,94,.22);
  text-decoration: none;
}

.group-card:active{
  transform: scale(0.99);
}

.group-name{
  display: block;
  font-size: 16px;
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: .2px;
}

.no-groups{
  text-align: center;
  color: var(--muted);
  margin: 8px 0 0;
}

/* Доступність: менше анімацій */
@media (prefers-reduced-motion: reduce){
  .group-card{
    transition: none !important;
    transform: none !important;
    opacity: 1 !important;
  }
}

/* Планшет */
@media (min-width: 768px){
  .page{ padding: 18px 0 34px; }

  .page-title{ font-size: 30px; margin-bottom: 12px; }
  .user-line{ font-size: 16px; }

  .news-section{ padding: 18px; margin-bottom: 20px; }
  .news-title{ font-size: 20px; }

  .groups-title{ font-size: 22px; }
  .groups-grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
  }

  .group-card{ min-height: 58px; }
}

/* Десктоп */
@media (min-width: 1024px){
  .page{ padding: 22px 0 40px; }

  .page-title{ font-size: 34px; }
  .news-section{ margin-bottom: 24px; }

  .groups-grid{
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
  }

  .group-card{
    padding: 14px 12px;
    min-height: 62px;
  }

  .group-name{ font-size: 18px; }
}
