/* ============================================
   News / Newsroom Page
   ============================================ */

:root {
  --mono: 'JetBrains Mono', ui-monospace, Menlo, monospace;
}

/* ---------- HERO (newspaper masthead layout) ---------- */
.news-hero {
  position: relative; overflow: hidden;
  background: var(--navy);
  min-height: calc(100vh - 64px);
  display: flex; align-items: stretch;
}
.news-hero__bg { position: absolute; inset: 0; opacity: .18; }
.news-hero__bg img { width: 100%; height: 100%; object-fit: cover; object-position: center; }
.news-hero__overlay {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at top right, rgba(201,169,110,.08), transparent 55%),
    linear-gradient(180deg, rgba(10,22,40,.7) 0%, rgba(10,22,40,.88) 45%, var(--navy) 100%);
}
.news-hero__inner {
  position: relative; z-index: 1;
  width: 100%; max-width: var(--max-w); margin: 0 auto;
  padding: 40px var(--pad) 32px;
  display: flex; flex-direction: column; gap: 32px;
}

/* Masthead */
.masthead {
  display: flex; flex-direction: column; gap: 4px;
  padding-bottom: 20px; border-bottom: 1px solid var(--gold-40);
}
.masthead__brand {
  font-family: var(--serif); font-size: 28px; font-weight: 400; color: var(--cream);
  letter-spacing: -.5px; line-height: 1;
}
.masthead__brand em { font-style: italic; color: var(--gold); }
.masthead__meta {
  font-family: var(--mono); font-size: 11px; letter-spacing: .5px;
  color: var(--muted); margin-top: 6px;
}
.masthead__meta .up { color: #4ade80; font-weight: 600; }
.masthead__issue {
  font-family: var(--mono); font-size: 10px; letter-spacing: 1.5px; color: var(--gold);
  text-transform: uppercase;
}

.news-hero__split { display: flex; flex-direction: column; gap: 40px; flex: 1; }

/* Lead article */
.hero-lead { display: flex; flex-direction: column; gap: 14px; max-width: 720px; }
.hero-lead__kicker {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 2px;
  color: var(--gold); font-weight: 600; text-transform: uppercase;
  padding-bottom: 4px; border-bottom: 1px dashed var(--gold-40); width: fit-content;
}
.hero-lead__dot {
  width: 7px; height: 7px; background: #ef4444; border-radius: 50%;
  animation: hero-pulse 1.5s ease-in-out infinite;
}
@keyframes hero-pulse { 0%,100% { opacity: 1; } 50% { opacity: .3; } }

.hero-lead__title {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(32px, 7vw, 64px); line-height: 1.05;
  color: var(--cream); letter-spacing: -.5px;
  max-width: none;
}
.hero-lead__desc { font-size: 15px; line-height: 1.7; color: var(--muted); max-width: 640px; }
.hero-lead__meta {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--mono); font-size: 11px; color: var(--muted); letter-spacing: .5px;
}
.hero-lead__dot-sm { width: 3px; height: 3px; background: var(--muted); border-radius: 50%; }
.hero-lead__cta {
  font-size: 14px; font-weight: 500; color: var(--gold); letter-spacing: .3px;
  padding-bottom: 3px; border-bottom: 1px solid var(--gold); width: fit-content;
  transition: gap .2s, color .2s;
}
.hero-lead__cta:hover { color: var(--cream); border-bottom-color: var(--cream); }

/* Brief list */
.hero-brief { display: flex; flex-direction: column; gap: 16px; min-width: 0; }
.hero-brief__head {
  display: flex; align-items: baseline; justify-content: space-between;
  padding-bottom: 10px; border-bottom: 1px solid rgba(201,169,110,.25);
}
.hero-brief__head h3 {
  font-family: var(--serif); font-size: 16px; color: var(--cream); font-weight: 400;
  letter-spacing: .3px;
}
.hero-brief__count { font-family: var(--mono); font-size: 11px; color: var(--gold); letter-spacing: 2px; }
.brief-list { list-style: none; display: flex; flex-direction: column; gap: 0; }
.brief-item {
  display: grid; grid-template-columns: 56px 1fr; gap: 10px;
  padding: 14px 0; border-bottom: 1px solid rgba(255,255,255,.05);
  align-items: start;
}
.brief-item time { font-family: var(--mono); font-size: 11px; color: var(--gold); letter-spacing: 1px; padding-top: 2px; }
.brief-item__tag {
  grid-column: 2;
  font-family: var(--mono); font-size: 9px; letter-spacing: 2px;
  color: var(--muted); font-weight: 600; margin-bottom: 4px;
}
.brief-item__title {
  grid-column: 2;
  font-family: var(--serif); font-size: 14px; color: var(--cream); line-height: 1.4; font-weight: 400;
}

