:root {
    --ink-950: #07070B;
    --ink-900: #0B0B12;
    --ink-850: #101019;
    --ink-800: #151520;
    --ink-700: #202030;
    --text: #F7F2E8;
    --text-soft: #C9C0B2;
    --text-muted: #918879;
    --gold-500: #F6B40C;
    --gold-300: #FFE58B;
    --gold-700: #9D6A05;
    --felt-500: #0E7A4F;
    --felt-700: #074B33;
    --red-500: #C84335;
    --cta-ink: #150F08;
    --nav-ink: #161008;
    --nav-bg: rgba(7, 7, 11, 0.72);
    --hero-gold-wash: rgba(246, 180, 12, 0.13);
    --hero-gold-orbit: rgba(246, 180, 12, 0.18);
    --hero-felt-orbit: rgba(14, 122, 79, 0.18);
    --hero-shade-left: rgba(7, 7, 11, 0.95);
    --hero-shade-mid: rgba(7, 7, 11, 0.42);
    --hero-shade-right: rgba(7, 7, 11, 0.86);
    --line: rgba(255, 229, 139, 0.16);
    --line-strong: rgba(255, 229, 139, 0.34);
    --line-hover: rgba(255, 229, 139, 0.62);
    --line-glass: rgba(255, 255, 255, 0.1);
    --line-glass-strong: rgba(255, 255, 255, 0.12);
    --surface: rgba(255, 255, 255, 0.055);
    --surface-soft: rgba(255, 255, 255, 0.035);
    --surface-strong: rgba(255, 255, 255, 0.095);
    --surface-glass: rgba(255, 255, 255, 0.065);
    --surface-glass-hover: rgba(255, 255, 255, 0.1);
    --surface-deep: rgba(0, 0, 0, 0.34);
    --surface-deeper: rgba(0, 0, 0, 0.28);
    --panel-highlight: rgba(255, 255, 255, 0.11);
    --panel-highlight-low: rgba(255, 255, 255, 0.04);
    --panel-felt: rgba(14, 122, 79, 0.32);
    --panel-ink: rgba(9, 9, 16, 0.88);
    --media-gold: rgba(246, 180, 12, 0.18);
    --media-glass-top: rgba(255, 255, 255, 0.07);
    --media-glass-bottom: rgba(255, 255, 255, 0.02);
    --proof-bg-top: rgba(21, 21, 32, 0.98);
    --proof-bg-bottom: rgba(11, 11, 18, 0.98);
    --section-felt-wash: rgba(14, 122, 79, 0.08);
    --cta-gold-wash: rgba(246, 180, 12, 0.16);
    --shadow: 0 28px 90px rgba(0, 0, 0, 0.48);
    --shadow-nav: 0 16px 60px rgba(0, 0, 0, 0.28);
    --shadow-card: 0 18px 54px rgba(0, 0, 0, 0.22);
    --shadow-gold: 0 18px 42px rgba(246, 180, 12, 0.26);
    --shadow-nav-cta: 0 12px 36px rgba(246, 180, 12, 0.28);
    --shadow-symbol: 0 16px 28px rgba(0, 0, 0, 0.48);
    --shadow-logo: 0 26px 45px rgba(0, 0, 0, 0.58);
    --shadow-live: 0 0 18px rgba(14, 122, 79, 0.9);
    --shadow-bullet: 0 0 18px rgba(246, 180, 12, 0.45);
    --focus-ring: rgba(255, 229, 139, 0.9);
    --font-display: "Avenir Next", "Segoe UI", system-ui, sans-serif;
    --font-body: "Avenir Next", "Segoe UI", system-ui, sans-serif;
    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-5: 1.25rem;
    --space-6: 1.5rem;
    --space-8: 2rem;
    --space-10: 2.5rem;
    --space-12: 3rem;
    --space-16: 4rem;
    --space-20: 5rem;
    --space-24: 6rem;
    --page-x: clamp(1rem, 4vw, 2rem);
    --section-y: clamp(4rem, 8vw, 6rem);
    --shell: 1180px;
    --shell-copy: 62ch;
    --shell-section-title: 820px;
    --shell-legal: 860px;
    --shell-legal-intro: 760px;
    --shell-hero-copy: 720px;
    --hero-stage-width: 460px;
    --hero-logo-width: 360px;
    --mobile-stage-width: 420px;
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 16px;
    --radius-pill: 999px;
    --border-ui: 1px;
    --focus-width: 3px;
    --card-border: 1px solid var(--line);
    --card-border-strong: 1px solid var(--line-strong);
    --card-padding: var(--space-6);
    --card-padding-compact: var(--space-5);
    --card-min-proof: 112px;
    --trust-min-block: 136px;
    --tile-media-height: 154px;
    --tile-media-height-mobile: 130px;
    --icon-size-md: 96px;
    --dot-size: 10px;
    --nav-min-height: 64px;
    --nav-min-height-mobile: 58px;
    --nav-logo-inset: 5pt;
    --nav-logo-height: calc(var(--nav-min-height) - (2 * var(--nav-logo-inset)));
    --nav-logo-height-mobile: calc(var(--nav-min-height-mobile) - (2 * var(--nav-logo-inset)));
    --button-min-height: 54px;
    --nav-cta-min-height: 48px;
    --nav-cta-min-height-mobile: 44px;
    --pill-min-height: 38px;
    --footer-logo-size: 44px;
    --brandmark-opacity: 0.78;
    --tracking-ui: 0.12em;
    --tracking-label: 0.16em;
    --tracking-micro: 0.08em;
    --tracking-prompt: 0.14em;
    --tracking-button: 0.04em;
    --motion-fast: 180ms ease;
    --motion-theme: 220ms ease;
}

