    :root {
        --tt-red: #f04142;
        --tt-red-dark: #d91f26;
        --tt-ink: #222226;
        --tt-muted: #737985;
        --tt-line: #eceff3;
        --tt-bg: #f6f7f9;
        --tt-card: #ffffff;
        --tt-soft: #fff4f4;
    }

    .tt-body {
        background: var(--tt-bg);
        color: var(--tt-ink);
        font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    }

    .tt-shell {
        width: min(1180px, calc(100vw - 32px));
        margin: 0 auto;
    }

    .tt-header {
        position: sticky;
        top: 0;
        z-index: 50;
        background: rgba(255, 255, 255, .96);
        border-bottom: 1px solid var(--tt-line);
        backdrop-filter: blur(12px);
    }

    .tt-header-row {
        display: flex;
        align-items: center;
        gap: 22px;
        min-height: 64px;
    }

    .tt-brand {
        display: inline-flex;
        align-items: center;
        gap: 10px;
        color: var(--tt-ink);
        font-size: 24px;
        font-weight: 850;
        letter-spacing: -0.04em;
        white-space: nowrap;
    }

    .tt-brand-mark {
        width: 10px;
        height: 28px;
        border-radius: 999px;
        background: linear-gradient(180deg, var(--tt-red), #ff7b5f);
    }

    .tt-topnav {
        display: flex;
        align-items: center;
        gap: 18px;
        color: #4b5563;
        font-weight: 650;
    }

    .tt-topnav a {
        padding: 22px 0 18px;
        border-bottom: 3px solid transparent;
    }

    .tt-topnav a:hover,
    .tt-topnav a.is-active {
        color: var(--tt-red);
        border-bottom-color: var(--tt-red);
    }

    .tt-search {
        margin-left: auto;
        display: flex;
        align-items: center;
        width: min(320px, 32vw);
        border: 1px solid var(--tt-line);
        background: #f8fafc;
        border-radius: 999px;
        overflow: hidden;
    }

    .tt-search input {
        min-width: 0;
        flex: 1;
        background: transparent;
        padding: 10px 4px 10px 16px;
        color: var(--tt-ink);
        outline: none;
    }

    .tt-search button {
        padding: 10px 14px;
        color: var(--tt-red);
    }

    .tt-mobile-menu {
        display: none;
        margin-left: auto;
        color: var(--tt-ink);
    }

    .tt-layout {
        display: grid;
        grid-template-columns: 148px minmax(0, 1fr) 292px;
        gap: 18px;
        padding: 22px 0 34px;
        align-items: start;
    }

    .tt-channel-rail {
        position: sticky;
        top: 84px;
        display: grid;
        gap: 4px;
        padding: 8px;
        background: var(--tt-card);
        border: 1px solid var(--tt-line);
        border-radius: 18px;
        box-shadow: 0 12px 30px rgba(15, 23, 42, .05);
    }

    .tt-channel {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 8px;
        padding: 11px 12px;
        border-radius: 12px;
        color: #4b5563;
        font-weight: 700;
    }

    .tt-channel:hover,
    .tt-channel.is-active {
        background: var(--tt-soft);
        color: var(--tt-red);
    }

    .tt-feed {
        display: grid;
        gap: 12px;
    }

    .tt-breaking {
        display: flex;
        gap: 12px;
        align-items: center;
        padding: 12px 16px;
        background: #fff;
        border: 1px solid var(--tt-line);
        border-radius: 16px;
        color: var(--tt-muted);
        font-weight: 650;
    }

    .tt-breaking strong {
        color: var(--tt-red);
    }

    .tt-feed-card,
    .tt-panel,
    .tt-article-card {
        background: var(--tt-card);
        border: 1px solid var(--tt-line);
        border-radius: 16px;
        box-shadow: 0 12px 30px rgba(15, 23, 42, .045);
    }

    .tt-feed-card {
        padding: 22px 24px;
    }

    .tt-section-title {
        display: flex;
        align-items: center;
        justify-content: flex-start;
        margin-bottom: 12px;
        font-size: 18px;
        font-weight: 850;
        letter-spacing: -0.02em;
    }

    .tt-section-title::before {
        content: "";
        display: inline-block;
        width: 4px;
        height: 18px;
        margin-right: 9px;
        border-radius: 999px;
        background: var(--tt-red);
    }

    .tt-title-row {
        display: flex;
        align-items: center;
        justify-content: flex-start;
        text-align: left;
    }

    .tt-card-meta {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 9px;
        color: var(--tt-muted);
        font-size: 13px;
        font-weight: 650;
    }

    .tt-pill {
        display: inline-flex;
        align-items: center;
        padding: 4px 9px;
        border-radius: 999px;
        background: var(--tt-soft);
        color: var(--tt-red);
        font-size: 12px;
        font-weight: 750;
    }

    .tt-article-card {
        display: grid;
        grid-template-columns: minmax(0, 1fr) 142px;
        gap: 18px;
        padding: 18px;
        transition: transform .18s ease, box-shadow .18s ease;
    }

    .tt-article-card:hover {
        transform: translateY(-1px);
        box-shadow: 0 18px 42px rgba(15, 23, 42, .07);
    }

    .tt-article-title {
        margin-top: 10px;
        color: #111827;
        font-size: 22px;
        line-height: 1.28;
        font-weight: 850;
        letter-spacing: -0.03em;
    }

    .tt-article-title a:hover {
        color: var(--tt-red);
    }

    .tt-article-summary {
        margin-top: 10px;
        color: #626a77;
        font-size: 15px;
        line-height: 1.75;
    }

    .tt-card-action {
        display: inline-flex;
        align-items: center;
        gap: 5px;
        margin-top: 14px;
        color: var(--tt-red);
        font-weight: 800;
    }

    .tt-thumb {
        min-height: 104px;
        border-radius: 14px;
        background:
            radial-gradient(circle at 72% 24%, rgba(240, 65, 66, .22), transparent 34%),
            linear-gradient(135deg, #fff3f3, #eef2ff);
        border: 1px solid #f1e3e4;
        display: grid;
        place-items: center;
        color: var(--tt-red);
        font-size: 32px;
        font-weight: 900;
    }

    .tt-sidebar {
        position: sticky;
        top: 84px;
        display: grid;
        gap: 14px;
    }

    .tt-panel {
        padding: 18px;
    }

    .tt-hot-list {
        display: grid;
        gap: 14px;
    }

    .tt-hot-item {
        display: grid;
        grid-template-columns: 24px minmax(0, 1fr);
        gap: 10px;
        align-items: start;
        color: #374151;
        font-size: 14px;
        line-height: 1.5;
        font-weight: 700;
    }

    .tt-hot-index {
        display: inline-grid;
        place-items: center;
        width: 22px;
        height: 22px;
        border-radius: 7px;
        background: #f1f5f9;
        color: #64748b;
        font-size: 12px;
        font-weight: 900;
    }

    .tt-hot-item:nth-child(-n+3) .tt-hot-index {
        background: var(--tt-red);
        color: #fff;
    }

    .tt-page-head {
        padding: 26px 28px;
        background:
            radial-gradient(circle at top right, rgba(240, 65, 66, .1), transparent 36%),
            #fff;
        border: 1px solid var(--tt-line);
        border-radius: 18px;
        box-shadow: 0 12px 30px rgba(15, 23, 42, .045);
    }

    .tt-page-kicker {
        margin-bottom: 8px;
        color: var(--tt-red);
        font-size: 13px;
        font-weight: 850;
        letter-spacing: .08em;
        text-transform: uppercase;
    }

    .tt-page-title {
        color: #111827;
        font-size: clamp(34px, 5vw, 56px);
        line-height: 1.08;
        font-weight: 900;
        letter-spacing: -0.06em;
    }

    .tt-page-desc {
        margin-top: 12px;
        color: #5f6876;
        font-size: 17px;
        line-height: 1.8;
    }

    .tt-article-layout {
        display: grid;
        grid-template-columns: minmax(0, 1fr) 300px;
        gap: 20px;
        padding: 22px 0 34px;
    }

    .tt-article-main {
        background: #fff;
        border: 1px solid var(--tt-line);
        border-radius: 20px;
        padding: clamp(24px, 5vw, 54px);
        box-shadow: 0 14px 34px rgba(15, 23, 42, .045);
    }

    .tt-article-h1 {
        color: #111827;
        font-size: clamp(32px, 5vw, 52px);
        line-height: 1.12;
        font-weight: 920;
        letter-spacing: -0.06em;
    }

    .tt-prose {
        margin-top: 28px;
        color: #263241;
        font-size: 18px;
        line-height: 1.95;
    }

    .tt-prose h2,
    .tt-prose h3 {
        margin: 2em 0 .8em;
        color: #111827;
        font-weight: 900;
        letter-spacing: -0.04em;
    }

    .tt-prose h2 {
        font-size: 1.65em;
        border-left: 4px solid var(--tt-red);
        padding-left: 12px;
    }

    .tt-prose h3 {
        font-size: 1.28em;
    }

    .tt-prose p,
    .tt-prose ul,
    .tt-prose ol,
    .tt-prose table,
    .tt-prose blockquote {
        margin: 1.05em 0;
    }

    .tt-prose a {
        color: var(--tt-red);
        font-weight: 750;
    }

    .tt-prose img {
        width: 100%;
        border-radius: 18px;
        box-shadow: 0 14px 36px rgba(15, 23, 42, .1);
    }

    .tt-prose figcaption {
        display: none;
    }

    .tt-prose table {
        display: block;
        width: 100%;
        overflow-x: auto;
        border-collapse: collapse;
    }

    .tt-prose th,
    .tt-prose td {
        border: 1px solid #e5e7eb;
        padding: 10px 12px;
    }

    .tt-prose th {
        background: #f8fafc;
        font-weight: 850;
    }

    .tt-footer {
        border-top: 1px solid var(--tt-line);
        background: #fff;
    }

    .tt-footer-inner {
        padding: 28px 0;
        text-align: center;
        color: var(--tt-muted);
        font-size: 14px;
    }

    @media (max-width: 1080px) {
        .tt-layout {
            grid-template-columns: 132px minmax(0, 1fr);
        }

        .tt-sidebar {
            display: none;
        }
    }

    @media (max-width: 820px) {
        .tt-shell {
            width: min(100% - 20px, 1180px);
        }

        .tt-topnav,
        .tt-search {
            display: none;
        }

        .tt-mobile-menu {
            display: inline-flex;
        }

        .tt-layout,
        .tt-article-layout {
            display: block;
        }

        .tt-channel-rail {
            position: static;
            display: flex;
            overflow-x: auto;
            margin-bottom: 14px;
            border-radius: 16px;
        }

        .tt-channel {
            white-space: nowrap;
        }

        .tt-feed {
            gap: 10px;
        }

        .tt-article-card {
            grid-template-columns: 1fr;
        }

        .tt-thumb {
            min-height: 86px;
        }
    }

    /*
     * High-fidelity news portal pass:
     * flatter white canvas, compact channel rail, feed rows with separators,
     * and a right-side hot board closer to Toutiao's public information layout.
     */
    .tt-body {
        background: #fff;
    }

    .tt-main {
        background: #fff;
    }

    .tt-shell {
        width: min(1170px, calc(100vw - 32px));
    }

    .tt-header {
        background: #fff;
        box-shadow: none;
    }

    .tt-header-row {
        min-height: 58px;
        gap: 24px;
    }

    .tt-brand {
        min-width: 128px;
        color: #222;
        font-size: 26px;
        font-weight: 900;
    }

    .tt-brand-mark {
        width: 32px;
        height: 32px;
        border-radius: 9px;
        background: var(--tt-red);
        box-shadow: inset 0 -7px 14px rgba(0, 0, 0, .08);
    }

    .tt-topnav {
        gap: 20px;
        color: #555;
        font-size: 15px;
    }

    .tt-topnav a {
        padding: 19px 0 16px;
        border-bottom-width: 2px;
        font-weight: 600;
    }

    .tt-search {
        width: 330px;
        height: 40px;
        border-color: #e8e8e8;
        background: #f5f6f7;
        border-radius: 4px;
    }

    .tt-search input {
        padding-left: 14px;
        font-size: 14px;
    }

    .tt-search button {
        min-width: 46px;
        background: var(--tt-red);
        color: #fff;
    }

    .tt-layout {
        grid-template-columns: 110px minmax(0, 650px) 320px;
        gap: 24px;
        padding-top: 18px;
    }

    .tt-channel-rail {
        top: 76px;
        gap: 2px;
        padding: 0;
        border: 0;
        border-radius: 0;
        background: transparent;
        box-shadow: none;
    }

    .tt-channel {
        height: 40px;
        justify-content: flex-start;
        padding: 0 12px;
        border-radius: 4px;
        color: #444;
        font-size: 16px;
        font-weight: 500;
    }

    .tt-channel small {
        display: none;
    }

    .tt-channel:hover {
        background: #f7f8fa;
        color: var(--tt-red);
    }

    .tt-channel.is-active {
        background: var(--tt-red);
        color: #fff;
        font-weight: 700;
    }

    .tt-feed {
        gap: 0;
        border-left: 1px solid #f2f2f2;
        border-right: 1px solid #f2f2f2;
        background: #fff;
    }

    .tt-page-head {
        padding: 20px 22px 18px;
        border: 0;
        border-bottom: 1px solid #f0f0f0;
        border-radius: 0;
        background: #fff;
        box-shadow: none;
    }

    .tt-page-kicker {
        margin-bottom: 6px;
        color: #999;
        font-size: 13px;
        font-weight: 500;
        letter-spacing: 0;
        text-transform: none;
    }

    .tt-page-title {
        font-size: 28px;
        line-height: 1.24;
        letter-spacing: -.02em;
        font-weight: 800;
    }

    .tt-page-desc {
        margin-top: 8px;
        color: #666;
        font-size: 14px;
        line-height: 1.7;
    }

    .tt-breaking {
        margin: 0;
        padding: 12px 22px;
        border: 0;
        border-bottom: 1px solid #f0f0f0;
        border-radius: 0;
        box-shadow: none;
        background: #fff;
        color: #444;
        font-size: 15px;
    }

    .tt-breaking strong {
        padding: 2px 7px;
        border-radius: 3px;
        background: var(--tt-red);
        color: #fff;
        font-size: 12px;
    }

    .tt-feed-card {
        padding: 0;
        border: 0;
        border-radius: 0;
        box-shadow: none;
    }

    .tt-section-title {
        margin: 0;
        padding: 14px 22px;
        border-bottom: 1px solid #f0f0f0;
        font-size: 18px;
        font-weight: 800;
    }

    .tt-section-title::before {
        width: 3px;
        height: 18px;
        margin-right: 1px;
        background: var(--tt-red);
    }

    .tt-article-card {
        grid-template-columns: minmax(0, 1fr) 156px;
        gap: 18px;
        padding: 18px 22px;
        border: 0;
        border-bottom: 1px solid #f0f0f0;
        border-radius: 0;
        box-shadow: none;
    }

    .tt-article-card:hover {
        transform: none;
        box-shadow: none;
        background: #fafafa;
    }

    .tt-card-meta {
        gap: 8px;
        color: #999;
        font-size: 13px;
        font-weight: 400;
    }

    .tt-pill {
        padding: 0;
        background: transparent;
        color: #999;
        font-size: 13px;
        font-weight: 400;
    }

    .tt-article-title {
        margin-top: 6px;
        font-size: 20px;
        line-height: 1.38;
        font-weight: 700;
        letter-spacing: 0;
    }

    .tt-article-summary {
        margin-top: 8px;
        color: #666;
        font-size: 14px;
        line-height: 1.7;
    }

    .tt-card-action {
        margin-top: 8px;
        color: #999;
        font-size: 13px;
        font-weight: 500;
    }

    .tt-card-action:hover {
        color: var(--tt-red);
    }

    .tt-thumb {
        min-height: 96px;
        border: 0;
        border-radius: 4px;
        background:
            linear-gradient(135deg, rgba(240, 65, 66, .78), rgba(255, 144, 84, .88)),
            linear-gradient(135deg, #fff3f3, #eef2ff);
        color: rgba(255, 255, 255, .94);
        font-size: 34px;
    }

    .tt-sidebar {
        top: 76px;
        gap: 16px;
    }

    .tt-panel {
        padding: 0;
        border: 0;
        border-radius: 0;
        background: #fff;
        box-shadow: none;
    }

    .tt-panel .tt-section-title {
        padding-left: 0;
        padding-right: 0;
    }

    .tt-hot-list {
        gap: 0;
    }

    .tt-hot-item {
        grid-template-columns: 24px minmax(0, 1fr);
        padding: 10px 0;
        border-bottom: 1px solid #f4f4f4;
        color: #333;
        font-size: 14px;
        font-weight: 500;
    }

    .tt-hot-index {
        background: transparent;
        color: #999;
        font-size: 15px;
    }

    .tt-hot-item:nth-child(1) .tt-hot-index {
        color: #f04142;
    }

    .tt-hot-item:nth-child(2) .tt-hot-index {
        color: #ff7a00;
    }

    .tt-hot-item:nth-child(3) .tt-hot-index {
        color: #ffb400;
    }

    .tt-article-layout {
        grid-template-columns: minmax(0, 720px) 320px;
        gap: 36px;
        padding-top: 28px;
    }

    .tt-article-main {
        padding: 0 0 40px;
        border: 0;
        border-radius: 0;
        box-shadow: none;
        background: #fff;
    }

    .tt-article-h1 {
        margin-top: 14px;
        font-size: 34px;
        line-height: 1.28;
        letter-spacing: 0;
        font-weight: 800;
    }

    .tt-article-main > .tt-card-meta {
        padding-bottom: 2px;
        color: #999;
    }

    .tt-prose {
        margin-top: 22px;
        color: #222;
        font-size: 17px;
        line-height: 1.95;
    }

    .tt-prose h2 {
        margin: 1.9em 0 .75em;
        padding-left: 10px;
        border-left: 3px solid var(--tt-red);
        font-size: 24px;
        letter-spacing: 0;
    }

    .tt-prose h3 {
        font-size: 20px;
        letter-spacing: 0;
    }

    .tt-prose img {
        border-radius: 4px;
        box-shadow: none;
    }

    .tt-prose blockquote {
        border-left: 4px solid #eee;
        padding-left: 16px;
        color: #555;
    }

    .tt-footer {
        margin-top: 20px;
    }

    @media (max-width: 1080px) {
        .tt-layout {
            grid-template-columns: 96px minmax(0, 1fr);
        }
    }

    @media (max-width: 820px) {
        .tt-layout,
        .tt-article-layout {
            display: block;
        }

        .tt-feed {
            border: 1px solid #f2f2f2;
        }

        .tt-channel-rail {
            display: flex;
            gap: 8px;
            padding-bottom: 12px;
            overflow-x: auto;
        }

        .tt-channel {
            height: 36px;
            white-space: nowrap;
        }

        .tt-article-card {
            grid-template-columns: 1fr;
        }
    }

    /*
     * Kami editorial refinement:
     * warm paper surface, ink-blue focus, fewer decorative red blocks, and
     * text-first feed rows when GEOFlow has no real cover image available.
     */
    :root {
        --tt-red: #1B365D;
        --tt-red-dark: #142946;
        --tt-ink: #141413;
        --tt-muted: #5e5d59;
        --tt-line: #e8e5da;
        --tt-bg: #f5f4ed;
        --tt-card: #faf9f5;
        --tt-soft: #EEF2F7;
    }

    .tt-body,
    .tt-main {
        background: var(--tt-bg);
    }

    .tt-header {
        background: rgba(250, 249, 245, .96);
        border-bottom-color: var(--tt-line);
    }

    .tt-brand {
        min-width: 132px;
        gap: 8px;
        font-size: 24px;
        letter-spacing: -0.035em;
    }

    .tt-brand-mark {
        width: 6px;
        height: 28px;
        border-radius: 999px;
        background: var(--tt-red);
        box-shadow: none;
    }

    .tt-topnav {
        color: #4d4c48;
    }

    .tt-topnav a:hover,
    .tt-topnav a.is-active {
        color: var(--tt-red);
        border-bottom-color: var(--tt-red);
    }

    .tt-search {
        width: 300px;
        border-color: var(--tt-line);
        background: #faf9f5;
        border-radius: 10px;
    }

    .tt-search button {
        min-width: 44px;
        background: var(--tt-red);
        color: #faf9f5;
    }

    .tt-layout {
        grid-template-columns: 116px minmax(0, 690px) 284px;
        gap: 22px;
        padding-top: 24px;
    }

    .tt-channel-rail {
        top: 82px;
        padding: 8px;
        border: 1px solid var(--tt-line);
        border-radius: 14px;
        background: var(--tt-card);
    }

    .tt-channel {
        height: 38px;
        padding: 0 12px;
        border-radius: 9px;
        color: #4d4c48;
        font-size: 15px;
    }

    .tt-channel:hover {
        background: #eef2f7;
        color: var(--tt-red);
    }

    .tt-channel.is-active {
        background: #eef2f7;
        color: var(--tt-red);
        font-weight: 700;
    }

    .tt-feed {
        gap: 14px;
        border: 0;
        background: transparent;
    }

    .tt-page-head,
    .tt-feed-card,
    .tt-panel {
        border: 1px solid var(--tt-line);
        border-radius: 16px;
        background: var(--tt-card);
    }

    .tt-page-head {
        padding: 26px 30px 24px;
        box-shadow: none;
    }

    .tt-page-kicker {
        color: #87867f;
        font-size: 13px;
        letter-spacing: .04em;
    }

    .tt-page-title {
        max-width: 13em;
        color: var(--tt-ink);
        font-size: clamp(30px, 3.2vw, 42px);
        line-height: 1.18;
        letter-spacing: -0.045em;
    }

    .tt-page-desc {
        max-width: 40em;
        color: var(--tt-muted);
        font-size: 15px;
        line-height: 1.62;
    }

    .tt-breaking {
        padding: 13px 18px;
        border: 1px solid var(--tt-line);
        border-radius: 14px;
        background: #faf9f5;
        color: #4d4c48;
    }

    .tt-breaking strong {
        background: #eef2f7;
        color: var(--tt-red);
        font-weight: 700;
    }

    .tt-feed-card {
        overflow: hidden;
        padding: 0;
    }

    .tt-section-title {
        padding: 16px 22px 14px;
        border-bottom-color: var(--tt-line);
        color: var(--tt-ink);
        font-size: 18px;
        font-weight: 700;
    }

    .tt-section-title::before {
        width: 3px;
        height: 18px;
        background: var(--tt-red);
    }

    .tt-article-card {
        grid-template-columns: 1fr;
        padding: 22px;
        border-bottom-color: var(--tt-line);
        background: transparent;
    }

    .tt-article-card:hover {
        background: #f7f6ef;
    }

    .tt-thumb {
        display: none;
    }

    .tt-card-meta,
    .tt-pill {
        color: #87867f;
        font-size: 13px;
    }

    .tt-pill {
        color: var(--tt-red);
        font-weight: 600;
    }

    .tt-article-title {
        max-width: 22em;
        margin-top: 7px;
        color: var(--tt-ink);
        font-size: 22px;
        line-height: 1.35;
        font-weight: 750;
        letter-spacing: -0.02em;
    }

    .tt-article-summary {
        max-width: 42em;
        color: var(--tt-muted);
        font-size: 15px;
        line-height: 1.62;
    }

    .tt-card-action {
        color: #87867f;
    }

    .tt-card-action:hover {
        color: var(--tt-red);
    }

    .tt-sidebar {
        top: 82px;
    }

    .tt-panel {
        padding: 0 18px 16px;
    }

    .tt-panel .tt-section-title {
        padding-left: 0;
        padding-right: 0;
    }

    .tt-hot-item {
        border-bottom-color: var(--tt-line);
        color: #3d3d3a;
        font-size: 14px;
        line-height: 1.55;
    }

    .tt-hot-index,
    .tt-hot-item:nth-child(1) .tt-hot-index,
    .tt-hot-item:nth-child(2) .tt-hot-index,
    .tt-hot-item:nth-child(3) .tt-hot-index {
        width: 22px;
        height: 22px;
        border-radius: 6px;
        background: #eef2f7;
        color: var(--tt-red);
        font-size: 12px;
        font-weight: 700;
    }

    .tt-footer {
        border-top-color: var(--tt-line);
        background: var(--tt-bg);
    }

    @media (max-width: 820px) {
        .tt-layout {
            padding-top: 14px;
        }

        .tt-channel-rail {
            padding: 8px;
            margin-bottom: 14px;
        }

        .tt-page-head {
            padding: 22px;
        }
    }

    /*
     * Grid alignment pass:
     * home/category use balanced 20/60/20 columns; article detail becomes a
     * single editorial reading column without side modules.
     */
    .tt-shell {
        width: min(1240px, calc(100vw - 48px));
    }

    .tt-layout {
        grid-template-columns: minmax(180px, 20%) minmax(0, 1fr) minmax(180px, 20%);
        gap: 24px;
        align-items: start;
    }

    .tt-brand {
        min-width: 180px;
    }

    .tt-search {
        width: min(360px, 28vw);
    }

    .tt-channel-rail,
    .tt-sidebar {
        width: 100%;
    }

    .tt-page-title {
        max-width: 15em;
    }

    .tt-article-layout {
        display: block;
        width: min(860px, calc(100vw - 48px));
        margin: 0 auto;
        padding: 42px 0 56px;
    }

    .tt-article-layout .tt-sidebar {
        display: none;
    }

    .tt-article-main {
        padding: 44px 56px 52px;
        border: 1px solid var(--tt-line);
        border-radius: 18px;
        background: var(--tt-card);
    }

    .tt-article-h1 {
        max-width: 16em;
        font-size: clamp(34px, 4vw, 48px);
        line-height: 1.16;
        letter-spacing: -0.04em;
    }

    .tt-prose {
        max-width: none;
        width: 100%;
        margin-left: 0;
        margin-right: 0;
    }

    @media (max-width: 1080px) {
        .tt-layout {
            grid-template-columns: 156px minmax(0, 1fr);
        }

        .tt-brand {
            min-width: 140px;
        }
    }

    @media (max-width: 820px) {
        .tt-shell,
        .tt-article-layout {
            width: min(100% - 20px, 1240px);
        }

        .tt-brand {
            min-width: auto;
        }

        .tt-article-main {
            padding: 28px 22px 34px;
        }
    }

    /*
     * Left rail detail pass: quieter border, softer active item, more breathing
     * room, and smaller typography so the rail reads as navigation rather than
     * a heavy card.
     */
    .tt-channel-rail {
        padding: 10px;
        border-color: #eeeadd;
        border-radius: 18px;
        background: rgba(250, 249, 245, .72);
        box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .42);
    }

    .tt-channel {
        height: 42px;
        padding: 0 14px;
        border-radius: 12px;
        color: #4d4c48;
        font-size: 14px;
        font-weight: 600;
        letter-spacing: -0.01em;
    }

    .tt-channel + .tt-channel {
        margin-top: 3px;
    }

    .tt-channel:hover {
        background: #f1f0e8;
    }

    .tt-channel.is-active {
        background: #EEF2F7;
        color: var(--tt-red);
        box-shadow: inset 3px 0 0 var(--tt-red);
    }

    @media (min-width: 1081px) {
        .tt-channel-rail {
            max-width: 170px;
        }
    }

    /*
     * Kami table-of-contents pass: the rail behaves like an editorial contents
     * block, not a button group. Focus is a thin ink-blue rule plus warm paper.
     */
    .tt-channel-rail {
        max-width: 178px;
        padding: 14px 10px;
        border: 1px solid #e8e5da;
        border-radius: 14px;
        background: #faf9f5;
        box-shadow: 0 10px 28px rgba(20, 20, 19, .035);
    }

    .tt-channel {
        position: relative;
        min-height: 36px;
        height: auto;
        padding: 8px 10px 8px 16px;
        border-left: 2.5px solid transparent;
        border-radius: 8px;
        color: #5e5d59;
        font-size: 13.5px;
        font-weight: 600;
        line-height: 1.35;
    }

    .tt-channel + .tt-channel {
        margin-top: 6px;
    }

    .tt-channel:hover {
        background: #f1f0e8;
        color: #3d3d3a;
    }

    .tt-channel.is-active {
        background: #EEF2F7;
        border-left-color: var(--tt-red);
        color: var(--tt-red);
        box-shadow: none;
    }

    /*
     * Final two-column home/category layout:
     * top navigation now owns channel switching, so page content starts near the
     * first nav item and keeps one consistent gutter to the recommendation rail.
     */
    .tt-layout {
        --tt-content-offset: 210px;
        width: calc(min(1240px, calc(100vw - 48px)) - var(--tt-content-offset));
        margin-left: calc((100vw - min(1240px, calc(100vw - 48px))) / 2 + var(--tt-content-offset));
        margin-right: auto;
        grid-template-columns: minmax(0, 1fr) 300px;
        gap: 22px;
    }

    .tt-feed,
    .tt-sidebar {
        min-width: 0;
    }

    .tt-page-head {
        padding: 24px 28px 22px;
    }

    .tt-page-title {
        max-width: 14em;
        font-size: clamp(30px, 3vw, 40px);
    }

    .tt-sidebar {
        top: 82px;
    }

    .tt-panel {
        border-radius: 14px;
    }

    @media (max-width: 1080px) {
        .tt-layout {
            width: min(100% - 32px, 900px);
            margin-left: auto;
            margin-right: auto;
            grid-template-columns: minmax(0, 1fr);
        }

        .tt-sidebar {
            display: none;
        }
    }

    @media (max-width: 820px) {
        .tt-layout {
            width: min(100% - 20px, 900px);
        }
    }

    /*
     * Unified container pass: header, two-column pages, and article detail now
     * share the same centered width so both edges align consistently.
     */
    .tt-shell {
        width: min(1364px, calc(100vw - 48px));
    }

    .tt-layout {
        width: min(1364px, calc(100vw - 48px));
        margin-left: auto;
        margin-right: auto;
        grid-template-columns: minmax(0, 1fr) 330px;
        gap: 24px;
    }

    .tt-article-layout {
        width: min(1364px, calc(100vw - 48px));
        margin-left: auto;
        margin-right: auto;
    }

    .tt-article-main {
        width: min(920px, 100%);
        margin-left: auto;
        margin-right: auto;
    }

    .tt-search {
        width: min(360px, 30vw);
    }

    @media (max-width: 1080px) {
        .tt-shell,
        .tt-layout,
        .tt-article-layout {
            width: min(100% - 32px, 980px);
        }
    }

    @media (max-width: 820px) {
        .tt-shell,
        .tt-layout,
        .tt-article-layout {
            width: min(100% - 20px, 980px);
        }
    }

    /*
     * Compact editorial container: all public pages use the same 1100px rhythm.
     * Search is intentionally hidden/removed for a calmer top bar.
     */
    .tt-shell,
    .tt-layout,
    .tt-article-layout {
        width: min(1100px, calc(100vw - 48px));
    }

    .tt-layout {
        grid-template-columns: minmax(0, 1fr) 300px;
        gap: 22px;
    }

    .tt-search {
        display: none;
    }

    .tt-header-row {
        justify-content: flex-start;
    }

    .tt-topnav {
        margin-left: 24px;
    }

    .tt-mobile-menu {
        margin-left: auto;
    }

    .tt-article-main {
        width: 100%;
    }

    @media (max-width: 1080px) {
        .tt-shell,
        .tt-layout,
        .tt-article-layout {
            width: min(100% - 32px, 980px);
        }
    }

    @media (max-width: 820px) {
        .tt-shell,
        .tt-layout,
        .tt-article-layout {
            width: min(100% - 20px, 980px);
        }

        .tt-topnav {
            margin-left: 0;
        }
    }

    .tt-breadcrumb {
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
        align-items: center;
        margin-bottom: 0;
        color: #87867f;
        font-size: 13px;
        line-height: 1.5;
    }

    .tt-breadcrumb a {
        color: #5e5d59;
        font-weight: 600;
    }

    .tt-breadcrumb a:hover {
        color: var(--tt-red);
    }

    .tt-breadcrumb span:last-child {
        max-width: 38em;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .tt-related-block {
        margin-top: 0;
        padding: 28px 56px 34px;
    }

    .tt-related-block .tt-section-title {
        padding: 0 0 16px;
        border-bottom: 0;
    }

    .tt-related-grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 12px 18px;
    }

    .tt-related-card {
        display: grid;
        grid-template-columns: 24px minmax(0, 1fr);
        gap: 10px;
        align-items: start;
        padding: 13px 0;
        border-bottom: 1px solid var(--tt-line);
        color: #3d3d3a;
        font-size: 15px;
        line-height: 1.55;
        font-weight: 600;
    }

    .tt-related-card:hover {
        color: var(--tt-red);
    }

    .tt-related-index {
        display: inline-grid;
        place-items: center;
        width: 22px;
        height: 22px;
        border-radius: 6px;
        background: #EEF2F7;
        color: var(--tt-red);
        font-size: 12px;
        font-weight: 700;
    }

    @media (max-width: 820px) {
        .tt-related-grid {
            grid-template-columns: 1fr;
        }

        .tt-breadcrumb span:last-child {
            max-width: 22em;
        }
    }

    .tt-article-layout {
        display: grid;
        gap: 18px;
    }

    .tt-article-module {
        border: 1px solid var(--tt-line);
        border-radius: 18px;
        background: var(--tt-card);
    }

    .tt-breadcrumb.tt-article-module {
        padding: 16px 22px;
    }

    .tt-article-main.tt-article-module {
        margin-left: 0;
        margin-right: 0;
    }

    @media (max-width: 820px) {
        .tt-related-block {
            padding: 24px 22px 28px;
        }
    }

    /*
     * Article page hard reset: keep article detail as a clean single-column
     * document flow. These rules intentionally sit last to avoid earlier
     * two-column/home overrides leaking into detail pages.
     */
    .tt-article-layout {
        display: flex;
        flex-direction: column;
        gap: 18px;
        width: min(1100px, calc(100vw - 48px));
        margin: 0 auto;
        padding: 34px 0 56px;
    }

    .tt-article-layout .tt-sidebar {
        display: none !important;
    }

    .tt-article-module,
    .tt-article-main.tt-article-module,
    .tt-related-block.tt-article-module {
        width: 100%;
        border: 1px solid var(--tt-line);
        border-radius: 18px;
        background: var(--tt-card);
        box-shadow: 0 10px 28px rgba(20, 20, 19, .025);
    }

    .tt-breadcrumb.tt-article-module {
        padding: 15px 22px;
    }

    .tt-article-main.tt-article-module {
        padding: 42px 56px 50px;
    }

    .tt-article-h1 {
        max-width: 100%;
        font-size: clamp(34px, 4.2vw, 54px);
        line-height: 1.13;
        letter-spacing: -0.045em;
    }

    .tt-article-main .tt-prose {
        max-width: none;
        width: 100%;
        font-size: 17px;
        line-height: 1.9;
    }

    .tt-related-block.tt-article-module {
        padding: 28px 56px 34px;
    }

    @media (max-width: 820px) {
        .tt-shell,
        .tt-layout,
        .tt-article-layout {
            width: min(100% - 20px, 1100px);
        }

        .tt-header-row {
            min-height: 56px;
        }

        .tt-brand {
            font-size: 21px;
        }

        .tt-topnav {
            display: none;
        }

        .tt-mobile-menu {
            display: inline-flex;
        }

        .tt-layout {
            grid-template-columns: 1fr;
            gap: 14px;
            padding-top: 16px;
        }

        .tt-sidebar {
            display: none;
        }

        .tt-page-head {
            padding: 22px 20px;
        }

        .tt-page-title {
            font-size: 30px;
            line-height: 1.18;
        }

        .tt-article-card {
            padding: 20px;
        }

        .tt-article-title {
            font-size: 21px;
        }

        .tt-article-layout {
            gap: 12px;
            padding: 16px 0 34px;
        }

        .tt-breadcrumb.tt-article-module {
            padding: 12px 16px;
            font-size: 12px;
        }

        .tt-article-main.tt-article-module {
            padding: 26px 20px 32px;
        }

        .tt-article-h1 {
            font-size: 34px;
            line-height: 1.16;
        }

        .tt-article-main .tt-prose {
            font-size: 16px;
            line-height: 1.82;
        }

        .tt-related-block.tt-article-module {
            padding: 24px 20px 28px;
        }
    }

    /*
     * List rows should be text-first when no real cover image is present.
     * Remove the reserved thumbnail column so title and summary align evenly
     * with the card padding on both sides.
     */
    .tt-feed .tt-article-card {
        grid-template-columns: minmax(0, 1fr) !important;
    }

    .tt-feed .tt-article-card > div {
        min-width: 0;
        width: 100%;
    }

    .tt-feed .tt-thumb {
        display: none !important;
    }

    .tt-feed .tt-article-title,
    .tt-feed .tt-article-summary {
        max-width: none;
        width: 100%;
    }

    .tt-hot-carousel {
        position: relative;
        display: grid;
        gap: 8px;
    }

    .tt-hot-carousel .tt-breaking {
        display: none;
    }

    .tt-hot-carousel .tt-breaking.is-active {
        display: flex;
    }

    .tt-hot-dots {
        display: flex;
        justify-content: flex-end;
        gap: 6px;
        padding-right: 4px;
    }

    .tt-hot-dots button {
        width: 7px;
        height: 7px;
        border-radius: 999px;
        background: #d8d6cf;
    }

    .tt-hot-dots button.is-active {
        width: 18px;
        background: var(--tt-red);
    }

    .tt-section-title::before {
        display: none !important;
    }

    /*
     * Article titles should feel editorial, not poster-sized. Keep the detail
     * page readable while avoiding oversized two-line headlines on desktop.
     */
    .tt-article-h1 {
        font-size: clamp(30px, 3vw, 40px) !important;
        line-height: 1.22 !important;
        letter-spacing: -0.03em;
    }

    @media (max-width: 768px) {
        .tt-article-h1 {
            font-size: 28px !important;
            line-height: 1.24 !important;
            letter-spacing: -0.02em;
        }
    }

    /*
     * Homepage poster + sidebar feed card. The main column now opens with an
     * optional configured visual slot, while the site introduction moves into
     * the right rail above the latest/hot list.
     */
    .tt-home-poster-carousel {
        position: relative;
        overflow: hidden;
        min-height: 220px;
        border: 1px solid var(--tt-line);
        border-radius: 18px;
        background: #ede9dc;
        box-shadow: 0 12px 30px rgba(20, 20, 19, .035);
    }

    .tt-home-poster-slide {
        display: none;
        position: relative;
        min-height: 220px;
        color: #fff;
    }

    .tt-home-poster-slide.is-active {
        display: block;
    }

    .tt-home-poster-slide img {
        display: block;
        width: 100%;
        height: 100%;
        min-height: 220px;
        aspect-ratio: 16 / 6.2;
        object-fit: cover;
    }

    .tt-home-poster-caption {
        position: absolute;
        left: 22px;
        bottom: 20px;
        max-width: min(520px, calc(100% - 44px));
        border-radius: 999px;
        background: rgba(17, 24, 39, .68);
        padding: 9px 14px;
        color: #fff;
        font-size: 15px;
        font-weight: 700;
        line-height: 1.35;
        backdrop-filter: blur(10px);
    }

    .tt-home-poster-dots {
        position: absolute;
        right: 18px;
        bottom: 16px;
        display: flex;
        gap: 7px;
        z-index: 2;
    }

    .tt-home-poster-dots button {
        width: 7px;
        height: 7px;
        border-radius: 999px;
        background: rgba(255, 255, 255, .62);
        box-shadow: 0 0 0 1px rgba(0, 0, 0, .08);
    }

    .tt-home-poster-dots button.is-active {
        width: 20px;
        background: #fff;
    }

    .tt-feed-panel {
        padding: 22px 20px 24px;
    }

    .tt-feed-panel-title {
        margin-top: 8px;
        color: var(--tt-ink);
        font-size: 26px;
        line-height: 1.15;
        font-weight: 850;
        letter-spacing: -0.045em;
    }

    .tt-feed-panel-desc {
        margin-top: 12px;
        color: var(--tt-muted);
        font-size: 14px;
        line-height: 1.7;
    }

    @media (max-width: 820px) {
        .tt-home-poster-carousel,
        .tt-home-poster-slide,
        .tt-home-poster-slide img {
            min-height: 168px;
        }

        .tt-home-poster-caption {
            left: 14px;
            bottom: 14px;
            max-width: calc(100% - 28px);
            border-radius: 14px;
            font-size: 13px;
        }
    }

    /*
     * Markdown table reset for article detail pages. The global theme table
     * rule used display:block for overflow handling, which made GFM tables keep
     * their intrinsic width and left a large blank area on the right. Keep the
     * scroll wrapper, but restore the table layout so columns fill the card.
     */
    .tt-prose .article-table-wrap {
        display: block;
        width: 100%;
        max-width: 100%;
        margin: 2rem auto;
        overflow-x: auto;
        overflow-y: hidden;
        border: 1px solid var(--tt-line);
        border-radius: 18px;
        background: #fff;
        box-shadow: 0 14px 34px rgba(20, 20, 19, .05);
    }

    .tt-prose .article-table {
        display: table !important;
        width: max(760px, 100%) !important;
        min-width: 100%;
        table-layout: auto;
        border-collapse: collapse;
        margin: 0;
        font-size: 15px;
        line-height: 1.72;
    }

    .tt-prose .article-table th,
    .tt-prose .article-table td {
        border-color: #e6e2d7;
        padding: 14px 16px;
        vertical-align: top;
        white-space: normal;
    }

    .tt-prose .article-table th {
        background: #f6f5ef;
        color: var(--tt-ink);
        font-weight: 800;
    }

    .tt-prose .article-table td {
        color: #354052;
    }

    @media (max-width: 820px) {
        .tt-prose .article-table-wrap {
            margin: 1.5rem auto;
            border-radius: 14px;
        }

        .tt-prose .article-table {
            width: max(640px, 100%) !important;
            font-size: 14px;
        }

        .tt-prose .article-table th,
        .tt-prose .article-table td {
            padding: 12px 14px;
        }
    }

/*
 * RSSGeo GEO service-provider homepage.
 * A warm technical editorial style: official, credible, and content-system first.
 */
:root {
    --rg-ink: #10261f;
    --rg-muted: #65736d;
    --rg-green: #0f6b52;
    --rg-green-deep: #063d32;
    --rg-amber: #dca54a;
    --rg-paper: #f6f2e8;
    --rg-card: rgba(255, 252, 244, .86);
    --rg-line: rgba(15, 107, 82, .16);
}

.tt-body {
    color: var(--rg-ink);
    font-family: "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;
}

.tt-brand {
    align-items: center;
    color: var(--rg-ink);
    font-family: "STZhongsong", "Songti SC", "Noto Serif CJK SC", serif;
    letter-spacing: -0.02em;
}

.tt-brand::before {
    content: "";
    width: 24px;
    height: 24px;
    border-radius: 9px;
    background:
        radial-gradient(circle at 68% 30%, #fff6d7 0 12%, transparent 13%),
        conic-gradient(from 210deg, var(--rg-green), #1a8c68, var(--rg-amber), var(--rg-green));
    box-shadow: 0 8px 18px rgba(15, 107, 82, .2);
}

.tt-topnav a:hover,
.tt-topnav a.is-active {
    color: var(--rg-green);
    border-bottom-color: var(--rg-green);
}

.rg-home {
    position: relative;
    display: grid;
    gap: 22px;
    padding: 28px 0 54px;
}

.rg-home::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    background:
        radial-gradient(circle at 10% 10%, rgba(220, 165, 74, .18), transparent 28%),
        radial-gradient(circle at 88% 8%, rgba(15, 107, 82, .14), transparent 32%),
        linear-gradient(115deg, rgba(15, 107, 82, .05) 0 1px, transparent 1px 34px),
        var(--rg-paper);
}

.rg-hero {
    position: relative;
    overflow: hidden;
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(360px, .92fr);
    gap: 26px;
    min-height: 520px;
    padding: clamp(34px, 5vw, 68px);
    border: 1px solid rgba(16, 38, 31, .12);
    border-radius: 34px;
    background:
        linear-gradient(135deg, rgba(255, 252, 244, .94), rgba(237, 247, 241, .82)),
        radial-gradient(circle at 82% 18%, rgba(220, 165, 74, .24), transparent 32%);
    box-shadow: 0 26px 70px rgba(35, 50, 42, .12);
}

.rg-hero::after {
    content: "";
    position: absolute;
    right: -120px;
    bottom: -170px;
    width: 440px;
    height: 440px;
    border: 1px solid rgba(15, 107, 82, .14);
    border-radius: 50%;
    background: repeating-radial-gradient(circle, transparent 0 18px, rgba(15, 107, 82, .08) 19px 20px);
}

.rg-hero-copy,
.rg-ops-card {
    position: relative;
    z-index: 1;
}

.rg-kicker {
    color: var(--rg-green);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .14em;
    text-transform: uppercase;
}

.rg-hero h1 {
    max-width: 10.5em;
    margin-top: 16px;
    color: var(--rg-ink);
    font-family: "STZhongsong", "Songti SC", "Noto Serif CJK SC", serif;
    font-size: clamp(42px, 6vw, 74px);
    line-height: 1.04;
    letter-spacing: -0.055em;
}

.rg-hero-lead {
    max-width: 44em;
    margin-top: 24px;
    color: var(--rg-muted);
    font-size: 17px;
    line-height: 1.88;
}

.rg-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 30px;
}

.rg-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 0 20px;
    border-radius: 999px;
    font-weight: 850;
    transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}

.rg-btn:hover {
    transform: translateY(-1px);
}

.rg-btn-primary {
    background: var(--rg-green);
    color: #fffaf0;
    box-shadow: 0 14px 30px rgba(15, 107, 82, .24);
}

.rg-btn-ghost {
    border: 1px solid rgba(15, 107, 82, .18);
    background: rgba(255, 255, 255, .5);
    color: var(--rg-green-deep);
}

.rg-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    margin-top: 42px;
}

