/* BeaconStoneVC — home (intelligence terminal) page styles.
   Standalone stylesheet for the redesigned home page only. Not loaded on
   other pages, which still use the Tailwind-built style.css until they're
   ported. */

:root {
    --paper: #F2EDE5;
    --paper-2: #E9E2D6;
    --paper-3: #DFD6C6;
    --ink: #141210;
    --ink-2: #2B2621;
    --ink-3: #5C544A;
    --ink-4: #8A8175;
    --rule: #2B2621;
    --rule-soft: rgba(20,18,16,0.14);
    --ember: #C8451C;
    --ember-deep: #9E3314;
    --signal: #1E6F4A;
    --warn: #A86A0A;
    --font-display: "Fraunces", "Times New Roman", serif;
    --font-sans: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;
    --font-mono: "JetBrains Mono", ui-monospace, monospace;
}

* { box-sizing: border-box; }
html, body {
    margin: 0;
    padding: 0;
    background: var(--paper);
    color: var(--ink);
    font-family: var(--font-sans);
    -webkit-font-smoothing: antialiased;
}
body { min-height: 100vh; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }

/* Paper grain */
body::before {
    content: "";
    position: fixed;
    inset: 0;
    background-image:
        radial-gradient(rgba(20,18,16,0.025) 1px, transparent 1px),
        radial-gradient(rgba(20,18,16,0.02) 1px, transparent 1px);
    background-size: 3px 3px, 7px 7px;
    background-position: 0 0, 1px 2px;
    pointer-events: none;
    z-index: 0;
    opacity: 0.7;
}

main, header, footer, .ticker { position: relative; z-index: 1; }

/* --- TICKER ------------------------------------------------------- */
.ticker {
    position: sticky;
    top: 0;
    z-index: 40;
    background: var(--ink);
    color: var(--paper);
    border-bottom: 1px solid var(--ink);
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.04em;
    overflow: hidden;
    display: flex;
    align-items: stretch;
    height: 32px;
}
.ticker-label {
    background: var(--ember);
    color: var(--paper);
    padding: 0 14px;
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
    text-transform: uppercase;
    flex-shrink: 0;
    position: relative;
}
.ticker-label::after {
    content: "";
    position: absolute;
    right: -10px;
    top: 0;
    width: 0;
    height: 0;
    border-left: 10px solid var(--ember);
    border-top: 16px solid transparent;
    border-bottom: 16px solid transparent;
}
.ticker-pulse {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--paper);
    animation: pulse 1.8s ease-in-out infinite;
}
@keyframes pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.3; }
}
.ticker-track {
    flex: 1;
    overflow: hidden;
    display: flex;
    align-items: center;
    padding-left: 20px;
    -webkit-mask-image: linear-gradient(90deg, transparent 0, black 24px, black calc(100% - 60px), transparent);
    mask-image: linear-gradient(90deg, transparent 0, black 24px, black calc(100% - 60px), transparent);
}
.ticker-stream {
    display: flex;
    align-items: center;
    gap: 0;
    white-space: nowrap;
    animation: ticker 90s linear infinite;
    padding-right: 40px;
}
@keyframes ticker {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}
.ticker-item {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 0 22px;
    border-right: 1px solid rgba(242,237,229,0.1);
}
.ticker-arrow { color: var(--ember); font-weight: 600; }
.ticker-arrow.down { color: #E89B4A; }
.ticker-time { opacity: 0.5; font-size: 10px; }

/* --- MASTHEAD ----------------------------------------------------- */
.masthead {
    border-bottom: 1px solid var(--rule);
    background: var(--paper);
    position: sticky;
    top: 32px;
    z-index: 30;
}
.masthead-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 32px;
    gap: 24px;
    border-bottom: 1px solid var(--rule-soft);
}
.mast-left {
    display: flex;
    align-items: baseline;
    gap: 16px;
    color: var(--ink);
}
.mast-wordmark {
    font-family: var(--font-display);
    font-size: 30px;
    line-height: 1;
    letter-spacing: -0.035em;
    font-weight: 500;
    color: var(--ink);
    font-variation-settings: "opsz" 72;
    white-space: nowrap;
}
.mast-wordmark .amp,
.footer-wordmark .amp {
    font-style: italic;
    font-weight: 300;
    color: var(--ember);
    padding: 0 1px;
}
.mast-tag {
    font-family: var(--font-display);
    font-size: 13px;
    font-style: italic;
    color: var(--ink-3);
    font-weight: 400;
    padding-left: 14px;
    border-left: 1px solid var(--rule-soft);
}
.mast-right { display: flex; align-items: stretch; gap: 0; }
.mast-search {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 16px;
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--ink-4);
    background: var(--paper-2);
    border: 1px solid var(--rule-soft);
    min-width: 380px;
}
.mast-search-icon { font-size: 13px; color: var(--ink-3); }
.mast-search input {
    flex: 1;
    border: 0;
    background: transparent;
    font: inherit;
    color: var(--ink-2);
    outline: none;
    min-width: 0;
}
.mast-search input::placeholder { color: var(--ink-4); }
.mast-search kbd {
    font-family: var(--font-mono);
    font-size: 10px;
    background: var(--paper);
    border: 1px solid var(--rule-soft);
    padding: 2px 6px;
    border-radius: 3px;
    margin-left: auto;
    color: var(--ink-3);
}

