:root { --bg:#f6f8fb; --card:#fff; --txt:#222; --muted:#666; --pri:#0ea5e9; }
*{box-sizing:border-box} body{font-family:system-ui,Arial; background:var(--bg); color:var(--txt); margin:0}
.container{max-width:980px;margin:32px auto;padding:0 16px}
.card{background:var(--card);border:1px solid #e5e7eb;border-radius:14px;padding:20px;box-shadow:0 4px 18px rgba(0,0,0,.04)}
input,button{font:inherit}
.input{width:100%;padding:12px;border:1px solid #d1d5db;border-radius:10px}
.row{display:flex;gap:12px;align-items:center}
.btn{background:var(--pri);color:#fff;border:none;padding:12px 16px;border-radius:10px;cursor:pointer}
.btn:disabled{opacity:.6;cursor:not-allowed}
.muted{color:var(--muted)}
.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}
.kpi{padding:16px;border-radius:12px;border:1px dashed #e5e7eb}
.kpi h3{margin:0 0 6px 0;font-size:18px}

/* ====== Banquito UI – Personas (Aportantes) ====== */
:root{
  --bg:#f6f7fb;
  --card:#ffffff;
  --ink:#101828;
  --muted:#667085;
  --primary:#0ea5e9;      /* celeste */
  --primary-ink:#0b76a8;
  --danger:#ef4444;
  --danger-ink:#b91c1c;
  --ring:#e5e7eb;
  --shadow: 0 8px 24px rgba(16,24,40,.06);
  --radius:16px;
}

body{ background:var(--bg); color:var(--ink); }
.container{ max-width:1200px; margin:34px auto; padding:0 20px; }

.page-title{
  font-size:28px; line-height:1.2; font-weight:800; letter-spacing:.1px;
  margin:0 0 16px 0;
}

.toolbar{
  display:flex; gap:12px; align-items:center; justify-content:space-between;
  background:var(--card); border:1px solid var(--ring); border-radius:var(--radius);
  padding:14px 16px; box-shadow:var(--shadow);
}

/* inputs */
.input{
  height:44px; border:1px solid var(--ring); border-radius:12px; padding:0 14px;
  font-size:14px; outline:none; min-width:280px; background:#fff;
}
.input:focus{ border-color:var(--primary); box-shadow:0 0 0 3px rgba(14,165,233,.2); }

/* botones */
.btn{
  height:44px; padding:0 16px; border-radius:12px; border:1px solid transparent;
  background:#fff; color:var(--ink); font-weight:600; cursor:pointer;
  display:inline-flex; align-items:center; gap:8px; text-decoration:none;
}
.btn:active{ transform:translateY(1px); }

.btn-primary{ background:var(--primary); color:#fff; }
.btn-primary:hover{ background:#06a2df; }
.btn-outline{ border-color:var(--ring); }
.btn-outline:hover{ border-color:var(--primary); color:var(--primary-ink); }
.btn-danger{ background:var(--danger); color:#fff; }
.btn-danger:hover{ background:#e63535; }

.people-grid{
  margin-top:16px;
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:16px;
}
@media (max-width:1200px){ .people-grid{ grid-template-columns:repeat(9,1fr);} }
@media (max-width:900px){  .people-grid{ grid-template-columns:repeat(6,1fr);} }
@media (max-width:640px){  .people-grid{ grid-template-columns:repeat(1,1fr);} }

/* tarjeta de persona */
.card-person{
  grid-column:span 4;
  background:var(--card); border:1px solid var(--ring); border-radius:var(--radius);
  padding:16px; box-shadow:var(--shadow);
  display:flex; flex-direction:column; gap:12px;
}
@media (max-width:900px){ .card-person{ grid-column:span 6; } }
@media (max-width:640px){ .card-person{ grid-column:span 1; } }

.person-head{ display:flex; align-items:center; gap:12px; }
.avatar{
  width:46px; height:46px; border-radius:12px; background:#e0f2fe; color:#0369a1;
  display:grid; place-items:center; font-weight:800; letter-spacing:.3px;
  border:1px solid #bae6fd;
}
.person-name{ font-size:16px; font-weight:800; line-height:1.2; }
.person-sub{ color:var(--muted); font-size:13px; }

.meta{ display:grid; row-gap:6px; }
.meta-row{ display:flex; gap:8px; align-items:center; font-size:14px; color:var(--ink); }
.meta-label{ color:var(--muted); width:62px; }

.card-actions{
  margin-top:4px; display:flex; gap:8px; justify-content:flex-end; flex-wrap:wrap;
}

/* vacío */
.empty{
  margin-top:18px; padding:24px; border:1px dashed var(--ring);
  border-radius:var(--radius); text-align:center; color:var(--muted);
  background:#fff;
}
