/* ── Dark-first terminal-minimal aesthetic ── */

:root {
    --bg: #f5f3f0;
    --surface: #eae7e3;
    --surface-soft: #e0ddd8;
    --text: #2c2832;
    --muted: #706a7a;
    --line: #d0ccc6;
    --accent: #8b6cc0;
    --accent-strong: #6b4ca0;
    --warn-bg: #fdf4e8;
    --warn-line: #e0c090;
    --ok-bg: #eaf0ec;
    --page-glow: transparent;
    --page-accent-glow: transparent;
    --page-top: #f5f3f0;
    --page-bottom: #f5f3f0;
    --focus: #8b6cc0;
    --on-accent: #ffffff;
    --header-bg: rgba(245, 243, 240, 0.95);
    --header-line: #d0ccc6;
    --btn-primary-hover: #5a3c88;
    --btn-ghost-hover-border: #b0a8c0;
    --btn-ghost-hover-bg: #e8e4f0;
    --status-none-bg: #ece8f4;
    --status-none-border: #c0b8d8;
    --status-none-text: #4a4060;
    --status-negotiating-bg: #e8e4ff;
    --status-negotiating-border: #a8a0e0;
    --status-negotiating-text: #3a2880;
    --status-active-bg: #e4f0e8;
    --status-active-border: #90c8a0;
    --status-active-text: #1a5030;
    --status-paused-bg: #f8f0e0;
    --status-paused-border: #d8b870;
    --status-paused-text: #6a4810;
    --status-revoked-bg: #f4e4e8;
    --status-revoked-border: #d8909c;
    --status-revoked-text: #702028;
    --status-ended-bg: #ebebeb;
    --status-ended-border: #b8b8b8;
    --status-ended-text: #484848;
    --hub-first-bg: #e8e4f0;
    --hub-first-border: #c0b8d8;
    --hub-stop-border: #c0b0c8;
    --hub-stop-bg-start: #ece8f2;
    --hub-stop-bg-end: #f0eef4;
    --stop-btn-bg: #a02020;
    --stop-btn-hover: #801818;
    --selected-border: #a890d0;
    --selected-bg: #ece8f4;
    --progress-complete-border: #90c8a0;
    --progress-complete-bg: #e4f0e8;
    --progress-complete-text: #1a5030;
    --progress-complete-step-border: #78b890;
    --progress-complete-step-bg: #d0e8d8;
    --statement-line: #a890d0;
    --error-bg: #f4e4e8;
    --error-border: #d8909c;
    --final-cta-start: #ece8f2;
    --final-cta-end: #f0eef4;
    --footer-bg: #eae7e3;
    --terminal-banner-bg: #8c1a20;
    --terminal-banner-border: #6a1018;
    --terminal-banner-text: #ffffff;
    --terminal-banner-label-bg: #5a0c10;
    --surface-raised-start: #eae7e3;
    --surface-raised-end: #e4e1dc;

    --radius: 8px;
    --radius-sm: 6px;
    --shadow: none;
    --container: 900px;

    --font-mono:
        "JetBrains Mono", "Fira Code", "SF Mono", "Cascadia Code", "Consolas",
        monospace;
}

