/* === Sistema de diseño Brash · Suite de evaluación financiera ===
   Flat, denso, paleta fría. Acento rojo SOLO puntual, nunca relleno de fondo.
   Tipografía condensada (Archivo Narrow / Bahnschrift). Bordes 1px, sin sombras. */
:root{
  --paper:#fcfcfb;--surface:#ffffff;--surface-2:#fafafa;
  --charcoal:#262626;--ink:#151916;--grey:#595959;--grey-2:#7f7f7f;
  --line:#d9d9d9;--line-2:#ececec;
  --accent:#ee4331;
  --nav:#002060;--risk:#c00000;--done:#00b050;
  --cond:'Bahnschrift','Archivo Narrow','Arial Narrow',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{
  background-color:var(--paper);
  background-image:
    linear-gradient(to right, rgba(38,38,38,.015) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(38,38,38,.015) 1px, transparent 1px);
  background-size:34px 34px;
  color:var(--charcoal);
  font-family:var(--cond);font-stretch:87.5%;
  font-size:14.5px;line-height:1.5;-webkit-font-smoothing:antialiased;
  font-variant-numeric:tabular-nums;text-rendering:optimizeLegibility;
}
::selection{background:var(--accent);color:#fff}
.wrap{max-width:1180px;margin:0 auto;padding:0 26px 90px}

button{font-family:var(--cond);font-stretch:87.5%;cursor:pointer;border:1px solid transparent;
  background:none;color:inherit;transition:border-color .15s ease,color .15s ease,background .15s ease}

/* ---------- header (menú) ---------- */
header{border-bottom:1px solid var(--line);padding:26px 0 16px;margin-bottom:26px}
.hdr{display:flex;justify-content:space-between;align-items:flex-end;gap:16px 26px;flex-wrap:wrap}
.brandline{display:flex;align-items:center;gap:15px;min-width:0}
.brandline img{height:27px;width:auto;display:block;flex:none}
.brandline .divider{width:1px;height:34px;background:var(--line);flex:none}
h1{font-family:var(--cond);font-weight:700;font-size:26px;letter-spacing:.005em;
  line-height:1.04;color:var(--ink);white-space:nowrap;text-transform:uppercase}
.sub{color:var(--grey-2);font-size:12.5px;margin-top:4px;letter-spacing:.02em}
.tag{font-size:11px;text-transform:uppercase;letter-spacing:.11em;font-weight:600;
  color:var(--charcoal);border:1px solid var(--line);padding:6px 11px;white-space:nowrap;
  display:inline-flex;align-items:center;gap:8px}
.tag::before{content:"";width:7px;height:7px;background:var(--accent);flex:none}

.topbar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-top:16px}
.who{font-size:12.5px;color:var(--grey);white-space:nowrap}
.who .who-k{text-transform:uppercase;letter-spacing:.13em;font-size:10.5px;font-weight:600;color:var(--grey-2);margin-right:7px}
.who b{color:var(--charcoal);font-weight:600}
.ghost{border:1px solid var(--line);color:var(--grey);padding:7px 13px;font-size:12.5px;font-weight:600;white-space:nowrap}
.ghost:hover{border-color:var(--charcoal);color:var(--charcoal)}

/* ---------- login ---------- */
.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{background:var(--surface);border:1px solid var(--line);padding:34px 32px;
  width:100%;max-width:372px}
.login-logo{height:26px;width:auto;display:block;margin-bottom:20px}
.login-card h1{font-size:23px;margin-bottom:3px;white-space:normal}
.login-card .sub{margin-bottom:24px}
label{display:block;text-transform:uppercase;letter-spacing:.13em;font-size:10.5px;
  font-weight:700;color:var(--grey-2);margin:0 0 7px}
input{width:100%;font-family:var(--cond);font-stretch:87.5%;font-size:15px;padding:10px 12px;
  border:1px solid var(--line);background:var(--surface-2);color:var(--charcoal)}
input::placeholder{color:var(--grey-2)}
input:focus{outline:none;border-color:var(--accent)}
.field{margin-bottom:16px}
.login-card button[type="submit"]{width:100%;background:var(--charcoal);color:#fff;
  border:1px solid var(--charcoal);padding:11px 18px;font-size:14px;font-weight:600;
  text-transform:uppercase;letter-spacing:.08em;margin-top:4px}
.login-card button[type="submit"]:hover{background:var(--ink);border-color:var(--ink)}
.login-card button[type="submit"]:disabled{opacity:.55;cursor:default}
.error{display:none;color:var(--risk);background:#fbeceb;border:1px solid var(--risk);
  padding:9px 11px;font-size:12.5px;margin-bottom:14px}
.error.show{display:block}
.hint{font-size:11.5px;color:var(--grey-2);margin-top:18px;line-height:1.8;
  border-top:1px solid var(--line-2);padding-top:13px;letter-spacing:.02em}

/* ---------- secciones (menú) ---------- */
.section{margin-bottom:28px}
.section-head{display:flex;align-items:baseline;gap:11px;
  border-bottom:1px solid var(--line);padding-bottom:9px;margin-bottom:13px}
.section-head .num{color:var(--accent);font-size:12px;font-weight:700;letter-spacing:.04em}
.section-head .label{font-weight:700;font-size:13.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink)}
.section-head .desc{color:var(--grey-2);font-size:12.5px;font-weight:500;margin-left:auto;text-align:right;letter-spacing:.01em;white-space:nowrap}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(228px,1fr));gap:8px}
.module{background:var(--surface);border:1px solid var(--line);padding:13px 14px 12px;
  text-align:left;display:flex;flex-direction:column;gap:11px;width:100%;color:var(--charcoal);min-height:74px}
