/* ══════════════════════════════════════════════════════════════
   SUPERSIMULADOR PY — Component Library
   Cartas · Terracota · Octagonal · Editorial
   ══════════════════════════════════════════════════════════════ */

/* ─── Carta Cards ────────────────────────────────────────── */
.carta {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  padding: var(--space-5);
  position: relative;
  transition: transform var(--duration-normal) var(--ease-out-expo),
              border-color var(--duration-fast) var(--ease-out-expo);
}

.carta::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--color-terracotta);
  transition: background var(--duration-fast) var(--ease-out-expo),
              width var(--duration-normal) var(--ease-out-expo);
}

.carta:hover {
  transform: translate(2px, -2px);
  border-color: var(--color-terracotta-pale);
}

.carta:hover::before {
  width: 4px;
  background: var(--color-gold);
}

/* Career color variants */
.carta-contabilidad::before { background: var(--career-contabilidad); }
.carta-administracion::before { background: var(--career-administracion); }
.carta-comercio::before { background: var(--career-comercio); }
.carta-ingenieria::before { background: var(--career-ingenieria); }

.carta-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-4);
  gap: var(--space-3);
  flex-wrap: wrap;
}

.carta-header h5, .carta-header h4 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 700;
  color: var(--color-ink);
}

.carta-body { font-family: var(--font-body); }

/* Legacy class alias */
.card-soft { background: var(--color-surface); border: 1px solid var(--color-border); padding: var(--space-5); position: relative; transition: transform var(--duration-normal) var(--ease-out-expo), border-color var(--duration-fast) var(--ease-out-expo); }
.card-soft:hover { transform: translate(2px, -2px); border-color: var(--color-terracotta-pale); }
.card-soft .card-header-clean {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-border-light);
}
.card-soft .card-header-clean h5, .card-soft .card-header-clean h4 { margin: 0; font-family: var(--font-display); font-weight: 700; color: var(--color-ink); font-size: var(--text-md); }
.card-body-clean { padding: var(--space-4) 0 0; }
.card-elev { box-shadow: var(--shadow-card); }

/* ─── KPI Stat Cards ─────────────────────────────────────── */
.kpi {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  padding: var(--space-5);
  position: relative;
  transition: transform var(--duration-normal) var(--ease-out-expo);
}

.kpi:hover {
  transform: translate(2px, -3px);
}

.kpi .kpi-label {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  color: var(--color-muted);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.kpi .kpi-value {
  font-family: var(--font-mono);
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--color-ink);
  margin-top: var(--space-1);
  line-height: 1.1;
  font-feature-settings: 'tnum' on, 'zero' on;
}

.kpi .kpi-sub {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  color: var(--color-muted);
  margin-top: var(--space-1);
  font-style: italic;
}

.kpi .kpi-icon {
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  width: 32px;
  height: 32px;
  color: var(--color-terracotta);
  display: grid;
  place-items: center;
  font-size: 1.1rem;
  opacity: 0.6;
  transition: opacity var(--duration-fast) var(--ease-out-expo),
              transform var(--duration-normal) var(--ease-out-expo);
}

.kpi:hover .kpi-icon { opacity: 1; transform: scale(1.05); }

/* Semantic KPI variants */
.kpi.kpi-success .kpi-icon { color: var(--color-success); }
.kpi.kpi-warning .kpi-icon { color: var(--color-warning); }
.kpi.kpi-danger .kpi-icon { color: var(--color-error); }

.kpi .kpi-trend {
  font-size: var(--text-xs);
  font-weight: 600;
  font-family: var(--font-mono);
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
}
.kpi .kpi-trend.up { color: var(--color-success); }
.kpi .kpi-trend.down { color: var(--color-error); }

/* ─── Tables ─────────────────────────────────────────────── */
.table-modern {
  font-size: var(--text-sm);
  margin: 0;
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-body);
}

.table-modern caption {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  color: var(--color-muted);
  text-align: left;
  margin-bottom: var(--space-2);
  font-style: italic;
}

