/* Доп. стили портала поверх m3.css */

.qr {
  border-radius: var(--md-sys-shape-corner-medium);
  background: #fff;
  padding: 8px;
  align-self: center;
}

.tg-login {
  display: flex;
  justify-content: center;
  min-height: 48px;
}

.brand .material-symbols-outlined {
  color: var(--md-sys-color-primary);
}

/* Логотип в шапке */
.brand__logo {
  width: 32px;
  height: 32px;
  display: block;
  object-fit: contain;
}

/* Логотип на странице входа */
.hero-logo {
  width: 96px;
  height: 96px;
  object-fit: contain;
  align-self: center;
}

.hero-icon {
  font-size: 48px;
  color: var(--md-sys-color-primary);
}

/* Бренд-ссылка в шапке */
.brand {
  display: flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  color: inherit;
}

/* ---------- Лендинг ---------- */
.landing { gap: 40px; padding-bottom: 8px; }
/* Лендинг шире обычного контейнера */
.m3-container:has(.landing) { max-width: 1040px; }

.hero {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  padding: 48px 24px;
}
.hero .body-large { max-width: 560px; }
.hero__cta { justify-content: center; margin-top: 8px; }

.features {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
}
.feature { display: flex; flex-direction: column; gap: 8px; }
.feature__icon { font-size: 32px; color: var(--md-sys-color-primary); }
.feature h3 { margin: 0; }

.tariffs__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 16px;
}
.tariff { display: flex; flex-direction: column; gap: 14px; }
.tariff--featured { border: 2px solid var(--md-sys-color-primary); }
.tariff__price { display: flex; align-items: baseline; gap: 8px; }
.tariff__price .body-medium { color: var(--md-sys-color-on-surface-variant); }
.tariff__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.tariff__list li {
  display: flex; align-items: center; gap: 8px;
  color: var(--md-sys-color-on-surface-variant);
}
.tariff__list .material-symbols-outlined { color: var(--md-sys-color-primary); font-size: 20px; }

.steps__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 16px;
}
.step { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 10px; }
.step__num {
  width: 40px; height: 40px; border-radius: var(--md-sys-shape-corner-full);
  background: var(--md-sys-color-primary); color: var(--md-sys-color-on-primary);
  display: flex; align-items: center; justify-content: center; font-weight: 600;
}

.m3-footer {
  text-align: center;
  padding: 24px 16px 32px;
  color: var(--md-sys-color-on-surface-variant);
}

/* ---------- Dashboard (M3 Expressive) ---------- */
.m3-container:has(.dashboard) {
  max-width: 880px;
  /* Вертикальное центрирование в свободной высоте (минус appbar и footer) */
  min-height: calc(100dvh - 64px - 96px);
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.dashboard { gap: 16px; width: 100%; }

.dash-grid {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 16px;
  align-items: start;
}
/* Если карточка статуса одна (нет ссылки) — растянуть и центрировать */
.dash-grid > .dash-status:only-child {
  grid-column: 1 / -1;
  max-width: 460px;
  margin: 0 auto;
}
@media (max-width: 719px) {
  .dash-grid { grid-template-columns: 1fr; }
}

.dash-status,
.dash-conn {
  display: flex;
  flex-direction: column;
  gap: 14px;
  border-radius: var(--md-sys-shape-corner-extra-large); /* 28dp — выразительная форма */
  padding: 20px;
}
.dash-status { background: var(--md-sys-color-surface-container); }
.dash-conn { background: var(--md-sys-color-surface-container-low); }
.dash-status__head { gap: 8px; }

/* Кольцо использования трафика (conic-gradient донат) */
.ring {
  position: relative;
  width: 168px;
  height: 168px;
  margin: 4px auto 0;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: conic-gradient(
    var(--md-sys-color-primary) calc(var(--p, 0) * 1%),
    var(--md-sys-color-surface-container-highest) 0
  );
}
.ring::before {
  content: "";
  position: absolute;
  inset: 16px;
  border-radius: 50%;
  background: var(--md-sys-color-surface-container);
}
.ring__center {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  line-height: 1.1;
}
.ring__used { font: 600 24px/1.1 var(--md-sys-typescale-font); }
.ring__limit { font: 400 13px/1.4 var(--md-sys-typescale-font); color: var(--md-sys-color-on-surface-variant); }

.ring--infinite {
  background: var(--md-sys-color-primary-container);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
}
.ring--infinite::before { display: none; }
.ring__inf { font-size: 56px; color: var(--md-sys-color-on-primary-container); }
.ring__cap { font: 500 14px/1 var(--md-sys-typescale-font); color: var(--md-sys-color-on-primary-container); }

.dash-meta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin: 0;
  color: var(--md-sys-color-on-surface-variant);
  font: 400 14px/1.4 var(--md-sys-typescale-font);
}
.dash-meta .material-symbols-outlined { font-size: 18px; }

/* Компактная карточка подключения: QR слева, ссылка+кнопки справа */
.conn-row { display: flex; gap: 16px; align-items: center; }
.qr--sm { width: 128px; height: 128px; flex: 0 0 auto; }
.conn-right { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 10px; }
.conn-actions { display: flex; flex-direction: column; gap: 8px; }
.code-box--clip { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
@media (max-width: 380px) {
  .conn-row { flex-direction: column; }
  .qr--sm { align-self: center; }
}

/* Диалог инструкции */
.m3-dialog {
  border: none;
  border-radius: var(--md-sys-shape-corner-extra-large);
  background: var(--md-sys-color-surface-container-high);
  color: var(--md-sys-color-on-surface);
  padding: 24px;
  max-width: 480px;
  width: calc(100% - 32px);
}
.m3-dialog::backdrop { background: rgba(0, 0, 0, .5); }
.m3-dialog__head { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.m3-dialog__head h2 { margin: 0; }
.howto-tabs { display: flex; flex-wrap: wrap; gap: 8px; margin: 14px 0; }
.howto-tabs .m3-chip { cursor: pointer; border: none; font: 500 14px/20px var(--md-sys-typescale-font); }
.howto-tabs .m3-chip.active { background: var(--md-sys-color-primary); color: var(--md-sys-color-on-primary); }
.howto-body { display: flex; flex-direction: column; gap: 8px; }
.howto-body p { margin: 0; }
.howto-body ol { margin: 4px 0 0; padding-left: 20px; display: flex; flex-direction: column; gap: 6px; }
.m3-dialog__actions { display: flex; justify-content: flex-end; flex-wrap: wrap; gap: 8px; margin-top: 16px; }

.chip--warn { background: var(--md-sys-color-error-container); color: var(--md-sys-color-on-error-container); }

/* Крупная выразительная кнопка */
.m3-btn--lg { height: 48px; font-size: 15px; margin-top: 2px; }
