* {
    box-sizing: border-box;
}

body {
    font-family: Arial, sans-serif;
    margin: 0;
    padding: 0;
    background: #fffbe6;
    color: #333;
    line-height: 1.55;
}

a {
    color: #0f5f8f;
}

header {
    background: linear-gradient(135deg, #6fc7ec, #2f9ed2);
    color: #fff;
    text-align: center;
    padding: 18px 10px 26px;
}

header p {
    max-width: 780px;
    margin: 10px auto 0;
}

.top-nav {
    max-width: 1080px;
    margin: 0 auto 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    flex-wrap: wrap;
}

.menu {
    list-style: none;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 8px 14px;
    padding: 0;
    margin: 0;
}

.menu li a {
    color: #fff;
    text-decoration: none;
    font-weight: 700;
    font-size: 14px;
}

.menu li a:hover {
    text-decoration: underline;
}

.lang-switch {
    display: flex;
    gap: 6px;
    align-items: center;
    justify-content: center;
}

.lang-switch a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 38px;
    height: 30px;
    padding: 0 10px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 800;
    text-decoration: none;
    color: #fff;
    background: rgba(255, 255, 255, .22);
    border: 1px solid rgba(255, 255, 255, .55);
}

.lang-switch a.active {
    background: #ffd700;
    color: #1f2937;
    border-color: #ffd700;
}

h1 {
    font-size: 24px;
    margin: 8px 0 0;
}

h2 {
    font-size: 20px;
    margin-top: 0;
}

h3 {
    font-size: 16px;
    margin-bottom: 6px;
}

.container {
    width: min(1000px, calc(100% - 24px));
    margin: 0 auto;
}

.content-card {
    background: #fff;
    border: 1px solid rgba(0,0,0,.08);
    border-radius: 16px;
    padding: 18px;
    margin: 18px auto;
    box-shadow: 0 8px 22px rgba(0,0,0,.06);
}

.table-wrapper {
    overflow-x: auto;
}

table {
    width: 100%;
    margin: 10px auto 15px;
    border-collapse: collapse;
    background: #fff;
    font-size: 14px;
}

table th,
table td {
    border: 1px solid #ddd;
    padding: 9px;
    text-align: center;
}

table th {
    background: #eef8fd;
}

.check-address {
    text-align: center;
}

.check-address form {
    display: grid;
    gap: 12px;
    justify-items: center;
}

.check-address label {
    display: grid;
    gap: 6px;
    width: min(340px, 100%);
    text-align: left;
    font-weight: 700;
}

.check-address input,
.check-address select {
    width: 100%;
    padding: 10px;
    border: 1px solid #cbd5e1;
    border-radius: 8px;
    font-size: 15px;
}

button,
.btn,
.page-nav a {
    background: #ffd700;
    color: #1f2937;
    border: none;
    padding: 11px 16px;
    border-radius: 8px;
    font-weight: 800;
    cursor: pointer;
    text-decoration: none;
    display: inline-block;
}

button:hover,
.btn:hover,
.page-nav a:hover {
    background: #ffc107;
}

.telegram-button {
    text-align: center;
    margin: 24px 0 4px;
}

.telegram-button a {
    display: inline-block;
    background: #ff6f00;
    color: #fff;
    padding: 13px 22px;
    border-radius: 10px;
    text-decoration: none;
    font-weight: 800;
    font-size: 15px;
}

.telegram-button a:hover {
    background: #eb6500;
}

.seo-text {
    max-width: 760px;
    margin: 16px auto;
    text-align: center;
    padding: 0 6px;
    font-size: 15px;
}

.page-nav {
    text-align: center;
    margin: 20px 0;
}

.page-nav a,
.page-nav button {
    margin: 5px;
}

.map-photo {
    text-align: center;
}

.map-photo img {
    width: 100%;
    max-width: 650px;
    border-radius: 14px;
    border: 1px solid #ddd;
    display: block;
    margin: 0 auto;
}

.city-buttons,
.district-buttons {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    margin: 20px 0 8px;
}

.district-buttons .btn {
    background: #2f9ed2;
    color: #fff;
}

.district-buttons .btn:hover {
    background: #1c86b8;
}

.faq-item {
    max-width: 780px;
    margin: 14px auto;
    padding: 14px;
    border-radius: 12px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
}

.faq-item p {
    margin: 0;
}

.clean-list {
    max-width: 760px;
    margin: 0 auto;
    padding-left: 22px;
}

footer {
    text-align: center;
    padding: 22px 12px;
    max-width: 960px;
    margin: 0 auto;
    font-size: 14px;
}

@media (max-width: 600px) {
    .top-nav {
        align-items: stretch;
        flex-direction: column;
    }

    .menu {
        flex-direction: column;
        gap: 7px;
    }

    h1 {
        font-size: 20px;
    }

    h2 {
        font-size: 18px;
    }

    table {
        font-size: 12px;
    }

    .content-card {
        padding: 14px;
        border-radius: 14px;
    }

    .telegram-button a {
        width: 100%;
    }
}

