/**
 * Krupnomery Page — Страница крупномеров
 * 
 * @package Biolocus
 * @version 1.2.0
 * 
 * Зависимости:
 * - variables.css
 * - components.css (карточки, кнопки, формы)
 * - sections.css (сетки, секции)
 */

/* ========================================
   ОТКЛЮЧЕНИЕ АНИМАЦИЙ fade-in-stagger
   На этой странице показываем сразу
   ======================================== */

.krupnomery-page .fade-in-stagger,
.krupnomery-page .fade-in-stagger > * {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    animation: none;
}

/* ========================================
   K-HERO — Hero блок страницы
   ======================================== */

.k-hero {
    position: relative;
    background: linear-gradient(135deg, rgba(127, 193, 67, 0.08) 0%, rgba(127, 193, 67, 0.02) 100%);
    overflow: hidden;
    min-height: 380px;
}

/* С фоновым изображением */
.k-hero--has-image {
    background: transparent;
}

.k-hero__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.k-hero__bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.k-hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0.4) 100%);
}

/* Хлебные крошки */
.k-hero__breadcrumbs {
    position: relative;
    z-index: 2;
    background: rgba(255, 254, 249, 0.95);
}

.k-hero--has-image .k-hero__breadcrumbs {
    background: rgba(0, 0, 0, 0.3);
}

.k-hero--has-image .k-hero__breadcrumbs .breadcrumbs a,
.k-hero--has-image .k-hero__breadcrumbs .breadcrumbs span {
    color: rgba(255, 255, 255, 0.85);
}

.k-hero--has-image .k-hero__breadcrumbs .breadcrumbs a:hover {
    color: #fff;
}

/* Контент Hero */
.k-hero__content {
    position: relative;
    z-index: 2;
    padding: var(--spacing-2xl) 0 var(--spacing-3xl);
    max-width: 800px;
}

/* Без картинки — центрируем */
.k-hero:not(.k-hero--has-image) .k-hero__content {
    max-width: 100%;
    text-align: center;
}

.k-hero:not(.k-hero--has-image) .k-hero__subtitle {
    margin-inline: auto;
}

.k-hero:not(.k-hero--has-image) .k-hero__actions,
.k-hero:not(.k-hero--has-image) .k-hero__features {
    justify-content: center;
}

.k-hero--has-image .k-hero__content {
    color: #fff;
}

/* Бейдж */
.k-hero__badge {
    display: inline-block;
    padding: 8px 18px;
    background: var(--accent);
    color: #fff;
    font-size: var(--font-size-sm);
    font-weight: var(--font-bold);
    border-radius: var(--radius-full);
    margin-bottom: var(--spacing-md);
    box-shadow: 0 4px 12px rgba(245, 166, 35, 0.3);
}

/* Заголовок */
.k-hero__title {
    font-size: clamp(28px, 5vw, 48px);
    font-weight: var(--font-extrabold);
    line-height: var(--line-height-tight);
    margin: 0 0 var(--spacing-md);
    color: var(--text-dark);
}

.k-hero--has-image .k-hero__title {
    color: #fff;
    text-shadow: 0 2px 12px rgba(0, 0, 0, 0.3);
}

/* Подзаголовок */
.k-hero__subtitle {
    font-size: var(--font-size-lg);
    color: var(--text-mid);
    line-height: var(--line-height-relaxed);
    margin: 0 0 var(--spacing-xl);
    max-width: 600px;
}

.k-hero--has-image .k-hero__subtitle {
    color: rgba(255, 255, 255, 0.9);
}

/* Кнопки */
.k-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
}

/* Фичи */
.k-hero__features {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-lg);
}

.k-hero__feature {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: var(--font-size-sm);
    font-weight: var(--font-medium);
    color: var(--text-mid);
}

.k-hero--has-image .k-hero__feature {
    color: rgba(255, 255, 255, 0.95);
}

.k-hero__feature svg {
    flex-shrink: 0;
    stroke: var(--primary);
}

.k-hero--has-image .k-hero__feature svg {
    stroke: var(--primary-light);
}

/* ========================================
   PROCESS STEPS — Этапы работы
   Переопределяем сетку
   ======================================== */

.process-steps {
    background: var(--card-bg);
}

.process-steps__grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: var(--spacing-lg);
}

.process-step {
    position: relative;
    text-align: center;
    padding: var(--spacing-lg);
    padding-top: calc(var(--spacing-lg) + 14px);
    background: var(--section-alt);
    border-radius: var(--radius-xl);
    transition: all var(--transition-normal);
}

.process-step:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.process-step__number {
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-size-sm);
    font-weight: var(--font-bold);
    color: #fff;
    background: var(--primary-grad);
    border-radius: var(--radius-full);
    box-shadow: 0 2px 8px rgba(127, 193, 67, 0.4);
}

.process-step__icon {
    width: 64px;
    height: 64px;
    margin: 0 auto var(--spacing-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 32px;
    background: var(--card-bg);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-sm);
}

.process-step__title {
    font-size: var(--font-size-base);
    font-weight: var(--font-bold);
    color: var(--text-dark);
    margin-bottom: var(--spacing-xs);
}

.process-step__text {
    font-size: var(--font-size-sm);
    color: var(--text-mid);
    line-height: var(--line-height-relaxed);
    margin: 0;
}

.process-step__arrow {
    display: none;
}

/* ========================================
   SEO BLOCK — Универсальный SEO блок
   ======================================== */

.seo-block__inner {
    display: flex;
    gap: var(--spacing-2xl);
    align-items: flex-start;
}

.seo-block__content {
    flex: 1;
    min-width: 0;
}

.seo-block__media {
    flex: 0 0 400px;
}