.rg-metrics span {
    min-height: 92px;
    padding: 16px;
    border: 1px solid var(--rg-line);
    border-radius: 20px;
    background: rgba(255, 255, 255, .45);
    color: var(--rg-muted);
    font-size: 13px;
    line-height: 1.45;
}

.rg-metrics strong {
    display: block;
    margin-bottom: 8px;
    color: var(--rg-ink);
    font-size: 18px;
}

.rg-ops-card {
    align-self: center;
    display: grid;
    gap: 16px;
    padding: 22px;
    border: 1px solid rgba(255, 255, 255, .52);
    border-radius: 30px;
    background:
        linear-gradient(150deg, rgba(7, 61, 50, .96), rgba(12, 96, 72, .92)),
        radial-gradient(circle at top right, rgba(220, 165, 74, .36), transparent 36%);
    color: #fffaf0;
    box-shadow: 0 28px 70px rgba(6, 61, 50, .26);
}

.rg-ops-top,
.rg-signal {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.rg-ops-top {
    color: rgba(255, 250, 240, .88);
    font-size: 13px;
    font-weight: 850;
    letter-spacing: .08em;
}

.rg-signal {
    padding: 16px;
    border-radius: 20px;
    background: rgba(255, 255, 255, .11);
}

.rg-signal strong {
    color: #ffe1a1;
    font-size: 28px;
}

.rg-flow-line {
    display: grid;
    gap: 12px;
}

.rg-flow-line div {
    display: grid;
    grid-template-columns: 32px minmax(0, 1fr);
    gap: 3px 12px;
    align-items: center;
    padding: 15px;
    border: 1px solid rgba(255, 255, 255, .13);
    border-radius: 18px;
    background: rgba(255, 255, 255, .08);
}

.rg-flow-line i {
    grid-row: span 2;
    color: #ffe1a1;
}

.rg-flow-line b {
    font-size: 17px;
}

.rg-flow-line small,
.rg-answer-preview small {
    color: rgba(255, 250, 240, .68);
}

.rg-answer-preview {
    padding: 18px;
    border-radius: 22px;
    background: #fffaf0;
    color: var(--rg-ink);
}

.rg-answer-preview p {
    margin-top: 8px;
    color: #3d554d;
    font-size: 14px;
    line-height: 1.7;
}

.rg-service-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
}

