/* ============================================================
   dagdAPP MES — main.css v1.0
   CSS centralizado — todas las páginas de la aplicación
   ============================================================ */

/* ── 1. VARIABLES ─────────────────────────────────────────── */
:root {
  /* Fondos */
  --bg:        #04070d;
  --bg-2:      #070d1a;
  --bg-3:      #0a1019;
  --surface:   #0f1726;
  --surface-2: #172240;
  --card:      #1e293b;

  /* Bordes */
  --border:    #172240;
  --border-2:  #2d3a5c;
  --border-3:  #334155;

  /* Texto */
  --txt:   #eaeff8;
  --txt-2: #cbd5e1;
  --txt-3: #94a3b8;
  --txt-4: #64748b;
  --txt-5: #455678;
  --txt-6: #8899b8;

  /* Colores de acento */
  --amber:    #f59e0b;
  --amber-h:  #d97706;
  --amber-bg: rgba(245,158,11,.10);
  --green:    #22c55e;
  --green-bg: #052e16;
  --red:      #ef4444;
  --red-h:    #dc2626;
  --blue:     #3b82f6;
  --blue-h:   #2563eb;
  --cyan:     #06b6d4;
  --purple:   #a78bfa;
  --teal:     #0ea5a0;
  --teal-d:   rgba(14,165,160,.13);

  /* Radios */
  --r-sm:  4px;
  --r:     6px;
  --r-md:  8px;
  --r-lg:  10px;
  --r-xl:  12px;
  --r-2xl: 14px;
  --r-3xl: 16px;

  /* Fuentes */
  --font:      'Segoe UI', system-ui, sans-serif;
  --font-mono: 'IBM Plex Mono', monospace;
}

/* ── 2. RESET Y BASE ──────────────────────────────────────── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--txt);
  min-height: 100vh;
  display: flex;
  font-size: 13px;
  line-height: 1.5;
}

h1 { font-size: 22px; font-weight: 800; margin-bottom: 16px; }
h1 span { font-weight: 400; color: var(--txt-4); font-size: 14px; }
h2 { font-size: 18px; font-weight: 700; }
h3 { font-size: 15px; font-weight: 700; }

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

/* ── 3. LAYOUT ────────────────────────────────────────────── */
.main {
  margin-left: 180px;
  flex: 1;
  padding: 24px;
  overflow-y: auto;
}

/* ── 4. TIPOGRAFÍA UTILITARIA ─────────────────────────────── */
.section-title {
  font-size: 11px;
  font-weight: 700;
  color: var(--txt-5);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 12px;
}

.subtitle { color: var(--txt-4); font-size: 13px; margin-bottom: 24px; }