.table-modern thead th {
  background: var(--color-forest);
  color: #fff;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: var(--space-3) var(--space-4);
  position: sticky;
  top: 0;
  white-space: nowrap;
}

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

.table-modern tbody tr { transition: background var(--duration-fast) var(--ease-out-expo); }

.table-modern tbody tr:hover {
  background: var(--color-gold-wash);
}

.table-modern tbody tr:last-child td { border-bottom: 0; }

.table-modern tbody tr.row-highlight {
  background: var(--color-terracotta-wash);
}

.table-modern tbody tr.row-highlight td:first-child {
  border-left: 3px solid var(--color-terracotta);
}

.table-responsive-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* ─── Chips / Badges ─────────────────────────────────────── */
.chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: 0.15rem 0.6rem;
  font-family: var(--font-body);
  font-size: 0.7rem;
  font-weight: 600;
  background: var(--color-surface-alt);
  color: var(--color-muted);
  white-space: nowrap;
  line-height: 1.6;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.chip-brand { background: var(--color-terracotta-wash); color: var(--color-terracotta-deep); }
.chip-success { background: var(--color-success-pale); color: var(--color-success); }
.chip-warning { background: var(--color-warning-pale); color: var(--color-warning); }
.chip-danger { background: var(--color-error-pale); color: var(--color-error); }
.chip-info { background: var(--color-river-wash); color: var(--color-river); }
.chip-gold { background: var(--color-gold-wash); color: var(--color-gold); }

.chip-lg { padding: 0.3rem 0.8rem; font-size: var(--text-xs); }

.chip-dot::before {
  content: "";
  width: 6px;
  height: 6px;
  background: currentColor;
  flex-shrink: 0;
  clip-path: polygon(30% 0%, 70% 0%, 100% 30%, 100% 70%, 70% 100%, 30% 100%, 0% 70%, 0% 30%);
}

/* ─── Buttons ────────────────────────────────────────────── */
.btn {
  font-family: var(--font-body);
  font-weight: 600;
  font-size: var(--text-sm);
  padding: var(--space-3) var(--space-5);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-out-expo);
  letter-spacing: 0.03em;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.btn-primary {
  background: var(--color-terracotta);
  border-color: var(--color-terracotta);
  color: #fff;
}
.btn-primary:hover {
  background: var(--color-terracotta-deep);
  border-color: var(--color-terracotta-deep);
  transform: translateY(-1px);
  color: #fff;
}
.btn-primary:focus-visible {
  outline: 2px solid var(--color-gold);
  outline-offset: 2px;
}

.btn-soft {
  background: transparent;
  border: 1.5px solid var(--color-border);
  color: var(--color-muted);
}
.btn-soft:hover {
  border-color: var(--color-terracotta);
  color: var(--color-terracotta);
  background: var(--color-terracotta-wash);
}

.btn-ghost {
  background: transparent;
  border: 0;
  color: var(--color-muted);
}
.btn-ghost:hover {
  background: var(--color-surface-alt);
  color: var(--color-ink);
}

.btn-light {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.15);
  color: var(--color-ink-dark);
}

