.tch-site-main {
    --tch-text: #101820;
    --tch-muted: #4b5563;
    --tch-border: #d8dee8;
    --tch-surface: #ffffff;
    --tch-soft: #f6f8fb;
    --tch-blue-soft: #e8f1fb;
    --tch-accent: #0b4a8f;
    --tch-accent-dark: #07345f;
    --tch-gold: #b88922;
    --tch-gold-soft: #fff8e6;
    --tch-success: #0f5132;
    --tch-success-soft: #dff4e7;
    --tch-focus: #f5a524;
    color: var(--tch-text);
    background: transparent;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-size: 1.125rem;
    line-height: 1.75;
    letter-spacing: 0;
    overflow-x: clip;
}

.tch-site-main *,
.tch-site-main *::before,
.tch-site-main *::after {
    box-sizing: border-box;
    letter-spacing: 0;
}

.tch-site-main h1,
.tch-site-main h2,
.tch-site-main h3,
.tch-site-main p {
    margin-top: 0;
}

.tch-site-main h1 {
    max-width: 22ch;
    margin-bottom: 1.25rem;
    color: var(--tch-text);
    font-size: 2.5rem;
    line-height: 1.15;
    font-weight: 760;
    hyphens: auto;
    overflow-wrap: break-word;
    word-break: normal;
}

.tch-site-main h2 {
    margin-bottom: 1.25rem;
    color: var(--tch-text);
    font-size: 2rem;
    line-height: 1.2;
    font-weight: 720;
    hyphens: auto;
    overflow-wrap: break-word;
    word-break: normal;
}

.tch-site-main h3 {
    font-size: 1.5rem;
    line-height: 1.25;
    font-weight: 720;
}

.tch-site-main a {
    color: var(--tch-accent);
    text-underline-offset: 0.18em;
}

.tch-site-main a:hover {
    color: var(--tch-accent-dark);
}

.tch-site-main :where(a, button, input, textarea, select, [tabindex]):focus-visible {
    outline: 3px solid var(--tch-focus);
    outline-offset: 4px;
    border-radius: 4px;
}

.tch-container {
    width: min(calc(100% - 2rem), 70rem);
    margin-inline: auto;
}

body .site-title,
body .site-title a,
body .ast-site-title-wrap {
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: normal;
}

.tch-kicker {
    margin-bottom: 0.65rem;
    color: var(--tch-muted);
    font-size: 0.875rem;
    font-weight: 760;
    line-height: 1.4;
    text-transform: uppercase;
}

.tch-breadcrumbs {
    margin-bottom: 1.15rem;
    color: var(--tch-muted);
    font-size: 0.96rem;
    font-weight: 650;
    line-height: 1.45;
}

.tch-breadcrumbs ol {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.25rem;
    padding: 0;
    margin: 0;
    list-style: none;
}

.tch-breadcrumbs li {
    display: inline-flex;
    min-height: 2.75rem;
    min-width: 0;
    align-items: center;
    color: var(--tch-muted);
}

.tch-breadcrumbs li + li::before {
    flex: 0 0 auto;
    margin-inline: 0.25rem;
    color: rgba(75, 85, 99, 0.72);
    content: "/";
}

.tch-breadcrumbs a {
    display: inline-flex;
    min-height: 2.75rem;
    align-items: center;
    padding: 0.25rem 0.6rem;
    border: 1px solid rgba(11, 74, 143, 0.16);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.72);
    color: var(--tch-accent-dark);
    font-weight: 760;
    text-decoration: none;
}

.tch-breadcrumbs a:hover {
    background: var(--tch-blue-soft);
    color: var(--tch-text);
}

.tch-breadcrumbs a:focus-visible {
    outline: 3px solid var(--tch-focus);
    outline-offset: 3px;
}

.tch-breadcrumbs [aria-current="page"] span {
    display: inline-flex;
    min-height: 2.75rem;
    max-width: 100%;
    align-items: center;
    padding: 0.25rem 0.35rem;
    overflow: visible;
    overflow-wrap: anywhere;
    color: var(--tch-text);
    text-overflow: clip;
    white-space: normal;
}

.tch-archive-hero,
.tch-detail-hero {
    position: relative;
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    isolation: isolate;
    overflow: hidden;
    border-bottom: 1px solid rgba(216, 222, 232, 0.86);
    background:
        linear-gradient(115deg, rgba(232, 241, 251, 0.95) 0 23%, transparent 23.1%),
        linear-gradient(100deg, #ffffff 0%, #f7fbff 52%, #fff8e6 100%);
}

.tch-archive-hero::before,
.tch-detail-hero::before {
    display: none;
}

.tch-archive-hero::after,
.tch-detail-hero::after {
    position: absolute;
    inset: auto 0 0;
    z-index: -1;
    height: 0.45rem;
    background: linear-gradient(90deg, var(--tch-accent), var(--tch-gold));
    opacity: 0.9;
    content: "";
}

.tch-archive-hero.has-background-image {
    background-image:
        linear-gradient(90deg, rgba(255, 255, 255, 0.9) 0%, rgba(255, 255, 255, 0.82) 44%, rgba(255, 255, 255, 0.54) 72%, rgba(255, 255, 255, 0.28) 100%),
        var(--tch-hero-bg-image);
    background-position: center, center 42%;
    background-size: cover, cover;
}

.tch-archive-hero.has-background-image::before {
    display: none;
}

.tch-archive-hero.has-background-image .tch-archive-hero__content {
    position: relative;
    padding: 2rem;
    margin-left: clamp(-2rem, -3vw, -1rem);
    border: 1px solid rgba(255, 255, 255, 0.72);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(255, 255, 255, 0.74)),
        rgba(255, 255, 255, 0.82);
    box-shadow: 0 26px 74px rgba(16, 24, 32, 0.14);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
}

.tch-archive-hero__inner,
.tch-detail-hero__inner {
    position: relative;
    z-index: 1;
    padding-block: 6rem 5rem;
}

.tch-archive-hero__inner {
    min-height: clamp(28rem, 44vw, 38rem);
    display: grid;
    align-items: center;
}

.tch-archive-hero.has-background-image:not(.is-taxonomy-hero) .tch-archive-hero__inner {
    min-height: clamp(22rem, 34vw, 30rem);
    padding-block: clamp(3.75rem, 7vw, 5rem) clamp(3.25rem, 6vw, 4.5rem);
}

.tch-archive-hero.is-taxonomy-hero .tch-archive-hero__inner {
    min-height: 0;
    padding-block: clamp(2.5rem, 6vw, 4rem) clamp(2.25rem, 5vw, 3.25rem);
}

.tch-archive-hero__content {
    width: min(100%, 55rem);
}

.tch-archive-hero__copy {
    max-width: 50rem;
    color: var(--tch-muted);
    font-size: 1.28rem;
    line-height: 1.65;
}

.tch-archive-hero h1 {
    max-width: 20ch;
    margin-bottom: 1.35rem;
    font-size: 4rem;
    line-height: 1.04;
}

.tch-hero-assurance {
    max-width: 42rem;
    margin: -0.35rem 0 0;
    color: #26384d;
    font-size: 1.125rem;
    line-height: 1.6;
}

.tch-archive-hero.is-taxonomy-hero h1 {
    margin-bottom: 0.8rem;
    font-size: clamp(2.75rem, 5vw, 4.25rem);
}

.tch-archive-hero.is-taxonomy-hero .tch-archive-hero__copy {
    max-width: 42rem;
    font-size: 1.16rem;
}

.tch-archive-hero__copy p:last-child,
.tch-review-content p:last-child {
    margin-bottom: 0;
}

.tch-section-heading {
    max-width: 44rem;
    margin-bottom: 2.25rem;
}

.tch-list-section {
    padding-block: 4.5rem;
}

.tch-subcategory-section + .tch-list-section {
    padding-top: 2.5rem;
}

.tch-archive-location-filter {
    display: grid;
    gap: 1.15rem;
    padding: clamp(1.15rem, 3vw, 1.6rem);
    margin-top: 3rem;
    margin-bottom: 0;
    border: 1px solid rgba(216, 222, 232, 0.95);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(247, 251, 255, 0.92) 56%, rgba(255, 248, 230, 0.62)),
        var(--tch-surface);
    box-shadow: 0 18px 42px rgba(16, 24, 32, 0.08);
}

.tch-archive-location-filter + .tch-subcategory-section,
.tch-archive-location-filter + .tch-list-section {
    padding-top: 2.75rem;
}

.tch-archive-location-filter__heading {
    min-width: 0;
}

.tch-archive-location-filter__heading h2 {
    margin-bottom: 0;
    font-size: clamp(1.5rem, 2.4vw, 2rem);
    line-height: 1.15;
}

.tch-archive-location-filter__list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    justify-content: flex-start;
    padding: 0;
    margin: 0;
    list-style: none;
}

.tch-archive-location-filter__chip {
    display: inline-flex;
    min-height: 2.75rem;
    align-items: center;
    gap: 0.65rem;
    padding: 0.45rem 0.5rem 0.45rem 0.8rem;
    border: 1px solid rgba(11, 74, 143, 0.24);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.96);
    color: var(--tch-accent-dark);
    font-weight: 820;
    line-height: 1.2;
    text-decoration: none;
    box-shadow: 0 10px 24px rgba(16, 24, 32, 0.06);
    transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, background-color 180ms ease, color 180ms ease;
}

.tch-archive-location-filter__chip strong {
    display: inline-flex;
    min-height: 1.9rem;
    align-items: center;
    padding: 0.25rem 0.6rem;
    border-radius: 999px;
    background: var(--tch-blue-soft);
    color: var(--tch-accent-dark);
    font-size: 0.9rem;
    font-weight: 780;
    white-space: nowrap;
}

.tch-archive-location-filter__chip:hover {
    border-color: rgba(11, 74, 143, 0.55);
    background: #ffffff;
    color: var(--tch-accent-dark);
    box-shadow: 0 14px 28px rgba(16, 24, 32, 0.1);
    transform: translateY(-1px);
}

.tch-archive-location-filter__chip:focus-visible {
    outline: 3px solid var(--tch-focus);
    outline-offset: 3px;
}

.tch-archive-location-filter__chip.is-active {
    border-color: var(--tch-accent);
    background: var(--tch-accent);
    color: #ffffff;
}

.tch-archive-location-filter__chip.is-active strong {
    background: rgba(255, 255, 255, 0.18);
    color: #ffffff;
}

.tch-hero-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    padding: 0;
    margin: 2.35rem 0 0;
    list-style: none;
}

.tch-hero-stats li {
    display: inline-flex;
    gap: 0.5rem;
    min-height: 2.75rem;
    align-items: center;
    padding: 0.55rem 0.9rem;
    border: 1px solid rgba(11, 74, 143, 0.2);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.86);
    color: var(--tch-accent-dark);
    font-size: 0.98rem;
    font-weight: 760;
    backdrop-filter: blur(10px);
    box-shadow: 0 14px 34px rgba(16, 24, 32, 0.08);
}

.tch-hero-search {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.75rem;
    width: min(100%, 42rem);
    padding: 0.5rem;
    margin-top: 1.35rem;
    border: 1px solid rgba(11, 74, 143, 0.3);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.96);
    box-shadow:
        0 20px 54px rgba(16, 24, 32, 0.14),
        inset 0 0 0 1px rgba(255, 255, 255, 0.72);
}

.tch-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1.25rem;
}

.tch-hero-shortcuts {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1rem;
}

.tch-hero-shortcuts .tch-button {
    min-height: 2.75rem;
    padding-inline: 1rem;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 10px 24px rgba(16, 24, 32, 0.08);
}

.tch-hero-listing-badge {
    display: grid;
    width: min(100%, 42rem);
    gap: 0.55rem;
    padding: 0.9rem 1rem;
    margin-top: 1.25rem;
    border: 1px solid rgba(184, 137, 34, 0.32);
    border-left: 0.35rem solid var(--tch-gold);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(255, 248, 230, 0.9)),
        var(--tch-surface);
    color: var(--tch-text);
    box-shadow: 0 18px 42px rgba(16, 24, 32, 0.1);
}

.tch-hero-listing-badge__count {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem 0.55rem;
    align-items: baseline;
    margin: 0;
    color: var(--tch-accent-dark);
    font-size: 1rem;
    font-weight: 800;
    line-height: 1.25;
}

.tch-hero-listing-badge__count strong {
    color: var(--tch-text);
    font-size: clamp(1.55rem, 3vw, 2rem);
    font-weight: 900;
    letter-spacing: 0;
}

.tch-hero-listing-badge__text {
    max-width: 40rem;
    margin: 0;
    color: #26384d;
    font-size: 1rem;
    line-height: 1.5;
}

.tch-hero-listing-badge__links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    margin: 0.1rem 0 0;
}

.tch-hero-listing-badge__links a {
    display: inline-flex;
    min-height: 2.4rem;
    align-items: center;
    padding: 0.38rem 0.75rem;
    border: 1px solid rgba(11, 74, 143, 0.26);
    border-radius: 999px;
    background: #ffffff;
    color: var(--tch-accent-dark);
    font-size: 0.96rem;
    font-weight: 820;
    line-height: 1.2;
    text-decoration: none;
}

.tch-hero-listing-badge__links a:hover {
    border-color: var(--tch-accent);
    background: var(--tch-blue-soft);
    color: var(--tch-accent-dark);
}

.tch-hero-listing-badge__links a:focus-visible {
    outline: 3px solid var(--tch-focus);
    outline-offset: 3px;
}

.tch-hero-search input[type="search"] {
    width: 100%;
    min-height: 3.35rem;
    padding: 0.85rem 1.05rem;
    border: 0;
    border-radius: 6px;
    background: transparent;
    color: var(--tch-text);
    font: inherit;
    font-size: 1.05rem;
}

.tch-hero-search input[type="search"]::placeholder {
    color: #5b6675;
}

.tch-hero-search input[type="search"]:focus-visible {
    outline: 3px solid var(--tch-focus);
    outline-offset: 2px;
}

.tch-hero-stats li::before {
    display: inline-block;
    flex: 0 0 auto;
    width: 0.48rem;
    height: 0.48rem;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--tch-accent), var(--tch-gold));
    content: "";
}

.tch-proof-strip {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.35rem;
    align-items: start;
    padding: clamp(1.25rem, 3vw, 1.75rem);
    margin-top: 0;
    margin-bottom: 4.75rem;
    border: 1px solid rgba(216, 222, 232, 0.94);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(247, 251, 255, 0.94) 58%, rgba(255, 248, 230, 0.84)),
        var(--tch-surface);
    box-shadow: 0 22px 54px rgba(16, 24, 32, 0.1);
}

.tch-proof-strip::before {
    position: absolute;
    inset: 0;
    height: 0.32rem;
    border-radius: 8px 8px 0 0;
    background: linear-gradient(90deg, var(--tch-accent), var(--tch-gold));
    content: "";
}

