/**
 * design-system.css — Умысел Design System
 *
 * Единый источник истины для токенов, типографики и компонентов.
 * Подключается в functions.php до main.css.
 *
 * Структура:
 *   1. Цвета
 *   2. Типографика
 *   3. Отступы (базовая единица: 1.04em)
 *   4. Скругления
 *   5. Тени
 *   6. Переходы / анимации
 *   7. Z-index
 *   8. Компоненты (кнопки, инпуты, бейджи, карточки)
 *   9. Утилиты
 */

/* =============================================================================
   1. ЦВЕТА
============================================================================= */

:root {
    /* Нейтральные */
    --c-black:      #000;
    --c-white:      #fff;
    --c-gray-50:    #fafafa;
    --c-gray-100:   #f3f3f3;
    --c-gray-200:   #eaeaea;
    --c-gray-300:   #ddd;
    --c-gray-400:   #c7c7c7;
    --c-gray-500:   #b0b0b0;

    /* Прозрачный чёрный (для overlay, текста, рамок) */
    --c-ink-06:   rgba(0,0,0,0.06);
    --c-ink-12:   rgba(0,0,0,0.12);
    --c-ink-18:   rgba(0,0,0,0.18);
    --c-ink-25:   rgba(0,0,0,0.25);
    --c-ink-40:   rgba(0,0,0,0.40);
    --c-ink-60:   rgba(0,0,0,0.60);

    /* Смысловые цвета */
    --c-error:      #c0392b;
    --c-error-bg:   #fde8e8;
    --c-success:    #3a7a3a;
    --c-success-bg: #e8f5e9;
    --c-warning:    #a0600a;
    --c-warning-bg: #fff3e0;
    --c-info:       #1565c0;
    --c-info-bg:    #e3f2fd;

    /* Поверхности */
    --c-surface:         var(--c-white);
    --c-surface-raised:  var(--c-gray-50);
    --c-surface-muted:   var(--c-gray-100);
    --c-surface-popup:   var(--c-gray-200);

    /* Акцент (сейчас чёрный; заменить на бренд-цвет при необходимости) */
    --c-accent:          var(--c-black);
    --c-accent-muted:    var(--c-gray-400);
}

/* =============================================================================
   2. ТИПОГРАФИКА
============================================================================= */

:root {
    --font-main:  'Varela Round', 'Varela', sans-serif;
    --font-brand: 'Pl 99 Delo 2', Impact, sans-serif;
    --font-mono:  'Courier New', monospace;

    /* Размеры текста */
    --text-2xs: 0.67em;
    --text-xs:  0.73em;
    --text-sm:  0.83em;
    --text-md:  1.04em;
    --text-lg:  1.25em;
    --text-xl:  1.67em;
    --text-2xl: 2em;
    --text-3xl: 2.5em;

    /* Высота строки */
    --lh-tight:  1.1;
    --lh-snug:   1.25;
    --lh-base:   1.4;
    --lh-relaxed: 1.6;

    /* Вес */
    --fw-regular: 400;
    --fw-medium:  500;
    --fw-semi:    600;
    --fw-bold:    700;
}

/* =============================================================================
   3. ОТСТУПЫ  (базовая единица --sp = 1.04em)
============================================================================= */

:root {
    --sp:   1.04em;   /* base unit */

    --sp-1: calc(var(--sp) * 0.25);   /* 0.26em */
    --sp-2: calc(var(--sp) * 0.5);    /* 0.52em */
    --sp-3: var(--sp);                /* 1.04em */
    --sp-4: calc(var(--sp) * 1.5);    /* 1.56em */
    --sp-5: calc(var(--sp) * 2);      /* 2.08em */
    --sp-6: calc(var(--sp) * 3);      /* 3.12em */
    --sp-7: calc(var(--sp) * 4);      /* 4.16em */
    --sp-8: calc(var(--sp) * 6);      /* 6.24em */

    /* Горизонтальные отступы страницы */
    --page-px: var(--sp-3);
}

/* =============================================================================
   4. СКРУГЛЕНИЯ
============================================================================= */

:root {
    --r-xs: 0.26em;
    --r-sm: 0.52em;
    --r-md: 0.78em;
    --r-lg: 1.04em;
    --r-xl: 1.56em;
    --r-pill: 100vmax;
}

/* =============================================================================
   5. ТЕНИ
============================================================================= */

:root {
    --shadow-xs: 0 1px 3px var(--c-ink-12);
    --shadow-sm: 0 2px 8px var(--c-ink-12);
    --shadow-md: 0 4px 16px var(--c-ink-12);
    --shadow-lg: 0 8px 32px var(--c-ink-18);
}

/* =============================================================================
   6. ПЕРЕХОДЫ
============================================================================= */