.rg-service-grid article,
.rg-proof,
.rg-content-hub,
.rg-contact,
.rg-article-card {
    border: 1px solid rgba(16, 38, 31, .1);
    background: var(--rg-card);
    box-shadow: 0 18px 44px rgba(35, 50, 42, .07);
    backdrop-filter: blur(14px);
}

.rg-service-grid article {
    min-height: 250px;
    padding: 24px;
    border-radius: 26px;
}

.rg-service-grid i {
    width: 34px;
    height: 34px;
    padding: 7px;
    border-radius: 13px;
    background: rgba(15, 107, 82, .1);
    color: var(--rg-green);
}

.rg-service-grid h2 {
    margin-top: 22px;
    color: var(--rg-ink);
    font-size: 22px;
    font-weight: 900;
    letter-spacing: -0.03em;
}

.rg-service-grid p {
    margin-top: 12px;
    color: var(--rg-muted);
    font-size: 14px;
    line-height: 1.72;
}

.rg-proof,
.rg-contact {
    display: grid;
    grid-template-columns: .9fr 1.1fr;
    gap: 26px;
    align-items: center;
    padding: 32px;
    border-radius: 30px;
}

.rg-proof h2,
.rg-section-head h2,
.rg-contact h2 {
    margin-top: 10px;
    color: var(--rg-ink);
    font-family: "STZhongsong", "Songti SC", "Noto Serif CJK SC", serif;
    font-size: clamp(28px, 3vw, 42px);
    line-height: 1.16;
    letter-spacing: -0.045em;
}