.tch-proof-strip__intro {
    max-width: 44rem;
}

.tch-proof-strip__intro h2 {
    margin-bottom: 0;
    font-size: clamp(1.75rem, 2.6vw, 2.35rem);
    line-height: 1.16;
    hyphens: none;
    overflow-wrap: normal;
}

.tch-proof-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 13.5rem), 1fr));
    gap: 0.85rem;
    padding: 0;
    margin: 0;
    list-style: none;
}

.tch-proof-list li {
    position: relative;
    min-height: 100%;
    padding: 1rem 1rem 1rem 1.15rem;
    border: 1px solid rgba(216, 222, 232, 0.9);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.9);
    box-shadow: 0 12px 28px rgba(16, 24, 32, 0.055);
}

.tch-proof-list li::before {
    position: absolute;
    inset: 1rem auto auto 0;
    width: 0.22rem;
    height: 2.4rem;
    border-radius: 0 999px 999px 0;
    background: linear-gradient(180deg, var(--tch-accent), var(--tch-gold));
    content: "";
}

.tch-proof-list strong {
    display: block;
    margin-bottom: 0.35rem;
    color: var(--tch-text);
    font-size: 1rem;
    line-height: 1.28;
}

.tch-proof-list span {
    display: block;
    color: #35465a;
    font-size: 0.98rem;
    line-height: 1.55;
}

.tch-list {
    display: grid;
    gap: 1.5rem;
    padding: 0;
    margin: 0;
    list-style: none;
}

.tch-search-hero {
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    border-bottom: 1px solid rgba(216, 222, 232, 0.86);
    background:
        linear-gradient(115deg, rgba(232, 241, 251, 0.95) 0 25%, transparent 25.1%),
        linear-gradient(100deg, #ffffff 0%, #f7fbff 55%, #fff8e6 100%);
}

.tch-search-hero__inner {
    padding-block: clamp(3rem, 7vw, 5.5rem);
}

.tch-search-hero h1 {
    max-width: 30ch;
    margin-bottom: 1rem;
    font-size: 2.6rem;
    line-height: 1.15;
    hyphens: auto;
    overflow-wrap: anywhere;
}

.tch-search-hero__lead {
    max-width: 48rem;
    color: var(--tch-muted);
    font-size: 1.22rem;
    line-height: 1.65;
}

.tch-search-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.75rem;
    width: min(100%, 46rem);
    margin-top: 2rem;
    padding: 0.6rem;
    border: 1px solid rgba(11, 74, 143, 0.2);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.92);
    box-shadow: 0 18px 46px rgba(16, 24, 32, 0.1);
}

.tch-search-form input[type="search"] {
    width: 100%;
    min-height: 3.25rem;
    padding: 0.75rem 1rem;
    border: 1px solid transparent;
    border-radius: 8px;
    background: #ffffff;
    color: var(--tch-text);
    font-size: 1.06rem;
    line-height: 1.3;
}

.tch-search-form input[type="search"]::placeholder {
    color: #667085;
    opacity: 1;
}

.tch-search-form input[type="search"]:focus-visible {
    border-color: var(--tch-accent);
    outline: 3px solid var(--tch-focus);
    outline-offset: 2px;
}

.tch-search-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    padding: 0;
    margin: 1.35rem 0 0;
    list-style: none;
}

.tch-search-stats li {
    min-height: 2.35rem;
    padding: 0.42rem 0.72rem;
    border: 1px solid rgba(11, 74, 143, 0.18);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.86);
    color: var(--tch-accent-dark);
    font-size: 0.95rem;
    font-weight: 760;
}

.tch-search-expansion {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem 0.7rem;
    align-items: center;
    margin-top: 1rem;
    color: var(--tch-text);
}

.tch-search-expansion > span {
    color: var(--tch-muted);
    font-size: 0.88rem;
    font-weight: 820;
    line-height: 1.2;
    text-transform: uppercase;
}

.tch-search-expansion ul {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    padding: 0;
    margin: 0;
    list-style: none;
}

.tch-search-expansion li {
    display: inline-flex;
    align-items: center;
    min-height: 2rem;
    padding: 0.3rem 0.62rem;
    border: 1px solid rgba(11, 74, 143, 0.18);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.9);
    color: var(--tch-accent-dark);
    font-size: 0.92rem;
    font-weight: 780;
    line-height: 1.2;
}

.tch-search-results {
    padding-block: 4rem;
}

.tch-search-result-list {
    width: min(100%, 60rem);
}

.tch-search-result-card {
    min-height: 14rem;
}

.tch-404-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1.25rem;
}

.tch-404-section {
    padding-block: 4rem 0;
}

.tch-404-section + .tch-404-section {
    padding-top: 3.25rem;
}

.tch-404-entry-list {
    width: min(100%, 60rem);
}

.tch-category-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 1fr));
    gap: 1.25rem;
    padding: 0;
    margin: 0;
    list-style: none;
}

.tch-mobile-category-nav {
    display: none;
}

.tch-category-card {
    position: relative;
    height: 100%;
    overflow: hidden;
    border: 1px solid rgba(216, 222, 232, 0.92);
    border-radius: 8px;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.98), rgba(248, 251, 255, 0.92) 58%, rgba(255, 248, 230, 0.18)),
        var(--tch-surface);
    box-shadow: 0 16px 38px rgba(16, 24, 32, 0.075);
    transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.tch-category-card::before {
    display: block;
    width: 100%;
    height: 0.45rem;
    background: linear-gradient(90deg, var(--tch-accent), var(--tch-gold));
    content: "";
}

.tch-category-card:hover {
    border-color: rgba(11, 74, 143, 0.36);
    box-shadow: 0 24px 58px rgba(16, 24, 32, 0.13);
    transform: translateY(-3px);
}

.tch-category-card__link {
    display: grid;
    min-height: 15rem;
    height: 100%;
    gap: 0.9rem;
    align-content: start;
    padding: 1.6rem;
    color: var(--tch-text);
    text-decoration: none;
}

.tch-category-card__link:hover {
    background: rgba(247, 251, 255, 0.72);
    color: var(--tch-text);
}

.tch-category-card__meta {
    color: #34465a;
    font-size: 0.875rem;
    font-weight: 760;
    text-transform: uppercase;
}

.tch-category-card__title {
    margin-bottom: 0;
    font-size: 1.65rem;
    overflow-wrap: anywhere;
}

.tch-category-card__description {
    margin-bottom: 0;
    color: var(--tch-muted);
    overflow-wrap: anywhere;
}

.tch-category-card__footer {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    align-self: end;
    align-items: center;
}

.tch-count-badge {
    justify-self: start;
    align-self: end;
    min-height: 2.35rem;
    padding: 0.4rem 0.75rem;
    border-radius: 999px;
    background: var(--tch-blue-soft);
    color: var(--tch-accent-dark);
    font-size: 0.9375rem;
    font-weight: 760;
    line-height: 1.2;
}

.tch-count-badge.is-empty {
    border: 1px solid rgba(75, 85, 99, 0.18);
    background: #f3f5f8;
    color: #4b5563;
}

.tch-subcount-badge {
    min-height: 2.35rem;
    padding: 0.4rem 0.75rem;
    border: 1px solid rgba(216, 222, 232, 0.95);
    border-radius: 999px;
    background: #fff;
    color: var(--tch-muted);
    font-size: 0.9375rem;
    font-weight: 720;
    line-height: 1.2;
}

.tch-location-section {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(18rem, 1.35fr);
    gap: clamp(1.5rem, 4vw, 3rem);
    align-items: center;
    padding: clamp(1.5rem, 4vw, 2.25rem);
    margin-top: 4.5rem;
    margin-bottom: 4rem;
    border: 1px solid rgba(216, 222, 232, 0.95);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(232, 241, 251, 0.72), rgba(255, 255, 255, 0.96) 45%, rgba(255, 248, 230, 0.72)),
        var(--tch-surface);
    box-shadow: 0 18px 48px rgba(16, 24, 32, 0.08);
}

.tch-location-section::before {
    position: absolute;
    inset: 1rem auto 1rem 0;
    width: 0.32rem;
    border-radius: 0 999px 999px 0;
    background: linear-gradient(180deg, var(--tch-accent), var(--tch-gold));
    content: "";
}

.tch-location-section + .tch-list-section {
    padding-top: 0;
}

.tch-location-section .tch-section-heading {
    margin-bottom: 0;
}

.tch-location-section .tch-section-heading p:last-child {
    max-width: 36rem;
    margin-bottom: 0;
    color: var(--tch-muted);
}

.tch-location-nav {
    position: relative;
    display: grid;
    gap: 0.85rem;
    min-width: 0;
    padding: 0;
}

.tch-location-search {
    position: relative;
}

.tch-location-search input[type="search"] {
    width: 100%;
    min-height: 3rem;
    padding: 0.72rem 1rem;
    border: 1px solid rgba(11, 74, 143, 0.22);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.92);
    color: var(--tch-text);
    font: inherit;
    font-size: 1rem;
    box-shadow: 0 10px 24px rgba(16, 24, 32, 0.055);
}

.tch-location-search input[type="search"]::placeholder {
    color: #5b6675;
    opacity: 1;
}

.tch-location-search input[type="search"]:focus-visible {
    border-color: var(--tch-accent);
    outline: 3px solid var(--tch-focus);
    outline-offset: 3px;
}

.tch-location-list {
    position: absolute;
    z-index: 8;
    top: calc(100% + 0.55rem);
    right: 0;
    left: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 12rem), 1fr));
    gap: 0.55rem;
    max-height: 14rem;
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior: contain;
    padding: 0.75rem;
    margin: 0;
    border: 1px solid rgba(11, 74, 143, 0.18);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.98);
    box-shadow: 0 20px 44px rgba(16, 24, 32, 0.14);
    list-style: none;
    scrollbar-width: thin;
}

.tch-location-list[hidden] {
    display: none;
}

.tch-location-list li[hidden] {
    display: none;
}

.tch-location-empty {
    position: absolute;
    z-index: 8;
    top: calc(100% + 0.55rem);
    right: 0;
    left: 0;
    margin: 0;
    padding: 0.85rem 1rem;
    border: 1px dashed rgba(11, 74, 143, 0.26);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.98);
    box-shadow: 0 16px 34px rgba(16, 24, 32, 0.1);
    color: var(--tch-muted);
    font-size: 1rem;
    line-height: 1.45;
}

.tch-location-chip {
    display: inline-flex;
    box-sizing: border-box;
    width: 100%;
    min-width: 0;
    min-height: 2.65rem;
    align-items: center;
    justify-content: space-between;
    gap: 0.65rem;
    padding: 0.5rem 0.55rem 0.5rem 0.8rem;
    border: 1px solid rgba(11, 74, 143, 0.24);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.94);
    color: var(--tch-text);
    text-decoration: none;
    box-shadow: none;
    transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, background-color 180ms ease;
}

.tch-location-chip:hover {
    border-color: rgba(11, 74, 143, 0.52);
    background: #fff;
    color: var(--tch-text);
    box-shadow: 0 10px 22px rgba(16, 24, 32, 0.09);
    transform: translateY(-1px);
}

.tch-location-chip:focus-visible {
    outline: 3px solid var(--tch-focus);
    outline-offset: 3px;
}

.tch-location-chip__name {
    min-width: 0;
    color: var(--tch-accent-dark);
    font-weight: 800;
    line-height: 1.25;
    overflow-wrap: anywhere;
}

.tch-location-chip__count {
    display: inline-flex;
    flex: 0 0 auto;
    min-height: 2rem;
    align-items: center;
    padding: 0.25rem 0.62rem;
    border-radius: 999px;
    background: var(--tch-blue-soft);
    color: var(--tch-accent-dark);
    font-size: 0.9rem;
    font-weight: 760;
    white-space: nowrap;
}

.tch-subcategory-section {
    padding-top: 2rem;
}

.tch-subcategory-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 13rem), 1fr));
    gap: 0.75rem;
    padding: 0;
    margin: 0;
    list-style: none;
}

.tch-subcategory-card {
    display: grid;
    min-height: 7rem;
    height: 100%;
    gap: 0.45rem;
    align-content: start;
    padding: 1rem;
    border: 1px solid rgba(216, 222, 232, 0.95);
    border-radius: 8px;
    background: var(--tch-surface);
    color: var(--tch-text);
    text-decoration: none;
    box-shadow: 0 8px 22px rgba(16, 24, 32, 0.055);
    transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.tch-subcategory-card:hover {
    border-color: rgba(11, 74, 143, 0.36);
    color: var(--tch-text);
    box-shadow: 0 18px 40px rgba(16, 24, 32, 0.1);
    transform: translateY(-2px);
}

.tch-subcategory-card__title {
    color: var(--tch-text);
    font-size: 1.16rem;
    font-weight: 760;
    line-height: 1.25;
    hyphens: auto;
    overflow-wrap: anywhere;
}

.tch-subcategory-card__description {
    color: var(--tch-muted);
    font-size: 0.95rem;
    line-height: 1.45;
    overflow-wrap: anywhere;
}

.tch-subcategory-card .tch-count-badge {
    margin-top: auto;
}

.tch-entry-list {
    display: grid;
    gap: 1.5rem;
    padding: 0;
    margin: 0;
    list-style: none;
}

.tch-latest-section {
    padding-block: 0 3rem;
}

.tch-latest-section .tch-section-heading p:last-child {
    max-width: 44rem;
    margin-bottom: 0;
    color: var(--tch-muted);
}

.tch-latest-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
    padding: 0;
    margin: 0;
    list-style: none;
}

