/* style.css */

/* -------------------- */
/* CSS Переменные */
/* -------------------- */
:root {
    --primary-bg-color: #0f172a;      
    --secondary-bg-color: #1e293b;  
    --card-bg-color: #334155;       
    --accent-color: #eab308;        
    --accent-color-hover: #f59e0b;  
    --text-color: #f8fafc;          
    --text-color-secondary: #cbd5e1;
    --border-color: #475569;        
    --error-color: #ef4444;         
    --error-bg-color: rgba(239, 68, 68, 0.1); 
    --success-color: #22c55e;       
    --bright-accent-color: #00f2ea; /* Новый яркий акцент */

    --font-family-main: 'Roboto', sans-serif;
    --font-family-headings: 'Poppins', sans-serif;

    --border-radius: 8px;
    --box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
    --card-hover-shadow: 0 8px 25px rgba(0,0,0,0.35);
}

/* -------------------- */
/* Базовый сброс и Body */
/* -------------------- */
* { margin: 0; padding: 0; box-sizing: border-box; }
html { font-size: 16px; }
body {
    font-family: var(--font-family-main);
    background-color: var(--primary-bg-color);
    color: var(--text-color);
    line-height: 1.6;
    display: flex; flex-direction: column;
    min-height: 100vh; padding: 20px; 
}

/* -------------------- */
/* Контейнеры и Шапка */
/* -------------------- */
.app-container {
    width: 100%; max-width: 1000px; margin: 0 auto; padding: 25px;
    background-color: var(--secondary-bg-color);
    border-radius: var(--border-radius); box-shadow: var(--box-shadow);
    flex-grow: 1; 
}
.app-header { position: relative; padding-top: 50px; margin-bottom: 30px; } /* Увеличен padding-top */
.auth-links {
    position: absolute; top: 15px; right: 0px; z-index: 10; font-size: 0.9em;
}
.auth-links a { color: var(--accent-color); margin-left: 15px; text-decoration: none; cursor: pointer; } 
.auth-links a:hover { text-decoration: underline; color: var(--accent-color-hover); }

/* -------------------- */
/* Заголовки и Текст */
/* -------------------- */
h1, h2, h3, h4, h5, h6 { font-family: var(--font-family-headings); color: var(--accent-color); margin-bottom: 0.75em; line-height: 1.2; font-weight: 700;}
.app-header > h1.main-title { 
    font-size: 2.8rem; margin-bottom: 15px; text-align: center; margin-top: 0;
    letter-spacing: -1px;
}
.app-header > h1.main-title a { text-decoration: none; color: var(--accent-color); }
.page-title { 
    font-size: 2.2rem; text-align:center; color: var(--text-color); /* Изменен цвет */
    margin-top: 10px; margin-bottom: 20px; padding-bottom: 10px;
    display: inline-block; border-bottom: 3px solid var(--accent-color);
}
.intro-paragraph {
    font-size: 1.1em; color: var(--text-color-secondary); max-width: 700px;
    margin: 0 auto 35px auto; text-align: center; line-height: 1.7;
}
p { margin-bottom: 1rem; color: var(--text-color-secondary); }
a { color: var(--accent-color); text-decoration: none; transition: color 0.3s ease; }
a:hover, a:focus { color: var(--accent-color-hover); text-decoration: underline; }

/* -------------------- */
/* Flash сообщения (без изменений) */
/* -------------------- */
.flash-messages { list-style-type: none; padding: 0; margin-bottom: 20px; }
.flash-messages li { padding: 12px 18px; margin-bottom: 10px; border-radius: var(--border-radius); color: var(--text-color); font-weight: 500; box-shadow: 0 2px 5px rgba(0,0,0,0.1); }
.flash-messages li.success { background-color: var(--success-color); }
.flash-messages li.danger { background-color: var(--error-color); }
.flash-messages li.info { background-color: var(--accent-color); }
.flash-messages li.warning { background-color: var(--accent-color-hover); }

/* -------------------- */
/* Карточки */
/* -------------------- */
.card {
    background-color: var(--card-bg-color); padding: 25px; /* Увеличен padding */
    border-radius: var(--border-radius); margin-bottom: 25px; /* Увеличен margin */
    box-shadow: 0 2px 8px rgba(0,0,0,0.3);
    border-left: 5px solid transparent; 
    transition: transform 0.3s ease-out, box-shadow 0.3s ease-out, border-left-color 0.3s ease-out;
}
.card:hover {
    transform: translateY(-4px);
    box-shadow: var(--card-hover-shadow);
    /* border-left-color: var(--accent-color); */ /* Можно раскомментировать для акцента */
}
.card.mt-2 { margin-top: 2rem; }
.card-title { 
    font-size: 1.6rem; /* Немного увеличен */
    color: var(--accent-color); margin-top: 0; margin-bottom: 20px; /* Увеличен margin */
    border-bottom: 2px solid var(--border-color); padding-bottom: 12px; /* Увеличен padding и толщина линии */
}

