/* ═══════════════════════════════════════════════════════════════════════
   engine.css · OpoJose Course Framework
   ─────────────────────────────────────────────────────────────────────
   Diseño unificado para todos los cursos. Sin dependencias externas.
   Estética: Notion + Linear + GitBook + Raycast + Vercel.
   Filosofía: minimalismo, claridad, espacio en blanco, paleta neutra,
               tipografía grande, sombras discretas, microanimaciones suaves.
   ─────────────────────────────────────────────────────────────────────
   ÍNDICE
      1. Tokens (colores, tipografía, espaciado, radios, sombras)
      2. Reset & base
      3. Layout (sidebar + topbar + main)
      4. Sidebar tipo Notion
      5. Topbar
      6. Paneles & cabeceras
      7. Bento grid (stats + módulos)
      8. Cards & callouts
      9. Steps, tablas, FHS, permisos
     10. Code blocks & terminal
     11. Arch diagram
     12. Quiz & ejercicios
     13. Cheatsheet, badges, tech pills
     14. Feedback widget
     15. Focus visible
     16. Course navbar
     17. Modo oscuro
     18. Print
   ═══════════════════════════════════════════════════════════════════════ */


/* ─── 1. Tokens ─────────────────────────────────────────────── */
:root {
  /* Neutros — base del diseño */
  --c-bg:        #FFFFFF;            /* página */
  --c-surface:   #FFFFFF;            /* cards, sidebar */
  --c-surface-2: #F7F7F5;            /* hover ligero, code inline */
  --c-surface-3: #EFEFED;            /* terciario */
  --c-border:    #ECECEA;            /* bordes principales */
  --c-border-2:  #E3E3E0;            /* bordes algo más visibles */
  --c-divider:   #F0F0EE;            /* separadores muy sutiles */

  /* Texto */
  --c-text:      #1F1F1F;            /* títulos */
  --c-text-2:    #37352F;            /* cuerpo */
  --c-text-3:    #6B6B6B;            /* secundario */
  --c-text-4:    #9B9B9B;            /* labels, captions */
  --c-text-5:    #B4B4B4;            /* placeholders */

  /* Accento — único, muy controlado (azul Linear-ish) */
  --c-accent:        #2F6FEB;
  --c-accent-hover:  #1D5DD9;
  --c-accent-soft:   #EEF3FE;
  --c-accent-border: #D9E3FB;
  --c-accent-text:   #2557C7;

  /* Semánticos — discretos */
  --c-ok:        #1F7A4A;
  --c-ok-soft:   #ECF6F0;
  --c-ok-border: #D4E9DC;
  --c-warn:        #B5680B;
  --c-warn-soft:   #FBF3E4;
  --c-warn-border: #EFDEB3;
  --c-err:        #B23A3A;
  --c-err-soft:   #FBEFEF;
  --c-err-border: #ECD0D0;
  --c-purple:        #6645C7;
  --c-purple-soft:   #F2EEFB;
  --c-purple-border: #DFD4F1;

  /* Acentos para hacer el bento visualmente variado pero neutro */
  --c-tint-blue:   #EEF3FE;
  --c-tint-green:  #ECF6F0;
  --c-tint-amber:  #FBF3E4;
  --c-tint-rose:   #FBEFEF;
  --c-tint-purple: #F2EEFB;
  --c-tint-stone:  #F4F4F2;

  /* Tipografía */
  --font:      'Inter', 'Geist', 'Manrope',
               -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
               "Helvetica Neue", Helvetica, Arial, sans-serif;
  --font-display: var(--font);
  --font-mono: 'JetBrains Mono', 'Geist Mono', ui-monospace, SFMono-Regular,
               Menlo, Consolas, "Liberation Mono", monospace;

  /* Tamaños de fuente — escala mayor que antes */
  --fs-xs:   0.75rem;    /* 12 */
  --fs-sm:   0.8125rem;  /* 13 */
  --fs-base: 0.9375rem;  /* 15 */
  --fs-md:   1rem;       /* 16 */
  --fs-lg:   1.125rem;   /* 18 */
  --fs-xl:   1.375rem;   /* 22 */
  --fs-2xl:  1.75rem;    /* 28 */
  --fs-3xl:  2.25rem;    /* 36 */
  --fs-4xl:  2.75rem;    /* 44 */

  /* Espaciado */
  --sp-1: 0.25rem;
  --sp-2: 0.5rem;
  --sp-3: 0.75rem;
  --sp-4: 1rem;
  --sp-5: 1.25rem;
  --sp-6: 1.5rem;
  --sp-7: 2rem;
  --sp-8: 2.5rem;
  --sp-9: 3rem;
  --sp-10: 4rem;

  /* Radios */
  --r-xs:  6px;
  --r-sm:  8px;
  --r:     10px;
  --r-md:  12px;
  --r-lg:  16px;
  --r-xl:  20px;
  --r-pill: 999px;

  /* Sombras — muy sutiles */
  --sh-xs: 0 1px 0 rgba(0,0,0,0.02), 0 1px 2px rgba(15,15,15,0.04);
  --sh-sm: 0 1px 2px rgba(15,15,15,0.04), 0 2px 6px rgba(15,15,15,0.04);
  --sh:    0 1px 3px rgba(15,15,15,0.06), 0 4px 12px rgba(15,15,15,0.05);
  --sh-md: 0 2px 6px rgba(15,15,15,0.06), 0 10px 32px rgba(15,15,15,0.07);
  --sh-lg: 0 8px 24px rgba(15,15,15,0.08), 0 24px 64px rgba(15,15,15,0.10);
  --sh-focus: 0 0 0 3px rgba(47, 111, 235, 0.18);

  /* Layout */
  --sidebar-w: 260px;
  --navbar-h:  48px;
  --content-max: 880px;

  /* Easing */
  --ease:     cubic-bezier(.2,.7,.2,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
  --t-fast: 120ms;
  --t-mid:  200ms;
}

/* v1 compat aliases — permite que los CSS de cursos existentes funcionen
   sin cambios usando los nombres antiguos de variables */
:root {
  --white:      var(--c-surface);
  --surface:    var(--c-surface);
  --border:     var(--c-border);
  --border-mid: var(--c-border-2);
  --radius:     var(--r);
  --radius-sm:  var(--r-sm);
  --radius-xs:  var(--r-xs);
  --radius-lg:  var(--r-lg);
  --text:       var(--c-text);
  --text-body:  var(--c-text-2);
  --text-dim:   var(--c-text-3);
  --text-light: var(--c-text-4);
  --blue:       var(--c-accent);
  --blue-light: var(--c-accent-hover);
  --blue-mid:   var(--c-accent-border);
  --blue-dim:   var(--c-accent-soft);
  --blue-pale:  var(--c-tint-blue);
  --blue-dark:  var(--c-accent-text);
  --green:      var(--c-ok);
  --green-bg:   var(--c-ok-soft);
  --green-mid:  var(--c-ok-border);
  --red:        var(--c-err);
  --red-bg:     var(--c-err-soft);
  --red-mid:    var(--c-err-border);
  --grey-50:    var(--c-surface-3);
  --grey-100:   var(--c-surface-2);
  --grey-200:   var(--c-border);
  --grey-300:   var(--c-border-2);
  --grey-400:   var(--c-text-4);
  --shadow-xs:  var(--sh-xs);
  --shadow-sm:  var(--sh-sm);
  --shadow-blue: var(--sh-focus);
}


/* ─── 2. Reset & base ────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--font);
  font-size: var(--fs-base);
  line-height: 1.6;
  color: var(--c-text-2);
  background: var(--c-bg);
  font-feature-settings: 'cv11', 'ss01', 'ss03';
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  color: var(--c-text);
  letter-spacing: -0.015em;
  margin: 0;
  font-weight: 600;
}

a {
  color: var(--c-accent);
  text-decoration: none;
  transition: color var(--t-fast) var(--ease);
}
a:hover { color: var(--c-accent-hover); }

button { font-family: inherit; }

img, svg { max-width: 100%; height: auto; display: block; }

::selection { background: var(--c-accent-soft); color: var(--c-accent-text); }

/* Scrollbar — fina y discreta, estilo Linear */
*::-webkit-scrollbar { width: 10px; height: 10px; }
*::-webkit-scrollbar-track { background: transparent; }
*::-webkit-scrollbar-thumb {
  background: transparent;
  border-radius: var(--r-pill);
  border: 2px solid transparent;
  background-clip: padding-box;
}
*:hover::-webkit-scrollbar-thumb { background: #D8D8D5; background-clip: padding-box; border: 2px solid transparent; }
*::-webkit-scrollbar-thumb:hover { background: #C4C4C0; background-clip: padding-box; border: 2px solid transparent; }

/* Skip link */
.skip-link {
  position: absolute; top: -48px; left: 12px;
  background: var(--c-text); color: #fff;
  padding: .55rem 1rem; z-index: 9999;
  font-size: var(--fs-xs); font-weight: 600;
  border-radius: 0 0 var(--r-sm) var(--r-sm);
  transition: top var(--t-mid) var(--ease);
}
.skip-link:focus { top: 0; color: #fff; }


/* ─── 3. Layout ─────────────────────────────────────────────── */
.layout {
  display: flex;
  min-height: 100vh;
  padding-top: var(--navbar-h);
}

@media (min-width: 992px) {
  .layout { align-items: flex-start; }
}


/* ─── 4. Sidebar Notion-style ───────────────────────────────── */
.sidebar {
  width: var(--sidebar-w);
  background: var(--c-surface);
  border-right: 1px solid var(--c-border);
  overflow-y: auto;
  display: flex; flex-direction: column;
}

/* Mobile: sidebar oculto fuera de pantalla por defecto */
@media (max-width: 991px) {
  .sidebar {
    position: fixed !important;
    top: var(--navbar-h);
    left: 0;
    height: calc(100vh - var(--navbar-h));
    z-index: 200;
    transform: translateX(-100%);
    transition: transform 0.28s var(--ease);
  }
  .sidebar.sidebar-open {
    transform: translateX(0);
    box-shadow: 6px 0 24px rgba(15,23,42,0.18);
  }
}

@media (min-width: 992px) {
  .sidebar {
    position: sticky; top: var(--navbar-h);
    height: calc(100vh - var(--navbar-h));
    flex-shrink: 0;
  }
}

/* Backdrop para cerrar sidebar en móvil */
.sidebar-backdrop {
  display: none;
  position: fixed; inset: 0;
  background: rgba(15,23,42,0.35);
  backdrop-filter: blur(2px);
  z-index: 199;
  cursor: pointer;
}
.sidebar-backdrop.show { display: block; animation: fadeIn .2s var(--ease); }
@media (min-width: 992px) { .sidebar-backdrop { display: none !important; } }

.sidebar-header {
  padding: var(--sp-4) var(--sp-5);
  border-bottom: 1px solid var(--c-divider);
  display: flex; align-items: center; justify-content: space-between;
}

.sidebar-logo {
  padding: var(--sp-5) var(--sp-5) var(--sp-4);
  border-bottom: 1px solid var(--c-divider);
}
.sidebar-logo .logo-badge {
  display: inline-flex; align-items: center; gap: .35rem;
  background: var(--c-surface-2);
  color: var(--c-text-3);
  border: 1px solid var(--c-border);
  border-radius: var(--r-xs);
  padding: .2rem .55rem;
  font-size: 0.68rem; font-weight: 500;
  letter-spacing: 0.02em;
  margin-bottom: .55rem;
}
.sidebar-logo .logo-title {
  font-family: var(--font-display);
  font-size: var(--fs-md); font-weight: 600;
  color: var(--c-text); line-height: 1.3;
  letter-spacing: -0.01em;
}
.sidebar-logo .logo-sub {
  font-size: var(--fs-xs);
  color: var(--c-text-4);
  margin-top: .25rem;
}

.sidebar-progress {
  padding: var(--sp-4) var(--sp-5);
  border-bottom: 1px solid var(--c-divider);
}
.progress-label {
  font-size: var(--fs-xs); font-weight: 500;
  color: var(--c-text-3); margin-bottom: .45rem;
  display: flex; justify-content: space-between;
}
.progress-label > :last-child { color: var(--c-text); font-variant-numeric: tabular-nums; font-weight: 600; }
.sidebar-progress .progress { background-color: var(--c-border); }
.sidebar-progress .progress-bar { background: var(--c-text); transition: width 600ms var(--ease-out); }

.nav-section-label {
  display: block; width: 100%;
  background: none; border: none; cursor: pointer;
  text-align: left;
  padding: var(--sp-5) var(--sp-5) var(--sp-2);
  font-size: 0.7rem; font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--c-text-4);
  font-family: inherit;
}

.nav-item {
  display: flex; align-items: center; gap: .6rem;
  padding: .4rem var(--sp-5);
  font-size: var(--fs-sm); font-weight: 450;
  color: var(--c-text-2); text-decoration: none;
  cursor: pointer; border: none; background: none; width: 100%;
  text-align: left;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
  position: relative;
  margin: 1px 0;
}
.nav-item:hover {
  background: var(--c-surface-2);
  color: var(--c-text);
}
.nav-item.active {
  background: var(--c-surface-2);
  color: var(--c-text);
  font-weight: 550;
}
.nav-item .nav-icon {
  font-size: 0.95rem; flex-shrink: 0;
  width: 16px; text-align: center;
  color: var(--c-text-4);
  transition: color var(--t-fast) var(--ease);
}
.nav-item:hover .nav-icon,
.nav-item.active .nav-icon { color: var(--c-text-2); }

.nav-item .nav-done {
  margin-left: auto;
  background: var(--c-ok-soft); color: var(--c-ok); border: none;
  display: none;
}
.nav-item.done .nav-done { display: inline-flex; }

.sidebar-footer {
  padding: var(--sp-4) var(--sp-5);
  border-top: 1px solid var(--c-divider);
  font-size: var(--fs-xs);
  color: var(--c-text-4);
  margin-top: auto;
}
.sidebar-footer .theme-toggle {
  display: block;
  margin-top: var(--sp-2);
}


/* ─── 5. Topbar ─────────────────────────────────────────────── */
.main { flex: 1; min-width: 0; }

.topbar {
  position: sticky; top: var(--navbar-h); z-index: 100;
  background: rgba(255, 255, 255, 0.85);
  backdrop-filter: blur(10px) saturate(180%);
  -webkit-backdrop-filter: blur(10px) saturate(180%);
  border-bottom: 1px solid var(--c-border);
  padding: .75rem var(--sp-7);
  display: flex; align-items: center; gap: var(--sp-4);
}
.topbar-breadcrumb {
  font-size: var(--fs-sm);
  color: var(--c-text-3);
  flex: 1; min-width: 0;
  overflow: hidden; white-space: nowrap; text-overflow: ellipsis;
}
.topbar-breadcrumb strong {
  color: var(--c-text);
  font-weight: 550;
}
.topbar-admin {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; border-radius: var(--r-sm);
  background: transparent;
  color: var(--c-text-3);
  font-size: 1rem;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
  margin-left: auto;
}
.topbar-admin:hover {
  background: var(--c-surface-2);
  color: var(--c-text);
}
.hamburger {
  background: none; border: none;
  font-size: 1.15rem; color: var(--c-text-3);
  padding: .3rem .55rem; border-radius: var(--r-sm);
  cursor: pointer;
  transition: background var(--t-fast) var(--ease);
}
.hamburger:hover { background: var(--c-surface-2); color: var(--c-text); }
@media (min-width: 992px) { .hamburger { display: none; } }


/* ─── 6. Paneles ────────────────────────────────────────────── */
.panel {
  display: none;
  padding: var(--sp-9) var(--sp-8) var(--sp-10);
  max-width: var(--content-max);
  margin: 0 auto;
  animation: panelIn 350ms var(--ease-out);
}
.panel.active { display: block; }

@keyframes panelIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}

.panel-header {
  margin-bottom: var(--sp-8);
}
.panel-tag {
  display: inline-flex; align-items: center;
  background: var(--c-surface-2);
  color: var(--c-text-3);
  border: 1px solid var(--c-border);
  border-radius: var(--r-xs);
  padding: .25rem .6rem;
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: 0.02em;
  margin-bottom: var(--sp-4);
}
.panel-title {
  font-family: var(--font-display);
  font-size: var(--fs-4xl);
  font-weight: 700;
  color: var(--c-text);
  line-height: 1.1;
  letter-spacing: -0.03em;
  margin-bottom: var(--sp-4);
  text-wrap: balance;
}
.panel-desc {
  font-size: var(--fs-lg);
  color: var(--c-text-3);
  max-width: 680px;
  line-height: 1.65;
  text-wrap: pretty;
}

.section-h2 {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 600;
  color: var(--c-text);
  margin: var(--sp-9) 0 var(--sp-4);
  letter-spacing: -0.02em;
}
.section-h3 {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--c-text);
  margin: var(--sp-6) 0 var(--sp-2);
}


/* ─── 7. Bento grid (stats) ─────────────────────────────────── */
.stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-3);
  margin-bottom: var(--sp-8);
}
.stat-card {
  position: relative;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: var(--sp-5);
  transition: border-color var(--t-mid) var(--ease),
              transform var(--t-mid) var(--ease);
}
.stat-card:hover {
  border-color: var(--c-border-2);
  transform: translateY(-1px);
}
.stat-card .stat-label {
  font-size: var(--fs-xs);
  color: var(--c-text-4);
  margin-bottom: var(--sp-3);
  font-weight: 500;
}
.stat-card .stat-val {
  font-family: var(--font-display);
  font-size: var(--fs-3xl);
  font-weight: 600;
  color: var(--c-text);
  line-height: 1;
  letter-spacing: -0.03em;
  margin-bottom: var(--sp-2);
  font-variant-numeric: tabular-nums;
}
.stat-card .stat-sub {
  font-size: var(--fs-xs);
  color: var(--c-text-4);
}

