/* =============================================================================
   Apostila Web — Design system premium (cyberpunk minimal / sci-fi doc)
   Dark-first; light alternativo. Apenas apresentação — conteúdo HTML intacto.
   ============================================================================= */

/* ----- Design tokens (marca) ----- */
:root {
  --color-bg-deep: #060816;
  --color-bg-elevated: #0b1020;
  --color-surface: #111827;
  --color-surface-alt: #1a2236;

  --color-text-primary: #f8fafc;
  --color-text-secondary: #cbd5e1;
  --color-text-muted: #94a3b8;

  --color-primary-400: #38bdf8;
  --color-primary-500: #0ea5e9;
  --color-primary-600: #0284c7;

  --color-purple-400: #a855f7;
  --color-purple-500: #9333ea;
  --color-purple-600: #7e22ce;

  --color-cyan: #22d3ee;
  --color-pink: #ec4899;

  --color-success: #22c55e;
  --color-warning: #f59e0b;
  --color-error: #ef4444;

  /* Brilhos discretos (evitar neon agressivo) */
  --glow-blue-soft: 0 0 32px rgba(56, 189, 248, 0.12);
  --glow-purple-soft: 0 0 40px rgba(168, 85, 247, 0.08);
  --border-glow: 0 0 0 1px rgba(56, 189, 248, 0.12), 0 0 0 1px rgba(168, 85, 247, 0.06);

  --font-sans: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-display: "Space Grotesk", var(--font-sans);
  --font-mono: "JetBrains Mono", ui-monospace, "Cascadia Code", monospace;

  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-xl: 20px;

  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 48px;

  --ease-out: cubic-bezier(0.33, 1, 0.68, 1);
  --duration-fast: 0.18s;
  --duration-base: 0.24s;

  /* Compatibilidade com cyberpunk-aulas.css (aliases) */
  --transition-neon: background-color var(--duration-base) var(--ease-out),
    border-color var(--duration-base) var(--ease-out),
    color var(--duration-base) var(--ease-out),
    box-shadow var(--duration-base) var(--ease-out);
  --transition-glow: box-shadow var(--duration-base) var(--ease-out),
    border-color var(--duration-base) var(--ease-out);

  /* Blocos de código — Dracula sobre fundo sempre preto (qualquer tema) */
  --syntax-bg: #000000;
  --syntax-fg: #f8f8f2;
  /* Barra do rótulo: tom sóbrio sobre preto */
  --syntax-header-bg: #141414;
  --syntax-comment: #6272a4;
  --syntax-pink: #ff79c6;
  --syntax-purple: #bd93f9;
  --syntax-green: #50fa7b;
  --syntax-yellow: #f1fa8c;
  --syntax-keyword: #8be9fd;
  --syntax-orange: #ffb86c;
  --syntax-pre-border: rgba(255, 255, 255, 0.1);
  --syntax-pre-shadow: 0 10px 36px rgba(0, 0, 0, 0.55),
    inset 0 1px 0 rgba(255, 255, 255, 0.04);
  --syntax-inline-bg: #000000;
  --syntax-inline-fg: var(--syntax-purple);
  --syntax-inline-border: rgba(189, 147, 249, 0.45);
}

