.sf-hidden{display:none!important}

/* ===== textSeo: основа ===== */
.textSeo {
    margin: 50px 0;
}
.textSeo p {
    line-height: 1.6;
    margin-bottom: 14px;
}

/* ===== H1 — уникальный стиль ===== */
.textSeo .seo-h1,
.textSeo h1 {
    font-size: 28px;
    font-weight: 800;
    line-height: 1.25;
    margin-bottom: 22px;
    margin-top: 0;
    letter-spacing: -0.3px;
    padding-bottom: 14px;
    border-bottom: 2px solid rgba(255, 255, 255, 0.15);
    position: relative;
}
.textSeo .seo-h1::after,
.textSeo h1::after {
    content: '';
    display: block;
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 60px;
    height: 2px;
    background: linear-gradient(90deg, rgba(255,200,50,0.9), rgba(255,200,50,0.2));
    border-radius: 2px;
}

/* ===== H2 — уникальный стиль с боковым акцентом ===== */
.textSeo .seo-h2,
.textSeo h2 {
    font-size: 22px;
    font-weight: 700;
    line-height: 1.3;
    margin-top: 36px;
    margin-bottom: 16px;
    padding-left: 14px;
    border-left: 3px solid rgba(255,200,50,0.75);
    letter-spacing: -0.2px;
}

/* ===== H3 ===== */
.textSeo h3 {
    font-size: 18px;
    font-weight: 700;
    margin-top: 24px;
    margin-bottom: 12px;
    opacity: 0.95;
}

/* ===== Первый заголовок — без верхнего отступа ===== */
.textSeo h1:first-child,
.textSeo h2:first-child,
.textSeo h3:first-child,
.textSeo .seo-h1:first-child,
.textSeo .seo-h2:first-child {
    margin-top: 0;
}

/* ===== Мобильные стили ===== */
@media (max-width: 767px) {
    .textSeo {
        margin: 30px 0;
    }
    .textSeo .seo-h1,
    .textSeo h1 {
        font-size: 22px;
        padding-bottom: 12px;
        margin-bottom: 18px;
    }
    .textSeo .seo-h2,
    .textSeo h2 {
        font-size: 18px;
        margin-top: 28px;
        margin-bottom: 12px;
        padding-left: 11px;
    }
    .textSeo h3 {
        font-size: 16px;
        margin-top: 18px;
    }
}

/* ===== textSeo: таблицы — мобильная адаптация ===== */
.textSeo .table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    margin: 20px 0;
    border-radius: 8px;
}
.textSeo table {
    width: 100%;
    min-width: 520px;
    border-collapse: collapse;
    font-size: 14px;
    color: inherit;
}
.textSeo table th {
    background: rgba(255,255,255,0.10);
    padding: 10px 14px;
    text-align: left;
    font-weight: 700;
    border-bottom: 2px solid rgba(255,200,50,0.3);
    white-space: nowrap;
    letter-spacing: 0.2px;
}
.textSeo table td {
    padding: 9px 14px;
    border-bottom: 1px solid rgba(255,255,255,0.07);
    vertical-align: top;
    line-height: 1.45;
}
.textSeo table tr:last-child td {
    border-bottom: none;
}
.textSeo table tr:nth-child(even) td {
    background: rgba(255,255,255,0.04);
}
.textSeo table tr:hover td {
    background: rgba(255,200,50,0.04);
    transition: background 0.15s ease;
}

/* ===== textSeo: списки ===== */
.textSeo ul,
.textSeo ol {
    padding-left: 22px;
    margin: 14px 0;
    line-height: 1.65;
}
.textSeo ul li,
.textSeo ol li {
    margin-bottom: 8px;
}
.textSeo ul {
    list-style: none;
    padding-left: 0;
}
.textSeo ul li {
    padding-left: 18px;
    position: relative;
}
.textSeo ul li::before {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    top: 9px;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: rgba(255,200,50,0.7);
    flex-shrink: 0;
}
.textSeo ol {
    list-style: decimal;
}

/* ===== Мобильные стили таблиц и списков ===== */
@media (max-width: 767px) {
    .textSeo .table-wrap {
        margin: 14px 0;
    }
    .textSeo table {
        font-size: 13px;
    }
    .textSeo table th,
    .textSeo table td {
        padding: 8px 10px;
    }
    .textSeo ul li::before {
        top: 8px;
        width: 5px;
        height: 5px;
    }
}
