
/* ═══════════════════════ DESIGN TOKENS ═══════════════════════ */
:root{
  /* Brand */
  --brand-50:#ECFDF5; --brand-100:#D1FAE5; --brand-200:#A7F3D0; --brand-300:#6EE7B7;
  --brand-400:#34D399; --brand-500:#10B981; --brand-600:#059669; --brand-700:#047857;
  --brand-800:#065F46; --brand-900:#064E3B; --brand-950:#022C22;

  /* Accent (warm) */
  --accent-50:#FFF7ED; --accent-100:#FFEDD5; --accent-300:#FDBA74;
  --accent-400:#FB923C; --accent-500:#F97316; --accent-600:#EA580C;

  /* Neutrals (slate-zinc hybrid) */
  --n-0:#FFFFFF;
  --n-25:#FCFCFD;
  --n-50:#F9FAFB;
  --n-100:#F3F4F6;
  --n-150:#EBECEF;
  --n-200:#E5E7EB;
  --n-300:#D1D5DB;
  --n-400:#9CA3AF;
  --n-500:#6B7280;
  --n-600:#4B5563;
  --n-700:#374151;
  --n-800:#1F2937;
  --n-900:#111827;
  --n-950:#0A0F1A;

  /* Semantic */
  --red-50:#FEF2F2; --red-100:#FEE2E2; --red-500:#EF4444; --red-600:#DC2626; --red-700:#B91C1C;
  --amber-50:#FFFBEB; --amber-100:#FEF3C7; --amber-500:#F59E0B; --amber-600:#D97706; --amber-700:#B45309;
  --green-50:#F0FDF4; --green-500:#22C55E; --green-600:#16A34A; --green-700:#15803D;
  --blue-50:#EFF6FF; --blue-100:#DBEAFE; --blue-500:#3B82F6; --blue-600:#2563EB; --blue-700:#1D4ED8;
  --purple-50:#FAF5FF; --purple-500:#A855F7; --purple-600:#9333EA;
  --pink-500:#EC4899;

  /* Surfaces */
  --surface:#FFFFFF;
  --surface-2:#FAFBFC;
  --surface-3:#F4F5F7;
  --bg:#F7F8FA;
  --border:#E8EAED;
  --border-strong:#D8DBE0;

  /* Effects */
  --shadow-xs:0 1px 2px rgba(15,23,42,.04);
  --shadow-sm:0 1px 3px rgba(15,23,42,.05),0 1px 2px rgba(15,23,42,.03);
  --shadow-md:0 4px 6px -1px rgba(15,23,42,.06),0 2px 4px -2px rgba(15,23,42,.04);
  --shadow-lg:0 10px 25px -5px rgba(15,23,42,.08),0 8px 10px -6px rgba(15,23,42,.04);
  --shadow-xl:0 25px 50px -12px rgba(15,23,42,.18);
  --ring:0 0 0 3px rgba(16,185,129,.18);

  /* Radii */
  --r-sm:6px; --r-md:8px; --r-lg:10px; --r-xl:12px; --r-2xl:16px; --r-3xl:20px;

  /* Typography */
  --font-sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,'SF Mono',monospace;
}

*{box-sizing:border-box;margin:0;padding:0}
*:focus{outline:none}
html{font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}
body{font-family:var(--font-sans);background:var(--bg);color:var(--n-900);min-height:100vh;font-feature-settings:'cv02','cv03','cv04','cv11';letter-spacing:-.005em}