/* ── 5. BOTONES ───────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  border-radius: var(--r);
  font-size: 13px;
  font-weight: 600;
  border: none;
  cursor: pointer;
  transition: all .2s;
  font-family: var(--font);
  white-space: nowrap;
  text-decoration: none;
}
.btn:disabled { opacity: .4; cursor: not-allowed; }

.btn-pri  { background: var(--amber); color: #000; }
.btn-pri:hover  { background: var(--amber-h); }

.btn-sec  { background: var(--card); color: var(--txt-3); border: 1px solid var(--border-3); }
.btn-sec:hover  { background: var(--border-3); }

.btn-danger { background: var(--red); color: #fff; }
.btn-danger:hover { background: var(--red-h); }

.btn-blue { background: var(--blue); color: #fff; }
.btn-blue:hover { background: var(--blue-h); }

.btn-ghost { background: none; border: 1px solid var(--border-2); color: var(--txt-3); }
.btn-ghost:hover { color: var(--txt); border-color: var(--border-3); }

.btn-ico {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 14px;
  padding: 4px;
  border-radius: var(--r-sm);
  color: var(--txt-3);
  transition: background .15s;
}
.btn-ico:hover { background: var(--card); }

.btn-sm { padding: 5px 10px; font-size: 11px; }

/* Spinner dentro de botón */
.btn .spin {
  display: none;
  width: 13px; height: 13px;
  border: 2px solid rgba(255,255,255,.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin .7s linear infinite;
}
.btn.loading .spin { display: block; }
.btn.loading .btn-label { display: none; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ── 6. INPUTS Y FORMULARIOS ──────────────────────────────── */
.search {
  background: var(--bg-3);
  border: 1px solid var(--border-2);
  border-radius: var(--r);
  padding: 7px 12px;
  color: var(--txt);
  font-size: 13px;
  width: 220px;
  outline: none;
  font-family: var(--font);
  transition: border-color .2s;
}
.search:focus { border-color: var(--amber); }

.fsel, .finp {
  background: var(--bg-3);
  border: 1px solid var(--border-2);
  border-radius: var(--r);
  padding: 6px 10px;
  color: var(--txt-3);
  font-size: 12px;
  outline: none;
  font-family: var(--font);
  transition: border-color .2s;
}
.fsel:focus, .finp:focus { border-color: var(--amber); }
.finp { color: var(--txt); }

/* Grid de formulario */
.fm-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.fm-grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }
.fm-g { display: flex; flex-direction: column; gap: 4px; margin-bottom: 0; }
.fm-g.fw { grid-column: 1 / -1; }
.fm-g.hw { grid-column: span 2; }

.fm-g label {
  font-size: 11px;
  color: var(--txt-6);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.fm-g input,
.fm-g select,
.fm-g textarea {
  background: var(--bg-3);
  border: 1px solid var(--border-2);
  border-radius: var(--r);
  padding: 8px 12px;
  color: var(--txt);
  font-size: 13px;
  outline: none;
  font-family: var(--font);
  transition: border-color .2s;
  width: 100%;
}
.fm-g input:focus,
.fm-g select:focus,
.fm-g textarea:focus { border-color: var(--amber); }
.fm-g input[type=color] { padding: 2px 4px; height: 36px; cursor: pointer; }
.fm-g textarea { resize: vertical; min-height: 80px; line-height: 1.5; }

.fm-section {
  font-size: 11px; font-weight: 700; color: var(--txt-5);
  text-transform: uppercase; letter-spacing: .1em;
  margin: 18px 0 10px; padding-bottom: 6px;
  border-bottom: 1px solid var(--border);
  grid-column: 1 / -1;
}

.fm-section-wrap {
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
  margin-bottom: 12px;
}
.fm-section-title {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 14px; background: var(--bg-2);
  font-size: 10px; font-weight: 700; color: var(--txt-5);
  text-transform: uppercase; letter-spacing: .08em;
}
.fm-section-body { padding: 14px; background: var(--bg-3); }

.hint { font-size: 10px; color: var(--txt-5); margin-top: 2px; }
.info-box {
  background: var(--bg-3); border: 1px solid var(--border);
  border-radius: var(--r-md); padding: 12px;
  margin-bottom: 14px; font-size: 12px; color: var(--txt-4);
}

/* ── 7. TABLAS ────────────────────────────────────────────── */
.table-wrap {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: auto;
  max-height: calc(100vh - 180px);
}

table { width: 100%; border-collapse: collapse; font-size: 12px; }

th {
  text-align: left;
  padding: 8px 10px;
  color: var(--txt-4);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .06em;
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  background: var(--surface);
  z-index: 1;
  user-select: none;
}
th:hover { color: var(--txt-3); }
th .sort-ico { font-size: 8px; margin-left: 3px; opacity: .5; }

td {
  padding: 8px 10px;
  border-bottom: 1px solid var(--bg-3);
  color: var(--txt-2);
  vertical-align: middle;
}
tr:hover td { background: rgba(10,16,25,.19); }

/* ── 8. MODALES ───────────────────────────────────────────── */
#modal-ov {
  position: fixed; inset: 0; z-index: 1000; display: none;
}
#modal-ov.visible { display: block; }

.m-bg {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.7);
  backdrop-filter: blur(4px);
}

.m-box {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  background: var(--surface);
  border: 1px solid var(--border-2);
  border-radius: var(--r-2xl);
  width: 680px; max-width: 95vw;
  max-height: 90vh; overflow-y: auto;
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
}
.m-box-sm { width: 480px; }
.m-box-md { width: 560px; }
.m-box-lg { width: 720px; }
.m-box-xl { width: 760px; }

.m-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 20px; border-bottom: 1px solid var(--border);
}
.m-head h3 { font-size: 16px; font-weight: 700; color: var(--txt); }

.m-close {
  background: none; border: none;
  color: var(--txt-4); font-size: 18px;
  cursor: pointer; padding: 4px 8px;
  border-radius: var(--r-sm);
  transition: all .15s;
}
.m-close:hover { background: var(--card); color: var(--txt); }

.m-body { padding: 20px; }
.m-foot {
  display: flex; justify-content: flex-end; gap: 10px;
  padding: 14px 20px; border-top: 1px solid var(--border);
}

/* ── 9. BADGES Y ESTADOS ──────────────────────────────────── */
.badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 99px;
  font-size: 10px;
  font-weight: 700;
}

/* Toasts */
.toast {
  position: fixed; bottom: 20px; right: 20px;
  padding: 12px 20px; border-radius: var(--r-md);
  font-size: 13px; font-weight: 600;
  z-index: 9999; opacity: 0;
  transform: translateY(10px);
  transition: all .3s;
  pointer-events: none;
}
.toast.visible { opacity: 1; transform: translateY(0); }
.t-ok    { background: var(--green); color: #000; }
.t-error { background: var(--red);   color: #fff; }
.t-info  { background: var(--blue);  color: #fff; }

/* Estado dots */
.dot {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  vertical-align: middle;
  margin-right: 5px;
}
.estado-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; margin-right: 6px; vertical-align: middle; }

/* Desviaciones */
.dev-pos, .delta-neg { color: var(--red); }
.dev-neg, .delta-pos { color: var(--green); }
.dev-neu, .delta-neu { color: var(--txt-3); }

/* Avatar */
.avatar {
  width: 28px; height: 28px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 800;
  background: var(--surface-2); color: var(--amber);
  vertical-align: middle; margin-right: 8px;
  flex-shrink: 0;
}

/* ── 10. TOOLBAR ──────────────────────────────────────────── */
.toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
  flex-wrap: wrap;
  gap: 10px;
}

.filters { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }

.filter-sel {
  background: var(--bg-3);
  border: 1px solid var(--border-2);
  border-radius: var(--r);
  padding: 7px 10px;
  color: var(--txt-3);
  font-size: 12px;
  outline: none;
  font-family: var(--font);
}
.filter-sel:focus { border-color: var(--amber); }

/* ── 11. CARDS GENÉRICAS ──────────────────────────────────── */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  overflow: hidden;
}
.card:hover { border-color: var(--border-2); }