/* --- NAV ---------------------------------------------------------- */
.nav {
    display: flex;
    align-items: stretch;
    background: var(--paper);
    flex-wrap: wrap;
}
.nav-item {
    padding: 12px 18px;
    font-family: var(--font-sans);
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.02em;
    color: var(--ink-2);
    cursor: pointer;
    transition: background 120ms;
    display: flex;
    align-items: center;
    gap: 6px;
    position: relative;
    white-space: nowrap;
}
.nav-item:hover { background: var(--paper-2); }
.nav-item.active { color: var(--ink); background: var(--paper); }
.nav-item.active::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -1px;
    height: 2px;
    background: var(--ember);
}
.nav-item .badge {
    font-family: var(--font-mono);
    font-size: 9px;
    background: var(--ink);
    color: var(--paper);
    padding: 1px 5px;
    border-radius: 2px;
    letter-spacing: 0.05em;
}
.nav-more {
    position: relative;
    display: flex;
    align-items: stretch;
}
.nav-more-btn {
    border: 0;
    background: transparent;
    color: var(--ink-2);
    font-family: inherit;
    line-height: 1;
    cursor: pointer;
}
.nav-more.active > .nav-more-btn {
    color: var(--ink);
}
.nav-more.active > .nav-more-btn::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -1px;
    height: 2px;
    background: var(--ember);
}
.nav-more .caret {
    margin-left: 4px;
    font-size: 10px;
    color: var(--ink-3);
}
.nav-dropdown {
    display: none;
    flex-direction: column;
    position: absolute;
    top: 100%;
    left: 0;
    background: var(--paper);
    border: 1px solid var(--rule);
    min-width: 200px;
    z-index: 50;
    box-shadow: 0 4px 12px rgba(20,18,16,0.08);
}
.nav-more.open > .nav-dropdown {
    display: flex;
}
.nav-dd-item {
    display: block;
    padding: 10px 16px;
    font-family: var(--font-sans);
    font-size: 12px;
    font-weight: 500;
    color: var(--ink-2);
    border-bottom: 1px solid var(--rule-soft);
    cursor: pointer;
    white-space: nowrap;
}
.nav-dd-item:last-child { border-bottom: none; }
.nav-dd-item:hover { background: var(--paper-2); color: var(--ink); }
.nav-dd-item.active { color: var(--ink); background: var(--paper-2); }
.nav-spacer { flex: 1; }
.nav-meta {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 0 20px;
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--ink-3);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    white-space: nowrap;
}
.nav-meta .sep { color: var(--rule-soft); }
.nav-meta .live-dot {
    display: inline-block;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--ember);
    animation: pulse 1.8s ease-in-out infinite;
    vertical-align: 1px;
    margin-right: 4px;
}

/* --- OVERVIEW ----------------------------------------------------- */
.overview {
    border-bottom: 1px solid var(--rule);
    background: var(--paper);
}
.overview-eyebrow {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 32px;
    border-bottom: 1px solid var(--rule-soft);
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--ink-3);
}
.overview-eyebrow .sep { color: var(--rule-soft); }
.overview-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    border-bottom: 1px solid var(--rule);
}
.ov-stat {
    padding: 14px 20px;
    border-right: 1px solid var(--rule-soft);
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.ov-stat:last-child { border-right: none; }
.ov-stat-label {
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--ink-3);
    display: flex;
    align-items: center;
    gap: 8px;
}
.ov-stat-label .dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
}
.dot-signal { background: var(--signal); }
.dot-warn   { background: var(--warn); }
.dot-ember  { background: var(--ember); }
.dot-ink    { background: var(--ink); }
.ov-stat-row {
    display: flex;
    align-items: baseline;
    gap: 10px;
}
.ov-stat-value {
    font-family: var(--font-display);
    font-size: 38px;
    line-height: 1;
    letter-spacing: -0.03em;
    color: var(--ink);
    font-weight: 400;
    font-variation-settings: "opsz" 72;
}
.ov-stat-delta {
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 600;
    color: var(--ink-3);
}
.ov-stat-delta.pos { color: var(--signal); }
.ov-stat-delta.neg { color: var(--ember); }
.ov-spark {
    width: 100%;
    height: 16px;
    display: block;
    margin-top: 2px;
}

