/* ============================================================
   main3.css — App del Evaluador (v3) · ENCCRV / CONAF
   Tema grayscale: SOLO var(--token) de tokens.css. Cero hex hardcodeado.
   Sin librerías externas.
   ============================================================ */

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-family);
  background: var(--color-bg);
  color: var(--color-text-primary);
  font-size: var(--font-size-md);
  line-height: 1.5;
}
a { color: inherit; }

/* ---------- NAVBAR ---------- */
.ev-nav {
  position: sticky; top: 0; z-index: 20;
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
}
.ev-nav-inner {
  max-width: 1480px; margin: 0 auto;
  padding: var(--space-3) var(--space-6);
  display: flex; align-items: center; gap: var(--space-6);
}
.ev-nav-brand { display: flex; align-items: center; gap: var(--space-3); cursor: pointer; }
.ev-nav-logo {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px; border-radius: var(--radius-md);
  background: var(--color-institutional); color: var(--color-institutional-text);
}
.ev-nav-brand-text { display: flex; flex-direction: column; line-height: 1.2; }
.ev-nav-kicker {
  font-size: var(--font-size-xs); font-weight: 700; letter-spacing: .05em;
  text-transform: uppercase; color: var(--color-text-muted);
}
.ev-nav-title { font-size: var(--font-size-sm); font-weight: 700; color: var(--color-text-primary); }
.ev-nav-tabs { display: flex; gap: var(--space-2); }
.ev-nav-tab {
  background: none; border: none; cursor: pointer; font-family: var(--font-family);
  padding: var(--space-2) var(--space-3); border-radius: var(--radius-md);
  font-size: var(--font-size-sm); font-weight: 600; color: var(--color-text-secondary);
}
.ev-nav-tab:hover { background: var(--color-surface-alt); }
.ev-nav-tab.is-active { background: var(--color-action); color: var(--color-action-text); }
.ev-nav-user { display: flex; align-items: center; gap: var(--space-3); margin-left: auto; }
.ev-nav-user-meta { display: flex; flex-direction: column; align-items: flex-end; line-height: 1.25; }
.ev-nav-user-name { font-size: var(--font-size-sm); font-weight: 700; }
.ev-nav-user-role { font-size: var(--font-size-xs); color: var(--color-text-muted); }
.ev-nav-avatar {
  width: 34px; height: 34px; border-radius: 50%;
  background: var(--color-surface-alt); color: var(--color-text-secondary);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: var(--font-size-xs); font-weight: 700;
}
.ev-nav-logout {
  background: none; border: 1px solid var(--color-border); cursor: pointer;
  width: 34px; height: 34px; border-radius: var(--radius-md);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--color-text-secondary);
}
.ev-nav-logout:hover { background: var(--color-surface-alt); }

/* ---------- LAYOUT ---------- */
.ev-app { min-height: calc(100vh - 62px); }
.ev-page { max-width: 1480px; margin: 0 auto; padding: var(--space-6); }
.ev-h1 { margin: var(--space-2) 0 var(--space-1); font-size: var(--font-size-xl); font-weight: 700; }
.ev-lead { margin: 0; font-size: var(--font-size-sm); color: var(--color-text-muted); max-width: 760px; }
.ev-page-head { display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-4); margin-bottom: var(--space-5); }

/* ---------- BREADCRUMBS ---------- */
.ev-crumbs { display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-4); font-size: var(--font-size-sm); }
.ev-crumb { color: var(--color-text-secondary); cursor: pointer; }
.ev-crumb:hover { color: var(--color-text-primary); text-decoration: underline; }
.ev-crumb.is-current { color: var(--color-text-muted); cursor: default; }
.ev-crumb-sep { color: var(--color-text-disabled); }

