/* site.css — футер (для index/terms/privacy) + типографика юр-страниц.
   Использует бренд-токены из brand.css (--mh-*). brand.css не трогаем. */

/* ───────── Футер (общий) ───────── */
.site-footer {
  background: var(--mh-ink);
  color: #fff;
  margin-top: 64px;
}
.site-footer .foot-wrap {
  max-width: 1120px;
  margin: 0 auto;
  padding: 40px 28px 48px;
  font-family: var(--mh-font);
}
.site-footer .foot-brand-line {
  font-size: 15px; line-height: 1.5; color: #fff; margin-bottom: 18px;
}
.site-footer .foot-brand-line strong { font-weight: 800; }
.site-footer .foot-brand-line span { color: rgba(255, 255, 255, 0.66); }
.site-footer .foot-links {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 28px;
  align-items: center;
  margin-bottom: 20px;
}
.site-footer .foot-links a {
  color: #fff;
  text-decoration: none;
  font-size: 14.5px;
  font-weight: 600;
  border-bottom: 1px solid rgba(255, 255, 255, 0.35);
  padding-bottom: 1px;
}
.site-footer .foot-links a:hover { border-bottom-color: #fff; }
.site-footer .foot-legal {
  font-size: 12.5px;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.74);
  max-width: 760px;
}
.site-footer .foot-legal strong { color: rgba(255, 255, 255, 0.92); font-weight: 700; }

@media (max-width: 560px) {
  .site-footer .foot-links { flex-direction: column; align-items: flex-start; gap: 12px; }
  .site-footer .foot-wrap { padding: 32px 18px 40px; }
}

/* ───────── Юридическая страница ───────── */
.legal-topbar {
  position: sticky; top: 0; z-index: 10;
  background: rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(14px) saturate(180%);
  border-bottom: 1px solid var(--mh-line);
}
.legal-topbar .tb-wrap {
  max-width: 760px; margin: 0 auto; padding: 14px 24px;
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--mh-font);
}
.legal-topbar .tb-brand { font-weight: 800; font-size: 18px; color: var(--mh-ink); text-decoration: none; }
.legal-topbar .tb-brand em { color: var(--mh-teal); font-style: normal; }
.legal-topbar .tb-home { color: var(--mh-teal); text-decoration: none; font-size: 14.5px; font-weight: 600; }

.legal-wrap {
  max-width: 760px; margin: 0 auto; padding: 36px 24px 8px;
  font-family: var(--mh-font); color: var(--mh-ink);
  font-size: 16px; line-height: 1.65;
}
.legal-wrap h1 {
  font-family: var(--mh-serif); font-weight: 600; font-size: clamp(28px, 5vw, 38px);
  line-height: 1.15; margin: 0 0 6px;
}
.legal-wrap .legal-meta { color: var(--mh-muted); font-size: 14px; margin: 0 0 28px; }
.legal-wrap h2 {
  font-size: 21px; font-weight: 700; margin: 34px 0 12px; line-height: 1.25;
}
.legal-wrap h3 { font-size: 17px; font-weight: 700; margin: 22px 0 8px; }
.legal-wrap p { margin: 0 0 14px; }
.legal-wrap ul, .legal-wrap ol { margin: 0 0 16px; padding-left: 22px; }
.legal-wrap li { margin: 0 0 8px; }
.legal-wrap a { color: var(--mh-teal); }
.legal-wrap strong { font-weight: 700; }
.legal-wrap code {
  font-family: var(--mh-mono); font-size: 0.92em;
  background: var(--mh-paper, #f2f2f7); padding: 1px 6px; border-radius: 6px;
}
.legal-wrap table {
  width: 100%; border-collapse: collapse; margin: 0 0 18px; font-size: 15px;
}
.legal-wrap th, .legal-wrap td {
  text-align: left; padding: 10px 14px; border: 1px solid var(--mh-line); vertical-align: top;
}
.legal-wrap th { background: var(--mh-paper, #f2f2f7); font-weight: 700; }
.legal-wrap .legal-entity {
  margin: 8px 0 18px; padding: 16px 18px; border: 1px solid var(--mh-line);
  border-radius: var(--mh-r-md, 14px); background: var(--mh-paper, #f7f7fa); font-size: 15px; line-height: 1.6;
}
.legal-wrap .cross {
  margin: 28px 0 8px; padding-top: 18px; border-top: 1px solid var(--mh-line); font-size: 15px;
}
.legal-wrap .legal-disclaimer {
  margin: 0 0 22px; padding: 12px 16px; font-size: 14px; line-height: 1.55;
  background: var(--mh-warn-soft, #fff4e5); border: 1px solid var(--mh-line);
  border-radius: var(--mh-r-md, 14px); color: var(--mh-ink-2, #48484A);
}

/* ───────── Переключатель языка (выпадающее меню, без JS: <details>) ───────── */
.lang-switch { position: relative; display: inline-block; }
.lang-switch > summary.lang-current {
  list-style: none; cursor: pointer; user-select: none;
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--mh-font); font-size: 13px; font-weight: 700; letter-spacing: 0.02em;
  color: var(--mh-ink); background: transparent;
  padding: 7px 12px; border: 1px solid var(--mh-line); border-radius: 999px; line-height: 1;
}
.lang-switch > summary.lang-current::-webkit-details-marker { display: none; }
.lang-switch > summary.lang-current::after {
  content: "▾"; font-size: 10px; color: var(--mh-muted, #8E8E93); transition: transform .15s;
}
.lang-switch[open] > summary.lang-current { background: var(--mh-paper, #f2f2f7); }
.lang-switch[open] > summary.lang-current::after { transform: rotate(180deg); }
.lang-switch .lang-menu {
  position: absolute; right: 0; top: calc(100% + 6px); z-index: 60;
  display: flex; flex-direction: column; min-width: 132px; padding: 6px;
  background: #fff; border: 1px solid var(--mh-line); border-radius: var(--mh-r-md, 14px);
  box-shadow: var(--mh-shadow-md, 0 8px 28px rgba(0,0,0,.14));
}
.lang-switch .lang-link {
  display: block; padding: 9px 12px; border-radius: 9px; line-height: 1.1;
  font-family: var(--mh-font); font-size: 14px; font-weight: 600;
  color: var(--mh-ink); text-decoration: none; white-space: nowrap;
}
.lang-switch .lang-link:hover { background: var(--mh-paper, #f2f2f7); }
.lang-switch .lang-link.active { color: var(--mh-teal); background: var(--mh-teal-soft, #e8f0ff); }
.legal-topbar .tb-right { display: flex; align-items: center; gap: 10px; }
@media (max-width: 560px) {
  .lang-switch > summary.lang-current { padding: 6px 10px; font-size: 12.5px; }
  .legal-topbar .tb-right { gap: 6px; }
}
