/* ==================== Design Tokens ==================== */
:root {
  --color-primary: #ed1c23;
  --color-primary-hover: #cf171d;
  --color-primary-active: #b71318;
  --color-primary-soft: #fdebed;
  --color-primary-glow: rgba(237, 28, 35, 0.18);

  --color-text-strong: #161215;
  --color-text-main: #40373c;
  --color-text-muted: #73686e;
  --color-text-inverse: #ffffff;

  --color-line-soft: #e7ecf2;
  --color-line-strong: #d8dfe8;

  --surface-base: #ffffff;
  --surface-raised: #fbfcfe;
  --surface-premium: #f6f8fb;
  --surface-tint: #f8fafc;
  --surface-panel: rgba(255, 255, 255, 0.96);

  --bg-body: linear-gradient(180deg, #fcfdfe 0%, #f5f7fa 100%);
  --bg-surface-soft: linear-gradient(180deg, var(--surface-base) 0%, var(--surface-raised) 100%);
  --bg-header: rgba(255, 255, 255, 0.86);
  --bg-overlay: rgba(18, 14, 16, 0.56);

  --font-family-base: "Montserrat", "Segoe UI", Roboto, Arial, sans-serif;

  --font-size-h1: clamp(2.2rem, 1.7vw + 1.5rem, 3.35rem);
  --font-size-h2: clamp(1.58rem, 1vw + 1rem, 2.15rem);
  --font-size-h3: clamp(1.14rem, 0.55vw + 0.92rem, 1.34rem);
  --font-size-section-title: clamp(1.22rem, 0.42vw + 1.04rem, 1.48rem);
  --font-size-card-title: clamp(1.02rem, 0.26vw + 0.96rem, 1.16rem);
  --font-size-body: 0.95rem;
  --font-size-small: 0.84rem;

  --line-height-tight: 1.15;
  --line-height-heading: 1.22;
  --line-height-body: 1.72;

  --weight-regular: 400;
  --weight-medium: 500;
  --weight-semibold: 600;
  --weight-bold: 700;

  --tracking-display: -0.026em;
  --tracking-heading: -0.014em;

  --flow-2xs: 0.25rem;
  --flow-xs: 0.5rem;
  --flow-sm: 0.75rem;
  --flow-md: 1rem;
  --flow-lg: 1.5rem;
  --flow-xl: 2.25rem;
  --flow-2xl: 3rem;
  --flow-3xl: 4.5rem;

  --space-shell-gap: clamp(1.8rem, 1.15vw + 1.1rem, 2.75rem);
  --space-stack-gap: clamp(2.25rem, 1.65vw + 1.2rem, 3.5rem);
  --space-grid-gap: clamp(1.1rem, 0.72vw + 0.86rem, 1.42rem);
  --space-card-padding: clamp(1.35rem, 0.9vw + 1rem, 1.8rem);
  --space-panel-padding: clamp(1.85rem, 1.25vw + 1.1rem, 2.7rem);

  --rhythm-listing: clamp(3rem, 2.1vw + 1.6rem, 4.5rem);
  --rhythm-content: clamp(3.8rem, 2.7vw + 1.9rem, 5.8rem);
  --prefooter-listing: clamp(8rem, 5vw + 3.4rem, 10rem);
  --prefooter-content: clamp(8.8rem, 5.4vw + 3.8rem, 11rem);

  --radius-sm: 8px;
  --radius-md: 11px;
  --radius-lg: 16px;
  --radius-xl: 22px;
  --radius-pill: 999px;

  --shadow-soft: 0 14px 28px -30px rgba(17, 13, 15, 0.16);
  --shadow-mid: 0 20px 40px -32px rgba(17, 13, 15, 0.2);
  --shadow-strong: 0 28px 56px -40px rgba(17, 13, 15, 0.24);

  --motion-fast: 180ms cubic-bezier(0.4, 0, 0.2, 1);
  --motion-base: 240ms cubic-bezier(0.4, 0, 0.2, 1);
  --motion-smooth: 320ms cubic-bezier(0.22, 1, 0.36, 1);

  --container-width: 1440px;
  --container-padding: clamp(16px, 2vw, 32px);
  --content-wide-width: var(--container-width);

  --measure-reading: 74ch;
  --measure-document: 80ch;
  --measure-legal: 102ch;

  --media-ratio-news: 16 / 10;
}

/* ==================== Public Materials Release ==================== */
.materials-nav-shell {
  display: grid;
  gap: 0.78rem;
  padding: clamp(1rem, 1vw + 0.72rem, 1.24rem);
  border: 1px solid var(--color-line-soft);
  border-radius: clamp(1rem, 1.8vw, 1.4rem);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 250, 253, 0.96));
  box-shadow: var(--shadow-soft);
}

.materials-nav-shell__label {
  font-size: 0.74rem;
  line-height: 1.1;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: var(--weight-semibold);
  color: var(--color-text-muted);
}

.materials-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.62rem;
}

.materials-tab {
  flex: 1 1 220px;
  min-height: 46px;
  padding: 0.82rem 1rem;
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-line-soft);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 12px 24px -24px rgba(17, 13, 15, 0.18);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  transition: transform var(--motion-base), border-color var(--motion-base), background var(--motion-base), box-shadow var(--motion-base), color var(--motion-base);
}

.materials-tab:hover {
  transform: translateY(-1px);
  border-color: var(--color-line-strong);
  background: #ffffff;
  box-shadow: 0 16px 28px -26px rgba(17, 13, 15, 0.2);
}

.materials-tab[aria-current="page"] {
  color: var(--color-text-inverse);
  border-color: transparent;
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover));
  box-shadow: 0 18px 30px -22px var(--color-primary-glow);
}

.materials-tab__label {
  font-size: 0.92rem;
  line-height: 1.24;
  font-weight: var(--weight-semibold);
  color: inherit;
}

.materials-tab__meta {
  display: none;
}

.summary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(18.5rem, 100%), 1fr));
  gap: var(--space-grid-gap);
}

.summary-card,
.section-card,
.curriculum-card,
.resource-card,
.stat-card,
.anchor-card {
  min-height: 100%;
  border: 1px solid var(--color-line-soft);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 20px 36px -34px rgba(17, 13, 15, 0.18);
}

.summary-card,
.section-card,
.resource-card,
.anchor-card {
  padding: var(--space-card-padding);
  display: grid;
  align-content: start;
  gap: 0.28rem;
}

.summary-card,
.resource-card,
.anchor-card,
.landing-highlight-card {
  grid-template-rows: auto auto minmax(0, 1fr) auto;
}

.summary-card__eyebrow,
.resource-card__eyebrow,
.curriculum-card__time {
  display: block;
  font-size: 0.72rem;
  line-height: 1.1;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: var(--weight-semibold);
  color: var(--color-primary-hover);
}

.summary-card__title,
.anchor-card__title,
.resource-card__title,
.section-card h3,
.curriculum-card__title {
  margin: 0.45rem 0 0;
  font-size: var(--font-size-card-title);
  line-height: 1.34;
  font-weight: var(--weight-semibold);
  letter-spacing: -0.012em;
  color: var(--color-text-strong);
  text-wrap: balance;
}

.section-card h2 {
  margin: 0.45rem 0 0;
  font-size: var(--font-size-section-title);
  line-height: 1.28;
  font-weight: var(--weight-bold);
  letter-spacing: -0.014em;
  color: var(--color-text-strong);
  text-wrap: balance;
}

.summary-card p,
.section-card p,
.resource-card p,
.curriculum-card p {
  margin: 0.86rem 0 0;
  color: var(--color-text-main);
  line-height: 1.72;
}

.section-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(21rem, 100%), 1fr));
  gap: var(--space-grid-gap);
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(1rem, 0.55vw + 0.82rem, 1.25rem);
}

.stat-card {
  padding: clamp(1.22rem, 0.7vw + 0.98rem, 1.48rem);
}

.stat-card__label {
  display: block;
  font-size: 0.78rem;
  line-height: 1.1;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
  font-weight: var(--weight-semibold);
}

.stat-card__value {
  display: block;
  margin-top: 0.45rem;
  color: var(--color-text-strong);
  font-size: 1rem;
  line-height: 1.4;
  font-weight: var(--weight-semibold);
}

.bullet-list,
.pill-list {
  margin: 0.95rem 0 0;
  padding-left: 1.15rem;
  color: var(--color-text-main);
}

.bullet-list li + li {
  margin-top: 0.5rem;
}

.pill-list {
  padding-left: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 0.62rem;
}

.pill-list li {
  padding: 0.5rem 0.75rem;
  border-radius: 999px;
  background: rgba(239, 247, 252, 0.95);
  border: 1px solid rgba(38, 84, 124, 0.14);
  color: var(--color-text-strong);
  font-size: 0.9rem;
  line-height: 1.35;
}

.curriculum-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(21rem, 100%), 1fr));
  gap: var(--space-grid-gap);
}

.curriculum-card {
  padding: var(--space-card-padding);
}

.curriculum-card__time {
  margin-bottom: 0.45rem;
}

.resource-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(18.5rem, 100%), 1fr));
  gap: var(--space-grid-gap);
}

.resource-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: auto;
  padding-top: 1rem;
}

.resource-anchor-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(21rem, 100%), 1fr));
  gap: var(--space-grid-gap);
}

.anchor-card__title {
  margin: 0;
  color: var(--color-text-strong);
}

.anchor-card p {
  margin: 0;
}

.anchor-card__link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  width: fit-content;
  margin-top: auto;
  padding-top: 1rem;
  color: var(--color-primary-hover);
  font-weight: var(--weight-semibold);
}

.anchor-card__link::after {
  content: "→";
}

.material-files__lead {
  margin: 0 0 1.12rem;
  color: var(--color-text-main);
}

.legacy-card {
  max-width: 760px;
}

@media (max-width: 1100px) {
  .stats-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .resource-grid,
  .summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 820px) {
  .summary-grid,
  .section-grid,
  .curriculum-grid,
  .resource-grid,
  .resource-anchor-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .stats-grid {
    grid-template-columns: 1fr;
  }

  .materials-tabs {
    flex-direction: column;
  }

  .materials-tab {
    width: 100%;
    flex-basis: auto;
  }

  .materials-tab,
  .summary-card,
  .section-card,
  .resource-card,
  .curriculum-card,
  .anchor-card,
  .materials-nav-shell {
    padding: 0.95rem;
  }
}

/* ==================== Reset ==================== */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
}

body {
  min-height: 100vh;
  background: var(--bg-body);
  color: var(--color-text-main);
  font-family: var(--font-family-base);
  font-size: var(--font-size-body);
  line-height: var(--line-height-body);
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

body.nav-lock {
  overflow: hidden;
}

body.lightbox-open {
  overflow: hidden;
}

body.modal-open {
  overflow: hidden;
}

img,
svg {
  display: block;
  max-width: 100%;
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input,
textarea,
select {
  color: inherit;
  font: inherit;
}

button {
  border: 0;
  background: none;
  cursor: pointer;
}

:focus {
  outline: none;
}

:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}

[hidden] {
  display: none !important;
}

/* ==================== Typography ==================== */
h1,
h2,
h3,
h4 {
  color: var(--color-text-strong);
}

h1 {
  font-size: var(--font-size-h1);
  line-height: var(--line-height-tight);
  letter-spacing: var(--tracking-display);
  font-weight: var(--weight-bold);
}

h2 {
  font-size: var(--font-size-h2);
  line-height: var(--line-height-heading);
  letter-spacing: var(--tracking-heading);
  font-weight: var(--weight-semibold);
}

h3,
h4 {
  font-size: var(--font-size-h3);
  line-height: 1.34;
  font-weight: var(--weight-semibold);
  letter-spacing: -0.01em;
}

p,
li,
div {
  color: var(--color-text-main);
}

small,
time {
  font-size: var(--font-size-small);
  color: var(--color-text-muted);
}

/* ==================== Utilities ==================== */
.container {
  width: 100%;
  max-width: calc(var(--container-width) + (var(--container-padding) * 2));
  margin-inline: auto;
  padding-inline: var(--container-padding);
}

.layout-shell {
  display: grid;
  gap: var(--space-shell-gap);
}

.content-stack {
  display: grid;
  gap: var(--space-stack-gap);
}

.section-head {
  max-width: 76ch;
  display: grid;
  gap: 0.72rem;
}

.reading-measure {
  max-width: var(--measure-reading);
}

.surface-tier-1 {
  background: var(--surface-base);
}

.surface-tier-2 {
  background: var(--surface-raised);
}

.surface-tier-3 {
  background: var(--surface-premium);
}

.is-hidden {
  display: none !important;
}

/* ==================== Layout ==================== */
.page {
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  --page-rhythm: var(--rhythm-listing);
  --page-breathing: var(--prefooter-listing);
}

.page--about,
.page--main,
.page--home,
.page--news-article,
.page--privacy,
.page--testing,
.page--registration,
.page--terms,
.page--cookie {
  --page-rhythm: var(--rhythm-content);
  --page-breathing: var(--prefooter-content);
}

.page__main {
  flex: 1 0 auto;
  padding-top: clamp(1.9rem, 1.45vw + 1rem, 2.95rem);
  padding-bottom: var(--page-breathing);
}

.section {
  padding-bottom: var(--page-rhythm);
}

.page__main > .section:last-of-type {
  padding-bottom: 0;
}

.cards-grid {
  display: grid;
  gap: clamp(1.55rem, 1.15vw + 0.94rem, 2.35rem);
  align-items: stretch;
}

.cards-grid--news,
.cards-grid--presentations {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.page--news .page-lead__panel,
.page--news .cards-grid--news,
.page--news-article .article-layout {
  max-width: var(--content-wide-width);
  margin-inline: auto;
}

/* ==================== Header ==================== */
.site-header {
  position: sticky;
  top: 0;
  z-index: 80;
  border-bottom: 1px solid rgba(216, 223, 232, 0.82);
  background: var(--bg-header);
  box-shadow: 0 14px 34px -32px rgba(17, 13, 15, 0.42);
  backdrop-filter: blur(14px);
}

.site-header__inner {
  min-height: 92px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--flow-lg);
}

.site-brand {
  display: grid;
  gap: 0.16rem;
}

.site-brand__logo {
  width: auto;
  height: 28px;
  object-fit: contain;
}

.site-brand__title {
  font-size: 0.9rem;
  letter-spacing: -0.016em;
  font-weight: var(--weight-bold);
  color: var(--color-text-strong);
}

.site-header__controls {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
  min-width: 0;
  position: relative;
  gap: 0.62rem;
}

.site-nav-toggle {
  display: none;
  width: 44px;
  height: 44px;
  padding: 0;
  border: 1px solid var(--color-line-soft);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.94);
  color: var(--color-text-strong);
  align-items: center;
  justify-content: center;
  box-shadow: 0 14px 30px -26px rgba(17, 13, 15, 0.22);
  transition: background var(--motion-base), border-color var(--motion-base), box-shadow var(--motion-base), transform var(--motion-base);
}

.site-nav-toggle:hover {
  border-color: var(--color-line-strong);
  background: #ffffff;
  transform: translateY(-1px);
}