/* ═══════════════════════ SIDEBAR ═══════════════════════ */
.sidebar{
  position:fixed;left:0;top:0;width:248px;height:100vh;
  background:linear-gradient(180deg,#0B1220 0%,#0A0F1A 100%);
  display:flex;flex-direction:column;z-index:100;
  border-right:1px solid rgba(255,255,255,.05);
}

.brand{padding:22px 22px 18px}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-name{
  font-size:26px;font-weight:800;letter-spacing:-.035em;line-height:1;
  background:linear-gradient(135deg,#FFFFFF 0%,#A7F3D0 60%,#34D399 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 1px 12px rgba(16,185,129,.25));
}
.brand-by{
  font-size:10px;color:rgba(255,255,255,.4);font-weight:600;
  margin-top:6px;letter-spacing:.22em;text-transform:uppercase;
}
.brand-by strong{color:rgba(255,255,255,.7);font-weight:700;letter-spacing:.18em}

/* Workspace block (panel principal — bloque de identidad) */
.workspace-switch{
  margin:8px 12px 14px;padding:11px 12px;
  background:linear-gradient(135deg,rgba(16,185,129,.08) 0%,rgba(16,185,129,.025) 100%);
  border:1px solid rgba(16,185,129,.16);
  border-radius:10px;cursor:pointer;transition:all .15s;
  display:flex;align-items:center;gap:9px;position:relative;overflow:hidden;
}
.workspace-switch::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:2px;
  background:linear-gradient(180deg,#34D399 0%,#10B981 100%);
}
.workspace-switch:hover{background:linear-gradient(135deg,rgba(16,185,129,.12) 0%,rgba(16,185,129,.04) 100%);border-color:rgba(16,185,129,.26)}
.ws-info{flex:1;min-width:0}
.ws-label{font-size:9.5px;color:rgba(110,231,183,.85);font-weight:700;text-transform:uppercase;letter-spacing:.13em}
.ws-name{font-size:13px;color:#fff;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:3px;letter-spacing:-.01em}

/* Cliente header (cuando estás dentro de un cliente) */
.ws-cliente-card{
  margin:8px 12px 14px;padding:12px 14px 13px;
  background:linear-gradient(160deg,rgba(251,146,60,.13) 0%,rgba(251,146,60,.04) 60%,transparent 100%);
  border:1px solid rgba(251,146,60,.24);border-radius:11px;
  position:relative;cursor:pointer;transition:background .14s,border-color .14s;
}
.ws-cliente-card:hover{
  background:linear-gradient(160deg,rgba(251,146,60,.18) 0%,rgba(251,146,60,.06) 60%,transparent 100%);
  border-color:rgba(251,146,60,.34);
}
.ws-back-btn{
  display:inline-flex;align-items:center;gap:5px;
  font-family:var(--font-sans);font-size:10.5px;font-weight:600;
  color:rgba(251,146,60,.95);background:transparent;border:none;
  cursor:pointer;padding:0;margin-bottom:9px;letter-spacing:.02em;
  transition:color .12s;
}
.ws-back-btn:hover{color:#FED7AA}
.ws-cli-name{
  font-size:15px;font-weight:700;color:#fff;line-height:1.2;
  letter-spacing:-.015em;
}
.ws-cli-meta{
  font-size:10.5px;color:rgba(255,255,255,.55);margin-top:4px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis
}
.ws-cli-foot{
  display:flex;align-items:center;gap:6px;margin-top:9px;
  padding-top:9px;border-top:1px solid rgba(255,255,255,.07)
}
.ws-cli-tag{
  display:inline-flex;align-items:center;gap:4px;
  padding:2.5px 8px;border-radius:5px;
  background:rgba(16,185,129,.18);color:#6EE7B7;
  font-size:9.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase
}
.ws-cli-tag::before{content:'';width:5px;height:5px;border-radius:50%;background:currentColor;box-shadow:0 0 0 2px rgba(16,185,129,.18)}
.ws-cli-tag.t-puntual{background:rgba(245,158,11,.18);color:#FCD34D}
.ws-cli-tag.t-puntual::before{box-shadow:0 0 0 2px rgba(245,158,11,.18)}
.ws-cli-tag.t-evaluacion{background:rgba(59,130,246,.18);color:#93C5FD}
.ws-cli-tag.t-evaluacion::before{box-shadow:0 0 0 2px rgba(59,130,246,.18)}

/* ── Cliente nav blocks (editorial · refinado) ── */
.cli-block{
  position:relative;
  padding:16px 12px 4px;
}
.cli-block + .cli-block{
  margin-top:0;
  padding-top:18px;
}
.cli-block + .cli-block::before{
  content:'';position:absolute;top:0;left:14px;right:14px;height:1px;
  background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.07) 14%,rgba(255,255,255,.07) 86%,transparent 100%);
}

.cli-block-head{
  display:flex;align-items:center;gap:11px;
  padding:0 6px 14px;
  position:relative;
}

.cli-block-num{
  width:24px;height:24px;border-radius:7px;
  display:flex;align-items:center;justify-content:center;
  font-size:10.5px;font-weight:700;font-family:var(--font-mono);
  flex-shrink:0;letter-spacing:0;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.09);
  color:rgba(255,255,255,.7);
  position:relative;
  transition:all .2s;
}
/* Acento sutil (tiny dot) por sección — identidad sin saturación */
.cli-block-num::after{
  content:'';position:absolute;top:-2px;right:-2px;
  width:6px;height:6px;border-radius:50%;
  background:var(--block-dot,transparent);
  border:1.5px solid #0E1525;
  opacity:.85;
}
.cli-block.b1{--block-dot:#60A5FA}
.cli-block.b2{--block-dot:#FBBF24}
.cli-block.b3{--block-dot:#34D399}

.cli-block-titles{display:flex;flex-direction:column;line-height:1;min-width:0;flex:1;gap:5px}
.cli-block-label{
  font-size:10.5px;color:rgba(255,255,255,.95);
  font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  font-feature-settings:'cv01','ss01';
}
.cli-block-sub{
  font-size:10.5px;color:rgba(255,255,255,.4);
  font-weight:400;letter-spacing:.005em;
  font-feature-settings:'cv01';
}

/* Indicador "step de fase" — 3 pequeños trazos a la derecha */
.cli-block-progress{
  display:flex;gap:3px;flex-shrink:0;
  align-items:center;
}
.cli-block-progress span{
  width:14px;height:2px;border-radius:99px;
  background:rgba(255,255,255,.08);
}
.cli-block.b1 .cli-block-progress span:nth-child(1){background:rgba(255,255,255,.35)}
.cli-block.b2 .cli-block-progress span:nth-child(1),
.cli-block.b2 .cli-block-progress span:nth-child(2){background:rgba(255,255,255,.35)}
.cli-block.b3 .cli-block-progress span{background:rgba(255,255,255,.35)}

/* Items dentro de cli-block — más refinados */
.cli-block .nav-item{
  margin:1px 0;
  padding:7.5px 12px;
  font-size:13px;font-weight:500;letter-spacing:-.008em;
  border-radius:7px;
  color:rgba(255,255,255,.7);
  transition:background .12s,color .12s;
}
.cli-block .nav-item:hover{
  background:rgba(255,255,255,.045);
  color:rgba(255,255,255,.98);
}
.cli-block .nav-item.active{
  background:rgba(16,185,129,.13);
  color:#fff;font-weight:600;
}
.cli-block .nav-item.active::before{
  content:'';position:absolute;left:-12px;top:8px;bottom:8px;width:2px;
  background:linear-gradient(180deg,#34D399 0%,#10B981 100%);
  border-radius:0 2px 2px 0;
}
.cli-block .nav-item .nav-icon{
  width:16px;height:16px;flex-shrink:0;opacity:.75;
  transition:opacity .12s,color .12s;
}
.cli-block .nav-item:hover .nav-icon{opacity:.95}
.cli-block .nav-item.active .nav-icon{opacity:1;color:#34D399}

.nav-scroll{flex:1;overflow-y:auto;padding-bottom:8px}
.nav-scroll::-webkit-scrollbar{width:0}
.nav-section{padding:14px 22px 6px;font-size:10px;color:rgba(255,255,255,.35);font-weight:600;letter-spacing:.12em;text-transform:uppercase}
.nav-item{
  display:flex;align-items:center;gap:11px;
  padding:7.5px 12px;margin:1px 10px;border-radius:7px;
  cursor:pointer;color:rgba(255,255,255,.7);font-size:13px;font-weight:500;
  transition:all .12s;position:relative;letter-spacing:-.005em
}
.nav-item:hover{background:rgba(255,255,255,.05);color:#fff}
.nav-item.active{
  background:linear-gradient(90deg,rgba(16,185,129,.15) 0%,rgba(16,185,129,.06) 100%);
  color:#fff;font-weight:600;
  box-shadow:inset 0 0 0 1px rgba(16,185,129,.2)
}
.nav-item.active::before{
  content:'';position:absolute;left:-10px;top:8px;bottom:8px;width:3px;
  background:linear-gradient(180deg,#34D399,#10B981);border-radius:2px;
}
.nav-icon{width:16px;height:16px;flex-shrink:0;opacity:.85}
.nav-item.active .nav-icon{opacity:1}
.nav-badge{
  margin-left:auto;font-size:10px;font-weight:600;padding:1px 6px;border-radius:20px;
  font-family:var(--font-mono);font-feature-settings:'tnum'
}
.nb-red{background:rgba(239,68,68,.18);color:#FCA5A5}
.nb-amber{background:rgba(245,158,11,.18);color:#FCD34D}
.nb-teal{background:rgba(16,185,129,.18);color:#6EE7B7}
.nb-blue{background:rgba(59,130,246,.18);color:#93C5FD}

.sidebar-footer{
  margin-top:auto;padding:10px;border-top:1px solid rgba(255,255,255,.06);
  display:flex;align-items:center;gap:10px;
}
.user-avatar{
  width:32px;height:32px;border-radius:9px;
  background:linear-gradient(135deg,#FB923C 0%,#EA580C 100%);
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;flex-shrink:0;
  box-shadow:0 2px 6px rgba(234,88,12,.3)
}
.user-info{flex:1;min-width:0}
.user-name{font-size:12.5px;color:rgba(255,255,255,.95);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{font-size:10.5px;color:rgba(255,255,255,.45);margin-top:1px}
.user-menu{padding:6px;border-radius:7px;color:rgba(255,255,255,.4);cursor:pointer;transition:all .12s}
.user-menu:hover{background:rgba(255,255,255,.06);color:#fff}

/* ═══════════════════════ MAIN ═══════════════════════ */
.main{margin-left:248px;min-height:100vh}

/* Header global */
.appbar{display:none}  /* App bar global oculta — superficie limpia */
.appbar-search{
  flex:1;max-width:420px;position:relative;
}
.appbar-search input{
  width:100%;padding:8px 12px 8px 36px;
  background:var(--surface);border:1px solid var(--border);border-radius:9px;
  font-family:var(--font-sans);font-size:13px;color:var(--n-900);
  transition:all .15s;
}
.appbar-search input::placeholder{color:var(--n-400)}
.appbar-search input:focus{border-color:var(--brand-500);box-shadow:var(--ring)}
.appbar-search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--n-400)}
.appbar-search kbd{
  position:absolute;right:9px;top:50%;transform:translateY(-50%);
  font-family:var(--font-mono);font-size:10.5px;color:var(--n-500);
  background:var(--n-100);padding:2px 6px;border-radius:5px;border:1px solid var(--border);
}
.appbar-actions{display:flex;align-items:center;gap:6px}
.icon-btn{
  width:34px;height:34px;border-radius:8px;
  background:transparent;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;color:var(--n-600);
  transition:all .12s;position:relative;
}
.icon-btn:hover{background:var(--n-100);color:var(--n-900)}
.icon-btn-dot{position:absolute;top:7px;right:7px;width:7px;height:7px;border-radius:50%;background:#EF4444;border:2px solid var(--bg)}

.content{padding:20px 28px 40px;max-width:1440px}
.page{display:none;animation:fadeIn .25s ease}
.page.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

/* Crumbs */
.crumb{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--n-500);margin-bottom:14px}
.crumb a{color:var(--n-700);font-weight:500;text-decoration:none;cursor:pointer;transition:color .12s}
.crumb a:hover{color:var(--brand-700)}
.crumb-sep{opacity:.4}

/* Page header */
.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:18px}
.page-title{font-size:21px;font-weight:800;letter-spacing:-.025em;color:var(--n-900);line-height:1.1}
.page-sub{font-size:13.5px;color:var(--n-500);margin-top:4px;font-weight:400}
.page-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:8px 14px;border-radius:8px;
  font-family:var(--font-sans);font-size:13px;font-weight:500;letter-spacing:-.005em;
  cursor:pointer;border:1px solid transparent;
  transition:all .12s;white-space:nowrap;
}
.btn:active{transform:translateY(.5px)}
.btn-primary{
  background:linear-gradient(180deg,#10B981 0%,#059669 100%);
  color:#fff;border-color:#047857;
  box-shadow:0 1px 2px rgba(4,120,87,.18),inset 0 1px 0 rgba(255,255,255,.18)
}
.btn-primary:hover{background:linear-gradient(180deg,#0DA372 0%,#048856 100%);box-shadow:0 2px 5px rgba(4,120,87,.25),inset 0 1px 0 rgba(255,255,255,.18)}
.btn-secondary{background:var(--surface);color:var(--n-800);border-color:var(--border-strong);box-shadow:var(--shadow-xs)}
.btn-secondary:hover{background:var(--n-50);border-color:var(--n-300)}
.btn-ghost{background:transparent;color:var(--n-700);border-color:transparent}
.btn-ghost:hover{background:var(--n-100);color:var(--n-900)}
.btn-danger{background:#fff;color:var(--red-600);border-color:#FECACA}
.btn-danger:hover{background:var(--red-50);border-color:#FCA5A5}
.btn-sm{padding:6px 11px;font-size:12px;border-radius:7px;gap:5px}
.btn-icon-l svg{margin-left:-2px}
.btn-icon-r svg{margin-right:-2px}

/* Pill */
.pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 9px;border-radius:20px;font-size:11.5px;font-weight:500;
  background:var(--n-100);color:var(--n-700);border:1px solid var(--border)
}
.pill-brand{background:var(--brand-50);color:var(--brand-700);border-color:var(--brand-200)}

/* Cards */
.card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-xl);overflow:hidden;
  box-shadow:var(--shadow-sm);
  margin-bottom:16px;transition:box-shadow .15s
}
.card-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px;border-bottom:1px solid var(--border);gap:12px
}
.card-title{font-size:13.5px;font-weight:600;color:var(--n-900);letter-spacing:-.01em}
.card-sub{font-size:12px;color:var(--n-500);margin-top:2px;font-weight:400}
.card-body{padding:18px}
.card-actions{display:flex;align-items:center;gap:6px}

/* Stat grid */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
.stat{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);
  padding:16px 18px;box-shadow:var(--shadow-sm);
  position:relative;overflow:hidden;transition:transform .15s,box-shadow .15s
}
.stat:hover{box-shadow:var(--shadow-md)}
.stat-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.stat-label{font-size:12px;color:var(--n-500);font-weight:500}
.stat-icon{
  width:28px;height:28px;border-radius:7px;
  display:flex;align-items:center;justify-content:center;
  background:var(--brand-50);color:var(--brand-600)
}
.stat-icon.warm{background:var(--accent-50);color:var(--accent-600)}
.stat-icon.red{background:var(--red-50);color:var(--red-600)}
.stat-icon.amber{background:var(--amber-50);color:var(--amber-600)}
.stat-icon.blue{background:var(--blue-50);color:var(--blue-600)}
.stat-value{font-size:26px;font-weight:700;letter-spacing:-.025em;color:var(--n-900);font-feature-settings:'tnum';line-height:1.1}
.stat-trend{font-size:11.5px;margin-top:6px;display:flex;align-items:center;gap:4px;font-weight:500}
.trend-up{color:var(--green-600)}
.trend-dn{color:var(--red-600)}
.trend-neu{color:var(--n-500)}
.stat-spark{position:absolute;right:10px;bottom:10px;opacity:.55}

/* Banners */
.banner{
  display:flex;align-items:flex-start;gap:12px;
  padding:12px 16px;border-radius:var(--r-xl);
  margin-bottom:16px;font-size:13px;line-height:1.5;
  background:linear-gradient(135deg,rgba(16,185,129,.06),rgba(16,185,129,.02));
  border:1px solid var(--brand-200);color:var(--brand-900)
}
.banner-icon{width:18px;height:18px;flex-shrink:0;color:var(--brand-600);margin-top:1px}
.banner strong{font-weight:600;color:var(--brand-900)}
.banner-info{background:linear-gradient(135deg,rgba(59,130,246,.06),rgba(59,130,246,.02));border-color:#BFDBFE;color:#1E3A8A}
.banner-info .banner-icon{color:var(--blue-600)}
.banner-info strong{color:var(--blue-700)}
.banner-warn{background:linear-gradient(135deg,rgba(245,158,11,.07),rgba(245,158,11,.02));border-color:#FDE68A;color:#78350F}
.banner-warn .banner-icon{color:var(--amber-600)}
.banner-warn strong{color:var(--amber-700)}

/* Tables */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}
thead th{
  text-align:left;padding:10px 18px;font-size:11px;font-weight:600;
  color:var(--n-500);text-transform:uppercase;letter-spacing:.06em;
  background:var(--n-50);border-bottom:1px solid var(--border);
  position:sticky;top:0;
}
thead th:first-child{padding-left:18px}
tbody td{
  padding:13px 18px;border-bottom:1px solid var(--border);
  font-size:13px;color:var(--n-800);vertical-align:middle
}
tbody tr:last-child td{border-bottom:none}
tr.row-clickable{cursor:pointer;transition:background .12s}
tr.row-clickable:hover td{background:var(--n-50)}

.cell-primary{font-weight:600;color:var(--n-900)}
.cell-meta{font-size:11.5px;color:var(--n-500);margin-top:2px;font-weight:400}
.mono{font-family:var(--font-mono);font-feature-settings:'tnum'}

/* Status chips */
.chip{
  display:inline-flex;align-items:center;gap:5px;
  padding:2.5px 9px;border-radius:20px;font-size:11.5px;font-weight:500;
  border:1px solid;line-height:1.4
}
.chip-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.chip-success{background:var(--green-50);color:var(--green-700);border-color:#BBF7D0}
.chip-success .chip-dot{background:var(--green-500)}
.chip-warn{background:var(--amber-50);color:var(--amber-700);border-color:#FDE68A}
.chip-warn .chip-dot{background:var(--amber-500)}
.chip-danger{background:var(--red-50);color:var(--red-700);border-color:#FECACA}
.chip-danger .chip-dot{background:var(--red-500)}
.chip-info{background:var(--blue-50);color:var(--blue-700);border-color:#BFDBFE}
.chip-info .chip-dot{background:var(--blue-500)}
.chip-neutral{background:var(--n-100);color:var(--n-700);border-color:var(--border)}
.chip-neutral .chip-dot{background:var(--n-400)}
.chip-purple{background:var(--purple-50);color:#7E22CE;border-color:#E9D5FF}

/* Risk chip (sober) */
.risk{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:600;line-height:1.5}
.risk-high{background:var(--red-50);color:var(--red-700);border:1px solid #FECACA}
.risk-med{background:var(--amber-50);color:var(--amber-700);border:1px solid #FDE68A}
.risk-low{background:var(--green-50);color:var(--green-700);border:1px solid #BBF7D0}

/* Progress */
.bar{display:flex;align-items:center;gap:10px;min-width:140px}
.bar-track{flex:1;height:6px;background:var(--n-150);border-radius:99px;overflow:hidden}
.bar-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--brand-500),var(--brand-400));transition:width .4s}
.bar-fill.amber{background:linear-gradient(90deg,var(--amber-500),#FBBF24)}
.bar-fill.red{background:linear-gradient(90deg,var(--red-500),#F87171)}
.bar-pct{font-size:11.5px;color:var(--n-600);min-width:34px;text-align:right;font-family:var(--font-mono);font-weight:500}

/* Avatar (org logo) */
.org-avatar{
  width:34px;height:34px;border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;flex-shrink:0;letter-spacing:-.02em;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.04)
}
.oa-1{background:linear-gradient(135deg,#DBEAFE,#BFDBFE);color:#1E40AF}
.oa-2{background:linear-gradient(135deg,#FEE2E2,#FECACA);color:#991B1B}
.oa-3{background:linear-gradient(135deg,#FEF3C7,#FDE68A);color:#92400E}
.oa-4{background:linear-gradient(135deg,#D1FAE5,#A7F3D0);color:#065F46}
.oa-5{background:linear-gradient(135deg,#E9D5FF,#D8B4FE);color:#6B21A8}
.oa-6{background:linear-gradient(135deg,#FED7AA,#FDBA74);color:#9A3412}

/* Client cards (galería) */
.client-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:14px}
.client-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-2xl);
  padding:18px;cursor:pointer;transition:all .18s;
  box-shadow:var(--shadow-sm);position:relative;overflow:hidden;
}
.client-card::after{
  content:'';position:absolute;inset:0;border-radius:var(--r-2xl);
  background:linear-gradient(135deg,rgba(16,185,129,0) 0%,rgba(16,185,129,.04) 100%);
  opacity:0;transition:opacity .18s;pointer-events:none
}
.client-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--brand-300)}
.client-card:hover::after{opacity:1}
.cc-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}
.cc-id{display:flex;gap:11px;flex:1;min-width:0}
.cc-name{font-size:15px;font-weight:600;letter-spacing:-.01em;color:var(--n-900);line-height:1.3}
.cc-nit{font-size:11.5px;color:var(--n-500);margin-top:2px;font-family:var(--font-mono)}
.cc-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--border);padding-top:12px;margin-top:4px}
.cc-stat{padding:0 8px;border-right:1px solid var(--border)}
.cc-stat:last-child{border-right:none}
.cc-stat:first-child{padding-left:0}
.cc-stat-val{font-size:18px;font-weight:700;color:var(--n-900);letter-spacing:-.02em;font-feature-settings:'tnum'}
.cc-stat-lbl{font-size:10.5px;color:var(--n-500);text-transform:uppercase;letter-spacing:.05em;margin-top:2px;font-weight:500}
.cc-foot{display:flex;align-items:center;justify-content:space-between;margin-top:14px;padding-top:12px;border-top:1px solid var(--border);font-size:11.5px;color:var(--n-500)}
.cc-meta-l{display:flex;align-items:center;gap:6px}
.cc-meta-arrow{color:var(--brand-600);transition:transform .18s}
.client-card:hover .cc-meta-arrow{transform:translateX(3px)}
.cc-add{
  background:transparent;border:1.5px dashed var(--n-300);
  display:flex;align-items:center;justify-content:center;min-height:240px;
  cursor:pointer;transition:all .18s;border-radius:var(--r-2xl);text-align:center
}
.cc-add:hover{border-color:var(--brand-500);background:var(--brand-50)}
.cc-add-icon{width:42px;height:42px;border-radius:11px;background:var(--brand-50);color:var(--brand-600);display:flex;align-items:center;justify-content:center;margin:0 auto 12px}
.cc-add:hover .cc-add-icon{background:var(--brand-600);color:#fff}

/* Two columns */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px}
.three-col{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}

/* List items (alerts/audits) */
.list-item{
  display:flex;align-items:flex-start;gap:12px;
  padding:12px 14px;border:1px solid var(--border);border-radius:var(--r-lg);
  margin-bottom:8px;transition:all .12s;background:var(--surface)
}
.list-item:hover{border-color:var(--border-strong)}
.list-item-icon{
  width:32px;height:32px;border-radius:8px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:14px
}
.lii-red{background:var(--red-50);color:var(--red-600)}
.lii-amber{background:var(--amber-50);color:var(--amber-600)}
.lii-blue{background:var(--blue-50);color:var(--blue-600)}
.lii-green{background:var(--green-50);color:var(--green-600)}
.lii-neutral{background:var(--n-100);color:var(--n-600)}
.list-item-body{flex:1;min-width:0}
.lib-title{font-size:13px;font-weight:600;color:var(--n-900);letter-spacing:-.005em}
.lib-sub{font-size:12px;color:var(--n-500);margin-top:3px;line-height:1.5}
.list-item-meta{font-size:11px;color:var(--n-500);font-family:var(--font-mono);white-space:nowrap;flex-shrink:0;align-self:flex-start;margin-top:3px}

/* Stepper */
.stepper{display:flex;align-items:center;padding:6px 0}
.step{flex:1;display:flex;flex-direction:column;align-items:center;position:relative}
.step:not(:last-child)::after{
  content:'';position:absolute;top:13px;left:calc(50% + 16px);right:calc(-50% + 16px);
  height:2px;background:var(--border);border-radius:2px
}
.step.done:not(:last-child)::after{background:linear-gradient(90deg,var(--brand-500),var(--brand-400))}
.step-dot{
  width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;background:var(--surface);border:2px solid var(--border);color:var(--n-500);
  z-index:1;transition:all .2s
}
.step.done .step-dot{background:var(--brand-500);border-color:var(--brand-500);color:#fff;box-shadow:0 0 0 4px var(--brand-50)}
.step.active .step-dot{background:var(--surface);border-color:var(--brand-500);color:var(--brand-700);box-shadow:0 0 0 4px var(--brand-50),0 4px 10px -2px rgba(16,185,129,.35)}
.step-label{font-size:10.5px;color:var(--n-500);margin-top:8px;text-align:center;max-width:90px;line-height:1.35;font-weight:500}
.step.done .step-label{color:var(--brand-700);font-weight:600}
.step.active .step-label{color:var(--n-900);font-weight:600}

/* Audit checklist */
.check{display:flex;align-items:flex-start;gap:11px;padding:11px 13px;border-radius:9px;margin-bottom:5px;border:1px solid var(--border);background:var(--surface)}
.check-i{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0;font-weight:700}
.ci-ok{background:var(--green-50);color:var(--green-700);border:1px solid #BBF7D0}
.ci-warn{background:var(--amber-50);color:var(--amber-700);border:1px solid #FDE68A}
.ci-fail{background:var(--red-50);color:var(--red-700);border:1px solid #FECACA}
.ci-pen{background:var(--n-100);color:var(--n-600);border:1px solid var(--border)}
.check-body{flex:1}
.check-title{font-size:13px;font-weight:600;color:var(--n-900)}
.check-sub{font-size:11.5px;color:var(--n-500);margin-top:3px;line-height:1.5}

/* Plans */
.plan-row{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border-radius:9px;margin-bottom:6px;border:1px solid var(--border);background:var(--surface)}
.plan-num{width:26px;height:26px;border-radius:50%;background:var(--n-900);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--font-mono)}
.plan-body{flex:1}
.plan-title{font-size:13px;font-weight:600;color:var(--n-900)}
.plan-meta{font-size:11.5px;color:var(--n-500);margin-top:3px}

/* Forms */
.form-group{margin-bottom:14px}
.form-label{font-size:12.5px;font-weight:600;color:var(--n-700);display:block;margin-bottom:6px;letter-spacing:-.005em}
.form-input,select.form-input,textarea.form-input{
  width:100%;padding:9px 12px;background:var(--surface);
  border:1px solid var(--border-strong);border-radius:8px;
  font-family:var(--font-sans);font-size:13px;color:var(--n-900);
  transition:all .12s
}
.form-input::placeholder{color:var(--n-400)}
.form-input:focus{border-color:var(--brand-500);box-shadow:var(--ring)}
.form-input.invalid{border-color:var(--red-500);background:var(--red-50)}
select.form-input{appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center;padding-right:32px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* Hint del riesgo legal auto-derivado por sector */
.legal-auto-hint{
  display:inline-flex;align-items:center;gap:0;
  font-size:9.5px;font-weight:700;color:var(--brand-700);
  background:var(--brand-50);border:1px solid var(--brand-100);
  padding:2px 7px;border-radius:99px;letter-spacing:.04em;text-transform:uppercase;
  cursor:help;
}
.legal-clase-tag{
  margin-top:5px;font-size:9.5px;font-weight:600;color:var(--n-600);
  display:flex;align-items:center;gap:6px;line-height:1.45;
  padding:5px 8px;background:var(--n-50);border:1px solid var(--border);
  border-radius:6px;
}
.legal-clase-tag .lct-dot{
  width:7px;height:7px;border-radius:50%;flex-shrink:0;
}
.legal-clase-tag.bajo .lct-dot{background:var(--green-500)}
.legal-clase-tag.medio .lct-dot{background:var(--amber-500)}
.legal-clase-tag.alto .lct-dot{background:var(--red-500)}
.legal-clase-tag .lct-clase{
  font-family:var(--font-mono);font-weight:700;color:var(--n-800);
  padding:1px 5px;background:var(--surface);border:1px solid var(--border);
  border-radius:4px;font-size:9px;letter-spacing:.04em;
}

/* ════ Chips de nivel para documentos auto-generados ════ */
.doc-niv-chip{
  display:inline-block;font-family:var(--font-mono);
  font-size:9.5px;font-weight:800;letter-spacing:.07em;
  padding:2px 7px;border-radius:99px;
  background:var(--n-100);color:var(--n-700);border:1px solid var(--border);
  vertical-align:middle;
}
.doc-niv-chip.doc-niv-bajo {background:var(--green-50); color:var(--green-700); border-color:#BBF7D0}
.doc-niv-chip.doc-niv-medio{background:var(--amber-50); color:var(--amber-700); border-color:#FDE68A}
.doc-niv-chip.doc-niv-alto {background:var(--red-50);   color:var(--red-700);   border-color:#FECACA}

.doc-niv-mini{
  display:inline-flex;align-items:center;justify-content:center;
  width:18px;height:18px;border-radius:5px;flex-shrink:0;
  font-family:var(--font-mono);font-size:9.5px;font-weight:800;letter-spacing:0;
  background:var(--n-100);color:var(--n-600);border:1px solid var(--border);
  cursor:help;
}
.doc-niv-mini.doc-niv-bajo {background:var(--green-50); color:var(--green-700); border-color:#BBF7D0}
.doc-niv-mini.doc-niv-medio{background:var(--amber-50); color:var(--amber-700); border-color:#FDE68A}
.doc-niv-mini.doc-niv-alto {background:var(--red-50);   color:var(--red-700);   border-color:#FECACA}

.doc-niv-ref{
  display:inline-block;margin-left:8px;
  font-size:10px;font-weight:600;color:var(--n-500);
  font-family:var(--font-mono);
  padding:1px 6px;border-radius:4px;
  background:var(--n-50);border:1px solid var(--border);
}

/* ════ Dashboard del cliente · v2 (look profesional refinado) ════ */
.cli-dashboard{margin-bottom:20px}
.cli-kpi-grid{
  display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:11px;margin-bottom:14px;
}
@media (max-width:1280px){.cli-kpi-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:760px){.cli-kpi-grid{grid-template-columns:repeat(2,1fr)}}

.cli-kpi{
  position:relative;display:flex;align-items:center;gap:12px;
  background:var(--surface);
  border:1px solid var(--border);border-radius:12px;
  padding:14px 15px;box-shadow:var(--shadow-xs);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  overflow:hidden;
}
.cli-kpi::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--n-300);border-radius:0 4px 4px 0;
  transition:width .25s;
}
.cli-kpi:hover{
  transform:translateY(-1px);box-shadow:var(--shadow-md);
  border-color:var(--border-strong);
}
.cli-kpi:hover::before{width:4px}
.cli-kpi-icon{
  width:36px;height:36px;border-radius:10px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:var(--n-100);color:var(--n-600);border:1px solid var(--border);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.5);
}
.cli-kpi-info{min-width:0;flex:1;line-height:1.15}
.cli-kpi-label{
  font-size:9.5px;color:var(--n-500);font-weight:700;
  text-transform:uppercase;letter-spacing:.09em;line-height:1.3;
}
.cli-kpi-value{
  font-size:24px;font-weight:800;color:var(--n-900);margin-top:5px;
  font-family:var(--font-mono);font-feature-settings:'tnum';letter-spacing:-.03em;line-height:1;
}
.cli-kpi-total{
  background:linear-gradient(135deg, rgba(16,185,129,.06) 0%, var(--surface) 60%);
  border-color:var(--brand-100);
}
.cli-kpi-total::before{background:linear-gradient(180deg,var(--brand-500),var(--brand-700))}
.cli-kpi-total .cli-kpi-icon{background:linear-gradient(135deg,var(--brand-100),var(--brand-50));color:var(--brand-700);border-color:var(--brand-200)}
.cli-kpi-total .cli-kpi-value{color:var(--brand-700)}

.cli-kpi-green  ::before{}
.cli-kpi-green::before {background:linear-gradient(180deg,var(--green-500),var(--green-700))}
.cli-kpi-green .cli-kpi-icon{background:var(--green-50); color:var(--green-700);border-color:#BBF7D0}
.cli-kpi-green .cli-kpi-value{color:var(--green-700)}

.cli-kpi-amber::before{background:linear-gradient(180deg,var(--amber-500),var(--amber-700))}
.cli-kpi-amber .cli-kpi-icon{background:var(--amber-50); color:var(--amber-700);border-color:#FDE68A}
.cli-kpi-amber .cli-kpi-value{color:var(--amber-700)}

.cli-kpi-orange::before{background:linear-gradient(180deg,var(--accent-500),var(--accent-600))}
.cli-kpi-orange .cli-kpi-icon{background:#FFEDD5; color:var(--accent-600);border-color:#FED7AA}
.cli-kpi-orange .cli-kpi-value{color:var(--accent-600)}

.cli-kpi-red::before{background:linear-gradient(180deg,var(--red-500),var(--red-700))}
.cli-kpi-red .cli-kpi-icon{background:var(--red-50); color:var(--red-700);border-color:#FECACA}
.cli-kpi-red .cli-kpi-value{color:var(--red-700)}

.cli-kpi-gray::before{background:linear-gradient(180deg,var(--n-300),var(--n-500))}
.cli-kpi-gray .cli-kpi-icon{background:var(--n-100); color:var(--n-600); border-color:var(--border)}

.cli-charts-grid{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:14px;
}
.cli-chart-card{
  background:var(--surface);
  border:1px solid var(--border);border-radius:14px;
  padding:18px 20px 20px;box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
  transition:box-shadow .2s, border-color .2s;
}
.cli-chart-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--brand-500),var(--brand-300),transparent 80%);
  opacity:.6;
}
.cli-chart-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong)}
.cli-chart-wide{grid-column:span 2}
@media (max-width:980px){.cli-charts-grid{grid-template-columns:1fr}.cli-chart-wide{grid-column:auto}}
.cli-chart-head{
  margin-bottom:14px;padding-bottom:11px;
  border-bottom:1px solid var(--border);
  display:flex;align-items:flex-start;justify-content:space-between;gap:12px;
}
.cli-chart-title{
  font-size:13px;font-weight:700;color:var(--n-900);letter-spacing:-.012em;
  display:flex;align-items:center;gap:8px;
}
.cli-chart-title::before{
  content:'';width:4px;height:14px;border-radius:2px;
  background:linear-gradient(180deg,var(--brand-500),var(--brand-700));
  flex-shrink:0;
}
.cli-chart-sub{font-size:10.5px;color:var(--n-500);margin-top:3px;font-weight:500;letter-spacing:-.005em;padding-left:12px}
.cli-chart-body{flex:1;min-height:140px}
.cli-chart-empty{
  font-size:12px;color:var(--n-500);text-align:center;padding:42px 10px;
  font-weight:500;
}

/* Donut con leyenda */
.cli-donut-wrap{display:flex;align-items:center;gap:22px;flex-wrap:wrap;padding:6px 0}
.cli-donut{flex-shrink:0;filter:drop-shadow(0 4px 12px rgba(15,23,42,.06))}
.cli-donut text.donut-num{font-size:26px;font-weight:800;font-family:var(--font-mono);fill:var(--n-900);letter-spacing:-.04em}
.cli-donut text.donut-lbl{font-size:8px;font-weight:700;letter-spacing:.12em;fill:var(--n-400)}
.cli-legend{display:flex;flex-direction:column;gap:8px;flex:1;min-width:150px}
.cli-legend-row{
  display:flex;align-items:center;gap:10px;
  font-size:12px;color:var(--n-700);font-weight:500;
  padding:5px 8px;border-radius:7px;
  transition:background .15s;
}
.cli-legend-row:hover{background:var(--n-50)}
.cli-legend-dot{
  width:10px;height:10px;border-radius:3px;flex-shrink:0;
  box-shadow:0 0 0 3px rgba(0,0,0,.04);
}
.cli-legend-name{flex:1;min-width:0;line-height:1.3;font-weight:600;color:var(--n-700)}
.cli-legend-val{
  font-family:var(--font-mono);font-weight:800;color:var(--n-900);
  font-size:13px;letter-spacing:-.015em;
}
.cli-legend-pct{
  font-size:10px;color:var(--n-500);font-weight:700;
  font-family:var(--font-mono);margin-left:4px;
  padding:1px 6px;border-radius:99px;
  background:var(--n-100);
}

/* Bars chart · ranking de avance */
.cli-bars{display:flex;flex-direction:column;gap:9px}
.cli-bar-row{
  display:grid;grid-template-columns:200px 1fr 78px;gap:14px;align-items:center;
  padding:6px 8px;border-radius:8px;
  transition:background .15s;
}
.cli-bar-row:hover{background:var(--n-50)}
.cli-bar-label{font-size:12px;font-weight:700;color:var(--n-800);line-height:1.25;min-width:0;letter-spacing:-.005em}
.cli-bar-label small{display:block;color:var(--n-500);font-weight:500;font-size:10px;margin-top:2px;font-family:var(--font-mono);letter-spacing:0}
.cli-bar-track{
  height:10px;background:var(--n-100);border-radius:99px;overflow:hidden;
  border:1px solid var(--border);position:relative;
}
.cli-bar-fill{
  height:100%;border-radius:99px;
  background:linear-gradient(90deg,var(--brand-600),var(--brand-400));
  transition:width .55s cubic-bezier(.4,0,.2,1);
  box-shadow:0 0 8px rgba(16,185,129,.35);
}
.cli-bar-fill.bar-warn{background:linear-gradient(90deg,var(--amber-600),var(--amber-400));box-shadow:0 0 8px rgba(245,158,11,.3)}
.cli-bar-fill.bar-bad{background:linear-gradient(90deg,var(--red-600),var(--red-400));box-shadow:0 0 8px rgba(239,68,68,.3)}
.cli-bar-val{
  font-family:var(--font-mono);font-weight:800;color:var(--n-900);font-size:13px;
  text-align:right;font-feature-settings:'tnum';line-height:1.1;letter-spacing:-.015em;
}
.cli-bar-val small{
  font-size:9.5px;color:var(--n-500);font-weight:600;display:block;margin-top:3px;
  text-transform:uppercase;letter-spacing:.04em;font-family:var(--font-sans);
}

/* ════ Display de exposición — derivado del modelo (read-only) ════ */
.exp-display{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:8px;
  background:var(--n-50);border:1.5px solid var(--border);
  font-size:12.5px;font-weight:600;color:var(--n-700);
  min-height:40px;line-height:1.3;
  position:relative;transition:all .18s;
}
.exp-display svg{flex-shrink:0}
.exp-display-empty{
  background:var(--n-50);border-style:dashed;border-color:var(--n-300);
  color:var(--n-500);font-weight:500;font-size:11.5px;
}
.exp-display-empty-txt{flex:1;min-width:0}
.exp-display-cta{
  font-size:10.5px;font-weight:700;letter-spacing:.02em;
  padding:5px 10px;border-radius:6px;
  background:var(--brand-50);color:var(--brand-700);
  border:1px solid var(--brand-200);cursor:pointer;
  transition:all .15s;font-family:var(--font-sans);
}
.exp-display-cta:hover{background:var(--brand-100);border-color:var(--brand-300)}

.exp-display-bajo{
  background:var(--green-50);border-color:#86EFAC;color:var(--green-700);
}
.exp-display-medio{
  background:var(--amber-50);border-color:#FCD34D;color:var(--amber-700);
}
.exp-display-alto{
  background:var(--red-50);border-color:#FCA5A5;color:var(--red-700);
}
.exp-display-value{
  font-family:var(--font-mono);font-weight:800;font-size:13px;
  letter-spacing:.04em;text-transform:uppercase;
  padding:2px 9px;border-radius:5px;background:rgba(255,255,255,.55);
  border:1px solid rgba(0,0,0,.05);
}
.exp-display-bajo  .exp-display-value{color:var(--green-700)}
/* Display simplificado: solo el nivel, centrado y prominente */
.exp-display-value-only{
  flex:1;text-align:center;
  font-family:var(--font-mono);font-weight:800;font-size:14px;
  letter-spacing:.06em;text-transform:uppercase;
  padding:3px 12px;border-radius:6px;
  background:rgba(255,255,255,.6);
  border:1px solid rgba(0,0,0,.06);
}
.exp-display-bajo  .exp-display-value-only{color:var(--green-700)}
.exp-display-medio .exp-display-value-only{color:var(--amber-700)}
.exp-display-alto  .exp-display-value-only{color:var(--red-700)}
.exp-display-medio .exp-display-value{color:var(--amber-700)}
.exp-display-alto  .exp-display-value{color:var(--red-700)}
.exp-display-source{
  flex:1;min-width:0;font-size:10.5px;font-weight:500;opacity:.85;
  display:flex;align-items:center;gap:6px;
}
.exp-display-source-num{
  font-family:var(--font-mono);font-weight:700;font-size:10px;
  padding:1px 6px;border-radius:99px;background:rgba(255,255,255,.6);
  border:1px solid rgba(0,0,0,.05);
}

/* ════ Tinte de exposición por nivel (fondo suave) ════ */
.form-input.exp-bajo{
  background-color:var(--green-50) !important;
  border-color:#86EFAC !important;
  color:var(--green-700) !important;
  font-weight:600;
}
.form-input.exp-medio{
  background-color:var(--amber-50) !important;
  border-color:#FCD34D !important;
  color:var(--amber-700) !important;
  font-weight:600;
}
.form-input.exp-alto{
  background-color:var(--red-50) !important;
  border-color:#FCA5A5 !important;
  color:var(--red-700) !important;
  font-weight:600;
}
.form-input.exp-bajo:focus,
.form-input.exp-medio:focus,
.form-input.exp-alto:focus{
  box-shadow:0 0 0 3px rgba(16,185,129,.12);
}
/* Variante chevron oscuro para que se vea bien sobre tinte */
select.form-input.exp-bajo{
  background-image:url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2315803D' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") !important;
}
select.form-input.exp-medio{
  background-image:url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23B45309' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") !important;
}
select.form-input.exp-alto{
  background-image:url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23B91C1C' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") !important;
}

/* ════ Variante visual para el modelo ambiental ════ */
.env-icon{
  background:linear-gradient(135deg,rgba(59,130,246,.15),rgba(59,130,246,.04)) !important;
  color:var(--blue-700) !important;border-color:var(--blue-100) !important;
}
.env-num{
  background:linear-gradient(135deg,#DBEAFE,rgba(59,130,246,.04)) !important;
  color:var(--blue-700) !important;border-color:var(--blue-100) !important;
}
.env-meter{
  background:linear-gradient(90deg,#10B981,#06B6D4,#3B82F6) !important;
}
.env-pill{font-family:var(--font-mono)}
.env-hint{
  background:#EFF6FF !important;border-color:#DBEAFE !important;color:var(--blue-700) !important;
}
.env-score-tag.bajo  .lct-dot{background:var(--green-500)}
.env-score-tag.medio .lct-dot{background:var(--amber-500)}
.env-score-tag.alto  .lct-dot{background:var(--red-500)}

/* ════ Modelo de exposición SST ════ */
.sst-model{
  margin-top:14px;
  background:linear-gradient(180deg,var(--n-25),var(--surface));
  border:1px solid var(--border);border-radius:11px;
  overflow:hidden;
}
.sst-model-head{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:12px 16px;cursor:pointer;
  border-bottom:1px solid transparent;
  transition:background .15s, border-color .15s;
}
.sst-model.open .sst-model-head{
  background:var(--surface);border-bottom-color:var(--border);
}
.sst-model-titlewrap{display:flex;align-items:center;gap:11px;min-width:0;flex:1}
.sst-model-icon{
  width:30px;height:30px;border-radius:8px;flex-shrink:0;
  background:linear-gradient(135deg,rgba(16,185,129,.15),rgba(16,185,129,.04));
  color:var(--brand-700);border:1px solid var(--brand-100);
  display:flex;align-items:center;justify-content:center;
}
.sst-model-title{
  font-size:12.5px;font-weight:700;color:var(--n-900);letter-spacing:-.008em;
}
.sst-model-sub{
  font-size:10.5px;color:var(--n-500);margin-top:2px;line-height:1.5;
}
.sst-model-sub strong{color:var(--n-700);font-weight:700}

.sst-model-toggle{display:flex;align-items:center;gap:10px;flex-shrink:0}
.sst-chev{color:var(--n-500);transition:transform .25s}
.sst-model.open .sst-chev{transform:rotate(180deg)}

.sst-model-result-pill{
  display:inline-flex;align-items:center;gap:7px;
  padding:4px 10px;border-radius:99px;
  background:var(--n-100);border:1px solid var(--border);
  font-size:10.5px;font-weight:700;color:var(--n-700);
  font-family:var(--font-mono);letter-spacing:.01em;
}
.sst-model-result-pill .dot{
  width:7px;height:7px;border-radius:50%;background:var(--n-400);
}
.sst-model-result-pill .lvl{color:var(--n-700)}
.sst-model-result-pill .sc{font-size:10px;opacity:.6}
.sst-model-result-pill.bajo  {background:var(--green-50); border-color:#BBF7D0; color:var(--green-700)}
.sst-model-result-pill.bajo  .dot{background:var(--green-500)}
.sst-model-result-pill.medio {background:var(--amber-50); border-color:#FDE68A; color:var(--amber-700)}
.sst-model-result-pill.medio .dot{background:var(--amber-500)}
.sst-model-result-pill.alto  {background:var(--red-50);   border-color:#FECACA; color:var(--red-700)}
.sst-model-result-pill.alto  .dot{background:var(--red-500)}

.sst-model-body{
  display:none;padding:14px 16px 16px;
}
.sst-model.open .sst-model-body{display:block;animation:fadeIn .2s ease}

.sst-factors-grid{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:11px;
}
@media (min-width:1280px){
  .sst-factors-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
}
.sst-factor{
  background:var(--surface);border:1px solid var(--border);border-radius:9px;
  padding:11px 12px;display:flex;flex-direction:column;gap:8px;
  transition:border-color .15s;
}
.sst-factor:focus-within{border-color:var(--brand-300);box-shadow:0 0 0 3px rgba(16,185,129,.12)}
.sst-factor-head{display:flex;align-items:flex-start;gap:9px}
.sst-factor-num{
  width:22px;height:22px;border-radius:6px;flex-shrink:0;
  background:linear-gradient(135deg,var(--brand-50),rgba(16,185,129,.04));
  color:var(--brand-700);border:1px solid var(--brand-100);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:800;font-family:var(--font-mono);
}
.sst-factor-info{min-width:0;flex:1}
.sst-factor-name{font-size:11.5px;font-weight:700;color:var(--n-900);letter-spacing:-.005em;line-height:1.3}
.sst-factor-meta{font-size:10px;color:var(--n-500);margin-top:2px;line-height:1.4}
.sst-input{padding:7px 28px 7px 10px;font-size:11.5px}

/* Score tag debajo del select SST */
.sst-score-tag{
  margin-top:5px;font-size:9.5px;font-weight:600;color:var(--n-600);
  display:flex;align-items:center;gap:6px;line-height:1.45;
  padding:5px 8px;background:var(--n-50);border:1px solid var(--border);
  border-radius:6px;
}
.sst-score-tag .lct-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;background:var(--n-400)}
.sst-score-tag.bajo  .lct-dot{background:var(--green-500)}
.sst-score-tag.medio .lct-dot{background:var(--amber-500)}
.sst-score-tag.alto  .lct-dot{background:var(--red-500)}
.sst-score-tag .sst-score-num{
  font-family:var(--font-mono);font-weight:700;color:var(--n-800);
  padding:1px 5px;background:var(--surface);border:1px solid var(--border);
  border-radius:4px;font-size:9px;letter-spacing:.04em;
}

/* Resultado del modelo */
.sst-result{
  margin-top:14px;
  display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:center;
  background:var(--surface);border:1px solid var(--border);border-radius:10px;
  padding:14px 16px;
}
@media (max-width:900px){.sst-result{grid-template-columns:1fr}}
.sst-result-left{display:flex;align-items:center;gap:18px;min-width:240px}
.sst-result-meter{
  position:relative;width:160px;height:8px;
  background:var(--n-150);border-radius:99px;overflow:hidden;
}
.sst-result-meter-fill{
  position:absolute;left:0;top:0;height:100%;width:0%;
  background:linear-gradient(90deg,var(--green-500),var(--amber-500),var(--red-500));
  border-radius:99px;transition:width .4s;
}
.sst-result-meter-marks{
  position:absolute;left:0;top:0;width:100%;height:100%;
  display:flex;justify-content:space-between;
}
.sst-result-meter-marks span{
  width:1px;height:8px;background:rgba(255,255,255,.55);
}
.sst-result-numbers{display:flex;gap:14px}
.sst-result-label{
  font-size:9px;color:var(--n-500);font-weight:700;
  text-transform:uppercase;letter-spacing:.09em;
}
.sst-result-score{
  font-size:22px;font-weight:800;color:var(--n-900);
  font-family:var(--font-mono);font-feature-settings:'tnum';letter-spacing:-.02em;
  margin-top:3px;line-height:1;
}
.sst-result-level{
  font-size:14.5px;font-weight:800;color:var(--n-700);
  margin-top:3px;line-height:1;letter-spacing:-.005em;
}
.sst-result-level.bajo {color:var(--green-700)}
.sst-result-level.medio{color:var(--amber-700)}
.sst-result-level.alto {color:var(--red-700)}
.sst-result-right{min-width:0}
.sst-result-implications{
  font-size:11.5px;color:var(--n-700);line-height:1.55;margin-top:5px;
}
.sst-result-implications strong{color:var(--n-900);font-weight:700}
.sst-result-implications ul{margin:5px 0 0 0;padding-left:0;list-style:none}
.sst-result-implications ul li{
  position:relative;padding-left:14px;line-height:1.55;
}
.sst-result-implications ul li::before{
  content:'';position:absolute;left:0;top:8px;width:6px;height:6px;
  border-radius:50%;background:var(--brand-500);
}



/* ═══════ Panel detalle del contratista ═══════ */

/* Score header */
.ctd-score-card{padding:16px 20px}
.ctd-score-num{font-size:42px;font-weight:800;letter-spacing:-.035em;line-height:1;font-family:var(--font-mono);font-feature-settings:'tnum';color:var(--n-900)}
.ctd-score-max{font-size:15px;color:var(--n-400);font-weight:600}
.ctd-score-bar{height:6px;background:var(--n-150);border-radius:99px;overflow:hidden;margin-top:9px;max-width:240px}
.ctd-score-bar-fill{height:100%;border-radius:99px;transition:width .4s,background .4s}
.dim-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.dim-card{background:var(--n-50);border:1px solid var(--border);border-radius:8px;padding:8px 11px}
.dim-label{font-size:9.5px;color:var(--n-500);font-weight:700;text-transform:uppercase;letter-spacing:.07em}
.dim-val{font-size:18px;font-weight:700;color:var(--n-900);margin-top:3px;font-feature-settings:'tnum';letter-spacing:-.022em}
.dim-bar{height:3px;background:var(--n-150);border-radius:99px;margin-top:5px;overflow:hidden}
.dim-bar-fill{height:100%;border-radius:99px;transition:width .35s}

/* Stepper-tabs · v2 (compacto, sin amontonamiento) */
.ctd-stepper{
  display:flex;align-items:stretch;gap:3px;
  background:var(--surface);border:1px solid var(--border);border-radius:10px;
  padding:4px;margin-bottom:14px;box-shadow:var(--shadow-xs);
  overflow-x:auto;
}
.ctd-step{
  flex:1;min-width:0;
  padding:8px 10px;cursor:pointer;
  display:flex;align-items:center;justify-content:flex-start;gap:8px;
  border-radius:7px;transition:all .15s;
  position:relative;
}
.ctd-step:hover{background:var(--n-50)}
.ctd-step.active{
  background:linear-gradient(135deg,var(--brand-50),rgba(16,185,129,.05));
  box-shadow:inset 0 0 0 1px var(--brand-200);
}
.ctd-step.done{background:rgba(16,185,129,.025)}
.ctd-step-num{
  width:22px;height:22px;border-radius:6px;
  background:var(--n-100);color:var(--n-600);
  font-size:11px;font-weight:700;font-family:var(--font-mono);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:all .15s;
}
.ctd-step.active .ctd-step-num{
  background:linear-gradient(135deg,#34D399,#059669);color:#fff;
  box-shadow:0 2px 5px rgba(16,185,129,.35);
}
.ctd-step.done .ctd-step-num{
  background:var(--green-50);color:var(--green-700);
  border:1px solid #BBF7D0;
}
.ctd-step-info{display:flex;flex-direction:column;line-height:1.15;min-width:0;flex:1}
.ctd-step-label{
  font-size:11.5px;font-weight:600;color:var(--n-800);letter-spacing:-.008em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.ctd-step.active .ctd-step-label{color:var(--brand-700);font-weight:700}
.ctd-step.done .ctd-step-label{color:var(--n-700)}
.ctd-step-sub{display:none}  /* sub-etiqueta oculta — la línea de tiempo arriba ya muestra el detalle */

/* Si el viewport lo permite, se muestra la sub */
@media (min-width:1320px){
  .ctd-step{padding:8px 12px;gap:10px}
  .ctd-step-sub{
    display:block;font-size:9.5px;color:var(--n-500);margin-top:3px;font-weight:500;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  }
  .ctd-step.active .ctd-step-sub{color:var(--brand-600)}
}
@media (max-width:920px){
  .ctd-step{padding:7px 8px;gap:6px}
  .ctd-step-num{width:20px;height:20px;font-size:10px;border-radius:5px}
  .ctd-step-label{font-size:11px}
}

/* ════ Línea de tiempo · v2 (8 fases) ════ */
.ctd-timeline-card{
  background:
    linear-gradient(90deg,var(--brand-600) 0%,var(--brand-500) 35%,var(--brand-400) 70%,var(--brand-300) 100%) top/100% 3px no-repeat,
    var(--surface);
  border:1px solid var(--border);border-radius:12px;
  padding:0;margin-bottom:14px;box-shadow:var(--shadow-sm);
  position:relative;overflow:visible;
}

/* Encabezado en dos zonas: título (izq) + KPIs (der) */
.ctd-timeline-head{
  display:grid;grid-template-columns:1fr auto;align-items:center;gap:20px;
  padding:14px 20px 12px;border-bottom:1px solid var(--border);
}
.ctd-timeline-titlewrap{display:flex;align-items:center;gap:11px;min-width:0}
.ctd-timeline-icon{
  width:36px;height:36px;border-radius:10px;flex-shrink:0;
  background:linear-gradient(135deg,rgba(16,185,129,.18) 0%,rgba(16,185,129,.05) 100%);
  color:var(--brand-700);border:1px solid var(--brand-100);
  display:flex;align-items:center;justify-content:center;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.4);
}
.ctd-timeline-title{
  font-size:13.5px;font-weight:700;color:var(--n-900);letter-spacing:-.012em;
  display:flex;align-items:center;gap:8px;
}
.ctd-timeline-title .tl-badge{
  font-size:9.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:2px 7px;border-radius:5px;
  background:var(--brand-50);color:var(--brand-700);border:1px solid var(--brand-100);
  font-family:var(--font-mono);
}
.ctd-timeline-sub{font-size:11px;color:var(--n-500);margin-top:3px;font-weight:500;letter-spacing:-.005em}

/* Tira de KPIs: pill agrupada con separadores */
.ctd-timeline-stats{
  display:flex;align-items:stretch;
  background:var(--n-50);
  border:1px solid var(--border);
  border-radius:10px;overflow:hidden;
}
.ctd-tl-stat{
  display:flex;flex-direction:column;justify-content:center;
  padding:7px 14px;min-width:90px;
  border-left:1px solid var(--border);
  position:relative;line-height:1.2;
}
.ctd-tl-stat:first-child{border-left:none}
.ctd-tl-stat.highlight{
  background:linear-gradient(180deg,rgba(16,185,129,.07) 0%,rgba(16,185,129,0) 100%);
}
.ctd-tl-stat-label{
  font-size:9px;color:var(--n-500);font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;margin-bottom:5px;
}
.ctd-tl-stat-val{
  font-size:17px;font-weight:800;color:var(--n-900);
  font-family:var(--font-mono);font-feature-settings:'tnum';letter-spacing:-.018em;
}
.ctd-tl-stat-val.brand{
  color:var(--brand-700);
  background:linear-gradient(135deg,var(--brand-700),var(--brand-500));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.ctd-tl-stat-val.txt{font-size:12.5px;letter-spacing:-.01em}
.ctd-tl-stat-trend{font-size:9.5px;color:var(--n-400);margin-top:1px;font-weight:500}

/* Cuerpo del timeline */
.ctd-timeline-body{padding:22px 24px 20px;position:relative}
.ctd-timeline{
  position:relative;display:grid;grid-template-columns:repeat(8,1fr);
  gap:0;
}
.ctd-timeline-track{
  position:absolute;left:calc(6.25% + 10px);right:calc(6.25% + 10px);
  top:42px;height:3px;
  background:var(--n-150);border-radius:99px;overflow:hidden;z-index:0;
}
.ctd-timeline-track-fill{
  height:100%;border-radius:99px;
  background:linear-gradient(90deg,var(--brand-600) 0%,var(--brand-500) 50%,var(--brand-400) 100%);
  box-shadow:0 0 14px rgba(16,185,129,.45);
  transition:width .65s cubic-bezier(.4,0,.2,1);width:0%;
  position:relative;
}
.ctd-timeline-track-fill::after{
  content:'';position:absolute;right:-2px;top:50%;transform:translateY(-50%);
  width:9px;height:9px;border-radius:50%;
  background:#fff;border:2px solid var(--brand-500);
  box-shadow:0 0 0 3px rgba(16,185,129,.18),0 0 12px rgba(16,185,129,.5);
}
.ctd-timeline-track-fill[data-empty="1"]::after{display:none}

/* Nodos */
.ctd-tl-node{
  position:relative;display:flex;flex-direction:column;align-items:center;
  cursor:pointer;z-index:1;padding:0 4px;
  transition:transform .18s ease;
}
.ctd-tl-node:hover{transform:translateY(-2px)}
.ctd-tl-num{
  font-size:9.5px;font-weight:700;color:var(--n-400);font-family:var(--font-mono);
  letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px;
}
.ctd-tl-node.done .ctd-tl-num{color:var(--brand-600)}
.ctd-tl-node.active .ctd-tl-num{color:var(--brand-700)}
.ctd-tl-node.warn .ctd-tl-num{color:var(--amber-700)}

.ctd-tl-dot{
  width:36px;height:36px;border-radius:50%;
  background:#fff;border:2.5px solid var(--n-300);
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;color:var(--n-500);font-family:var(--font-mono);
  transition:all .25s;
  box-shadow:0 0 0 5px var(--surface);
  position:relative;
}
.ctd-tl-node.done .ctd-tl-dot{
  background:linear-gradient(135deg,var(--brand-500) 0%,var(--brand-600) 100%);
  border-color:var(--brand-600);color:#fff;
  box-shadow:0 0 0 5px var(--surface),0 4px 12px -2px rgba(16,185,129,.55);
}
.ctd-tl-node.active .ctd-tl-dot{
  background:#fff;border-color:var(--brand-500);color:var(--brand-700);
  box-shadow:0 0 0 5px var(--brand-50),0 0 0 8px var(--surface),0 4px 16px -2px rgba(16,185,129,.45);
  animation:tl-pulse 2.2s infinite;
}
.ctd-tl-node.warn .ctd-tl-dot{
  background:linear-gradient(135deg,var(--amber-500),var(--amber-600));
  border-color:var(--amber-600);color:#fff;
  box-shadow:0 0 0 5px var(--surface),0 4px 12px -2px rgba(245,158,11,.5);
}
@keyframes tl-pulse{
  0%,100%{box-shadow:0 0 0 5px var(--brand-50),0 0 0 8px var(--surface),0 4px 16px -2px rgba(16,185,129,.45)}
  50%{box-shadow:0 0 0 9px rgba(16,185,129,.18),0 0 0 12px var(--surface),0 6px 20px -2px rgba(16,185,129,.6)}
}

.ctd-tl-name{
  font-size:11.5px;font-weight:600;color:var(--n-700);margin-top:14px;
  text-align:center;line-height:1.25;letter-spacing:-.005em;
}
.ctd-tl-node.done .ctd-tl-name{color:var(--brand-700);font-weight:700}
.ctd-tl-node.active .ctd-tl-name{color:var(--n-900);font-weight:700}
.ctd-tl-node.warn .ctd-tl-name{color:var(--amber-700);font-weight:700}

.ctd-tl-meta{
  display:flex;flex-direction:column;align-items:center;gap:5px;margin-top:7px;
}
.ctd-tl-date{
  font-size:9.5px;color:var(--n-400);
  font-family:var(--font-mono);font-weight:600;letter-spacing:.01em;
}
.ctd-tl-node.done .ctd-tl-date{color:var(--green-600)}
.ctd-tl-node.active .ctd-tl-date{color:var(--brand-600)}
.ctd-tl-node.warn .ctd-tl-date{color:var(--amber-700)}

.ctd-tl-pct{
  font-size:9.5px;font-weight:700;font-family:var(--font-mono);
  color:var(--n-500);
  padding:2px 9px;border-radius:99px;background:var(--n-100);
  letter-spacing:.02em;min-width:42px;text-align:center;
  border:1px solid transparent;
}
.ctd-tl-node.done .ctd-tl-pct{background:var(--green-50);color:var(--green-700);border-color:#BBF7D0}
.ctd-tl-node.active .ctd-tl-pct{background:var(--brand-50);color:var(--brand-700);border-color:var(--brand-200)}
.ctd-tl-node.warn .ctd-tl-pct{background:var(--amber-50);color:var(--amber-700);border-color:#FCD34D}

/* Tooltip — aparece DEBAJO del nodo, sin chocar con el header */
.ctd-tl-tip{
  position:absolute;top:calc(100% + 10px);left:50%;
  transform:translateX(-50%) translateY(-4px);
  background:var(--n-900);color:#fff;
  padding:10px 13px;border-radius:9px;
  font-size:10.5px;font-weight:500;line-height:1.5;white-space:nowrap;
  opacity:0;pointer-events:none;transition:all .2s;z-index:20;
  box-shadow:0 12px 28px -6px rgba(0,0,0,.35),0 0 0 1px rgba(255,255,255,.05);
  min-width:185px;text-align:left;
}
.ctd-tl-tip::before{
  content:'';position:absolute;bottom:100%;left:50%;transform:translateX(-50%);
  border:6px solid transparent;border-bottom-color:var(--n-900);
}
.ctd-tl-tip-title{
  color:var(--brand-300);font-weight:700;margin-bottom:6px;
  font-size:9.5px;letter-spacing:.07em;text-transform:uppercase;
}
.ctd-tl-tip-row{
  display:flex;justify-content:space-between;gap:16px;
  color:rgba(255,255,255,.65);font-size:10.5px;line-height:1.7;
}
.ctd-tl-tip-row span:last-child{color:#fff;font-weight:600;font-family:var(--font-mono)}
.ctd-tl-tip-detail{
  margin-top:7px;padding-top:7px;
  border-top:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.78);font-size:10px;
  white-space:normal;line-height:1.5;
}
.ctd-tl-node:hover .ctd-tl-tip{opacity:1;transform:translateX(-50%) translateY(0)}

/* Las primeras y últimas tooltips se desplazan para no salirse del card */
.ctd-tl-node[data-idx="0"] .ctd-tl-tip,
.ctd-tl-node[data-idx="1"] .ctd-tl-tip{
  left:0;transform:translateX(0) translateY(-4px);
}
.ctd-tl-node[data-idx="0"] .ctd-tl-tip::before,
.ctd-tl-node[data-idx="1"] .ctd-tl-tip::before{left:18px;transform:none}
.ctd-tl-node[data-idx="0"]:hover .ctd-tl-tip,
.ctd-tl-node[data-idx="1"]:hover .ctd-tl-tip{transform:translateX(0) translateY(0)}

.ctd-tl-node[data-idx="6"] .ctd-tl-tip,
.ctd-tl-node[data-idx="7"] .ctd-tl-tip{
  left:auto;right:0;transform:translateX(0) translateY(-4px);
}
.ctd-tl-node[data-idx="6"] .ctd-tl-tip::before,
.ctd-tl-node[data-idx="7"] .ctd-tl-tip::before{left:auto;right:18px;transform:none}
.ctd-tl-node[data-idx="6"]:hover .ctd-tl-tip,
.ctd-tl-node[data-idx="7"]:hover .ctd-tl-tip{transform:translateX(0) translateY(0)}

/* Responsive */
@media (max-width:1240px){
  .ctd-timeline-head{grid-template-columns:1fr;gap:16px}
  .ctd-timeline-stats{justify-self:stretch}
  .ctd-tl-stat{flex:1;min-width:0;padding:8px 10px}
}
@media (max-width:1100px){
  .ctd-tl-name{font-size:10.5px}
  .ctd-tl-date,.ctd-tl-pct{font-size:9px}
  .ctd-tl-dot{width:32px;height:32px;font-size:12px}
  .ctd-timeline-track{top:46px}
  .ctd-timeline-body{padding:24px 18px 22px}
}

.ctd-panel{display:none;animation:fadeIn .25s ease}
.ctd-panel.active{display:block}

/* Risk classification cards */
.risk-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.risk-card{cursor:pointer;display:block;position:relative}
.risk-card input{position:absolute;opacity:0;pointer-events:none}
.risk-card-inner{
  border:1.5px solid var(--border-strong);border-radius:11px;
  padding:14px 16px;background:var(--surface);transition:all .15s;
  display:flex;flex-direction:column;gap:5px;
}
.risk-card:hover .risk-card-inner{border-color:var(--n-400);background:var(--n-50)}
.risk-card.bajo input:checked + .risk-card-inner{border-color:var(--green-500);background:var(--green-50);box-shadow:0 0 0 3px rgba(34,197,94,.14)}
.risk-card.medio input:checked + .risk-card-inner{border-color:var(--amber-500);background:var(--amber-50);box-shadow:0 0 0 3px rgba(245,158,11,.14)}
.risk-card.alto input:checked + .risk-card-inner{border-color:var(--red-500);background:var(--red-50);box-shadow:0 0 0 3px rgba(239,68,68,.14)}
.risk-card-tag{font-size:10px;font-weight:800;letter-spacing:.13em;text-transform:uppercase}
.risk-card.bajo .risk-card-tag{color:var(--green-700)}
.risk-card.medio .risk-card-tag{color:var(--amber-700)}
.risk-card.alto .risk-card-tag{color:var(--red-700)}
.risk-card-title{font-size:14px;font-weight:700;color:var(--n-900);letter-spacing:-.01em;margin-top:3px}
.risk-card-desc{font-size:11.5px;color:var(--n-500);line-height:1.5}

/* ════ Portal del contratista ════ */
.portal-hero{
  background:linear-gradient(135deg,#022C22 0%,#047857 55%,#10B981 100%);
  border-radius:16px;padding:30px 36px;color:#fff;
  position:relative;overflow:hidden;margin-bottom:14px;
  box-shadow:0 10px 28px -10px rgba(4,120,87,.4),inset 0 1px 0 rgba(255,255,255,.08);
}
.portal-hero::before{
  content:'';position:absolute;top:-50%;right:-10%;width:60%;height:200%;
  background:radial-gradient(circle,rgba(52,211,153,.22),transparent 55%);pointer-events:none;
}
.portal-hero > *{position:relative}
.portal-hero-meta{font-size:10.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;opacity:.55}
.portal-hero-title{font-size:30px;font-weight:800;letter-spacing:-.03em;margin-top:9px;line-height:1.05}
.portal-hero-sub{font-size:13px;opacity:.78;margin-top:9px}
.portal-hero-stats{
  display:flex;gap:32px;margin-top:22px;padding-top:18px;
  border-top:1px solid rgba(255,255,255,.13);font-size:12px;flex-wrap:wrap;
}
.portal-hero-stats > div{opacity:.78;display:flex;align-items:center;gap:8px}
.portal-hero-stats strong{color:#fff;font-weight:700;opacity:1;font-family:var(--font-mono)}

/* Hero unificado en 2 columnas — info + avance */
.portal-hero-grid{
  display:grid;grid-template-columns:1.4fr auto;gap:28px;align-items:center;
}
.portal-hero-left{min-width:0}
.portal-hero-right{
  text-align:right;position:relative;
  padding-left:28px;border-left:1px solid rgba(255,255,255,.18);
  min-width:200px;
}
.portal-hero-pct-label{
  font-size:10.5px;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;opacity:.72;
}
.portal-hero-pct{
  font-size:54px;font-weight:800;letter-spacing:-.04em;line-height:1;
  margin-top:6px;font-feature-settings:'tnum';color:#fff;
}
.portal-hero-pct span{font-size:24px;opacity:.55;font-weight:700;margin-left:2px}
.portal-hero-pct-sub{
  font-size:12px;opacity:.78;margin-top:6px;font-weight:500;
}
.portal-hero-status-pill{
  display:inline-flex;align-items:center;gap:6px;
  margin-top:14px;padding:6px 14px;border-radius:99px;
  font-size:11.5px;font-weight:700;letter-spacing:.04em;
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.22);
  backdrop-filter:blur(6px);
}
.portal-hero-status-pill.s-ok{background:rgba(16,185,129,.30);border-color:rgba(110,231,183,.55);color:#A7F3D0}
.portal-hero-status-pill.s-warn{background:rgba(245,158,11,.28);border-color:rgba(252,211,77,.55);color:#FDE68A}
.portal-hero-status-pill.s-crit{background:rgba(239,68,68,.28);border-color:rgba(252,165,165,.55);color:#FECACA}
.portal-hero-status-dot{width:7px;height:7px;border-radius:50%;background:currentColor}
@media (max-width:980px){
  .portal-hero-grid{grid-template-columns:1fr}
  .portal-hero-right{padding-left:0;border-left:0;border-top:1px solid rgba(255,255,255,.18);padding-top:18px;text-align:left}
}

.portal-progress-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:13px;padding:14px 20px;margin-bottom:16px;
  display:flex;align-items:center;gap:18px;box-shadow:var(--shadow-sm);
}
.portal-progress-icon{
  width:38px;height:38px;border-radius:10px;
  background:var(--brand-50);color:var(--brand-700);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  border:1px solid var(--brand-100);
}
.portal-progress-info{flex:1;min-width:0}
.portal-progress-label{
  font-size:10.5px;color:var(--n-500);font-weight:700;
  text-transform:uppercase;letter-spacing:.09em;margin-bottom:7px;
}
.portal-progress-bar{height:8px;background:var(--n-150);border-radius:99px;overflow:hidden}
.portal-progress-fill{height:100%;background:linear-gradient(90deg,var(--brand-500),var(--brand-400));border-radius:99px;transition:width .4s}
.portal-progress-pct{
  font-size:24px;font-weight:800;color:var(--n-900);
  font-feature-settings:'tnum';letter-spacing:-.025em;font-family:var(--font-mono);
}

.doc-group{
  background:var(--surface);border:1px solid var(--border);
  border-radius:14px;margin-bottom:12px;overflow:hidden;box-shadow:var(--shadow-sm);
}
.doc-group-head{
  padding:16px 22px;
  background:linear-gradient(180deg,var(--n-50) 0%,var(--surface) 100%);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:13px;
}
.doc-group-icon{
  width:38px;height:38px;border-radius:11px;
  background:linear-gradient(135deg,rgba(16,185,129,.14),rgba(16,185,129,.04));
  color:var(--brand-700);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  border:1px solid rgba(16,185,129,.18);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.55),0 1px 2px rgba(16,185,129,.08);
}
.doc-group-titles{flex:1;min-width:0}
.doc-group-name{font-size:15px;font-weight:700;color:var(--n-900);letter-spacing:-.015em;line-height:1.2}
.doc-group-meta{font-size:11.5px;color:var(--n-500);margin-top:4px;font-weight:500}
.doc-group-counter{
  font-size:11.5px;font-weight:700;color:var(--n-700);
  font-family:var(--font-mono);background:var(--n-100);
  padding:5px 12px;border-radius:8px;border:1px solid var(--border);
  flex-shrink:0;
}
.doc-group-counter.complete{background:var(--green-50);color:var(--green-700);border-color:#BBF7D0}

.doc-item{
  display:grid;grid-template-columns:auto 1fr auto;
  gap:14px;align-items:center;
  padding:14px 22px;border-bottom:1px solid var(--border);
  transition:background .14s;
}
.doc-item:last-child{border-bottom:none}
.doc-item.uploaded{
  background:linear-gradient(90deg,rgba(16,185,129,.04) 0%,rgba(16,185,129,.01) 80%,transparent 100%);
}

.doc-status-dot{
  width:10px;height:10px;border-radius:50%;
  background:var(--n-300);flex-shrink:0;position:relative;
}
.doc-item.uploaded .doc-status-dot{
  background:var(--green-500);box-shadow:0 0 0 3px rgba(34,197,94,.18);
}
.doc-status-dot::after{
  content:'';position:absolute;inset:0;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.5),transparent 60%);
}

.doc-item-info{min-width:0}
.doc-item-name{
  font-size:13.5px;font-weight:600;color:var(--n-900);
  letter-spacing:-.005em;line-height:1.4;
  display:flex;align-items:center;gap:9px;flex-wrap:wrap;
}
.doc-item-required{
  font-size:9.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  color:var(--red-700);background:var(--red-50);
  padding:2px 7px;border-radius:5px;border:1px solid #FECACA;
}
.doc-item-meta{
  display:flex;gap:10px;margin-top:5px;align-items:center;
  font-size:11.5px;color:var(--n-500);flex-wrap:wrap;
}
.doc-item-file{
  display:inline-flex;align-items:center;gap:5px;
  background:var(--green-50);color:var(--green-700);
  padding:2.5px 8px;border-radius:5px;
  font-size:11px;font-family:var(--font-mono);font-weight:500;
  border:1px solid #BBF7D0;
}

.doc-item-actions{display:flex;gap:6px;flex-shrink:0;align-items:center}

.btn-upload{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;border-radius:8px;
  background:var(--surface);
  border:1.5px dashed var(--border-strong);
  color:var(--n-700);font-size:12px;font-weight:600;
  cursor:pointer;transition:all .14s;
  font-family:var(--font-sans);white-space:nowrap;letter-spacing:-.005em;
}
.btn-upload:hover{
  background:var(--brand-50);border-color:var(--brand-500);
  color:var(--brand-700);border-style:solid;
}
.btn-upload-replace{
  padding:6px 11px;border-radius:7px;
  background:transparent;border:1px solid var(--border);
  color:var(--n-600);font-size:11.5px;font-weight:600;cursor:pointer;
  font-family:var(--font-sans);
}
.btn-upload-replace:hover{background:var(--n-50);border-color:var(--n-400);color:var(--n-900)}

/* ════ Step card (cards de fases de la metodología) ════ */
.step-card{
  background:var(--surface);border:1px solid var(--border);border-radius:14px;
  margin-bottom:14px;overflow:hidden;box-shadow:var(--shadow-sm);
  transition:box-shadow .15s,border-color .15s;
}
.step-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong)}
.step-card-head{
  padding:18px 22px;
  background:linear-gradient(180deg,var(--n-50) 0%,var(--surface) 100%);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:13px;
}
.step-card-icon{
  width:38px;height:38px;border-radius:11px;
  background:linear-gradient(135deg,rgba(16,185,129,.14),rgba(16,185,129,.04));
  color:var(--brand-700);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  border:1px solid rgba(16,185,129,.18);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.55),0 1px 2px rgba(16,185,129,.08);
}
.step-card-titles{flex:1;min-width:0}
.step-card-name{
  font-size:15px;font-weight:700;color:var(--n-900);
  letter-spacing:-.015em;line-height:1.2;
}
.step-card-meta{
  font-size:11.5px;color:var(--n-500);margin-top:4px;font-weight:500;
}
.step-card-pill{
  flex-shrink:0;
  font-size:10px;font-weight:700;color:var(--brand-700);
  background:var(--brand-50);padding:4px 10px;border-radius:6px;
  border:1px solid var(--brand-200);font-family:var(--font-mono);
  letter-spacing:.06em;text-transform:uppercase;
}
.step-card-body{padding:22px}

/* ════ Evaluación checklist — rediseño editorial ════ */
.eval-dim{
  background:var(--surface);border:1px solid var(--border);border-radius:14px;
  margin-bottom:14px;overflow:hidden;box-shadow:var(--shadow-sm);
  transition:box-shadow .15s,border-color .15s;
}
.eval-dim:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong)}

.eval-dim-head{
  padding:18px 22px;
  background:linear-gradient(180deg,var(--n-50) 0%,var(--surface) 100%);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;gap:14px;
}
.eval-dim-left{display:flex;align-items:center;gap:13px}
.eval-dim-icon{
  width:38px;height:38px;border-radius:11px;
  background:linear-gradient(135deg,rgba(16,185,129,.14),rgba(16,185,129,.04));
  color:var(--brand-700);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  border:1px solid rgba(16,185,129,.18);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.55),0 1px 2px rgba(16,185,129,.08);
}
.eval-dim-name{
  font-size:15px;font-weight:700;color:var(--n-900);
  letter-spacing:-.015em;line-height:1.2;
}
.eval-dim-meta{
  font-size:11.5px;color:var(--n-500);margin-top:4px;font-weight:500;
}
.eval-dim-score{
  font-size:26px;font-weight:800;color:var(--n-400);
  letter-spacing:-.03em;font-family:var(--font-mono);font-feature-settings:'tnum';
  line-height:1;
}
.eval-dim-score-suffix{font-size:13px;color:var(--n-400);font-weight:600}

.eval-row{
  display:grid;grid-template-columns:1fr auto;gap:18px;
  padding:15px 22px;border-bottom:1px solid var(--border);align-items:center;
  transition:background .14s;
}
.eval-row:last-child{border-bottom:none}
.eval-row:hover{background:var(--n-25)}

.eval-criterion-text{
  font-size:13.5px;color:var(--n-900);font-weight:600;
  letter-spacing:-.005em;line-height:1.45;
  display:flex;align-items:center;gap:9px;flex-wrap:wrap;
}
.eval-bloq{
  display:inline-flex;align-items:center;gap:4px;
  background:rgba(239,68,68,.08);color:var(--red-700);
  padding:2.5px 8px;border-radius:6px;
  font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  border:1px solid rgba(239,68,68,.18);
}
.eval-bloq svg{width:10px;height:10px;flex-shrink:0}

.eval-meta-row{
  display:flex;gap:16px;margin-top:7px;align-items:center;flex-wrap:wrap;
}
.eval-meta-item{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11.5px;color:var(--n-500);font-weight:500;
}
.eval-meta-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.eval-meta-dot.sev-baja{background:var(--green-500)}
.eval-meta-dot.sev-media{background:var(--amber-500)}
.eval-meta-dot.sev-alta{background:var(--accent-500)}
.eval-meta-dot.sev-critica{background:var(--red-500)}

/* Segmented control estilo iOS premium */
.eval-options{
  display:inline-flex;background:var(--n-100);
  border-radius:10px;padding:3px;gap:0;
  flex-shrink:0;border:1px solid var(--n-150);
}
.eval-opt{
  padding:7px 14px;font-size:12px;font-weight:600;
  cursor:pointer;border-radius:7px;
  color:var(--n-500);border:none;background:transparent;
  transition:color .14s,background .14s,box-shadow .14s;
  font-family:var(--font-sans);white-space:nowrap;letter-spacing:-.005em;
}
.eval-opt:hover{color:var(--n-800)}
.eval-opt.selected{
  background:var(--surface);
  box-shadow:0 1px 3px rgba(15,23,42,.09),0 0 0 1px rgba(15,23,42,.04);
}
.eval-opt.selected.cumple{color:var(--green-700)}
.eval-opt.selected.parcial{color:var(--amber-700)}
.eval-opt.selected.no_cumple{color:var(--red-700)}

/* Decisión hero */
.decision-hero{
  border-radius:14px;padding:28px 32px;color:#fff;
  position:relative;overflow:hidden;text-align:center;
}
.decision-hero::after{
  content:'';position:absolute;top:-50%;right:-15%;width:60%;height:200%;
  background:radial-gradient(circle,rgba(255,255,255,.18),transparent 60%);pointer-events:none;
}
.decision-hero.empty{background:linear-gradient(135deg,#4B5563 0%,#6B7280 100%)}
.decision-hero.aprobado{background:linear-gradient(135deg,#047857 0%,#10B981 100%)}
.decision-hero.aprobado_seguimiento{background:linear-gradient(135deg,#B45309 0%,#F59E0B 100%)}
.decision-hero.condicionado{background:linear-gradient(135deg,#C2410C 0%,#F97316 100%)}
.decision-hero.no_apto{background:linear-gradient(135deg,#991B1B 0%,#DC2626 100%)}
.decision-label{font-size:11px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;opacity:.75;position:relative}
.decision-title{font-size:34px;font-weight:800;letter-spacing:-.025em;margin-top:8px;position:relative}
.decision-sub{font-size:14px;opacity:.85;margin-top:7px;position:relative}
.decision-stats{display:inline-flex;gap:18px;margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,255,255,.18);position:relative;font-size:12.5px;font-family:var(--font-mono);opacity:.9}

/* Botón icono dentro de filas (eliminar, etc.) */
.btn-icon-row{
  width:28px;height:28px;border-radius:7px;
  border:1px solid transparent;background:transparent;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--n-500);transition:all .12s;
}
.btn-icon-row:hover{background:var(--red-50);color:var(--red-600);border-color:#FECACA}
.btn-icon-row.neutral:hover{background:var(--n-100);color:var(--n-900);border-color:var(--border-strong)}

/* Persist badge (footer status indicator) */
.persist-badge{
  position:fixed;bottom:14px;left:262px;z-index:40;
  display:flex;align-items:center;gap:6px;
  padding:5px 11px;border-radius:20px;
  background:rgba(255,255,255,.8);backdrop-filter:blur(10px);
  border:1px solid var(--border);box-shadow:var(--shadow-sm);
  font-size:11px;color:var(--n-600);font-weight:500;
}
.persist-badge::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--green-500);box-shadow:0 0 0 3px rgba(34,197,94,.18)}

/* Form sections */
.form-section{margin-bottom:18px}
.form-section + .form-section{padding-top:18px;border-top:1px solid var(--border)}
.form-section-title{
  font-size:10.5px;color:var(--n-500);font-weight:700;
  text-transform:uppercase;letter-spacing:.09em;margin-bottom:12px;
  display:flex;align-items:center;gap:6px;
}
.form-section-title::before{content:'';width:14px;height:1px;background:var(--n-300)}
.form-grid-3{display:grid;grid-template-columns:1fr 2fr;gap:12px}
.form-hint{font-size:11.5px;color:var(--n-500);margin-top:5px;line-height:1.5}

/* Scope selector cards */
.scope-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:9px}
.scope-card{cursor:pointer;display:block;position:relative}
.scope-card input{position:absolute;opacity:0;pointer-events:none}
.scope-card-inner{
  border:1.5px solid var(--border-strong);border-radius:11px;
  padding:13px;background:var(--surface);
  transition:all .15s;height:100%;
  display:flex;flex-direction:column;gap:7px;position:relative
}
.scope-card:hover .scope-card-inner{border-color:var(--n-400);background:var(--n-50)}
.scope-card input:checked + .scope-card-inner{
  border-color:var(--brand-500);background:linear-gradient(135deg,var(--brand-50),rgba(16,185,129,.04));
  box-shadow:0 0 0 3px rgba(16,185,129,.12);
}
.scope-card input:checked + .scope-card-inner::after{
  content:'';position:absolute;top:10px;right:10px;width:16px;height:16px;border-radius:50%;
  background:var(--brand-500) url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/10px no-repeat;
}
.scope-icon{
  width:32px;height:32px;border-radius:8px;background:var(--n-100);
  color:var(--n-600);display:flex;align-items:center;justify-content:center;
  transition:all .15s
}
.scope-card input:checked + .scope-card-inner .scope-icon{background:var(--brand-100);color:var(--brand-700)}
.scope-name{font-size:13px;font-weight:600;color:var(--n-900);letter-spacing:-.01em;margin-top:2px}
.scope-desc{font-size:11.5px;color:var(--n-500);line-height:1.45}
.scope-tag{margin-top:auto;font-size:10.5px;color:var(--n-600);font-weight:500;padding-top:6px;border-top:1px solid var(--border)}
.scope-card input:checked + .scope-card-inner .scope-tag{color:var(--brand-700);border-top-color:var(--brand-200)}

/* Esquema chip (in tables) */
.esq-chip{
  display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;
  font-size:11px;font-weight:600;letter-spacing:-.005em;border:1px solid;line-height:1.4
}
.esq-puntual{background:var(--amber-50);color:var(--amber-700);border-color:#FDE68A}
.esq-completo{background:var(--brand-50);color:var(--brand-700);border-color:var(--brand-200)}
.esq-evaluacion{background:var(--blue-50);color:var(--blue-700);border-color:#BFDBFE}

/* ════ Chip de Acceso al portal ════ */
.acc-chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:3px 10px;border-radius:99px;
  font-size:10.5px;font-weight:700;letter-spacing:.04em;
  border:1px solid var(--border);background:var(--n-50);color:var(--n-600);
  cursor:pointer;transition:all .15s;font-family:var(--font-sans);
  white-space:nowrap;
}
.acc-chip:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.acc-chip svg{flex-shrink:0}
.acc-chip.acc-on{
  background:var(--green-50);color:var(--green-700);border-color:#BBF7D0;
}
.acc-chip.acc-off{
  background:var(--n-100);color:var(--n-500);border-color:var(--border);
  border-style:dashed;
}
.acc-chip.acc-pend{
  background:var(--amber-50);color:var(--amber-700);border-color:#FDE68A;
}

/* ════ Modal Acceso al portal ════ */
.acc-modal-content{padding:20px 24px}
.acc-state-card{
  display:flex;align-items:center;gap:14px;
  padding:16px 18px;margin-bottom:18px;
  background:linear-gradient(135deg,var(--n-50),var(--surface));
  border:1px solid var(--border);border-radius:11px;
  position:relative;overflow:hidden;
}
.acc-state-card::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:4px;
  background:var(--n-300);
}
.acc-state-card.s-on::before{background:linear-gradient(180deg,var(--brand-500),var(--brand-700))}
.acc-state-card.s-on{background:linear-gradient(135deg,var(--brand-50),var(--surface));border-color:var(--brand-100)}
.acc-state-card.s-off::before{background:var(--n-300)}
.acc-state-icon{
  width:42px;height:42px;border-radius:11px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:var(--n-100);color:var(--n-500);border:1px solid var(--border);
}
.acc-state-card.s-on .acc-state-icon{
  background:linear-gradient(135deg,var(--brand-100),var(--brand-50));
  color:var(--brand-700);border-color:var(--brand-200);
}
.acc-state-info{flex:1;min-width:0}
.acc-state-label{
  font-size:9.5px;font-weight:800;color:var(--n-500);
  text-transform:uppercase;letter-spacing:.1em;
}
.acc-state-status{
  font-size:16px;font-weight:800;color:var(--n-900);margin-top:3px;letter-spacing:-.018em;
}
.acc-state-card.s-on .acc-state-status{color:var(--brand-700)}
.acc-state-meta{
  font-size:11px;color:var(--n-500);margin-top:3px;font-weight:500;
}

.acc-section{margin-bottom:14px}
.acc-section-title{
  font-size:10.5px;font-weight:700;color:var(--n-700);
  text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;
  display:flex;align-items:center;gap:6px;
}
.acc-section-title::before{
  content:'';width:14px;height:1px;background:var(--n-300);
}
.acc-cred-box{
  background:var(--n-900);color:#A7F3D0;
  border-radius:9px;padding:14px 16px;
  font-family:var(--font-mono);font-size:12px;
  display:grid;grid-template-columns:90px 1fr auto;gap:10px 12px;align-items:center;
  position:relative;
}
.acc-cred-box .lbl{
  font-size:9px;color:rgba(167,243,208,.5);
  text-transform:uppercase;letter-spacing:.1em;font-weight:700;
}
.acc-cred-box .val{
  color:#fff;font-weight:600;letter-spacing:.02em;
  word-break:break-all;
}
.acc-cred-box .copy{
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);
  color:#fff;cursor:pointer;border-radius:6px;
  padding:4px 9px;font-size:10px;font-weight:700;letter-spacing:.05em;
  transition:background .15s;text-transform:uppercase;
}
.acc-cred-box .copy:hover{background:rgba(255,255,255,.14)}

.acc-actions-row{display:flex;gap:8px;flex-wrap:wrap}

.acc-perm-list{display:flex;flex-direction:column;gap:6px}
.acc-perm-row{
  display:flex;align-items:center;gap:9px;
  padding:8px 11px;border-radius:8px;
  background:var(--n-50);border:1px solid var(--border);
  font-size:11.5px;color:var(--n-700);
}
.acc-perm-row svg{color:var(--brand-600);flex-shrink:0}
.acc-perm-row strong{color:var(--n-900);font-weight:700}

.acc-log{
  font-size:11px;color:var(--n-600);
  display:flex;flex-direction:column;gap:5px;
  padding:10px 12px;background:var(--n-50);border:1px solid var(--border);
  border-radius:7px;font-family:var(--font-mono);
}
.acc-log .empty{color:var(--n-400);font-style:italic;font-family:var(--font-sans)}

/* Botón con variante danger sutil */
.btn.btn-danger-soft{
  background:var(--red-50);color:var(--red-700);border:1px solid #FECACA;
}
.btn.btn-danger-soft:hover{background:var(--red-100);border-color:#F87171}


/* Filter bar */
.filter-bar{
  display:flex;align-items:center;gap:8px;
  margin-bottom:14px;padding:8px 10px;
  background:var(--surface);border:1px solid var(--border);border-radius:10px;
  box-shadow:var(--shadow-xs)
}
.filter-search{
  flex:1;position:relative;
}
.filter-search input{
  width:100%;padding:7px 11px 7px 32px;border:none;background:transparent;
  font-family:var(--font-sans);font-size:13px;outline:none;color:var(--n-900)
}
.filter-search input::placeholder{color:var(--n-400)}
.filter-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--n-400)}
.filter-divider{width:1px;height:20px;background:var(--border)}
.filter-chip-btn{
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 10px;border-radius:7px;border:1px solid var(--border);
  background:var(--surface);font-size:12px;font-weight:500;color:var(--n-700);
  cursor:pointer;transition:all .12s
}
.filter-chip-btn:hover{background:var(--n-50);border-color:var(--n-300)}
.filter-chip-btn.active{background:var(--brand-50);color:var(--brand-700);border-color:var(--brand-300)}

/* Modal */
.modal-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(15,23,42,.5);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  z-index:300;align-items:center;justify-content:center;padding:20px
}
.modal-overlay.show{display:flex;animation:fadeIn .15s}
.modal{
  background:var(--surface);border-radius:var(--r-2xl);
  width:100%;max-width:680px;max-height:92vh;overflow-y:auto;
  box-shadow:var(--shadow-xl);
  animation:modalIn .22s cubic-bezier(.4,0,.2,1)
}
.modal-wide{max-width:760px}
@keyframes modalIn{from{transform:translateY(8px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.modal-head{padding:20px 22px 8px}
.modal-title{font-size:17px;font-weight:700;color:var(--n-900);letter-spacing:-.02em}
.modal-sub{font-size:13px;color:var(--n-500);margin-top:4px;font-weight:400}
.modal-body{padding:14px 22px}
.modal-foot{padding:14px 22px 20px;display:flex;gap:8px;justify-content:flex-end;border-top:1px solid var(--border);margin-top:10px}

/* Drawer panel */
.drawer-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.4);backdrop-filter:blur(4px);z-index:200}
.drawer-overlay.show{display:block;animation:fadeIn .2s}
.drawer{
  position:fixed;right:0;top:0;width:560px;height:100vh;background:var(--surface);
  z-index:201;overflow-y:auto;box-shadow:var(--shadow-xl);
  animation:slideIn .25s cubic-bezier(.4,0,.2,1);display:none
}
.drawer.show{display:block}
@keyframes slideIn{from{transform:translateX(20px);opacity:0}to{transform:none;opacity:1}}
.drawer-head{
  padding:18px 22px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;background:var(--surface);z-index:1
}
.drawer-title{font-size:15px;font-weight:700;color:var(--n-900);letter-spacing:-.01em}
.drawer-close{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:var(--surface);cursor:pointer;color:var(--n-600);display:flex;align-items:center;justify-content:center;transition:all .12s}
.drawer-close:hover{background:var(--n-100);color:var(--n-900)}
.drawer-body{padding:18px 22px}

/* Info pairs */
.kv-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:18px}
.kv{background:var(--n-50);border:1px solid var(--border);border-radius:9px;padding:10px 12px}
.kv-k{font-size:10.5px;color:var(--n-500);font-weight:500;text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px}
.kv-v{font-size:13px;font-weight:600;color:var(--n-900)}

/* Doc rows */
.doc{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:9px;margin-bottom:5px;background:var(--n-50);border:1px solid var(--border)}
.doc-icon{width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.doc-info{flex:1;min-width:0}
.doc-title{font-size:13px;font-weight:600;color:var(--n-900)}
.doc-meta{font-size:11.5px;color:var(--n-500);margin-top:2px}

/* Section divider */
.divider{height:1px;background:var(--border);margin:18px 0}
.section-head{font-size:11px;font-weight:600;color:var(--n-500);text-transform:uppercase;letter-spacing:.07em;margin-bottom:10px;display:flex;align-items:center;justify-content:space-between}

/* Tabs */
.tabs{display:flex;gap:2px;padding:3px;background:var(--n-100);border-radius:9px;margin-bottom:18px;width:fit-content}
.tab{padding:6px 14px;border-radius:6px;cursor:pointer;font-size:12.5px;color:var(--n-600);font-weight:500;transition:all .12s}
.tab:hover{color:var(--n-900)}
.tab.active{background:var(--surface);color:var(--n-900);box-shadow:var(--shadow-xs);font-weight:600}

/* Notif — oculta por defecto, solo aparece con .show */
.notif{
  position:fixed;top:18px;right:18px;
  background:var(--n-900);color:#fff;padding:11px 16px;border-radius:10px;
  font-size:13px;font-weight:500;z-index:500;
  box-shadow:var(--shadow-xl);max-width:340px;
  display:none;align-items:center;gap:8px
}
.notif.show{display:flex;animation:notifIn .25s}
.notif.error{background:var(--red-600)}
@keyframes notifIn{from{transform:translateY(-8px);opacity:0}to{transform:none;opacity:1}}

/* Upload zone */
.uploader{
  border:2px dashed var(--border-strong);border-radius:var(--r-xl);
  padding:32px;text-align:center;cursor:pointer;
  background:var(--n-50);transition:all .15s
}
.uploader:hover{border-color:var(--brand-500);background:var(--brand-50)}
.uploader-icon{width:46px;height:46px;border-radius:11px;background:var(--surface);color:var(--brand-600);display:flex;align-items:center;justify-content:center;margin:0 auto 10px;box-shadow:var(--shadow-sm)}
.uploader-title{font-size:14px;font-weight:600;color:var(--n-900);margin-bottom:3px}
.uploader-sub{font-size:12px;color:var(--n-500)}

/* Report card */
.report-hero{
  background:linear-gradient(135deg,#022C22 0%,#064E3B 50%,#047857 100%);
  border-radius:var(--r-xl) var(--r-xl) 0 0;padding:24px 28px;color:#fff;
  position:relative;overflow:hidden
}
.report-hero::after{
  content:'';position:absolute;top:-50%;right:-10%;width:60%;height:200%;
  background:radial-gradient(circle,rgba(52,211,153,.18),transparent 60%);pointer-events:none
}
.report-hero-meta{font-size:11px;color:rgba(255,255,255,.5);font-weight:500;text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}
.report-hero-title{font-size:22px;font-weight:700;letter-spacing:-.02em;line-height:1.2;position:relative}
.report-hero-sub{font-size:13px;color:rgba(255,255,255,.7);margin-top:6px;font-weight:400;position:relative}
.report-hero-foot{display:flex;align-items:center;gap:14px;margin-top:18px;padding-top:14px;border-top:1px solid rgba(255,255,255,.12);position:relative}
.signed{display:flex;align-items:center;gap:8px;font-size:12px;color:rgba(255,255,255,.85)}
.signed-av{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#FB923C,#EA580C);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff}

.kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px}
.kpi{background:var(--n-50);border:1px solid var(--border);border-radius:10px;padding:14px 16px;text-align:center}
.kpi-val{font-size:22px;font-weight:700;color:var(--n-900);font-feature-settings:'tnum';letter-spacing:-.02em}
.kpi-lbl{font-size:11px;color:var(--n-500);margin-top:2px;font-weight:500}

/* Empty */
.empty{padding:60px 30px;text-align:center;color:var(--n-500)}
.empty-icon{width:56px;height:56px;border-radius:14px;background:var(--n-100);color:var(--n-500);display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.empty-title{font-size:15px;font-weight:600;color:var(--n-900);margin-bottom:4px}
.empty-sub{font-size:13px}

/* Avatar group */
.av-group{display:flex}
.av-group .org-avatar{margin-left:-8px;border:2px solid var(--surface)}
.av-group .org-avatar:first-child{margin-left:0}

/* Scrollbar */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--n-200);border-radius:99px;border:2px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:var(--n-300)}

@media (max-width:1100px){
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .two-col,.three-col{grid-template-columns:1fr}
}

/* ═══════════════════════ V5 · TOGGLE SIDEBAR / FULLSCREEN ═══════════════════════ */
/* Botón siempre dentro del área de contenido principal (no se superpone al sidebar) */
.sb-toggle{
  position:fixed;top:18px;z-index:90;
  width:34px;height:34px;border-radius:9px;
  background:var(--brand-50);border:1px solid var(--brand-200);
  color:var(--brand-700);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 1px 2px rgba(15,23,42,.04);
  transition:left .25s cubic-bezier(.4,0,.2,1), background .15s, color .15s, border-color .15s, transform .12s;
}
.sb-toggle:hover{
  background:var(--brand-100);border-color:var(--brand-400);
  color:var(--brand-800);
}
.sb-toggle:active{transform:scale(.94)}
/* Sidebar visible: botón pegado al borde derecho del sidebar (en el área del main) */
body:not(.sb-hidden) .sb-toggle{ left:264px; }
/* Sidebar oculto: botón al inicio del main */
body.sb-hidden .sb-toggle{ left:18px; }
/* Modo fullscreen: ocultar sidebar y reclamar espacio */
body.sb-hidden .sidebar{
  transform:translateX(-260px);
  pointer-events:none;
}
body.sb-hidden .main{
  margin-left:0 !important;
}
.sidebar{transition:transform .25s cubic-bezier(.4,0,.2,1)}
.main{transition:margin-left .25s cubic-bezier(.4,0,.2,1)}
/* Aire encima del título de cada página para que el botón no cubra el texto */
.main .content{padding-top:56px}

/* ═══════════════════════ V5 · VENCIMIENTOS / ALERTAS ═══════════════════════ */
.venc-pill{
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 9px;border-radius:99px;
  font-size:10.5px;font-weight:700;letter-spacing:.02em;text-transform:uppercase;
  font-family:var(--font-mono);
}
.venc-pill::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor}
.venc-vigente   {background:var(--green-50);color:var(--green-700);border:1px solid #BBF7D0}
.venc-por-vencer{background:var(--amber-50);color:var(--amber-700);border:1px solid #FDE68A}
.venc-vencido   {background:var(--red-50);  color:var(--red-700);  border:1px solid #FECACA}
.venc-sin       {background:var(--n-100);   color:var(--n-600);    border:1px solid var(--border)}

.alert-row{
  display:grid;grid-template-columns:auto 1fr auto auto auto;gap:14px;align-items:center;
  padding:14px 16px;border-bottom:1px solid var(--border);
  transition:background .12s;
}
.alert-row:hover{background:var(--n-50);cursor:pointer}
.alert-row:last-child{border-bottom:none}
.alert-icon{
  width:36px;height:36px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.alert-icon.crit{background:var(--red-50);color:var(--red-600);border:1px solid #FECACA}
.alert-icon.warn{background:var(--amber-50);color:var(--amber-600);border:1px solid #FDE68A}
.alert-icon.info{background:var(--blue-50);color:var(--blue-600);border:1px solid #BFDBFE}
.alert-title{font-size:13.5px;font-weight:600;color:var(--n-900);line-height:1.35}
.alert-meta{font-size:11.5px;color:var(--n-500);margin-top:3px}
.alert-meta strong{color:var(--n-700);font-weight:600}
.alert-days{
  font-family:var(--font-mono);font-size:12px;font-weight:700;
  padding:5px 10px;border-radius:7px;white-space:nowrap;
}

.alert-summary{
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:18px;
}
.alert-kpi{
  background:var(--surface);border:1px solid var(--border);border-radius:11px;
  padding:14px 16px;display:flex;align-items:flex-start;gap:11px;
}
.alert-kpi .ak-icon{
  width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.alert-kpi.k-crit .ak-icon{background:var(--red-50);color:var(--red-600)}
.alert-kpi.k-warn .ak-icon{background:var(--amber-50);color:var(--amber-600)}
.alert-kpi.k-ok   .ak-icon{background:var(--green-50);color:var(--green-700)}
.alert-kpi.k-info .ak-icon{background:var(--blue-50);color:var(--blue-700)}
.alert-kpi .ak-val{font-size:22px;font-weight:700;color:var(--n-900);line-height:1;font-feature-settings:'tnum';letter-spacing:-.02em}
.alert-kpi .ak-lbl{font-size:11px;color:var(--n-500);margin-top:3px;font-weight:500;text-transform:uppercase;letter-spacing:.04em}

.alert-tabs{
  display:flex;gap:2px;padding:3px;background:var(--n-100);
  border-radius:9px;margin-bottom:14px;width:fit-content;
}
.alert-tab{
  padding:6px 14px;border-radius:7px;cursor:pointer;
  font-size:12px;color:var(--n-600);font-weight:600;
  transition:all .12s;display:inline-flex;align-items:center;gap:6px;
  background:transparent;border:none;
}
.alert-tab:hover{color:var(--n-900)}
.alert-tab.active{background:var(--surface);color:var(--n-900);box-shadow:var(--shadow-xs)}
.alert-tab-count{
  font-family:var(--font-mono);font-size:10.5px;font-weight:700;
  padding:1px 7px;border-radius:99px;background:var(--n-200);color:var(--n-700);
}
.alert-tab.active .alert-tab-count{background:var(--brand-100);color:var(--brand-800)}

/* ═══════════════════════ V5 · VALIDACIÓN EXPERTA ═══════════════════════ */
.aud-numeral{
  background:var(--surface);border:1px solid var(--border);border-radius:14px;
  margin-bottom:14px;overflow:hidden;
  transition:border-color .15s, box-shadow .15s;
}
.aud-numeral.cumple{border-color:#BBF7D0;background:linear-gradient(180deg,var(--green-50) 0%,#fff 22%)}
.aud-numeral.parcial{border-color:#FDE68A;background:linear-gradient(180deg,var(--amber-50) 0%,#fff 22%)}
.aud-numeral.no_cumple{border-color:#FECACA;background:linear-gradient(180deg,var(--red-50) 0%,#fff 22%)}
.aud-num-head{
  padding:14px 18px;display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;
  border-bottom:1px solid var(--border);
}
.aud-num-badge{
  width:38px;height:38px;border-radius:10px;
  background:var(--n-900);color:#fff;font-weight:800;font-size:14px;
  display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);
  letter-spacing:-.01em;flex-shrink:0;
}
.aud-numeral.cumple .aud-num-badge{background:var(--green-700)}
.aud-numeral.parcial .aud-num-badge{background:var(--amber-700)}
.aud-numeral.no_cumple .aud-num-badge{background:var(--red-700)}
.aud-num-title{font-size:13.5px;font-weight:700;color:var(--n-900);letter-spacing:-.005em;line-height:1.35}
.aud-num-sub{font-size:11.5px;color:var(--n-500);margin-top:3px;line-height:1.45}
.aud-num-body{padding:14px 18px}
.aud-options{display:flex;gap:6px;flex-wrap:wrap}
.aud-opt{
  padding:7px 13px;border-radius:9px;border:1.5px solid var(--border);
  background:var(--surface);font-size:12px;font-weight:600;color:var(--n-700);
  cursor:pointer;transition:all .12s;display:inline-flex;align-items:center;gap:6px;
}
.aud-opt:hover{border-color:var(--n-400)}
.aud-opt.selected.cumple    {background:var(--green-600);color:#fff;border-color:var(--green-700)}
.aud-opt.selected.parcial   {background:var(--amber-600);color:#fff;border-color:var(--amber-700)}
.aud-opt.selected.no_cumple {background:var(--red-600);color:#fff;border-color:var(--red-700)}
.aud-num-obs{
  width:100%;margin-top:11px;padding:9px 12px;font-size:12.5px;
  border:1px solid var(--border);border-radius:9px;background:var(--n-50);
  font-family:var(--font-sans);resize:vertical;min-height:60px;color:var(--n-800);
}
.aud-num-obs:focus{border-color:var(--brand-500);background:#fff;box-shadow:var(--ring)}
.aud-num-evid{
  display:flex;align-items:center;gap:8px;margin-top:9px;
  font-size:11.5px;color:var(--n-500);
}
.aud-num-evid input{
  flex:1;padding:6px 9px;font-size:11.5px;border:1px solid var(--border);
  border-radius:7px;font-family:var(--font-sans);background:var(--surface);
}
.aud-num-evid input:focus{border-color:var(--brand-500);box-shadow:var(--ring)}

.aud-summary{
  background:linear-gradient(135deg,var(--brand-900) 0%,var(--brand-700) 100%);
  border-radius:14px;padding:22px 26px;color:#fff;margin-bottom:18px;
  display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;
}
.aud-summary-num{font-size:42px;font-weight:800;letter-spacing:-.03em;font-feature-settings:'tnum';line-height:1}
.aud-summary-lbl{font-size:11px;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin-bottom:4px}
.aud-summary-sub{font-size:12.5px;color:rgba(255,255,255,.85);margin-top:4px}
.aud-summary-meta{display:flex;flex-direction:column;gap:6px}
.aud-summary-row{display:flex;align-items:center;gap:8px;font-size:12.5px}
.aud-summary-row strong{color:#fff;font-weight:700}
.aud-summary-tag{
  padding:5px 11px;border-radius:99px;font-size:10.5px;font-weight:700;
  text-transform:uppercase;letter-spacing:.04em;
  background:rgba(255,255,255,.16);color:#fff;backdrop-filter:blur(6px);
}
.aud-summary-tag.t-cumple {background:rgba(187,247,208,.22);color:#BBF7D0}
.aud-summary-tag.t-parcial{background:rgba(253,230,138,.22);color:#FDE68A}
.aud-summary-tag.t-no     {background:rgba(254,202,202,.22);color:#FECACA}
.aud-summary-actions{display:flex;flex-direction:column;gap:8px}

.aud-firma{
  background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:18px 22px;
  margin-top:18px;
}
.aud-firma-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.aud-firma-grid .form-group{margin:0}
.aud-firma-foot{
  padding-top:14px;border-top:1px dashed var(--border);
  display:flex;align-items:center;justify-content:space-between;gap:14px;
}
.aud-firma-state{font-size:12.5px;color:var(--n-600);display:flex;align-items:center;gap:8px}
.aud-firma-state.signed{color:var(--green-700)}

/* ═══════════════════════════════════════════════════════════
   SPLIT VIEWS · Responsive + Login + Admin Back Button
   ═══════════════════════════════════════════════════════════ */
@media (max-width:1180px){.content{padding:18px 20px 36px;max-width:100%}.two-col,.three-col{grid-template-columns:1fr}.form-grid{grid-template-columns:1fr}.page-head{align-items:stretch;flex-direction:column}.page-actions{flex-wrap:wrap}.dim-grid{grid-template-columns:repeat(2,1fr)}.ctd-score-card .card-body>div{grid-template-columns:1fr!important;gap:16px!important}}
@media (max-width:760px){.stat-grid,.cli-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}.cli-charts-grid{grid-template-columns:1fr!important}.cli-chart-wide{grid-column:auto!important}.filter-bar{align-items:stretch;flex-direction:column}.filter-search{max-width:none;width:100%}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}table{min-width:760px}.modal{width:calc(100vw - 24px);max-height:calc(100vh - 24px)}.drawer{width:100vw;max-width:100vw}.risk-cards{grid-template-columns:1fr}.ctd-timeline{min-width:920px}.ctd-timeline-body{overflow-x:auto}.portal-hero{padding:24px 20px}.portal-hero-title{font-size:24px}}
@media (max-width:560px){html{font-size:13px}.sidebar{transform:translateX(-100%);transition:transform .22s ease;box-shadow:var(--shadow-xl)}body.sb-open .sidebar{transform:translateX(0)}.main{margin-left:0}.sb-toggle{display:flex!important;left:14px;top:14px}.content{padding:64px 10px 28px}.stat-grid,.cli-kpi-grid{grid-template-columns:1fr!important}.card-head,.card-body{padding-left:14px;padding-right:14px}.btn{width:100%}.page-actions .btn,.card-actions .btn{width:auto}.portal-progress-card{align-items:flex-start;flex-direction:column}.portal-progress-pct{align-self:flex-end}.doc-item{grid-template-columns:1fr;gap:10px}.doc-item-actions{justify-content:flex-start;flex-wrap:wrap}.form-grid{gap:8px}}
body.portal-view .main{margin-left:0}body.portal-view .content{max-width:1180px;margin:0 auto}body.portal-view .sb-toggle{display:none!important}
.login-page{min-height:100vh;margin:0;background:var(--n-950,#020617);font-family:var(--font-sans,'Inter',sans-serif);overflow-x:hidden;color:var(--n-900,#111827)}.login-page .pagina_principal{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}.login-page .panel_izquierdo{background:radial-gradient(circle at 28% 52%,rgba(16,185,129,.23),transparent 34%),radial-gradient(circle at 76% 24%,rgba(52,211,153,.18),transparent 30%),linear-gradient(160deg,#022C22 0%,#064E3B 50%,#0F172A 100%);display:flex;align-items:center;justify-content:center;padding:56px;position:relative;overflow:hidden}.login-page .panel_izquierdo__contenido{text-align:center;position:relative;z-index:1;max-width:540px}.login-page .login-brand-mark{display:inline-flex;margin-bottom:22px;padding:8px 14px;border-radius:999px;border:1px solid rgba(209,250,229,.22);background:rgba(2,44,34,.45);color:#D1FAE5;font-size:11px;font-weight:800;letter-spacing:.22em;text-transform:uppercase}.login-page .panel_izquierdo__titulo{font-family:var(--font-sans,'Inter',sans-serif);font-size:64px;line-height:.95;color:#fff;letter-spacing:-.055em;margin:0 0 18px;font-weight:800}.login-page .panel_izquierdo__subtitulo{font-size:15px;line-height:1.7;color:rgba(236,253,245,.72);margin:0 0 28px}.login-page .panel_izquierdo__decoracion{width:48px;height:4px;background:linear-gradient(90deg,var(--brand-400,#34D399),var(--brand-600,#059669));border-radius:999px;margin:0 auto;box-shadow:0 0 24px rgba(52,211,153,.34)}.login-page .panel_derecho{background:linear-gradient(180deg,#fff 0%,#F8FAFC 100%);display:flex;align-items:center;justify-content:center;padding:56px 40px}.login-page .bloque_iniciosesion{width:100%;max-width:430px;display:flex;flex-direction:column;gap:26px;background:rgba(255,255,255,.86);border:1px solid var(--border,#E5E7EB);border-radius:22px;padding:34px;box-shadow:var(--shadow-xl,0 24px 70px rgba(15,23,42,.16));backdrop-filter:blur(12px)}.login-page .bloque_iniciosesion__titulo{font-size:34px;line-height:1;letter-spacing:-.04em;color:var(--n-950,#020617);margin:0;font-weight:800}.login-page .bloque_iniciosesion__descripcion{font-size:13.5px;color:var(--n-500,#6B7280);margin:7px 0 0;line-height:1.55}.login-page .formulario_sesion{display:flex;flex-direction:column;gap:16px}.login-page .formulario_sesion__campo{display:flex;flex-direction:column;gap:6px}.login-page .campo__etiqueta{font-size:11px;font-weight:800;color:var(--n-700,#374151);letter-spacing:.09em;text-transform:uppercase}.login-page .campo__contenedor_input{display:flex;align-items:center;background:var(--n-50,#F9FAFB);border:1px solid var(--border,#E5E7EB);border-radius:12px;overflow:hidden}.login-page .campo__contenedor_input:focus-within{border-color:var(--brand-500,#10B981);box-shadow:0 0 0 4px rgba(16,185,129,.14);background:#fff}.login-page .campo__contenedor_input--error{border-color:var(--red-500,#EF4444);background:#FEF2F2}.login-page .campo__icono{display:flex;align-items:center;justify-content:center;padding:0 14px;color:var(--n-400,#9CA3AF);flex-shrink:0}.login-page .campo__icono svg,.login-page .icono_ojo{width:18px;height:18px}.login-page .campo__input{flex:1;background:transparent;border:0;outline:0;font-size:14px;color:var(--n-900,#111827);padding:13px 14px 13px 0;line-height:1.45;min-width:0}.login-page .campo__boton_ver{display:flex;align-items:center;justify-content:center;padding:0 14px;color:var(--n-500,#6B7280);border:0;background:transparent;cursor:pointer}.login-page .campo__mensaje_error{font-size:12px;color:var(--red-600,#DC2626);font-weight:700;display:block;min-height:17px;padding-left:3px;opacity:0;transform:translateY(-3px);transition:.22s}.login-page .campo__mensaje_error--visible{opacity:1;transform:translateY(0)}.login-page .formulario_sesion__opciones{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}.login-page .opcion_recordar{display:flex;align-items:center;gap:8px;cursor:pointer}.login-page .opcion_recordar__checkbox{appearance:none;-webkit-appearance:none;width:17px;height:17px;border:1px solid var(--border-strong,#D1D5DB);border-radius:5px;background:#fff;cursor:pointer;position:relative}.login-page .opcion_recordar__checkbox:checked{background:var(--brand-600,#059669);border-color:var(--brand-600,#059669)}.login-page .opcion_recordar__checkbox:checked::after{content:"";position:absolute;left:5px;top:2px;width:5px;height:9px;border:2px solid #fff;border-top:0;border-left:0;transform:rotate(45deg)}.login-page .opcion_recordar__texto,.login-page .enlace_olvide{font-size:13px;color:var(--n-500,#6B7280)}.login-page .enlace_olvide{color:var(--brand-700,#047857);font-weight:700}.login-page .boton_ingresar{width:100%;padding:14px 24px;background:linear-gradient(135deg,var(--brand-600,#059669),var(--brand-700,#047857));color:#fff;border-radius:12px;font-size:13px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;margin-top:4px;border:0;cursor:pointer;transition:.22s}.login-page .boton_ingresar:hover{box-shadow:0 12px 30px rgba(5,150,105,.32);transform:translateY(-2px)}.login-demo-users{margin:0;padding:12px 14px;border:1px dashed var(--border,#E5E7EB);border-radius:12px;background:var(--n-50,#F9FAFB);font-size:12px;line-height:1.55;color:var(--n-500,#6B7280);text-align:center}.login-demo-users strong{color:var(--n-800,#1F2937)}@media (max-width:768px){.login-page .pagina_principal{grid-template-columns:1fr}.login-page .panel_izquierdo{display:none}.login-page .panel_derecho{min-height:100vh;padding:28px 16px}.login-page .bloque_iniciosesion{max-width:520px;padding:26px}.login-page .formulario_sesion__opciones{align-items:flex-start;flex-direction:column}}
.auth-bar{position:relative;top:auto;right:auto;z-index:10;display:flex;align-items:center;justify-content:flex-end;gap:8px;width:max-content;max-width:calc(100% - 32px);margin:14px 16px 0 auto;padding:7px;background:rgba(255,255,255,.92);border:1px solid var(--border,#E5E7EB);border-radius:999px;box-shadow:var(--shadow-sm,0 1px 3px rgba(15,23,42,.08));backdrop-filter:blur(12px)}.auth-bar__logout,.auth-bar__admin{height:30px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;font-size:11px;font-weight:800;padding:0 13px;text-decoration:none;cursor:pointer}.auth-bar__logout{border:1px solid #FECACA;background:var(--red-50,#FEF2F2);color:var(--red-700,#B91C1C)}.auth-bar__logout:hover{background:#FEE2E2}.auth-bar__admin{border:1px solid var(--brand-300,#6EE7B7);background:var(--brand-50,#ECFDF5);color:var(--brand-700,#047857)}.auth-bar__admin:hover{background:#D1FAE5;border-color:var(--brand-400,#34D399)}@media (max-width:560px){.auth-bar{margin:10px 10px 0 auto;border-radius:14px}}