/* Variantes de tint para bento variado */
.stat-card:nth-child(1) { background: var(--c-surface); }
.stat-card:nth-child(2) { background: var(--c-tint-stone); border-color: transparent; }
.stat-card:nth-child(3) { background: var(--c-surface); }
.stat-card:nth-child(4) { background: var(--c-tint-stone); border-color: transparent; }


/* ─── 8. Cards & callouts ───────────────────────────────────── */
.card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: var(--sp-5);
  margin-bottom: var(--sp-4);
  transition: border-color var(--t-mid) var(--ease);
}
.card:hover { border-color: var(--c-border-2); }
.card-title {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--c-text);
  margin-bottom: var(--sp-2);
}
.card p {
  font-size: var(--fs-base);
  color: var(--c-text-3);
  line-height: 1.65;
  margin: 0;
}
.card-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-4); }
.card-grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--sp-4); }

.callout {
  display: flex; gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-5);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  margin: var(--sp-4) 0;
  font-size: var(--fs-base);
  line-height: 1.6;
  color: var(--c-text-2);
  background: var(--c-surface);
}
.callout-icon {
  font-size: 1rem; flex-shrink: 0;
  margin-top: 0.05rem; line-height: 1.4;
  color: var(--c-text-3);
}
.callout-info   { background: var(--c-accent-soft); border-color: var(--c-accent-border); }
.callout-info   .callout-icon { color: var(--c-accent); }
.callout-ok     { background: var(--c-ok-soft);     border-color: var(--c-ok-border); }
.callout-ok     .callout-icon { color: var(--c-ok); }
.callout-warn   { background: var(--c-warn-soft);   border-color: var(--c-warn-border); }
.callout-warn   .callout-icon { color: var(--c-warn); }
.callout-danger { background: var(--c-err-soft);    border-color: var(--c-err-border); }
.callout-danger .callout-icon { color: var(--c-err); }
.callout-purple { background: var(--c-purple-soft); border-color: var(--c-purple-border); }
.callout-purple .callout-icon { color: var(--c-purple); }
.callout-teal   { background: var(--c-tint-stone);  border-color: var(--c-border-2); }