/* ---------- BUTTONS ---------- */
.ev-btn {
  display: inline-flex; align-items: center; gap: var(--space-2);
  font-family: var(--font-family); font-size: var(--font-size-sm); font-weight: 600;
  padding: var(--space-2) var(--space-4); border-radius: var(--radius-md);
  border: 1px solid transparent; cursor: pointer; white-space: nowrap;
}
.ev-btn--sm { padding: var(--space-1) var(--space-3); font-size: var(--font-size-xs); }
.ev-btn--primary { background: var(--color-action); color: var(--color-action-text); }
.ev-btn--primary:hover { background: var(--color-action-hover); }
.ev-btn--primary:disabled { background: var(--color-step-pending); color: var(--color-text-disabled); cursor: not-allowed; }
.ev-btn--ghost { background: var(--color-surface); color: var(--color-action-ghost-text); border-color: var(--color-action-ghost-border); }
.ev-btn--ghost:hover { background: var(--color-surface-alt); }
.ev-link { color: var(--color-text-secondary); font-size: var(--font-size-sm); cursor: pointer; }
.ev-link:hover { text-decoration: underline; }
.ev-iconbtn {
  background: var(--color-surface); border: 1px solid var(--color-border); cursor: pointer;
  width: 30px; height: 30px; border-radius: var(--radius-sm);
  display: inline-flex; align-items: center; justify-content: center; color: var(--color-text-secondary);
}
.ev-iconbtn:hover { background: var(--color-surface-alt); }

/* ---------- FILTERS ---------- */
.ev-filters {
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); padding: var(--space-4);
  display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-3);
  margin-bottom: var(--space-4); box-shadow: var(--shadow-card);
}
.ev-fld { display: flex; flex-direction: column; gap: var(--space-1); }
.ev-fld > span { font-size: var(--font-size-xs); font-weight: 600; color: var(--color-text-secondary); }
.ev-fld--block { margin-bottom: var(--space-4); }
.ev-input {
  width: 100%; font-family: var(--font-family); font-size: var(--font-size-sm);
  padding: var(--space-2) var(--space-3); border: 1px solid var(--color-border);
  border-radius: var(--radius-md); background: var(--color-surface); color: var(--color-text-primary);
}
.ev-input:focus { outline: none; border-color: var(--color-border-focus); box-shadow: 0 0 0 1px var(--color-border-focus); }
.ev-input--ro { background: var(--color-surface-alt); color: var(--color-text-secondary); font-weight: 600; cursor: not-allowed; }
.ev-input--sm { padding: var(--space-1) var(--space-2); font-size: var(--font-size-xs); }
.ev-textarea { min-height: 70px; resize: vertical; }
.ev-filters-actions {
  grid-column: 1 / -1; display: flex; align-items: center; justify-content: flex-end; gap: var(--space-4);
  border-top: 1px solid var(--color-border); padding-top: var(--space-3);
}
.ev-result-meta { font-size: var(--font-size-sm); color: var(--color-text-secondary); margin-bottom: var(--space-3); }
.ev-result-meta strong { color: var(--color-text-primary); }

/* ---------- FILTROS (barra dinámica) ---------- */
.ev-filterbar {
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); padding: var(--space-4); margin-bottom: var(--space-4);
  box-shadow: var(--shadow-card); display: flex; flex-direction: column; gap: var(--space-3);
}
.ev-filterbar-context { display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap; }
.ev-region-chip {
  display: inline-flex; align-items: center; gap: 6px; font-size: var(--font-size-sm);
  background: var(--color-surface-alt); border: 1px solid var(--color-border);
  border-radius: var(--radius-md); padding: var(--space-1) var(--space-3); color: var(--color-text-secondary);
}
.ev-region-chip strong { color: var(--color-text-primary); }
.ev-region-note { font-size: var(--font-size-xs); color: var(--color-text-muted); }
.ev-filter-row { display: flex; align-items: flex-end; gap: var(--space-3); flex-wrap: wrap; }
.ev-filter-adv { border-top: 1px dashed var(--color-border); padding-top: var(--space-3); }
.ev-fld--grow { flex: 1 1 280px; min-width: 220px; }
.ev-fld--med  { flex: 0 0 200px; }
.ev-fld--year { flex: 0 0 96px; width: 96px; }
.ev-filters-toggle { display: inline-flex; align-items: center; gap: 4px; white-space: nowrap; padding-bottom: 8px; user-select: none; font-weight: 600; }
.ev-filters-toggle svg { transition: transform .15s ease; }
.ev-filters-toggle.is-open svg { transform: rotate(180deg); }
.ev-filter-foot { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); border-top: 1px solid var(--color-border); padding-top: var(--space-3); flex-wrap: wrap; }
.ev-chips { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; }
.ev-chips-label { font-size: var(--font-size-xs); color: var(--color-text-muted); margin-right: 2px; }
.ev-chip-filter {
  display: inline-flex; align-items: center; gap: 6px; font-size: var(--font-size-xs); font-weight: 600;
  background: var(--color-surface-alt); border: 1px solid var(--color-border); border-radius: 999px;
  padding: 2px 4px 2px 10px; color: var(--color-text-secondary);
}
.ev-chip-filter button {
  border: none; background: var(--color-border); color: var(--color-text-secondary);
  width: 16px; height: 16px; border-radius: 50%; cursor: pointer; font-size: 12px; line-height: 1;
  display: inline-flex; align-items: center; justify-content: center; padding: 0;
}
.ev-chip-filter button:hover { background: var(--color-text-muted); color: var(--color-text-inverse); }

