/**
 * Тема Loyal Club — консистентна с PWA Loyal (D:\pwa-loyal)
 * Цвета и токены из design.json + globals.css
 */

:root {
    /* Brand (design.json) */
    --lc-primary: #C31E3C;
    --lc-primary-hover: #A81830;
    --lc-primary-active: #8F1326;
    --lc-primary-soft: #F6D3DA;
    --lc-primary-rgb: 195, 30, 60;

    /* Neutrals */
    --lc-bg-page: #FFFFFF;
    --lc-bg-section: #F9F9F9;
    --lc-surface-card: #F8F8F8;
    --lc-border: #E6E6E6;
    --lc-text-primary: #1D1D20;
    --lc-text-secondary: #454141;
    --lc-text-muted: #A2A2A2;
    --lc-text-on-accent: #FFFFFF;

    /* State */
    --lc-focus-ring: rgba(195, 30, 60, 0.28);
    --lc-shadow-card: 0 8px 24px rgba(29, 29, 32, 0.08);
    --lc-shadow-card-hover: 0 12px 32px rgba(29, 29, 32, 0.10);

    /* Radii (design.json) */
    --lc-radius-button: 8px;
    --lc-radius-card: 16px;
    --lc-radius-section: 28px;

    /* Переопределение Bootstrap 5 под тему — прямые значения (не var-ссылки)
       чтобы rgba(var(--bs-*-rgb)) работал корректно в Bootstrap 5.3 */
    --bs-primary: #C31E3C;
    --bs-primary-rgb: 195, 30, 60;
    --bs-body-bg: #F9F9F9;
    --bs-body-color: #1D1D20;
    --bs-secondary: #454141;
    --bs-border-color: #E6E6E6;
    --bs-border-radius: 8px;
    --bs-border-radius-sm: 6px;
    --bs-border-radius-lg: 16px;
    --bs-link-color: #C31E3C;
    --bs-link-color-rgb: 195, 30, 60;
    --bs-link-hover-color: #A81830;
    --bs-heading-color: #1D1D20;
    --bs-danger: #EF4444;
    --bs-success: #10B981;
    --bs-warning: #F59E0B;
    --bs-info: #C31E3C;
    --bs-info-rgb: 195, 30, 60;
}

