﻿/* =====================================================
   NEON GLASS — Dark Mode Enterprise Theme
   ===================================================== */

/* --- CSS Variables --- */
:root {
  --bg-body: #0f111a;
  --bg-surface: rgba(26, 27, 38, 0.85);
  --bg-glass: rgba(255, 255, 255, 0.04);
  --bg-glass-hover: rgba(255, 255, 255, 0.08);
  --bg-input: rgba(255, 255, 255, 0.06);
  --border-subtle: rgba(65, 72, 104, 0.6);
  --border-glow: rgba(157, 114, 255, 0.4);
  --accent: #9d72ff;
  --accent-light: #7aa2f7;
  --accent-blue: #3b82f6;
  --text-primary: #c0caf5;
  --text-secondary: #565f89;
  --text-white: #e4e8f7;
  --text-muted: #6b7294;
  --success: #9ece6a;
  --warning: #e0af68;
  --danger: #f7768e;
  --radius: 12px;
  --radius-lg: 16px;
  --shadow-glow: 0 0 20px rgba(157, 114, 255, 0.08);
  --shadow-card: 0 4px 24px rgba(0, 0, 0, 0.4);
  --blur: blur(16px);
  --font: 'Inter', 'Segoe UI', system-ui, -apple-system, sans-serif;

  /* Aliases usados por el menú principal */
  --primary-bg: #0f111a;
  --surface-color: rgba(26, 27, 38, 0.85);
  --surface-variant: rgba(255, 255, 255, 0.04);
  --border-color: rgba(65, 72, 104, 0.6);
  --border-radius: 12px;
  --border-radius-lg: 16px;
  --text-secondary-alt: #565f89;
  --accent-color: #9d72ff;
  --box-shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.2);
  --box-shadow-md: 0 4px 24px rgba(0, 0, 0, 0.4);
  --box-shadow-lg: 0 8px 40px rgba(0, 0, 0, 0.5);
  --space-xs: .25rem;
  --space-sm: .5rem;
  --space-md: 1rem;
  --space-lg: 1.5rem;
  --space-xl: 2rem;
  --font-xs: .75rem;
  --font-sm: .85rem;
  --font-md: .95rem;
  --font-lg: 1.05rem;
  --font-xl: 1.25rem;
  --font-family: 'Inter', 'Segoe UI', system-ui, -apple-system, sans-serif;
  --transition-base: .25s ease;
}

/* --- Base --- */
html { font-size: 15px; }
@media (min-width: 1200px) { html { font-size: 14.5px; } }

*, *::before, *::after { box-sizing: border-box; }

body {
  background-color: var(--bg-body);
  background-image:
    radial-gradient(ellipse at 20% 0%, rgba(157, 114, 255, 0.06) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 100%, rgba(59, 130, 246, 0.05) 0%, transparent 50%);
  color: var(--text-primary);
  font-family: var(--font);
  min-height: 100vh;
  margin: 0;
}

::selection {
  background: rgba(157, 114, 255, 0.3);
  color: #fff;
}

/* --- Scrollbar --- */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border-subtle); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--accent); }

/* --- Navbar (sitio) --- */
.navbar {
  background: var(--bg-surface) !important;
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  border-bottom: 1px solid var(--border-subtle);
  box-shadow: 0 1px 12px rgba(0, 0, 0, 0.3);
}

.navbar-brand {
  font-size: 1rem !important;
  letter-spacing: .3px;
  background: linear-gradient(135deg, var(--accent), var(--accent-light));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 600;
}

.navbar-brand i {
  -webkit-text-fill-color: var(--accent);
}

/* --- Layout --- */
main.container { padding-top: 2rem !important; padding-bottom: 2rem !important; }

/* --- Tabs --- */
.nav-tabs { border-bottom: 1px solid var(--border-subtle); }

.nav-tabs .nav-link {
  color: var(--text-secondary);
  border: none;
  border-bottom: 2px solid transparent;
  background: transparent;
  font-size: .9rem;
  padding: .6rem 1.2rem;
  transition: color .2s, border-color .2s;
}

.nav-tabs .nav-link:hover {
  color: var(--text-primary);
  border-bottom-color: rgba(157, 114, 255, 0.3);
}

.nav-tabs .nav-link.active {
  color: var(--accent) !important;
  background: transparent !important;
  border-bottom: 2px solid var(--accent) !important;
}

/* --- Glass Card --- */
.card {
  background: var(--bg-glass);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  position: relative;
  overflow: hidden;
  transition: border-color .3s, box-shadow .3s;
}

.card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--accent), var(--accent-light), var(--accent-blue));
  opacity: 0.8;
}

.card:hover {
  border-color: rgba(157, 114, 255, 0.25);
  box-shadow: var(--shadow-card), var(--shadow-glow);
}

.card-body { padding: 1.5rem !important; }