/* -------------------- */
/* Формы (без существенных изменений) */
/* -------------------- */
.form-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 25px; margin-bottom: 30px; }
.form-group { margin-bottom: 18px; } /* Немного увеличен */
.form-group label { display: block; margin-bottom: 8px; color: var(--text-color-secondary); font-weight: 700; /* Жирнее */ font-size:0.95em; }
.form-control {
    width: 100%; padding: 12px 15px; /* Увеличен padding */
    background-color: var(--primary-bg-color); color: var(--text-color); 
    border: 1px solid var(--border-color); border-radius: calc(var(--border-radius) - 3px); 
    font-size: 1rem; transition: border-color 0.3s ease, box-shadow 0.3s ease;
}
.form-control:focus { outline: none; border-color: var(--accent-color); box-shadow: 0 0 0 3px rgba(234, 179, 8, 0.3); }
.form-control-error { border-color: var(--error-color) !important; }
.error-message-inline span { display: block; color: var(--error-color); font-size: 0.85em; margin-top: 4px;}

/* -------------------- */
/* Кнопки */
/* -------------------- */
.btn {
    display: inline-block; width: 100%; padding: 14px 25px; font-size: 1.1rem;
    font-weight: 700; text-align: center; text-decoration: none;
    color: var(--primary-bg-color); 
    background-image: linear-gradient(45deg, var(--accent-color) 0%, var(--accent-color-hover) 100%);
    border: none; border-radius: 50px; cursor: pointer;
    transition: all 0.3s ease; margin-top: 15px; 
    box-shadow: 0 4px 12px rgba(var(--accent-color), 0.25);
    text-transform: uppercase; letter-spacing: 0.5px;
}
.btn:hover, .btn:focus {
    background-image: linear-gradient(45deg, var(--accent-color-hover) 0%, var(--accent-color) 100%);
    transform: translateY(-3px) scale(1.01);
    box-shadow: 0 6px 18px rgba(var(--accent-color), 0.35);
    outline: none;
}
.btn:active { transform: translateY(-1px) scale(0.99); box-shadow: 0 2px 10px rgba(var(--accent-color), 0.3); }
.btn:disabled { /* Стили для заблокированной кнопки */
    background-image: none;
    background-color: var(--border-color); 
    color: var(--text-color-secondary); 
    cursor: not-allowed; transform: translateY(0);
    box-shadow: none;
}

/* -------------------- */
/* Секция с результатами и ошибками (без существенных изменений) */
/* -------------------- */
.messages-section { margin-top: 35px; }
.error-message { /* Стили без изменений */ }
.results-list { /* Стили без изменений */ }
.results-list li { /* Стили без изменений */ }
.ai-summary-text { /* Стили без изменений */ }

/* -------------------- */
/* Глобальный спиннер/загрузчик (без изменений) */
/* -------------------- */
.global-loader-overlay { /* ... */ }
.global-loader-overlay.active { /* ... */ }
.global-loader-overlay .spinner-big { /* ... */ }
@keyframes spinGlobalLoader { /* ... */ }
.global-loader-overlay p { /* ... */ }

/* -------------------- */
/* Модальное окно входа (без изменений) */
/* -------------------- */
#loginModalOverlay { /* ... */ }
.modal-content { /* ... */ }
@keyframes zoomInModal { /* ... */ }
.modal-close-btn { /* ... */ }
/* ... и остальные стили модального окна ... */

/* -------------------- */
/* График Chart.js */
/* -------------------- */
.chart-container {
    position: relative;
    margin: 20px auto; /* Центрируем и добавляем отступы */
    height: 250px; /* Высота контейнера графика */
    width: 100%;
    max-width: 350px; /* Максимальная ширина графика */
}


/* -------------------- */
/* Футер (без изменений) */
/* -------------------- */
.app-footer { /* ... */ }

/* -------------------- */
/* Адаптивность */
/* -------------------- */
@media (max-width: 768px) {
    body { padding: 15px; }
    .app-container { padding: 20px; }
    .app-header { padding-top: 60px; margin-bottom: 20px;} /* Увеличиваем отступ для auth-links в мобильной версии */
    .auth-links { position: absolute; top:10px; right: 10px; text-align: right;} /* Остаются справа сверху */
    .app-header > h1.main-title { font-size: 2.2rem; padding-top: 0; } 
    .page-title { font-size: 1.8rem; }
    h3.card-title { font-size: 1.4rem; } /* Увеличил для мобильных */
    .form-grid { grid-template-columns: 1fr; }
    .global-loader-overlay .spinner-big { width: 50px; height: 50px; border-width: 6px; }
    .global-loader-overlay p { font-size: 1.1em; }
    .modal-content { max-width: 90%; padding: 20px;}
    .chart-container { height: 220px; max-width: 300px;}
}

@media (max-width: 480px) {
    html { font-size: 14px; }
    body { padding: 10px; } .app-container { padding: 15px; }
    .app-header { padding-top: 50px; }
    .app-header > h1.main-title {font-size: 1.8rem;} /* Еще меньше */
    .page-title {font-size: 1.5rem;} /* Еще меньше */
    .btn { font-size: 1rem; padding: 12px 18px; } /* Немного поправил */
    .form-control { font-size: 0.95rem; }
    .chart-container { height: 200px; max-width: 280px;}
}

/* Анимация появления */
.fade-in { animation: fadeInAnimation 0.5s ease-in-out; }
@keyframes fadeInAnimation { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