/* Hero foot stats */
.news-hero__foot {
  display: grid; grid-template-columns: auto 1fr;
  gap: 2px 16px;
  padding-top: 20px; border-top: 1px solid var(--gold-40);
  font-family: var(--mono); font-size: 11px; letter-spacing: .5px;
}
.news-hero__foot span { color: var(--muted); text-transform: uppercase; font-size: 9px; letter-spacing: 1.8px; }
.news-hero__foot strong { color: var(--cream); font-weight: 600; }

/* ---------- FILTER CHIPS ---------- */
.filters {
  background: var(--navy-light);
  border-top: 1px solid rgba(201,169,110,.12); border-bottom: 1px solid rgba(201,169,110,.12);
}
.filters__inner {
  max-width: var(--max-w); margin: 0 auto;
  padding: 18px var(--pad);
  display: flex; align-items: center; gap: 20px;
}
.filters__label {
  font-family: var(--mono); font-size: 10px; letter-spacing: 2px;
  color: var(--muted); font-weight: 600; flex-shrink: 0;
}
.filters__chips {
  display: flex; gap: 8px;
  overflow-x: auto; scrollbar-width: none;
  flex: 1;
}
.filters__chips::-webkit-scrollbar { display: none; }
.chip {
  flex-shrink: 0;
  padding: 8px 16px; font-size: 12px; font-weight: 500; letter-spacing: .3px;
  color: var(--cream); border: 1px solid rgba(255,255,255,.12);
  background: transparent;
  transition: background .2s, border-color .2s, color .2s;
  white-space: nowrap;
}
.chip:hover { border-color: var(--gold-40); color: var(--gold); }
.chip--active { background: var(--gold); color: var(--navy); border-color: var(--gold); }

/* ---------- TOP STORIES (asymmetric grid) ---------- */
.stories { padding: 80px var(--pad); max-width: var(--max-w); margin: 0 auto; }
.stories__grid { display: grid; grid-template-columns: 1fr; gap: 24px; margin-top: 32px; }
.story { display: flex; flex-direction: column; gap: 16px; transition: transform .4s ease; }
.story:hover { transform: translateY(-4px); }
.story__img { aspect-ratio: 16/10; overflow: hidden; background: var(--navy-card); }
.story__img img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s ease; }
.story:hover .story__img img { transform: scale(1.03); }
.story__tag {
  font-family: var(--mono); font-size: 10px; letter-spacing: 2px;
  color: var(--gold); font-weight: 600; text-transform: uppercase;
}
.story__title {
  font-family: var(--serif); font-weight: 400; color: var(--cream);
  font-size: 20px; line-height: 1.25; letter-spacing: -.3px;
}
.story__desc { font-size: 14px; color: var(--muted); line-height: 1.6; }
.story__meta {
  font-family: var(--mono); font-size: 11px; color: var(--muted); letter-spacing: .5px;
}

/* ---------- ARCHIVE LIST ---------- */
.archive { padding: 40px var(--pad) 80px; max-width: var(--max-w); margin: 0 auto; }
.archive__head { display: flex; flex-direction: column; gap: 24px; margin-bottom: 16px; }
.archive__tools { display: flex; flex-direction: column; gap: 10px; }
.archive__search { display: flex; }
.archive__search input {
  width: 100%;
  background: var(--navy-card); border: 1px solid rgba(255,255,255,.08);
  color: var(--cream); font-size: 13px; padding: 12px 16px;
  font-family: inherit; border-radius: 0;
  transition: border-color .2s;
}
.archive__search input::placeholder { color: rgba(139,154,181,.55); font-size: 13px; }
.archive__search input:focus { border-color: var(--gold-40); }
.archive__year {
  background: var(--navy-card); border: 1px solid rgba(255,255,255,.08);
  color: var(--cream); font-size: 13px; padding: 12px 16px;
  font-family: inherit; border-radius: 0;
  appearance: none; -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23C9A96E' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 16px center; padding-right: 40px;
}

