/* ═══════════════════════════════════════
   Дизайн-токены: светлая тема
   ═══════════════════════════════════════ */
:root {
    /* Navbar */
    --navbar-height: 49px;

    /* Радиусы */
    --radius-sm:  6px;
    --radius-md:  8px;
    --radius-lg:  12px;
    --radius-full: 50%;

    /* Тени */
    --shadow-sm:  0 2px 4px rgba(0, 0, 0, 0.08);
    --shadow-md:  0 4px 12px rgba(0, 0, 0, 0.12);
    --shadow-lg:  0 8px 24px rgba(0, 0, 0, 0.16);

    /* Отступы */
    --space-xs:   4px;
    --space-sm:   8px;
    --space-md:   12px;
    --space-lg:   16px;
    --space-xl:   20px;
    --space-2xl:  24px;
    --space-3xl:  32px;

    /* Шрифт */
    --font-xs:   12px;
    --font-sm:   13px;
    --font-md:   14px;
    --font-lg:   16px;
    --font-xl:   18px;

    /* Анимации */
    --transition-fast: 0.15s ease;
    --transition-base: 0.2s ease;
    --transition-slow: 0.3s ease;

    /* Фоны */
    --bg-app:            #ffffff;
    --bg-panel:          #f7f7f7;
    --bg-surface:        #ffffff;
    --bg-hover:          #f0f0f0;
    --bg-active:         #e3e8ff;
    --bg-input:          #ffffff;
    --bg-message-other:  #f0f0f0;
    --bg-danger:         #fff5f5;
    --bg-info:           #e3f2fd;
    --bg-toast:          #2a2a3e;

    /* Границы */
    --border:              #e0e0e0;
    --border-input:        #dddddd;
    --border-danger:       #ffeeee;
    --border-danger-hover: #feb2b2;

    /* Текст */
    --text-primary:      #333333;
    --text-secondary:    #555555;
    --text-muted:        #666666;
    --text-placeholder:  #767676;
    --text-on-accent:    #ffffff;
    --text-toast:        #e2e2f0;

    /* Акценты */
    --accent:            #667eea;
    --accent-hover:      #5a67d8;
    --accent-secondary:  #764ba2;
    --danger:            #e53e3e;
    --info:              #1976d2;
    --info-text:         #1976d2;
}

/* ═══════════════════════════════════════
   Дизайн-токены: тёмная тема
   ═══════════════════════════════════════ */
[data-bs-theme="dark"] {
    --shadow-sm:  0 2px 4px rgba(0, 0, 0, 0.2);
    --shadow-md:  0 4px 12px rgba(0, 0, 0, 0.3);
    --shadow-lg:  0 8px 24px rgba(0, 0, 0, 0.4);

    --bg-app:            #1a1a2e;
    --bg-panel:          #16162a;
    --bg-surface:        #1e1e30;
    --bg-hover:          #252540;
    --bg-active:         #2d3561;
    --bg-input:          #252540;
    --bg-message-other:  #252540;
    --bg-danger:         #2d1515;
    --bg-info:           #0d2137;
    --bg-toast:          #2e2e50;

    --border:              #2e2e50;
    --border-input:        #3a3a60;
    --border-danger:       #4a2020;
    --border-danger-hover: #6b3030;

    --text-primary:      #e2e2f0;
    --text-secondary:    #b8b8d0;
    --text-muted:        #8888a8;
    --text-placeholder:  #8888aa;
    --text-toast:        #e2e2f0;

    --accent:            #667eea;
    --accent-hover:      #7a8ef8;
    --danger:            #fc6b6b;
    --info:              #64b5f6;
    --info-text:         #64b5f6;
}

/* ═══════════════════════════════════════
   Сброс и базовые стили
   ═══════════════════════════════════════ */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-size: var(--font-md);
    line-height: 1.5;
    background-color: var(--bg-app);
    color: var(--text-primary);
}

/* ═══════════════════════════════════════
   Скроллбары
   ═══════════════════════════════════════ */
::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

::-webkit-scrollbar-track {
    background: transparent;
}

::-webkit-scrollbar-thumb {
    background: var(--text-placeholder);
    border-radius: var(--radius-sm);
}

::-webkit-scrollbar-thumb:hover {
    background: var(--text-muted);
}

/* ═══════════════════════════════════════
   Анимации
   ═══════════════════════════════════════ */
@keyframes fadeIn {
    from { opacity: 0; }
    to   { opacity: 1; }
}

/* ═══════════════════════════════════════
   Тогл-переключатель (общий компонент)
   ═══════════════════════════════════════ */
.toggle {
    cursor: pointer;
}

