/* ============================================================================
   JuridicoDigital.cl — Portal ADMIN (backoffice). Estilos de layout.
   Tabular sobrio, acento navy (--jd-accent = navy vía data-portal="admin").
   Usa exclusivamente los tokens --jd-* de brand-tokens.css.
   ============================================================================ */

* { box-sizing: border-box; }
body { margin: 0; }
a { color: var(--jd-accent); }

/* ---- Header ---- */
.jd-header__inner {
  width: 100%; max-width: var(--jd-container); margin: 0 auto;
  display: flex; align-items: center; gap: var(--jd-sp-4);
  padding: 0 var(--jd-sp-5);
}
.jd-brand { font-family: var(--jd-font-display); font-size: 1.2rem; text-decoration: none;
  display: inline-flex; align-items: baseline; gap: 4px; white-space: nowrap; }
.jd-brand__j { color: var(--jd-cream); font-weight: var(--jd-fw-bold); letter-spacing: .04em; }
.jd-brand__d { color: var(--jd-gold); font-weight: var(--jd-fw-bold); letter-spacing: .04em; }
.jd-brand__tag { font-family: var(--jd-font-body); font-size: var(--jd-fs-xs);
  text-transform: uppercase; letter-spacing: var(--jd-tracking-caps); color: var(--jd-cream-text); }

.jd-nav { display: flex; flex-wrap: wrap; gap: var(--jd-sp-3); flex: 1; }
.jd-nav a { color: var(--jd-cream-text); text-decoration: none; font-size: var(--jd-fs-sm);
  font-weight: var(--jd-fw-medium); padding: var(--jd-sp-1) var(--jd-sp-2); border-radius: var(--jd-radius-sm); }
.jd-nav a:hover { color: var(--jd-white); background: var(--jd-navy-deep); }

.jd-user { color: var(--jd-cream-text); font-size: var(--jd-fs-sm); white-space: nowrap; }
.jd-user a { color: var(--jd-gold); margin-left: var(--jd-sp-3); text-decoration: none; }
.jd-user a:hover { text-decoration: underline; }

/* ---- Main ---- */
.jd-main { width: 100%; max-width: var(--jd-container); margin: 0 auto;
  padding: var(--jd-sp-6) var(--jd-sp-5); min-height: 60vh; }
.jd-page-head { display: flex; align-items: center; justify-content: space-between;
  gap: var(--jd-sp-4); margin-bottom: var(--jd-sp-5); flex-wrap: wrap; }
.jd-page-head h1 { margin: 0; font-size: var(--jd-fs-h1); }
h2 { font-size: var(--jd-fs-h2); }

/* ---- Notificaciones ---- */
.jd-notif { max-width: var(--jd-container); margin: var(--jd-sp-3) auto 0; padding: var(--jd-sp-3) var(--jd-sp-5);
  border-radius: var(--jd-radius); font-size: var(--jd-fs-sm); border: 1px solid var(--jd-border); background: var(--jd-surface-alt); }