/* Шрифт как в pwa-loyal */
body {
    font-family: Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Кнопки: primary = акцент */
.btn-primary {
    background-color: var(--lc-primary);
    border-color: var(--lc-primary);
}
.btn-primary:hover {
    background-color: var(--lc-primary-hover);
    border-color: var(--lc-primary-hover);
    transform: translateY(-1px);
}
.btn-primary:active {
    background-color: var(--lc-primary-active);
    transform: translateY(0);
}
.btn-outline-primary {
    color: var(--lc-primary);
    border-color: var(--lc-primary);
}
.btn-outline-primary:hover {
    background-color: var(--lc-primary-soft);
    border-color: var(--lc-primary);
    color: var(--lc-primary);
}

/* Карточки: нейтральный фон, тень и радиус как в pwa-loyal */
.card {
    background-color: var(--lc-surface-card);
    border: 1px solid var(--lc-border);
    border-radius: var(--lc-radius-card);
    box-shadow: var(--lc-shadow-card);
    transition: box-shadow 0.18s cubic-bezier(0.2, 0.8, 0.2, 1), transform 0.18s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.card:hover {
    box-shadow: var(--lc-shadow-card-hover);
    border-color: #DDDDDD;
}

/* Навбар кабинета: белый фон, акцентные ссылки */
.navbar-light .navbar-nav .nav-link:hover,
.navbar-light .navbar-nav .nav-link:focus {
    color: var(--lc-primary);
}
.navbar-light .navbar-brand {
    color: var(--lc-text-primary);
}

/* Фокус как в pwa-loyal */
:focus { outline: none; }
:focus-visible {
    outline: 2px solid transparent;
    outline-offset: 2px;
    box-shadow: 0 0 0 4px var(--lc-focus-ring), 0 0 0 1px var(--lc-primary);
}
button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
    outline: none;
    box-shadow: 0 0 0 4px var(--lc-focus-ring), 0 0 0 1px var(--lc-primary);
}

/* Формы: граница при фокусе */
.form-control:focus,
.form-select:focus {
    border-color: var(--lc-primary);
    box-shadow: 0 0 0 4px var(--lc-focus-ring);
}

/* Алёрты: успех/ошибка в стиле pwa */
.alert-success {
    background-color: #D1FAE5;
    color: #059669;
    border-color: #A7F3D0;
}
.alert-danger {
    background-color: #FEE2E2;
    color: #DC2626;
    border-color: #FECACA;
}
.alert-warning,
.bg-warning.text-dark {
    background-color: #FEF3C7;
    color: #92400E;
}
/* alert-info: нейтральный вместо синего */
.alert-info {
    background-color: var(--lc-primary-soft);
    color: var(--lc-primary-active, #8F1326);
    border-color: #EBA8B5;
}

/* Убрать Bootstrap синий полностью */
.text-primary { color: var(--lc-primary) !important; }
.bg-primary { background-color: var(--lc-primary) !important; }
.border-primary { border-color: var(--lc-primary) !important; }
.btn-outline-primary:active,
.btn-outline-primary:focus {
    background-color: var(--lc-primary);
    border-color: var(--lc-primary);
    color: #fff;
}
a { color: var(--lc-primary); }
a:hover { color: var(--lc-primary-hover); }
.breadcrumb-item a { color: var(--lc-primary); }
.breadcrumb-item a:hover { color: var(--lc-primary-hover); }
.nav-link { color: var(--lc-text-primary); }
.nav-link:hover,
.nav-link:focus { color: var(--lc-primary); }
.nav-link.active { color: var(--lc-primary) !important; }

/* Таблицы */
.table th {
    background-color: var(--lc-bg-section);
    color: var(--lc-text-primary);
    font-weight: 600;
}
.table-hover tbody tr:hover {
    background-color: rgba(195, 30, 60, 0.04);
}

/* Progress bar — жёсткое переопределение синего */
.progress-bar,
.progress-bar.bg-primary {
    background-color: #C31E3C !important;
}
.progress {
    --bs-progress-bar-bg: #C31E3C;
}

/* Badge успех = зелёный как в pwa */
.badge.bg-success {
    background-color: #10B981 !important;
}

/* Чекбоксы и радио — акцент */
.form-check-input:checked {
    background-color: var(--lc-primary);
    border-color: var(--lc-primary);
}
.form-check-input:focus {
    border-color: var(--lc-primary-soft);
    box-shadow: 0 0 0 4px var(--lc-focus-ring);
}

/* Админ: тёмный хедер в духе pwa, акцент при ховере */
.navbar-dark,
.lc-admin-nav {
    background-color: var(--lc-text-primary) !important;
}
.navbar-dark .navbar-nav .nav-link,
.lc-admin-nav .navbar-nav .nav-link {
    color: rgba(255, 255, 255, 0.88);
    font-weight: 500;
}
.navbar-dark .navbar-nav .nav-link:hover,
.lc-admin-nav .navbar-nav .nav-link:hover {
    color: var(--lc-primary-soft);
}
.lc-admin-nav .nav-link.lc-nav-link-platform {
    color: var(--lc-primary-soft);
}
.lc-admin-nav .nav-link.lc-nav-link-platform:hover {
    color: #fff;
}
.navbar-dark .navbar-brand,
.lc-admin-nav .navbar-brand {
    color: #fff;
}
.navbar-dark .btn-outline-light:hover,
.lc-admin-nav .btn-outline-light:hover {
    background-color: var(--lc-primary);
    border-color: var(--lc-primary);
    color: #fff;
}
