/* Homepage layout — loaded only on homepage */

.md3-hero-tonal {
  background: linear-gradient(
    145deg,
    color-mix(in srgb, var(--md-sys-color-primary-container) 85%, transparent),
    var(--md-sys-color-surface-container-lowest)
  );
  border: 1px solid var(--md-sys-color-outline-variant);
}

.hs-filter-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0 0 1rem;
  align-items: center;
}

.hs-filter-chips .md3-chip-filter.is-active {
  background: var(--md-sys-color-primary);
  color: var(--md-sys-color-on-primary);
  border-color: transparent;
}

.hs-mag-card.is-filtered-out {
  display: none !important;
}

.read-next-section {
  margin: 2.5rem 0 1rem;
}

.read-next-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-top: 0.75rem;
}

@media (max-width: 960px) {
  .read-next-grid {
    grid-template-columns: 1fr;
  }
}

.read-next-card {
  text-decoration: none;
  color: inherit;
  display: block;
}

.read-next-card:hover {
  text-decoration: none;
  color: inherit;
}

.home-wrap {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 1rem 2rem;
}
.home-hero-site-subtitle {
    margin: 0 0 1.25rem;
    font-size: 1.05rem;
    line-height: 1.55;
    color: var(--color-text-secondary, #475569);
    max-width: 720px;
}
.hs-hero-newsletter {
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: 1.5rem;
    align-items: start;
    margin: 1.5rem 0 1rem;
}
@media (max-width: 960px) {
    .hs-hero-newsletter { grid-template-columns: 1fr; }
}
.home-hero img {
    width: 100%;
    border-radius: 1rem;
    aspect-ratio: 16 / 9;
    object-fit: cover;
}
.home-hero h1 {
    margin: 0.75rem 0 0;
    font-size: var(--font-size-display-small, 2.25rem);
    font-weight: 700;
    line-height: 1.22;
    color: var(--color-text-strong, var(--color-text-primary));
}
.home-hero h1 a { color: inherit; text-decoration: none; }
.home-hero h1 a:hover { color: var(--color-accent-primary); text-decoration: underline; }
.home-hero p {
    margin: 0.5rem 0 0;
    font-size: var(--font-size-body-large, 1.125rem);
    line-height: 1.56;
    color: var(--color-text-muted, var(--color-text-secondary));
}
.hs-newsletter-col .newsletter-signup--light { margin: 0; }
.hs-mag-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    margin-top: 0.75rem;
}
@media (max-width: 960px) {
    .hs-mag-cards { grid-template-columns: 1fr; }
}
.hs-mag-card {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    text-decoration: none;
    color: inherit;
}
.hs-mag-card:hover { text-decoration: none; color: inherit; }
.hs-mag-card .hs-mag-thumb {
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: var(--color-border-light);
}
.hs-mag-card .hs-mag-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.hs-mag-card .hs-mag-body { padding: 0.85rem 1rem 1rem; }
.hs-mag-card .hs-mag-body h3 {
    margin: 0 0 0.35rem;
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.35;
    color: var(--color-text-strong, var(--color-text-primary));
}
.hs-mag-card .hs-mag-body p {
    margin: 0;
    font-size: 0.875rem;
    line-height: 1.45;
    color: var(--color-text-muted, var(--color-text-secondary));
}
.feed-section { margin: 2rem 0; }
.feed-section h2 {
    margin: 0 0 1rem 0;
    font-size: var(--font-size-headline-medium, 1.75rem);
    font-weight: 600;
    line-height: 1.29;
}
.feed-section h2 a {
    font-size: 0.85rem;
    font-weight: 600;
    margin-left: 0.5rem;
    vertical-align: middle;
}
.feed-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    list-style: none;
    margin: 0;
    padding: 0;
}
.feed-list-item {
    display: flex;
    align-items: stretch;
    gap: 1rem;
    overflow: hidden;
    text-decoration: none;
    color: inherit;
}
.feed-list-item:hover { text-decoration: none; }
.feed-list-item .feed-card-thumb {
    flex-shrink: 0;
    width: 192px;
    aspect-ratio: 16 / 9;
    overflow: hidden;
}
.feed-list-item .feed-card-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.feed-list-item .feed-card-body {
    flex: 1;
    min-width: 0;
    padding: 1rem 1.25rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.feed-list-item .feed-card-body h3 {
    margin: 0 0 0.35rem 0;
    font-size: var(--font-size-title-medium, 1.25rem);
    font-weight: 600;
    line-height: 1.4;
    color: var(--color-text-strong, var(--color-text-primary));
}
.feed-list-item .feed-card-body h3 a { color: inherit; text-decoration: none; }
.feed-list-item .feed-card-body h3 a:hover { color: var(--color-accent-primary); text-decoration: underline; }
.feed-list-item .feed-card-body p {
    margin: 0;
    font-size: var(--font-size-body-medium, 1rem);
    line-height: 1.5;
    color: var(--color-text-muted, var(--color-text-secondary));
}
.feed-card-meta {
    margin: 0 0 0.35rem 0;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--color-text-secondary);
}
.feed-card-meta-md3 {
    margin: 0 0 0.35rem 0;
    font-size: var(--font-size-label-small, 0.75rem);
    font-weight: 500;
    color: var(--color-text-secondary);
    line-height: 1.45;
}
.feed-card-body .md3-chip-assist { margin-bottom: 0.35rem; }
.feed-view-all { margin: 0.75rem 0 0 0; font-size: 0.9375rem; }
.feed-view-all a { font-weight: 600; color: var(--color-accent-primary); text-decoration: none; }
.feed-view-all a:hover { text-decoration: underline; }
.feed-pagination {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-top: 0.75rem;
    flex-wrap: wrap;
}
.feed-pagination[hidden] { display: none !important; }
.feed-page-prev, .feed-page-next {
    padding: 0.4rem 0.85rem;
    font-size: 0.875rem;
    font-weight: 600;
    border: 1px solid var(--color-border);
    border-radius: 0.5rem;
    background: #fff;
    color: var(--color-text-primary);
    cursor: pointer;
    font-family: inherit;
}
.feed-page-prev:hover:not(:disabled), .feed-page-next:hover:not(:disabled) {
    border-color: var(--color-accent-primary);
    color: var(--color-accent-primary);
}
.feed-page-prev:disabled, .feed-page-next:disabled { opacity: 0.45; cursor: not-allowed; }
.feed-page-status { font-size: 0.875rem; color: var(--color-text-secondary); min-width: 4.5rem; text-align: center; }
@media (max-width: 480px) {
    .feed-list-item { flex-direction: column; }
    .feed-list-item .feed-card-thumb { width: 100%; min-height: 0; }
}
.home-newsletter { margin-top: 2rem; }
.quick-link-card {
    display: block;
    text-decoration: none;
    color: inherit;
    background: #ffffff;
    border: 1px solid var(--color-border);
    border-radius: 0.9rem;
    box-shadow: var(--shadow-md);
    padding: 1.5rem;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.quick-link-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-lg);
    text-decoration: none;
}
.quick-link-card .quick-link-icon {
    font-size: 1.75rem;
    color: var(--color-accent-primary);
    margin-bottom: 0.5rem;
    display: block;
}
.quick-link-card h3 {
    margin: 0 0 0.35rem 0;
    font-size: var(--font-size-title-medium, 1.25rem);
    font-weight: 600;
    color: var(--color-text-primary);
}
.quick-link-card p {
    margin: 0;
    font-size: var(--font-size-body-medium, 1rem);
    line-height: 1.5;
    color: #334155;
}
.category-browse .category-grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 0.75rem;
}
.category-browse .category-grid a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    padding: 0.85rem 1rem;
    background: #ffffff;
    border: 1px solid var(--color-border);
    border-radius: 0.75rem;
    text-decoration: none;
    color: var(--color-text-primary);
    font-weight: 600;
    font-size: 0.9375rem;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.category-browse .category-grid a:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
    text-decoration: none;
    color: var(--color-accent-primary);
}
.category-browse .cat-count {
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--color-text-secondary);
    background: var(--color-surface-alt, #f1f5f9);
    padding: 0.15rem 0.5rem;
    border-radius: 9999px;
}
.hs-main-col h2 { margin-top: 0; }
/* Unified page grid: hero + sidebar flush from the top */
.hs-page-grid {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 1.5rem;
    align-items: start;
    margin: 1.5rem 0;
}
@media (max-width: 960px) {
    .hs-page-grid { grid-template-columns: 1fr; }
}
.hs-page-main {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    min-width: 0;
}
.hs-page-sidebar {
    position: sticky;
    top: 88px;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    /* Do not constrain height — let it grow naturally with content.
       Only apply scroll on very tall viewports where the sidebar
       would genuinely overflow the visible area. */
    align-self: start;
}
@media (max-width: 960px) {
    .hs-page-sidebar { position: static; max-height: none; overflow-y: visible; }
}
.hs-sidebar-newsletter { margin: 0; }

