/* =================================================================== */
/* --- 1. Базовые стили и переменные тем --- */
/* =================================================================== */
:root {
    --bg-color: #121212;
    --surface-color: #1e1e1e;
    --primary-text-color: #e0e0e0;
    --secondary-text-color: #a0a0a0;
    --accent-color: #bb86fc;
    --input-bg-color: #2c2c2c;
    --border-color: #3a3a3a;
    --error-color: #cf6679;
    --success-color: #66bb6a;
}

body.light-mode {
    --bg-color: #fbfbfb;
    --surface-color: #ffffff;
    --primary-text-color: #1c1e21;
    --secondary-text-color: #606770;
    --accent-color: #1877f2;
    --input-bg-color: #f5f6f7;
    --border-color: #dddfe2;
    --error-color: #d32f2f;
    --success-color: #388e3c;
}

.span-logo-color {
    color: var(--accent-color);
}

body {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    background-color: var(--bg-color);
    color: var(--primary-text-color);
    margin: 0;
    transition: background-color 0.3s, color 0.3s;
}

/* =================================================================== */
/* --- 2. Стили для форм авторизации (auth-container) --- */
/* =================================================================== */
.auth-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
}
.auth-container {
    background: var(--surface-color);
    padding: 2rem 2.5rem;
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
    width: 100%;
    max-width: 450px;
    text-align: center;
    border: 1px solid var(--border-color);
    position: relative;
}
.theme-switcher {
    position: absolute;
    top: 1rem;
    right: 1rem;
    cursor: pointer;
    font-size: 1.5rem;
}
.auth-container h2 { margin-top: 0; margin-bottom: 0.5rem; font-size: 1.8rem; }
.auth-container p { color: var(--secondary-text-color); margin-bottom: 2rem; }
.message { color: var(--success-color); font-weight: bold; }
.error { color: var(--error-color); font-weight: bold; }
.input-field {
    width: 100%;
    padding: 14px;
    margin-bottom: 1rem;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    background-color: var(--input-bg-color);
    color: var(--primary-text-color);
    font-size: 1rem;
    box-sizing: border-box;
}
.auth-container a { color: var(--accent-color); text-decoration: none; margin-top: 1.5rem; display: inline-block; }
.auth-container button { width: 100%; padding: 14px; /* ... другие стили кнопок ... */ }


/* =================================================================== */
/* --- 3. Стили для личного кабинета и поискового сайта --- */
/* =================================================================== */
.profile-layout {
    display: flex;
    min-height: 100vh;
    width: 100%;
}
.profile-content {
    flex-grow: 1;
    position: relative;
}
.profile-header {
    display: flex;
    justify-content: flex-end;
    padding: 0;
    position: fixed;
    top: 1rem;
    right: 2rem;
    z-index: 100;
}
/* ... (все остальные стили из profile.css для .profile-menu, .avatar-small и т.д.) ... */
/* ... (просто скопируйте сюда всю оставшуюся часть profile.css) ... */


/* =================================================================== */
/* --- 4. Стили для страницы ПОИСКА --- */
/* =================================================================== */
.search-page-wrapper {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.search-logo {
    margin-bottom: 2rem;
}
.search-bar-container {
    width: 100%;
    max-width: 600px;
    position: relative;
}
.search-bar {
    width: 100%;
    padding: 1rem 1.5rem;
    font-size: 1.2rem;
    border-radius: 50px;
    border: 1px solid var(--border-color);
    background-color: var(--input-bg-color);
    color: var(--primary-text-color);
    box-sizing: border-box;
}
.search-results {
    max-width: 600px;
    width: 100%;
    text-align: left;
    margin-top: 2rem;
}
.result-item {
    padding: 1rem;
    border-bottom: 1px solid var(--border-color);
}

/* --- Стили для нового меню профиля в шапке --- */
.profile-header {
    display: flex;
    justify-content: flex-end;
    padding: 0;
    margin-bottom: 2rem;
    position: fixed;
    top: 15px;
    right: 15px;
}

.profile-menu-trigger {
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
}

.avatar-small {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background-color: var(--accent-color);
    color: var(--bg-color);
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.2rem;
    font-weight: bold;
}

.avatar-large {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background-color: var(--accent-color);
    color: var(--bg-color);
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 2rem;
    font-weight: bold;
    margin: 0 auto 1rem;
}

.form-row .value {
    flex-grow: 1;
    display: flex; /* Добавлено для управления вложенными элементами */
    flex-direction: column; /* Элементы внутри будут идти друг под другом */
}

/* Добавьте это, чтобы поля ввода занимали всю ширину */
.form-row .value .input-field,
.form-row .value .input-group {
    width: 100%;
    box-sizing: border-box;
}

/* Сделаем кнопку "Изменить" менее навязчивой */
.action button.link-style {
    background: none;
    border: none;
    color: var(--accent-color);
    font-weight: 500;
    cursor: pointer;
    padding: 0;
    font-size: 1rem;
    margin: 0;
}

label {
    margin-bottom: 10px;
}

/* --- Стили для страницы результатов поиска --- */
.header-search-block {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    background-color: var(--surface-color);
    padding: 1rem 2rem;
    display: flex;
    align-items: center;
    gap: 1.5rem;
    z-index: 90;
    border-bottom: 1px solid var(--border-color);
}
.header-logo { height: 30px; }
.header-search-form { flex-grow: 1; max-width: 600px; position: relative; }
.header-search-form .search-bar { padding-right: 50px; }
.header-search-form button {
    position: absolute;
    right: 5px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    color: var(--secondary-text-color);
    font-size: 1.2rem;
    cursor: pointer;
    padding: 0 10px;
    margin: 0;
}
.search-tabs {
    position: fixed;
    top: 70px; /* Высота .header-search-block */
    left: 0;
    width: 100%;
    background-color: var(--surface-color);
    padding: 0 2rem;
    padding-left: 150px; /* Отступ для логотипа */
    display: flex;
    gap: 1.5rem;
    z-index: 89;
}
.search-tabs a {
    padding: 1rem 0;
    margin: 0;
    color: var(--secondary-text-color);
    border-bottom: 3px solid transparent;
    display: flex;
    gap: 0.5rem;
    align-items: center;
}
.search-tabs a.active {
    color: var(--accent-color);
    border-bottom-color: var(--accent-color);
}
.results-page {
    padding-top: 140px !important; /* Отступ от шапки и табов */
}
.results-layout {
    display: flex;
    gap: 2rem;
}
.results-main-col {
    flex-grow: 1;
    max-width: 650px;
}
.results-side-col {
    flex-basis: 350px;
    flex-shrink: 0;
}
.results-info {
    color: var(--secondary-text-color);
    font-size: 0.9rem;
}
.result-item { margin-bottom: 1.5rem; }
.result-title { font-size: 1.2rem; text-decoration: none; color: var(--accent-color); }
.result-url { font-size: 0.9rem; color: var(--secondary-text-color); margin-top: 0.25rem; }
.result-description { color: var(--primary-text-color); font-size: 1rem; margin-top: 0.5rem; }
.knowledge-panel-placeholder {
    background-color: var(--surface-color);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 2rem;
    min-height: 200px;
}

.footer-left li {
    display: block;
}

@media (max-width: 768px) {
    .search-footer {
        display: none;
    }
}