[data-theme="dark"] {
    --bg: #1a1824;
    --surface: #22202e;
    --surface-soft: #2a2838;
    --text: #c8c4d4;
    --muted: #706888;
    --line: #332e48;
    --accent: #9b82c8;
    --accent-strong: #b89eff;
    --warn-bg: #2e2418;
    --warn-line: #604828;
    --ok-bg: #142018;
    --page-glow: transparent;
    --page-accent-glow: transparent;
    --page-top: #1a1824;
    --page-bottom: #1a1824;
    --focus: #b89eff;
    --on-accent: #1a1824;
    --header-bg: rgba(26, 24, 36, 0.95);
    --header-line: #332e48;
    --btn-primary-hover: #cbb8ff;
    --btn-ghost-hover-border: #504870;
    --btn-ghost-hover-bg: #2e2a40;
    --status-none-bg: #242038;
    --status-none-border: #3e3860;
    --status-none-text: #b0a8d0;
    --status-negotiating-bg: #202040;
    --status-negotiating-border: #484898;
    --status-negotiating-text: #c0b8ff;
    --status-active-bg: #102818;
    --status-active-border: #2a6848;
    --status-active-text: #90d8a8;
    --status-paused-bg: #2e2010;
    --status-paused-border: #705828;
    --status-paused-text: #d8c080;
    --status-revoked-bg: #301018;
    --status-revoked-border: #703848;
    --status-revoked-text: #e8a0b0;
    --status-ended-bg: #202024;
    --status-ended-border: #484850;
    --status-ended-text: #b0b0b8;
    --hub-first-bg: #242038;
    --hub-first-border: #3e3860;
    --hub-stop-border: #403058;
    --hub-stop-bg-start: #22203a;
    --hub-stop-bg-end: #1e1c30;
    --stop-btn-bg: #c03040;
    --stop-btn-hover: #a02030;
    --selected-border: #6858a0;
    --selected-bg: #282440;
    --progress-complete-border: #2a6848;
    --progress-complete-bg: #102818;
    --progress-complete-text: #90d8a8;
    --progress-complete-step-border: #388058;
    --progress-complete-step-bg: #183020;
    --statement-line: #6858a0;
    --error-bg: #301018;
    --error-border: #703848;
    --final-cta-start: #22203a;
    --final-cta-end: #1e1c30;
    --footer-bg: #161422;
    --terminal-banner-bg: #7a1820;
    --terminal-banner-border: #5a0c10;
    --terminal-banner-text: #ffe0e4;
    --terminal-banner-label-bg: #4a0810;
    --surface-raised-start: #22202e;
    --surface-raised-end: #1e1c2a;
    --shadow: none;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    color-scheme: light;
}

html[data-theme="dark"] {
    color-scheme: dark;
}

html,
body {
    margin: 0;
    padding: 0;
}

body {
    font-family: var(--font-mono);
    color: var(--text);
    background: var(--bg);
    line-height: 1.6;
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
    font-size: 0.92rem;
}

#main-content {
    flex: 1;
    display: flex;
    flex-direction: column;
}

h1,
h2,
h3 {
    margin: 0 0 0.6rem;
    line-height: 1.3;
    letter-spacing: -0.02em;
    font-family: var(--font-mono);
    font-weight: 700;
}

h1 {
    font-size: clamp(1.5rem, 3vw, 2.2rem);
}

h2 {
    font-size: clamp(1.1rem, 1.8vw, 1.4rem);
}

p {
    margin: 0 0 0.8rem;
}

a {
    color: var(--accent);
    text-decoration: none;
}

a:hover {
    color: var(--accent-strong);
}

a:focus-visible,
button:focus-visible {
    outline: 2px solid var(--focus);
    outline-offset: 2px;
    border-radius: var(--radius-sm);
}

.skip-link {
    position: absolute;
    left: -999px;
    top: -999px;
    background: var(--surface);
    padding: 0.5rem 0.8rem;
    z-index: 1000;
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
}

.skip-link:focus {
    left: 1rem;
    top: 1rem;
}

.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* ── Layout ── */

.container {
    width: min(var(--container), calc(100% - 2rem));
    margin-inline: auto;
}

.section {
    padding: clamp(2rem, 5vw, 4rem) 0;
    animation: rise 350ms ease both;
}

/* ── Header ── */

.site-header {
    position: sticky;
    top: 0;
    z-index: 20;
    border-bottom: 1px solid var(--line);
    background: var(--header-bg);
    backdrop-filter: blur(8px);
}

.header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    min-height: 3.5rem;
}

.brand {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--text);
    font-weight: 700;
    font-family: var(--font-mono);
}

