/* Monifactu — estilos. Paleta de marca: verde #43523F, dorado #EFBB3F,
   papel #e9f1ea. Sin dependencias, todo nativo. */
:root {
  --verde: #43523f;
  --verde-2: #36422f;
  --dorado: #efbb3f;
  --papel: #e9f1ea;
  --tinta: #2b2f2a;
  --tinta-2: #6b726a;
  --linea: #d4ddd3;
  --blanco: #ffffff;
  --rojo: #c0392b;
  --verde-ok: #2e7d52;
}
* { box-sizing: border-box; }
html, body { margin: 0; height: 100%; }
body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  background: var(--papel);
  color: var(--tinta);
  -webkit-font-smoothing: antialiased;
}
.mono { font-family: ui-monospace, "SF Mono", Menlo, monospace; }
.cargando { padding: 40px; color: var(--tinta-2); font-size: 13px; letter-spacing: .1em; text-transform: uppercase; }

/* ── Login ── */
.login-wrap { min-height: 100%; display: flex; align-items: center; justify-content: center; padding: 24px; }
.login-card { width: 100%; max-width: 380px; background: var(--blanco); border: 1px solid var(--linea); border-radius: 16px; padding: 32px; }
.login-logo { display: flex; align-items: center; gap: 12px; margin-bottom: 24px; }
.login-logo img { width: 40px; height: 40px; border-radius: 9px; }
.login-logo b { font-size: 15px; letter-spacing: .18em; text-transform: uppercase; }
.login-logo span { font-size: 9px; letter-spacing: .16em; text-transform: uppercase; color: var(--tinta-2); display: block; margin-top: 2px; }
.tabs { display: flex; gap: 6px; margin-bottom: 18px; }
.tabs button { flex: 1; padding: 8px; border: 1px solid var(--linea); background: var(--papel); border-radius: 9px; font-size: 11px; letter-spacing: .1em; text-transform: uppercase; cursor: pointer; color: var(--tinta-2); }
.tabs button.on { background: var(--verde); color: var(--blanco); border-color: var(--verde); }

