/* ═══════════════════════════════════════════════════════════════════
   BASE.CSS — Reset, typography, background FX, global utilities
   ═══════════════════════════════════════════════════════════════════ */

/* ── Reset and base ──────────────────────────────────────────────── */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'JetBrains Mono', monospace;
  background: var(--ink);
  color: var(--white);
  min-height: 100vh;
  overflow-x: hidden;
}

/* ── Background FX ───────────────────────────────────────────────── */

.bg-grid {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background-image: linear-gradient(rgba(0,200,83,.03) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(0,200,83,.03) 1px, transparent 1px);
  background-size: 40px 40px;
}
.bg-radial {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background: radial-gradient(ellipse 80% 60% at 50% 0%, rgba(0,200,83,.06), transparent);
}
.scan-line {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background: repeating-linear-gradient(0deg, transparent, transparent 2px, rgba(0,200,83,.008) 2px, rgba(0,200,83,.008) 4px);
}
#particles { position: fixed; inset: 0; z-index: 0; pointer-events: none; overflow: hidden; }
.pt {
  position: absolute; border-radius: 50%;
  animation: float linear infinite;
}
.pt-node {
  position: absolute; border-radius: 50%;
  box-shadow: 0 0 6px rgba(0,229,255,.25);
  animation: nodeDrift linear infinite;
}
.pt-edge {
  position: absolute; height: 1px;
  transform-origin: left center;
  animation: edgePulse ease-in-out infinite;
}
@keyframes nodeDrift {
  0%, 100% { transform: translate(0, 0); opacity: .3; }
  25% { opacity: .9; }
  50% { transform: translate(var(--dx), var(--dy)); opacity: .6; }
  75% { opacity: .8; }
}
@keyframes edgePulse {
  0%, 100% { opacity: 0; }
  30%, 70% { opacity: .4; }
}
@keyframes float {
  0% { transform: translateY(0) translateX(0); opacity: 0; }
  10% { opacity: 1; }
  90% { opacity: .6; }
  100% { transform: translateY(-100vh) translateX(var(--dx, 0)); opacity: 0; }
}

/* ── Typography ──────────────────────────────────────────────────── */

h1, h2, h3, h4 {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 700;
  line-height: 1.1;
}
a { color: inherit; text-decoration: none; }
input, textarea, button { font-family: inherit; }
::placeholder { color: var(--muted); }