:root {
    /* Кастомные кривые (сильнее чем встроенные ease/ease-in-out) */
    --ease-out:    cubic-bezier(0.23, 1, 0.32, 1);
    --ease-in-out: cubic-bezier(0.645, 0.045, 0.355, 1);
    --ease-drawer: cubic-bezier(0.32, 0.72, 0, 1);   /* iOS-like drawer */
    --ease:        var(--ease-out);

    --t-fast:    0.15s var(--ease-out);
    --t-base:    0.25s var(--ease-out);
    --t-slow:    0.35s var(--ease-drawer);

    /* Слайд-in панелей */
    --t-panel:   var(--t-slow);
}

/* =============================================================================
   7. Z-INDEX
============================================================================= */

:root {
    --z-base:      1;
    --z-raised:    10;
    --z-dropdown:  100;
    --z-header:    998;
    --z-popup:     999;
    --z-overlay:   9000;
    --z-modal:     9999;
}

/* =============================================================================
   8. КОМПОНЕНТЫ
============================================================================= */

/* ── Кнопки ──────────────────────────────────────────────────────────────── */

.ds-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--sp-2);
    padding: 0.75em 1.25em;
    font-family: var(--font-main);
    font-size: 1em;
    font-weight: var(--fw-regular);
    line-height: var(--lh-tight);
    border-radius: var(--r-sm);
    border: none;
    cursor: pointer;
    text-decoration: none;
    transition: opacity var(--t-fast), background-color var(--t-fast);
}
.ds-btn:hover    { opacity: 0.85; }
.ds-btn:active   { opacity: 0.7; }
.ds-btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* Варианты */
.ds-btn--primary   { background: var(--c-black); color: var(--c-white); }
.ds-btn--secondary { background: var(--c-gray-400); color: var(--c-black); }
.ds-btn--ghost     { background: transparent; color: var(--c-black); border: 1px solid var(--c-ink-25); }
.ds-btn--danger    { background: var(--c-error-bg); color: var(--c-error); }

/* Размеры */
.ds-btn--sm   { padding: 0.5em 0.85em; font-size: var(--text-sm); }
.ds-btn--lg   { padding: 0.9em 1.56em; font-size: var(--text-md); }
.ds-btn--full { width: 100%; }

/* Состояние загрузки */
.ds-btn--loading { pointer-events: none; opacity: 0.6; }

/* ── Инпуты ──────────────────────────────────────────────────────────────── */

.ds-input {
    display: block;
    width: 100%;
    padding: 0.75em 1em;
    font-family: var(--font-main);
    font-size: 1em;
    line-height: var(--lh-base);
    color: var(--c-black);
    background: var(--c-gray-100);
    border: 1px solid transparent;
    border-radius: var(--r-sm);
    box-sizing: border-box;
    transition: border-color var(--t-fast), background var(--t-fast);
    outline: none;
}
.ds-input:focus   { border-color: var(--c-ink-25); background: var(--c-white); }
.ds-input--error  { border-color: var(--c-error) !important; background: var(--c-error-bg); }
.ds-input::placeholder { color: var(--c-ink-40); }

/* ── Лейблы ──────────────────────────────────────────────────────────────── */

.ds-label {
    display: block;
    font-size: var(--text-sm);
    font-weight: var(--fw-semi);
    color: var(--c-ink-60);
    margin-bottom: var(--sp-1);
}

/* ── Группа поля (label + input + error) ────────────────────────────────── */

.ds-field {
    display: flex;
    flex-direction: column;
    gap: var(--sp-1);
}
.ds-field__error {
    font-size: var(--text-xs);
    color: var(--c-error);
    line-height: var(--lh-base);
}

/* ── Карточка ────────────────────────────────────────────────────────────── */

.ds-card {
    background: var(--c-surface);
    border-radius: var(--r-md);
    border: 1px solid var(--c-ink-06);
    padding: var(--sp-4);
}
.ds-card--muted  { background: var(--c-surface-muted); }
.ds-card--raised { background: var(--c-surface-raised); box-shadow: var(--shadow-sm); }

/* ── Бейджи статуса ──────────────────────────────────────────────────────── */

.ds-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.2em 0.6em;
    font-size: var(--text-xs);
    font-weight: var(--fw-semi);
    line-height: var(--lh-tight);
    border-radius: var(--r-pill);
    white-space: nowrap;
}
.ds-badge--default  { background: var(--c-gray-200); color: var(--c-ink-60); }
.ds-badge--pending  { background: var(--c-warning-bg); color: var(--c-warning); }
.ds-badge--active   { background: var(--c-info-bg); color: var(--c-info); }
.ds-badge--success  { background: var(--c-success-bg); color: var(--c-success); }
.ds-badge--error    { background: var(--c-error-bg); color: var(--c-error); }

