.grid-container {
    /* Верхний отступ минимальный, чтобы быть близко к новости */
    padding: 0.5rem 1.25rem 5rem 1.25rem; 
    display: flex; 
    align-items: center; 
    justify-content: center;
    min-height: 85vh; 
}

.services-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 5rem;
    width: 100%; max-width: 80.75rem; /* 1100px */
}

.card {
    background: var(--brand-dark); color: var(--white); 
    padding: 3rem; /* 45px */
    min-height: 12rem; /* 220px */
    border-radius: 0.25rem 6.25rem 6.25rem 0.25rem; 
    position: relative; overflow: hidden;
    display: flex; flex-direction: column; justify-content: space-between;
    transition: 0.4s cubic-bezier(0.2, 0.8, 0.2, 1); cursor: pointer; text-decoration: none;
}

.card h3 {
    font-size: 1.6rem; font-weight: 500; 
    text-transform: uppercase; line-height: 1.1; z-index: 2;
}

/* css/main.css */

/* Общие стили для декоративного символа сзади */
.card::after {
    position: absolute;
    top: -0.625rem;
    right: -0.625rem;
    z-index: 1;
    content: ""; 
    display: block; 
    
    /* Возвращаем оригинальный размер (было font-size: 10rem) */
    width: clamp(10rem, 20vw, 15rem); 
    height: clamp(10rem, 20vw, 15rem);

    /* ИСПРАВЛЕНИЕ: Возвращаем ваш оригинальный полупрозрачный цвет */
    background-color: var(--white-decoration); 
    
    transition: 0.6s;
    
    /* Стили маски */
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
}
.card:hover::after {
    /* Возвращаем ваш оригинальный цвет при ховере */
    background-color: var(--magenta);
    opacity: 0.2; 
    transform: rotate(15deg) scale(1.1);
}

/* =========================================
   Конкретные маски для каждой карточки
   (SVG коды стандартных символов в DataURI)
   ========================================= */

