/* Category A (Mosaic Magazine) – loaded only on non-country category pages */

/* Hero row */
.catA-hero { margin:16px 0 10px; }
.catA-hero-grid { display:grid; grid-template-columns: 1.6fr 1fr; gap: var(--bwtv-gutter, 16px); align-items:stretch; }
.catA-hero-main .media,
.catA-hero-side .media { display:block; width:100%; aspect-ratio:16/9; background:#eee; border-radius:6px; overflow:hidden; position:relative; }
.catA-hero-main .media-img,
.catA-hero-side .media-img { width:100%; height:100%; object-fit:cover; display:block; }
.catA-hero-main .media.no-img,
.catA-hero-side .media.no-img { background:#f0f0f0; }
.media-body { margin-top:10px; }
.media-title { font-size: var(--fs-h2, 28px); line-height: var(--lh-h2, 1.2); font-weight:900; margin:6px 0 4px; text-wrap: balance; }
.media-title a { color:#000; text-decoration:none; }
.media-title a:hover { color: var(--bwtv-color-primary, #fcc600); }
.media-meta { color: var(--bwtv-color-muted, #666); font-size: var(--fs-meta, 12px); line-height: var(--lh-meta, 1.3); }
.media-excerpt { color: var(--bwtv-color-text, #222); font-size: var(--fs-body-m, 16px); line-height: var(--lh-body-m, 1.5); margin-top:6px; }
.catA-hero-side { display:grid; gap: var(--bwtv-gutter, 16px); }
.side-item .side-title { font-weight:900; margin:6px 0 2px; font-size: var(--fs-h4, 20px); line-height: var(--lh-h4, 1.35); }
.side-item .side-title a { color:#000; text-decoration:none; }
.side-item .side-title a:hover { color: var(--bwtv-color-primary, #fcc600); }
.side-item .side-meta { color: var(--bwtv-color-muted, #666); font-size: var(--fs-meta, 12px); line-height: var(--lh-meta, 1.3); }

/* Grid */
.catA-grid { list-style:none; margin:14px 0 0; padding:0; display:grid; grid-template-columns: repeat(3, 1fr); gap: var(--bwtv-gutter, 16px); }
.card { display:grid; gap:8px; grid-template-rows: auto 1fr; }
.card-media { display:block; width:100%; aspect-ratio:16/9; background:#eee; border-radius:6px; overflow:hidden; position:relative; }
.card-media.no-img { background:#f0f0f0; }
.card-img { width:100%; height:100%; object-fit:cover; display:block; }
.card-body { min-width:0; }
.card-title { margin:0; font-weight:900; font-size: var(--fs-h4, 20px); line-height: var(--lh-h4, 1.35); text-wrap: balance; }
.card-title a { color:#000; text-decoration:none; }
.card-title a:hover { color: var(--bwtv-color-primary, #fcc600); }
.card-excerpt { color: var(--bwtv-color-muted, #666); font-size: var(--fs-body-m, 16px); line-height: var(--lh-body-m, 1.5); margin-top:4px; }
.card-meta { color: var(--bwtv-color-muted, #666); font-size: var(--fs-meta, 12px); line-height: var(--lh-meta, 1.3); margin-top:6px; }

/* Infeed ad placeholder safety */
.catA-grid .ad-infeed { list-style:none; display:flex; align-items:center; justify-content:center; min-height:250px; border:1px dashed #eee; border-radius:6px; }
/* Sidebar square ad reserved space */
.archive-sidebar .ad-square { width:300px; height:300px; background:#f4f4f4; border:1px solid #e5e5e5; border-radius:4px; display:flex; align-items:center; justify-content:center; color:#999; font-weight:900; }
@media (max-width: 1024px) { .archive-sidebar .ad-square { width:100%; max-width:300px; margin-left:auto; margin-right:auto; } }

/* Responsive */
@media (max-width: 1024px) {
  .catA-hero-grid { grid-template-columns: 1fr; }
  .catA-hero-side { grid-template-columns: repeat(2, 1fr); }
  .catA-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .catA-hero-side { grid-template-columns: 1fr; }
  .catA-grid { grid-template-columns: 1fr; }
  .media-title { font-size: calc(var(--fs-h3, 22px) + 2px); }
}

/* Container width for category pages (non-country) */
@media (min-width: 1024px) {
  .container.layout { width: min(100% - 2*var(--bwtv-gutter, 16px), 900px); margin-left:auto; margin-right:auto; }
}

/* List + Right rail layout */
.catL-grid { display:grid; grid-template-columns: .65fr .35fr; gap: var(--bwtv-gutter, 16px); align-items:start; }
.catL-left { min-width:0; }
.catL-list { list-style:none; margin:8px 0 0; padding:0; display:grid; gap:18px; }

.li { display:grid; grid-template-columns: 260px 1fr; gap:16px; align-items:start; }
.li-media { display:block; width:100%; aspect-ratio:16/9; background:#eee; border-radius:8px; overflow:hidden; position:relative; }
.li-media.no-img { background:#f0f0f0; }
.li-img { width:100%; height:100%; object-fit:cover; display:block; }
.li-body { min-width:0; }
.li-title { margin:0; font-weight:900; font-size: var(--fs-h4, 18px); line-height: var(--lh-h4, 1.28); text-wrap: balance; }
.li-title a { color:#000; text-decoration:none; }
.li-title a:hover { color: var(--bwtv-color-primary, #fcc600); }
.li-excerpt { color: var(--bwtv-color-text, #222); font-size: var(--fs-body-m, 16px); line-height: var(--lh-body-m, 1.5); margin-top:6px; overflow:hidden; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; line-clamp:2; }
.li-meta { color: var(--bwtv-color-muted, #666); font-size: var(--fs-meta, 12px); line-height: var(--lh-meta, 1.3); margin-top:6px; }

.catL-rail { min-width:0; position:sticky; top:84px; align-self:start; }
.rail-head { display:inline-block; background: var(--bwtv-color-primary, #fcc600); color:#000; font-weight:900; font-family: var(--bwtv-font-headings, inherit); text-transform:uppercase; letter-spacing:.02em; padding:4px 8px; border-radius:3px; margin:0 0 10px; }
.rail-list { list-style:none; margin:0; padding:0; display:grid; gap:12px; }
.rail-item { display:grid; grid-template-columns: 46px 1fr; gap:8px; align-items:start; }
.rail-time { color: var(--bwtv-color-muted, #666); font-size:12px; line-height:1.2; margin-top:2px; white-space:nowrap; }
.rail-badge { display:inline-block; background:#ff9900; color:#000; font-weight:900; text-transform:uppercase; font-size:11px; line-height:1; padding:3px 6px; border-radius:3px; margin-right:6px; }
.rail-link { color:#000; text-decoration:none; font-weight:700; }
.rail-link:hover { color: var(--bwtv-color-primary, #fcc600); }

@media (max-width: 1024px) {
  .catL-grid { grid-template-columns: 1fr; }
  .catL-rail { position:static; }
  .li { grid-template-columns: 220px 1fr; }
}
@media (max-width: 640px) {
  .li { grid-template-columns: 1fr; }
}