/* --- Typography --- */
.h5, h2.h5 {
  font-size: 1.05rem !important;
  background: linear-gradient(135deg, var(--text-white), var(--accent-light));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 600;
}

.form-label, .small {
  font-size: .85rem !important;
  color: var(--text-muted) !important;
}

.text-muted {
  color: var(--text-muted) !important;
  font-size: .85rem !important;
}

/* --- Form Controls --- */
.form-control, .form-select {
  background: var(--bg-input);
  border: 1px solid var(--border-subtle);
  color: var(--text-primary);
  font-size: .95rem;
  padding: .375rem .5rem;
  border-radius: var(--radius);
  transition: border-color .2s, box-shadow .2s, background .2s;
}

.form-control-lg { font-size: .95rem; padding: .6rem .85rem; }

textarea.form-control { min-height: 6rem; }

.form-control::placeholder { color: var(--text-secondary); opacity: 0.6; }

.form-control:focus, .form-select:focus {
  background: rgba(255, 255, 255, 0.08);
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(157, 114, 255, 0.15), 0 0 12px rgba(157, 114, 255, 0.08);
  color: var(--text-white);
  outline: none;
}

/* --- Buttons --- */
.btn { font-size: .95rem; padding: .45rem .85rem; border-radius: var(--radius); }

.btn-primary {
  background: linear-gradient(135deg, var(--accent), var(--accent-blue));
  border: none;
  color: #fff;
  font-weight: 500;
  box-shadow: 0 2px 12px rgba(157, 114, 255, 0.25);
  transition: box-shadow .2s, transform .15s, opacity .2s;
}

.btn-primary:hover {
  box-shadow: 0 4px 20px rgba(157, 114, 255, 0.4);
  transform: translateY(-1px);
  opacity: 0.95;
}

.btn-primary:active { transform: translateY(0); }
.btn-primary:disabled { opacity: 0.5; transform: none; box-shadow: none; }

.btn-secondary {
  background: var(--bg-glass);
  border: 1px solid var(--border-subtle);
  color: var(--text-primary);
}

.btn-secondary:hover {
  background: var(--bg-glass-hover);
  border-color: var(--accent);
  color: var(--text-white);
}

.btn-outline-secondary {
  border-color: var(--border-subtle);
  color: var(--text-secondary);
}

.btn-outline-secondary:hover {
  background: var(--bg-glass-hover);
  border-color: var(--accent);
  color: var(--accent);
}

.btn-outline-primary {
  border-color: var(--accent);
  color: var(--accent);
}

.btn-outline-primary:hover {
  background: rgba(157, 114, 255, 0.15);
  color: var(--text-white);
  border-color: var(--accent);
  box-shadow: 0 0 12px rgba(157, 114, 255, 0.2);
}

/* --- Alerts --- */
.alert { font-size: .95rem; padding: .5rem .75rem; border-radius: var(--radius); }

.alert-warning {
  background: rgba(224, 175, 104, 0.1);
  border: 1px solid rgba(224, 175, 104, 0.3);
  color: var(--warning);
}

.alert-danger {
  background: rgba(247, 118, 142, 0.1);
  border: 1px solid rgba(247, 118, 142, 0.3);
  color: var(--danger);
}

.alert-info {
  background: rgba(122, 162, 247, 0.15);
  border: 1px solid rgba(122, 162, 247, 0.3);
  color: var(--accent-light);
}

/* --- Copied toast --- */
#copied {
  position: fixed;
  top: .75rem;
  left: .75rem;
  z-index: 2000;
  pointer-events: none;
  backdrop-filter: var(--blur);
}

/* --- Modal (Glass) --- */
.modal-content {
  background: var(--bg-surface);
  backdrop-filter: var(--blur);
  -webkit-backdrop-filter: var(--blur);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  box-shadow: 0 8px 40px rgba(0, 0, 0, 0.6), 0 0 30px rgba(157, 114, 255, 0.1);
  color: var(--text-primary);
}

.modal-header { border-bottom: 1px solid var(--border-subtle); padding: 1rem 1.25rem; }

.modal-title {
  background: linear-gradient(135deg, var(--text-white), var(--accent-light));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 600;
}

.modal-body { padding: 1.25rem; }
.modal-footer { border-top: 1px solid var(--border-subtle); padding: .75rem 1.25rem; }
.btn-close { filter: invert(1) grayscale(1) brightness(0.8); }

.modal-open main, .modal-open nav, .modal-open footer {
  filter: blur(6px);
  transition: filter .2s ease-in-out;
}

.modal-backdrop { background: rgba(0, 0, 0, 0.6) !important; }
.modal-body .table { color: var(--text-primary); }
.modal-body .table th { color: var(--text-muted); }
.modal-body .table td strong { color: var(--text-white); }