.tch-latest-card {
    position: relative;
    display: grid;
    grid-template-rows: auto 1fr;
    height: 100%;
    overflow: hidden;
    border: 1px solid rgba(216, 222, 232, 0.94);
    border-radius: 8px;
    background: var(--tch-surface);
    box-shadow: 0 18px 44px rgba(16, 24, 32, 0.09);
    transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.tch-latest-card::before {
    position: absolute;
    inset: 0 0 auto;
    height: 0.4rem;
    background: linear-gradient(90deg, var(--tch-accent), var(--tch-gold));
    content: "";
}

.tch-latest-card.is-premium {
    border-color: rgba(184, 137, 34, 0.74);
    background:
        linear-gradient(135deg, rgba(255, 248, 230, 0.58), rgba(255, 255, 255, 0.98) 45%),
        var(--tch-surface);
}

.tch-latest-card:hover {
    border-color: rgba(11, 74, 143, 0.34);
    box-shadow: 0 24px 56px rgba(16, 24, 32, 0.14);
    transform: translateY(-2px);
}

.tch-latest-card__media {
    display: grid;
    height: clamp(10rem, 12vw, 11.5rem);
    overflow: hidden;
    place-items: center;
    background: var(--tch-soft);
    color: var(--tch-muted);
    text-decoration: none;
}

.tch-latest-card__image {
    display: block;
    width: 100%;
    height: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
}

.tch-latest-card__body {
    display: grid;
    grid-template-rows: auto auto 1fr auto;
    gap: 0.9rem;
    min-width: 0;
    padding: 1.25rem;
}

.tch-latest-card__topline {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
    justify-content: space-between;
    color: var(--tch-muted);
    font-size: 0.86rem;
    font-weight: 760;
    line-height: 1.35;
    text-transform: uppercase;
}

.tch-latest-card__topline .tch-premium-badge {
    min-height: 1.9rem;
    padding: 0.25rem 0.55rem;
    font-size: 0.78rem;
}

.tch-latest-card__title {
    min-width: 0;
    margin-bottom: 0;
    font-size: clamp(1.12rem, 1.12vw, 1.22rem);
    line-height: 1.28;
    hyphens: none;
    overflow-wrap: break-word;
    word-break: normal;
}

.tch-latest-card__title a {
    color: var(--tch-text);
    text-decoration-thickness: 0.08em;
    hyphens: none;
    overflow-wrap: break-word;
    word-break: normal;
}

.tch-latest-card__summary {
    min-width: 0;
    margin-bottom: 0;
    color: var(--tch-muted);
    font-size: 1rem;
    line-height: 1.6;
    overflow-wrap: anywhere;
}

.tch-card__microfact {
    display: inline-flex;
    justify-self: start;
    min-height: 2rem;
    align-items: center;
    margin-bottom: 0;
    padding: 0.28rem 0.62rem;
    border: 1px solid rgba(11, 74, 143, 0.16);
    border-radius: 999px;
    background: rgba(232, 241, 251, 0.78);
    color: var(--tch-accent-dark);
    font-size: 0.9rem;
    font-weight: 760;
    line-height: 1.25;
}

.tch-latest-card__body > .tch-button {
    align-self: end;
    width: 100%;
    margin-top: 0.25rem;
}

.tch-entry-card {
    position: relative;
    display: grid;
    grid-template-columns: minmax(13rem, 18rem) minmax(0, 1fr);
    gap: 1.5rem;
    overflow: hidden;
    padding: 1.25rem;
    border: 1px solid rgba(216, 222, 232, 0.92);
    border-radius: 8px;
    background: var(--tch-surface);
    box-shadow: 0 14px 36px rgba(16, 24, 32, 0.08);
    transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.tch-entry-card:hover {
    border-color: rgba(11, 74, 143, 0.34);
    box-shadow: 0 22px 52px rgba(16, 24, 32, 0.13);
    transform: translateY(-2px);
}

.tch-entry-list__item.is-premium .tch-entry-card {
    border-color: rgba(184, 137, 34, 0.88);
    background:
        linear-gradient(135deg, rgba(255, 248, 230, 0.72), rgba(255, 255, 255, 0.98) 38%),
        var(--tch-surface);
    box-shadow: 0 22px 56px rgba(16, 24, 32, 0.14);
}

.tch-entry-list__item.is-premium .tch-entry-card::before {
    position: absolute;
    inset: 0 0 auto;
    height: 0.45rem;
    background: linear-gradient(90deg, var(--tch-gold), var(--tch-accent));
    content: "";
}

.tch-entry-card__media {
    display: grid;
    place-items: center;
    min-height: 11rem;
    overflow: hidden;
    border: 1px solid var(--tch-border);
    border-radius: 8px;
    background: var(--tch-soft);
    color: var(--tch-muted);
    text-decoration: none;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.5);
}

.tch-entry-card__image {
    display: block;
    width: 100%;
    height: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
}

.tch-entry-card__placeholder,
.tch-listing-placeholder {
    position: relative;
    isolation: isolate;
    display: grid;
    width: 100%;
    height: 100%;
    min-height: 11rem;
    place-items: center;
    gap: 0.65rem;
    overflow: hidden;
    padding: 1.15rem;
    background:
        linear-gradient(115deg, rgba(232, 241, 251, 0.96) 0 31%, transparent 31.2%),
        linear-gradient(135deg, #ffffff 0%, #f7fbff 52%, #fff8e6 100%);
    color: var(--tch-accent-dark);
    font-size: 1rem;
    font-weight: 780;
    line-height: 1.3;
    text-align: center;
}

.tch-listing-placeholder::before {
    position: absolute;
    inset: 0;
    z-index: -2;
    background:
        linear-gradient(90deg, rgba(11, 74, 143, 0.08) 1px, transparent 1px),
        linear-gradient(0deg, rgba(11, 74, 143, 0.06) 1px, transparent 1px);
    background-size: 3rem 3rem;
    opacity: 0.5;
    content: "";
}

.tch-listing-placeholder::after {
    position: absolute;
    inset: auto 0 0;
    z-index: -1;
    height: 0.35rem;
    background: linear-gradient(90deg, var(--tch-accent), var(--tch-gold));
    content: "";
}

.tch-listing-placeholder__mark {
    display: inline-grid;
    width: 4rem;
    height: 4rem;
    place-items: center;
    border: 1px solid rgba(11, 74, 143, 0.22);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.92);
    color: var(--tch-accent-dark);
    font-size: 1.18rem;
    font-weight: 860;
    letter-spacing: 0.02em;
    box-shadow: 0 12px 26px rgba(16, 24, 32, 0.1);
}

.tch-listing-placeholder__label {
    display: block;
    max-width: 14rem;
    color: var(--tch-text);
    overflow-wrap: break-word;
}

.tch-listing-placeholder.is-free-basic .tch-listing-placeholder__mark {
    border-color: rgba(184, 137, 34, 0.34);
    color: #513709;
}

.tch-latest-card__media .tch-listing-placeholder {
    min-height: 100%;
}

.tch-entry-card__body {
    display: grid;
    gap: 1.25rem;
    align-content: start;
}

.tch-entry-card__header {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    justify-content: space-between;
}

.tch-entry-card__badges {
    display: flex;
    flex: 0 0 auto;
    flex-wrap: wrap;
    gap: 0.5rem;
    justify-content: flex-end;
}

.tch-entry-card__facts {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    padding: 0;
    margin: -0.25rem 0 0;
    list-style: none;
}

.tch-entry-card__facts li {
    display: inline-flex;
    min-height: 2rem;
    align-items: center;
    padding: 0.28rem 0.62rem;
    border: 1px solid rgba(216, 222, 232, 0.96);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.88);
    color: var(--tch-muted);
    font-size: 0.9rem;
    font-weight: 720;
    line-height: 1.25;
}

.tch-entry-card__title-wrap {
    min-width: 0;
}

.tch-card {
    display: grid;
    gap: 1.25rem;
    padding: 1.75rem;
    border: 1px solid var(--tch-border);
    border-radius: 8px;
    background: var(--tch-surface);
    box-shadow: 0 14px 34px rgba(16, 24, 32, 0.07);
}

.tch-list__item.is-premium .tch-card {
    border-color: rgba(184, 137, 34, 0.72);
    box-shadow: 0 18px 42px rgba(16, 24, 32, 0.1);
}

.tch-card__header,
.tch-detail-hero__inner {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1.25rem;
}

.tch-card__title-wrap {
    min-width: 0;
}

.tch-card__title {
    margin-bottom: 0;
}

.tch-card__title a {
    color: var(--tch-text);
    text-decoration-thickness: 0.08em;
}

.tch-card__eyebrow {
    margin-bottom: 0.4rem;
    color: var(--tch-muted);
    font-size: 0.9375rem;
    font-weight: 700;
}

.tch-card__summary {
    max-width: 54rem;
    margin-bottom: 0;
    color: var(--tch-muted);
}

.tch-card__footer {
    display: flex;
    align-items: center;
    justify-content: flex-start;
}

.tch-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    min-height: 3rem;
    padding: 0.72rem 1.1rem;
    border: 1px solid var(--tch-accent);
    border-radius: 8px;
    background: var(--tch-surface);
    color: var(--tch-accent);
    font-size: 1rem;
    font-weight: 720;
    line-height: 1.2;
    text-decoration: none;
    cursor: pointer;
}

.tch-button__label {
    display: inline-block;
    color: currentColor;
    -webkit-text-fill-color: currentColor;
}

.tch-button:hover {
    border-color: var(--tch-accent-dark);
    background: #f1f6ff;
    color: var(--tch-accent-dark);
}

.tch-button--primary {
    border-color: var(--tch-accent);
    background:
        linear-gradient(180deg, #125da8, var(--tch-accent));
    color: #ffffff;
    box-shadow: 0 14px 28px rgba(11, 74, 143, 0.22);
}

.tch-site-main a.tch-button.tch-button--primary,
.tch-site-main a.tch-button.tch-button--primary:visited {
    border-color: var(--tch-accent) !important;
    background:
        linear-gradient(180deg, #125da8, var(--tch-accent)) !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff;
}

.tch-site-main a.tch-button.tch-button--primary .tch-button__label,
.tch-site-main a.tch-button.tch-button--primary:visited .tch-button__label {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff;
}

.tch-button--primary:hover,
.tch-site-main a.tch-button.tch-button--primary:hover {
    border-color: var(--tch-accent-dark);
    background:
        linear-gradient(180deg, #0f559d, var(--tch-accent-dark));
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff;
    box-shadow: 0 16px 34px rgba(11, 74, 143, 0.28);
}

.tch-button--quiet {
    border-color: rgba(12, 55, 101, 0.24);
    background: #ffffff;
    color: var(--tch-accent-dark);
}

.tch-button--quiet:hover {
    border-color: var(--tch-accent-dark);
    background: #f7fbff;
    color: var(--tch-accent-dark);
}

.tch-site-main a.tch-button.tch-button--primary:focus-visible {
    outline: 3px solid var(--tch-focus);
    outline-offset: 4px;
    box-shadow: 0 0 0 6px rgba(245, 165, 36, 0.22);
}

.tch-badge {
    display: inline-flex;
    flex: 0 0 auto;
    align-items: center;
    min-height: 2.25rem;
    padding: 0.42rem 0.72rem;
    border: 1px solid rgba(15, 81, 50, 0.25);
    border-radius: 999px;
    background: var(--tch-success-soft);
    color: var(--tch-success);
    font-size: 0.875rem;
    font-weight: 780;
    line-height: 1.2;
    white-space: nowrap;
    box-shadow: 0 8px 20px rgba(15, 81, 50, 0.09);
}

.tch-badge--large {
    margin-top: 0.35rem;
}

.tch-premium-badge {
    display: inline-flex;
    flex: 0 0 auto;
    align-items: center;
    min-height: 2.25rem;
    padding: 0.42rem 0.72rem;
    border: 1px solid rgba(98, 71, 14, 0.22);
    border-radius: 999px;
    background: linear-gradient(135deg, #fff8e6, #f5df9a);
    color: #3f2b05;
    font-size: 0.875rem;
    font-weight: 820;
    line-height: 1.2;
    white-space: normal;
    box-shadow: 0 10px 24px rgba(98, 71, 14, 0.13);
}

.tch-premium-badge--soft {
    border-color: rgba(11, 74, 143, 0.22);
    background: rgba(232, 241, 251, 0.9);
    color: var(--tch-accent-dark);
}

.tch-detail-hero__content {
    min-width: 0;
}

.tch-detail-hero__badges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    max-width: 100%;
    margin: 0 0 1rem;
}

.tch-detail-hero__lead {
    max-width: 48rem;
    margin-bottom: 0;
    color: var(--tch-muted);
    font-size: 1.25rem;
    line-height: 1.65;
}

.tch-quick-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1.4rem;
}

.tch-quick-actions .tch-button {
    box-shadow: 0 14px 32px rgba(16, 24, 32, 0.1);
}

.tch-quick-actions .tch-button--primary {
    min-width: 12rem;
}

.tch-quick-actions .tch-button--visit {
    position: relative;
    min-width: 14rem;
    overflow: hidden;
    border-color: #083766 !important;
    background:
        linear-gradient(135deg, #06345f 0%, #0b4a8f 58%, #104f86 100%) !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff;
    box-shadow:
        inset 0 -0.25rem 0 rgba(184, 137, 34, 0.95),
        0 18px 38px rgba(11, 74, 143, 0.24);
}

.tch-quick-actions .tch-button--visit::after {
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, transparent 0%, rgba(255, 255, 255, 0.18) 44%, transparent 72%);
    content: "";
    opacity: 0;
    transform: translateX(-40%);
    transition: opacity 160ms ease, transform 220ms ease;
}

.tch-quick-actions .tch-button--visit:hover,
.tch-quick-actions .tch-button--visit:active {
    border-color: #062c50 !important;
    background:
        linear-gradient(135deg, #05294b 0%, #073f78 58%, #0b4a8f 100%) !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff;
    box-shadow:
        inset 0 -0.25rem 0 rgba(184, 137, 34, 1),
        0 22px 46px rgba(11, 74, 143, 0.32);
    transform: translateY(-1px);
}

.tch-quick-actions .tch-button--visit:hover::after,
.tch-quick-actions .tch-button--visit:active::after {
    opacity: 1;
    transform: translateX(34%);
}

.tch-language-switch {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    max-width: 100%;
    margin-top: 1rem;
    padding: 0.35rem;
    border: 1px solid rgba(11, 74, 143, 0.18);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.84);
    box-shadow: 0 12px 28px rgba(16, 24, 32, 0.08);
}

.tch-language-switch__label {
    padding-inline: 0.55rem 0.25rem;
    color: var(--tch-muted);
    font-size: 0.88rem;
    font-weight: 800;
    line-height: 1.2;
    text-transform: uppercase;
}

.tch-language-switch__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.2rem;
    padding: 0.42rem 0.78rem;
    border: 1px solid transparent;
    border-radius: 999px;
    color: var(--tch-accent-dark);
    font-size: 0.96rem;
    font-weight: 780;
    line-height: 1.2;
    text-decoration: none;
    transition: background-color 160ms ease, border-color 160ms ease, color 160ms ease, transform 160ms ease;
}

.tch-language-switch__link:visited {
    color: var(--tch-accent-dark);
}

.tch-language-switch__link:hover,
.tch-language-switch__link:active,
.tch-language-switch__link:focus-visible,
.tch-language-switch__link.is-active,
.tch-language-switch__link[aria-current="page"] {
    border-color: rgba(8, 65, 126, 0.5);
    background: #0b4a8f;
    color: #ffffff !important;
}

.tch-language-switch__link:hover:visited,
.tch-language-switch__link:active:visited,
.tch-language-switch__link:focus-visible:visited,
.tch-language-switch__link.is-active:visited,
.tch-language-switch__link[aria-current="page"]:visited {
    color: #ffffff !important;
}

.tch-language-switch__link:focus-visible {
    outline: 3px solid var(--tch-focus);
    outline-offset: 3px;
}

.tch-detail-hero h1 {
    max-width: min(100%, 24ch);
    font-size: clamp(2.45rem, 4.8vw, 3.15rem);
    line-height: 1.08;
    hyphens: none;
    overflow-wrap: break-word;
    word-break: normal;
}

.tch-detail-hero__inner.has-media {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(18rem, 31rem);
    align-items: center;
}

.tch-detail-hero__media {
    position: relative;
    margin: 0;
    overflow: hidden;
    border: 1px solid rgba(216, 222, 232, 0.94);
    border-radius: 8px;
    background: var(--tch-surface);
    box-shadow: 0 24px 60px rgba(16, 24, 32, 0.18);
}

.tch-detail-hero__image {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 10;
    height: auto;
    object-fit: cover;
}

.tch-detail-hero__media--placeholder {
    display: grid;
    min-height: clamp(14rem, 25vw, 21rem);
}

.tch-detail-hero__media--placeholder .tch-listing-placeholder {
    min-height: 100%;
    aspect-ratio: 16 / 10;
}

.tch-detail-hero__media--placeholder .tch-listing-placeholder__mark {
    width: 5.25rem;
    height: 5.25rem;
    font-size: 1.45rem;
}

.tch-detail-hero__media--placeholder .tch-listing-placeholder__label {
    font-size: 1.08rem;
}

.tch-detail-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(18rem, 24rem);
    gap: 2rem;
    align-items: start;
    padding-block: 4rem;
}

