/*
 * base.css — Estilos globales y componentes del portal.
 * Solo usa variables de tokens.css; nunca valores de color/tipografía en bruto.
 */

/* ─── Reset mínimo ──────────────────────────────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
}

body, h1, h2, h3, p, ul, li, figure, figcaption, blockquote, dl, dd {
  margin: 0;
  padding: 0;
}

ul, ol {
  list-style: none;
}

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

a {
  color: inherit;
  text-decoration: none;
}

button {
  cursor: pointer;
  background: none;
  border: none;
  font: inherit;
}

/* ─── Base de documento ─────────────────────────────────────────────────────── */
html {
  /* La transición en el html permite que el cambio de tema sea suave */
  transition: background-color var(--transition-normal), color var(--transition-normal);
}

body {
  font-family:    var(--font-family);
  font-size:      var(--font-size-base);
  font-weight:    var(--font-weight-normal);
  line-height:    var(--line-height-normal);
  color:          var(--color-text-primary);
  background:     var(--color-bg);
  min-height:     100vh;
  display:        flex;
  flex-direction: column;
  /* Manchas de color suaves para que el efecto liquidglass tenga algo que
     refractar — sin un fondo con tinte, los cristales se ven planos. */
  background-image:
    radial-gradient(circle at 8% 12%,  var(--page-tint-1) 0%, transparent 38%),
    radial-gradient(circle at 88% 18%, var(--page-tint-2) 0%, transparent 42%),
    radial-gradient(circle at 50% 92%, var(--page-tint-3) 0%, transparent 46%);
  background-attachment: fixed;
}

/* ─── Header ────────────────────────────────────────────────────────────────── */
.site-header {
  /* Header translúcido: el cristal deja entrever el fondo de la página al hacer
     scroll. Mantenemos el header oscuro (contraste con el contenido). */
  background:   color-mix(in srgb, var(--color-header-bg) 78%, transparent);
  color:        var(--color-header-text);
  border-bottom: 1px solid var(--color-header-border);
  position:     sticky;
  top:          0;
  z-index:      100;
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturate, 140%));
  backdrop-filter:         blur(var(--glass-blur)) saturate(var(--glass-saturate, 140%));
}

.header-inner {
  max-width:      1200px;
  margin:         0 auto;
  padding:        0 var(--space-6);
  height:         56px;
  display:        flex;
  align-items:    center;
  justify-content: space-between;
  gap:            var(--space-4);
}

/* Logo */
.header-logo {
  display:     flex;
  align-items: center;
  gap:         var(--space-3);
  color:       var(--color-header-text);
  flex-shrink: 0;
}

.header-logo:hover {
  opacity: 0.85;
}

.logo-icon {
  width:  28px;
  height: 28px;
  color:  var(--color-accent);
  flex-shrink: 0;
}

/* ─── Ojo de Sauron (partial eye.ejs) ───────────────────────────────────────── */
.eye-wrap {
  display:     inline-block;
  position:    relative;
  flex-shrink: 0;
  will-change: filter, transform;
}

.eye-wrap svg { display: block; }

/* Respiración lenta y dorada — estado por defecto en el header del portal. */
.eye-wrap--calm {
  animation: portal-eye-breathe 4s ease-in-out infinite;
  color:     #f59e0b;
}

@keyframes portal-eye-breathe {
  0%, 100% { filter: drop-shadow(0 0 4px currentColor); }
  50%      { filter: drop-shadow(0 0 12px currentColor) brightness(1.15); }
}

/* Respeta usuarios con prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
  .eye-wrap--calm { animation: none; }
}

.logo-text {
  font-size:   var(--font-size-lg);
  font-weight: var(--font-weight-semi);
  letter-spacing: -0.02em;
}

/* Agrupa tema + usuario en la derecha del header */
.header-right {
  display:     flex;
  align-items: center;
  gap:         var(--space-3);
  flex-shrink: 0;
}

/* Bloque usuario: nombre + botón logout.
   La cápsula es una sola pieza (chip), pegada al header — sin padding vertical
   superfluo. Compacta en altura: que no ocupe más que el header. */
.header-user {
  display:        inline-flex;
  align-items:    center;
  gap:            var(--space-2);
  height:         28px;
  padding:        0 var(--space-1) 0 var(--space-3);
  background:     rgba(255, 255, 255, 0.07);
  border:         1px solid rgba(255, 255, 255, 0.12);
  border-radius:  var(--radius-full);
  line-height:    1;
}