.toggle__track {
    width: 44px;
    height: 24px;
    background: var(--border);
    border-radius: 12px;
    position: relative;
    transition: background var(--transition-slow);
    cursor: pointer;
}

.toggle__track--on {
    background: var(--accent);
}

.toggle__thumb {
    width: 20px;
    height: 20px;
    background: var(--text-on-accent);
    border-radius: var(--radius-full);
    position: absolute;
    top: 2px;
    left: 2px;
    transition: transform var(--transition-slow);
    box-shadow: var(--shadow-sm);
}

.toggle__thumb--on {
    transform: translateX(20px);
}

/* ═══════════════════════════════════════
   Модалки (общие стили)
   ═══════════════════════════════════════ */
.modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    animation: fadeIn var(--transition-fast) forwards;
    outline: none;
}

.modal-content {
    background: var(--bg-surface);
    border-radius: var(--radius-lg);
    padding: var(--space-3xl);
    width: 480px;
    max-width: 100%;
    max-height: 80vh;
    overflow-y: auto;
    box-shadow: var(--shadow-lg);
    position: relative;
}

.modal-content__close {
    position: absolute;
    top: var(--space-lg);
    right: var(--space-lg);
    background: none;
    border: none;
    font-size: 24px;
    font-weight: 600;
    color: var(--text-placeholder);
    cursor: pointer;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-md);
    padding: 0;
    transition: background-color var(--transition-base), color var(--transition-base);
}

.modal-content__close:hover {
    color: var(--text-primary);
    background: var(--bg-hover);
}

.modal-content__title {
    margin-bottom: var(--space-xl);
    font-size: var(--font-xl);
    font-weight: 600;
    color: var(--text-primary);
}

.modal-content__form-group {
    margin-bottom: var(--space-xl);
}

.modal-content__form-group label {
    display: block;
    margin-bottom: var(--space-sm);
    font-size: var(--font-sm);
    font-weight: 600;
    color: var(--text-secondary);
}

.modal-content__form-group input,
.modal-content__form-group select {
    width: 100%;
    padding: var(--space-md);
    border: 1px solid var(--border-input);
    border-radius: var(--radius-md);
    font-size: var(--font-md);
    font-family: inherit;
    background: var(--bg-input);
    color: var(--text-primary);
    transition: border-color var(--transition-base);
}

.modal-content__form-group input::placeholder {
    color: var(--text-placeholder);
}

.modal-content__form-group input:focus,
.modal-content__form-group select:focus {
    outline: none;
    border-color: var(--accent);
}

.modal-content__actions {
    display: flex;
    gap: var(--space-md);
    justify-content: flex-end;
}

.modal-content__actions button {
    padding: var(--space-md) var(--space-xl);
    border: none;
    border-radius: var(--radius-md);
    cursor: pointer;
    font-size: var(--font-md);
    font-weight: 500;
    transition: background-color var(--transition-base), color var(--transition-base);
}

/* ═══════════════════════════════════════
   Профиль (общие стили модалки)
   ═══════════════════════════════════════ */
.profile-modal {
    width: 420px;
}

.profile-modal__header {
    display: flex;
    align-items: center;
    gap: var(--space-lg);
    margin-bottom: var(--space-2xl);
}

.profile-modal__avatar {
    width: 56px;
    height: 56px;
    background: var(--accent);
    color: var(--text-on-accent);
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: var(--font-xl);
    flex-shrink: 0;
}

.profile-modal__title h2 {
    font-size: var(--font-xl);
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
}

.profile-modal__email {
    font-size: var(--font-sm);
    color: var(--text-muted);
}

.profile-modal__details {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    padding: var(--space-lg);
    background: var(--bg-panel);
    border-radius: var(--radius-md);
}

.profile-modal__row {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.profile-modal__label {
    font-size: var(--font-md);
    color: var(--text-secondary);
}

.profile-modal__value {
    font-size: var(--font-md);
    color: var(--text-primary);
    font-weight: 500;
}

.profile-modal__value--success {
    color: #38a169;
}

.profile-modal__value--warning {
    color: var(--danger);
}

/* ═══════════════════════════════════════
   Кнопки (общие)
   ═══════════════════════════════════════ */
.btn--primary {
    background: var(--accent);
    color: var(--text-on-accent);
}

.btn--primary:hover:not(:disabled) {
    background: var(--accent-hover);
}

.btn--danger {
    padding: var(--space-md) var(--space-xl);
    background: var(--danger);
    color: var(--text-on-accent);
    border: none;
    border-radius: var(--radius-md);
    cursor: pointer;
    font-size: var(--font-md);
    font-weight: 500;
    transition: opacity var(--transition-base);
}

.btn--danger:hover {
    opacity: 0.9;
}
