/* Zodified — Mobile-first stylesheet
   Breakpoints: 320 (mobile) → 480 → 640 (tablet) → 1024 (desktop)
*/

:root {
  --color-bg: #faf9f6;
  --color-surface: #ffffff;
  --color-fg: #1a1a1a;
  --color-fg-soft: #4a4a4a;
  --color-muted: #777;
  --color-accent: #6b3fa0;
  --color-accent-soft: #f0ebf8;
  --color-accent-dark: #4a2873;
  --color-border: #e5e1d8;
  --color-border-soft: #f0ede5;
  --color-gold: #b89a3e;
  --color-night: #1e1b3a;
  --color-night-soft: #2a274a;

  --radius-sm: 6px;
  --radius-md: 12px;
  --radius-lg: 20px;

  --shadow-sm: 0 1px 2px rgba(20,15,40,0.04), 0 2px 6px rgba(20,15,40,0.04);
  --shadow-md: 0 4px 12px rgba(20,15,40,0.08), 0 2px 4px rgba(20,15,40,0.04);

  --max-w-content: 720px;
  --max-w-wide: 1100px;

  --font-body: -apple-system, BlinkMacSystemFont, 'SF Pro Text', 'Segoe UI', Roboto, sans-serif;
  --font-display: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;

  --tap: 44px;
}

* { box-sizing: border-box; }
html { font-size: 16px; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-body);
  color: var(--color-fg);
  background: var(--color-bg);
  margin: 0;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }

h1, h2, h3, h4 { font-family: var(--font-display); line-height: 1.18; font-weight: 600; margin: 0 0 0.5em; }
h1 { font-size: clamp(1.75rem, 5vw, 2.5rem); }
h2 { font-size: clamp(1.35rem, 4vw, 1.75rem); }
h3 { font-size: clamp(1.1rem, 3vw, 1.25rem); }

a { color: var(--color-accent); text-decoration: none; }
a:hover { text-decoration: underline; }
a:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 2px; border-radius: 2px; }

.skip-link { position: absolute; top: -100px; left: 0; background: var(--color-fg); color: white; padding: 8px 16px; z-index: 100; }
.skip-link:focus { top: 0; }

/* ===== Header ===== */
.site-header {
  position: sticky;
  top: 0;
  background: rgba(255, 255, 255, 0.95);
  border-bottom: 1px solid var(--color-border);
  z-index: 50;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.site-nav {
  max-width: var(--max-w-wide);
  margin: 0 auto;
  padding: 0.75rem 1rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.brand {
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--color-fg);
  letter-spacing: -0.01em;
  white-space: nowrap;
}
.brand::before { content: "✦ "; color: var(--color-accent); }

.signs-nav { display: none; }
@media (min-width: 1024px) {
  .signs-nav {
    display: flex;
    flex: 1;
    list-style: none;
    margin: 0;
    padding: 0;
    gap: 0.25rem;
    justify-content: center;
    flex-wrap: wrap;
  }
  .signs-nav a {
    color: var(--color-fg-soft);
    font-size: 0.85rem;
    padding: 0.25rem 0.5rem;
    border-radius: var(--radius-sm);
    text-decoration: none;
  }
  .signs-nav a:hover { background: var(--color-accent-soft); color: var(--color-accent); }
}

.nav-spacer { flex: 1; }
@media (min-width: 1024px) { .nav-spacer { display: none; } }

.lang-switcher {
  list-style: none;
  margin: 0;
  padding: 2px;
  display: flex;
  gap: 0.125rem;
  background: var(--color-bg);
  border-radius: var(--radius-sm);
}
.lang-switcher a {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 28px;
  padding: 0 0.5rem;
  color: var(--color-fg-soft);
  font-size: 0.75rem;
  font-weight: 600;
  text-decoration: none;
  border-radius: var(--radius-sm);
}
.lang-switcher .current a { background: var(--color-surface); color: var(--color-accent); box-shadow: var(--shadow-sm); }
.lang-switcher a:hover { background: var(--color-surface); }

/* ===== Breadcrumb ===== */
.breadcrumb { max-width: var(--max-w-content); margin: 1rem auto 0; padding: 0 1rem; }
.breadcrumb ol { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: 0.5rem; font-size: 0.8rem; color: var(--color-muted); }
.breadcrumb li:not(:first-child)::before { content: "›"; margin-right: 0.5rem; color: var(--color-border); }
.breadcrumb a { color: var(--color-fg-soft); }

/* ===== Content ===== */
.content { max-width: var(--max-w-content); margin: 0 auto 3rem; padding: 0 1rem; }
.content-wide { max-width: var(--max-w-wide); }

/* ===== Hero ===== */
.hero { text-align: center; padding: 1.5rem 0 0.5rem; }
.hero-eyebrow {
  display: inline-block;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-accent);
  font-weight: 600;
  margin-bottom: 0.5rem;
}
.hero h1 { margin-bottom: 0.5rem; }
.lede {
  font-size: 1.05rem;
  color: var(--color-fg-soft);
  max-width: 540px;
  margin: 0 auto 1rem;
  line-height: 1.55;
}

