/* CodeMax RMS Web — mock clone. Palette from the real login screenshot (docs/PORTAL-DESIGN.md). */
:root{
  --navy:#1f2d5a; --navy-2:#23306a; --navy-deep:#16203f;
  --blue:#3a86c8; --blue-2:#2f80c9; --cream:#fbfbe8;
  --bg:#eef1f5; --card:#fff; --line:#e4e8ee; --ink:#27324d; --muted:#7a8699; --amber:#c9821f;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;font-family:"Segoe UI",Roboto,Arial,sans-serif;color:var(--ink)}
body.view-dashboard{background:var(--bg)}
.logo{height:46px;width:auto;display:block}
.num{text-align:right;font-variant-numeric:tabular-nums}

/* ===================== LOGIN ===================== */
.login{display:flex;height:100vh;overflow:hidden}
.login__brand{flex:1;background:#fff;position:relative;display:flex;align-items:center;justify-content:center}
.brand{text-align:center;z-index:2}
.brand__logo .logo{height:64px;margin:0 auto 18px;color:var(--navy)}
.brand__tagline{display:inline-block;background:var(--navy);color:#fff;font-size:13px;font-weight:600;
  letter-spacing:4px;padding:9px 22px;border-radius:6px}
.login__floor{position:absolute;left:-20%;right:-20%;bottom:0;height:42%;
  background-image:repeating-linear-gradient(90deg,#eef0f3 0 1px,transparent 1px 64px),
                   repeating-linear-gradient(0deg,#eef0f3 0 1px,transparent 1px 64px);
  transform:perspective(320px) rotateX(62deg);transform-origin:bottom;opacity:.9}
.login__form{flex:1;position:relative;display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(120% 90% at 50% 0%, rgba(40,55,110,.45), rgba(0,0,0,0) 60%),
    repeating-linear-gradient(91deg,#1d2a55 0 5px,#202e5b 5px 11px),
    linear-gradient(180deg,#22305f,#16203f)}
.badge{position:absolute;top:22px;right:26px;background:#cfe0f5;color:#1c64b5;text-align:center;
  font-size:12px;font-weight:700;line-height:1.45;padding:8px 16px;border-radius:6px}
.signin{width:380px;max-width:80vw;color:#fff}
.signin h1{font-size:34px;font-weight:600;margin:0 0 26px}
.signin label{display:block;font-size:15px;margin:16px 0 7px}
.field{position:relative}
.field input{width:100%;height:44px;border:0;border-radius:5px;background:var(--cream);
  padding:0 44px 0 14px;font-size:15px;color:#33373a}
.field input:focus{outline:2px solid var(--blue)}
.field__ico{position:absolute;right:6px;top:6px;width:32px;height:32px;border-radius:4px;background:#e7e7d6;
  color:#9a9a86;display:flex;align-items:center;justify-content:center;font-size:18px}
.signin__row{display:flex;align-items:center;justify-content:space-between;margin-top:26px}
.muted{color:#cdd6ea;text-decoration:none;font-size:14px}
.muted:hover{text-decoration:underline}
.btn{background:linear-gradient(180deg,#4a90c2,#357fb8);border:0;color:#fff;font-size:15px;font-weight:600;
  padding:11px 30px;border-radius:5px;cursor:pointer}
.btn:hover{filter:brightness(1.06)}
.btn:disabled{opacity:.6;cursor:default}
.signin__err{margin-top:16px;color:#ffb4a8;font-size:14px}
.signin__hint{margin-top:22px;color:#9fb0d0;font-size:12px}

/* ===================== DASHBOARD ===================== */
.topbar{height:60px;background:linear-gradient(180deg,var(--navy-2),var(--navy));color:#fff;
  display:flex;align-items:center;gap:26px;padding:0 22px;box-shadow:0 2px 6px rgba(0,0,0,.15)}
.topbar__brand{color:#fff}.topbar__brand .logo{height:30px}
.topbar__nav{display:flex;gap:20px;flex:1}
.topbar__nav a{color:#c6d0e8;font-size:14px;cursor:pointer;padding:4px 0;border-bottom:2px solid transparent}
.topbar__nav a.active,.topbar__nav a:hover{color:#fff;border-color:var(--blue)}
.topbar__right{display:flex;align-items:center;gap:18px;font-size:13px}
.engine select{background:#16203f;color:#fff;border:1px solid #3a4a7a;border-radius:4px;padding:3px 6px}
.user small{color:#aab6d2}
.link{background:none;border:1px solid #44528a;color:#dfe6f5;border-radius:4px;padding:5px 12px;cursor:pointer}
.link:hover{background:#16203f}

.content{max-width:1140px;margin:0 auto;padding:24px 22px 80px}
.content h2{margin:6px 0 18px;color:var(--navy);font-weight:600}
.content h2 small{color:var(--muted);font-weight:400;text-transform:uppercase;font-size:12px;letter-spacing:1px}

.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(165px,1fr));gap:14px;margin-bottom:22px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:9px;padding:16px 18px;box-shadow:0 1px 2px rgba(20,30,60,.04)}
.kpi__v{font-size:30px;font-weight:700;color:var(--navy)}
.kpi__l{font-size:13px;color:var(--muted);margin-top:2px}
.kpi--warn{border-left:4px solid var(--amber)}.kpi--warn .kpi__v{color:var(--amber)}

.grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.card{background:var(--card);border:1px solid var(--line);border-radius:9px;padding:16px 18px;box-shadow:0 1px 2px rgba(20,30,60,.04)}
.card--wide{grid-column:1 / -1}
.card h3{margin:0 0 12px;font-size:15px;color:var(--navy)}
table{width:100%;border-collapse:collapse}
th{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);text-align:left;padding:6px 8px;border-bottom:2px solid var(--line)}
td{padding:8px;border-bottom:1px solid var(--line);font-size:14px}
tr:last-child td{border-bottom:0}

.pill{display:inline-block;font-size:11px;font-weight:600;padding:2px 9px;border-radius:11px;background:#eef1f5;color:#5a6679}
.pill--completed{background:#e3f5ea;color:#1f8a4d}
.pill--in{background:#e6f0fb;color:#2f6dba}      /* In Progress */
.pill--approved{background:#e4f3f4;color:#1f8a8a}
.pill--failed,.pill--cancelled{background:#fde8e6;color:#c5392b}
.pill--draft{background:#eef1f5;color:#7a8699}

.err{color:#c5392b;margin-top:14px}

.chat-launcher{position:fixed;right:24px;bottom:24px;width:58px;height:58px;border-radius:50%;
  background:linear-gradient(180deg,#4a90c2,#2f6dba);color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:26px;box-shadow:0 6px 18px rgba(20,40,90,.35);cursor:pointer}
.chat-launcher:hover{filter:brightness(1.07)}
