
.tjx-dyn-v3 {
    --tjx-dyn-primary: #d71920;
    --tjx-dyn-accent: #111111;
    --tjx-dyn-dark: #0a0f16;
    --tjx-dyn-light: #f7f7f7;
    --tjx-dyn-border: #e2e8f0;
    --tjx-dyn-muted: #5b6978;
    --tjx-dyn-shadow: 0 22px 56px rgba(16, 30, 44, .12);
    font-family: Arial, Helvetica, sans-serif;
    color: #233143;
}

.tjx-dyn-v3 * {
    box-sizing: border-box;
}

.tjx-dyn-container {
    width: min(1180px, calc(100% - 32px));
    margin: 0 auto;
}

.tjx-dyn-hero {
    padding: 82px 0;
    color: #fff;
    background:
        radial-gradient(circle at top right, rgba(215, 25, 32, .28), transparent 32%),
        linear-gradient(135deg, rgba(16, 30, 44, .98), rgba(10, 15, 22, .96));
}

.tjx-dyn-hero-grid,
.tjx-dyn-two-col,
.tjx-dyn-final-cta-inner {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(280px, .85fr);
    gap: 34px;
    align-items: center;
}

.tjx-dyn-kicker {
    margin: 0 0 12px;
    color: var(--tjx-dyn-primary);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.tjx-dyn-hero .tjx-dyn-kicker,
.tjx-dyn-section-dark .tjx-dyn-kicker,
.tjx-dyn-final-cta .tjx-dyn-kicker {
    color: #ffd3a8;
}

.tjx-dyn-hero h1 {
    max-width: 880px;
    margin: 0 0 18px;
    font-size: clamp(40px, 6vw, 72px);
    line-height: 1.02;
    letter-spacing: -.045em;
}

.tjx-dyn-hero p {
    max-width: 780px;
    color: rgba(255,255,255,.88);
    font-size: 18px;
    line-height: 1.72;
}

.tjx-dyn-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 24px;
}

.tjx-dyn-btn {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    min-height: 48px;
    padding: 13px 22px;
    border-radius: 999px;
    background: var(--tjx-dyn-primary);
    color: #fff !important;
    font-weight: 900;
    text-decoration: none;
    border: 2px solid var(--tjx-dyn-primary);
    box-shadow: 0 16px 34px rgba(215, 25, 32, .22);
}

.tjx-dyn-btn-secondary {
    background: #fff;
    color: var(--tjx-dyn-dark) !important;
    border-color: #fff;
    box-shadow: none;
}

.tjx-dyn-hero-card,
.tjx-dyn-side-card,
.tjx-dyn-answer-card,
.tjx-dyn-dark-card {
    border-radius: 24px;
    padding: 28px;
    background: #fff;
    color: var(--tjx-dyn-dark);
    box-shadow: var(--tjx-dyn-shadow);
}

.tjx-dyn-hero-card {
    display: grid;
    gap: 12px;
}

.tjx-dyn-hero-card strong {
    font-size: 26px;
    line-height: 1.15;
}

.tjx-dyn-hero-card span {
    color: var(--tjx-dyn-muted);
}

.tjx-dyn-hero-card em {
    display: inline-flex;
    width: fit-content;
    padding: 8px 12px;
    border-radius: 999px;
    background: rgba(215,25,32,.10);
    color: var(--tjx-dyn-accent);
    font-style: normal;
    font-weight: 800;
}

.tjx-dyn-trust-row {
    background: var(--tjx-dyn-primary);
    color: #fff;
    padding: 22px 0;
}

.tjx-dyn-stat-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}

.tjx-dyn-stat-grid strong,
.tjx-dyn-stat-grid span {
    display: block;
}

.tjx-dyn-stat-grid strong {
    font-size: 18px;
}

.tjx-dyn-stat-grid span {
    color: rgba(255,255,255,.82);
}

.tjx-dyn-section {
    padding: 76px 0;
    background: #fff;
}

.tjx-dyn-section-light {
    background: var(--tjx-dyn-light);
}