.tch-entry-jump-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
    padding: 1rem 0 0;
}

.tch-entry-jump-nav__label {
    color: var(--tch-muted);
    font-size: 0.88rem;
    font-weight: 800;
    line-height: 1.2;
    text-transform: uppercase;
}

.tch-entry-jump-nav__list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    padding: 0;
    margin: 0;
    list-style: none;
}

.tch-entry-jump-nav a {
    display: inline-flex;
    min-height: 2.35rem;
    align-items: center;
    padding: 0.42rem 0.72rem;
    border: 1px solid rgba(11, 74, 143, 0.2);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.9);
    color: var(--tch-accent-dark);
    font-size: 0.94rem;
    font-weight: 760;
    line-height: 1.2;
    text-decoration: none;
    box-shadow: 0 10px 22px rgba(16, 24, 32, 0.055);
}

.tch-entry-jump-nav a:hover {
    border-color: rgba(11, 74, 143, 0.45);
    background: var(--tch-blue-soft);
    color: var(--tch-accent-dark);
}

.tch-detail-content,
.tch-review-panel {
    min-width: 0;
}

.tch-content-section + .tch-content-section {
    margin-top: 1.5rem;
}

.tch-content-section {
    max-width: 50rem;
    padding: 1.8rem;
    border: 1px solid rgba(216, 222, 232, 0.92);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 16px 38px rgba(16, 24, 32, 0.07);
}

.tch-content-section.tch-review-panel {
    border-color: rgba(184, 137, 34, 0.48);
    background:
        linear-gradient(135deg, rgba(255, 248, 230, 0.96), rgba(255, 255, 255, 0.94) 52%, rgba(255, 248, 230, 0.78)),
        #fffaf0;
    box-shadow: 0 18px 42px rgba(83, 60, 13, 0.12);
}

.tch-content-section h2 {
    margin-bottom: 1rem;
    font-size: 1.75rem;
}

.tch-content-section .tch-rich-content,
.tch-content-section .tch-review-content {
    max-width: none;
}

.tch-review-badge {
    display: inline-flex;
    align-items: center;
    min-height: 2.35rem;
    padding: 0.45rem 0.8rem;
    margin-bottom: 1.1rem;
    border: 1px solid rgba(11, 74, 143, 0.22);
    border-radius: 999px;
    background: rgba(232, 241, 251, 0.92);
    color: var(--tch-accent-dark);
    font-size: 0.92rem;
    font-weight: 800;
    line-height: 1.2;
    text-transform: uppercase;
    box-shadow: 0 10px 24px rgba(16, 24, 32, 0.08);
}

.tch-review-panel .tch-review-badge {
    border-color: rgba(184, 137, 34, 0.38);
    background: rgba(255, 248, 230, 0.94);
    color: #513709;
}

.tch-rich-content,
.tch-review-content {
    max-width: 46rem;
    color: var(--tch-text);
}

.tch-rich-content :where(ul, ol),
.tch-review-content :where(ul, ol) {
    padding-left: 1.25rem;
}

.tch-rich-content :where(li + li),
.tch-review-content :where(li + li) {
    margin-top: 0.4rem;
}

.tch-gallery {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 15rem), 1fr));
    gap: 0.85rem;
    padding: 0;
    margin: 0;
    list-style: none;
}

.tch-gallery__figure {
    margin: 0;
    border-radius: 8px;
}

.tch-gallery__link,
.tch-detail-hero__link {
    display: block;
    color: inherit;
    text-decoration: none;
}

.tch-gallery__link {
    position: relative;
    display: grid;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    border: 1px solid var(--tch-border);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(232, 241, 251, 0.78), rgba(255, 255, 255, 0.96) 54%, rgba(255, 248, 230, 0.7));
    box-shadow: 0 12px 28px rgba(16, 24, 32, 0.08);
    transition: border-color 160ms ease, box-shadow 160ms ease, filter 160ms ease;
}

.tch-gallery__link::before {
    position: absolute;
    inset: -0.75rem;
    background-image: linear-gradient(rgba(255, 255, 255, 0.34), rgba(255, 255, 255, 0.5)), var(--tch-gallery-bg);
    background-position: center;
    background-size: cover;
    content: "";
    filter: blur(16px) saturate(1.04);
    opacity: 0.48;
    transform: scale(1.06);
}

.tch-gallery__image {
    position: relative;
    z-index: 1;
    display: block;
    width: 100%;
    aspect-ratio: 4 / 3;
    height: 100%;
    border: 0;
    border-radius: 0;
    object-fit: contain;
    object-position: center;
    background: transparent;
}

.tch-gallery__caption {
    margin-top: 0.65rem;
    color: var(--tch-muted);
    font-size: 0.95rem;
    font-weight: 650;
    line-height: 1.45;
}

.tch-gallery__link:hover .tch-gallery__image {
    filter: saturate(1.04) contrast(1.03);
}

.tch-gallery__link:hover {
    border-color: rgba(11, 74, 143, 0.34);
    box-shadow: 0 16px 34px rgba(16, 24, 32, 0.12);
}

.tch-detail-hero__link:hover .tch-detail-hero__image {
    filter: saturate(1.04) contrast(1.03);
    transform: scale(1.015);
}

body.tch-lightbox-open {
    overflow: hidden;
}

.tch-lightbox[hidden] {
    display: none;
}

.tch-lightbox {
    position: fixed;
    z-index: 99999;
    inset: 0;
    display: grid;
    place-items: center;
    padding: 1.25rem;
}

.tch-lightbox__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(16, 24, 32, 0.88);
}

.tch-lightbox__panel {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 3rem minmax(0, 1fr) 3rem;
    gap: 1rem;
    align-items: center;
    width: min(100%, 76rem);
}

.tch-lightbox__figure {
    min-width: 0;
    margin: 0;
}

.tch-lightbox__image {
    display: block;
    max-width: 100%;
    max-height: min(78vh, 56rem);
    width: auto;
    height: auto;
    margin-inline: auto;
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.45);
}

.tch-lightbox__caption {
    margin-top: 0.85rem;
    color: #ffffff;
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.4;
    text-align: center;
}

.tch-lightbox__close,
.tch-lightbox__nav {
    appearance: none;
    -webkit-appearance: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    border: 1px solid rgba(255, 255, 255, 0.34);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.94);
    color: var(--tch-text) !important;
    font: inherit;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-size: 2rem;
    font-weight: 820;
    line-height: 1;
    text-align: center;
    text-decoration: none;
    -webkit-text-fill-color: var(--tch-text);
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.24);
    cursor: pointer;
    transition: background-color 160ms ease, border-color 160ms ease, color 160ms ease, transform 160ms ease, box-shadow 160ms ease;
}

.tch-lightbox__close span,
.tch-lightbox__nav span {
    display: block;
    color: currentColor !important;
    line-height: 1;
    pointer-events: none;
    -webkit-text-fill-color: currentColor;
}

.tch-lightbox__close:hover,
.tch-lightbox__close:active,
.tch-lightbox__nav:hover,
.tch-lightbox__nav:active {
    border-color: rgba(255, 255, 255, 0.78) !important;
    background: #ffffff !important;
    color: var(--tch-text) !important;
    -webkit-text-fill-color: var(--tch-text);
    transform: translateY(-1px);
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.34);
}

.tch-lightbox__close {
    position: absolute;
    top: -4rem;
    right: 0;
    border-color: #0b4a8f !important;
    background: #0b4a8f !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff;
}

.tch-lightbox__close:hover,
.tch-lightbox__close:active {
    border-color: #07345f !important;
    background: #07345f !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff;
}

.tch-lightbox__close:focus-visible,
.tch-lightbox__nav:focus-visible {
    outline: 3px solid #f5a524 !important;
    outline-offset: 4px;
    box-shadow: 0 0 0 6px rgba(245, 165, 36, 0.24), 0 18px 42px rgba(0, 0, 0, 0.34);
}

.tch-social-section {
    max-width: 50rem;
    padding: 1.8rem;
    margin-top: 1.5rem;
    border: 1px solid rgba(216, 222, 232, 0.92);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 16px 38px rgba(16, 24, 32, 0.07);
}

.tch-social-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    padding: 0;
    margin: 1rem 0 0;
    list-style: none;
}

.tch-social-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.875rem;
    padding: 0.72rem 1rem;
    border: 1px solid transparent;
    border-radius: 8px;
    color: #ffffff !important;
    font-size: 1rem;
    font-weight: 780;
    line-height: 1.15;
    text-decoration: none;
    box-shadow: 0 14px 28px rgba(16, 24, 32, 0.14);
    transition: transform 160ms ease, box-shadow 160ms ease, filter 160ms ease;
}

.tch-social-button:visited,
.tch-social-button:hover,
.tch-social-button:active {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff;
}

.tch-social-button:hover,
.tch-social-button:active {
    filter: saturate(1.05) contrast(1.08);
    transform: translateY(-1px);
    box-shadow: 0 18px 36px rgba(16, 24, 32, 0.18);
}

.tch-social-button:focus-visible {
    outline: 3px solid var(--tch-focus);
    outline-offset: 3px;
}

.tch-social-button--facebook {
    background: #0b4a8f;
}

.tch-social-button--instagram {
    background: linear-gradient(135deg, #5b2a86 0%, #8f1f5b 48%, #9f1239 100%);
}

.tch-social-button--tiktok {
    border-color: rgba(37, 244, 238, 0.55);
    background: #111827;
    box-shadow: inset 0 -3px 0 rgba(254, 44, 85, 0.72), 0 14px 28px rgba(16, 24, 32, 0.14);
}

.tch-social-button--youtube {
    background: #b91c1c;
}

.tch-keyfacts {
    position: sticky;
    top: 1.5rem;
    padding: 1.5rem;
    border: 1px solid rgba(184, 137, 34, 0.52);
    border-radius: 8px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(255, 248, 230, 0.96)),
        var(--tch-gold-soft);
    box-shadow: 0 20px 46px rgba(16, 24, 32, 0.12);
}

.tch-keyfacts h2 {
    margin-bottom: 0.65rem;
    font-size: 1.5rem;
}

.tch-keyfacts__intro {
    margin-bottom: 1rem;
    color: #4d3920;
    font-size: 1rem;
    line-height: 1.55;
}

.tch-owner-actions {
    margin-top: 1.25rem;
    padding-top: 1.15rem;
    border-top: 1px solid rgba(184, 137, 34, 0.24);
}

.tch-owner-actions h3 {
    margin: 0 0 0.45rem;
    font-size: 1.05rem;
    line-height: 1.25;
}

.tch-owner-actions p {
    margin: 0 0 0.9rem;
    color: #4d3920;
    font-size: 0.96rem;
    line-height: 1.5;
}

.tch-owner-actions__buttons {
    display: grid;
    gap: 0.65rem;
}

.tch-owner-actions__buttons > .tch-button {
    width: 100%;
    min-height: 3.15rem;
    text-align: center;
}

.tch-report-entry {
    margin-top: 1.25rem;
    padding-top: 1.15rem;
    border-top: 1px solid rgba(184, 137, 34, 0.24);
}

.tch-report-entry h3 {
    margin: 0 0 0.45rem;
    font-size: 1.05rem;
    line-height: 1.25;
}

.tch-report-entry p {
    margin: 0 0 0.9rem;
    color: #4d3920;
    font-size: 0.96rem;
    line-height: 1.5;
}

.tch-report-entry__message {
    padding: 0.72rem 0.85rem;
    border: 1px solid transparent;
    border-radius: 8px;
    font-weight: 700;
}

.tch-report-entry__message.is-success {
    border-color: rgba(15, 81, 50, 0.28);
    background: var(--tch-success-soft);
    color: var(--tch-success);
}

.tch-report-entry__message.is-error {
    border-color: rgba(153, 27, 27, 0.26);
    background: #fff1f2;
    color: #7f1d1d;
}

.tch-report-entry__details > summary {
    width: 100%;
    list-style: none;
}

.tch-report-entry__details > summary::-webkit-details-marker {
    display: none;
}

.tch-report-entry__form {
    display: grid;
    gap: 0.8rem;
    margin-top: 0.9rem;
}

.tch-report-entry__field {
    display: grid;
    gap: 0.35rem;
}

.tch-report-entry__field label {
    color: #344154;
    font-size: 0.92rem;
    font-weight: 760;
}

.tch-report-entry__field input,
.tch-report-entry__field textarea {
    width: 100%;
    border: 1px solid rgba(11, 74, 143, 0.28);
    border-radius: 8px;
    background: #ffffff;
    color: var(--tch-text);
    font: inherit;
}

.tch-report-entry__field input {
    min-height: 2.8rem;
    padding: 0.65rem 0.75rem;
}

.tch-report-entry__field textarea {
    min-height: 7.5rem;
    padding: 0.75rem;
    resize: vertical;
}

.tch-report-entry__field input:focus-visible,
.tch-report-entry__field textarea:focus-visible {
    outline: 3px solid var(--tch-focus);
    outline-offset: 2px;
    border-color: var(--tch-accent);
}

.tch-report-entry__honeypot {
    position: absolute;
    left: -10000px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.tch-facts-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0 0.65rem;
    color: var(--tch-text);
    font-size: 1rem;
    line-height: 1.5;
    table-layout: auto;
}

.tch-facts-table tbody,
.tch-facts-table tr,
.tch-facts-table th,
.tch-facts-table td {
    display: block;
    width: 100%;
}

