/* 
Сфера - Кастомные стили
Темно-зеленая цветовая схема (НЕ синий!)
Обязательная адаптация под смартфоны
*/

:root {
    /* Пастельная зеленая палитра */
    --eventarium-primary: #2f6f44;      /* смягченный темно-зеленый */
    --eventarium-secondary: #78c28a;    /* пастельный зеленый акцент */
    --eventarium-light: #e9f5ee;        /* очень светлый зеленый */
    --eventarium-dark: #1f4d30;         /* глубокий, но мягкий зеленый */
    --eventarium-success: #79c08a;      /* мягкий успех */
    --eventarium-warning: #ffe08a;      /* мягкий желтый */
    --eventarium-danger: #f4a6a6;       /* мягкий красный */
    --eventarium-info: #8fd1de;         /* мягкий голубой */
    
    /* Градиенты (пастель) */
    --eventarium-gradient: linear-gradient(135deg, #2f6f44 0%, #78c28a 100%);
    --eventarium-gradient-light: linear-gradient(135deg, #e9f5ee 0%, #d9efe4 100%);
    
    /* Тени слегка легче */
    --eventarium-shadow: 0 4px 6px rgba(47, 111, 68, 0.08);
    --eventarium-shadow-lg: 0 10px 25px rgba(47, 111, 68, 0.12);
}

/* Основные цветовые классы */
.bg-eventarium-primary { background-color: var(--eventarium-primary) !important; }
.bg-eventarium-secondary { background-color: var(--eventarium-secondary) !important; }
.bg-eventarium-light { background-color: var(--eventarium-light) !important; }
.bg-eventarium-dark { background-color: var(--eventarium-dark) !important; }

.text-eventarium-primary { color: var(--eventarium-primary) !important; }
.text-eventarium-secondary { color: var(--eventarium-secondary) !important; }
.text-eventarium-light { color: var(--eventarium-light) !important; }
.text-eventarium-dark { color: var(--eventarium-dark) !important; }

/* Кнопки */
.btn-eventarium-primary {
    background: var(--eventarium-gradient);
    border: none;
    color: white;
    font-weight: 500;
    padding: 0.5rem 1.5rem;
    border-radius: 0.5rem;
    transition: all 0.3s ease;
    box-shadow: var(--eventarium-shadow);
}

.btn-eventarium-primary:hover {
    transform: translateY(-2px);
    box-shadow: var(--eventarium-shadow-lg);
    color: white;
}

.btn-eventarium-secondary {
    background-color: transparent;
    border: 2px solid var(--eventarium-secondary);
    color: var(--eventarium-secondary);
    font-weight: 500;
    padding: 0.5rem 1.5rem;
    border-radius: 0.5rem;
    transition: all 0.3s ease;
}

.btn-eventarium-secondary:hover {
    background-color: var(--eventarium-secondary);
    color: white;
    transform: translateY(-1px);
}

/* Карточки */
.card-eventarium {
    border: none;
    border-radius: 1rem;
    box-shadow: var(--eventarium-shadow);
    transition: all 0.3s ease;
    overflow: hidden;
}

.card-eventarium:hover {
    transform: translateY(-5px);
    box-shadow: var(--eventarium-shadow-lg);
}

.card-eventarium .card-header {
    background: var(--eventarium-gradient);
    color: white;
    border: none;
    font-weight: 600;
}

/* Навигация */
.navbar-dark .navbar-nav .nav-link {
    color: rgba(255, 255, 255, 0.9);
    font-weight: 500;
    transition: color 0.3s ease;
}

.navbar-dark .navbar-nav .nav-link:hover {
    color: var(--eventarium-light);
}

.navbar-brand {
    font-size: 1.5rem;
    font-weight: 700;
}

/* Логотипы бренда */
.brand-logo {
    height: 28px;
    width: auto;
}

.hero-logo {
    max-width: 90%;
    height: auto;
    border-radius: 0.5rem;
    box-shadow: var(--eventarium-shadow-lg);
}

/* Формы */
.form-control:focus {
    border-color: var(--eventarium-secondary);
    box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.25);
}

.form-select:focus {
    border-color: var(--eventarium-secondary);
    box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.25);
}

/* Алерты */
.alert-success {
    background-color: var(--eventarium-light);
    border-color: var(--eventarium-secondary);
    color: var(--eventarium-dark);
}

/* Бейджи */
.badge-eventarium {
    background: var(--eventarium-gradient);
    color: white;
    font-weight: 500;
    padding: 0.5em 0.75em;
    border-radius: 0.5rem;
}

