/* ═══════════════════════════════════════════
   OBSIDIAN SMP — Global Stylesheet
   ═══════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;900&family=JetBrains+Mono:wght@300;400;500;600&display=swap');

/* ── Variables ─────────────────────────── */
:root {
  --bg:       #0a0a0f;
  --bg2:      #0f0f1a;
  --bg3:      #13131f;
  --bg4:      #1a1a2e;
  --p1:       #7c3aed;
  --p2:       #a855f7;
  --p3:       #c084fc;
  --p4:       #e9d5ff;
  --glow:     rgba(124,58,237,0.35);
  --glow2:    rgba(168,85,247,0.18);
  --glass:    rgba(124,58,237,0.07);
  --glass2:   rgba(124,58,237,0.12);
  --border:   rgba(124,58,237,0.22);
  --border2:  rgba(168,85,247,0.38);
  --text:     #e2d9f3;
  --text2:    #9d8ec4;
  --text3:    #6b5e8a;
  --green:    #22c55e;
  --red:      #ef4444;
  --yellow:   #eab308;
  --sidebar:  248px;
  --radius:   14px;
  --radius-sm:8px;
}

/* ── Reset ─────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: 'JetBrains Mono', monospace;
  min-height: 100vh;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* ── Scrollbar ─────────────────────────── */
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background: var(--bg2); }
::-webkit-scrollbar-thumb { background: var(--p1); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background: var(--p2); }

