:root {
    --pages-max-width: min(1160px, calc(100% - 32px));
    --pages-surface: rgba(255, 255, 255, 0.92);
    --pages-surface-strong: #ffffff;
    --pages-surface-muted: rgba(255, 255, 255, 0.7);
    --pages-border: rgba(255, 42, 35, 0.18);
    --pages-border-strong: rgba(255, 42, 35, 0.3);
    --pages-shadow: 0 24px 60px rgba(17, 17, 17, 0.1);
    --pages-text: #2c2c2c;
    --pages-text-soft: #5d5d5d;
    --pages-title: #121212;
    --pages-accent: var(--accent, #ff2a23);
    --pages-accent-strong: #c91d16;
    --pages-accent-soft: rgba(255, 42, 35, 0.08);
}

body {
    background:
        radial-gradient(circle at top right, rgba(255, 42, 35, 0.12), transparent 26%),
        radial-gradient(circle at top left, rgba(255, 42, 35, 0.08), transparent 22%),
        linear-gradient(180deg, #f7f5f3 0%, #efefef 100%);
}

.page-content {
    width: var(--pages-max-width);
    margin: 0 auto;
    padding: clamp(28px, 4vw, 56px) 0 clamp(52px, 7vw, 90px);
}

.page-content > * + * {
    margin-top: clamp(22px, 3vw, 36px);
}

.page-content > section,
.page-content > figure {
    margin-bottom: 0;
}

.page-content h1,
.page-content h2,
.page-content h3 {
    margin-top: 0;
    color: var(--pages-title);
    letter-spacing: -0.03em;
}

.page-content h1 {
    margin-bottom: 16px;
    font-size: clamp(2.2rem, 1.55rem + 2.2vw, 3.9rem);
    line-height: 1.04;
    text-wrap: balance;
}

.page-content h2 {
    margin-bottom: 14px;
    font-size: clamp(1.45rem, 1.14rem + 1.2vw, 2.35rem);
    line-height: 1.12;
}

.page-content h3 {
    margin-bottom: 12px;
    font-size: clamp(1.05rem, 0.96rem + 0.48vw, 1.36rem);
    line-height: 1.26;
}

.page-content p,
.page-content li,
.page-content td,
.page-content th,
.spoiler-toggle {
    color: var(--pages-text);
    font-size: clamp(0.99rem, 0.95rem + 0.16vw, 1.06rem);
    line-height: 1.74;
}

.page-content p {
    margin: 0 0 16px;
}

.page-content p:last-child,
.page-content li p:last-child,
.page-content td p:last-child,
.page-content th p:last-child {
    margin-bottom: 0;
}

.page-content strong {
    color: var(--pages-title);
}

.page-content a {
    color: var(--pages-accent-strong);
    text-decoration-color: rgba(255, 42, 35, 0.35);
    text-underline-offset: 0.18em;
}

.page-content a:hover,
.page-content a:focus-visible {
    text-decoration-color: rgba(255, 42, 35, 0.8);
}

.page-hero,
.page-section,
.page-section-accent,
.article-table-wrap,
.article-toc,
.spoiler,
.service-shell {
    border: 1px solid var(--pages-border);
    border-radius: 28px;
    box-shadow: var(--pages-shadow);
}

.page-hero {
    overflow: hidden;
    background:
        linear-gradient(135deg, rgba(255, 42, 35, 0.12), rgba(255, 255, 255, 0.92) 42%, rgba(255, 42, 35, 0.05)),
        var(--pages-surface-strong);
}

.page-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.18fr) minmax(260px, 0.82fr);
    gap: clamp(18px, 3vw, 34px);
    align-items: center;
    padding: clamp(22px, 4vw, 40px);
}

.page-hero-center .page-hero-grid,
.page-hero-service .page-hero-grid {
    grid-template-columns: 1fr;
}

.page-hero-copy > p {
    color: var(--pages-text-soft);
}

.page-hero-copy > p:last-child {
    margin-bottom: 0;
}

.page-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin: 0 0 14px;
    padding: 8px 14px;
    border-radius: 999px;
    background: rgba(255, 42, 35, 0.09);
    color: var(--pages-accent-strong);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.page-hero-media,
.article-media {
    display: grid;
    gap: 14px;
    margin: 0;
}

.article-media-standalone {
    margin: 0;
}

.article-media-link {
    display: block;
}

.page-hero-media img,
.article-media img {
    width: 100%;
    height: auto;
    border-radius: 22px;
    border: 1px solid rgba(255, 42, 35, 0.12);
    box-shadow: 0 18px 40px rgba(17, 17, 17, 0.12);
}

.article-media-centered {
    justify-items: center;
    margin: 30px 0;
}

.article-media-centered img {
    max-width: 760px;
}

.page-section,
.service-shell {
    padding: clamp(20px, 3vw, 30px);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(255, 255, 255, 0.88));
}