.site-nav-toggle__bars {
  position: relative;
  display: inline-flex;
  width: 18px;
  height: 14px;
}

.site-nav-toggle__bar {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  border-radius: var(--radius-pill);
  background: currentColor;
  transform-origin: center;
  transition: transform var(--motion-base), opacity var(--motion-base), top var(--motion-base);
}

.site-nav-toggle__bar:nth-child(1) {
  top: 0;
}

.site-nav-toggle__bar:nth-child(2) {
  top: 6px;
}

.site-nav-toggle__bar:nth-child(3) {
  top: 12px;
}

.site-header--menu-open .site-nav-toggle__bar:nth-child(1) {
  top: 6px;
  transform: rotate(45deg);
}

.site-header--menu-open .site-nav-toggle__bar:nth-child(2) {
  opacity: 0;
}

.site-header--menu-open .site-nav-toggle__bar:nth-child(3) {
  top: 6px;
  transform: rotate(-45deg);
}

.micro-nav {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  max-width: 100%;
  min-width: 0;
  gap: 0.34rem;
  padding: 6px;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 14px 30px -28px rgba(17, 13, 15, 0.18);
}

.micro-nav__item {
  position: relative;
  min-width: 0;
}

.micro-nav__item--dropdown::after {
  display: none;
}

.micro-nav__link {
  min-height: 40px;
  padding-inline: 1rem;
  border-radius: var(--radius-pill);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  font-size: 0.82rem;
  font-weight: var(--weight-semibold);
  color: var(--color-text-main);
  transition: transform var(--motion-base), color var(--motion-base), background var(--motion-base), box-shadow var(--motion-base);
}

.micro-nav__link--button {
  border: 0;
  background: transparent;
  gap: 0.46rem;
}

.micro-nav__link--button svg {
  width: 14px;
  height: 14px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: transform var(--motion-base);
}

.micro-nav__link:hover {
  color: var(--color-text-strong);
  background: #f6f8fb;
  transform: translateY(-1px);
}

.micro-nav__item--dropdown.micro-nav__item--open > .micro-nav__link--button svg,
.micro-nav__item--dropdown.micro-nav__item--active > .micro-nav__link--button svg {
  transform: rotate(180deg);
}

.micro-nav__link--active,
.micro-nav__link[aria-current="page"],
.micro-nav__item--active > .micro-nav__link,
.micro-nav__item--active > .micro-nav__link--button {
  color: var(--color-text-inverse);
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover));
  box-shadow: 0 16px 30px -20px var(--color-primary-glow);
}

.micro-nav__dropdown {
  position: absolute;
  top: calc(100% + 0.72rem);
  left: 0;
  min-width: 232px;
  width: min(340px, calc(100vw - 2rem));
  padding: 0.72rem;
  border: 1px solid var(--color-line-soft);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: var(--shadow-mid);
  backdrop-filter: blur(10px);
  display: none;
  gap: 0.24rem;
  opacity: 0;
  visibility: hidden;
  transform: translateY(6px);
  pointer-events: none;
  transition: opacity var(--motion-base), transform var(--motion-base), visibility var(--motion-base);
  z-index: 90;
}

.micro-nav__dropdown--root {
  right: 0;
  left: auto;
  overflow: hidden;
}

.micro-nav__item--dropdown.micro-nav__item--open > .micro-nav__dropdown {
  display: grid;
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

.micro-nav__dropdown-link {
  min-height: 42px;
  padding: 0.74rem 0.92rem;
  border-radius: 12px;
  display: flex;
  align-items: center;
  font-size: 0.82rem;
  font-weight: var(--weight-semibold);
  color: var(--color-text-main);
  transition: color var(--motion-base), background var(--motion-base), transform var(--motion-base);
}

.micro-nav__dropdown-link--button {
  width: 100%;
  justify-content: space-between;
  border: 0;
  background: transparent;
  text-align: left;
}

.micro-nav__dropdown-link--button svg {
  width: 14px;
  height: 14px;
  flex: 0 0 auto;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: transform var(--motion-base);
}

.micro-nav__dropdown-link:hover {
  color: var(--color-text-strong);
  background: #f6f8fb;
  transform: translateY(-1px);
}

.micro-nav__dropdown-link--active,
.micro-nav__dropdown-link[aria-current="page"],
.micro-nav__subgroup--active > .micro-nav__dropdown-link--button {
  color: var(--color-primary-hover);
  background: #fff5f6;
}

.micro-nav__section {
  display: grid;
  gap: 0.28rem;
  margin-top: 0.18rem;
  padding-top: 0.42rem;
  border-top: 1px solid rgba(217, 224, 236, 0.78);
}

.micro-nav__section-label {
  padding: 0.12rem 0.92rem 0.02rem;
  color: #8b7f86;
  font-size: 0.7rem;
  font-weight: var(--weight-semibold);
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.micro-nav__subgroup {
  display: grid;
  gap: 0.28rem;
  margin-top: 0.18rem;
  padding-top: 0.42rem;
  border-top: 1px solid rgba(217, 224, 236, 0.78);
}

.micro-nav__subgroup::after {
  display: none;
}

.micro-nav__subgroup.micro-nav__subgroup--open > .micro-nav__dropdown-link--button svg,
.micro-nav__subgroup.micro-nav__subgroup--active > .micro-nav__dropdown-link--button svg {
  transform: rotate(90deg);
}

.micro-nav__dropdown--sub {
  position: static;
  top: auto;
  left: auto;
  right: auto;
  width: 100%;
  min-width: 0;
  margin-top: 0;
  padding: 0.1rem 0 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  transform: none;
}

.micro-nav__subgroup.micro-nav__subgroup--open > .micro-nav__dropdown--sub,
.micro-nav__subgroup.micro-nav__subgroup--active > .micro-nav__dropdown--sub {
  display: grid;
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

/* ==================== Breadcrumbs ==================== */
.page-crumbs {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 0.9rem;
  font-size: 0.78rem;
  font-weight: var(--weight-semibold);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.page-crumbs a,
.page-crumbs span {
  color: inherit;
}

.page-crumbs a {
  transition: color var(--motion-base);
}

.page-crumbs a:hover {
  color: var(--color-primary-hover);
}

.page-crumbs__sep {
  color: var(--color-line-strong);
}

/* ==================== Page Lead ==================== */
.page-lead {
  margin-bottom: clamp(2.7rem, 2.15vw + 1.2rem, 3.9rem);
}

.page-lead__panel {
  display: grid;
  gap: clamp(0.95rem, 0.55vw + 0.78rem, 1.22rem);
  max-width: var(--content-wide-width);
  margin-inline: auto;
  padding-bottom: clamp(1.7rem, 1.1vw + 0.9rem, 2.3rem);
  border-bottom: 1px solid rgba(23, 19, 22, 0.1);
}

.page-lead__eyebrow {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 1.85rem;
  padding: 0.18rem 0;
  font-size: 0.78rem;
  line-height: 1.1;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: var(--weight-semibold);
  color: var(--color-primary-hover);
}

.page-lead__title {
  display: inline-flex;
  align-items: center;
  gap: 0.76rem;
  text-wrap: balance;
}

.page-lead__title::before {
  content: "";
  width: 28px;
  height: 3px;
  border-radius: var(--radius-pill);
  background: var(--color-primary);
  flex: 0 0 auto;
}

.page-lead__description {
  max-width: 66ch;
  font-size: 0.96rem;
  line-height: 1.8;
  color: var(--color-text-main);
}

.page-lead__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
  padding-top: 0.2rem;
}

.page-lead__actions .button {
  min-width: 220px;
}

/* ==================== Buttons ==================== */
.button {
  min-height: 44px;
  border: 1px solid transparent;
  border-radius: var(--radius-pill);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--flow-xs);
  padding: 0.66rem 1.26rem;
  font-size: 0.85rem;
  line-height: 1.2;
  font-weight: var(--weight-semibold);
  transition: transform var(--motion-fast), background var(--motion-base), color var(--motion-base), border-color var(--motion-base), box-shadow var(--motion-base);
}

.button:hover {
  transform: translateY(-1px);
}

.button:active {
  transform: scale(0.985);
}

.button--primary {
  color: var(--color-text-inverse);
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover));
  box-shadow: 0 18px 32px -20px var(--color-primary-glow);
}

.button--primary:hover {
  background: linear-gradient(135deg, var(--color-primary-hover), var(--color-primary-active));
}

.button--secondary {
  color: var(--color-primary-hover);
  border-color: var(--color-line-strong);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 12px 24px -24px rgba(17, 13, 15, 0.16);
}

.button--secondary:hover {
  color: var(--color-primary-active);
  border-color: var(--color-line-strong);
  background: var(--surface-raised);
}

.button--ghost {
  color: var(--color-text-main);
  border-color: var(--color-line-soft);
  background: #ffffff;
  box-shadow: 0 12px 24px -24px rgba(17, 13, 15, 0.16);
}

.button--ghost:hover {
  color: var(--color-text-strong);
  border-color: var(--color-line-strong);
  background: #fbfcfe;
}

.button__icon {
  width: 1rem;
  height: 1rem;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.72;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-line-soft);
  background: #f8fafc;
  color: var(--color-primary-hover);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-size: 0.72rem;
  font-weight: var(--weight-semibold);
}

/* ==================== Events Calendar ==================== */
.events-calendar {
  scroll-margin-top: 110px;
  display: grid;
  gap: clamp(1.15rem, 1.4vw, 1.75rem);
  padding: var(--space-panel-padding);
  border: 1px solid var(--color-line-soft);
  border-radius: clamp(1.15rem, 2.4vw, 1.75rem);
  background:
    radial-gradient(circle at top right, rgba(237, 28, 35, 0.055), transparent 30%),
    var(--bg-surface-soft);
  box-shadow: var(--shadow-mid);
}

.events-calendar__header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(240px, 0.36fr);
  gap: var(--space-grid-gap);
  align-items: start;
}

.events-calendar__eyebrow,
.events-calendar__details-eyebrow,
.event-detail-card__eyebrow,
.event-modal__eyebrow {
  display: block;
  margin: 0 0 0.42rem;
  font-size: 0.72rem;
  line-height: 1.1;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: var(--weight-semibold);
  color: var(--color-primary-hover);
}

.events-calendar__header h2 {
  margin: 0;
  font-size: var(--font-size-h2);
  line-height: var(--line-height-heading);
  letter-spacing: var(--tracking-heading);
}

.events-calendar__note {
  margin: 0;
  max-width: 34ch;
  justify-self: end;
  font-size: 0.86rem;
  line-height: 1.62;
  color: var(--color-text-muted);
}

.events-calendar__controls {
  display: grid;
  gap: 0.92rem;
  padding: clamp(0.9rem, 1vw, 1.15rem);
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 14px 28px -30px rgba(17, 13, 15, 0.18);
}

.events-calendar__filter-group {
  display: grid;
  gap: 0.58rem;
}

.events-calendar__filters {
  display: flex;
  flex-wrap: wrap;
  gap: 0.48rem;
}

.events-filter {
  min-height: 38px;
  padding: 0.55rem 0.86rem;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.88);
  color: var(--color-text-main);
  font-size: 0.78rem;
  line-height: 1.2;
  font-weight: var(--weight-semibold);
  transition: color var(--motion-base), background var(--motion-base), border-color var(--motion-base), box-shadow var(--motion-base), transform var(--motion-fast);
}

.events-filter:hover {
  transform: translateY(-1px);
  border-color: var(--color-line-strong);
  color: var(--color-text-strong);
  background: #ffffff;
}

.events-filter--active {
  color: var(--color-text-inverse);
  border-color: transparent;
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover));
  box-shadow: 0 16px 28px -22px var(--color-primary-glow);
}

.events-calendar__search {
  display: grid;
  grid-template-columns: minmax(8.5rem, auto) minmax(0, 1fr);
  gap: 0.75rem;
  align-items: center;
  max-width: 100%;
}

.events-calendar__search-label,
.events-calendar__control-label,
.event-form__field span {
  font-size: 0.72rem;
  line-height: 1.1;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: var(--weight-semibold);
  color: var(--color-text-muted);
}

.events-calendar__search-input,
.event-form__field input {
  width: 100%;
  min-height: 44px;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.96);
  padding: 0.72rem 1rem;
  color: var(--color-text-strong);
  font-size: 0.88rem;
  line-height: 1.25;
  transition: border-color var(--motion-base), box-shadow var(--motion-base), background var(--motion-base);
}

.events-calendar__search-input::placeholder {
  color: rgba(115, 104, 110, 0.78);
}

.event-form__field input::placeholder {
  color: rgba(115, 104, 110, 0.54);
}

.events-calendar__search-input:focus,
.event-form__field input:focus {
  border-color: rgba(237, 28, 35, 0.34);
  background: #ffffff;
  box-shadow: 0 0 0 4px rgba(237, 28, 35, 0.08);
}

.events-calendar__layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 0.34fr);
  gap: var(--space-grid-gap);
  align-items: start;
}

.events-calendar__months {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 20.5rem), 1fr));
  gap: var(--space-grid-gap);
  align-items: start;
}

.events-calendar__empty,
.events-calendar__details > p {
  margin: 0;
  color: var(--color-text-main);
  font-size: 0.9rem;
  line-height: 1.68;
}

.calendar-month,
.events-calendar__details,
.event-detail-card {
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: var(--shadow-soft);
}

.calendar-month {
  display: grid;
  align-content: start;
  gap: 0.78rem;
  padding: clamp(1rem, 0.8vw + 0.72rem, 1.3rem);
}

.calendar-month__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  padding-bottom: 0.68rem;
  border-bottom: 1px solid rgba(226, 232, 240, 0.88);
}

.calendar-month__header h3 {
  margin: 0;
  font-size: 1.02rem;
  line-height: 1.25;
  font-weight: var(--weight-semibold);
  letter-spacing: -0.01em;
  text-transform: capitalize;
}

.calendar-month__header span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  min-height: 1.65rem;
  padding: 0.26rem 0.58rem;
  border-radius: var(--radius-pill);
  background: var(--surface-premium);
  color: var(--color-text-muted);
  font-size: 0.75rem;
  font-weight: var(--weight-semibold);
}

.calendar-month__days {
  display: grid;
  gap: 0.62rem;
}

.calendar-day {
  display: grid;
  grid-template-columns: 3.25rem minmax(0, 1fr);
  gap: 0.62rem;
  align-items: stretch;
}

.calendar-day__date {
  min-height: 100%;
  border: 1px solid var(--color-line-soft);
  border-radius: 1rem;
  background: var(--surface-tint);
  color: var(--color-text-main);
  display: grid;
  place-items: center;
  padding: 0.45rem 0.3rem;
  transition: color var(--motion-base), border-color var(--motion-base), background var(--motion-base), box-shadow var(--motion-base);
}

.calendar-day__number {
  font-size: 1.1rem;
  line-height: 1;
  font-weight: var(--weight-bold);
  letter-spacing: -0.02em;
}