.brand-mark {
    display: inline-grid;
    place-items: center;
    width: 1.6rem;
    height: 1.6rem;
    border-radius: 4px;
    background: var(--accent-strong);
    color: var(--on-accent);
    font-size: 0.8rem;
    font-weight: 800;
}

.brand-text {
    font-size: 0.95rem;
    letter-spacing: 0.04em;
    text-transform: lowercase;
}

.site-nav {
    display: none;
    align-items: center;
    gap: 0.8rem;
}

.site-nav a {
    color: var(--muted);
    font-weight: 600;
    font-size: 0.85rem;
    padding-bottom: 0.15rem;
    border-bottom: 1px solid transparent;
    transition:
        color 160ms ease,
        border-color 160ms ease;
}

.site-nav a:hover,
.site-nav a.active {
    color: var(--text);
    border-color: var(--accent);
}

.auth-actions {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.auth-meta {
    color: var(--muted);
    font-size: 0.8rem;
    max-width: 10rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.inline-form {
    margin: 0;
}

/* ── Buttons ── */

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius);
    border: 1px solid transparent;
    font-weight: 700;
    font-family: var(--font-mono);
    font-size: 0.85rem;
    line-height: 1;
    padding: 0.55rem 0.9rem;
    transition:
        background-color 140ms ease,
        color 140ms ease,
        border-color 140ms ease;
    cursor: pointer;
}

.btn-primary {
    background: var(--accent-strong);
    color: var(--on-accent);
}

.btn-primary:hover {
    background: var(--btn-primary-hover);
    color: var(--on-accent);
}

.btn-ghost {
    background: transparent;
    border-color: var(--line);
    color: var(--text);
}

.btn-ghost:hover {
    border-color: var(--btn-ghost-hover-border);
    background: var(--btn-ghost-hover-bg);
}

.btn-link {
    padding: 0.55rem 0;
    color: var(--accent);
    border: none;
    background: none;
}

.theme-toggle {
    min-width: 0;
    width: 2rem;
    height: 2rem;
    padding: 0;
    border-radius: var(--radius);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.theme-icon {
    font-size: 1rem;
    line-height: 1;
    transition: opacity 160ms ease;
}

html[data-theme="light"] .theme-icon-sun {
    display: none;
}

html[data-theme="light"] .theme-icon-moon {
    display: inline;
}

html[data-theme="dark"] .theme-icon-moon {
    display: none;
}

html[data-theme="dark"] .theme-icon-sun {
    display: inline;
}

/* ── Hero / Landing ── */

.hero {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding-top: 0;
    padding-bottom: 0;
    min-height: 0;
}

.hero-centered {
    text-align: center;
    max-width: 36rem;
    margin-inline: auto;
    padding: clamp(3rem, 10vw, 8rem) 0;
}

.hero-centered .lead {
    margin-inline: auto;
}

.hero-centered .actions {
    justify-content: center;
}

.hero-grid {
    display: grid;
    gap: 1.5rem;
}

/* ── Surfaces ── */

.page-hero .container,
.hero-grid,
.card,
.callout {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: clamp(1rem, 2.5vw, 1.5rem);
}

.eyebrow {
    display: inline-block;
    font-size: 0.75rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--muted);
    font-weight: 700;
    margin-bottom: 0.6rem;
}

.lead {
    color: var(--muted);
    font-size: 0.95rem;
    max-width: 50ch;
}

.actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 1rem;
}

.panel {
    background: var(--surface-soft);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 1rem;
}

.list-check,
.list-cross,
.card ul {
    margin: 0;
    padding-left: 1.2rem;
}

.list-check li,
.list-cross li,
.card li {
    margin-bottom: 0.4rem;
}

/* ── Trust strip (landing) ── */

.trust-strip {
    display: grid;
    gap: 0.75rem;
}

.trust-card {
    display: block;
    color: var(--text);
    transition: border-color 160ms ease;
}

