:root {
  --bg: #061A33;
  --bg-panel: #091f3d;
  --bg-panel-2: #0d2548;
  --text: #D7ECFF;
  --text-muted: #8CB7E0;
  --accent: #2F86E8;
  --ornament: #F28A2E;
  --line: rgba(47,134,232,.18);
  --line-strong: rgba(47,134,232,.35);
  --soft: rgba(47,134,232,.06);
  --shadow: rgba(0,0,0,.55);
  --good: #7ec47c;
  --warn: #F28A2E;
  --bad: #cc6a5e;
  --font-display: "Space Grotesk", system-ui, sans-serif;
  --font-body: "Lora", Georgia, serif;
  --font-mono: "Cascadia Code", "JetBrains Mono", Consolas, monospace;
}

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

html {
  min-height: 100%;
  background: var(--bg);
}

body {
  background: radial-gradient(circle at 75% 0, rgba(47,134,232,.07), transparent 28rem), linear-gradient(135deg, #040f1e, var(--bg));
  color: var(--text);
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.5;
  overflow-x: hidden;
}

.page {
  width: min(1280px, calc(100% - 48px));
  margin: 0 auto;
  padding: 32px 0 56px;
}

h1,
h2,
h3 {
  font-family: var(--font-display);
  font-weight: 700;
  color: var(--text);
}

a {
  color: inherit;
  text-decoration: none;
}

.hero {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px 20px;
  background: linear-gradient(180deg, var(--soft), transparent 60%), var(--bg-panel);
  box-shadow: 0 18px 48px var(--shadow);
  margin-bottom: 24px;
}

.hero-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.wordmark {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.3rem;
  color: var(--text);
  letter-spacing: -.01em;
}

.wordmark span {
  color: var(--accent);
}

.tagline {
  color: var(--text-muted);
  font-size: .85rem;
  margin-top: 2px;
}

.splash-clock {
  text-align: right;
  font-family: var(--font-mono);
}

.clock-time {
  font-size: 1.1rem;
  color: var(--text);
}

.clock-secs {
  color: var(--text-muted);
  font-size: .9rem;
}

.clock-date {
  color: var(--text-muted);
  font-size: .75rem;
  margin-top: 2px;
}

.clock-prog {
  height: 2px;
  background: var(--line);
  border-radius: 1px;
  margin: 4px 0;
}

.clock-prog-fill {
  height: 100%;
  background: var(--accent);
  border-radius: 1px;
  transition: width .4s linear;
}

.app-tile-grid {
  display: flex;
  justify-content: center;
  gap: 16px;
  margin-bottom: 36px;
  flex-wrap: wrap;
}

.app-tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 28px 36px;
  background: var(--bg-panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  cursor: pointer;
  transition: border-color .15s, background .15s, transform .1s;
}

.app-tile:hover {
  border-color: var(--accent);
  background: var(--bg-panel-2);
  transform: translateY(-2px);
}

.app-tile-icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ornament);
  flex-shrink: 0;
  font-size: 1.4rem;
}

.app-tile-icon svg {
  width: 28px;
  height: 28px;
  stroke: var(--ornament);
}

.app-tile-name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1rem;
  color: var(--text);
  letter-spacing: .02em;
}

.app-tile-sub {
  font-size: .75rem;
  color: var(--text-muted);
  margin-top: 2px;
}

.splash-quote {
  border-top: 1px solid var(--line);
  padding-top: 24px;
  margin-top: 8px;
  text-align: center;
}

.sq-lede {
  font-family: var(--font-display);
  font-size: .7rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ornament);
  margin-bottom: 16px;
  min-height: 1em;
  text-align: center;
}