.tch-facts-table th,
.tch-facts-table td {
    border-top: 0;
    vertical-align: top;
}

.tch-facts-table th {
    padding: 0.82rem 0.95rem 0.15rem;
    border: 1px solid rgba(216, 222, 232, 0.92);
    border-bottom: 0;
    border-radius: 8px 8px 0 0;
    background: rgba(255, 255, 255, 0.88);
    color: var(--tch-muted);
    font-size: 0.88rem;
    letter-spacing: 0;
    text-align: left;
    font-weight: 820;
    text-transform: uppercase;
}

.tch-facts-table td {
    padding: 0.12rem 0.95rem 0.9rem;
    border: 1px solid rgba(216, 222, 232, 0.92);
    border-top: 0;
    border-radius: 0 0 8px 8px;
    background: rgba(255, 255, 255, 0.88);
    overflow-wrap: anywhere;
    box-shadow: 0 10px 24px rgba(16, 24, 32, 0.05);
}

.tch-facts-link,
.tch-facts-phone {
    color: var(--tch-accent);
    overflow-wrap: anywhere;
    text-decoration-thickness: 0.08em;
    text-underline-offset: 0.2em;
    word-break: break-word;
}

.tch-facts-phone {
    font-weight: 820;
}

a.tch-facts-link:hover,
a.tch-facts-phone:hover {
    color: var(--tch-accent-dark);
}

.tch-single {
    background:
        linear-gradient(180deg, rgba(246, 248, 251, 0.86), rgba(255, 255, 255, 0.98) 34rem),
        #ffffff;
}

.tch-single .tch-container {
    width: min(calc(100% - 2rem), 76rem);
}

.tch-single .tch-detail-hero {
    background:
        radial-gradient(circle at 84% 22%, rgba(184, 137, 34, 0.16), transparent 28rem),
        radial-gradient(circle at 8% 8%, rgba(11, 74, 143, 0.14), transparent 25rem),
        linear-gradient(115deg, rgba(232, 241, 251, 0.95) 0 19%, transparent 19.1%),
        linear-gradient(100deg, #ffffff 0%, #f8fbff 48%, #fff8e6 100%);
}

.tch-single .tch-detail-hero__inner {
    padding-block: clamp(3.4rem, 6vw, 5.5rem);
}

.tch-detail-hero__content {
    position: relative;
    padding: clamp(1.4rem, 2.8vw, 2.15rem);
    border: 1px solid rgba(255, 255, 255, 0.72);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.76);
    box-shadow: 0 24px 70px rgba(16, 24, 32, 0.12);
    -webkit-backdrop-filter: blur(3px);
    backdrop-filter: blur(3px);
}

.tch-company-logo {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    max-width: min(100%, 18rem);
    min-width: 6rem;
    min-height: 4rem;
    padding: 0.65rem 0.9rem;
    margin: 0 0 1rem;
    border: 1px solid rgba(216, 222, 232, 0.96);
    border-radius: 8px;
    background: linear-gradient(180deg, #ffffff, #f8fafc);
    box-shadow: 0 18px 42px rgba(16, 24, 32, 0.08);
}

.tch-company-logo__image {
    display: block;
    width: auto;
    max-width: 100%;
    max-height: 4.8rem;
    object-fit: contain;
}

.tch-detail-hero__facts {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    padding: 0;
    margin: 1.15rem 0 0;
    list-style: none;
}

.tch-detail-hero__facts li {
    display: inline-grid;
    grid-template-columns: auto auto;
    gap: 0.45rem;
    align-items: baseline;
    max-width: 100%;
    min-height: 2.35rem;
    padding: 0.42rem 0.72rem;
    border: 1px solid rgba(11, 74, 143, 0.18);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.9);
    box-shadow: 0 10px 24px rgba(16, 24, 32, 0.06);
}

.tch-detail-hero__facts span {
    color: var(--tch-muted);
    font-size: 0.84rem;
    font-weight: 800;
    line-height: 1.2;
    text-transform: uppercase;
}

.tch-detail-hero__facts strong {
    min-width: 0;
    color: var(--tch-accent-dark);
    font-size: 0.98rem;
    font-weight: 820;
    line-height: 1.2;
    overflow-wrap: anywhere;
}

.tch-service-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem 0.7rem;
    align-items: center;
    max-width: 100%;
    margin-top: 1rem;
}

.tch-service-tags__label {
    color: var(--tch-muted);
    font-size: 0.84rem;
    font-weight: 820;
    line-height: 1.2;
    text-transform: uppercase;
}

.tch-service-tags ul {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    padding: 0;
    margin: 0;
    list-style: none;
}

.tch-service-tags li {
    display: inline-flex;
    align-items: center;
    min-height: 2.1rem;
    padding: 0.32rem 0.68rem;
    border: 1px solid rgba(11, 74, 143, 0.18);
    border-radius: 999px;
    color: var(--tch-accent-dark);
    font-size: 0.94rem;
    font-weight: 760;
    line-height: 1.2;
    background: rgba(255, 255, 255, 0.86);
    box-shadow: 0 10px 24px rgba(16, 24, 32, 0.06);
}

@media (max-width: 38rem) {
    .tch-service-tags {
        flex-direction: column;
        align-items: flex-start;
    }
}

.tch-detail-hero__media {
    border-color: rgba(184, 137, 34, 0.34);
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(232, 241, 251, 0.82)),
        var(--tch-surface);
    box-shadow:
        0 26px 68px rgba(16, 24, 32, 0.2),
        0 0 0 0.45rem rgba(255, 255, 255, 0.55);
}

.tch-detail-hero__media::after {
    position: absolute;
    inset: auto 0 0;
    height: 0.38rem;
    background: linear-gradient(90deg, var(--tch-accent), var(--tch-gold));
    content: "";
}

.tch-entry-jump-nav {
    position: relative;
    margin-top: -1.35rem;
    padding: 0.85rem 1rem;
    border: 1px solid rgba(216, 222, 232, 0.9);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 16px 38px rgba(16, 24, 32, 0.08);
}

.tch-detail-content {
    display: grid;
    gap: 1.4rem;
}

.tch-content-section {
    position: relative;
    max-width: none;
    overflow: hidden;
    border-color: rgba(216, 222, 232, 0.86);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(255, 255, 255, 0.92)),
        var(--tch-surface);
    box-shadow: 0 18px 46px rgba(16, 24, 32, 0.075);
}

.tch-content-section + .tch-content-section {
    margin-top: 0;
}

.tch-content-section::before {
    position: absolute;
    inset: 0 auto 0 0;
    width: 0.28rem;
    background: linear-gradient(180deg, rgba(11, 74, 143, 0.88), rgba(184, 137, 34, 0.88));
    content: "";
    opacity: 0.78;
}

.tch-content-section.tch-review-panel {
    padding: clamp(1.6rem, 3vw, 2.25rem);
    border-color: rgba(184, 137, 34, 0.58);
    background:
        radial-gradient(circle at 92% 14%, rgba(184, 137, 34, 0.14), transparent 14rem),
        linear-gradient(135deg, rgba(255, 248, 230, 0.98), rgba(255, 255, 255, 0.96) 46%, rgba(255, 251, 239, 0.95)),
        #fffaf0;
    box-shadow: 0 22px 52px rgba(83, 60, 13, 0.14);
}

.tch-content-section.tch-review-panel::before {
    width: 0.42rem;
    background: linear-gradient(180deg, var(--tch-gold), var(--tch-accent));
    opacity: 1;
}

.tch-review-panel .tch-rich-content {
    color: #251a08;
    font-size: 1.16rem;
    line-height: 1.75;
}

.tch-review-panel .tch-rich-content p:last-child,
.tch-content-section .tch-rich-content p:last-child {
    margin-bottom: 0;
}

.tch-review-badge {
    letter-spacing: 0;
}

.tch-review-panel .tch-review-badge {
    border-color: rgba(184, 137, 34, 0.48);
    background: #fff4d1;
    color: #3f2b05;
    box-shadow: 0 12px 28px rgba(98, 71, 14, 0.13);
}

.tch-content-section[aria-labelledby="tch-gallery-title"] {
    padding: clamp(1.35rem, 2.6vw, 1.8rem);
}

.tch-gallery {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.tch-gallery__item--lead {
    grid-column: 1 / -1;
}

.tch-gallery__item--lead .tch-gallery__link {
    aspect-ratio: 16 / 9;
}

.tch-gallery__link {
    border-color: rgba(216, 222, 232, 0.84);
    background:
        radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.38), rgba(255, 255, 255, 0.86)),
        var(--tch-gallery-bg),
        linear-gradient(135deg, rgba(232, 241, 251, 0.78), rgba(255, 248, 230, 0.74));
    background-position: center;
    background-size: cover;
    box-shadow: 0 16px 36px rgba(16, 24, 32, 0.1);
}

.tch-gallery__image {
    padding: 0.35rem;
}

.tch-keyfacts {
    overflow: hidden;
    border-color: rgba(184, 137, 34, 0.6);
    background:
        radial-gradient(circle at 94% 6%, rgba(184, 137, 34, 0.16), transparent 13rem),
        linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(255, 248, 230, 0.94)),
        var(--tch-gold-soft);
}

.tch-keyfacts::before {
    position: absolute;
    inset: 0 0 auto;
    height: 0.42rem;
    background: linear-gradient(90deg, var(--tch-accent), var(--tch-gold));
    content: "";
}

.tch-keyfacts h2 {
    padding-top: 0.35rem;
}

.tch-facts-table {
    border-spacing: 0;
}

.tch-facts-table tbody {
    display: grid;
    gap: 0.75rem;
}

.tch-facts-table tr {
    display: grid;
    grid-template-columns: 3.4rem minmax(0, 1fr);
    overflow: hidden;
    border: 1px solid rgba(216, 222, 232, 0.92);
    border-left: 0.28rem solid rgba(11, 74, 143, 0.86);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.88);
    box-shadow: 0 12px 26px rgba(16, 24, 32, 0.055);
}

.tch-facts-table th,
.tch-facts-table td {
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.tch-facts-table th {
    display: grid;
    align-items: center;
    justify-content: center;
    min-width: 0;
    padding: 0.72rem 0.5rem;
    color: #344154;
    hyphens: auto;
    overflow-wrap: anywhere;
    word-break: normal;
}

.tch-facts-table td {
    display: flex;
    align-items: center;
    min-width: 0;
    padding: 0.85rem 0.95rem;
    color: var(--tch-text);
    font-weight: 560;
}

.tch-fact-icon {
    display: inline-grid;
    width: 2.2rem;
    height: 2.2rem;
    place-items: center;
    border: 1px solid rgba(11, 74, 143, 0.18);
    border-radius: 999px;
    background:
        linear-gradient(135deg, rgba(232, 241, 251, 0.96), rgba(255, 255, 255, 0.96));
    color: var(--tch-accent-dark);
    box-shadow: 0 8px 18px rgba(16, 24, 32, 0.06);
}

.tch-fact-icon svg {
    display: block;
    width: 1.18rem;
    height: 1.18rem;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.85;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.tch-social-section {
    max-width: none;
    border-color: rgba(216, 222, 232, 0.86);
    background:
        linear-gradient(135deg, rgba(232, 241, 251, 0.6), rgba(255, 255, 255, 0.96) 48%, rgba(255, 248, 230, 0.5)),
        var(--tch-surface);
}

.tch-status {
    display: inline-flex;
    align-items: center;
    min-height: 1.75rem;
    padding: 0.18rem 0.55rem;
    border-radius: 999px;
    font-weight: 760;
}

.tch-status.is-positive {
    background: var(--tch-success-soft);
    color: var(--tch-success);
}

.tch-status.is-muted {
    background: #eef1f5;
    color: #374151;
}

.tch-pagination {
    margin-top: 2.5rem;
}

.tch-pagination .nav-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

.tch-pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.75rem;
    min-height: 2.75rem;
    padding: 0.45rem 0.75rem;
    border: 1px solid var(--tch-border);
    border-radius: 8px;
    background: var(--tch-surface);
    color: var(--tch-text);
    text-decoration: none;
}

.tch-pagination .page-numbers.current {
    border-color: var(--tch-accent);
    background: var(--tch-accent);
    color: #ffffff;
}

.tch-empty-state {
    max-width: 42rem;
    padding: 2rem;
    border: 1px solid var(--tch-border);
    border-radius: 8px;
    background: var(--tch-soft);
}

.tch-info-page {
    padding: 3.5rem 0 4.5rem;
}

.tch-info-page__hero {
    max-width: 58rem;
    padding-bottom: 2.25rem;
    margin-bottom: 2.75rem;
    border-bottom: 1px solid var(--tch-border);
}

.tch-info-page__lead {
    max-width: 54rem;
    color: var(--tch-muted);
    font-size: 1.25rem;
    line-height: 1.7;
}

.tch-info-section {
    max-width: 58rem;
    margin-top: 2.75rem;
}

.tch-info-section:first-child {
    margin-top: 0;
}

.tch-info-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 17rem), 1fr));
    gap: 1rem;
    padding: 0;
    margin: 1.5rem 0 0;
    list-style: none;
}

.tch-info-card {
    padding: 1.2rem;
    border: 1px solid var(--tch-border);
    border-radius: 8px;
    background: var(--tch-surface);
    box-shadow: 0 12px 28px rgba(16, 24, 32, 0.07);
}

.tch-info-card strong {
    display: block;
    margin-bottom: 0.4rem;
    color: var(--tch-text);
}

.tch-info-card p {
    margin-bottom: 0;
    color: var(--tch-muted);
    font-size: 1rem;
    line-height: 1.6;
}

.tch-service-panel {
    padding: 1.5rem;
    border: 1px solid rgba(11, 74, 143, 0.22);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(232, 241, 251, 0.92), rgba(255, 248, 230, 0.66)),
        var(--tch-surface);
    box-shadow: 0 16px 36px rgba(16, 24, 32, 0.08);
}