:root[data-theme="light"] {
    --ink-950: #FAF7EF;
    --ink-900: #F3EBDC;
    --ink-850: #EFE4D0;
    --ink-800: #E7D8BD;
    --ink-700: #CDBB98;
    --text: #17120B;
    --text-soft: #4C4030;
    --text-muted: #746850;
    --gold-500: #B77702;
    --gold-300: #7F4F00;
    --gold-700: #5E3900;
    --felt-500: #0A6B4A;
    --felt-700: #084831;
    --red-500: #B3382B;
    --cta-ink: #FFF7E6;
    --nav-ink: #FFF7E6;
    --nav-bg: rgba(255, 251, 242, 0.82);
    --hero-gold-wash: rgba(183, 119, 2, 0.16);
    --hero-gold-orbit: rgba(183, 119, 2, 0.16);
    --hero-felt-orbit: rgba(10, 107, 74, 0.16);
    --hero-shade-left: rgba(250, 247, 239, 0.93);
    --hero-shade-mid: rgba(250, 247, 239, 0.44);
    --hero-shade-right: rgba(250, 247, 239, 0.84);
    --line: rgba(82, 61, 24, 0.18);
    --line-strong: rgba(82, 61, 24, 0.34);
    --line-hover: rgba(127, 79, 0, 0.62);
    --line-glass: rgba(82, 61, 24, 0.16);
    --line-glass-strong: rgba(82, 61, 24, 0.2);
    --surface: rgba(255, 255, 255, 0.58);
    --surface-soft: rgba(255, 255, 255, 0.46);
    --surface-strong: rgba(255, 255, 255, 0.72);
    --surface-glass: rgba(255, 255, 255, 0.62);
    --surface-glass-hover: rgba(255, 255, 255, 0.84);
    --surface-deep: rgba(255, 251, 242, 0.62);
    --surface-deeper: rgba(255, 251, 242, 0.52);
    --panel-highlight: rgba(255, 255, 255, 0.72);
    --panel-highlight-low: rgba(255, 255, 255, 0.28);
    --panel-felt: rgba(10, 107, 74, 0.16);
    --panel-ink: rgba(255, 251, 242, 0.86);
    --media-gold: rgba(183, 119, 2, 0.16);
    --media-glass-top: rgba(255, 255, 255, 0.7);
    --media-glass-bottom: rgba(255, 255, 255, 0.28);
    --proof-bg-top: rgba(255, 251, 242, 0.98);
    --proof-bg-bottom: rgba(243, 235, 220, 0.98);
    --section-felt-wash: rgba(10, 107, 74, 0.08);
    --cta-gold-wash: rgba(183, 119, 2, 0.16);
    --shadow: 0 28px 90px rgba(71, 45, 8, 0.18);
    --shadow-nav: 0 16px 60px rgba(71, 45, 8, 0.16);
    --shadow-card: 0 18px 54px rgba(71, 45, 8, 0.12);
    --shadow-gold: 0 18px 42px rgba(183, 119, 2, 0.22);
    --shadow-nav-cta: 0 12px 36px rgba(183, 119, 2, 0.22);
    --shadow-symbol: 0 16px 28px rgba(71, 45, 8, 0.2);
    --shadow-logo: 0 22px 38px rgba(71, 45, 8, 0.26);
    --shadow-live: 0 0 18px rgba(10, 107, 74, 0.58);
    --shadow-bullet: 0 0 18px rgba(183, 119, 2, 0.34);
    --focus-ring: rgba(10, 107, 74, 0.9);
}

* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    background: var(--ink-950);
    color: var(--text);
    overflow-x: hidden;
    scroll-behavior: smooth;
}

body {
    min-width: 320px;
    overflow-x: hidden;
    background:
        radial-gradient(circle at 50% 0%, var(--hero-gold-wash), transparent 32rem),
        linear-gradient(180deg, var(--ink-950), var(--ink-900) 42%, var(--ink-950));
    color: var(--text);
    font-family: var(--font-body);
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    transition: background var(--motion-theme), color var(--motion-theme);
}

img,
svg,
canvas {
    display: block;
    max-width: 100%;
}

a {
    color: inherit;
}

:focus-visible {
    outline: var(--focus-width) solid var(--focus-ring);
    outline-offset: 4px;
}

.section-shell,
.nav-shell,
.hero-shell {
    width: min(calc(100% - (2 * var(--page-x))), var(--shell));
    margin-inline: auto;
}

.site-nav {
    position: fixed;
    inset: var(--space-4) 0 auto;
    z-index: 50;
    pointer-events: none;
    transition: transform var(--motion-fast);
}

.site-nav.is-scrolled {
    transform: translateY(-4px);
}

.nav-shell {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: var(--space-6);
    min-height: var(--nav-min-height);
    padding: var(--space-2);
    border: var(--border-ui) solid var(--line-glass);
    border-radius: var(--radius-lg);
    background: var(--nav-bg);
    box-shadow: var(--shadow-nav);
    -webkit-backdrop-filter: blur(18px);
    backdrop-filter: blur(18px);
    pointer-events: auto;
}

.nav-brand {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 0;
    width: fit-content;
    padding-inline: var(--nav-logo-inset);
    color: var(--gold-300);
    font-family: var(--font-display);
    font-size: 0.88rem;
    font-weight: 900;
    letter-spacing: var(--tracking-label);
    text-decoration: none;
    text-transform: uppercase;
}

.nav-brand img {
    width: auto;
    height: var(--nav-logo-height);
    object-fit: contain;
}

.nav-links {
    display: flex;
    align-items: center;
    gap: var(--space-6);
}

.nav-actions {
    justify-self: end;
    display: flex;
    align-items: center;
    gap: var(--space-2);
    min-width: 0;
}

.nav-links a,
.footer-links a {
    color: var(--text-soft);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: var(--tracking-ui);
    text-decoration: none;
    text-transform: uppercase;
    transition: color var(--motion-fast);
}

.nav-links a:hover,
.footer-links a:hover {
    color: var(--gold-300);
}

.nav-icon-link,
.theme-toggle,
.nav-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: var(--border-ui) solid transparent;
    font-weight: 900;
    text-decoration: none;
    transition: transform var(--motion-fast), border-color var(--motion-fast), background var(--motion-fast), color var(--motion-fast), box-shadow var(--motion-fast);
}

.nav-icon-link,
.theme-toggle {
    min-height: var(--nav-cta-min-height);
    border-color: var(--line-glass-strong);
    border-radius: var(--radius-pill);
    background: var(--surface-glass);
    color: var(--text);
}

.nav-icon-link {
    gap: var(--space-2);
    padding: 0 var(--space-3);
    font-size: 0.76rem;
    letter-spacing: var(--tracking-micro);
    text-transform: uppercase;
}

.theme-toggle {
    position: relative;
    width: var(--nav-cta-min-height);
    padding: 0;
    cursor: pointer;
}

