/* DESIGN.md: Vercel-Inspired — Black-ink precision, Geist/Inter, mesh gradient */
/* Fonts */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=JetBrains+Mono&display=swap');

* { margin: 0; padding: 0; box-sizing: border-box; }

:root {
  /* Brand */
  --ink: #171717;
  --ink-on: #ffffff;
  --body: #4d4d4d;
  --mute: #888888;
  --hairline: #ebebeb;
  --hairline-strong: #a1a1a1;
  --canvas: #ffffff;
  --canvas-soft: #fafafa;
  --canvas-soft2: #f5f5f5;
  --link: #0070f3;
  --link-deep: #0761d1;
  --success: #0070f3;
  --error: #ee0000;
  --error-soft: #f7d4d6;
  --warning: #f5a623;
  --warning-soft: #ffefcf;
  --violet: #7928ca;
  --cyan: #50e3c2;
  --highlight-pink: #ff0080;
  --highlight-magenta: #eb367f;
  --gradient-dev-start: #007cf0;
  --gradient-dev-end: #00dfd8;
  --gradient-preview-start: #7928ca;
  --gradient-preview-end: #ff0080;
  --gradient-ship-start: #ff4d4d;
  --gradient-ship-end: #f9cb28;

  /* Typography */
  --font-sans: 'Inter', system-ui, -apple-system, sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, Monaco, monospace;

  /* Display */
  --display-xl-size: 48px;
  --display-xl-lh: 48px;
  --display-xl-ls: -2.4px;
  --display-lg-size: 32px;
  --display-lg-lh: 40px;
  --display-lg-ls: -1.28px;
  --display-md-size: 24px;
  --display-md-lh: 32px;
  --display-md-ls: -0.96px;
  --display-sm-size: 20px;
  --display-sm-lh: 28px;
  --display-sm-ls: -0.6px;

  /* Body */
  --body-lg-size: 18px; --body-lg-lh: 28px;
  --body-md-size: 16px; --body-md-lh: 24px;
  --body-sm-size: 14px; --body-sm-lh: 20px;
  --caption-size: 12px; --caption-lh: 16px;
  --code-size: 13px; --code-lh: 20px;

  /* Shapes */
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-pill: 100px;
  --radius-full: 9999px;

  /* Spacing */
  --space-xs: 8px;
  --space-sm: 12px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 32px;
  --space-2xl: 40px;
  --space-3xl: 48px;
  --space-4xl: 64px;
  --space-5xl: 96px;

  /* Shadows — stacked, subtle */
  --shadow-card: 0 0 0 1px rgba(0,0,0,0.08), 0px 1px 1px rgba(0,0,0,0.02), 0px 2px 2px rgba(0,0,0,0.04);
  --shadow-card-lg: 0 0 0 1px rgba(0,0,0,0.08), 0px 2px 2px rgba(0,0,0,0.04), 0px 8px 16px -4px rgba(0,0,0,0.04);
  --shadow-modal: 0 0 0 1px rgba(0,0,0,0.08), 0px 8px 16px -4px rgba(0,0,0,0.04), 0px 24px 32px -8px rgba(0,0,0,0.06);
}

body {
  font-family: var(--font-sans);
  font-size: var(--body-md-size);
  line-height: var(--body-md-lh);
  font-weight: 400;
  color: var(--ink);
  background: var(--canvas-soft);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

/* ─── Navigation Bar ─── */
.nav-bar {
  background: var(--canvas);
  color: var(--ink);
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--space-lg);
  position: sticky;
  top: 0;
  z-index: 100;
  border-bottom: 1px solid var(--hairline);
  font-size: var(--body-sm-size);
  font-weight: 500;
}
.nav-bar .nav-brand {
  font-size: var(--body-sm-size);
  font-weight: 600;
  color: var(--ink);
  text-decoration: none;
  letter-spacing: -0.28px;
}
.nav-bar .nav-links {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}
.nav-bar .nav-stats {
  font-size: var(--caption-size);
  color: var(--body);
  font-weight: 400;
}

