/* tpl/editorial-policy-e3e31329.css — page CSS shared by 1 page(s) of this template.
   Auto-extracted from inline <style> by scripts/refactor_css.py.
   Loaded after components.css; per-page :root{} stays inline. */

body { background: var(--color-base-bg); }
.v3 { position: relative; }
.v3-nav { position: sticky; top: 0; z-index: var(--z-header); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); background: color-mix(in srgb, var(--color-base-bg) 80%, transparent); border-bottom: 1px solid var(--color-base-border); }
.v3-nav__inner { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: var(--space-5); height: 68px; }
.v3-logo { display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-body); font-weight: 700; font-size: 18px; letter-spacing: -0.02em; color: var(--color-text-primary); text-decoration: none; }
.v3-logo svg { width: 22px; height: 22px; }
.v3-pillnav { display: flex; gap: 2px; justify-self: center; background: var(--color-base-surface); border: 1px solid var(--color-base-border); padding: 4px; border-radius: var(--radius-full); }
.v3-pillnav > a { padding: 7px 15px; border-radius: var(--radius-full); font-size: 13px; font-weight: 500; color: var(--color-text-secondary); text-decoration: none; transition: background 0.15s, color 0.15s; }
.v3-pillnav > a:hover { color: var(--color-text-primary); background: var(--color-base-bg); }
@media (max-width: 1024px) { .v3-pillnav { display: none; } }
.v3-nav__cta { display: flex; align-items: center; gap: var(--space-2); }
.v3-pill { display: inline-flex; align-items: center; gap: 8px; height: 40px; padding: 0 18px; border-radius: var(--radius-full); font-size: 13px; font-weight: 600; letter-spacing: 0.01em; text-decoration: none; transition: transform 0.15s, background 0.15s, border-color 0.15s; }
.v3-pill:active { transform: scale(0.97); }
.v3-pill--solid { background: var(--color-text-primary); color: var(--color-base-bg); }
.v3-pill--solid:hover { opacity: 0.88; }
.ab-hero { padding: var(--space-8) 0 var(--space-6); border-bottom: 1px solid var(--color-base-border); }
.ab-eyebrow { display: inline-flex; align-items: center; gap: 8px; font-size: 11px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-text-tertiary); }
.ab-eyebrow i { width: 7px; height: 7px; border-radius: 50%; background: var(--accent-astrology); display: block; }
.ab-hero__title { font-family: var(--font-body); font-weight: 700; font-size: clamp(34px, 5vw, 56px); line-height: 1.05; letter-spacing: -0.035em; margin-top: var(--space-4); color: var(--color-text-primary); max-width: 16ch; }
.ab-hero__title em { font-family: var(--font-display); font-style: italic; font-weight: 500; color: var(--accent-astrology); }
.ab-hero__lede { margin-top: var(--space-5); font-size: clamp(17px, 1.8vw, 20px); line-height: 1.6; color: var(--color-text-secondary); max-width: 62ch; }
.ab-body { padding: var(--space-8) 0; }
.ab-grid { display: grid; grid-template-columns: 220px 1fr; gap: var(--space-8); align-items: start; }
@media (max-width: 880px) { .ab-grid { grid-template-columns: 1fr; gap: var(--space-5); } }
.ab-toc { position: sticky; top: 88px; }
@media (max-width: 880px) { .ab-toc { position: static; } }
.ab-toc__h { font-size: 11px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-text-tertiary); margin-bottom: var(--space-3); }
.ab-toc a { display: block; font-size: 14px; color: var(--color-text-secondary); text-decoration: none; padding: 6px 0 6px 12px; border-left: 2px solid transparent; transition: color 0.15s, border-color 0.15s; }
.ab-toc a:hover, .ab-toc a.active { color: var(--color-text-primary); border-color: var(--accent-astrology); }
.ab-prose { max-width: 68ch; }
.ab-prose h2 { font-family: var(--font-body); font-weight: 700; font-size: clamp(22px, 2.6vw, 30px); letter-spacing: -0.025em; color: var(--color-text-primary); margin: var(--space-7) 0 var(--space-3); scroll-margin-top: 88px; }
.ab-prose h2:first-child { margin-top: 0; }
.ab-prose p { font-size: 16px; line-height: 1.72; color: var(--color-text-secondary); margin-bottom: var(--space-4); }
.ab-prose ul { margin: 0 0 var(--space-4); padding-left: 1.2em; }
.ab-prose li { font-size: 16px; line-height: 1.7; color: var(--color-text-secondary); margin-bottom: 8px; }
.ab-prose strong { color: var(--color-text-primary); font-weight: 600; }
.ab-prose a.xlink { color: var(--accent-astrology); text-decoration: none; border-bottom: 1px solid color-mix(in srgb, var(--accent-astrology) 35%, transparent); }
.ab-prose a.xlink:hover { border-bottom-color: var(--accent-astrology); }
.ab-note { margin-top: var(--space-6); padding: var(--space-5); border-radius: 16px; background: color-mix(in srgb, var(--accent-astrology) 6%, var(--color-base-surface)); border: 1px solid color-mix(in srgb, var(--accent-astrology) 18%, transparent); }
.ab-note h2 { margin-top: 0 !important; }
.ab-note p { font-size: 14.5px; margin-bottom: 0; }
.v3-footer { margin-top: var(--space-9); padding: var(--space-8) 0 var(--space-6); border-top: 1px solid var(--color-base-border); }
.v3-footer__grid { display: grid; grid-template-columns: 1.8fr 1fr 1fr 1fr 1fr; gap: var(--space-7); }
@media (max-width: 900px) { .v3-footer__grid { grid-template-columns: 1fr 1fr; gap: var(--space-5); } }
@media (max-width: 560px) { .v3-footer__grid { grid-template-columns: 1fr; } }
.v3-footer__brand p { font-size: 13px; line-height: 1.65; color: var(--color-text-tertiary); margin-top: var(--space-3); max-width: 240px; }
.v3-footer__col h4 { font-size: 11px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-text-tertiary); margin-bottom: var(--space-3); }
.v3-footer__col a { display: block; font-size: 13.5px; color: var(--color-text-secondary); text-decoration: none; margin-bottom: 8px; transition: color 0.15s; }
.v3-footer__col a:hover { color: var(--color-text-primary); }
.v3-footer__legal { display: flex; justify-content: space-between; align-items: center; margin-top: var(--space-7); padding-top: var(--space-5); border-top: 1px solid var(--color-base-border); font-size: 12px; color: var(--color-text-tertiary); flex-wrap: wrap; gap: var(--space-3); }