/* ─── 9. Steps, tablas, FHS, permisos ───────────────────────── */
.steps {
  counter-reset: step;
  display: flex; flex-direction: column;
  margin: var(--sp-4) 0;
}
.step {
  display: flex; gap: var(--sp-4);
  padding-bottom: var(--sp-6);
  position: relative;
}
.step:last-child { padding-bottom: 0; }
.step::after {
  content: '';
  position: absolute;
  left: 13px; top: 30px; bottom: 0;
  width: 1px;
  background: var(--c-border);
}
.step:last-child::after { display: none; }
.step-num {
  flex-shrink: 0;
  width: 28px; height: 28px;
  background: var(--c-surface);
  border: 1px solid var(--c-border-2);
  border-radius: var(--r-pill);
  display: flex; align-items: center; justify-content: center;
  font-size: var(--fs-xs);
  font-weight: 600;
  color: var(--c-text-2);
  counter-increment: step;
  position: relative; z-index: 1;
  transition: all var(--t-mid) var(--ease);
}
.step:hover .step-num {
  background: var(--c-text);
  border-color: var(--c-text);
  color: #fff;
}
.step-num::before { content: counter(step); }
.step-body { flex: 1; padding-top: .2rem; }
.step-title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--fs-md);
  color: var(--c-text);
  margin-bottom: var(--sp-1);
}
.step-text {
  font-size: var(--fs-base);
  color: var(--c-text-3);
  line-height: 1.65;
}

/* Tablas */
.table-wrap {
  overflow-x: auto;
  margin: var(--sp-4) 0;
  border-radius: var(--r-md);
  border: 1px solid var(--c-border);
}
.table {
  width: 100%;
  font-size: var(--fs-sm);
  border-collapse: collapse;
  margin: 0;
}
.table thead { background: var(--c-surface-2); }
.table th {
  padding: var(--sp-3) var(--sp-4);
  font-weight: 550;
  font-size: var(--fs-xs);
  color: var(--c-text-3);
  border-bottom: 1px solid var(--c-border);
  white-space: nowrap;
  text-align: left;
}
.table td {
  padding: var(--sp-3) var(--sp-4);
  color: var(--c-text-2);
  vertical-align: top;
  line-height: 1.55;
  border-bottom: 1px solid var(--c-divider);
}
.table tbody tr:last-child td { border-bottom: none; }
.table tbody tr { transition: background var(--t-fast) var(--ease); }
.table tbody tr:hover { background: var(--c-surface-2); }
.table td:first-child { color: var(--c-text); font-weight: 500; }

code {
  font-family: var(--font-mono);
  font-size: 0.88em;
  background: var(--c-surface-2);
  color: var(--c-text);
  border-radius: var(--r-xs);
  padding: .12em .4em;
  border: 1px solid var(--c-border);
}
.callout-ok code     { background: rgba(31,122,74,0.06); color: var(--c-ok); border-color: var(--c-ok-border); }
.callout-warn code   { background: rgba(181,104,11,0.06); color: var(--c-warn); border-color: var(--c-warn-border); }
.callout-danger code { background: rgba(178,58,58,0.06); color: var(--c-err); border-color: var(--c-err-border); }
.callout-info code   { background: rgba(47,111,235,0.06); color: var(--c-accent); border-color: var(--c-accent-border); }