/* ─── Buttons ─── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  border: none;
  font-family: var(--font-sans);
  font-weight: 500;
  cursor: pointer;
  text-decoration: none;
  transition: all 0.15s ease;
}
.btn-primary {
  background: var(--ink);
  color: var(--ink-on);
  font-size: 16px;
  line-height: 24px;
  padding: 0 var(--space-xl);
  height: 48px;
  border-radius: var(--radius-pill);
}
.btn-primary:hover {
  background: #333333;
}
.btn-secondary {
  background: var(--canvas);
  color: var(--ink);
  font-size: 16px;
  line-height: 24px;
  padding: 0 var(--space-xl);
  height: 48px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--hairline);
}
.btn-secondary:hover {
  border-color: var(--hairline-strong);
}
.btn-ghost {
  background: transparent;
  color: var(--body);
  font-size: var(--body-sm-size);
  line-height: var(--body-sm-lh);
  padding: var(--space-xs) var(--space-sm);
  border-radius: var(--radius-full);
}
.btn-ghost:hover {
  background: var(--canvas-soft);
  color: var(--ink);
}
.btn-sm {
  font-size: var(--body-sm-size);
  line-height: var(--body-sm-lh);
  padding: 0 var(--space-sm);
  height: 32px;
  border-radius: var(--radius-pill);
}
.btn-primary-sm {
  background: var(--ink);
  color: var(--ink-on);
  font-size: var(--body-sm-size);
  line-height: var(--body-sm-lh);
  padding: 0 var(--space-sm);
  height: 32px;
  border-radius: var(--radius-sm);
  font-weight: 500;
}
.btn-primary-sm:hover { background: #333333; }
.btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* ─── Layout ─── */
.container { max-width: 1040px; margin: 0 auto; padding: var(--space-lg) var(--space-lg) var(--space-4xl); }

/* ─── Chapter Section ─── */
.chapter-section {
  background: var(--canvas);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
  margin-bottom: var(--space-sm);
  overflow: hidden;
}
.chapter-header {
  display: flex;
  align-items: center;
  padding: var(--space-md) var(--space-lg);
  cursor: pointer;
  user-select: none;
  transition: background 0.15s;
  gap: var(--space-sm);
}
.chapter-header:hover { background: var(--canvas-soft); }
.chapter-number {
  width: 32px; height: 32px;
  background: var(--ink);
  color: var(--ink-on);
  border-radius: var(--radius-full);
  display: flex; align-items: center; justify-content: center;
  font-size: var(--caption-size);
  font-weight: 600;
  flex-shrink: 0;
}
.chapter-info { flex: 1; min-width: 0; }
.chapter-info h3 {
  font-size: var(--body-sm-size);
  font-weight: 600;
  letter-spacing: -0.28px;
}
.chapter-desc {
  font-size: var(--caption-size);
  color: var(--mute);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.chapter-progress {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--caption-size);
  color: var(--mute);
  flex-shrink: 0;
}
.progress-bar {
  width: 64px; height: 4px;
  background: var(--hairline);
  border-radius: 2px;
  overflow: hidden;
}
.progress-fill {
  height: 100%;
  background: var(--ink);
  border-radius: 2px;
  transition: width 0.3s;
}
.chapter-arrow {
  font-size: var(--caption-size);
  color: var(--mute);
  transition: transform 0.2s;
  margin-left: var(--space-xs);
}
.chapter-section.open .chapter-arrow { transform: rotate(180deg); }