/* Карточка 1: Секвенирование -> Промотер */
.card:nth-child(1)::after {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M5 20V8h14M16 5l3 3-3 3' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath d='M5 20V8h14M16 5l3 3-3 3' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}

/* Карточка 2: Синтез -> Круг (○) */
.card:nth-child(2)::after {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='8'%3E%3C/circle%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='8'%3E%3C/circle%3E%3C/svg%3E");
}

/* Карточка 3: Сборка -> Стрелка вправо-вверх (↗) */
.card:nth-child(3)::after {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='7' y1='17' x2='17' y2='7'%3E%3C/line%3E%3Cpolyline points='7 7 17 7 17'%3E%3C/polyline%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='7' y1='17' x2='17' y2='7'%3E%3C/line%3E%3Cpolyline points='7 7 17 7 17'%3E%3C/polyline%3E%3C/svg%3E");
}

/* Карточка 4: Реактивы -> Квадрат (■) */
.card:nth-child(4)::after {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='3' width='14' height='14' rx='2' ry='2'%3E%3C/rect%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='3' width='14' height='14' rx='2' ry='2'%3E%3C/rect%3E%3C/svg%3E");
}

/* АНИМАЦИЯ */
.card:hover { transform: translateY(-0.625rem); 
box-shadow: 
        0 0.5rem 2.5rem var(--magenta-glow),      /* Ближний слой (объем) */
        0 2.5rem 4rem var(--magenta-glow-soft), /* Средний слой (рассеивание) */
        0 4rem 5rem rgba(0, 0, 0, 0.1);       /* Темное основание для глубины */
}


.btn-text { color: var(--magenta); font-weight: 600; font-size: 0.8rem; z-index: 2; letter-spacing: 0.1em; }

.news-announcement {
    width: 100%;
    display: flex;
    justify-content: center;
    /* 2rem сверху от хедера, 0.5rem снизу до фигур */
    padding: 2rem 0 0.5rem 0; 
}

.news-window {
    background: var(--brand-dark);
    color: var(--white);
    padding: 0.6rem 1.2rem;
    border-radius: 3rem;
    display: flex;
    align-items: center;
    gap: 1rem;
    font-size: 0.75rem;
    box-shadow: var(--shadow-sm);
    border: 1px solid rgba(var(--shadow-rgb-magenta), 0.3);
    
    /* ОБЪЕДИНЯЕМ АНИМАЦИИ: 
       1. slideInDown - срабатывает один раз при загрузке.
       2. newsPulse - запускается через 0.6с и работает бесконечно. */
    animation: 
        slideInDown 0.6s ease-out, 
        newsPulse 3s infinite ease-in-out 0.6s;
    
    z-index: 10;
    transition: opacity 0.4s ease, transform 0.4s ease; /* Для плавной смены текста */
    min-width: 25rem; /* Фиксируем ширину, чтобы окно не "скакало" при разной длине названий */
}

/* Эффект мягкого пульсирующего свечения */
@keyframes newsPulse {
    0%, 100% { 
        transform: scale(1); 
        box-shadow: var(--shadow-sm); 
        border-color: rgba(var(--shadow-rgb-magenta), 0.3); /* Рамка приглушена */
    }
    50% { 
        transform: scale(1.02); 
        box-shadow: var(--shadow-magenta-glow-strong); 
        border-color: var(--magenta); /* Рамка вспыхивает на 100% цвета */
    }
}

.news-tag {
    background: var(--magenta);
    color: var(--white);
    padding: 0.2rem 0.6rem;
    border-radius: 2rem;
    font-weight: 900;
    font-size: 0.65rem;
    letter-spacing: 0.05em;
}


.news-link {
    color: var(--white);
    text-decoration: none;
    font-weight: 700;
    transition: opacity 0.2s;
    flex-grow: 1;
    text-align: center;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis; /* Если название слишком длинное, оно аккуратно сократится */
}

.news-link:hover {
    opacity: 0.8;
}

@keyframes slideInDown {
    from { opacity: 0; transform: translateY(-10px); }
    to { opacity: 1; transform: translateY(0); }
}
.cabinet-btn {
    background: var(--white-soft);
    padding: 8px 15px;
    border-radius: 8px;
    border: 1px solid var(--brand-dark);
    transition: all 0.3s ease;
}
.cabinet-btn:hover {
    background: var(--magenta);
    color: #fff !important;
}
@media (max-width: 768px) {
    .services-grid {
        grid-template-columns: 1fr; 
        gap: 1rem; 
    }

    /* Уменьшаем гигантские отступы в карточках */
    .card {
        padding: 1.5rem; 
        min-height: auto;
        border-radius: 0.25rem 2rem 2rem 0.25rem; /* Смягчаем скругление */
    }
    
    .card h3 {
        font-size: 1.2rem; 
        margin-bottom: 1rem;
    }

    /* Уменьшаем декоративные символы на фоне карточек */
    .card::after {
        font-size: 5rem; 
        width: clamp(5rem, 15vw, 10rem); 
        height: clamp(5rem, 15vw, 10rem); 
        top: 0;
        right: 0;
    }

    /* --- ОКНО НОВОСТЕЙ --- */
    .news-announcement {
        padding: 1rem 1rem 0 1rem;
    }
    
    .news-window {
        min-width: 0;
        width: 100%;
        /* Оставляем строку, а не колонку, чтобы было компактно */
        flex-direction: row; 
        flex-wrap: wrap; /* Разрешаем перенос внутри плашки */
        justify-content: center;
        text-align: center;
        gap: 0.5rem;
        padding: 0.8rem;
        border-radius: 1rem;
        border: 1px solid rgba(var(--shadow-rgb-magenta), 0.3);
    }
    
    .news-text {
        white-space: normal;
        flex-basis: 100%; /* Заставляем текст занять всю ширину, отправляя "Подробнее" вниз */
        font-size: 0.8rem;
        margin: 0.2rem 0;
    }

    .news-link {
        font-size: 0.75rem;
    }
}