/* --- Table --- */
.table {
  color: var(--text-primary);
  --bs-table-bg: transparent;
  --bs-table-hover-bg: rgba(255, 255, 255, 0.04);
  --bs-table-striped-bg: rgba(255, 255, 255, 0.02);
}

.table thead th {
  background: rgba(15, 17, 26, 0.9);
  color: var(--text-secondary);
  border-bottom: 1px solid var(--border-subtle);
  font-weight: 600;
  text-transform: uppercase;
  font-size: .75rem;
  letter-spacing: .5px;
  padding: .6rem .5rem;
  position: sticky;
  top: 0;
  z-index: 1;
}

.table tbody td {
  border-bottom: 1px solid rgba(65, 72, 104, 0.25);
  padding: .45rem .5rem;
  vertical-align: middle;
}

.table tbody tr:hover { background: var(--bg-glass-hover) !important; }
.table tbody td strong { color: var(--accent-light); }

.table-warning, tr.table-warning {
  --bs-table-bg: rgba(224, 175, 104, 0.06) !important;
  --bs-table-hover-bg: rgba(224, 175, 104, 0.1) !important;
}

.table .text-danger { color: var(--danger) !important; }

/* --- Clear button --- */
.input-with-clear { position: relative; }

.input-with-clear .input-clear-target { padding-right: 2.8rem !important; line-height: 1.25; }

.btn-clear {
  position: absolute;
  right: .55rem;
  top: 0; bottom: 0;
  margin: auto 0;
  height: calc(100% - 0.5rem);
  aspect-ratio: 1/1;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border-subtle);
  background: rgba(255, 255, 255, 0.05);
  color: var(--text-secondary);
  padding: 0;
  line-height: 1;
  border-radius: 50%;
  cursor: pointer;
  transition: background .2s, color .2s, border-color .2s, box-shadow .2s;
}

.btn-clear:hover {
  background: rgba(157, 114, 255, 0.15);
  color: var(--accent);
  border-color: var(--accent);
  box-shadow: 0 0 8px rgba(157, 114, 255, 0.2);
}

.btn-clear:active { background: rgba(157, 114, 255, 0.25); }

.btn-clear:focus-visible {
  outline: 0;
  box-shadow: 0 0 0 .15rem rgba(157, 114, 255, 0.35);
}

.btn-clear i { font-size: .9rem; pointer-events: none; }

@media (max-width: 420px) {
  .input-with-clear .input-clear-target { padding-right: 2.4rem !important; }
  .btn-clear { right: .45rem; }
}

/* --- Autocomplete --- */
#sugs { border-radius: var(--radius); overflow: hidden; }

#sugs .list-group-item {
  background: var(--bg-glass);
  border: none;
  border-bottom: 1px solid rgba(65, 72, 104, 0.2);
  color: var(--text-primary);
}

#sugs .list-group-item.disabled { color: var(--text-secondary); }

#sugs .list-group-item:not(.disabled):not(.list-group-item-danger) {
  cursor: pointer;
  transition: background .15s, border-left-color .15s, box-shadow .15s;
  border-left: 3px solid transparent;
}

#sugs .list-group-item:not(.disabled):not(.list-group-item-danger):hover {
  background: linear-gradient(135deg, rgba(157, 114, 255, 0.2), rgba(59, 130, 246, 0.15));
  color: var(--text-white);
  border-left-color: var(--accent);
  box-shadow: inset 0 0 20px rgba(157, 114, 255, 0.05);
}

#sugs .list-group-item:not(.disabled):not(.list-group-item-danger):hover strong,
#sugs .list-group-item:not(.disabled):not(.list-group-item-danger):hover .fa-road {
  color: var(--text-white) !important;
}

#sugs .list-group-item:not(.disabled):not(.list-group-item-danger):active {
  background: rgba(157, 114, 255, 0.3);
}

#sugs .list-group-item.list-group-item-light { background: rgba(157, 114, 255, 0.06); }

#sugs .list-group-item-danger {
  background: rgba(247, 118, 142, 0.08);
  color: var(--danger);
}

/* --- Footer --- */
footer {
  color: var(--text-secondary);
  border-top: 1px solid rgba(65, 72, 104, 0.2);
}

/* --- Batch summary --- */
#batchSummary { color: var(--text-muted); }

/* --- Responsive --- */
@supports (block-size: 100%) {
  .btn-clear { block-size: calc(100% - 0.5rem); }
}

/* =====================================================
   MENÚ PRINCIPAL — Portal de Aplicaciones
   ===================================================== */

/* Tema claro */
:root[data-theme="light"] {
  --primary-bg: #f5f7fb;
  --surface-color: #ffffff;
  --surface-variant: #e9eef5;
  --border-color: rgba(0,0,0,.12);
  --text-primary: #1d2433;
  --text-secondary: #334155;
  --accent-color: #6366f1;
  --accent-light: #818cf8;
  --bg-body: #f5f7fb;
}

