/* Shared styles for the Parallel "contemporaries" SEO pages (EN + DE). */
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }

:root {
  --c-bg:#ffffff; --c-bg-alt:#f6f6f4; --c-text:#0a0a0a; --c-text-soft:#4a4a4a; --c-text-muted:#757575;
  --c-line:#e6e6e6; --c-shadow:rgba(0,0,0,0.08); --c-shadow-strong:rgba(0,0,0,0.18);
  --c-button:#000000; --c-button-text:#ffffff; --c-card-bg:#ffffff;
  --c-artists:#E74C3C; --c-music:#2E9FD8; --c-literature:#5B4FC8; --c-sciences:#16A085; --c-philosophy:#D9A21A; --c-politics:#9E2B4E;
}
@media (prefers-color-scheme: dark) {
  :root {
    --c-bg:#0d0d0e; --c-bg-alt:#16161a; --c-text:#f0f0f0; --c-text-soft:#b8b8b8; --c-text-muted:#707075;
    --c-line:#2a2a2e; --c-shadow:rgba(0,0,0,0.5); --c-shadow-strong:rgba(0,0,0,0.8);
    --c-button:#f0f0f0; --c-button-text:#0d0d0e; --c-card-bg:#1c1c20;
    --c-artists:#FF7062; --c-music:#5FB8E8; --c-literature:#877BE6; --c-sciences:#1FCC9F; --c-philosophy:#EDBA3E; --c-politics:#C9476D;
  }
}

html, body { overflow-x: hidden; width: 100%; max-width: 100vw; position: relative; }
body {
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 400; color: var(--c-text); background: var(--c-bg); line-height: 1.55;
  -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-rendering: optimizeLegibility;
  transition: background 0.3s ease, color 0.3s ease;
}
a { color: var(--c-text); text-decoration: underline; text-underline-offset: 3px; }
a:hover { opacity: 0.65; }
:focus-visible { outline: 2px solid var(--c-sciences); outline-offset: 2px; }

section { padding: 72px 0; width: 100%; background: var(--c-bg); transition: background 0.3s ease; }
@media (max-width: 600px) { section { padding: 40px 0; } }
section.alt-bg { background: var(--c-bg-alt); }
section .inner { max-width: 1100px; margin: 0 auto; padding: 0 28px; }
section h2 { font-size: clamp(28px, 4.4vw, 42px); font-weight: 700; letter-spacing: -0.025em; line-height: 1.1; margin-bottom: 22px; max-width: 760px; color: var(--c-text); }
section .kicker { display: inline-block; font-size: 12px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--c-text-muted); margin-bottom: 14px; }
section p { font-size: clamp(16px, 1.6vw, 18px); font-weight: 400; max-width: 660px; margin-bottom: 18px; color: var(--c-text-soft); }
section p.lead { font-size: clamp(18px, 2.1vw, 21px); color: var(--c-text); max-width: 720px; }

.site-header { position: fixed; top: 0; left: 0; right: 0; z-index: 100; background: transparent; border-bottom: 1px solid transparent; transition: background 0.3s, border-color 0.3s; }
.site-header.scrolled { background: color-mix(in srgb, var(--c-bg) 88%, transparent); backdrop-filter: saturate(180%) blur(10px); -webkit-backdrop-filter: saturate(180%) blur(10px); border-bottom-color: var(--c-line); }
.site-header-inner { max-width: 1100px; margin: 0 auto; padding: 14px 28px; display: flex; align-items: center; }
.site-header .brand { display: flex; align-items: center; gap: 10px; text-decoration: none; color: var(--c-text); }
.site-header .brand:hover { opacity: 1; }
.site-header .brand-icon { width: 32px; height: 32px; border-radius: 22%; box-shadow: 0 2px 8px var(--c-shadow); }
.site-header .brand-name { font-size: 18px; font-weight: 700; letter-spacing: -0.01em; }
.site-nav { display: flex; gap: 28px; margin-left: auto; margin-right: 28px; }
.site-nav a { font-size: 13px; font-weight: 500; letter-spacing: 0.02em; color: var(--c-text-soft); text-decoration: none; transition: color 0.2s; }
.site-nav a:hover { color: var(--c-text); opacity: 1; }
@media (max-width: 600px) { .site-nav { display: none; } }
.lang-toggle { display: flex; gap: 0; font-size: 12px; letter-spacing: 0.1em; margin-left: auto; }
.lang-toggle a { text-decoration: none; color: var(--c-text-soft); transition: color 0.2s; }
.lang-toggle .active { font-weight: 600; color: var(--c-text); }
.lang-toggle .sep { opacity: 0.3; padding: 0 6px; }

footer { padding: 14px 28px; padding-bottom: max(14px, env(safe-area-inset-bottom)); display: flex; justify-content: center; gap: 24px; font-weight: 300; font-size: 11px; letter-spacing: 0.1em; color: var(--c-text-muted); border-top: 1px solid var(--c-line); }
footer a { color: var(--c-text); text-decoration: none; }
footer a:hover { text-decoration: underline; }
footer .sep { color: var(--c-text-muted); pointer-events: none; }
@media (max-width: 480px) { footer { gap: 16px; font-size: 10px; padding: 10px 16px; flex-wrap: wrap; } }

.reveal { opacity: 0; transform: translateY(50px) scale(0.985); transition: opacity 0.9s cubic-bezier(0.16,0.84,0.30,1), transform 0.9s cubic-bezier(0.16,0.84,0.30,1); }
@media (max-width: 600px) { .reveal { transform: translateY(28px); } }
.reveal.in-view { opacity: 1; transform: translateY(0) scale(1); }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } }

/* ---- Contemporaries page ---- */
.first { padding-top: 110px; padding-bottom: 56px; }
@media (max-width: 600px) { .first { padding-top: 88px; padding-bottom: 36px; } }
.first h1 { font-size: clamp(32px, 5.4vw, 56px); font-weight: 700; letter-spacing: -0.03em; line-height: 1.05; margin-bottom: 18px; max-width: 820px; color: var(--c-text); }

.cont-card { --cont-lw: 150px; border: 1px solid var(--c-line); border-radius: 14px; background: var(--c-card-bg); padding: 30px 30px 26px; margin-top: 30px; box-shadow: 0 18px 50px var(--c-shadow); }
@media (max-width: 600px) { .cont-card { --cont-lw: 112px; padding: 20px 14px; margin-top: 22px; } }
.cont-chart { position: relative; }
.cont-row { display: grid; grid-template-columns: var(--cont-lw) 1fr; gap: 16px; align-items: center; height: 32px; position: relative; z-index: 1; }
@media (max-width: 600px) { .cont-row { gap: 10px; height: 30px; } }
.cont-name { font-size: 14px; text-align: right; color: var(--c-text-soft); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cont-name.hi-name { color: var(--c-text); font-weight: 600; }
@media (max-width: 600px) { .cont-name { font-size: 12px; } }
.cont-track { position: relative; height: 100%; }
.cont-bar {
  position: absolute; top: 50%; transform: translateY(-50%); height: 18px; border-radius: 5px; min-width: 8px;
  display: flex; align-items: center; justify-content: center; padding: 0 5px; overflow: hidden;
  font-size: 11px; font-weight: 600; font-variant-numeric: tabular-nums; white-space: nowrap;
  color: #ffffff; text-shadow: 0 1px 1.5px rgba(0,0,0,0.3);
}
.cont-bar.hi { outline: 2px solid var(--c-text); outline-offset: 1px; }
@media (prefers-color-scheme: dark) { .cont-bar { color: rgba(0,0,0,0.8); text-shadow: none; } }
@media (max-width: 600px) { .cont-bar { font-size: 8px; padding: 0 1px; letter-spacing: -0.3px; } }

.cont-ov { position: absolute; top: 0; bottom: 32px; left: calc(var(--cont-lw) + 16px); right: 0; pointer-events: none; z-index: 0; }
@media (max-width: 600px) { .cont-ov { left: calc(var(--cont-lw) + 10px); } }
.cont-band { position: absolute; top: 0; bottom: 0; border-radius: 7px; }

.cont-axis { position: relative; margin-left: calc(var(--cont-lw) + 16px); height: 18px; margin-top: 10px; }
@media (max-width: 600px) { .cont-axis { margin-left: calc(var(--cont-lw) + 10px); } }
.cont-tick { position: absolute; font-size: 12px; color: var(--c-text-muted); transform: translateX(-50%); font-variant-numeric: tabular-nums; }

.cont-legend { display: flex; flex-wrap: wrap; gap: 12px 16px; margin-top: 22px; font-size: 13px; color: var(--c-text-soft); }
.cont-dot { width: 11px; height: 11px; border-radius: 3px; display: inline-block; vertical-align: -1px; margin-right: 6px; }
.cont-note { font-size: 13px; color: var(--c-text-muted); margin-top: 16px; line-height: 1.55; }

.facts { display: grid; grid-template-columns: 1fr; gap: 16px; margin-top: 8px; }
@media (min-width: 700px) { .facts { grid-template-columns: 1fr 1fr; } }
.fact { border: 1px solid var(--c-line); border-radius: 12px; background: var(--c-card-bg); padding: 22px 24px; }
.fact h3 { font-size: 16px; font-weight: 600; color: var(--c-text); margin-bottom: 6px; }
.fact p { font-size: 15px; color: var(--c-text-soft); margin: 0; max-width: none; }

.cta-row { display: flex; align-items: center; gap: 22px; flex-wrap: wrap; margin-top: 24px; }
.appstore-badge { display: inline-flex; align-items: center; gap: 11px; background: var(--c-button); color: var(--c-button-text); border-radius: 10px; padding: 11px 18px; text-decoration: none; }
.appstore-badge:hover { opacity: 0.88; }
.appstore-badge svg { width: 22px; height: 22px; fill: var(--c-button-text); flex-shrink: 0; }
.appstore-badge .ab-small { font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; opacity: 0.85; display: block; line-height: 1.15; }
.appstore-badge .ab-big { font-size: 17px; font-weight: 600; line-height: 1.15; }
.cta-hint { font-size: 13px; color: var(--c-text-muted); }

/* ---- "See who lived at the same time" link grid (homepage + cross-links) ---- */
.cont-links { display: grid; grid-template-columns: 1fr; gap: 12px; margin-top: 8px; }
@media (min-width: 600px) { .cont-links { grid-template-columns: 1fr 1fr; } }
.cont-link { display: flex; align-items: center; justify-content: space-between; gap: 12px; border: 1px solid var(--c-line); border-radius: 12px; background: var(--c-card-bg); padding: 16px 20px; text-decoration: none; color: var(--c-text); font-weight: 600; transition: border-color 0.2s, transform 0.2s; }
.cont-link:hover { opacity: 1; border-color: var(--c-text-muted); transform: translateY(-2px); }
.cont-link .arrow { color: var(--c-text-muted); }