.rg-proof-list {
    display: grid;
    gap: 12px;
}

.rg-proof-list span {
    padding: 15px 18px;
    border-radius: 18px;
    background: rgba(15, 107, 82, .08);
    color: #23433a;
    font-weight: 750;
}

.rg-content-hub {
    padding: 30px;
    border-radius: 30px;
}

.rg-section-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 20px;
}

.rg-section-head a {
    color: var(--rg-green);
    font-weight: 850;
}

.rg-article-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.rg-article-card {
    min-height: 190px;
    padding: 22px;
    border-radius: 22px;
    transition: transform .18s ease, box-shadow .18s ease;
}

.rg-article-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 24px 54px rgba(35, 50, 42, .11);
}

.rg-article-card span {
    color: var(--rg-green);
    font-size: 12px;
    font-weight: 900;
}

.rg-article-card h3 {
    margin-top: 12px;
    color: var(--rg-ink);
    font-size: 20px;
    line-height: 1.35;
    font-weight: 900;
    letter-spacing: -0.03em;
}

.rg-article-card p {
    margin-top: 10px;
    color: var(--rg-muted);
    font-size: 14px;
    line-height: 1.7;
}

.rg-contact {
    background:
        linear-gradient(135deg, rgba(6, 61, 50, .95), rgba(15, 107, 82, .86)),
        radial-gradient(circle at top right, rgba(220, 165, 74, .32), transparent 34%);
    color: #fffaf0;
}