.calendar-day__weekday {
  font-size: 0.64rem;
  line-height: 1.1;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.calendar-day--active .calendar-day__date,
.calendar-day__date:hover {
  border-color: rgba(237, 28, 35, 0.3);
  background: var(--color-primary-soft);
  color: var(--color-primary-hover);
}

.calendar-day__events {
  display: grid;
  gap: 0.5rem;
}

.calendar-event {
  width: 100%;
  display: grid;
  gap: 0.42rem;
  text-align: left;
  border: 1px solid rgba(226, 232, 240, 0.95);
  border-radius: 1rem;
  background: #ffffff;
  padding: 0.72rem;
  transition: transform var(--motion-fast), border-color var(--motion-base), box-shadow var(--motion-base), background var(--motion-base);
}

.calendar-event:hover,
.calendar-event:focus-visible {
  transform: translateY(-1px);
  border-color: var(--color-line-strong);
  box-shadow: 0 14px 28px -26px rgba(17, 13, 15, 0.18);
}

.calendar-event__title {
  color: var(--color-text-strong);
  font-size: 0.84rem;
  line-height: 1.34;
  font-weight: var(--weight-semibold);
  letter-spacing: -0.006em;
}

.calendar-event__audience {
  color: var(--color-text-muted);
  font-size: 0.74rem;
  line-height: 1.25;
  font-weight: var(--weight-medium);
}

.event-status {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  width: fit-content;
  min-height: 1.5rem;
  padding: 0.26rem 0.56rem;
  border-radius: var(--radius-pill);
  background: #f3f6fa;
  color: var(--color-text-main);
  font-size: 0.72rem;
  line-height: 1.1;
  font-weight: var(--weight-semibold);
}

.event-status--confirmed {
  background: #e8f7ee;
  color: #168348;
}

.event-progress {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.55rem;
  align-items: center;
}

.event-progress__bar {
  height: 0.42rem;
  border-radius: var(--radius-pill);
  background: #eef2f7;
  overflow: hidden;
}

.event-progress__bar span {
  display: block;
  min-width: 0.42rem;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #b8c3d1, #8c99aa);
  opacity: 0.56;
}

.event-progress--confirmed .event-progress__bar span {
  background: linear-gradient(90deg, #2aa867, #168348);
  opacity: 1;
}

.event-progress__count {
  white-space: nowrap;
  color: var(--color-text-muted);
  font-size: 0.72rem;
  line-height: 1.1;
  font-weight: var(--weight-semibold);
}

.events-calendar__details {
  position: sticky;
  top: 112px;
  display: grid;
  gap: 0.9rem;
  padding: clamp(1rem, 0.9vw + 0.76rem, 1.4rem);
}

.events-calendar__details h3,
.event-detail-card h3 {
  margin: 0;
  font-size: var(--font-size-card-title);
  line-height: 1.32;
  font-weight: var(--weight-semibold);
  letter-spacing: -0.01em;
}

.events-calendar__details-list {
  display: grid;
  gap: 0.8rem;
}

.event-detail-card {
  display: grid;
  gap: 0.9rem;
  padding: clamp(0.95rem, 0.8vw + 0.72rem, 1.24rem);
}

.event-detail-card__head {
  display: grid;
  gap: 0.75rem;
}

.event-detail-card p {
  margin: 0;
  color: var(--color-text-main);
  font-size: 0.9rem;
  line-height: 1.68;
}

.event-detail-card .button {
  justify-self: start;
  min-width: 160px;
}

.summary-grid--secondary {
  margin-top: clamp(0.35rem, 0.8vw, 0.9rem);
}

.event-modal {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: grid;
  place-items: center;
  padding: clamp(1rem, 4vw, 2rem);
}

.event-modal__backdrop {
  position: absolute;
  inset: 0;
  background: var(--bg-overlay);
  backdrop-filter: blur(8px);
}

.event-modal__dialog {
  position: relative;
  z-index: 1;
  width: min(100%, 720px);
  max-height: min(760px, calc(100vh - 2rem));
  overflow: auto;
  display: grid;
  gap: 1rem;
  border: 1px solid rgba(231, 236, 242, 0.86);
  border-radius: clamp(1rem, 2.4vw, 1.6rem);
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 28px 68px -34px rgba(17, 13, 15, 0.38);
  padding: clamp(1.15rem, 2vw, 1.7rem);
}

.event-modal__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

.event-modal__header h2 {
  margin: 0;
  font-size: var(--font-size-h3);
  line-height: var(--line-height-heading);
  letter-spacing: var(--tracking-heading);
}

.event-modal__close {
  width: 2.35rem;
  height: 2.35rem;
  border: 1px solid var(--color-line-soft);
  border-radius: 50%;
  background: #ffffff;
  color: var(--color-text-main);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  transition: color var(--motion-base), border-color var(--motion-base), background var(--motion-base);
}

.event-modal__close:hover {
  color: var(--color-primary-hover);
  border-color: rgba(237, 28, 35, 0.24);
  background: var(--color-primary-soft);
}

.event-modal__close svg {
  width: 1rem;
  height: 1rem;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
}

.event-modal__meta {
  margin: 0;
  color: var(--color-text-muted);
  font-size: 0.88rem;
  line-height: 1.55;
}

.event-form {
  display: grid;
  gap: 1rem;
}

.event-form__consent {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  font-size: 0.92rem;
  line-height: 1.45;
}

.event-form__consent input {
  margin-top: 0.2rem;
  flex: 0 0 auto;
  width: 1.05rem;
  height: 1.05rem;
}

.event-form__consent a {
  color: inherit;
  text-decoration: underline;
}

/* Honeypot-ловушка: скрыта от пользователей, но доступна ботам в DOM.
   Стандартный visually-hidden (clip) — не влияет на раскладку и прокрутку. */
.event-form__trap {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  border: 0 !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
}

.event-form__trap input {
  width: 1px !important;
  height: 1px !important;
}

.event-form__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.82rem;
}

.event-form__field {
  display: grid;
  gap: 0.38rem;
}

.event-form__field input {
  border-radius: 1rem;
}

.event-form__message {
  margin: 0;
  border-radius: 1rem;
  padding: 0.78rem 0.9rem;
  font-size: 0.84rem;
  line-height: 1.45;
  font-weight: var(--weight-medium);
}

.event-form__message--success {
  background: #eaf7ef;
  color: #167544;
}

.event-form__message--error {
  background: var(--color-primary-soft);
  color: var(--color-primary-active);
}

.event-form__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  justify-content: flex-end;
  padding-top: 0.2rem;
}

.event-form__actions .button {
  min-width: 180px;
}

.event-form__frame {
  display: none;
}

/* ==================== Events Admin ==================== */
.page--admin-events {
  min-height: 100vh;
}

.admin-page {
  min-height: 100vh;
  padding: clamp(1rem, 3vw, 2.4rem);
}

.admin-login {
  min-height: calc(100vh - clamp(1rem, 3vw, 2.4rem) * 2);
  display: grid;
  place-items: center;
}

.admin-login__panel,
.admin-workspace {
  width: min(100%, 1180px);
  border: 1px solid var(--color-line-soft);
  border-radius: clamp(1.2rem, 2.4vw, 1.8rem);
  background:
    radial-gradient(circle at top right, rgba(237, 28, 35, 0.06), transparent 34%),
    var(--bg-surface-soft);
  box-shadow: var(--shadow-mid);
}

.admin-login__panel {
  max-width: 560px;
  display: grid;
  gap: 1.25rem;
  padding: clamp(1.35rem, 2.2vw, 2rem);
}

.admin-login__brand {
  margin-bottom: 0.25rem;
}

.admin-login__content,
.admin-login__form,
.admin-workspace,
.admin-json,
.admin-events-list {
  display: grid;
  gap: 1rem;
}

.admin-login__content h1,
.admin-workspace__header h1 {
  margin: 0;
  font-size: var(--font-size-h2);
  line-height: var(--line-height-heading);
  letter-spacing: var(--tracking-heading);
}

.admin-login__content p,
.admin-workspace__header p {
  margin: 0;
  max-width: 68ch;
  color: var(--color-text-main);
  font-size: 0.92rem;
  line-height: 1.68;
}

.admin-page__eyebrow {
  margin: 0;
  color: var(--color-primary-hover);
  font-size: 0.72rem;
  line-height: 1.1;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: var(--weight-semibold);
}

.admin-workspace {
  margin-inline: auto;
  padding: clamp(1rem, 2vw, 1.7rem);
}

.admin-workspace__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(226, 232, 240, 0.9);
}

.admin-workspace__actions,
.admin-toolbar,
.admin-event-card__footer {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
}

.admin-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-grid-gap);
}

.admin-summary article {
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.92);
  padding: 1rem;
  display: grid;
  gap: 0.25rem;
}

.admin-summary span {
  color: var(--color-text-muted);
  font-size: 0.76rem;
  line-height: 1.2;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: var(--weight-semibold);
}

.admin-summary strong {
  color: var(--color-text-strong);
  font-size: clamp(1.5rem, 1.5vw, 2rem);
  line-height: 1;
  letter-spacing: -0.03em;
}

.admin-toolbar {
  position: sticky;
  top: 1rem;
  z-index: 20;
  padding: 1rem;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 18px 34px -30px rgba(17, 13, 15, 0.22);
  backdrop-filter: blur(12px);
}

.admin-field {
  display: grid;
  gap: 0.42rem;
}

.admin-field span {
  color: var(--color-text-muted);
  font-size: 0.72rem;
  line-height: 1.1;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: var(--weight-semibold);
}

.admin-field input,
.admin-field select,
.admin-field textarea {
  width: 100%;
  min-height: 44px;
  border: 1px solid var(--color-line-soft);
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.96);
  padding: 0.72rem 0.9rem;
  color: var(--color-text-strong);
  font-size: 0.88rem;
  line-height: 1.45;
  transition: border-color var(--motion-base), box-shadow var(--motion-base), background var(--motion-base);
}

.admin-field textarea {
  resize: vertical;
}

.admin-field input:focus,
.admin-field select:focus,
.admin-field textarea:focus {
  border-color: rgba(237, 28, 35, 0.34);
  background: #ffffff;
  box-shadow: 0 0 0 4px rgba(237, 28, 35, 0.08);
}

.admin-message {
  margin: 0;
  border-radius: 1rem;
  padding: 0.78rem 0.9rem;
  font-size: 0.84rem;
  line-height: 1.45;
  font-weight: var(--weight-medium);
}

.admin-message--success {
  background: #eaf7ef;
  color: #167544;
}

.admin-message--error {
  background: var(--color-primary-soft);
  color: var(--color-primary-active);
}

.admin-json {
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.9);
  padding: 1rem;
}

.admin-events-list {
  gap: var(--space-grid-gap);
}

.admin-event-card {
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.95);
  box-shadow: var(--shadow-soft);
  display: grid;
  gap: 1rem;
  padding: clamp(1rem, 1.1vw, 1.25rem);
}

.admin-event-card__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

.admin-event-card__date {
  display: block;
  margin-bottom: 0.35rem;
  color: var(--color-primary-hover);
  font-size: 0.72rem;
  line-height: 1.1;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: var(--weight-semibold);
}

.admin-event-card h2 {
  margin: 0;
  font-size: var(--font-size-card-title);
  line-height: 1.32;
  font-weight: var(--weight-semibold);
  letter-spacing: -0.01em;
}

.admin-event-card__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.85rem;
}

.admin-field--wide {
  grid-column: span 3;
}

.admin-event-card__footer {
  justify-content: space-between;
  align-items: center;
  padding-top: 0.2rem;
}

.admin-event-card__footer span {
  color: var(--color-text-muted);
  font-size: 0.82rem;
  font-weight: var(--weight-semibold);
}

.admin-delete-button {
  min-height: 38px;
  border: 1px solid rgba(237, 28, 35, 0.2);
  border-radius: var(--radius-pill);
  background: var(--color-primary-soft);
  color: var(--color-primary-active);
  padding: 0.5rem 0.9rem;
  font-size: 0.8rem;
  font-weight: var(--weight-semibold);
  transition: color var(--motion-base), background var(--motion-base), border-color var(--motion-base);
}

.admin-delete-button:hover {
  color: #ffffff;
  border-color: transparent;
  background: var(--color-primary-hover);
}

@media (max-width: 1024px) {
  .events-calendar__layout,
  .events-calendar__header {
    grid-template-columns: 1fr;
  }

  .events-calendar__note {
    justify-self: start;
  }

  .events-calendar__details {
    position: static;
  }

  .admin-workspace__header {
    display: grid;
  }

  .admin-event-card__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .admin-field--wide {
    grid-column: span 2;
  }
}

@media (max-width: 768px) {
  .events-calendar {
    padding: 1rem;
  }

  .events-calendar__search {
    grid-template-columns: 1fr;
    gap: 0.4rem;
  }

  .events-calendar__filters {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 0.25rem;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
  }

  .events-filter {
    flex: 0 0 auto;
  }

  .calendar-day {
    grid-template-columns: 2.8rem minmax(0, 1fr);
  }

  .calendar-event {
    padding: 0.66rem;
  }

  .event-progress {
    grid-template-columns: 1fr;
    gap: 0.36rem;
  }

  .event-detail-card .button,
  .event-form__actions .button {
    width: 100%;
    min-width: 0;
  }

  .event-form__grid {
    grid-template-columns: 1fr;
  }

  .event-form__actions {
    flex-direction: column;
  }

  .admin-page {
    padding: 0.75rem;
  }

  .admin-toolbar {
    top: 0.75rem;
  }

  .admin-summary,
  .admin-event-card__grid {
    grid-template-columns: 1fr;
  }

  .admin-field--wide {
    grid-column: auto;
  }

  .admin-workspace__actions .button,
  .admin-toolbar .button,
  .admin-login__form .button {
    width: 100%;
  }
}

/* ==================== Main Page ==================== */
.landing-section {
  padding-bottom: clamp(5.6rem, 8vw, 8.4rem);
}

.landing-section:last-child {
  padding-bottom: 0;
}

.landing-section__head {
  display: grid;
  gap: 0.82rem;
  margin-bottom: clamp(2.25rem, 2.9vw, 3.4rem);
}

.landing-section__head--center {
  justify-items: center;
  text-align: center;
}

.landing-section__head--center h2 {
  max-width: 20ch;
}

.landing-section--hero .container {
  display: grid;
  justify-items: center;
}

.landing-hero {
  display: grid;
  width: min(100%, 72rem);
  align-items: start;
  border: 1px solid var(--color-line-soft);
  border-radius: clamp(1.25rem, 3vw, 2rem);
  background:
    radial-gradient(circle at top right, rgba(233, 30, 39, 0.08), transparent 28%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(249, 250, 252, 0.96));
  box-shadow: var(--shadow-mid);
  padding: clamp(1.9rem, 2.5vw + 1rem, 3.1rem);
  overflow: hidden;
}

.landing-hero__content {
  position: relative;
  z-index: 1;
  display: grid;
  gap: clamp(1.5rem, 1.4vw + 1rem, 2rem);
  width: 100%;
}