.nav-control-icon,
.nav-star-icon,
.theme-icon {
    width: 18px;
    height: 18px;
    flex: 0 0 auto;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.nav-star-icon {
    width: 14px;
    height: 14px;
    color: var(--gold-300);
    fill: currentColor;
}

.theme-icon {
    position: absolute;
    transition: opacity var(--motion-fast), transform var(--motion-fast);
}

.theme-icon-moon,
:root[data-theme="light"] .theme-icon-sun {
    opacity: 0;
    transform: scale(0.72) rotate(-20deg);
}

:root[data-theme="light"] .theme-icon-moon,
.theme-icon-sun {
    opacity: 1;
    transform: scale(1) rotate(0deg);
}

.nav-icon-link:hover,
.theme-toggle:hover {
    transform: translateY(-2px);
    border-color: var(--line-hover);
    background: var(--surface-glass-hover);
    color: var(--gold-300);
}

.nav-cta {
    min-height: var(--nav-cta-min-height);
    padding: 0 var(--space-5);
    border-radius: var(--radius-md);
    background: linear-gradient(180deg, var(--gold-300), var(--gold-500));
    color: var(--nav-ink);
    box-shadow: var(--shadow-nav-cta);
}

.nav-cta-short {
    display: none;
}

.nav-cta:hover,
.btn:hover {
    transform: translateY(-2px);
}

.hero {
    position: relative;
    min-height: 100svh;
    isolation: isolate;
    overflow: hidden;
    border-bottom: 1px solid var(--line);
}

.hero-bg,
.hero-shade {
    position: absolute;
    inset: 0;
    z-index: -2;
}

.hero-bg {
    background: url('../assets/img/hero-bg.webp') center / cover no-repeat;
    opacity: 0.56;
    transform: scale(1.02);
}

.hero-shade {
    z-index: -1;
    background:
        radial-gradient(circle at 75% 26%, var(--hero-gold-orbit), transparent 24rem),
        radial-gradient(circle at 20% 55%, var(--hero-felt-orbit), transparent 22rem),
        linear-gradient(90deg, var(--hero-shade-left), var(--hero-shade-mid) 48%, var(--hero-shade-right));
}

.hero-shell {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, var(--hero-stage-width));
    align-items: center;
    gap: clamp(2rem, 6vw, 5rem);
    min-height: 100svh;
    padding-block: clamp(8rem, 14vw, 10rem) var(--space-16);
}

.hero-copy {
    max-width: var(--shell-hero-copy);
}

.eyebrow {
    color: var(--gold-300);
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: var(--tracking-label);
    text-transform: uppercase;
}

h1,
h2,
h3 {
    font-family: var(--font-display);
    font-weight: 900;
    letter-spacing: 0;
    line-height: 0.98;
}

h1 {
    max-width: 10.5ch;
    margin-top: var(--space-5);
    font-size: clamp(3.2rem, 7.2vw, 6.4rem);
    text-wrap: balance;
}

h1 span {
    display: block;
}

h2 {
    font-size: clamp(2.35rem, 5vw, 4.7rem);
    text-wrap: balance;
}

h3 {
    font-size: clamp(1.35rem, 2vw, 1.75rem);
}

.hero-sub,
.section-copy > p,
.section-title > p,
.cta-shell > p {
    color: var(--text-soft);
    font-size: clamp(1.02rem, 1.7vw, 1.2rem);
}

.hero-sub {
    max-width: 58ch;
    margin-top: var(--space-6);
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-4);
    margin-top: var(--space-8);
}

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: var(--button-min-height);
    padding: 0 var(--space-6);
    border: var(--border-ui) solid transparent;
    border-radius: var(--radius-md);
    font-weight: 900;
    letter-spacing: var(--tracking-button);
    text-decoration: none;
    text-transform: uppercase;
    transition: transform var(--motion-fast), border-color var(--motion-fast), background var(--motion-fast), box-shadow var(--motion-fast);
}

.btn-primary {
    background: linear-gradient(180deg, var(--gold-300), var(--gold-500));
    color: var(--cta-ink);
    box-shadow: var(--shadow-gold);
}