.rg-contact h2,
.rg-contact .rg-kicker {
    color: #fffaf0;
}

.rg-contact p {
    margin-top: 12px;
    color: rgba(255, 250, 240, .78);
    font-size: 16px;
    line-height: 1.75;
}

.rg-contact .rg-btn {
    justify-self: end;
    background: #fffaf0;
    color: var(--rg-green-deep);
}

@media (max-width: 980px) {
    .rg-hero,
    .rg-proof,
    .rg-contact {
        grid-template-columns: 1fr;
    }

    .rg-service-grid,
    .rg-article-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .rg-contact .rg-btn {
        justify-self: start;
    }
}

@media (max-width: 640px) {
    .rg-home {
        padding-top: 16px;
    }

    .rg-hero {
        min-height: auto;
        padding: 26px 20px;
        border-radius: 24px;
    }

    .rg-hero h1 {
        font-size: 38px;
    }

    .rg-hero-lead {
        font-size: 15px;
        line-height: 1.75;
    }

    .rg-metrics,
    .rg-service-grid,
    .rg-article-grid {
        grid-template-columns: 1fr;
    }

    .rg-ops-card,
    .rg-proof,
    .rg-content-hub,
    .rg-contact {
        padding: 20px;
        border-radius: 22px;
    }

    .rg-section-head {
        display: block;
    }
}