.landing-hero__intro {
  display: grid;
  gap: 1rem;
  max-width: 60rem;
}

.landing-hero__eyebrow {
  width: fit-content;
  display: inline-flex;
  align-items: center;
  min-height: 2rem;
  padding: 0.35rem 0.82rem;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(233, 30, 39, 0.14);
  background: rgba(255, 255, 255, 0.88);
  font-size: 0.82rem;
  line-height: 1.2;
  font-weight: var(--weight-bold);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-primary-hover);
}

.landing-hero__title {
  font-size: clamp(2.85rem, 2.1vw + 1.9rem, 3.85rem);
  line-height: 0.96;
  letter-spacing: -0.05em;
  text-wrap: pretty;
}

.landing-hero__title-line {
  display: block;
}

.landing-hero__title-line + .landing-hero__title-line {
  margin-top: 0.08em;
}

.landing-hero__text {
  max-width: 52ch;
  font-size: 1rem;
  line-height: 1.78;
  color: #4a4146;
}

.landing-hero__features {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem;
  width: 100%;
}

.landing-hero__feature {
  min-height: 100%;
  padding: 1.08rem 1.12rem;
  border: 1px solid var(--color-line-soft);
  border-radius: 1.25rem;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: var(--shadow-soft);
  display: grid;
  gap: 0.72rem;
  align-content: start;
}

.landing-hero__feature-label {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.76rem;
  line-height: 1.2;
  font-weight: var(--weight-semibold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-primary-hover);
}

.landing-hero__feature-label::before {
  content: "";
  width: 0.46rem;
  height: 0.46rem;
  border-radius: 50%;
  background: var(--color-primary);
  flex: 0 0 auto;
}

.landing-hero__feature p {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.62;
  color: var(--color-text-main);
}

.landing-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
  padding-top: 0.1rem;
}

.landing-hero__actions .button {
  min-width: 210px;
}

.landing-audience {
  display: grid;
  gap: var(--space-grid-gap);
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.landing-audience__card {
  min-height: 100%;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.95);
  box-shadow: var(--shadow-soft);
  padding: var(--space-card-padding);
  display: grid;
  gap: 1.08rem;
  align-content: start;
  transition: transform var(--motion-smooth), box-shadow var(--motion-smooth), border-color var(--motion-base);
}

.landing-audience__card:hover {
  transform: translateY(-2px);
  border-color: var(--color-line-strong);
  box-shadow: var(--shadow-mid);
}

.landing-audience__icon {
  width: 3rem;
  height: 3rem;
  border-radius: 1rem;
  border: 1px solid var(--color-line-soft);
  background: var(--surface-base);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.landing-audience__icon svg {
  width: 1.35rem;
  height: 1.35rem;
  fill: none;
  stroke: var(--color-primary-hover);
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.landing-audience__card h3 {
  font-size: var(--font-size-card-title);
  line-height: 1.34;
  font-weight: var(--weight-semibold);
  letter-spacing: -0.012em;
}

.landing-audience__card p {
  font-size: 0.9rem;
  line-height: 1.72;
}

.landing-highlights {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(21rem, 100%), 1fr));
  gap: var(--space-grid-gap);
}

.landing-highlight-card {
  min-height: 100%;
  border: 1px solid var(--color-line-soft);
  border-radius: clamp(1.05rem, 2vw, 1.5rem);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: var(--shadow-soft);
  padding: var(--space-card-padding);
  display: grid;
  align-content: start;
  gap: 0.3rem;
  transition: transform var(--motion-smooth), box-shadow var(--motion-smooth), border-color var(--motion-base);
}

.landing-highlight-card:hover {
  transform: translateY(-2px);
  border-color: var(--color-line-strong);
  box-shadow: var(--shadow-mid);
}

.landing-highlight-card__eyebrow {
  font-size: 0.74rem;
  line-height: 1.1;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: var(--weight-semibold);
  color: var(--color-primary-hover);
}

.landing-highlight-card h3 {
  margin-top: 0.42rem;
  font-size: var(--font-size-card-title);
  line-height: 1.34;
  font-weight: var(--weight-semibold);
  letter-spacing: -0.012em;
  color: var(--color-text-strong);
}

.landing-highlight-card p {
  margin-top: 0.86rem;
  margin-bottom: 0;
  color: var(--color-text-main);
  font-size: 0.92rem;
  line-height: 1.72;
}

.landing-cta {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--color-line-soft);
  border-radius: clamp(1.15rem, 3vw, 1.9rem);
  background: var(--bg-surface-soft);
  box-shadow: var(--shadow-mid);
  padding: clamp(1.6rem, 3vw, 2.5rem);
  display: grid;
  gap: 1.15rem;
}

.landing-cta__content {
  display: grid;
  gap: 0.8rem;
}

.landing-cta__content p {
  max-width: 68ch;
  font-size: 0.95rem;
  line-height: 1.76;
}

.landing-cta__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
}

.landing-cta__actions .button {
  min-width: 240px;
}

/* ==================== News Cards ==================== */
.news-card {
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: rgba(255, 255, 255, 0.95);
  box-shadow: var(--shadow-soft);
  transition: transform var(--motion-smooth), box-shadow var(--motion-smooth), border-color var(--motion-base);
}

.news-card:hover {
  transform: translateY(-2px);
  border-color: var(--color-line-strong);
  box-shadow: var(--shadow-mid);
}

.news-card__link {
  min-height: 100%;
  display: flex;
  flex-direction: column;
}

.news-card__media {
  overflow: hidden;
  border-bottom: 1px solid rgba(228, 232, 238, 0.92);
}

.news-card__image {
  width: 100%;
  aspect-ratio: var(--media-ratio-news);
  object-fit: cover;
  transition: transform var(--motion-smooth);
}

.news-card:hover .news-card__image {
  transform: scale(1.03);
}

.news-card__body {
  padding: 1.35rem 1.28rem 1.28rem;
  display: grid;
  gap: 0.72rem;
  flex: 1;
}

.news-card__date {
  font-size: var(--font-size-small);
  font-weight: var(--weight-medium);
  color: var(--color-text-muted);
}

.news-card__title {
  font-size: var(--font-size-card-title);
  line-height: 1.34;
  font-weight: var(--weight-semibold);
  color: var(--color-text-strong);
  letter-spacing: -0.012em;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: auto;
  text-wrap: balance;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.news-card__excerpt {
  margin-bottom: auto;
  font-size: 0.9rem;
  line-height: 1.7;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}

.news-card__link-icon {
  margin-top: 0.18rem;
  align-self: flex-start;
  width: fit-content;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  min-height: 2rem;
  padding: 0 0.78rem;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-pill);
  background: var(--surface-base);
  color: var(--color-text-strong);
  transition: color var(--motion-base), border-color var(--motion-base), background var(--motion-base), transform var(--motion-base);
}

.news-card__action {
  font-size: 0.78rem;
  font-weight: var(--weight-semibold);
  letter-spacing: 0.015em;
  color: inherit;
  opacity: 1;
  transform: none;
  transition: color var(--motion-base);
}

.news-card__link-icon svg {
  width: 1.08rem;
  height: 1.08rem;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.78;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.news-card:hover .news-card__link-icon,
.news-card__link:focus-visible .news-card__link-icon {
  color: var(--color-primary-hover);
  border-color: var(--color-line-strong);
}

.news-card:hover .news-card__action {
  color: var(--color-primary-hover);
}

.news-toolbar {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  margin-top: 0.2rem;
}

.news-sort {
  display: inline-flex;
  align-items: center;
  gap: 0.72rem;
  min-height: 42px;
  padding: 0.32rem 0.36rem 0.32rem 0.84rem;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 14px 26px -28px rgba(17, 13, 15, 0.2);
}

.news-sort__label {
  font-size: 0.76rem;
  font-weight: var(--weight-semibold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.news-sort__select {
  min-height: 34px;
  padding: 0 2rem 0 0.82rem;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-pill);
  background: #ffffff;
  color: var(--color-text-strong);
  font: inherit;
  font-size: 0.82rem;
  font-weight: var(--weight-semibold);
  appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, currentColor 50%),
    linear-gradient(135deg, currentColor 50%, transparent 50%);
  background-position:
    calc(100% - 1rem) calc(50% - 1px),
    calc(100% - 0.72rem) calc(50% - 1px);
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
}

.news-sort__select:focus-visible {
  outline: none;
  border-color: rgba(239, 26, 35, 0.26);
  box-shadow: 0 0 0 4px rgba(239, 26, 35, 0.1);
}

/* ==================== Presentation Cards ==================== */
.presentation-card {
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: rgba(255, 255, 255, 0.95);
  box-shadow: var(--shadow-soft);
  display: flex;
  flex-direction: column;
  transition: transform var(--motion-smooth), box-shadow var(--motion-smooth), border-color var(--motion-base);
}

.presentation-card:hover {
  transform: translateY(-2px);
  border-color: var(--color-line-strong);
  box-shadow: var(--shadow-mid);
}

.presentation-card__link {
  min-height: 100%;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.presentation-card__media {
  overflow: hidden;
  border-bottom: 1px solid rgba(228, 232, 238, 0.92);
}

.presentation-card__image {
  width: 100%;
  aspect-ratio: var(--media-ratio-news);
  object-fit: cover;
  transition: transform var(--motion-smooth);
}

.presentation-card:hover .presentation-card__image {
  transform: scale(1.03);
}

.presentation-card__body {
  padding: 1.3rem 1.22rem 0.96rem;
  display: grid;
  gap: 0.7rem;
  flex: 1;
}

.presentation-card__date {
  font-size: var(--font-size-small);
  color: var(--color-text-muted);
  font-weight: var(--weight-medium);
}

.presentation-card__title {
  font-size: var(--font-size-card-title);
  line-height: 1.34;
  font-weight: var(--weight-semibold);
  color: var(--color-text-strong);
  letter-spacing: -0.012em;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: auto;
  text-wrap: balance;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.presentation-card__description {
  margin-bottom: auto;
  font-size: 0.9rem;
  line-height: 1.68;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}

.presentation-card__footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  padding-top: 0.1rem;
}

.presentation-card__file {
  font-size: var(--font-size-small);
  font-weight: var(--weight-medium);
  overflow-wrap: anywhere;
}

.presentation-card__actions {
  padding: 0 1.22rem 1.08rem;
}

.presentation-card__actions .button {
  min-height: 40px;
  padding: 0.54rem 0.92rem;
}

@media (min-width: 768px) {
  .landing-cta {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
  }

  .landing-cta__actions {
    justify-content: flex-end;
  }

  .document-viewer-shell__toolbar {
    grid-template-columns: minmax(0, 1fr) auto;
  }

  .document-viewer-shell__actions {
    justify-self: end;
    align-self: start;
  }
}

@media (min-width: 1100px) {
  .landing-hero {
    padding-inline: clamp(2.3rem, 3vw, 3.4rem);
  }
}

/* ==================== Article ==================== */
.article-backlink {
  margin-bottom: 1rem;
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-pill);
  background: #ffffff;
  padding: 0.38rem 0.75rem;
  color: var(--color-text-main);
  font-size: var(--font-size-small);
  font-weight: var(--weight-medium);
  box-shadow: 0 10px 20px -24px rgba(17, 13, 15, 0.18);
  transition: transform var(--motion-base), border-color var(--motion-base), background var(--motion-base), color var(--motion-base), box-shadow var(--motion-base);
}

.article-backlink:hover {
  transform: translateY(-1px);
  color: var(--color-text-strong);
  border-color: var(--color-line-strong);
  background: #fafbfd;
}

.article-layout {
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-xl);
  background: rgba(255, 255, 255, 0.95);
  box-shadow: var(--shadow-mid);
  padding: clamp(1.7rem, 1.4vw + 1rem, 2.6rem);
}

.article-layout__header {
  margin-bottom: 1.55rem;
  padding-bottom: 1.15rem;
  border-bottom: 1px solid var(--color-line-soft);
  display: grid;
  gap: 0.9rem;
}

.article-layout__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.52rem;
}

.article-layout__meta time {
  min-height: 30px;
  padding-inline: 0.7rem;
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-line-soft);
  background: #f9fbfd;
  display: inline-flex;
  align-items: center;
  font-size: var(--font-size-small);
  font-weight: var(--weight-medium);
}

.article-layout__cover {
  margin-bottom: 1.55rem;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-lg);
  overflow: hidden;
  position: relative;
  box-shadow: var(--shadow-soft);
}

.article-layout__cover-image {
  width: 100%;
  aspect-ratio: 16 / 8.5;
  object-fit: cover;
}

.article-layout__video-badge {
  position: absolute;
  left: 1rem;
  bottom: 1rem;
  min-height: 34px;
  padding: 0 0.66rem;
  border-radius: var(--radius-pill);
  background: rgba(16, 13, 14, 0.78);
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  gap: 0.36rem;
}

.article-layout__video-icon {
  width: 1.1rem;
  height: 1.1rem;
}

.article-layout__video-icon svg {
  width: 100%;
  height: 100%;
  fill: currentColor;
}

.article-layout__video-text {
  font-size: 0.77rem;
  font-weight: var(--weight-semibold);
}

.article-layout__content {
  display: grid;
  gap: 1rem;
}

.article-embed {
  width: 100%;
  max-width: min(960px, 100%);
  margin-inline: auto;
}

.article-embed__frame {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border: 1px solid var(--color-line-soft);
  border-radius: 24px;
  background: #000000;
  box-shadow: 0 20px 48px -34px rgba(17, 13, 15, 0.34);
}

.article-embed__frame iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

.article-layout__content p,
.privacy-page__source p,
.privacy-page__source li,
.privacy-page__source td,
.privacy-page__source th {
  overflow-wrap: anywhere;
}

.article-layout__list {
  max-width: min(78ch, 100%);
  margin-left: 1.15rem;
  padding-left: 0.45rem;
  display: grid;
  gap: 0.42rem;
}

.article-layout__list li {
  color: var(--color-text-main);
  line-height: 1.8;
}

.page--news-article .article-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
  column-gap: clamp(1.5rem, 1vw + 1rem, 2.3rem);
  align-items: start;
}

.page--news-article .article-layout.article-layout--no-attachments {
  grid-template-columns: 1fr;
}

.page--news-article .article-layout__header,
.page--news-article .article-layout__cover {
  grid-column: 1 / -1;
}

.page--news-article .article-layout__content {
  grid-column: 1;
  padding-right: clamp(0.1rem, 0.5vw, 0.6rem);
}

.page--news-article .article-layout.article-layout--no-attachments .article-layout__content {
  grid-column: 1 / -1;
  padding-right: 0;
}

.page--news-article .article-layout__content p {
  max-width: min(78ch, 100%);
  font-size: 1rem;
  line-height: 1.82;
}

.page--news-article .article-layout__content p:first-child {
  font-size: 1.1rem;
  line-height: 1.8;
  color: #2f272a;
}

.article-layout__gallery {
  display: grid;
  gap: 0.95rem;
  margin-top: 1.7rem;
  padding-top: 1.15rem;
  border-top: 1px solid var(--color-line-soft);
}