.card-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 14px; border-bottom: 1px solid var(--border);
}
.card-title {
  font-size: 11px; font-weight: 700;
  color: var(--txt-4); text-transform: uppercase; letter-spacing: .06em;
}
.card-body { padding: 16px; }

/* ── 12. WELCOME / HERO BANNERS ───────────────────────────── */
.welcome {
  background: linear-gradient(135deg, var(--surface), var(--bg-2));
  border: 1px solid #1e3a5f;
  border-radius: var(--r-xl);
  padding: 16px 22px;
  margin-bottom: 16px;
  position: relative;
  overflow: hidden;
}
.welcome::before,
.welcome-section::before,
.ciclo-hero::before,
.login-container::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--amber), var(--blue), var(--green), var(--purple));
}
.welcome h1 { font-size: 19px; font-weight: 800; margin-bottom: 2px; }
.welcome-sub { font-size: 11px; color: var(--txt-5); margin-top: 3px; }

/* ── 13. PAGINACIÓN ───────────────────────────────────────── */
.pager {
  display: flex; align-items: center; gap: 10px;
  margin-top: 12px; font-size: 12px; color: var(--txt-4);
}
.pager-btn {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r); padding: 5px 10px;
  color: var(--txt-3); cursor: pointer; font-size: 11px;
  transition: all .2s; font-family: var(--font);
}
.pager-btn:hover:not(:disabled) { background: var(--card); color: var(--txt); }
.pager-btn:disabled { opacity: .3; cursor: default; }
.pager-info { font-size: 11px; color: var(--txt-4); }

/* ── 14. BARRAS DE PROGRESO ───────────────────────────────── */
.bar-wrap {
  background: var(--surface-2);
  border-radius: 99px; height: 6px;
  width: 100px; overflow: hidden;
}
.bar-fill { height: 100%; border-radius: 99px; transition: width .3s; }

/* ── 15. TABS ─────────────────────────────────────────────── */
.tabs-bar {
  display: flex; gap: 4px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 16px;
}
.tab-btn {
  padding: 7px 15px;
  font-size: 12px; font-weight: 500;
  color: var(--txt-4);
  background: none; border: none;
  border-bottom: 2px solid transparent;
  cursor: pointer; font-family: var(--font);
  transition: all .15s;
}
.tab-btn:hover { color: var(--txt); }
.tab-btn.active { color: var(--amber); border-bottom-color: var(--amber); }
.tab-pane { display: none; }
.tab-pane.active { display: block; }

/* ── 16. NÚMEROS FORMATO ESPAÑOL ──────────────────────────── */
/* Aplicar .num-es a cualquier elemento que muestre cifras */
.num-es { font-variant-numeric: tabular-nums; }

/* ── 17. COMPONENTES DASHBOARD ────────────────────────────── */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 10px; margin-bottom: 16px;
}
.kpi {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: 11px 12px; text-align: center;
}
.kpi-ico { font-size: 15px; margin-bottom: 4px; }
.kpi-val { font-size: 20px; font-weight: 900; color: var(--amber); line-height: 1; }
.kpi-lbl { font-size: 9px; color: var(--txt-5); text-transform: uppercase; letter-spacing: .04em; margin-top: 3px; }

.row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 14px; }
.row-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px; margin-bottom: 14px; }

.alerta {
  background: var(--amber-bg); border: 1px solid rgba(245,158,11,.33);
  border-radius: var(--r-lg); padding: 11px 16px;
  margin-bottom: 14px; display: flex; align-items: center; gap: 14px;
}
.alerta-val  { font-size: 24px; font-weight: 900; color: var(--amber); }
.alerta-lbl  { font-size: 12px; color: var(--txt-3); }
.alerta-sub  { font-size: 10px; color: var(--txt-4); margin-top: 2px; }

.scope-btn {
  padding: 5px 12px; border-radius: var(--r);
  font-size: 11px; font-weight: 700;
  border: 1px solid var(--border-2);
  background: transparent; color: var(--txt-4);
  cursor: pointer; transition: all .2s; font-family: var(--font);
}
.scope-btn.active { background: var(--amber); color: #000; border-color: var(--amber); }

/* ── 18. COMPONENTES SEGUIMIENTO ──────────────────────────── */
.summary-grid {
  display: grid; grid-template-columns: repeat(5, 1fr);
  gap: 10px; margin-bottom: 14px;
}
.sum-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-md); padding: 10px 14px;
}
.sum-val { font-size: 20px; font-weight: 900; line-height: 1; }
.sum-lbl { font-size: 9px; color: var(--txt-4); text-transform: uppercase; letter-spacing: .05em; margin-top: 3px; }