.overview-panels {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
}
.ov-panel {
    padding: 18px 20px 20px;
    border-right: 1px solid var(--rule-soft);
    min-width: 0;
}
.ov-panel:last-child { border-right: none; }
.ov-panel-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    margin-bottom: 12px;
    gap: 10px;
}
.ov-panel-head > span:first-child {
    font-family: var(--font-display);
    font-size: 16px;
    font-weight: 500;
    letter-spacing: -0.01em;
    color: var(--ink);
    font-variation-settings: "opsz" 24;
}
.ov-panel-sub {
    font-family: var(--font-mono);
    font-size: 9px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--ink-3);
}
.ov-graph-wrap {
    position: relative;
}
.ov-graph {
    display: block;
    width: 100%;
    height: auto;
    max-height: 360px;
}
.ov-graph-node { cursor: pointer; }
.ov-graph-node circle { transition: filter 120ms; }
.ov-graph-node:hover circle,
.ov-graph-node:focus-visible circle {
    filter: brightness(1.18);
    stroke: var(--ember);
    stroke-width: 2;
}
.ov-graph-tip {
    position: absolute;
    pointer-events: none;
    background: var(--paper);
    border: 1px solid var(--rule);
    box-shadow: 0 4px 12px rgba(20,18,16,0.10);
    padding: 10px 12px;
    min-width: 160px;
    max-width: 220px;
    z-index: 5;
    opacity: 0;
    transform: translate(-50%, calc(-100% - 10px));
    transition: opacity 90ms;
}
.ov-graph-tip.visible {
    opacity: 1;
}
.ov-graph-tip .tip-eyebrow {
    font-family: var(--font-mono);
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--ink-3);
    margin-bottom: 4px;
}
.ov-graph-tip .tip-name {
    font-family: var(--font-display);
    font-size: 16px;
    font-weight: 500;
    letter-spacing: -0.005em;
    color: var(--ink);
    line-height: 1.2;
    font-variation-settings: "opsz" 24;
}
.ov-graph-tip .tip-meta {
    font-family: var(--font-mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--ink-3);
    margin-top: 6px;
}
.ov-graph-tip .tip-cta {
    font-family: var(--font-mono);
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--ember);
    margin-top: 6px;
    font-weight: 600;
}
.ov-graph-cta {
    display: inline-block;
    margin-top: 8px;
    font-family: var(--font-mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--ink-3);
    border-bottom: 1px dotted currentColor;
    padding-bottom: 1px;
}
.ov-graph-cta:hover { color: var(--ember); }
.ov-empty {
    font-family: var(--font-display);
    font-style: italic;
    color: var(--ink-3);
    margin: 0;
    padding: 20px 0;
    text-align: center;
}

.ov-panel-active {
    display: flex;
    flex-direction: column;
}
.ov-active-list {
    display: flex;
    flex-direction: column;
}
.ov-active-list.is-paginated .ov-active-row { display: none; }
.ov-active-list.is-paginated .ov-active-row.on-page { display: grid; }
.ov-active-pager {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    padding: 10px 0 0;
    margin-top: auto;
    border-top: 1px solid var(--rule-soft);
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--ink-3);
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.ov-active-pager-btn {
    border: 1px solid var(--rule-soft);
    background: var(--paper);
    color: var(--ink-2);
    width: 22px;
    height: 22px;
    line-height: 1;
    font-size: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    padding: 0;
}
.ov-active-pager-btn:hover:not(:disabled) {
    border-color: var(--ink);
    background: var(--ink);
    color: var(--paper);
}
.ov-active-pager-btn:disabled {
    opacity: 0.35;
    cursor: not-allowed;
}
.ov-active-pager-status {
    min-width: 36px;
    text-align: center;
    font-weight: 600;
    color: var(--ink-2);
}
.ov-active-row {
    display: grid;
    grid-template-columns: 22px 1fr 60px 32px;
    gap: 10px;
    align-items: center;
    padding: 6px 0;
    border-bottom: 1px solid var(--rule-soft);
    cursor: pointer;
}
.ov-active-row:last-child { border-bottom: none; }
.ov-active-row:hover .ov-active-name { color: var(--ember); }
.ov-active-rank {
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--ink-4);
}
.ov-active-name {
    font-family: var(--font-display);
    font-size: 14px;
    color: var(--ink);
    font-weight: 500;
    transition: color 120ms;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.ov-active-bar {
    height: 4px;
    background: var(--paper-2);
    position: relative;
}
.ov-active-bar span {
    position: absolute;
    inset: 0 auto 0 0;
    background: var(--ember);
}
.ov-active-val {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--ink);
    font-weight: 600;
    text-align: right;
}

/* --- FEED HEADER + COUNT ----------------------------------------- */
.feed-header {
    padding: 28px 32px 0;
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
}
.feed-title {
    font-family: var(--font-display);
    font-size: 32px;
    letter-spacing: -0.02em;
    font-weight: 400;
    color: var(--ink);
    margin: 0;
    font-variation-settings: "opsz" 72;
}
.feed-title em { font-style: italic; font-weight: 300; }
.feed-count {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--ink-3);
    letter-spacing: 0.04em;
}
.feed-count b { color: var(--ink); font-weight: 600; }

/* --- FILTERS ------------------------------------------------------ */
.filters {
    padding: 18px 32px;
    border-bottom: 1px solid var(--rule);
    display: flex;
    align-items: center;
    gap: 6px;
    font-family: var(--font-mono);
    font-size: 11px;
    flex-wrap: wrap;
}
.filter-label {
    color: var(--ink-3);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-right: 10px;
}
.chip {
    padding: 6px 12px;
    border: 1px solid var(--rule-soft);
    background: var(--paper);
    color: var(--ink-2);
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.02em;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: all 120ms;
}
.chip:hover {
    border-color: var(--ink);
    color: var(--ink);
}
.chip.active {
    background: var(--ink);
    color: var(--paper);
    border-color: var(--ink);
}
.chip .count {
    font-size: 10px;
    opacity: 0.7;
}
.filter-divider {
    width: 1px;
    height: 16px;
    background: var(--rule-soft);
    margin: 0 10px;
}

/* --- FEED LIST ---------------------------------------------------- */
.feed-list { }
.feed-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 130px;
    align-items: start;
    gap: 20px;
    padding: 22px 32px;
    border-bottom: 1px solid var(--rule-soft);
    transition: background 100ms;
    position: relative;
}
.feed-item:hover { background: var(--paper-2); }