.tch-upgrade-body .entry-title {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.tch-upgrade-body .site-content .ast-container,
.tch-upgrade-body .entry-content {
    max-width: 100% !important;
    overflow-x: hidden;
}

.tch-upgrade-page {
    box-sizing: border-box;
    width: min(calc(100vw - 2rem), 72rem) !important;
    max-width: calc(100vw - 2rem) !important;
    padding: 2.25rem 0 4.5rem;
    margin-inline: auto !important;
}

.tch-upgrade-page *,
.tch-upgrade-page *::before,
.tch-upgrade-page *::after {
    box-sizing: border-box;
}

.tch-upgrade-hero {
    position: relative;
    overflow: hidden;
    padding: clamp(2rem, 5vw, 4rem);
    border: 1px solid rgba(216, 222, 232, 0.92);
    border-radius: 8px;
    background:
        linear-gradient(115deg, rgba(232, 241, 251, 0.96) 0 24%, transparent 24.1%),
        linear-gradient(100deg, #ffffff 0%, #f8fbff 54%, #fff8e6 100%);
    box-shadow: 0 26px 70px rgba(16, 24, 32, 0.12);
}

.tch-upgrade-hero::before {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(11, 74, 143, 0.08) 1px, transparent 1px),
        linear-gradient(0deg, rgba(11, 74, 143, 0.06) 1px, transparent 1px);
    background-size: 5rem 5rem;
    opacity: 0.34;
    content: "";
}

.tch-upgrade-hero::after {
    position: absolute;
    inset: auto 0 0;
    height: 0.45rem;
    background: linear-gradient(90deg, var(--tch-accent), var(--tch-gold));
    content: "";
}

.tch-upgrade-hero > * {
    position: relative;
    z-index: 1;
}

.tch-upgrade-hero h1 {
    max-width: 17ch;
    font-size: clamp(2.45rem, 4.5vw, 4rem);
    line-height: 1.04;
}

.tch-upgrade-hero__lead {
    max-width: 55rem;
    color: var(--tch-muted);
    font-size: 1.24rem;
    line-height: 1.72;
}

.tch-upgrade-hero__actions,
.tch-upgrade-pill-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
    margin-top: 1.35rem;
}

.tch-upgrade-pill-row span {
    display: inline-flex;
    min-height: 2.6rem;
    align-items: center;
    padding: 0.42rem 0.9rem;
    border: 1px solid rgba(11, 74, 143, 0.22);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.9);
    color: var(--tch-accent-dark);
    font-size: 0.96rem;
    font-weight: 790;
    box-shadow: 0 10px 24px rgba(16, 24, 32, 0.06);
}

.tch-upgrade-section {
    margin-top: clamp(2.75rem, 6vw, 4rem);
}

.tch-upgrade-section > p {
    max-width: 58rem;
    color: var(--tch-muted);
}

.tch-upgrade-compare {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    margin-top: 1.35rem;
}

.tch-upgrade-plan {
    position: relative;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    padding: clamp(1.35rem, 3vw, 2rem);
    border: 1px solid rgba(216, 222, 232, 0.94);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 18px 42px rgba(16, 24, 32, 0.08);
}

.tch-upgrade-plan::before {
    position: absolute;
    inset: 0 0 auto;
    height: 0.32rem;
    background: var(--tch-accent);
    content: "";
}

.tch-upgrade-plan--popular {
    border-color: rgba(11, 74, 143, 0.48);
    box-shadow: 0 24px 58px rgba(11, 74, 143, 0.13);
}

.tch-upgrade-plan--popular::before {
    background: linear-gradient(90deg, var(--tch-accent), var(--tch-gold));
}

.tch-upgrade-plan--premium {
    border-color: rgba(184, 137, 34, 0.55);
    background:
        linear-gradient(135deg, rgba(255, 248, 230, 0.92), rgba(255, 255, 255, 0.95) 46%, rgba(232, 241, 251, 0.72)),
        #ffffff;
    box-shadow: 0 24px 58px rgba(83, 60, 13, 0.13);
}

.tch-upgrade-plan--premium::before {
    background: linear-gradient(90deg, var(--tch-gold), var(--tch-accent));
}

.tch-upgrade-plan__label {
    display: inline-flex;
    min-height: 2rem;
    width: fit-content;
    align-items: center;
    padding: 0.24rem 0.68rem;
    border-radius: 999px;
    background: var(--tch-blue-soft);
    color: var(--tch-accent-dark);
    font-size: 0.82rem;
    font-weight: 820;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.tch-upgrade-plan__topline {
    display: flex;
    min-height: 2rem;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
    justify-content: space-between;
}

.tch-upgrade-plan__badge {
    display: inline-flex;
    min-height: 2rem;
    align-items: center;
    padding: 0.24rem 0.68rem;
    border-radius: 999px;
    background: var(--tch-accent-dark);
    color: #ffffff;
    font-size: 0.82rem;
    font-weight: 820;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    box-shadow: 0 10px 22px rgba(11, 74, 143, 0.22);
}

.tch-upgrade-plan--premium .tch-upgrade-plan__label {
    background: var(--tch-gold-soft);
    color: #513709;
}

.tch-upgrade-plan h3 {
    min-height: 4.75rem;
    margin: 0.9rem 0 0;
    font-size: clamp(1.55rem, 3vw, 2.05rem);
    line-height: 1.15;
}

.tch-upgrade-plan p {
    min-height: 10.25rem;
    margin: 0.9rem 0 0;
    color: var(--tch-muted);
    font-size: 1.04rem;
    line-height: 1.62;
}

.tch-upgrade-list {
    display: grid;
    flex: 1 1 auto;
    align-content: start;
    gap: 0.7rem;
    padding: 0;
    margin: 1.1rem 0 0;
    list-style: none;
}

.tch-upgrade-list li {
    position: relative;
    min-height: 1.55rem;
    padding-left: 1.7rem;
    color: var(--tch-text);
    font-size: 1rem;
    font-weight: 650;
    line-height: 1.5;
}

.tch-upgrade-list li::before {
    position: absolute;
    top: 0.52em;
    left: 0;
    display: inline-grid;
    width: 0.72rem;
    height: 0.72rem;
    place-items: center;
    border-radius: 999px;
    content: "";
}

.tch-upgrade-list .tch-upgrade-list__item--included::before {
    background: #147a45;
    box-shadow: 0 0 0 3px rgba(20, 122, 69, 0.12);
}

.tch-upgrade-list .tch-upgrade-list__item--missing {
    color: #4d1f1f;
}

.tch-upgrade-list .tch-upgrade-list__item--missing::before {
    top: 0.18em;
    width: 1.08rem;
    height: 1.08rem;
    background: #b42318;
    color: #ffffff;
    content: "\00d7";
    font-size: 0.92rem;
    font-weight: 900;
    line-height: 1;
    box-shadow: 0 0 0 3px rgba(180, 35, 24, 0.12);
}

.tch-upgrade-price {
    display: grid;
    min-height: 15.45rem;
    align-content: start;
    gap: 0.24rem;
    padding: 1rem;
    margin-top: 1.45rem;
    border: 1px solid rgba(11, 74, 143, 0.18);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(232, 241, 251, 0.9), rgba(255, 255, 255, 0.96)),
        #ffffff;
    box-shadow: 0 12px 28px rgba(16, 24, 32, 0.08);
}

.tch-upgrade-plan--premium .tch-upgrade-price {
    border-color: rgba(184, 137, 34, 0.38);
    background:
        linear-gradient(135deg, rgba(255, 248, 230, 0.96), rgba(255, 255, 255, 0.95)),
        #ffffff;
}

.tch-upgrade-price__eyebrow {
    color: var(--tch-muted);
    font-size: 0.78rem;
    font-weight: 820;
    letter-spacing: 0.04em;
    line-height: 1.2;
    text-transform: uppercase;
}

.tch-upgrade-price strong {
    display: flex;
    min-height: 4.75rem;
    align-items: center;
    color: var(--tch-text);
    font-size: clamp(1.8rem, 3.2vw, 2.45rem);
    line-height: 1.05;
}

.tch-upgrade-price span:last-child {
    color: var(--tch-muted);
    font-size: 0.94rem;
    line-height: 1.45;
}

.tch-upgrade-price-note {
    max-width: 62rem;
    padding: 0.95rem 1rem;
    margin: 1rem 0 0;
    border: 1px solid rgba(216, 222, 232, 0.95);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.86);
    color: var(--tch-muted);
    font-size: 0.95rem;
    line-height: 1.55;
}

.tch-upgrade-ai-bridge {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(18rem, 0.36fr);
    gap: clamp(1.25rem, 4vw, 2.5rem);
    align-items: center;
    padding: clamp(1.35rem, 4vw, 2.35rem);
    border: 1px solid rgba(11, 74, 143, 0.24);
    border-radius: 8px;
    background:
        linear-gradient(115deg, rgba(232, 241, 251, 0.9) 0 24%, transparent 24.1%),
        linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(255, 248, 230, 0.72)),
        #ffffff;
    box-shadow: 0 20px 48px rgba(16, 24, 32, 0.09);
}

.tch-upgrade-ai-bridge h2 {
    max-width: 24ch;
    font-size: clamp(1.85rem, 3.6vw, 2.7rem);
    line-height: 1.12;
    hyphens: none;
    overflow-wrap: normal;
}

.tch-upgrade-ai-bridge p {
    max-width: 58rem;
    color: var(--tch-muted);
    font-size: 1.1rem;
    line-height: 1.72;
}

.tch-upgrade-ai-bridge__contact {
    display: grid;
    gap: 0.9rem;
    padding: 1rem;
    border: 1px solid rgba(184, 137, 34, 0.36);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.88);
    box-shadow: 0 14px 32px rgba(16, 24, 32, 0.08);
}

.tch-upgrade-ai-bridge__contact span {
    color: var(--tch-muted);
    font-size: 0.86rem;
    font-weight: 820;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.tch-upgrade-ai-bridge__contact .tch-button {
    width: 100%;
    padding-inline: 0.85rem;
    white-space: nowrap;
}

.tch-upgrade-card-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    padding: 0;
    margin: 1.5rem 0 0;
    list-style: none;
}

.tch-upgrade-card {
    min-height: 12rem;
    padding: 1.2rem;
    border: 1px solid var(--tch-border);
    border-radius: 8px;
    background: var(--tch-surface);
    box-shadow: 0 14px 34px rgba(16, 24, 32, 0.08);
}

.tch-upgrade-card strong {
    display: block;
    margin-bottom: 0.5rem;
    color: var(--tch-text);
    font-size: 1.08rem;
}

.tch-upgrade-card p {
    margin: 0;
    color: var(--tch-muted);
    font-size: 1rem;
    line-height: 1.62;
}

.tch-upgrade-note,
.tch-upgrade-cta {
    padding: clamp(1.35rem, 4vw, 2.25rem);
    border: 1px solid rgba(11, 74, 143, 0.2);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(232, 241, 251, 0.88), rgba(255, 255, 255, 0.96) 48%, rgba(255, 248, 230, 0.74)),
        var(--tch-surface);
    box-shadow: 0 16px 38px rgba(16, 24, 32, 0.08);
}

.tch-upgrade-cta {
    border-color: rgba(184, 137, 34, 0.46);
    background: var(--tch-gold-soft);
}

.tch-upgrade-cta p {
    max-width: 48rem;
}

.tch-upgrade-cta__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1.25rem;
}

.tch-ai-search-body .entry-title {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.tch-ai-search-page {
    width: min(calc(100vw - 2rem), 70rem);
    max-width: calc(100vw - 2rem);
    margin-inline: auto;
    padding: 2.25rem 0 4.5rem;
}

.tch-ai-hero {
    position: relative;
    overflow: hidden;
    padding: clamp(2rem, 5vw, 4rem);
    border: 1px solid rgba(216, 222, 232, 0.92);
    border-radius: 8px;
    background:
        linear-gradient(115deg, rgba(232, 241, 251, 0.96) 0 23%, transparent 23.1%),
        linear-gradient(100deg, #ffffff 0%, #f7fbff 55%, #fff8e6 100%);
    box-shadow: 0 24px 64px rgba(16, 24, 32, 0.12);
}

.tch-ai-hero::before {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(11, 74, 143, 0.08) 1px, transparent 1px),
        linear-gradient(0deg, rgba(11, 74, 143, 0.06) 1px, transparent 1px);
    background-size: 5rem 5rem;
    opacity: 0.34;
    content: "";
}

.tch-ai-hero::after {
    position: absolute;
    inset: auto 0 0;
    height: 0.45rem;
    background: linear-gradient(90deg, var(--tch-accent), var(--tch-gold));
    content: "";
}

.tch-ai-hero > * {
    position: relative;
    z-index: 1;
}

.tch-ai-hero h1 {
    max-width: 22ch;
    font-size: clamp(2.2rem, 4vw, 3.35rem);
    line-height: 1.1;
}

.tch-ai-hero__lead {
    max-width: 50rem;
    color: var(--tch-muted);
    font-size: 1.24rem;
    line-height: 1.72;
}

.tch-ai-alert {
    max-width: 56rem;
    padding: 1.35rem 1.5rem;
    margin-top: 1.5rem;
    border: 1px solid rgba(184, 137, 34, 0.46);
    border-radius: 8px;
    background: rgba(255, 248, 230, 0.88);
    color: #3f2b05;
    font-weight: 680;
    line-height: 1.65;
}

.tch-ai-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1.5rem;
}

.tch-ai-section {
    margin-top: clamp(2.75rem, 6vw, 4rem);
}

.tch-ai-section > p {
    max-width: 54rem;
    color: var(--tch-muted);
}

.tch-ai-source {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    align-items: baseline;
    padding: 0.85rem 1rem;
    margin-top: 0.35rem;
    border: 1px solid rgba(11, 74, 143, 0.2);
    border-radius: 8px;
    background: rgba(232, 241, 251, 0.68);
    color: var(--tch-text);
    font-weight: 650;
}

.tch-ai-source a {
    color: var(--tch-accent);
    text-decoration-thickness: 0.12em;
    text-underline-offset: 0.18em;
}

.tch-ai-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    padding: 0;
    margin: 1.5rem 0 0;
    list-style: none;
}

.tch-ai-card {
    position: relative;
    min-height: 14rem;
    overflow: hidden;
    padding: 1.25rem;
    border: 1px solid var(--tch-border);
    border-radius: 8px;
    background: var(--tch-surface);
    box-shadow: 0 14px 34px rgba(16, 24, 32, 0.08);
}

.tch-ai-card::before {
    position: absolute;
    inset: 0 0 auto;
    height: 0.32rem;
    background: linear-gradient(90deg, var(--tch-accent), var(--tch-gold));
    content: "";
}

.tch-ai-card h3 {
    margin-bottom: 0.65rem;
}

.tch-ai-card p {
    color: var(--tch-muted);
    font-size: 1rem;
    line-height: 1.62;
}

.tch-ai-split {
    display: grid;
    grid-template-columns: minmax(0, 0.82fr) minmax(0, 1fr);
    gap: 2rem;
    align-items: start;
    padding: clamp(1.5rem, 4vw, 2.5rem);
    margin-top: clamp(2.75rem, 6vw, 4rem);
    border: 1px solid rgba(11, 74, 143, 0.18);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(232, 241, 251, 0.96), rgba(255, 248, 230, 0.62)),
        var(--tch-surface);
}

.tch-ai-checks {
    display: grid;
    gap: 0.75rem;
    padding: 0;
    margin: 0;
    list-style: none;
}

.tch-ai-checks li {
    padding: 0.9rem 1rem;
    border: 1px solid rgba(216, 222, 232, 0.96);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.9);
    color: var(--tch-text);
    font-weight: 650;
}

