/* public/css/widgets/home-stats.css
   Блок статистики главной.
   Цвета не задаются отдельными палитрами: всё берётся из home.css через --hp-*.
*/

.home-page .home-community-stats,
.home-page .home-community-stats * {
  box-sizing: border-box;
}

.home-page .home-community-stats {
  position: relative;

  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, .92fr);
  gap: clamp(14px, 2.4vw, 24px);
  align-items: stretch;

  margin: 0 0 clamp(14px, 2.2vw, 24px);
  padding: clamp(16px, 3vw, 30px);

  overflow: hidden;
  isolation: isolate;

  border: 1px solid var(--hp-border);
  border-radius: var(--hp-radius-lg, 26px);

  background-color: var(--hp-surface-1);
  background-image:
    radial-gradient(780px 280px at 0% 0%, color-mix(in srgb, var(--hp-brand) 13%, transparent), transparent 66%),
    radial-gradient(620px 260px at 100% 100%, color-mix(in srgb, var(--hp-accent) 13%, transparent), transparent 64%),
    linear-gradient(135deg, color-mix(in srgb, var(--hp-surface-2) 48%, transparent), var(--hp-surface-1));

  color: var(--hp-text);
  box-shadow: var(--hp-shadow, var(--hp-shadow-soft));
}

.home-page .home-community-stats::before {
  content: "";
  position: absolute;
  inset: 1px;
  z-index: -1;

  border-radius: calc(var(--hp-radius-lg, 26px) - 1px);

  background:
    linear-gradient(120deg, rgba(255,255,255,.08), transparent 34%),
    radial-gradient(circle at 50% 0%, rgba(255,255,255,.08), transparent 46%);

  pointer-events: none;
}

.home-page .home-community-stats__glow {
  position: absolute;
  z-index: -2;

  width: 260px;
  height: 260px;

  border-radius: 999px;
  opacity: .26;
  filter: blur(12px);

  pointer-events: none;
}

.home-page .home-community-stats__glow--one {
  top: -120px;
  left: 10%;
  background: var(--hp-brand);
}

.home-page .home-community-stats__glow--two {
  right: -110px;
  bottom: -130px;
  background: var(--hp-accent);
}

.home-page .home-community-stats__main {
  position: relative;
  z-index: 1;

  min-width: 0;

  display: flex;
  flex-direction: column;
  justify-content: center;
}

.home-page .home-community-stats__kicker {
  width: max-content;
  max-width: 100%;

  display: inline-flex;
  align-items: center;
  gap: 9px;

  margin-bottom: 14px;
  padding: 7px 11px;

  border: 1px solid color-mix(in srgb, var(--hp-brand) 32%, transparent);
  border-radius: 999px;

  background-color: color-mix(in srgb, var(--hp-brand) 10%, transparent);
  color: color-mix(in srgb, var(--hp-text) 88%, var(--hp-brand));

  font-size: .84rem;
  line-height: 1;
  font-weight: 900;
}

.home-page .home-community-stats__spark {
  width: 22px;
  height: 22px;
  flex: 0 0 auto;

  display: grid;
  place-items: center;

  border-radius: 999px;

  background-color: var(--hp-brand);
  background-image: linear-gradient(135deg, var(--hp-brand), var(--hp-accent));
  color: #fff;

  box-shadow: 0 0 14px color-mix(in srgb, var(--hp-brand) 70%, transparent);

  font-size: .78rem;
  line-height: 1;
}

.home-page .home-community-stats__title {
  max-width: 720px;
  margin: 0;

  color: var(--hp-text);

  font-size: clamp(1.55rem, 1.08rem + 2.15vw, 2.8rem);
  line-height: 1.12;
  letter-spacing: -.035em;
  font-weight: 850;

  text-wrap: balance;
}

@media (max-width: 680px) {
  .home-page .home-community-stats__title {
    font-size: clamp(1.42rem, 1.08rem + 5vw, 2.25rem);
    line-height: 1.14;
    letter-spacing: -.028em;
  }
}

.home-page .home-community-stats__text {
  max-width: 680px;
  margin: 16px 0 0;

  color: var(--hp-muted);

  font-size: clamp(.98rem, .9rem + .3vw, 1.1rem);
  line-height: 1.62;
}

.home-page .home-community-stats__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;

  margin-top: 24px;
}

.home-page .home-community-stats__btn {
  min-height: 46px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  padding: 10px 18px;

  border-radius: 999px;
  text-decoration: none;

  font-weight: 900;
  line-height: 1;

  transition:
    transform .16s ease,
    filter .16s ease,
    border-color .16s ease,
    background-color .16s ease;
}

.home-page .home-community-stats__btn:hover {
  transform: translateY(-1px);
  filter: brightness(1.05);
}