.tjx-dyn-section-dark {
    background: var(--tjx-dyn-dark);
    color: #fff;
}

.tjx-dyn-section-dark p,
.tjx-dyn-section-dark li {
    color: rgba(255,255,255,.82);
}

.tjx-dyn-section-head {
    max-width: 780px;
    margin-bottom: 28px;
}

.tjx-dyn-section h2,
.tjx-dyn-section-head h2,
.tjx-dyn-final-cta h2 {
    margin: 0 0 14px;
    color: var(--tjx-dyn-dark);
    font-size: clamp(30px, 4vw, 48px);
    line-height: 1.08;
    letter-spacing: -.035em;
}

.tjx-dyn-section-dark h2,
.tjx-dyn-final-cta h2 {
    color: #fff;
}

.tjx-dyn-section p {
    color: var(--tjx-dyn-muted);
    font-size: 17px;
    line-height: 1.78;
}

.tjx-dyn-section h3 {
    margin: 28px 0 10px;
    color: var(--tjx-dyn-dark);
    font-size: 25px;
    line-height: 1.15;
}

.tjx-dyn-side-card h3,
.tjx-dyn-dark-card h3 {
    margin-top: 0;
}

.tjx-dyn-card-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}

.tjx-dyn-link-card,
.tjx-dyn-mini-card,
.tjx-dyn-process-step,
.tjx-dyn-faq-list details {
    display: block;
    border: 1px solid var(--tjx-dyn-border);
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 12px 30px rgba(16, 30, 44, .06);
}

.tjx-dyn-link-card {
    padding: 20px;
    text-decoration: none;
    color: var(--tjx-dyn-dark);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.tjx-dyn-link-card:hover {
    transform: translateY(-4px);
    border-color: var(--tjx-dyn-primary);
    box-shadow: var(--tjx-dyn-shadow);
}

.tjx-dyn-link-card strong {
    display: block;
    color: var(--tjx-dyn-dark);
    font-size: 19px;
    line-height: 1.2;
}

.tjx-dyn-link-card span {
    display: block;
    margin-top: 7px;
    color: var(--tjx-dyn-muted);
}

.tjx-dyn-answer-card {
    max-width: 980px;
}

.tjx-dyn-answer-card h2 {
    color: var(--tjx-dyn-dark);
}

.tjx-dyn-mini-card {
    padding: 18px;
    color: var(--tjx-dyn-dark);
    font-weight: 800;
}

.tjx-dyn-note {
    margin-top: 24px;
    padding: 22px;
    border-left: 5px solid var(--tjx-dyn-primary);
    border-radius: 16px;
    background: #fff;
    color: var(--tjx-dyn-muted);
    box-shadow: 0 12px 30px rgba(16, 30, 44, .06);
}

.tjx-dyn-muted {
    color: var(--tjx-dyn-muted);
}

.tjx-dyn-clean-list {
    margin: 0;
    padding-left: 20px;
}

.tjx-dyn-clean-list li {
    margin: 8px 0;
}

.tjx-dyn-check-grid,
.tjx-dyn-process-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
}

.tjx-dyn-check-grid div {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    padding: 18px;
    border: 1px solid var(--tjx-dyn-border);
    border-radius: 18px;
    background: #fff;
    color: var(--tjx-dyn-dark);
    font-weight: 700;
}

.tjx-dyn-check-grid span {
    display: grid;
    place-items: center;
    flex: 0 0 24px;
    width: 24px;
    height: 24px;
    border-radius: 999px;
    background: rgba(47, 127, 115, .14);
    color: var(--tjx-dyn-accent);
    font-weight: 900;
}

.tjx-dyn-process-step {
    padding: 22px;
}

.tjx-dyn-process-step > span {
    display: grid;
    place-items: center;
    width: 38px;
    height: 38px;
    border-radius: 12px;
    background: var(--tjx-dyn-primary);
    color: #fff;
    font-weight: 900;
}

