/* ============= CSS ПЕРЕМЕННЫЕ ============= */
:root {
    /* === ЦВЕТА === */
    --color-primary: #003d68;
    --color-primary-light: #003e66;
    --color-accent: #00c5f4;
    --color-white: #ffffff;
    --color-text: #333333;
    --color-text-light: #666666;
    --color-text-muted: #72777a;
    --color-border: #DFE0EB;
    --color-bg-light: #f5f9fc;
    --color-danger: #f44336;
    --color-success: #4caf50;
    --color-warning: #ff9800;

    /* === ЦВЕТА UI (для совместимости с main.min.css) === */
    --c-ui-blue: #003e66;

    /* === ТИПОГРАФИКА - РАЗМЕРЫ === */
    --font-size-xs: 11px;
    --font-size-sm: 12px;
    --font-size-base: 14px;
    --font-size-md: 15px;
    --font-size-lg: 16px;
    --font-size-xl: 18px;
    --font-size-2xl: 20px;
    --font-size-3xl: 24px;
    --font-size-4xl: 28px;

    /* === ТИПОГРАФИКА - ЗАГОЛОВКИ === */
    --h1-size: var(--font-size-3xl);
    --h2-size: var(--font-size-2xl);
    --h3-size: var(--font-size-xl);
    --h4-size: var(--font-size-lg);
    --h5-size: var(--font-size-base);
    --h6-size: var(--font-size-sm);

    /* === ТИПОГРАФИКА - LINE-HEIGHT === */
    --line-height-tight: 1.2;
    --line-height-normal: 1.5;
    --line-height-relaxed: 1.7;

    /* === ШРИФТЫ === */
    --font-family: 'Montserrat', sans-serif;
    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;

    /* === ОТСТУПЫ === */
    --spacing-xs: 4px;
    --spacing-sm: 8px;
    --spacing-md: 16px;
    --spacing-lg: 24px;
    --spacing-xl: 32px;

    /* === СКРУГЛЕНИЯ === */
    --radius-sm: 4px;
    --radius-md: 6px;
    --radius-lg: 8px;
    --radius-xl: 12px;

    /* === ЛОАДЕР (существующие) === */
    --loaderBgColor: rgba(0,0,0,.5);
    --spinnerWidth: 80px;
    --spinnerHeight: 80px;
    --spinnerSize: 3px;
    --spinnerColor: #003e66;
    --animationSpeed: .8s;
}

/* ============= БАЗОВАЯ ТИПОГРАФИКА ============= */
body {
    font-family: var(--font-family);
    font-size: var(--font-size-base);
    line-height: var(--line-height-normal);
    color: var(--color-text);
}

/* ============= ГЛОБАЛЬНЫЕ СТИЛИ ЗАГОЛОВКОВ СТРАНИЦ ============= */
/* Эти стили работают для .inner-header независимо от родительской обертки */

.inner-header {
    margin-bottom: 5rem;
}

.inner-header .inner-header-top {
    display: flex;
    align-items: flex-end;
}

.inner-header-top .group {
    display: flex;
    align-items: flex-end;
}

.inner-header-top .add-item {
    margin-top: 0 !important;
}

.inner-header-top.top--button {
    gap: 2rem;
    align-items: center;
}