.home-page .home-community-stats__btn--primary {
  border: 1px solid color-mix(in srgb, var(--hp-brand) 42%, transparent);

  background-color: var(--hp-brand);
  background-image: linear-gradient(
    135deg,
    var(--hp-brand),
    color-mix(in srgb, var(--hp-brand) 62%, var(--hp-accent))
  );

  color: #fff;

  box-shadow: 0 14px 30px color-mix(in srgb, var(--hp-brand) 22%, transparent);
}

.home-page .home-community-stats__btn--secondary {
  border: 1px solid var(--hp-border);

  background-color: color-mix(in srgb, var(--hp-surface-2) 86%, transparent);
  background-image: none;

  color: var(--hp-text);

  box-shadow: none;
}

.home-page .home-community-stats__grid {
  position: relative;
  z-index: 1;

  min-width: 0;

  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

.home-page .home-community-stat-card {
  position: relative;

  min-width: 0;
  min-height: 126px;

  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  grid-template-areas:
    "icon value"
    "icon label"
    "icon hint";
  column-gap: 16px;
  align-content: center;

  padding: 18px;

  overflow: hidden;

  border: 1px solid color-mix(in srgb, var(--hp-border) 90%, transparent);
  border-radius: 22px;

  background-color: var(--hp-card);
  background-image:
    radial-gradient(260px 120px at 100% 0%, color-mix(in srgb, var(--hp-brand) 10%, transparent), transparent 70%),
    linear-gradient(180deg, color-mix(in srgb, var(--hp-text) 4%, transparent), transparent);

  color: var(--hp-text);

  box-shadow: var(--hp-shadow-card, 0 14px 34px rgba(0,0,0,.13));
}

.home-page .home-community-stat-card::after {
  content: "";
  position: absolute;
  top: -46px;
  right: -42px;

  width: 118px;
  height: 118px;

  border-radius: 999px;

  background: var(--hp-text);
  opacity: .06;

  pointer-events: none;
}

.home-page .home-community-stat-card__icon {
  grid-area: icon;

  width: 56px;
  height: 56px;

  display: grid;
  place-items: center;
  align-self: center;

  border-radius: 18px;

  background-color: color-mix(in srgb, var(--hp-brand) 18%, transparent);
  color: var(--hp-brand);

  border: 1px solid color-mix(in srgb, var(--hp-brand) 26%, transparent);
}

.home-page .home-community-stat-card__icon svg {
  width: 27px;
  height: 27px;
}

.home-page .home-community-stat-card__value {
  grid-area: value;

  min-width: 0;

  color: var(--hp-brand);

  font-size: clamp(2rem, 1.55rem + 2.2vw, 3.15rem);
  line-height: .95;
  font-weight: 950;
  letter-spacing: -.06em;
  font-variant-numeric: tabular-nums;
}

.home-page .home-community-stat-card__label {
  grid-area: label;

  margin-top: 6px;

  color: var(--hp-text);

  font-size: 1rem;
  line-height: 1.15;
  font-weight: 950;
}

.home-page .home-community-stat-card__hint {
  grid-area: hint;

  margin: 5px 0 0;

  color: var(--hp-muted);

  font-size: .92rem;
  line-height: 1.35;
}

@media (max-width: 920px) {
  .home-page .home-community-stats {
    grid-template-columns: 1fr;
  }

  .home-page .home-community-stats__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .home-page .home-community-stat-card {
    min-height: 156px;

    grid-template-columns: 1fr;
    grid-template-areas:
      "icon"
      "value"
      "label"
      "hint";
    row-gap: 7px;
  }

  .home-page .home-community-stat-card__icon {
    width: 50px;
    height: 50px;
  }
}

@media (max-width: 680px) {
  .home-page .home-community-stats {
    padding: 16px;
    border-radius: 22px;
  }

  .home-page .home-community-stats__grid {
    grid-template-columns: 1fr;
  }

  .home-page .home-community-stat-card {
    min-height: 116px;

    grid-template-columns: auto minmax(0, 1fr);
    grid-template-areas:
      "icon value"
      "icon label"
      "icon hint";
  }

  .home-page .home-community-stats__actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .home-page .home-community-stats__btn {
    width: 100%;
  }
}

@media (max-width: 420px) {
  .home-page .home-community-stats {
    padding: 14px;
    border-radius: 20px;
  }

  .home-page .home-community-stat-card {
    padding: 14px;
    column-gap: 12px;
    border-radius: 18px;
  }

  .home-page .home-community-stat-card__icon {
    width: 46px;
    height: 46px;
    border-radius: 16px;
  }

  .home-page .home-community-stat-card__icon svg {
    width: 23px;
    height: 23px;
  }

  .home-page .home-community-stat-card__hint {
    font-size: .86rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .home-page .home-community-stats *,
  .home-page .home-community-stats *::before,
  .home-page .home-community-stats *::after {
    transition: none !important;
    animation: none !important;
  }

  .home-page .home-community-stats__btn:hover {
    transform: none;
  }
}