/*
Theme Name: МалоМетров Child
Theme URI: https://malometrov.ru/
Description: Дочерняя тема GeneratePress для проекта МалоМетров — кастомные шаблоны и дизайн-система бренда (CSS-токены --mm-*). Обновления GeneratePress не затрагивают эту тему.
Author: Claude Code
Template: generatepress
Version: 2.1.6
Text Domain: malometrov-child
License: GNU General Public License v2 or later
*/

/* ============================================================
   МалоМетров — Дизайн-система (design_handoff_malometrov_ds).
   Источник истины для цвета, типографики, отступов, радиусов и теней.
   Шрифты (Onest + JetBrains Mono) подключаются в functions.php.
   Все шаблоны используют ТОЛЬКО переменные --mm-*, без хардкода.
   ============================================================ */

/* ---- Цвет ---- */
:root {
  /* Core */
  --mm-graphite: #211C17;       /* ink: текст, чертёжный знак, тёмные поверхности */
  --mm-terracotta: #C2603A;     /* единственный акцент: CTA, ссылки, .ru */
  --mm-cream: #FBF8F2;          /* основная тёплая поверхность */

  /* Нейтральная шкала (тёплая, одно семейство) */
  --mm-cream-50: #FBF8F2;       /* Крем */
  --mm-linen-100: #F1EBE0;      /* Лён */
  --mm-sand-200: #E4DAC9;       /* Песок */
  --mm-stone-300: #BCB0A0;      /* Камень */
  --mm-taupe-500: #7A7163;      /* Таупе */
  --mm-graphite-900: #211C17;   /* Графит */

  /* Холст за карточками */
  --mm-canvas: #e7e5df;

  /* Акцентная шкала (терракота) */
  --mm-accent-tint: #F0DBCF;    /* Тинт — подложки, hover-фон */
  --mm-accent-soft: #DD8A66;    /* Мягкая — иллюстрации, вторичный акцент */
  --mm-accent: #C2603A;         /* Терракота — базовый акцент */
  --mm-accent-clay: #9A4A2C;    /* Глина — pressed / тёмное на светлом */
  --mm-accent-on-dark: #E2895F; /* терракота, осветлённая для тёмного фона */

  /* Вторичный */
  --mm-olive: #7C8568;          /* Олива — редкий вторичный сигнал (статусы, теги) */

  /* Support / линии */
  --mm-label-muted: #9a8f7e;    /* mono-метки, приглушённая мета */
  --mm-border: #ece5d8;         /* волосяная линия на креме */
  --mm-border-strong: #e2d9c9;  /* границы контролов */
  --mm-border-warm: #d6cab5;    /* разделители на песке */

  /* Семантические алиасы */
  --mm-bg-canvas: var(--mm-canvas);
  --mm-surface: var(--mm-cream);
  --mm-surface-sunk: var(--mm-linen-100);
  --mm-surface-dark: var(--mm-graphite);
  --mm-text: var(--mm-graphite-900);
  --mm-text-secondary: #6c6356;
  --mm-text-strong-body: #4a4338;
  --mm-text-muted: var(--mm-taupe-500);
  --mm-text-on-dark: var(--mm-cream);
  --mm-text-on-dark-muted: #cfc8ba;
  --mm-link: var(--mm-terracotta);
}

/* ---- Типографика ---- */
:root {
  --mm-font-sans: 'Onest', system-ui, sans-serif;            /* всё */
  --mm-font-mono: 'JetBrains Mono', ui-monospace, monospace; /* только технические метки */

  --mm-w-regular: 400;
  --mm-w-medium: 500;
  --mm-w-semibold: 600;
  --mm-w-bold: 700;
  --mm-w-black: 800;

  --mm-display-size: 52px;  --mm-display-weight: 800; --mm-display-track: -0.03em; --mm-display-leading: 1.05;
  --mm-h1-size: 34px;       --mm-h1-weight: 800;      --mm-h1-track: -0.02em;      --mm-h1-leading: 1.1;
  --mm-h2-size: 24px;       --mm-h2-weight: 700;      --mm-h2-track: -0.02em;      --mm-h2-leading: 1.2;
  --mm-h3-size: 18px;       --mm-h3-weight: 700;      --mm-h3-track: -0.01em;      --mm-h3-leading: 1.25;
  --mm-body-size: 16px;     --mm-body-weight: 400;    --mm-body-leading: 1.6;
  --mm-small-size: 13.5px;  --mm-small-weight: 400;   --mm-small-leading: 1.5;

  --mm-label-size: 11px;    --mm-label-weight: 500;   --mm-label-track: 0.12em;
}