.trust-card:hover {
    border-color: var(--accent);
    color: var(--text);
}

.trust-card h2 {
    font-size: 1rem;
    margin-bottom: 0.3rem;
}

.trust-card p {
    color: var(--muted);
    margin-bottom: 0;
    font-size: 0.88rem;
}

/* ── Process strip ── */

.process-strip {
    list-style: none;
    margin: 1rem 0 0;
    padding: 0;
    display: grid;
    gap: 0.5rem;
}

.process-strip li {
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background: var(--surface);
    padding: 0.8rem;
}

.process-strip strong {
    display: block;
    margin-bottom: 0.2rem;
}

.process-strip span {
    color: var(--muted);
    font-size: 0.88rem;
}

.card-grid {
    display: grid;
    gap: 0.75rem;
}

.card h2 {
    margin-bottom: 0.5rem;
}

.text-link {
    font-weight: 700;
}

/* ── Status chips ── */

.status-chip {
    display: inline-flex;
    align-items: center;
    border-radius: var(--radius);
    border: 1px solid var(--line);
    padding: 0.2rem 0.6rem;
    font-size: 0.78rem;
    font-weight: 700;
    white-space: nowrap;
    font-family: var(--font-mono);
}

.status-none {
    background: var(--status-none-bg);
    border-color: var(--status-none-border);
    color: var(--status-none-text);
}

.status-negotiating {
    background: var(--status-negotiating-bg);
    border-color: var(--status-negotiating-border);
    color: var(--status-negotiating-text);
}

.status-active {
    background: var(--status-active-bg);
    border-color: var(--status-active-border);
    color: var(--status-active-text);
}

.status-paused {
    background: var(--status-paused-bg);
    border-color: var(--status-paused-border);
    color: var(--status-paused-text);
}

.status-revoked {
    background: var(--status-revoked-bg);
    border-color: var(--status-revoked-border);
    color: var(--status-revoked-text);
}

.status-ended {
    background: var(--status-ended-bg);
    border-color: var(--status-ended-border);
    color: var(--status-ended-text);
}

/* ── Hub / Status ── */

.hub-section {
    padding-top: 1.5rem;
}

.hub-stack {
    display: grid;
    gap: 0.75rem;
}

.hub-notice {
    color: var(--muted);
    font-size: 0.88rem;
    border-left: 2px solid var(--accent);
    padding-left: 0.8rem;
    margin: 0;
}

.hub-context-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: clamp(1rem, 2.5vw, 1.5rem);
}

.hub-title {
    margin-bottom: 0;
    font-size: clamp(1.2rem, 2vw, 1.6rem);
}

.hub-status-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.8rem;
}

.hub-meta,
.hub-state-explanation,
.hub-next-note,
.relationship-meta {
    color: var(--muted);
    font-size: 0.88rem;
}

.hub-mixed-note {
    border: 1px solid var(--line);
    background: var(--surface-soft);
    border-radius: var(--radius-sm);
    padding: 0.4rem 0.6rem;
    margin-bottom: 0.6rem;
    font-size: 0.88rem;
}

.hub-stop-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    border: 1px solid var(--hub-stop-border);
    border-radius: var(--radius);
    padding: 0.6rem 0.8rem;
    background: var(--surface);
}

.hub-stop-text {
    margin: 0;
    font-weight: 700;
    font-size: 0.88rem;
}

.hub-next-steps {
    border-top: 1px solid var(--line);
    margin-top: 1rem;
    padding-top: 0.8rem;
}

.btn-stop {
    background: var(--stop-btn-bg);
    color: #ffffff;
    white-space: nowrap;
}

.btn-stop:hover {
    background: var(--stop-btn-hover);
    color: #ffffff;
}

/* ── Relationships ── */

.relationship-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.5rem;
}

.relationship-item {
    display: grid;
    gap: 0.5rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    padding: 0.7rem;
    background: var(--surface-soft);
}

