/* ===================== AgilusMed · Repositório de Documentos ===================== */
@font-face { font-family:"Montserrat"; src:url("/fonts/Montserrat-Regular.ttf") format("truetype"); font-weight:400; font-display:swap; }
@font-face { font-family:"Montserrat"; src:url("/fonts/Montserrat-Medium.ttf") format("truetype"); font-weight:500; font-display:swap; }
@font-face { font-family:"Montserrat"; src:url("/fonts/Montserrat-SemiBold.ttf") format("truetype"); font-weight:600; font-display:swap; }
@font-face { font-family:"Montserrat"; src:url("/fonts/Montserrat-Bold.ttf") format("truetype"); font-weight:700; font-display:swap; }
@font-face { font-family:"Montserrat"; src:url("/fonts/Montserrat-ExtraBold.ttf") format("truetype"); font-weight:800; font-display:swap; }

:root{
  --oliva:#585850; --oliva-esc:#43433c; --oliva-claro:#6f6f64;
  --dourado:#D8C860; --dourado-esc:#B9A63F;
  --bg:#f4f4f1; --card:#ffffff; --linha:#e7e7e1; --texto:#33332e; --suave:#8a8a80;
  --vermelho:#c0392b; --laranja:#c97a17; --amarelo:#b9930a; --verde:#4f7a3a;
  --radius:14px; --sombra:0 1px 3px rgba(60,60,50,.08),0 6px 22px rgba(60,60,50,.06);
}
*{box-sizing:border-box}
[hidden]{display:none !important}
html,body{margin:0;padding:0}
body{font-family:"Montserrat",system-ui,sans-serif;background:var(--bg);color:var(--texto);-webkit-font-smoothing:antialiased;font-size:15px}
h1,h2,h3{margin:0;font-weight:700;letter-spacing:-.01em}
a{color:var(--oliva)}
button{font-family:inherit}
input,select,textarea{font-family:inherit;font-size:15px}

/* -------- Botões -------- */
.btn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--linha);background:#fff;color:var(--texto);
  padding:9px 15px;border-radius:10px;cursor:pointer;font-weight:600;font-size:14px;transition:.15s;white-space:nowrap}