/* ---------- Avance / progreso en tabla ---------- */
.ev-progress { display: flex; align-items: center; gap: var(--space-2); min-width: 110px; }
.ev-progress-track { flex: 1; height: 7px; background: var(--color-step-pending); border-radius: 999px; overflow: hidden; min-width: 56px; }
.ev-progress-fill { height: 100%; background: var(--color-text-primary); border-radius: 999px; }
.ev-progress-pct { font-size: var(--font-size-xs); font-weight: 700; color: var(--color-text-secondary); min-width: 30px; text-align: right; }
.ev-medidas { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.ev-link--xs { font-size: var(--font-size-xs); }

/* ---------- TABLE ---------- */
.ev-table-wrap { overflow-x: auto; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); box-shadow: var(--shadow-card); }
.ev-table { width: 100%; border-collapse: collapse; font-size: var(--font-size-sm); }
.ev-table thead th {
  text-align: left; font-size: var(--font-size-xs); font-weight: 700; text-transform: uppercase; letter-spacing: .02em;
  color: var(--color-text-muted); padding: var(--space-3) var(--space-3);
  border-bottom: 1px solid var(--color-border); background: var(--color-surface-alt); white-space: nowrap;
}
.ev-table tbody td { padding: var(--space-3); border-bottom: 1px solid var(--color-border); vertical-align: top; }
.ev-table tbody tr:last-child td { border-bottom: none; }
.ev-table tbody tr:hover { background: var(--color-surface-alt); }
.ev-td-num { color: var(--color-text-muted); font-weight: 700; }
.ev-td-actions { white-space: nowrap; display: flex; gap: var(--space-2); align-items: center; }
.ev-code { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: var(--font-size-xs); font-weight: 600; }
.ev-cell-strong { font-weight: 600; color: var(--color-text-primary); }
.ev-cell-soft { font-size: var(--font-size-xs); color: var(--color-text-muted); }
.ev-empty { text-align: center; color: var(--color-text-muted); padding: var(--space-8); }
.ev-table--inner { box-shadow: none; border: 1px solid var(--color-border); border-radius: var(--radius-md); }
.ev-table--inner thead th { background: var(--color-surface-alt); }

/* chips & badges */
.ev-chip {
  display: inline-block; font-size: var(--font-size-xs); font-weight: 700;
  padding: 1px var(--space-2); border-radius: var(--radius-sm);
  background: var(--color-surface-alt); color: var(--color-text-secondary); border: 1px solid var(--color-border);
}
.ev-badge {
  display: inline-block; font-size: var(--font-size-xs); font-weight: 700;
  padding: 2px var(--space-2); border-radius: 999px;
}
.ev-badge--soft { background: var(--color-surface-alt); color: var(--color-text-muted); }
.ev-badge--info { background: var(--color-info-bg); color: var(--color-info); }
.ev-badge--done { background: var(--color-success-bg); color: var(--color-success); }
.ev-badge--warn { background: var(--color-warning-bg); color: var(--color-warning); }
.ev-assign { font-size: var(--font-size-xs); font-weight: 600; }
.ev-assign--on { color: var(--color-success); }
.ev-assign--off { color: var(--color-text-muted); }
.ev-pill { display: inline-block; font-size: var(--font-size-xs); font-weight: 700; padding: 2px var(--space-2); border-radius: var(--radius-sm); border: 1px dashed var(--color-border); color: var(--color-text-secondary); }