@media (min-width: 900px) {
    h1 {
        font-size: 30px;
    }

    h2 {
        font-size: 23px;
    }

    table {
        font-size: 16px;
    }

    .telegram-button a {
        font-size: 17px;
        padding: 15px 30px;
    }
}

/* ===== Графік відключень світла з JSON ===== */

.outage-card h2 {
    text-align: center;
    margin-bottom: 8px;
}

.schedule-meta {
    margin: 0 auto 12px;
    text-align: center;
    color: #64748b;
    font-size: 14px;
}

.outage-notice {
    max-width: 820px;
    margin: 12px auto 14px;
    padding: 12px 14px;
    border-radius: 12px;
    background: #eef8fd;
    border: 1px solid #bae6fd;
    color: #0f5f8f;
    text-align: center;
    font-weight: 700;
}

.outage-table {
    border-radius: 12px;
    overflow: hidden;
}

.outage-table th {
    background: #dff4ff;
    color: #0f3754;
}

.outage-table td {
    vertical-align: middle;
}

.outage-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 28px;
    padding: 5px 10px;
    border-radius: 999px;
    background: #fff7cc;
    color: #6b4e00;
    font-weight: 800;
    line-height: 1.25;
}

@media (max-width: 600px) {
    .schedule-meta {
        font-size: 13px;
    }

    .outage-notice {
        font-size: 14px;
        padding: 10px;
    }

    .outage-status {
        padding: 5px 8px;
        font-size: 12px;
    }
}


/* ===== Зручний вибір групи відключень ===== */

.group-schedule-controls {
    max-width: 820px;
    margin: 14px auto 16px;
    padding: 14px;
    border-radius: 14px;
    background: #f8fbff;
    border: 1px solid #dbeafe;
}

.group-select-label {
    display: grid;
    gap: 8px;
    font-weight: 800;
    color: #0f3754;
}

.group-select-label select {
    width: 100%;
    min-height: 44px;
    padding: 10px 12px;
    border: 1px solid #b6d9ef;
    border-radius: 10px;
    background: #fff;
    color: #1f2937;
    font-size: 16px;
    font-weight: 700;
}

.group-select-help {
    margin: 10px 0 0;
    color: #475569;
    font-size: 14px;
    line-height: 1.45;
}

.outage-status.status-planned {
    background: #fff7cc;
    color: #6b4e00;
}

.outage-status.status-emergency {
    background: #fee2e2;
    color: #991b1b;
}

.outage-status.status-clear {
    background: #dcfce7;
    color: #166534;
}

.outage-status.status-pending {
    background: #e0f2fe;
    color: #075985;
}

.outage-status.status-maybe {
    background: #fef3c7;
    color: #92400e;
}

.schedule-secondary-times {
    display: block;
    margin-top: 8px;
    padding-top: 8px;
    border-top: 1px dashed rgba(15, 23, 42, .18);
    color: #64748b;
    font-size: .92em;
    line-height: 1.45;
    font-weight: 700;
}

.schedule-secondary-times.is-primary {
    margin-top: 0;
    padding-top: 0;
    border-top: 0;
    color: #92400e;
}

.map-photo.is-missing {
    min-height: 160px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px dashed #9ec9e2;
    border-radius: 14px;
    background: #eef8fd;
    color: #0f5f8f;
    font-weight: 800;
    padding: 18px;
    text-align: center;
}

.map-photo.is-missing::before {
    content: attr(data-fallback);
}

.seo-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    margin-top: 16px;
}

.seo-mini-card {
    border-radius: 14px;
    border: 1px solid #e2e8f0;
    background: #f8fafc;
    padding: 14px;
}

.seo-mini-card h3 {
    margin-top: 0;
    color: #0f3754;
}

@media (max-width: 600px) {
    .group-schedule-controls {
        padding: 12px;
    }

    .group-select-label select {
        font-size: 15px;
    }
}

/* ===== Патч 1: SEO-страницы городов и групп ===== */
.menu li a.is-active {
    color: #fff7cc;
    text-decoration: underline;
    text-underline-offset: 4px;
}

.breadcrumbs {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    align-items: center;
    margin: 16px auto 0;
    color: #64748b;
    font-size: 14px;
}

.breadcrumbs a {
    color: #0f5f8f;
    font-weight: 700;
    text-decoration: none;
}

.breadcrumbs a:hover {
    text-decoration: underline;
}

.city-hero-card {
    text-align: center;
}

.group-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(128px, 1fr));
    gap: 10px;
    margin: 18px 0 8px;
}

.group-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 50px;
    padding: 12px;
    border-radius: 14px;
    border: 1px solid #b6d9ef;
    background: linear-gradient(135deg, #f8fcff, #e8f7ff);
    color: #0f3754;
    font-weight: 900;
    text-decoration: none;
    box-shadow: 0 6px 14px rgba(15, 95, 143, .08);
}