.page-section-accent {
    padding: clamp(20px, 3vw, 30px);
    background:
        linear-gradient(145deg, rgba(255, 42, 35, 0.12), rgba(255, 255, 255, 0.94) 55%, rgba(255, 42, 35, 0.04)),
        var(--pages-surface-strong);
    border-color: var(--pages-border-strong);
}

.page-content ul,
.page-content ol {
    margin: 0 0 18px;
}

.page-content ul {
    padding: 0;
    list-style: none;
}

.page-content ul li {
    position: relative;
    padding-left: 1.4rem;
    margin-bottom: 10px;
}

.page-content ul li::before {
    content: "";
    position: absolute;
    top: 0.8em;
    left: 0;
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--pages-accent), var(--pages-accent-strong));
    transform: translateY(-50%);
}

.page-content ol {
    padding-left: 1.3rem;
}

.page-content ol li {
    margin-bottom: 10px;
    padding-left: 0.18rem;
}

.article-table-wrap {
    margin: 18px 0 0;
    overflow-x: auto;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(250, 250, 250, 0.92));
}

.article-table-wrap table {
    width: 100%;
    min-width: 640px;
    border-collapse: collapse;
}

.article-table-wrap th,
.article-table-wrap td {
    padding: 14px 16px;
    vertical-align: top;
    text-align: left;
}

.article-table-wrap thead th {
    color: var(--pages-title);
    font-size: 0.84rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    background: rgba(255, 42, 35, 0.08);
}

.article-table-wrap tbody tr:nth-child(even) {
    background: rgba(255, 42, 35, 0.03);
}

.article-table-wrap tbody tr + tr td {
    border-top: 1px solid rgba(255, 42, 35, 0.08);
}

.article-toc {
    overflow: hidden;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.97), rgba(248, 248, 248, 0.92));
}

.article-toc summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 18px 22px;
    cursor: pointer;
    list-style: none;
    color: var(--pages-title);
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.article-toc summary::-webkit-details-marker {
    display: none;
}

.article-toc summary::after {
    content: "›";
    color: var(--pages-accent);
    font-size: 1.6rem;
    line-height: 1;
    transform: rotate(90deg);
    transition: transform 0.2s ease;
}

.article-toc[open] summary::after {
    transform: rotate(270deg);
}

.article-toc nav {
    padding: 0 22px 20px;
    border-top: 1px solid rgba(255, 42, 35, 0.1);
}

.article-toc ol {
    margin: 0;
    padding-left: 1.15rem;
}

.article-toc li {
    margin-bottom: 7px;
}

.article-inline-cta {
    display: flex;
    justify-content: center;
    margin-top: 4px;
}

.article-inline-cta .pill {
    min-width: min(100%, 260px);
}

.page-content a.pill,
.page-content a.pill:visited,
.page-content a.pill:hover,
.page-content a.pill:focus-visible,
.page-content .pill-bright,
.page-content .pill-bright:visited,
.page-content .pill-bright:hover,
.page-content .pill-bright:focus-visible {
    color: #ffffff;
    text-decoration: none;
}

.faq-group {
    display: grid;
    gap: 14px;
}

.spoiler {
    overflow: hidden;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 248, 248, 0.94));
}

.spoiler-toggle {
    position: relative;
    margin: 0;
    padding: 18px 56px 18px 22px;
    font-weight: 700;
    color: var(--pages-title);
    cursor: pointer;
}

.spoiler-toggle::after {
    content: "›";
    position: absolute;
    top: 50%;
    right: 22px;
    color: var(--pages-accent);
    font-size: 1.7rem;
    line-height: 1;
    transform: translateY(-50%) rotate(90deg);
    transition: transform 0.2s ease;
}

.spoiler.active .spoiler-toggle::after {
    transform: translateY(-50%) rotate(270deg);
}

.spoiler-content {
    max-height: 0;
    overflow: hidden;
    padding: 0 22px;
    border-top: 1px solid transparent;
    transition: max-height 0.25s ease, padding 0.25s ease, border-color 0.25s ease;
}

.spoiler.active .spoiler-content {
    padding-top: 16px;
    padding-bottom: 18px;
    border-top-color: rgba(255, 42, 35, 0.1);
    overflow: visible;
}

.spoiler-content > *:last-child {
    margin-bottom: 0;
}

.service-shell > * + * {
    margin-top: 18px;
}

.service-shell h1 {
    margin-bottom: 14px;
}

.service-shell h2 {
    margin-top: 0;
}

@media (max-width: 820px) {
    .page-content {
        width: min(100% - 24px, 100%);
        padding-top: 22px;
    }

    .page-hero-grid {
        grid-template-columns: 1fr;
    }

    .page-content h1 {
        font-size: clamp(1.95rem, 7vw, 2.8rem);
    }

    .article-table-wrap table {
        min-width: 560px;
    }

    .spoiler-toggle {
        padding-right: 50px;
    }
}