.btn-success {
  background: var(--color-success);
  border-color: var(--color-success);
  color: #fff;
}
.btn-success:hover { background: #1e6e38; border-color: #1e6e38; transform: translateY(-1px); color: #fff; }

.btn-danger {
  background: var(--color-error);
  border-color: var(--color-error);
  color: #fff;
}
.btn-danger:hover { background: #b83030; border-color: #b83030; transform: translateY(-1px); color: #fff; }

.btn-gold {
  background: var(--color-gold);
  border-color: var(--color-gold);
  color: #fff;
}
.btn-gold:hover { background: var(--color-gold-bright); border-color: var(--color-gold-bright); transform: translateY(-1px); color: #fff; }

.btn-lg { padding: var(--space-4) var(--space-6); font-size: var(--text-base); }
.btn-sm { padding: var(--space-2) var(--space-4); font-size: var(--text-xs); }
.btn-block { width: 100%; justify-content: center; }

/* ─── Forms ──────────────────────────────────────────────── */
.form-label {
  font-family: var(--font-body);
  font-weight: 600;
  color: var(--color-muted);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: var(--space-1);
}

.form-control,
.form-select {
  font-family: var(--font-body);
  font-size: var(--text-base);
  padding: var(--space-3);
  border: none;
  border-bottom: 2px solid var(--color-border);
  background: transparent;
  color: var(--color-ink);
  transition: border-color var(--duration-fast) var(--ease-out-expo);
}

.form-control:focus,
.form-select:focus {
  outline: none;
  border-color: var(--color-terracotta);
  box-shadow: none;
}

.form-control::placeholder { color: var(--color-border); font-style: italic; }

.form-text {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  color: var(--color-muted);
  font-style: italic;
}

.input-group-text {
  background: transparent;
  border: none;
  border-bottom: 2px solid var(--color-border);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--color-muted);
}

/* Octagonal checkboxes */
.form-check-input[type="checkbox"] {
  width: 18px;
  height: 18px;
  clip-path: polygon(30% 0%, 70% 0%, 100% 30%, 100% 70%, 70% 100%, 30% 100%, 0% 70%, 0% 30%);
  appearance: none;
  -webkit-appearance: none;
  background: var(--color-border);
  border: none;
  cursor: pointer;
  transition: background var(--duration-fast) var(--ease-out-expo);
}
.form-check-input[type="checkbox"]:checked {
  background: var(--color-terracotta);
}
.form-check-input[type="checkbox"]:focus-visible {
  outline: 2px solid var(--color-gold);
  outline-offset: 2px;
}

.form-switch .form-check-input:checked {
  background-color: var(--color-terracotta);
  border-color: var(--color-terracotta);
}

/* ─── Progress ───────────────────────────────────────────── */
.progress {
  height: 6px;
  background: var(--color-border-light);
  overflow: hidden;
}

.progress-bar {
  background: var(--color-terracotta);
  transition: width var(--duration-slow) var(--ease-out-expo);
}

.progress-bar-success { background: var(--color-success); }
.progress-bar-warning { background: var(--color-warning); }
.progress-bar-danger { background: var(--color-error); }

/* ─── Alerts ─────────────────────────────────────────────── */
.alert {
  padding: var(--space-3) var(--space-4);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  animation: fadeIn var(--duration-normal) var(--ease-out-expo);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  border-left: 3px solid;
  background: var(--color-surface);
}

.alert-success { border-left-color: var(--color-success); color: var(--color-success); background: var(--color-success-pale); }
.alert-danger { border-left-color: var(--color-error); color: var(--color-error); background: var(--color-error-pale); }
.alert-info { border-left-color: var(--color-river); color: var(--color-river); background: var(--color-river-wash); }
.alert-warning { border-left-color: var(--color-warning); color: var(--color-warning); background: var(--color-warning-pale); }

/* ─── Toasts (right edge slide-in) ───────────────────────── */
.toast-container {
  position: fixed;
  top: calc(var(--topbar-height) + var(--space-3));
  right: var(--space-3);
  z-index: var(--z-toast);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  pointer-events: none;
}

.toast-premium {
  pointer-events: auto;
  animation: toastIn var(--duration-normal) var(--ease-out-expo) both;
  background: var(--color-surface);
  border-left: 3px solid var(--color-terracotta);
  padding: var(--space-3) var(--space-4);
  box-shadow: var(--shadow-elevated);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  min-width: 280px;
  max-width: 400px;
  font-family: var(--font-body);
  font-size: var(--text-sm);
}

.toast-premium.toast-hiding { animation: toastOut var(--duration-fast) var(--ease-out-expo) both; }

.toast-premium .toast-icon {
  width: 24px;
  height: 24px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  font-size: 1rem;
}
.toast-premium .toast-icon.success { color: var(--color-success); }
.toast-premium .toast-icon.error { color: var(--color-error); }
.toast-premium .toast-icon.info { color: var(--color-river); }
.toast-premium .toast-icon.warning { color: var(--color-warning); }

/* ─── DecoTabs (pill-style tabs) ─────────────────────────── */
.deco-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-5);
}