/* ----- Tema escuro (padrão da experiência) ----- */
[data-theme="dark"] {
  --neon-blue: var(--color-primary-400);
  --neon-purple: var(--color-purple-500);
  --neon-pink: var(--color-pink);
  --neon-green: var(--color-success);
  --neon-orange: var(--color-warning);

  --cyber-black: var(--color-bg-deep);
  --cyber-dark: var(--color-bg-elevated);
  --cyber-gray: var(--color-surface);
  --cyber-light-gray: var(--color-surface-alt);
  --cyber-white: var(--color-text-primary);
  --cyber-off-white: #f1f5f9;

  --font-cyberpunk: var(--font-sans);
  --font-cyberpunk-display: var(--font-display);
  --font-code: var(--font-mono);

  --neon-glow: var(--glow-blue-soft);
  --neon-glow-blue: 0 0 24px rgba(56, 189, 248, 0.18);
  --neon-glow-purple: 0 0 28px rgba(168, 85, 247, 0.14);
  --neon-glow-green: 0 0 20px rgba(34, 197, 94, 0.12);

  --primary-color: var(--color-primary-400);
  --primary-color-dark: var(--color-primary-600);
  --secondary-color: var(--color-surface);
  --accent-color: var(--color-cyan);

  --success-color: var(--color-success);
  --success-color-light: rgba(34, 197, 94, 0.12);

  --warning-color: var(--color-warning);
  --warning-color-light: rgba(245, 158, 11, 0.12);

  --accent-color-light: rgba(34, 211, 238, 0.1);

  --info-color: var(--color-primary-500);
  --info-color-light: rgba(14, 165, 233, 0.1);

  --light-bg: var(--color-bg-deep);
  --dark-bg: var(--color-bg-elevated);
  --white: #ffffff;
  --black: #020617;

  --gray-100: var(--color-surface);
  --gray-200: var(--color-surface-alt);
  --gray-300: rgba(148, 163, 184, 0.22);
  --gray-400: rgba(148, 163, 184, 0.35);
  --gray-500: #64748b;
  --gray-600: var(--color-text-muted);
  --gray-700: var(--color-text-secondary);
  --gray-800: #e2e8f0;
  --gray-900: var(--color-text-primary);

  --text-secondary: var(--color-text-muted);

  --font-family-base: var(--font-sans);
  --font-family-code: var(--font-mono);

  --border-radius-sm: var(--radius-sm);
  --border-radius: var(--radius-md);
  --border-radius-lg: var(--radius-lg);

  --box-shadow: 0 8px 32px rgba(2, 6, 23, 0.45), var(--border-glow);
  --box-shadow-md: 0 12px 40px rgba(2, 6, 23, 0.55), var(--glow-blue-soft);
  --box-shadow-lg: 0 24px 64px rgba(2, 6, 23, 0.6);

  --header-height: 64px;
  --sidebar-width: 272px;

  color-scheme: dark;
}

/* ----- Tema claro (opcional, legível) ----- */
[data-theme="light"] {
  --neon-blue: var(--color-primary-600);
  --neon-purple: var(--color-purple-600);
  --neon-pink: #db2777;
  --neon-green: #16a34a;
  --neon-orange: #d97706;

  --cyber-black: #0f172a;
  --cyber-dark: #1e293b;
  --cyber-gray: #f1f5f9;
  --cyber-light-gray: #e2e8f0;
  --cyber-white: #ffffff;
  --cyber-off-white: #f8fafc;

  --font-cyberpunk: var(--font-sans);
  --font-cyberpunk-display: var(--font-display);
  --font-code: var(--font-mono);

  --neon-glow: 0 0 24px rgba(14, 165, 233, 0.15);
  --neon-glow-blue: 0 0 20px rgba(14, 165, 233, 0.12);
  --neon-glow-purple: 0 0 20px rgba(147, 51, 234, 0.1);
  --neon-glow-green: 0 0 16px rgba(22, 163, 74, 0.1);

  --primary-color: var(--color-primary-600);
  --primary-color-dark: #0369a1;
  --secondary-color: #1e293b;
  --accent-color: var(--color-primary-500);

  --success-color: var(--neon-green);
  --success-color-light: #dcfce7;
  --warning-color: var(--neon-orange);
  --warning-color-light: #fef3c7;
  --accent-color-light: #e0f2fe;

  --info-color: var(--color-primary-600);
  --info-color-light: #e0f2fe;

  --light-bg: #f8fafc;
  --dark-bg: #0f172a;
  --white: #ffffff;
  --black: #020617;

  --gray-100: #f1f5f9;
  --gray-200: #e2e8f0;
  --gray-300: #cbd5e1;
  --gray-400: #94a3b8;
  --gray-500: #64748b;
  --gray-600: #475569;
  --gray-700: #334155;
  --gray-800: #1e293b;
  --gray-900: #0f172a;

  --text-secondary: var(--gray-600);

  --font-family-base: var(--font-sans);
  --font-family-code: var(--font-mono);

  --border-radius-sm: var(--radius-sm);
  --border-radius: var(--radius-md);
  --border-radius-lg: var(--radius-lg);

  --box-shadow: 0 2px 8px rgba(15, 23, 42, 0.06);
  --box-shadow-md: 0 8px 24px rgba(15, 23, 42, 0.08);
  --box-shadow-lg: 0 16px 48px rgba(15, 23, 42, 0.12);

  --header-height: 64px;
  --sidebar-width: 272px;

  color-scheme: light;
}