.header-username {
  display:     inline-flex;
  align-items: center;
  gap:         var(--space-1);
  font-size:   var(--font-size-xs);
  color:       rgba(255, 255, 255, 0.85);
  white-space: nowrap;
  line-height: 1;
}

.logout-form {
  display:     inline-flex;
  align-items: center;
}

.btn-logout {
  display:        inline-flex;
  align-items:    center;
  justify-content: center;
  gap:            var(--space-1);
  height:         22px;
  padding:        0 var(--space-2);
  border-radius:  var(--radius-full);
  font-size:      var(--font-size-xs);
  font-weight:    var(--font-weight-medium);
  color:          rgba(255, 255, 255, 0.65);
  transition:     background var(--transition-fast), color var(--transition-fast);
  white-space:    nowrap;
  cursor:         pointer;
  border:         1px solid transparent;
  line-height:    1;
}

.btn-logout:hover {
  color:       rgba(255, 255, 255, 0.9);
  background:  rgba(255, 255, 255, 0.1);
}

@media (max-width: 480px) {
  .header-username {
    display: none;
  }
  .btn-logout span {
    display: none;
  }
  .btn-logout {
    padding: var(--space-1) var(--space-2);
  }
}

/* ─── Selector de tema ──────────────────────────────────────────────────────── */
.theme-selector {
  display:     flex;
  align-items: center;
  gap:         var(--space-1);
  background:  rgba(255, 255, 255, 0.07);
  border:      1px solid rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-full);
  padding:     var(--space-1);
}

.theme-btn {
  display:     flex;
  align-items: center;
  gap:         var(--space-2);
  padding:     var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  font-size:   var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color:       rgba(255, 255, 255, 0.6);
  transition:  background var(--transition-fast), color var(--transition-fast);
  white-space: nowrap;
}

.theme-btn:hover {
  color:       rgba(255, 255, 255, 0.9);
  background:  rgba(255, 255, 255, 0.1);
}

.theme-btn.active {
  background:  rgba(255, 255, 255, 0.15);
  color:       rgba(255, 255, 255, 1);
}

/* En pantallas pequeñas, ocultar la etiqueta de texto y dejar solo el icono */
@media (max-width: 480px) {
  .theme-btn span {
    display: none;
  }
  .theme-btn {
    padding: var(--space-1) var(--space-2);
  }
}

/* ─── Contenido principal ───────────────────────────────────────────────────── */
.main-content {
  flex:       1;
  max-width:  1200px;
  margin:     0 auto;
  padding:    var(--space-12) var(--space-6);
  width:      100%;
}

/* ─── Hero ──────────────────────────────────────────────────────────────────── */
.hero {
  text-align: center;
  padding:    var(--space-16) 0 var(--space-12);
}

.hero-title {
  font-size:      var(--font-size-4xl);
  font-weight:    var(--font-weight-semi);
  letter-spacing: -0.03em;
  line-height:    var(--line-height-tight);
  color:          var(--color-text-primary);
  margin-bottom:  var(--space-4);
}

.hero-subtitle {
  font-size:     var(--font-size-lg);
  color:         var(--color-text-secondary);
  max-width:     480px;
  margin:        0 auto var(--space-8);
}

/* Aviso de "en desarrollo" */
.hero-notice {
  display:        inline-flex;
  align-items:    center;
  gap:            var(--space-2);
  padding:        var(--space-2) var(--space-4);
  background:     var(--glass-bg);
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturate, 140%));
  backdrop-filter:         blur(var(--glass-blur)) saturate(var(--glass-saturate, 140%));
  border:         1px solid var(--glass-border);
  border-radius:  var(--radius-full);
  font-size:      var(--font-size-sm);
  color:          var(--color-text-secondary);
  box-shadow:     var(--glass-shadow);
}

/* ─── Sección de apps ───────────────────────────────────────────────────────── */
.apps-section {
  padding-top: var(--space-4);
}

.section-title {
  font-size:      var(--font-size-sm);
  font-weight:    var(--font-weight-semi);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color:          var(--color-text-muted);
  margin-bottom:  var(--space-6);
}

/* Grid responsive: 1 columna en móvil, 2 en tablet, 3 en escritorio */
.apps-grid {
  display:               grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap:                   var(--space-4);
}

