/* ==========================================================================
   Layout archetype: COMPACT NEWS DASHBOARD  (Spektra, Magna)
   A dense, modular control-panel of news: a metric bar, a compact lead block,
   per-channel panels (each a header + mini-list), a dense latest list and a
   channel index. Token-driven so it works on a semi-dark theme (Spektra) and a
   light ivory theme (Magna) alike. Scoped under .cd-* — the other four
   archetypes are untouched. Not a hero, not magazine, not a river, not masonry.
   ========================================================================== */

.cd { padding-top: var(--sp-4); }

/* ---- metric / dashboard bar ---- */
.cd-bar { display: flex; align-items: center; gap: var(--sp-3) var(--sp-4); flex-wrap: wrap; padding-bottom: var(--sp-3); margin-bottom: var(--sp-4); border-bottom: 2px solid var(--c-accent); }
.cd-bar__label { display: inline-flex; align-items: center; gap: 7px; font-family: var(--font-ui); font-weight: 800; font-size: .74rem; letter-spacing: .12em; text-transform: uppercase; color: var(--c-accent); }
.cd-bar__label::before { content: ""; width: 8px; height: 8px; border-radius: 2px; background: var(--c-accent); }
.cd-bar__date { font-family: var(--font-ui); font-size: .82rem; color: var(--c-text-muted); }
.cd-metrics { display: flex; gap: var(--sp-2); margin-left: auto; flex-wrap: wrap; }
.cd-metric { border: 1px solid var(--c-border); border-radius: var(--radius-sm); padding: 5px 12px; background: var(--c-surface); }
.cd-metric__num { display: block; font-family: var(--font-metric, var(--font-ui)); font-weight: 800; font-size: 1.05rem; line-height: 1.1; color: var(--c-accent); }
.cd-metric__label { font-family: var(--font-ui); font-size: .6rem; letter-spacing: .08em; text-transform: uppercase; color: var(--c-text-muted); }

/* ---- modular grid ---- */
.cd-grid { display: grid; grid-template-columns: 1fr; gap: var(--sp-4); }
.cd-panel { background: var(--c-surface); border: 1px solid var(--c-border); border-radius: var(--radius); padding: var(--sp-4); min-width: 0; }
.cd-panel__head { display: flex; align-items: baseline; justify-content: space-between; gap: var(--sp-2); margin-bottom: var(--sp-3); padding-bottom: var(--sp-2); border-bottom: 1px solid var(--c-border); }
.cd-panel__title { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-ui); font-weight: 800; font-size: .82rem; letter-spacing: .06em; text-transform: uppercase; color: var(--c-text); margin: 0; }
.cd-panel__title::before { content: ""; width: 4px; height: 14px; background: var(--c-accent); border-radius: 2px; }
.cd-panel__more { font-family: var(--font-ui); font-size: .72rem; font-weight: 600; color: var(--c-accent); white-space: nowrap; }

.cd-list { display: flex; flex-direction: column; }
.cd-row { padding: var(--sp-2) 0; border-bottom: 1px solid var(--c-border); }
.cd-row:last-child { border-bottom: 0; padding-bottom: 0; }
.cd-row__title { font-family: var(--font-display); font-size: .94rem; line-height: 1.3; margin: 0; font-weight: 600; display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.cd-row__title a { color: var(--c-text); }
.cd-row__title a:hover { color: var(--c-primary); text-decoration: none; }
.cd-row__meta { font-family: var(--font-ui); font-size: .7rem; color: var(--c-text-muted); margin: 3px 0 0; }
.cd-row__meta time { font-weight: 600; }

/* lead block (compact, not a hero) */
.cd-lead__media { display: block; border-radius: var(--radius-sm); overflow: hidden; aspect-ratio: 16 / 9; background: var(--c-surface-2); margin-bottom: var(--sp-3); }
.cd-lead__media img { width: 100%; height: 100%; object-fit: cover; }
.cd-kicker { display: inline-block; font-family: var(--font-ui); font-weight: 800; font-size: .66rem; letter-spacing: .07em; text-transform: uppercase; color: var(--c-accent); margin-bottom: 5px; }
.cd-lead__title { font-family: var(--font-display); font-size: 1.4rem; line-height: 1.2; margin: 0; }
.cd-lead__title a { color: var(--c-text); }
.cd-lead__title a:hover { color: var(--c-primary); text-decoration: none; }
.cd-lead__dek { color: var(--c-text-muted); font-size: .96rem; line-height: 1.55; margin: var(--sp-2) 0 var(--sp-3); display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.cd-lead__sec { border-top: 1px solid var(--c-border); margin-top: var(--sp-3); padding-top: var(--sp-2); }

/* numbered side block */
.cd-rank { counter-reset: cdr; display: flex; flex-direction: column; }
.cd-rank__item { display: grid; grid-template-columns: auto 1fr; gap: var(--sp-3); align-items: start; padding: var(--sp-2) 0; border-bottom: 1px solid var(--c-border); }
.cd-rank__item:last-child { border-bottom: 0; }
.cd-rank__item::before { counter-increment: cdr; content: counter(cdr, decimal-leading-zero); font-family: var(--font-metric, var(--font-ui)); font-weight: 800; font-size: 1.1rem; color: var(--c-accent); line-height: 1.2; }
.cd-rank__title { font-family: var(--font-display); font-size: .92rem; line-height: 1.3; margin: 0; font-weight: 600; }
.cd-rank__title a { color: var(--c-text); }

/* channel index chips */
.cd-index { display: flex; flex-wrap: wrap; gap: var(--sp-2); }
.cd-index a { font-family: var(--font-ui); font-size: .8rem; font-weight: 600; color: var(--c-text); border: 1px solid var(--c-border); padding: 4px 11px; border-radius: 999px; }
.cd-index a:hover { background: var(--c-accent); color: var(--c-on-accent); border-color: var(--c-accent); text-decoration: none; }

/* small screens: 1 tidy column, slimmer header */
@media (max-width: 599px) {
  :root { --header-h: 54px; }
  .brand img, .brand .custom-logo { height: 34px; }
  .brand__name { font-size: 1.04rem; }
  .cd-metrics { width: 100%; margin-left: 0; }
}

/* tablet: 2 columns */
@media (min-width: 600px) {
  .cd-grid { grid-template-columns: 1fr 1fr; }
  .cd-lead, .cd-wide { grid-column: 1 / -1; }
}

/* desktop: a 12-column dashboard */
@media (min-width: 1000px) {
  .cd-grid { grid-template-columns: repeat(12, 1fr); gap: var(--sp-4); }
  .cd-lead { grid-column: span 8; }
  .cd-side { grid-column: span 4; }
  .cd-panel--chan { grid-column: span 4; }
  .cd-wide { grid-column: span 8; }
  .cd-narrow { grid-column: span 4; }
}