.btn-secondary {
    border-color: var(--line-strong);
    background: var(--surface-glass);
    color: var(--text);
}

.btn-secondary:hover {
    border-color: var(--line-hover);
    background: var(--surface-glass-hover);
}

.legal-note {
    max-width: 62ch;
    margin-top: var(--space-5);
    color: var(--text-muted);
    font-size: 0.88rem;
}

.hero-stage {
    justify-self: end;
    width: min(100%, var(--hero-stage-width));
}

.hero-logo {
    width: min(var(--hero-logo-width), 82%);
    margin-inline: auto;
    margin-bottom: var(--space-8);
    filter: drop-shadow(var(--shadow-logo));
}

.table-preview,
.studio-panel {
    border: var(--card-border-strong);
    border-radius: var(--radius-lg);
    background:
        linear-gradient(180deg, var(--panel-highlight), var(--panel-highlight-low)),
        linear-gradient(135deg, var(--panel-felt), var(--panel-ink));
    box-shadow: var(--shadow);
    -webkit-backdrop-filter: blur(16px);
    backdrop-filter: blur(16px);
}

.table-preview {
    padding: var(--space-5);
}

.table-header,
.room-meta,
.studio-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
}

.table-header {
    color: var(--text);
    font-size: 0.82rem;
    font-weight: 900;
    letter-spacing: var(--tracking-ui);
    text-transform: uppercase;
}

.status-dot {
    width: var(--dot-size);
    height: var(--dot-size);
    border-radius: var(--radius-pill);
    background: var(--felt-500);
    box-shadow: var(--shadow-live);
}

.reel-preview {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-3);
    margin-block: var(--space-5);
    padding: var(--space-4);
    border: var(--border-ui) solid var(--line-glass-strong);
    border-radius: var(--radius-md);
    background: var(--surface-deep);
}

.reel-preview img {
    width: 100%;
    height: auto;
    aspect-ratio: 1;
    object-fit: contain;
    padding: var(--space-2);
    border-radius: var(--radius-sm);
    background: radial-gradient(circle, var(--line), transparent 62%);
}

.room-meta {
    color: var(--text-soft);
    font-size: 0.86rem;
}

.proof-strip {
    border-bottom: var(--border-ui) solid var(--line);
    background: linear-gradient(180deg, var(--proof-bg-top), var(--proof-bg-bottom));
}

.proof-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-4);
    padding-block: var(--space-8);
}

.proof-item,
.step-card,
.feature-card,
.trust-item,
.legal-card {
    border: var(--card-border);
    border-radius: var(--radius-md);
    background: var(--surface);
    box-shadow: var(--shadow-card);
}

.proof-item {
    min-height: var(--card-min-proof);
    padding: var(--card-padding-compact);
    background: var(--surface-soft);
}

.proof-item strong,
.trust-item strong {
    display: block;
    color: var(--gold-300);
    font-family: var(--font-display);
    font-size: 1.15rem;
    font-weight: 900;
}

.proof-item span,
.trust-item span,
.feature-card p,
.step-card p,
.clean-list li,
.footer-shell p {
    color: var(--text-soft);
}

.section-band {
    padding-block: var(--section-y);
}

.rooms-section,
.trust-section {
    background:
        linear-gradient(90deg, var(--section-felt-wash), transparent 42%),
        var(--ink-900);
}

.games-section,
.studio-section {
    background: var(--ink-950);
}

.split-layout,
.studio-layout,
.trust-layout {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
    gap: clamp(2rem, 6vw, 5rem);
    align-items: center;
}

.studio-layout,
.trust-layout {
    grid-template-columns: minmax(0, 1fr) minmax(0, 0.9fr);
}

.section-copy > h2,
.section-title > h2,
.cta-shell > h2 {
    margin-top: var(--space-4);
}

.section-copy > p,
.section-title > p,
.cta-shell > p {
    max-width: var(--shell-copy);
    margin-top: var(--space-5);
}

.section-title {
    max-width: var(--shell-section-title);
    margin-bottom: var(--space-12);
}

.steps-grid,
.feature-grid,
.trust-grid {
    display: grid;
    gap: var(--space-4);
}

.steps-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.feature-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.trust-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.step-card,
.feature-card,
.trust-item {
    padding: var(--card-padding);
}