.page--news-article .article-layout__gallery {
  grid-column: 1 / -1;
}

.article-gallery__header {
  display: grid;
  gap: 0.35rem;
}

.article-gallery__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.82rem;
}

.article-gallery__item {
  display: block;
  position: relative;
  overflow: hidden;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: var(--shadow-soft);
  cursor: zoom-in;
  transition: transform var(--motion-base), box-shadow var(--motion-base), border-color var(--motion-base);
}

.article-gallery__item:hover {
  transform: translateY(-2px);
  border-color: var(--color-line-strong);
  box-shadow: var(--shadow-mid);
}

.article-gallery__item--featured {
  grid-column: span 2;
  grid-row: span 2;
}

.article-gallery__image {
  width: 100%;
  height: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  transition: transform var(--motion-smooth);
}

.article-gallery__item--featured .article-gallery__image {
  aspect-ratio: 16 / 11;
}

.article-gallery__item:hover .article-gallery__image {
  transform: scale(1.03);
}

.article-layout__cover[data-lightbox-source] {
  cursor: zoom-in;
}

.article-layout__cover[data-lightbox-source]:hover .article-layout__cover-image {
  transform: scale(1.02);
}

.article-layout__cover[data-lightbox-source]:focus-visible {
  outline: none;
  box-shadow: 0 0 0 4px rgba(239, 26, 35, 0.1), var(--shadow-soft);
}

.article-layout__cover-image {
  transition: transform var(--motion-smooth);
}

.image-lightbox {
  position: fixed;
  inset: 0;
  z-index: 140;
  display: grid;
  place-items: center;
  padding: clamp(1rem, 3vw, 2rem);
}

.image-lightbox[hidden] {
  display: none;
}

.image-lightbox__backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: rgba(14, 12, 13, 0.84);
  backdrop-filter: blur(10px);
}

.image-lightbox__dialog {
  position: relative;
  z-index: 1;
  width: min(1120px, 100%);
  display: grid;
  gap: 0.82rem;
}

.image-lightbox__close {
  justify-self: end;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.08);
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background var(--motion-base), transform var(--motion-base), border-color var(--motion-base);
}

.image-lightbox__close:hover {
  background: rgba(255, 255, 255, 0.14);
  border-color: rgba(255, 255, 255, 0.28);
  transform: translateY(-1px);
}

.image-lightbox__close svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.image-lightbox__figure {
  display: grid;
  gap: 0.72rem;
  margin: 0;
}

.image-lightbox__image {
  width: 100%;
  max-height: calc(100vh - 8rem);
  object-fit: contain;
  border-radius: 22px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.06);
  box-shadow: 0 26px 54px -34px rgba(0, 0, 0, 0.7);
}

.image-lightbox__caption {
  text-align: center;
  font-size: 0.9rem;
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.82);
}

.article-layout__attachments {
  display: grid;
  gap: 0.8rem;
  margin-top: 1.45rem;
  padding-top: 1rem;
  border-top: 1px solid var(--color-line-soft);
}

.page--news-article .article-layout__attachments {
  grid-column: 2;
  grid-row: 3;
  margin-top: 0;
  padding-top: 0;
  border-top: 0;
  padding-left: clamp(1rem, 1vw, 1.4rem);
  border-left: 1px solid rgba(23, 19, 22, 0.08);
  align-self: start;
  position: sticky;
  top: 108px;
}

.attachment-section__title {
  font-size: 18px;
  line-height: 1.34;
  font-weight: var(--weight-bold);
  color: var(--color-text-strong);
}

/* ==================== Attachments ==================== */
.attachment-list {
  display: grid;
  gap: 0.65rem;
}

.attachment-list--tiles {
  grid-template-columns: repeat(auto-fit, minmax(min(18.5rem, 100%), 1fr));
  gap: clamp(1rem, 0.6vw + 0.85rem, 1.22rem);
  align-items: stretch;
}

.attachment-item {
  width: 100%;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.66rem;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 14px 30px -30px rgba(17, 13, 15, 0.16);
  padding: 0.8rem 0.95rem;
  transition: transform var(--motion-base), box-shadow var(--motion-base), border-color var(--motion-base);
}

.attachment-item:hover {
  transform: translateY(-1px);
  border-color: var(--color-line-strong);
  box-shadow: var(--shadow-soft);
}

.attachment-item--static {
  cursor: default;
}

.attachment-item--static:hover {
  transform: none;
  border-color: var(--color-line-soft);
  box-shadow: 0 14px 30px -30px rgba(17, 13, 15, 0.16);
}

.content-section .attachment-item {
  max-width: 760px;
}

.attachment-list--tiles .attachment-item {
  max-width: none;
  min-height: 100%;
  height: 100%;
  grid-template-columns: auto minmax(0, 1fr);
  grid-template-rows: auto 1fr auto;
  align-items: start;
  gap: 0.9rem 0.82rem;
  padding: clamp(1rem, 0.4vw + 0.92rem, 1.15rem);
  border-radius: var(--radius-lg);
}

.attachment-list--tiles .attachment-item::after {
  content: "Только просмотр";
  grid-column: 1 / -1;
  margin-top: 0.1rem;
  justify-self: start;
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0.2rem 0.72rem;
  border-radius: var(--radius-pill);
  background: rgba(237, 28, 35, 0.08);
  color: var(--color-primary-hover);
  font-size: 0.75rem;
  line-height: 1.2;
  font-weight: var(--weight-semibold);
}

.attachment-list--tiles .attachment-item__download {
  display: none;
}

.attachment-list--tiles .attachment-item__icon {
  width: 2.5rem;
  height: 2.5rem;
  border: 1px solid var(--color-line-soft);
  border-radius: 0.9rem;
  background: var(--surface-base);
  display: grid;
  place-items: center;
}

.attachment-item__icon,
.attachment-item__download {
  width: 1.08rem;
  height: 1.08rem;
  color: var(--color-primary-hover);
}

.attachment-item__icon svg,
.attachment-item__download svg {
  width: 100%;
  height: 100%;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.72;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.attachment-item__content {
  min-width: 0;
}

.attachment-list--tiles .attachment-item__content {
  grid-column: 2;
  grid-row: 1 / 3;
  display: grid;
  align-content: start;
  gap: 0.42rem;
  min-height: 100%;
}

.attachment-item__name {
  display: block;
  color: var(--color-text-strong);
  font-size: 0.9rem;
  line-height: 1.45;
  font-weight: var(--weight-semibold);
  overflow-wrap: anywhere;
}

.attachment-item__meta {
  display: block;
  margin-top: 0.08rem;
  color: var(--color-text-muted);
  font-size: var(--font-size-small);
  line-height: 1.58;
}

.attachment-list--tiles .attachment-item:hover .attachment-item__name {
  color: var(--color-primary-hover);
}

/* ==================== Document Viewer ==================== */
.page--document-viewer .page__main {
  padding-bottom: clamp(7rem, 5vw + 2rem, 9rem);
}

.document-viewer-shell {
  border: 1px solid var(--color-line-soft);
  border-radius: clamp(1.1rem, 2vw, 1.6rem);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: var(--shadow-soft);
  padding: var(--space-card-padding);
  display: grid;
  gap: 1.15rem;
}

.document-viewer-shell__toolbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 0.9rem;
  align-items: start;
}

.document-viewer-shell__meta {
  max-width: 72ch;
  display: grid;
  gap: 0.6rem;
}

.document-viewer-shell__actions {
  justify-self: start;
}

.document-viewer-shell__meta p {
  margin: 0;
  color: var(--color-text-main);
  font-size: 0.92rem;
  line-height: 1.68;
}

.document-viewer-frame {
  min-height: clamp(560px, 76vh, 1080px);
  border: 1px solid rgba(224, 230, 238, 0.96);
  border-radius: 20px;
  overflow: hidden;
  background: #f7f9fc;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
  padding: clamp(0.45rem, 0.55vw + 0.3rem, 0.78rem);
}

.document-viewer-frame__inner {
  display: block;
  width: 100%;
  min-height: clamp(560px, 76vh, 1080px);
  height: clamp(560px, 76vh, 1080px);
  border: 0;
  background: #ffffff;
  border-radius: 16px;
}

.document-viewer-frame__loading,
.document-viewer-empty {
  min-height: inherit;
  display: grid;
  place-items: center;
  padding: 1.5rem;
  text-align: center;
}

.document-viewer-frame__loading {
  color: var(--color-text-muted);
}

.document-viewer-empty {
  gap: 0.85rem;
}

.document-viewer-empty h2 {
  color: var(--color-text-strong);
}

.document-viewer-empty p {
  max-width: 42ch;
  color: var(--color-text-main);
}

/* ==================== Regulations ==================== */
.regulations-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.reg-card {
  min-height: 246px;
  border: 1px solid var(--color-line-soft);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.95);
  box-shadow: var(--shadow-soft);
  padding: 1.35rem;
  display: grid;
  grid-template-rows: auto auto 1fr auto;
  gap: 1rem;
  transition: transform var(--motion-base), box-shadow var(--motion-base), border-color var(--motion-base);
}

.reg-card:hover {
  transform: translateY(-2px);
  border-color: var(--color-line-strong);
  box-shadow: var(--shadow-mid);
}

.reg-card__icon {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  border: 1px solid var(--color-line-soft);
  background: var(--surface-base);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
  display: grid;
  place-items: center;
  color: var(--color-primary-hover);
}

.reg-card__icon svg {
  width: 22px;
  height: 22px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.72;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.reg-card__title {
  font-size: var(--font-size-card-title);
  line-height: 1.34;
  font-weight: var(--weight-semibold);
  color: #1f1a1d;
  letter-spacing: -0.012em;
  text-wrap: balance;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: auto;
}

.reg-card__description {
  font-size: 0.92rem;
  line-height: 1.68;
  color: #4e4449;
}

.reg-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
}

.reg-card__download {
  min-height: 34px;
  padding: 0.42rem 0.8rem;
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-line-soft);
  background: #ffffff;
  color: var(--color-text-strong);
  font-size: 0.78rem;
  font-weight: var(--weight-semibold);
  transition: color var(--motion-base), border-color var(--motion-base), background var(--motion-base), transform var(--motion-base);
}

.reg-card__download:hover {
  color: var(--color-primary-hover);
  border-color: var(--color-line-strong);
  background: #fbfcfe;
  transform: translateY(-1px);
}

/* ==================== Home Page Scenario ==================== */
.page--main .page__main,
.page--home .page__main {
  padding-top: clamp(1.8rem, 1.5vw + 1rem, 2.8rem);
}

.home-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.04fr) minmax(360px, 0.96fr);
  border-radius: 24px;
  overflow: hidden;
  border: 1px solid var(--color-line-soft);
  background: var(--bg-surface-soft);
  box-shadow: var(--shadow-strong);
}

.home-hero__content {
  position: relative;
  z-index: 1;
  padding: clamp(1.8rem, 2vw + 1rem, 3.2rem);
  display: grid;
  align-content: center;
  gap: 1rem;
}

.home-hero__eyebrow {
  font-size: 0.74rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: var(--weight-semibold);
  color: var(--color-primary-hover);
}

.home-hero h1 {
  max-width: 18ch;
  font-size: 4rem;
  line-height: 1.06;
  font-weight: var(--weight-bold);
  letter-spacing: -0.03em;
  text-wrap: balance;
}

.home-hero__lead {
  max-width: 60ch;
  font-size: 1.04rem;
  line-height: 1.78;
  color: #2d2528;
}

.home-hero__actions {
  margin-top: 0.3rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.62rem;
}

.home-hero__actions .button {
  min-width: 228px;
}

.home-hero__signals {
  margin-top: 0.5rem;
  list-style: none;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.62rem;
  max-width: 760px;
}

.home-hero__signal {
  border: 1px solid rgba(220, 226, 235, 0.96);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.84);
  padding: 0.72rem 0.78rem;
  font-size: 0.78rem;
  line-height: 1.56;
  color: #2f282b;
}

.home-hero__media {
  position: relative;
  min-height: 100%;
  overflow: hidden;
}

.home-hero__media::before {
  content: none;
}

.home-hero__image {
  width: 100%;
  height: 100%;
  min-height: 560px;
  object-fit: cover;
}

.home-hero__media-badge {
  position: absolute;
  left: 1rem;
  bottom: 1rem;
  z-index: 2;
  max-width: 280px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  border-radius: var(--radius-md);
  background: rgba(16, 12, 14, 0.54);
  backdrop-filter: blur(4px);
  padding: 0.78rem 0.84rem;
}

.home-hero__media-title {
  margin-bottom: 0.28rem;
  color: #ffffff;
  font-size: 0.78rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-weight: var(--weight-semibold);
}

.home-hero__media-text {
  color: rgba(255, 255, 255, 0.92);
  font-size: 0.82rem;
  line-height: 1.48;
}

.home-hub {
  display: grid;
  gap: clamp(1.6rem, 0.8vw + 1.2rem, 2rem);
  margin-top: clamp(3rem, 8vw, 7.5rem);
}

.home-hub__head {
  max-width: 78ch;
  display: grid;
  gap: 0.62rem;
}

.home-hub__head p {
  font-size: 0.96rem;
  line-height: 1.76;
}

.home-hub__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-grid-gap);
  align-items: stretch;
}

.home-hub-card {
  position: relative;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.95);
  box-shadow: var(--shadow-soft);
  padding: var(--space-card-padding);
  min-height: 252px;
  display: flex;
  flex-direction: column;
  gap: 0.95rem;
  transition: transform var(--motion-smooth), box-shadow var(--motion-smooth), border-color var(--motion-base);
}

.home-hub-card__header {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: start;
  gap: 0.72rem;
}

.home-hub-card__icon {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  border: 1px solid var(--color-line-soft);
  background: var(--surface-base);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
  color: var(--color-primary);
  display: grid;
  place-items: center;
  flex-shrink: 0;
}

.home-hub-card__icon svg {
  width: 22px;
  height: 22px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.85;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.home-hub-card:hover {
  transform: translateY(-2px);
  border-color: var(--color-line-strong);
  box-shadow: var(--shadow-mid);
}

.home-hub-card__title {
  margin-top: 0.16rem;
  font-size: var(--font-size-card-title);
  line-height: 1.34;
  font-weight: var(--weight-semibold);
  letter-spacing: -0.012em;
}

.home-hub-card__meta {
  font-size: 0.92rem;
  line-height: 1.68;
}

.home-hub-card__cta {
  margin-top: auto;
  align-self: flex-start;
  width: fit-content;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  color: var(--color-text-strong);
  font-size: 0.82rem;
  font-weight: var(--weight-semibold);
  border-bottom: 1px solid rgba(23, 19, 22, 0.18);
  transition: color var(--motion-base), border-color var(--motion-base), transform var(--motion-base);
}

.home-hub-card__cta::after {
  content: "→";
  font-size: 0.86rem;
  transform: translateX(0);
  transition: transform var(--motion-base);
}

.home-hub-card__cta:hover {
  color: var(--color-primary-hover);
  border-color: rgba(23, 19, 22, 0.26);
}

.home-hub-card__cta:hover::after {
  transform: translateX(2px);
}

.home-audience {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 0.42rem;
}

.home-audience__item {
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-pill);
  background: #fbfcfe;
  padding: 0.38rem 0.68rem;
  font-size: 0.78rem;
}