/* Markets live widgets: indices table + ticker strip */
.cms-ticker-table {
  list-style: none;
  margin: 0;
  padding: 0;
}

.cms-ticker-row {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 0.25rem 0.4rem;
  padding: 0.35rem 0;
  border-bottom: 1px solid var(--md-sys-color-outline-variant, #e7e5e4);
  min-width: 0;
}

.cms-ticker-row:last-child {
  border-bottom: none;
}

/* Label grows to fill available space; all other cells shrink to content */
.cms-ticker-label {
  flex: 1 1 0;
  min-width: 0;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  font-size: 0.8125rem;
}

.cms-ticker-price {
  flex: 0 0 auto;
  font-size: 0.8125rem;
  font-family: var(--font-family-mono, ui-monospace, monospace);
  white-space: nowrap;
}

.cms-ticker-chg {
  flex: 0 0 auto;
  font-size: 0.8125rem;
  font-family: var(--font-family-mono, ui-monospace, monospace);
  white-space: nowrap;
}

/* Sparklines — keep them fixed size and vertically centred */
.sparkline {
  flex: 0 0 auto;
  display: inline-block;
  vertical-align: middle;
  overflow: visible;
}

.cms-ticker-row .sparkline {
  flex: 0 0 auto;
}

.hs-ticker-item {
  display: inline-flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 0.2rem;
  white-space: nowrap;
}

.hs-ticker-item .sparkline {
  flex: 0 0 auto;
  vertical-align: middle;
}

/* ============================================================
   Homepage sidebar widgets — card skin, signal card, movers
   ============================================================ */

/* Sidebar widget card */
.hs-widget {
  background: var(--md-sys-color-surface-container-lowest, #fff);
  border: 1px solid var(--md-sys-color-outline-variant, #e7e5e4);
  border-radius: var(--md-sys-shape-corner-md, 12px);
  padding: 0.875rem 1rem;
  min-width: 0;
}

.hs-widget h3 {
  font-size: 0.8125rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--md-sys-color-on-surface-variant, #44403c);
  margin: 0 0 0.65rem;
}

/* Top mover / signal-of-day card */
.hs-signal-card {
  background: var(--md-sys-color-surface-container-lowest, #fff);
  border: 1px solid var(--md-sys-color-outline-variant, #e7e5e4);
  border-radius: var(--md-sys-shape-corner-md, 12px);
  padding: 0.875rem 1rem;
}

.sig-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-bottom: 0.65rem;
}

.sig-head h3 {
  margin: 0;
  font-size: 0.875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--md-sys-color-on-surface-variant, #44403c);
}

.sig-body {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.sig-tiles {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem;
}

.sig-tile {
  display: block;
  padding: 0.6rem 0.75rem;
  border: 1px solid var(--md-sys-color-outline-variant, #e7e5e4);
  border-radius: var(--md-sys-shape-corner-sm, 8px);
  text-decoration: none;
  color: var(--md-sys-color-on-surface, #1c1917);
  background: var(--md-sys-color-surface-container-low, #f5f5f4);
  transition: background 0.15s ease;
}

.sig-tile:hover {
  background: color-mix(in srgb, var(--md-sys-color-primary) 8%, var(--md-sys-color-surface-container-low, #f5f5f4));
  text-decoration: none;
}

.sig-tile--empty {
  opacity: 0.55;
  pointer-events: none;
}

.sig-tile-head {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--md-sys-color-on-surface-variant, #78716c);
  margin-bottom: 0.2rem;
}

.sig-tile-name {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--md-sys-color-on-surface, #1c1917);
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.sig-tile-name--ticker .sig-tk {
  font-family: var(--font-family-mono, ui-monospace, monospace);
  font-size: 0.875rem;
}

.sig-tile-ticker {
  font-size: 0.75rem;
  font-family: var(--font-family-mono, ui-monospace, monospace);
}

.sig-tile-body {
  font-size: 0.8125rem;
  margin-top: 0.15rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.25rem;
}

.sig-sum {
  font-size: 0.8125rem;
  color: var(--md-sys-color-on-surface-variant, #57534e);
  line-height: 1.5;
  margin: 0;
}

.sig-tk {
  font-weight: 700;
  font-family: var(--font-family-mono, ui-monospace, monospace);
  color: var(--md-sys-color-primary, #3751ff);
}

/* ──────────────────────────────────────
   Utility classes used by home-live.js
   ────────────────────────────────────── */

/* Positive / negative change */
.chg-up {
  color: var(--md-sys-color-bull, #15803d);
}
.chg-dn {
  color: var(--md-sys-color-bear, #b91c1c);
}

/* Muted text */
.cms-muted {
  color: var(--md-sys-color-on-surface-variant, #78716c);
  font-size: 0.8125rem;
}

/* Generic sidebar list (movers, headlines) */
.cms-side-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.cms-side-list li {
  padding: 0.3rem 0;
  font-size: 0.8125rem;
  border-bottom: 1px solid var(--md-sys-color-outline-variant, #e7e5e4);
  line-height: 1.4;
}

.cms-side-list li:last-child {
  border-bottom: none;
}

.cms-side-list a {
  color: var(--md-sys-color-on-surface, #1c1917);
  text-decoration: none;
  font-weight: 600;
}

.cms-side-list a:hover {
  color: var(--md-sys-color-primary, #3751ff);
  text-decoration: underline;
}

.cms-ticker-sub {
  font-size: 0.75rem;
  font-family: var(--font-family-mono, ui-monospace, monospace);
  color: var(--md-sys-color-on-surface-variant, #78716c);
}

/* Macro widget */
.cms-macro-label {
  font-size: 0.75rem;
  color: var(--md-sys-color-on-surface-variant, #78716c);
  margin-right: 0.25rem;
}

.cms-macro-list {
  list-style: none;
  margin: 0.4rem 0;
  padding: 0;
}

.cms-macro-list li {
  font-size: 0.8125rem;
  padding: 0.2rem 0;
  border-bottom: 1px solid var(--md-sys-color-outline-variant, #e7e5e4);
}

.cms-macro-note {
  font-size: 0.6875rem;
  color: var(--md-sys-color-on-surface-variant, #78716c);
  margin: 0.35rem 0 0;
}

/* Market regime pills */
.regime-up {
  color: var(--md-sys-color-bull, #15803d);
  font-weight: 700;
}
.regime-dn {
  color: var(--md-sys-color-bear, #b91c1c);
  font-weight: 700;
}
.regime-flat {
  color: var(--md-sys-color-neutral-signal, #92400e);
  font-weight: 700;
}

/* Data-delay badge */
.cms-delay-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.6875rem;
  color: var(--md-sys-color-on-surface-variant, #78716c);
  white-space: nowrap;
}

.cms-delay-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--md-sys-color-neutral-signal, #d97706);
  flex-shrink: 0;
}

.cms-delay-link {
  font-size: 0.6875rem;
  color: var(--md-sys-color-on-surface-variant, #78716c);
  text-decoration: underline;
}

/* Markets page subtitle */
.home-hero-site-subtitle {
  font-size: 0.9375rem;
  color: var(--md-sys-color-on-surface-variant, #57534e);
  margin: 0.25rem 0 0.75rem;
  line-height: 1.5;
}

/* Watchlist form row */
.hs-watchlist-form {
  display: flex;
  gap: 0.5rem;
  align-items: flex-end;
  flex-wrap: wrap;
}

.hs-watchlist-form .btn {
  flex-shrink: 0;
  align-self: stretch;
  min-height: 48px;
}

/* Dark mode overrides */
html[data-theme="dark"] .hs-widget,
html[data-theme="dark"] .hs-signal-card {
  background: var(--md-sys-color-surface-container-low, #292524);
  border-color: var(--md-sys-color-outline-variant, #44403c);
}

html[data-theme="dark"] .sig-tile {
  background: var(--md-sys-color-surface-container, #44403c);
  border-color: var(--md-sys-color-outline-variant, #57534e);
}

html[data-theme="dark"] .chg-up {
  color: var(--md-sys-color-bull, #4ade80);
}

html[data-theme="dark"] .chg-dn {
  color: var(--md-sys-color-bear, #f87171);
}
