/* ===== HOME PAGE - Design from newswire-redesign (3) ===== */

@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(1vw); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes slideGlow {
  0% { background-position: -200% center; }
  100% { background-position: 200% center; }
}
@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.5; transform: scale(1.4); }
}

.home-page-container {
  display: grid;
  grid-template-columns: 1fr 19vw;
  gap: 1.5vw;
  padding: 1.2vw 1.5vw;
  padding-top: 2.2vw;
  margin-left: 4.5vw;
  max-width: 100%;
  min-height: 100vh;
  background: #f5f6f8;
}

.home-main-column {
  display: flex;
  flex-direction: column;
  gap: 2.5vw;
}

/* ── WELCOME BANNER ── */
.home-welcome-banner {
  position: relative;
  overflow: hidden;
  background: #fff;
  border: 0.06vw solid #e2e5ea;
  border-radius: 0.7vw;
  padding: 1.4vw 1.6vw;
}

.home-welcome-banner::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 0.22vw;
  background: linear-gradient(90deg, #4f6ef7, #8b5cf6, #4f6ef7);
  background-size: 200% 100%;
  animation: slideGlow 4s linear infinite;
}

.home-welcome-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1vw;
}

.home-welcome-left {
  display: flex;
  align-items: center;
  gap: 1vw;
}

.home-welcome-logo-badge {
  width: 3.6vw;
  height: 3.6vw;
  border-radius: 0.5vw;
  background: linear-gradient(135deg, #4f6ef7 0%, #6366f1 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0.3vw 1vw rgba(79,110,247,0.3);
  flex-shrink: 0;
}

.home-welcome-logo-icon {
  width: 2.6vw;
  height: 2.6vw;
  color: #fff;
}

.home-welcome-text h1 {
  font-size: 1.35vw;
  font-weight: 800;
  color: #111318;
  line-height: 1.2;
  margin: 0 0 0.2vw 0;
}

.home-welcome-text p {
  font-size: 0.78vw;
  color: #667085;
  line-height: 1.5;
  margin: 0;
}

.home-welcome-right {
  display: flex;
  align-items: center;
  gap: 0.7vw;
  flex-shrink: 0;
}

.home-online-badge {
  display: flex;
  align-items: center;
  gap: 0.35vw;
  background: rgba(16,185,129,0.08);
  border: 0.06vw solid rgba(16,185,129,0.2);
  border-radius: 2vw;
  padding: 0.35vw 0.75vw;
}

.home-online-dot {
  width: 0.4vw;
  height: 0.4vw;
  border-radius: 50%;
  background: #10b981;
  animation: pulse-dot 2s ease infinite;
}

.home-online-badge span {
  font-size: 0.68vw;
  font-weight: 600;
  color: #10b981;
}

.home-btn-primary {
  display: flex;
  align-items: center;
  gap: 0.4vw;
  background: transparent;
  color: #4f6ef7;
  padding: 0.5vw 1vw;
  border-radius: 0.4vw;
  font-size: 0.88vw;
  font-weight: 500;
  text-decoration: none;
  border: 0.06vw solid rgba(79,110,247,0.35);
  transition: all 0.2s;
}

.home-btn-primary i {
  font-size: 0.9vw;
  opacity: 0.85;
}

.home-btn-primary:hover {
  background: rgba(79,110,247,0.06);
  border-color: rgba(79,110,247,0.5);
  color: #3b5bdb;
}

.home-btn-secondary {
  display: flex;
  align-items: center;
  gap: 0.4vw;
  background: transparent;
  color: #374151;
  padding: 0.5vw 1vw;
  border-radius: 0.4vw;
  font-size: 0.88vw;
  font-weight: 500;
  text-decoration: none;
  border: 0.06vw solid #e2e5ea;
  transition: all 0.2s;
}

.home-btn-secondary:hover {
  border-color: #c0c5cf;
  color: #111318;
}

/* ── SECTION HEADERS ── */
.home-section {
  margin-bottom: 0.5vw;
}

.home-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.2vw;
}

.home-section-title-row {
  display: flex;
  align-items: center;
  gap: 0.7vw;
}