/* ─── Exercise Card Grid ─── */
.exercise-grid {
  display: none;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: var(--space-sm);
  padding: 0 var(--space-lg) var(--space-md);
}
.chapter-section.open .exercise-grid { display: grid; }
.exercise-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: var(--space-md);
  background: var(--canvas-soft);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-sm);
  cursor: pointer;
  text-decoration: none;
  color: var(--ink);
  position: relative;
  transition: all 0.15s ease;
}
.exercise-card:hover {
  box-shadow: var(--shadow-card);
  border-color: var(--hairline-strong);
}
.exercise-card.completed {
  background: var(--canvas);
  border-color: var(--ink);
}
.exercise-card .ex-level {
  font-family: var(--font-mono);
  font-size: var(--caption-size);
  font-weight: 600;
  color: var(--mute);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.exercise-card .ex-title {
  font-size: var(--body-sm-size);
  font-weight: 500;
  text-align: center;
  line-height: var(--body-sm-lh);
}
.exercise-card .ex-type-icon {
  font-size: 11px;
  font-weight: 500;
  padding: 1px 8px;
  border-radius: var(--radius-full);
  background: var(--canvas);
  color: var(--body);
  border: 1px solid var(--hairline);
}
.exercise-card .ex-status {
  position: absolute; top: var(--space-xs); right: var(--space-xs);
  font-size: 10px;
}
.completed-badge { color: var(--ink); font-weight: 700; }
.difficulty-stars { color: var(--warning); font-size: 11px; margin-top: 2px; }

/* ─── Exercise Page ─── */
.exercise-container { max-width: 700px; margin: 0 auto; padding: var(--space-xl) var(--space-lg); }
.exercise-meta { margin-bottom: var(--space-lg); }
.exercise-meta h2 {
  font-size: var(--display-sm-size);
  font-weight: 600;
  line-height: var(--display-sm-lh);
  letter-spacing: var(--display-sm-ls);
  margin-bottom: var(--space-xs);
}
.exercise-desc {
  font-size: var(--body-md-size);
  line-height: var(--body-md-lh);
  color: var(--body);
  margin-bottom: var(--space-sm);
}
.exercise-tags { display: flex; gap: var(--space-xs); align-items: center; margin-bottom: var(--space-lg); }

.tag {
  font-size: var(--caption-size);
  font-weight: 500;
  padding: 2px var(--space-sm);
  border-radius: var(--radius-full);
  background: var(--canvas-soft);
  color: var(--body);
  border: 1px solid var(--hairline);
}
.tag.choice-tag { color: var(--link); border-color: var(--link); background: rgba(0,112,243,0.04); }
.tag.drag-tag { color: var(--warning); border-color: var(--warning); background: var(--warning-soft); }

/* ─── Drag & Drop Blocks ─── */
.blocks-panel {
  background: var(--canvas-soft);
  border: 2px dashed var(--hairline);
  border-radius: var(--radius-sm);
  padding: var(--space-sm);
  margin-bottom: var(--space-sm);
  min-height: 60px;
  transition: border-color 0.15s;
}
.blocks-panel:has(.block-item) { border-style: solid; border-color: var(--hairline); }
.panel-label {
  font-family: var(--font-mono);
  font-size: var(--caption-size);
  color: var(--mute);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: var(--space-xs);
  font-weight: 500;
}
.block-item {
  background: var(--canvas);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-sm);
  padding: var(--space-xs) var(--space-sm);
  margin-bottom: var(--space-xs);
  cursor: grab;
  font-family: var(--font-mono);
  font-size: var(--code-size);
  line-height: var(--code-lh);
  white-space: pre-wrap;
  transition: all 0.15s;
}
.block-item:active { cursor: grabbing; }
.block-item:hover { border-color: var(--hairline-strong); }
.block-item.sortable-ghost { opacity: 0.4; background: var(--canvas-soft2); }
.block-item.sortable-chosen { box-shadow: var(--shadow-card-lg); }
.answer-panel {
  background: var(--canvas);
  border: 2px solid var(--ink);
  border-radius: var(--radius-sm);
  padding: var(--space-sm);
  min-height: 60px;
}
.answer-panel .panel-label { color: var(--ink); }

/* ─── Choice Options ─── */
.choice-options { display: flex; flex-direction: column; gap: var(--space-xs); }
.choice-option {
  background: var(--canvas);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-sm);
  padding: var(--space-sm) var(--space-md);
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: var(--code-size);
  line-height: var(--code-lh);
  transition: all 0.15s;
}
.choice-option:hover { border-color: var(--hairline-strong); background: var(--canvas-soft); }
.choice-option.selected {
  border-color: var(--ink);
  background: var(--canvas-soft);
  font-weight: 500;
}
.choice-option.correct { border-color: var(--success); background: rgba(0,112,243,0.04); }
.choice-option.wrong { border-color: var(--error); background: var(--error-soft); }

/* ─── Feedback Overlay ─── */
.feedback-overlay {
  display: none;
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  background: rgba(0,0,0,0.3);
  z-index: 200;
  align-items: center; justify-content: center;
}
.feedback-overlay.show { display: flex; }
.feedback-card {
  background: var(--canvas);
  border-radius: var(--radius-lg);
  padding: var(--space-2xl) var(--space-xl);
  text-align: center;
  max-width: 400px;
  width: 90%;
  box-shadow: var(--shadow-modal);
}
.feedback-icon { font-size: 2.5rem; margin-bottom: var(--space-sm); }
.feedback-title {
  font-size: var(--display-sm-size);
  font-weight: 600;
  line-height: var(--display-sm-lh);
  letter-spacing: var(--display-sm-ls);
  margin-bottom: var(--space-xs);
}
.feedback-text {
  font-size: var(--body-sm-size);
  color: var(--body);
  margin-bottom: var(--space-md);
}
.feedback-actions { display: flex; gap: var(--space-xs); justify-content: center; flex-wrap: wrap; }

