/* Кастомная цветовая палитра проекта "Пища для ума" */
:root {
    /* Основные цвета из логотипа */
    --primary-green: #1e3a3a;        /* Темно-зеленый из логотипа */
    --primary-blue: #7dd3fc;         /* Светло-голубой из логотипа */
    --primary-blue-dark: #0891b2;    /* Более темный голубой */
    --primary-blue-light: #bae6fd;   /* Очень светлый голубой */
    
    /* Дополнительные оттенки для гармонии */
    --accent-teal: #14b8a6;          /* Бирюзовый акцент */
    --accent-teal-light: #5eead4;    /* Светлый бирюзовый */
    --sage-green: #86efac;           /* Мягкий зеленый */
    --sage-green-dark: #22c55e;      /* Средний зеленый */
    
    /* Нейтральные цвета */
    --neutral-50: #f8fafc;
    --neutral-100: #f1f5f9;
    --neutral-200: #e2e8f0;
    --neutral-700: #334155;
    --neutral-800: #1e293b;
    --neutral-900: #0f172a;
}

/* Кастомные шрифты */
body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
    background-color: var(--neutral-50);
}

.login-block {
    background-color: rgba(255, 255, 255, 0.8);
    backdrop-filter: blur(10px);
    border-radius: 1rem;
    padding: 2rem;
}

/* Карточки мероприятий */
.event-card { 
    background: #fff; 
    border: 1px solid #e5e7eb; 
    border-radius: 0.75rem; 
    padding: 1rem; 
    box-shadow: 0 2px 10px rgba(0,0,0,.04); 
}

.event-card:hover { 
    box-shadow: 0 8px 24px rgba(0,0,0,.08); 
    transform: translateY(-1px); 
    transition: .2s; 
}

.event-grid { 
    display: grid; 
    grid-template-columns: repeat(3, 1fr); 
    gap: 1.25rem; 
}

@media (max-width: 1024px) { 
    .event-grid { 
        grid-template-columns: repeat(2, 1fr); 
    } 
}

@media (max-width: 640px) { 
    .event-grid { 
        grid-template-columns: 1fr; 
    } 
}

.badge { 
    display:inline-block; 
    padding:.25rem .5rem; 
    font-size:.75rem; 
    font-weight:600; 
    border-radius:.5rem; 
}

.badge-green { 
    background:#dcfce7; 
    color:#166534; 
}

.badge-orange { 
    background:#ffedd5; 
    color:#9a3412; 
}

.badge-pink { 
    background:#fde2e2; 
    color:#9f1239; 
}

.badge-purple { 
    background:#e9d5ff; 
    color:#6b21a8; 
}

.badge-gray { 
    background:#e5e7eb; 
    color:#374151; 
}

/* Карточки университетов */
.uni-card { 
    background:#fff; 
    border:1px solid #e5e7eb; 
    border-radius:.75rem; 
    padding:1rem; 
    box-shadow:0 2px 10px rgba(0,0,0,.04); 
}

.uni-topbar { 
    height:6px; 
    border-radius:.5rem; 
    background: linear-gradient(90deg, #22c55e, #60a5fa); 
}

/* Стили для статусов */
.status-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.75rem;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 500;
    line-height: 1;
}

.status-implemented {
    background-color: var(--sage-green);
    color: var(--primary-green);
    border: 1px solid var(--sage-green-dark);
}

.status-discussion {
    background-color: var(--primary-blue-light);
    color: var(--primary-blue-dark);
    border: 1px solid var(--primary-blue);
}

.status-agreement {
    background-color: var(--accent-teal-light);
    color: var(--primary-green);
    border: 1px solid var(--accent-teal);
}

.status-paused {
    background-color: var(--neutral-100);
    color: var(--neutral-700);
    border: 1px solid var(--neutral-200);
}

.status-in_progress {
    background-color: var(--accent-teal-light);
    color: var(--primary-green);
    border: 1px solid var(--accent-teal);
}

.status-completed {
    background-color: var(--sage-green);
    color: var(--primary-green);
    border: 1px solid var(--sage-green-dark);
}

.status-planned {
    background-color: var(--primary-blue-light);
    color: var(--primary-blue-dark);
    border: 1px solid var(--primary-blue);
}

.status-confirmed {
    background-color: var(--sage-green);
    color: var(--primary-green);
    border: 1px solid var(--sage-green-dark);
}

/* Стили для контактных карточек */
.contact-category {
    display: inline-block;
    padding: 0.125rem 0.5rem;
    border-radius: 0.25rem;
    font-size: 0.75rem;
    font-weight: 500;
}

.contact-category.admin {
    background-color: #fee2e2;
    color: #991b1b;
    border: 1px solid #fca5a5;
}

.contact-category.contractor {
    background-color: #fef3c7;
    color: #92400e;
    border: 1px solid #fcd34d;
}

.contact-category.ecoclub {
    background-color: #d1fae5;
    color: #065f46;
    border: 1px solid #6ee7b7;
}

.contact-category.student {
    background-color: #dbeafe;
    color: #1e40af;
    border: 1px solid #93c5fd;
}

.contact-category.teacher {
    background-color: #e0e7ff;
    color: #3730a3;
    border: 1px solid #a5b4fc;
}

.contact-category.media {
    background-color: #fce7f3;
    color: #be185d;
    border: 1px solid #f9a8d4;
}

.contact-category.partner {
    background-color: #f0fdf4;
    color: #166534;
    border: 1px solid #86efac;
}

/* Кнопки */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.5rem 1rem;
    border-radius: 0.375rem;
    font-weight: 500;
    text-decoration: none;
    transition: all 0.15s ease-in-out;
    cursor: pointer;
    border: none;
}

.btn-primary {
    background-color: var(--accent-teal);
    color: white;
}

.btn-primary:hover {
    background-color: #0d9488;
}

.btn-secondary {
    background-color: #6b7280;
    color: white;
}

.btn-secondary:hover {
    background-color: #4b5563;
}

.btn-sm {
    padding: 0.375rem 0.75rem;
    font-size: 0.875rem;
}

/* Адаптивный дизайн */
@media (max-width: 640px) {
    .container {
        padding-left: 1rem;
        padding-right: 1rem;
    }
    
    .card-grid {
        grid-template-columns: 1fr;
        gap: 1rem;
    }
    
    .stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    h1 {
        font-size: 1.5rem;
        line-height: 1.3;
    }
    
    h2 {
        font-size: 1.25rem;
        line-height: 1.3;
    }
}

@media (min-width: 641px) and (max-width: 768px) {
    .container {
        padding-left: 1.5rem;
        padding-right: 1.5rem;
    }
    
    .card-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.5rem;
    }
    
    .stats-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (min-width: 1025px) {
    .card-grid {
        grid-template-columns: repeat(3, 1fr);
    }
    
    .stats-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}