/* ----- Base ----- */
html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
}

body {
  font-family: var(--font-sans);
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.65;
  letter-spacing: -0.01em;
  background-color: var(--light-bg);
  background-image: radial-gradient(
      ellipse 120% 80% at 50% -20%,
      rgba(56, 189, 248, 0.08),
      transparent 50%
    ),
    radial-gradient(ellipse 80% 50% at 100% 0%, rgba(168, 85, 247, 0.05), transparent);
  color: var(--gray-900);
}

[data-theme="light"] body {
  background-image: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--font-display);
  font-weight: 600;
  line-height: 1.25;
  letter-spacing: -0.02em;
  text-transform: none;
}

a {
  color: var(--primary-color);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease-out);
}

a:hover {
  color: var(--accent-color);
}

[data-theme="dark"] a:focus-visible {
  outline: 2px solid var(--color-primary-400);
  outline-offset: 2px;
}

/* ----- Cabeçalho (HUD / vidro moderado) ----- */
header {
  height: var(--header-height);
  padding: 0 var(--space-5);
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: sticky;
  top: 0;
  z-index: 100;

  background: color-mix(in srgb, var(--color-bg-elevated) 82%, transparent);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid color-mix(in srgb, var(--color-primary-400) 22%, transparent);
  box-shadow: 0 4px 24px rgba(2, 6, 23, 0.35),
    inset 0 1px 0 rgba(248, 250, 252, 0.06);
}

[data-theme="light"] header {
  background: color-mix(in srgb, var(--white) 88%, transparent);
  border-bottom-color: color-mix(in srgb, var(--color-primary-500) 18%, transparent);
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.06);
}

header h1 {
  font-family: var(--font-display);
  font-size: clamp(0.9375rem, 2vw, 1.125rem);
  font-weight: 600;
  margin: 0;
  color: var(--gray-900);
  text-shadow: none;
}

header .header-tools {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-shrink: 0;
  --header-tool-size: 48px;
  --header-tool-icon: 1.125rem;
}

/* Mesmo tamanho e círculo que o tema — par visual no header */
header .header-tools .theme-toggle,
header .header-tools .toggle-menu {
  width: var(--header-tool-size);
  height: var(--header-tool-size);
  min-width: var(--header-tool-size);
  min-height: var(--header-tool-size);
  padding: 0;
  border-radius: 999px;
  box-sizing: border-box;
  font-size: var(--header-tool-icon);
  line-height: 1;
}

header .header-tools .toggle-menu {
  display: none;
  align-items: center;
  justify-content: center;
  background: color-mix(in srgb, var(--color-surface-alt) 90%, transparent);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  border: 1px solid color-mix(in srgb, var(--primary-color) 28%, transparent);
  color: var(--primary-color);
  box-shadow: var(--box-shadow), var(--glow-blue-soft);
  transition: transform var(--duration-fast) var(--ease-out),
    border-color var(--duration-base) var(--ease-out),
    box-shadow var(--duration-base) var(--ease-out),
    background var(--duration-fast) var(--ease-out);
}

header .header-tools .toggle-menu:hover {
  transform: scale(1.04);
  box-shadow: var(--box-shadow-md);
  background: color-mix(in srgb, var(--color-surface-alt) 94%, transparent);
}

header .header-tools .toggle-menu:active {
  transform: scale(0.98);
}

[data-theme="light"] header .header-tools .toggle-menu {
  background: color-mix(in srgb, var(--white) 88%, transparent);
  color: var(--primary-color-dark);
  border-color: color-mix(in srgb, var(--color-primary-500) 22%, transparent);
  box-shadow: var(--box-shadow);
}

[data-theme="light"] header .header-tools .toggle-menu:hover {
  background: color-mix(in srgb, var(--white) 96%, transparent);
}

