/* ════════════════════════════════════════════════════════════════
   APEX — Navegación adaptable + hogares Start / Performance Lab
   Fase 6.A. Se encola globalmente (depende de apex-tokens.css).
   Brand Kit v2: Lima #C8FF00 sobre Dark Teal, isotipo, SVG monocromos,
   radios 3/6/12, sin emojis, tuteo neutro.

   ALCANCE / NO ROMPER:
   - En páginas internas (dashboard, cursos…) la barra .apex-mob-nav YA se
     estila en apex-shell.css. Aquí NO se redefine su base: solo se añade el
     switch de modo, la hoja "Próximamente" y el botón de menú del topbar.
   - Las páginas-app (body.apex-app = Start / Lab) NO cargan apex-shell.css,
     así que aquí se define su layout completo, todo scoped a body.apex-app.
   ════════════════════════════════════════════════════════════════ */

:root {
  --apex-pos: #6ee7a0;
  --apex-neg: #ff7a7a;
  --apex-nav-h: 60px;
}

/* ════════════════════════════════════════════════════════════════
   1 · SELLO "PRÓXIMAMENTE" (inline, reutilizable)
   ════════════════════════════════════════════════════════════════ */
.apex-soon-tag {
  display: inline-flex; align-items: center;
  font-family: var(--font-mono); font-size: 9px; font-weight: 600;
  letter-spacing: .1em; text-transform: uppercase;
  padding: 3px 8px; border-radius: var(--radius);
  background: var(--accent-bg); color: var(--accent);
  border: 1px solid var(--accent-bd); white-space: nowrap;
}

/* ════════════════════════════════════════════════════════════════
   2 · SWITCH DE MODO (Academia ↔ Performance Lab)
   Fijo, centrado, justo encima de la barra inferior — nunca choca con
   el topbar existente y es alcanzable con el pulgar.
   ════════════════════════════════════════════════════════════════ */
.apex-modeswitch {
  position: fixed; left: 50%; transform: translateX(-50%); z-index: 60;
  bottom: calc(var(--apex-nav-h) + 12px + env(safe-area-inset-bottom, 0px));
  display: inline-flex; gap: 2px; padding: 3px;
  background: var(--bg-deeper); border: 1px solid var(--border2);
  border-radius: 999px; box-shadow: 0 8px 24px rgba(0, 0, 0, .45);
}
.apex-modeswitch-opt {
  font-family: var(--font-mono); font-size: 10px; font-weight: 600;
  letter-spacing: .08em; text-transform: uppercase; text-decoration: none;
  color: var(--gray); padding: 7px 16px; border-radius: 999px;
  transition: color .15s, background .15s; white-space: nowrap;
}
.apex-modeswitch-opt.active { color: var(--accent-t); background: var(--accent); }
.apex-modeswitch-opt:not(.active):hover { color: var(--text); }

/* En escritorio y en páginas internas (con sidebar), el switch flotante se
   oculta: la barra inferior solo existe en móvil. En páginas-app (Start/Lab)
   no hay sidebar, así que el switch se mantiene a todos los anchos. */
@media (min-width: 781px) {
  body:not(.apex-app) .apex-modeswitch { display: none; }
}

/* Páginas internas (dashboard, cursos…) en móvil: .content ya reserva 80px
   para la barra inferior (apex-shell.css), pero no para el switch flotante
   que vive encima de ella. Sin esto, el switch tapa los últimos ~30px de
   contenido al hacer scroll cuando el alumno tiene Academy + Performance.
   Solo afecta a quien tiene ambos niveles; el resto de alumnos no cambia. */
@media (max-width: 780px) {
  body.apex-has-modeswitch:not(.apex-app) .content {
    padding-bottom: 148px !important;
  }
}

/* En páginas internas, el switch flota sobre el contenido; el contenido ya
   tiene scroll propio, así que no hace falta empujar nada salvo asegurar que
   la barra inferior no lo tape (ya están escalonados por el bottom). */

/* ════════════════════════════════════════════════════════════════
   3 · HOJA "PRÓXIMAMENTE" (para ítems aún no construidos)
   ════════════════════════════════════════════════════════════════ */
