/* static/css/vaelo.css */
/* ===============  VA E L O   UI  =============== */
/* Paleta y tokens */
:root{
  --bg: #f6f8fb;
  --card: #ffffff;
  --text: #0f172a;
  --muted: #64748b;
  --border: #e5e7eb;
  --primary: #0ea5e9;
  --primary-contrast: #ffffff;
  --accent: #22c55e;
  --danger: #ef4444;
  --warning: #f59e0b;

  --sidebar-bg: #ffffff;
  --sidebar-text: #0f172a;
  --sidebar-active-bg: #e6f6ff;

  --topbar-bg: #ffffff;
  --topbar-border: #e5e7eb;

  --radius-md: 12px;
  --radius-lg: 14px;
  --shadow-sm: 0 1px 1px rgba(15, 23, 42, .04);
  --shadow-md: 0 6px 20px rgba(15, 23, 42, .06);
}

/* Reset básico */
* { box-sizing: border-box; }
html, body { height: 100%; }
body { margin:0; background: var(--bg); color: var(--text); font-synthesis-weight: none; text-rendering: optimizeLegibility; }
a { color: var(--primary); text-decoration: none; }
a:hover { text-decoration: underline; }

/* Topbar */
.navbar { background: var(--topbar-bg) !important; border-color: var(--topbar-border) !important; }

/* Sidebar */
.vaelo-sidebar{
  background: var(--sidebar-bg);
  border-right: 1px solid var(--border);
  padding: 12px;
  position: sticky;
  top: 56px; /* coincide con la altura de la topbar */
  height: calc(100vh - 56px);
  overflow-y: auto;
  box-shadow: var(--shadow-sm);
}
.vaelo-menu .section-title{
  font-size: 12px; letter-spacing:.06em; text-transform: uppercase;
  color: var(--muted); margin: 14px 8px 8px;
}
.vaelo-menu .vaelo-link{
  display:flex; align-items:center; gap:10px; padding:10px 12px; margin:6px 0;
  border-radius: var(--radius-md); color: var(--sidebar-text);
}
.vaelo-menu .vaelo-link:hover{ background: var(--sidebar-active-bg); text-decoration: none; }
.vaelo-menu .vaelo-link .bi{ opacity:.85; }

/* Tarjetas y superficies */
.card-vaelo{
  background: var(--card); border:1px solid var(--border);
  border-radius: var(--radius-lg); padding: 16px;
  box-shadow: var(--shadow-sm);
}

/* Chips / Badges suaves */
.badge-soft{ background: rgba(14,165,233,.12); color: var(--primary); border: 1px solid rgba(14,165,233,.3); }
.badge[role="status"] { letter-spacing: .02em; }

/* Tablas */
.table-vaelo thead th{ color: var(--muted); font-weight: 600; border-bottom-color: var(--border); }
.table-vaelo tbody tr:hover{ background: rgba(14,165,233,.06); }
.table-vaelo td, .table-vaelo th { vertical-align: middle; }

/* Formularios */
.form-control, .form-select { border-color: var(--border); border-radius: var(--radius-md); }
.form-control:focus, .form-select:focus {
  border-color: rgba(14,165,233,.6);
  box-shadow: 0 0 0 .2rem rgba(14,165,233,.15);
}

/* Botones */
.btn-outline-secondary { border-color: var(--border); }
.btn-outline-secondary:hover { background: #f3f4f6; }
.btn-primary {
  --bs-btn-bg: var(--primary); --bs-btn-border-color: var(--primary);
  --bs-btn-hover-bg: #0c97d4; --bs-btn-hover-border-color: #0c97d4;
  --bs-btn-active-bg: #0a86bb; --bs-btn-active-border-color: #0a86bb;
}

/* Breadcrumbs */
.breadcrumb { --bs-breadcrumb-divider-color: var(--muted); }
.breadcrumb .breadcrumb-item + .breadcrumb-item::before { color: var(--muted); }
.breadcrumb .breadcrumb-item.active { color: var(--muted); }

/* Avatares de iniciales */
.vaelo-avatar { display:inline-flex; align-items:center; justify-content:center; border-radius: 50%; color: #fff; font-weight: 600; }

/* Toasts */
#vaeloToasts .toast{ min-width:280px; box-shadow: var(--shadow-md); }

/* ===== Sidebar en móvil (off-canvas) ===== */
@media (max-width: 991.98px){
  .vaelo-sidebar{
    position: fixed; left: 0; top: 56px; bottom: 0; width: 264px;
    transform: translateX(-100%); transition: transform .2s ease; z-index: 1040;
  }
  .vaelo-sidebar.open{ transform: translateX(0); }
}

/* Backdrop para el off-canvas */
.vaelo-backdrop{
  position: fixed; left: 0; right: 0; top: 56px; bottom: 0;
  background: rgba(15,23,42,.35);
  opacity: 0; visibility: hidden; transition: opacity .2s ease;
  z-index: 1030; /* debajo de la sidebar (1040) */
  pointer-events: none;
}
.vaelo-backdrop.show{ opacity: 1; visibility: visible; pointer-events: auto; }
@media (min-width: 992px){
  .vaelo-backdrop{ display:none; }
}

/* Utilidades sutiles */
.shadow-soft { box-shadow: var(--shadow-sm); }
.rounded-md { border-radius: var(--radius-md); }
.rounded-lg { border-radius: var(--radius-lg); }
.text-muted-2 { color: var(--muted) !important; }

/* Estado activo en el menú lateral y badges */
.vaelo-link.active { background: var(--sidebar-active-bg); font-weight: 600; }
.vaelo-link .menu-badge { font-size: 11px; line-height: 1; padding: .35rem .45rem; }

/* ESCRITORIO: fuerza visible y sin transform */
@media (min-width: 992px){
  .vaelo-sidebar{ transform: none !important; position: sticky; top: 56px; }
}

/* Paletas badge rápidas */
.badge.text-bg-dark { background:#0f172a !important; }
.badge.text-bg-primary { background:#0ea5e9 !important; }
.badge.text-bg-success { background:#22c55e !important; }

/* ===============  FIN VA E L O  =============== */

/* Tarjeta base Vaelo */
.card-vaelo {
  background: #fff;
  border: 1px solid #e9ecef;
  border-radius: .75rem;
  box-shadow: 0 1px 2px rgba(0,0,0,.03);
  padding: 1rem;
}

/* Tabla Vaelo */
.table-vaelo {
  --vaelo-row-hover: rgba(13,110,253,.06);
}
.table-vaelo > thead > tr > th {
  font-weight: 600;
  color: #6c757d;
  border-top: 0;
  border-bottom: 1px solid #e9ecef;
}
.table-vaelo > tbody > tr:hover {
  background: var(--vaelo-row-hover);
}

/* Botón marca Vaelo */
.btn-vaelo {
  background: #0d6efd;
  color: #fff;
  border: 1px solid #0d6efd;
}
.btn-vaelo:hover { filter: brightness(.95); color:#fff; }