/* ---------- CARDS ---------- */
.ev-card { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-5); box-shadow: var(--shadow-card); }
.ev-card-title { margin: 0 0 var(--space-1); font-size: var(--font-size-sm); font-weight: 700; text-transform: uppercase; letter-spacing: .03em; color: var(--color-text-secondary); }
.ev-card-sub { margin: 0 0 var(--space-4); font-size: var(--font-size-sm); color: var(--color-text-muted); }
.ev-card-row { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); margin-bottom: var(--space-3); }
.ev-mini-title { margin: var(--space-4) 0 var(--space-2); font-size: var(--font-size-sm); font-weight: 700; color: var(--color-text-primary); }
.ev-note { margin-top: var(--space-3); font-size: var(--font-size-xs); color: var(--color-text-muted); background: var(--color-warning-bg); border-left: 3px solid var(--color-warning); padding: var(--space-2) var(--space-3); border-radius: var(--radius-sm); }
.ev-grid3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-3); margin-bottom: var(--space-4); }

/* ---------- DETAIL ---------- */
.ev-detail-head { display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-4); margin-bottom: var(--space-5); }
.ev-detail-actions { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.ev-detail-grid { display: grid; grid-template-columns: 1fr 320px; gap: var(--space-5); align-items: start; }
.ev-tabs { display: flex; gap: var(--space-1); margin-bottom: var(--space-3); }
.ev-tab { background: none; border: 1px solid transparent; border-bottom: 2px solid transparent; cursor: pointer; font-family: var(--font-family); font-size: var(--font-size-sm); font-weight: 600; color: var(--color-text-muted); padding: var(--space-2) var(--space-3); }
.ev-tab.is-active { color: var(--color-text-primary); border-bottom-color: var(--color-action); }
.ev-dl { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3); margin: 0; }
.ev-dl-row { display: flex; flex-direction: column; gap: 1px; }
.ev-dl-row dt { font-size: var(--font-size-xs); font-weight: 700; text-transform: uppercase; letter-spacing: .02em; color: var(--color-text-muted); }
.ev-dl-row dd { margin: 0; font-size: var(--font-size-sm); color: var(--color-text-primary); }
.ev-predios { margin-top: var(--space-4); border-top: 1px solid var(--color-border); padding-top: var(--space-3); }
.ev-predio { background: var(--color-surface-alt); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-3); margin-bottom: var(--space-2); font-size: var(--font-size-sm); }
.ev-predio-areas { margin: var(--space-2) 0 0; padding-left: var(--space-4); display: flex; flex-direction: column; gap: 2px; }

/* ---------- TIMELINE ---------- */
.ev-timeline-card { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-5); box-shadow: var(--shadow-sidebar); position: sticky; top: 78px; }
.ev-side-title { margin: 0 0 var(--space-4); font-size: var(--font-size-sm); font-weight: 700; text-transform: uppercase; letter-spacing: .03em; color: var(--color-text-secondary); }
.ev-timeline { list-style: none; margin: 0; padding: 0; }
.ev-tl-item { position: relative; padding: 0 0 var(--space-4) var(--space-5); border-left: 2px solid var(--color-border); }
.ev-tl-item:last-child { border-left-color: transparent; padding-bottom: 0; }
.ev-tl-dot { position: absolute; left: -7px; top: 2px; width: 12px; height: 12px; border-radius: 50%; background: var(--color-step-pending); border: 2px solid var(--color-surface); }
.ev-tl-item--done .ev-tl-dot { background: var(--color-step-done); }
.ev-tl-body { display: flex; flex-direction: column; gap: 1px; }
.ev-tl-date { font-size: var(--font-size-xs); font-weight: 700; color: var(--color-text-muted); }
.ev-tl-title { font-size: var(--font-size-sm); font-weight: 700; color: var(--color-text-primary); }
.ev-tl-detail { font-size: var(--font-size-xs); color: var(--color-text-muted); }
.ev-tl-item--pending .ev-tl-title { color: var(--color-text-muted); }