/* ── Разделитель ─────────────────────────────────────────────────────────── */

.ds-divider {
    border: none;
    border-top: 1px solid var(--c-ink-12);
    margin: var(--sp-3) 0;
}

/* ── Сообщения ───────────────────────────────────────────────────────────── */

.ds-alert {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-2);
    padding: var(--sp-2) var(--sp-3);
    border-radius: var(--r-sm);
    font-size: var(--text-sm);
    line-height: var(--lh-base);
}
.ds-alert--error   { background: var(--c-error-bg);   color: var(--c-error); }
.ds-alert--success { background: var(--c-success-bg); color: var(--c-success); }
.ds-alert--info    { background: var(--c-info-bg);    color: var(--c-info); }
.ds-alert--warning { background: var(--c-warning-bg); color: var(--c-warning); }

/* ── Трекер статуса заказа ────────────────────────────────────────────────── */

.ds-tracker {
    display: flex;
    align-items: flex-start;
    gap: 0;
    position: relative;
    padding: var(--sp-3) 0;
}

.ds-tracker__step {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex: 1;
    position: relative;
    gap: var(--sp-1);
}

.ds-tracker__step::before {
    content: '';
    position: absolute;
    top: 0.65em;
    left: calc(50% + 0.65em);
    width: calc(100% - 1.3em);
    height: 2px;
    background: var(--c-gray-300);
    transition: background var(--t-base);
}
.ds-tracker__step:last-child::before { display: none; }

.ds-tracker__step.is-done::before    { background: var(--c-black); }
.ds-tracker__step.is-active::before  { background: var(--c-gray-300); }

.ds-tracker__dot {
    width: 1.3em;
    height: 1.3em;
    border-radius: var(--r-pill);
    border: 2px solid var(--c-gray-300);
    background: var(--c-white);
    position: relative;
    z-index: 1;
    transition: background var(--t-base), border-color var(--t-base), border-width var(--t-base);
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.ds-tracker__step.is-done   .ds-tracker__dot { background: var(--c-black); border-color: var(--c-black); }
.ds-tracker__step.is-active .ds-tracker__dot { border-color: var(--c-black); border-width: 3px; }

.ds-tracker__label {
    font-size: var(--text-xs);
    color: var(--c-ink-40);
    text-align: center;
    line-height: var(--lh-snug);
    transition: color var(--t-fast);
}
.ds-tracker__step.is-done   .ds-tracker__label { color: var(--c-ink-60); }
.ds-tracker__step.is-active .ds-tracker__label { color: var(--c-black); font-weight: var(--fw-semi); }

/* ── Таблица данных (для позиций заказа) ─────────────────────────────────── */

.ds-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--text-sm);
}
.ds-table th {
    text-align: left;
    font-weight: var(--fw-semi);
    color: var(--c-ink-40);
    padding: var(--sp-1) var(--sp-2);
    border-bottom: 1px solid var(--c-ink-12);
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.ds-table td {
    padding: var(--sp-2);
    border-bottom: 1px solid var(--c-ink-06);
    vertical-align: middle;
}
.ds-table tr:last-child td { border-bottom: none; }

/* =============================================================================
   9. УТИЛИТЫ
============================================================================= */

.ds-text-muted   { color: var(--c-ink-40); }
.ds-text-sm      { font-size: var(--text-sm); }
.ds-text-xs      { font-size: var(--text-xs); }
.ds-text-lg      { font-size: var(--text-lg); }
.ds-text-bold    { font-weight: var(--fw-semi); }
.ds-text-center  { text-align: center; }

.ds-flex         { display: flex; }
.ds-flex-col     { display: flex; flex-direction: column; }
.ds-items-center { align-items: center; }
.ds-justify-between { justify-content: space-between; }
.ds-gap-1        { gap: var(--sp-1); }
.ds-gap-2        { gap: var(--sp-2); }
.ds-gap-3        { gap: var(--sp-3); }

.ds-w-full       { width: 100%; }
.ds-mt-2         { margin-top: var(--sp-2); }
.ds-mt-3         { margin-top: var(--sp-3); }
.ds-mt-4         { margin-top: var(--sp-4); }

/* Спиннер загрузки */
@keyframes ds-spin { to { transform: rotate(360deg); } }
.ds-spinner {
    width: 1.2em;
    height: 1.2em;
    border: 2px solid var(--c-ink-12);
    border-top-color: var(--c-black);
    border-radius: 50%;
    animation: ds-spin 0.4s linear infinite;
    display: inline-block;
}

/* =============================================================================
   10. ДОСТУПНОСТЬ — prefers-reduced-motion
   Отключает анимации для пользователей с вестибулярными нарушениями.
   Сохраняет финальные состояния — вёрстка не ломается.
============================================================================= */

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