code.code-large { font-size: 1em; padding: .2em .5em; font-weight: 500; }

/* FHS tree */
.fhs-tree {
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: var(--sp-5);
  margin: var(--sp-4) 0;
  line-height: 1.85;
  overflow-x: auto;
  white-space: pre;
  color: var(--c-text-3);
}
.fhs-tree .fhs-root    { color: var(--c-text); font-weight: 600; }
.fhs-tree .fhs-dir     { color: var(--c-accent); }
.fhs-tree .fhs-imp     { color: var(--c-warn); font-weight: 500; }
.fhs-tree .fhs-comment { color: var(--c-text-4); }

/* Tabla de permisos */
.perm-table {
  width: 100%; border-collapse: collapse;
  margin: var(--sp-4) 0;
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  overflow: hidden;
  font-size: var(--fs-sm);
}
.perm-table th {
  background: var(--c-surface-2);
  padding: var(--sp-3) var(--sp-3);
  font-weight: 550;
  color: var(--c-text-3);
  font-size: var(--fs-xs);
  border-bottom: 1px solid var(--c-border);
  text-align: center;
}
.perm-table td {
  padding: var(--sp-3);
  border-bottom: 1px solid var(--c-divider);
  color: var(--c-text-2);
  text-align: center;
  background: var(--c-surface);
}
.perm-table tbody tr:last-child td { border-bottom: none; }
.perm-table td code {
  background: var(--c-surface-2);
  color: var(--c-text);
  font-weight: 500;
}
.perm-table .r { color: var(--c-ok); font-weight: 600; }
.perm-table .w { color: var(--c-warn); font-weight: 600; }
.perm-table .x { color: var(--c-err); font-weight: 600; }

/* Signal table */
.signal-table {
  width: 100%; border-collapse: collapse;
  margin: var(--sp-4) 0;
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  overflow: hidden;
  font-size: var(--fs-sm);
}
.signal-table th {
  background: var(--c-surface-2);
  padding: var(--sp-3) var(--sp-4);
  font-weight: 550;
  font-size: var(--fs-xs);
  color: var(--c-text-3);
  text-align: left;
  border-bottom: 1px solid var(--c-border);
}
.signal-table td {
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--c-divider);
  color: var(--c-text-2);
  background: var(--c-surface);
}
.signal-table tbody tr:last-child td { border-bottom: none; }
.signal-table tbody tr:hover td { background: var(--c-surface-2); }
.signal-table td:first-child {
  font-family: var(--font-mono);
  font-weight: 500;
  color: var(--c-text);
}


/* ─── 10. Code blocks & terminal ────────────────────────────── */
.code-wrap {
  background: #FAFAF9;
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  margin: var(--sp-4) 0;
  overflow: hidden;
}
.code-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: .55rem var(--sp-4);
  background: var(--c-surface);
  border-bottom: 1px solid var(--c-border);
}
.code-header span {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--c-text-4);
  letter-spacing: 0.02em;
}
.code-head { display: flex; align-items: center; justify-content: space-between; padding: .55rem var(--sp-4); background: var(--c-surface); border-bottom: 1px solid var(--c-border); }
.code-head span { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--c-text-4); letter-spacing: 0.02em; }
.copy-btn {
  background: transparent;
  border: 1px solid var(--c-border-2);
  border-radius: var(--r-xs);
  padding: .25rem .6rem;
  font-size: 0.7rem;
  font-weight: 500;
  color: var(--c-text-3);
  cursor: pointer;
  transition: all var(--t-fast) var(--ease);
  font-family: var(--font);
}
.copy-btn:hover {
  background: var(--c-surface-2);
  color: var(--c-text);
  border-color: var(--c-border-2);
}
.copy-btn.ok {
  color: var(--c-ok);
  border-color: var(--c-ok-border);
  background: var(--c-ok-soft);
}