/* ─── Tarjeta de app ─────────────────────────────────────────────────────────── */
.app-card {
  /* Cristal líquido: fondo semitransparente + blur por detrás, borde de
     "menisco" sutil y una leve luz interna en la parte superior. */
  background:     var(--glass-bg);
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturate, 140%));
  backdrop-filter:         blur(var(--glass-blur)) saturate(var(--glass-saturate, 140%));
  border:         1px solid var(--glass-border);
  border-radius:  var(--radius-lg);
  padding:        var(--space-5);
  display:        flex;
  flex-direction: column;
  gap:            var(--space-4);
  box-shadow:     var(--glass-shadow);
  transition:     box-shadow var(--transition-fast), transform var(--transition-fast),
                  border-color var(--transition-fast), opacity var(--transition-fast),
                  background var(--transition-fast);
  /* Necesario para el enlace absoluto que cubre toda la tarjeta */
  position:       relative;
  overflow:       hidden;
}

/* Borde superior con highlight: simula el reflejo del menisco del cristal. */
.app-card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(180deg, var(--glass-highlight) 0%, transparent 14%);
  opacity: 0.35;
}

/* Enlace invisible que cubre toda la tarjeta cuando la app está disponible.
   z-index: 1 para que quede sobre el contenido de la tarjeta. */
.app-card-link {
  position:      absolute;
  inset:         0;
  border-radius: inherit;
  z-index:       1;
}

/* Las tarjetas disponibles tienen cursor pointer y efecto hover */
.app-card--disponible {
  cursor: pointer;
}
.app-card--disponible:hover {
  background:   var(--glass-bg-elevated);
  box-shadow:   var(--app-card-hover-shadow);
  transform:    translateY(-2px);
  border-color: color-mix(in srgb, var(--color-accent) 45%, var(--glass-border));
}

/* Las tarjetas no disponibles se muestran algo atenuadas */
.app-card--no-disponible {
  opacity: 0.65;
}

/* Las tarjetas sin configurar se muestran más atenuadas */
.app-card--sin-configurar {
  opacity: 0.45;
}

/* Cabecera de la tarjeta: badge de inicial + icono de enlace externo */
.app-card-top {
  display:     flex;
  align-items: flex-start;
  justify-content: space-between;
}

/* Badge cuadrado con la inicial de la app */
.app-card-badge {
  width:           44px;
  height:          44px;
  border-radius:   var(--radius-md);
  display:         flex;
  align-items:     center;
  justify-content: center;
  font-size:       var(--font-size-xl);
  font-weight:     var(--font-weight-semi);
  color:           #ffffff;
  flex-shrink:     0;
}

/* Icono de "abrir en nueva pestaña" — solo visible en tarjetas disponibles */
.app-card-ext-icon {
  color:      var(--color-text-muted);
  margin-top: var(--space-1);
  flex-shrink: 0;
  transition: color var(--transition-fast);
}
.app-card--disponible:hover .app-card-ext-icon {
  color: var(--color-accent);
}

.app-card-content {
  flex: 1;
}

.app-card-name {
  font-size:     var(--font-size-base);
  font-weight:   var(--font-weight-semi);
  color:         var(--color-text-primary);
  margin-bottom: var(--space-1);
}

.app-card-desc {
  font-size:   var(--font-size-sm);
  color:       var(--color-text-secondary);
  line-height: var(--line-height-normal);
}

.app-card-footer {
  margin-top: auto;
}

/* ─── Badges de estado ──────────────────────────────────────────────────────── */
.status-badge {
  display:       inline-flex;
  align-items:   center;
  gap:           var(--space-2);
  padding:       var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  font-size:     var(--font-size-xs);
  font-weight:   var(--font-weight-medium);
}

/* Punto de color dentro del badge */
.status-dot {
  width:         6px;
  height:        6px;
  border-radius: 50%;
  flex-shrink:   0;
  background:    currentColor;
}

/* Gris — sin configurar */
.status-badge--pending {
  background: var(--color-surface-elevated);
  color:      var(--color-text-muted);
  border:     1px solid var(--color-border);
}

/* Verde — disponible */
.status-badge--ok {
  background: color-mix(in srgb, var(--color-success) 12%, transparent);
  color:      var(--color-success);
  border:     1px solid color-mix(in srgb, var(--color-success) 25%, transparent);
}

/* Naranja — no disponible */
.status-badge--warning {
  background: color-mix(in srgb, var(--color-warning) 12%, transparent);
  color:      var(--color-warning);
  border:     1px solid color-mix(in srgb, var(--color-warning) 25%, transparent);
}

/* ═══════════════════════════════════════════════════════════════════════════════
   SECCIÓN DE ADMINISTRACIÓN — estilos de las páginas /admin/*
   ═══════════════════════════════════════════════════════════════════════════════ */