.module .name{font-weight:600;font-size:15px;line-height:1.24;letter-spacing:.005em}
.module .state{font-size:10px;text-transform:uppercase;letter-spacing:.13em;font-weight:700;
  display:inline-flex;align-items:center;gap:8px;margin-top:auto}
.module .state::before{content:"";width:8px;height:8px;flex:none}

.module.on{cursor:pointer}
.module.on .state{color:var(--charcoal)}
.module.on .state::before{background:var(--accent)}              /* bullet cuadrado rojo */
.module.on:hover{background:var(--surface-2);border-color:var(--charcoal)}
.module.off{background:var(--surface-2);cursor:not-allowed}
.module.off .name{color:var(--grey-2)}
.module.off .state{color:var(--grey-2)}
.module.off .state::before{background:transparent;border:1px solid var(--line)}

/* ---------- toast ---------- */
.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(16px);
  background:var(--ink);color:#fff;padding:12px 16px;font-size:13px;border:1px solid var(--charcoal);
  display:inline-flex;align-items:center;gap:10px;opacity:0;pointer-events:none;transition:.18s ease;max-width:90vw}
.toast::before{content:"";width:8px;height:8px;background:var(--accent);flex:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast b{color:#fff;font-weight:600}

/* ---------- selector de empresa activa (header) ---------- */
.empresa-select{font-family:var(--cond);font-stretch:87.5%;font-size:11px;font-weight:600;
  text-transform:uppercase;letter-spacing:.11em;color:var(--charcoal);background-color:var(--surface);
  border:1px solid var(--line);padding:6px 30px 6px 11px;appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' fill='none' stroke='%23262626' stroke-width='1.5'/></svg>");
  background-repeat:no-repeat;background-position:right 9px center;background-size:10px}
.empresa-select:hover{border-color:var(--charcoal)}
.empresa-select:focus{outline:none;border-color:var(--accent)}

/* ---------- banner: empresa inhabilitada vista por staff ---------- */
.banner-inhab{border:1px solid var(--risk);background:#fbeceb;color:var(--risk);
  padding:9px 13px;font-size:12.5px;margin-bottom:22px;letter-spacing:.01em}
.banner-inhab b{color:var(--risk);font-weight:700}

/* ---------- pantalla "servicio inhabilitado" (cliente) ---------- */
.inhab-screen{display:flex;justify-content:center;padding:46px 0}
.inhab-card{border:1px solid var(--line);background:var(--surface);padding:30px 32px;max-width:460px;width:100%}
.inhab-card .inhab-k{text-transform:uppercase;letter-spacing:.13em;font-size:10.5px;font-weight:700;
  color:var(--risk);display:flex;align-items:center;gap:8px}
.inhab-card .inhab-k::before{content:"";width:8px;height:8px;background:var(--risk);flex:none}
.inhab-card h2{font-family:var(--cond);font-weight:700;font-size:21px;text-transform:uppercase;
  color:var(--ink);margin:9px 0 8px;letter-spacing:.005em}
.inhab-card p{color:var(--grey);font-size:13.5px;line-height:1.6}

/* ---------- placeholder de módulo (en construcción) ---------- */
.construccion{border:1px solid var(--line);background:var(--surface);padding:30px 32px;max-width:560px}
.construccion .construccion-k{text-transform:uppercase;letter-spacing:.13em;font-size:10.5px;font-weight:700;
  color:var(--accent);display:flex;align-items:center;gap:8px}
.construccion .construccion-k::before{content:"";width:8px;height:8px;background:var(--accent);flex:none}
.construccion h2{font-family:var(--cond);font-weight:700;font-size:22px;text-transform:uppercase;
  color:var(--ink);margin:9px 0 10px;letter-spacing:.005em}
.construccion p{color:var(--grey);font-size:13.5px;line-height:1.6;margin-bottom:8px}