/* ─── Action Bar ─── */
.action-bar {
  display: flex; gap: var(--space-sm); align-items: center;
  margin-top: var(--space-lg);
  flex-wrap: wrap;
}
.attempt-counter {
  font-size: var(--caption-size);
  color: var(--mute);
  margin-left: auto;
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* ─── Admin ─── */
.admin-container { max-width: 1040px; margin: 0 auto; padding: var(--space-lg) var(--space-lg) var(--space-4xl); }
.admin-header { margin-bottom: var(--space-xl); }
.admin-header h2 {
  font-size: var(--display-md-size);
  font-weight: 600;
  line-height: var(--display-md-lh);
  letter-spacing: var(--display-md-ls);
  margin-bottom: var(--space-xs);
}
.admin-header p {
  font-size: var(--body-md-size);
  color: var(--body);
}
.stat-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: var(--space-sm); margin-bottom: var(--space-xl); }
.stat-card {
  background: var(--canvas);
  border-radius: var(--radius-sm);
  padding: var(--space-md);
  box-shadow: var(--shadow-card);
}
.stat-card .stat-value {
  font-size: var(--display-sm-size);
  font-weight: 600;
  line-height: var(--display-sm-lh);
  letter-spacing: var(--display-sm-ls);
  color: var(--ink);
}
.stat-card .stat-label {
  font-family: var(--font-mono);
  font-size: var(--caption-size);
  color: var(--mute);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-top: 2px;
}
.chart-container {
  background: var(--canvas);
  border-radius: var(--radius-sm);
  padding: var(--space-lg);
  margin-bottom: var(--space-xl);
  box-shadow: var(--shadow-card);
}
.chart-container h3 {
  font-size: var(--body-sm-size);
  font-weight: 600;
  letter-spacing: -0.28px;
  margin-bottom: var(--space-sm);
}
.data-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--canvas);
  border-radius: var(--radius-sm);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  margin-bottom: var(--space-md);
}
.data-table th, .data-table td {
  padding: var(--space-xs) var(--space-md);
  text-align: left;
  font-size: var(--body-sm-size);
  line-height: var(--body-sm-lh);
  border-bottom: 1px solid var(--hairline);
}
.data-table th {
  background: var(--canvas-soft);
  font-family: var(--font-mono);
  font-size: var(--caption-size);
  font-weight: 500;
  color: var(--mute);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.data-table tr:hover td { background: var(--canvas-soft); }

/* ─── Form Inputs ─── */
.form-input {
  width: 100%;
  background: var(--canvas);
  color: var(--ink);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-sm);
  padding: 0 var(--space-sm);
  height: 40px;
  font-family: var(--font-sans);
  font-size: var(--body-sm-size);
  line-height: var(--body-sm-lh);
  transition: border-color 0.15s;
}
.form-input:focus { outline: none; border-color: var(--ink); }
.form-select {
  width: 100%;
  background: var(--canvas);
  color: var(--ink);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-sm);
  padding: 0 var(--space-sm);
  height: 40px;
  font-family: var(--font-sans);
  font-size: var(--body-sm-size);
  cursor: pointer;
}
.form-select:focus { outline: none; border-color: var(--ink); }
.form-textarea {
  width: 100%;
  background: var(--canvas);
  color: var(--ink);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-sm);
  padding: var(--space-xs) var(--space-sm);
  font-family: var(--font-mono);
  font-size: var(--code-size);
  line-height: var(--code-lh);
  resize: vertical;
  min-height: 100px;
}
.form-textarea:focus { outline: none; border-color: var(--ink); }
.form-label {
  display: block;
  font-family: var(--font-mono);
  font-size: var(--caption-size);
  font-weight: 500;
  color: var(--mute);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: var(--space-xs);
}
.form-group { margin-bottom: var(--space-md); }