/* Navbar portal */
.portal-navbar {
  background: rgba(255,255,255,0.05) !important;
  backdrop-filter: blur(16px);
  border: 1px solid var(--border-color, var(--border-subtle));
  border-radius: var(--border-radius-lg, var(--radius-lg));
  margin: var(--space-md) var(--space-md) 0;
  padding: .75rem 1.25rem;
  box-shadow: var(--box-shadow-md, var(--shadow-card));
  transition: var(--transition-base);
}

:root[data-theme="light"] .portal-navbar {
  background: #ffffff !important;
  box-shadow: var(--box-shadow-sm);
}

.portal-navbar .navbar-brand {
  font-weight: 600;
  letter-spacing: .4px;
  background: linear-gradient(135deg, var(--text-primary), var(--text-secondary));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* Dashboard container */
.dashboard-container {
  max-width: 1400px;
  margin: 0 auto;
  padding: var(--space-lg) var(--space-md) var(--space-md);
}

/* App cards grid */
.apps-grid { row-gap: var(--space-xl); }

.apps-grid .app-card {
  background: rgba(255,255,255,0.05);
  backdrop-filter: blur(14px);
  border: 1px solid var(--border-color, var(--border-subtle));
  border-radius: var(--border-radius-lg, var(--radius-lg));
  position: relative;
  padding: var(--space-lg);
  height: 100%;
  display: flex;
  flex-direction: column;
  box-shadow: 0 8px 32px rgba(0,0,0,0.30);
  transition: all var(--transition-base);
  overflow: hidden;
}

:root[data-theme="light"] .apps-grid .app-card {
  background: #ffffff;
  box-shadow: var(--box-shadow-md);
}

.apps-grid .app-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--accent-color, var(--accent)), var(--accent-light));
  opacity: .85;
}

.apps-grid .app-card:hover,
.apps-grid .app-card:focus-within {
  transform: translateY(-4px);
  border-color: rgba(157,114,255,.45);
  box-shadow: 0 16px 48px rgba(0,0,0,.45), 0 0 24px rgba(157,114,255,.25);
}

:root[data-theme="light"] .apps-grid .app-card:hover {
  box-shadow: 0 12px 36px rgba(0,0,0,.15), 0 0 16px rgba(99,102,241,.25);
}

.apps-grid .app-icon {
  font-size: 2.4rem;
  line-height: 1;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,.25));
}

.apps-grid h5 {
  font-weight: 600;
  font-size: var(--font-lg);
  margin-bottom: .25rem;
  color: var(--text-primary);
  background: none;
  -webkit-text-fill-color: unset;
}

.apps-grid p {
  color: var(--text-secondary);
  font-size: var(--font-sm);
  margin-bottom: .75rem;
}

.apps-grid .badge {
  background: rgba(157,114,255,.12);
  color: var(--accent-light);
  font-weight: 500;
  letter-spacing: .4px;
  border: 1px solid rgba(157,114,255,.30);
}

:root[data-theme="light"] .apps-grid .badge {
  background: rgba(99,102,241,.15);
  color: #4338ca;
  border: 1px solid rgba(99,102,241,.35);
}

.apps-grid .app-card a.stretched-link:focus::after {
  box-shadow: 0 0 0 3px rgba(157,114,255,.6);
  border-radius: var(--border-radius-lg, var(--radius-lg));
}

/* Search */
.app-search input { width: 320px; backdrop-filter: blur(6px); }
.app-search input::placeholder { color: var(--text-secondary); opacity: .6; }

/* Theme & size toggles */
#themeToggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .35rem;
  padding: .45rem .85rem;
}

#sizeToggle, #themeToggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
}

#sizeToggle i, #themeToggle i {
  font-size: 1.05rem;
  line-height: 1;
  width: 1.15rem;
  text-align: center;
}

/* Sun/Moon icons */
#themeToggle .icon-sun  { display: inline-block; }
#themeToggle .icon-moon { display: none; }
:root[data-theme="light"] #themeToggle .icon-sun  { display: none; }
:root[data-theme="light"] #themeToggle .icon-moon { display: inline-block; }

/* Compact mode */
body.compact-mode .apps-grid .app-card    { padding: var(--space-md); }
body:not(.compact-mode) .apps-grid .app-card { padding: var(--space-lg); }

/* --- Badge En desarrollo (WIP) --- */
.badge-wip {
  background: rgba(224, 175, 104, 0.12);
  color: var(--warning, #e0af68);
  font-weight: 500;
  letter-spacing: .4px;
  border: 1px solid rgba(224, 175, 104, 0.35);
}

.app-card:has(.badge-wip) {
  opacity: .8;
  cursor: default;
}

/* Responsive */
@media (max-width: 768px) {
  .app-search input { width: 100%; }
}