label { display: block; font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--tinta-2); margin: 14px 0 5px; }
input, select { width: 100%; padding: 10px 12px; border: 1px solid var(--linea); border-radius: 10px; font-size: 14px; background: var(--blanco); color: var(--tinta); }
input:focus, select:focus { outline: none; border-color: var(--verde); }
.btn { width: 100%; margin-top: 20px; padding: 12px; border: none; border-radius: 11px; background: var(--verde); color: var(--blanco); font-size: 12px; letter-spacing: .12em; text-transform: uppercase; cursor: pointer; }
.btn:hover { background: var(--verde-2); }
.btn:disabled { opacity: .5; cursor: default; }
.btn-dorado { background: var(--dorado); color: #3a2e00; }
.btn-dorado:hover { background: #e0ad2c; }
.err { color: var(--rojo); font-size: 12px; margin-top: 12px; min-height: 16px; }
.ok { color: var(--verde-ok); }

/* ── App ── */
.topbar { display: flex; align-items: center; gap: 12px; padding: 14px 22px; background: var(--blanco); border-bottom: 1px solid var(--linea); }
.topbar img { width: 30px; height: 30px; border-radius: 7px; }
.topbar .marca b { font-size: 13px; letter-spacing: .18em; text-transform: uppercase; }
.topbar .marca span { font-size: 8px; letter-spacing: .14em; text-transform: uppercase; color: var(--tinta-2); display: block; }
.topbar .sp { flex: 1; }
.topbar .quien { font-size: 12px; color: var(--tinta-2); }

/* Chip de plan / botón de suscripción en la barra superior. */
.plan-chip { font-size: 10px; letter-spacing: .1em; text-transform: uppercase; padding: 5px 10px; border-radius: 999px; border: 1px solid var(--linea); }
.plan-chip.pro { background: var(--dorado); color: #3a2e00; border-color: var(--dorado); font-weight: 700; }
.plan-chip.suscribir { background: var(--verde); color: var(--blanco); border-color: var(--verde); cursor: pointer; }
.plan-chip.suscribir:hover { background: var(--verde-2); }

/* Banner de prueba / fin de prueba (bajo la barra superior). */
.banner-acceso { display: flex; align-items: center; gap: 14px; padding: 10px 22px; font-size: 13px; }
.banner-acceso.trial { background: #fbf6ec; color: #6b5a1e; border-bottom: 1px solid #efe3c4; }
.banner-acceso.fin { background: #fbecec; color: #7a2b22; border-bottom: 1px solid #f0cfc9; }
.banner-acceso .banner-btn { margin-left: auto; padding: 6px 14px; border: none; border-radius: 8px; background: var(--dorado); color: #3a2e00; font-size: 11px; letter-spacing: .08em; text-transform: uppercase; cursor: pointer; font-weight: 700; }
.banner-acceso .banner-btn:hover { filter: brightness(.95); }

/* Selector de idioma (login + barra superior): discreto, paleta de marca. */
.login-logo .sp { flex: 1; }
.lang-sel {
  width: auto; padding: 5px 8px; font-size: 10px; letter-spacing: .1em; text-transform: uppercase;
  color: var(--tinta-2); background: var(--papel); border: 1px solid var(--linea); border-radius: 8px; cursor: pointer;
}
.lang-sel:focus { border-color: var(--verde); }
.topbar .lang-sel { margin-right: 4px; }
.salir { border: 1px solid var(--linea); background: var(--papel); border-radius: 8px; padding: 6px 12px; font-size: 10px; letter-spacing: .1em; text-transform: uppercase; cursor: pointer; color: var(--tinta-2); }

.layout { display: flex; gap: 20px; padding: 20px; max-width: 1100px; margin: 0 auto; }
.col-emisores { width: 240px; flex-shrink: 0; }
.col-facturas { flex: 1; min-width: 0; }
.panel { background: var(--blanco); border: 1px solid var(--linea); border-radius: 14px; padding: 16px; }
.panel h2 { font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--tinta-2); margin: 0 0 12px; }

.emisor { padding: 10px 12px; border: 1px solid var(--linea); border-radius: 10px; margin-bottom: 8px; cursor: pointer; }
.emisor.sel { border-color: var(--verde); background: var(--papel); }
.emisor b { font-size: 13px; display: block; }
.emisor span { font-size: 11px; color: var(--tinta-2); }

table { width: 100%; border-collapse: collapse; font-size: 13px; }
th { text-align: left; font-size: 9px; letter-spacing: .1em; text-transform: uppercase; color: var(--tinta-2); padding: 6px 8px; border-bottom: 1px solid var(--linea); }
td { padding: 8px; border-bottom: 1px solid var(--papel); }
td.num { text-align: right; }
.vacio { color: var(--tinta-2); font-size: 12px; padding: 20px; text-align: center; }

.secciones { display: flex; gap: 6px; margin-bottom: 14px; }
.secciones .sec { padding: 7px 16px; border: 1px solid var(--linea); background: var(--blanco); border-radius: 10px; font-size: 11px; letter-spacing: .08em; text-transform: uppercase; cursor: pointer; color: var(--tinta-2); }
.secciones .sec:hover { border-color: var(--verde); }
.secciones .sec.on { background: var(--verde); color: var(--blanco); border-color: var(--verde); }

.linea-form { display: grid; grid-template-columns: 1fr 90px 70px; gap: 8px; margin-bottom: 8px; }
.mini { font-size: 11px; }
.totales { display: flex; gap: 18px; flex-wrap: wrap; margin: 14px 0; font-size: 13px; }
.totales b { font-size: 16px; }
.row { display: flex; gap: 10px; align-items: center; }
.huella { font-size: 10px; color: var(--tinta-2); word-break: break-all; }

@media (max-width: 720px) {
  .layout { flex-direction: column; }
  .col-emisores { width: 100%; }
}