/* ── 19. COMPONENTES CICLO ESTRATÉGICO ────────────────────── */
.step-bar {
  display: flex; gap: 4px; margin-bottom: 20px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: 8px;
}
.step {
  flex: 1; padding: 10px 6px; border-radius: 7px;
  text-align: center; cursor: pointer; border: none;
  background: transparent; transition: all .2s;
  border-bottom: 3px solid transparent;
  font-family: var(--font);
}
.step.active  { border-bottom-color: var(--fase-color, var(--amber)); background: rgba(245,158,11,.05); }
.step.done    { border-bottom-color: var(--green); background: rgba(34,197,94,.05); }
.step.locked  { opacity: .35; cursor: not-allowed; }
.step-num { font-size: 10px; font-weight: 800; text-transform: uppercase; color: var(--txt-4); }
.step.active .step-num { color: var(--fase-color, var(--amber)); }
.step.done   .step-num { color: var(--green); }
.step-label { font-size: 11px; font-weight: 700; color: var(--txt-3); margin-top: 2px; }
.step-sub   { font-size: 9px; color: var(--txt-5); margin-top: 1px; }

.fases-progress {
  display: grid; grid-template-columns: repeat(5, 1fr);
  gap: 8px; margin-bottom: 20px;
}
.fase-item {
  background: var(--bg-3); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: 12px; text-align: center;
  cursor: pointer; transition: all .2s; position: relative;
}
.fase-item:hover   { border-color: rgba(245,158,11,.27); }
.fase-item.done    { border-color: rgba(34,197,94,.27); background: rgba(5,46,22,.06); }
.fase-item.current { border-color: var(--fase-color, var(--amber)); background: rgba(245,158,11,.05); }
.fase-item.locked  { opacity: .4; cursor: not-allowed; }
.fase-num  { font-size: 11px; font-weight: 800; margin-bottom: 4px; color: var(--txt-5); }
.fase-item.done    .fase-num { color: var(--green); }
.fase-item.current .fase-num { color: var(--fase-color, var(--amber)); }
.fase-titulo { font-size: 12px; font-weight: 700; color: var(--txt-3); }
.fase-sub    { font-size: 10px; color: var(--txt-5); margin-top: 2px; }

.gate-score  { font-size: 36px; font-weight: 900; text-align: center; margin: 8px 0; }
.gate-result { padding: 10px 14px; border-radius: var(--r-md); font-size: 12px; font-weight: 600; text-align: center; margin-top: 10px; }
.gate-pass   { background: var(--green-bg); color: var(--green); border: 1px solid rgba(34,197,94,.27); }
.gate-fail   { background: var(--amber-bg); color: var(--amber); border: 1px solid rgba(245,158,11,.27); }
.gate-pending{ background: var(--surface); color: var(--txt-4); border: 1px solid var(--border); }

/* ── 20. COMPONENTES BIENVENIDA ───────────────────────────── */
.status-grid  { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; margin-bottom: 24px; }
.status-card  { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-xl); padding: 18px 20px; transition: all .2s; }
.status-card:hover { transform: translateY(-2px); border-color: var(--border-2); }
.status-icon  { width: 38px; height: 38px; border-radius: var(--r-md); display: flex; align-items: center; justify-content: center; font-size: 18px; margin-bottom: 10px; }
.status-title { font-size: 11px; font-weight: 600; color: var(--txt-4); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 4px; }
.status-value { font-size: 22px; font-weight: 800; color: var(--txt); }

.acciones-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px,1fr)); gap: 10px; }
.accion {
  display: flex; align-items: center; gap: 10px;
  text-decoration: none; color: inherit;
  background: var(--bg-3); border: 1px solid var(--border);
  border-radius: var(--r-md); padding: 12px 14px;
  transition: all .2s;
}
.accion:hover { border-color: var(--amber); background: var(--amber-bg); transform: translateY(-1px); }
.accion-ico   { font-size: 18px; }
.accion-title { font-size: 12px; font-weight: 700; }
.accion-sub   { font-size: 10px; color: var(--txt-4); margin-top: 1px; }