.home-news-preview__list {
  list-style: none;
  display: grid;
  gap: 0.34rem;
}

.home-news-preview__item {
  font-size: 0.82rem;
  line-height: 1.56;
}

.home-expert {
  gap: 1.12rem;
  margin-top: clamp(3rem, 8vw, 7.5rem);
}

.home-expert__header {
  max-width: 78ch;
  display: grid;
  gap: 0.46rem;
}

.home-expert__header p {
  font-size: 0.96rem;
  line-height: 1.76;
}

.content-section {
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.95);
  box-shadow: var(--shadow-soft);
  padding: var(--space-panel-padding);
  display: grid;
  gap: clamp(1.48rem, 0.82vw + 1.04rem, 1.92rem);
}

.content-section > p {
  max-width: 92ch;
}

.content-section > h2,
.content-section > h3 {
  font-size: var(--font-size-section-title);
  line-height: 1.24;
  font-weight: var(--weight-bold);
  letter-spacing: -0.014em;
  text-wrap: balance;
}

.content-section > h3 {
  margin-top: 0;
}

.content-section--lean-office {
  position: relative;
  overflow: hidden;
  border-color: var(--color-line-soft);
  background: var(--bg-surface-soft);
  box-shadow: var(--shadow-soft);
  gap: 1.15rem;
}

.content-section--lean-office::before {
  content: none;
}

.content-section--lean-office > * {
  position: relative;
  z-index: 1;
}

.lean-office-head {
  display: grid;
  gap: 0.8rem;
  border-bottom: 1px solid var(--color-line-soft);
  padding-bottom: 1.1rem;
}

.lean-office-head__eyebrow {
  width: fit-content;
  font-size: 0.74rem;
  line-height: 1.2;
  font-weight: var(--weight-bold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-primary-hover);
}

.lean-office-head h3 {
  max-width: 31ch;
  font-size: clamp(1.32rem, 0.7vw + 1.06rem, 1.84rem);
  line-height: 1.24;
}

.lean-office-head__text {
  max-width: 96ch;
  display: grid;
  gap: 0.62rem;
}

.lean-office-head__lead {
  color: var(--color-text-strong);
}

.lean-office-head__chips {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 0.44rem;
}

.lean-office-head__chip {
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.84);
  padding: 0.38rem 0.7rem;
  font-size: 0.77rem;
  line-height: 1.3;
  font-weight: var(--weight-semibold);
  color: var(--color-text-main);
}

.feature-list {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.feature-list--lean-office {
  gap: 0.94rem;
}

.feature-item {
  min-height: 178px;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.95);
  box-shadow: var(--shadow-soft);
  padding: 1.02rem;
  display: grid;
  gap: 0.58rem;
  align-content: start;
  transition: transform var(--motion-base), border-color var(--motion-base), box-shadow var(--motion-base);
}

.content-section--lean-office .feature-item {
  min-height: 196px;
  border-color: var(--color-line-soft);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: var(--shadow-soft);
}

.feature-item:hover {
  transform: translateY(-2px);
  border-color: var(--color-line-strong);
  box-shadow: var(--shadow-soft);
}

.content-section--lean-office .feature-item:hover {
  border-color: var(--color-line-strong);
  box-shadow: var(--shadow-mid);
}

.feature-item__head {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: start;
  gap: 0.62rem;
}

.feature-item__icon {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  border: 1px solid var(--color-line-soft);
  background: var(--surface-base);
  color: var(--color-primary);
  display: grid;
  place-items: center;
  flex-shrink: 0;
}

.feature-item__icon svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.82;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.feature-item__title {
  display: block;
  font-size: 0.98rem;
  line-height: 1.36;
  font-weight: var(--weight-bold);
  color: var(--color-text-strong);
}

.feature-item__text {
  font-size: 0.9rem;
  line-height: 1.68;
}

.diagram {
  margin-top: 0.12rem;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.95);
  padding: 1.1rem;
  display: grid;
  gap: 1rem;
  overflow: visible;
}

.content-section--diagram .diagram {
  margin-top: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  padding: 0;
  box-shadow: none;
}

.content-section--diagram {
  margin-top: clamp(3rem, 8vw, 7.5rem);
}

.content-section--regulations {
  margin-top: clamp(3rem, 8vw, 7.5rem);
}

.diagram__viewport {
  width: 100%;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-sm);
  background: #ffffff;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
}

.diagram__svg {
  display: block;
  width: 100%;
  min-width: 1100px;
  height: auto;
  border: 0;
  border-radius: 0;
  background: #ffffff;
}

.diagram__legend {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 0.72rem;
}

.diagram__legend-item {
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: var(--shadow-soft);
  padding: 0.82rem 0.9rem;
  display: grid;
  gap: 0.38rem;
  align-content: start;
}

.diagram__legend-title {
  display: block;
  font-size: 0.82rem;
  line-height: 1.3;
  font-weight: var(--weight-bold);
  color: var(--color-text-strong);
}

.diagram__legend-text {
  display: block;
  font-size: var(--font-size-small);
  line-height: 1.58;
  color: var(--color-text-main);
}

/* ==================== Testing / Registration ==================== */
.testing-flow,
.registration-flow {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.9rem;
}

.testing-flow__card,
.registration-flow__step {
  position: relative;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.95);
  box-shadow: var(--shadow-soft);
  padding: 1.18rem;
  display: grid;
  gap: 0.62rem;
}

.testing-flow__card::before,
.registration-flow__step::before {
  content: "";
  width: 34px;
  height: 34px;
  border-radius: 10px;
  border: 1px solid var(--color-line-soft);
  background:
    radial-gradient(circle at 50% 50%, rgba(237, 28, 35, 0.92) 0 16%, transparent 18% 100%),
    var(--surface-base);
}

.registration-flow {
  counter-reset: regstep;
}

.registration-flow__step {
  counter-increment: regstep;
}

.registration-flow__step::after {
  content: counter(regstep);
  position: absolute;
  right: 0.88rem;
  top: 0.86rem;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  border: 1px solid var(--color-line-soft);
  background: var(--surface-base);
  color: var(--color-primary-hover);
  display: grid;
  place-items: center;
  font-size: 0.74rem;
  font-weight: var(--weight-bold);
}

.testing-flow__card h2,
.registration-flow__step h2 {
  font-size: 1.04rem;
  line-height: 1.38;
  font-weight: var(--weight-bold);
  padding-right: 1.8rem;
}

.testing-flow__card p,
.registration-flow__step p {
  font-size: 0.92rem;
  line-height: 1.7;
}

.testing-actions,
.registration-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}

/* ==================== Testing App ==================== */
.testing-app {
  display: grid;
  gap: 1.2rem;
}

.testing-app__hero {
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-xl);
  background: var(--bg-surface-soft);
  box-shadow: var(--shadow-mid);
  padding: clamp(1.35rem, 1vw + 0.9rem, 1.95rem);
  display: grid;
  gap: 1.15rem;
}

.testing-app__hero-copy {
  display: grid;
  gap: 0.45rem;
  max-width: 76ch;
}

.testing-app__eyebrow {
  font-size: 0.76rem;
  line-height: 1.3;
  font-weight: var(--weight-bold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-primary-hover);
}

.testing-app__title {
  font-size: clamp(1.38rem, 0.8vw + 1.1rem, 1.9rem);
  line-height: 1.22;
  font-weight: var(--weight-bold);
  color: var(--color-text-strong);
}

.testing-app__description {
  max-width: 64ch;
  font-size: 0.95rem;
  line-height: 1.74;
}

.testing-app__stats {
  font-size: 0.85rem;
  line-height: 1.55;
  color: var(--color-text-muted);
}

.testing-app__controls {
  display: grid;
  grid-template-columns: minmax(260px, 1.6fr) repeat(2, minmax(180px, 0.8fr)) auto auto;
  gap: 0.82rem;
  align-items: end;
}

.testing-app__field {
  display: grid;
  gap: 0.38rem;
}

.testing-app__field-label {
  font-size: 0.74rem;
  line-height: 1.3;
  font-weight: var(--weight-semibold);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #6b6065;
}

.testing-app__input,
.testing-app__select {
  min-height: 44px;
  width: 100%;
  border: 1px solid var(--color-line-soft);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.98);
  color: var(--color-text-strong);
  padding: 0.72rem 0.9rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
  transition: border-color var(--motion-base), box-shadow var(--motion-base), background var(--motion-base);
}

.testing-app__input::placeholder {
  color: #8a7e84;
}

.testing-app__input:focus,
.testing-app__select:focus {
  border-color: rgba(237, 28, 35, 0.28);
  box-shadow: 0 0 0 4px rgba(237, 28, 35, 0.1);
  background: #ffffff;
}

.testing-app__toggle {
  min-height: 44px;
  padding: 0.72rem 0.92rem;
  border: 1px solid var(--color-line-soft);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.98);
  display: inline-flex;
  align-items: center;
  gap: 0.68rem;
  align-self: stretch;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.testing-app__toggle input {
  accent-color: var(--color-primary);
}

.testing-app__toggle-label {
  font-size: 0.88rem;
  line-height: 1.4;
  font-weight: var(--weight-medium);
  color: var(--color-text-main);
}

.testing-app__layout {
  display: grid;
  grid-template-columns: minmax(300px, 360px) minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}

.testing-app__panel {
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-xl);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: var(--shadow-soft);
  overflow: hidden;
  min-height: 0;
}

.testing-app__panel-head {
  padding: 1rem 1.08rem;
  border-bottom: 1px solid var(--color-line-soft);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(249, 251, 253, 0.9) 100%);
}

.testing-app__panel-head h3 {
  font-size: 0.76rem;
  line-height: 1.3;
  font-weight: var(--weight-bold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #796d73;
}

.testing-app__list {
  max-height: min(950px, calc(100vh - 270px));
  overflow: auto;
  padding: 0.48rem;
  display: grid;
  gap: 0.44rem;
  scrollbar-gutter: stable;
}

.testing-app__list::-webkit-scrollbar {
  width: 10px;
}

.testing-app__list::-webkit-scrollbar-thumb {
  background: rgba(121, 109, 115, 0.24);
  border-radius: 999px;
  border: 2px solid rgba(255, 255, 255, 0.75);
}

.testing-app__item {
  width: 100%;
  padding: 0.82rem 0.88rem;
  border: 1px solid transparent;
  border-radius: 14px;
  background: #fcfdff;
  cursor: pointer;
  display: grid;
  gap: 0.52rem;
  text-align: left;
  transition: transform var(--motion-fast), background var(--motion-base), border-color var(--motion-base), box-shadow var(--motion-base);
}

.testing-app__item:hover {
  transform: translateY(-1px);
  background: #ffffff;
  border-color: var(--color-line-strong);
  box-shadow: 0 16px 28px -30px rgba(17, 13, 15, 0.18);
}

.testing-app__item--active {
  border-color: rgba(237, 28, 35, 0.24);
  background: var(--surface-base);
  box-shadow: var(--shadow-soft);
}

.testing-app__item-title {
  font-size: 0.9rem;
  line-height: 1.52;
  color: var(--color-text-strong);
}

.testing-app__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.42rem;
}

.testing-app__tag {
  min-height: 24px;
  padding: 0.18rem 0.58rem;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-pill);
  background: #ffffff;
  display: inline-flex;
  align-items: center;
  font-size: 0.74rem;
  line-height: 1.2;
  color: #6d6267;
}

.testing-app__content {
  min-height: 560px;
  padding: clamp(1.15rem, 1vw + 0.8rem, 1.5rem);
  display: grid;
  gap: 1.15rem;
}

.testing-app__question {
  font-size: clamp(1.25rem, 0.7vw + 1rem, 1.52rem);
  line-height: 1.28;
  font-weight: var(--weight-bold);
  letter-spacing: -0.02em;
  color: var(--color-text-strong);
}

.testing-app__answers {
  display: grid;
  gap: 0.72rem;
}

.testing-app__answer {
  border: 1px solid rgba(214, 221, 230, 0.96);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.98);
  padding: 0.95rem 1rem;
  cursor: pointer;
  transition: transform var(--motion-fast), border-color var(--motion-base), box-shadow var(--motion-base), background var(--motion-base);
}

.testing-app__answer:hover {
  transform: translateY(-1px);
  border-color: rgba(216, 223, 232, 0.94);
  box-shadow: var(--shadow-soft);
  background: #ffffff;
}

.testing-app__answer--open {
  border-color: #d9e0ea;
}

.testing-app__answer--correct {
  border-color: rgba(22, 163, 74, 0.28);
  background: linear-gradient(180deg, #fbfffc 0%, #f6fff8 100%);
}

.testing-app__answer-header {
  display: flex;
  gap: 0.78rem;
  align-items: flex-start;
}

.testing-app__letter {
  width: 2rem;
  height: 2rem;
  flex: 0 0 2rem;
  border-radius: 12px;
  border: 1px solid var(--color-line-soft);
  background: var(--surface-base);
  color: var(--color-primary-hover);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.84rem;
  font-weight: var(--weight-bold);
}

.testing-app__answer-main {
  flex: 1;
  min-width: 0;
  display: grid;
  gap: 0.62rem;
}

.testing-app__answer-row {
  display: flex;
  gap: 0.72rem;
  align-items: flex-start;
  justify-content: space-between;
}

.testing-app__answer-text {
  flex: 1;
  min-width: 0;
  font-size: 0.92rem;
  line-height: 1.62;
  color: var(--color-text-strong);
}

.testing-app__answer-badge {
  flex: 0 0 auto;
  min-height: 24px;
  padding: 0.15rem 0.58rem;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.85);
  display: inline-flex;
  align-items: center;
  font-size: 0.72rem;
  line-height: 1.2;
  color: #70646a;
}

.testing-app__answer-badge--ok {
  border-color: rgba(22, 163, 74, 0.28);
  background: rgba(22, 163, 74, 0.06);
  color: #17823f;
}

.testing-app__answer-badge--bad {
  border-color: rgba(237, 28, 35, 0.24);
  background: rgba(237, 28, 35, 0.06);
  color: var(--color-primary-hover);
}

.testing-app__explain {
  display: none;
  padding-top: 0.55rem;
  border-top: 1px solid rgba(214, 221, 230, 0.88);
  font-size: 0.88rem;
  line-height: 1.66;
  color: #6b6065;
}

.testing-app__answer--open .testing-app__explain {
  display: block;
}

.testing-app__helper {
  font-size: 0.84rem;
  line-height: 1.56;
  color: var(--color-text-muted);
}

.testing-app__empty {
  font-size: 0.94rem;
  color: var(--color-text-muted);
}

.testing-app__footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  border-top: 1px solid var(--color-line-soft);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(249, 251, 253, 0.88) 100%);
  padding: 1rem 1.08rem;
}

.testing-app__hint {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.36rem;
}

