/* =========================================================================
   CIPHERIANS — runic cyberpunk terminal
   ========================================================================= */

:root {
  --bg:           #07050a;
  --bg-soft:      #0c0809;
  --panel:       rgba(14, 9, 8, 0.55);
  --line:        rgba(255, 110, 32, 0.10);
  --line-strong: rgba(255, 110, 32, 0.22);
  --ember:       rgba(255, 110, 32, 0.40);
  --ember-bg:    rgba(255, 110, 32, 0.06);

  --orange:      #ff6a14;
  --orange-hot:  #ff8a2a;
  --orange-soft: #ffb27a;
  --orange-dim:  #8a3a10;

  --ink:         #f3e7d8;
  --ink-dim:     #9a8c79;
  --ink-mute:    #5a4d3f;

  --display: "Cinzel", "Trajan Pro", Georgia, serif;
  --mono:    "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --body:    "Sora", system-ui, sans-serif;
}

/* ---------- Reset / base ---------- */
* { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--body);
  font-weight: 300;
  color: var(--ink);
  background: var(--bg);
  overflow-x: hidden;
}

::selection { background: var(--orange); color: #0a0604; }

/* ---------- Typography utilities ---------- */
.font-display { font-family: var(--display); font-weight: 900; letter-spacing: 0.02em; }
.font-mono    { font-family: var(--mono); }
.font-body    { font-family: var(--body); }

.eyebrow {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--orange-soft);
}

/* ---------- The signature: runic glow ---------- */
.runic {
  font-family: var(--display);
  font-weight: 900;
  color: #ffd0a8;
  letter-spacing: 0.08em;
  text-shadow:
    0 0 1px  #fff,
    0 0 6px  #ff8a2a,
    0 0 14px #ff6a14,
    0 0 28px rgba(255, 106, 20, 0.85),
    0 0 56px rgba(255, 106, 20, 0.55),
    0 0 96px rgba(255, 80, 10, 0.35);
  animation: runic-breathe 4.4s ease-in-out infinite;
}
@keyframes runic-breathe {
  0%, 100% { filter: brightness(1)    saturate(1); }
  47%      { filter: brightness(1.08) saturate(1.1); }
  49%      { filter: brightness(0.92) saturate(0.95); }
  50%      { filter: brightness(1.18) saturate(1.15); }
  51%      { filter: brightness(0.95) saturate(1); }
  53%      { filter: brightness(1.06) saturate(1.05); }
}

.runic-sm {
  font-family: var(--display);
  font-weight: 700;
  color: #ffd0a8;
  letter-spacing: 0.06em;
  text-shadow:
    0 0 4px #ff6a14,
    0 0 12px rgba(255, 106, 20, 0.6),
    0 0 28px rgba(255, 106, 20, 0.3);
}

/* ---------- Global grid backdrop ---------- */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size: 56px 56px;
  background-position: -1px -1px;
  mask-image: radial-gradient(ellipse 90% 70% at 50% 30%, #000 30%, transparent 100%);
  -webkit-mask-image: radial-gradient(ellipse 90% 70% at 50% 30%, #000 30%, transparent 100%);
}
/* Dots at intersections — fainter, more sparse */
body::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image: radial-gradient(circle at 1px 1px, var(--ember) 1px, transparent 1.4px);
  background-size: 56px 56px;
  background-position: -1px -1px;
  opacity: 0.55;
  mask-image: radial-gradient(ellipse 80% 60% at 50% 25%, #000 25%, transparent 95%);
  -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 25%, #000 25%, transparent 95%);
}

/* Lift content above grid layers */
main, nav, footer { position: relative; z-index: 2; }

/* ---------- Hero perspective grid floor ---------- */
.floor-stage {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 1;
}
.floor {
  position: absolute;
  left: -25%; right: -25%;
  bottom: -120px;
  height: 70vh;
  background-image:
    linear-gradient(var(--orange) 1px, transparent 1px),
    linear-gradient(90deg, var(--orange) 1px, transparent 1px);
  background-size: 72px 72px;
  background-position: 0 0;
  opacity: 0.22;
  transform-origin: 50% 0;
  transform: perspective(700px) rotateX(62deg);
  mask-image: linear-gradient(to bottom, transparent 0%, #000 25%, #000 70%, transparent 100%);
  -webkit-mask-image: linear-gradient(to bottom, transparent 0%, #000 25%, #000 70%, transparent 100%);
  animation: floor-drift 22s linear infinite;
}
@keyframes floor-drift {
  from { background-position: 0    0;   }
  to   { background-position: 0    72px; }
}
.floor-dots {
  position: absolute;
  left: -25%; right: -25%;
  bottom: -120px;
  height: 70vh;
  background-image: radial-gradient(circle at 1px 1px, var(--orange-hot) 1.2px, transparent 1.8px);
  background-size: 72px 72px;
  opacity: 0.55;
  transform-origin: 50% 0;
  transform: perspective(700px) rotateX(62deg);
  mask-image: linear-gradient(to bottom, transparent 0%, #000 25%, #000 70%, transparent 100%);
  -webkit-mask-image: linear-gradient(to bottom, transparent 0%, #000 25%, #000 70%, transparent 100%);
  animation: floor-drift 22s linear infinite;
}

/* The traveling pulse — a soft orange beam sweeping horizontally L→R.
   Uses transform on a pseudo-element instead of background-position to
   avoid the loop-snap glitch (band wasn't fully off-screen at the
   keyframe-100% before snapping back to keyframe-0%). */
.floor-pulse {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}
.floor-pulse::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 40%;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255, 138, 42, 0.05) 30%,
    rgba(255, 138, 42, 0.22) 50%,
    rgba(255, 138, 42, 0.05) 70%,
    transparent 100%
  );
  mix-blend-mode: screen;
  animation: pulse-sweep 6.5s linear infinite;
  transform: translateX(-100%);
  will-change: transform;
}
@keyframes pulse-sweep {
  0%   { transform: translateX(-100%); }   /* fully off-left */
  100% { transform: translateX(250%); }    /* fully off-right */
}

/* Horizon glow above the floor */
.horizon {
  position: absolute;
  left: 0; right: 0;
  bottom: 22vh;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--orange), transparent);
  filter: blur(0.5px);
  box-shadow: 0 0 24px var(--orange-hot), 0 0 80px rgba(255, 138, 42, 0.6);
  opacity: 0.7;
}
.horizon::after {
  content: "";
  position: absolute;
  left: 0; right: 0; top: 0;
  height: 36vh;
  background: radial-gradient(ellipse 60% 100% at 50% 0%, rgba(255, 110, 20, 0.25), transparent 70%);
  transform: translateY(-100%);
  pointer-events: none;
}