/* ---------- MODALS ---------- */
.ev-modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.45); /* scrim: sin token de overlay en el DS; alineado a la convención rgba de --shadow-* */ display: flex; align-items: center; justify-content: center; padding: var(--space-5); z-index: 50; }
.ev-modal { background: var(--color-surface); border-radius: var(--radius-lg); padding: var(--space-6); max-width: 460px; width: 100%; box-shadow: var(--shadow-card); }
.ev-modal--wide { max-width: 640px; }
.ev-modal-icon { width: 44px; height: 44px; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin-bottom: var(--space-3); }
.ev-modal-icon--warn { background: var(--color-warning-bg); color: var(--color-warning); }
.ev-modal-title { margin: 0 0 var(--space-2); font-size: var(--font-size-lg); font-weight: 700; }
.ev-modal-body { font-size: var(--font-size-sm); color: var(--color-text-secondary); line-height: 1.6; }
.ev-modal-actions { display: flex; justify-content: flex-end; gap: var(--space-2); margin-top: var(--space-5); }
.ev-modal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-3); }
.ev-modal-close { background: none; border: none; cursor: pointer; color: var(--color-text-muted); padding: var(--space-1); }

/* ---------- EDICIÓN ---------- */
.ev-edit-grid { display: grid; grid-template-columns: 300px 1fr; gap: var(--space-5); align-items: start; }
.ev-control { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-4); box-shadow: var(--shadow-sidebar); position: sticky; top: 78px; }
.ev-ctrl-head { padding-bottom: var(--space-3); border-bottom: 1px solid var(--color-border); margin-bottom: var(--space-3); }
.ev-ctrl-kicker { font-size: var(--font-size-xs); font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--color-text-muted); }
.ev-ctrl-h2 { margin: 2px 0 0; font-size: var(--font-size-md); font-weight: 700; }
.ev-ctrl-blk { padding: var(--space-3) 0; border-bottom: 1px solid var(--color-border); }
.ev-ctrl-blk:last-child { border-bottom: none; }
.ev-ctrl-title { margin: 0 0 var(--space-2); font-size: var(--font-size-xs); font-weight: 700; text-transform: uppercase; letter-spacing: .02em; color: var(--color-text-muted); }
.ev-ctrl-row { display: flex; justify-content: space-between; gap: var(--space-3); font-size: var(--font-size-xs); padding: 2px 0; }
.ev-ctrl-row > span { color: var(--color-text-muted); flex: none; }
.ev-ctrl-row > strong { color: var(--color-text-primary); text-align: right; font-weight: 600; }
.ev-ctrl-howto { margin-top: var(--space-2); }
.ev-ctrl-howto > span { font-size: var(--font-size-xs); font-weight: 700; color: var(--color-text-muted); }
.ev-ctrl-howto p { margin: 2px 0 0; font-size: var(--font-size-xs); color: var(--color-text-secondary); }
.ev-dl-btn { display: block; width: 100%; text-align: left; background: var(--color-surface-alt); border: 1px solid var(--color-border); border-radius: var(--radius-sm); padding: var(--space-2) var(--space-3); margin-bottom: var(--space-2); font-family: var(--font-family); font-size: var(--font-size-xs); font-weight: 600; color: var(--color-text-secondary); cursor: pointer; }
.ev-dl-btn:hover { background: var(--color-surface); }

.ev-edit-main { display: flex; flex-direction: column; gap: var(--space-4); min-width: 0; }

/* warn banner */
.ev-warn { display: flex; gap: var(--space-3); background: var(--color-warning-bg); border: 1px solid var(--color-border); border-left: 3px solid var(--color-warning); border-radius: var(--radius-md); padding: var(--space-4); }
.ev-warn--soft { background: var(--color-surface-alt); }
.ev-warn-icon { flex: none; color: var(--color-warning); font-weight: 700; }
.ev-warn-list { margin: var(--space-2) 0 0; padding-left: var(--space-4); font-size: var(--font-size-sm); color: var(--color-text-secondary); }
.ev-warn strong { font-size: var(--font-size-sm); }

/* stepper */
.ev-stepper { display: flex; align-items: center; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-3) var(--space-4); box-shadow: var(--shadow-card); }
.ev-step { display: flex; align-items: center; gap: var(--space-2); flex: none; }
.ev-step-num { width: 22px; height: 22px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-size: var(--font-size-xs); font-weight: 700; flex: none; }
.ev-step--done .ev-step-num { background: var(--color-step-done); color: var(--color-step-text-done); }
.ev-step--active .ev-step-num { background: var(--color-step-active); color: var(--color-step-text-active); }
.ev-step--pending .ev-step-num { background: var(--color-step-pending); color: var(--color-step-text-pending); }
.ev-step-txt { display: flex; flex-direction: column; line-height: 1.2; }
.ev-step-txt b { font-size: var(--font-size-xs); font-weight: 700; color: var(--color-text-primary); }
.ev-step-txt i { font-size: var(--font-size-xs); font-style: normal; color: var(--color-text-muted); }
.ev-step--pending .ev-step-txt b { color: var(--color-text-muted); }
.ev-step-line { flex: 1 1 auto; height: 1px; background: var(--color-border); margin: 0 var(--space-2); min-width: 12px; }

