/* ============================================================
   RESET & BASE
   ============================================================ */
*{margin:0;padding:0;box-sizing:border-box}

/* PALETA */
:root{
  --bg:#f5f6f8;--c:#fff;--b:#e5e7eb;
  --t:#111827;--t2:#4b5563;--t3:#6b7280;--t4:#9ca3af;--t5:#d1d5db;
  --bl:#1d4ed8;--blL:#eff6ff;--blM:#dbeafe;
  --am:#b45309;--amL:#fef3c7;
  --rd:#b91c1c;--rdL:#fee2e2;
  --gn:#047857;--gnL:#ecfdf5;
  --sw:220px;--hh:52px;
}

html,body{height:100%;font:13px/1.5 'IBM Plex Sans',sans-serif;color:var(--t);background:var(--bg)}
button{cursor:pointer;border:none;background:none;font:inherit}
input,select{font:inherit;color:var(--t)}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:2px}

/* ============================================================
   TELA DE LOGIN
   ============================================================ */
body.login-body{background:#f5f7fa}

#loginScreen{position:fixed;inset:0;z-index:10000;display:flex;background:#f5f7fa;overflow:hidden}
#loginScreen.hidden{display:none}

/* Lado azul */
#loginScreen .lg-side{flex:1;background:linear-gradient(135deg,#0d2559 0%,#1d4ed8 50%,#2563eb 100%);position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;padding:44px 46px;color:#fff}
#loginScreen .lg-side::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 20% 30%,rgba(255,255,255,0.12) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(255,255,255,0.06) 0%,transparent 50%);pointer-events:none;z-index:0}
#loginScreen .lg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,0.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.035) 1px,transparent 1px);background-size:40px 40px;pointer-events:none;z-index:0}
#loginScreen .lg-brand{position:relative;z-index:2}
#loginScreen .lg-brand img{height:26px;width:auto;filter:brightness(0) invert(1);margin-bottom:6px;display:block}
#loginScreen .lg-brand .pas{display:inline-block;font-size:10px;font-weight:700;letter-spacing:2px;padding:3px 8px;background:rgba(255,255,255,0.15);border:1px solid rgba(255,255,255,0.25);border-radius:3px;color:#fff;margin-top:8px}
#loginScreen .lg-middle{position:relative;z-index:2}
#loginScreen .lg-middle h1{font-size:28px;font-weight:700;line-height:1.25;margin:0 0 10px;color:#fff}
#loginScreen .lg-middle p{font-size:13px;line-height:1.6;color:rgba(255,255,255,0.82);max-width:480px;margin:0}
#loginScreen .lg-footer{position:relative;z-index:2;font-size:10px;color:rgba(255,255,255,0.5);line-height:1.5}

/* Lado do formulário */
#loginScreen .lg-form-side{width:460px;max-width:100%;display:flex;flex-direction:column;justify-content:center;padding:44px 56px;background:#fff;position:relative;z-index:10}
#loginScreen .lg-form{animation:loginFadeIn .5s ease-out;max-width:360px;margin:0 auto;width:100%;position:relative;z-index:20}
#loginScreen .lg-tag{display:inline-block;font-size:9px;text-transform:uppercase;letter-spacing:1.5px;color:#6b7280;font-weight:700;padding:3px 8px;background:#f3f4f6;border-radius:3px;border:1px solid #e5e7eb}
#loginScreen .lg-form h2{font-size:24px;font-weight:700;color:#111827;margin:14px 0 4px}
#loginScreen .lg-form .sub{font-size:12px;color:#6b7280;margin:0 0 28px;line-height:1.5}
#loginScreen .lg-fg{margin-bottom:14px;position:relative;z-index:20}
#loginScreen .lg-fg label{display:block;font-size:10px;font-weight:600;color:#374151;margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}
#loginScreen .lg-fg input{width:100%;padding:11px 13px;border:1px solid #d1d5db;border-radius:4px;font-size:13px;font-family:inherit;color:#111827;background:#fff;transition:border-color .15s,box-shadow .15s;box-sizing:border-box;position:relative;z-index:20}
#loginScreen .lg-fg input:focus{outline:none;border-color:#1d4ed8;box-shadow:0 0 0 3px rgba(29,78,216,0.12)}
#loginScreen .lg-fg input.err{border-color:#b91c1c;animation:shakeErr .35s}
#loginScreen .lg-row{display:flex;justify-content:space-between;align-items:center;margin:4px 0 18px;font-size:11px;position:relative;z-index:20}
#loginScreen .lg-chk{display:flex;align-items:center;gap:6px;cursor:pointer;color:#4b5563}
#loginScreen .lg-chk input{margin:0;cursor:pointer}
#loginScreen .lg-row a{color:#1d4ed8;text-decoration:none;font-weight:500;cursor:pointer}
#loginScreen .lg-row a:hover{text-decoration:underline}
#loginScreen .lg-btn{width:100%;padding:12px 16px;background:#1d4ed8;color:#fff;border:0;border-radius:4px;font-size:13px;font-weight:600;letter-spacing:.3px;cursor:pointer;transition:background .15s;position:relative;z-index:20}
#loginScreen .lg-btn:hover{background:#1e40af}
#loginScreen .lg-btn:disabled{background:#9ca3af;cursor:not-allowed}
#loginScreen .lg-err{padding:9px 11px;background:#fee2e2;border:1px solid #fecaca;border-radius:4px;color:#991b1b;font-size:11px;margin-bottom:14px;display:none}
#loginScreen .lg-err.on{display:block;animation:loginFadeIn .3s}
#loginScreen .lg-status{position:absolute;top:18px;right:22px;display:flex;align-items:center;gap:6px;font-size:10px;color:#6b7280;z-index:30}
#loginScreen .lg-status .dot{width:7px;height:7px;border-radius:50%;background:#047857;animation:dotPulse 2s infinite}
#loginScreen .lg-fine{font-size:9px;color:#9ca3af;margin-top:20px;text-align:center;line-height:1.6}
#loginScreen .lg-fine a{color:#6b7280;text-decoration:none;cursor:pointer}
#loginScreen .lg-demo{position:absolute;bottom:14px;left:0;right:0;text-align:center;font-size:9px;color:#9ca3af;z-index:30}
#loginScreen .lg-demo kbd{background:#f3f4f6;border:1px solid #d1d5db;border-radius:2px;padding:1px 5px;font-family:'IBM Plex Mono',monospace;color:#374151;font-size:9px}
#loginScreen .lg-loading{display:none;align-items:center;gap:8px;margin-top:10px;font-size:11px;color:#6b7280}
#loginScreen .lg-loading.on{display:flex}
#loginScreen .lg-loading .spinner{width:13px;height:13px;border:2px solid #e5e7eb;border-top-color:#1d4ed8;border-radius:50%;animation:spinLG 0.7s linear infinite}

/* Responsivo */
@media(max-width:900px){
  #loginScreen .lg-side{display:none}
  #loginScreen .lg-form-side{width:100%;padding:40px 24px}
}

/* ============================================================
   DASHBOARD — SIDEBAR, HEADER, MAIN
   ============================================================ */
#S{position:fixed;top:0;left:0;width:var(--sw);height:100%;background:var(--c);border-right:1px solid var(--b);z-index:20;display:flex;flex-direction:column}
#S-logo{padding:10px 12px;border-bottom:1px solid var(--b);display:flex;align-items:center;gap:6px;min-height:var(--hh);max-height:var(--hh);overflow:hidden}
#S-logo img{height:18px;width:auto;display:block;flex-shrink:0;max-width:110px;object-fit:contain}
#S-logo .pastag{font-size:9px;font-weight:700;color:var(--t3);letter-spacing:1.2px;text-transform:uppercase;padding:2px 5px;background:var(--bg);border-radius:2px;border:1px solid var(--b);flex-shrink:0}
#S-nav{flex:1;overflow-y:auto;padding:6px 0}
.ng{padding:10px 14px 3px;font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--t4)}
.nb{display:block;width:100%;text-align:left;padding:7px 14px;font-size:11.5px;color:var(--t2);border-left:2px solid transparent;transition:background .1s}
.nb:hover{background:#f9fafb}
.nb.on{background:var(--blL);color:var(--bl);border-left-color:var(--bl);font-weight:600}
#S-foot{border-top:1px solid var(--b);padding:10px 12px}
#S-foot .sup-btn{width:100%;padding:8px 10px;background:var(--bl);color:#fff;border-radius:3px;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:6px;transition:background .15s}
#S-foot .sup-btn:hover{background:#1e40af}
#S-foot .sup-meta{font-size:9px;color:var(--t3);text-align:center;margin-top:6px;line-height:1.4}

#H{position:fixed;top:0;left:var(--sw);right:0;height:var(--hh);background:var(--c);border-bottom:1px solid var(--b);display:flex;align-items:center;justify-content:space-between;padding:0 18px;z-index:10}
#H h1{font-size:13px;font-weight:600;color:var(--t)}
#H-right{display:flex;align-items:center;gap:12px}
#H-right .sup-top{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--bl);font-weight:600;padding:5px 10px;border:1px solid var(--blM);border-radius:3px;background:var(--blL);cursor:pointer;transition:background .15s}
#H-right .sup-top:hover{background:var(--blM)}

#M{margin-left:var(--sw);margin-top:var(--hh);padding:16px 18px;min-height:calc(100vh - var(--hh))}

/* ============================================================
   COMPONENTES GERAIS
   ============================================================ */
.pg{display:none}.pg.on{display:block}
.cd{background:var(--c);border:1px solid var(--b);border-radius:3px;margin-bottom:8px}
.ch{padding:6px 10px;border-bottom:1px solid var(--b);display:flex;align-items:center;justify-content:space-between}
.ch h3{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--t3)}
.cb{padding:9px 10px}
.kg{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:6px;margin-bottom:8px}
.kp{background:var(--c);border:1px solid var(--b);border-left:3px solid var(--t5);padding:7px 10px;border-radius:0 3px 3px 0}
.kl{font-size:8px;text-transform:uppercase;letter-spacing:1px;color:var(--t3);font-weight:600;margin-bottom:2px}
.kv{font-size:16px;font-weight:700;color:var(--t)}.ks{font-size:9px;color:var(--t3);margin-top:1px;line-height:1.2}
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:8px;text-transform:uppercase;letter-spacing:.8px;color:var(--t3);font-weight:600;padding:6px 8px;border-bottom:2px solid var(--b)}
td{padding:6px 8px;border-bottom:1px solid #f3f4f6;font-size:11.5px;color:var(--t2)}
tr:hover{background:#f9fafb}
.mo{font-family:'IBM Plex Mono',monospace;font-size:10.5px;color:var(--t2)}
.pwi{width:28px;height:28px;border-radius:50%;background:#fff;border:1px solid var(--b);color:var(--t3);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.pwi-active{background:var(--bl);color:#fff;border-color:var(--bl)}
.pwi-done{background:var(--gn);color:#fff;border-color:var(--gn)}
.pwi-line{flex:1;height:1px;background:var(--b);min-width:12px;max-width:30px}
.rwi{width:38px;height:38px;border-radius:50%;background:#fff;border:2px solid var(--b);color:var(--t3);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0;transition:all .2s}
.rwi-active{background:var(--bl);color:#fff;border-color:var(--bl)}
.rwi-done{background:var(--gn);color:#fff;border-color:var(--gn)}
.rwi-line{flex:1;height:2px;background:var(--b);min-width:18px;max-width:60px}
.rwi-done+.rwi-line{background:var(--gn)}
.bt-big{font-size:14px;padding:14px 28px;font-weight:700}
.bt-huge{font-size:16px;padding:18px 40px;font-weight:700}
.bs{display:inline-block;padding:2px 6px;border-radius:2px;font-size:8px;font-weight:700;letter-spacing:.3px}
.bs-n{background:#f3f4f6;color:var(--t3);border:1px solid var(--b)}
.bs-p{background:var(--blL);color:var(--bl);border:1px solid var(--blM)}
.bs-a{background:var(--amL);color:var(--am);border:1px solid #fde68a}
.bs-c{background:var(--rdL);color:var(--rd);border:1px solid #fecaca}
.bs-ok{background:var(--gnL);color:var(--gn);border:1px solid #a7f3d0}
.bg{background:#f3f4f6;color:var(--t3);border:1px solid var(--b)}
.br{background:var(--rdL);color:var(--rd);border:1px solid #fecaca}
.ba{background:var(--amL);color:var(--am);border:1px solid #fde68a}
.bb{background:var(--blL);color:var(--bl);border:1px solid var(--blM)}
.bt{display:inline-flex;align-items:center;padding:5px 12px;font-size:10.5px;font-weight:600;border-radius:3px;gap:3px;transition:background .1s,color .1s}
.bp{background:var(--bl);color:#fff}.bp:hover{background:#1e40af}
.b2{background:var(--c);border:1px solid var(--b);color:var(--t2)}.b2:hover{background:#f9fafb;border-color:var(--t4)}
.bd{background:var(--rd);color:#fff}.bv{background:var(--gn);color:#fff}
.dt{color:var(--t2);font-size:10.5px;font-weight:500}
.dt-urg{color:var(--am);font-size:10.5px;font-weight:600}
.fg{display:flex;flex-direction:column;gap:2px}
.fg label{font-size:8px;text-transform:uppercase;letter-spacing:.7px;color:var(--t3);font-weight:600}
.fg input,.fg select{padding:6px 8px;border:1px solid var(--b);border-radius:3px;background:#fafbfc;font-size:11.5px;color:var(--t)}
.fg input:focus,.fg select:focus{outline:none;border-color:var(--bl);box-shadow:0 0 0 2px rgba(29,78,216,.08)}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.g4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:8px}
.mbg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:100;align-items:center;justify-content:center;padding:20px}
.mbg.on{display:flex}
.mdl{background:var(--c);border:1px solid var(--b);border-radius:4px;width:600px;max-width:95vw;max-height:90vh;overflow-y:auto}
.mh{padding:10px 14px;border-bottom:1px solid var(--b);display:flex;align-items:center;justify-content:space-between}
.mh h3{font-size:12px;font-weight:700}.mx{font-size:16px;color:var(--t3);cursor:pointer}
.mbd{padding:11px 12px}
.sb{display:flex;gap:6px;margin-bottom:10px}
.sb input{flex:1;padding:6px 10px;border:1px solid var(--b);border-radius:3px;background:#fafbfc;font-size:11.5px}
.sb input:focus{outline:none;border-color:var(--bl)}
#toast{position:fixed;bottom:16px;right:16px;background:var(--t);color:#fff;padding:8px 14px;border-radius:3px;font-size:11px;font-weight:500;z-index:200;display:none}
#toast.on{display:block}
.ey{padding:24px;text-align:center;color:var(--t3);font-size:11px}
.mi{display:flex;gap:8px;padding:6px 0;border-bottom:1px solid #f3f4f6}
.mi:last-child{border-bottom:none}
.mic{width:22px;height:22px;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}
.min{background:var(--gnL);color:var(--gn)}.mou{background:var(--rdL);color:var(--rd)}
.tk{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid #f3f4f6}
.tk:last-child{border-bottom:none}
.tkc{width:16px;height:16px;border:1.5px solid var(--b);border-radius:2px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:9px;flex-shrink:0}
.tkc.dn{background:var(--gn);border-color:var(--gn);color:#fff}

/* ============================================================
   MOBILE
   ============================================================ */
@media(max-width:768px){#S{display:none}#H{left:0}#M{margin-left:0}}

/* ============================================================
   ANIMAÇÕES
   ============================================================ */
@keyframes blinker{50%{opacity:0.3}}
@keyframes fadeSlide{from{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}
@keyframes loginFadeIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes shakeErr{0%,100%{transform:translateX(0)}25%{transform:translateX(-6px)}75%{transform:translateX(6px)}}
@keyframes dotPulse{0%,100%{opacity:0.3}50%{opacity:1}}
@keyframes spinLG{to{transform:rotate(360deg)}}