/* ---------- Corner brackets — wraps any element ---------- */
.bracket {
  position: relative;
}
.bracket::before,
.bracket::after,
.bracket > .br-tr,
.bracket > .br-br {
  content: "";
  position: absolute;
  width: 14px;
  height: 14px;
  border-color: var(--orange);
  pointer-events: none;
}
.bracket::before { /* top-left */
  top: -1px; left: -1px;
  border-top: 1px solid var(--orange);
  border-left: 1px solid var(--orange);
}
.bracket::after { /* bottom-left */
  bottom: -1px; left: -1px;
  border-bottom: 1px solid var(--orange);
  border-left: 1px solid var(--orange);
}
.bracket > .br-tr {
  top: -1px; right: -1px;
  border-top: 1px solid var(--orange);
  border-right: 1px solid var(--orange);
}
.bracket > .br-br {
  bottom: -1px; right: -1px;
  border-bottom: 1px solid var(--orange);
  border-right: 1px solid var(--orange);
}
.bracket-dim::before,
.bracket-dim::after,
.bracket-dim > .br-tr,
.bracket-dim > .br-br {
  border-color: var(--orange-dim);
}
.bracket-dim::before { border-top-color: var(--orange-dim);    border-left-color: var(--orange-dim); }
.bracket-dim::after  { border-bottom-color: var(--orange-dim); border-left-color: var(--orange-dim); }
.bracket-dim > .br-tr { border-top-color: var(--orange-dim);    border-right-color: var(--orange-dim); }
.bracket-dim > .br-br { border-bottom-color: var(--orange-dim); border-right-color: var(--orange-dim); }

/* ---------- HUD ticker bar ---------- */
.hud-bar {
  border-top: 1px solid var(--line-strong);
  border-bottom: 1px solid var(--line-strong);
  background:
    linear-gradient(90deg, transparent, rgba(255, 110, 20, 0.04), transparent),
    var(--bg-soft);
}
.hud-tick {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  color: var(--orange-soft);
  text-transform: uppercase;
}
.hud-tick .dim { color: var(--ink-mute); }
.hud-tick .dot {
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--orange);
  box-shadow: 0 0 8px var(--orange-hot);
  vertical-align: 2px;
  margin: 0 6px;
  /* animation removed per design — static glow only */
}
@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.35; transform: scale(0.7); }
}