.tch-ai-final {
    max-width: 62rem;
    padding: clamp(1.5rem, 4vw, 2.5rem);
    margin-top: clamp(2.75rem, 6vw, 4rem);
    border: 1px solid rgba(184, 137, 34, 0.52);
    border-radius: 8px;
    background: var(--tch-gold-soft);
    box-shadow: 0 20px 46px rgba(16, 24, 32, 0.1);
}

.tch-ai-final p {
    max-width: 50rem;
    color: var(--tch-muted);
}

.tch-webdesign-body .entry-title {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.tch-webdesign-body .site-content .ast-container,
.tch-webdesign-body .entry-content {
    max-width: 100% !important;
    overflow-x: hidden;
}

.tch-webdesign-page {
    box-sizing: border-box;
    width: min(calc(100vw - 2rem), 70rem) !important;
    max-width: calc(100vw - 2rem) !important;
    margin-inline: auto !important;
    overflow-x: clip;
    padding: 2.25rem 0 4.5rem;
}

.tch-webdesign-page *,
.tch-webdesign-page *::before,
.tch-webdesign-page *::after {
    box-sizing: border-box;
}

.tch-webdesign-hero {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1.04fr) minmax(19rem, 0.72fr);
    gap: clamp(2rem, 5vw, 4rem);
    align-items: center;
    overflow: hidden;
    padding: clamp(2rem, 5vw, 4rem);
    border: 1px solid rgba(216, 222, 232, 0.9);
    border-radius: 8px;
    background:
        linear-gradient(115deg, rgba(232, 241, 251, 0.95) 0 24%, transparent 24.1%),
        linear-gradient(100deg, #ffffff 0%, #f7fbff 54%, #fff8e6 100%);
    box-shadow: 0 26px 70px rgba(16, 24, 32, 0.12);
}

.tch-webdesign-hero::before {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(11, 74, 143, 0.08) 1px, transparent 1px),
        linear-gradient(0deg, rgba(11, 74, 143, 0.06) 1px, transparent 1px);
    background-size: 5rem 5rem;
    opacity: 0.34;
    content: "";
}

.tch-webdesign-hero::after {
    position: absolute;
    inset: auto 0 0;
    height: 0.45rem;
    background: linear-gradient(90deg, var(--tch-accent), var(--tch-gold));
    content: "";
}

.tch-webdesign-hero__content,
.tch-webdesign-visual {
    position: relative;
    z-index: 1;
    min-width: 0;
}

.tch-webdesign-hero h1 {
    max-width: 13ch;
    font-size: clamp(2.4rem, 5vw, 4.5rem);
}

.tch-webdesign-hero__lead {
    max-width: 44rem;
    color: var(--tch-muted);
    font-size: 1.25rem;
    line-height: 1.72;
    overflow-wrap: break-word;
}

.tch-webdesign-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1.5rem;
}

.tch-webdesign-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    padding: 0;
    margin: 1.5rem 0 0;
    list-style: none;
}

.tch-webdesign-chips li {
    min-height: 2.35rem;
    padding: 0.42rem 0.75rem;
    border: 1px solid rgba(11, 74, 143, 0.2);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.86);
    color: var(--tch-accent-dark);
    font-size: 0.96rem;
    font-weight: 760;
    box-shadow: 0 10px 24px rgba(16, 24, 32, 0.08);
}

.tch-webdesign-visual {
    display: grid;
    align-items: center;
    justify-items: end;
    margin: 0;
}

.tch-webdesign-graphic {
    display: block;
    width: min(100%, 35rem);
    height: auto;
    border-radius: 8px;
    filter: drop-shadow(0 28px 48px rgba(16, 24, 32, 0.18));
}

.tch-webdesign-visual--portrait {
    justify-items: center;
}

.tch-webdesign-portrait {
    width: min(100%, 18rem);
    aspect-ratio: 259 / 300;
    object-fit: cover;
    border: 1px solid rgba(216, 222, 232, 0.96);
    background: #ffffff;
    box-shadow:
        0 26px 54px rgba(16, 24, 32, 0.18),
        0 0 0 0.65rem rgba(255, 255, 255, 0.72);
}

.tch-browser-card {
    width: min(100%, 25rem);
    overflow: hidden;
    border: 1px solid rgba(216, 222, 232, 0.94);
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 30px 70px rgba(16, 24, 32, 0.2);
}

.tch-browser-card__bar {
    display: flex;
    gap: 0.38rem;
    padding: 0.85rem;
    border-bottom: 1px solid var(--tch-border);
    background: #f6f8fb;
}

.tch-browser-card__bar span {
    width: 0.68rem;
    height: 0.68rem;
    border-radius: 999px;
    background: var(--tch-border);
}

.tch-browser-card__bar span:nth-child(1) {
    background: var(--tch-gold);
}

.tch-browser-card__bar span:nth-child(2) {
    background: var(--tch-accent);
}

.tch-browser-card__bar span:nth-child(3) {
    background: var(--tch-success);
}

.tch-browser-card__hero {
    height: 9rem;
    margin: 1rem;
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(11, 74, 143, 0.88), rgba(184, 137, 34, 0.74)),
        linear-gradient(90deg, rgba(255, 255, 255, 0.22) 1px, transparent 1px);
    background-size: auto, 2.5rem 2.5rem;
}

.tch-browser-card__lines {
    display: grid;
    gap: 0.65rem;
    padding: 0 1rem 1rem;
}

.tch-browser-card__lines span {
    display: block;
    height: 0.72rem;
    border-radius: 999px;
    background: #e8eef6;
}

.tch-browser-card__lines span:nth-child(1) {
    width: 78%;
}

.tch-browser-card__lines span:nth-child(2) {
    width: 92%;
}

.tch-browser-card__lines span:nth-child(3) {
    width: 58%;
}

.tch-browser-card__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.7rem;
    padding: 0 1rem 1rem;
}

.tch-browser-card__grid span {
    aspect-ratio: 1;
    border-radius: 8px;
    background: var(--tch-blue-soft);
}

.tch-webdesign-stats,
.tch-webdesign-split,
.tch-webdesign-final-cta {
    margin-top: 2rem;
    border-radius: 8px;
}

.tch-webdesign-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1px;
    overflow: hidden;
    border: 1px solid var(--tch-border);
    background: var(--tch-border);
    box-shadow: 0 16px 36px rgba(16, 24, 32, 0.08);
}

.tch-webdesign-stats div {
    padding: 1.25rem;
    background: var(--tch-surface);
}

.tch-webdesign-stats strong,
.tch-webdesign-stats span {
    display: block;
}

.tch-webdesign-stats strong {
    color: var(--tch-text);
    font-size: 1.35rem;
    line-height: 1.2;
}

.tch-webdesign-stats span {
    color: var(--tch-muted);
    font-size: 1rem;
}

.tch-webdesign-section {
    margin-top: clamp(2.75rem, 6vw, 4.5rem);
}

.tch-webdesign-section h2,
.tch-webdesign-split h2,
.tch-webdesign-final-cta h2 {
    max-width: 18ch;
}

.tch-webdesign-final-cta h2 {
    max-width: 22ch;
    hyphens: none;
    word-break: keep-all;
    overflow-wrap: normal;
}

.tch-webdesign-card-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
    padding: 0;
    margin: 1.5rem 0 0;
    list-style: none;
}

.tch-webdesign-card {
    position: relative;
    min-height: 16rem;
    padding: 1.25rem;
    overflow: hidden;
    border: 1px solid var(--tch-border);
    border-radius: 8px;
    background: var(--tch-surface);
    box-shadow: 0 14px 32px rgba(16, 24, 32, 0.08);
}

.tch-webdesign-card::before {
    position: absolute;
    inset: 0 0 auto;
    height: 0.32rem;
    background: linear-gradient(90deg, var(--tch-accent), var(--tch-gold));
    content: "";
}

.tch-webdesign-card span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.4rem;
    min-height: 2.4rem;
    margin-bottom: 1.35rem;
    border-radius: 999px;
    background: var(--tch-blue-soft);
    color: var(--tch-accent-dark);
    font-weight: 820;
}

.tch-webdesign-card h3 {
    margin-bottom: 0.7rem;
}

.tch-webdesign-card p {
    color: var(--tch-muted);
    font-size: 1rem;
    line-height: 1.62;
}

.tch-webdesign-split {
    display: grid;
    grid-template-columns: minmax(0, 0.8fr) minmax(0, 1fr);
    gap: 2rem;
    align-items: start;
    padding: clamp(1.5rem, 4vw, 2.5rem);
    border: 1px solid rgba(11, 74, 143, 0.18);
    background:
        linear-gradient(135deg, rgba(232, 241, 251, 0.96), rgba(255, 248, 230, 0.62)),
        var(--tch-surface);
}

.tch-webdesign-split p {
    color: var(--tch-muted);
}

.tch-webdesign-checks {
    display: grid;
    gap: 0.75rem;
    padding: 0;
    margin: 0;
    list-style: none;
}

.tch-webdesign-checks li {
    padding: 0.9rem 1rem;
    border: 1px solid rgba(216, 222, 232, 0.96);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.88);
    color: var(--tch-text);
    font-weight: 650;
}

.tch-webdesign-final-cta {
    max-width: 60rem;
    padding: clamp(1.5rem, 4vw, 2.5rem);
    border: 1px solid rgba(184, 137, 34, 0.52);
    background: var(--tch-gold-soft);
    box-shadow: 0 20px 46px rgba(16, 24, 32, 0.1);
}

.tch-webdesign-final-cta p {
    max-width: 46rem;
    color: var(--tch-muted);
}

.tch-premium-limit-callout {
    position: relative;
    max-width: 64rem;
    overflow: hidden;
    padding: clamp(1.5rem, 4vw, 2.25rem);
    border: 1px solid rgba(184, 137, 34, 0.72);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(255, 248, 230, 0.94), rgba(232, 241, 251, 0.82)),
        var(--tch-surface);
    box-shadow: 0 24px 64px rgba(16, 24, 32, 0.14);
}

.tch-premium-limit-callout::before {
    position: absolute;
    inset: 0 0 auto;
    height: 0.55rem;
    background: linear-gradient(90deg, var(--tch-gold), var(--tch-accent));
    content: "";
}

.tch-premium-limit-callout h2 {
    max-width: 18ch;
    margin-bottom: 1rem;
    font-size: clamp(2rem, 4vw, 3rem);
    line-height: 1.08;
}

.tch-premium-limit-callout p {
    max-width: 48rem;
    color: var(--tch-text);
    font-size: 1.16rem;
    line-height: 1.65;
}

.tch-premium-limit-callout p:last-child {
    margin-bottom: 0;
}

.tch-check-list {
    padding-left: 1.2rem;
}

.tch-check-list li + li {
    margin-top: 0.55rem;
}

.tch-faq {
    display: grid;
    gap: 0.8rem;
}

.tch-faq details {
    border: 1px solid var(--tch-border);
    border-radius: 8px;
    background: var(--tch-surface);
    box-shadow: 0 10px 24px rgba(16, 24, 32, 0.06);
}

.tch-faq summary {
    cursor: pointer;
    padding: 1rem 1.15rem;
    color: var(--tch-text);
    font-weight: 760;
    line-height: 1.45;
}

.tch-faq summary:focus-visible {
    outline: 3px solid var(--tch-focus);
    outline-offset: 4px;
    border-radius: 4px;
}

.tch-faq details > div {
    padding: 0 1.15rem 1.15rem;
    color: var(--tch-text);
}

.tch-faq details > div p:last-child {
    margin-bottom: 0;
}

.tch-legal-note {
    padding: 1rem 1.15rem;
    border: 1px solid rgba(184, 137, 34, 0.36);
    border-radius: 8px;
    background: var(--tch-gold-soft);
    color: #62470e;
    font-size: 1rem;
}

.screen-reader-text {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

@media (max-width: 54rem) {
    .tch-container {
        width: min(calc(100vw - 2rem), 70rem);
    }

    .tch-archive-hero,
    .tch-detail-hero,
    .tch-search-hero {
        width: 100%;
        max-width: 100%;
        margin-left: 0;
        margin-right: 0;
    }

    .tch-archive-hero__inner,
    .tch-detail-hero__inner {
        padding-block: 3rem;
    }

    .tch-archive-hero__inner {
        min-height: 0;
    }

    .tch-archive-hero h1 {
        font-size: 2.75rem;
        line-height: 1.08;
    }

    .tch-archive-hero.has-background-image .tch-archive-hero__content {
        margin-left: 0;
        background: rgba(255, 255, 255, 0.82);
    }

    .tch-proof-strip {
        grid-template-columns: 1fr;
        margin-top: 1.5rem;
        margin-bottom: 3rem;
    }

    .tch-proof-strip__intro h2 {
        font-size: 1.8rem;
    }

    .tch-detail-hero__inner,
    .tch-card__header,
    .tch-entry-card__header {
        flex-direction: column;
        align-items: flex-start;
    }

    .tch-entry-card__badges {
        justify-content: flex-start;
    }

    .tch-hero-search,
    .tch-search-form {
        grid-template-columns: 1fr;
    }

    .tch-hero-search .tch-button,
    .tch-search-form .tch-button,
    .tch-quick-actions .tch-button {
        width: auto;
    }

    .tch-entry-card {
        grid-template-columns: 1fr;
    }

    .tch-latest-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .tch-detail-hero__inner.has-media {
        grid-template-columns: 1fr;
    }

    .tch-detail-hero h1 {
        max-width: 100%;
        font-size: clamp(2rem, 6.5vw, 2.55rem);
        hyphens: none;
        overflow-wrap: break-word;
        word-break: normal;
    }

    .tch-entry-card__media {
        min-height: 0;
    }

    .tch-detail-grid {
        grid-template-columns: 1fr;
        gap: 2rem;
        padding-block: 2.75rem;
    }

    .tch-keyfacts {
        position: static;
        order: -1;
    }

    .tch-subcategory-grid {
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 15rem), 1fr));
    }

    .tch-location-section {
        grid-template-columns: 1fr;
        gap: 1.25rem;
        margin-top: 3rem;
        margin-bottom: 3rem;
    }

    .tch-archive-location-filter__list {
        justify-content: flex-start;
    }

    .tch-location-list {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        max-height: 18rem;
    }

    .tch-location-chip {
        width: 100%;
    }

    .tch-webdesign-hero,
    .tch-ai-split,
    .tch-webdesign-split,
    .tch-upgrade-compare {
        grid-template-columns: 1fr;
    }

    .tch-upgrade-plan h3,
    .tch-upgrade-plan p {
        min-height: 0;
    }

    .tch-webdesign-visual {
        justify-items: stretch;
    }

    .tch-webdesign-graphic {
        width: min(100%, 32rem);
        margin-inline: auto;
    }

    .tch-browser-card {
        width: 100%;
    }

    .tch-webdesign-card-grid,
    .tch-upgrade-card-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .tch-ai-grid {
        grid-template-columns: 1fr;
    }

    .tch-social-links {
        flex-direction: column;
        align-items: stretch;
    }

    .tch-social-button {
        width: 100%;
    }
}