.archive__list { list-style: none; border-top: 1px solid rgba(201,169,110,.2); }
.arch-row {
  display: grid; grid-template-columns: 64px 1fr; gap: 14px;
  padding: 20px 0; border-bottom: 1px solid rgba(255,255,255,.06);
  position: relative;
}
.arch-row--divider {
  grid-template-columns: 1fr auto;
  padding: 28px 0 12px; border-bottom: 1px solid var(--gold-40);
  background: transparent;
}
.arch-row--divider span {
  font-family: var(--mono); font-size: 11px; letter-spacing: 3px; color: var(--gold);
  font-weight: 700; text-transform: uppercase;
}
.arch-row--divider em {
  font-style: normal; font-family: var(--mono); font-size: 10px; letter-spacing: 1.5px;
  color: var(--muted); font-weight: 500;
}
.arch-row__thumb { aspect-ratio: 1; overflow: hidden; background: var(--navy-card); }
.arch-row__thumb img { width: 100%; height: 100%; object-fit: cover; }
.arch-row__body { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.arch-row__body--full { grid-column: 1 / -1; }
.arch-row__tag {
  font-family: var(--mono); font-size: 9px; letter-spacing: 2px;
  color: var(--gold); font-weight: 600; text-transform: uppercase;
}
.arch-row__body h3 {
  font-family: var(--serif); font-size: 17px; color: var(--cream); font-weight: 400;
  line-height: 1.3; letter-spacing: -.2px;
}
.arch-row__body p { font-size: 13px; color: var(--muted); line-height: 1.6; }
.arch-row__date {
  display: none;
  font-family: var(--mono); color: var(--muted); text-align: right; flex-shrink: 0;
}
.arch-row__date span { font-family: var(--serif); font-size: 28px; color: var(--cream); font-weight: 400; line-height: 1; display: block; }
.arch-row__date em { font-style: normal; font-size: 9px; letter-spacing: 1.8px; }

.archive__loadmore {
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  padding: 40px 0 0;
}
.archive__count { font-family: var(--mono); font-size: 11px; letter-spacing: 1px; color: var(--muted); }

/* ---------- FILINGS TERMINAL ---------- */
.filings {
  background: var(--dark-bg);
  padding: 80px var(--pad);
  border-top: 1px solid rgba(201,169,110,.18);
}
.filings__inner { max-width: var(--max-w); margin: 0 auto; }
.filings__head {
  display: flex; flex-direction: column; gap: 24px;
  padding-bottom: 32px;
}
.filings__head > div { display: flex; flex-direction: column; gap: 10px; }
.filings__title { font-family: var(--serif); font-size: clamp(26px, 5vw, 42px); line-height: 1.1; color: var(--cream); font-weight: 400; letter-spacing: -.3px; }
.filings__sub { font-size: 14px; color: var(--muted); line-height: 1.7; max-width: 580px; }
.filings__bursa {
  font-family: var(--mono); font-size: 12px; font-weight: 500; color: var(--gold);
  padding-bottom: 3px; border-bottom: 1px solid var(--gold-40); width: fit-content;
}

.filings__terminal {
  background: var(--navy);
  border: 1px solid rgba(201,169,110,.3);
  font-family: var(--mono); overflow-x: auto;
}
.filings__thead {
  display: none;
  background: rgba(201,169,110,.08);
  border-bottom: 1px solid rgba(201,169,110,.3);
  padding: 12px 20px;
  font-size: 10px; letter-spacing: 2px; font-weight: 700; color: var(--gold);
  grid-template-columns: 140px 120px 120px 1fr 120px; gap: 20px;
}
.filings__row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 4px 20px;
  padding: 16px 20px;
  border-bottom: 1px solid rgba(255,255,255,.05);
  font-size: 12px; color: var(--cream);
  transition: background .2s;
}
.filings__row:hover { background: rgba(201,169,110,.05); }
.filings__row:last-child { border-bottom: none; }
.filings__ref { color: var(--gold); letter-spacing: .3px; font-weight: 500; font-size: 11px; }
.filings__date { color: var(--muted); font-size: 11px; letter-spacing: .5px; }
.filings__type {
  color: var(--gold); font-size: 9px; letter-spacing: 2px; font-weight: 700;
  padding: 2px 8px; background: rgba(201,169,110,.08); border: 1px solid rgba(201,169,110,.25); width: fit-content;
  margin: 4px 0;
}
.filings__title { font-family: var(--serif); font-size: 15px; color: var(--cream); line-height: 1.4; font-weight: 400; letter-spacing: 0; }
.filings__file { color: var(--muted); font-size: 11px; letter-spacing: .5px; }