/* ===== Period strip (horizontally scrollable on mobile) ===== */
.period-strip {
  display: flex;
  gap: 0.5rem;
  overflow-x: auto;
  scrollbar-width: none;
  padding: 0.5rem 1rem;
  margin: 0 -1rem 1.25rem;
  scroll-snap-type: x mandatory;
}
.period-strip::-webkit-scrollbar { display: none; }
.period-strip a {
  flex-shrink: 0;
  padding: 0.5rem 1rem;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-fg);
  font-size: 0.875rem;
  font-weight: 500;
  text-decoration: none;
  scroll-snap-align: start;
  white-space: nowrap;
  min-height: var(--tap);
  display: inline-flex;
  align-items: center;
}
.period-strip a.current { background: var(--color-fg); color: var(--color-surface); border-color: var(--color-fg); }
.period-strip a:hover:not(.current) { border-color: var(--color-accent); color: var(--color-accent); }

/* ===== Sign grid (the hero conversion surface) ===== */
.sign-grid { margin: 1rem 0 2rem; }
.sign-grid > h2 {
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-muted);
  text-align: center;
  margin-bottom: 1rem;
  font-family: var(--font-body);
  font-weight: 600;
}
.sign-grid ul {
  list-style: none; margin: 0; padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem;
}
@media (min-width: 480px) { .sign-grid ul { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 768px) { .sign-grid ul { grid-template-columns: repeat(6, 1fr); gap: 1rem; } }

.sign-tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
  padding: 1rem 0.5rem;
  min-height: 110px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-fg);
  text-decoration: none;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}
.sign-tile:hover {
  text-decoration: none;
  border-color: var(--color-accent);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}
.sign-tile .symbol { font-size: 2rem; line-height: 1; color: var(--color-accent); margin-bottom: 0.25rem; }
.sign-tile .name { font-size: 0.95rem; font-weight: 600; }
.sign-tile .dates { font-size: 0.7rem; color: var(--color-muted); }

/* ===== Today in the Sky panel ===== */
.sky-panel {
  background: linear-gradient(135deg, var(--color-night) 0%, var(--color-night-soft) 100%);
  color: #f0ecf5;
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  margin: 1.5rem 0;
  position: relative;
  overflow: hidden;
}
.sky-panel::before {
  content: "";
  position: absolute;
  top: -20px; right: -20px;
  width: 160px; height: 160px;
  background: radial-gradient(circle, rgba(184,154,62,0.15) 0%, transparent 70%);
  pointer-events: none;
}
.sky-panel h2 {
  font-size: 1.1rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-family: var(--font-body);
  font-weight: 600;
  color: var(--color-gold);
  margin-bottom: 1rem;
}
.sky-header { margin-bottom: 1rem; }
.sky-subtitle {
  display: block;
  font-size: 0.8rem;
  color: rgba(240,236,245,0.65);
  margin-top: 0.25rem;
}
.sky-table {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  margin-bottom: 1rem;
}
@media (min-width: 640px) {
  .sky-table { grid-template-columns: repeat(2, 1fr); column-gap: 1.5rem; }
}
@media (min-width: 1024px) {
  .sky-table { grid-template-columns: repeat(2, 1fr); }
}
.sky-row {
  display: grid;
  grid-template-columns: 22px 80px 36px 22px 1fr 14px;
  align-items: center;
  gap: 0.5rem;
  padding: 0.4rem 0;
  border-bottom: 1px solid rgba(240,236,245,0.08);
  font-size: 0.875rem;
  font-variant-numeric: tabular-nums;
}
.sky-row:last-child { border-bottom: none; }
.sky-glyph { color: var(--color-gold); font-size: 1.05rem; text-align: center; line-height: 1; }
.sky-planet { color: rgba(240,236,245,0.92); font-weight: 500; }
.sky-degree { color: rgba(240,236,245,0.7); text-align: right; }
.sky-sign-glyph { color: var(--color-gold); font-size: 1rem; text-align: center; }
.sky-sign-name { color: rgba(240,236,245,0.85); }
.sky-retro { color: #ff9d6c; font-size: 0.95rem; font-weight: 600; text-align: center; }
.sky-retro-placeholder { width: 14px; }

.sky-note {
  font-size: 0.85rem; line-height: 1.55; color: rgba(240,236,245,0.75);
  margin: 1rem 0 0; padding-top: 0.75rem;
  border-top: 1px solid rgba(240,236,245,0.1);
}
.sky-note a { color: var(--color-gold); text-decoration: underline; }

/* ===== Featured forecast card ===== */
.featured-card {
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  margin: 1.5rem 0;
  border: 1px solid var(--color-border);
}
.featured-card .tag {
  display: inline-block;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-accent);
  font-weight: 600;
  margin-bottom: 0.5rem;
}
.featured-card h3 { margin-bottom: 0.5rem; }
.featured-card p { color: var(--color-fg-soft); margin: 0 0 1rem; }
.featured-card .cta {
  display: inline-block;
  padding: 0.625rem 1.25rem;
  background: var(--color-fg);
  color: white;
  border-radius: var(--radius-md);
  font-size: 0.9rem;
  font-weight: 500;
  text-decoration: none;
  min-height: var(--tap);
  line-height: calc(var(--tap) - 1.25rem);
}
.featured-card .cta:hover { background: var(--color-accent); text-decoration: none; }