.jd-notif--exito { background: #E7F4E8; border-color: var(--jd-success); color: #1B5E20; }
.jd-notif--error { background: #FBE7E9; border-color: var(--jd-danger); color: var(--jd-danger); }
.jd-notif--advertencia { background: #FFF3E0; border-color: var(--jd-warning); color: var(--jd-warning); }

/* ---- Tarjetas ---- */
.jd-card { background: var(--jd-surface); border: 1px solid var(--jd-border);
  border-radius: var(--jd-radius-lg); box-shadow: var(--jd-shadow-sm); padding: var(--jd-sp-5); margin-bottom: var(--jd-sp-5); }

/* ---- KPIs ---- */
.jd-kpis { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: var(--jd-sp-4); }
.jd-kpi { background: var(--jd-surface); border: 1px solid var(--jd-border); border-left: 4px solid var(--jd-accent);
  border-radius: var(--jd-radius); padding: var(--jd-sp-4); }
.jd-kpi__valor { font-family: var(--jd-font-display); font-size: 2rem; color: var(--jd-navy); line-height: 1; }
.jd-kpi__rotulo { font-size: var(--jd-fs-sm); color: var(--jd-muted); margin-top: var(--jd-sp-2); }

/* ---- Tablas ---- */
.jd-table { width: 100%; border-collapse: collapse; background: var(--jd-surface);
  border: 1px solid var(--jd-border); border-radius: var(--jd-radius); overflow: hidden; }
.jd-table th, .jd-table td { padding: var(--jd-sp-3) var(--jd-sp-4); text-align: left;
  font-size: var(--jd-fs-sm); border-bottom: 1px solid var(--jd-border); vertical-align: middle; }
.jd-table thead th { background: var(--jd-navy); color: var(--jd-cream); font-weight: var(--jd-fw-semibold);
  text-transform: uppercase; letter-spacing: .04em; font-size: var(--jd-fs-xs); }
.jd-table tbody tr:nth-child(even) { background: var(--jd-surface-alt); }
.jd-table tbody tr:hover { background: #EEF1F6; }
.jd-table td.num { text-align: right; font-variant-numeric: tabular-nums; }
.jd-table .acciones { white-space: nowrap; text-align: right; }
.jd-empty { color: var(--jd-muted); font-style: italic; padding: var(--jd-sp-4); }

/* ---- Botones ---- */
.jd-btn { display: inline-flex; align-items: center; gap: var(--jd-sp-2); padding: var(--jd-sp-2) var(--jd-sp-4);
  border-radius: var(--jd-radius); font-weight: var(--jd-fw-semibold); border: 1px solid transparent;
  cursor: pointer; transition: var(--jd-transition); text-decoration: none; font-size: var(--jd-fs-sm);
  font-family: var(--jd-font-body); }
.jd-btn--primary { background: var(--jd-navy); color: var(--jd-cream); }
.jd-btn--primary:hover { background: var(--jd-navy-deep); }
.jd-btn--secondary { background: transparent; color: var(--jd-navy); border-color: var(--jd-navy); }
.jd-btn--secondary:hover { background: var(--jd-navy); color: var(--jd-cream); }
.jd-btn--gold { background: var(--jd-gold); color: var(--jd-navy); }
.jd-btn--gold:hover { background: var(--jd-gold-light); }
.jd-btn--sm { padding: 2px var(--jd-sp-3); font-size: var(--jd-fs-xs); }
.jd-btn--danger { background: transparent; color: var(--jd-danger); border-color: var(--jd-danger); }
.jd-btn--danger:hover { background: var(--jd-danger); color: var(--jd-white); }
.jd-btn:focus-visible { outline: none; box-shadow: var(--jd-ring); }

/* ---- Formularios ---- */
.jd-form { max-width: var(--jd-container-narrow); }
.jd-field { margin-bottom: var(--jd-sp-4); }
.jd-field label { display: block; font-weight: var(--jd-fw-semibold); font-size: var(--jd-fs-sm);
  margin-bottom: var(--jd-sp-2); color: var(--jd-ink); }
.jd-field input[type=text], .jd-field input[type=email], .jd-field input[type=password],
.jd-field input[type=number], .jd-field input[type=date], .jd-field select, .jd-field textarea {
  width: 100%; padding: var(--jd-sp-3); border: 1px solid var(--jd-border); border-radius: var(--jd-radius);
  font-family: var(--jd-font-body); font-size: var(--jd-fs-body); background: var(--jd-white); color: var(--jd-ink); }
.jd-field textarea { min-height: 96px; resize: vertical; }
.jd-field input:focus, .jd-field select:focus, .jd-field textarea:focus { outline: none; box-shadow: var(--jd-ring); border-color: var(--jd-accent); }
.jd-field--check { display: flex; align-items: center; gap: var(--jd-sp-2); }
.jd-field--check label { margin: 0; }
.jd-field .ayuda { font-size: var(--jd-fs-xs); color: var(--jd-muted); margin-top: var(--jd-sp-1); }
.jd-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--jd-sp-4); }
.jd-form-actions { display: flex; gap: var(--jd-sp-3); margin-top: var(--jd-sp-5); }
.field-validation-error, .jd-error { color: var(--jd-danger); font-size: var(--jd-fs-sm); }
.input-validation-error { border-color: var(--jd-danger) !important; }
.jd-login { max-width: 380px; margin: var(--jd-sp-8) auto; }

/* ---- Badges auxiliares ---- */
.jd-pill { display: inline-block; padding: 1px var(--jd-sp-3); border-radius: var(--jd-radius-pill);
  font-size: var(--jd-fs-xs); font-weight: var(--jd-fw-semibold); background: var(--jd-surface-alt); color: var(--jd-muted); }
.jd-pill--si { background: #E7F4E8; color: #1B5E20; }
.jd-pill--no { background: #FBE7E9; color: var(--jd-danger); }

.jd-footer { text-align: center; color: var(--jd-muted); font-size: var(--jd-fs-xs);
  padding: var(--jd-sp-5); border-top: 1px solid var(--jd-border); margin-top: var(--jd-sp-6); }

/* ---- Responsive ---- */
@media (max-width: 768px) {
  .jd-grid-2 { grid-template-columns: 1fr; }
  .jd-header { height: auto; }
  .jd-header__inner { flex-wrap: wrap; padding: var(--jd-sp-3); }
  .jd-table { display: block; overflow-x: auto; white-space: nowrap; }
}