/* ---------- MEDIA RESOURCES ---------- */
.media { padding: 80px var(--pad); max-width: var(--max-w); margin: 0 auto; }
.media__heading { font-family: var(--serif); font-size: clamp(28px, 5vw, 46px); line-height: 1.1; color: var(--cream); margin: 20px 0 40px; font-weight: 400; letter-spacing: -.3px; }

.media__grid { display: grid; grid-template-columns: 1fr; gap: 16px; margin-bottom: 60px; }
.media-card {
  background: var(--navy-card);
  padding: 32px 28px 28px;
  display: flex; flex-direction: column; gap: 12px;
  border: 1px solid rgba(255,255,255,.05);
  transition: border-color .3s, transform .3s;
  position: relative;
}
.media-card::after {
  content: '↓'; position: absolute; top: 28px; right: 24px;
  width: 32px; height: 32px; border: 1px solid var(--gold-40);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--gold); font-size: 14px;
  transition: background .3s, color .3s, transform .3s;
}
.media-card:hover { border-color: var(--gold-40); transform: translateY(-3px); }
.media-card:hover::after { background: var(--gold); color: var(--navy); transform: translateY(3px); }
.media-card__num { font-family: var(--serif); font-size: 32px; color: var(--gold); line-height: 1; font-weight: 400; opacity: .9; }
.media-card h3 { font-family: var(--serif); font-size: 22px; color: var(--cream); font-weight: 400; line-height: 1.2; letter-spacing: -.2px; }
.media-card p { font-size: 13px; color: var(--muted); line-height: 1.65; }
.media-card__file {
  font-family: var(--mono); font-size: 10px; letter-spacing: 1.5px;
  color: var(--gold); text-transform: uppercase; font-weight: 500;
  margin-top: 8px; padding-top: 12px; border-top: 1px dashed rgba(201,169,110,.3);
}

.media__contact {
  display: grid; grid-template-columns: 1fr;
  gap: 24px;
  padding: 40px 0 0;
  border-top: 1px solid rgba(201,169,110,.2);
}
.media__contact-col { display: flex; flex-direction: column; gap: 6px; }
.media__contact-label { font-family: var(--mono); font-size: 10px; letter-spacing: 2.5px; color: var(--gold); font-weight: 700; }
.media__contact-col a { font-family: var(--serif); font-size: 22px; color: var(--cream); font-weight: 400; border-bottom: 1px solid rgba(255,255,255,.15); width: fit-content; padding-bottom: 2px; transition: border-color .2s; letter-spacing: -.2px; }
.media__contact-col a:hover { border-bottom-color: var(--gold); }
.media__contact-note { font-size: 12px; color: var(--muted); line-height: 1.5; }

/* ---------- PRESS SUBSCRIBE ---------- */
.press-subscribe { background: var(--cream); color: var(--navy); padding: 60px var(--pad); }
.press-subscribe__inner { max-width: var(--max-w); margin: 0 auto; display: flex; flex-direction: column; gap: 32px; }
.press-subscribe__label { font-family: var(--mono); font-size: 10px; letter-spacing: 2.5px; color: rgba(10,22,40,.55); font-weight: 700; }
.press-subscribe__inner h2 { font-family: var(--serif); font-size: clamp(26px, 5vw, 44px); line-height: 1.1; margin: 10px 0 12px; font-weight: 400; letter-spacing: -.3px; }
.press-subscribe__inner p { font-size: 14px; line-height: 1.7; color: rgba(10,22,40,.7); max-width: 480px; }
.press-subscribe__form { display: flex; flex-direction: column; gap: 10px; }
.press-subscribe__form input,
.press-subscribe__form select {
  background: var(--cream); border: 1px solid rgba(10,22,40,.2);
  color: var(--navy); font-size: 14px; padding: 14px 16px;
  font-family: inherit; border-radius: 0;
  transition: border-color .2s;
}
.press-subscribe__form select {
  appearance: none; -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%230A1628' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 16px center; padding-right: 40px;
}
.press-subscribe__form input::placeholder { color: rgba(10,22,40,.4); }
.press-subscribe__form input:focus,
.press-subscribe__form select:focus { border-color: var(--navy); }
.press-subscribe__form .btn { width: 100%; }