.btn:hover{border-color:#cfcfc6;background:#fafaf8}
.btn svg{width:17px;height:17px}
.btn-primary{background:var(--oliva);border-color:var(--oliva);color:#fff}
.btn-primary:hover{background:var(--oliva-esc);border-color:var(--oliva-esc)}
.btn-gold{background:var(--dourado);border-color:var(--dourado);color:#43433c}
.btn-gold:hover{background:var(--dourado-esc);border-color:var(--dourado-esc)}
.btn-ghost{border-color:transparent;background:transparent}
.btn-ghost:hover{background:#eceae3}
.btn-danger{color:var(--vermelho);border-color:#e9cfca}
.btn-danger:hover{background:#fbeae7;border-color:#e0b6ae}
.btn-sm{padding:6px 11px;font-size:13px;border-radius:9px}
.btn-block{width:100%;justify-content:center;padding:12px}
.btn:disabled{opacity:.55;cursor:not-allowed}
.icon-btn{padding:7px;border-radius:9px;line-height:0}

/* -------- Login -------- */
.login-wrap{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;padding:24px;
  background:radial-gradient(1200px 600px at 50% -10%, #fff, var(--bg))}
.login-card{background:var(--card);border:1px solid var(--linha);border-radius:18px;box-shadow:var(--sombra);
  padding:30px 28px;width:100%;max-width:380px;display:flex;flex-direction:column;gap:12px}
.login-logo{height:54px;object-fit:contain;align-self:center;margin-bottom:6px}
.login-card h1{font-size:20px;text-align:center;color:var(--oliva)}
.login-sub{margin:0 0 8px;text-align:center;color:var(--suave);font-size:13px}
.login-card label,.modal label{display:flex;flex-direction:column;gap:5px;font-size:13px;font-weight:600;color:var(--oliva)}
.login-card input,.modal input,.modal select,.modal textarea{
  border:1px solid var(--linha);border-radius:10px;padding:11px 12px;background:#fcfcfa;color:var(--texto);font-weight:500}
.login-card input:focus,.modal input:focus,.modal select:focus,.modal textarea:focus{
  outline:none;border-color:var(--dourado-esc);background:#fff;box-shadow:0 0 0 3px rgba(216,200,96,.18)}
.login-foot{color:var(--suave);font-size:12px}
.erro{color:var(--vermelho);font-size:13px;font-weight:600;min-height:18px;text-align:center}

/* -------- Topo / layout -------- */
.topbar{position:sticky;top:0;z-index:20;background:var(--oliva);color:#fff;display:flex;align-items:center;gap:16px;
  padding:0 18px;height:60px;box-shadow:0 2px 12px rgba(60,60,50,.18)}
.topbar .brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:16px;color:#fff;text-decoration:none}
.topbar .brand img{height:30px}
.topbar .brand small{display:block;font-size:10.5px;font-weight:600;color:var(--dourado);letter-spacing:.04em;text-transform:uppercase}
.nav{display:flex;gap:2px;margin-left:8px;flex:1;overflow-x:auto}
.nav a{display:inline-flex;align-items:center;gap:7px;color:#e9e9e2;text-decoration:none;padding:9px 13px;border-radius:9px;
  font-weight:600;font-size:14px;white-space:nowrap;cursor:pointer}
.nav a svg{width:17px;height:17px;opacity:.85}
.nav a:hover{background:rgba(255,255,255,.1)}
.nav a.ativo{background:rgba(216,200,96,.22);color:#fff}
.nav a.ativo svg{opacity:1;color:var(--dourado)}
.usermenu{position:relative}
.usermenu>button{display:flex;align-items:center;gap:9px;background:rgba(255,255,255,.08);border:none;color:#fff;
  padding:7px 11px;border-radius:10px;cursor:pointer;font-weight:600;font-size:13px}
.usermenu .av{width:28px;height:28px;border-radius:50%;background:var(--dourado);color:#43433c;display:grid;place-items:center;font-weight:800;font-size:13px}
.dropdown{position:absolute;right:0;top:46px;background:#fff;color:var(--texto);border:1px solid var(--linha);border-radius:12px;
  box-shadow:var(--sombra);min-width:210px;padding:6px;display:none}
.dropdown.open{display:block}
.dropdown .who{padding:9px 11px;border-bottom:1px solid var(--linha);margin-bottom:4px}
.dropdown .who b{display:block;font-size:14px}
.dropdown .who span{font-size:12px;color:var(--suave)}
.dropdown button{display:flex;align-items:center;gap:9px;width:100%;text-align:left;background:none;border:none;padding:9px 11px;
  border-radius:8px;cursor:pointer;font-size:14px;color:var(--texto);font-weight:500}
.dropdown button:hover{background:#f3f2ec}

main{max-width:1180px;margin:0 auto;padding:22px 18px 60px}
.page-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.page-head h2{font-size:22px;color:var(--oliva-esc)}
.page-head .sub{color:var(--suave);font-size:13px;margin-top:2px}
.toolbar{display:flex;gap:9px;flex-wrap:wrap;align-items:center}

/* -------- Cards / grids -------- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:22px}
.stat{background:var(--card);border:1px solid var(--linha);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--sombra)}
.stat .v{font-size:30px;font-weight:800;color:var(--oliva-esc);line-height:1}
.stat .l{color:var(--suave);font-size:13px;font-weight:600;margin-top:6px}
.stat.alerta .v{color:var(--vermelho)}
.stat.aviso .v{color:var(--laranja)}
.stat .l svg{width:15px;height:15px;vertical-align:-2px;margin-right:3px}

.panel{background:var(--card);border:1px solid var(--linha);border-radius:var(--radius);box-shadow:var(--sombra);margin-bottom:18px;overflow:hidden}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 18px;border-bottom:1px solid var(--linha)}
.panel-head h3{font-size:16px;color:var(--oliva-esc);display:flex;align-items:center;gap:8px}
.panel-head h3 svg{width:18px;height:18px;color:var(--oliva)}
.panel-body{padding:6px 18px 16px}

/* -------- Tabelas -------- */
.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.03em;color:var(--suave);font-weight:700;padding:10px 10px;border-bottom:1px solid var(--linha)}
.tbl td{padding:11px 10px;border-bottom:1px solid #f0efe9;vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr.click{cursor:pointer}
.tbl tr.click:hover td{background:#faf9f4}
.tbl .nome{font-weight:600;color:var(--oliva-esc)}
.tbl .mut{color:var(--suave);font-size:13px}
.right{text-align:right}.center{text-align:center}
.acoes{display:flex;gap:5px;justify-content:flex-end}

/* -------- Chips / badges -------- */
.chip{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;
  background:#eef0e8;color:var(--oliva)}
.chip.cat{background:#eef0e8;color:var(--oliva-esc)}
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:7px;font-size:12px;font-weight:700}
.b-vencido{background:#fbeae7;color:var(--vermelho)}
.b-30{background:#fbeedd;color:var(--laranja)}
.b-60{background:#fdf6df;color:var(--amarelo)}
.b-90{background:#eaf2e4;color:var(--verde)}
.b-ok{background:#eef0e8;color:var(--oliva)}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.pill-tab{display:inline-flex;background:#eceae3;border-radius:10px;padding:3px;gap:3px}
.pill-tab button{border:none;background:none;padding:7px 14px;border-radius:8px;font-weight:600;font-size:13px;color:var(--suave);cursor:pointer}
.pill-tab button.ativo{background:#fff;color:var(--oliva-esc);box-shadow:0 1px 3px rgba(0,0,0,.08)}

/* -------- Busca / inputs inline -------- */
.search{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--linha);border-radius:10px;padding:0 12px;min-width:230px}
.search input{border:none;outline:none;background:none;padding:10px 0;flex:1;font-weight:500}
.search svg{width:17px;height:17px;color:var(--suave)}
select.sel{border:1px solid var(--linha);border-radius:10px;padding:9px 12px;background:#fff;font-weight:600;color:var(--texto);cursor:pointer}

/* -------- Modal -------- */
.modal-bg{position:fixed;inset:0;background:rgba(50,50,42,.42);backdrop-filter:blur(2px);z-index:60;display:flex;align-items:flex-start;justify-content:center;padding:30px 16px;overflow:auto}
.modal{background:#fff;border-radius:18px;box-shadow:0 20px 60px rgba(0,0,0,.25);width:100%;max-width:540px;animation:pop .14s ease}
.modal.lg{max-width:760px}
@keyframes pop{from{transform:translateY(8px);opacity:.6}to{transform:none;opacity:1}}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--linha)}
.modal-head h3{font-size:18px;color:var(--oliva-esc)}
.modal-body{padding:20px 22px;display:flex;flex-direction:column;gap:14px}
.modal-foot{display:flex;justify-content:flex-end;gap:9px;padding:14px 22px;border-top:1px solid var(--linha)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.row{display:flex;gap:12px;align-items:center}
.check{flex-direction:row !important;align-items:center;gap:9px;cursor:pointer;font-weight:600;color:var(--texto)}
.check input{width:18px;height:18px;accent-color:var(--oliva)}
.hint{font-size:12px;color:var(--suave);font-weight:500}

/* -------- Dropzone -------- */
.dropzone{border:2px dashed #d3d2c8;border-radius:12px;padding:22px;text-align:center;color:var(--suave);cursor:pointer;background:#fcfcfa;transition:.15s}
.dropzone:hover,.dropzone.over{border-color:var(--dourado-esc);background:#fffdf2;color:var(--oliva)}
.dropzone svg{width:26px;height:26px;color:var(--oliva-claro);margin-bottom:6px}
.dropzone b{color:var(--oliva-esc)}
.file-chip{display:flex;align-items:center;gap:10px;background:#eef0e8;border-radius:10px;padding:10px 12px;font-weight:600;color:var(--oliva-esc)}
.file-chip .x{margin-left:auto;cursor:pointer;color:var(--suave)}

/* -------- Estados -------- */
.empty{text-align:center;color:var(--suave);padding:46px 20px}
.empty svg{width:42px;height:42px;opacity:.4;margin-bottom:10px}
.empty b{display:block;color:var(--oliva-esc);font-size:16px;margin-bottom:4px}
.loading{text-align:center;color:var(--suave);padding:40px}
.spin{width:30px;height:30px;border:3px solid var(--linha);border-top-color:var(--oliva);border-radius:50%;animation:r 1s linear infinite;margin:0 auto 12px}
@keyframes r{to{transform:rotate(360deg)}}

/* -------- Toast -------- */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);background:var(--oliva-esc);color:#fff;padding:12px 20px;
  border-radius:12px;font-weight:600;font-size:14px;z-index:90;box-shadow:0 8px 30px rgba(0,0,0,.25);max-width:90vw}
.toast.err{background:var(--vermelho)}
.toast.ok{background:var(--verde)}

/* -------- Portal cliente -------- */
.portal-hero{background:linear-gradient(120deg,var(--oliva),var(--oliva-esc));color:#fff;border-radius:var(--radius);padding:24px;margin-bottom:20px}
.portal-hero h2{font-size:22px}
.portal-hero p{margin:6px 0 0;color:#e6e6dd}
.doc-card{display:flex;align-items:center;gap:14px;padding:13px 14px;border:1px solid var(--linha);border-radius:12px;background:#fff;margin-bottom:10px}
.doc-card .fi{width:42px;height:42px;border-radius:10px;background:#eef0e8;display:grid;place-items:center;color:var(--oliva);flex-shrink:0}
.doc-card .fi svg{width:21px;height:21px}
.doc-card .meta{flex:1;min-width:0}
.doc-card .meta b{display:block;color:var(--oliva-esc);font-size:15px}
.doc-card .meta span{font-size:12.5px;color:var(--suave)}
.cat-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--dourado-esc);margin:18px 0 10px}

@media (max-width:680px){
  main{padding:16px 12px 60px}
  .grid2{grid-template-columns:1fr}
  .nav a span{display:none}
  .nav a{padding:9px}
  .hide-sm{display:none}
  .topbar .brand small{display:none}
}
