/* ============================================
   Snowflake Marketplace — Dormant Equity Reactivation
   Page-specific styles scoped under .snowflake-page
   ============================================ */

.snowflake-page {
    --sf-card: rgba(12, 26, 46, 0.78);
    --sf-card-strong: rgba(15, 34, 61, 0.92);
    --sf-line: rgba(126, 202, 236, 0.16);
    --sf-line-strong: rgba(126, 202, 236, 0.28);
    --sf-text: #f1f7ff;
    --sf-muted: #c3d2e4;
    --sf-soft: #9db3cc;
    --sf-cyan: #52b8e0;
    --sf-green: #24c47e;
    --sf-orange: #f59e0b;
    --sf-purple: #9b7cff;
    --sf-radius: 12px;
    --sf-shadow: 0 28px 90px rgba(0, 0, 0, 0.38);
}

.snowflake-page {
    background:
        radial-gradient(circle at 18% 2%, rgba(82, 184, 224, 0.22), transparent 32rem),
        radial-gradient(circle at 86% 9%, rgba(36, 196, 126, 0.14), transparent 25rem),
        linear-gradient(180deg, #050b15 0%, #060d18 48%, #040912 100%);
}

.snowflake-page::before {
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    content: "";
    opacity: 0.38;
    background-image:
        linear-gradient(rgba(126, 202, 236, 0.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(126, 202, 236, 0.06) 1px, transparent 1px);
    background-size: 58px 58px;
    mask-image: radial-gradient(ellipse at 50% 12%, #000 8%, transparent 74%);
    -webkit-mask-image: radial-gradient(ellipse at 50% 12%, #000 8%, transparent 74%);
}

.snowflake-page main {
    position: relative;
    z-index: 1;
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 clamp(1rem, 3vw, 2.5rem);
}

html:has(body.snowflake-page) {
    scroll-padding-top: 96px;
}

/* ---- Buttons (scoped) ---- */

.snowflake-page .sf-button {
    display: inline-flex;
    min-height: 44px;
    align-items: center;
    justify-content: center;
    border: 1px solid transparent;
    border-radius: 10px;
    padding: 0.8rem 1.15rem;
    text-decoration: none;
    font-weight: 750;
    line-height: 1;
    transition: transform 160ms ease, border-color 160ms ease, background 160ms ease;
    cursor: pointer;
    font-family: inherit;
}

.snowflake-page .sf-button:hover {
    transform: translateY(-1px);
}

.snowflake-page .sf-button-primary {
    background: var(--sf-cyan);
    color: #04111e;
    box-shadow: 0 12px 30px rgba(82, 184, 224, 0.22);
}

.snowflake-page .sf-button-primary:hover {
    background: #76c9e9;
}

.snowflake-page .sf-button-secondary {
    border-color: var(--sf-line-strong);
    background: rgba(255, 255, 255, 0.04);
    color: var(--sf-text);
}

.snowflake-page .sf-button-secondary:hover {
    border-color: rgba(82, 184, 224, 0.46);
    background: rgba(82, 184, 224, 0.1);
}

/* ---- Hero ---- */

.snowflake-page .sf-hero {
    padding: clamp(3rem, 7vw, 5.5rem) 0 clamp(2.5rem, 6vw, 5rem);
}

.snowflake-page .sf-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
    gap: clamp(2rem, 5vw, 5rem);
    align-items: center;
}

.snowflake-page .sf-hero-copy {
    display: grid;
    gap: 1.35rem;
}

.snowflake-page .sf-hero-copy h1 {
    margin: 0;
    color: var(--sf-text);
    font-weight: 650;
    font-size: clamp(2.4rem, 5.8vw, 4.6rem);
    line-height: 1.05;
    letter-spacing: -0.01em;
    max-width: 980px;
}

.snowflake-page .sf-hero-copy p:not(.sf-eyebrow) {
    max-width: 820px;
    color: var(--sf-muted);
    font-size: clamp(1.05rem, 1.3vw, 1.2rem);
    line-height: 1.6;
}

.snowflake-page .sf-eyebrow {
    color: var(--sf-cyan);
    font-size: 0.78rem;
    font-weight: 850;
    letter-spacing: 0.11em;
    text-transform: uppercase;
}

.snowflake-page .sf-hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
    margin-top: 0.5rem;
}

.snowflake-page .sf-hero-panel {
    position: relative;
    min-height: 440px;
    overflow: hidden;
    border: 1px solid var(--sf-line-strong);
    border-radius: var(--sf-radius);
    padding: clamp(1.25rem, 3vw, 2rem);
    background:
        linear-gradient(150deg, rgba(82, 184, 224, 0.12), transparent 38%),
        radial-gradient(circle at 82% 16%, rgba(155, 124, 255, 0.18), transparent 16rem),
        var(--sf-card);
    box-shadow: var(--sf-shadow);
}

.snowflake-page .sf-hero-panel::before {
    position: absolute;
    inset: 0;
    content: "";
    opacity: 0.44;
    background-image:
        linear-gradient(rgba(126, 202, 236, 0.09) 1px, transparent 1px),
        linear-gradient(90deg, rgba(126, 202, 236, 0.09) 1px, transparent 1px);
    background-size: 38px 38px;
}

.snowflake-page .sf-panel-orbit {
    position: absolute;
    inset: 11% 8%;
    border: 1px solid rgba(82, 184, 224, 0.18);
    border-radius: 50%;
    box-shadow:
        inset 0 0 60px rgba(82, 184, 224, 0.08),
        0 0 90px rgba(36, 196, 126, 0.12);
}

.snowflake-page .sf-panel-orbit::before,
.snowflake-page .sf-panel-orbit::after {
    position: absolute;
    inset: 15%;
    content: "";
    border: 1px solid rgba(82, 184, 224, 0.14);
    border-radius: 50%;
}

.snowflake-page .sf-panel-orbit::after {
    inset: 30%;
    border-color: rgba(36, 196, 126, 0.22);
}

.snowflake-page .sf-hero-object,
.snowflake-page .sf-hero-signal-grid {
    position: relative;
    z-index: 1;
}

.snowflake-page .sf-hero-object {
    display: grid;
    gap: 0.65rem;
    margin-top: 3rem;
    border: 1px solid rgba(82, 184, 224, 0.28);
    border-radius: 10px;
    padding: 1.25rem;
    background: rgba(5, 11, 21, 0.72);
}

.snowflake-page .sf-hero-object span,
.snowflake-page .sf-object-card span {
    color: var(--sf-soft);
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.snowflake-page .sf-hero-object strong,
.snowflake-page .sf-object-card strong {
    color: var(--sf-text);
    font-size: clamp(1.2rem, 2vw, 1.65rem);
    overflow-wrap: anywhere;
}

.snowflake-page .sf-hero-signal-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.7rem;
    margin-top: 1rem;
}

.snowflake-page .sf-hero-signal-grid span {
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 10px;
    padding: 0.75rem;
    background: rgba(255, 255, 255, 0.045);
    color: #dce8f7;
    font-weight: 700;
    text-align: center;
}

.snowflake-page .sf-metrics-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 1rem;
    margin-top: clamp(2rem, 5vw, 4.5rem);
}

.snowflake-page .sf-metric-card,
.snowflake-page .sf-info-card,
.snowflake-page .sf-logic-card,
.snowflake-page .sf-query-card,
.snowflake-page .sf-object-card,
.snowflake-page .sf-companion-card,
.snowflake-page .sf-callout,
.snowflake-page .sf-calculator-inputs,
.snowflake-page .sf-calculator-results,
.snowflake-page .sf-schema-group {
    border: 1px solid var(--sf-line);
    border-radius: var(--sf-radius);
    background: var(--sf-card);
    box-shadow: 0 16px 50px rgba(0, 0, 0, 0.18);
}

.snowflake-page .sf-metric-card {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 148px;
    padding: 1.1rem;
}

.snowflake-page .sf-metric-card strong {
    display: block;
    color: var(--sf-text);
    /* Tighter upper bound so the longest value ("No 12-mo activity") sits on one line
       beside the short numeric values without dominating the row visually. */
    font-size: clamp(1.35rem, 2.05vw, 1.85rem);
    line-height: 1.08;
    font-weight: 700;
    letter-spacing: -0.01em;
    text-wrap: balance;
    overflow-wrap: break-word;
}

.snowflake-page .sf-metric-card span {
    display: block;
    margin-top: 0.85rem;
    color: var(--sf-muted);
    font-size: 0.95rem;
    line-height: 1.35;
    font-weight: 650;
    text-wrap: balance;
}

.snowflake-page .sf-fine-print,
.snowflake-page .sf-note {
    color: var(--sf-soft);
    font-size: 0.95rem;
    line-height: 1.55;
}

.snowflake-page .sf-fine-print {
    margin-top: 1rem;
}

/* ---- Sections ---- */

.snowflake-page .sf-section {
    padding: clamp(3rem, 7vw, 6rem) 0;
}

.snowflake-page .sf-section.sf-banded {
    position: relative;
}

.snowflake-page .sf-section.sf-banded::before {
    position: absolute;
    inset: 0 calc(clamp(1rem, 3vw, 2.5rem) * -1);
    z-index: -1;
    content: "";
    border-block: 1px solid rgba(126, 202, 236, 0.08);
    background: linear-gradient(180deg, rgba(12, 26, 46, 0.42), rgba(5, 11, 21, 0.1));
}

.snowflake-page .sf-section-head {
    display: grid;
    gap: 0.75rem;
    margin-bottom: 1.75rem;
}

.snowflake-page .sf-section-head h2 {
    margin: 0;
    color: var(--sf-text);
    font-weight: 650;
    font-size: clamp(1.85rem, 4.2vw, 3.4rem);
    line-height: 1.07;
    max-width: 920px;
    letter-spacing: -0.01em;
}

.snowflake-page .sf-lead-copy {
    max-width: 940px;
    color: var(--sf-muted);
    font-size: 1.08rem;
    line-height: 1.6;
}

.snowflake-page .sf-two-column {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.25rem;
    max-width: 1100px;
    color: var(--sf-muted);
    font-size: 1.05rem;
    line-height: 1.65;
}

.snowflake-page .sf-card-grid {
    display: grid;
    gap: 1rem;
    margin-top: 1.5rem;
}

.snowflake-page .sf-card-grid.sf-four {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.snowflake-page .sf-card-grid.sf-three {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.snowflake-page .sf-info-card {
    display: grid;
    gap: 0.7rem;
    min-height: 180px;
    padding: 1.25rem;
}

.snowflake-page .sf-info-card h3,
.snowflake-page .sf-logic-card h3,
.snowflake-page .sf-query-card h3 {
    margin: 0;
    color: var(--sf-text);
    font-size: 1.1rem;
    font-weight: 700;
    line-height: 1.25;
}

.snowflake-page .sf-info-card p,
.snowflake-page .sf-logic-card p {
    color: var(--sf-muted);
    line-height: 1.6;
    margin: 0;
}

.snowflake-page .sf-info-card::before,
.snowflake-page .sf-logic-card::before {
    display: block;
    width: 36px;
    height: 3px;
    border-radius: 999px;
    content: "";
    background: linear-gradient(90deg, var(--sf-cyan), var(--sf-green));
}

/* ---- Tables ---- */

.snowflake-page .sf-table-wrap {
    width: 100%;
    margin: 1.5rem 0;
    overflow-x: auto;
    border: 1px solid var(--sf-line);
    border-radius: var(--sf-radius);
}

.snowflake-page .sf-table-wrap table {
    width: 100%;
    min-width: 640px;
    border-collapse: collapse;
    background: rgba(5, 11, 21, 0.5);
}

.snowflake-page .sf-table-wrap th,
.snowflake-page .sf-table-wrap td {
    border-bottom: 1px solid rgba(126, 202, 236, 0.1);
    padding: 0.9rem 1rem;
    text-align: left;
    vertical-align: top;
    font-family: inherit;
}

.snowflake-page .sf-table-wrap th {
    color: var(--sf-text);
    background: rgba(82, 184, 224, 0.08);
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.snowflake-page .sf-table-wrap td {
    color: var(--sf-muted);
}

.snowflake-page .sf-table-wrap .sf-value-cell {
    color: var(--sf-text);
    font-weight: 700;
    text-align: right;
}

/* ---- Logic grid ---- */

.snowflake-page .sf-logic-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem;
    margin: 1.5rem 0;
}

.snowflake-page .sf-logic-card {
    display: grid;
    gap: 0.75rem;
    min-height: 270px;
    padding: 1.05rem;
}

.snowflake-page .sf-logic-card > .sf-step-num {
    color: var(--sf-cyan);
    font-weight: 850;
    font-size: 0.85rem;
    letter-spacing: 0.08em;
}

.snowflake-page .sf-logic-card code {
    display: block;
    border: 1px solid rgba(82, 184, 224, 0.14);
    border-radius: 8px;
    padding: 0.75rem;
    background: rgba(1, 6, 12, 0.54);
    color: #f6fbff;
    font-size: 0.82rem;
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
    white-space: normal;
    overflow-wrap: anywhere;
}

/* ---- SQL block ---- */

.snowflake-page .sf-sql-card {
    overflow: hidden;
    margin: 1.25rem 0;
    border: 1px solid rgba(126, 202, 236, 0.18);
    border-radius: var(--sf-radius);
    background: #020812;
}

.snowflake-page .sf-sql-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    border-bottom: 1px solid rgba(126, 202, 236, 0.14);
    padding: 0.7rem 0.85rem;
    color: var(--sf-soft);
    font-size: 0.82rem;
    font-weight: 800;
}

.snowflake-page .sf-copy-button {
    border: 1px solid rgba(82, 184, 224, 0.3);
    border-radius: 8px;
    padding: 0.42rem 0.65rem;
    background: rgba(82, 184, 224, 0.11);
    color: var(--sf-text);
    cursor: pointer;
    font-weight: 800;
    font-family: inherit;
    font-size: 0.85rem;
}

.snowflake-page .sf-copy-button:hover {
    background: rgba(82, 184, 224, 0.22);
}

.snowflake-page .sf-sql-card pre {
    max-height: 560px;
    margin: 0;
    overflow: auto;
    padding: 1rem;
    color: #e7f5ff;
    font-size: 0.88rem;
    line-height: 1.55;
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
}

/* ---- ROI Calculator ---- */

.snowflake-page .sf-calculator-grid {
    display: grid;
    grid-template-columns: minmax(280px, 0.9fr) minmax(320px, 1.1fr);
    gap: 1rem;
    margin: 1.5rem 0;
}

.snowflake-page .sf-calculator-inputs,
.snowflake-page .sf-calculator-results {
    display: grid;
    gap: 0.85rem;
    padding: 1rem;
}

.snowflake-page .sf-calculator-help {
    border: 1px solid rgba(82, 184, 224, 0.16);
    border-radius: 8px;
    padding: 0.85rem;
    background: rgba(82, 184, 224, 0.07);
    color: var(--sf-muted);
    font-size: 0.95rem;
    line-height: 1.55;
    margin: 0;
}

.snowflake-page .sf-field {
    display: grid;
    gap: 0.45rem;
}

.snowflake-page .sf-field span {
    display: flex;
    justify-content: space-between;
    gap: 0.75rem;
    color: #dce8f7;
    font-weight: 700;
    font-size: 0.95rem;
}

.snowflake-page .sf-field em {
    color: var(--sf-cyan);
    font-style: normal;
}

.snowflake-page .sf-field input,
.snowflake-page .sf-schema-search input {
    width: 100%;
    border: 1px solid rgba(126, 202, 236, 0.18);
    border-radius: 8px;
    padding: 0.82rem 0.9rem;
    background: rgba(1, 6, 12, 0.52);
    color: var(--sf-text);
    font-family: inherit;
    font-size: 1rem;
}

.snowflake-page .sf-field input:focus,
.snowflake-page .sf-schema-search input:focus {
    outline: 2px solid rgba(82, 184, 224, 0.5);
    outline-offset: 1px;
    border-color: rgba(82, 184, 224, 0.5);
}

.snowflake-page .sf-calculator-results {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.snowflake-page .sf-calculator-results article {
    min-height: 116px;
    border: 1px solid rgba(126, 202, 236, 0.12);
    border-radius: 10px;
    padding: 1rem;
    background: rgba(255, 255, 255, 0.035);
}

.snowflake-page .sf-calculator-results article.sf-result-highlight {
    background: linear-gradient(145deg, rgba(82, 184, 224, 0.14), rgba(36, 196, 126, 0.06));
}

.snowflake-page .sf-calculator-results .sf-fixed-price-card {
    border-color: rgba(245, 158, 11, 0.28);
    background: linear-gradient(145deg, rgba(245, 158, 11, 0.12), rgba(82, 184, 224, 0.04));
}

.snowflake-page .sf-calculator-results .sf-fixed-price-card strong {
    color: var(--sf-orange);
}

.snowflake-page .sf-calculator-results article span {
    display: block;
    color: var(--sf-soft);
    font-size: 0.9rem;
}

.snowflake-page .sf-calculator-results article strong {
    display: block;
    margin-top: 0.45rem;
    color: var(--sf-text);
    font-size: clamp(1.4rem, 2.6vw, 2rem);
    line-height: 1.1;
    font-weight: 700;
}

.snowflake-page .sf-callout {
    display: grid;
    gap: 0.8rem;
    max-width: 1080px;
    margin: 1.25rem 0;
    padding: 1.15rem;
    border-color: rgba(36, 196, 126, 0.24);
    background: linear-gradient(145deg, rgba(36, 196, 126, 0.09), rgba(82, 184, 224, 0.06));
    color: #dce8f7;
    line-height: 1.6;
}

.snowflake-page .sf-callout p {
    margin: 0;
}

.snowflake-page .sf-object-card {
    display: grid;
    grid-template-columns: minmax(280px, 0.75fr) minmax(320px, 1.25fr);
    gap: 1rem;
    align-items: start;
    margin: 1.5rem 0;
    padding: 1rem;
}

.snowflake-page .sf-object-card .sf-table-wrap {
    margin: 0;
}

.snowflake-page .sf-object-card > div {
    display: grid;
    gap: 0.65rem;
    align-content: start;
}

/* ---- Schema browser ---- */

.snowflake-page .sf-schema-browser {
    display: grid;
    gap: 1rem;
}

.snowflake-page .sf-schema-search {
    display: grid;
    gap: 0.5rem;
    max-width: 560px;
    color: var(--sf-text);
    font-weight: 800;
    font-size: 0.85rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.snowflake-page .sf-schema-groups {
    display: grid;
    gap: 0.85rem;
}

.snowflake-page .sf-schema-group {
    overflow: hidden;
}

.snowflake-page .sf-schema-group-title {
    display: flex;
    width: 100%;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    border: 0;
    padding: 1rem;
    background: transparent;
    color: var(--sf-text);
    cursor: pointer;
    text-align: left;
    font-family: inherit;
    font-size: 1rem;
    font-weight: 700;
}

.snowflake-page .sf-schema-group-title strong {
    color: var(--sf-cyan);
    white-space: nowrap;
    font-weight: 700;
    font-size: 0.85rem;
}

.snowflake-page .sf-schema-group-title::after {
    content: "+";
    color: var(--sf-soft);
    font-size: 1.2rem;
    margin-left: 0.5rem;
    transition: transform 200ms ease;
}

.snowflake-page .sf-schema-group[data-open="true"] .sf-schema-group-title::after {
    content: "−";
}

.snowflake-page .sf-schema-fields {
    display: grid;
    gap: 0.7rem;
    border-top: 1px solid rgba(126, 202, 236, 0.1);
    padding: 1rem;
}

.snowflake-page .sf-schema-group[data-open="false"] .sf-schema-fields {
    display: none;
}

.snowflake-page .sf-schema-field {
    display: grid;
    grid-template-columns: minmax(220px, 0.35fr) 1fr;
    gap: 1rem;
}

.snowflake-page .sf-schema-field code {
    color: #f6fbff;
    font-size: 0.9rem;
    overflow-wrap: anywhere;
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
}

.snowflake-page .sf-schema-field p {
    color: var(--sf-muted);
    margin: 0;
    line-height: 1.5;
}

/* ---- Quick start queries ---- */

.snowflake-page .sf-quickstart-stack {
    display: grid;
    gap: 1.25rem;
    margin-top: 1.5rem;
}

.snowflake-page .sf-query-card {
    padding: 1.25rem;
}

.snowflake-page .sf-query-label {
    color: var(--sf-cyan);
    font-size: 0.78rem;
    font-weight: 850;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    margin: 0;
}

.snowflake-page .sf-query-card h3 {
    margin: 0.35rem 0 0;
}

.snowflake-page .sf-business-use {
    display: grid;
    gap: 0.35rem;
    color: var(--sf-muted);
    line-height: 1.6;
}

.snowflake-page .sf-business-use strong {
    color: var(--sf-text);
}

/* ---- Companion card ---- */

.snowflake-page .sf-companion-card {
    display: flex;
    gap: 1rem;
    align-items: center;
    justify-content: space-between;
    margin-top: 1.5rem;
    padding: 1.25rem;
    border-color: rgba(245, 158, 11, 0.24);
    background: linear-gradient(145deg, rgba(245, 158, 11, 0.1), rgba(82, 184, 224, 0.04));
    flex-wrap: wrap;
}

.snowflake-page .sf-companion-card > div {
    display: grid;
    gap: 0.65rem;
    flex: 1;
    min-width: 260px;
}

.snowflake-page .sf-companion-card strong.sf-price {
    color: var(--sf-orange);
    font-size: 1.35rem;
    font-weight: 700;
}

.snowflake-page .sf-companion-card h3 {
    margin: 0;
    color: var(--sf-text);
    font-size: 1.25rem;
    line-height: 1.3;
}

.snowflake-page .sf-companion-card p {
    margin: 0;
    color: var(--sf-muted);
    line-height: 1.55;
}

/* ---- Final CTA ---- */

.snowflake-page .sf-final-cta {
    margin: clamp(3rem, 7vw, 6rem) 0;
    overflow: hidden;
    border: 1px solid rgba(82, 184, 224, 0.28);
    border-radius: var(--sf-radius);
    padding: clamp(1.75rem, 5vw, 4rem);
    background:
        radial-gradient(circle at 78% 20%, rgba(82, 184, 224, 0.22), transparent 21rem),
        radial-gradient(circle at 12% 85%, rgba(36, 196, 126, 0.13), transparent 18rem),
        linear-gradient(135deg, rgba(12, 26, 46, 0.92), rgba(5, 11, 21, 0.92));
    box-shadow: var(--sf-shadow);
}

.snowflake-page .sf-final-cta > div {
    display: grid;
    max-width: 860px;
    gap: 1rem;
}

.snowflake-page .sf-final-cta h2 {
    margin: 0;
    color: var(--sf-text);
    font-weight: 650;
    font-size: clamp(1.85rem, 4.2vw, 3rem);
    line-height: 1.1;
    letter-spacing: -0.01em;
}

.snowflake-page .sf-final-cta p {
    color: var(--sf-muted);
    font-size: 1.06rem;
    line-height: 1.6;
    margin: 0;
}

.snowflake-page .sf-support-line {
    font-size: 0.95rem;
}

.snowflake-page .sf-support-line a {
    color: var(--sf-cyan);
    text-decoration: none;
}

.snowflake-page .sf-support-line a:hover {
    text-decoration: underline;
}

/* ---- Responsive ---- */

@media (max-width: 1180px) {
    .snowflake-page .sf-hero-grid,
    .snowflake-page .sf-calculator-grid,
    .snowflake-page .sf-object-card {
        grid-template-columns: 1fr;
    }

    .snowflake-page .sf-metrics-grid,
    .snowflake-page .sf-card-grid.sf-four,
    .snowflake-page .sf-card-grid.sf-three {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .snowflake-page .sf-hero {
        padding-top: 2rem;
    }

    .snowflake-page .sf-hero-panel {
        min-height: 360px;
    }

    .snowflake-page .sf-hero-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .snowflake-page .sf-hero-actions .sf-button {
        width: 100%;
    }

    .snowflake-page .sf-two-column,
    .snowflake-page .sf-calculator-results,
    .snowflake-page .sf-schema-field {
        grid-template-columns: 1fr;
    }

    .snowflake-page .sf-hero-signal-grid,
    .snowflake-page .sf-metrics-grid,
    .snowflake-page .sf-card-grid.sf-four,
    .snowflake-page .sf-card-grid.sf-three {
        grid-template-columns: 1fr;
    }

    .snowflake-page .sf-metric-card {
        min-height: 100px;
    }

    .snowflake-page .sf-table-wrap .sf-value-cell {
        text-align: left;
    }

    .snowflake-page .sf-logic-grid {
        grid-template-columns: 1fr;
    }

    .snowflake-page .sf-sql-card pre {
        font-size: 0.78rem;
    }

    .snowflake-page .sf-companion-card {
        flex-direction: column;
        align-items: stretch;
    }
}

/* =========================================================
   Aggregate companion page — additions
   ========================================================= */

/* Hero panel layout: the aggregate version stacks object + badges + views.
   Default behaviour kept; here we tighten spacing and remove the 3rem top margin
   the reactivation page applies to .sf-hero-object. */
.snowflake-page .sf-aggregate-hero-panel .sf-hero-object {
    margin-top: 0;
}

/* Highlight the last two badge chips in amber so the compliance signals pop
   ("INVESTOR_CNT >= 50" and "Code dictionary included"). */
.snowflake-page .sf-aggregate-badges span:nth-child(3),
.snowflake-page .sf-aggregate-badges span:nth-child(4) {
    border-color: rgba(245, 158, 11, 0.28);
    background: rgba(245, 158, 11, 0.08);
}

/* Included views panel — list of view names below the hero badges. */
.snowflake-page .sf-included-views-panel {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 0.8rem;
    margin-top: 1rem;
    border: 1px solid rgba(82, 184, 224, 0.22);
    border-radius: var(--sf-radius);
    padding: 1rem;
    background: rgba(1, 6, 12, 0.48);
}

.snowflake-page .sf-included-views-panel > span {
    color: var(--sf-soft);
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.snowflake-page .sf-included-views-panel ul {
    display: grid;
    gap: 0.5rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.snowflake-page .sf-included-views-panel li {
    border-bottom: 1px solid rgba(126, 202, 236, 0.1);
    padding-bottom: 0.45rem;
    color: #e7f5ff;
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
    font-size: 0.82rem;
    overflow-wrap: anywhere;
}

.snowflake-page .sf-included-views-panel li:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

/* Object grid — 3-column grid of view summary cards. */
.snowflake-page .sf-object-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    margin-top: 1.5rem;
}

.snowflake-page .sf-view-card {
    display: grid;
    gap: 0.7rem;
    padding: 1.25rem;
    border: 1px solid var(--sf-line);
    border-radius: var(--sf-radius);
    background: var(--sf-card);
    box-shadow: 0 16px 50px rgba(0, 0, 0, 0.18);
}

.snowflake-page .sf-view-card > span {
    color: var(--sf-cyan);
    font-weight: 850;
    font-size: 0.85rem;
    letter-spacing: 0.08em;
}

.snowflake-page .sf-view-card h3 {
    margin: 0;
    color: var(--sf-text);
    font-size: 1.05rem;
    font-weight: 700;
    line-height: 1.3;
    overflow-wrap: anywhere;
}

.snowflake-page .sf-view-card p {
    margin: 0;
    color: var(--sf-muted);
    line-height: 1.55;
    font-size: 0.95rem;
}

.snowflake-page .sf-view-card strong {
    color: var(--sf-text);
}

/* Native HTML <details> schema accordion. No JS needed. */
.snowflake-page .sf-schema-stack {
    display: grid;
    gap: 0.85rem;
    margin-top: 1.5rem;
}

.snowflake-page .sf-schema-detail {
    overflow: hidden;
    border: 1px solid var(--sf-line);
    border-radius: var(--sf-radius);
    background: var(--sf-card);
    box-shadow: 0 16px 50px rgba(0, 0, 0, 0.18);
}

.snowflake-page .sf-schema-detail summary {
    cursor: pointer;
    list-style: none;
    padding: 1rem;
    color: var(--sf-text);
    font-weight: 700;
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
    font-size: 0.95rem;
    position: relative;
    padding-right: 2.5rem;
}

.snowflake-page .sf-schema-detail summary::-webkit-details-marker {
    display: none;
}

.snowflake-page .sf-schema-detail summary::after {
    content: "+";
    position: absolute;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--sf-soft);
    font-size: 1.2rem;
    font-family: var(--font-display);
}

.snowflake-page .sf-schema-detail[open] summary::after {
    content: "−";
}

.snowflake-page .sf-schema-detail .sf-table-wrap {
    margin: 0;
    border: 0;
    border-top: 1px solid rgba(126, 202, 236, 0.1);
    border-radius: 0;
}

.snowflake-page .sf-schema-fields-compact {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.55rem;
    border-top: 1px solid rgba(126, 202, 236, 0.1);
    padding: 1rem;
}

.snowflake-page .sf-schema-fields-compact code {
    display: block;
    border: 1px solid rgba(82, 184, 224, 0.14);
    border-radius: 8px;
    padding: 0.6rem 0.7rem;
    background: rgba(1, 6, 12, 0.48);
    color: #e7f5ff;
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
    font-size: 0.78rem;
    overflow-wrap: anywhere;
}

/* Band definitions — 5-column grid of compact reference cards. */
.snowflake-page .sf-definition-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 1rem;
    margin-top: 1.5rem;
}

.snowflake-page .sf-definition-card {
    display: grid;
    gap: 0.7rem;
    padding: 1.1rem;
    border: 1px solid var(--sf-line);
    border-radius: var(--sf-radius);
    background: var(--sf-card);
    box-shadow: 0 16px 50px rgba(0, 0, 0, 0.18);
}

.snowflake-page .sf-definition-card::before {
    display: block;
    width: 36px;
    height: 3px;
    border-radius: 999px;
    content: "";
    background: linear-gradient(90deg, var(--sf-cyan), var(--sf-green));
}

.snowflake-page .sf-definition-card h3 {
    margin: 0;
    color: var(--sf-text);
    font-size: 0.92rem;
    font-weight: 700;
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
    overflow-wrap: anywhere;
}

.snowflake-page .sf-definition-card ul {
    margin: 0;
    padding-left: 1.1rem;
    color: var(--sf-muted);
    font-size: 0.88rem;
    line-height: 1.6;
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
}

.snowflake-page .sf-definition-card p.sf-note {
    margin: 0;
    font-size: 0.85rem;
    line-height: 1.45;
}

/* Campaign tiers — 3-column. */
.snowflake-page .sf-tier-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
    margin-top: 1.5rem;
}

.snowflake-page .sf-tier-card {
    display: grid;
    gap: 0.8rem;
    padding: 1.25rem;
    border: 1px solid var(--sf-line);
    border-radius: var(--sf-radius);
    background: var(--sf-card);
    box-shadow: 0 16px 50px rgba(0, 0, 0, 0.18);
}

.snowflake-page .sf-tier-card::before {
    display: block;
    width: 36px;
    height: 3px;
    border-radius: 999px;
    content: "";
    background: linear-gradient(90deg, var(--sf-cyan), var(--sf-green));
}

.snowflake-page .sf-tier-card h3 {
    margin: 0;
    color: var(--sf-text);
    font-size: 1rem;
    font-weight: 700;
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
}

.snowflake-page .sf-tier-card code {
    display: block;
    white-space: pre-wrap;
    border: 1px solid rgba(82, 184, 224, 0.14);
    border-radius: 8px;
    padding: 0.75rem;
    background: rgba(1, 6, 12, 0.54);
    color: #f6fbff;
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
    font-size: 0.82rem;
    line-height: 1.5;
    overflow-wrap: anywhere;
}

.snowflake-page .sf-tier-card p {
    margin: 0;
    color: var(--sf-muted);
    line-height: 1.55;
    font-size: 0.95rem;
}

.snowflake-page .sf-tier-card p strong {
    color: var(--sf-text);
}

/* Amber-tinted warning callout (Responsible Use). */
.snowflake-page .sf-callout.sf-warning {
    border-color: rgba(245, 158, 11, 0.28);
    background: linear-gradient(145deg, rgba(245, 158, 11, 0.1), rgba(82, 184, 224, 0.04));
}

/* Tablet — collapse the wider grids. */
@media (max-width: 1180px) {
    .snowflake-page .sf-object-grid,
    .snowflake-page .sf-tier-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .snowflake-page .sf-definition-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
    .snowflake-page .sf-schema-fields-compact {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .snowflake-page .sf-object-grid,
    .snowflake-page .sf-tier-grid,
    .snowflake-page .sf-definition-grid,
    .snowflake-page .sf-schema-fields-compact {
        grid-template-columns: 1fr;
    }
}