.feed-body-col {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.feed-body-head {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    flex-wrap: wrap;
}
.feed-body-foot {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
    font-family: var(--font-mono);
    font-size: 9px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--ink-3);
}
.feed-body-foot .sep { color: var(--rule-soft); }
.feed-body-foot .region {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--ink-2);
    text-transform: uppercase;
    letter-spacing: 0.1em;
}
.feed-body-foot .region::before {
    content: "";
    display: inline-block;
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: var(--ink-3);
}
.feed-body-foot .confidence {
    display: inline-flex;
    align-items: center;
    gap: 5px;
}
.feed-body-foot .bars {
    display: inline-flex;
    gap: 1.5px;
}
.feed-body-foot .bars span {
    width: 3px;
    height: 8px;
    background: var(--rule-soft);
    display: inline-block;
}
.feed-body-foot .bars span.on { background: var(--signal); }

.feed-type-flag {
    font-family: var(--font-mono);
    font-size: 9px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    padding: 3px 7px;
    width: fit-content;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    flex-shrink: 0;
    margin-top: 4px;
}
.flag-new { background: var(--ember); color: var(--paper); }
.flag-exit { background: var(--ink); color: var(--paper); }
.flag-update {
    background: var(--paper-3);
    color: var(--ink);
    border: 1px solid var(--rule-soft);
}
.flag-add { background: var(--signal); color: var(--paper); }
.flag-drop { background: var(--warn); color: var(--paper); }

.feed-body {
    font-family: var(--font-display);
    font-size: 18px;
    line-height: 1.35;
    color: var(--ink);
    letter-spacing: -0.005em;
    font-weight: 400;
    font-variation-settings: "opsz" 24;
    text-wrap: pretty;
    min-width: 0;
    flex: 1;
}
.feed-body .link {
    font-weight: 500;
    background-image: linear-gradient(var(--rule-soft), var(--rule-soft));
    background-size: 100% 1px;
    background-repeat: no-repeat;
    background-position: 0 100%;
    padding-bottom: 1px;
    transition: color 120ms, background-image 120ms;
}
.feed-body a.link:hover {
    color: var(--ember);
    background-image: linear-gradient(var(--ember), var(--ember));
}
.feed-body .role {
    font-family: var(--font-sans);
    font-size: 12px;
    color: var(--ink-3);
    letter-spacing: 0.02em;
    padding: 0 2px;
    font-style: normal;
}
.feed-body .arrow {
    color: var(--ember);
    font-family: var(--font-mono);
    font-size: 14px;
    padding: 0 4px;
    font-weight: 500;
}
.feed-body .status-old {
    text-decoration: line-through;
    color: var(--ink-4);
    font-family: var(--font-mono);
    font-size: 13px;
}
.feed-body .status-new {
    color: var(--ember);
    font-family: var(--font-mono);
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.feed-action {
    display: flex;
    flex-direction: column;
    gap: 6px;
    align-items: flex-end;
    padding-top: 4px;
}
.feed-time {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--ink-2);
    letter-spacing: 0.02em;
    text-align: right;
}
.feed-time.today {
    color: var(--ember);
    font-weight: 600;
}
.feed-time .abs {
    display: block;
    font-size: 9px;
    color: var(--ink-4);
    letter-spacing: 0.05em;
    margin-top: 2px;
}
.briefing-btn {
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--ink);
    border: 1px solid var(--ink);
    padding: 5px 10px;
    background: var(--paper);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-weight: 600;
}
.briefing-btn:hover { background: var(--ink); color: var(--paper); }
.briefing-btn::before {
    content: "";
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: var(--ember);
}

.feed-empty {
    padding: 60px 32px;
    text-align: center;
    font-family: var(--font-display);
    font-style: italic;
    color: var(--ink-3);
    border-bottom: 1px solid var(--rule-soft);
}
.feed-empty .link {
    color: var(--ember);
    border-bottom: 1px dotted currentColor;
}

/* --- PAGINATION --------------------------------------------------- */
.feed-pagination {
    padding: 28px 32px 40px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--ink-3);
    letter-spacing: 0.08em;
    text-transform: uppercase;
}
.page-num {
    font-family: var(--font-display);
    font-size: 22px;
    color: var(--ink);
    font-weight: 400;
    letter-spacing: -0.02em;
    margin: 0 4px;
}
.page-nav {
    display: flex;
    align-items: center;
    gap: 12px;
}
.page-link {
    color: var(--ink-3);
    cursor: pointer;
    padding: 8px 4px;
}
.page-link:hover { color: var(--ink); }
.page-btn {
    padding: 8px 16px;
    border: 1px solid var(--ink);
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    background: var(--paper);
    cursor: pointer;
    font-weight: 600;
    color: var(--ink);
}
.page-btn:hover { background: var(--ink); color: var(--paper); }