/* Статусы */
.status-draft { background-color: #6c757d; color: white; }
.status-planning { background-color: #ffc107; color: #212529; }
.status-registration-open { background-color: var(--eventarium-secondary); color: white; }
.status-registration-closed { background-color: #fd7e14; color: white; }
.status-in-progress { background-color: #17a2b8; color: white; }
.status-completed { background-color: var(--eventarium-primary); color: white; }
.status-cancelled { background-color: #dc3545; color: white; }

/* Мобильная адаптация */
@media (max-width: 768px) {
    .navbar-brand {
        font-size: 1.25rem;
    }
    
    .card-eventarium {
        margin-bottom: 1rem;
    }
    
    .btn-eventarium-primary,
    .btn-eventarium-secondary {
        width: 100%;
        margin-bottom: 0.5rem;
    }
    
    /* Увеличиваем размер кнопок для удобства на мобильных */
    .btn {
        min-height: 44px;
        font-size: 1rem;
    }
    
    /* Улучшаем читаемость на маленьких экранах */
    .card-body {
        padding: 1rem;
    }
    
    .table-responsive {
        font-size: 0.9rem;
    }
}

@media (max-width: 576px) {
    .container {
        padding-left: 1rem;
        padding-right: 1rem;
    }
    
    .card-eventarium {
        border-radius: 0.5rem;
    }
    
    /* Компактные заголовки на очень маленьких экранах */
    h1 { font-size: 1.75rem; }
    h2 { font-size: 1.5rem; }
    h3 { font-size: 1.25rem; }
}

/* Специальные стили для drag-and-drop (будет использоваться в расписании) */
.draggable {
    cursor: move;
    transition: all 0.3s ease;
}

.draggable:hover {
    transform: scale(1.02);
    box-shadow: var(--eventarium-shadow-lg);
}

.drop-zone {
    min-height: 100px;
    border: 2px dashed var(--eventarium-secondary);
    border-radius: 0.5rem;
    background-color: rgba(40, 167, 69, 0.05);
    transition: all 0.3s ease;
}

.drop-zone.drag-over {
    background-color: rgba(40, 167, 69, 0.1);
    border-color: var(--eventarium-primary);
}

/* Анимации */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.fade-in-up {
    animation: fadeInUp 0.6s ease-out;
}

/* Улучшения для таблиц на мобильных */
@media (max-width: 768px) {
    .table-mobile-stack {
        border: 0;
    }
    
    .table-mobile-stack thead {
        display: none;
    }
    
    .table-mobile-stack tr {
        border: 1px solid var(--eventarium-light);
        border-radius: 0.5rem;
        display: block;
        margin-bottom: 1rem;
        padding: 1rem;
        background: white;
        box-shadow: var(--eventarium-shadow);
    }
    
    .table-mobile-stack td {
        border: none;
        display: block;
        text-align: right;
        padding: 0.25rem 0;
    }
    
    .table-mobile-stack td:before {
        content: attr(data-label) ": ";
        float: left;
        font-weight: bold;
        color: var(--eventarium-dark);
    }
}

/* Загрузчик */
.spinner-eventarium {
    border: 4px solid var(--eventarium-light);
    border-top: 4px solid var(--eventarium-primary);
    border-radius: 50%;
    width: 40px;
    height: 40px;
    animation: spin 1s linear infinite;
    margin: 20px auto;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* Улучшения для форм */
.form-floating > .form-control:focus ~ label,
.form-floating > .form-control:not(:placeholder-shown) ~ label {
    color: var(--eventarium-primary);
}

/* Кастомные чекбоксы и радиокнопки */
.form-check-input:checked {
    background-color: var(--eventarium-secondary);
    border-color: var(--eventarium-secondary);
}

.form-check-input:focus {
    box-shadow: 0 0 0 0.25rem rgba(40, 167, 69, 0.25);
}

/* Прогресс-бары */
.progress-bar-eventarium {
    background: var(--eventarium-gradient);
}

/* Хлебные крошки */
.breadcrumb-item.active {
    color: var(--eventarium-primary);
}

.breadcrumb-item + .breadcrumb-item::before {
    color: var(--eventarium-secondary);
}

/* Утилиты */
.text-gradient {
    background: var(--eventarium-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    font-weight: bold;
}

.border-eventarium {
    border-color: var(--eventarium-secondary) !important;
}

.shadow-eventarium {
    box-shadow: var(--eventarium-shadow) !important;
}

.shadow-eventarium-lg {
    box-shadow: var(--eventarium-shadow-lg) !important;
}

/* Улучшения действий в мобильных таблицах */
.table-mobile-stack .btn-group {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}
.table-mobile-stack .btn-group .btn {
    flex: 1 1 auto;
}

/* Улучшение скролла таблиц на мобильных устройствах */
.table-responsive {
    -webkit-overflow-scrolling: touch; /* инерционный скролл */
}

/* Контейнер таблицы: перехватываем горизонтальный свайп и не пробрасываем его странице */
.table-container {
    overscroll-behavior-x: contain; /* не прокидывать горизонтальный скролл наружу */
    touch-action: pan-x;            /* свайпы интерпретируем как горизонтальные */
}

/* Улучшение UX горизонтальной ленты канбана на мобильных */
.kanban-board {
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
}
.kanban-column {
    scroll-snap-align: start;
}
