/* CTA [29/06/2026], INTRANET-FLOJIM, design system (clean modern, FLOJIM brand). Responsive, mobile-first. */
:root{
  --brand:#16314e; --brand2:#2d6a9f; --ink:#0f172a; --mut:#64748b; --line:#e2e8f0; --bg:#eef2f6; --card:#fff;
  --ok:#16a34a; --okbg:#ecfdf5; --am:#b45309; --ambg:#fffbeb; --rd:#b91c1c; --rdbg:#fef2f2; --bl:#2d6a9f; --blbg:#eff6ff;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow-x:hidden;max-width:100%}
body{font-family:'Segoe UI',Roboto,-apple-system,Arial,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}

.appbar{background:var(--brand);color:#fff;display:flex;align-items:center;gap:12px;padding:10px 16px;position:sticky;top:0;z-index:30;box-shadow:0 1px 8px rgba(15,40,70,.18)}
.appbar img.logo{height:24px;background:#fff;border-radius:5px;padding:2px 6px;flex:0 0 auto}
.appbar .ttl{font-weight:700;font-size:15px;letter-spacing:.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.appbar .sp{flex:1}
.appbar .who{font-size:12px;opacity:.92;white-space:nowrap}
.appbar .who a{text-decoration:underline;opacity:.85}
.wrap{max-width:1180px;margin:0 auto;padding:18px;width:100%}

.phead{display:flex;align-items:center;gap:10px;margin:6px 2px 16px}
.phead h1{font-size:20px;color:var(--brand);font-weight:800}
.phead .sub{font-size:13px;color:var(--mut)}

.kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:18px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:14px 16px;min-width:0;overflow:hidden}
.kpi .l{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--mut);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kpi .v{font-size:24px;font-weight:800;color:var(--brand);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kpi .d{font-size:12px;color:var(--mut);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:16px}
.mod{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px;display:flex;flex-direction:column;gap:6px;box-shadow:0 1px 2px rgba(15,40,70,.04);transition:transform .08s,box-shadow .12s;border-top:3px solid var(--brand2);min-width:0}
.mod:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(15,40,70,.12)}
.mod .ic{font-size:30px}
.mod .nm{font-weight:700;font-size:16px;color:var(--brand)}
.mod .ds{font-size:12.5px;color:var(--mut)}
.mod.soon{opacity:.65;border-top-color:var(--line)}
.mod .tag{align-self:flex-start;font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px;background:var(--blbg);color:var(--bl);margin-top:4px}
.mod .tag.soon{background:#f1f5f9;color:var(--mut)}

.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px;margin-bottom:14px}
.btn{display:inline-block;background:var(--brand2);color:#fff;border:none;border-radius:12px;padding:12px 18px;font-size:15px;font-weight:700;cursor:pointer;text-align:center}
.btn.g{background:var(--ok)} .btn.gh{background:#fff;color:var(--brand2);border:1.5px solid var(--brand2)}
table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;font-size:14px}
th{background:#f1f5f9;text-align:left;padding:10px 12px;color:var(--mut);font-size:11px;text-transform:uppercase;letter-spacing:.3px}
td{padding:10px 12px;border-top:1px solid var(--line)}

.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#16314e,#2d6a9f);padding:20px}
.login-card{background:#fff;border-radius:18px;padding:30px 26px;width:100%;max-width:380px;box-shadow:0 20px 50px rgba(0,0,0,.25)}
.login-card .brand{text-align:center;margin-bottom:14px}
.login-card .brand img{height:40px;max-width:100%}
.login-card .brand .s{display:block;font-size:12px;color:var(--mut);margin-top:8px;letter-spacing:.5px}
.login-card h1{font-size:18px;color:var(--brand);text-align:center;margin-bottom:14px}
.login-card label{display:block;font-size:12px;color:var(--mut);margin:10px 0 4px;font-weight:600}
.login-card input{width:100%;border:1.5px solid var(--line);border-radius:10px;padding:12px;font-size:15px}
.login-card input:focus{outline:none;border-color:var(--brand2)}
.btn-login{width:100%;background:var(--brand2);color:#fff;border:none;border-radius:12px;padding:13px;font-size:16px;font-weight:700;margin-top:18px;cursor:pointer}
.login-error{background:var(--rdbg);color:var(--rd);border:1px solid #fecaca;border-radius:10px;padding:10px;font-size:13px;margin-bottom:8px}

@media(max-width:860px){ .kpis{grid-template-columns:repeat(2,minmax(0,1fr))} .wrap{padding:12px} }
@media(max-width:480px){ .grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px} .mod{padding:14px} .mod .ic{font-size:24px} .mod .nm{font-size:14px} .mod .ds{display:none} .kpi .v{font-size:20px} }
.toast-host{position:fixed;left:0;right:0;bottom:16px;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:50}
.demo-bar{display:none}