/* ─── Nav de admin en el header ─────────────────────────────────────────────── */
.header-admin-nav {
  display:     flex;
  gap:         var(--space-1);
  margin-left: var(--space-4);
}

.header-nav-link {
  padding:       var(--space-1) var(--space-3);
  border-radius: var(--radius-md);
  font-size:     var(--font-size-xs);
  font-weight:   var(--font-weight-medium);
  color:         rgba(255, 255, 255, 0.65);
  transition:    color var(--transition-fast), background var(--transition-fast);
  text-decoration: none;
}
.header-nav-link:hover  { color: rgba(255,255,255,.9); background: rgba(255,255,255,.1); }
.header-nav-link.active { color: rgba(255,255,255,1);  background: rgba(255,255,255,.15); }

/* ─── Contenedor principal admin ────────────────────────────────────────────── */
.admin-main {
  flex:       1;
  max-width:  1100px;
  margin:     0 auto;
  padding:    var(--space-8) var(--space-6);
  width:      100%;
}

.admin-header {
  display:     flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-6);
}

.admin-title {
  font-size:      var(--font-size-2xl);
  font-weight:    var(--font-weight-semi);
  letter-spacing: -0.02em;
}

.admin-card {
  background:    var(--glass-bg);
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturate, 140%));
  backdrop-filter:         blur(var(--glass-blur)) saturate(var(--glass-saturate, 140%));
  border:        1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  overflow:      hidden;
  box-shadow:    var(--glass-shadow);
  margin-bottom: var(--space-6);
}

.admin-empty {
  padding:    var(--space-8);
  text-align: center;
  color:      var(--color-text-muted);
  font-size:  var(--font-size-sm);
}

.admin-sub {
  color:     var(--color-text-muted);
  font-size: var(--font-size-xs);
}

.admin-row-inactivo td {
  opacity: 0.5;
}

/* ─── Tabla admin ────────────────────────────────────────────────────────────── */
.admin-table {
  width:           100%;
  border-collapse: collapse;
  font-size:       var(--font-size-sm);
}

.admin-table th {
  text-align:     left;
  padding:        var(--space-3) var(--space-4);
  border-bottom:  2px solid var(--color-border);
  font-weight:    var(--font-weight-semi);
  color:          var(--color-text-secondary);
  text-transform: uppercase;
  font-size:      var(--font-size-xs);
  letter-spacing: 0.05em;
  white-space:    nowrap;
}

.admin-table td {
  padding:       var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-border-subtle);
  vertical-align: middle;
}

.admin-table tr:last-child td { border-bottom: none; }
.admin-table tr:hover td { background: var(--color-surface-elevated); }

.accesos-cell { display: flex; flex-wrap: wrap; gap: var(--space-1); align-items: center; }

.admin-actions { display: flex; gap: var(--space-2); flex-wrap: wrap; }

/* ─── Badges genéricos ───────────────────────────────────────────────────────── */
.badge {
  display:       inline-flex;
  align-items:   center;
  padding:       2px var(--space-2);
  border-radius: var(--radius-full);
  font-size:     var(--font-size-xs);
  font-weight:   var(--font-weight-medium);
}

.badge-admin    { background: color-mix(in srgb, var(--color-accent) 12%, transparent); color: var(--color-accent); border: 1px solid color-mix(in srgb, var(--color-accent) 25%, transparent); }
.badge-usuario  { background: var(--color-surface-elevated); color: var(--color-text-secondary); border: 1px solid var(--color-border); }
.badge-sso      { background: color-mix(in srgb, var(--color-success) 12%, transparent); color: var(--color-success); border: 1px solid color-mix(in srgb, var(--color-success) 25%, transparent); }
.badge-activo   { background: color-mix(in srgb, var(--color-success) 12%, transparent); color: var(--color-success); border: 1px solid color-mix(in srgb, var(--color-success) 25%, transparent); }
.badge-inactivo { background: var(--color-surface-elevated); color: var(--color-text-muted); border: 1px solid var(--color-border); }
.badge-app      { background: var(--color-surface-elevated); color: var(--color-text-secondary); border: 1px solid var(--color-border); font-size: 10px; padding: 1px var(--space-1); }
.badge-app-admin { background: color-mix(in srgb, var(--color-warning) 12%, transparent); color: var(--color-warning); border: 1px solid color-mix(in srgb, var(--color-warning) 25%, transparent); font-size: 10px; padding: 1px var(--space-1); }

