/* MonsterMoozy — shared archive UI
   Dark, archival, cinematic. Images carry the colour; UI stays restrained. */

:root {
  --void: #060708;
  --graphite: #0d0f11;
  --panel: #101316;
  --line: rgba(255, 255, 255, 0.10);
  --line-soft: rgba(255, 255, 255, 0.06);
  --ink: #d8dad6;
  --ink-dim: #8a8f8a;
  --moss: #6fae6a;
  --teal: #46c8c0;
  --amber: #e0a83c;
  --red: #e0452f;
  --ivory: #efe9dc;
  --mono: "SF Mono", "Menlo", "Consolas", "Courier New", monospace;
  --serifish: "Avenir Next", "Futura", "Helvetica Neue", Arial, sans-serif;
}

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

html, body {
  background: var(--void);
  color: var(--ink);
  font-family: var(--serifish);
  -webkit-font-smoothing: antialiased;
}

::selection { background: rgba(111, 174, 106, 0.35); }

/* ---------- type ---------- */

.meta {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-dim);
}

.meta b { color: var(--ink); font-weight: 600; }

h1.display {
  font-size: clamp(34px, 6vw, 84px);
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.02;
  text-transform: uppercase;
  color: var(--ivory);
}

h2.section {
  font-size: clamp(20px, 2.6vw, 32px);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ivory);
}

p.lede {
  max-width: 56ch;
  font-size: 15px;
  line-height: 1.7;
  color: var(--ink-dim);
}

/* ---------- chrome ---------- */

.topbar {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 22px;
  background: linear-gradient(to bottom, rgba(6, 7, 8, 0.85), rgba(6, 7, 8, 0));
  pointer-events: none;
}

.topbar a, .topbar span { pointer-events: auto; }

.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: var(--ivory);
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

/* the big-eye motif as logo */
.eye {
  width: 22px; height: 22px;
  border-radius: 50%;
  border: 1.5px solid var(--ink-dim);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: none;
}
.eye::after {
  content: "";
  width: 9px; height: 9px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, #fff 0 18%, var(--teal) 20% 55%, #02110f 60%);
}

.navlinks { display: flex; gap: 18px; }
.navlinks a {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-dim);
  text-decoration: none;
  padding: 6px 2px;
  border-bottom: 1px solid transparent;
  transition: color .2s, border-color .2s;
}
.navlinks a:hover, .navlinks a.active { color: var(--ivory); border-color: var(--moss); }
.navlinks a.danger:hover, .navlinks a.danger.active { border-color: var(--red); }

.badge {
  display: inline-block;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 4px 9px;
  border: 1px solid var(--line);
  border-radius: 3px;
  color: var(--ink-dim);
  background: rgba(0,0,0,0.35);
}
.badge.moss  { color: var(--moss);  border-color: rgba(111,174,106,.4); }
.badge.red   { color: var(--red);   border-color: rgba(224,69,47,.45); }
.badge.amber { color: var(--amber); border-color: rgba(224,168,60,.45); }
.badge.teal  { color: var(--teal);  border-color: rgba(70,200,192,.4); }

.rule { height: 1px; background: var(--line-soft); margin: 26px 0; }

/* ---------- cards ---------- */

.grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
}

.card {
  position: relative;
  background: var(--panel);
  border: 1px solid var(--line-soft);
  border-radius: 6px;
  overflow: hidden;
  transition: transform .25s ease, border-color .25s ease;
}
.card:hover { transform: translateY(-4px); border-color: rgba(111,174,106,.45); }

.card img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  display: block;
  filter: saturate(.96);
  transition: filter .3s;
}
.card:hover img { filter: saturate(1.08); }

.card .body { padding: 12px 14px 14px; border-top: 1px solid var(--line-soft); }
.card .body h3 { font-size: 15px; letter-spacing: .04em; color: var(--ivory); margin: 6px 0 6px; }
.card .body p  { font-size: 12.5px; line-height: 1.55; color: var(--ink-dim); }

.wide-frame {
  position: relative;
  border: 1px solid var(--line-soft);
  border-radius: 8px;
  overflow: hidden;
}
.wide-frame img { width: 100%; display: block; }
.wide-frame .caption {
  position: absolute;
  left: 14px; bottom: 12px;
  display: flex; gap: 8px; align-items: center;
}

/* ---------- layout ---------- */

.page { max-width: 1280px; margin: 0 auto; padding: 0 22px 90px; }
.block { margin-top: 64px; }

footer.site {
  border-top: 1px solid var(--line-soft);
  margin-top: 80px;
  padding: 26px 22px 60px;
  display: flex;
  flex-wrap: wrap;
  gap: 14px 30px;
  justify-content: space-between;
}

button.cta, a.cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ivory);
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 13px 22px;
  cursor: pointer;
  text-decoration: none;
  transition: background .2s, border-color .2s, transform .15s;
}
button.cta:hover, a.cta:hover {
  background: rgba(111,174,106,0.12);
  border-color: rgba(111,174,106,0.6);
  transform: translateY(-1px);
}
a.cta.red:hover, button.cta.red:hover {
  background: rgba(224,69,47,0.12);
  border-color: rgba(224,69,47,0.6);
}

@media (max-width: 640px) {
  .topbar { padding: 10px 14px; align-items: flex-start; }
  .brand { font-size: 10px; letter-spacing: .14em; }
  .navlinks { gap: 4px 10px; flex-wrap: wrap; justify-content: flex-end; max-width: 60vw; }
  .navlinks a, .sound-toggle { font-size: 9px !important; letter-spacing: .1em !important; padding: 3px 2px !important; white-space: nowrap; }
}