/* ===== Famous birthdays ===== */
.birthdays-section { margin: 2rem 0; }
.birthdays-section h2 {
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-muted);
  font-family: var(--font-body);
  font-weight: 600;
  margin-bottom: 1rem;
  text-align: center;
}
.birthdays-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
  list-style: none;
  margin: 0;
  padding: 0;
}
@media (min-width: 640px) { .birthdays-list { grid-template-columns: repeat(4, 1fr); } }
.birthday-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 0.75rem;
  text-align: center;
}
.birthday-card .avatar {
  width: 48px; height: 48px;
  border-radius: 50%;
  display: block;
  margin: 0 auto 0.5rem;
  object-fit: cover;
}
.birthday-card .avatar-initial {
  background: var(--color-accent-soft);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem;
  color: var(--color-accent);
  font-family: var(--font-display);
  font-weight: 600;
}
.birthday-card .info-btn {
  display: inline-flex;
  align-items: center;
  margin-left: 0.25rem;
  color: var(--color-muted);
  cursor: pointer;
  opacity: 0.5;
  vertical-align: middle;
  transition: opacity 0.15s ease, color 0.15s ease;
}
.birthday-card .info-btn:hover { opacity: 1; color: var(--color-accent); }
.birthday-card .name { font-size: 0.85rem; font-weight: 600; line-height: 1.3; }
.birthday-card .meta { font-size: 0.7rem; color: var(--color-muted); margin-top: 0.25rem; }

/* ===== Tools row ===== */
.tools-row { margin: 2rem 0; }
.tools-row h2 {
  font-size: 1rem; text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--color-muted); font-family: var(--font-body); font-weight: 600;
  text-align: center; margin-bottom: 1rem;
}
.tools-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
  list-style: none;
  margin: 0; padding: 0;
}
@media (min-width: 640px) { .tools-grid { grid-template-columns: repeat(4, 1fr); } }
.tool-card {
  display: flex; flex-direction: column; align-items: center; gap: 0.5rem;
  padding: 1rem 0.5rem;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-fg);
  text-decoration: none;
  text-align: center;
  min-height: 100px;
}
.tool-card .icon { font-size: 1.75rem; }
.tool-card .label { font-size: 0.85rem; font-weight: 500; }
.tool-card:hover { border-color: var(--color-accent); text-decoration: none; }

/* ===== Newsletter ===== */
.newsletter {
  background: var(--color-accent-soft);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  margin: 2rem 0;
  text-align: center;
}
.newsletter h3 { color: var(--color-accent-dark); margin-bottom: 0.5rem; }
.newsletter p { font-size: 0.95rem; color: var(--color-fg-soft); margin: 0 0 1rem; }
.newsletter form { display: flex; flex-direction: column; gap: 0.5rem; max-width: 400px; margin: 0 auto; }
@media (min-width: 480px) { .newsletter form { flex-direction: row; } }
.newsletter input[type="email"] {
  flex: 1;
  padding: 0.75rem 1rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: 0.95rem;
  background: var(--color-surface);
  min-height: var(--tap);
}
.newsletter button {
  padding: 0.75rem 1.5rem;
  background: var(--color-fg);
  color: white;
  border: none;
  border-radius: var(--radius-md);
  font-size: 0.95rem;
  font-weight: 500;
  cursor: pointer;
  min-height: var(--tap);
}
.newsletter button:hover { background: var(--color-accent); }

