:root {
  --bg: #f4f5f7;
  --bg-strong: #eceef2;
  --surface: rgba(255, 255, 255, 0.88);
  --surface-strong: rgba(255, 255, 255, 0.98);
  --surface-dark: #cf1f26;
  --line: rgba(18, 24, 34, 0.08);
  --line-strong: rgba(18, 24, 34, 0.16);
  --ink: #1d2129;
  --muted: #6b7280;
  --accent: #d21920;
  --accent-strong: #23262d;
  --accent-soft: rgba(210, 25, 32, 0.08);
  --success: #0b7d53;
  --shadow:
    0 10px 28px rgba(17, 24, 39, 0.06),
    0 2px 8px rgba(17, 24, 39, 0.04);
  --radius-lg: 16px;
  --radius-md: 12px;
  --radius-sm: 8px;
  --content-width: 1420px;
  --font-body:
    'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', 'Noto Sans SC',
    sans-serif;
  --font-display:
    'Source Han Serif SC', 'Songti SC', 'Noto Serif SC', 'STSong', serif;

  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.5;
  font-weight: 400;
  color: var(--ink);
  background: var(--bg);
  font-synthesis: none;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-width: 320px;
  background:
    radial-gradient(circle at top left, rgba(255, 255, 255, 0.92), transparent 32%),
    linear-gradient(180deg, #fafbfc 0%, #f4f5f7 36%, #eef1f5 100%);
  color: var(--ink);
}

body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(19, 32, 51, 0.015) 1px, transparent 1px),
    linear-gradient(90deg, rgba(19, 32, 51, 0.015) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.16), transparent 90%);
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input {
  font: inherit;
}

button {
  cursor: pointer;
}

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

h1,
h2,
h3,
p {
  margin: 0;
}

#root {
  min-height: 100vh;
}

/* Published newsroom template shell */
.app-shell {
  width: min(100%, calc(var(--content-width) + 40px));
  margin: 0 auto;
  padding: 12px 20px 28px;
  position: relative;
}

.masthead,
.top-dock,
.hero-banner,
.control-panel,
.headline-grid,
.operations-grid,
.ticker-strip,
.content-layout,
.saved-layout,
.article-page__nav,
.article-hero,
.article-layout,
.site-footer {
  animation: rise-in 0.5s ease both;
}

.masthead {
  margin-bottom: 10px;
  padding: 12px 18px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: var(--shadow);
}

.masthead__core,
.masthead__summary,
.masthead__actions,
.masthead__signal,
.top-dock,
.channel-nav,
.hero-banner__actions,
.hero-banner__chips,
.hero-banner__rail,
.hero-banner__stats,
.hero-spotlight__topline,
.hero-spotlight__meta,
.search-panel,
.compact-links,
.source-pulse__item,
.ticker-strip,
.ticker-strip__label,
.section-heading,
.story-card__topline,
.story-card__footer,
.story-card__stats,
.story-card__actions,
.article-meta,
.article-actions,
.article-page__nav,
.site-footer,
.site-footer__meta,
.special-card__topline {
  display: flex;
  align-items: center;
}

.masthead__core {
  justify-content: space-between;
  gap: 12px;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.brand__mark {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: var(--surface-dark);
  color: white;
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.12em;
}

.brand__mark img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: inherit;
}

.brand__eyebrow,
.eyebrow {
  color: var(--accent);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.brand h1 {
  font-family: var(--font-display);
  font-size: clamp(1.36rem, 1.8vw, 1.86rem);
  line-height: 0.95;
  letter-spacing: -0.05em;
}

.brand__meta {
  margin-top: 4px;
  max-width: 36ch;
  color: var(--muted);
  font-size: 0.78rem;
  line-height: 1.5;
}

.masthead__summary {
  gap: 10px;
  flex-wrap: wrap;
  color: var(--muted);
  font-size: 0.76rem;
}

.masthead__signal {
  gap: 6px;
  color: var(--accent-strong);
}

.masthead__actions {
  gap: 8px;
}

.masthead__action,
.channel-nav__home,
.channel-nav__link,
.filter-pill,
.refresh-button,
.ghost-button,
.story-card__save,
.story-card__origin,
.article-origin,
.back-link,
.topic-chip {
  transition:
    transform 0.18s ease,
    background 0.18s ease,
    border-color 0.18s ease,
    color 0.18s ease;
}

.masthead__action,
.channel-nav__home,
.refresh-button,
.ghost-button,
.story-card__save,
.story-card__origin,
.article-origin,
.back-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  padding: 0 12px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.9);
  color: var(--accent-strong);
}