/* Scrolling marquee */
.marquee {
  display: flex;
  overflow: hidden;
  mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.marquee-track {
  display: inline-flex;
  white-space: nowrap;
  animation: marquee 48s linear infinite;
  gap: 48px;
  padding-right: 48px;
}
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ---------- Buttons ---------- */
.btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 14px 22px;
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: #1a0a02;
  background: linear-gradient(180deg, var(--orange-hot), var(--orange));
  border: 1px solid var(--orange-hot);
  box-shadow:
    0 0 0 1px rgba(255, 138, 42, 0.2),
    0 0 24px rgba(255, 106, 20, 0.5),
    inset 0 0 12px rgba(255, 200, 140, 0.3);
  transition: transform 0.2s ease, box-shadow 0.3s ease;
  position: relative;
  overflow: hidden;
}
.btn-primary:hover {
  transform: translateY(-1px);
  box-shadow:
    0 0 0 1px rgba(255, 178, 122, 0.3),
    0 0 36px rgba(255, 106, 20, 0.85),
    inset 0 0 18px rgba(255, 220, 180, 0.45);
}
.btn-primary::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(115deg, transparent 40%, rgba(255, 255, 255, 0.35) 50%, transparent 60%);
  transform: translateX(-120%);
  transition: transform 0.7s ease;
}
.btn-primary:hover::after { transform: translateX(120%); }

.btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 13px 22px;
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--orange-soft);
  background: transparent;
  border: 1px solid var(--orange-dim);
  transition: border-color 0.2s, color 0.2s, background 0.2s;
}
.btn-ghost:hover {
  color: var(--orange);
  border-color: var(--orange);
  background: var(--ember-bg);
}

/* ---------- Panels ---------- */
.panel {
  position: relative;
  background: var(--panel);
  border: 1px solid var(--line-strong);
  padding: 24px;
  backdrop-filter: blur(2px);
}
.panel-tight { padding: 16px; }

.panel-glow {
  background:
    radial-gradient(ellipse 100% 60% at 50% 0%, rgba(255, 110, 20, 0.08), transparent 70%),
    var(--panel);
}

/* ---------- Stat readout ---------- */
.stat {
  font-family: var(--mono);
  font-weight: 500;
  font-size: 36px;
  color: var(--ink);
  letter-spacing: 0.04em;
  line-height: 1;
}
.stat-glow { color: var(--orange-soft); text-shadow: 0 0 16px rgba(255, 138, 42, 0.55); }
.stat-label {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-top: 8px;
}

/* ---------- Code blocks ---------- */
pre, code { font-family: var(--mono); }
.codeblock {
  background: #04030680;
  border: 1px solid var(--line-strong);
  padding: 16px 18px;
  font-size: 12px;
  line-height: 1.7;
  color: #ffce9a;
  overflow-x: auto;
  position: relative;
}
.codeblock::before {
  content: var(--label, "▸ shell");
  position: absolute;
  top: -10px;
  left: 12px;
  background: var(--bg);
  padding: 0 8px;
  font-size: 9px;
  letter-spacing: 0.3em;
  color: var(--orange-dim);
  text-transform: uppercase;
}
.codeblock .com  { color: var(--ink-mute); }
.codeblock .var  { color: var(--orange-soft); }
.codeblock .str  { color: #ff9a4a; }
.codeblock .ok   { color: var(--orange); }
.codeblock .key  { color: var(--orange-soft); }
.codeblock .val  { color: #ffe0c2; }
.codeblock .dim  { color: var(--ink-mute); }

/* "Paste-at-agent" variant — emphasizes the prompt visually */
.codeblock-paste {
  font-size: 14px;
  color: #ffe0c2;
  padding: 22px 22px;
  line-height: 1.6;
}
.codeblock-paste .prompt-prefix {
  color: var(--orange);
  margin-right: 8px;
}

/* ---------- Section divider ---------- */
.divider {
  position: relative;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--orange-dim), transparent);
  margin: 0;
}
.divider-coords {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 24px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.divider-coords .sep { color: var(--orange-dim); }

/* ---------- Sigil (hero right) ---------- */
.sigil {
  position: relative;
  width: 100%;
  aspect-ratio: 1;
  max-width: 600px;
  margin: 0 auto;
}
.sigil svg { width: 100%; height: 100%; display: block; }
.sigil-rune {
  fill: none;
  stroke: var(--orange);
  stroke-width: 1;
  filter: drop-shadow(0 0 4px var(--orange)) drop-shadow(0 0 12px rgba(255, 106, 20, 0.6));
}
.sigil-rune-thin {
  fill: none;
  stroke: var(--orange-dim);
  stroke-width: 0.6;
}
.sigil-fill { fill: var(--orange); filter: drop-shadow(0 0 6px var(--orange-hot)); }
.sigil-rotate-slow { transform-origin: 50% 50%; animation: rot 80s linear infinite; }
.sigil-rotate-rev  { transform-origin: 50% 50%; animation: rot 60s linear infinite reverse; }
.sigil-rotate-fast { transform-origin: 50% 50%; animation: rot 18s linear infinite; }
@keyframes rot { to { transform: rotate(360deg); } }

.sigil-core {
  transform-origin: 50% 50%;
  animation: core-pulse 3.2s ease-in-out infinite;
}
@keyframes core-pulse {
  0%, 100% { opacity: 0.85; transform: scale(1); }
  50%      { opacity: 1;    transform: scale(1.08); }
}

.sigil-scan {
  transform-origin: 50% 50%;
  animation: rot 4.5s linear infinite;
}

/* ---------- Step cards ---------- */
.step {
  position: relative;
  padding: 28px 24px 24px;
  border: 1px solid var(--line-strong);
  background:
    linear-gradient(180deg, rgba(255, 110, 20, 0.05), transparent 40%),
    var(--panel);
  transition: border-color 0.25s, background 0.25s;
}
.step:hover {
  border-color: var(--orange);
  background:
    linear-gradient(180deg, rgba(255, 110, 20, 0.1), transparent 40%),
    var(--panel);
}
.step-num {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.3em;
  color: var(--orange);
  text-transform: uppercase;
  margin-bottom: 16px;
}
.step h3 {
  font-family: var(--display);
  font-weight: 700;
  font-size: 22px;
  color: #ffd0a8;
  letter-spacing: 0.04em;
  margin-bottom: 10px;
}
.step p {
  font-size: 13px;
  line-height: 1.7;
  color: var(--ink-dim);
}
.step p .hi { color: var(--orange-soft); }

/* ---------- Trait chip ---------- */
.chip {
  position: relative;
  padding: 14px 16px 16px;
  background: var(--panel);
  border: 1px solid var(--line);
  transition: border-color 0.2s, background 0.2s;
}
.chip:hover {
  border-color: var(--orange-dim);
  background: var(--ember-bg);
}
.chip-cat {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--orange);
  margin-bottom: 8px;
}
.chip p {
  font-size: 11px;
  line-height: 1.7;
  color: var(--ink-dim);
}