/* ── Background Effects ────────────────── */
.bg-grid {
  position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background-image:
    linear-gradient(rgba(124,58,237,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(124,58,237,0.04) 1px, transparent 1px);
  background-size: 44px 44px;
}
.bg-noise {
  position: fixed; inset: 0; pointer-events: none; z-index: 0; opacity: 0.35;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
}
.orb {
  position: fixed; border-radius: 50%;
  filter: blur(110px); pointer-events: none; z-index: 0;
  will-change: transform;
}
.orb-1 { width:700px; height:700px; background:rgba(124,58,237,0.11); top:-250px; left:-250px; animation: orbDrift 14s ease-in-out infinite; }
.orb-2 { width:500px; height:500px; background:rgba(168,85,247,0.07); bottom:-150px; right:-150px; animation: orbDrift 18s ease-in-out infinite reverse 2s; }
.orb-3 { width:350px; height:350px; background:rgba(192,132,252,0.05); top:40%; left:55%; animation: orbDrift 22s ease-in-out infinite 6s; }

@keyframes orbDrift {
  0%,100% { transform:translate(0,0) scale(1); }
  33%      { transform:translate(35px,-25px) scale(1.05); }
  66%      { transform:translate(-25px,35px) scale(0.97); }
}

/* ── Custom Cursor ─────────────────────── */
.cursor {
  width:10px; height:10px; border-radius:50%;
  background: var(--p2); position:fixed; pointer-events:none;
  z-index:9999; transform:translate(-50%,-50%);
  box-shadow: 0 0 14px var(--p2), 0 0 28px var(--glow);
  transition: transform 0.08s ease, width 0.2s, height 0.2s;
}
.cursor-ring {
  width:38px; height:38px; border-radius:50%;
  border:1px solid rgba(168,85,247,0.45);
  position:fixed; pointer-events:none; z-index:9998;
  transform:translate(-50%,-50%);
  transition: all 0.14s ease;
}
body:not(.page-body) .cursor,
body:not(.page-body) .cursor-ring { display:none; }

/* ── Glassmorphism Cards ───────────────── */
.glass-card {
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  transition: border-color 0.3s, box-shadow 0.3s, transform 0.3s;
}
.glass-card:hover {
  border-color: var(--border2);
  box-shadow: 0 8px 32px var(--glow2);
  transform: translateY(-2px);
}
.glass-card::before {
  content:''; position:absolute; inset:0; border-radius:inherit;
  background:linear-gradient(135deg,rgba(255,255,255,0.03),transparent);
  pointer-events:none;
}

/* ── Gradient Text ─────────────────────── */
.grad-text {
  background: linear-gradient(135deg, #fff 0%, var(--p3) 45%, var(--p2) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.grad-text-purple {
  background: linear-gradient(135deg, var(--p3), var(--p2));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}

/* ── Buttons ───────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 22px; border-radius:var(--radius-sm);
  font-family:'JetBrains Mono',monospace; font-size:0.75rem;
  letter-spacing:0.06em; cursor:pointer; border:none;
  transition:all 0.25s; position:relative; overflow:hidden;
}
.btn::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,0.1),transparent);
  opacity:0; transition:opacity 0.2s;
}
.btn:hover::after { opacity:1; }
.btn-primary {
  background:linear-gradient(135deg,var(--p1),var(--p2));
  color:#fff; box-shadow:0 4px 20px var(--glow);
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 32px var(--glow); }
.btn-ghost {
  background:var(--glass); color:var(--p3);
  border:1px solid var(--border);
}
.btn-ghost:hover { background:var(--glass2); border-color:var(--border2); }
.btn-danger {
  background:rgba(239,68,68,0.1); color:var(--red);
  border:1px solid rgba(239,68,68,0.3);
}
.btn-danger:hover { background:rgba(239,68,68,0.2); }
.btn-success {
  background:rgba(34,197,94,0.1); color:var(--green);
  border:1px solid rgba(34,197,94,0.3);
}
.btn-success:hover { background:rgba(34,197,94,0.2); }

/* ── Badges ────────────────────────────── */
.badge { display:inline-block; padding:3px 10px; border-radius:20px; font-size:0.6rem; letter-spacing:0.1em; text-transform:uppercase; }
.badge-pending  { background:rgba(234,179,8,0.12);  color:var(--yellow); border:1px solid rgba(234,179,8,0.28); }
.badge-done     { background:rgba(34,197,94,0.1);   color:var(--green);  border:1px solid rgba(34,197,94,0.28); }
.badge-dismissed{ background:rgba(239,68,68,0.08);  color:var(--red);    border:1px solid rgba(239,68,68,0.22); }
.badge-online   { background:rgba(34,197,94,0.1);   color:var(--green);  border:1px solid rgba(34,197,94,0.28); }
.badge-offline  { background:rgba(239,68,68,0.08);  color:var(--red);    border:1px solid rgba(239,68,68,0.22); }

/* ── Status Dot ────────────────────────── */
.dot { width:8px; height:8px; border-radius:50%; display:inline-block; flex-shrink:0; }
.dot-green { background:var(--green); box-shadow:0 0 8px var(--green); animation:dotPulse 2s ease-in-out infinite; }
.dot-red   { background:var(--red);   box-shadow:0 0 8px var(--red); }
.dot-yellow{ background:var(--yellow);box-shadow:0 0 8px var(--yellow); }
@keyframes dotPulse { 0%,100%{opacity:1} 50%{opacity:0.55} }

/* ── Section Labels ────────────────────── */
.section-label {
  font-size:0.62rem; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--p3); display:flex; align-items:center; gap:12px; margin-bottom:20px;
}
.section-label::after { content:''; flex:1; height:1px; background:linear-gradient(90deg,var(--border),transparent); }

/* ── Toast ─────────────────────────────── */
#toast {
  position:fixed; bottom:32px; left:50%;
  transform:translateX(-50%) translateY(80px);
  background:var(--bg3); border:1px solid var(--border2);
  padding:12px 28px; border-radius:40px;
  font-size:0.75rem; color:var(--p3);
  backdrop-filter:blur(20px);
  transition:transform 0.35s cubic-bezier(0.34,1.56,0.64,1);
  z-index:9990; box-shadow:0 8px 32px var(--glow2);
  white-space:nowrap;
}
#toast.show { transform:translateX(-50%) translateY(0); }