.apex-soon-overlay {
  display: none; position: fixed; inset: 0; z-index: 998;
  background: rgba(6, 15, 20, .6); backdrop-filter: blur(2px);
}
.apex-soon-overlay.visible { display: block; }
.apex-soon-sheet {
  position: fixed; left: 50%; bottom: 0; transform: translateX(-50%) translateY(110%);
  width: min(440px, 100vw); z-index: 999;
  background: var(--bg2); border: 1px solid var(--border2);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  padding: 14px 22px calc(26px + env(safe-area-inset-bottom, 0px));
  text-align: center; transition: transform .3s cubic-bezier(.22, 1, .36, 1);
}
.apex-soon-sheet.visible { transform: translateX(-50%) translateY(0); }
.apex-soon-grip { width: 38px; height: 4px; border-radius: 2px; background: var(--bg5); margin: 0 auto 16px; }
.apex-soon-seal {
  display: inline-flex; font-family: var(--font-mono); font-size: 9px; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase; padding: 4px 10px;
  border-radius: var(--radius); background: var(--accent-bg);
  color: var(--accent); border: 1px solid var(--accent-bd); margin-bottom: 12px;
}
.apex-soon-title {
  font-family: var(--font-display); font-size: 19px; font-weight: 800;
  color: var(--text); text-transform: uppercase; letter-spacing: .01em; margin-bottom: 8px;
}
.apex-soon-text { font-family: var(--font-body, 'Barlow', sans-serif); font-size: 14px; color: var(--gray); line-height: 1.5; margin: 0 0 18px; }
.apex-soon-btn {
  width: 100%; height: 46px; border: none; cursor: pointer;
  background: var(--accent); color: var(--accent-t);
  font-family: var(--font-display); font-weight: 700; font-size: 14px;
  letter-spacing: .06em; text-transform: uppercase; border-radius: var(--radius-md);
}

/* ════════════════════════════════════════════════════════════════
   4 · BOTÓN DE MENÚ EN EL TOPBAR (zona Academy, solo móvil)
   Inyectado por JS para no perder acceso al drawer (perfil, biblioteca…).
   ════════════════════════════════════════════════════════════════ */
.apex-topbar-burger {
  display: none; align-items: center; justify-content: center;
  width: 36px; height: 36px; margin-right: 4px; flex: 0 0 36px;
  background: var(--bg3); border: 1px solid var(--border); border-radius: var(--radius-md);
  color: var(--text); cursor: pointer;
}
@media (max-width: 780px) { .apex-topbar-burger { display: inline-flex; } }

/* ════════════════════════════════════════════════════════════════
   5 · LAYOUT DE PÁGINAS-APP (Start / Performance Lab)
   Todo scoped a body.apex-app — no afecta a las páginas internas.
   ════════════════════════════════════════════════════════════════ */
body.apex-app {
  min-height: 100vh; background: var(--bg); color: var(--text);
  font-family: var(--font-body, 'Barlow', -apple-system, sans-serif);
}
.apex-app-shell { min-height: 100vh; display: flex; flex-direction: column; max-width: 560px; margin: 0 auto; }

/* Topbar */
.apex-app-topbar {
  position: sticky; top: 0; z-index: 40;
  height: calc(56px + env(safe-area-inset-top, 0px));
  padding: env(safe-area-inset-top, 0px) 16px 0;
  display: flex; align-items: center; gap: 12px;
  background: rgba(10, 30, 38, .97); backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
}
.apex-app-iso {
  width: 38px; height: 38px; flex: 0 0 38px; border-radius: var(--radius-md);
  background: var(--bg4); border: 1px solid var(--accent-bd);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-size: 19px; font-weight: 900;
  color: var(--text); text-decoration: none; line-height: 1; letter-spacing: -.01em;
}
.apex-app-iso i { color: var(--accent); font-style: normal; }
.apex-app-titles { min-width: 0; }
.apex-app-kicker { font-family: var(--font-mono); font-size: 9px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--gray2); }
.apex-app-title { font-family: var(--font-display); font-size: 19px; font-weight: 800; color: var(--text); text-transform: uppercase; letter-spacing: .02em; line-height: 1.1; }
.apex-app-access {
  margin-left: auto; flex-shrink: 0;
  font-family: var(--font-mono); font-size: 10px; font-weight: 600;
  letter-spacing: .08em; text-transform: uppercase; text-decoration: none;
  color: var(--gray); padding: 8px 12px; border: 1px solid var(--border); border-radius: var(--radius);
  transition: color .15s, border-color .15s;
}
.apex-app-access:hover { color: var(--text); border-color: var(--border2); }