/* ============================================
   RESPONSIVE — Tablet (>= 640px)
   ============================================ */
@media (min-width: 640px) {
  .news-hero__foot { grid-template-columns: auto auto auto auto auto auto; gap: 4px 20px; }
  .news-hero__foot > *:nth-child(even) { grid-row: 1; }
  .stories__grid { grid-template-columns: 1fr 1fr; }
  .media__grid { grid-template-columns: 1fr 1fr; }
  .media__contact { grid-template-columns: 1fr 1fr; }
  .archive__tools { flex-direction: row; }
  .archive__search { flex: 1; }
  .archive__year { flex-shrink: 0; width: 180px; }
  .arch-row { grid-template-columns: 80px 1fr 100px; }
  .arch-row__date { display: flex; flex-direction: column; }
  .arch-row__body--full { grid-column: 1 / span 2; }
  .press-subscribe__form { flex-direction: row; flex-wrap: wrap; }
  .press-subscribe__form input { flex: 1; min-width: 240px; }
  .press-subscribe__form select { flex-shrink: 0; width: 180px; }
  .press-subscribe__form .btn { width: auto; white-space: nowrap; }
}

/* ============================================
   RESPONSIVE — Desktop (>= 1024px)
   ============================================ */
@media (min-width: 1024px) {
  .news-hero { min-height: calc(100vh - 64px); }
  .news-hero__inner { padding: 56px var(--pad-desk) 48px; gap: 40px; }
  .masthead {
    flex-direction: row; align-items: center; justify-content: space-between;
    padding-bottom: 24px;
  }
  .masthead__meta { margin-top: 0; }
  .masthead__brand { font-size: 34px; }
  .news-hero__split { flex-direction: row; gap: 56px; }
  .hero-lead { flex: 1.3; }
  .hero-lead__desc { font-size: 16px; }
  .hero-brief { flex: 1; max-width: 420px; border-left: 1px solid rgba(201,169,110,.2); padding-left: 40px; }
  .news-hero__foot {
    grid-template-columns: repeat(6, auto);
    gap: 4px 48px; justify-content: flex-start;
  }

  .filters__inner { padding: 22px var(--pad-desk); }
  .filters__chips { justify-content: flex-start; flex-wrap: nowrap; overflow-x: auto; }

  .stories, .archive, .media { padding-left: var(--pad-desk); padding-right: var(--pad-desk); padding-top: 120px; padding-bottom: 80px; }

  .stories__grid {
    grid-template-columns: 2fr 1fr;
    grid-template-rows: auto auto;
    gap: 28px 36px;
  }
  .story--wide { grid-row: span 2; }
  .story--wide .story__title { font-size: 32px; }
  .story--wide .story__img { aspect-ratio: 16/11; }
  .story:not(.story--wide) { display: grid; grid-template-columns: 180px 1fr; gap: 20px; align-items: start; }
  .story:not(.story--wide) .story__img { aspect-ratio: 1; }
  .story:not(.story--wide) .story__body { gap: 8px; }

  .arch-row { grid-template-columns: 120px 1fr 140px; gap: 24px; padding: 28px 0; }
  .arch-row__body h3 { font-size: 20px; }
  .arch-row__body p { font-size: 14px; }
  .arch-row__date span { font-size: 32px; }

  .filings { padding: 120px var(--pad-desk); }
  .filings__head { flex-direction: row; justify-content: space-between; align-items: flex-end; gap: 60px; }
  .filings__thead { display: grid; }
  .filings__row {
    grid-template-columns: 140px 120px 140px 1fr 120px;
    gap: 20px; padding: 18px 20px;
    align-items: center;
  }
  .filings__type { margin: 0; }

  .media { padding-bottom: 120px; }
  .media__grid { grid-template-columns: repeat(3, 1fr); gap: 20px; margin-bottom: 80px; }
  .media__contact { grid-template-columns: repeat(3, 1fr); gap: 48px; padding-top: 60px; }

  .press-subscribe { padding: 100px var(--pad-desk); }
  .press-subscribe__inner { flex-direction: row; align-items: center; gap: 80px; justify-content: space-between; }
  .press-subscribe__inner > div { flex: 1; max-width: 540px; }
  .press-subscribe__form { flex: 1; flex-direction: row; max-width: 600px; flex-wrap: nowrap; }
}
