/* --- Сброс и Переменные --- */
:root {
    --bg-color: #F3F5F9;
    --text-primary: #111827;
    --text-secondary: #6B7280;
    --primary-color: #111827;
    --accent-blue: #2563EB;
	--gradient-teal: linear-gradient(135deg, #14B8A6 0%, #0F766E 100%);
    --gradient-orange: linear-gradient(135deg, #FBBF24 0%, #D97706 100%);
    
    /* Градиенты карточек */
    --gradient-blue: linear-gradient(135deg, #3B82F6 0%, #2563EB 100%);
    --gradient-mint: linear-gradient(135deg, #E0F2F1 0%, #D1FAE5 100%);
    --gradient-dark: linear-gradient(145deg, #1E293B 0%, #0F172A 100%); /* Midnight */
    
    /* Дополнительные градиенты */
    --gradient-yellow: linear-gradient(135deg, #F59E0B 0%, #D97706 100%);
    --gradient-coral: linear-gradient(135deg, #FB923C 0%, #EA580C 100%);
    --gradient-cyan: linear-gradient(135deg, #22D3EE 0%, #06B6D4 100%);
    --gradient-indigo: linear-gradient(135deg, #6366F1 0%, #4338CA 100%);
    --gradient-violet: linear-gradient(135deg, #8B5CF6 0%, #6D28D9 100%);
    --gradient-rose: linear-gradient(135deg, #F43F5E 0%, #E11D48 100%);
    
    /* Новые градиенты */
    --gradient-emerald: linear-gradient(135deg, #34D399 0%, #059669 100%);
    --gradient-fuchsia: linear-gradient(135deg, #E879F9 0%, #C026D3 100%);
    --gradient-amber: linear-gradient(135deg, #F59E0B 0%, #B45309 100%);
    
    --radius-lg: 24px;
    --shadow-soft: 0 4px 20px rgba(0, 0, 0, 0.03);
    --shadow-hover: 0 12px 32px rgba(0, 0, 0, 0.08);
    --font-main: 'Manrope', sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
    font-family: var(--font-main);
    background-color: var(--bg-color);
    color: var(--text-primary);
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    /* FIX: Запрещаем горизонтальный скролл всей страницы */
    overflow-x: hidden; 
    width: 100%;
}

.container { max-width: 1200px; margin: 0 auto; padding: 0 20px; width: 100%; }

/* --- Хедер --- */
.header { 
    padding: 16px 0; /* Чуть меньше отступы */
    background: transparent; margin-bottom: 20px;
    border-bottom: 1px solid rgba(0,0,0,0.03);
}

.header__container { 
    display: flex; 
    align-items: center; 
    gap: 24px; 
    flex-wrap: wrap; /* Разрешаем перенос для поиска */
}

/* Бренд блок */
.brand-wrapper {
    display: flex; flex-direction: column; justify-content: center; 
    margin-right: auto; /* Отодвигаем всё остальное вправо */
}
.logo { 
    font-size: 24px; font-weight: 800; color: var(--text-primary); 
    text-decoration: none; letter-spacing: -0.03em; line-height: 1;
}
.tagline {
    font-size: 12px; color: var(--text-secondary); margin-top: 4px;
    font-weight: 500;
    /* FIX: Теперь показываем везде, но можно скрыть на совсем мелких */
    display: block; 
}

/* Кнопка в шапке */
.btn {
    padding: 10px 18px; border-radius: 12px; font-weight: 700; font-size: 14px;
    cursor: pointer; border: none; text-decoration: none; display: inline-block;
    transition: transform 0.2s, box-shadow 0.2s; white-space: nowrap;
}
.btn--primary { background-color: var(--primary-color); color: #fff; }
.btn:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.2); }

/* --- Поиск (LIVE SEARCH) --- */
.search-bar { 
    flex-grow: 1; max-width: 480px; position: relative; 
    display: block; /* FIX: Показываем всегда */
    z-index: 500;
}

.search-bar input {
    width: 100%; padding: 10px 16px 10px 40px; border-radius: 99px;
    border: 1px solid rgba(0,0,0,0.05); background: #fff;
    font-family: inherit; font-size: 14px; transition: all 0.2s; 
    outline: none; box-shadow: var(--shadow-soft);
}
.search-bar input:focus { border-color: var(--accent-blue); box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1); }
.search-bar > svg { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); color: var(--text-secondary); }

.search-results {
    position: absolute; top: 100%; left: 0; width: 100%;
    max-height: 400px; overflow-y: auto; background: #fff;
    border-radius: 16px; box-shadow: 0 10px 40px rgba(0,0,0,0.15), 0 2px 10px rgba(0,0,0,0.05);
    margin-top: 12px; opacity: 0; visibility: hidden; transform: translateY(-10px);
    transition: all 0.2s cubic-bezier(0.25, 0.8, 0.25, 1); z-index: 9999;
    border: 1px solid rgba(0,0,0,0.05);
    scrollbar-width: thin; scrollbar-color: #E5E7EB transparent;
}
.search-results::-webkit-scrollbar { width: 6px; }
.search-results::-webkit-scrollbar-thumb { background-color: #E5E7EB; border-radius: 20px; }
.search-results.active { opacity: 1; visibility: visible; transform: translateY(0); }

.search-item {
    display: flex; align-items: center; gap: 12px; padding: 14px 16px;
    text-decoration: none; color: var(--text-primary);
    transition: background 0.1s; border-bottom: 1px solid #F3F4F6;
}
.search-item:last-child { border-bottom: none; }
.search-item:hover { background: #F9FAFB; }

.search-icon {
    width: 36px; height: 36px; border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.search-icon svg { width: 22px !important; height: 22px !important; display: block; }

.search-info { display: flex; flex-direction: column; overflow: hidden; }
.search-info h4 { font-size: 14px; font-weight: 600; margin-bottom: 2px; white-space: nowrap; text-overflow: ellipsis; overflow: hidden; }
.search-info span { font-size: 12px; color: var(--text-secondary); white-space: nowrap; text-overflow: ellipsis; overflow: hidden; opacity: 0.8; }
.search-info strong { color: var(--accent-blue); background: rgba(37, 99, 235, 0.1); padding: 0 2px; border-radius: 2px; font-weight: 800; }
.no-results { padding: 20px; text-align: center; color: var(--text-secondary); font-size: 14px; }

/* --- АДАПТИВ (Мобильная версия) --- */
@media (max-width: 768px) {
    .header__container { 
        gap: 16px; 
    }
    
    /* 1. Логотип и Кнопка в одну строку */
    .brand-wrapper { order: 1; }
    .btn { order: 2; font-size: 12px; padding: 8px 14px; } /* Уменьшили кнопку */
    
    /* 2. Поиск переносим на новую строку и растягиваем */
    .search-bar { 
        order: 3; 
        width: 100%; 
        max-width: 100%; 
        margin-top: 4px;
    }
    
    .tagline { display: none; } /* На совсем узких можно скрыть слоган, если мешает */
}

/* На совсем маленьких экранах (iPhone SE) */
@media (max-width: 380px) {
    .logo { font-size: 20px; }
    .btn { padding: 6px 12px; }
}

/* --- Контент --- */
.main { padding-top: 20px; padding-bottom: 80px; flex-grow: 1; }
.section-title { font-size: 32px; font-weight: 800; margin-bottom: 32px; letter-spacing: -0.02em; }

/* --- BENTO GRID --- */
.bento-grid { display: grid; grid-template-columns: 1fr; gap: 20px; }
@media (min-width: 768px) { .bento-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .bento-grid { grid-template-columns: repeat(4, 1fr); grid-auto-rows: minmax(180px, auto); } }

/* Карточки (Базовый стиль) */
.card {
    background: #fff; border-radius: var(--radius-lg); padding: 24px;
    display: flex; flex-direction: column; 
    
    /* FIX: Прижимаем контент к верху, чтобы не было "дыр" посередине */
    justify-content: flex-start; 
    /* Добавляем фиксированный отступ между элементами */
    gap: 16px;
    
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    border: 1px solid rgba(255,255,255,0.6); box-shadow: var(--shadow-soft);
    position: relative; overflow: hidden; cursor: pointer; text-decoration: none; color: inherit;
}
.card:hover { transform: translateY(-4px) scale(1.01); box-shadow: var(--shadow-hover); }

/* SAFE FIX: Поддержка и H2, и H3 (на случай рассинхрона) */
.card h3, .card h2 { 
    font-size: 18px; font-weight: 700; margin: 0; letter-spacing: -0.01em; 
    color: inherit; line-height: 1.3;
}
.card p { font-size: 14px; color: var(--text-secondary); line-height: 1.4; margin: 0; }

.card__icon-wrapper {
    width: 48px; height: 48px; border-radius: 12px; display: flex; align-items: center;
    justify-content: center; margin-bottom: 0; /* Отступ теперь через gap у родителя */
    background: #F3F4F6; color: var(--text-primary);
    flex-shrink: 0; /* Чтобы иконку не плющило */
}

/* --- Стили конкретных карточек (УНИВЕРСАЛЬНЫЕ) --- */

/* Featured (Blue - Ипотека) */
.card--featured { background: var(--gradient-blue); color: #fff; }
@media (min-width: 1024px) { .card--featured { grid-column: span 2; grid-row: span 2; } }

/* Универсальный селектор для заголовков в Featured */
.card--featured h3, .card--featured h2 { 
    font-size: 24px; 
    color: #fff !important; 
    margin-bottom: 4px; /* Небольшой доп отступ */
}
.card--featured p { 
    color: rgba(255,255,255,0.9) !important; 
    font-size: 16px; 
    max-width: 90%; 
    font-weight: 500; 
}
.card--featured .card__icon-wrapper { background: rgba(255,255,255,0.2); color: #fff; width: 56px; height: 56px; }
.card__action { 
    margin-top: auto; /* Прижимаем кнопку к самому низу */
    display: flex; align-items: center; gap: 8px; font-weight: 600; font-size: 14px; 
}

/* Wide (Обычно для дат) */
@media (min-width: 1024px) { .card--wide { grid-column: span 2; } }
/* Flex контейнер для заголовка и иконки в ряд */
.card--wide .card__top { 
    display: flex; align-items: center; gap: 16px; 
    width: 100%;
}
/* Сброс маргинов внутри флекса */
.card--wide .card__top h2, .card--wide .card__top h3 { margin: 0; }

/* Mint (Проценты) */
.card--mint { background: var(--gradient-mint); }
.card--mint .card__icon-wrapper { background: rgba(255,255,255,0.6); color: #059669; }
.card--mint h3, .card--mint h2 { color: #064E3B; }
.card--mint p { color: #065F46; }

/* Premium Dark (Разработка) */
@media (min-width: 1024px) { .card--dark { grid-column: span 2; } }
@media (min-width: 768px) { .card--wide-bottom { grid-column: 1 / -1; } }

.card--dark {
    background: var(--gradient-dark);
    border: 1px solid rgba(255, 255, 255, 0.08);
    position: relative; overflow: hidden;
}
.card--dark:hover::before { opacity: 1; }
.card--dark::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; bottom: 0;
    background: radial-gradient(circle at top right, rgba(139, 92, 246, 0.15), transparent 40%);
    opacity: 0.5; transition: opacity 0.3s;
}

.card--dark .card__content-row { 
    display: flex; gap: 16px; align-items: flex-start; position: relative; z-index: 2; 
    min-width: 0; 
}

/* Заголовок и текст Premium */
.premium-title {
    color: #fff !important;
    font-size: 18px; font-weight: 700; margin-bottom: 6px; letter-spacing: -0.01em;
}
/* Дублируем для тегов */
.card--dark h3, .card--dark h2 { color: #fff !important; }

.premium-desc {
    color: #CBD5E1 !important; /* Slate-300 */
    font-size: 14px; line-height: 1.5; font-weight: 500;
}
.card--dark p { color: #CBD5E1 !important; }

.card__icon-wrapper--premium {
    background: linear-gradient(135deg, #6366F1 0%, #8B5CF6 100%);
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.2);
    box-shadow: 0 4px 12px rgba(99, 102, 241, 0.3);
    width: 48px; height: 48px; border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}

.card--dark .card__action-arrow { 
    position: absolute; bottom: 24px; right: 24px; 
    color: rgba(255, 255, 255, 0.6); opacity: 0.8; transition: 0.2s; z-index: 2; 
}
.card--dark:hover .card__action-arrow { color: #fff; transform: translateX(4px); opacity: 1; }


/* --- ЦВЕТНЫЕ КАРТОЧКИ (УНИВЕРСАЛЬНЫЕ СЕЛЕКТОРЫ) --- */

/* Yellow (ИМТ) */
.card--yellow { background: var(--gradient-yellow); color: #fff; }
.card--yellow .card__icon-wrapper { background: rgba(255,255,255,0.2); color: #fff; }
.card--yellow h3, .card--yellow h2, .card--yellow p { color: #fff; }
.card--yellow p { opacity: 0.9; }

/* Coral (Калории) */
.card--coral { background: var(--gradient-coral); color: #fff; }
.card--coral .card__icon-wrapper { background: rgba(255,255,255,0.2); color: #fff; }
.card--coral h3, .card--coral h2, .card--coral p { color: #fff; }
.card--coral p { opacity: 0.9; }

/* Cyan (Краска) */
.card--cyan { background: var(--gradient-cyan); color: #fff; }
.card--cyan .card__icon-wrapper { background: rgba(255,255,255,0.2); color: #fff; }
.card--cyan h3, .card--cyan h2, .card--cyan p { color: #fff; }
.card--cyan p { opacity: 0.9; }

/* Indigo (НДС) */
.card--indigo { background: var(--gradient-indigo); color: #fff; }
.card--indigo .card__icon-wrapper { background: rgba(255,255,255,0.2); color: #fff; }
.card--indigo h3, .card--indigo h2, .card--indigo p { color: #fff; }
.card--indigo p { opacity: 0.9; }

/* Violet (Даты) */
.card--violet { background: var(--gradient-violet); color: #fff; }
.card--violet .card__icon-wrapper { background: rgba(255,255,255,0.2); color: #fff; }
.card--violet h3, .card--violet h2, .card--violet p { color: #fff; }

/* Rose (Топливо) */
.card--rose { background: var(--gradient-rose); color: #fff; }
.card--rose .card__icon-wrapper { background: rgba(255,255,255,0.2); color: #fff; }
.card--rose h3, .card--rose h2, .card--rose p { color: #fff; }
.card--rose p { opacity: 0.9; }

/* Teal (Автокредит) */
.card--teal { background: var(--gradient-teal); color: #fff; }
.card--teal .card__icon-wrapper { background: rgba(255,255,255,0.2); color: #fff; }
.card--teal h3, .card--teal h2, .card--teal p { color: #fff; }

/* Orange (Плитка) */
.card--orange { background: var(--gradient-orange); color: #fff; }
.card--orange .card__icon-wrapper { background: rgba(255,255,255,0.2); color: #fff; }
.card--orange h3, .card--orange h2, .card--orange p { color: #fff; }

/* Emerald (Вклады) */
.card--emerald { background: var(--gradient-emerald); color: #fff; }
.card--emerald .card__icon-wrapper { background: rgba(255,255,255,0.2); color: #fff; }
.card--emerald h3, .card--emerald h2, .card--emerald p { color: #fff; }

/* Fuchsia (Обои) */
.card--fuchsia { background: var(--gradient-fuchsia); color: #fff; }
.card--fuchsia .card__icon-wrapper { background: rgba(255,255,255,0.2); color: #fff; }
.card--fuchsia h3, .card--fuchsia h2, .card--fuchsia p { color: #fff; }

/* Amber (Ламинат) */
.card--amber { background: var(--gradient-amber); color: #fff; }
.card--amber .card__icon-wrapper { background: rgba(255,255,255,0.2); color: #fff; }
.card--amber h3, .card--amber h2, .card--amber p { color: #fff; }

/* Вспомогательные классы */
.card__icon-wrapper--yellow { background: #FEF3C7; color: #D97706; }


/* --- Каталог (Mini Grid) --- */
.catalog-section { padding-top: 60px; padding-bottom: 60px; }
.category-nav {
    display: flex; gap: 10px; overflow-x: auto; padding-bottom: 16px; margin-bottom: 40px;
    scrollbar-width: none; -webkit-overflow-scrolling: touch;
}
.category-nav::-webkit-scrollbar { display: none; }
.cat-pill {
    padding: 10px 20px; border-radius: 99px; background: #fff; border: 1px solid #E5E7EB;
    color: var(--text-secondary); font-size: 14px; font-weight: 600; cursor: pointer;
    white-space: nowrap; transition: all 0.2s; font-family: inherit;
}
.cat-pill:hover { border-color: #D1D5DB; color: var(--text-primary); transform: translateY(-1px); }
.cat-pill.active { background: var(--text-primary); color: #fff; border-color: var(--text-primary); box-shadow: 0 4px 12px rgba(0,0,0,0.15); }

.catalog-group { margin-bottom: 48px; transition: opacity 0.3s ease; }
.group-title { font-size: 20px; font-weight: 700; margin-bottom: 20px; color: var(--text-primary); display: flex; align-items: center; }
.group-title::after { content: ''; flex-grow: 1; height: 1px; background: #E5E7EB; margin-left: 16px; }

.mini-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 16px; }
@media (max-width: 600px) { .mini-grid { grid-template-columns: 1fr; } }

.mini-card {
    background: #fff; border-radius: 16px; padding: 16px; display: flex; align-items: center; gap: 16px;
    text-decoration: none; border: 1px solid rgba(0,0,0,0.04); transition: all 0.2s; box-shadow: 0 2px 4px rgba(0,0,0,0.02);
    /* FIX: Гарантируем, что карточка не шире контейнера */
    max-width: 100%; 
    overflow: hidden; 
}
.mini-card:hover { transform: translateY(-2px); box-shadow: 0 8px 16px rgba(0,0,0,0.06); border-color: rgba(0,0,0,0.08); }

.mini-icon {
    width: 48px; height: 48px; border-radius: 12px; display: flex; align-items: center; justify-content: center;
    color: var(--text-primary); background: #F3F4F6; flex-shrink: 0;
}

.mini-info { 
    flex-grow: 1; 
    overflow: hidden; 
    /* FIX: Критически важно для работы text-overflow внутри Flex */
    min-width: 0; 
}

/* FIX: Универсальный селектор для мини-карточек (H3 и H4) */
.mini-info h4, .mini-info h3 { 
    font-size: 15px; font-weight: 700; color: var(--text-primary); margin: 0 0 4px 0; 
    white-space: nowrap; text-overflow: ellipsis; overflow: hidden; 
}
.mini-info span { 
    font-size: 13px; color: var(--text-secondary); display: block; 
    white-space: nowrap; text-overflow: ellipsis; overflow: hidden; 
}
.mini-card.disabled { opacity: 0.8; cursor: default; background: #F9FAFB; border-style: dashed; }
.mini-card.disabled:hover { transform: none; box-shadow: none; }

/* Внутренние */
.calc-box { 
    background: #fff; padding: 30px; border-radius: var(--radius-lg); 
    box-shadow: var(--shadow-soft); max-width: 600px; margin: 0 auto; 
}
.back-link { 
    display: inline-flex; align-items: center; gap: 8px; margin-bottom: 24px; 
    color: var(--text-secondary); text-decoration: none; font-weight: 500; font-size: 14px; 
}
.back-link:hover { color: var(--accent-blue); }

/* --- ФУТЕР (Dark) --- */
.footer { background: #111827; color: #D1D5DB; padding: 60px 0 20px; margin-top: auto; }
.footer-grid { display: grid; grid-template-columns: 1fr; gap: 40px; margin-bottom: 40px; }
@media (min-width: 768px) { .footer-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .footer-grid { grid-template-columns: 2fr 1fr 1fr 1fr; } }

.footer-logo { color: #fff; margin-bottom: 16px; display: inline-block; font-size: 24px; }
.footer-desc { font-size: 14px; line-height: 1.6; max-width: 300px; color: #D1D5DB; }

/* FIX: Универсальный селектор для футера (H3 и H4) */
.footer-col h4, .footer-col h3 { color: #fff; font-size: 16px; font-weight: 700; margin-bottom: 20px; }

.footer-links { list-style: none; padding: 0; margin: 0; }
.footer-links li { margin-bottom: 12px; }
.footer-links a { color: #D1D5DB; text-decoration: none; font-size: 14px; transition: color 0.2s; }
.footer-links a:hover { color: #fff; padding-left: 4px; }
.social-icons { margin-top: 20px; display: flex; gap: 12px; }
.social-link {
    width: 36px; height: 36px; border-radius: 50%; background: rgba(255,255,255,0.1);
    display: flex; align-items: center; justify-content: center; color: #fff; transition: background 0.2s; text-decoration: none;
}
.social-link:hover { background: #3B82F6; }
.footer-bottom {
    border-top: 1px solid rgba(255,255,255,0.1); padding-top: 24px;
    display: flex; justify-content: space-between; align-items: center; font-size: 13px; 
    color: #9CA3AF; /* Исправлен цвет на светло-серый */
}
.api-status { background: rgba(255,255,255,0.1); padding: 4px 8px; border-radius: 4px; font-family: monospace; color: #fff; }

/* --- Исправление текста на цветных карточках (Featured & Dark) --- */
.card--featured p, .card--dark p {
    color: rgba(255, 255, 255, 0.9) !important;
    font-weight: 500;
}
.card--featured:hover p, .card--dark:hover p { color: #ffffff !important; }
.card--featured h3, .card--dark h3 { color: #ffffff !important; }