/* ── 21. COMPONENTES LOGIN ────────────────────────────────── */
.login-container {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-3xl);
  padding: 40px; width: 100%; max-width: 400px;
  box-shadow: 0 20px 40px rgba(0,0,0,.3);
  position: relative; overflow: hidden;
}
.login-header  { text-align: center; margin-bottom: 32px; }
.login-logo    {
  display: inline-flex; align-items: center; justify-content: center;
  width: 60px; height: 60px;
  background: linear-gradient(135deg, var(--amber), var(--blue));
  border-radius: var(--r-xl); color: #fff;
  font-size: 24px; font-weight: 800; margin-bottom: 16px;
}
.login-title   { font-size: 24px; font-weight: 800; margin-bottom: 4px; color: var(--txt); }
.login-subtitle{ font-size: 14px; color: var(--txt-4); }
.login-btn {
  width: 100%; padding: 12px 24px;
  background: linear-gradient(135deg, var(--blue), #1d4ed8);
  border: none; border-radius: var(--r-md);
  color: #fff; font-size: 14px; font-weight: 600;
  cursor: pointer; transition: all .2s; margin-bottom: 16px;
  font-family: var(--font);
}
.login-btn:hover    { transform: translateY(-1px); box-shadow: 0 4px 12px rgba(59,130,246,.3); }
.login-btn:active   { transform: translateY(0); }
.login-btn:disabled { opacity: .6; cursor: not-allowed; transform: none; }
.login-footer  {
  text-align: center; margin-top: 24px;
  padding-top: 20px; border-top: 1px solid var(--border);
  font-size: 11px; color: var(--txt-5);
}
.form-group  { margin-bottom: 20px; }
.form-label  {
  display: block; font-size: 12px; font-weight: 600;
  color: var(--txt-6); margin-bottom: 6px;
  text-transform: uppercase; letter-spacing: .05em;
}
.form-input  {
  width: 100%; padding: 12px 16px;
  background: var(--bg-3); border: 1px solid var(--border);
  border-radius: var(--r-md); color: var(--txt);
  font-size: 14px; transition: all .2s; font-family: var(--font);
  outline: none;
}
.form-input:focus { border-color: var(--blue); box-shadow: 0 0 0 2px rgba(59,130,246,.1); }
.form-input::placeholder { color: var(--txt-5); }
.alert         { padding: 12px 16px; border-radius: var(--r-md); margin-bottom: 20px; font-size: 13px; font-weight: 500; }
.alert-error   { background: rgba(239,68,68,.1); border: 1px solid rgba(239,68,68,.2); color: #fca5a5; }
.alert-success { background: rgba(34,197,94,.1); border: 1px solid rgba(34,197,94,.2); color: #86efac; }
.remember-group{ display: flex; align-items: center; gap: 8px; margin-bottom: 20px; }
.checkbox      { width: 16px; height: 16px; accent-color: var(--blue); }
.remember-label{ font-size: 12px; color: var(--txt-6); cursor: pointer; }
.field-hint    { font-size: 10px; color: var(--txt-4); margin-top: 4px; }

/* ── 22. COMPONENTES ESTRATEGIA ───────────────────────────── */
.fase-banner {
  display: flex; align-items: center; gap: 12px;
  padding: .875rem 1.25rem; border-radius: var(--r-lg);
  border: 1px solid var(--border); background: var(--card);
  margin-bottom: 1.25rem; flex-wrap: wrap;
}
.fase-steps  { display: flex; align-items: center; flex: 1; }
.fase-step   { display: flex; align-items: center; gap: 7px; font-size: 12px; color: var(--txt-4); padding: 5px 10px; border-radius: var(--r); transition: .2s; }
.fase-step.done   { color: var(--green); }
.fase-step.active { color: var(--teal); background: var(--teal-d); font-weight: 600; }
.fase-step .num   { width: 20px; height: 20px; border-radius: 50%; border: 1.5px solid currentColor; display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; flex-shrink: 0; }
.fase-step.done .num { background: var(--green); border-color: var(--green); color: #fff; }
.fase-sep    { width: 24px; height: 1px; background: var(--border); flex-shrink: 0; }
.fase-actions{ display: flex; gap: 8px; flex-wrap: wrap; }

.src-pills   { display: flex; gap: 7px; flex-wrap: wrap; margin-bottom: 1.25rem; }
.src         { display: flex; align-items: center; gap: 5px; font-size: 11px; padding: 3px 10px; border-radius: 20px; border: 1px solid var(--border); color: var(--txt-3); background: var(--surface); }
.src.mes     { border-color: var(--teal); color: var(--teal); background: var(--teal-d); }
.src.web     { border-color: var(--blue); color: var(--blue); background: rgba(59,130,246,.11); }
.src.ai      { border-color: var(--amber); color: var(--amber); background: var(--amber-bg); }

.dafo-g      { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 1rem; }
.dbox        { background: var(--card); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 1rem; }
.dbox-h      { display: flex; align-items: center; gap: 9px; margin-bottom: .875rem; padding-bottom: .625rem; border-bottom: 1px solid var(--border); }
.dico        { width: 28px; height: 28px; border-radius: var(--r); display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; flex-shrink: 0; }
.dtitle      { font-size: 13px; font-weight: 600; }
.dsub        { font-size: 10px; color: var(--txt-4); margin-top: 1px; }
.slbl        { font-size: 10px; font-weight: 600; color: var(--txt-4); text-transform: uppercase; letter-spacing: .5px; margin: 9px 0 5px; }

.val-summary { background: var(--card); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 1rem 1.25rem; margin-bottom: 1.25rem; display: none; }
.val-summary.show { display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap; }
.vs-stat     { text-align: center; }
.vs-val      { font-size: 20px; font-weight: 700; }
.vs-lbl      { font-size: 10px; color: var(--txt-4); margin-top: 1px; }
.vs-sep      { width: 1px; height: 36px; background: var(--border); flex-shrink: 0; }
.vs-msg      { flex: 1; font-size: 12px; color: var(--txt-3); line-height: 1.5; }

/* ── 23. OPERACIONES — LAYOUT ESPECÍFICO ──────────────────── */
.ops-grid   { display: grid; grid-template-columns: 25% 15% 15% 15% 15% 10% 5%; width: 100%; }
.ops-header { background: var(--bg-2); border-bottom: 1px solid var(--border); position: sticky; top: 0; z-index: 2; }
.ops-header .col { padding: 7px 16px; color: var(--txt-5); font-size: 10px; text-transform: uppercase; letter-spacing: .06em; font-weight: 700; }
.ops-header .col.center { text-align: center; }
.seccion-block  { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-xl); margin-bottom: 10px; overflow: hidden; }
.seccion-header { display: flex; justify-content: space-between; align-items: center; padding: 12px 16px; cursor: pointer; transition: background .15s; }
.seccion-header:hover { background: var(--bg-3); }
.seccion-codigo { font-size: 13px; font-weight: 800; color: var(--cyan); margin-left: 10px; }
.seccion-nombre { font-size: 13px; color: var(--txt-3); font-weight: 400; margin-left: 4px; }
.op-row { display: grid; grid-template-columns: 25% 15% 15% 15% 15% 10% 5%; width: 100%; border-top: 1px solid var(--bg-3); transition: background .15s; cursor: grab; }
.op-row:hover { background: rgba(10,16,25,.19); }
.op-row .col { padding: 8px 16px; color: var(--txt-3); font-size: 12px; display: flex; align-items: center; }
.op-row .col.center { justify-content: center; font-size: 18px; }
.op-row.dragging { opacity: .4; background: var(--surface-2); }
.op-row.drag-over { border-top: 2px solid var(--amber); }
.drag-handle { color: var(--border-2); font-size: 14px; cursor: grab; padding-right: 6px; }

/* ── 24. RESPONSIVE ───────────────────────────────────────── */
@media (max-width: 1400px) { .kpi-grid { grid-template-columns: repeat(4,1fr); } }
@media (max-width: 1000px) { .row-2, .row-3 { grid-template-columns: 1fr; } }
@media (max-width: 900px)  {
  .dafo-g, .fases-progress, .status-grid, .summary-grid { grid-template-columns: 1fr 1fr; }
  .main { margin-left: 0; padding: 16px; }
}
@media (max-width: 600px)  {
  .dafo-g, .fases-progress, .status-grid, .summary-grid { grid-template-columns: 1fr; }
  .fm-grid, .fm-grid-3 { grid-template-columns: 1fr; }
}
@media (max-width: 480px)  {
  .login-container { padding: 24px; margin: 20px; }
}

/* ── 25. ESTRATEGIA — ESTILOS ESPECÍFICOS ─────────────────── */
.hdr{background:var(--surface);border-bottom:1px solid var(--border);padding:.875rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.hdr-l{display:flex;align-items:center;gap:10px}
.back{display:flex;align-items:center;gap:5px;color:var(--txt-4);text-decoration:none;font-size:12px;padding:4px 10px;border:1px solid var(--border);border-radius:var(--r);transition:.15s}
.back:hover{color:var(--txt);border-color:var(--border-2)}
.ptitle{font-size:15px;font-weight:600;display:flex;align-items:center;gap:8px}
.ebadge{display:flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:5px 12px;font-size:12px}
.eav{width:22px;height:22px;border-radius:50%;background:var(--teal-d);border:1px solid var(--teal);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:var(--teal)}
.log{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:.625rem 1rem;margin-bottom:1.25rem;display:none;font-family:var(--font-mono);font-size:11px;color:var(--txt-3);max-height:100px;overflow-y:auto}
.log.show{display:block}
.ll{display:flex;gap:8px;margin-bottom:2px}
.ll .ts{color:var(--txt-4);flex-shrink:0}
.ll.ok .m{color:var(--green)}.ll.info .m{color:var(--teal)}.ll.warn .m{color:var(--amber)}.ll.err .m{color:var(--red)}
.tb{padding:7px 15px;font-size:12px;font-weight:500;color:var(--txt-4);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-family:var(--font);transition:.15s}
.tb:hover{color:var(--txt)}.tb.on{color:var(--teal);border-bottom-color:var(--teal)}
.pane{display:none}.pane.on{display:block}
.ditem{display:flex;align-items:flex-start;gap:6px;margin-bottom:6px;padding:6px 8px;border-radius:var(--r);border:1px solid var(--border);background:var(--surface);transition:.2s;animation:fi .2s ease}
@keyframes fi{from{opacity:0;transform:translateY(3px)}to{opacity:1;transform:none}}
.ditem.approved{border-color:rgba(34,197,94,.4);background:rgba(34,197,94,.05)}
.ditem.rejected{opacity:.3}
.ditem.editing{border-color:var(--teal);background:var(--teal-d)}
.ditem-body{flex:1;min-width:0}
.ditem-qual{font-size:10px;color:var(--teal);font-weight:600;margin-bottom:2px}
.ditem-txt{font-size:12px;color:var(--txt);line-height:1.4}
.ditem-input{width:100%;font-size:12px;padding:3px 6px;background:var(--surface);border:1px solid var(--border);border-radius:4px;color:var(--txt);font-family:var(--font);display:none}
.ditem-input:focus{outline:none;border-color:var(--teal)}
.ditem-acts{display:flex;gap:3px;flex-shrink:0;margin-top:1px}
.iact{width:22px;height:22px;border-radius:50%;border:1px solid var(--border);background:none;cursor:pointer;font-size:11px;display:flex;align-items:center;justify-content:center;color:var(--txt-4);transition:.15s;flex-shrink:0}
.iact:hover{transform:scale(1.1)}
.iact.approve:hover,.iact.active-approve{background:rgba(34,197,94,.12);border-color:var(--green);color:var(--green)}
.iact.reject:hover,.iact.active-reject{background:rgba(239,68,68,.12);border-color:var(--red);color:var(--red)}
.iact.edit:hover{background:var(--teal-d);border-color:var(--teal);color:var(--teal)}
.add-btn{width:100%;font-size:11px;color:var(--txt-4);background:none;border:1px dashed var(--border);border-radius:var(--r);padding:3px 9px;cursor:pointer;margin-top:4px;font-family:var(--font);transition:.15s;text-align:left}
.add-btn:hover{border-color:var(--teal);color:var(--teal)}
.fc{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:.875rem;display:flex;flex-direction:column;gap:7px;transition:.15s}
.fc.approved{border-color:rgba(34,197,94,.4)}
.fc.has-data .f-adjust{display:flex}
.fc.has-data .fc-acts{display:flex}
.fn{font-size:11px;font-weight:600;color:var(--txt-3);line-height:1.4}
.fsr{display:flex;align-items:center;gap:6px}
.fsc{font-size:21px;font-weight:700;min-width:42px}
.fsc.hi{color:var(--red)}.fsc.md{color:var(--amber)}.fsc.lo{color:var(--green)}.fsc.p{color:var(--txt-4);font-size:15px}
.fbt{flex:1;height:4px;border-radius:2px;background:var(--border);overflow:hidden}
.fbf{height:4px;border-radius:2px;transition:width .7s cubic-bezier(.4,0,.2,1)}
.frat{font-size:11px;color:var(--txt-4);line-height:1.5;min-height:36px}
.fpend{font-size:11px;color:var(--txt-4);font-style:italic;min-height:36px;display:flex;align-items:center}
.f-adjust{display:none;flex-direction:column;gap:4px;margin-top:2px}
.f-adjust label{font-size:10px;color:var(--txt-4);display:flex;justify-content:space-between}
.f-adjust input[type=range]{width:100%;accent-color:var(--teal)}
.fc-acts{display:none;gap:5px;justify-content:flex-end}
.cc{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:.875rem;transition:.2s;position:relative}
.cc.approved{border-color:rgba(34,197,94,.4);background:rgba(34,197,94,.03)}
.cc.rejected{opacity:.3}
.cc-badge{position:absolute;top:8px;right:8px;font-size:10px;padding:2px 7px;border-radius:8px;font-weight:600}
.cc-badge.new{background:var(--amber-bg);border:1px solid var(--amber);color:var(--amber)}
.cc-badge.known{background:var(--teal-d);border:1px solid var(--teal);color:var(--teal)}
.cc-h{display:flex;align-items:flex-start;gap:8px;margin-bottom:.5rem}
.cav{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}
.cnm{font-size:12px;font-weight:600;line-height:1.3}.clc{font-size:10px;color:var(--txt-4);margin-top:1px}
.chips{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:.5rem}
.chip{font-size:10px;padding:2px 6px;border-radius:8px;background:var(--bg-3);border:1px solid var(--border);color:var(--txt-4)}
.chip.a{background:var(--amber-bg);border-color:var(--amber);color:var(--amber)}
.chip.r{background:rgba(239,68,68,.12);border-color:var(--red);color:var(--red)}
.chip.g{background:rgba(34,197,94,.12);border-color:var(--green);color:var(--green)}
.cbr{display:flex;align-items:center;gap:5px;margin-bottom:3px}
.cbl{font-size:10px;color:var(--txt-4);width:82px;text-align:right;flex-shrink:0}
.cbt{flex:1;height:3px;border-radius:2px;background:var(--border)}
.cbf{height:3px;border-radius:2px}.cbv{font-size:10px;font-weight:600;width:24px}
.cdsc{font-size:11px;color:var(--txt-4);line-height:1.4;margin:.4rem 0}
.cthr{font-size:10px;padding:4px 8px;border-radius:var(--r);background:var(--amber-bg);border:1px solid rgba(245,158,11,.3);color:var(--amber);line-height:1.4;margin-bottom:.5rem}
.cc-acts{display:flex;gap:5px;justify-content:flex-end}
.rec-list{display:flex;flex-direction:column;gap:8px}
.rc{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:.875rem 1.125rem;display:flex;gap:11px;transition:.2s;animation:fi .3s ease}
.rc.approved{border-color:rgba(34,197,94,.4);background:rgba(34,197,94,.03)}
.rc.rejected{opacity:.3}
.rn{width:26px;height:26px;border-radius:50%;background:var(--teal-d);border:1px solid var(--teal);color:var(--teal);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.rt{font-size:13px;font-weight:600;margin-bottom:3px;display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.rtx{font-size:12px;color:var(--txt-4);line-height:1.5}
.pri{font-size:10px;padding:2px 6px;border-radius:8px;font-weight:500}
.pri.alta{background:rgba(239,68,68,.12);color:var(--red);border:1px solid rgba(239,68,68,.3)}
.pri.media{background:var(--amber-bg);color:var(--amber);border:1px solid rgba(245,158,11,.3)}
.pri.baja{background:rgba(59,130,246,.11);color:var(--blue);border:1px solid rgba(59,130,246,.3)}
.rc-acts{display:flex;gap:5px;flex-shrink:0;margin-top:2px}
.sbadge{font-size:11px;padding:3px 10px;border-radius:10px;background:var(--teal-d);border:1px solid var(--teal);color:var(--teal)}
.sh{display:flex;align-items:center;justify-content:space-between;margin-bottom:.875rem;flex-wrap:wrap;gap:8px}
.sh h3{font-size:14px;font-weight:600}
.empty{text-align:center;padding:2.5rem 1rem;color:var(--txt-4);border:1px dashed var(--border);border-radius:var(--r-lg)}
.empty .ei{font-size:28px;margin-bottom:.625rem;opacity:.35}
.act-bar{display:flex;gap:8px;justify-content:flex-end;margin-top:.875rem;flex-wrap:wrap}
.btn.teal{background:var(--teal);border-color:var(--teal);color:#fff}
.btn.teal:hover{background:#0c9490}
.btn.grn{background:var(--green);border-color:var(--green);color:#fff}
.btn.grn:hover{background:#16a34a}
.btn.ghost{background:none;border:1px solid var(--border);color:var(--txt-4)}
.btn.ghost:hover{color:var(--txt);border-color:var(--border-2)}
@media(max-width:900px){.dafo-g,.forces,.comp-g{grid-template-columns:1fr}.forces{grid-template-columns:1fr 1fr}}

/* ── 26. ÍTEMS DAFO — COLORES POR CUADRANTE ───────────────── */
/* Aplicar al .ditem según el cuadrante — independiente del estado */
.ditem-f { border-left: 3px solid var(--green);  background: rgba(34,197,94,.04); }
.ditem-d { border-left: 3px solid var(--red);    background: rgba(239,68,68,.04); }
.ditem-o { border-left: 3px solid var(--blue);   background: rgba(59,130,246,.04); }
.ditem-a { border-left: 3px solid var(--amber);  background: rgba(245,158,11,.04); }

/* En modo validación — override con estado */
.ditem.approved { border-left: 3px solid var(--green) !important; background: rgba(34,197,94,.08) !important; }
.ditem.rejected { opacity: .3; }
.ditem.editing  { border-color: var(--teal) !important; background: var(--teal-d) !important; }

/* ── 27. ESTRATEGIA — ESCALA DE FUENTE ────────────────────── */
/* Equiparar tamaños al resto de la aplicación (base 13px) */
.ditem-txt   { font-size: 13px; }
.ditem-qual  { font-size: 11px; }
.dtitle      { font-size: 14px; }
.dsub        { font-size: 11px; }
.slbl        { font-size: 11px; }
.tb          { font-size: 13px; }
.fn          { font-size: 12px; }
.frat        { font-size: 12px; }
.fpend       { font-size: 12px; }
.fsc         { font-size: 22px; }
.cnm         { font-size: 13px; }
.clc         { font-size: 11px; }
.cdsc        { font-size: 12px; }
.cthr        { font-size: 11px; }
.chip        { font-size: 11px; }
.rt          { font-size: 14px; }
.rtx         { font-size: 13px; }
.add-btn     { font-size: 12px; }
.sbadge      { font-size: 12px; }
.src         { font-size: 12px; }
.fase-step   { font-size: 13px; }
.vs-msg      { font-size: 13px; }
.vs-val      { font-size: 22px; }

/* ── 28. COMPETIDORES — ESCALA DE FUENTE ──────────────────── */
.cc .cnm   { font-size: 14px; }
.cc .clc   { font-size: 12px; }
.cc .cdsc  { font-size: 13px; }
.cc .cthr  { font-size: 12px; }
.cc .chip  { font-size: 12px; }
.cc .cbl   { font-size: 12px; }
.cc .cbv   { font-size: 12px; }