/* ---- Отступы, радиусы, тени ---- */
:root {
  --mm-space-1: 4px;
  --mm-space-2: 8px;
  --mm-space-3: 12px;
  --mm-space-4: 16px;
  --mm-space-5: 24px;
  --mm-space-6: 32px;
  --mm-space-7: 40px;
  --mm-space-8: 48px;
  --mm-space-9: 64px;

  --mm-radius-control: 8px;  /* кнопки, поля */
  --mm-radius-card: 10px;    /* карточки */
  --mm-radius-window: 12px;  /* крупные рамки */
  --mm-radius-pill: 20px;    /* фильтр-чипы */
  --mm-radius-badge: 14px;   /* теги / бейджи */

  --mm-shadow-card: 0 1px 3px rgba(0,0,0,0.08);
  --mm-shadow-hover: 0 8px 24px rgba(33,28,23,0.10);
  --mm-shadow-window: 0 24px 60px rgba(33,28,23,0.18);

  --mm-border-width: 1px;
}

/* ============================================================
   Перепривязка глобальной палитры GeneratePress → дизайн-система.
   GP объявляет инлайном :root{--base-2;--contrast;--accent;…} и тянет
   из них фон body, текст, ссылки и пресеты цветов Gutenberg.
   Переопределяем на html:root (специфичность выше, чем :root GP, —
   побеждает независимо от порядка инлайн-CSS).
   ============================================================ */
html:root {
  --base:       var(--mm-cream);          /* было #f0f0f0 — тёплые фоны секций */
  --base-2:     var(--mm-cream);          /* было #f7f8f9 — фон страницы (body) */
  --base-3:     #ffffff;                  /* белый для явных карточек/контента */
  --contrast:   var(--mm-graphite-900);   /* было #222222 — основной текст */
  --contrast-2: var(--mm-text-secondary); /* было #575760 — вторичный текст */
  --contrast-3: var(--mm-text-muted);     /* было #b2b2be — приглушённая мета */
  --accent:     var(--mm-terracotta);     /* было #1e73be (синий!) — акцент GP */
}

/* ============================================================
   Алиасы старой брендовой схемы (раздел 9 ТЗ) → новая дизайн-система.
   Для обратной совместимости с любым «Дополнительным CSS» в Кастомайзере.
   ============================================================ */
:root {
  --ink:        var(--mm-graphite);
  --ink-mid:    var(--mm-text-secondary);
  --ink-faint:  var(--mm-text-muted);
  --paper:      var(--mm-cream);
  --paper-warm: var(--mm-linen-100);
  --sand:       var(--mm-sand-200);
  --sand-dark:  var(--mm-border-warm);
  --copper:     var(--mm-terracotta);
  --copper-lt:  var(--mm-accent-soft);
  --white:      #FFFFFF;
  --font-serif: var(--mm-font-sans);
  --font-body:  var(--mm-font-sans);
  --radius:     var(--mm-radius-control);
  --radius-lg:  var(--mm-radius-window);
}

/* ============================================================
   Базовая типографика бренда
   ============================================================ */
body {
  font-family: var(--mm-font-sans);
  font-size: var(--mm-body-size);
  line-height: var(--mm-body-leading);
  color: var(--mm-text);
  background-color: var(--mm-cream);
}

a {
  color: var(--mm-link);
}
/* body-префикс повышает специфичность над GP `a:hover{color:var(--contrast)}` */
body a:hover,
body a:focus,
body a:active {
  color: var(--mm-accent-clay);
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--mm-font-sans);
  color: var(--mm-text);
}

h1 {
  font-size: var(--mm-h1-size);
  font-weight: var(--mm-h1-weight);
  letter-spacing: var(--mm-h1-track);
  line-height: var(--mm-h1-leading);
}
h2 {
  font-size: var(--mm-h2-size);
  font-weight: var(--mm-h2-weight);
  letter-spacing: var(--mm-h2-track);
  line-height: var(--mm-h2-leading);
}
h3 {
  font-size: var(--mm-h3-size);
  font-weight: var(--mm-h3-weight);
  letter-spacing: var(--mm-h3-track);
  line-height: var(--mm-h3-leading);
}

