
:root{
  --bg:#f6f7f9;
  --bg-soft:#fbfcfd;
  --card:#ffffff;
  --text:#101828;
  --muted:#667085;
  --line:#e4e7ec;
  --primary:#155eef;
  --primary-soft:#eff4ff;
  --success:#12b76a;
  --warning:#f79009;
  --danger:#f04438;
  --shadow:0 1px 2px rgba(16,24,40,.06),0 10px 24px rgba(16,24,40,.04);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
a{text-decoration:none;color:inherit}button,input,select,textarea{font:inherit}
.layout{display:flex;min-height:100vh}
.sidebar{width:272px;background:#fff;color:var(--text);position:fixed;left:0;top:0;bottom:0;overflow:auto;padding:24px 16px;z-index:30;border-right:1px solid var(--line)}
.brand-wrap{display:flex;align-items:center;gap:12px;margin-bottom:20px}.compact-brand{margin-bottom:28px}
.brand-mark{width:42px;height:42px;border-radius:14px;background:var(--text);display:grid;place-items:center;font-weight:700;font-size:14px;color:#fff}
.brand-title{font-size:16px;font-weight:700;letter-spacing:-.02em}.brand-subtitle{font-size:12px;color:var(--muted);margin-top:2px}
.nav-group{display:grid;gap:4px;margin-top:16px}.nav-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#98a2b3;padding:0 12px 6px}
.nav-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;color:#344054;font-weight:500;transition:.16s ease}.nav-link:hover{background:#f9fafb}.nav-link.active{background:var(--primary-soft);color:var(--primary);font-weight:600}
.nav-icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 18px}.nav-icon svg{width:18px;height:18px;display:block}
.sidebar-footer{margin-top:18px;padding-top:18px;border-top:1px solid var(--line)}.user-mini{display:flex;align-items:center;gap:10px;padding:8px 8px 12px}.avatar{width:36px;height:36px;border-radius:50%;background:#101828;display:grid;place-items:center;font-weight:600;color:#fff}.avatar.small{width:32px;height:32px;font-size:12px}
.logout-link{color:#475467}
.main{margin-left:272px;flex:1;padding:20px 20px 28px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:10px 12px;box-shadow:var(--shadow);position:sticky;top:12px;z-index:20}.topbar-left,.topbar-right{display:flex;align-items:center;gap:10px}
.searchbar{display:flex;align-items:center;gap:10px;padding:0 14px;background:#fff;border:1px solid var(--line);border-radius:12px;min-width:280px;height:42px;color:var(--muted)}.searchbar input{border:0;background:transparent;outline:none;width:100%;color:var(--muted)}
.icon-btn,.mini-action,.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:12px;padding:10px 14px;font-weight:600;cursor:pointer;transition:.16s ease}.btn-block{width:100%}
.icon-btn{width:40px;height:40px;background:#fff;color:#344054;border:1px solid var(--line);padding:0}.icon-btn .nav-icon{margin:0}
.mini-action,.btn{background:var(--primary);color:#fff}.mini-action .nav-icon,.btn .nav-icon{color:#fff}.btn.secondary{background:#344054}.btn.success{background:var(--success)}.btn.danger{background:var(--danger)}.btn.light{background:#fff;color:#344054;border:1px solid var(--line)}.btn.outline{background:transparent;border:1px solid var(--line);color:#344054}.icon-btn:hover,.mini-action:hover,.btn:hover{filter:brightness(.98)}
.user-chip{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:14px;padding:6px 10px;background:#fff}.user-chip small,.user-mini small{display:block;color:var(--muted);margin-top:2px}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin:22px 2px 18px}.page-head h1{margin:0;font-size:28px;line-height:1.1;letter-spacing:-.03em}.page-head p{margin:6px 0 0}
.grid{display:grid;gap:16px}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.card{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:var(--shadow)}.card h2,.card h3{margin:0 0 14px;font-size:18px;letter-spacing:-.02em}.stat-card{position:relative}.stat-label{display:flex;align-items:center;gap:8px;color:var(--muted);font-weight:500;font-size:14px}.metric{font-size:28px;font-weight:700;margin:10px 0 4px;letter-spacing:-.04em}.muted{color:var(--muted)}.section-actions,.actions{display:flex;gap:8px;flex-wrap:wrap}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:16px}.table{width:100%;border-collapse:collapse;background:#fff}.table th,.table td{padding:12px 14px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}.table th{font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);background:#fcfcfd;font-weight:600}.table tr:last-child td{border-bottom:0}
.badge{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;font-size:12px;font-weight:600}.badge.info{background:#eff4ff;color:#155eef}.badge.warning{background:#fffaeb;color:#b54708}.badge.success{background:#ecfdf3;color:#027a48}.badge.danger{background:#fef3f2;color:#b42318}.badge.muted{background:#f2f4f7;color:#475467}
.form{display:grid;gap:14px}.form-row{display:grid;gap:14px;grid-template-columns:repeat(2,minmax(0,1fr))}label{display:block;margin-bottom:7px;font-size:13px;font-weight:600;color:#344054}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:12px;padding:11px 14px;background:#fff;color:var(--text);outline:none;transition:.16s ease}input:focus,select:focus,textarea:focus{border-color:#84adff;box-shadow:0 0 0 4px rgba(21,94,239,.08)}textarea{min-height:100px;resize:vertical}
.alert{padding:13px 16px;border-radius:14px;margin:14px 0;background:#ecfdf3;color:#027a48;border:1px solid #d1fadf}.alert.error{background:#fef3f2;color:#b42318;border-color:#fecdca}.alert.warning{background:#fffaeb;color:#b54708;border-color:#fedf89}
.login-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:var(--bg)}.login-shell{display:grid;grid-template-columns:1.1fr .9fr;gap:20px;max-width:1000px;width:100%}.minimal-login-shell{max-width:980px}
.login-panel,.login-card{border-radius:24px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow)}.login-panel{padding:32px;display:flex;flex-direction:column;justify-content:space-between}.minimal-login-panel{background:linear-gradient(180deg,#fff,#fafafa)}.login-card{padding:32px}.login-hero h1{font-size:36px;line-height:1.08;margin:10px 0 10px;letter-spacing:-.04em}.compact-hero p{max-width:520px}.login-minimal-points{display:grid;gap:14px;margin-top:28px}.login-minimal-points div{padding:14px 0;border-top:1px solid var(--line)}.login-minimal-points strong{display:block;margin-bottom:4px;font-size:14px}.login-minimal-points span{font-size:14px;color:var(--muted)}
.login-card-header h2{margin:0;font-size:28px;letter-spacing:-.03em}.login-card-header p{margin:8px 0 20px}.login-footer-note{margin-top:18px;padding:14px 16px;border-radius:14px;background:#f9fafb;color:var(--muted);font-size:13px;border:1px solid var(--line)}.minimal-note{background:#fcfcfd}
.ocr-box{white-space:pre-wrap;max-height:280px;overflow:auto;background:#101828;color:#f8fafc;border-radius:16px;padding:14px;font-size:13px}.chart{width:100%;height:320px;border:1px solid var(--line);border-radius:16px;background:#fff}.price-up{color:var(--danger);font-weight:700}.price-down{color:var(--success);font-weight:700}.inline-stats{display:flex;gap:12px;flex-wrap:wrap}.inline-stat{padding:12px 14px;background:#fcfcfd;border:1px solid var(--line);border-radius:14px;min-width:150px}.sidebar-overlay{display:none}.empty-state{padding:22px;text-align:center;color:var(--muted)}
@media (max-width:1100px){.grid-4,.kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.searchbar{min-width:220px}.login-shell{grid-template-columns:1fr}}
@media (max-width:900px){.sidebar{transform:translateX(-110%);transition:.2s ease}.sidebar.open{transform:translateX(0)}.sidebar-overlay{display:block;position:fixed;inset:0;background:rgba(16,24,40,.35);opacity:0;pointer-events:none;transition:.2s ease;z-index:25}.sidebar-overlay.show{opacity:1;pointer-events:auto}.main{margin-left:0;padding:14px}#menuBtn{display:inline-flex}.topbar{top:8px}.topbar-right .mini-action{display:none}.searchbar{min-width:unset;width:100%}.topbar-left{width:100%}.user-chip strong,.user-chip small{display:none}.grid-4,.grid-3,.grid-2,.kpis,.form-row{grid-template-columns:1fr}.page-head h1{font-size:24px}}
@media (max-width:640px){.topbar{align-items:flex-start;flex-direction:column}.topbar-right{width:100%;justify-content:flex-end}.card{padding:16px;border-radius:16px}.metric{font-size:24px}.login-page{padding:14px}.login-panel,.login-card{padding:22px;border-radius:20px}.login-hero h1{font-size:28px}.table-wrap{overflow:visible;border:0;background:transparent}.table,.table thead,.table tbody,.table tr,.table th,.table td{display:block;width:100%}.table thead{display:none}.table tr{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);margin-bottom:12px;overflow:hidden}.table td{border-bottom:1px solid var(--line);padding:10px 14px}.table td:last-child{border-bottom:0}.table td[data-label]::before{content:attr(data-label);display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#98a2b3;margin-bottom:4px}.actions{display:grid;grid-template-columns:1fr 1fr}.actions .btn{width:100%}}


/* Correção mobile da tela de login */
@media (max-width:640px){
  body:has(.login-page){
    background:#f6f7f9;
  }

  .login-page{
    min-height:100dvh;
    display:block;
    padding:14px;
    overflow:auto;
  }

  .minimal-login-shell,
  .login-shell{
    display:block;
    width:100%;
    max-width:100%;
  }

  .minimal-login-panel{
    display:none;
  }

  .minimal-login-card,
  .login-card{
    display:block;
    width:100%;
    max-width:100%;
    margin:0 auto;
    padding:22px;
    border-radius:20px;
  }

  .login-card-header h2{
    font-size:26px;
  }

  .login-footer-note{
    font-size:12px;
    padding:12px;
  }

  .btn-block{
    width:100%;
  }
}

@media (max-width:380px){
  .minimal-login-card,
  .login-card{
    padding:18px;
  }

  input,select,textarea{
    padding:10px 12px;
  }
}
