/* base.css — переменные, сброс, типографика */

:root {
  /* База */
  --color-bg: #19265a;
  --color-bg-light: #FFFFFF;
  --color-bg-soft: #F6F7FB;

  /* Текст */
  --color-text: #1A1D2E;
  --color-text-muted: #6B7080;
  --color-text-on-dark: #FFFFFF;

  /* Акценты */
  --color-accent: #FFFFFF;
  --color-accent-hover: #6B7080;
  --color-cosmic: #5B7FFF;
  --color-warm: #5B7FFF;

  /* Утилиты */
  --color-border: #E4E7EF;
  --color-success: #2DBA77;
  --color-danger: #E64E4E;

  --accent: var(--color-cosmic);

  --font-display: "Unbounded", "Onest", system-ui, sans-serif;
  --font-body: "Inter", "Manrope", system-ui, sans-serif;

  --container-max: 1200px;
  --header-h: 64px;

  --space-1: 4px;
  --space-2: 8px;
  --space-3: 16px;
  --space-4: 24px;
  --space-5: 32px;
  --space-6: 48px;
  --space-7: 64px;
  --space-8: 96px;

  --radius-sm: 8px;
  --radius-md: 16px;
  --radius-lg: 24px;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  color: var(--color-text);
  background: var(--color-bg-light);
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  font-weight: 600;
  line-height: 1.2;
  margin: 0 0 var(--space-3);
}

h1 { font-size: clamp(28px, 4vw, 44px); }
h2 { font-size: clamp(24px, 3vw, 32px); }
h3 { font-size: 20px; }

p { margin: 0 0 var(--space-3); }

a {
  color: var(--accent);
  text-decoration: none;
  transition: color 0.2s;
}
a:hover { color: var(--color-accent-hover); }

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

ul, ol {
  margin: 0 0 var(--space-3);
  padding-left: var(--space-4);
}

table {
  border-collapse: collapse;
  width: 100%;
}

button {
  font-family: inherit;
  cursor: pointer;
}

input, textarea, select {
  font-family: inherit;
  font-size: inherit;
}

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

.prose > * + * {
  margin-top: var(--space-3);
}
.prose h2, .prose h3 {
  margin-top: var(--space-5);
}

/* ---- Accessibility ---- */

/* Видимый focus только при клавиатурной навигации */
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
summary:focus-visible,
[tabindex]:focus-visible {
  outline: 2px solid var(--color-cosmic);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

/* main:focus от tabindex="-1" (для skip-link) — без видимой обводки */
main:focus,
main:focus-visible {
  outline: none;
}

/* Skip-to-content — спрятан, появляется при tab */
.skip-to-content {
  position: absolute;
  top: -100px;
  left: var(--space-2);
  z-index: 1000;
  padding: 12px 20px;
  background: var(--color-cosmic);
  color: #fff;
  border-radius: 0 0 var(--radius-sm) var(--radius-sm);
  font-weight: 600;
  transition: top 0.18s ease;
}
.skip-to-content:focus {
  top: 0;
  color: #fff;
}

/* Только для скринридеров */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}
