@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,wght@0,400;0,500;0,700;1,400&family=DM+Serif+Display&display=swap');

:root {
  --gray-900: #2b2f36;
  --gray-700: #4a5059;
  --gray-500: #7a828e;
  --gray-200: #e4e7eb;
  --gray-100: #f3f5f7;
  --teal: #0d7a72;
  --white: #fff;
  --sans: 'DM Sans', system-ui, sans-serif;
  --display: 'DM Serif Display', Georgia, serif;
  --g1: 4px; --g2: 8px; --g3: 12px; --g4: 16px; --g5: 24px;
  --pill: 20px;
  --max: 1120px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 15px; }
body { font-family: var(--sans); background: var(--gray-100); color: var(--gray-900); line-height: 1.55; }
a { color: var(--teal); text-decoration: none; }
a:hover { text-decoration: underline; }
img, svg { display: block; max-width: 100%; }

.box { max-width: var(--max); margin: 0 auto; padding: 0 var(--g5); }

/* Compact topbar */
.topbar {
  background: var(--gray-900);
  color: var(--white);
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--g2) var(--g5);
  font-size: 0.8rem;
}
.topbar .brand { font-family: var(--display); font-size: 1.1rem; color: var(--white); text-decoration: none; }
.topbar nav { display: flex; gap: var(--g5); }
.topbar nav a { color: #b0b8c4; text-decoration: none; font-weight: 500; }
.topbar nav a:hover, .topbar nav a.on { color: var(--white); }
.tb-menu { display: none; background: transparent; border: 1px solid #555; color: var(--white); padding: 4px 10px; cursor: pointer; font-size: 0.75rem; }

/* Mixed magazine 8-col */
.mag-grid {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: var(--g4);
  margin: var(--g5) 0;
}
.mag-lead { grid-column: span 5; }
.mag-side { grid-column: span 3; }
.mag-row { grid-column: span 8; display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--g4); }

.shadow-card {
  background: var(--white);
  border-radius: var(--pill);
  overflow: hidden;
  box-shadow: 0 2px 12px rgba(43,47,54,0.08);
  transition: box-shadow 0.2s;
}
.shadow-card:hover { box-shadow: 0 4px 20px rgba(43,47,54,0.12); }
.shadow-card img, .shadow-card svg { width: 100%; aspect-ratio: 3/2; object-fit: cover; }
.shadow-card .inner { padding: var(--g4); }
.shadow-card .tag { font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--teal); }
.shadow-card h2, .shadow-card h3 { font-family: var(--display); font-size: 1.25rem; margin: var(--g2) 0; line-height: 1.25; }
.shadow-card h3 { font-size: 1rem; }
.shadow-card h2 a, .shadow-card h3 a { color: var(--gray-900); text-decoration: none; }
.shadow-card .meta { font-size: 0.75rem; color: var(--gray-500); }

.lead-card { padding: var(--g5); }
.lead-card h1 { font-family: var(--display); font-size: 1.8rem; line-height: 1.2; margin: var(--g3) 0; }
.lead-card h1 a { color: var(--gray-900); text-decoration: none; }
.lead-card p { color: var(--gray-700); font-size: 0.95rem; }

.compact-list { list-style: none; }
.compact-list li { padding: var(--g3) 0; border-bottom: 1px solid var(--gray-200); font-size: 0.9rem; }
.compact-list li a { color: var(--gray-900); font-weight: 500; }

/* Wide magazine article */
.art-wide { display: grid; grid-template-columns: 1fr 240px; gap: var(--g5); margin: var(--g5) 0 var(--g5); }
.art-body { background: var(--white); padding: var(--g5); border-radius: var(--pill); box-shadow: 0 2px 12px rgba(43,47,54,0.06); }
.art-body h1 { font-family: var(--display); font-size: 2rem; line-height: 1.15; margin-bottom: var(--g4); }
.art-body .meta { font-size: 0.8rem; color: var(--gray-500); margin-bottom: var(--g5); }
.art-body p { margin-bottom: var(--g4); font-size: 1rem; }
.art-body h2 { font-family: var(--display); font-size: 1.2rem; margin: var(--g5) 0 var(--g3); }
.art-body figure img, .art-body figure svg { width: 100%; aspect-ratio: 3/2; border-radius: 12px; margin: var(--g4) 0; }

.side-rail { align-self: start; position: sticky; top: var(--g4); }
.side-rail .shadow-card { margin-bottom: var(--g4); }
.side-rail h4 { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--gray-500); margin-bottom: var(--g3); }

.static-pg { background: var(--white); padding: var(--g5); border-radius: var(--pill); max-width: 720px; margin: var(--g5) auto; box-shadow: 0 2px 12px rgba(43,47,54,0.06); }
.static-pg h1 { font-family: var(--display); font-size: 1.6rem; margin-bottom: var(--g4); }
.static-pg p { margin-bottom: var(--g4); }
.static-pg h2 { font-size: 1rem; margin: var(--g5) 0 var(--g3); color: var(--gray-700); }

/* Two column footer */
.foot2 { background: var(--white); border-top: 1px solid var(--gray-200); padding: var(--g5); margin-top: var(--g5); }
.foot2-cols { max-width: var(--max); margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: var(--g5); font-size: 0.85rem; }
.foot2 h4 { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--gray-500); margin-bottom: var(--g3); }
.foot2 ul { list-style: none; }
.foot2 li { margin-bottom: var(--g2); }
.foot2 a { color: var(--gray-700); }
.foot2-base { text-align: center; margin-top: var(--g5); font-size: 0.75rem; color: var(--gray-500); }

/* Cookie slide */
.cookie-slide {
  position: fixed; left: 0; right: 0; bottom: -100px;
  background: var(--white); border-top: 2px solid var(--teal);
  padding: var(--g4) var(--g5); display: flex; justify-content: center; align-items: center; gap: var(--g5);
  font-size: 0.8rem; z-index: 999; transition: bottom 0.3s;
  box-shadow: 0 -4px 20px rgba(0,0,0,0.08);
}
.cookie-slide.show { bottom: 0; }
.cookie-slide.hide { display: none; }
.cookie-slide button { background: var(--teal); color: var(--white); border: none; padding: 8px 20px; border-radius: var(--pill); cursor: pointer; font-family: var(--sans); font-weight: 600; }

@media (max-width: 900px) {
  .mag-grid, .mag-lead, .mag-side, .mag-row { grid-column: span 8; display: block; }
  .mag-row { display: flex; flex-direction: column; gap: var(--g4); }
  .art-wide { grid-template-columns: 1fr; }
  .foot2-cols { grid-template-columns: 1fr; }
  .topbar nav { display: none; flex-direction: column; position: absolute; top: 100%; left: 0; right: 0; background: var(--gray-900); padding: var(--g4); }
  .topbar nav.open { display: flex; }
  .topbar { position: relative; flex-wrap: wrap; }
  .tb-menu { display: block; }
}