/* ============================================================
   Логотип в шапке: знак (картинка GP) + словесный знак.
   Полный логотип = иконка + «МалоМетров.ru», Onest 800, «.ru» терракотой.
   Текст живой (не вшит в SVG) — по правилу брендгайда (Архив/svg/README.txt).
   ============================================================ */
.site-logo {
  margin-right: var(--mm-space-4); /* охранное поле ≈ ¼ высоты знака */
}
.site-logo img.header-image {
  display: block;
}
/* Словесный знак «МалоМетров» + терракотовое «.ru» */
.main-title {
  font-family: var(--mm-font-sans);
  font-weight: var(--mm-w-black); /* Onest 800 */
  letter-spacing: -0.02em;
}
.main-title a::after {
  content: ".ru";
  color: var(--mm-terracotta);
  font-weight: var(--mm-w-black);
}

/* ---- Утилиты дизайн-системы ---- */

/* Display — крупный заголовок витрины */
.mm-display {
  font-family: var(--mm-font-sans);
  font-size: var(--mm-display-size);
  font-weight: var(--mm-display-weight);
  letter-spacing: var(--mm-display-track);
  line-height: var(--mm-display-leading);
  color: var(--mm-text);
}

/* Mono-метка — короткие технические подписи UPPERCASE (СЕРИЯ 1-447, 31 М²) */
.mm-mono-label {
  font-family: var(--mm-font-mono);
  font-size: var(--mm-label-size);
  font-weight: var(--mm-label-weight);
  letter-spacing: var(--mm-label-track);
  text-transform: uppercase;
  color: var(--mm-label-muted);
}

/* Мелкий текст / подписи */
.mm-small {
  font-size: var(--mm-small-size);
  line-height: var(--mm-small-leading);
  color: var(--mm-text-secondary);
}

/* ---- Кнопки / контролы (базовый вид дизайн-системы) ---- */
.button,
button,
input[type="button"],
input[type="submit"],
.wp-block-button__link {
  font-family: var(--mm-font-sans);
  font-weight: var(--mm-w-semibold);
  background-color: var(--mm-accent);
  color: var(--mm-text-on-dark);
  border-radius: var(--mm-radius-control);
  border: var(--mm-border-width) solid transparent;
  transition: filter .15s ease, transform .15s ease;
}
.button:hover,
button:hover,
input[type="button"]:hover,
input[type="submit"]:hover,
.wp-block-button__link:hover {
  filter: brightness(.94);
  color: var(--mm-text-on-dark);
}
.button:active,
button:active,
input[type="submit"]:active,
.wp-block-button__link:active {
  transform: translateY(1px);
}

/* ============================================================
   Переопределение хардкод-цветов кнопок GeneratePress.
   GP инлайном задаёт серые кнопки (#55555e/#3f4047) селекторами
   высокой специфичности. Бьём их body-префиксом (специфичность выше),
   чтобы единственным акцентом осталась терракота.
   ============================================================ */
body button,
body input[type="button"],
body input[type="reset"],
body input[type="submit"],
body a.button,
body a.wp-block-button__link:not(.has-background) {
  background-color: var(--mm-accent);
  color: var(--mm-text-on-dark);
}
body button:hover,
body input[type="button"]:hover,
body input[type="reset"]:hover,
body input[type="submit"]:hover,
body a.button:hover,
body a.button:focus,
body a.wp-block-button__link:not(.has-background):hover,
body a.wp-block-button__link:not(.has-background):focus {
  background-color: var(--mm-accent);
  color: var(--mm-text-on-dark);
  filter: brightness(.94);
}

/* ---- Поля ввода — терракотовое фокус-кольцо ---- */
input[type="text"],
input[type="email"],
input[type="search"],
input[type="url"],
input[type="tel"],
input[type="number"],
input[type="password"],
textarea,
select {
  font-family: var(--mm-font-sans);
  border: var(--mm-border-width) solid var(--mm-border-strong);
  border-radius: var(--mm-radius-control);
  background-color: var(--mm-surface);
  color: var(--mm-text);
}
input[type="text"]:focus,
input[type="email"]:focus,
input[type="search"]:focus,
input[type="url"]:focus,
input[type="tel"]:focus,
input[type="number"]:focus,
input[type="password"]:focus,
textarea:focus,
select:focus {
  border-color: var(--mm-accent);
  box-shadow: 0 0 0 3px rgba(194,96,58,.12);
  outline: none;
}