.ev-edit-foot { display: flex; align-items: center; justify-content: space-between; }

/* actividades / variables */
.ev-act-predio { margin-bottom: var(--space-4); }
.ev-var { border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-4); margin-bottom: var(--space-3); }
.ev-var-head { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); flex-wrap: wrap; }
.ev-formula { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: var(--font-size-xs); background: var(--color-surface-alt); padding: 2px var(--space-2); border-radius: var(--radius-sm); color: var(--color-text-secondary); }

/* callouts & checks */
.ev-callout { border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-4); margin-top: var(--space-3); font-size: var(--font-size-sm); color: var(--color-text-secondary); }
.ev-callout--info { background: var(--color-info-bg); }
.ev-delta-list { margin: var(--space-2) 0 0; padding-left: var(--space-4); font-size: var(--font-size-sm); color: var(--color-text-primary); }
.ev-delta-list li { margin-bottom: 2px; }
.ev-delta-list span { color: var(--color-text-muted); }
/* ---------- Actividades y costos (wizard) ---------- */
.ev-act-table th { text-align: center; }
.ev-act-table td { vertical-align: middle; }
.ev-act-table td:first-child { text-align: left; }
.ev-act-cat td { background: var(--color-surface-alt); font-weight: 700; font-size: var(--font-size-xs); text-transform: uppercase; letter-spacing: .02em; color: var(--color-text-secondary); }
.ev-act-qty { max-width: 78px; text-align: right; margin: 0 auto; }
.ev-act-mon { font-size: var(--font-size-xs); color: var(--color-text-secondary); white-space: nowrap; }
/* Barra de presupuesto sticky (siempre visible al hacer scroll) */
.ev-budgetbar {
  position: sticky; bottom: var(--space-3); z-index: 20; margin-top: var(--space-5);
  display: flex; align-items: center; gap: var(--space-5); flex-wrap: wrap;
  background: var(--color-surface); border: 1px solid var(--color-border); border-left: 4px solid var(--color-text-primary);
  border-radius: var(--radius-lg); padding: var(--space-3) var(--space-4);
  box-shadow: 0 6px 20px rgba(0,0,0,.12);
}
.ev-budgetbar.is-over { border-left-color: var(--color-error); }
.ev-bb-saldo { display: flex; flex-direction: column; gap: 1px; flex: 0 0 auto; }
.ev-bb-lbl { font-size: var(--font-size-xs); font-weight: 700; text-transform: uppercase; letter-spacing: .02em; color: var(--color-text-muted); }
.ev-bb-saldo-val { font-size: var(--font-size-xl); font-weight: 800; color: var(--color-text-primary); line-height: 1.1; }
.ev-bb-saldo-val.is-neg { color: var(--color-error); }
.ev-bb-pct { font-size: var(--font-size-xs); color: var(--color-text-muted); }
.ev-bb-progresswrap { flex: 1 1 340px; min-width: 280px; display: flex; flex-direction: column; gap: var(--space-2); }
.ev-bb-track { height: 10px; background: var(--color-step-pending); border-radius: 999px; overflow: hidden; }
.ev-bb-fill { height: 100%; background: var(--color-text-primary); border-radius: 999px; transition: width .15s ease; }
.ev-budgetbar.is-over .ev-bb-fill { background: var(--color-error); }
.ev-bb-figs { display: flex; gap: var(--space-5); flex-wrap: wrap; }
.ev-bb-fig { display: flex; flex-direction: column; }
.ev-bb-fig span { font-size: var(--font-size-xs); color: var(--color-text-muted); }
.ev-bb-fig strong { font-size: var(--font-size-sm); color: var(--color-text-primary); }