[data-theme="dark"] header h1 {
  color: var(--color-text-primary);
}

.toggle-menu {
  display: none;
  background: rgba(56, 189, 248, 0.08);
  border: 1px solid color-mix(in srgb, var(--color-primary-400) 25%, transparent);
  color: var(--primary-color);
  font-size: 1.25rem;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out);
}

.toggle-menu:hover {
  background: rgba(56, 189, 248, 0.14);
  text-shadow: none;
  transform: none;
}

[data-theme="light"] .toggle-menu {
  background: rgba(14, 165, 233, 0.1);
  color: var(--primary-color-dark);
}

/* ----- Layout ----- */
.container {
  display: flex;
  min-height: calc(100vh - var(--header-height));
}

.loading-indicator {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  min-height: 40vh;
  color: var(--gray-600);
  font-family: var(--font-sans);
}

.loading-indicator i {
  font-size: 2rem;
  color: var(--primary-color);
  opacity: 0.85;
}

main {
  flex: 1;
  padding: var(--space-6) var(--space-5);
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  background: transparent;
}

/* Aulas injetadas em #content — coluna única centrada (.lesson-content não pode usar max-width:none) */
main#content > article {
  width: 100%;
  max-width: min(56.25rem, 100%);
  margin-inline: auto;
  box-sizing: border-box;
}

footer {
  text-align: center;
  padding: var(--space-5);
  margin-top: var(--space-6);
  border-top: 1px solid color-mix(in srgb, var(--gray-600) 25%, transparent);
  background: var(--dark-bg);
  color: var(--gray-700);
}

[data-theme="dark"] footer {
  background: var(--color-bg-elevated);
  color: var(--color-text-muted);
  border-top-color: rgba(148, 163, 184, 0.12);
}

.footer-links a {
  color: var(--primary-color);
}

.grid {
  gap: var(--space-5);
}

/* ----- Navegação ----- */
nav {
  width: var(--sidebar-width);
  flex-shrink: 0;
  padding: var(--space-5);
  height: calc(100vh - var(--header-height));
  position: sticky;
  top: var(--header-height);
  overflow-y: auto;

  background: color-mix(in srgb, var(--color-surface) 94%, transparent);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  border-right: 1px solid color-mix(in srgb, var(--color-primary-400) 12%, transparent);
  box-shadow: inset -1px 0 0 rgba(248, 250, 252, 0.04);
}

[data-theme="light"] nav {
  background: var(--gray-100);
  border-right: 1px solid var(--gray-200);
  box-shadow: none;
}

nav h3 {
  font-family: var(--font-display);
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--gray-600);
  margin: var(--space-5) 0 var(--space-3);
  padding-bottom: var(--space-2);
  border-bottom: 1px solid color-mix(in srgb, var(--gray-600) 35%, transparent);
  text-shadow: none;
}

nav h3:first-child {
  margin-top: 0;
}

nav ul {
  list-style: none;
  margin: 0 0 var(--space-5);
  padding: 0;
}

nav li {
  margin-bottom: var(--space-1);
}

nav a {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  color: var(--gray-700);
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 0.8125rem;
  line-height: 1.4;
  text-transform: none;
  letter-spacing: -0.01em;
  border-left: none;
}

[data-theme="dark"] nav a {
  color: var(--color-text-secondary);
}

nav a:hover {
  background: rgba(56, 189, 248, 0.08);
  color: var(--primary-color);
  box-shadow: none;
  text-shadow: none;
}

nav a.active {
  background: linear-gradient(
    90deg,
    rgba(56, 189, 248, 0.18),
    rgba(168, 85, 247, 0.08)
  );
  color: var(--gray-900);
  font-weight: 600;
  border: 1px solid color-mix(in srgb, var(--primary-color) 35%, transparent);
}

[data-theme="dark"] nav a.active {
  color: var(--color-text-primary);
}

/* ----- Artigo / tipografia pedagogica ----- */
article {
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
}

article h1 {
  font-size: clamp(2rem, 4vw, 2.375rem);
  font-weight: 700;
  margin-bottom: var(--space-5);
}