/*
 * RSSGeo workbench layout correction:
 * keep Chinese labels in readable phrases instead of one-character vertical wraps.
 */
.rg-ops-card,
.rg-hero-copy,
.rg-flow-line,
.rg-flow-line div {
    min-width: 0;
}

.rg-ops-top span,
.rg-signal span,
.rg-signal strong,
.rg-flow-line b,
.rg-metrics strong {
    white-space: nowrap;
    word-break: keep-all;
    overflow-wrap: normal;
}

.rg-flow-line div {
    grid-template-columns: 40px minmax(180px, 1fr);
    align-items: start;
}

.rg-flow-line small {
    display: block;
    margin-top: 2px;
    white-space: normal;
    word-break: keep-all;
    overflow-wrap: normal;
    line-break: strict;
}

.rg-metrics {
    grid-template-columns: repeat(3, minmax(155px, 1fr));
}

.rg-metrics span {
    word-break: keep-all;
    overflow-wrap: normal;
}

@media (max-width: 980px) {
    .rg-metrics {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .rg-flow-line div {
        grid-template-columns: 40px minmax(0, 1fr);
    }
}

@media (max-width: 760px) {
    .rg-metrics {
        grid-template-columns: 1fr;
    }
}

/*
 * RSSGeo homepage typography polish:
 * avoid orphaned one/two-character Chinese wraps in large display text.
 */
.rg-hero {
    grid-template-columns: minmax(0, 1fr) minmax(360px, 420px);
    gap: clamp(20px, 3vw, 34px);
    padding: clamp(30px, 4.4vw, 56px);
}

.rg-hero h1,
.rg-proof h2,
.rg-section-head h2,
.rg-contact h2,
.rg-service-grid h2,
.rg-article-card h3 {
    text-wrap: balance;
    word-break: auto-phrase;
    overflow-wrap: normal;
    line-break: strict;
}

.rg-hero h1 {
    max-width: 12.8em;
    font-size: clamp(38px, 4.8vw, 58px);
    line-height: 1.11;
    letter-spacing: -0.045em;
}

.rg-hero-lead {
    max-width: 46em;
    font-size: 16px;
    line-height: 1.82;
    text-wrap: pretty;
}

.rg-proof h2,
.rg-section-head h2,
.rg-contact h2 {
    max-width: 13em;
    font-size: clamp(26px, 2.6vw, 36px);
    line-height: 1.22;
    letter-spacing: -0.035em;
}

.rg-service-grid article {
    min-height: 226px;
}

.rg-service-grid h2 {
    margin-top: 18px;
    font-size: 20px;
    line-height: 1.32;
    letter-spacing: -0.02em;
}

.rg-service-grid p,
.rg-proof-list span,
.rg-contact p {
    text-wrap: pretty;
}

.rg-proof-list span {
    line-height: 1.56;
}

.rg-article-card {
    min-height: 178px;
}

.rg-article-card h3 {
    font-size: 18.5px;
    line-height: 1.42;
    letter-spacing: -0.015em;
}

.rg-article-card p {
    font-size: 13.5px;
    line-height: 1.68;
    text-wrap: pretty;
}

.rg-section-head {
    align-items: center;
}

@media (max-width: 980px) {
    .rg-hero {
        grid-template-columns: 1fr;
    }

    .rg-hero h1 {
        max-width: 11.5em;
    }
}

@media (max-width: 640px) {
    .rg-hero h1 {
        font-size: 34px;
        line-height: 1.16;
        letter-spacing: -0.035em;
    }

    .rg-proof h2,
    .rg-section-head h2,
    .rg-contact h2 {
        max-width: 100%;
        font-size: 25px;
        line-height: 1.25;
    }

    .rg-service-grid h2,
    .rg-article-card h3 {
        text-wrap: pretty;
    }
}

/*
 * RSSGeo workbench microcopy polish:
 * keep the three small descriptor lines compact and readable.
 */
.rg-flow-line {
    gap: 10px;
}

.rg-flow-line div {
    grid-template-columns: 34px minmax(0, 1fr);
    gap: 2px 12px;
    padding: 14px 15px;
}

.rg-flow-line small {
    display: inline-flex;
    width: fit-content;
    max-width: 100%;
    white-space: nowrap;
    word-break: keep-all;
    overflow-wrap: normal;
    font-size: 12px;
    line-height: 1.2;
    letter-spacing: .01em;
    color: rgba(255, 250, 240, .74);
}

.rg-flow-line b {
    line-height: 1.22;
}

@media (max-width: 420px) {
    .rg-flow-line small {
        white-space: normal;
        line-height: 1.35;
    }
}

/*
 * RSSGeo GEO prompts system section:
 * bridge public GEO prompt methodology into the site's own GEOFlow workflow.
 */
.rg-prompt-system {
    padding: 30px;
    border: 1px solid rgba(16, 38, 31, .1);
    border-radius: 30px;
    background:
        linear-gradient(135deg, rgba(255, 252, 244, .92), rgba(238, 247, 241, .78)),
        radial-gradient(circle at 90% 0, rgba(220, 165, 74, .18), transparent 34%);
    box-shadow: 0 18px 44px rgba(35, 50, 42, .07);
}

.rg-prompt-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin-top: 18px;
}