/* ---------- Criterios de exclusión / consentimiento ---------- */
.ev-criterios { display: grid; gap: var(--space-3); margin: 0 0 var(--space-4); }
.ev-criterio dt { font-size: var(--font-size-sm); font-weight: 700; color: var(--color-text-primary); }
.ev-criterio dd { margin: 2px 0 0; font-size: var(--font-size-sm); color: var(--color-text-secondary); line-height: 1.5; }
.ev-consent { border-top: 1px solid var(--color-border); padding-top: var(--space-4); }

.ev-comision-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-5); align-items: start; margin-top: var(--space-4); }
.ev-concl-text { margin: 0; font-size: var(--font-size-sm); color: var(--color-text-secondary); line-height: 1.6; }
@media (max-width: 880px) { .ev-comision-grid { grid-template-columns: 1fr; } }
.ev-check { display: flex; gap: var(--space-2); align-items: flex-start; font-size: var(--font-size-sm); color: var(--color-text-secondary); margin-top: var(--space-2); cursor: pointer; }
.ev-check input { margin-top: 3px; flex: none; }
.ev-check--block { border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-3); background: var(--color-surface); }
.ev-check-hint { display: block; font-style: normal; font-size: var(--font-size-xs); color: var(--color-text-muted); margin-top: 2px; }
.ev-checks { display: flex; flex-direction: column; gap: var(--space-3); margin-top: var(--space-4); }

/* matriz / conclusion */
.ev-table--matrix td { font-size: var(--font-size-xs); }
.ev-concl { margin-top: var(--space-5); padding-top: var(--space-4); border-top: 1px solid var(--color-border); }
.ev-radio-row { display: flex; gap: var(--space-4); margin: var(--space-3) 0 var(--space-3); }
.ev-radio { display: flex; align-items: center; gap: var(--space-2); font-size: var(--font-size-sm); cursor: pointer; }

/* ---------- FACTIBILIDAD · SALVAGUARDAS (smart checklist) ---------- */
.ev-modal-body p { margin: 0 0 var(--space-3); }
.ev-modal-body p:last-child { margin-bottom: 0; }

/* selector de criterios de exclusión MGAS */
.ev-fac-exclusion { display: flex; align-items: center; gap: var(--space-4); }
.ev-fac-exclusion-txt { flex: 1; }
.ev-fac-exclusion-sel { flex: 0 0 96px; }

.ev-fac-sec { margin-top: var(--space-5); }

/* tarjeta de riesgo */
.ev-risk { border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-4); margin-bottom: var(--space-3); background: var(--color-surface); }
.ev-risk.is-alta { border-color: var(--color-text-secondary); box-shadow: inset 3px 0 0 var(--color-text-primary); }
.ev-risk-head { display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-4); }
.ev-risk-info { flex: 1; min-width: 0; }
.ev-risk-title { display: flex; align-items: center; gap: var(--space-2); font-size: var(--font-size-md); font-weight: 700; color: var(--color-text-primary); }
.ev-risk-desc { margin: var(--space-1) 0 0; font-size: var(--font-size-sm); color: var(--color-text-secondary); line-height: 1.5; }
.ev-risk-triggers { display: flex; flex-wrap: wrap; gap: 6px; margin-top: var(--space-2); }
.ev-chip--trigger { background: var(--color-surface-alt); color: var(--color-text-secondary); }
.ev-risk-sel { flex: 0 0 150px; }
.ev-risk-sel > span { font-size: var(--font-size-xs); font-weight: 600; color: var(--color-text-secondary); }

/* checklist de mitigaciones (nivel Alto) */
.ev-risk-mit { margin-top: var(--space-3); padding-top: var(--space-3); border-top: 1px dashed var(--color-border); }
.ev-risk-mit-head { font-size: var(--font-size-sm); font-weight: 700; color: var(--color-text-primary); margin-bottom: var(--space-1); }
.ev-risk-mit-head em { font-weight: 400; font-style: normal; color: var(--color-text-muted); }
.ev-mit { margin-top: var(--space-2); }
.ev-mit-otro { margin-top: var(--space-2); min-height: 56px; }

/* panel social (pueblos originarios) */
.ev-social { border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-4); background: var(--color-surface-alt); }
.ev-social .ev-mini-title { margin-top: 0; display: flex; align-items: center; gap: var(--space-2); }

