/* ============================================================
   METIS ERP – CSS Global (2025-10)
   Se aplica a: Recibos, Cuotas, Contratos, Calculadora, Reportes, etc.
   NO se aplica a Comprobantes (mantiene su propio CSS).
   Estructura: variables → reset → layout → header → botones
               formularios → tablas → modales → utilidades → print
   ============================================================ */

/* -------------------- Variables de diseño ------------------- */
:root{
  --bg: #faf7f4;
  --bg-2:#fffdfb;
  --ink:#2b2b2b;
  --muted:#6b6b6b;

  /* Paleta cálida 2025 */
  --beige:#f4ebe4;
  --beige-2:#eadfd7;
  --sand:#e6d4c9;
  --rose:#d9b8aa;
  --brown:#8a5a44;

  /* Acciones */
  --green:#2bb673;
  --blue:#3b82f6;
  --red:#e74c3c;
  --amber:#ffb020;
  --gray:#e9ecef;

  /* UI */
  --br:12px;
  --shadow-sm:0 4px 16px rgba(0,0,0,.08);
  --shadow-md:0 10px 28px rgba(0,0,0,.12);
}

/* --------------------------- Reset -------------------------- */
*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  margin:0;
  font:14px/1.45 system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";
  color:var(--ink);
  background:linear-gradient(180deg,var(--bg),var(--bg-2));
}
a{color:inherit;text-decoration:none}
a:hover{text-decoration:underline}

/* ---------------------- Contenedores ------------------------ */
.container{max-width:1100px;margin:0 auto;padding:20px 16px}
section.card{
  background:#fff;border-radius:var(--br);box-shadow:var(--shadow-sm);
  padding:18px;margin:14px 0;
}

/* -------------------------- Header ------------------------- */
header{
  display:flex;gap:14px;align-items:center;margin:10px 0 18px;
}
header .logo{
  width:56px;height:56px;object-fit:contain;background:#fff;
  border-radius:50%;box-shadow:var(--shadow-sm);
}
header h2{margin:0 0 4px;font-size:20px}
header p{margin:0;color:var(--muted)}