@media (max-width: 44rem) {
    .tch-latest-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 34rem) {
    body .site-title,
    body .site-title a {
        font-size: clamp(1.65rem, 9vw, 2.35rem);
        line-height: 1.12;
    }

    body .ast-builder-layout-element,
    body .ast-site-identity {
        min-width: 0;
    }

    .tch-container {
        width: min(calc(100vw - 2.5rem), 70rem) !important;
        max-width: calc(100vw - 2.5rem) !important;
    }

    .tch-site-main h1,
    .tch-site-main h2 {
        max-width: 100%;
        hyphens: none;
        overflow-wrap: break-word;
        word-break: normal;
    }

    .tch-site-main h1 {
        font-size: clamp(1.85rem, 8.2vw, 2.25rem);
        line-height: 1.14;
    }

    .tch-site-main h2 {
        font-size: clamp(1.55rem, 7vw, 1.95rem);
        line-height: 1.2;
    }

    .tch-archive-hero__inner,
    .tch-detail-hero__inner,
    .tch-search-hero__inner,
    .tch-archive-hero__content,
    .tch-detail-hero__content,
    .tch-archive-hero__copy,
    .tch-search-hero__lead {
        width: 100% !important;
        max-width: 100% !important;
    }

    .tch-archive-hero__copy,
    .tch-search-hero__lead,
    .tch-card__summary,
    .tch-category-card__description,
    .tch-subcategory-card__description {
        overflow-wrap: anywhere;
    }

    .tch-archive-hero__copy,
    .tch-archive-hero__copy p,
    .tch-detail-hero__lead,
    .tch-search-hero__lead {
        width: min(100%, calc(100vw - 3.5rem)) !important;
        max-width: calc(100vw - 3.5rem) !important;
    }

    .tch-archive-hero h1 {
        font-size: clamp(2rem, 8.5vw, 2.35rem);
        hyphens: none;
        overflow-wrap: break-word;
    }

    .tch-archive-hero__copy {
        font-size: 1.125rem;
    }

    .tch-archive-hero.has-background-image {
        background-image:
            linear-gradient(0deg, rgba(255, 255, 255, 0.94), rgba(255, 255, 255, 0.78)),
            var(--tch-hero-bg-image);
        background-position: center, center;
    }

    .tch-archive-hero.has-background-image .tch-archive-hero__content {
        padding: 1.15rem;
        border-color: rgba(255, 255, 255, 0.82);
        background: rgba(255, 255, 255, 0.9);
        box-shadow: 0 16px 42px rgba(16, 24, 32, 0.12);
    }

    .tch-hero-listing-badge {
        width: 100%;
    }

    .tch-hero-listing-badge__links {
        display: grid;
        grid-template-columns: 1fr;
    }

    .tch-hero-listing-badge__links a {
        justify-content: center;
        overflow-wrap: anywhere;
        text-align: center;
    }

    .tch-archive-location-filter {
        margin-top: 2rem;
    }

    .tch-archive-location-filter__list {
        display: grid;
        grid-template-columns: 1fr;
    }

    .tch-archive-location-filter__chip {
        width: 100%;
        justify-content: space-between;
    }

    .tch-search-hero h1 {
        max-width: 100%;
        font-size: 1.8rem;
        line-height: 1.18;
        hyphens: auto;
        overflow-wrap: anywhere;
    }

    .tch-search-hero__lead {
        font-size: 1.08rem;
    }

    .tch-card,
    .tch-keyfacts,
    .tch-empty-state,
    .tch-content-section,
    .tch-social-section {
        padding: 1.25rem;
    }

    .tch-detail-hero h1 {
        max-width: 100%;
        font-size: clamp(1.85rem, 8.2vw, 2.15rem);
        hyphens: none;
        overflow-wrap: break-word;
    }

    .tch-hero-search,
    .tch-search-form {
        width: 100%;
        padding: 0.5rem;
    }

    .tch-archive-hero .tch-hero-stats {
        display: none;
    }

    .tch-hero-assurance {
        font-size: 1.05rem;
    }

    .tch-proof-strip {
        padding: 1rem;
    }

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

    .tch-proof-list li {
        padding: 0.95rem 1rem 0.95rem 1.1rem;
    }

    .tch-hero-stats,
    .tch-hero-shortcuts,
    .tch-category-card__footer,
    .tch-quick-actions {
        align-items: stretch;
        flex-direction: column;
    }

    .tch-hero-stats li,
    .tch-hero-shortcuts .tch-button,
    .tch-count-badge,
    .tch-subcount-badge,
    .tch-quick-actions .tch-button,
    .tch-button {
        width: 100%;
    }

    .tch-category-card__link,
    .tch-subcategory-card,
    .tch-entry-card {
        padding: 1.15rem;
    }

    .tch-category-grid,
    .tch-subcategory-grid,
    .tch-location-list,
    .tch-latest-grid {
        grid-template-columns: 1fr;
    }

    .tch-location-nav {
        padding: 0.85rem;
    }

    .tch-location-section .tch-location-nav {
        padding: 0;
    }

    .tch-location-list {
        max-height: 18rem;
    }

    .tch-location-chip {
        border-radius: 8px;
    }

    .tch-list-section .tch-section-heading {
        margin-bottom: 1.25rem;
    }

    .tch-mobile-category-nav {
        display: block;
        padding: 1rem;
        margin-bottom: 2rem;
        border: 1px solid rgba(216, 222, 232, 0.95);
        border-radius: 8px;
        background:
            linear-gradient(135deg, rgba(232, 241, 251, 0.78), rgba(255, 255, 255, 0.96) 42%, rgba(255, 248, 230, 0.76));
        box-shadow: 0 16px 36px rgba(16, 24, 32, 0.08);
    }

    .tch-mobile-category-nav__intro {
        margin-bottom: 0.85rem;
    }

    .tch-mobile-category-nav__intro h3 {
        margin-bottom: 0;
        font-size: 1.35rem;
        line-height: 1.2;
    }

    .tch-mobile-category-tree {
        display: grid;
        gap: 0.5rem;
        padding: 0;
        margin: 0;
        list-style: none;
    }

    .tch-mobile-category-tree.is-nested {
        gap: 0.4rem;
        padding-left: 0.95rem;
        margin: 0.45rem 0 0.25rem 0.45rem;
        border-left: 2px solid rgba(11, 74, 143, 0.18);
    }

    .tch-mobile-category-link {
        display: flex;
        min-height: 3rem;
        align-items: center;
        justify-content: space-between;
        gap: 0.7rem;
        padding: 0.72rem 0.8rem;
        border: 1px solid rgba(216, 222, 232, 0.95);
        border-radius: 8px;
        background: rgba(255, 255, 255, 0.92);
        color: var(--tch-text);
        text-decoration: none;
        box-shadow: 0 8px 18px rgba(16, 24, 32, 0.045);
    }

    .tch-mobile-category-link:hover,
    .tch-mobile-category-link:focus-visible {
        border-color: rgba(11, 74, 143, 0.45);
        background: #ffffff;
        color: var(--tch-text);
    }

    .tch-mobile-category-link__title {
        position: relative;
        min-width: 0;
        padding-left: 1rem;
        color: var(--tch-text);
        font-size: 1.03rem;
        font-weight: 760;
        line-height: 1.25;
        hyphens: none;
        overflow-wrap: break-word;
    }

    .tch-mobile-category-link__title::before {
        position: absolute;
        top: 0.53em;
        left: 0;
        width: 0.42rem;
        height: 0.42rem;
        border-radius: 999px;
        background: linear-gradient(135deg, var(--tch-accent), var(--tch-gold));
        content: "";
    }

    .tch-mobile-category-tree__item.is-child .tch-mobile-category-link {
        min-height: 2.75rem;
        background: rgba(255, 255, 255, 0.78);
    }

    .tch-mobile-category-tree__item.is-child .tch-mobile-category-link__title {
        font-size: 0.98rem;
        font-weight: 720;
    }

    .tch-mobile-category-link__count {
        flex: 0 0 auto;
        min-width: 2.35rem;
        padding: 0.25rem 0.55rem;
        border-radius: 999px;
        background: var(--tch-blue-soft);
        color: var(--tch-accent-dark);
        font-size: 0.85rem;
        font-weight: 760;
        line-height: 1.25;
        text-align: center;
        white-space: nowrap;
    }

    .tch-category-grid {
        display: none;
    }

    .tch-entry-card__facts {
        display: grid;
        grid-template-columns: 1fr;
    }

    .tch-entry-card__facts li,
    .tch-card__microfact {
        width: 100%;
        border-radius: 8px;
    }

    .tch-entry-jump-nav {
        width: calc(100vw - 2.5rem) !important;
        max-width: calc(100vw - 2.5rem) !important;
        padding-top: 0.85rem;
        overflow-x: auto;
        flex-wrap: nowrap;
        scrollbar-width: thin;
    }

    .tch-entry-jump-nav__label,
    .tch-entry-jump-nav__list,
    .tch-entry-jump-nav__list li,
    .tch-entry-jump-nav a {
        flex: 0 0 auto;
    }

    .tch-entry-jump-nav__list {
        flex-wrap: nowrap;
    }

    .tch-webdesign-page {
        width: calc(100vw - 2.5rem) !important;
        max-width: calc(100vw - 2.5rem) !important;
        padding-top: 1.5rem;
    }

    .tch-ai-search-page {
        width: calc(100vw - 2.5rem) !important;
        max-width: calc(100vw - 2.5rem) !important;
        padding-top: 1.5rem;
    }

    .tch-upgrade-page {
        width: calc(100vw - 2.5rem) !important;
        max-width: calc(100vw - 2.5rem) !important;
        padding-top: 1.5rem;
    }

    .tch-ai-hero,
    .tch-webdesign-hero,
    .tch-upgrade-hero {
        padding: 1.5rem;
    }

    .tch-ai-hero,
    .tch-ai-section,
    .tch-ai-split,
    .tch-ai-final,
    .tch-webdesign-hero,
    .tch-webdesign-stats,
    .tch-webdesign-section,
    .tch-webdesign-split,
    .tch-webdesign-final-cta,
    .tch-upgrade-hero,
    .tch-upgrade-section,
    .tch-upgrade-ai-bridge,
    .tch-upgrade-note,
    .tch-upgrade-cta {
        width: calc(100vw - 2.5rem) !important;
        max-width: calc(100vw - 2.5rem) !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }

    .tch-ai-hero h1,
    .tch-webdesign-hero h1,
    .tch-upgrade-hero h1 {
        max-width: 100%;
        font-size: clamp(1.85rem, 8.2vw, 2.2rem);
        line-height: 1.14;
        hyphens: none;
        overflow-wrap: break-word;
    }

    .tch-webdesign-hero__content,
    .tch-webdesign-actions,
    .tch-webdesign-chips,
    .tch-webdesign-visual,
    .tch-webdesign-graphic,
    .tch-browser-card {
        width: 100%;
        max-width: 19rem !important;
    }

    .tch-ai-hero__lead,
    .tch-webdesign-hero__lead,
    .tch-upgrade-hero__lead {
        max-width: 18rem;
    }

    .tch-ai-actions .tch-button,
    .tch-webdesign-actions .tch-button,
    .tch-webdesign-chips li,
    .tch-upgrade-hero__actions .tch-button,
    .tch-upgrade-cta__actions .tch-button {
        max-width: 18rem;
    }

    .tch-ai-hero__lead,
    .tch-webdesign-hero__lead,
    .tch-upgrade-hero__lead {
        font-size: 1.125rem;
    }

    .tch-ai-actions,
    .tch-webdesign-actions,
    .tch-webdesign-chips,
    .tch-upgrade-hero__actions,
    .tch-upgrade-pill-row,
    .tch-upgrade-cta__actions {
        align-items: stretch;
        flex-direction: column;
    }

    .tch-webdesign-chips li {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 100%;
    }

    .tch-webdesign-stats,
    .tch-ai-grid,
    .tch-webdesign-card-grid,
    .tch-upgrade-ai-bridge,
    .tch-upgrade-card-grid {
        grid-template-columns: 1fr;
    }

    .tch-upgrade-pill-row span {
        justify-content: center;
        width: 100%;
        max-width: 18rem;
    }

    .tch-browser-card__hero {
        height: 7rem;
    }

    .tch-webdesign-final-cta h2 {
        max-width: 14ch;
        font-size: 1.85rem;
        line-height: 1.18;
    }

    .tch-lightbox {
        padding: 0.75rem;
    }

    .tch-lightbox__panel {
        grid-template-columns: 1fr;
    }

    .tch-lightbox__nav {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
    }

    .tch-lightbox__nav:hover,
    .tch-lightbox__nav:active {
        transform: translateY(-50%);
    }

    .tch-lightbox__nav--prev {
        left: 0.5rem;
    }

    .tch-lightbox__nav--next {
        right: 0.5rem;
    }

    .tch-lightbox__close {
        top: 0.5rem;
        right: 0.5rem;
    }
}

@media (max-width: 54rem) {
    .tch-single .tch-detail-hero__content {
        padding: 1.25rem;
    }

    .tch-detail-hero__facts {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .tch-detail-hero__facts li {
        grid-template-columns: 1fr;
        border-radius: 8px;
    }

    .tch-entry-jump-nav {
        margin-top: 1rem;
    }

    .tch-gallery {
        grid-template-columns: 1fr 1fr;
    }

    .tch-facts-table tr {
        grid-template-columns: 3.4rem minmax(0, 1fr);
    }
}

@media (max-width: 34rem) {
    .tch-single .tch-container {
        width: min(calc(100vw - 2.5rem), 76rem) !important;
        max-width: calc(100vw - 2.5rem) !important;
    }

    .tch-single .tch-detail-hero__inner {
        padding-block: 1.5rem 2rem;
    }

    .tch-detail-hero__facts,
    .tch-gallery {
        grid-template-columns: 1fr;
    }

    .tch-detail-hero__facts li {
        min-height: 0;
    }

    .tch-entry-jump-nav {
        margin-top: 0.85rem;
        padding: 0.65rem;
    }

    .tch-gallery__item--lead .tch-gallery__link,
    .tch-gallery__link {
        aspect-ratio: 4 / 3;
    }

    .tch-facts-table tbody {
        gap: 0.65rem;
    }

    .tch-facts-table tr {
        grid-template-columns: 3.2rem minmax(0, 1fr);
    }

    .tch-facts-table th {
        padding: 0.65rem 0.45rem;
    }

    .tch-facts-table td {
        padding: 0.72rem 0.85rem 0.72rem 0.35rem;
    }

    .tch-fact-icon {
        width: 2rem;
        height: 2rem;
    }
}