/* --- FOOTER ------------------------------------------------------- */
.footer {
    border-top: 1px solid var(--rule);
    background: var(--ink);
    color: var(--paper);
    padding: 48px 32px 32px;
}
.footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr 1fr;
    gap: 40px;
    border-bottom: 1px solid rgba(242,237,229,0.12);
    padding-bottom: 36px;
}
.footer-brand .footer-wordmark {
    font-family: var(--font-display);
    font-size: 42px;
    line-height: 0.9;
    letter-spacing: -0.045em;
    font-weight: 500;
    color: var(--paper);
    font-variation-settings: "opsz" 96;
    white-space: nowrap;
    display: inline-block;
}
.footer-brand p {
    font-family: var(--font-sans);
    font-size: 13px;
    color: rgba(242,237,229,0.6);
    line-height: 1.5;
    max-width: 320px;
    margin: 18px 0 0;
}
.footer-col h4 {
    font-family: var(--font-mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: rgba(242,237,229,0.5);
    margin: 0 0 14px;
    font-weight: 600;
}
.footer-col a {
    display: block;
    font-family: var(--font-sans);
    font-size: 13px;
    color: var(--paper);
    opacity: 0.85;
    padding: 4px 0;
    transition: color 120ms, opacity 120ms;
}
.footer-col a:hover {
    color: var(--ember);
    opacity: 1;
}
.footer-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 20px;
    font-family: var(--font-mono);
    font-size: 10px;
    color: rgba(242,237,229,0.5);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    flex-wrap: wrap;
    gap: 12px;
}
.footer-bottom-links a {
    color: var(--paper);
    opacity: 0.7;
    margin-left: 18px;
    transition: opacity 120ms;
}
.footer-bottom-links a:hover { opacity: 1; }
.footer-disclaimer {
    margin: 16px 0 0;
    font-family: var(--font-sans);
    font-size: 11px;
    color: rgba(242,237,229,0.4);
    line-height: 1.5;
    max-width: 760px;
}

/* --- PROFILE / DETAIL (archetype B) ------------------------------- */
/* Identity strip — profile header (fund, company, person, sector). */
.identity-strip {
    padding: 36px 32px 28px;
    border-bottom: 1px solid var(--rule);
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 18px;
    align-items: end;
}
@media (min-width: 900px) {
    .identity-strip {
        grid-template-columns: minmax(0, 1fr) auto;
    }
}
.identity-crumb {
    font-family: var(--font-mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--ink-3);
    margin-bottom: 12px;
}
.identity-crumb a {
    color: var(--ink-3);
    border-bottom: 1px dotted currentColor;
    padding-bottom: 1px;
}
.identity-crumb a:hover { color: var(--ember); }
.identity-name {
    font-family: var(--font-display);
    font-size: 36px;
    line-height: 1.05;
    letter-spacing: -0.025em;
    font-weight: 400;
    color: var(--ink);
    margin: 0;
    font-variation-settings: "opsz" 96;
}
.identity-name em { font-style: italic; font-weight: 300; color: var(--ember); }
@media (min-width: 900px) { .identity-name { font-size: 44px; } }
.identity-meta {
    margin-top: 12px;
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    align-items: center;
    font-family: var(--font-mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--ink-3);
}
.identity-meta .sep { color: var(--rule-soft); }
.identity-meta a {
    color: var(--ink-3);
    border-bottom: 1px dotted currentColor;
    padding-bottom: 1px;
}
.identity-meta a:hover { color: var(--ember); }

/* KPI strip — 2–4 large stat cells next to identity (or below). */
.kpi-strip {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    border-top: 1px solid var(--rule-soft);
    border-left: 1px solid var(--rule-soft);
}
.kpi-strip > div {
    padding: 14px 18px;
    border-right: 1px solid var(--rule-soft);
    border-bottom: 1px solid var(--rule-soft);
    background: var(--paper);
}
.kpi-strip .kv {
    display: block;
    font-family: var(--font-display);
    font-size: 28px;
    line-height: 1;
    letter-spacing: -0.02em;
    color: var(--ink);
    font-weight: 400;
    font-variation-settings: "opsz" 48;
}
.kpi-strip .kv.pos { color: var(--signal); }
.kpi-strip .kv.neg { color: var(--ember); }
.kpi-strip .kl {
    display: block;
    margin-top: 6px;
    font-family: var(--font-mono);
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--ink-3);
}

/* Tab strip — secondary navigation under an identity strip. */
.tab-strip {
    display: flex;
    gap: 0;
    border-bottom: 1px solid var(--rule);
    padding: 0 32px;
    overflow-x: auto;
    scrollbar-width: none;
}
.tab-strip::-webkit-scrollbar { display: none; }
.tab-strip [role="tab"], .tab-strip a {
    padding: 12px 18px;
    font-family: var(--font-sans);
    font-size: 12px;
    font-weight: 500;
    color: var(--ink-2);
    border: 0;
    background: transparent;
    cursor: pointer;
    position: relative;
    white-space: nowrap;
    text-decoration: none;
}
.tab-strip [role="tab"]:hover, .tab-strip a:hover { background: var(--paper-2); }
.tab-strip [role="tab"][aria-selected="true"],
.tab-strip [role="tab"].active,
.tab-strip a.active {
    color: var(--ink);
}
.tab-strip [role="tab"][aria-selected="true"]::after,
.tab-strip [role="tab"].active::after,
.tab-strip a.active::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -1px;
    height: 2px;
    background: var(--ember);
}
.tab-strip [role="tab"] .count,
.tab-strip a .count {
    font-family: var(--font-mono);
    font-size: 9px;
    color: var(--ink-3);
    margin-left: 4px;
    letter-spacing: 0.05em;
}

/* Profile body container. */
.profile-body {
    padding: 24px 32px 60px;
}
.profile-body h2 {
    font-family: var(--font-display);
    font-size: 18px;
    font-weight: 500;
    letter-spacing: -0.005em;
    color: var(--ink);
    margin: 24px 0 12px;
    font-variation-settings: "opsz" 24;
}

