/* main.css – AstraGate ✦ Sovereign Style Layer */

:root {
  --bg: #000;
  --text: #eaeaea;
  --accent: #ff66cc;
  --button-bg: #330033;
  --button-hover: #550055;
  --button-border: #660066;
  --quote-glow: rgba(255, 102, 204, 0.5);
  --dim-text: #888;
}

body {
  background-color: var(--bg);
  color: var(--text);
  font-family: "Courier New", Courier, monospace;
  margin: 2em;
  line-height: 1.6;
}

a {
  color: #cc66ff;
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

h1,
h2,
h3 {
  font-weight: normal;
  letter-spacing: 0.03em;
  color: var(--accent);
}

h2 {
  font-size: 1.5em;
  margin-top: 2em;
}

.dim {
  opacity: 0.5;
  font-size: 0.9em;
  margin-top: 1em;
  transition: opacity 0.3s ease;
}

.dim:hover {
  opacity: 1;
}

.contact {
  margin-top: 3em;
  padding-top: 1em;
  border-top: 1px solid #222;
}

.button {
  display: inline-block;
  padding: 0.5em 1em;
  background-color: var(--button-bg);
  color: #ffccff;
  border: 1px solid var(--button-border);
  border-radius: 4px;
  font-weight: bold;
  margin-top: 0.5em;
}

.button.secondary {
  background-color: #1a1a1a;
  border: 1px solid #555;
  color: #ccc;
  padding: 0.8em 1.5em;
  font-size: 1.1em;
  letter-spacing: 0.05em;
  border-radius: 6px;
  box-shadow: 0 0 0.4em rgba(255, 102, 204, 0.2);
  transition: all 0.25s ease-in-out;
}

.button:hover {
  background-color: var(--button-hover);
  cursor: pointer;
}

.button.secondary:hover {
  background-color: #222;
  color: #ffccff;
  box-shadow: 0 0 1em rgba(255, 102, 204, 0.4);
}

footer {
  margin-top: 3em;
  font-size: 0.8em;
  color: var(--dim-text);
  border-top: 1px solid #222;
  padding-top: 1em;
}

.about-link {
  margin-top: 1.5em;
  padding-top: 1em;
  border-top: 1px dashed #333;
  padding-left: 1em;
  text-align: left;
  animation: veilPulse 8s ease-in-out infinite;
}

/* Ritual glow effect for quotes */
code.quote {
  background-color: #111;
  padding: 0.1em 0.4em;
  border-radius: 4px;
  color: #ffccff;
  font-size: 0.95em;
  font-family: "Courier New", Courier, monospace;
  box-shadow: 0 0 0.5em var(--quote-glow);
  animation: glowPulse 2.5s ease-in-out infinite;
}

@keyframes glowPulse {
  0% {
    box-shadow: 0 0 0.5em var(--quote-glow);
  }
  50% {
    box-shadow: 0 0 1.2em var(--quote-glow);
  }
  100% {
    box-shadow: 0 0 0.5em var(--quote-glow);
  }
}

@keyframes veilPulse {
  0% {
    opacity: 1;
  }
  50% {
    opacity: 0.85;
  }
  100% {
    opacity: 1;
  }
}