.rg-prompt-grid a {
    min-height: 150px;
    padding: 20px;
    border: 1px solid rgba(15, 107, 82, .12);
    border-radius: 22px;
    background: rgba(255, 255, 255, .58);
    transition: transform .18s ease, box-shadow .18s ease;
}

.rg-prompt-grid a:hover {
    transform: translateY(-2px);
    box-shadow: 0 18px 38px rgba(35, 50, 42, .09);
}

.rg-prompt-grid strong {
    display: block;
    color: var(--rg-ink);
    font-size: 20px;
    line-height: 1.32;
    font-weight: 900;
    text-wrap: balance;
}

.rg-prompt-grid span,
.rg-source-note {
    display: block;
    margin-top: 10px;
    color: var(--rg-muted);
    font-size: 14px;
    line-height: 1.72;
    text-wrap: pretty;
}

.rg-source-note {
    margin-top: 18px;
    padding-top: 16px;
    border-top: 1px solid rgba(15, 107, 82, .12);
    font-size: 13px;
}

@media (max-width: 900px) {
    .rg-prompt-grid {
        grid-template-columns: 1fr;
    }
}

/*
 * RSSGeo workbench bottom preview compact pass.
 * Turn the large white paragraph box into a tight status strip.
 */
.rg-ops-card {
    gap: 12px;
}