.tjx-dyn-process-step h3 {
    margin: 18px 0 8px;
    font-size: 20px;
}

.tjx-dyn-process-step p {
    margin-bottom: 0;
    font-size: 15px;
}

.tjx-dyn-faq-list {
    display: grid;
    gap: 14px;
}

.tjx-dyn-faq-list details {
    padding: 18px 20px;
}

.tjx-dyn-faq-list summary {
    cursor: pointer;
    color: var(--tjx-dyn-dark);
    font-weight: 900;
    font-size: 18px;
}

.tjx-dyn-faq-list p {
    margin-bottom: 0;
}

.tjx-dyn-final-cta {
    padding: 72px 0;
    background:
        radial-gradient(circle at top right, rgba(212,104,34,.32), transparent 30%),
        linear-gradient(135deg, var(--tjx-dyn-dark), #152b3e);
    color: #fff;
}

.tjx-dyn-final-cta p {
    max-width: 760px;
    color: rgba(255,255,255,.82);
    font-size: 18px;
}

@media (max-width: 1024px) {
    .tjx-dyn-hero-grid,
    .tjx-dyn-two-col,
    .tjx-dyn-final-cta-inner {
        grid-template-columns: 1fr;
    }

    .tjx-dyn-card-grid,
    .tjx-dyn-check-grid,
    .tjx-dyn-process-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 720px) {
    .tjx-dyn-hero {
        padding: 58px 0;
    }

    .tjx-dyn-hero h1 {
        font-size: 40px;
    }

    .tjx-dyn-section,
    .tjx-dyn-final-cta {
        padding: 56px 0;
    }

    .tjx-dyn-card-grid,
    .tjx-dyn-check-grid,
    .tjx-dyn-process-grid,
    .tjx-dyn-stat-grid {
        grid-template-columns: 1fr;
    }

    .tjx-dyn-btn {
        width: 100%;
    }
}

/* v3.4.0 T & J Contracting red/black cleanup */
.tjx-dyn-hero {
    background:
        radial-gradient(circle at top right, rgba(215, 25, 32, .26), transparent 34%),
        linear-gradient(135deg, rgba(10, 15, 22, .98), rgba(31, 10, 12, .97));
    border-bottom: 4px solid #d71920;
}

.tjx-dyn-btn {
    background: linear-gradient(135deg, #d71920, #990c12);
    border-color: #d71920;
    box-shadow: 0 16px 34px rgba(215, 25, 32, .2);
}

.tjx-dyn-btn-secondary {
    background: #fff;
    color: #0a0f16 !important;
    border-color: #fff;
}

.tjx-dyn-trust-row {
    background: #070b10;
    border-top: 1px solid rgba(255,255,255,.08);
    border-bottom: 3px solid #d71920;
}

.tjx-dyn-kicker {
    color: #d71920;
}

.tjx-dyn-hero-card em,
.tjx-dyn-side-card em {
    color: #d71920;
    background: rgba(215,25,32,.08);
}

.tjx-dyn-card:hover,
.tjx-dyn-link-card:hover {
    border-color: rgba(215,25,32,.35);
}

.tjx-dyn-final-cta {
    background:
        radial-gradient(circle at top right, rgba(215,25,32,.24), transparent 34%),
        linear-gradient(135deg, #070b10, #241014);
}


/* v3.5 visual refinement */
.tjx-dyn-v3 {
    --tjx-dyn-primary: #d71920;
    --tjx-dyn-accent: #111111;
    --tjx-dyn-dark: #070d14;
    --tjx-dyn-light: #f5f6f8;
    color: #141b24;
}
.tjx-dyn-hero {
    padding: 92px 0 84px;
    background:
        radial-gradient(circle at 92% 18%, rgba(215,25,32,.34), transparent 28%),
        linear-gradient(135deg, #070d14 0%, #14171d 52%, #33080d 100%);
    border-bottom: 5px solid var(--tjx-dyn-primary);
}
.tjx-dyn-hero-card {
    border-top: 5px solid var(--tjx-dyn-primary);
}
.tjx-dyn-section {
    padding: 68px 0;
}
.tjx-dyn-section-light {
    background:
        linear-gradient(180deg, #f7f8fa, #fff);
}
.tjx-dyn-section h2,
.tjx-dyn-section-head h2,
.tjx-dyn-final-cta h2 {
    letter-spacing: -.045em;
}
.tjx-dyn-two-col {
    align-items: start;
}
.tjx-dyn-side-card {
    border-top: 5px solid var(--tjx-dyn-primary);
}
.tjx-dyn-answer-card {
    border-left: 6px solid var(--tjx-dyn-primary);
}
.tjx-dyn-mini-card {
    border-left: 4px solid var(--tjx-dyn-primary);
}
.tjx-dyn-check-grid div span {
    background: rgba(215,25,32,.10);
    color: var(--tjx-dyn-primary);
}
.tjx-dyn-process-step {
    border-top: 4px solid var(--tjx-dyn-primary);
}
.tjx-dyn-link-card:hover {
    border-color: rgba(215,25,32,.38);
}
.tjx-dyn-final-cta {
    background:
        radial-gradient(circle at top right, rgba(215,25,32,.28), transparent 30%),
        linear-gradient(135deg, #070d14, #210509);
    border-top: 5px solid var(--tjx-dyn-primary);
}
.tjx-dyn-card-grid .tjx-dyn-link-card strong {
    font-size: 20px;
}
.tjx-dyn-kicker {
    color: #667589;
}
.tjx-dyn-section-dark .tjx-dyn-dark-card {
    background: #fff;
    color: #111;
}
.tjx-dyn-section-dark .tjx-dyn-dark-card li {
    color: #324154;
}
.tjx-dyn-section-dark {
    background: linear-gradient(135deg, #070d14, #101720);
}
@media (max-width: 720px) {
    .tjx-dyn-hero {
        padding: 64px 0;
    }
    .tjx-dyn-section {
        padding: 52px 0;
    }
}


/* Sitewide dynamic lead form */
.tjx-dyn-lead-section {
    background:
        radial-gradient(circle at top right, rgba(215, 25, 32, .10), transparent 30%),
        #fff;
    border-top: 1px solid var(--tjx-dyn-border);
}

.tjx-dyn-lead-grid {
    display: grid;
    grid-template-columns: minmax(0, .9fr) minmax(320px, 1.1fr);
    gap: 34px;
    align-items: start;
}

.tjx-dyn-lead-phone {
    display: inline-grid;
    gap: 4px;
    margin-top: 18px;
    padding: 16px 18px;
    border-radius: 18px;
    background: var(--tjx-dyn-dark);
    color: #fff;
}

.tjx-dyn-lead-phone span {
    color: rgba(255,255,255,.70);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.tjx-dyn-lead-phone a {
    color: #fff;
    font-size: 22px;
    font-weight: 1000;
    text-decoration: none;
}

.tjx-dyn-lead-form {
    display: grid;
    gap: 14px;
    padding: 28px;
    border: 1px solid var(--tjx-dyn-border);
    border-radius: 24px;
    background: #fff;
    box-shadow: var(--tjx-dyn-shadow);
}

.tjx-dyn-form-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.tjx-dyn-lead-form label {
    display: grid;
    gap: 7px;
    color: var(--tjx-dyn-dark);
    font-weight: 900;
}

.tjx-dyn-lead-form input,
.tjx-dyn-lead-form select,
.tjx-dyn-lead-form textarea {
    width: 100%;
    min-height: 48px;
    padding: 12px 14px;
    border: 1px solid var(--tjx-dyn-border);
    border-radius: 14px;
    color: var(--tjx-dyn-dark);
    background: #fff;
    font: inherit;
    font-weight: 600;
}

.tjx-dyn-lead-form textarea {
    min-height: 132px;
    resize: vertical;
}

.tjx-dyn-hp-field {
    position: absolute !important;
    left: -9999px !important;
    width: 1px !important;
    height: 1px !important;
    opacity: 0 !important;
}

.tjx-dyn-mini-card,
.tjx-dyn-check-grid div,
.tjx-dyn-clean-list li {
    text-transform: none;
}

@media (max-width: 860px) {
    .tjx-dyn-lead-grid,
    .tjx-dyn-form-row {
        grid-template-columns: 1fr;
    }
}


/* v3.8 user, SEO, voice-search, and form polish */
.tjx-dyn-v3 {
    color: #111820;
}
.tjx-dyn-section p,
.tjx-dyn-link-card span,
.tjx-dyn-hero-card span {
    color: #4f5f70;
}
.tjx-dyn-kicker {
    color: #6a7888;
}
.tjx-dyn-hero .tjx-dyn-kicker,
.tjx-dyn-final-cta .tjx-dyn-kicker,
.tjx-dyn-section-dark .tjx-dyn-kicker {
    color: #ffd5a8;
}
.tjx-dyn-faq-list--featured {
    grid-template-columns: 1fr;
    max-width: 980px;
}
.tjx-dyn-faq-list--featured details {
    border-left: 5px solid var(--tjx-dyn-primary);
    padding: 22px 24px;
}
.tjx-dyn-faq-list--featured details[open] {
    background:
        radial-gradient(circle at top right, rgba(215,25,32,.06), transparent 28%),
        #fff;
}
.tjx-dyn-faq-list--featured summary {
    font-size: 20px;
    line-height: 1.25;
}
.tjx-dyn-faq-list--featured p {
    max-width: 880px;
    font-size: 17px;
    color: #4f5f70;
}
.tjx-dyn-lead-section {
    background:
        radial-gradient(circle at top right, rgba(215, 25, 32, .08), transparent 30%),
        linear-gradient(180deg, #fff, #f7f8fa);
}
.tjx-dyn-lead-grid {
    grid-template-columns: minmax(0, .8fr) minmax(380px, 1.2fr);
}
.tjx-dyn-lead-grid > div h2 {
    margin: 0 0 14px;
    color: var(--tjx-dyn-dark);
    font-size: clamp(34px, 4vw, 52px);
    line-height: 1.08;
    letter-spacing: -.04em;
}
.tjx-dyn-lead-form {
    gap: 16px;
    padding: 32px;
}
.tjx-dyn-lead-form input,
.tjx-dyn-lead-form select,
.tjx-dyn-lead-form textarea {
    min-height: 54px;
    font-size: 16px;
}
.tjx-dyn-lead-form textarea {
    min-height: 230px;
    line-height: 1.65;
}
.tjx-dyn-form-row {
    gap: 16px;
}
@media (max-width: 860px) {
    .tjx-dyn-lead-grid {
        grid-template-columns: 1fr;
    }
    .tjx-dyn-lead-form {
        padding: 22px;
    }
    .tjx-dyn-lead-form textarea {
        min-height: 190px;
    }
}


/* v3.9 polish: plugin styling controls, better root-service wording, larger forms */
.tjx-dyn-v3 {
    --tjx-dyn-primary: var(--tjx-primary, #d71920);
    --tjx-dyn-dark: var(--tjx-dark, #0a0f16);
    --tjx-dyn-accent: var(--tjx-accent, #111111);
    --tjx-dyn-light: var(--tjx-light, #f7f7f7);
}

.tjx-dyn-answer-card h2 {
    max-width: 100%;
}

.tjx-dyn-lead-grid {
    grid-template-columns: minmax(0, .72fr) minmax(600px, 1.28fr);
    gap: 42px;
}

.tjx-dyn-lead-form {
    padding: 36px;
}

.tjx-dyn-form-row {
    grid-template-columns: repeat(2, minmax(260px, 1fr));
    gap: 18px;
}

.tjx-dyn-lead-form input,
.tjx-dyn-lead-form select {
    min-height: 62px;
    font-size: 17px;
}

.tjx-dyn-lead-form textarea {
    min-height: 300px;
    font-size: 17px;
    line-height: 1.7;
}

.tjx-dyn-lead-form label {
    font-size: 17px;
}

@media (max-width: 1080px) {
    .tjx-dyn-lead-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 720px) {
    .tjx-dyn-form-row {
        grid-template-columns: 1fr;
    }
    .tjx-dyn-lead-form {
        padding: 22px;
    }
    .tjx-dyn-lead-form textarea {
        min-height: 220px;
    }
}


/* v4.0 form overflow fix and root-service punctuation cleanup support */
.tjx-dyn-lead-grid {
    grid-template-columns: minmax(260px, .8fr) minmax(0, 1.2fr);
    overflow: hidden;
}

.tjx-dyn-lead-form {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    overflow: hidden;
}

.tjx-dyn-form-row {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    width: 100%;
    min-width: 0;
}

.tjx-dyn-lead-form label,
.tjx-dyn-lead-form input,
.tjx-dyn-lead-form select,
.tjx-dyn-lead-form textarea {
    max-width: 100%;
    min-width: 0;
}

.tjx-dyn-lead-form input,
.tjx-dyn-lead-form select {
    min-height: 62px;
}

.tjx-dyn-lead-form textarea {
    min-height: 260px;
    line-height: 1.7;
}

@media (max-width: 860px) {
    .tjx-dyn-lead-grid,
    .tjx-dyn-form-row {
        grid-template-columns: 1fr !important;
    }

    .tjx-dyn-lead-form textarea {
        min-height: 210px;
    }
}


/* v4.1 lead form hard fix: match the working contact-page behavior */
.tjx-dyn-lead-section {
    overflow-x: hidden !important;
}

.tjx-dyn-lead-grid {
    display: grid !important;
    grid-template-columns: minmax(0, .82fr) minmax(0, 1.18fr) !important;
    gap: 42px !important;
    overflow: visible !important;
    align-items: start !important;
}

.tjx-dyn-lead-form {
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: 100% !important;
    max-width: 760px !important;
    min-width: 0 !important;
    margin-left: auto !important;
    overflow: visible !important;
}

.tjx-dyn-form-row {
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: 100% !important;
    min-width: 0 !important;
}

.tjx-dyn-lead-form label,
.tjx-dyn-lead-form input,
.tjx-dyn-lead-form select,
.tjx-dyn-lead-form textarea {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
}

.tjx-dyn-lead-form input,
.tjx-dyn-lead-form select {
    min-height: 62px !important;
}

.tjx-dyn-lead-form textarea {
    min-height: 300px !important;
}

.tjx-dyn-v3,
.tjx-dyn-v3 body {
    overflow-x: hidden !important;
}

@media (max-width: 1050px) {
    .tjx-dyn-lead-grid {
        grid-template-columns: 1fr !important;
    }

    .tjx-dyn-lead-form {
        max-width: 100% !important;
        margin-left: 0 !important;
    }
}


.tjx-dyn-service-group-grid {
    display: grid;
    gap: 28px;
}

.tjx-dyn-service-group {
    padding: 22px;
    border: 1px solid rgba(15, 23, 42, 0.10);
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.76);
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.06);
}

.tjx-dyn-service-group h3 {
    margin: 0 0 16px;
    color: var(--tjx-dyn-dark, #0a0f16);
    font-size: clamp(1.1rem, 2vw, 1.45rem);
}

.tjx-dyn-section-dark .tjx-dyn-service-group {
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(255, 255, 255, 0.12);
}

.tjx-dyn-section-dark .tjx-dyn-service-group h3 {
    color: #ffffff;
}


/* v5.2 layout starters: same CSV data, different page structures */
.tjx-dyn-v3[class*="tjx-layout-"] .tjx-dyn-link-card span {
    line-height: 1.55;
}

.tjx-layout-storm-response .tjx-dyn-hero {
    background:
        linear-gradient(90deg, rgba(215,25,32,.92), rgba(10,15,22,.78)),
        radial-gradient(circle at 85% 10%, rgba(255,255,255,.18), transparent 30%),
        #0a0f16;
}

.tjx-layout-storm-response .tjx-dyn-hero-grid {
    grid-template-columns: minmax(0, 1.3fr) minmax(260px, .7fr);
}

.tjx-layout-storm-response .tjx-sec-warning .tjx-dyn-card-grid,
.tjx-layout-storm-response .tjx-dyn-check-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.tjx-layout-storm-response .tjx-sec-warning .tjx-dyn-mini-card {
    border-left: 6px solid var(--tjx-dyn-primary);
    font-size: 18px;
}

.tjx-layout-claims .tjx-dyn-hero {
    background:
        linear-gradient(135deg, rgba(10,15,22,.96), rgba(39,46,59,.94)),
        radial-gradient(circle at top left, rgba(215,25,32,.24), transparent 30%);
}

.tjx-layout-claims .tjx-sec-claims {
    background: #fff8f0;
}

.tjx-layout-claims .tjx-sec-process .tjx-dyn-process-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.tjx-layout-service-authority .tjx-dyn-hero {
    background: linear-gradient(135deg, #111827, #0a0f16);
}

.tjx-layout-service-authority .tjx-sec-overview .tjx-dyn-two-col {
    grid-template-columns: minmax(0, .82fr) minmax(320px, .38fr);
    align-items: start;
}

.tjx-layout-service-authority .tjx-sec-overview article {
    font-size: 18px;
    line-height: 1.82;
}

.tjx-layout-local-authority .tjx-dyn-hero {
    background:
        linear-gradient(135deg, rgba(10,15,22,.90), rgba(215,25,32,.74)),
        radial-gradient(circle at 15% 20%, rgba(255,255,255,.17), transparent 28%);
}

.tjx-layout-local-authority .tjx-dyn-service-group-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
}

.tjx-layout-exterior-clean .tjx-dyn-hero {
    background: #f8fafc;
    color: var(--tjx-dyn-dark);
    border-bottom: 1px solid var(--tjx-dyn-border);
}

.tjx-layout-exterior-clean .tjx-dyn-hero p {
    color: #334155;
}

.tjx-layout-exterior-clean .tjx-dyn-hero .tjx-dyn-kicker {
    color: var(--tjx-dyn-primary);
}

.tjx-layout-exterior-clean .tjx-dyn-hero-grid {
    grid-template-columns: minmax(0, .95fr) minmax(320px, 1.05fr);
}

.tjx-layout-commercial .tjx-dyn-hero {
    background:
        linear-gradient(135deg, #111827, #243142);
}

.tjx-layout-commercial .tjx-dyn-card-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.tjx-layout-roof-type-guide .tjx-dyn-hero {
    background:
        linear-gradient(135deg, #3d2f25, #0a0f16);
}

.tjx-layout-roof-type-guide .tjx-sec-overview .tjx-dyn-two-col {
    grid-template-columns: minmax(0, 1fr);
}

.tjx-layout-state-hub .tjx-dyn-hero {
    background:
        linear-gradient(135deg, rgba(10,15,22,.96), rgba(58,63,72,.92));
}

.tjx-layout-state-hub .tjx-dyn-card-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.tjx-dyn-service-group h3 {
    display: flex;
    align-items: center;
    gap: 10px;
}

.tjx-dyn-service-group h3::before {
    content: "";
    width: 12px;
    height: 12px;
    border-radius: 999px;
    background: var(--tjx-dyn-primary);
    flex: 0 0 auto;
}

@media (max-width: 900px) {
    .tjx-layout-local-authority .tjx-dyn-service-group-grid,
    .tjx-layout-storm-response .tjx-sec-warning .tjx-dyn-card-grid,
    .tjx-layout-storm-response .tjx-dyn-check-grid,
    .tjx-layout-claims .tjx-sec-process .tjx-dyn-process-grid,
    .tjx-layout-state-hub .tjx-dyn-card-grid,
    .tjx-layout-commercial .tjx-dyn-card-grid {
        grid-template-columns: 1fr;
    }
}