.step-number {
    display: inline-flex;
    margin-bottom: var(--space-8);
    color: var(--gold-500);
    font-family: var(--font-display);
    font-weight: 900;
}

.step-card h3,
.feature-card h3 {
    margin-bottom: var(--space-3);
}

.feature-card {
    min-height: 100%;
    transition: transform var(--motion-fast), border-color var(--motion-fast), background var(--motion-fast);
}

.feature-card:hover {
    transform: translateY(-4px);
    border-color: var(--line-strong);
    background: var(--surface-strong);
}

.feature-media {
    display: grid;
    place-items: center;
    height: var(--tile-media-height);
    margin-bottom: var(--space-5);
    border-radius: var(--radius-sm);
    background:
        radial-gradient(circle, var(--media-gold), transparent 58%),
        linear-gradient(180deg, var(--media-glass-top), var(--media-glass-bottom));
}

.feature-media img {
    width: var(--icon-size-md);
    height: var(--icon-size-md);
    object-fit: contain;
    filter: drop-shadow(var(--shadow-symbol));
}

.studio-panel {
    padding: var(--space-5);
}

.studio-topbar {
    justify-content: flex-start;
    color: var(--text-soft);
    font-size: 0.78rem;
    letter-spacing: var(--tracking-micro);
    text-transform: uppercase;
}

.studio-topbar span {
    width: var(--dot-size);
    height: var(--dot-size);
    border-radius: var(--radius-pill);
    background: var(--gold-500);
}

.studio-topbar span:nth-child(2) {
    background: var(--felt-500);
}

.studio-topbar span:nth-child(3) {
    background: var(--red-500);
}

.prompt-card {
    margin-block: var(--space-5);
    padding: var(--space-5);
    border: var(--border-ui) solid var(--line-glass-strong);
    border-radius: var(--radius-md);
    background: var(--surface-deeper);
}

.prompt-card small {
    color: var(--gold-300);
    font-size: 0.72rem;
    font-weight: 900;
    letter-spacing: var(--tracking-prompt);
    text-transform: uppercase;
}

.prompt-card p {
    margin-top: var(--space-2);
    color: var(--text);
    font-family: var(--font-display);
    font-size: clamp(1.4rem, 3vw, 2.25rem);
    font-weight: 900;
    line-height: 1.08;
}

.generated-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-3);
}

.generated-row img {
    width: 100%;
    height: auto;
    aspect-ratio: 1;
    object-fit: contain;
    padding: var(--space-3);
    border: var(--border-ui) solid var(--line-glass);
    border-radius: var(--radius-sm);
    background: var(--surface);
}

.clean-list {
    display: grid;
    gap: var(--space-3);
    margin-top: var(--space-6);
    list-style: none;
}

.clean-list li {
    position: relative;
    padding-left: var(--space-6);
}

.clean-list li::before {
    content: '';
    position: absolute;
    top: 0.62em;
    left: 0;
    width: var(--dot-size);
    height: var(--dot-size);
    border-radius: var(--radius-pill);
    background: var(--gold-500);
    box-shadow: var(--shadow-bullet);
}

.trust-item {
    min-height: var(--trust-min-block);
}

.trust-item span {
    display: block;
    margin-top: var(--space-2);
}

.final-cta {
    padding-block: var(--section-y);
    border-block: var(--border-ui) solid var(--line);
    background:
        radial-gradient(circle at 50% 0%, var(--cta-gold-wash), transparent 28rem),
        linear-gradient(180deg, var(--ink-850), var(--ink-950));
    text-align: center;
}

.cta-shell {
    max-width: var(--shell-section-title);
}

.cta-shell .hero-actions {
    justify-content: center;
}

.cta-shell p {
    margin-inline: auto;
}

.soon-row {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-3);
    margin-top: var(--space-5);
}

.soon-row span {
    display: inline-flex;
    align-items: center;
    min-height: var(--pill-min-height);
    padding-inline: var(--space-4);
    border: var(--border-ui) solid var(--line);
    border-radius: var(--radius-sm);
    color: var(--text-soft);
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: var(--tracking-ui);
    text-transform: uppercase;
}

.site-footer {
    padding-block: var(--space-16);
    background: var(--ink-950);
}