/* ---------- Rarity tiles ---------- */
.rarity {
  padding: 22px 20px;
  border: 1px solid var(--line-strong);
  background: var(--panel);
  position: relative;
  overflow: hidden;
}
.rarity::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, var(--accent, transparent) 0, transparent 60%);
  opacity: 0.12;
  pointer-events: none;
}
.rarity-legendary { --accent: #ff6a14; }
.rarity-rare      { --accent: #ff9a4a; }
.rarity-uncommon  { --accent: #c46a14; }
.rarity-common    { --accent: #5a4d3f; }
.rarity-name {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--orange-soft);
}
.rarity-common .rarity-name { color: var(--ink-dim); }
.rarity-num {
  font-family: var(--display);
  font-weight: 700;
  font-size: 38px;
  color: #ffd0a8;
  line-height: 1;
  margin-top: 14px;
}
.rarity-meta {
  margin-top: 8px;
  font-family: var(--mono);
  font-size: 10px;
  color: var(--ink-mute);
  letter-spacing: 0.1em;
}

/* ---------- Side rail (vertical text) ---------- */
.rail {
  position: fixed;
  top: 50%;
  right: 18px;
  transform: translateY(-50%) rotate(180deg);
  writing-mode: vertical-rl;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.45em;
  text-transform: uppercase;
  color: var(--orange-dim);
  z-index: 30;
  pointer-events: none;
  user-select: none;
}
@media (max-width: 900px) { .rail { display: none; } }

/* ---------- Pixelated img ---------- */
.pixelated {
  image-rendering: pixelated;
  image-rendering: -moz-crisp-edges;
  image-rendering: crisp-edges;
}

/* ---------- Lightbox ---------- */
#lightbox.active { display: flex !important; }

/* ---------- Boot terminal in nav ---------- */
.boot {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  color: var(--orange-soft);
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.boot .caret {
  display: inline-block;
  width: 7px; height: 12px;
  background: var(--orange);
  box-shadow: 0 0 10px var(--orange-hot);
  animation: caret-blink 1s steps(2) infinite;
}
@keyframes caret-blink {
  50% { opacity: 0; }
}

/* ---------- Scrollbar ---------- */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb {
  background: var(--orange-dim);
  border: 2px solid var(--bg);
}
::-webkit-scrollbar-thumb:hover { background: var(--orange); }

/* ---------- Misc helpers ---------- */
.kbd {
  font-family: var(--mono);
  font-size: 10px;
  padding: 2px 6px;
  border: 1px solid var(--line-strong);
  color: var(--orange-soft);
  background: var(--ember-bg);
  letter-spacing: 0.15em;
}

a { color: inherit; }
a.link { color: var(--orange-soft); text-decoration: none; border-bottom: 1px dotted var(--orange-dim); }
a.link:hover { color: var(--orange); border-bottom-color: var(--orange); }

/* Tailwind 'hidden' override safety for kept-but-stubbed JS targets */
.js-stub { position: absolute; left: -9999px; top: 0; opacity: 0; pointer-events: none; }