.group-btn:hover,
.group-btn.is-current {
    background: linear-gradient(135deg, #2f9ed2, #0f5f8f);
    color: #fff;
    border-color: #0f5f8f;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    margin-top: 18px;
}

.btn-secondary {
    background: #e0f2fe;
    color: #075985;
}

.btn-secondary:hover {
    background: #bae6fd;
}

.seo-schedule-table a {
    color: #0f5f8f;
    text-decoration: none;
}

.seo-schedule-table a:hover {
    text-decoration: underline;
}

.single-group-card {
    max-width: 760px;
    margin: 16px auto;
    padding: 18px;
    border-radius: 18px;
    background: linear-gradient(135deg, #f8fcff, #ffffff);
    border: 1px solid #dbeafe;
    box-shadow: 0 10px 24px rgba(15, 95, 143, .08);
    text-align: center;
}

.single-group-main,
.single-group-time {
    display: grid;
    gap: 6px;
    margin-bottom: 14px;
}

.single-group-main span,
.single-group-time span {
    color: #64748b;
    font-size: 14px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.single-group-main strong {
    font-size: clamp(34px, 8vw, 62px);
    color: #0f3754;
    line-height: 1;
}

.single-group-time strong {
    font-size: clamp(22px, 5vw, 34px);
    color: #1f2937;
    line-height: 1.25;
}

.single-group-status {
    margin: 12px 0;
}

.seo-city-block p {
    max-width: 820px;
    margin-left: auto;
    margin-right: auto;
}

@media (max-width: 600px) {
    .group-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .group-btn {
        min-height: 46px;
        padding: 10px 8px;
        border-radius: 12px;
    }

    .breadcrumbs {
        font-size: 13px;
    }

    .single-group-card {
        padding: 14px;
    }
}


/* ===== Патч 2: страницы воды и водные карточки ===== */
.water-entry-card {
    border-color: #b6e6ff;
    background: linear-gradient(135deg, #f8fcff, #eef9ff);
}

.btn-water {
    background: linear-gradient(135deg, #2f9ed2, #0f5f8f);
    color: #fff;
}

.btn-water:hover {
    background: linear-gradient(135deg, #0f5f8f, #083d62);
}

.water-hero-card {
    background: linear-gradient(135deg, #ffffff, #f0faff);
}

.water-empty {
    padding: 18px;
    border-radius: 16px;
    background: #ecfdf5;
    border: 1px solid #bbf7d0;
    color: #14532d;
    text-align: center;
}

.water-empty p {
    margin-bottom: 0;
}

.water-list {
    display: grid;
    gap: 14px;
    margin-top: 16px;
}

.water-card {
    padding: 18px;
    border-radius: 18px;
    background: #fff;
    border: 1px solid #dbeafe;
    box-shadow: 0 8px 20px rgba(15, 95, 143, .08);
}

.water-card-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 8px;
}

.water-card h2 {
    margin: 0;
    color: #0f3754;
}

.water-meta {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 10px;
    margin-top: 14px;
    color: #475569;
}

.water-meta span {
    padding: 10px 12px;
    border-radius: 12px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
}

.water-updates {
    display: grid;
    gap: 10px;
    padding-left: 0;
    list-style: none;
}

.water-updates li {
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
    padding: 12px;
    border-radius: 14px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
}

.water-updates small {
    color: #64748b;
}

@media (max-width: 600px) {
    .water-card {
        padding: 14px;
    }

    .water-meta {
        grid-template-columns: 1fr;
    }
}

/* ===== Патч 3: финальное SEO, FAQ, реклама и мобильная доводка ===== */
html {
    scroll-behavior: smooth;
    overflow-x: hidden;
}

body {
    overflow-x: hidden;
}

img,
video,
iframe {
    max-width: 100%;
}

.info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 14px;
    margin-top: 14px;
}

.info-grid > div {
    padding: 16px;
    border-radius: 16px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
}

.info-grid strong {
    display: inline-block;
    margin-bottom: 6px;
    color: #0f3754;
    font-size: 16px;
}

.info-grid p {
    margin: 0;
    color: #475569;
}

.faq-card .faq-list {
    display: grid;
    gap: 10px;
}

.faq-card details {
    padding: 14px 16px;
    border-radius: 14px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
}

.faq-card summary {
    cursor: pointer;
    font-weight: 900;
    color: #0f3754;
}

.faq-card details[open] {
    background: #eef8fd;
    border-color: #bae6fd;
}

.faq-card details p {
    margin: 10px 0 0;
    color: #334155;
}

.ad-strip {
    width: min(1000px, calc(100% - 24px));
    margin: 18px auto;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.ad-box {
    min-height: 92px;
    padding: 18px;
    border-radius: 18px;
    border: 1px dashed #8ecae6;
    background: linear-gradient(135deg, #f8fcff, #e8f7ff);
    color: #0f3754;
    display: grid;
    align-content: center;
    text-align: center;
    box-shadow: 0 8px 22px rgba(15, 95, 143, .06);
}

.ad-box span {
    font-weight: 900;
    font-size: 16px;
}

.ad-box small {
    margin-top: 4px;
    color: #64748b;
}

.ad-box-secondary {
    background: linear-gradient(135deg, #fffdf0, #fff7cc);
    border-color: #facc15;
}

.seo-expanded-block ul {
    max-width: 820px;
    margin: 12px auto 0;
    padding-left: 22px;
}

.seo-expanded-block li {
    margin: 6px 0;
}

.menu a,
.btn,
.group-btn,
.lang-switch a,
.telegram-button a {
    -webkit-tap-highlight-color: transparent;
}

@media (max-width: 700px) {
    header {
        padding: 14px 10px 22px;
    }

    .container,
    .ad-strip {
        width: min(100% - 18px, 1000px);
    }

    .ad-strip {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .ad-box {
        min-height: 74px;
        padding: 14px;
    }

    .info-grid {
        grid-template-columns: 1fr;
    }

    .faq-card details {
        padding: 13px;
    }

    .table-wrapper {
        margin-left: -4px;
        margin-right: -4px;
        padding-bottom: 4px;
    }

    table th,
    table td {
        padding: 8px 6px;
        word-break: normal;
    }
}

@media (max-width: 380px) {
    .group-grid {
        grid-template-columns: 1fr;
    }

    .menu li a {
        font-size: 13px;
    }

    .lang-switch a {
        min-width: 34px;
        height: 28px;
        font-size: 12px;
    }
}

/* ===== Cleanup patch: managed ads without public placeholders ===== */
.managed-ad-slot:empty {
    display: none !important;
}

.ad-custom-html {
    grid-column: 1 / -1;
    width: 100%;
    min-height: 90px;
    display: grid;
    place-items: center;
}

.ad-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    margin: 10px auto 0;
    padding: 9px 14px;
    border-radius: 999px;
    background: #0f9bd7;
    color: #fff;
    font-weight: 800;
    text-decoration: none;
}

.ad-link:hover {
    background: #0878ad;
}

/* ===== Пакет 2: доверие, актуальность, источники, Telegram CTA ===== */
.freshness-notice {
    display: grid;
    gap: 5px;
    margin: 14px 0;
    padding: 13px 15px;
    border-radius: 14px;
    border: 1px solid #dbeafe;
    background: #eff6ff;
    color: #1e3a8a;
}

.freshness-notice strong {
    font-size: 15px;
}

.freshness-notice span {
    color: inherit;
    opacity: .9;
}

.freshness-notice.is-fresh {
    border-color: #bbf7d0;
    background: #f0fdf4;
    color: #166534;
}

.freshness-notice.is-warning {
    border-color: #fde68a;
    background: #fffbeb;
    color: #92400e;
}

.freshness-notice.is-danger {
    border-color: #fecaca;
    background: #fef2f2;
    color: #991b1b;
}

.freshness-notice.is-info {
    border-color: #bae6fd;
    background: #f0f9ff;
    color: #075985;
}

.trust-card {
    background: linear-gradient(135deg, #ffffff, #f8fcff);
    border-color: #cfe9f6;
}

.trust-card-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 10px;
}

.eyebrow {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    margin-bottom: 5px;
    padding: 4px 9px;
    border-radius: 999px;
    background: #e0f2fe;
    color: #075985;
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .03em;
}

.trust-badge {
    display: inline-flex;
    align-items: center;
    padding: 7px 10px;
    border-radius: 999px;
    background: #fff7ed;
    color: #9a3412;
    border: 1px solid #fed7aa;
    font-weight: 900;
    font-size: 13px;
}

.source-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
    margin-top: 14px;
}

.source-card {
    display: grid;
    gap: 5px;
    min-height: 126px;
    padding: 15px;
    border-radius: 16px;
    border: 1px solid #dbeafe;
    background: #ffffff;
    text-decoration: none;
    color: #0f3754;
    box-shadow: 0 6px 16px rgba(15, 95, 143, .05);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.source-card:hover {
    transform: translateY(-2px);
    border-color: #7dd3fc;
    box-shadow: 0 10px 24px rgba(15, 95, 143, .1);
}

.source-card span {
    width: fit-content;
    padding: 4px 8px;
    border-radius: 999px;
    background: #eef8fd;
    color: #075985;
    font-size: 12px;
    font-weight: 900;
}

.source-card strong {
    font-size: 16px;
}

.source-card small {
    color: #475569;
    line-height: 1.45;
}

.telegram-cta-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    background: linear-gradient(135deg, #fff7ed, #eff6ff);
    border-color: #fed7aa;
}

.telegram-cta-card h2 {
    margin-bottom: 6px;
}

.telegram-cta-card p {
    margin: 0;
    max-width: 660px;
    color: #475569;
}

.telegram-cta-btn {
    white-space: nowrap;
    background: #ff6f00;
    color: #fff;
}

.telegram-cta-btn:hover {
    background: #eb6500;
}

.gas-entry-card,
.gas-hero-card {
    background: linear-gradient(135deg, #ffffff, #fff7ed);
    border-color: #fed7aa;
}

.btn-gas {
    background: #f97316;
    color: #fff;
}

.btn-gas:hover {
    background: #ea580c;
}

.gas-safety-box {
    margin: 16px 0;
    padding: 16px;
    border-radius: 16px;
    background: #fff7ed;
    border: 1px solid #fed7aa;
    color: #7c2d12;
}

.gas-safety-box h3 {
    margin-top: 0;
    color: #9a3412;
}

.footer-disclaimer {
    max-width: 840px;
    margin: 0 auto 8px;
    color: #64748b;
    font-size: 13px;
}

@media (max-width: 700px) {
    .telegram-cta-card {
        display: grid;
        text-align: left;
    }

    .telegram-cta-btn {
        width: 100%;
        text-align: center;
    }

    .source-list {
        grid-template-columns: 1fr;
    }
}

/* ===== Пакет 3: глубокие безопасные разделы без поиска по улицам ===== */
.deep-hero-card {
    background: linear-gradient(135deg, #ffffff, #f8fcff);
    border-color: #cfe9f6;
}

.deep-status-grid,
.deep-link-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 12px;
    margin-top: 14px;
}

.deep-status-card,
.deep-link-card {
    display: grid;
    gap: 6px;
    padding: 16px;
    border-radius: 16px;
    border: 1px solid #dbeafe;
    background: #f8fafc;
    color: #0f3754;
    text-decoration: none;
    box-shadow: 0 6px 16px rgba(15, 95, 143, .05);
}

.deep-status-card strong {
    font-size: clamp(26px, 5vw, 42px);
    line-height: 1;
    color: #0f5f8f;
}

.deep-status-card span,
.deep-link-card small {
    color: #475569;
    line-height: 1.4;
}

.deep-link-card span {
    font-weight: 900;
    font-size: 16px;
}

.deep-link-card:hover,
.deep-link-card.is-current {
    background: linear-gradient(135deg, #2f9ed2, #0f5f8f);
    color: #fff;
    border-color: #0f5f8f;
}

.deep-link-card:hover small,
.deep-link-card.is-current small {
    color: rgba(255,255,255,.88);
}

.sources-page-card .trust-card-head {
    margin-bottom: 14px;
}

.sources-note-list {
    display: grid;
    gap: 10px;
    padding-left: 20px;
}

.sources-note-list li {
    padding-left: 4px;
}

@media (max-width: 600px) {
    .deep-status-grid,
    .deep-link-grid {
        grid-template-columns: 1fr;
    }

    .deep-status-card,
    .deep-link-card {
        padding: 14px;
    }
}

/* ===== Пакет 4: Telegram-воронка и deep-link CTA ===== */
.telegram-funnel-card {
    align-items: stretch;
    background: linear-gradient(135deg, #fff7ed, #eef8ff 55%, #ffffff);
    border: 1px solid #fed7aa;
    position: relative;
    overflow: hidden;
}

.telegram-funnel-card::after {
    content: "";
    position: absolute;
    right: -70px;
    top: -70px;
    width: 180px;
    height: 180px;
    border-radius: 999px;
    background: rgba(47, 158, 210, .12);
    pointer-events: none;
}

.telegram-cta-main {
    position: relative;
    z-index: 1;
    flex: 1;
}

.telegram-funnel-steps {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(165px, 1fr));
    gap: 10px;
    margin-top: 14px;
}

.telegram-funnel-step {
    display: grid;
    gap: 4px;
    padding: 12px;
    border-radius: 14px;
    background: rgba(255, 255, 255, .78);
    border: 1px solid rgba(125, 211, 252, .45);
}

.telegram-funnel-step strong {
    color: #0f3754;
    font-size: 14px;
}

.telegram-funnel-step span {
    color: #475569;
    font-size: 13px;
    line-height: 1.35;
}

.telegram-cta-card .telegram-cta-btn {
    position: relative;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 185px;
    align-self: center;
    box-shadow: 0 10px 26px rgba(255, 111, 0, .22);
}

.telegram-cta-card .telegram-cta-btn::before {
    content: "↗";
    margin-right: 7px;
    font-weight: 900;
}

@media (max-width: 700px) {
    .telegram-funnel-steps {
        grid-template-columns: 1fr;
    }

    .telegram-cta-card .telegram-cta-btn {
        width: 100%;
        min-width: 0;
    }
}


/* ===== Пакет 5: монетизация без вреда SEO ===== */
.ad-disclosure {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    margin: 0 auto 8px;
    padding: 4px 9px;
    border-radius: 999px;
    background: rgba(15, 95, 143, .1);
    color: #0f5f8f;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .02em;
    text-transform: uppercase;
}

.product-ad-section {
    border-color: #fde68a;
    background: linear-gradient(135deg, #fffefa, #fff8db);
}

.product-ad-head {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    align-items: flex-start;
    margin-bottom: 14px;
}

.product-ad-head h2 {
    margin-bottom: 6px;
    color: #5b4200;
}

.product-ad-head p {
    margin: 0;
    max-width: 780px;
    color: #6b5b25;
}

.product-ad-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 14px;
}

.product-ad-card {
    position: relative;
    display: grid;
    align-content: start;
    gap: 8px;
    min-height: 230px;
    padding: 16px;
    border-radius: 18px;
    background: #fff;
    border: 1px solid #f3d36b;
    box-shadow: 0 10px 22px rgba(91, 66, 0, .08);
}

.product-ad-icon {
    width: 46px;
    height: 46px;
    display: grid;
    place-items: center;
    border-radius: 16px;
    background: #fff7cc;
    font-size: 24px;
}

.product-ad-tag {
    width: fit-content;
    padding: 4px 9px;
    border-radius: 999px;
    background: #e0f2fe;
    color: #075985;
    font-size: 12px;
    font-weight: 900;
}

.product-ad-card h3 {
    margin: 0;
    color: #1f2937;
    font-size: 17px;
}

.product-ad-card p {
    margin: 0;
    color: #475569;
    font-size: 14px;
}

.product-ad-price {
    margin-top: auto;
    color: #166534;
    font-size: 15px;
}

.product-ad-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    margin-top: 4px;
    padding: 10px 12px;
    border-radius: 12px;
    background: #ffd700;
    color: #1f2937;
    text-decoration: none;
    font-weight: 900;
}

.product-ad-link:hover {
    background: #ffc107;
}

@media (max-width: 640px) {
    .product-ad-head {
        display: block;
    }

    .product-ad-grid {
        grid-template-columns: 1fr;
    }

    .product-ad-card {
        min-height: 0;
    }
}


/* ===== DTEK address monitoring + mobile burger patch ===== */
.mobile-menu-toggle{display:none;align-items:center;justify-content:center;gap:8px;background:rgba(255,255,255,.18);color:#fff;border:1px solid rgba(255,255,255,.55);border-radius:999px;padding:9px 14px;font-weight:900;line-height:1}
.mobile-menu-toggle:hover{background:rgba(255,255,255,.28)}
.source-note{font-size:14px;color:#64748b;margin:10px 0 0}.eyebrow{display:inline-flex;align-items:center;border-radius:999px;background:#eef8fd;color:#0f5f8f;font-size:12px;font-weight:900;letter-spacing:.04em;text-transform:uppercase;padding:5px 9px;margin-bottom:8px}.dtek-search-form{display:grid;grid-template-columns:1fr 160px auto;gap:12px;align-items:end}.dtek-search-form label,.dtek-add-form{display:grid;gap:6px;font-weight:800}.dtek-search-form input{width:100%;padding:11px;border:1px solid #cbd5e1;border-radius:10px;font-size:15px}.dtek-result-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}.dtek-address-card,.dtek-alert-item{border:1px solid #e5e7eb;border-radius:14px;background:#f8fafc;padding:14px}.dtek-area-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:14px}.dtek-area-box{border:1px solid #e5e7eb;border-radius:14px;background:#f8fafc;padding:14px}.dtek-area-box ul{list-style:none;margin:0;padding:0;display:grid;gap:7px}.dtek-area-box li{display:flex;justify-content:space-between;gap:10px;border-bottom:1px dashed #dbe6ef;padding-bottom:6px}.dtek-area-box li:last-child{border-bottom:0}.dtek-alert-card{border-color:#facc15;background:linear-gradient(180deg,#fffbea,#fff)}.dtek-alert-item p{margin:8px 0}.dtek-add-form{margin-top:12px;max-width:360px}.electricity-search-card{background:linear-gradient(180deg,#fff,#f7fbff)}
@media(max-width:700px){.top-nav{position:relative;justify-content:space-between;align-items:center;gap:8px;flex-direction:row;flex-wrap:wrap}.mobile-menu-toggle{display:inline-flex}.top-nav .lang-switch{margin-left:auto}.top-nav .menu{display:none;order:3;width:100%;flex-direction:column;align-items:stretch;gap:7px;background:rgba(15,95,143,.98);border:1px solid rgba(255,255,255,.25);border-radius:16px;padding:10px;margin-top:8px}.top-nav.is-menu-open .menu{display:flex}.menu li a{display:block;padding:10px 12px;border-radius:10px;background:rgba(255,255,255,.08)}.dtek-search-form{grid-template-columns:1fr}.dtek-search-form button{width:100%}.dtek-area-grid,.dtek-result-grid{grid-template-columns:1fr}}

/* DTEK address worker V1 */
.dtek-group-chip{display:inline-flex;align-items:center;gap:6px;margin:8px 0 10px;padding:8px 12px;border-radius:999px;background:#fff7db;color:#6d4b00;border:1px solid rgba(212,175,55,.45);font-weight:800}
.dtek-official-box{display:grid;gap:5px;margin:10px 0;padding:10px 12px;border-radius:14px;background:rgba(0,31,63,.045);border:1px solid rgba(0,31,63,.09);font-size:.95rem;color:#24364a}
.dtek-monitor-stats{display:flex;flex-wrap:wrap;gap:10px;margin:10px 0 18px}.dtek-monitor-stats span{display:inline-flex;gap:6px;align-items:center;border-radius:999px;background:#f7fafc;border:1px solid #e4ebf2;padding:8px 12px}.outage-status.status-active{background:#dcfce7;color:#166534}.outage-status.status-warning{background:#fef3c7;color:#92400e}.outage-status.status-restored{background:#e0f2fe;color:#075985}.save-address-btn{border:0;border-radius:999px;padding:9px 13px;background:#001f3f;color:#fff;font-weight:800;cursor:pointer;margin-top:8px}.save-address-btn:hover{filter:brightness(1.08)}
@media(max-width:640px){.dtek-monitor-stats{display:grid}.dtek-group-chip{width:100%;justify-content:center}.dtek-official-box{font-size:.9rem}}

/* DTEK VPS official import status */
.dtek-import-status{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:12px 0 0;padding:11px 12px;border-radius:14px;background:#ecfdf5;border:1px solid #bbf7d0;color:#14532d;font-size:.94rem}.dtek-import-status strong{margin-right:4px}.dtek-import-status span{display:inline-flex;align-items:center;border-radius:999px;background:rgba(255,255,255,.72);border:1px solid rgba(20,83,45,.12);padding:5px 9px;font-weight:700}.dtek-import-status.is-warning{background:#fff7ed;border-color:#fed7aa;color:#7c2d12}.dtek-group-link{display:inline-flex;align-items:center;justify-content:center;margin:0 0 10px;padding:8px 12px;border-radius:999px;background:#001f3f;color:#fff;text-decoration:none;font-weight:800;font-size:.92rem}.dtek-group-link:hover{filter:brightness(1.08);color:#fff}.dtek-address-card .dtek-group-chip + .dtek-group-link{margin-top:0}@media(max-width:640px){.dtek-import-status{display:grid}.dtek-import-status span{justify-content:center}.dtek-group-link{width:100%}}

/* ===== DTEK user layer: autocomplete + saved address ===== */
.section-head-row{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap}.clean-status-pill{display:inline-flex;align-items:center;gap:6px;width:max-content;padding:7px 11px;border-radius:999px;background:#eef2ff;color:#3730a3;border:1px solid #c7d2fe;font-weight:900;font-size:.9rem}.clean-status-pill.is-ok{background:#ecfdf5;color:#166534;border-color:#bbf7d0}.clean-source-note{max-width:920px}.dtek-field{position:relative}.dtek-suggest-box{display:none;position:absolute;z-index:30;left:0;right:0;top:calc(100% + 6px);max-height:310px;overflow:auto;background:#fff;border:1px solid #cbd5e1;border-radius:14px;box-shadow:0 18px 40px rgba(15,23,42,.18);padding:7px}.dtek-suggest-box.is-open{display:grid;gap:5px}.dtek-suggest-item{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;border:0;background:#f8fafc;border-radius:11px;padding:10px 11px;text-align:left;cursor:pointer;color:#0f172a}.dtek-suggest-item:hover,.dtek-suggest-item:focus{background:#e0f2fe;outline:2px solid rgba(14,165,233,.15)}.dtek-suggest-item span{font-weight:900}.dtek-suggest-item small{white-space:nowrap;color:#64748b;font-weight:800}.dtek-suggest-empty{padding:11px;border-radius:11px;background:#fff7ed;color:#9a3412;font-weight:800}.clean-dtek-alerts{border-color:#fde68a;background:linear-gradient(180deg,#fffbeb,#fff)}.clean-alert-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}.dtek-alert-item.is-planned{border-color:#facc15;background:#fffbea}.dtek-alert-item.is-emergency{border-color:#fecaca;background:#fff1f2}.dtek-alert-item.is-info{border-color:#bfdbfe;background:#eff6ff}.alert-type-pill{display:inline-flex;width:max-content;margin-bottom:8px;padding:5px 9px;border-radius:999px;background:#fff;color:#334155;border:1px solid rgba(15,23,42,.08);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.03em}.clean-address-card{background:linear-gradient(180deg,#fff,#f8fafc)}.my-group-big{display:flex;align-items:center;justify-content:center;gap:8px;margin:12px 0;padding:16px;border-radius:18px;background:linear-gradient(135deg,#001f3f,#0f5f8f);color:#fff;font-size:1.25rem;font-weight:900}.my-group-big strong{font-size:1.45rem;color:#ffd700}.small-actions{gap:10px;flex-wrap:wrap}.small-actions .btn,.small-actions button.btn,.small-actions .save-address-btn{margin:0}.save-address-btn.is-saved{background:#15803d}.dtek-user-help-card .info-grid div{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;padding:14px}.my-dtek-address-card{border-color:#bae6fd;background:linear-gradient(180deg,#f0f9ff,#fff)}.saved-status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px;margin:12px 0}.saved-status-grid div{display:grid;gap:5px;padding:12px;border-radius:16px;background:#fff;border:1px solid #dbeafe}.saved-status-grid span{color:#64748b;font-weight:800;font-size:.9rem}.saved-status-grid strong{font-size:1.05rem;color:#0f172a}.my-dtek-address-card .btn-secondary{border:1px solid #cbd5e1;background:#fff;color:#0f172a}.clean-empty-box{border:1px dashed #fbbf24;background:#fffbeb;border-radius:16px;padding:16px}
@media(max-width:700px){.section-head-row{display:grid}.dtek-suggest-box{position:static;margin-top:6px;max-height:240px}.dtek-suggest-item{display:grid}.dtek-suggest-item small{white-space:normal}.my-group-big{font-size:1.08rem}.my-group-big strong{font-size:1.25rem}.small-actions .btn,.small-actions button.btn,.small-actions .save-address-btn{width:100%;justify-content:center}}

/* ===== DTEK auto update layer: event distribution ===== */
.dtek-event-box{border-width:1px;border-style:solid}
.dtek-event-box strong{font-size:1rem;color:#0f172a}
.dtek-event-box.is-planned{background:#fffbeb;border-color:#facc15;color:#78350f}
.dtek-event-box.is-emergency{background:#fff1f2;border-color:#fecaca;color:#7f1d1d}
.dtek-event-box.is-other{background:#eff6ff;border-color:#bfdbfe;color:#1e3a8a}
.dtek-saved-event{display:grid;gap:4px;margin:12px 0;padding:12px 14px;border-radius:16px;border:1px solid #bfdbfe;background:#eff6ff;color:#1e3a8a}
.dtek-saved-event span{font-weight:900;font-size:.86rem;text-transform:uppercase;letter-spacing:.03em;opacity:.9}
.dtek-saved-event strong{font-size:1.02rem}
.dtek-saved-event em{font-style:normal;font-weight:800;color:inherit}
.dtek-saved-event.is-planned{background:#fffbeb;border-color:#facc15;color:#78350f}
.dtek-saved-event.is-emergency{background:#fff1f2;border-color:#fecaca;color:#7f1d1d}
.dtek-saved-event.is-other{background:#eff6ff;border-color:#bfdbfe;color:#1e3a8a}

/* DTEK status-driven patch */
.dtek-real-status-box,
.dtek-saved-event {
    border: 1px solid rgba(15, 95, 143, .18);
    border-radius: 16px;
    padding: 12px 14px;
    margin: 12px 0;
    background: #f7fbff;
    display: grid;
    gap: 5px;
}
.dtek-real-status-box span,
.dtek-saved-event span,
.single-group-possible span {
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: #527086;
}
.dtek-real-status-box strong,
.dtek-saved-event strong {
    font-size: 16px;
    color: #11203e;
}
.dtek-real-status-box p,
.dtek-saved-event p {
    margin: 0;
}
.dtek-real-status-box small,
.dtek-saved-event em {
    color: #64748b;
    font-style: normal;
}
.dtek-real-status-box.status-clear,
.dtek-saved-event.is-no_active {
    background: #f0fff4;
    border-color: rgba(46, 125, 50, .18);
}
.dtek-real-status-box.status-emergency,
.dtek-saved-event.is-emergency {
    background: #fff5f5;
    border-color: rgba(211, 47, 47, .22);
}
.dtek-real-status-box.status-planned,
.dtek-saved-event.is-planned,
.dtek-saved-event.is-stabilization {
    background: #fff9e8;
    border-color: rgba(184, 119, 0, .22);
}
.single-group-card.is-reference-schedule {
    border-color: rgba(212, 175, 55, .35);
}
.single-group-possible {
    display: grid;
    gap: 6px;
    padding: 12px;
    border-radius: 14px;
    background: rgba(255, 229, 0, .12);
}

/* ===== Final DTEK display priority fix ===== */
.saved-status-grid.is-factual-only {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.dtek-reference-details,
.reference-gpv-details {
    margin: 14px 0;
    border: 1px dashed #cbd5e1;
    border-radius: 18px;
    background: #f8fafc;
    overflow: hidden;
}

.dtek-reference-details summary,
.reference-gpv-details summary {
    cursor: pointer;
    padding: 13px 16px;
    font-weight: 900;
    color: #0f172a;
    background: linear-gradient(180deg, #ffffff, #f1f5f9);
    list-style-position: inside;
}

.dtek-reference-details[open] summary,
.reference-gpv-details[open] summary {
    border-bottom: 1px solid #e2e8f0;
}

.dtek-reference-body,
.reference-gpv-body {
    padding: 14px 16px 16px;
    display: grid;
    gap: 12px;
}

.dtek-reference-warning,
.reference-gpv-body > p:first-child {
    margin: 0;
    padding: 11px 13px;
    border-radius: 14px;
    background: #fff7ed;
    border: 1px solid #fed7aa;
    color: #9a3412;
    font-weight: 800;
}

.dtek-reference-grid {
    display: grid;
    gap: 10px;
}

.dtek-reference-row,
.reference-gpv-body .single-group-time,
.reference-gpv-body .single-group-possible {
    display: grid;
    gap: 6px;
    padding: 12px;
    border-radius: 14px;
    background: #fff;
    border: 1px solid #e2e8f0;
}

.dtek-reference-row span,
.reference-gpv-body .single-group-time span,
.reference-gpv-body .single-group-possible span {
    color: #64748b;
    font-size: .88rem;
    font-weight: 900;
}

.dtek-reference-row strong,
.reference-gpv-body .single-group-time strong,
.reference-gpv-body .single-group-possible strong {
    color: #0f172a;
    line-height: 1.55;
}

.dtek-reference-row.is-muted,
.reference-gpv-body .single-group-possible {
    background: #f8fafc;
}

.dtek-reference-updated {
    margin: 0;
    color: #64748b;
    font-weight: 800;
    font-size: .92rem;
}

.single-group-card.is-fact-first .single-group-status.is-primary-status {
    margin: 12px 0;
}

.single-group-card.is-fact-first .outage-status.status-clear {
    background: #ecfdf5;
    color: #166534;
    border-color: #bbf7d0;
}