/* -------------------------- Botones ------------------------ */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 14px;border-radius:10px;border:1px solid transparent;
  cursor:pointer;background:#f6f6f6;transition:.15s;box-shadow:var(--shadow-sm);
}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn.gray{background:var(--gray)}
.btn.green{background:var(--green);color:#fff}
.btn.blue{background:var(--blue);color:#fff}
.btn.red{background:var(--red);color:#fff}
.btn.brown{background:var(--brown);color:#fff}
.btn.ghost{background:transparent;border-color:#d9d9d9}
.btn-sm{padding:6px 9px;border-radius:8px;font-size:13px}
.btn-lg{padding:12px 18px;border-radius:12px;font-size:15px}
.acciones{display:flex;flex-wrap:wrap;gap:10px;margin:10px 0}

/* ------------------------- Formularios --------------------- */
.form-recibo,.form-filtros,.form-inline{
  display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin:10px 0 16px;
}
label{font-size:13px;color:#444}
input[type="text"],input[type="number"],input[type="date"],select,textarea{
  width:220px;max-width:100%;
  padding:9px 10px;border:1px solid #ddd;border-radius:10px;background:#fff;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,0);transition:.12s;
}
input:focus,select:focus,textarea:focus{
  outline:none;border-color:#c9b7a9;box-shadow:0 0 0 3px rgba(201,183,169,.25)
}
textarea{min-height:90px;resize:vertical}

/* Grid simple (p/ modales y formularios anchos) */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:720px){
  .form-grid{grid-template-columns:1fr}
  .form-recibo,.form-filtros,.form-inline{flex-direction:column;align-items:stretch}
  input,select,textarea{width:100%}
}

/* Pequeñas toolbars reusables */
.toolbar{
  display:flex;flex-wrap:wrap;gap:10px;align-items:center;
  padding:10px;background:#fff;border:1px solid #eee;border-radius:12px;
  box-shadow:var(--shadow-sm);margin:10px 0;
}

/* --------------------------- Tablas ------------------------ */
.table-scroll{overflow:auto;border-radius:12px;border:1px solid #eee;background:#fff}
table{width:100%;border-collapse:separate;border-spacing:0}
thead th{
  position:sticky;top:0;z-index:2;
  background:linear-gradient(180deg,var(--beige),#fff);
  color:#333;font-weight:600;text-align:left;padding:10px;border-bottom:1px solid #e9e1db;
}
tbody td{padding:10px;border-bottom:1px solid #f0ece7;vertical-align:middle}
tbody tr:nth-child(odd){background:#fff}
tbody tr:nth-child(even){background:#fffaf6}
tbody tr:hover{background:#fff3e4}
tr.seleccionada{background:#fff1b8 !important}
th.text-right,td.text-right{text-align:right}
th.text-center,td.text-center{text-align:center}

/* Column widths reusables */
.col-xxs{width:50px}.col-xs{width:80px}.col-s{width:120px}
.col-m{width:180px}.col-l{width:240px}

/* Tabla compacta opcional */
.table-compact thead th{padding:8px}
.table-compact tbody td{padding:8px}

/* Footer/paginación opcional */
.table-foot{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;color:#666}

/* --------------------------- Modales ----------------------- */
.modal{
  position:fixed;inset:0;background:rgba(0,0,0,.28);
  display:flex;align-items:center;justify-content:center;z-index:999;
}
.modal.hidden{display:none}
.modal-box{
  width:min(560px,96vw);
  background:#fff;border-radius:14px;padding:18px;box-shadow:var(--shadow-md);
}
.modal-box h3{margin:0 0 8px}

/* -------------------------- Utilidades --------------------- */
.hidden{display:none !important}
.text-center{text-align:center}.text-right{text-align:right}
.m-0{margin:0}.mt-6{margin-top:6px}.mt-10{margin-top:10px}.mt-16{margin-top:16px}
.mb-6{margin-bottom:6px}.mb-10{margin-bottom:10px}.mb-16{margin-bottom:16px}
.p-10{padding:10px}.p-16{padding:16px}
.badge{display:inline-block;padding:3px 8px;border-radius:999px;background:#efe5dc;color:#694f3a;font-size:12px}
.tag{padding:2px 6px;border-radius:6px;background:#ececec;font-size:12px}
.ok{color:var(--green)} .warn{color:var(--amber)} .err{color:var(--red)}
.box-warn{background:#fff6e6;border:1px solid #ffe1b3;border-radius:10px;padding:10px}

/* Cards y KPIs */
.card-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.card{grid-column:span 12;background:#fff;border-radius:var(--br);box-shadow:var(--shadow-sm);padding:14px}
.kpi{
  background:#fff;border:1px solid #eee;border-radius:12px;box-shadow:var(--shadow-sm);
  padding:12px 14px;display:flex;flex-direction:column;gap:4px
}
.kpi .label{font-size:12px;color:#7a6b60}
.kpi .value{font-size:20px;font-weight:700}

/* Avisos */
.notice{background:#fffdf5;border:1px solid #ffe5b5;border-radius:10px;padding:10px;color:#7a5b2a}

/* ---------------------------- Print ------------------------ */
@media print{
  body{background:#fff}
  .acciones,.btn,.toolbar,.modal{display:none !important}
  .table-scroll{overflow:visible;border:0;box-shadow:none}
  table{page-break-inside:auto}
  tr{page-break-inside:avoid;page-break-after:auto}
  thead{display:table-header-group}
  tfoot{display:table-footer-group}
}
/* ======================= Login ======================== */
.login-page{display:flex;min-height:100vh;align-items:center;justify-content:center}
.login-wrap{width:min(560px,96vw)}
.login-card{
  background:#fff;border-radius:16px;padding:20px 18px;box-shadow:var(--shadow-md);
}
.login-head{display:flex;gap:12px;align-items:center;margin-bottom:8px}
.brand-circle{
  width:52px;height:52px;display:grid;place-items:center;
  border-radius:50%;background:var(--beige);font-weight:800;color:#5a4337;
  box-shadow:var(--shadow-sm)
}
.login-card h1{margin:0;font-size:22px}
.login-card .muted{color:var(--muted)}
.login-foot{margin-top:10px;text-align:center}
.input-with-end{position:relative}
.input-with-end input{width:100%}
.input-end{
  position:absolute;right:6px;top:50%;transform:translateY(-50%);
}
.msg{min-height:18px}

/* botón loading */
.is-loading i{margin-right:6px}

/* ======================== Home ======================== */
.app-shell{min-height:100vh}
.app-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 0;
}
.brand{display:flex;align-items:center;gap:10px}
.brand-txt h2{margin:0;font-size:22px}
.brand-txt .muted{margin:0;color:var(--muted)}
.userbox{display:flex;align-items:center;gap:10px}
.badge.role-admin{background:#e8fff3;color:#1f7a4d}
.badge.role-assistant{background:#fff8ea;color:#8a5a44}
.badge.role-viewer{background:#eef1f8;color:#314a78}

/* Mosaico de módulos */
.nav-grid{
  display:grid;grid-template-columns:repeat(5,1fr);gap:14px
}
@media (max-width:980px){ .nav-grid{grid-template-columns:repeat(3,1fr)} }
@media (max-width:640px){ .nav-grid{grid-template-columns:repeat(1,1fr)} }

.tile{
  display:flex;flex-direction:column;gap:6px;align-items:flex-start;
  background:#fff;border:1px solid #eee;border-radius:14px;
  padding:16px;box-shadow:var(--shadow-sm);transition:transform .12s, box-shadow .12s;
}
.tile i{font-size:22px}
.tile:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.tile[aria-disabled="true"]{opacity:.45;filter:grayscale(1);cursor:not-allowed}

/* Ocultar panel de Importar/Exportar para roles no-admin */
html:not([data-role="admin"]) .sync-panel { 
  display: none !important; 
}
/* ====== FIXES Login ====== */
body.login-page{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
}

.login-wrap{ width:min(560px,96vw); }
.login-card{ background:#fff; border-radius:16px; padding:20px 18px; box-shadow:var(--shadow-md); }

.login-head{ display:flex; gap:12px; align-items:center; margin-bottom:8px; }
.brand-circle{
  width:52px; height:52px; display:grid; place-items:center;
  border-radius:50%; background:var(--beige); font-weight:800; color:#5a4337;
  box-shadow:var(--shadow-sm);
}

.login-card .form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.login-card label{ display:flex; flex-direction:column; gap:6px; }
.login-card input{ width:100%; }

.input-with-end{ position:relative; }
.input-end{ position:absolute; right:6px; top:50%; transform:translateY(-50%); }

#btnLogin{ width:100%; }           /* botón a todo el ancho */
.msg{ min-height:18px; }

input[type="password"]::-ms-reveal,
input[type="password"]::-ms-clear { display: none; }