.top-dock {
  position: sticky;
  top: 6px;
  z-index: 12;
  margin-bottom: 14px;
  padding: 10px 14px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.94);
  backdrop-filter: blur(18px);
  box-shadow: 0 10px 28px rgba(16, 29, 45, 0.08);
}

.channel-nav {
  gap: 6px;
  flex-wrap: wrap;
}

.channel-nav__link {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 10px;
  border-radius: 999px;
  color: var(--muted);
}

.channel-nav__home:hover,
.channel-nav__link:hover,
.masthead__action:hover,
.refresh-button:hover,
.ghost-button:hover,
.story-card__save:hover,
.story-card__origin:hover,
.article-origin:hover,
.back-link:hover,
.topic-chip:hover,
.filter-pill:hover,
.board-list__item:hover,
.mini-list__item:hover,
.ticker-strip__item:hover,
.special-card__list a:hover,
.channel-card__links a:hover {
  transform: translateY(-1px);
}

.channel-nav__home[aria-current='page'],
.channel-nav__link[aria-current='page'],
.filter-pill[aria-current='page'],
.filter-pill:hover {
  background: var(--accent-soft);
  color: var(--accent);
  border-color: rgba(198, 86, 52, 0.24);
}

.page-stage,
.news-page,
.channel-page,
.topic-page,
.saved-page,
.article-page {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.hero-banner,
.control-panel,
.panel,
.headline-grid__main,
.headline-grid__side,
.ticker-strip,
.content-layout__main,
.content-layout__side,
.saved-layout__main,
.saved-layout__side,
.article-page__nav,
.article-hero,
.article-layout__main,
.article-layout__side,
.empty-panel,
.article-loading,
.site-footer,
.operations-grid > .panel {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: var(--shadow);
}

.hero-banner {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  align-items: stretch;
  gap: 18px;
  padding: 20px 22px;
  background:
    radial-gradient(circle at right top, rgba(198, 86, 52, 0.15), transparent 38%),
    linear-gradient(135deg, rgba(25, 55, 83, 0.97), rgba(13, 28, 42, 0.95));
  color: white;
  overflow: hidden;
}

.hero-banner--saved,
.hero-banner--topic {
  background:
    radial-gradient(circle at left top, rgba(198, 86, 52, 0.2), transparent 32%),
    linear-gradient(135deg, rgba(29, 50, 72, 0.97), rgba(17, 31, 47, 0.96));
}

.hero-banner--home {
  min-height: 440px;
  background:
    radial-gradient(circle at 14% 12%, rgba(255, 200, 140, 0.16), transparent 26%),
    radial-gradient(circle at 86% 16%, rgba(120, 205, 255, 0.2), transparent 22%),
    linear-gradient(132deg, #0f2235 0%, #15314a 48%, #3d271f 100%);
}

.hero-banner--home::before,
.hero-banner--home::after {
  content: '';
  position: absolute;
  pointer-events: none;
}

.hero-banner--home::before {
  inset: auto auto -30% -6%;
  width: 34vw;
  height: 34vw;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(198, 86, 52, 0.3), transparent 68%);
  opacity: 0.9;
}

.hero-banner--home::after {
  inset: 24px 26px auto auto;
  width: 220px;
  height: 220px;
  border-radius: 34px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.02)),
    linear-gradient(135deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0));
  transform: rotate(10deg);
  opacity: 0.5;
}

.hero-banner > * {
  position: relative;
  z-index: 1;
}

.hero-banner__copy,
.hero-banner__visual,
.hero-banner__rail,
.metric-card,
.control-panel,
.panel,
.stacked-cards,
.stream-list,
.mini-list,
.board-list,
.source-pulse,
.article-body,
.article-hero__content,
.article-hero__media,
.special-card,
.special-card__list,
.channel-card,
.channel-card__links {
  display: flex;
  flex-direction: column;
}

.hero-banner__copy {
  gap: 10px;
  max-width: 760px;
}

.hero-banner--home .hero-banner__copy {
  justify-content: space-between;
  max-width: none;
}

.hero-banner__copy--newsroom {
  max-width: 58rem;
}

.hero-banner__copy h2,
.article-hero__content h2 {
  font-family: var(--font-display);
  font-size: clamp(1.66rem, 2.2vw, 2.36rem);
  line-height: 1.08;
  letter-spacing: -0.045em;
}