article h2 {
  font-size: 1.875rem;
  font-weight: 600;
  margin-bottom: var(--space-5);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid color-mix(in srgb, var(--primary-color) 28%, transparent);
  color: var(--gray-900);
  text-shadow: none;
}

article h3 {
  font-size: 1.5rem;
  font-weight: 600;
  margin: var(--space-6) 0 var(--space-4);
  color: var(--gray-900);
  text-transform: none;
}

article h4 {
  font-size: 1.25rem;
  font-weight: 600;
  margin: var(--space-5) 0 var(--space-3);
  color: var(--text-secondary);
}

article p {
  margin-bottom: var(--space-4);
  color: var(--gray-700);
}

[data-theme="dark"] article p {
  color: var(--color-text-secondary);
}

article ul,
article ol {
  margin: var(--space-4) 0 var(--space-4) 1.5rem;
}

article li {
  margin-bottom: var(--space-2);
  color: var(--gray-700);
}

[data-theme="dark"] article li {
  color: var(--color-text-secondary);
}

blockquote {
  border-left: 3px solid var(--accent-color);
  padding: var(--space-4) var(--space-5);
  margin: var(--space-5) 0;
  background: color-mix(in srgb, var(--gray-100) 75%, transparent);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  box-shadow: var(--box-shadow);
  font-style: normal;
  font-family: var(--font-sans);
}

[data-theme="dark"] blockquote {
  background: color-mix(in srgb, var(--color-surface) 92%, transparent);
  box-shadow: var(--neon-glow);
}

blockquote p {
  margin: 0;
  color: var(--gray-700);
}

[data-theme="dark"] blockquote p {
  color: var(--color-text-secondary);
}

/* ----- Código inline e blocos (paleta Dracula / editor) ----- */
code {
  font-family: var(--font-mono);
  font-size: 0.875em;
  font-weight: 500;
  background: var(--syntax-inline-bg);
  color: var(--syntax-inline-fg);
  padding: 0.125em 0.4em;
  border-radius: 6px;
  border: 1px solid var(--syntax-inline-border);
  box-shadow: none;
}

[data-theme="light"] code {
  background: var(--syntax-inline-bg);
  color: var(--syntax-inline-fg);
  border-color: var(--syntax-inline-border);
}

.code-header {
  font-family: var(--font-display);
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-top: var(--space-6);
  margin-bottom: 0;
  padding: var(--space-3) var(--space-4);
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--syntax-header-bg) 100%, transparent),
    var(--syntax-bg)
  );
  color: var(--syntax-fg);
  border: 1px solid var(--syntax-pre-border);
  border-radius: var(--radius-md) var(--radius-md) 0 0;
  border-bottom: none;
  box-shadow: inset 0 1px 0 rgba(248, 250, 252, 0.06);
}

[data-theme="light"] .code-header {
  background: linear-gradient(
    180deg,
    var(--syntax-header-bg),
    var(--syntax-bg)
  );
  color: var(--syntax-fg);
  border-color: var(--syntax-pre-border);
}

pre {
  background: var(--syntax-bg) !important;
  color: var(--syntax-fg) !important;
  padding: var(--space-5) !important;
  border-radius: 0 0 var(--radius-md) var(--radius-md) !important;
  border: 1px solid var(--syntax-pre-border);
  border-top: none;
  margin: 0 0 var(--space-6) !important;
  overflow-x: auto;
  box-shadow: var(--syntax-pre-shadow);
}

pre code {
  font-size: 0.875rem;
  line-height: 1.6;
  background: transparent !important;
  border: none !important;
  color: inherit !important;
  padding: 0 !important;
}

/* Imagens da apostila */
.img-container img {
  border-radius: var(--radius-md);
  border: 1px solid color-mix(in srgb, var(--primary-color) 15%, transparent);
  box-shadow: var(--box-shadow);
}

.img-caption {
  font-size: 0.875rem;
  color: var(--gray-600);
  margin-top: var(--space-2);
  font-family: var(--font-sans);
}

/* Tabelas */
table {
  background: color-mix(in srgb, var(--gray-100) 94%, transparent);
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--gray-600) 22%, transparent);
  box-shadow: var(--box-shadow);
}