/* Design-system "table" rendered as hairline-grid rows */
.dt-table {
    border-top: 1px solid var(--rule-soft);
}
.dt-row {
    display: grid;
    gap: 14px;
    padding: 14px 0;
    border-bottom: 1px solid var(--rule-soft);
    align-items: center;
    font-family: var(--font-sans);
    font-size: 13px;
    color: var(--ink-2);
}
.dt-row .nm {
    font-family: var(--font-display);
    font-size: 16px;
    font-weight: 500;
    color: var(--ink);
    letter-spacing: -0.005em;
    font-variation-settings: "opsz" 24;
}
.dt-row .nm a { color: inherit; }
.dt-row .nm a:hover { color: var(--ember); }
.dt-row .meta {
    font-family: var(--font-mono);
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--ink-3);
}
.dt-row .num {
    font-family: var(--font-mono);
    font-size: 12px;
    font-weight: 600;
    color: var(--ink);
    text-align: right;
}
.dt-row .ext {
    font-family: var(--font-mono);
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--ember);
    text-align: right;
}
.dt-row .ext:hover { color: var(--ember-deep); }

/* Filter input above tables (inherits .ds-search) */
.dt-filter { margin: 0 0 14px; }

/* Section block — grouping content inside profile-body */
.section-block {
    border-top: 1px solid var(--rule-soft);
    padding-top: 20px;
    margin-top: 28px;
}
.section-block:first-child {
    border-top: none;
    margin-top: 0;
    padding-top: 0;
}
.section-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 12px;
}
.section-head h2 {
    margin: 0;
}
.section-head .sub {
    font-family: var(--font-mono);
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--ink-3);
}

/* Activity event list (for vc/company profiles) — like home feed but compact */
.event-list {}
.event-row {
    display: grid;
    grid-template-columns: 70px minmax(0, 1fr) 110px;
    gap: 14px;
    align-items: start;
    padding: 12px 0;
    border-bottom: 1px solid var(--rule-soft);
    font-family: var(--font-sans);
    font-size: 13px;
}
.event-row .e-flag {
    font-family: var(--font-mono);
    font-size: 8.5px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    padding: 3px 6px;
    width: fit-content;
    font-weight: 600;
}
.event-row .e-flag.add { background: var(--signal); color: var(--paper); }
.event-row .e-flag.drop { background: var(--warn); color: var(--paper); }
.event-row .e-flag.new { background: var(--ember); color: var(--paper); }
.event-row .e-flag.exit { background: var(--ink); color: var(--paper); }
.event-row .e-flag.update { background: var(--paper-3); color: var(--ink); border: 1px solid var(--rule-soft); }
.event-row .e-body {
    font-family: var(--font-display);
    font-size: 15px;
    line-height: 1.4;
    color: var(--ink);
    font-variation-settings: "opsz" 24;
    min-width: 0;
}
.event-row .e-body a {
    font-weight: 500;
    background-image: linear-gradient(var(--rule-soft), var(--rule-soft));
    background-size: 100% 1px;
    background-repeat: no-repeat;
    background-position: 0 100%;
    padding-bottom: 1px;
}
.event-row .e-body a:hover {
    color: var(--ember);
    background-image: linear-gradient(var(--ember), var(--ember));
}
.event-row .e-time {
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--ink-3);
    text-align: right;
    letter-spacing: 0.04em;
}
.event-row .e-arrow {
    color: var(--ember);
    font-family: var(--font-mono);
    font-size: 13px;
    padding: 0 2px;
}

/* --- INDEX / LIST (archetype A) ----------------------------------- */
/* Page header strip used by directory / index pages. Same vibe as
   .feed-header on home but full-bleed with bottom rule. */
.page-head {
    padding: 28px 32px 22px;
    border-bottom: 1px solid var(--rule);
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
}
.page-head .ph-left {
    flex: 1;
    min-width: 200px;
}
.page-head h1 {
    font-family: var(--font-display);
    font-size: 32px;
    line-height: 1.05;
    letter-spacing: -0.02em;
    font-weight: 400;
    color: var(--ink);
    margin: 0;
    font-variation-settings: "opsz" 72;
}
.page-head h1 em { font-style: italic; font-weight: 300; color: var(--ember); }
.page-head .sub {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--ink-3);
    letter-spacing: 0.04em;
    margin: 8px 0 0;
}
.page-head .sub b { color: var(--ink); font-weight: 600; }

/* Search input styled to match the masthead search */
.ds-search {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 8px 14px;
    background: var(--paper-2);
    border: 1px solid var(--rule-soft);
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--ink-2);
    min-width: 240px;
    margin-right: 10px;
}
.ds-search input {
    border: 0;
    background: transparent;
    font: inherit;
    color: var(--ink-2);
    outline: none;
    flex: 1;
    min-width: 0;
}
.ds-search input::placeholder { color: var(--ink-4); }
.ds-search-icon { color: var(--ink-3); font-size: 13px; }