.hero-banner__copy p:not(.eyebrow),
.article-hero__excerpt {
  max-width: 64ch;
  color: rgba(255, 255, 255, 0.84);
  font-size: 0.94rem;
  line-height: 1.66;
}

.hero-banner--home .hero-banner__copy h2 {
  max-width: 14ch;
  font-size: clamp(2.4rem, 4vw, 3.8rem);
  line-height: 1.02;
}

.hero-banner--home .hero-banner__copy p:not(.eyebrow) {
  max-width: 50ch;
  font-size: 1rem;
  line-height: 1.72;
}

.hero-banner__actions,
.hero-banner__chips,
.hero-spotlight__meta {
  gap: 10px;
  flex-wrap: wrap;
}

.hero-banner__actions {
  margin-top: 10px;
}

.ghost-button--light,
.ghost-button--soft {
  border-color: rgba(255, 255, 255, 0.16);
}

.ghost-button--light {
  background: rgba(255, 255, 255, 0.92);
  color: var(--accent-strong);
}

.ghost-button--soft {
  background: rgba(255, 255, 255, 0.08);
  color: white;
}

.hero-banner__chip {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 12px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.88);
  transition:
    transform 0.18s ease,
    background 0.18s ease,
    border-color 0.18s ease;
}

.hero-banner__chip:hover {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, 0.16);
}

.hero-banner__rail,
.hero-banner__stats {
  gap: 12px;
  align-self: stretch;
}

.hero-banner__rail {
  width: min(380px, 100%);
}

.hero-banner__visual {
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 14px;
  min-width: 0;
}

.hero-banner--home .hero-banner__rail {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.hero-brief {
  display: flex;
  min-height: 100%;
  flex-direction: column;
  gap: 10px;
  padding: 14px 16px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(18px);
  transition:
    transform 0.18s ease,
    background 0.18s ease,
    border-color 0.18s ease;
}

.hero-brief:hover {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, 0.15);
}

.hero-brief__label {
  color: rgba(255, 255, 255, 0.68);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.hero-brief strong {
  font-size: 1.2rem;
  line-height: 1.35;
}

.hero-brief p {
  color: rgba(255, 255, 255, 0.74);
  font-size: 0.82rem;
  line-height: 1.7;
}

.hero-brief__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: auto;
  color: rgba(255, 255, 255, 0.74);
  font-size: 0.76rem;
}

.metric-card,
.hero-banner__stats > div {
  gap: 5px;
  padding: 12px 14px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.08);
}

.hero-banner--home .metric-card {
  height: 100%;
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(18px);
}

.metric-card span,
.hero-banner__stats span,
.section-heading__meta,
.story-card__category,
.story-card__time,
.story-card__stats,
.status-line,
.site-footer p,
.site-footer__meta,
.mini-list__item span,
.empty-note,
.source-pulse__item span {
  color: var(--muted);
  font-size: 0.88rem;
}

.metric-card strong,
.hero-banner__stats strong {
  font-size: 1.3rem;
  line-height: 1.1;
}

.metric-card p {
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.8rem;
}

.control-panel {
  gap: 10px;
  padding: 12px 16px;
  border-top: 3px solid var(--accent);
}

.control-panel--compact {
  padding-block: 12px;
}

.search-panel {
  justify-content: space-between;
  gap: 10px;
}

.search-input {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 40px;
  padding: 0 12px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.94);
}

.search-input input {
  flex: 1;
  border: 0;
  outline: none;
  background: transparent;
  color: var(--ink);
  font-size: 0.92rem;
}

.compact-links {
  gap: 6px;
  flex-wrap: wrap;
}

.filter-pill,
.topic-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 30px;
  padding: 0 10px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  color: var(--accent-strong);
}

.topic-chip span {
  display: inline-grid;
  place-items: center;
  min-width: 22px;
  min-height: 22px;
  padding: 0 6px;
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent);
  font-size: 0.78rem;
}

.status-line {
  display: flex;
  align-items: center;
  gap: 8px;
}

.status-line--error {
  color: #a12424;
}

.news-page--portal {
  gap: 16px;
}

.portal-home__banner {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(360px, 0.98fr) 320px;
  align-items: start;
  gap: 18px;
  padding: 18px;
  border: 1px solid var(--line);
  border-top: 4px solid var(--accent);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: var(--shadow);
}

.portal-home__lead,
.portal-home__headline-group,
.portal-home__headline-main,
.portal-home__headline-list,
.portal-home__aside,
.portal-home__rank-list,
.portal-home__promo-list,
.portal-home__lead-copy,
.portal-home__visual-copy {
  display: flex;
  flex-direction: column;
}

