/* WBF Academy — Custom CSS */

/* ─── Custom properties ─────────────────────────────────────── */
:root {
  --color-bg:         #020617;
  --color-surface:    #0f172a;
  --color-surface-2:  #1e293b;
  --color-border:     #1e293b;
  --color-accent:     #7c3aed;
  --color-accent-lg:  #8b5cf6;
  --color-text:       #e2e8f0;
  --color-muted:      #64748b;
  --color-success:    #10b981;
  --color-warning:    #f59e0b;
  --color-danger:     #ef4444;
  --sidebar-w:        240px;
  --radius:           0.75rem;
  --transition:       150ms ease;
}

/* ─── Base ──────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: 'Inter', system-ui, sans-serif; background: var(--color-bg); color: var(--color-text); }

/* ─── Scrollbar ─────────────────────────────────────────────── */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: var(--color-bg); }
::-webkit-scrollbar-thumb { background: var(--color-surface-2); border-radius: 999px; }
::-webkit-scrollbar-thumb:hover { background: #334155; }

/* ─── Sidebar links ─────────────────────────────────────────── */
.sidebar-link {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.5rem 0.75rem;
  border-radius: 0.5rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: #94a3b8;
  transition: background var(--transition), color var(--transition);
  text-decoration: none;
}
.sidebar-link:hover {
  background: rgba(139, 92, 246, 0.1);
  color: #a78bfa;
}
.sidebar-active {
  background: rgba(139, 92, 246, 0.15);
  color: #a78bfa;
}
.sidebar-danger { color: #f87171; }
.sidebar-danger:hover { background: rgba(239, 68, 68, 0.1); color: #fca5a5; }

/* ─── Cards ─────────────────────────────────────────────────── */
.card {
  background: var(--color-surface);
  border-radius: var(--radius);
  border: 1px solid var(--color-border);
}

/* ─── Buttons ───────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  font-weight: 500;
  border-radius: 0.5rem;
  cursor: pointer;
  transition: background var(--transition), opacity var(--transition), transform 60ms;
  text-decoration: none;
  border: none;
}
.btn:active { transform: scale(0.97); }
.btn-primary { background: var(--color-accent); color: #fff; padding: 0.5rem 1rem; }
.btn-primary:hover { background: var(--color-accent-lg); }
.btn-secondary { background: var(--color-surface-2); color: #cbd5e1; padding: 0.5rem 1rem; }
.btn-secondary:hover { background: #334155; }
.btn-sm { padding: 0.375rem 0.75rem; font-size: 0.8125rem; }
.btn-lg { padding: 0.75rem 1.5rem; font-size: 1rem; }
.btn:disabled, .btn[data-loading="true"] { opacity: 0.55; cursor: not-allowed; transform: none; }

/* ─── Inputs ────────────────────────────────────────────────── */
.input {
  background: var(--color-surface-2);
  border: 1px solid #334155;
  color: #f1f5f9;
  border-radius: 0.5rem;
  padding: 0.625rem 1rem;
  font-size: 0.875rem;
  width: 100%;
  transition: border-color var(--transition), box-shadow var(--transition);
  outline: none;
}
.input::placeholder { color: #475569; }
.input:focus {
  border-color: var(--color-accent-lg);
  box-shadow: 0 0 0 2px rgba(139, 92, 246, 0.3);
}
.input-error { border-color: var(--color-danger) !important; }
.field-error { font-size: 0.75rem; color: #f87171; margin-top: 0.25rem; }

/* ─── Labels ────────────────────────────────────────────────── */
label { font-size: 0.875rem; font-weight: 500; color: #cbd5e1; }

/* ─── Code / syntax highlighting ────────────────────────────── */
pre, code {
  font-family: 'Fira Code', 'Cascadia Code', 'JetBrains Mono', monospace;
  font-size: 0.8125rem;
  line-height: 1.6;
}
pre {
  background: #0d1117;
  border: 1px solid #1e293b;
  border-radius: 0.625rem;
  padding: 1.25rem 1.5rem;
  overflow-x: auto;
  color: #c9d1d9;
}
.code-kw  { color: #ff7b72; }   /* keyword */
.code-fn  { color: #d2a8ff; }   /* function/type */
.code-str { color: #a5d6ff; }   /* string */
.code-cm  { color: #8b949e; }   /* comment */
.code-num { color: #f0883e; }   /* number */
.code-op  { color: #79c0ff; }   /* operator/punct */
.code-var { color: #ffa657; }   /* variable */

/* ─── Quiz options ──────────────────────────────────────────── */
.quiz-option {
  display: flex;
  align-items: center;
  gap: 0.875rem;
  padding: 0.875rem 1rem;
  border-radius: 0.625rem;
  border: 1px solid #1e293b;
  background: #0f172a;
  cursor: pointer;
  transition: border-color var(--transition), background var(--transition);
  font-size: 0.9375rem;
  color: #e2e8f0;
}
.quiz-option:hover { border-color: #7c3aed; background: rgba(124, 58, 237, 0.07); }
.quiz-option.selected { border-color: #7c3aed; background: rgba(124, 58, 237, 0.15); }
.quiz-option.correct  { border-color: #10b981; background: rgba(16, 185, 129, 0.1); }
.quiz-option.incorrect { border-color: #ef4444; background: rgba(239, 68, 68, 0.1); }

/* ─── Progress bar ──────────────────────────────────────────── */
.progress-bar { height: 6px; border-radius: 999px; background: #1e293b; overflow: hidden; }
.progress-fill {
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, #7c3aed, #6366f1);
  transition: width 0.4s ease;
  animation: progress-glow 2s ease-in-out infinite alternate;
}
@keyframes progress-glow {
  from { box-shadow: none; }
  to   { box-shadow: 0 0 8px rgba(139, 92, 246, 0.6); }
}

/* ─── Skeleton loading ──────────────────────────────────────── */
.skeleton {
  background: linear-gradient(90deg, #1e293b 25%, #2d3f55 50%, #1e293b 75%);
  background-size: 200% 100%;
  animation: skeleton-shimmer 1.5s infinite;
  border-radius: 0.375rem;
}
@keyframes skeleton-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ─── Streak flame animation ────────────────────────────────── */
.flame {
  display: inline-block;
  animation: flame-flicker 0.8s ease-in-out infinite alternate;
  transform-origin: bottom center;
}
@keyframes flame-flicker {
  0%   { transform: scaleY(1) rotate(-2deg); filter: brightness(1); }
  50%  { transform: scaleY(1.08) rotate(0deg); filter: brightness(1.15); }
  100% { transform: scaleY(0.95) rotate(2deg); filter: brightness(0.9); }
}

/* ─── Toast notifications ───────────────────────────────────── */
.toast {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  border-radius: 0.625rem;
  border: 1px solid transparent;
  font-size: 0.875rem;
  font-weight: 500;
  pointer-events: auto;
  animation: toast-in 0.25s ease forwards;
  max-width: 20rem;
  box-shadow: 0 8px 32px rgba(0,0,0,0.4);
}
@keyframes toast-in {
  from { opacity: 0; transform: translateX(1rem); }
  to   { opacity: 1; transform: translateX(0); }
}
.toast-out { animation: toast-out 0.2s ease forwards; }
@keyframes toast-out {
  from { opacity: 1; transform: translateX(0); }
  to   { opacity: 0; transform: translateX(1rem); }
}
.toast-success { background: #052e16; border-color: rgba(16,185,129,0.3); color: #6ee7b7; }
.toast-error   { background: #2d0a0a; border-color: rgba(239,68,68,0.3);  color: #fca5a5; }
.toast-warning { background: #1c1000; border-color: rgba(245,158,11,0.3); color: #fde68a; }
.toast-info    { background: #0a192f; border-color: rgba(99,102,241,0.3); color: #a5b4fc; }

/* ─── Badge pill ────────────────────────────────────────────── */
.badge-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  padding: 0.2rem 0.6rem;
  border-radius: 999px;
  border: 1px solid transparent;
  text-transform: uppercase;
}

/* ─── Gradient text ─────────────────────────────────────────── */
.text-gradient {
  background: linear-gradient(135deg, #a78bfa 0%, #818cf8 50%, #67e8f9 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ─── Glassmorphism ─────────────────────────────────────────── */
.glass {
  background: rgba(15, 23, 42, 0.6);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(255, 255, 255, 0.07);
}

/* ─── Gradient border card ──────────────────────────────────── */
.card-glow {
  position: relative;
}
.card-glow::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: calc(var(--radius) + 1px);
  background: linear-gradient(135deg, rgba(124,58,237,0.4), rgba(99,102,241,0.2), transparent 60%);
  z-index: -1;
}

/* ─── Hero background animation ─────────────────────────────── */
.hero-grid {
  background-image:
    linear-gradient(rgba(124, 58, 237, 0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(124, 58, 237, 0.06) 1px, transparent 1px);
  background-size: 60px 60px;
}
.hero-glow {
  background: radial-gradient(ellipse 80% 50% at 50% -10%, rgba(124, 58, 237, 0.25), transparent);
}

/* ─── Floating animation ─────────────────────────────────────── */
.float {
  animation: float 4s ease-in-out infinite;
}
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-10px); }
}

/* ─── Fade-in on scroll (CSS only fallback) ──────────────────── */
.fade-up {
  animation: fade-up 0.6s ease both;
}
@keyframes fade-up {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}
.delay-100 { animation-delay: 0.1s; }
.delay-200 { animation-delay: 0.2s; }
.delay-300 { animation-delay: 0.3s; }
.delay-400 { animation-delay: 0.4s; }
.delay-500 { animation-delay: 0.5s; }

/* ─── Pulse dot ─────────────────────────────────────────────── */
.pulse-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--color-success);
  animation: pulse-dot 2s ease infinite;
}
@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.5; transform: scale(1.4); }
}

/* ─── Responsive ────────────────────────────────────────────── */
@media (max-width: 767px) {
  .input { font-size: 1rem; }   /* prevent iOS zoom */
}