.deco-tab {
  font-family: var(--font-body);
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
  padding: var(--space-2) var(--space-5);
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-muted);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  transition: all var(--duration-fast) var(--ease-out-expo);
}

.deco-tab:hover {
  border-color: var(--color-terracotta);
  color: var(--color-terracotta);
  background: var(--color-terracotta-wash);
}

.deco-tab.active {
  background: var(--color-terracotta);
  color: #fff;
  border-color: var(--color-terracotta);
}

[data-bs-theme="dark"] .deco-tab.active {
  box-shadow: 0 2px 12px rgba(199,91,57,0.3);
}

/* ─── Empty State ────────────────────────────────────────── */
.empty-state {
  text-align: center;
  padding: var(--space-10) var(--space-5);
  font-family: var(--font-body);
  color: var(--color-muted);
}

.empty-state i {
  font-size: 2.5rem;
  color: var(--color-border);
  margin-bottom: var(--space-3);
  display: block;
}

.empty-state h6 {
  font-family: var(--font-display);
  font-size: var(--text-md);
  color: var(--color-muted);
  margin-bottom: var(--space-2);
}

/* ─── Glass Effect ───────────────────────────────────────── */
.glass {
  background: rgba(255,253,249,0.8);
  backdrop-filter: blur(16px) saturate(1.4);
  -webkit-backdrop-filter: blur(16px) saturate(1.4);
  border: 1px solid rgba(217,208,193,0.4);
}
[data-bs-theme="dark"] .glass {
  background: rgba(36,32,24,0.8);
  border: 1px solid rgba(255,255,255,0.04);
}

/* ─── Health Bar ─────────────────────────────────────────── */
.health-bar { height: 5px; background: var(--color-border-light); overflow: hidden; }
.health-bar-fill { height: 100%; transition: width var(--duration-normal) var(--ease-out-expo); }
.health-bar-fill.good { background: var(--color-success); }
.health-bar-fill.warning { background: var(--color-warning); }
.health-bar-fill.danger { background: var(--color-error); }

/* ─── Stat Compare ───────────────────────────────────────── */
.stat-compare { display: flex; align-items: center; gap: var(--space-3); }
.stat-compare .current {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: var(--text-lg);
  color: var(--color-ink);
}
.stat-compare .delta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 600;
  padding: var(--space-1) var(--space-2);
}
.stat-compare .delta.positive { background: var(--color-success-pale); color: var(--color-success); }
.stat-compare .delta.negative { background: var(--color-error-pale); color: var(--color-error); }

/* ─── Skeleton (trama pattern expansion) ─────────────────── */
.skeleton {
  background: linear-gradient(105deg,
    var(--color-surface-alt) 30%,
    var(--color-gold-wash) 50%,
    var(--color-surface-alt) 70%
  );
  background-size: 200% 100%;
  animation: shimmer 2s ease-in-out infinite;
}

/* ─── Avatar Stack ───────────────────────────────────────── */
.avatar-stack { display: flex; }
.avatar-stack .avatar {
  width: 28px;
  height: 28px;
  border: 2px solid var(--color-surface);
  margin-left: -8px;
  clip-path: polygon(30% 0%, 70% 0%, 100% 30%, 100% 70%, 70% 100%, 30% 100%, 0% 70%, 0% 30%);
}
.avatar-stack .avatar:first-child { margin-left: 0; }

/* ─── Tooltip ────────────────────────────────────────────── */
.tooltip-premium { position: relative; }
.tooltip-premium[data-tooltip]:hover::after {
  content: attr(data-tooltip);
  position: absolute;
  bottom: calc(100% + 6px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--color-charcoal);
  color: var(--color-ink-dark);
  padding: var(--space-1) var(--space-3);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  white-space: nowrap;
  z-index: var(--z-dropdown);
  pointer-events: none;
}