/* Index row — directory entries (funds, companies, sectors, posts) */
.index-list {}
.index-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 160px;
    gap: 24px;
    align-items: start;
    padding: 18px 32px;
    border-bottom: 1px solid var(--rule-soft);
    transition: background 100ms;
    cursor: pointer;
}
.index-row:hover { background: var(--paper-2); }
.index-row .ix-name {
    font-family: var(--font-display);
    font-size: 18px;
    line-height: 1.25;
    letter-spacing: -0.005em;
    font-weight: 500;
    color: var(--ink);
    font-variation-settings: "opsz" 24;
    margin: 0 0 6px;
}
.index-row:hover .ix-name { color: var(--ember); }
.index-row .ix-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
    font-family: var(--font-mono);
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--ink-3);
}
.index-row .ix-meta .sep { color: var(--rule-soft); }
.index-row .ix-meta .region::before {
    content: "";
    display: inline-block;
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: var(--ink-3);
    margin-right: 6px;
    vertical-align: 1px;
}
.index-row .ix-stat {
    text-align: right;
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--ink-2);
    letter-spacing: 0.04em;
}
.index-row .ix-stat .v {
    display: block;
    font-family: var(--font-display);
    font-size: 20px;
    color: var(--ink);
    font-weight: 400;
    letter-spacing: -0.01em;
    line-height: 1;
    font-variation-settings: "opsz" 24;
}
.index-row .ix-stat .l {
    display: block;
    margin-top: 4px;
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--ink-3);
}
.index-row .ix-body {
    margin-top: 6px;
    font-family: var(--font-display);
    font-size: 14px;
    line-height: 1.45;
    color: var(--ink-3);
}
.index-row .ix-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 8px;
}
.index-row .ix-tags .tag {
    font-family: var(--font-mono);
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--ink-3);
    border: 1px solid var(--rule-soft);
    padding: 2px 6px;
}
@media (max-width: 600px) {
    .index-row {
        grid-template-columns: 1fr;
        padding-left: 20px;
        padding-right: 20px;
    }
    .index-row .ix-stat { text-align: left; }
}

/* Hairline-grid for thumbed entities — sector cards, etc. */
.index-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 0;
    border-top: 1px solid var(--rule-soft);
    border-left: 1px solid var(--rule-soft);
}
.index-grid > a {
    display: block;
    padding: 20px;
    border-right: 1px solid var(--rule-soft);
    border-bottom: 1px solid var(--rule-soft);
    background: var(--paper);
    transition: background 100ms;
    cursor: pointer;
}
.index-grid > a:hover { background: var(--paper-2); }
.index-grid .ig-name {
    font-family: var(--font-display);
    font-size: 18px;
    line-height: 1.2;
    letter-spacing: -0.005em;
    font-weight: 500;
    color: var(--ink);
    font-variation-settings: "opsz" 24;
}
.index-grid > a:hover .ig-name { color: var(--ember); }
.index-grid .ig-meta {
    margin-top: 8px;
    font-family: var(--font-mono);
    font-size: 9px;
    color: var(--ink-3);
    text-transform: uppercase;
    letter-spacing: 0.12em;
}
.index-grid .ig-stat {
    margin-top: 6px;
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--ink-2);
    font-weight: 600;
}

/* Filter row above lists */
.filter-row {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    padding: 18px 32px;
    border-bottom: 1px solid var(--rule);
    font-family: var(--font-mono);
    font-size: 11px;
}
.filter-row .filter-label {
    color: var(--ink-3);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-right: 10px;
}

/* Collapsible filter pickers (used by company directory) */
.cd-filters {
    border-bottom: 1px solid var(--rule);
}
.cd-filter {
    border-bottom: 1px solid var(--rule-soft);
}
.cd-filter:last-child { border-bottom: none; }
.cd-filter > summary {
    list-style: none;
    cursor: pointer;
    padding: 14px 32px;
    display: flex;
    align-items: center;
    gap: 14px;
    font-family: var(--font-mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--ink-3);
    user-select: none;
    transition: background 100ms;
}
.cd-filter > summary::-webkit-details-marker { display: none; }
.cd-filter > summary:hover { background: var(--paper-2); }
.cd-filter-label {
    color: var(--ink);
    font-weight: 600;
    letter-spacing: 0.16em;
}
.cd-filter-count {
    color: var(--ink-3);
    font-size: 10px;
}
.cd-filter-chevron {
    margin-left: auto;
    color: var(--ink-3);
    font-size: 10px;
    transition: transform 120ms;
}
.cd-filter[open] > summary .cd-filter-chevron { transform: rotate(180deg); }
.cd-filter-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 6px 32px 18px;
    max-height: 280px;
    overflow-y: auto;
}
.cd-filter[open] > summary {
    background: var(--paper-2);
    border-bottom: 1px solid var(--rule-soft);
}

/* Empty state for any list */
.list-empty {
    padding: 80px 32px;
    text-align: center;
    font-family: var(--font-display);
    font-style: italic;
    color: var(--ink-3);
    font-size: 18px;
}
.list-empty .link {
    color: var(--ember);
    border-bottom: 1px dotted currentColor;
}

/* --- EDITORIAL (archetype D) -------------------------------------- */
/* Used by: about, privacy, terms, contact, 404, blog post, insight,
   trends summary. Center-column layout inside the full-bleed page. */
