:root { --max: 840px; }
* { box-sizing: border-box; }
body { font-family: "Host Grotesk", system-ui, -apple-system, Segoe UI, Roboto, sans-serif; line-height: 1.25; margin: 0; display: flex; flex-direction: column; align-items: center; background: #fff; color: #1C1D1A; font-size: 18px; font-weight: 400; font-style: normal; font-optical-sizing: auto; font-synthesis: none; -webkit-font-smoothing: antialiased; }
h1, h2 { font-family: "Instrument Serif", serif; color: #1C1D1A; font-weight: 400; font-style: normal; }
h3, h4, h5, h6 { font-family: "Instrument Serif", serif; color: #1C1D1A; font-weight: 400; font-style: normal; }
h1 { line-height: 1.05; font-size: 48px; }
h2 { font-size: 40px; }
h3 { font-size: 32px; line-height: 1.2; }
.site-header { width: 100%; padding: 16px 16px; display: flex; justify-content: center; align-items: center; position: sticky; top: 0; z-index: 10; background: #fff; }
.site-header__inner { width: 100%; display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.site-header__brand { font-size: 18px; font-weight: 700; text-decoration: none; color: inherit; }
.site-header__brand:hover { opacity: 0.8; }
.site-header__countdown { font-size: 12px; padding: 4px 10px; background: #1C1D1A; color: #FAF8F6; border-radius: 999px; font-variant-numeric: tabular-nums; display: inline-flex; align-items: center; gap: 6px; }
.site-header__countdown::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: #4CAF50; box-shadow: 0 0 0 2px rgba(76, 175, 80, 0.25); }
.container { width: min(100%, var(--max)); margin: 24px 0; padding: 0 16px; }
.homepage-hero { display: grid; gap: 64px; margin: 0 0 56px; padding: 32px; border-radius: 20px; background: #FAF8F6; align-items: start; }
.homepage-hero__intro { display: grid; gap: 16px; }
.page-title { margin: 0 0 16px; font-size: 48px; line-height: 1.05; }
.homepage-hero__title { margin-bottom: 0; }
.homepage-hero__lead { margin: 0; font-size: 18px; max-width: 540px; color: #1C1D1A; }
.weekly-feature { display: grid; gap: 16px; padding: 32px; border-radius: 16px; background: #FAF8F6; color: inherit; text-decoration: none; position: relative; }
.homepage-hero__feature.weekly-feature { padding: 16px; box-shadow: 0 18px 45px rgba(28, 29, 26, 0.18); border-radius: 12px; backdrop-filter: blur(0); }
.homepage-hero__feature.weekly-feature::after { content: ""; position: absolute; inset: 0; border: 1.5px solid rgba(255, 255, 255, 0.2); border-radius: inherit; pointer-events: none; }
.weekly-feature__meta { display: flex; flex-wrap: wrap; gap: 12px; font-size: 14px; letter-spacing: 0.08em; text-transform: uppercase; color: #1C1D1A; }
.weekly-feature__date { font-weight: 600; font-size: 12px; }
.weekly-feature__week { font-weight: 500; }
.weekly-feature__title { margin: 0; font-size: 40px; line-height: 1.2; }
.weekly-feature__summary { margin: 0; font-size: 18px; max-width: 620px; }
.weekly-feature__highlights { display: grid; gap: 12px; }
.weekly-feature__highlights h3 { margin: 0; font-size: 32px; font-family: "Host Grotesk", system-ui, -apple-system, Segoe UI, Roboto, sans-serif; letter-spacing: 0.08em; text-transform: uppercase; font-weight: 600; }
.weekly-feature__highlights ul { margin: 0; padding-left: 20px; display: grid; gap: 8px; }
.weekly-feature__highlights li { background: transparent; padding: 0; border-radius: 0; color: #1C1D1A; font-size: 16px; line-height: 1.5; }
.weekly-feature__cta { display: flex; align-items: center; justify-content: center; font-size: 16px; gap: 8px; padding: 8px 16px; border-radius: 4px; background: #1C1D1A; color: #fff; text-decoration: none; font-weight: 500; transition: background 0.2s ease, color 0.2s ease; width: 100%; position: sticky; bottom: 16px; z-index: 2; }
.weekly-feature__cta:hover { background: #EFEDEB; color: #1C1D1A; }
.homepage-archive { display: grid; gap: 24px; margin-top: 64px; }
.homepage-archive__header { display: grid; gap: 8px; max-width: 560px; }
.homepage-section-title { margin: 0; font-size: 40px; line-height: 1.2; }
.homepage-archive__hint { margin: 0; font-size: 16px; color: #1C1D1A; }
.homepage-empty { margin: 0; padding: 24px; border-radius: 16px; background: #FAF8F6; font-size: 16px; }
.weekly h2 { margin-top: 1.25em; }
.archive { list-style: none; padding: 0; }
.archive li { display: flex; gap: 8px; padding: 8px 0; }
.weekly-archive { display: grid; gap: 24px; padding: 0; margin: 0; }
.weekly-preview { display: flex; flex-direction: column; gap: 12px; border-radius: 16px; padding: 24px; background: #FAF8F6; color: inherit; text-decoration: none; transition: background 0.2s ease, color 0.2s ease; min-height: 220px; }
.weekly-preview:hover { background: #EFEDEB; color: #1C1D1A; }
.weekly-preview__meta { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: #1C1D1A; font-weight: 600; }
.weekly-preview__date { font-weight: 600; }
.weekly-preview__week { font-weight: 500; }
.weekly-preview__title { margin: 0; font-size: 32px; line-height: 1.2; }
.weekly-preview__summary { margin: 0; color: #1C1D1A; font-size: 16px; }
.weekly-preview__highlights { display: grid; gap: 8px; }
.weekly-preview__highlight-label { margin: 0; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; font-weight: 600; color: #1C1D1A; }
.weekly-preview__highlights ul { margin: 0; padding-left: 18px; display: grid; gap: 6px; }
.weekly-preview__highlights li { background: transparent; padding: 0; border-radius: 0; color: #1C1D1A; font-size: 14px; line-height: 1.5; }
.weekly-preview__cta { margin-top: auto; font-size: 14px; font-weight: 600; color: #446CB7; }
.weekly-highlight { margin-top: 12px; }
.weekly-highlight h3 { margin: 0 0 8px; font-size: 32px; text-transform: uppercase; letter-spacing: 0.05em; }
.weekly-highlight ul { margin: 0 0 0 20px; padding: 0; }
.weekly { display: grid; gap: 32px; }
.weekly-header { display: grid; gap: 12px; }
.weekly-meta { margin: 0; color: #D9D9D9; font-size: 14px; font-weight: 600; }
.weekly-meta time { color: inherit; font-weight: 500; }
.weekly-header .page-title { margin: 0; font-size: 48px; line-height: 1.05; }
.weekly-header .weekly-summary { margin: 0; }
.weekly-topics { display: grid; gap: 16px; }
.weekly-topics h2 { margin: 0; }
.topics-grid { display: grid; gap: 16px; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.topic-card { display: grid; grid-template-rows: 1fr auto; gap: 32px; border-radius: 12px; padding: 16px; background: #FAF8F6; color: inherit; overflow: hidden; height: 100%; }
.topic-card__content { display: grid; gap: 12px; color: inherit; }
.topic-card__media { border-radius: 8px; overflow: hidden; background: #f3f4f6; aspect-ratio: 16 / 9; width: 100%; background-size: cover; background-position: center; background-repeat: no-repeat; }
.topic-card h3 { margin: 0; font-size: 32px; }
.topic-card__excerpt { color: #1C1D1A; font-size: 16px; }
.topic-card__excerpt p { margin: 0; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis; }
.topic-card__excerpt ul { margin: 0 0 0 16px; padding: 0; }
.topic-card__cta{
  justify-self: start;
  padding: 8px 12px;
  border-radius: 999px;
  border: none;
  background: #1C1D1A;
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  text-transform: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s ease;
}

.topic-card__cta:hover {
  background: #484946;
}

.topic-card__cta:focus-visible {
  outline: 2px solid #446CB7;
  outline-offset: 2px;
}
.weekly-extra__content { display: grid; gap: 12px; }
.weekly-extra__content ul { margin-left: 20px; }
.weekly-topic-page { display: grid; gap: 24px; }
.weekly-topic-page .topic-nav { display: flex; justify-content: flex-start; align-items: center; gap: 12px; }
.weekly-topic-page .topic-nav a { text-decoration: none; color: #1C1D1A; font-weight: 600; transition: opacity 0.2s ease; }
.weekly-topic-page .topic-nav a:hover { opacity: 0.7; }
.weekly-topic-week { margin: 0; color: #D9D9D9; font-size: 14px; }
.topic-hero { margin: 0; border-radius: 12px; overflow: hidden; background: #f3f4f6; aspect-ratio: 16 / 9; width: 100%; background-size: cover; background-position: center; background-repeat: no-repeat; display: flex; align-items: flex-end; justify-content: flex-start; text-align: left; padding: 32px; }
.topic-content { display: grid; gap: 16px; }
.topic-title { font-size: 48px; margin: 0; max-width: 640px; line-height: 1.05; }
.topic-content ul { margin-left: 20px; }
.topic-content p { line-height: 1.75; }
.weekly-feature__highlights li > a {color: #1C1D1A; opacity: 0.7; text-decoration: none;}
.weekly-feature__highlights li > a:hover { opacity: 1; }
.highlight-section li > a {color: #1C1D1A; opacity: 0.7; text-decoration: none;}
.highlight-section li > a:hover { opacity: 1; }
.topic-content a {color: #1C1D1A; opacity: 0.7; text-decoration: none;}
.topic-content a:hover { opacity: 1; }
.highlight-section { margin-top: 32px; display: grid; gap: 16px; }
.highlight-section h2 { margin: 0; }
.highlight-section ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
.highlight-section li { padding: 16px; border-radius: 8px; background: #FAF8F6; color: #1C1D1A; font-size: 16px; line-height: 1.5; }
.highlight-section li > p { margin: 0; }
.topic-sources { margin-top: 24px; display: grid; gap: 12px; }
.topic-sources h2 { margin: 0; }
.sources-pills { display: flex; flex-wrap: wrap; gap: 8px; }
.source-pill { display: inline-flex; align-items: center; padding: 8px 14px; border-radius: 999px; background: #FAF8F6; color: #1C1D1A; text-decoration: none; font-size: 14px; font-weight: 600; transition: background 0.2s ease, color 0.2s ease; }
.source-pill:hover { background: #EFEDEB; color: #1C1D1A; }
@media (min-width: 720px) { .homepage-hero { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 720px) { .topics-grid { grid-template-columns: 1fr; } .topic-hero { padding: 20px; } body { font-size: 17px; } .homepage-hero { padding: 24px; margin-bottom: 40px; gap: 48px; } .weekly-feature { padding: 24px; } .homepage-hero__feature.weekly-feature { padding: 16px; box-shadow: 0 14px 32px rgba(28, 29, 26, 0.18); } .weekly-preview { padding: 20px; min-height: auto; } }
@media (max-width: 560px) { .site-header__brand { font-size: 20px; } .page-title { font-size: 24px; } .homepage-hero__title { font-size: 48px; line-height: 1.05; } .topic-title { font-size: 32px; line-height: 1.2; } .homepage-hero { padding: 20px; gap: 32px; } .homepage-hero__lead { font-size: 16px; } .homepage-hero__feature.weekly-feature { padding: 16px; box-shadow: 0 12px 28px rgba(28, 29, 26, 0.18); } .homepage-section-title { font-size: 40px; } .weekly-feature__title { font-size: 40px; } .weekly-preview__title { font-size: 32px; } }