/* ===== Sign hub / forecast pages ===== */
.sign-glyph {
  font-size: 4.5rem;
  color: var(--color-accent);
  text-align: center;
  line-height: 1;
  margin: 0.5rem 0 1rem;
}
.key-facts {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 1rem;
  margin: 1rem 0;
}
.key-facts dl {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
  margin: 0;
}
.key-facts dt { font-size: 0.75rem; color: var(--color-muted); text-transform: uppercase; letter-spacing: 0.05em; }
.key-facts dd { margin: 0.125rem 0 0; font-weight: 500; }

.forecast header { text-align: center; margin-bottom: 1rem; }
.forecast .date {
  display: inline-block;
  font-size: 0.85rem;
  color: var(--color-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.forecast .body { margin: 1.5rem 0; font-size: 1.05rem; line-height: 1.7; }
.forecast .body p { margin: 0 0 1.25rem; color: var(--color-fg); }
.forecast .body h2 {
  font-size: 1.35rem;
  margin: 2rem 0 0.75rem;
  color: var(--color-fg);
  font-family: var(--font-display);
  font-weight: 600;
}
.forecast .body h3 {
  font-size: 1.15rem;
  margin: 1.5rem 0 0.5rem;
  color: var(--color-fg);
  font-family: var(--font-display);
}
.forecast .body ul, .forecast .body ol { margin: 0 0 1.25rem; padding-left: 1.5rem; }
.forecast .body li { margin: 0 0 0.5rem; }
.forecast .body strong { color: var(--color-fg); font-weight: 600; }
.forecast .body em { color: var(--color-fg-soft); }
.forecast .body blockquote {
  border-left: 3px solid var(--color-accent);
  padding-left: 1rem;
  margin: 1.25rem 0;
  color: var(--color-fg-soft);
  font-style: italic;
}

.engagement {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  padding: 0.875rem 1rem;
  margin: 1.5rem 0;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  color: var(--color-fg-soft);
}
.engagement-views {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  color: var(--color-fg-soft);
}
.engagement-divider { color: var(--color-border); margin: 0 0.25rem; }
.engagement-prompt { margin-right: 0.25rem; }
.vote-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.4rem 0.75rem;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  cursor: pointer;
  color: var(--color-fg-soft);
  font-size: 0.85rem;
  min-height: 36px;
  transition: border-color 0.15s ease, color 0.15s ease, background 0.15s ease;
}
.vote-btn:hover { border-color: var(--color-accent); color: var(--color-accent); }
.vote-btn:active { transform: scale(0.97); }
.vote-btn.voted-active { background: var(--color-accent-soft); border-color: var(--color-accent); color: var(--color-accent); }
.vote-btn.voted-disabled { opacity: 0.45; cursor: not-allowed; }
.vote-count { font-variant-numeric: tabular-nums; font-weight: 500; }
.engagement-pct { margin-left: auto; font-size: 0.8rem; color: var(--color-muted); }

.lucky {
  background: linear-gradient(135deg, #fdf6e3 0%, #faf0d4 100%);
  border-radius: var(--radius-lg);
  padding: 1.25rem;
  margin: 1.5rem 0;
  border: 1px solid #f0e5c4;
}
.lucky h3 {
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin: 0 0 0.75rem;
  font-family: var(--font-body);
  color: #8a6e25;
}
.lucky ul {
  list-style: none;
  margin: 0; padding: 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.5rem;
}
@media (min-width: 480px) { .lucky ul { grid-template-columns: repeat(4, 1fr); } }
.lucky li { font-size: 0.85rem; }
.lucky strong { display: block; font-size: 0.7rem; color: #8a6e25; text-transform: uppercase; letter-spacing: 0.05em; font-weight: 600; margin-bottom: 0.125rem; }

.topic-nav, .period-nav { margin: 1.5rem 0; padding: 1rem 0; border-top: 1px solid var(--color-border); }
.topic-nav h2, .period-nav h2 {
  font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--color-muted); font-family: var(--font-body); font-weight: 600; margin-bottom: 0.75rem;
}
.topic-nav ul, .period-nav ul {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-wrap: wrap; gap: 0.5rem;
}
.topic-nav a, .period-nav a {
  display: inline-block;
  padding: 0.5rem 0.875rem;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-fg);
  font-size: 0.85rem;
  text-decoration: none;
}
.topic-nav a:hover, .period-nav a:hover { border-color: var(--color-accent); color: var(--color-accent); }

/* ===== Compatibility page ===== */
.pair-glyphs {
  font-size: 3rem; text-align: center;
  display: flex; align-items: center; justify-content: center; gap: 0.5rem;
  color: var(--color-accent);
  margin: 0.5rem 0 1rem;
}
.pair-glyphs .amp { font-size: 1.25rem; color: var(--color-muted); }
.scores { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.75rem; margin: 1rem 0; }
.scores > div { text-align: center; padding: 1rem 0.5rem; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); }
.scores label { display: block; font-size: 0.75rem; color: var(--color-muted); text-transform: uppercase; letter-spacing: 0.05em; }
.scores strong { font-size: 1.5rem; font-family: var(--font-display); color: var(--color-accent); display: block; margin-top: 0.25rem; }

