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

:root {
  --black: #111111;
  --gray: #666666;
  --light: #f7f7f7;
  --white: #ffffff;
  --line: #e0e0e0;
  --container: 720px;
  --space-1: 12px;
  --space-2: 24px;
  --space-3: 36px;
  --space-4: 48px;
  --space-5: 72px;
  --radius: 0px;
  --font: 'DM Sans', system-ui, sans-serif;
}

[data-theme="dark"] {
  --black: #f0f0f0;
  --gray: #999999;
  --light: #1a1a1a;
  --white: #111111;
  --line: #333333;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: var(--font);
  font-size: 18px;
  line-height: 1.7;
  color: var(--black);
  background: var(--white);
  transition: background 0.2s, color 0.2s;
}

a { color: var(--black); text-decoration: underline; text-underline-offset: 3px; }
a:hover { opacity: 0.7; }

.wrap { max-width: var(--container); margin: 0 auto; padding: 0 var(--space-2); }

/* Minimal header */
.hdr {
  padding: var(--space-3) 0 var(--space-2);
  border-bottom: 1px solid var(--line);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}

.hdr-brand { font-weight: 700; font-size: 1rem; letter-spacing: -0.02em; text-decoration: none; color: var(--black); }
.hdr-brand span { font-weight: 400; color: var(--gray); }

.hdr-actions { display: flex; gap: var(--space-2); align-items: center; }

.nav-min { display: flex; gap: var(--space-2); list-style: none; }
.nav-min a { text-decoration: none; font-size: 0.9rem; color: var(--gray); }
.nav-min a:hover, .nav-min a.on { color: var(--black); opacity: 1; }

.theme-btn, .menu-btn {
  background: none;
  border: 1px solid var(--line);
  padding: 4px 10px;
  font-family: var(--font);
  font-size: 0.8rem;
  cursor: pointer;
  color: var(--black);
}

.menu-btn { display: none; }

/* Article stream */
.stream { padding: var(--space-4) 0; }

.stream-intro { margin-bottom: var(--space-4); }
.stream-intro h1 { font-size: 1.75rem; font-weight: 700; letter-spacing: -0.03em; margin-bottom: var(--space-1); }
.stream-intro p { color: var(--gray); font-size: 1rem; }

.stream-item {
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--line);
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: var(--space-2);
  align-items: start;
}

.stream-thumb { width: 80px; height: 80px; object-fit: cover; background: var(--light); }

.stream-item h2 { font-size: 1.15rem; font-weight: 600; margin-bottom: 6px; line-height: 1.35; }
.stream-item h2 a { text-decoration: none; }
.stream-meta { font-size: 0.8rem; color: var(--gray); }
.stream-excerpt { font-size: 0.95rem; color: var(--gray); margin-top: 6px; display: none; }
.stream-item:first-of-type .stream-excerpt { display: block; }
.stream-item:first-of-type { grid-template-columns: 1fr; }
.stream-item:first-of-type .stream-thumb { width: 100%; height: auto; aspect-ratio: 1; max-height: 360px; }

.label { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--gray); }

/* Flat cards list */
.flat-list { display: flex; flex-direction: column; gap: var(--space-2); }

/* Article minimalist reading */
.article-page { padding: var(--space-4) 0 var(--space-5); max-width: 620px; margin: 0 auto; }
.article-page h1 { font-size: 2rem; font-weight: 700; letter-spacing: -0.03em; line-height: 1.2; margin-bottom: var(--space-2); }
.article-page .meta { font-size: 0.85rem; color: var(--gray); margin-bottom: var(--space-3); }
.article-page p { margin-bottom: var(--space-2); }
.article-page h2 { font-size: 1.2rem; font-weight: 600; margin: var(--space-3) 0 var(--space-1); }
.article-page img.hero-img { width: 100%; aspect-ratio: 1; object-fit: cover; margin-bottom: var(--space-3); background: var(--light); }

.byline-min { font-size: 0.85rem; color: var(--gray); }

.related-inline { margin-top: var(--space-4); padding-top: var(--space-2); border-top: 1px solid var(--line); font-size: 0.9rem; }
.related-inline a { margin-right: var(--space-2); }

/* Page */
.page { padding: var(--space-4) 0 var(--space-5); max-width: 620px; margin: 0 auto; }
.page h1 { font-size: 1.75rem; margin-bottom: var(--space-2); }
.page h2 { font-size: 1.1rem; margin: var(--space-3) 0 var(--space-1); }
.page p { margin-bottom: var(--space-2); color: var(--gray); }
.page p strong { color: var(--black); }

.contact-form input, .contact-form textarea {
  width: 100%;
  padding: 10px;
  border: 1px solid var(--line);
  font-family: var(--font);
  margin-bottom: var(--space-1);
  background: var(--white);
  color: var(--black);
}
.contact-form label { font-size: 0.85rem; display: block; margin-bottom: 4px; }
.contact-form button {
  background: var(--black);
  color: var(--white);
  border: none;
  padding: 10px 24px;
  font-family: var(--font);
  cursor: pointer;
  margin-top: var(--space-1);
}

/* Minimal single footer */
.ftr {
  padding: var(--space-3) 0;
  border-top: 1px solid var(--line);
  text-align: center;
  font-size: 0.8rem;
  color: var(--gray);
}
.ftr a { color: var(--gray); text-decoration: none; margin: 0 8px; }
.ftr a:hover { color: var(--black); }

/* Corner cookie */
.cookie-popup {
  position: fixed;
  bottom: var(--space-2);
  right: var(--space-2);
  max-width: 300px;
  background: var(--black);
  color: var(--white);
  padding: var(--space-2);
  font-size: 0.8rem;
  line-height: 1.5;
  z-index: 999;
  display: none;
}
.cookie-popup.show { display: block; }
.cookie-popup a { color: var(--white); }
.cookie-popup button {
  margin-top: var(--space-1);
  background: var(--white);
  color: var(--black);
  border: none;
  padding: 6px 16px;
  font-family: var(--font);
  cursor: pointer;
  font-size: 0.8rem;
}

@media (max-width: 600px) {
  .menu-btn { display: block; }
  .nav-min { display: none; position: absolute; top: 100%; right: 0; background: var(--white); border: 1px solid var(--line); flex-direction: column; padding: var(--space-1); }
  .nav-min.open { display: flex; }
  .hdr { position: relative; flex-wrap: wrap; }
  .stream-item { grid-template-columns: 1fr; }
  .stream-thumb { width: 100%; height: auto; aspect-ratio: 1; }
}