pre {
  padding: var(--sp-4) var(--sp-5);
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  line-height: 1.7;
  overflow-x: auto;
  color: #37352F;
  margin: 0;
  tab-size: 2;
}
.t-comment { color: #9B9B9B; font-style: normal; }
.t-cmd     { color: #2557C7; }
.t-str     { color: #B5680B; }
.t-key     { color: #6645C7; font-weight: 500; }
.t-ok      { color: #1F7A4A; }
.t-red     { color: #B23A3A; }
.t-dim     { color: #9B9B9B; }
.t-hl      { color: #6645C7; }

/* Terminal — fondo oscuro elegante */
.terminal-wrap {
  background: #1A1A1A;
  border: 1px solid #2A2A2A;
  border-radius: var(--r-md);
  margin: var(--sp-5) 0;
  overflow: hidden;
  box-shadow: var(--sh-sm);
}
.terminal-topbar {
  display: flex; align-items: center; gap: .45rem;
  padding: .55rem .85rem;
  background: #222;
  border-bottom: 1px solid #2A2A2A;
}
.terminal-dot {
  width: 11px; height: 11px; border-radius: 50%;
  flex-shrink: 0;
}
.terminal-dot.r { background: #FF5F56; }
.terminal-dot.y { background: #FFBD2E; }
.terminal-dot.g { background: #27C93F; }
.terminal-topbar span {
  flex: 1; text-align: center;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  color: #888;
}
.terminal-body {
  height: 340px; overflow-y: auto;
  padding: var(--sp-4);
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  line-height: 1.7;
  color: #E5E5E5;
  background: #1A1A1A;
  cursor: text;
  white-space: pre-wrap; word-break: break-all;
}
.terminal-body .term-prompt .term-user   { color: #7EE787; }
.terminal-body .term-prompt .term-at     { color: #888; }
.terminal-body .term-prompt .term-host   { color: #79C0FF; }
.terminal-body .term-prompt .term-path   { color: #D2A8FF; }
.terminal-body .term-prompt .term-dollar { color: #888; }
.terminal-body .term-cmd    { color: #FAFAFA; }
.terminal-body .term-output { color: #C9D1D9; }
.terminal-body .term-output.dir  { color: #79C0FF; }
.terminal-body .term-output.exe  { color: #7EE787; }
.terminal-body .term-output.link { color: #D2A8FF; }
.terminal-body .term-output.err  { color: #FF7B72; }
.terminal-body .term-cursor {
  display: inline-block; width: 7px; height: 14px;
  background: #79C0FF; vertical-align: middle;
  animation: blink 1s step-end infinite;
}
@keyframes blink { 50% { opacity: 0; } }
.terminal-input-line { display: flex; align-items: baseline; }
.terminal-input-line .term-prompt { flex-shrink: 0; }
.terminal-input {
  background: transparent; border: none; outline: none;
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  color: #FAFAFA; caret-color: #79C0FF;
  flex: 1; min-width: 0;
  padding: 0; margin: 0;
}

/* ─── 11. Arch diagram (minimalista) ─────────────────────────── */
.arch-diagram {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--sp-7);
  margin: var(--sp-5) 0;
  overflow-x: auto;
}
.arch-row {
  display: flex; align-items: center; justify-content: center;
  gap: var(--sp-2); flex-wrap: wrap;
  margin-bottom: var(--sp-3);
}
.arch-box {
  background: var(--c-surface);
  border: 1px solid var(--c-border-2);
  border-radius: var(--r-sm);
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-text);
  text-align: center;
  min-width: 100px;
  transition: all var(--t-mid) var(--ease);
}
.arch-box:hover {
  border-color: var(--c-text-3);
  transform: translateY(-1px);
}
.arch-box.blue   { background: var(--c-tint-blue);   border-color: var(--c-accent-border); color: var(--c-accent-text); }
.arch-box.green  { background: var(--c-tint-green);  border-color: var(--c-ok-border);     color: var(--c-ok); }
.arch-box.amber  { background: var(--c-tint-amber);  border-color: var(--c-warn-border);   color: var(--c-warn); }
.arch-box.purple { background: var(--c-tint-purple); border-color: var(--c-purple-border); color: var(--c-purple); }
.arch-box.teal   { background: var(--c-tint-stone);  border-color: var(--c-border-2);      color: var(--c-text-2); }
.arch-arrow { font-size: 1rem; color: var(--c-text-4); }
.arch-connector {
  display: flex; justify-content: center;
  margin: var(--sp-2) 0;
  color: var(--c-text-4);
  font-size: .95rem;
}
.arch-label {
  text-align: center;
  font-size: var(--fs-xs);
  font-weight: 500;
  color: var(--c-text-4);
  letter-spacing: 0.02em;
  margin-bottom: var(--sp-3);
}


/* ─── 12. Quiz & ejercicios ─────────────────────────────────── */
.quiz-box {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: var(--sp-5);
  margin-bottom: var(--sp-4);
  transition: border-color var(--t-mid) var(--ease);
}
.quiz-box.state-correct { border-color: var(--c-ok-border); background: var(--c-ok-soft); }
.quiz-box.state-wrong   { border-color: var(--c-err-border); background: var(--c-err-soft); }
.quiz-q {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: 550;
  color: var(--c-text);
  margin-bottom: var(--sp-4);
  line-height: 1.5;
}
.quiz-q .qn {
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--c-surface-2);
  color: var(--c-text-3);
  border: 1px solid var(--c-border);
  border-radius: var(--r-xs);
  padding: .15rem .5rem;
  font-size: var(--fs-xs);
  font-weight: 600;
  margin-right: var(--sp-2);
}
.quiz-opts { display: flex; flex-direction: column; gap: .5rem; }
.quiz-opt {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm);
  padding: var(--sp-3) var(--sp-4);
  cursor: pointer;
  font-size: var(--fs-base);
  font-weight: 450;
  color: var(--c-text-2);
  display: flex; align-items: center; gap: var(--sp-3);
  transition: all var(--t-fast) var(--ease);
  text-align: left;
  font-family: inherit;
}
.quiz-opt:hover:not(:disabled) {
  border-color: var(--c-text-3);
  background: var(--c-surface-2);
}
.quiz-opt.ans-correct {
  border-color: var(--c-ok);
  background: var(--c-ok-soft);
  color: var(--c-ok);
  font-weight: 550;
}
.quiz-opt.ans-wrong {
  border-color: var(--c-err);
  background: var(--c-err-soft);
  color: var(--c-err);
}
.quiz-opt .ol {
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 600;
  font-size: 0.7rem;
  color: var(--c-text-4);
  width: 22px; height: 22px;
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-radius: var(--r-xs);
  flex-shrink: 0;
  transition: all var(--t-fast) var(--ease);
}
.quiz-opt:hover:not(:disabled) .ol { color: var(--c-text); border-color: var(--c-border-2); }
.quiz-opt.ans-correct .ol { background: var(--c-ok); color: #fff; border-color: var(--c-ok); }
.quiz-opt.ans-wrong   .ol { background: var(--c-err); color: #fff; border-color: var(--c-err); }
.quiz-fb {
  display: none;
  margin-top: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--r-sm);
  font-size: var(--fs-sm);
  line-height: 1.55;
  border: 1px solid;
}
.quiz-fb.show { display: block; animation: fadeIn 200ms var(--ease-out); }
.quiz-fb.fb-ok   { background: var(--c-ok-soft);  color: var(--c-ok);  border-color: var(--c-ok-border); }
.quiz-fb.fb-fail { background: var(--c-err-soft); color: var(--c-err); border-color: var(--c-err-border); }

.quiz-scoreboard {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: var(--sp-5) var(--sp-6);
  margin-bottom: var(--sp-6);
  display: flex; align-items: center; gap: var(--sp-5);
}
.score-ring {
  width: 56px; height: 56px; flex-shrink: 0; border-radius: 50%;
  background: conic-gradient(var(--c-text) var(--p, 0%), var(--c-border) 0%);
  display: flex; align-items: center; justify-content: center;
  position: relative;
}
.score-ring::before {
  content: ''; position: absolute;
  width: 44px; height: 44px;
  background: var(--c-surface); border-radius: 50%; z-index: 1;
}
.score-ring span {
  position: relative; z-index: 2;
  font-family: var(--font-display);
  font-weight: 600; font-size: var(--fs-sm);
  color: var(--c-text);
  font-variant-numeric: tabular-nums;
}
.score-info strong {
  font-family: var(--font-display);
  display: block;
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--c-text);
}
.score-info small { font-size: var(--fs-sm); color: var(--c-text-3); }

/* Ejercicios */
.ex-item {
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  margin-bottom: var(--sp-3);
  overflow: hidden;
  background: var(--c-surface);
  transition: border-color var(--t-mid) var(--ease);
}
.ex-item:hover { border-color: var(--c-border-2); }
.ex-item.open { border-color: var(--c-border-2); }
.ex-head {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-5);
  cursor: pointer;
  background: var(--c-surface);
  border: none; width: 100%;
  text-align: left;
  transition: background var(--t-fast) var(--ease);
  font-family: inherit;
}
.ex-head:hover { background: var(--c-surface-2); }
.ex-item.open .ex-head {
  background: var(--c-surface-2);
  border-bottom: 1px solid var(--c-border);
}
.ex-num {
  background: var(--c-text);
  color: #fff;
  border-radius: var(--r-xs);
  padding: .2rem .55rem;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  flex-shrink: 0;
  font-family: var(--font-mono);
}
.ex-title {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: 550;
  color: var(--c-text);
  flex: 1;
}
.ex-chevron {
  color: var(--c-text-4);
  font-size: 0.75rem;
  transition: transform var(--t-mid) var(--ease);
}
.ex-item.open .ex-chevron { transform: rotate(90deg); color: var(--c-text-2); }
.ex-body {
  display: none;
  padding: var(--sp-5);
  background: var(--c-bg);
}
.ex-item.open .ex-body { display: block; animation: fadeIn 200ms var(--ease-out); }
.ex-desc {
  font-size: var(--fs-base);
  color: var(--c-text-3);
  line-height: 1.65;
  margin: 0 0 var(--sp-4);
}
.ex-task-label {
  font-size: var(--fs-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--c-text-4);
  margin-bottom: var(--sp-2);
}
.ex-task {
  border-left: 2px solid var(--c-border-2);
  padding: var(--sp-1) 0 var(--sp-1) var(--sp-4);
  margin-bottom: var(--sp-4);
}
.ex-task p {
  font-size: var(--fs-base);
  color: var(--c-text-2);
  line-height: 1.65;
  margin: 0;
}
.ex-footer {
  display: flex; align-items: center; gap: var(--sp-4);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--c-border);
}
.done-btn {
  background: var(--c-text);
  color: #fff;
  border: 1px solid var(--c-text);
  border-radius: var(--r-sm);
  padding: var(--sp-2) var(--sp-5);
  font-size: var(--fs-sm);
  font-weight: 550;
  cursor: pointer;
  transition: all var(--t-fast) var(--ease);
  font-family: inherit;
}
.done-btn:hover {
  background: #000;
  border-color: #000;
}
.done-btn:active { transform: translateY(1px); }
.done-btn.completed {
  background: var(--c-ok);
  border-color: var(--c-ok);
  cursor: default;
}
.done-btn.completed:hover { background: var(--c-ok); }
.ex-time {
  font-size: var(--fs-sm);
  color: var(--c-text-4);
  display: inline-flex; align-items: center; gap: .3rem;
}

.ex-progress {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: var(--sp-4) var(--sp-5);
  display: flex; align-items: center; gap: var(--sp-5);
  margin-bottom: var(--sp-5);
}
.ex-prog-ring {
  width: 44px; height: 44px; flex-shrink: 0; border-radius: 50%;
  background: conic-gradient(var(--c-text) var(--p,0%), var(--c-border) 0%);
  display: flex; align-items: center; justify-content: center;
  position: relative;
}
.ex-prog-ring::before {
  content: ''; position: absolute;
  width: 34px; height: 34px;
  background: var(--c-surface); border-radius: 50%;
}
.ex-prog-ring span {
  position: relative; z-index: 1;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--fs-xs);
  color: var(--c-text);
  font-variant-numeric: tabular-nums;
}
.ex-prog-info strong {
  font-family: var(--font-display);
  display: block;
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--c-text);
}
.ex-prog-info small { font-size: var(--fs-sm); color: var(--c-text-3); }


/* ─── 13. Cheatsheet, badges, tech pills ────────────────────── */
.cheat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--sp-4);
}
.cheat-card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  overflow: hidden;
  transition: border-color var(--t-mid) var(--ease);
}
.cheat-card:hover { border-color: var(--c-border-2); }
.cheat-head {
  background: var(--c-surface-2);
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--c-text-3);
  border-bottom: 1px solid var(--c-border);
}
.cheat-row {
  display: flex; align-items: flex-start; gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--c-divider);
  font-size: var(--fs-sm);
  transition: background var(--t-fast) var(--ease);
}
.cheat-row:last-child { border-bottom: none; }
.cheat-row:hover { background: var(--c-surface-2); }
.cheat-cmd {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  white-space: nowrap;
  background: var(--c-surface);
  color: var(--c-text);
  border-radius: var(--r-xs);
  padding: .18rem .5rem;
  flex-shrink: 0;
  margin-top: 0.05rem;
  border: 1px solid var(--c-border);
  font-weight: 500;
}
.cheat-desc { color: var(--c-text-3); line-height: 1.5; }

/* .badge base provided by Bootstrap — solo sobreescribimos tipografía y forma */
.badge { font-size: var(--fs-xs); font-weight: 500; border-radius: var(--r-pill); }
.badge-blue   { background: var(--c-accent-soft); color: var(--c-accent-text); border: 1px solid var(--c-accent-border); }
.badge-green  { background: var(--c-ok-soft);     color: var(--c-ok);          border: 1px solid var(--c-ok-border); }
.badge-amber  { background: var(--c-warn-soft);   color: var(--c-warn);        border: 1px solid var(--c-warn-border); }
.badge-red    { background: var(--c-err-soft);    color: var(--c-err);         border: 1px solid var(--c-err-border); }
.badge-purple { background: var(--c-purple-soft); color: var(--c-purple);      border: 1px solid var(--c-purple-border); }
.badge-teal   { background: var(--c-tint-stone);  color: var(--c-text-2);      border: 1px solid var(--c-border-2); }

.tech-grid {
  display: flex; flex-wrap: wrap; gap: var(--sp-2);
  margin: var(--sp-3) 0 var(--sp-5);
}
.tech-pill {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-pill);
  padding: var(--sp-2) var(--sp-3);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-text-2);
  transition: all var(--t-fast) var(--ease);
}
.tech-pill:hover {
  border-color: var(--c-text-3);
  color: var(--c-text);
}
.tech-pill .dot {
  width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0;
}
.dot-blue   { background: var(--c-accent); }
.dot-green  { background: var(--c-ok); }
.dot-amber  { background: var(--c-warn); }
.dot-purple { background: var(--c-purple); }
.dot-teal   { background: #0F766E; }
.dot-red    { background: var(--c-err); }
.dot-grey   { background: var(--c-text-3); }


/* ─── Flow ──────────────────────────────────────────────────── */
.flow {
  display: flex; align-items: stretch;
  gap: var(--sp-1); flex-wrap: wrap;
  margin: var(--sp-5) 0;
  justify-content: center;
}
.flow-step {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: var(--sp-4) var(--sp-4);
  min-width: 110px; min-height: 84px;
  text-align: center;
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-text);
  line-height: 1.3;
  transition: all var(--t-mid) var(--ease);
}
.flow-step:hover {
  border-color: var(--c-text-3);
  transform: translateY(-1px);
}
.flow-step .fs-icon {
  font-size: 1.25rem; line-height: 1;
  height: 1.4rem;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: var(--sp-2);
  color: var(--c-text-3);
}
.flow-arrow {
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--c-text-4);
  font-size: 1rem;
  padding: 0 var(--sp-2);
  flex-shrink: 0;
  align-self: center;
}
.flow-step.blue  { background: var(--c-tint-blue);  border-color: var(--c-accent-border); color: var(--c-accent-text); }
.flow-step.blue  .fs-icon { color: var(--c-accent); }
.flow-step.green { background: var(--c-tint-green); border-color: var(--c-ok-border);     color: var(--c-ok); }
.flow-step.green .fs-icon { color: var(--c-ok); }


/* ─── Compare ───────────────────────────────────────────────── */
.compare-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--sp-4); margin: var(--sp-4) 0;
}
.compare-col {
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  overflow: hidden;
  background: var(--c-surface);
}
.compare-head {
  padding: var(--sp-3) var(--sp-4);
  font-family: var(--font-display);
  font-size: var(--fs-sm);
  font-weight: 600;
  text-align: center;
  letter-spacing: -0.01em;
}
.compare-head.bad  { background: var(--c-err-soft); color: var(--c-err); border-bottom: 1px solid var(--c-err-border); }
.compare-head.good { background: var(--c-ok-soft);  color: var(--c-ok);  border-bottom: 1px solid var(--c-ok-border); }
.compare-item {
  padding: var(--sp-3) var(--sp-4);
  border-top: 1px solid var(--c-divider);
  font-size: var(--fs-sm);
  display: flex; align-items: flex-start; gap: var(--sp-2);
  color: var(--c-text-2);
}
.compare-item:first-of-type { border-top: none; }


/* ─── 14. Feedback widget ───────────────────────────────────── */
.feedback-widget {
  margin-top: var(--sp-9);
  padding: var(--sp-6);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  background: var(--c-surface);
}
.feedback-header {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--c-text);
  margin-bottom: var(--sp-5);
  letter-spacing: -0.01em;
}
.feedback-stars-row, .feedback-actions-row,
.feedback-note-row, .feedback-footer {
  display: flex; align-items: flex-start; gap: var(--sp-4);
  margin-bottom: var(--sp-4); flex-wrap: wrap;
}
.feedback-label {
  font-size: var(--fs-sm);
  color: var(--c-text-3);
  white-space: nowrap;
  padding-top: .25rem;
  min-width: 80px;
  font-weight: 500;
}
.feedback-stars { display: flex; gap: var(--sp-1); }
.star-btn {
  background: none; border: none;
  font-size: 1.4rem;
  color: var(--c-border-2);
  cursor: pointer; line-height: 1; padding: 0;
  transition: all var(--t-fast) var(--ease);
}
.star-btn.active { color: #E5A53C; }
.star-btn:hover { color: #E5A53C; transform: scale(1.1); }

.feedback-actions { display: flex; gap: var(--sp-2); flex-wrap: wrap; }
.feedback-action-btn {
  display: inline-flex; align-items: center;
  padding: var(--sp-2) var(--sp-4);
  border: 1px solid var(--c-border);
  border-radius: var(--r-pill);
  background: var(--c-surface);
  color: var(--c-text-2);
  font-size: var(--fs-sm);
  font-weight: 500;
  font-family: inherit;
  cursor: pointer;
  transition: all var(--t-fast) var(--ease);
}
.feedback-action-btn:hover {
  border-color: var(--c-text-3);
  background: var(--c-surface-2);
  color: var(--c-text);
}
.feedback-action-btn.selected {
  background: var(--c-text);
  color: #fff;
  border-color: var(--c-text);
}

.feedback-textarea {
  width: 100%;
  padding: var(--sp-3) var(--sp-4);
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm);
  background: var(--c-surface);
  color: var(--c-text);
  font-size: var(--fs-base);
  font-family: var(--font);
  resize: vertical;
  min-height: 90px;
  transition: all var(--t-fast) var(--ease);
}
.feedback-textarea:focus {
  outline: none;
  border-color: var(--c-text-3);
  box-shadow: var(--sh-focus);
}

.feedback-save-btn {
  display: inline-flex; align-items: center; gap: .35rem;
  padding: var(--sp-3) var(--sp-6);
  background: var(--c-text);
  color: #fff; border: 1px solid var(--c-text);
  border-radius: var(--r-sm);
  font-size: var(--fs-base);
  font-weight: 550;
  font-family: var(--font);
  cursor: pointer;
  transition: all var(--t-fast) var(--ease);
}
.feedback-save-btn:hover { background: #000; border-color: #000; }
.feedback-save-btn:active { transform: translateY(1px); }
.feedback-save-btn:disabled {
  opacity: 0.5; cursor: not-allowed; transform: none;
}

.feedback-saved-indicator {
  font-size: var(--fs-sm);
  opacity: 0;
  transition: opacity var(--t-mid) var(--ease);
  align-self: center;
  font-weight: 500;
}
.feedback-saved-indicator.visible { opacity: 1; }
.feedback-saved-indicator.ok    { color: var(--c-ok); }
.feedback-saved-indicator.warn  { color: var(--c-warn); }
.feedback-saved-indicator.error { color: var(--c-err); }

.feedback-server-msg {
  display: flex; align-items: center; gap: var(--sp-3);
  margin-top: var(--sp-2);
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--r-sm);
  font-size: var(--fs-sm);
  flex-wrap: wrap;
  border: 1px solid;
}
.feedback-server-msg.msg-error { background: var(--c-err-soft);  color: var(--c-err);  border-color: var(--c-err-border); }
.feedback-server-msg.msg-warn  { background: var(--c-warn-soft); color: var(--c-warn); border-color: var(--c-warn-border); }
.msg-dl-btn {
  padding: .2rem .55rem;
  background: var(--c-surface);
  border: 1px solid currentColor;
  border-radius: var(--r-xs);
  color: inherit;
  font-size: var(--fs-xs);
  font-weight: 500;
  cursor: pointer; white-space: nowrap;
  transition: background var(--t-fast) var(--ease);
}
.msg-dl-btn:hover { background: rgba(255,255,255,0.6); }

/* Backend status */
.backend-status-badge {
  display: inline-flex; align-items: center; gap: .35rem;
  font-size: var(--fs-xs);
  font-weight: 500;
  padding: .2rem .5rem;
  border-radius: var(--r-xs);
  margin-top: .35rem;
  border: 1px solid;
}
.backend-status-badge.badge-ok    { background: var(--c-ok-soft);   color: var(--c-ok);   border-color: var(--c-ok-border); }
.backend-status-badge.badge-error { background: var(--c-err-soft);  color: var(--c-err);  border-color: var(--c-err-border); }
.backend-status-badge.badge-warn  { background: var(--c-warn-soft); color: var(--c-warn); border-color: var(--c-warn-border); }

.btn-download-mejoras {
  display: flex; align-items: center; gap: var(--sp-2);
  width: 100%;
  padding: var(--sp-2) var(--sp-3);
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm);
  color: var(--c-text-3);
  font-size: var(--fs-sm);
  font-weight: 500;
  cursor: pointer;
  transition: all var(--t-fast) var(--ease);
  margin-top: var(--sp-2);
  font-family: inherit;
}
.btn-download-mejoras:hover {
  border-color: var(--c-text-3);
  color: var(--c-text);
  background: var(--c-surface-2);
}


/* ─── 15. Focus visible ─────────────────────────────────────── */
:focus-visible {
  outline: none;
  box-shadow: var(--sh-focus);
  border-radius: var(--r-xs);
}
.nav-item:focus-visible {
  box-shadow: inset 0 0 0 2px var(--c-accent);
  border-radius: 0;
}


/* ─── 16. Course navbar (clean & light) ─────────────────────── */
.course-navbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--navbar-h);
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(12px) saturate(180%);
  -webkit-backdrop-filter: blur(12px) saturate(180%);
  border-bottom: 1px solid var(--c-border);
  z-index: 1030;
  display: flex; align-items: center;
}
.course-navbar-inner {
  display: flex; align-items: center;
  width: 100%;
  padding: 0 var(--sp-5);
  gap: var(--sp-2);
}
.course-navbar-back {
  display: inline-flex; align-items: center; gap: .35rem;
  color: var(--c-text-3); text-decoration: none;
  font-size: var(--fs-sm); font-weight: 500;
  padding: .35rem .65rem;
  border-radius: var(--r-sm);
  transition: all var(--t-fast) var(--ease);
  white-space: nowrap; flex-shrink: 0;
}
.course-navbar-back:hover {
  color: var(--c-text); text-decoration: none;
  background: var(--c-surface-2);
}
.course-navbar-links {
  display: flex; align-items: center; gap: .15rem;
  justify-content: center; flex: 1;
}
.course-navbar-link {
  display: inline-flex; align-items: center; gap: .3rem;
  color: var(--c-text-3); text-decoration: none;
  font-size: var(--fs-sm); font-weight: 500;
  padding: .35rem .75rem;
  border-radius: var(--r-sm);
  transition: all var(--t-fast) var(--ease);
  white-space: nowrap;
}
.course-navbar-link i { font-size: 0.85rem; }
.course-navbar-link:hover {
  color: var(--c-text); text-decoration: none;
  background: var(--c-surface-2);
}
.course-navbar-link.active {
  color: var(--c-text);
  background: var(--c-surface-2);
  font-weight: 550;
}
.course-navbar-sep {
  width: 1px; height: 20px;
  background: var(--c-border);
  margin: 0 .25rem; flex-shrink: 0;
}
.course-navbar-user {
  display: flex; align-items: center; gap: var(--sp-3);
  margin-left: auto; flex-shrink: 0;
}
.course-navbar-username {
  color: var(--c-text-3);
  font-size: var(--fs-sm); font-weight: 500;
}
.course-navbar-avatar {
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--c-text); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: var(--fs-sm); font-weight: 600;
  transition: all var(--t-fast) var(--ease);
  cursor: pointer;
}
.course-navbar-avatar:hover { transform: scale(1.05); }