.portal-home__lead,
.portal-home__aside-card,
.portal-home__visual-card,
.portal-home__express-card {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: white;
}

.portal-home__lead {
  display: flex;
  flex-direction: column;
  gap: 0;
  min-height: 100%;
  padding: 0;
  overflow: hidden;
}

.portal-home__lead-media {
  display: block;
  min-height: 0;
  overflow: hidden;
  border-radius: 0;
  background: linear-gradient(135deg, rgba(210, 25, 32, 0.88), rgba(34, 41, 51, 0.92));
  aspect-ratio: 16 / 9;
}

.portal-home__lead-media img,
.portal-home__promo-media img,
.portal-home__visual-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.news-image__fallback {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  min-height: inherit;
  background:
    linear-gradient(135deg, rgba(198, 40, 40, 0.92), rgba(38, 49, 63, 0.96)),
    radial-gradient(circle at 80% 20%, rgba(255, 255, 255, 0.14), transparent 24%);
}

.news-image__fallback::before,
.news-image__fallback::after {
  content: '';
  position: absolute;
  inset: auto;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
}

.news-image__fallback::before {
  top: 14%;
  right: 11%;
  width: 18%;
  height: 18%;
}

.news-image__fallback::after {
  left: 10%;
  bottom: 12%;
  width: 30%;
  height: 14%;
}

.portal-home__lead-copy {
  padding: 16px 18px 18px;
  background: rgba(255, 255, 255, 0.98);
  justify-content: space-between;
  min-width: 0;
  gap: 12px;
}