/* ── Animations ────────────────────────── */
@keyframes fadeUp   { from{opacity:0;transform:translateY(18px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn   { from{opacity:0} to{opacity:1} }
@keyframes scaleIn  { from{opacity:0;transform:scale(0.94)} to{opacity:1;transform:scale(1)} }
@keyframes slideLeft{ from{opacity:0;transform:translateX(20px)} to{opacity:1;transform:translateX(0)} }
@keyframes shimmer  {
  0%   { background-position:-200% center; }
  100% { background-position: 200% center; }
}

.anim-fade-up  { animation:fadeUp  0.5s ease both; }
.anim-fade-in  { animation:fadeIn  0.4s ease both; }
.anim-scale-in { animation:scaleIn 0.4s ease both; }

/* Stagger helpers */
.delay-1 { animation-delay:0.08s; }
.delay-2 { animation-delay:0.16s; }
.delay-3 { animation-delay:0.24s; }
.delay-4 { animation-delay:0.32s; }
.delay-5 { animation-delay:0.40s; }

/* ── Obsidian Block ────────────────────── */
.obs-block {
  display:grid; grid-template-columns:repeat(4,1fr); grid-template-rows:repeat(4,1fr);
  gap:1.5px; border-radius:5px; overflow:hidden;
}
.obs-block span { display:block; animation:blockFlicker 3s ease-in-out infinite; }
.obs-block span:nth-child(1)  { background:#1a0a2e; }
.obs-block span:nth-child(2)  { background:#7c3aed; animation-delay:0.2s; }
.obs-block span:nth-child(3)  { background:#0f0f1a; animation-delay:0.5s; }
.obs-block span:nth-child(4)  { background:#2d1060; animation-delay:0.1s; }
.obs-block span:nth-child(5)  { background:#7c3aed; animation-delay:0.7s; }
.obs-block span:nth-child(6)  { background:#0a0a0f; animation-delay:0.3s; }
.obs-block span:nth-child(7)  { background:#a855f7; animation-delay:0.9s; }
.obs-block span:nth-child(8)  { background:#1a0a2e; animation-delay:0.4s; }
.obs-block span:nth-child(9)  { background:#0f0f1a; animation-delay:0.6s; }
.obs-block span:nth-child(10) { background:#2d1060; animation-delay:0.8s; }
.obs-block span:nth-child(11) { background:#7c3aed; animation-delay:0.2s; }
.obs-block span:nth-child(12) { background:#0a0a0f; animation-delay:1.0s; }
.obs-block span:nth-child(13) { background:#a855f7; animation-delay:0.5s; }
.obs-block span:nth-child(14) { background:#1a0a2e; animation-delay:0.3s; }
.obs-block span:nth-child(15) { background:#7c3aed; animation-delay:0.7s; }
.obs-block span:nth-child(16) { background:#0f0f1a; animation-delay:0.1s; }
@keyframes blockFlicker { 0%,100%{opacity:1} 50%{opacity:0.65} }

/* ── Input ─────────────────────────────── */
.input {
  background:rgba(0,0,0,0.35); border:1px solid var(--border);
  border-radius:var(--radius-sm); color:var(--text);
  font-family:'JetBrains Mono',monospace; font-size:0.82rem;
  padding:11px 16px; outline:none; width:100%;
  transition:border-color 0.2s, box-shadow 0.2s;
}
.input:focus { border-color:var(--p2); box-shadow:0 0 0 3px rgba(168,85,247,0.12); }
.input::placeholder { color:var(--text3); }

/* ── Header ────────────────────────────── */
.site-header {
  position:fixed; top:0; left:0; right:0; z-index:100;
  padding:14px 0;
  background:rgba(10,10,15,0.82);
  backdrop-filter:blur(22px);
  border-bottom:1px solid var(--border);
}
.header-inner {
  max-width:1240px; margin:0 auto; padding:0 28px;
  display:flex; align-items:center; justify-content:space-between;
}
.site-logo {
  display:flex; align-items:center; gap:12px;
  font-family:'Cinzel',serif; font-size:1.15rem; font-weight:900;
  color:var(--p3); letter-spacing:0.08em;
  text-decoration:none;
  text-shadow:0 0 24px var(--glow);
}
.site-nav { display:flex; gap:4px; }
.site-nav a {
  color:var(--text2); text-decoration:none; font-size:0.72rem;
  padding:7px 16px; border-radius:var(--radius-sm); letter-spacing:0.05em;
  border:1px solid transparent; transition:all 0.2s;
}
.site-nav a:hover { color:var(--p3); border-color:var(--border); background:var(--glass); }

/* ── Footer ────────────────────────────── */
.site-footer {
  border-top:1px solid var(--border);
  padding:36px 0; text-align:center;
  color:var(--text3); font-size:0.68rem; letter-spacing:0.1em;
}
.site-footer a { color:var(--p3); text-decoration:none; }
.site-footer a:hover { text-decoration:underline; }

/* ── Responsive ────────────────────────── */
@media (max-width:768px) {
  :root { --sidebar:0px; }
  .site-nav { display:none; }
  .orb-1 { width:350px; height:350px; }
  .orb-2 { width:250px; height:250px; }
}