.sq-slots {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
@media (max-width: 900px) {
  .sq-slots { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px) {
  .sq-slots { grid-template-columns: 1fr; }
}

.sq-slot {
  background: var(--bg-panel);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 14px 16px;
  text-align: left;
}

q.sq-text {
  display: block;
  font-family: var(--font-body);
  font-style: italic;
  font-size: .9rem;
  color: var(--text);
  quotes: none;
  line-height: 1.55;
  margin-bottom: 8px;
  text-align: justify;
  hyphens: auto;
}

.sq-attr {
  font-family: var(--font-display);
  font-size: .72rem;
  color: var(--text-muted);
  display: block;
  margin-top: 6px;
  letter-spacing: .06em;
  opacity: 0;
}
.sq-attr.sq-attr-reveal {
  animation: sq-attr-in 300ms ease both;
}
@keyframes sq-attr-in {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* 1. Typewriter caret */
.sq-style-typewriter:not(.typed)::after { content: "|"; margin-left: 1px; color: var(--accent); animation: caret-blink 0.65s step-end infinite; }
.sq-style-typewriter.typed::after       { content: "|"; margin-left: 1px; color: var(--accent); opacity: 0.3; }
@keyframes caret-blink {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0; }
}

/* 2. Cascade */
@keyframes sq-cascade-word {
  from { opacity: 0; transform: translateY(5px); }
  to   { opacity: 1; transform: translateY(0); }
}
.sq-style-cascade .sq-cascade-word {
  display: inline-block;
  opacity: 0;
  animation: sq-cascade-word 260ms ease forwards;
}

/* 3. Glitch */
.sq-style-glitch { color: var(--accent); }
.sq-style-glitch.resolved { color: var(--qcolor, var(--text)); transition: color 400ms ease; }

/* 4. Redact */
.sq-redact-word {
  display: inline-block;
  background: var(--text);
  color: var(--text);
  transition: background 160ms ease, color 160ms ease;
}
.sq-redact-word.revealed { background: transparent; color: inherit; }

/* 5. Ink bleed */
@keyframes sq-ink {
  from { filter: blur(7px); opacity: 0.3; }
  to   { filter: blur(0);   opacity: 1; }
}
.sq-style-ink { animation: sq-ink 650ms ease both; }

.splash-footer {
  margin-top: 32px;
  text-align: center;
  color: var(--text-muted);
  font-family: var(--font-display);
  font-size: .75rem;
  letter-spacing: .06em;
  opacity: .45;
}

/* ── Orb rail ──────────────────────────────────────────────── */
@keyframes orb-enter {
  to { opacity: 1; transform: translateY(0); }
}

.orb-rail {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: .4rem;
  width: min(1280px, calc(100% - 48px));
  margin: 0 auto 28px;
  padding: 20px 0 4px;
  border-top: 1px solid var(--line);
}

.orb-link {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
  text-decoration: none;
  color: var(--text-muted);
  opacity: 0;
  transform: translateY(12px);
  animation: orb-enter 0.5s cubic-bezier(0.22, 1, 0.36, 1) forwards;
  transition: color 200ms ease;
  padding: 6px 0;
  width: 96px;
  flex-shrink: 0;
}

.orb-link:nth-child(1) { animation-delay: .1s; }
.orb-link:nth-child(2) { animation-delay: .22s; }
.orb-link:nth-child(3) { animation-delay: .34s; }
.orb-link:nth-child(4) { animation-delay: .46s; }
.orb-link:nth-child(5) { animation-delay: .58s; }
.orb-link:nth-child(6) { animation-delay: .7s; }

.orb-icon {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-panel-2);
  border: 1px solid var(--line);
  box-shadow: 0 8px 28px var(--shadow);
  transition: transform 220ms cubic-bezier(0.22, 1, 0.36, 1),
              box-shadow 220ms ease,
              background 220ms ease;
}

.orb-icon svg {
  width: 24px;
  height: 24px;
  transition: transform 220ms cubic-bezier(0.22, 1, 0.36, 1), opacity 220ms ease;
  opacity: .65;
}

.orb-label {
  font-family: var(--font-display);
  font-size: .62rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-align: center;
  text-transform: uppercase;
  line-height: 1.2;
  transition: color 220ms ease;
}

.orb-link:hover { color: var(--text); }
.orb-link:hover .orb-icon svg { opacity: 1; transform: scale(1.08); }

.orb-link--github:hover .orb-icon {
  transform: translateY(-5px);
  box-shadow: 0 16px 40px rgba(0,0,0,.4), 0 0 28px rgba(47,134,232,.22);
}
.orb-link--steam:hover .orb-icon {
  transform: translateY(-5px);
  box-shadow: 0 16px 40px rgba(0,0,0,.4), 0 0 28px rgba(27,154,247,.28);
}
.orb-link--reddit:hover .orb-icon {
  transform: translateY(-5px);
  box-shadow: 0 16px 40px rgba(0,0,0,.4), 0 0 28px rgba(255,69,0,.28);
}
.orb-link--themes:hover .orb-icon {
  transform: translateY(-5px);
  box-shadow: 0 16px 40px rgba(0,0,0,.4), 0 0 28px rgba(242,138,46,.28);
}
.orb-link--cattap:hover .orb-icon {
  transform: translateY(-5px);
  box-shadow: 0 16px 40px rgba(0,0,0,.4), 0 0 28px rgba(168,85,247,.28);
}
.orb-link--kofi:hover .orb-icon {
  transform: translateY(-5px);
  box-shadow: 0 16px 40px rgba(0,0,0,.4), 0 0 28px rgba(255,95,128,.28);
}

/* Boot sequence */
@keyframes boot-slide-up {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes boot-fade {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.boot-hidden { opacity: 0; pointer-events: none; }
.boot-fade-in { animation: boot-fade 400ms ease both; }
.boot-slide-in { animation: boot-slide-up 350ms ease both; }
#bootWordmark.boot-typing::after {
  content: "|";
  color: var(--accent);
  animation: caret-blink 0.65s step-end infinite;
  margin-left: 2px;
}
@media (prefers-reduced-motion: reduce) {
  .boot-hidden { opacity: 1 !important; pointer-events: auto !important; }
  .boot-fade-in, .boot-slide-in { animation: none !important; opacity: 1 !important; }
  #bootWordmark.boot-typing::after { display: none; }
}

.chip {
  display: inline-flex;
  align-items: center;
  padding: 3px 9px;
  border-radius: 999px;
  border: 1px solid var(--line);
  font-family: var(--font-mono);
  font-size: .7rem;
  color: var(--text-muted);
  background: var(--bg-panel);
}

.chip.info {
  border-color: var(--accent);
  color: var(--accent);
}

.chip.good {
  border-color: var(--good);
  color: var(--good);
}

.chip.warn {
  border-color: var(--warn);
  color: var(--warn);
}