.ed-masthead {
    padding: 60px 32px 40px;
    border-bottom: 1px solid var(--rule);
}
.ed-masthead-inner {
    max-width: 720px;
    margin: 0 auto;
    text-align: center;
}
.ed-eyebrow {
    font-family: var(--font-mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--ink-3);
    margin-bottom: 16px;
}
.ed-title {
    font-family: var(--font-display);
    font-size: 44px;
    font-weight: 400;
    line-height: 1.05;
    letter-spacing: -0.025em;
    color: var(--ink);
    font-variation-settings: "opsz" 96;
    margin: 0 0 16px;
}
.ed-title em { font-style: italic; font-weight: 300; color: var(--ember); }
@media (min-width: 900px) {
    .ed-title { font-size: 56px; }
}
.ed-tagline {
    font-family: var(--font-display);
    font-size: 18px;
    line-height: 1.4;
    color: var(--ink-3);
    margin: 0;
    font-variation-settings: "opsz" 24;
}
.ed-byline {
    font-family: var(--font-sans);
    font-size: 13px;
    color: var(--ink-3);
}
.ed-body {
    max-width: 720px;
    margin: 0 auto;
    padding: 40px 32px 80px;
    font-family: var(--font-display);
    font-size: 18px;
    line-height: 1.6;
    color: var(--ink);
    font-variation-settings: "opsz" 24;
}
.ed-body h2 {
    font-family: var(--font-display);
    font-size: 24px;
    font-weight: 500;
    letter-spacing: -0.01em;
    color: var(--ink);
    margin: 32px 0 10px;
    line-height: 1.25;
    font-variation-settings: "opsz" 24;
}
.ed-body h3 {
    font-family: var(--font-display);
    font-size: 18px;
    font-weight: 500;
    color: var(--ink);
    margin: 24px 0 8px;
}
.ed-body p { margin: 0 0 18px; }
.ed-body a:not(.btn) {
    color: var(--ember);
    background-image: linear-gradient(var(--rule-soft), var(--rule-soft));
    background-size: 100% 1px;
    background-repeat: no-repeat;
    background-position: 0 100%;
    padding-bottom: 1px;
    transition: background-image 120ms;
}
.ed-body a:not(.btn):hover {
    background-image: linear-gradient(var(--ember), var(--ember));
}
.ed-body strong { font-weight: 600; color: var(--ink); }
.ed-body ul, .ed-body ol {
    margin: 0 0 18px;
    padding-left: 24px;
}
.ed-body li { margin-bottom: 8px; }
.ed-body .ed-meta {
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--ink-4);
    margin-top: 32px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
}
.ed-body .ed-callout {
    background: var(--paper-2);
    padding: 22px 24px;
    margin: 28px 0;
    border-left: 2px solid var(--ember);
    font-family: var(--font-display);
    font-size: 16px;
    line-height: 1.5;
    color: var(--ink);
}
.ed-body .ed-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
    border-top: 1px solid var(--rule-soft);
    border-bottom: 1px solid var(--rule-soft);
    margin: 24px 0;
}
.ed-body .ed-grid > div {
    padding: 20px 0;
    border-bottom: 1px solid var(--rule-soft);
}
.ed-body .ed-grid > div:last-child { border-bottom: none; }
.ed-body .ed-grid strong { display: block; margin-bottom: 4px; }

/* Buttons used in editorial / shared layouts */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: var(--font-mono);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-weight: 600;
    padding: 10px 16px;
    border: 1px solid var(--ink);
    background: var(--paper);
    color: var(--ink);
    cursor: pointer;
    transition: background 120ms, color 120ms;
}
.btn:hover { background: var(--ink); color: var(--paper); }
.btn-primary { background: var(--ink); color: var(--paper); }
.btn-primary:hover { background: var(--ember); border-color: var(--ember); color: var(--paper); }
.btn-row { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }

/* Big stat strip used by editorial pages (e.g. about coverage) */
.ed-stat-strip {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    border-top: 1px solid var(--rule-soft);
    border-bottom: 1px solid var(--rule-soft);
    margin: 24px 0;
}
.ed-stat-strip > div {
    padding: 18px 22px;
    border-right: 1px solid var(--rule-soft);
}
.ed-stat-strip > div:last-child { border-right: none; }
.ed-stat-strip .v {
    font-family: var(--font-display);
    font-size: 28px;
    line-height: 1;
    letter-spacing: -0.02em;
    font-weight: 400;
    color: var(--ink);
    font-variation-settings: "opsz" 48;
    display: block;
}
.ed-stat-strip .l {
    display: block;
    margin-top: 8px;
    font-family: var(--font-mono);
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--ink-3);
}

/* Empty / 404 hero */
.empty-hero {
    padding: 120px 32px;
    text-align: center;
}
.empty-hero .code {
    font-family: var(--font-display);
    font-size: 88px;
    font-weight: 400;
    color: var(--ink);
    letter-spacing: -0.04em;
    line-height: 1;
    font-variation-settings: "opsz" 96;
    margin-bottom: 12px;
}
.empty-hero p {
    font-family: var(--font-display);
    font-size: 22px;
    color: var(--ink-3);
    font-style: italic;
    margin: 0 0 32px;
}

/* --- RESPONSIVE COLLAPSE (per README) ----------------------------- */
@media (max-width: 1100px) {
    .nav-meta { display: none; }
}
@media (max-width: 980px) {
    .mast-search { min-width: 240px; }
    .mast-search input { font-size: 10px; }
}
@media (max-width: 900px) {
    .overview-panels { grid-template-columns: 1fr; }
    .ov-panel { border-right: none; border-bottom: 1px solid var(--rule-soft); }
    .ov-panel:last-child { border-bottom: none; }
    .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 760px) {
    .overview-stats { grid-template-columns: 1fr 1fr; }
    .ov-stat:nth-child(2n) { border-right: none; }
    .ov-stat:nth-child(-n+2) { border-bottom: 1px solid var(--rule-soft); }
    .mast-search { display: none; }
    .masthead-bar { padding: 14px 20px; }
    .feed-header, .filters, .feed-item, .feed-pagination { padding-left: 20px; padding-right: 20px; }
}
@media (max-width: 600px) {
    .feed-item { grid-template-columns: 1fr; }
    .feed-action { align-items: flex-start; flex-direction: row; gap: 12px; }
    .footer-grid { grid-template-columns: 1fr; }
    .footer { padding: 32px 20px 24px; }
}
