/* ============================================================
   COCUYO — Sistema de diseño (tokens)
   La ÚNICA fuente de verdad de estilos base. Ver CLAUDE.md.
   ============================================================ */

:root {
  /* --- Color: la oscuridad y la luz del Cocuyo --- */
  --negro-abismo: #050807;      /* fondo principal — nunca #000 puro */
  --negro-elevado: #0B0F0D;     /* tarjetas, superficies elevadas */
  --negro-borde: #14201B;       /* bordes sutiles */
  --verde-cocuyo: #00FF88;      /* EL verde — acento principal, glow */
  --verde-profundo: #0A3D2A;    /* fondos de acento, estados */
  --verde-apagado: #1E5C42;     /* hover/pressed de elementos verdes */
  --blanco-luz: #EAFFF5;        /* texto principal (blanco verdoso) */
  --gris-niebla: #8FA89C;       /* texto secundario */
  --gris-humo: #4A5B53;         /* texto terciario, placeholders */
  --peligro: #FF4D5E;           /* errores */

  /* --- El glow (la firma visual) --- */
  --glow-suave: 0 0 12px rgba(0, 255, 136, 0.35);
  --glow-medio: 0 0 24px rgba(0, 255, 136, 0.45), 0 0 6px rgba(0, 255, 136, 0.6);
  --glow-fuerte: 0 0 48px rgba(0, 255, 136, 0.55), 0 0 12px rgba(0, 255, 136, 0.8);

  /* --- Tipografía (sistema, sin CDNs) --- */
  --fuente: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --fuente-mono: "Cascadia Code", "SF Mono", Consolas, monospace; /* para "coordenadas del universo" */
  --texto-xs: 0.75rem;
  --texto-sm: 0.875rem;
  --texto-base: 1rem;
  --texto-lg: 1.25rem;
  --texto-xl: 1.75rem;
  --texto-hero: clamp(2rem, 8vw, 3.5rem);

  /* --- Espaciado y forma --- */
  --esp-1: 0.25rem; --esp-2: 0.5rem; --esp-3: 0.75rem;
  --esp-4: 1rem;    --esp-6: 1.5rem; --esp-8: 2rem;
  --radio-sm: 8px; --radio-md: 14px; --radio-lg: 22px; --radio-pill: 999px;

  /* --- Capas --- */
  --z-nav: 100; --z-overlay: 200; --z-modal: 300;

  /* --- Movimiento --- */
  --trans-rapida: 150ms ease;
  --trans-media: 300ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

/* ============ Reset y base ============ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; }
body {
  background: var(--negro-abismo);
  color: var(--blanco-luz);
  font-family: var(--fuente);
  font-size: var(--texto-base);
  line-height: 1.5;
  min-height: 100dvh;
  -webkit-font-smoothing: antialiased;
}
img, video { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: none; cursor: pointer; }
input, select, textarea { font: inherit; }

/* ============ El wordmark (COCUYO con la 2ª O encendida) ============ */
.wordmark { font-weight: 800; letter-spacing: 0.14em; color: var(--blanco-luz); }
.wordmark .o-viva { color: var(--verde-cocuyo); text-shadow: var(--glow-medio); }

/* ============ Los dos faros (logo mínimo, puro CSS) ============ */
.faros { display: inline-flex; gap: 0.45em; align-items: center; }
.faros i {
  width: 0.55em; height: 0.55em; border-radius: 50%;
  background: var(--verde-cocuyo);
  box-shadow: var(--glow-medio);
  animation: respirar 3.2s ease-in-out infinite;
}
.faros i:last-child { animation-delay: 0.25s; }
@keyframes respirar {
  0%, 100% { opacity: 1; box-shadow: var(--glow-medio); }
  50% { opacity: 0.82; box-shadow: var(--glow-suave); }
}

/* ============ Botones ============ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--esp-2);
  padding: 0.8em 1.6em; border-radius: var(--radio-pill);
  font-weight: 700; transition: transform var(--trans-rapida), box-shadow var(--trans-media);
  min-height: 48px; /* táctil: pulgar */
}
.btn:active { transform: scale(0.97); }
.btn-primario { background: var(--verde-cocuyo); color: #04150D; box-shadow: var(--glow-suave); }
.btn-primario:hover { box-shadow: var(--glow-medio); }
.btn-fantasma { border: 1px solid var(--negro-borde); color: var(--blanco-luz); background: rgba(11,15,13,0.6); }
.btn-fantasma:hover { border-color: var(--verde-apagado); }

/* ============ Tarjeta de mundo (carátula que se enciende) ============ */
.mundo-card {
  position: relative; border-radius: var(--radio-md); overflow: hidden;
  background: var(--negro-elevado); border: 1px solid var(--negro-borde);
  transition: transform var(--trans-media), box-shadow var(--trans-media), border-color var(--trans-media);
}
.mundo-card:hover, .mundo-card:focus-visible {
  transform: translateY(-4px) scale(1.02);
  border-color: var(--verde-apagado);
  box-shadow: var(--glow-suave), 0 12px 32px rgba(0,0,0,0.6);
}

/* ============ Coordenadas del universo (el prompt como estética) ============ */
.coordenadas {
  font-family: var(--fuente-mono); font-size: var(--texto-xs);
  color: var(--verde-cocuyo); opacity: 0.85;
  background: var(--verde-profundo); border: 1px solid var(--verde-apagado);
  border-radius: var(--radio-sm); padding: var(--esp-3) var(--esp-4);
  overflow-wrap: anywhere;
}

/* ============ Loader "Sintonizando señal…" ============ */
.sintonizando { display: flex; flex-direction: column; align-items: center; gap: var(--esp-4); }
.sintonizando .faros i { width: 14px; height: 14px; }

/* ============ Nav inferior móvil ============ */
.nav-inferior {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: var(--z-nav);
  display: flex; justify-content: space-around; align-items: center;
  padding: var(--esp-2) var(--esp-2) calc(var(--esp-2) + env(safe-area-inset-bottom));
  background: rgba(5, 8, 7, 0.92); backdrop-filter: blur(14px);
  border-top: 1px solid var(--negro-borde);
}
.nav-inferior a {
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  font-size: var(--texto-xs); color: var(--gris-niebla); padding: var(--esp-2) var(--esp-3);
  min-width: 64px; min-height: 48px; justify-content: center;
}
.nav-inferior a.activo { color: var(--verde-cocuyo); text-shadow: var(--glow-suave); }

/* ============ Utilidades ============ */
.oculto { display: none !important; }
.contenedor { width: 100%; max-width: 1200px; margin-inline: auto; padding-inline: var(--esp-4); }
.texto-secundario { color: var(--gris-niebla); }
.solo-lectores { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); }