th,
td {
  border: 1px solid color-mix(in srgb, var(--gray-600) 15%, transparent);
  padding: var(--space-3) var(--space-4);
}

th {
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--color-primary-500) 25%, transparent),
    color-mix(in srgb, var(--color-purple-500) 15%, transparent)
  );
  color: var(--color-text-primary);
  font-family: var(--font-display);
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

[data-theme="light"] th {
  color: var(--gray-900);
}

tr:nth-child(even) {
  background: color-mix(in srgb, var(--gray-100) 50%, transparent);
}

tr:hover {
  background: color-mix(in srgb, var(--accent-color) 6%, transparent);
}

/* Caixas de informação */
.info-box {
  background: color-mix(in srgb, var(--info-color) 10%, transparent);
  border-left: 3px solid var(--info-color);
  padding: var(--space-5);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  box-shadow: var(--box-shadow);
}

.info-box h4,
.info-box h5 {
  font-family: var(--font-display);
  color: var(--info-color);
  font-size: 1rem;
  text-transform: none;
  letter-spacing: -0.01em;
}

.info-box h5 {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: 0;
  margin-bottom: var(--space-2);
}

.warning-box {
  background: color-mix(in srgb, var(--warning-color) 10%, transparent);
  border-left: 3px solid var(--warning-color);
}

.warning-box h4 {
  color: var(--warning-color);
}

.success-box {
  background: color-mix(in srgb, var(--success-color) 10%, transparent);
  border-left: 3px solid var(--success-color);
}

.success-box h4,
.success-box h5 {
  color: var(--success-color);
}

.success-box h5 {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: 0;
  font-family: var(--font-display);
  font-size: 1rem;
}

.error-box {
  background: color-mix(in srgb, var(--color-error) 10%, transparent);
  border-left: 3px solid var(--color-error);
}

.error-box h4 {
  color: var(--color-error);
}

.desafio {
  background: color-mix(in srgb, var(--warning-color) 12%, transparent);
  border-left: 3px solid var(--warning-color);
  padding: var(--space-5);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  margin: var(--space-5) 0;
  border: 1px solid color-mix(in srgb, var(--warning-color) 25%, transparent);
  box-shadow: var(--box-shadow);
}

.desafio h4 {
  font-family: var(--font-display);
  color: var(--warning-color);
  text-shadow: none;
  text-transform: none;
}

details:not(.solucao):not(.os-details) > summary {
  cursor: pointer;
  padding: var(--space-3) var(--space-4);
  background: color-mix(in srgb, var(--gray-200) 80%, transparent);
  border-radius: var(--radius-sm);
  color: var(--gray-900);
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 0.9375rem;
  text-transform: none;
  border: 1px solid color-mix(in srgb, var(--gray-600) 18%, transparent);
  transition: background var(--duration-fast) var(--ease-out),
    border-color var(--duration-fast) var(--ease-out);
}

details:not(.solucao):not(.os-details) > summary:hover {
  background: color-mix(in srgb, var(--primary-color) 12%, transparent);
  transform: none;
  box-shadow: var(--neon-glow);
}

details:not(.solucao):not(.os-details)[open] > summary {
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
}

.solution {
  padding: var(--space-5);
  background: var(--gray-100);
  border-radius: 0 0 var(--radius-sm) var(--radius-sm);
  border-left: 3px solid var(--success-color);
  border-top: 1px solid color-mix(in srgb, var(--gray-600) 14%, transparent);
}

/* Timeline */
.timeline::after {
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--primary-color) 90%, transparent),
    color-mix(in srgb, var(--color-purple-500) 75%, transparent)
  );
  box-shadow: none;
}

.timeline-item::after {
  background: var(--gray-900);
  border-color: var(--primary-color);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--primary-color) 35%, transparent);
}

.timeline-content {
  background: color-mix(in srgb, var(--gray-100) 94%, transparent);
  border-radius: var(--radius-md);
  border: 1px solid color-mix(in srgb, var(--primary-color) 16%, transparent);
  box-shadow: var(--box-shadow);
}

.timeline-year {
  font-family: var(--font-display);
  color: var(--primary-color);
}