.legal-page {
    padding-block: clamp(8rem, 14vw, 10rem) var(--space-20);
}

.legal-page h1 {
    max-width: 12ch;
    margin-top: var(--space-4);
    font-size: clamp(3rem, 8vw, 6rem);
}

.legal-intro {
    max-width: var(--shell-legal-intro);
    margin-top: var(--space-6);
    color: var(--text-soft);
    font-size: clamp(1.05rem, 1.8vw, 1.25rem);
}

.legal-card {
    max-width: var(--shell-legal);
    margin-top: var(--space-5);
    padding: var(--card-padding);
}

.legal-card:first-of-type {
    margin-top: var(--space-10);
}

.legal-page h2 {
    color: var(--gold-300);
    font-size: clamp(1.35rem, 2vw, 1.85rem);
}

.legal-page p,
.legal-page li {
    color: var(--text-soft);
}

.legal-card p,
.legal-page ul {
    margin-top: var(--space-3);
}

.legal-page ul {
    display: grid;
    gap: var(--space-2);
    padding-left: var(--space-6);
}

.footer-shell {
    display: grid;
    justify-items: center;
    gap: var(--space-6);
    text-align: center;
}

.footer-logo {
    width: var(--footer-logo-size);
    height: var(--footer-logo-size);
    object-fit: contain;
    opacity: var(--brandmark-opacity);
}

.footer-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-6);
}

.footer-shell p {
    max-width: var(--shell-legal);
    font-size: 0.92rem;
}

@media (max-width: 980px) {
    .nav-shell {
        grid-template-columns: minmax(0, 1fr) auto;
    }

    .nav-links {
        display: none;
    }

    .nav-github span {
        display: none;
    }

    .hero-shell,
    .split-layout,
    .studio-layout,
    .trust-layout {
        grid-template-columns: 1fr;
    }

    .hero-stage {
        justify-self: start;
        max-width: var(--mobile-stage-width);
    }

    .steps-grid,
    .feature-grid,
    .trust-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    :root {
        --section-y: 3.5rem;
    }

    .site-nav {
        position: absolute;
        inset: var(--space-3) 0 auto;
    }

    .nav-shell {
        min-height: var(--nav-min-height-mobile);
        gap: var(--space-3);
    }

    .nav-brand img {
        max-width: 100%;
        height: var(--nav-logo-height-mobile);
    }

    .nav-actions {
        gap: var(--space-1);
    }

    .nav-icon-link,
    .theme-toggle {
        min-height: var(--nav-cta-min-height-mobile);
    }

    .nav-icon-link {
        width: var(--nav-cta-min-height-mobile);
        padding: 0;
    }

    .theme-toggle {
        width: var(--nav-cta-min-height-mobile);
    }

    .nav-cta {
        min-height: var(--nav-cta-min-height-mobile);
        padding-inline: var(--space-3);
        font-size: 0.88rem;
    }

    .nav-cta-full {
        display: none;
    }

    .nav-cta-short {
        display: inline;
    }

    .nav-brand img {
        max-width: 132px;
    }

    .hero-shell {
        gap: var(--space-10);
        padding-block: 6.5rem var(--space-12);
    }

    h1 {
        max-width: 100%;
        font-size: clamp(2.75rem, 12vw, 3.35rem);
    }

    h2 {
        font-size: clamp(2.25rem, 11vw, 3.35rem);
    }

    .hero-actions,
    .cta-shell .hero-actions {
        flex-direction: column;
    }

    .btn {
        width: 100%;
    }

    .soon-row {
        display: grid;
        grid-template-columns: 1fr;
    }

    .soon-row span {
        justify-content: center;
    }

    .hero-logo {
        display: none;
    }

    .proof-grid {
        grid-template-columns: 1fr;
        padding-block: var(--space-5);
    }

    .proof-item,
    .step-card,
    .feature-card,
    .trust-item,
    .studio-panel {
        padding: var(--card-padding-compact);
    }

    .feature-media {
        height: var(--tile-media-height-mobile);
    }

    .room-meta {
        align-items: flex-start;
        flex-direction: column;
    }
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        scroll-behavior: auto !important;
        transition-duration: 0.01ms !important;
    }
}
