/* === policy-page.css — shared styles for legal/policy text pages === */

/* ─── Body wrapper ──────────────────────────────────────── */
.policy-page__body { padding-block: 2.5rem 5rem; }

/* ─── Reading column ────────────────────────────────────── */
.policy-page__content { max-width: 52rem; }

/* ─── Intro lead ────────────────────────────────────────── */
.policy-page__lead { font-size: clamp(1rem, 1.5vw, 1.125rem); line-height: 1.7; color: var(--color-hero-text); margin: 0 0 2.5rem; padding-bottom: 2.5rem; border-bottom: 1px solid var(--color-border-light); }

/* ─── Section blocks ────────────────────────────────────── */
.policy-page__section { padding-block: 2rem; border-bottom: 1px solid var(--color-border-light); }

.policy-page__section:last-child { border-bottom: none; padding-bottom: 0; }

/* ─── Section heading ───────────────────────────────────── */
.policy-page__heading { display: flex; flex-direction: column; gap: 0.75rem; margin: 0 0 1.25rem; }

.policy-page__heading-rule { display: block; width: 2.5rem; height: 3px; background-color: var(--color-primary); flex-shrink: 0; }

.policy-page__heading-text { margin: 0; font-family: var(--font-heading); font-size: clamp(1.2rem, 2vw, 1.5rem); font-weight: 500; line-height: 1.2; letter-spacing: -0.02em; color: var(--color-black); }

/* ─── Body copy ─────────────────────────────────────────── */
.policy-page__text { margin: 0 0 1rem; font-size: var(--text-body); line-height: 1.75; color: var(--color-hero-text); }

.policy-page__text:last-child { margin-bottom: 0; }

/* ─── Lists ─────────────────────────────────────────────── */
.policy-page__list { margin: 0 0 1rem; padding-left: 1.25rem; display: flex; flex-direction: column; gap: 0.625rem; }

.policy-page__list li { font-size: var(--text-body); line-height: 1.7; color: var(--color-hero-text); }

.policy-page__list li::marker { color: var(--color-primary); }

/* ─── Inline links ──────────────────────────────────────── */
.policy-page__text a,
.policy-page__list a { color: var(--color-primary); text-decoration: underline; text-underline-offset: 0.2em; }

.policy-page__text a:hover,
.policy-page__list a:hover { text-decoration: none; }

/* ─── H3 sub-heading ────────────────────────────────────── */
.policy-page__subheading { margin: 1.75rem 0 0.5rem; font-family: var(--font-heading); font-size: clamp(1rem, 1.5vw, 1.125rem); font-weight: 600; letter-spacing: -0.01em; color: var(--color-black); }

/* ─── Pull quote ────────────────────────────────────────── */
.policy-page__quote { margin: 2rem 0; padding: 1.25rem 1.5rem; border-left: 4px solid var(--color-primary); background-color: var(--color-gray-mid); border-radius: 0 var(--radius-sm) var(--radius-sm) 0; }

.policy-page__quote p { margin: 0; font-family: var(--font-heading); font-size: clamp(1.05rem, 1.8vw, 1.25rem); font-weight: 500; line-height: 1.5; color: var(--color-black); font-style: italic; }

/* ─── Attribution ───────────────────────────────────────── */
.policy-page__attribution { margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid var(--color-border-light); font-size: 0.9rem; line-height: 1.6; color: var(--color-hero-text); }

.policy-page__attribution strong { display: block; color: var(--color-black); font-weight: 600; }

/* ─── Bottom CTA panel ──────────────────────────────────── */
.policy-page__cta { background-color: var(--color-gray-mid); padding-block: 3rem; margin-top: 1rem; }

.policy-page__cta-inner { display: flex; flex-direction: column; align-items: flex-start; gap: 1rem; }

.policy-page__cta-rule { display: block; width: 4rem; height: 4px; background-color: var(--color-black); margin-bottom: 0.25rem; }

.policy-page__cta-title { margin: 0 0 0.25rem; font-family: var(--font-heading); font-size: clamp(1.5rem, 2.5vw, 2rem); font-weight: 500; line-height: 1.15; letter-spacing: -0.03em; color: var(--color-black); }