.professor-perfil {
  background: color-mix(in srgb, var(--gray-100) 92%, transparent);
  border-radius: var(--radius-lg);
  border: 1px solid color-mix(in srgb, var(--primary-color) 15%, transparent);
  box-shadow: var(--box-shadow);
}

.professor-foto img {
  border-width: 2px;
  box-shadow: var(--glow-blue-soft);
}

.professor-cargo {
  font-family: var(--font-sans);
  text-transform: none;
}

.social-link:hover {
  text-shadow: none;
}

.card {
  background: color-mix(in srgb, var(--gray-100) 88%, transparent);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  border-radius: var(--radius-lg);
  border: 1px solid color-mix(in srgb, var(--primary-color) 14%, transparent);
  box-shadow: var(--box-shadow);
  padding: var(--space-5);
}

[data-theme="light"] .card {
  background: var(--white);
}

.card:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--primary-color) 35%, transparent);
  box-shadow: var(--box-shadow-md), var(--glow-blue-soft);
}

.video-embed {
  border-radius: var(--radius-md);
  border: 1px solid color-mix(in srgb, var(--primary-color) 20%, transparent);
  box-shadow: var(--box-shadow-md);
}

/* Responsivo */
@media (max-width: 768px) {
  header {
    gap: var(--space-2);
  }

  header h1 {
    flex: 1 1 0%;
    min-width: 0;
    padding-right: var(--space-1);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .container {
    flex-direction: column;
  }

  nav {
    width: 100%;
    height: auto;
    position: static;
    display: none;
    border-right: none;
    border-bottom: 1px solid color-mix(in srgb, var(--primary-color) 12%, transparent);
  }

  nav.active {
    display: block;
  }

  header .header-tools .toggle-menu {
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .timeline::after {
    left: 31px;
  }

  .timeline-item {
    width: 100%;
    padding-left: 70px;
    padding-right: 25px;
  }

  .timeline-left::after,
  .timeline-right::after {
    left: 21px;
  }

  .timeline-right {
    left: 0;
  }

  .professor-perfil {
    flex-direction: column;
    text-align: center;
    align-items: center;
  }
}

@media (max-width: 576px) {
  main {
    padding: var(--space-5) var(--space-4);
  }

  .card {
    padding: var(--space-4);
  }

  article h2 {
    font-size: 1.5rem;
  }
}

/* Utilitários (cores texto) — alinhados ao erro brand */
.text-danger {
  color: var(--color-error);
}

[data-theme="dark"] .text-danger {
  color: var(--neon-pink);
}

/* Utilitários usados em trechos tipo Tailwind dentro das aulas */
.text-sm {
  font-size: 0.875rem;
  line-height: 1.5;
  font-weight: 400;
}

.text-gray-600 {
  color: var(--gray-600);
}

.text-gray-500 {
  color: var(--gray-500);
}

.text-gray-700 {
  color: var(--gray-700);
}

.text-gray-900 {
  color: var(--gray-900);
}

.text-center {
  text-align: center;
}

.mb-3 {
  margin-bottom: var(--space-3);
}

.mb-4 {
  margin-bottom: var(--space-4);
}

.mt-2 {
  margin-top: var(--space-2);
}

.mt-3 {
  margin-top: var(--space-3);
}

.mt-4 {
  margin-top: var(--space-4);
}

.py-8 {
  padding-top: var(--space-6);
  padding-bottom: var(--space-6);
}

.px-6 {
  padding-left: var(--space-5);
  padding-right: var(--space-5);
}

.py-3 {
  padding-top: var(--space-3);
  padding-bottom: var(--space-3);
}

.py-4 {
  padding-top: var(--space-4);
  padding-bottom: var(--space-4);
}

.font-medium {
  font-weight: 500;
}

.rounded {
  border-radius: var(--radius-md);
}

.border {
  border: 1px solid color-mix(in srgb, var(--gray-600) 25%, transparent);
}

.w-full {
  width: 100%;
}

.flex {
  display: flex;
}

.items-center {
  align-items: center;
}

.space-x-2 > * + * {
  margin-left: var(--space-2);
}