.inner-header .page-icon {
    width: 4rem;
    height: 4rem;
    background: var(--c-ui-blue);
    margin-right: 2rem;
    border-radius: 0.8rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.inner-header .page-icon .icon {
    width: 2rem;
    height: 2rem;
}

.inner-header .page-icon .icon svg {
    display: block;
    width: 100%;
    height: 100%;
    fill: var(--color-white);
}

.inner-header .header-tip {
    padding-top: 2rem;
    font-size: 1.6rem;
    color: var(--color-text-muted);
}

.inner-header .add-item {
    margin-top: 3rem;
}

/* === ЗАГОЛОВКИ СТРАНИЦ === */
.page-title,
.inner-header-top .h1 {
    font-size: var(--h1-size);
    font-weight: var(--font-weight-bold);
    color: var(--color-primary);
    line-height: var(--line-height-tight);
    margin: 0 0 var(--spacing-md) 0;
}

/* page-header h1 наследует цвет от родителя (для темных фонов) */
.page-header h1 {
    font-size: var(--h1-size);
    font-weight: var(--font-weight-bold);
    line-height: var(--line-height-tight);
    margin: 0;
}

/* === ЗАГОЛОВКИ СЕКЦИЙ === */
.section-title,
.modal .title-box h2 {
    font-size: var(--h2-size);
    font-weight: var(--font-weight-semibold);
    color: var(--color-primary);
    line-height: var(--line-height-tight);
    margin: 0 0 var(--spacing-md) 0;
}

/* === ЗАГОЛОВКИ БЛОКОВ/ВИДЖЕТОВ === */
.block-title,
.widget-title,
.info-item .head-item h3,
.item-header .item-title {
    font-size: var(--h3-size);
    font-weight: var(--font-weight-semibold);
    color: var(--color-primary);
    line-height: var(--line-height-tight);
    text-transform: uppercase;
    margin: 0;
}

/* === ЗАГОЛОВКИ КАРТОЧЕК === */
.card-title {
    font-size: var(--h4-size);
    font-weight: var(--font-weight-semibold);
    color: var(--color-primary);
    line-height: var(--line-height-tight);
    margin: 0 0 var(--spacing-sm) 0;
}

/* === МЕЛКИЕ ЗАГОЛОВКИ === */
.small-title,
.filter-group label {
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* ============= УТИЛИТАРНЫЕ КЛАССЫ ============= */
.text-xs { font-size: var(--font-size-xs); }
.text-sm { font-size: var(--font-size-sm); }
.text-base { font-size: var(--font-size-base); }
.text-md { font-size: var(--font-size-md); }
.text-lg { font-size: var(--font-size-lg); }
.text-xl { font-size: var(--font-size-xl); }
.text-2xl { font-size: var(--font-size-2xl); }
.text-3xl { font-size: var(--font-size-3xl); }
.text-4xl { font-size: var(--font-size-4xl); }

.text-primary { color: var(--color-primary); }
.text-muted { color: var(--color-text-muted); }
.text-white { color: var(--color-white); }
.text-danger { color: var(--color-danger); }
.text-success { color: var(--color-success); }

.font-normal { font-weight: var(--font-weight-normal); }
.font-medium { font-weight: var(--font-weight-medium); }
.font-semibold { font-weight: var(--font-weight-semibold); }
.font-bold { font-weight: var(--font-weight-bold); }

/* ============= АЛЕРТЫ ============= */
.alert {
    position: relative;
    padding: 1rem 1rem;
    margin-bottom: 1rem;
    border: 1px solid transparent;
    border-radius: var(--radius-sm);
    font-size: var(--font-size-base);
}

.alert h4 {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--spacing-sm);
}

.alert-danger {
    color: #922820;
    background-color: #fdd9d7;
    border-color: #fcc7c3;
}

.alert-success {
    color: #2e6930;
    background-color: #dbefdc;
    border-color: #c9e7cb;
}

/* ============= КНОПКИ ============= */
.d-none {
    display: none;
}

.btn-outline-danger {
    color: var(--color-danger);
    border-color: var(--color-danger);
}

.btn-outline-danger:hover {
    color: var(--color-white);
    background-color: var(--color-danger);
    border-color: var(--color-danger);
}

.btn-primary {
    color: var(--color-white);
    background-color: #2196f3;
    border-color: #2196f3;
}

.btn-color {
    color: var(--color-white);
}

.btn-outline-success {
    color: var(--color-success);
    border-color: var(--color-success);
}

.btn-outline-continue:hover {
    color: var(--color-white);
}

.btn-outline-success:hover {
    color: var(--color-white);
    background-color: var(--color-success);
    border-color: var(--color-success);
}

/* ============= ПАГИНАЦИЯ ============= */
.pagination {
    font-size: var(--font-size-base);
}

/* ============= ЛОАДЕР ============= */
.js-page-loader * {
    -webkit-box-sizing: border-box !important;
    box-sizing: border-box !important;
}

.js-page-loader {
    background-color: var(--loaderBgColor);
}

.js-page-loader .spinner {
    width: var(--spinnerWidth);
    height: var(--spinnerHeight);
    border-top: var(--spinnerSize) solid var(--spinnerColor);
    border-right: var(--spinnerSize) solid transparent;
    border-radius: 50%;
    animation: spinnerRotation var(--animationSpeed) linear infinite;
}

@keyframes spinnerRotation {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

/* Фикс заголовка страницы /manager/ */
.manager-page-header {
    display: flex !important;
    align-items: center;
    margin-bottom: 3rem;
    padding: 0;
}

.manager-page-header .page-icon {
    width: 4rem;
    height: 4rem;
    background: var(--c-ui-blue);
    margin-right: 2rem;
    border-radius: 0.8rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    flex-shrink: 0;
}

.manager-page-header .page-icon svg {
    width: 2rem;
    height: 2rem;
    fill: #fff;
}

.manager-page-header .page-title {
    font-size: 2.6rem;
    line-height: 1.2;
    font-weight: 600;
    margin: 0;
}