.home-section-icon {
  width: 2.1vw;
  height: 2.1vw;
  border-radius: 0.45vw;
  display: flex;
  align-items: center;
  justify-content: center;
}

.home-section-icon i,
.home-section-icon .lucide-icon {
  width: 1.2vw;
  height: 1.2vw;
  font-size: 1.2vw !important;
}

.home-section-icon.trending {
  background: rgba(245,158,11,0.1);
}

.home-section-icon.trending i,
.home-section-icon.trending .lucide-icon {
  color: #f59e0b;
}

.home-section-icon.news {
  background: rgba(239,68,68,0.1);
}

.home-section-icon.news i,
.home-section-icon.news .lucide-icon {
  color: #ef4444;
}

.home-section-icon.stats {
  background: rgba(79,110,247,0.1);
}

.home-section-icon.stats i,
.home-section-icon.stats .lucide-icon {
  color: #4f6ef7;
}

.home-section-icon.explore {
  background: rgba(139,92,246,0.1);
}

.home-section-icon.explore i,
.home-section-icon.explore .lucide-icon {
  color: #8b5cf6;
}

.home-section-title {
  font-size: 1.28vw;
  font-weight: 700;
  color: #111318;
  margin: 0;
  letter-spacing: -0.02vw;
}

.home-view-all-link {
  display: flex;
  align-items: center;
  gap: 0.2vw;
  font-size: 0.9vw;
  font-weight: 600;
  color: #4f6ef7;
  text-decoration: none;
}

.home-view-all-link:hover {
  color: #3b5bdb;
}

/* ── TRENDING & NEWS GRIDS (use content-cards.css) ── */
.home-cards-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.8vw;
}

.home-cards-grid .news-date-search {
  font-size: 0.7vw;
}

/* Trending: 5 cards, proportionally scaled */
.home-trending-grid {
  grid-template-columns: repeat(5, 1fr);
  gap: 0.6vw;
}

.home-trending-grid .category-image-container-search {
  aspect-ratio: 16 / 9;
}

.home-trending-grid .category-content-search {
  padding: 0.5vw 0.6vw;
  gap: 0.15vw;
}

.home-trending-grid .category-icon-search {
  width: 1.35vw;
  height: 1.35vw;
  font-size: 0.68vw;
}

.home-trending-grid .category-title-search {
  font-size: 0.8vw;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: block;
}

.home-trending-grid .category-footer-search {
  padding-top: 0.35vw;
}

.home-trending-grid .category-meta-info {
  font-size: 0.6vw;
  padding: 0.18vw 0.4vw;
}

.home-trending-grid .category-explore-link {
  font-size: 0.6vw;
}

.home-trending-grid .category-explore-link i {
  font-size: 0.55vw;
}

/* ── COMMUNITY STATS ── */
.home-stats-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 0.7vw;
}

.home-stat-card {
  background: #fff;
  border: 0.06vw solid #e2e5ea;
  border-radius: 0.55vw;
  padding: 1vw 0.9vw;
  display: flex;
  flex-direction: column;
  gap: 0.5vw;
  transition: all 0.2s;
  cursor: default;
}

.home-stat-card:hover {
  border-color: rgba(79,110,247,0.4);
  box-shadow: 0 0.3vw 1vw rgba(79,110,247,0.15);
}

.home-stat-top-row {
  display: flex;
  align-items: center;
  gap: 0.6vw;
}

.home-stat-icon {
  width: 2.4vw;
  height: 2.4vw;
  border-radius: 0.45vw;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.home-stat-icon i,
.home-stat-icon .lucide-icon {
  width: 1.3vw;
  height: 1.3vw;
  font-size: 1.3vw !important;
}

.home-stat-value {
  font-size: 1.35vw;
  font-weight: 800;
  color: #111318;
  line-height: 1;
}

.home-stat-label {
  font-size: 0.78vw;
  font-weight: 500;
  color: #667085;
}

/* ── EXPLORE NAV LINKS ── */
.home-nav-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.7vw;
}

.home-nav-link {
  display: flex;
  align-items: center;
  gap: 0.9vw;
  text-decoration: none;
  background: #fff;
  border: 0.06vw solid #e2e5ea;
  border-radius: 0.55vw;
  padding: 1vw 1.2vw;
  transition: all 0.2s;
}