/* otros ámbitos (colapsable) */
.ev-fac-otros { margin-top: var(--space-5); border-top: 1px solid var(--color-border); padding-top: var(--space-4); }
.ev-fac-otros > summary { font-size: var(--font-size-sm); font-weight: 700; color: var(--color-text-secondary); cursor: pointer; }
.ev-fac-otros[open] > summary { margin-bottom: var(--space-3); }

/* conformidad de la persona titular */
.ev-fac-titular { display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-4); margin-top: var(--space-4); padding-top: var(--space-4); border-top: 1px solid var(--color-border); }
.ev-fld-lbl { flex: 1; font-size: var(--font-size-sm); color: var(--color-text-secondary); line-height: 1.5; }
.ev-fac-titular select { flex: 0 0 120px; }

/* comparativo & upload */
.ev-table--cmp td:nth-child(4) { background: var(--color-surface-alt); }
.ev-upload { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); border: 1px dashed var(--color-border); border-radius: var(--radius-md); padding: var(--space-3); font-size: var(--font-size-sm); }
.ev-upload-btn { background: var(--color-action); color: var(--color-action-text); padding: var(--space-2) var(--space-3); border-radius: var(--radius-md); font-size: var(--font-size-xs); font-weight: 600; cursor: pointer; }

/* ---------- RESULTADO ---------- */
.ev-result-head { display: flex; align-items: stretch; justify-content: space-between; gap: var(--space-4); margin-bottom: var(--space-5); }
.ev-score-final { flex: none; min-width: 220px; text-align: center; border-radius: var(--radius-lg); padding: var(--space-4) var(--space-5); display: flex; flex-direction: column; gap: 2px; border: 1px solid var(--color-border); }
.ev-score-final.is-ok { background: var(--color-success-bg); }
.ev-score-final.is-no { background: var(--color-error-bg); }
.ev-score-label { font-size: var(--font-size-xs); font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--color-text-muted); }
.ev-score-num { font-size: 40px; font-weight: 800; line-height: 1; color: var(--color-text-primary); }
.ev-exc { font-size: var(--font-size-xs); font-weight: 700; color: var(--color-text-secondary); }
.ev-score-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--space-3); margin-bottom: var(--space-5); }
.ev-score-card { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-4); text-align: center; display: flex; flex-direction: column; gap: 2px; box-shadow: var(--shadow-card); }
.ev-score-k { font-size: var(--font-size-xs); font-weight: 700; color: var(--color-text-muted); }
.ev-score-v { font-size: var(--font-size-xl); font-weight: 800; color: var(--color-text-primary); }
.ev-score-w { font-size: var(--font-size-xs); color: var(--color-text-muted); }
.ev-result-grid { display: grid; grid-template-columns: 1fr 320px; gap: var(--space-5); align-items: start; }
.ev-tr-total td { font-weight: 700; background: var(--color-surface-alt); }
.ev-result-grid + .ev-card, .ev-card + .ev-card { margin-top: var(--space-5); }
.ev-result-actions { display: flex; gap: var(--space-2); margin-top: var(--space-5); }

/* fórmulas */
.ev-fx { border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-3); margin-bottom: var(--space-2); display: flex; flex-direction: column; gap: var(--space-1); }
.ev-fx--total { background: var(--color-surface-alt); }
.ev-fx-1 { font-size: var(--font-size-xs); color: var(--color-text-muted); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
.ev-fx-2 { font-size: var(--font-size-sm); color: var(--color-text-primary); font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }

/* ---------- RESPONSIVE ---------- */
@media (max-width: 1040px) {
  .ev-detail-grid, .ev-edit-grid, .ev-result-grid { grid-template-columns: 1fr; }
  .ev-control, .ev-timeline-card { position: static; }
  .ev-filters { grid-template-columns: repeat(2, 1fr); }
  .ev-score-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 720px) {
  .ev-nav-tabs { display: none; }
  .ev-page-head, .ev-detail-head, .ev-result-head { flex-direction: column; }
  .ev-grid3, .ev-filters { grid-template-columns: 1fr; }
  .ev-stepper { overflow-x: auto; }
  .ev-risk-head, .ev-fac-exclusion, .ev-fac-titular { flex-direction: column; align-items: stretch; gap: var(--space-3); }
  .ev-risk-sel, .ev-fac-exclusion-sel, .ev-fac-titular select { flex: none; width: 100%; }
}