/* ─── Formulario admin ──────────────────────────────────────────────────────── */
.admin-form {
  background:    var(--glass-bg);
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturate, 140%));
  backdrop-filter:         blur(var(--glass-blur)) saturate(var(--glass-saturate, 140%));
  border:        1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding:       var(--space-8);
  max-width:     680px;
  box-shadow:    var(--glass-shadow);
}

.admin-form-section       { margin-bottom: var(--space-8); }
.admin-form-section-title { font-size: var(--font-size-lg); font-weight: var(--font-weight-semi); margin-bottom: var(--space-4); padding-bottom: var(--space-3); border-bottom: 1px solid var(--color-border); }

.admin-form-row {
  display:   grid;
  grid-template-columns: 160px 1fr;
  gap:       var(--space-4);
  align-items: start;
  padding:   var(--space-3) 0;
  border-bottom: 1px solid var(--color-border-subtle);
}
.admin-form-row:last-of-type { border-bottom: none; }

.admin-form-label { font-size: var(--font-size-sm); font-weight: var(--font-weight-medium); color: var(--color-text-secondary); padding-top: var(--space-2); }

.admin-form-input,
.admin-form-select {
  padding:       var(--space-2) var(--space-3);
  background:    var(--color-bg);
  border:        1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-family:   var(--font-family);
  font-size:     var(--font-size-sm);
  color:         var(--color-text-primary);
  width:         100%;
  transition:    border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.admin-form-input:focus,
.admin-form-select:focus {
  outline:    none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-accent) 15%, transparent);
}

.admin-form-hint { font-size: var(--font-size-xs); color: var(--color-text-muted); margin-top: var(--space-1); }

.admin-form-actions { display: flex; gap: var(--space-3); margin-top: var(--space-6); padding-top: var(--space-6); border-top: 1px solid var(--color-border); }

/* Accesos grid */
.accesos-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: var(--space-4); }
.acceso-item  { display: flex; flex-direction: column; gap: var(--space-2); }
.acceso-app-header { display: flex; align-items: center; gap: var(--space-2); }
.acceso-color-dot  { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.acceso-app-nombre { font-size: var(--font-size-xs); font-weight: var(--font-weight-semi); color: var(--color-text-secondary); text-transform: uppercase; letter-spacing: 0.05em; }

/* ─── Botones genéricos (reutilizados en admin) ──────────────────────────────── */
.btn {
  display:       inline-flex;
  align-items:   center;
  gap:           var(--space-2);
  padding:       var(--space-2) var(--space-4);
  border-radius: var(--radius-md);
  font-family:   var(--font-family);
  font-size:     var(--font-size-sm);
  font-weight:   var(--font-weight-medium);
  cursor:        pointer;
  text-decoration: none;
  border:        1px solid transparent;
  transition:    all var(--transition-fast);
  white-space:   nowrap;
}
.btn-primary   { background: var(--color-accent); color: var(--color-accent-fg); border-color: var(--color-accent); }
.btn-primary:hover { background: var(--color-accent-hover); }
.btn-secondary { background: var(--color-surface); color: var(--color-text-primary); border-color: var(--color-border); }
.btn-secondary:hover { background: var(--color-surface-elevated); }
.btn-danger    { background: color-mix(in srgb, var(--color-error) 10%, transparent); color: var(--color-error); border-color: color-mix(in srgb, var(--color-error) 25%, transparent); }
.btn-danger:hover { background: color-mix(in srgb, var(--color-error) 20%, transparent); }
.btn-sm { padding: var(--space-1) var(--space-3); font-size: var(--font-size-xs); }

/* ─── Alertas ──────────────────────────────────────────────────────────────── */
.alert         { padding: var(--space-3) var(--space-4); border-radius: var(--radius-md); font-size: var(--font-size-sm); margin-bottom: var(--space-6); display: flex; align-items: center; gap: var(--space-2); }
.alert-success { background: color-mix(in srgb, var(--color-success) 10%, transparent); color: var(--color-success); border: 1px solid color-mix(in srgb, var(--color-success) 25%, transparent); }
.alert-error   { background: color-mix(in srgb, var(--color-error) 10%, transparent); color: var(--color-error); border: 1px solid color-mix(in srgb, var(--color-error) 25%, transparent); }

/* ─── Pie de la admin ─────────────────────────────────────────────────────── */
.admin-footer-links { display: flex; gap: var(--space-6); font-size: var(--font-size-sm); color: var(--color-text-muted); }
.admin-footer-links a { color: var(--color-text-secondary); }
.admin-footer-links a:hover { color: var(--color-accent); }