/* ===== Calendar widget ===== */
.calendar-widget {
  margin: 2rem 0;
}
.calendar-widget > h2 {
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-muted);
  font-family: var(--font-body);
  font-weight: 600;
  text-align: center;
  margin-bottom: 0.5rem;
}
.calendar-note {
  font-size: 0.85rem;
  color: var(--color-muted);
  text-align: center;
  margin: 0 0 1rem;
}
.cal-month {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 1rem;
  margin-bottom: 0.75rem;
}
.cal-month-title {
  font-size: 1rem;
  font-family: var(--font-display);
  text-align: center;
  margin: 0 0 0.5rem;
  color: var(--color-fg);
}
.cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
}
.cal-day-name {
  font-size: 0.7rem;
  text-align: center;
  padding: 0.25rem 0;
  color: var(--color-muted);
  font-weight: 600;
}
.cal-cell {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 0.25rem;
  font-size: 0.85rem;
  border-radius: var(--radius-sm);
  text-decoration: none;
}
.cal-blank { visibility: hidden; }
.cal-day { color: var(--color-accent); }
.cal-day:hover { background: var(--color-accent-soft); text-decoration: none; }
.cal-today {
  background: var(--color-accent);
  color: white !important;
  font-weight: 700;
}
.cal-today:hover { background: var(--color-accent-dark); text-decoration: none; }
.cal-unavailable { color: var(--color-border); cursor: not-allowed; }
.calendar-more { text-align: center; margin-top: 0.75rem; }
.calendar-more a { font-size: 0.85rem; color: var(--color-accent); }

/* ===== Sign hub layout ===== */
.sign-hub-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}
@media (min-width: 1024px) {
  .sign-hub-grid {
    grid-template-columns: 2fr 1fr;
    gap: 2rem;
  }
}
.sign-hub-main { min-width: 0; }
.sign-hub-side { min-width: 0; }

.sign-hub-nav {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.5rem;
  margin: 1.5rem 0;
}
@media (min-width: 480px) { .sign-hub-nav { grid-template-columns: repeat(4, 1fr); } }
.sign-hub-nav a {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 0.25rem;
  padding: 0.875rem 0.5rem;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-fg);
  font-size: 0.85rem;
  font-weight: 500;
  text-decoration: none;
  text-align: center;
  min-height: var(--tap);
}
.sign-hub-nav a:hover { border-color: var(--color-accent); color: var(--color-accent); text-decoration: none; }
.sign-hub-nav .icon { font-size: 1.25rem; line-height: 1; }

.sign-description { margin: 1rem 0 1.5rem; line-height: 1.7; }
.sign-description p { margin: 0 0 1rem; }

.famous-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem;
  list-style: none;
  margin: 0;
  padding: 0;
}
.famous-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 0.75rem;
  text-align: center;
}
.famous-card .avatar {
  width: 64px; height: 64px;
  border-radius: 50%;
  display: block;
  margin: 0 auto 0.5rem;
  object-fit: cover;
}
.famous-card .avatar-initial {
  background: var(--color-accent-soft);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem;
  color: var(--color-accent);
  font-weight: 600;
  font-family: var(--font-display);
}
.famous-card .avatar-photo {
  /* no border — clean circular photo */
}
.famous-card .name { font-size: 0.85rem; font-weight: 600; line-height: 1.25; }
.famous-card .meta { font-size: 0.7rem; color: var(--color-muted); margin-top: 0.2rem; }
.famous-card .info-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 0.25rem;
  color: var(--color-muted);
  cursor: pointer;
  vertical-align: middle;
  line-height: 1;
  opacity: 0.5;
  transition: opacity 0.15s ease, color 0.15s ease;
}
.famous-card .info-btn:hover { color: var(--color-accent); opacity: 1; }
.famous-card .info-btn:focus { outline: none; color: var(--color-accent); opacity: 1; }
.famous-card .info-btn:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 2px; border-radius: 50%; }
.famous-card .info-btn svg { display: block; }