.relationship-item.is-selected {
    border-color: var(--selected-border);
    background: var(--selected-bg);
}

.relationship-label {
    margin: 0;
    font-weight: 700;
}

.relationship-meta {
    margin: 0.15rem 0 0;
    font-size: 0.85rem;
}

.relationship-status-block {
    display: grid;
    align-content: start;
    gap: 0.3rem;
    justify-items: start;
}

.relationship-badges,
.hub-state-badges {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.3rem 0.5rem;
}

.badge-label {
    font-family: var(--font-mono);
    font-size: 0.72rem;
    color: var(--muted);
    letter-spacing: 0.04em;
}

/* ── Registration ── */

.register-shell {
    display: grid;
    gap: 0.75rem;
}

.register-step-card,
.register-form-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 1rem;
}

.register-purpose {
    color: var(--muted);
    margin-bottom: 0;
    font-size: 0.88rem;
}

.register-progress {
    margin: 0.8rem 0 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 0.4rem;
}

.register-progress li {
    display: grid;
    grid-template-columns: 1.4rem 1fr;
    align-items: center;
    gap: 0.5rem;
    border-radius: var(--radius-sm);
    border: 1px solid var(--line);
    padding: 0.35rem 0.5rem;
    color: var(--muted);
    font-size: 0.88rem;
}

.register-progress li span:first-child {
    width: 1.3rem;
    height: 1.3rem;
    border-radius: 4px;
    display: inline-grid;
    place-items: center;
    border: 1px solid var(--line);
    font-size: 0.75rem;
    font-weight: 700;
    background: var(--surface-soft);
}

.register-progress li.is-current {
    color: var(--text);
    border-color: var(--selected-border);
    background: var(--selected-bg);
}

.register-progress li.is-complete {
    border-color: var(--progress-complete-border);
    background: var(--progress-complete-bg);
    color: var(--progress-complete-text);
}

.register-progress li.is-complete span:first-child {
    border-color: var(--progress-complete-step-border);
    background: var(--progress-complete-step-bg);
}

.register-progress li.is-locked {
    opacity: 0.5;
}

.register-form h2 {
    margin-bottom: 0.4rem;
}

.register-statement {
    border-left: 2px solid var(--statement-line);
    padding-left: 0.6rem;
    color: var(--muted);
    font-size: 0.9rem;
}

.check-row {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    margin: 0.4rem 0;
}

.check-row input {
    margin-top: 0.2rem;
}

.field-label {
    display: block;
    font-weight: 700;
    margin: 0.5rem 0 0.2rem;
    font-size: 0.88rem;
}

.field-input {
    width: 100%;
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    padding: 0.5rem 0.65rem;
    font: inherit;
    font-size: 0.9rem;
    color: var(--text);
    background: var(--surface-soft);
}

.field-input:focus-visible {
    outline: 2px solid var(--focus);
    outline-offset: 1px;
}

.field-help {
    color: var(--muted);
    font-size: 0.85rem;
}

.register-errors {
    margin-bottom: 0.8rem;
    background: var(--error-bg);
    border: 1px solid var(--error-border);
    border-radius: var(--radius-sm);
    padding: 0.6rem;
}

.register-errors h2 {
    font-size: 1rem;
}

.register-errors ul {
    margin: 0;
    padding-left: 1rem;
}

.review-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.35rem;
}

.review-list li {
    display: flex;
    justify-content: space-between;
    gap: 0.8rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    padding: 0.4rem 0.55rem;
    font-size: 0.88rem;
}

.review-list li.is-done {
    background: var(--progress-complete-bg);
    border-color: var(--progress-complete-border);
}

.review-list li.is-missing {
    background: var(--error-bg);
    border-color: var(--error-border);
}

/* ── Terminal stop banner ── */