/* Contenido (deja espacio para la barra inferior fija) */
.apex-app-content {
  flex: 1; padding: 18px 16px;
  padding-bottom: calc(var(--apex-nav-h) + 28px + env(safe-area-inset-bottom, 0px));
}
body.apex-app.apex-has-modeswitch .apex-app-content {
  padding-bottom: calc(var(--apex-nav-h) + 70px + env(safe-area-inset-bottom, 0px));
}

/* Barra inferior en páginas-app (apex-shell.css no se carga aquí) */
body.apex-app .apex-mob-nav {
  position: fixed; bottom: 0; left: 50%; transform: translateX(-50%);
  width: 100%; max-width: 560px; z-index: 50;
  height: calc(var(--apex-nav-h) + env(safe-area-inset-bottom, 0px));
  padding-bottom: env(safe-area-inset-bottom, 0px);
  display: flex; align-items: stretch;
  background: var(--bg-deeper); border-top: 1px solid var(--border);
}
body.apex-app .apex-mob-nav-item {
  flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 4px; text-decoration: none; color: var(--gray2);
  font-family: var(--font-mono); font-size: 9px; font-weight: 600; letter-spacing: .04em;
  transition: color .15s; position: relative;
}
body.apex-app .apex-mob-nav-item.active { color: var(--accent); }
body.apex-app .apex-mob-nav-item:hover { color: var(--text); }
body.apex-app .apex-mob-nav-item.active::before {
  content: ''; position: absolute; top: 0; left: 50%; transform: translateX(-50%);
  width: 26px; height: 2px; background: var(--accent); border-radius: 0 0 2px 2px;
}
body.apex-app .apex-mob-nav-ico { display: flex; }

/* ════════════════════════════════════════════════════════════════
   6 · PERFORMANCE LAB — tarjetas demo
   ════════════════════════════════════════════════════════════════ */
.apex-lab-hero {
  background: linear-gradient(160deg, var(--bg3), var(--bg2));
  border: 1px solid var(--accent-bd); border-radius: var(--radius-lg);
  padding: 18px; margin-bottom: 14px;
}
.apex-lab-hero-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 10px; }
.apex-lab-hero-label { font-family: var(--font-mono); font-size: 10px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--gray); }
.apex-lab-hero-score { display: flex; align-items: baseline; gap: 8px; }
.apex-lab-score-num { font-family: var(--font-display); font-size: 64px; font-weight: 900; color: var(--accent); line-height: 1; letter-spacing: -.02em; }
.apex-lab-score-max { font-family: var(--font-mono); font-size: 14px; color: var(--gray2); }
.apex-lab-score-tend { margin-left: auto; font-family: var(--font-mono); font-size: 13px; font-weight: 600; color: var(--apex-pos); }
.apex-lab-hero-meta { display: flex; flex-direction: column; gap: 3px; margin-top: 12px; font-size: 13px; color: var(--text); }
.apex-lab-hero-meta span { color: var(--gray); }
.apex-lab-hero-note { margin: 12px 0 0; font-size: 12px; color: var(--gray2); font-style: italic; }

.apex-lab-card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 16px; margin-bottom: 14px; }
.apex-lab-card-head { display: flex; align-items: center; gap: 8px; margin-bottom: 14px; }
.apex-lab-card-ico { display: flex; color: var(--accent); }
.apex-lab-card-head h3 { font-family: var(--font-display); font-size: 15px; font-weight: 800; color: var(--text); text-transform: uppercase; letter-spacing: .03em; margin: 0; }
.apex-lab-card-head .apex-soon-tag { margin-left: auto; }

.apex-lab-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.apex-lab-stat { background: var(--bg3); border: 1px solid var(--border); border-radius: var(--radius-md); padding: 12px; display: flex; flex-direction: column; gap: 3px; }
.apex-lab-stat .v { font-family: var(--font-display); font-size: 22px; font-weight: 800; color: var(--text); line-height: 1; }
.apex-lab-stat .v.pos { color: var(--apex-pos); }
.apex-lab-stat .v.neg { color: var(--apex-neg); }
.apex-lab-stat .k { font-family: var(--font-mono); font-size: 9px; font-weight: 500; letter-spacing: .06em; text-transform: uppercase; color: var(--gray); }
.apex-lab-muestra { margin: 12px 0 0; font-size: 11px; color: var(--gray2); }