.testing-app__hint-text {
  font-size: 0.82rem;
  color: var(--color-text-muted);
}

.testing-app__kbd {
  min-width: 26px;
  min-height: 26px;
  padding: 0.18rem 0.4rem;
  border: 1px solid var(--color-line-soft);
  border-radius: 9px;
  background: rgba(255, 255, 255, 0.92);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 0.76rem;
  color: #72666c;
}

.testing-app__footer-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}

/* ==================== Lower Zone ==================== */
.lower-zone {
  border-top: 1px solid rgba(216, 223, 232, 0.74);
  background: var(--bg-surface-soft);
  padding: clamp(3.6rem, 2.5vw + 1.8rem, 5rem) 0 clamp(6.8rem, 5vw + 3rem, 9rem);
}

.lower-zone__inner {
  display: grid;
  gap: clamp(1rem, 0.55vw + 0.76rem, 1.28rem);
}

.lower-zone__card {
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: var(--shadow-soft);
  padding: var(--space-panel-padding);
  display: grid;
  align-content: start;
  gap: 1.22rem;
}

.lower-zone__card--contact {
  max-width: 100%;
  grid-template-columns: minmax(220px, 0.8fr) minmax(0, 1.2fr);
  grid-template-areas: "title list";
  column-gap: clamp(1.35rem, 1vw + 0.9rem, 2.4rem);
  row-gap: 1rem;
  align-items: start;
}

.lower-zone__card--contact .lower-zone__title {
  grid-area: title;
  max-width: 22ch;
  padding-top: 0.08rem;
  font-size: clamp(1.08rem, 0.48vw + 0.98rem, 1.3rem);
  line-height: 1.22;
}

.lower-zone__card--contact .lower-zone__list {
  grid-area: list;
}

.lower-zone__title {
  font-size: 1rem;
  line-height: 1.36;
  font-weight: var(--weight-bold);
}

.lower-zone__list {
  list-style: none;
  display: grid;
  gap: 0.74rem;
}

.lower-zone__item {
  font-size: 0.93rem;
  line-height: 1.64;
}

.lower-zone__item strong {
  color: var(--color-text-strong);
  font-weight: var(--weight-semibold);
}

.lower-zone__list--contact {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  column-gap: 1rem;
  row-gap: 1rem;
}

.lower-zone__list--contact .lower-zone__item {
  min-height: 100%;
  padding: 1rem 1rem;
  border: 1px solid rgba(228, 232, 238, 0.92);
  border-radius: var(--radius-md);
  background: rgba(251, 252, 254, 0.94);
  box-shadow: 0 12px 26px -28px rgba(17, 13, 15, 0.14);
  display: grid;
  gap: 0.22rem;
  align-content: start;
}

.lower-zone__list--contact .lower-zone__item strong {
  display: block;
  margin-bottom: 0.08rem;
  font-size: 0.75rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #5e5358;
}

.lower-zone__link {
  color: var(--color-text-strong);
  border-bottom: 1px solid rgba(23, 19, 22, 0.14);
  transition: color var(--motion-base), border-color var(--motion-base);
}

.lower-zone__link:hover {
  color: var(--color-primary-hover);
  border-color: rgba(23, 19, 22, 0.24);
}

/* ==================== Footer ==================== */
.site-footer {
  margin-top: auto;
  border-top: 1px solid var(--color-line-soft);
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(6px);
}

.site-footer__inner {
  min-height: 110px;
  padding-block: 1.45rem;
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: clamp(1rem, 2vw, 2.2rem);
}

.site-footer__brand {
  display: inline-flex;
  align-items: center;
}

.site-footer__logo {
  width: auto;
  height: 32px;
  object-fit: contain;
}

.footer-links {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.68rem 0.95rem;
}

.footer-links__button {
  min-height: 32px;
  border: 1px solid transparent;
  border-radius: var(--radius-pill);
  padding: 0.32rem 0.64rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-main);
  font-size: 0.79rem;
  font-weight: var(--weight-medium);
  transition: color var(--motion-base), border-color var(--motion-base), background var(--motion-base), box-shadow var(--motion-base);
}

.footer-links__button:hover {
  color: var(--color-text-strong);
  border-color: var(--color-line-strong);
  background: #fbfcfe;
  box-shadow: 0 12px 22px -24px rgba(17, 13, 15, 0.14);
}

.footer-links__button[aria-current="page"] {
  color: var(--color-text-inverse);
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-hover));
}

/* ==================== Cookie Banner ==================== */
.cookie-banner {
  position: fixed;
  left: 50%;
  bottom: max(var(--flow-md), env(safe-area-inset-bottom));
  transform: translateX(-50%);
  z-index: 120;
  width: min(1060px, calc(100% - 2rem));
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.97);
  box-shadow: var(--shadow-strong);
  backdrop-filter: blur(10px);
}

.cookie-banner__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.08rem;
}

.cookie-banner__text {
  font-size: 0.82rem;
  line-height: 1.6;
}

.cookie-banner__actions {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 0.48rem;
}

/* ==================== Legal Pages ==================== */
.page--privacy .article-layout,
.page--terms .article-layout,
.page--cookie .article-layout {
  max-width: 1320px;
  margin-inline: auto;
  padding: clamp(1.35rem, 1.25vw + 0.98rem, 2.35rem);
  animation: none;
}

.privacy-page__header {
  margin-bottom: 1.6rem;
  display: grid;
  gap: 0.68rem;
}

.privacy-page__content {
  display: grid;
  max-width: min(106ch, 100%);
  margin-inline: auto;
  gap: 0.2rem;
}

.privacy-page__source {
  font-size: 0.95rem;
  line-height: 1.8;
  letter-spacing: -0.002em;
  hyphens: auto;
  color: var(--color-text-main);
}

.privacy-page__source > * + * {
  margin-top: 0.82rem;
}

.privacy-page__source p,
.privacy-page__source div,
.privacy-page__source li {
  text-align: left;
  color: var(--color-text-main);
}

.privacy-page__source ul,
.privacy-page__source ol {
  margin-left: 1.1rem;
  padding-left: 0.4rem;
}

.privacy-page__source li + li {
  margin-top: 0.28rem;
}

.privacy-page__intro-title {
  margin-top: 0;
  font-weight: var(--weight-bold);
  letter-spacing: 0.05em;
}

.privacy-page__intro-line {
  margin-top: 0;
}

.privacy-page__source h2 {
  margin-top: 2.1rem;
  margin-bottom: 0.7rem;
  font-size: 1.24rem;
  line-height: 1.34;
  font-weight: var(--weight-bold);
  color: var(--color-text-strong);
}

.privacy-page__source h3 {
  margin-top: 1.4rem;
  margin-bottom: 0.58rem;
  font-size: 1.05rem;
  line-height: 1.34;
  font-weight: var(--weight-semibold);
  color: #2f272a;
}

.privacy-page__subtitle {
  margin-top: 0;
  font-weight: var(--weight-semibold);
  color: var(--color-text-strong);
}

.privacy-page__center {
  text-align: left;
}

.privacy-page__source a {
  color: var(--color-primary-hover);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
}

.privacy-page__source a:focus-visible {
  border-radius: 4px;
  outline-offset: 1px;
}

.privacy-page__source table {
  width: 100%;
  margin-top: 0.95rem;
  margin-bottom: 1.3rem;
  border-collapse: collapse;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-md);
  overflow: hidden;
  display: block;
  overflow-x: auto;
  scrollbar-gutter: stable both-edges;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 16px 30px -30px rgba(17, 13, 15, 0.14);
}

.privacy-page__source thead,
.privacy-page__source tbody {
  display: table;
  width: 100%;
}

.privacy-page__source th,
.privacy-page__source td {
  border: 1px solid var(--color-line-soft);
  padding: 0.58rem 0.66rem;
  vertical-align: top;
  min-width: 140px;
  font-size: 0.88rem;
  line-height: 1.58;
  white-space: normal;
}

.privacy-page__source th:first-child,
.privacy-page__source td:first-child {
  min-width: 76px;
  text-align: center;
  font-weight: var(--weight-semibold);
}

.privacy-page__source th:nth-child(2),
.privacy-page__source td:nth-child(2) {
  min-width: 260px;
}

.privacy-page__source th:nth-child(3),
.privacy-page__source td:nth-child(3) {
  min-width: 190px;
}

.privacy-page__source th:nth-child(4),
.privacy-page__source td:nth-child(4) {
  min-width: 190px;
}

.privacy-page__source th:nth-child(5),
.privacy-page__source td:nth-child(5) {
  min-width: 220px;
}

.privacy-page__source tbody tr:nth-child(even) td {
  background: #fbfcfe;
}

.privacy-page__source th {
  background: #f8fafc;
  color: var(--color-text-strong);
  font-weight: var(--weight-semibold);
}

.privacy-page__source td p,
.privacy-page__source td div,
.privacy-page__source th p,
.privacy-page__source th div {
  margin-top: 0;
}

.privacy-page__source td p + p,
.privacy-page__source th p + p {
  margin-top: 0.26rem;
}

.privacy-page__notes {
  margin-top: 1.32rem;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-md);
  background: rgba(251, 252, 255, 0.96);
  padding: 1rem 1.05rem;
  box-shadow: 0 16px 28px -30px rgba(17, 13, 15, 0.1);
}

.privacy-page__notes p + p {
  margin-top: 0.52rem;
}

.privacy-page__source sup {
  font-size: 0.7em;
  line-height: 0;
}

.privacy-page__source br + br {
  display: none;
}

