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

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

body {
  background: #1a1625;
  color: #c4b8d9;
  font-family: 'Space Mono', monospace;
  min-height: 100vh;
  padding: 1rem;
  font-size: 16px;
  line-height: 1.4;
  overflow-x: hidden;
}

.prompt { color: #a78bfa; }
.comment { color: #a99cc4; }
.comment-block {
  color: #a99cc4;
  padding-left: 1.5ch;
  max-width: 42ch;
  margin: 0;
}
.comment-block::before {
  content: '# ';
  margin-left: -2ch;
}
.comment-block + .comment-block {
  margin-top: 0.5rem;
}
.green { color: #a0f5c4; }
.pink { color: #f5a0b3; }

.line { margin: 0; word-wrap: break-word; overflow-wrap: break-word; }

.ascii-art {
  color: #a0f5c4;
  line-height: 1.2;
  margin: 0 0 0.5rem 0;
  font-size: 18px;
  max-width: 100%;
  overflow-x: auto;
}

.blink { animation: blink 1s step-end infinite; }
@keyframes blink { 50% { opacity: 0; } }

#cmd {
  display: inline;
  background: none;
  border: none;
  outline: none;
  color: #c4b8d9;
  font-family: 'Space Mono', monospace;
  font-size: 16px;
  width: 20ch;
  caret-color: #a78bfa;
}

#cmd::placeholder { color: #7b6d9e; }

.submit-btn {
  background: none;
  border: 1px solid #7b6d9e;
  color: #a78bfa;
  font-family: 'Space Mono', monospace;
  font-size: 16px;
  padding: 2px 10px;
  margin-left: 1ch;
  cursor: pointer;
}
.submit-btn:hover { border-color: #a78bfa; }

.output { color: #a0f5c4; }
.error { color: #f5a0b3; }

a { color: #7b6d9e; text-decoration: none; }
a:hover { color: #a78bfa; }

.footer {
  margin-top: 2rem;
  padding: 1rem 0;
  font-size: 11px;
}

.sparkle {
  display: inline-block;
  animation: sparkle 2s ease-in-out infinite;
}
@keyframes sparkle { 0%, 100% { opacity: 0.4; } 50% { opacity: 1; } }

/* Subpage styles */
h1, h2, h3 {
  font-family: 'Space Mono', monospace;
  font-weight: 700;
}

h1 {
  color: #a0f5c4;
  font-size: 18px;
  margin-bottom: 1rem;
}

h2 {
  color: #a78bfa;
  font-size: 16px;
  margin: 1.5rem 0 0.5rem;
}

h3 {
  color: #c4b8d9;
  font-size: 16px;
  margin: 1rem 0 0.25rem;
}

.sr-only {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.nav {
  margin: 0.5rem 0 1rem;
  font-size: 14px;
}
.nav a {
  color: #a99cc4;
  margin-right: 2ch;
}
.nav a:hover { color: #a78bfa; }
.nav .active { color: #a0f5c4; }

.content {
  max-width: 60ch;
}

.content p {
  margin: 0.5rem 0;
  max-width: 55ch;
}

.content pre {
  color: #c4b8d9;
  line-height: 1.4;
  margin: 0.5rem 0;
  max-width: 100%;
  overflow-x: auto;
  font-size: 14px;
}

.content .file-header {
  color: #a78bfa;
  margin: 1.5rem 0 0.25rem;
}

.content .file-content {
  color: #c4b8d9;
  padding-left: 2ch;
}

.content .yes-items { color: #a0f5c4; }
.content .no-items { color: #f5a0b3; }
.content .tip-items { color: #c4b8d9; }
.content .muted { color: #a99cc4; }

.cta-box {
  border: 1px solid #7b6d9e;
  padding: 0.75rem 1rem;
  margin: 1.5rem 0;
  max-width: 50ch;
}
.cta-box a { color: #a78bfa; }
.cta-box a:hover { text-decoration: underline; }

.faq-answer {
  color: #a99cc4;
  padding-left: 2ch;
  max-width: 55ch;
  margin-bottom: 1rem;
}

.holiday-list {
  font-size: 14px;
  line-height: 1.6;
}

.lookup-input {
  display: inline;
  background: none;
  border: none;
  outline: none;
  color: #c4b8d9;
  font-family: 'Space Mono', monospace;
  font-size: 16px;
  width: 10ch;
  caret-color: #a78bfa;
  text-transform: uppercase;
}
.lookup-input::placeholder { color: #7b6d9e; }

.result-block {
  margin: 0.5rem 0;
  padding-left: 2ch;
}

@media (max-width: 480px) {
  body { padding: 0.75rem; font-size: 16px; }
  .ascii-art { font-size: 12px; }
  #cmd { font-size: 16px; }
  .footer { font-size: 10px; }
  .content pre { font-size: 13px; }
}

@media (max-width: 360px) {
  .ascii-art { font-size: 10px; }
}