.policy-page__cta-sub { margin: 0; font-size: var(--text-body); line-height: 1.65; color: var(--color-hero-text); }

/* ─── Responsive ─────────────────────────────────────────── */
@media (min-width: 992px) {
    .policy-page__body { padding-block: 3.5rem 6rem; }

    .policy-page__section { padding-block: 2.5rem; }

    .policy-page__cta { padding-block: 4rem; }

    .policy-page__cta-inner { flex-direction: row; align-items: center; justify-content: space-between; gap: 2.5rem; }

    .policy-page__cta-content { flex: 1 1 0; }
}

/* ─── Wide content column ───────────────────────────────── */
.policy-page__content--wide { max-width: 72rem; }

/* Architectural models page: constrain hero width, but let inner copy use full row width */
.arch-models-index .ip-hero.policy-page__content--wide .ip-hero__body { max-width: none; }

.arch-models-index .ip-hero.policy-page__content--wide .ip-hero__intro { max-width: none; }

.cookies-page .ip-hero.policy-page__content .ip-hero__body { max-width: none; }

.cookies-page .ip-hero.policy-page__content .ip-hero__intro { max-width: none; }

/* ─── Callout box (phone/CTA inline) ───────────────────── */
.policy-page__callout { margin: 1.5rem 0; padding: 1.25rem 1.5rem; border-left: 4px solid var(--color-primary); background-color: var(--color-gray-mid); border-radius: 0 var(--radius-sm) var(--radius-sm) 0; font-size: var(--text-body); line-height: 1.6; color: var(--color-black); }

.policy-page__callout a { color: var(--color-primary); font-weight: 600; text-decoration: none; }

.policy-page__callout a:hover { text-decoration: none; }

/* ─── Scale reference table ─────────────────────────────── */
.policy-page__scale-table { width: 100%; border-collapse: collapse; margin: 1.5rem 0; font-size: var(--text-body); }

.policy-page__scale-table th,
.policy-page__scale-table td { padding: 0.6rem 1rem; text-align: left; border-bottom: 1px solid var(--color-border-light); }

.policy-page__scale-table th { font-family: var(--font-heading); font-weight: 600; font-size: 0.875rem; letter-spacing: 0.03em; text-transform: uppercase; color: var(--color-black); background-color: var(--color-gray-mid); }

.policy-page__scale-table td:first-child { font-weight: 600; color: var(--color-primary); font-family: var(--font-heading); }

/* ─── Scale images row ──────────────────────────────────── */
.policy-page__image-row { display: grid; grid-template-columns: 1fr; gap: 1rem; margin: 1.5rem 0; }

.policy-page__image-row img { width: 100%; height: auto; border-radius: var(--radius-sm); display: block; }

/* ─── Two-column info grid ──────────────────────────────── */
.policy-page__info-grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; margin: 1.5rem 0; }

.policy-page__info-col strong { display: block; font-family: var(--font-heading); font-weight: 600; font-size: 1rem; color: var(--color-black); margin-bottom: 0.625rem; }

.policy-page__info-col em { display: block; font-size: 0.875rem; color: var(--color-hero-text); margin-bottom: 0.5rem; }

.policy-page__info-col ul { margin: 0; padding-left: 1.25rem; display: flex; flex-direction: column; gap: 0.4rem; }

.policy-page__info-col ul li { font-size: var(--text-body); line-height: 1.6; color: var(--color-hero-text); }

.policy-page__info-col ul li::marker { color: var(--color-primary); }

/* ─── Responsive additions ──────────────────────────────── */
@media (min-width: 640px) {
    .policy-page__image-row { grid-template-columns: repeat(3, 1fr); }

    .policy-page__info-grid { grid-template-columns: repeat(2, 1fr); gap: 2rem; }
}

@media (max-width: 767px) {
    .arch-models-index .policy-page__body { padding-top: 0; padding-bottom: 2.5rem; }
    .policy-page__cta-rule { margin-bottom: .75rem; }
    .policy-page__cta { padding-block: 2.5rem; }
    .ip-hero__cta { width: 100%; }
}