/* Gradient text utilities */
.org {
  background: linear-gradient(135deg, var(--gold2), var(--em), var(--teal));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.dat {
  background: linear-gradient(135deg, var(--teal), var(--cyan), var(--violet));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.gld {
  background: linear-gradient(135deg, var(--gold), var(--gold3));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.shim {
  background: linear-gradient(90deg, var(--muted), var(--silver), var(--em), var(--silver), var(--muted));
  background-size: 300% 100%;
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: shimmer 3s linear infinite;
}
@keyframes shimmer { to { background-position: -300% 0; } }

/* ── Scrollbar ───────────────────────────────────────────────────── */

::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: var(--deep); }
::-webkit-scrollbar-thumb { background: var(--em3); border-radius: 2px; }

/* ── Fade-up animations ──────────────────────────────────────────── */

.fade-up   { animation: fadeUp .7s ease both; }
.fade-up-2 { animation: fadeUp .7s .1s ease both; }
.fade-up-3 { animation: fadeUp .7s .2s ease both; }
.fade-up-4 { animation: fadeUp .7s .3s ease both; }
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── XP pop animation ────────────────────────────────────────────── */

.xp-pop {
  position: fixed; z-index: 9999;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px; font-weight: 700;
  color: var(--em);
  pointer-events: none;
  animation: xpPop 1.5s ease forwards;
}
@keyframes xpPop {
  0%   { opacity: 1; transform: translateY(0); }
  100% { opacity: 0; transform: translateY(-50px); }
}

/* ── Toast notifications ─────────────────────────────────────────── */

#toastWrap {
  position: fixed; bottom: 24px; right: 24px; z-index: 9000;
  display: flex; flex-direction: column; gap: 8px; align-items: flex-end;
}
.toast {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 16px; border-radius: 10px;
  font-size: 12px; font-weight: 500;
  border: 1px solid; max-width: 320px;
  animation: toastIn .3s ease;
  transition: opacity .3s;
}
@keyframes toastIn { from { opacity: 0; transform: translateX(20px); } }
.toast.xp   { background: rgba(0,200,83,.12); border-color: rgba(0,200,83,.3); color: var(--em); }
.toast.badge { background: rgba(201,168,76,.12); border-color: rgba(201,168,76,.3); color: var(--gold2); }
.toast.err  { background: rgba(224,82,82,.12); border-color: rgba(224,82,82,.3); color: var(--coral); }
.toast-icon { font-size: 16px; flex-shrink: 0; }

/* ── Config banner ───────────────────────────────────────────────── */

.config-banner {
  position: sticky; top: 0; z-index: 800;
  background: rgba(4,12,6,.95); border-bottom: 1px solid var(--border);
  padding: 8px 20px; display: flex; align-items: center; gap: 10px;
  font-size: 10px; color: var(--silver); backdrop-filter: blur(8px);
  flex-wrap: wrap;
}
.config-banner input {
  background: var(--panel); border: 1px solid var(--border);
  border-radius: 6px; padding: 5px 10px; font-size: 10px; color: var(--white);
  width: 180px; outline: none;
}
.config-banner input:focus { border-color: var(--em3); }
.config-save {
  background: var(--em3); border: 1px solid var(--em2); border-radius: 6px;
  color: var(--em); padding: 5px 14px; font-size: 10px; font-weight: 700;
  cursor: pointer; letter-spacing: .1em;
  transition: background .2s;
}
.config-save:hover { background: rgba(0,94,32,.8); }

/* ── Holographic rule divider ────────────────────────────────────── */

.holo-rule {
  height: 1px; margin: 0;
  background: linear-gradient(90deg, transparent, var(--em3) 20%, var(--teal) 50%, var(--em3) 80%, transparent);
}

/* ── Page system ─────────────────────────────────────────────────── */

.page { display: none; position: relative; z-index: 1; min-height: calc(100vh - 60px); }
.page.on { display: block; }

/* ── Modal system ────────────────────────────────────────────────── */

.modal-bg {
  position: fixed; inset: 0; z-index: 5000;
  background: rgba(2,9,5,.85); backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
}
.modal-bg.hidden { display: none; }
.modal {
  background: var(--panel); border: 1px solid var(--border2);
  border-radius: 16px; padding: 28px; width: 100%; max-width: 480px;
  position: relative;
}
.modal-close {
  position: absolute; top: 14px; right: 14px;
  background: none; border: 1px solid var(--border); border-radius: 6px;
  color: var(--muted); font-size: 12px; width: 28px; height: 28px;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
}
.modal-close:hover { color: var(--white); border-color: var(--border2); }
.modal-title { font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 700; margin-bottom: 18px; }
.modal-tabs { display: flex; gap: 0; border: 1px solid var(--border); border-radius: 8px; overflow: hidden; margin-bottom: 16px; }
.mt {
  flex: 1; padding: 8px; font-size: 11px; font-weight: 600;
  background: transparent; border: none; color: var(--muted);
  cursor: pointer; letter-spacing: .1em; transition: all .2s;
}
.mt.on { background: var(--em3); color: var(--em); }
.modal-input {
  width: 100%; background: var(--card); border: 1px solid var(--border);
  border-radius: 8px; padding: 11px 14px; font-size: 13px; color: var(--white);
  margin-bottom: 10px; outline: none;
}
.modal-input:focus { border-color: var(--em3); }
.modal-err {
  background: rgba(224,82,82,.1); border: 1px solid rgba(224,82,82,.3);
  border-radius: 8px; padding: 10px 14px; font-size: 12px; color: var(--coral);
  margin-bottom: 12px;
}
.modal-textarea {
  width: 100%; background: var(--card); border: 1px solid var(--border);
  border-radius: 8px; padding: 11px 14px; font-size: 13px; color: var(--white);
  margin-bottom: 10px; outline: none; resize: vertical; min-height: 100px;
}

/* ── Buttons ─────────────────────────────────────────────────────── */

.btn-p {
  background: linear-gradient(135deg, var(--em3), rgba(0,94,32,.6));
  border: 1px solid var(--em3); border-radius: 8px;
  color: var(--em); padding: 11px 22px; font-size: 11px; font-weight: 700;
  letter-spacing: .12em; cursor: pointer;
  transition: all .2s;
}
.btn-p:hover { background: rgba(0,94,32,.8); border-color: var(--em2); }
.btn-s {
  background: transparent; border: 1px solid var(--border2);
  border-radius: 8px; color: var(--silver); padding: 11px 22px;
  font-size: 11px; font-weight: 600; letter-spacing: .12em; cursor: pointer;
  transition: all .2s;
}
.btn-s:hover { border-color: var(--em3); color: var(--white); }

/* ── Type badges ─────────────────────────────────────────────────── */

.type-indica  { background: rgba(80,0,160,.2); border: 1px solid rgba(80,0,160,.4); color: var(--lav); padding: 3px 10px; border-radius: 100px; font-size: 9px; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; }
.type-sativa  { background: rgba(0,200,83,.1); border: 1px solid var(--em3); color: var(--em); padding: 3px 10px; border-radius: 100px; font-size: 9px; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; }
.type-hybrid  { background: rgba(0,212,255,.1); border: 1px solid rgba(0,212,255,.2); color: var(--cyan); padding: 3px 10px; border-radius: 100px; font-size: 9px; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; }

/* ── Eyebrow text ────────────────────────────────────────────────── */

.eyebrow {
  display: flex; align-items: center; gap: 10px;
  font-size: 9px; letter-spacing: .25em; text-transform: uppercase;
  color: var(--muted); font-weight: 500;
}
.eyebrow::before, .eyebrow::after {
  content: ''; flex: 1; height: 1px;
  background: linear-gradient(90deg, transparent, var(--em3));
}
.eyebrow::after { background: linear-gradient(90deg, var(--em3), transparent); }

/* ── Section title ───────────────────────────────────────────────── */

.sec-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 20px; font-weight: 700; margin-bottom: 16px;
}