.terminal-banner {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    background: var(--terminal-banner-bg);
    border: 2px solid var(--terminal-banner-border);
    border-radius: var(--radius);
    padding: 0.75rem 1rem;
    color: var(--terminal-banner-text);
    font-family: var(--font-mono);
    font-size: 0.95rem;
    font-weight: 700;
    letter-spacing: 0.01em;
}

.terminal-banner-label {
    display: inline-block;
    background: var(--terminal-banner-label-bg);
    color: var(--terminal-banner-text);
    font-family: var(--font-mono);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    padding: 0.15em 0.5em;
    border-radius: var(--radius-sm);
    white-space: nowrap;
    flex-shrink: 0;
}

.workspace-interactive.is-frozen {
    opacity: 0.6;
    pointer-events: none;
    user-select: none;
}

.workspace-interactive {
    border: none;
    padding: 0;
    margin: 0;
    min-width: 0;
}

/* ── Workspace ── */

.workspace-chat-card {
    display: grid;
}

.workspace-chat-input {
    min-height: 6rem;
}

.workspace-tasks-disabled {
    margin-top: 0.4rem;
    border: 1px solid var(--warn-line);
    background: var(--warn-bg);
    border-radius: var(--radius-sm);
    padding: 0.5rem 0.65rem;
    font-size: 0.88rem;
}

.workspace-tasks-card button[disabled] {
    cursor: not-allowed;
    opacity: 0.5;
}

.workspace-chat-disabled {
    margin-top: 0.4rem;
    border: 1px solid var(--warn-line);
    background: var(--warn-bg);
    border-radius: var(--radius-sm);
    padding: 0.5rem 0.65rem;
    font-size: 0.88rem;
}

.workspace-chat-card button[disabled],
.workspace-chat-card textarea[disabled] {
    cursor: not-allowed;
    opacity: 0.5;
}

.register-summary-note,
.register-safe-links {
    color: var(--muted);
    font-size: 0.88rem;
}

/* ── Final CTA ── */

.final-cta .container {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: clamp(1rem, 3vw, 1.5rem);
    text-align: center;
}

.final-cta .actions {
    justify-content: center;
}

/* ── Process stack ── */

.process-stack {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 0.5rem;
}

.process-stack li {
    padding: 0.8rem;
    border: 1px solid var(--line);
    border-radius: var(--radius-sm);
    background: var(--surface);
}

.callout {
    background: var(--ok-bg);
}

.card-warn {
    background: var(--warn-bg);
    border-color: var(--warn-line);
}

.narrow {
    width: min(600px, calc(100% - 2rem));
}

/* ── Footer ── */

.site-footer {
    border-top: 1px solid var(--line);
    background: var(--footer-bg);
}

.footer-inner {
    padding: 0.8rem 0 1.2rem;
    display: grid;
    gap: 0.5rem;
}

.footer-note {
    margin: 0;
    color: var(--muted);
    font-size: 0.8rem;
}

.footer-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.7rem;
    font-size: 0.8rem;
}

/* ── Animation ── */

@keyframes rise {
    from {
        opacity: 0;
        transform: translateY(6px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* ── Responsive ── */

@media (min-width: 768px) {
    .site-nav {
        display: inline-flex;
    }

    .hero-grid {
        grid-template-columns: 1.35fr 1fr;
        align-items: start;
    }

    .card-grid {
        grid-template-columns: 1fr 1fr;
    }

    .trust-strip {
        grid-template-columns: repeat(3, 1fr);
    }

    .process-strip {
        grid-template-columns: repeat(5, minmax(0, 1fr));
    }

    .relationship-item {
        grid-template-columns: 1fr auto;
        align-items: start;
    }

    .register-shell {
        grid-template-columns: 0.9fr 1.3fr;
        align-items: start;
    }
}

@media (max-width: 860px) {
    .site-nav {
        display: none;
    }

    .site-header--private .site-nav {
        display: inline-flex;
    }

    .auth-actions .btn-login {
        display: none;
    }
}

@media (min-width: 1100px) {
    .section {
        padding: 4rem 0;
    }
}