.portal-home__lead-topline,
.portal-home__lead-meta,
.portal-home__aside-title {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.portal-home__lead-topline,
.portal-home__lead-meta {
  color: var(--muted);
  font-size: 0.84rem;
}

.portal-home__lead-badge {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: var(--accent);
  color: white;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.portal-home__lead-link h2 {
  font-family: var(--font-display);
  font-size: clamp(1.66rem, 2vw, 2.32rem);
  line-height: 1.14;
  color: #181b22;
}

.portal-home__lead-copy p {
  color: #505866;
  font-size: 0.94rem;
  line-height: 1.74;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

.portal-home__headline-group {
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.98);
  gap: 14px;
  min-width: 0;
}

.portal-home__headline-main {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.portal-home__headline-card {
  min-width: 0;
  padding: 0 0 12px;
  border-bottom: 1px solid rgba(18, 24, 34, 0.08);
}

.portal-home__headline-card h3 {
  margin-bottom: 8px;
  font-family: var(--font-display);
  font-size: 1.26rem;
  line-height: 1.28;
}

.portal-home__headline-card p {
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.68;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

.portal-home__headline-list {
  gap: 10px;
  padding: 12px 0 0;
  border-top: 2px solid rgba(210, 25, 32, 0.12);
}

.portal-home__headline-item {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding-bottom: 10px;
  border-bottom: 1px dashed rgba(18, 24, 34, 0.08);
}

.portal-home__headline-item span,
.portal-home__visual-copy span,
.portal-home__express-card span {
  color: var(--accent);
  font-size: 0.78rem;
  white-space: nowrap;
}

.portal-home__headline-item strong,
.portal-home__promo strong,
.portal-home__visual-copy h3,
.portal-home__express-card strong {
  font-family: var(--font-display);
  line-height: 1.32;
}

.portal-home__headline-item strong,
.portal-home__promo strong,
.portal-home__visual-copy h3,
.portal-home__express-card strong,
.board-list__item span,
.mini-list__item strong {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.portal-home__headline-item strong {
  -webkit-line-clamp: 2;
}

.portal-home__aside {
  display: flex;
  flex-direction: column;
  gap: 14px;
  align-self: start;
}

.portal-home__aside-card {
  gap: 12px;
  padding: 12px;
  height: auto;
}

.portal-home__aside-title {
  color: var(--accent-strong);
  font-family: var(--font-display);
  font-size: 1rem;
}

.portal-home__rank-list,
.portal-home__promo-list {
  gap: 10px;
}

.portal-home__rank-item {
  display: flex;
  gap: 10px;
  align-items: flex-start;
}

.portal-home__rank-item strong {
  min-width: 18px;
  color: var(--accent);
  font-size: 1rem;
}

.portal-home__rank-item span {
  line-height: 1.5;
}

.portal-home__promo {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.portal-home__promo strong {
  -webkit-line-clamp: 3;
}

.portal-home__express-card strong {
  -webkit-line-clamp: 2;
}

.portal-home__promo-media {
  aspect-ratio: 16 / 10;
  height: auto;
  overflow: hidden;
  border-radius: 8px;
  background: #eceff4;
}

.portal-home__visual-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 16px;
  align-items: start;
}

.portal-home__visual-card,
.portal-home__express-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-width: 0;
  height: auto;
  align-self: start;
  padding: 14px;
}

.portal-home__visual-card {
  grid-column: span 4;
}

.portal-home__express-card {
  grid-column: span 2;
}

.portal-home__visual-media {
  aspect-ratio: 16 / 10;
  height: auto;
  overflow: hidden;
  border-radius: 8px;
  background: #eceff4;
}

.portal-home__visual-copy {
  gap: 8px;
}

.portal-home__visual-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.portal-home__visual-topline small {
  color: var(--muted);
  font-size: 0.78rem;
  white-space: nowrap;
}

.portal-home__visual-copy h3 {
  font-size: 1.04rem;
  -webkit-line-clamp: 2;
}

.board-list__item span {
  -webkit-line-clamp: 2;
}

.mini-list__item strong {
  -webkit-line-clamp: 2;
}

.portal-home__visual-copy p,
.portal-home__express-card p {
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.62;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

.portal-home__express-card {
  justify-content: flex-start;
  border-top: 3px solid var(--accent);
}

.headline-grid,
.content-layout,
.saved-layout,
.article-layout {
  display: grid;
  align-items: start;
  gap: 18px;
  grid-template-columns: minmax(0, 1fr) 340px;
}

.content-layout--home {
  grid-template-columns: minmax(0, 1fr) 360px;
}

.saved-layout {
  grid-template-columns: minmax(0, 1fr) 320px;
}

.article-layout {
  grid-template-columns: minmax(0, 1fr) 340px;
}

.headline-grid--single,
.content-layout--single,
.saved-layout--single {
  grid-template-columns: minmax(0, 1fr);
}

.headline-grid__main,
.content-layout__main,
.saved-layout__main,
.article-layout__main {
  padding: 16px 18px;
  min-width: 0;
}

.headline-grid__side,
.content-layout__side,
.saved-layout__side,
.article-layout__side {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 16px;
  min-width: 0;
}

.headline-grid__side {
  display: flex;
  flex-direction: column;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.content-layout__side--sticky {
  position: sticky;
  top: 86px;
  align-self: start;
}

.hero-spotlight,
.hero-quickline {
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(18px);
}

.hero-spotlight {
  display: flex;
  flex-direction: column;
  gap: 14px;
  justify-content: space-between;
  min-height: 100%;
  padding: 22px;
  border-radius: 28px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.hero-spotlight--placeholder {
  display: grid;
  place-items: center;
  color: rgba(255, 255, 255, 0.86);
}

.hero-spotlight__topline {
  justify-content: space-between;
  gap: 12px;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.82rem;
}

.hero-spotlight__label {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.16);
  color: white;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.hero-spotlight__link {
  display: flex;
  flex-direction: column;
  gap: 12px;
  color: white;
}

.hero-spotlight__link h3 {
  max-width: 16ch;
  font-family: var(--font-display);
  font-size: clamp(1.85rem, 2.7vw, 3rem);
  line-height: 0.98;
  letter-spacing: -0.04em;
}

.hero-spotlight__link p {
  max-width: 54ch;
  color: rgba(255, 255, 255, 0.8);
  line-height: 1.72;
}

.hero-quickline__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.hero-quickline {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
  padding: 12px 14px;
  border-radius: 18px;
  transition:
    transform 0.18s ease,
    background 0.18s ease,
    border-color 0.18s ease;
}

.hero-quickline:hover {
  transform: translateY(-1px);
  background: rgba(255, 255, 255, 0.14);
}

.hero-quickline span {
  color: rgba(255, 255, 255, 0.62);
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.hero-quickline strong {
  font-family: var(--font-display);
  color: white;
  line-height: 1.2;
}

.panel {
  gap: 12px;
  padding: 16px;
  border-top: 3px solid rgba(210, 25, 32, 0.88);
}

.panel--tight {
  padding: 12px;
}

.panel__title,
.section-heading h3,
.saved-page h3 {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--accent-strong);
  font-family: var(--font-display);
  font-size: 1.12rem;
}

.stacked-cards,
.stream-list,
.mini-list,
.board-list,
.source-pulse {
  gap: 8px;
}

.topic-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.operations-grid,
.special-grid,
.channel-mosaic {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  align-items: stretch;
}

.content-layout__side .channel-mosaic {
  grid-template-columns: 1fr;
}

.channel-mosaic--sidebar {
  display: flex;
  flex-direction: column;
}

.channel-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.channel-list-item {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.98);
}

.channel-list-item__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.channel-list-item__links {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.channel-list-item__links a {
  display: block;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.72);
  font-family: var(--font-display);
  line-height: 1.4;
}

.board-list__item,
.special-card__list a,
.channel-card__links a {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.72);
}

.mini-list__item {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.72);
}

.board-list__item strong {
  min-width: 42px;
  color: var(--accent);
  font-size: 0.9rem;
}

.board-list__item span,
.mini-list__item strong,
.special-card__list a,
.channel-card__links a,
.story-card h3,
.special-card h4,
.channel-card h4 {
  font-family: var(--font-display);
  line-height: 1.16;
}

.special-card,
.channel-card {
  gap: 8px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.98);
}

.special-card__topline {
  justify-content: space-between;
  gap: 12px;
  color: var(--muted);
  font-size: 0.82rem;
}

.special-card__entry,
.channel-card__entry {
  display: block;
  color: var(--accent-strong);
}

.channel-card__header--sidebar {
  flex-direction: column;
  align-items: flex-start;
}

.channel-card__jump {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 0 12px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  color: var(--accent-strong);
}

.special-card__summary,
.channel-card__summary {
  display: block;
}

.special-card h4,
.channel-card h4 {
  font-size: 1.05rem;
}

.special-card p,
.channel-card p,
.special-card__summary,
.channel-card__summary {
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.56;
}

.special-card__list,
.channel-card__links {
  gap: 8px;
}

.ticker-strip {
  gap: 12px;
  padding: 12px 14px;
  border-left: 4px solid var(--accent);
}

.ticker-strip__label {
  gap: 8px;
  white-space: nowrap;
  color: var(--accent-strong);
  font-weight: 700;
}

.ticker-strip__track {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  scrollbar-width: none;
}

.ticker-strip__track::-webkit-scrollbar {
  display: none;
}

.ticker-strip__item {
  flex: 0 0 auto;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.82);
  color: var(--accent-strong);
}

.section-heading {
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.channel-section {
  margin-top: 22px;
}

.feed-sentinel {
  margin-top: 10px;
  padding: 10px 12px;
  border: 1px dashed var(--line-strong);
  border-radius: 16px;
  color: var(--muted);
  font-size: 0.82rem;
  text-align: center;
}

.feed-sentinel--end {
  background: rgba(255, 255, 255, 0.62);
}

.story-card {
  position: relative;
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 16px;
  padding: 16px 18px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.98);
  overflow: hidden;
}

.story-card::before {
  content: '';
  position: absolute;
  inset: 0 0 auto;
  height: 1px;
  background: linear-gradient(90deg, rgba(198, 86, 52, 0.22), transparent 72%);
}

.story-card__media {
  overflow: hidden;
  border-radius: 8px;
  min-height: 0;
  aspect-ratio: 16 / 10;
  background: linear-gradient(135deg, rgba(198, 86, 52, 0.92), rgba(25, 55, 83, 0.94));
}

.story-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.story-card__media--empty {
  display: grid;
  place-items: center;
  color: rgba(255, 255, 255, 0.86);
  letter-spacing: 0.18em;
  font-size: 0.82rem;
}

.story-card__body {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.story-card__topline {
  gap: 8px;
  flex-wrap: wrap;
}

.story-card__source,
.story-card__category,
.story-card__rank {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 9px;
  border-radius: 999px;
  font-size: 0.74rem;
}

.story-card__source {
  background: rgba(25, 55, 83, 0.08);
  color: var(--accent-strong);
}

.story-card__category {
  background: var(--accent-soft);
  color: var(--accent);
}

.story-card__rank {
  background: var(--surface-dark);
  color: white;
}

.story-card__link {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.story-card h3 {
  font-size: 1.16rem;
  line-height: 1.34;
}

.story-card__link p {
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.62;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.story-card__footer {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  gap: 10px;
  margin-top: auto;
}

.story-card__stats {
  gap: 12px;
  flex-wrap: wrap;
}

.story-card__stats span,
.article-meta span,
.site-footer__meta span {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.story-card__actions {
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.story-card__save--active {
  background: var(--accent-soft);
  color: var(--accent);
  border-color: rgba(198, 86, 52, 0.28);
}

.story-card--lead {
  grid-template-columns: minmax(300px, 42%) minmax(0, 1fr);
  min-height: 240px;
  padding: 16px 18px;
}

.story-card--lead .story-card__media {
  min-height: 0;
  aspect-ratio: 16 / 10;
}

.story-card--lead h3 {
  font-size: clamp(1.5rem, 1.9vw, 2rem);
}

.story-card--lead .story-card__body {
  justify-content: flex-start;
}

.story-card--lead .story-card__footer {
  margin-top: 14px;
}

.story-card--feature,
.story-card--compact {
  grid-template-columns: 1fr;
}

.story-card--feature .story-card__media {
  min-height: 160px;
}

.story-card--compact {
  gap: 6px;
  padding: 10px;
}

.story-card--compact .story-card__media {
  display: none;
}

.story-card--compact h3 {
  font-size: 0.92rem;
}

.story-card--compact .story-card__footer {
  grid-template-columns: 1fr;
  align-items: start;
  gap: 8px;
  margin-top: 0;
}

.story-card--compact .story-card__stats,
.story-card--compact .story-card__actions {
  justify-content: flex-start;
}

.story-card--compact .story-card__stats {
  gap: 10px;
  row-gap: 6px;
}

.story-card--compact .story-card__stats span,
.story-card--compact .story-card__time,
.story-card--compact .story-card__save,
.story-card--compact .story-card__origin {
  white-space: nowrap;
}

.stacked-cards--sidebar .story-card--compact .story-card__footer {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.stacked-cards--sidebar .story-card--compact .story-card__actions {
  width: 100%;
  justify-content: flex-start;
}

.stacked-cards--sidebar .story-card--compact .story-card__time {
  display: none;
}

.sidebar-story-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.98);
}

.sidebar-story-card__topline,
.sidebar-story-card__meta,
.sidebar-story-card__actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.sidebar-story-card__title {
  display: block;
  font-family: var(--font-display);
  font-size: 1rem;
  line-height: 1.45;
}

.sidebar-story-card__meta {
  color: var(--muted);
  font-size: 0.86rem;
}

.sidebar-story-card__meta span,
.sidebar-story-card__actions > * {
  white-space: nowrap;
}

.sidebar-story-card__actions {
  justify-content: flex-start;
}

.saved-layout {
  gap: 14px;
}

.article-page__nav {
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
}

.article-hero {
  align-items: stretch;
  gap: 18px;
  padding: 18px;
  background:
    radial-gradient(circle at right top, rgba(198, 86, 52, 0.12), transparent 28%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(252, 247, 241, 0.82));
}

.article-hero__content {
  flex: 1.4;
  gap: 10px;
}

.article-meta {
  gap: 12px;
  flex-wrap: wrap;
}

.article-actions {
  gap: 10px;
  flex-wrap: wrap;
}

.article-hero__media {
  flex: 1;
  min-height: 260px;
  overflow: hidden;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(198, 86, 52, 0.92), rgba(25, 55, 83, 0.94));
  color: white;
  display: grid;
  place-items: center;
}

.article-hero__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.article-layout__main,
.article-layout__side {
  padding: 16px;
}

.article-body {
  gap: 12px;
}

.article-body p {
  font-size: 0.96rem;
  line-height: 1.82;
  color: #253140;
}

.empty-panel,
.article-loading {
  display: grid;
  place-items: center;
  gap: 10px;
  min-height: 180px;
  padding: 24px;
  color: var(--muted);
  text-align: center;
}

.article-loading--error {
  min-height: 280px;
}

.site-footer {
  justify-content: space-between;
  gap: 18px;
  margin-top: 16px;
  padding: 16px 18px;
}

.site-footer strong {
  font-family: var(--font-display);
  font-size: 1.18rem;
}

.site-footer__meta {
  gap: 16px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.source-pulse__item {
  justify-content: space-between;
  gap: 14px;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.72);
}

.empty-note {
  line-height: 1.65;
}

.is-spinning {
  animation: spin 1s linear infinite;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

@keyframes rise-in {
  from {
    opacity: 0;
    transform: translateY(14px);
  }

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

@media (max-width: 1360px) {
  .portal-home__banner {
    grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
  }

  .portal-home__aside {
    grid-column: 1 / -1;
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
    grid-template-rows: none;
  }

  .portal-home__visual-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }

  .portal-home__visual-card,
  .portal-home__express-card {
    grid-column: span 3;
  }

  .story-card {
    grid-template-columns: 200px minmax(0, 1fr);
  }
}

@media (max-width: 1180px) {
  .portal-home__banner {
    grid-template-columns: 1fr;
  }

  .portal-home__lead {
    grid-template-columns: 1fr;
  }

  .portal-home__headline-main {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: stretch;
  }

  .portal-home__aside {
    grid-template-columns: 1fr 1fr;
  }

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

  .portal-home__visual-card,
  .portal-home__express-card {
    grid-column: span 1;
  }

  .headline-grid,
  .content-layout,
  .saved-layout,
  .article-layout,
  .site-footer {
    grid-template-columns: 1fr;
  }

  .article-hero {
    flex-direction: column;
  }

  .operations-grid,
  .special-grid,
  .channel-mosaic {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .hero-banner__rail {
    width: 100%;
  }

  .hero-banner {
    grid-template-columns: 1fr;
  }

  .hero-banner--home .hero-banner__rail,
  .hero-quickline__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .content-layout__side--sticky {
    position: static;
  }
}

@media (max-width: 900px) {
  .app-shell {
    width: 100%;
    padding: 8px 10px 18px;
  }

  .portal-home__lead-media {
    min-height: 240px;
  }

  .masthead__core,
  .search-panel,
  .story-card__footer,
  .site-footer {
    flex-direction: column;
  }

  .hero-banner,
  .story-card,
  .story-card--lead {
    grid-template-columns: 1fr;
  }

  .portal-home__headline-main,
  .portal-home__aside {
    grid-template-columns: 1fr;
  }

  .story-card__actions {
    justify-content: flex-start;
  }

  .operations-grid,
  .special-grid,
  .channel-mosaic {
    grid-template-columns: 1fr;
  }

  .hero-banner,
  .control-panel,
  .portal-home__banner,
  .content-layout__main,
  .content-layout__side,
  .saved-layout__main,
  .saved-layout__side,
  .article-hero,
  .article-layout__main,
  .article-layout__side,
  .site-footer {
    padding: 16px;
  }

  .top-dock {
    top: 6px;
  }

  .story-card__footer {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .hero-banner--home .hero-banner__copy h2,
  .hero-spotlight__link h3 {
    max-width: none;
  }

  .hero-banner--home .hero-banner__copy h2 {
    font-size: 2.3rem;
  }

  .hero-banner--home .hero-banner__rail,
  .hero-quickline__grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .masthead__summary {
    display: none;
  }

  .channel-nav,
  .compact-links,
  .hero-banner__actions,
  .hero-banner__chips,
  .hero-banner__stats,
  .hero-banner__rail {
    width: 100%;
  }

  .story-card__stats,
  .article-meta {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }

  .hero-banner__copy h2,
  .article-hero__content h2 {
    font-size: 1.75rem;
  }

  .portal-home__visual-grid {
    grid-template-columns: 1fr;
  }

  .portal-home__visual-card,
  .portal-home__express-card {
    grid-column: span 1;
  }

  .portal-home__banner,
  .portal-home__lead,
  .portal-home__aside-card,
  .portal-home__visual-card,
  .portal-home__express-card {
    padding: 10px;
  }

  .hero-banner--home {
    min-height: auto;
  }

  .hero-brief {
    min-height: auto;
  }

  .hero-spotlight {
    padding: 18px;
  }
}


.published-newsroom .app-shell {
  width: min(100%, calc(var(--content-width) + 40px));
}

.published-newsroom .brand__mark {
  overflow: hidden;
}

.published-newsroom-art {
  width: 100%;
  height: 100%;
  min-height: 100%;
  display: grid;
  place-items: end start;
  padding: 18px;
  color: #fff;
  background:
    radial-gradient(circle at 78% 16%, rgba(255,255,255,0.26), transparent 22%),
    linear-gradient(135deg, rgba(210,25,32,0.94), rgba(25,55,83,0.96));
}

.published-newsroom-art span {
  max-width: 24ch;
  font-family: var(--font-display);
  font-size: clamp(1.1rem, 1.5vw, 1.6rem);
  line-height: 1.18;
  text-shadow: 0 10px 24px rgba(0,0,0,0.24);
}

.published-newsroom-art--thumb span,
.published-newsroom-art--photo span {
  font-size: 1rem;
}

.published-newsroom .search-input input {
  pointer-events: none;
}