.home-nav-link:hover {
  transform: translateY(-0.1vw);
}

.home-nav-icon {
  width: 2.8vw;
  height: 2.8vw;
  border-radius: 0.5vw;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.home-nav-icon i,
.home-nav-icon .lucide-icon {
  width: 1.45vw;
  height: 1.45vw;
  font-size: 1.45vw !important;
}

.home-nav-text {
  flex: 1;
}

.home-nav-title {
  font-size: 0.98vw;
  font-weight: 650;
  color: #111318;
}

.home-nav-desc {
  font-size: 0.78vw;
  color: #667085;
  font-weight: 500;
}

.home-nav-arrow {
  flex-shrink: 0;
  color: #c0c5cf;
}

.home-nav-arrow i,
.home-nav-arrow .lucide-icon {
  width: 1vw;
  height: 1vw;
}

/* ── RIGHT SIDEBAR ── */
.home-sidebar {
  display: flex;
  flex-direction: column;
  gap: 1vw;
  position: sticky;
  top: 1.2vw;
  align-self: start;
}

.home-sidebar-card {
  background: #fff;
  border: 0.06vw solid #e2e5ea;
  border-radius: 0.55vw;
  overflow: hidden;
}

.home-sidebar-header {
  padding: 0.9vw 1vw;
  border-bottom: 0.06vw solid #e2e5ea;
  display: flex;
  align-items: center;
  gap: 0.55vw;
}

.home-sidebar-header i,
.home-sidebar-header .lucide-icon {
  width: 1.15vw;
  height: 1.15vw;
  font-size: 1.15vw !important;
}

.home-sidebar-header span {
  font-size: 1.05vw;
  font-weight: 650;
  color: #111318;
}

.home-sidebar-content {
  padding: 0.7vw 1vw;
}

.home-contributor-row {
  display: flex;
  align-items: center;
  gap: 0.65vw;
  padding: 0.6vw 0;
  transition: background 0.15s;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
}

.home-contributor-row:hover {
  background: #f5f6f8;
}

.home-contributor-rank {
  width: 1.7vw;
  height: 1.7vw;
  border-radius: 0.4vw;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.78vw;
  font-weight: 700;
  flex-shrink: 0;
}

.home-contributor-avatar {
  width: 2.2vw;
  height: 2.2vw;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}

.home-contributor-info {
  flex: 1;
  min-width: 0;
}

.home-contributor-name {
  font-size: 0.9vw;
  font-weight: 600;
  color: #111318;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.home-contributor-xp {
  font-size: 0.75vw;
  color: #667085;
  font-weight: 500;
}

/* Quick Links */
.home-quick-link {
  display: flex;
  align-items: center;
  gap: 0.6vw;
  padding: 0.65vw 0.9vw;
  border-radius: 0.4vw;
  text-decoration: none;
  transition: background 0.15s;
}

.home-quick-link:hover {
  background: #f5f6f8;
}

.home-quick-link i,
.home-quick-link .lucide-icon {
  width: 0.95vw;
  height: 0.95vw;
  color: #667085;
  flex-shrink: 0;
}

.home-quick-link span {
  font-size: 0.78vw;
  font-weight: 500;
  color: #374151;
}

.home-quick-link .home-quick-arrow {
  margin-left: auto;
  color: #c0c5cf;
}

.home-quick-link .home-quick-arrow i,
.home-quick-link .home-quick-arrow .lucide-icon {
  width: 0.65vw;
  height: 0.65vw;
}

/* Ad Banner — полноразмерная заглушка */
.home-ad-banner {
    width: 100%;
    min-height: 200px;
    border-radius: 0.55vw;
    border: 0.12vw dashed #d1d5db;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.6vw;
    background: #f5f6f8;
}

.home-ad-badge {
    background: #e5e7eb;
    border-radius: 0.35vw;
    padding: 0.4vw 0.8vw;
    font-size: 0.75vw;
    font-weight: 700;
    color: #9ca3af;
}

.home-ad-text {
    font-size: 0.9vw;
    font-weight: 600;
    color: #9ca3af;
}

.home-ad-subtext {
    font-size: 0.72vw;
    color: #c0c5cf;
}