/* ==================== Motion ==================== */
@keyframes rise-fade {
  from {
    opacity: 0;
    transform: translateY(14px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.landing-hero,
.landing-audience__card,
.landing-highlight-card,
.landing-cta,
.home-hero,
.page-lead,
.article-layout,
.home-hub-card,
.news-card,
.presentation-card,
.content-section,
.testing-flow__card,
.registration-flow__step,
.lower-zone__card {
  animation: rise-fade var(--motion-smooth) both;
}

.home-hub-card:nth-child(1),
.news-card:nth-child(1),
.presentation-card:nth-child(1),
.testing-flow__card:nth-child(1),
.registration-flow__step:nth-child(1),
.lower-zone__card:nth-child(1) {
  animation-delay: 40ms;
}

.home-hub-card:nth-child(2),
.news-card:nth-child(2),
.presentation-card:nth-child(2),
.testing-flow__card:nth-child(2),
.registration-flow__step:nth-child(2),
.lower-zone__card:nth-child(2) {
  animation-delay: 90ms;
}

.home-hub-card:nth-child(3),
.news-card:nth-child(3),
.presentation-card:nth-child(3),
.testing-flow__card:nth-child(3),
.registration-flow__step:nth-child(3),
.lower-zone__card:nth-child(3) {
  animation-delay: 130ms;
}

@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* ==================== Responsive ==================== */
@media (max-width: 1260px) {
  .micro-nav__link {
    padding-inline: 0.84rem;
    font-size: 0.79rem;
  }

  .micro-nav__dropdown {
    min-width: 220px;
  }

  .home-hero {
    grid-template-columns: minmax(0, 1fr) minmax(310px, 0.88fr);
  }

  .home-hero__image {
    min-height: 500px;
  }

  .testing-app__controls {
    grid-template-columns: minmax(220px, 1.4fr) repeat(2, minmax(180px, 1fr));
  }
}

@media (max-width: 1024px) {
  :root {
    --rhythm-listing: clamp(2.3rem, 1.8vw + 1rem, 3.3rem);
    --rhythm-content: clamp(2.7rem, 2vw + 1.15rem, 3.8rem);
    --prefooter-listing: clamp(6rem, 4vw + 2rem, 7.5rem);
    --prefooter-content: clamp(6.8rem, 4.4vw + 2.4rem, 8.3rem);
  }

  .site-header__inner {
    min-height: 82px;
    row-gap: 0.6rem;
  }

  .site-header__controls {
    flex: 1 1 auto;
    gap: 0.55rem;
  }

  .cards-grid--news,
  .cards-grid--presentations {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .home-hero {
    grid-template-columns: 1fr;
  }

  .landing-hero,
  .landing-highlights {
    grid-template-columns: 1fr;
  }

  .home-hero h1 {
    font-size: 3rem;
  }

  .home-hero__image {
    min-height: 300px;
    height: 300px;
  }

  .home-hero__signals {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .home-hub__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .home-hub,
  .home-expert {
    margin-top: 3.2rem;
  }

  .content-section--diagram {
    margin-top: 3.2rem;
  }

  .content-section--regulations {
    margin-top: 3.2rem;
  }

  .feature-list {
    grid-template-columns: 1fr;
  }

  .testing-flow,
  .registration-flow {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .testing-app__controls {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .testing-app__field--search {
    grid-column: 1 / -1;
  }

  .testing-app__layout {
    grid-template-columns: 1fr;
  }

  .testing-app__list {
    max-height: 420px;
  }

  .page--news-article .article-layout {
    grid-template-columns: 1fr;
  }

  .page--news-article .article-layout__content {
    padding-right: 0;
  }

  .page--news-article .article-layout__attachments {
    grid-column: 1;
    grid-row: auto;
    margin-top: 1.25rem;
    padding-top: 0.9rem;
    padding-left: 0;
    border-left: 0;
    border-top: 1px solid var(--color-line-soft);
    position: static;
  }

  .article-gallery__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .article-gallery__item--featured {
    grid-column: span 2;
    grid-row: auto;
  }

  .regulations-grid {
    grid-template-columns: 1fr;
  }

  .reg-card__title {
    text-wrap: pretty;
  }

  .lower-zone__card--contact {
    grid-template-columns: 1fr;
    grid-template-areas:
      "title"
      "list";
  }

  .lower-zone__card--contact .lower-zone__title {
    max-width: none;
    padding-top: 0;
  }

  .lower-zone__list--contact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .privacy-page__content {
    max-width: 100%;
  }

  .privacy-page__source h2 {
    margin-top: 1.6rem;
  }

  .privacy-page__source th:nth-child(2),
  .privacy-page__source td:nth-child(2) {
    min-width: 220px;
  }

  .privacy-page__source th:nth-child(5),
  .privacy-page__source td:nth-child(5) {
    min-width: 190px;
  }
}

@media (max-width: 900px) {
  .site-header__inner {
    min-height: auto;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    row-gap: 0.75rem;
    padding-block: 0.9rem;
  }

  .site-brand {
    min-width: 0;
  }

  .site-brand__logo {
    height: 32px;
  }

  .site-header__controls {
    width: auto;
    flex: 0 0 auto;
    justify-content: flex-end;
    margin-left: 0;
  }

  .site-nav-toggle {
    display: inline-flex;
  }

  .site-header--nav-ready .micro-nav {
    display: none;
  }

  .site-header--nav-ready.site-header--menu-open .micro-nav {
    display: grid;
  }

  .micro-nav {
    grid-column: 1 / -1;
    width: 100%;
    grid-template-columns: 1fr;
    align-items: stretch;
    gap: 0.5rem;
    padding: 0.95rem;
    border-radius: 26px;
    box-shadow: 0 18px 40px -32px rgba(17, 13, 15, 0.28);
  }

  .micro-nav__item {
    width: 100%;
  }

  .micro-nav__link,
  .micro-nav__link--button {
    width: 100%;
    min-height: 48px;
    justify-content: space-between;
    padding-inline: 1rem;
    font-size: 0.94rem;
  }

  .micro-nav__dropdown {
    position: static;
    width: 100%;
    min-width: 0;
    margin-top: 0.28rem;
    padding: 0.4rem 0 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
    transform: none;
  }

  .micro-nav__dropdown--root,
  .micro-nav__dropdown--sub {
    left: auto;
    right: auto;
  }

  .micro-nav__dropdown-link {
    min-height: 44px;
    padding: 0.82rem 1rem;
    border: 1px solid rgba(217, 224, 236, 0.82);
    background: #fbfcff;
  }

  .micro-nav__dropdown-link--button {
    background: #f6f8fb;
  }

  .micro-nav__subgroup {
    margin-top: 0.2rem;
    padding-top: 0.5rem;
  }

  .micro-nav__section {
    margin-top: 0.2rem;
    padding-top: 0.5rem;
  }

  .micro-nav__section-label {
    padding-inline: 1rem;
  }
}

@media (max-width: 768px) {
  :root {
    --font-size-body: 0.92rem;
    --font-size-small: 0.8rem;
  }

  .site-header__inner {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
  }

  .site-brand {
    text-align: left;
  }

  .site-brand__logo {
    height: 32px;
  }

  .site-header__controls {
    width: auto;
    flex-direction: row;
    align-items: center;
    gap: 0;
  }

  .page__main {
    padding-top: 1.2rem;
  }

  .landing-section {
    padding-bottom: clamp(4rem, 10vw, 5.4rem);
  }

  .page-lead__actions,
  .landing-hero__actions,
  .landing-cta__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .page-lead__actions .button,
  .landing-hero__actions .button,
  .landing-cta__actions .button {
    width: 100%;
    min-width: 0;
  }

  .document-viewer-shell__actions,
  .document-viewer-shell__actions .button {
    width: 100%;
  }

  .news-toolbar {
    width: 100%;
  }

  .news-sort {
    width: 100%;
    justify-content: space-between;
  }

  .news-sort__select {
    flex: 1 1 auto;
    min-width: 0;
  }

  .landing-hero,
  .landing-audience__card,
  .landing-highlight-card,
  .landing-cta {
    padding: 1.12rem;
  }

  .cards-grid,
  .cards-grid--news,
  .cards-grid--presentations,
  .home-hub__grid,
  .testing-flow,
  .registration-flow,
  .feature-list,
  .home-hero__signals {
    grid-template-columns: 1fr;
    gap: 0.78rem;
  }

  .news-card__action {
    opacity: 1;
    transform: none;
  }

  .article-layout {
    border-radius: var(--radius-lg);
    padding: 1rem;
  }

  .article-layout__header {
    margin-bottom: 1rem;
  }

  .article-layout__cover {
    margin-bottom: 1rem;
  }

  .article-layout__attachments {
    margin-top: 1.2rem;
    padding-top: 0.86rem;
  }

  .attachment-item {
    grid-template-columns: auto minmax(0, 1fr);
    row-gap: 0.34rem;
  }

  .attachment-item__download {
    grid-column: 2;
    justify-self: end;
  }

  .attachment-list--tiles {
    grid-template-columns: 1fr;
  }

  .attachment-list--tiles .attachment-item {
    min-height: 0;
  }

  .article-layout__gallery {
    margin-top: 1.35rem;
    padding-top: 0.95rem;
  }

  .article-gallery__grid {
    grid-template-columns: 1fr;
  }

  .article-gallery__item--featured {
    grid-column: auto;
  }

  .home-hero {
    border-radius: 20px;
  }

  .home-hero__content {
    padding: 1.05rem;
    gap: 0.72rem;
  }

  .home-hero h1 {
    font-size: 2.4rem;
  }

  .home-hero__media-badge {
    left: 0.75rem;
    right: 0.75rem;
    max-width: none;
  }

  .home-hero__actions,
  .testing-actions,
  .registration-actions,
  .cookie-banner__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .home-hero__actions .button,
  .testing-actions .button,
  .registration-actions .button,
  .cookie-banner__actions .button {
    width: 100%;
    min-width: 0;
  }

  .home-hub-card,
  .content-section,
  .testing-flow__card,
  .registration-flow__step,
  .lower-zone__card {
    padding: 1rem;
  }

  .testing-app__hero,
  .testing-app__content,
  .testing-app__footer {
    padding-inline: 0.95rem;
  }

  .testing-app__controls {
    display: grid;
    grid-template-columns: 1fr;
  }

  .testing-app__content {
    min-height: 0;
  }

  .testing-app__answer-row,
  .testing-app__footer,
  .testing-app__footer-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .testing-app__answer-badge {
    align-self: flex-start;
  }

  .testing-app__list {
    max-height: 360px;
  }

  .home-hub-card__header {
    gap: 0.6rem;
  }

  .lower-zone__list--contact {
    grid-template-columns: 1fr;
  }

  .home-hub-card__icon {
    width: 38px;
    height: 38px;
    border-radius: 10px;
  }

  .home-hub-card__icon svg {
    width: 20px;
    height: 20px;
  }

  .diagram {
    padding: 0.72rem;
  }

  .diagram__legend {
    grid-template-columns: 1fr;
  }

  .diagram__svg {
    min-width: 980px;
  }

  .site-footer__inner {
    grid-template-columns: 1fr;
    justify-items: center;
    gap: 0.7rem;
    padding-block: 1rem;
  }

  .footer-links {
    width: 100%;
    justify-content: center;
  }

  .cookie-banner {
    left: var(--flow-sm);
    right: var(--flow-sm);
    transform: none;
    width: auto;
  }

  .cookie-banner__inner {
    padding: 0.9rem;
    flex-direction: column;
    align-items: stretch;
  }

  .privacy-page__source {
    font-size: 0.9rem;
    line-height: 1.62;
  }

  .privacy-page__source h2 {
    font-size: 1.1rem;
    margin-top: 1.3rem;
  }

  .privacy-page__source h3 {
    font-size: 0.98rem;
    margin-top: 1.05rem;
  }

  .privacy-page__source th,
  .privacy-page__source td {
    font-size: 0.84rem;
    line-height: 1.52;
    padding: 0.5rem 0.55rem;
  }
}

/* ============================================================
   Серверный пульт управления (AdonisJS). Дополняет существующие
   admin-* стили классами разметки дашборда и flash-уведомлений.
   ============================================================ */
.admin-page--dashboard {
  max-width: 1120px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: clamp(1.5rem, 2vw, 2.4rem);
}

.site-flash {
  margin: 0;
  border-radius: var(--radius-md);
  padding: 0.85rem 1.1rem;
  font-size: var(--font-size-small);
  font-weight: var(--weight-medium);
  border: 1px solid var(--color-line-strong);
  background: var(--surface-premium);
  color: var(--color-text-main);
}
.site-flash--success {
  border-color: #b8e0c2;
  background: #eef9f1;
  color: #1f7a3d;
}
.site-flash--error {
  border-color: #f3c2c5;
  background: var(--color-primary-soft);
  color: var(--color-primary-active);
}

.admin-inline-form {
  display: inline-flex;
  margin: 0;
}

.admin-block {
  background: var(--surface-base);
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
  padding: clamp(1.1rem, 2vw, 1.75rem);
  display: flex;
  flex-direction: column;
  gap: var(--flow-lg);
}
.admin-block > h2 {
  margin: 0;
  font-size: var(--font-size-section-title);
  color: var(--color-text-strong);
}

.admin-create {
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-md);
  background: var(--surface-tint);
  padding: 0.35rem 1rem;
}
.admin-create > summary {
  cursor: pointer;
  font-weight: var(--weight-semibold);
  color: var(--color-primary);
  padding: 0.55rem 0;
  list-style: none;
}
.admin-create > summary::-webkit-details-marker {
  display: none;
}
.admin-create > summary::before {
  content: "+ ";
  font-weight: var(--weight-bold);
}
.admin-create[open] > summary::before {
  content: "− ";
}
.admin-create[open] > summary {
  margin-bottom: var(--flow-md);
  border-bottom: 1px solid var(--color-line-soft);
}

.admin-grid-form {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: var(--flow-md);
  align-items: end;
  margin: 0;
}
.admin-grid-form .admin-field--wide {
  grid-column: 1 / -1;
}
.admin-field--actions {
  display: flex;
  align-items: flex-end;
}
.admin-checkbox {
  grid-auto-flow: column;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: var(--flow-xs);
}
.admin-checkbox input {
  width: auto;
  min-height: 0;
}
.admin-checkbox span {
  text-transform: none;
  letter-spacing: 0;
  font-size: 0.84rem;
}

.admin-list {
  display: flex;
  flex-direction: column;
  gap: var(--flow-lg);
}
.admin-card {
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-md);
  background: var(--surface-raised);
  padding: clamp(0.9rem, 1.6vw, 1.4rem);
  box-shadow: var(--shadow-soft);
}
.admin-delete {
  display: flex;
  justify-content: flex-end;
  margin-top: calc(-1 * var(--flow-md));
  padding-bottom: var(--flow-sm);
}

/* ============================================================
   Пульт управления v2: разделы (вкладки), карточки контента,
   статусы, миниатюры, загрузка изображений, таблица заявок.
   ============================================================ */
.admin-topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  gap: clamp(0.75rem, 2vw, 1.75rem);
  flex-wrap: wrap;
  padding: 0.75rem clamp(1rem, 4vw, 2.5rem);
  background: var(--surface-base);
  border-bottom: 1px solid var(--color-line-soft);
  box-shadow: var(--shadow-soft);
}
.admin-topbar__brand {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  font-weight: var(--weight-semibold);
  color: var(--color-text-strong);
  text-decoration: none;
}
.admin-topbar__brand img {
  height: 34px;
  width: auto;
}
.admin-topbar__nav {
  display: flex;
  gap: 0.3rem;
  flex-wrap: wrap;
  margin-right: auto;
}
.admin-tab {
  display: inline-flex;
  align-items: center;
  padding: 0.5rem 0.95rem;
  border-radius: var(--radius-pill, 999px);
  font-size: 0.92rem;
  font-weight: var(--weight-medium);
  color: var(--color-text-muted);
  text-decoration: none;
  transition: background 0.15s ease, color 0.15s ease;
}
.admin-tab:hover {
  background: var(--surface-tint);
  color: var(--color-text-strong);
}
.admin-tab.is-active {
  background: var(--color-primary);
  color: #fff;
}
.admin-topbar__actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.admin-hero {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.admin-hero h1 {
  margin: 0;
  font-size: clamp(1.6rem, 2.4vw, 2.2rem);
  color: var(--color-text-strong);
}
.admin-hero p {
  margin: 0;
  max-width: 70ch;
  color: var(--color-text-muted);
}

.admin-summary__card {
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.92);
  padding: 1.1rem 1.2rem;
  display: grid;
  gap: 0.3rem;
  text-decoration: none;
  transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}
.admin-summary__card:hover {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-soft);
  transform: translateY(-2px);
}
.admin-summary__card em {
  font-style: normal;
  font-size: 0.82rem;
  font-weight: var(--weight-semibold);
  color: var(--color-primary);
}

.admin-block__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--flow-md);
  flex-wrap: wrap;
}
.admin-block__head h1 {
  margin: 0;
  font-size: var(--font-size-section-title);
  color: var(--color-text-strong);
}
.admin-block__hint {
  margin: 0.35rem 0 0;
  max-width: 80ch;
  color: var(--color-text-muted);
  font-size: 0.9rem;
  line-height: 1.5;
}

.admin-form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--flow-md);
  align-items: end;
  margin: 0;
}
.admin-form-grid .admin-field--wide {
  grid-column: 1 / -1;
}

.admin-field input[type="file"] {
  min-height: 0;
  padding: 0.55rem 0.65rem;
  background: var(--surface-tint);
  font-size: 0.85rem;
  cursor: pointer;
}

.admin-card__bar {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  margin-bottom: var(--flow-md);
  padding-bottom: var(--flow-sm);
  border-bottom: 1px solid var(--color-line-soft);
  flex-wrap: wrap;
}
.admin-card__title {
  font-weight: var(--weight-semibold);
  color: var(--color-text-strong);
}
.admin-card__footer {
  grid-column: 1 / -1;
  display: flex;
  justify-content: flex-end;
}
.admin-card__delete {
  display: flex;
  justify-content: flex-end;
  margin-top: var(--flow-sm);
}
.admin-card--compact {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--flow-md);
  flex-wrap: wrap;
}
.admin-card__main {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}
.admin-card__meta {
  margin: 0;
  color: var(--color-text-muted);
  font-size: 0.86rem;
}

.admin-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.22rem 0.6rem;
  border-radius: var(--radius-pill, 999px);
  font-size: 0.74rem;
  font-weight: var(--weight-semibold);
  letter-spacing: 0.02em;
  border: 1px solid transparent;
  white-space: nowrap;
}
.admin-badge--confirmed {
  background: #eef9f1;
  border-color: #b8e0c2;
  color: #1f7a3d;
}
.admin-badge--recruiting {
  background: #fff6e6;
  border-color: #f3dca0;
  color: #9a6a07;
}
.admin-badge--full {
  background: var(--color-primary-soft);
  border-color: #f3c2c5;
  color: var(--color-primary-active);
}
.admin-badge--video {
  background: #eef1fb;
  border-color: #c3cdf0;
  color: #34459a;
}
.admin-badge--article {
  background: var(--surface-tint);
  border-color: var(--color-line-soft);
  color: var(--color-text-muted);
}

.admin-thumb {
  width: 100%;
  max-width: 220px;
  height: auto;
  border-radius: var(--radius-sm, 8px);
  border: 1px solid var(--color-line-soft);
}

.admin-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: var(--flow-sm);
}
.admin-gallery__item {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-sm, 8px);
  padding: 0.4rem;
  background: var(--surface-tint);
}
.admin-gallery__item img {
  width: 100%;
  height: 96px;
  object-fit: cover;
  border-radius: 6px;
}
.admin-gallery__remove {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.78rem;
  color: var(--color-text-muted);
  cursor: pointer;
}
.admin-gallery__remove input {
  width: auto;
  min-height: 0;
}

.admin-table-wrap {
  overflow-x: auto;
}
.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.88rem;
}
.admin-table th,
.admin-table td {
  text-align: left;
  padding: 0.6rem 0.7rem;
  border-bottom: 1px solid var(--color-line-soft);
  white-space: nowrap;
}
.admin-table th {
  color: var(--color-text-muted);
  font-size: 0.74rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.admin-table tbody tr:hover {
  background: var(--surface-tint);
}

.admin-create--reg > summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--flow-sm);
}
.admin-create--reg > summary::before {
  content: none;
}
.admin-reg-summary__count {
  font-size: 0.8rem;
  font-weight: var(--weight-medium);
  color: var(--color-text-muted);
}