.photo-popover {
  position: absolute;
  background: var(--color-fg);
  color: white;
  padding: 0.5rem 0.75rem;
  border-radius: var(--radius-sm);
  font-size: 0.75rem;
  max-width: 240px;
  z-index: 100;
  box-shadow: var(--shadow-md);
  pointer-events: none;
}
.photo-popover::after {
  content: '';
  position: absolute;
  top: -5px;
  left: 50%;
  transform: translateX(-50%);
  border: 5px solid transparent;
  border-bottom-color: var(--color-fg);
  border-top: none;
}
.photo-popover .license { display: block; margin-top: 0.25rem; opacity: 0.7; }

/* ===== Portal page (/today/, /week/, etc.) ===== */
.portal-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
  list-style: none;
  margin: 1.5rem 0;
  padding: 0;
}
@media (min-width: 640px) { .portal-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .portal-grid { grid-template-columns: repeat(3, 1fr); } }
.portal-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.portal-card-head {
  display: flex; align-items: center; gap: 0.5rem;
  border-bottom: 1px solid var(--color-border-soft);
  padding-bottom: 0.5rem;
}
.portal-card-sign {
  display: flex; align-items: center; gap: 0.5rem;
  color: var(--color-fg);
  text-decoration: none;
  transition: color 0.18s ease;
}
.portal-card-sign:hover { color: var(--color-accent); text-decoration: none; }
.portal-card-head .symbol {
  font-size: 1.5rem; color: var(--color-accent);
}
.portal-card-head .name {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 600;
}
.portal-card-head .dates {
  font-size: 0.7rem;
  color: var(--color-muted);
  margin-left: auto;
}
.portal-card-excerpt {
  font-size: 0.9rem;
  color: var(--color-fg-soft);
  line-height: 1.55;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.portal-card-cta {
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--color-accent);
  align-self: flex-start;
  text-decoration: none;
}
.portal-card-cta:hover { text-decoration: underline; }
.portal-card.placeholder {
  border-style: dashed;
  opacity: 0.7;
}
.portal-card.placeholder .portal-card-excerpt {
  font-style: italic;
  color: var(--color-muted);
}

/* Archive banner */
.archive-banner {
  background: #fef9e7;
  border: 1px solid #f0e5c4;
  color: #6a5310;
  padding: 0.75rem 1rem;
  border-radius: var(--radius-md);
  font-size: 0.9rem;
  margin: 1rem 0;
  text-align: center;
}
.archive-banner a { color: #6a5310; font-weight: 600; }

/* ===== Footer ===== */
.site-footer {
  background: var(--color-fg);
  color: rgba(255,255,255,0.85);
  padding: 2rem 1rem 1.5rem;
  margin-top: 3rem;
}
.footer-cols {
  max-width: var(--max-w-wide);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid rgba(255,255,255,0.1);
}
@media (min-width: 640px) { .footer-cols { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .footer-cols { grid-template-columns: repeat(4, 1fr); } }
.footer-col h4 {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin: 0 0 0.75rem;
  color: rgba(255,255,255,0.5);
  font-family: var(--font-body);
  font-weight: 600;
}
.footer-col ul { list-style: none; margin: 0; padding: 0; }
.footer-col li { margin-bottom: 0.5rem; }
.footer-col a { color: rgba(255,255,255,0.85); font-size: 0.9rem; text-decoration: none; }
.footer-col a:hover { color: white; text-decoration: underline; }
.footer-bottom {
  max-width: var(--max-w-wide);
  margin: 1.5rem auto 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  align-items: center;
  font-size: 0.8rem;
  color: rgba(255,255,255,0.5);
  text-align: center;
}
@media (min-width: 640px) { .footer-bottom { flex-direction: row; justify-content: space-between; } }
.footer-bottom .brand-line::before { content: "✦ "; color: var(--color-gold); }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { transition-duration: 0s !important; animation-duration: 0s !important; }
}