/* Если медиа пустой — контент на всю ширину */
.seo-block__media:empty {
    display: none;
}

/* Заголовок */
.seo-block__title {
    font-size: var(--font-size-2xl);
    font-weight: var(--font-bold);
    color: var(--text-dark);
    margin: 0 0 var(--spacing-md);
    line-height: var(--line-height-normal);
}

/* Текст */
.seo-block__text {
    font-size: var(--font-size-base);
    color: var(--text-mid);
    line-height: var(--line-height-relaxed);
}

.seo-block__text p {
    margin-bottom: var(--spacing-md);
}

.seo-block__text p:last-child {
    margin-bottom: 0;
}

.seo-block__text strong {
    color: var(--text-dark);
    font-weight: var(--font-semibold);
}

.seo-block__text em {
    color: var(--primary);
    font-style: normal;
    font-weight: var(--font-semibold);
}

/* Список */
.seo-list {
    list-style: none;
    padding: 0;
    margin: var(--spacing-lg) 0;
}

.seo-list li {
    position: relative;
    padding-left: 28px;
    margin-bottom: var(--spacing-sm);
    line-height: var(--line-height-relaxed);
}

.seo-list li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: var(--primary);
    font-weight: var(--font-bold);
}

/* Фичи */
.seo-features {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-lg);
}

.seo-feature {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-sm);
    font-size: var(--font-size-sm);
}

.seo-feature__icon {
    color: var(--primary);
    font-weight: var(--font-bold);
}

/* ========================================
   SEO BLOCK — Картинка
   ======================================== */

.seo-block--text_image .seo-block__image {
    border-radius: var(--radius-2xl);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
}

.seo-block--text_image .seo-block__image img {
    width: 100%;
    height: auto;
    display: block;
}

.seo-block--reverse .seo-block__inner {
    flex-direction: row-reverse;
}

/* ========================================
   SEO BLOCK — Форма
   ======================================== */

.seo-block__form {
    background: var(--card-bg);
    border-radius: var(--radius-xl);
    padding: var(--spacing-xl);
    box-shadow: var(--shadow-md);
    border: 1px solid var(--card-border);
}

.seo-block--text_form.section-alt .seo-block__form {
    background: #fff;
}

.seo-block__form-title {
    font-size: var(--font-size-xl);
    font-weight: var(--font-bold);
    color: var(--text-dark);
    margin: 0 0 var(--spacing-xs);
    text-align: center;
}

.seo-block__form-desc {
    font-size: var(--font-size-sm);
    color: var(--text-light);
    margin: 0 0 var(--spacing-lg);
    text-align: center;
}

.seo-form {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

/* ========================================
   SEO BLOCK — Форма со скидкой
   ======================================== */

.seo-block__form--discount {
    position: relative;
    padding-top: calc(var(--spacing-xl) + 20px);
}

.seo-discount {
    position: absolute;
    top: -18px;
    left: 50%;
    transform: translateX(-50%);
    text-align: center;
    z-index: 2;
}

.seo-discount__value {
    display: inline-block;
    padding: 10px 24px;
    background: var(--sale);
    color: #fff;
    font-size: var(--font-size-2xl);
    font-weight: var(--font-extrabold);
    border-radius: var(--radius-full);
    box-shadow: 0 4px 15px rgba(229, 62, 62, 0.4);
    line-height: 1;
}

.seo-discount__text {
    display: block;
    margin-top: 4px;
    font-size: var(--font-size-xxs);
    font-weight: var(--font-semibold);
    color: var(--text-light);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* ========================================
   K-FAQ — Упрощённый FAQ
   ======================================== */

.k-faq__wrapper {
    max-width: 900px;
    margin: 0 auto;
}

/* ========================================
   RESPONSIVE
   ======================================== */

@media (max-width: 1200px) {
    .process-steps__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 1024px) {
    .seo-block__inner {
        gap: var(--spacing-xl);
    }
    
    .seo-block__media {
        flex: 0 0 340px;
    }
    
    .process-steps__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 900px) {
    /* Hero */
    .k-hero__content {
        padding: var(--spacing-xl) 0 var(--spacing-2xl);
    }
    
    .k-hero__actions {
        flex-direction: column;
    }
    
    .k-hero__actions .btn {
        width: 100%;
        justify-content: center;
    }
    
    .k-hero__features {
        flex-direction: column;
        gap: var(--spacing-sm);
    }
    
    /* SEO блоки */
    .seo-block__inner {
        flex-direction: column;
    }
    
    .seo-block__media {
        flex: none;
        width: 100%;
    }
    
    .seo-block--reverse .seo-block__inner {
        flex-direction: column;
    }
    
    /* Process */
    .process-steps__grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-md);
    }
}

@media (max-width: 768px) {
    .k-hero {
        min-height: auto;
    }
    
    .k-hero__title {
        font-size: var(--font-size-2xl);
    }
    
    .k-hero__subtitle {
        font-size: var(--font-size-base);
    }
    
    .seo-block__title {
        font-size: var(--font-size-xl);
    }
    
    .seo-block__form {
        padding: var(--spacing-lg);
    }
    
    .process-step {
        padding: var(--spacing-md);
        padding-top: calc(var(--spacing-md) + 14px);
    }
    
    .process-step__icon {
        width: 56px;
        height: 56px;
        font-size: 28px;
    }
}

@media (max-width: 480px) {
    .k-hero__content {
        padding: var(--spacing-lg) 0 var(--spacing-xl);
    }
    
    .k-hero__badge {
        font-size: var(--font-size-xs);
        padding: 6px 14px;
    }
    
    .seo-block__inner {
        gap: var(--spacing-lg);
    }
    
    .seo-discount__value {
        font-size: var(--font-size-xl);
        padding: 8px 18px;
    }
}