.rg-answer-preview {
    display: grid;
    grid-template-columns: 10px minmax(0, 1fr);
    gap: 10px;
    align-items: start;
    padding: 13px 14px;
    border-radius: 16px;
    background: rgba(255, 250, 240, .94);
    box-shadow: inset 0 0 0 1px rgba(15, 107, 82, .08);
}

.rg-answer-dot {
    width: 8px;
    height: 8px;
    margin-top: 5px;
    border-radius: 999px;
    background: #dca54a;
    box-shadow: 0 0 0 5px rgba(220, 165, 74, .14);
}

.rg-answer-preview small {
    display: block;
    color: var(--rg-green-deep);
    font-size: 12px;
    line-height: 1.15;
    font-weight: 900;
    letter-spacing: .04em;
}

.rg-answer-preview p {
    margin-top: 5px;
    color: #3d554d;
    font-size: 13px;
    line-height: 1.45;
    text-wrap: pretty;
}

@media (max-width: 640px) {
    .rg-answer-preview {
        padding: 12px;
    }
}

/*
 * Footer ICP record link.
 */
.tt-footer-inner .tt-beian-link {
    color: inherit;
    text-decoration: none;
    border-bottom: 1px solid rgba(15, 107, 82, .28);
}

.tt-footer-inner .tt-beian-link:hover {
    color: var(--rg-green, #0f6b52);
    border-bottom-color: currentColor;
}

/*
 * RSSGeo brand asset pass.
 * Use the SVG wordmark when configured and remove the old CSS-only badge.
 */
.tt-brand:has(img)::before {
    display: none;
}

.tt-brand img {
    height: 42px;
    max-width: 190px;
    object-fit: contain;
}

@media (max-width: 640px) {
    .tt-brand img {
        height: 36px;
        max-width: 160px;
    }
}
