:root{
  --bg:#f6f7f9; --panel:#ffffff; --ink:#1f2330; --muted:#6b7280;
  --line:#e5e7eb; --accent:#0d6efd; --accent-ink:#fff;
  --amarillo:#fff6c2; --amarillo-bd:#f2d600;
  --radius:14px; --shadow:0 1px 3px rgba(16,24,40,.06),0 1px 2px rgba(16,24,40,.04);
  --shadow-h:0 6px 20px rgba(16,24,40,.10);
  font-size:15px;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg); color:var(--ink); display:flex; min-height:100vh;
}
a{color:inherit}

/* ---------- Sidebar ---------- */
.sidebar{
  width:230px; flex:0 0 230px; background:var(--panel); border-right:1px solid var(--line);
  padding:18px 12px; position:sticky; top:0; height:100vh; overflow:auto;
}
.brand{font-weight:700; font-size:1.05rem; padding:6px 10px 16px; letter-spacing:.2px}
.brand small{display:block; font-weight:500; color:var(--muted); font-size:.72rem; margin-top:2px}
.nav a{
  display:flex; align-items:center; gap:10px; padding:9px 12px; border-radius:10px;
  text-decoration:none; color:var(--ink); font-weight:500; margin-bottom:2px;
}
.nav a:hover{background:#f0f1f4}
.nav a.active{background:#eef2ff; color:var(--accent)}
.nav a .ic{font-size:1.05rem; width:22px; text-align:center}

/* ---------- Main ---------- */
.main{flex:1; padding:28px 34px; max-width:1280px; margin:0 auto; width:100%}
.page-head{display:flex; align-items:center; gap:12px; margin-bottom:6px}
.page-head h1{font-size:1.7rem; margin:0}
.page-sub{color:var(--muted); margin:0 0 22px}

/* ---------- Grid de columnas (tipo Trello) ---------- */
.cols{display:grid; grid-template-columns:repeat(auto-fill,minmax(330px,1fr)); gap:20px; align-items:start}
.col-wide{grid-column:1/-1}

/* ---------- Panel / card ---------- */
.panel{background:var(--panel); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); overflow:hidden}
.panel>header{display:flex; align-items:center; justify-content:space-between; padding:14px 16px; border-bottom:1px solid var(--line)}
.panel>header h2{font-size:1rem; margin:0; display:flex; align-items:center; gap:8px}
.panel .body{padding:12px 16px}
.panel .empty{color:var(--muted); font-size:.9rem; padding:8px 2px}

/* ---------- Cards internas ---------- */
.card{
  background:#fff; border:1px solid var(--line); border-radius:11px; padding:11px 12px;
  margin-bottom:10px; box-shadow:var(--shadow); transition:box-shadow .15s, transform .05s;
}
.card:hover{box-shadow:var(--shadow-h)}
.card .t{font-weight:600}
.card .m{color:var(--muted); font-size:.84rem; margin-top:2px}
.card .row{display:flex; justify-content:space-between; align-items:flex-start; gap:10px}
.card.amarillo{background:var(--amarillo); border-color:var(--amarillo-bd)}
.card.tachado .t,.card.tachado .m{text-decoration:line-through; color:var(--muted)}

.badge{display:inline-block; font-size:.7rem; font-weight:600; padding:2px 8px; border-radius:999px; background:#eef2ff; color:var(--accent)}
.badge.gray{background:#f1f2f4; color:var(--muted)}
.badge.green{background:#e7f6ec; color:#198754}
.badge.red{background:#fde8e8; color:#d63384}
.badge.orange{background:#fff1e3; color:#fd7e14}

/* ---------- Botones ---------- */
.btn{
  border:1px solid var(--line); background:#fff; color:var(--ink); border-radius:9px;
  padding:7px 13px; font-size:.86rem; font-weight:600; cursor:pointer; text-decoration:none;
  display:inline-flex; align-items:center; gap:6px; transition:.12s;
}
.btn:hover{background:#f4f5f7}
.btn.primary{background:var(--accent); color:#fff; border-color:transparent}
.btn.primary:hover{filter:brightness(.95)}
.btn.sm{padding:4px 9px; font-size:.78rem}
.btn.ghost{border-color:transparent; background:transparent; color:var(--muted)}
.btn.ghost:hover{background:#f0f1f4; color:var(--ink)}
.iconbtn{border:none;background:transparent;cursor:pointer;color:var(--muted);font-size:.95rem;padding:3px 6px;border-radius:7px}
.iconbtn:hover{background:#f0f1f4;color:var(--ink)}
.btn-row{display:flex; gap:8px; flex-wrap:wrap}

/* botones de acceso rápido (RCTA / MIRX) */
.quick{display:flex; gap:10px; flex-wrap:wrap}
.quick a{flex:1; min-width:120px; justify-content:center; color:#fff; padding:14px; font-size:1rem; border-radius:11px}

/* ---------- Honorario destacado ---------- */
.fee{display:flex; align-items:baseline; gap:8px}
.fee .amount{font-size:1.9rem; font-weight:700}
.fee .since{color:var(--muted); font-size:.85rem}

/* ---------- Forms ---------- */
.field{display:flex; flex-direction:column; gap:4px; margin-bottom:10px}
.field label{font-size:.78rem; color:var(--muted); font-weight:600}
input,textarea,select{
  font:inherit; padding:8px 10px; border:1px solid var(--line); border-radius:9px; background:#fff; width:100%;
}
textarea{resize:vertical; min-height:64px}
input:focus,textarea:focus,select:focus{outline:2px solid #c7d2fe; border-color:#c7d2fe}
.inline-add{display:flex; gap:8px; margin-top:6px}
.inline-add input{flex:1}

/* ---------- Modal ---------- */
.modal-bg{position:fixed; inset:0; background:rgba(16,24,40,.45); display:none; align-items:center; justify-content:center; z-index:50; padding:20px}
.modal-bg.show{display:flex}
.modal{background:#fff; border-radius:16px; width:min(520px,100%); max-height:90vh; overflow:auto; box-shadow:var(--shadow-h)}
.modal header{display:flex; justify-content:space-between; align-items:center; padding:16px 20px; border-bottom:1px solid var(--line)}
.modal header h3{margin:0; font-size:1.1rem}
.modal .content{padding:18px 20px}
.modal footer{display:flex; justify-content:flex-end; gap:10px; padding:14px 20px; border-top:1px solid var(--line)}
.grid2{display:grid; grid-template-columns:1fr 1fr; gap:10px}

/* ---------- Resumen ---------- */
.stat-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr)); gap:16px; margin-bottom:24px}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}
.stat .n{font-size:1.8rem;font-weight:700}
.stat .l{color:var(--muted);font-size:.85rem}

/* ---------- Agenda semanal ---------- */
.agenda-head{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.agenda-head .rango{font-weight:600;font-size:1.05rem;min-width:230px}
.week{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff;box-shadow:var(--shadow)}
.week-grid{display:grid;grid-template-columns:56px repeat(var(--ndays,6),1fr)}
.week-grid .wh{padding:8px 4px;text-align:center;border-bottom:1px solid var(--line);border-left:1px solid var(--line);font-size:.78rem;font-weight:600}
.week-grid .wh.gutter{border-left:none}
.week-grid .wh .dnum{display:block;font-size:1.25rem;font-weight:700;line-height:1.1}
.week-grid .wh.hoy{background:#eef2ff;color:var(--accent)}
.week-body{position:relative;display:grid;grid-template-columns:56px repeat(var(--ndays,6),1fr);max-height:70vh;overflow:auto}
.time-col{border-right:1px solid var(--line)}
.time-col .h{height:48px;font-size:.7rem;color:var(--muted);text-align:right;padding:2px 6px;transform:translateY(-7px)}
.day-col{position:relative;border-left:1px solid var(--line);
  background-image:repeating-linear-gradient(to bottom,transparent 0,transparent 47px,var(--line) 47px,var(--line) 48px);}
.day-col.hoy{background-color:#fbfcff}
.slot-click{position:absolute;left:0;right:0;cursor:pointer}
.slot-click:hover{background:rgba(13,110,253,.06)}
.appt{position:absolute;left:3px;right:3px;border-radius:8px;padding:4px 6px;overflow:hidden;
  background:#198754;color:#fff;font-size:.74rem;cursor:pointer;box-shadow:var(--shadow);border:1px solid rgba(0,0,0,.06)}
.appt .nm{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.appt .mt{opacity:.9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.appt.atendido{background:#6b7280}
.appt.gcal{background:#0d6efd}
.appt:hover{filter:brightness(1.05)}

.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(20px);background:#1f2330;color:#fff;padding:10px 18px;border-radius:10px;opacity:0;transition:.25s;z-index:99}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@media(max-width:760px){
  body{flex-direction:column}
  .sidebar{width:100%;height:auto;position:static;display:flex;gap:6px;overflow-x:auto}
  .nav{display:flex;gap:4px}
  .brand{display:none}
}
