:root {
    --swh-ink: #10181c;
    --swh-paper: #f8fbf2;
    --swh-gold: #dfcf72;
    --swh-aqua: #6ca6a3;
    --swh-mist: #eef1d8;
    --swh-shadow: 0 24px 70px rgba(10, 12, 18, .18);
    --swh-round: 24px;
    --swh-speed: 220ms ease;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body.swh-body { margin: 0; font-family: "Karla", Arial, sans-serif; color: var(--swh-ink); background: var(--swh-paper); line-height: 1.65; }
a { color: inherit; }
.swh-mast { position: sticky; top: 0; z-index: 20; display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 16px clamp(18px, 4vw, 58px); background: color-mix(in srgb, var(--swh-paper) 88%, white); border-bottom: 1px solid rgba(20,20,20,.08); backdrop-filter: blur(18px); }
.swh-sigil { display: inline-flex; align-items: center; gap: 12px; text-decoration: none; font-weight: 800; }
.swh-sigil span { width: 42px; height: 42px; border-radius: 50%; display: grid; place-items: center; background: var(--swh-ink); color: var(--swh-gold); font-family: "Marcellus", serif; }
.swh-navline { display: flex; align-items: center; gap: 18px; font-size: .96rem; }
.swh-navline a { text-decoration: none; opacity: .82; }
.swh-navline a:hover { opacity: 1; color: var(--swh-aqua); }
.swh-menu-rune { display: none; border: 0; background: var(--swh-ink); color: var(--swh-paper); border-radius: 999px; padding: 10px 16px; font-weight: 800; }
.swh-hero { min-height: 72vh; padding: clamp(58px, 8vw, 110px) clamp(20px, 6vw, 82px) 44px; position: relative; overflow: hidden; }
.swh-hero h1, .swh-page-hero h1, .swh-section-head h2, .swh-cta h2 { font-family: "Marcellus", Georgia, serif; line-height: 1.04; margin: 0; }
.swh-hero h1 { font-size: clamp(2.55rem, 6vw, 5.9rem); max-width: 900px; }
.swh-hero p { max-width: 720px; font-size: clamp(1.05rem, 1.6vw, 1.28rem); }
.swh-hero-split, .swh-hero-editorial, .swh-hero-mosaic { display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(260px, .72fr); gap: clamp(30px, 5vw, 70px); align-items: center; }
.swh-hero-centered { text-align: center; display: grid; place-items: center; align-content: center; }
.swh-hero-centered p, .swh-hero-centered h1 { margin-left: auto; margin-right: auto; }
.swh-hero-cards { display: grid; grid-template-columns: .48fr 1fr; gap: 42px; align-items: center; }
.swh-hero-quiet { display: grid; gap: 26px; }
.swh-quiet-grid { display: grid; grid-template-columns: 1fr .7fr; gap: 36px; align-items: end; }
.swh-kicker, .swh-halo, .swh-section-head span { display: inline-block; text-transform: uppercase; letter-spacing: .08em; font-weight: 800; color: var(--swh-aqua); font-size: .82rem; }
.swh-hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin: 28px 0; }
.swh-hero-actions a, .swh-hero-link, .swh-plan-card a, .swh-cta a, .swh-signal-form button, .swh-hero-panel a { display: inline-flex; justify-content: center; align-items: center; min-height: 46px; padding: 12px 20px; border-radius: 999px; background: var(--swh-ink); color: var(--swh-paper); text-decoration: none; font-weight: 800; border: 0; cursor: pointer; }
.swh-hero-actions a:nth-child(2) { background: var(--swh-gold); color: var(--swh-ink); }
.swh-fold-note { margin-top: 22px; max-width: 760px; padding: 16px 18px; border-radius: calc(var(--swh-round) * .7); background: color-mix(in srgb, var(--swh-gold) 22%, white); border: 1px solid color-mix(in srgb, var(--swh-gold) 42%, var(--swh-ink)); font-weight: 700; }
.swh-astro-disc, .swh-hero-panel, .swh-mosaic-board, .swh-mini-stack { background: linear-gradient(145deg, var(--swh-ink), color-mix(in srgb, var(--swh-ink) 76%, var(--swh-aqua))); color: var(--swh-paper); border-radius: var(--swh-round); box-shadow: var(--swh-shadow); padding: clamp(26px, 5vw, 54px); }
.swh-astro-disc { aspect-ratio: 1; display: grid; place-items: center; text-align: center; }
.swh-astro-disc span { font-family: "Marcellus", serif; font-size: clamp(4rem, 9vw, 8rem); color: var(--swh-gold); }
.swh-mini-stack, .swh-mosaic-board { display: grid; gap: 16px; }
.swh-mini-stack span, .swh-mosaic-board span, .swh-proof-strip span { padding: 14px; border-radius: 18px; background: rgba(255,255,255,.12); }
.swh-proof-strip { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 20px; }
.swh-band { padding: clamp(54px, 7vw, 96px) clamp(20px, 6vw, 82px); }
.swh-section-head { display: grid; gap: 12px; margin-bottom: 30px; max-width: 840px; }
.swh-section-head h2 { font-size: clamp(2rem, 4vw, 3.7rem); }
.swh-feature-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 18px; }
.swh-feature-tile, .swh-plan-card, .swh-voice-card, .swh-read-card, .swh-contact-copy, .swh-signal-form, .swh-article-slab, .swh-contact-card, .swh-note-box { border: 1px solid rgba(20,20,20,.09); border-radius: var(--swh-round); padding: 24px; background: color-mix(in srgb, var(--swh-paper) 82%, white); box-shadow: 0 14px 44px rgba(15, 20, 20, .08); }
.swh-feature-tile h3, .swh-plan-card h3, .swh-read-card h3 { margin-top: 0; font-size: 1.35rem; }
.swh-plan-lane { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 20px; align-items: stretch; }
.swh-plan-card { position: relative; display: flex; flex-direction: column; gap: 10px; }
.swh-plan-card ul { padding-left: 20px; margin-bottom: 18px; }
.swh-plan-card a { margin-top: auto; }
.swh-badge { width: fit-content; border-radius: 999px; padding: 6px 10px; background: var(--swh-gold); font-weight: 800; }
.swh-voice-flow { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 18px; }
.swh-voice-card { margin: 0; }
.swh-voice-card blockquote { margin: 0 0 18px; font-size: 1.05rem; }
.swh-voice-card figcaption { display: grid; gap: 2px; }
.swh-voice-card span { color: color-mix(in srgb, var(--swh-ink) 65%, white); }
.swh-read-shelf { display: grid; grid-template-columns: repeat(auto-fit, minmax(245px, 1fr)); gap: 18px; }
.swh-read-card { text-decoration: none; display: grid; gap: 8px; }
.swh-contact-zone { display: grid; grid-template-columns: .82fr 1fr; gap: 22px; align-items: start; }
.swh-signal-form { display: grid; gap: 14px; }
.swh-signal-form label { display: grid; gap: 7px; font-weight: 800; }
.swh-signal-form input, .swh-signal-form textarea { width: 100%; border: 1px solid rgba(20,20,20,.16); border-radius: 16px; padding: 13px 14px; font: inherit; background: white; }
.swh-form-result { min-height: 26px; font-weight: 800; color: var(--swh-aqua); margin: 0; }
.swh-question-list { display: grid; gap: 12px; }
.swh-question-cell { border: 1px solid rgba(20,20,20,.12); border-radius: 20px; background: white; overflow: hidden; }
.swh-question-button { width: 100%; text-align: left; border: 0; background: transparent; padding: 18px 20px; font: inherit; font-weight: 900; cursor: pointer; }
.swh-answer-panel { display: none; padding: 0 20px 18px; }
.swh-question-cell.swh-open .swh-answer-panel { display: block; }
.swh-cta { margin: clamp(30px, 5vw, 70px) clamp(20px, 6vw, 82px); padding: clamp(34px, 6vw, 66px); border-radius: var(--swh-round); background: var(--swh-ink); color: var(--swh-paper); }
.swh-cta h2 { font-size: clamp(2rem, 4vw, 3.5rem); max-width: 900px; }
.swh-cta a { background: var(--swh-gold); color: var(--swh-ink); margin-top: 12px; }
.swh-footer { padding: 42px clamp(20px, 6vw, 82px); background: color-mix(in srgb, var(--swh-ink) 96%, black); color: var(--swh-paper); }
.swh-foot-brand { max-width: 840px; margin-bottom: 28px; }
.swh-foot-grid { display: grid; grid-template-columns: 1fr 1fr 1.2fr; gap: 28px; }
.swh-foot-grid div { display: grid; align-content: start; gap: 8px; }
.swh-subpage { padding: 34px clamp(20px, 6vw, 82px) 76px; }
.swh-crumbs { display: flex; flex-wrap: wrap; gap: 10px; font-size: .92rem; margin: 18px 0 30px; }
.swh-crumbs a { color: var(--swh-aqua); }
.swh-page-hero { padding: clamp(32px, 6vw, 70px); border-radius: var(--swh-round); background: var(--swh-mist); margin-bottom: 22px; }
.swh-page-hero h1 { font-size: clamp(2.2rem, 5vw, 4.8rem); }
.swh-article-slab { margin: 16px 0; }
.swh-related { margin-top: 28px; display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.swh-related h2 { width: 100%; font-family: "Marcellus", serif; }
.swh-related a { border-radius: 999px; padding: 10px 15px; background: var(--swh-mist); text-decoration: none; font-weight: 800; }
.swh-contact-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 18px; }
.swh-longform { max-width: 980px; }
.swh-two-read { columns: 2 300px; column-gap: 34px; }
.swh-quote-line { margin: 24px 0; padding: 22px; border-left: 5px solid var(--swh-gold); background: white; font-weight: 900; }
.swh-cookie { position: fixed; left: 18px; right: 18px; bottom: 18px; z-index: 30; display: none; align-items: center; justify-content: space-between; gap: 14px; padding: 16px; border-radius: 20px; background: var(--swh-ink); color: var(--swh-paper); box-shadow: var(--swh-shadow); }
.swh-cookie button { border: 0; border-radius: 999px; padding: 10px 16px; background: var(--swh-gold); color: var(--swh-ink); font-weight: 900; cursor: pointer; }
.swh-cookie.swh-seenless { display: flex; }
@media (max-width: 840px) {
    .swh-menu-rune { display: inline-flex; }
    .swh-navline { position: absolute; left: 16px; right: 16px; top: 72px; padding: 16px; border-radius: 20px; background: var(--swh-paper); box-shadow: var(--swh-shadow); display: none; flex-direction: column; align-items: flex-start; }
    .swh-navline.swh-navlive { display: flex; }
    .swh-hero-split, .swh-hero-editorial, .swh-hero-mosaic, .swh-hero-cards, .swh-quiet-grid, .swh-contact-zone, .swh-foot-grid { grid-template-columns: 1fr; }
    .swh-hero { min-height: auto; }
    .swh-cookie { flex-direction: column; align-items: flex-start; }
}