/* ─── Hero Band (Vercel hero-band) ─── */
.hero-band {
  position: relative;
  background: var(--canvas);
  color: var(--ink);
  padding: var(--space-5xl) var(--space-lg) var(--space-4xl);
  text-align: center;
  overflow: hidden;
}
.hero-mesh {
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 100%;
  pointer-events: none;
  z-index: 0;
}
.hero-mesh canvas {
  width: 100%;
  height: 100%;
  display: block;
}
.hero-content {
  position: relative;
  z-index: 1;
  max-width: 720px;
  margin: 0 auto;
}
.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--canvas-soft);
  color: var(--body);
  font-family: var(--font-mono);
  font-size: var(--caption-size);
  font-weight: 500;
  padding: 4px var(--space-sm);
  border-radius: var(--radius-full);
  margin-bottom: var(--space-lg);
  border: 1px solid var(--hairline);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.hero-badge .badge-dot {
  width: 6px; height: 6px;
  background: var(--cyan);
  border-radius: 50%;
}
.hero-headline {
  font-size: var(--display-xl-size);
  font-weight: 600;
  line-height: var(--display-xl-lh);
  letter-spacing: var(--display-xl-ls);
  margin-bottom: var(--space-md);
  color: var(--ink);
}
.hero-lead {
  font-size: var(--body-lg-size);
  font-weight: 400;
  line-height: var(--body-lg-lh);
  color: var(--body);
  margin-bottom: var(--space-xl);
}
.hero-cta-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  flex-wrap: wrap;
}
.hero-stat-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-xl);
  margin-top: var(--space-2xl);
  font-size: var(--body-sm-size);
  color: var(--mute);
}
.hero-stat-row .hero-stat-number {
  font-size: var(--display-sm-size);
  font-weight: 600;
  color: var(--ink);
  line-height: var(--display-sm-lh);
  letter-spacing: var(--display-sm-ls);
}
.hero-stat-row .hero-stat-label {
  font-family: var(--font-mono);
  font-size: var(--caption-size);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--mute);
}

/* ─── Animations ─── */
@keyframes shake {
  0%, 100% { transform: translateX(0); }
  20%, 60% { transform: translateX(-4px); }
  40%, 80% { transform: translateX(4px); }
}
.shake { animation: shake 0.4s ease-in-out; }

/* ─── Loading ─── */
.loading {
  text-align: center;
  padding: var(--space-4xl);
  color: var(--mute);
  font-size: var(--body-sm-size);
}
.spinner {
  width: 24px; height: 24px;
  border: 2px solid var(--hairline);
  border-top-color: var(--ink);
  border-radius: 50%;
  animation: spin 0.6s linear infinite;
  margin: 0 auto var(--space-sm);
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ─── Login ─── */
.login-container { max-width: 420px; margin: var(--space-5xl) auto; padding: var(--space-lg); }
.login-card {
  background: var(--canvas);
  border-radius: var(--radius-lg);
  padding: var(--space-2xl);
  box-shadow: var(--shadow-card-lg);
  text-align: center;
}
.login-card h2 {
  font-size: var(--display-sm-size);
  font-weight: 600;
  line-height: var(--display-sm-lh);
  letter-spacing: var(--display-sm-ls);
  margin-bottom: var(--space-xs);
}
.login-card p {
  font-size: var(--body-sm-size);
  color: var(--body);
  margin-bottom: var(--space-lg);
}
.login-card input {
  width: 100%;
  background: var(--canvas);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-sm);
  padding: 0 var(--space-sm);
  height: 40px;
  font-family: var(--font-sans);
  font-size: var(--body-sm-size);
  margin-bottom: var(--space-sm);
}
.login-card input:focus { outline: none; border-color: var(--ink); }

/* ─── Responsive ─── */
@media (max-width: 600px) {
  .container, .admin-container { padding: var(--space-sm) var(--space-sm) var(--space-2xl); }
  .exercise-container { padding: var(--space-lg) var(--space-sm); }
  .exercise-grid { grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); }
  .stat-cards { grid-template-columns: repeat(2, 1fr); }
  :root {
    --display-xl-size: 36px; --display-xl-lh: 36px; --display-xl-ls: -1.8px;
    --display-lg-size: 24px; --display-lg-lh: 32px; --display-lg-ls: -0.96px;
  }
}