.apex-lab-chart-demo { height: 120px; background: var(--bg3); border: 1px solid var(--border); border-radius: var(--radius-md); margin-bottom: 12px; overflow: hidden; }
.apex-lab-chart-demo svg { width: 100%; height: 100%; display: block; opacity: .85; }

.apex-lab-locked .apex-lab-locked-text { font-size: 13px; color: var(--gray); line-height: 1.5; margin: 0; }
.apex-lab-alerts { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.apex-lab-alerts li { display: flex; align-items: center; gap: 10px; font-size: 13px; color: var(--text); }
.apex-lab-alerts .dot { width: 8px; height: 8px; border-radius: 50%; flex: 0 0 8px; }
.apex-lab-alerts .dot.ok { background: var(--apex-pos); }
.apex-lab-alerts .dot.warn { background: #ffce6b; }

.apex-lab-report-rows { display: flex; flex-direction: column; gap: 8px; margin-top: 14px; }
.apex-lab-report-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 12px; background: var(--bg3); border: 1px solid var(--border); border-radius: var(--radius-md); font-size: 13px; color: var(--text); }
.apex-lab-report-row > span:first-child { display: inline-flex; align-items: center; gap: 8px; }
.apex-lab-report-row svg { color: var(--gray); }

/* ════════════════════════════════════════════════════════════════
   7 · APEX START — shell público
   ════════════════════════════════════════════════════════════════ */
.apex-start-hero { padding: 14px 0 22px; }
.apex-start-hero-title { font-family: var(--font-display); font-size: clamp(26px, 7vw, 34px); font-weight: 900; color: var(--text); text-transform: uppercase; letter-spacing: .01em; line-height: 1.08; margin: 0 0 12px; }
.apex-start-hero-sub { font-size: 15px; color: var(--gray); line-height: 1.5; margin: 0 0 20px; }
.apex-start-cta {
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--accent); color: var(--accent-t); text-decoration: none;
  font-family: var(--font-display); font-weight: 700; font-size: 14px;
  letter-spacing: .06em; text-transform: uppercase;
  padding: 14px 22px; border-radius: var(--radius-md);
}

.apex-start-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.apex-start-tile {
  display: flex; flex-direction: column; gap: 6px; text-decoration: none;
  background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius-lg);
  padding: 16px; transition: border-color .15s, transform .15s;
}
.apex-start-tile:hover { border-color: var(--accent-bd); transform: translateY(-2px); }
.apex-start-tile-ico { display: flex; color: var(--accent); margin-bottom: 4px; }
.apex-start-tile-t { font-family: var(--font-display); font-size: 15px; font-weight: 800; color: var(--text); text-transform: uppercase; letter-spacing: .02em; line-height: 1.1; }
.apex-start-tile-s { font-size: 12px; color: var(--gray); line-height: 1.4; }
.apex-start-tile-accent { background: var(--accent-bg); border-color: var(--accent-bd); }

.apex-start-empty { text-align: center; padding: 40px 16px; display: flex; flex-direction: column; align-items: center; gap: 12px; }
.apex-start-empty-ico { display: flex; align-items: center; justify-content: center; width: 56px; height: 56px; border-radius: var(--radius-lg); background: var(--bg3); border: 1px solid var(--border); color: var(--accent); }
.apex-start-empty-ico svg { width: 24px; height: 24px; }
.apex-start-empty h2 { font-family: var(--font-display); font-size: 22px; font-weight: 800; color: var(--text); text-transform: uppercase; letter-spacing: .02em; margin: 4px 0 0; }
.apex-start-empty p { font-size: 14px; color: var(--gray); line-height: 1.5; max-width: 320px; margin: 0; }
.apex-start-back { font-family: var(--font-mono); font-size: 11px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: var(--accent); text-decoration: none; margin-top: 6px; }

/* ════════════════════════════════════════════════════════════════
   8 · SAFE-AREA — switch de modo en modo standalone (páginas-app)
   En páginas internas el safe-area de .apex-mob-nav ya lo maneja apex-pwa.css.
   ════════════════════════════════════════════════════════════════ */
@media (display-mode: standalone) {
  body.apex-standalone.apex-app .apex-mob-nav { height: calc(var(--apex-nav-h) + env(safe-area-inset-bottom, 0px)); }
}