/* Color variants — activos con tinte semántico */
.course-navbar-link.cn-blue.active   { color: var(--c-accent);  background: var(--c-accent-soft); }
.course-navbar-link.cn-green.active  { color: var(--c-ok);      background: var(--c-ok-soft); }
.course-navbar-link.cn-amber.active  { color: var(--c-warn);    background: var(--c-warn-soft); }
.course-navbar-link.cn-purple.active { color: var(--c-purple);  background: var(--c-purple-soft); }
.course-navbar-link.cn-teal.active   { color: #0F766E;          background: #CCFBF1; }
.course-navbar-link.cn-red.active    { color: var(--c-err);     background: var(--c-err-soft); }

/* Dropdowns */
.course-navbar-dropdown {
  position: relative; display: inline-flex;
}
.course-navbar-dropdown .dropdown-content {
  display: none; position: absolute; top: 100%; left: 50%; transform: translateX(-50%);
  background: var(--c-surface, #fff); border: 1px solid var(--c-border, #e2e2e0);
  border-radius: var(--r-sm, 8px); padding: 0.35rem 0;
  min-width: 160px; z-index: 1100;
  box-shadow: var(--sh-md, 0 2px 6px rgba(15,15,15,0.06), 0 10px 32px rgba(15,15,15,0.07));
}
.course-navbar-dropdown:hover .dropdown-content,
.course-navbar-dropdown .dropdown-content:hover { display: block; }
.course-navbar-dropdown .dropdown-content a {
  display: flex; align-items: center; gap: 0.4rem;
  padding: 0.45rem 1rem; color: var(--c-text-2, #37352f);
  font-size: 0.8rem; text-decoration: none; white-space: nowrap;
}
.course-navbar-dropdown .dropdown-content a:hover {
  background: var(--c-surface-2, #f7f7f5); color: var(--c-text, #1f1f1f);
}
.course-navbar-dropdown .dropdown-content i { font-size: 0.85rem; color: var(--c-text-4, #9b9b9b); }

/* Dark mode dropdown */
[data-theme="dark"] .course-navbar-dropdown .dropdown-content {
  background: #1a1d23; border-color: #2d333b;
  box-shadow: 0 8px 24px rgba(0,0,0,0.4);
}
[data-theme="dark"] .course-navbar-dropdown .dropdown-content a { color: #c9d1d9; }
[data-theme="dark"] .course-navbar-dropdown .dropdown-content a:hover { background: rgba(255,255,255,0.06); color: #fff; }
[data-theme="dark"] .course-navbar-dropdown .dropdown-content i { color: #8b949e; }

@media (max-width: 768px) {
  .course-navbar-dropdown .dropdown-content { left: auto; right: 0; transform: none; }
}

@media (max-width: 560px) {
  .course-navbar-link span { display: none; }
  .course-navbar-link { padding: .35rem .5rem; }
  .course-navbar-username { display: none; }
}


/* ─── Overlay ───────────────────────────────────────────────── */
.overlay {
  display: none; position: fixed; inset: 0;
  background: rgba(15, 15, 15, 0.35);
  backdrop-filter: blur(2px);
  z-index: 190;
}
.overlay.show { display: block; animation: fadeIn 200ms var(--ease); }


/* ─── 17. Modo oscuro elegante ──────────────────────────────── */
[data-theme="dark"] {
  --c-bg:        #0F0F0F;
  --c-surface:   #181818;
  --c-surface-2: #2A2A2A;
  --c-surface-3: #262626;
  --c-border:    #262626;
  --c-border-2:  #333;
  --c-divider:   #1F1F1F;

  --c-text:    #FAFAFA;
  --c-text-2:  #E5E5E5;
  --c-text-3:  #A1A1A1;
  --c-text-4:  #737373;
  --c-text-5:  #525252;

  --c-accent:        #6997FB;
  --c-accent-hover:  #8AB0FC;
  --c-accent-soft:   rgba(105, 151, 251, 0.12);
  --c-accent-border: rgba(105, 151, 251, 0.25);
  --c-accent-text:   #94B5FA;

  --c-ok:        #4ADE80;
  --c-ok-soft:   rgba(74, 222, 128, 0.10);
  --c-ok-border: rgba(74, 222, 128, 0.22);
  --c-warn:        #FBBF24;
  --c-warn-soft:   rgba(251, 191, 36, 0.10);
  --c-warn-border: rgba(251, 191, 36, 0.22);
  --c-err:        #F87171;
  --c-err-soft:   rgba(248, 113, 113, 0.10);
  --c-err-border: rgba(248, 113, 113, 0.22);
  --c-purple:        #A78BFA;
  --c-purple-soft:   rgba(167, 139, 250, 0.10);
  --c-purple-border: rgba(167, 139, 250, 0.22);

  --c-tint-blue:   rgba(105, 151, 251, 0.08);
  --c-tint-green:  rgba(74, 222, 128, 0.08);
  --c-tint-amber:  rgba(251, 191, 36, 0.08);
  --c-tint-rose:   rgba(248, 113, 113, 0.08);
  --c-tint-purple: rgba(167, 139, 250, 0.08);
  --c-tint-stone:  #1F1F1F;
}

[data-theme="dark"] body { color: var(--c-text-2); background: var(--c-bg); }
[data-theme="dark"] .topbar { background: rgba(15,15,15,0.85); }
[data-theme="dark"] .course-navbar { background: rgba(15,15,15,0.85); border-bottom-color: var(--c-border); }
[data-theme="dark"] .code-wrap { background: #141414; }
[data-theme="dark"] .code-wrap pre { color: #E5E5E5; }
[data-theme="dark"] .code-wrap .t-comment { color: #737373; }
[data-theme="dark"] .code-wrap .t-cmd     { color: #94B5FA; }
[data-theme="dark"] .code-wrap .t-str     { color: #FBBF24; }
[data-theme="dark"] .code-wrap .t-key     { color: #A78BFA; }
[data-theme="dark"] .code-wrap .t-ok      { color: #4ADE80; }
[data-theme="dark"] .code-wrap .t-red     { color: #F87171; }
[data-theme="dark"] .code-wrap .t-hl      { color: #A78BFA; }
[data-theme="dark"] .sidebar-progress .progress-bar { background: var(--c-text); }
[data-theme="dark"] .ex-num { background: var(--c-text); color: var(--c-bg); }
[data-theme="dark"] .done-btn,
[data-theme="dark"] .feedback-save-btn { background: var(--c-text); color: var(--c-bg); border-color: var(--c-text); }
[data-theme="dark"] .done-btn:hover,
[data-theme="dark"] .feedback-save-btn:hover { background: #fff; border-color: #fff; }
[data-theme="dark"] .feedback-action-btn.selected { background: var(--c-text); color: var(--c-bg); border-color: var(--c-text); }
[data-theme="dark"] .course-navbar-avatar { background: var(--c-text); color: var(--c-bg); }

/* Theme toggle button */
.theme-toggle {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px;
  appearance: none; -webkit-appearance: none;
  background: transparent;
  border: none;
  border-radius: var(--r-sm);
  color: var(--c-text-3);
  font-size: 0.95rem;
  cursor: pointer;
  transition: all var(--t-fast) var(--ease);
}
.theme-toggle:hover {
  background: var(--c-surface-2);
  color: var(--c-text);
}


/* ─── 18. Print ─────────────────────────────────────────────── */
@media print {
  .sidebar, .topbar, .hamburger, .course-navbar { display: none !important; }
  .main { flex: 1; }
  .panel { display: block !important; padding: 1rem; page-break-after: always; }
  body { background: #fff; color: #000; }
}


/* ─── Responsive ────────────────────────────────────────────── */
@media (max-width: 900px) {
  .panel { padding: var(--sp-6) var(--sp-5) var(--sp-9); }
  .stats-row { grid-template-columns: repeat(2, 1fr); }
  .card-grid-2, .card-grid-3 { grid-template-columns: 1fr; }
  .compare-grid { grid-template-columns: 1fr; }
  .panel-title { font-size: var(--fs-3xl); }
}
@media (max-width: 560px) {
  .stats-row { grid-template-columns: 1fr; }
  .flow { flex-direction: column; }
  .flow-arrow { transform: rotate(90deg); }
  .topbar { padding: var(--sp-3) var(--sp-4); }
  .panel-title { font-size: var(--fs-2xl); }
  .panel-desc { font-size: var(--fs-md); }
  .quiz-scoreboard, .ex-progress {
    flex-direction: column; align-items: flex-start; gap: var(--sp-3);
  }
  .score-ring, .ex-prog-ring { align-self: center; }
  .cheat-grid { grid-template-columns: 1fr; }
}
@media (max-width: 400px) {
  .panel { padding: var(--sp-5) var(--sp-4) var(--sp-9); }
  .topbar { padding: var(--sp-2) var(--sp-3); }
  .panel-title { font-size: 1.6rem; }
  .section-h2 { font-size: var(--fs-lg); }
}


/* ─── Reduced motion ────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}
