@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;600;700;800&family=Source+Sans+3:wght@400;600&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--p:#1a3a6b;--pl:#2563eb;--a:#f59e0b;--s:#059669;--d:#dc2626;--g1:#f8fafc;--g2:#e2e8f0;--g5:#64748b;--g8:#1e293b;--r:8px;--fs:1;--sb:250px}
html{font-size:calc(15px*var(--fs))}
body{font-family:'Source Sans 3',sans-serif;color:var(--g8);background:var(--g1);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--pl);text-decoration:none}

/* ── ADMIN LAYOUT ────────────────────────────────────────────── */
.layout{display:flex;height:100vh;overflow:hidden}
.sidebar{width:var(--sb);background:var(--p);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;transition:transform .25s;z-index:200}
.sb-brand{padding:18px;border-bottom:1px solid rgba(255,255,255,.1)}
.sb-logo{display:flex;align-items:center;gap:10px}
.sb-brasao{width:38px;height:38px;border-radius:50%;object-fit:contain;background:rgba(255,255,255,.12);border:2px solid rgba(255,255,255,.2);padding:2px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sb-name{font-family:'Sora',sans-serif;font-size:.92rem;font-weight:800;color:#fff;line-height:1.2}
.sb-sub{font-size:.62rem;color:rgba(255,255,255,.4);margin-top:2px;text-transform:uppercase;letter-spacing:.06em}
.sb-nav{flex:1;padding:8px 0}
.sb-sec{font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.28);padding:10px 18px 2px}
.sb-link{display:flex;align-items:center;gap:8px;padding:10px 18px;color:rgba(255,255,255,.65);font-size:.85rem;border-left:3px solid transparent;transition:all .15s;text-decoration:none}
.sb-link:hover,.sb-link.active{background:rgba(255,255,255,.09);color:#fff;border-left-color:var(--a)}
.sb-foot{padding:12px 18px;border-top:1px solid rgba(255,255,255,.08);font-size:.65rem;color:rgba(255,255,255,.22)}
.content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.topbar{height:56px;background:#fff;border-bottom:1px solid var(--g2);display:flex;align-items:center;justify-content:space-between;padding:0 16px;flex-shrink:0;gap:10px}
.tb-title{font-family:'Sora',sans-serif;font-size:.88rem;font-weight:700;color:var(--g8);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tb-user{display:flex;align-items:center;gap:9px;flex-shrink:0}
.tb-av{width:32px;height:32px;border-radius:50%;background:var(--p);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Sora',sans-serif;font-size:.7rem;font-weight:800;flex-shrink:0}
.tb-name{font-size:.8rem;font-weight:700;color:var(--g8);line-height:1}
.tb-role{font-size:.62rem;color:var(--g5);text-transform:uppercase}
.main{flex:1;padding:16px;overflow-y:auto;background:var(--g1)}

/* Hamburger button (mobile only) */
.sb-toggle{display:none;background:none;border:none;cursor:pointer;padding:6px;color:var(--g8);font-size:1.3rem;line-height:1;flex-shrink:0}
.sb-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:199}

/* ── CARDS ────────────────────────────────────────────────────── */
.card{background:#fff;border-radius:12px;border:1px solid var(--g2);margin-bottom:16px;overflow:hidden}
.ch{padding:13px 16px;border-bottom:1px solid var(--g1);display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}
.cht{font-family:'Sora',sans-serif;font-size:.85rem;font-weight:700;color:var(--g8)}
.cb{padding:16px}
.cf{padding:11px 16px;border-top:1px solid var(--g1);background:var(--g1);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}

/* ── STATS ────────────────────────────────────────────────────── */
.stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px;margin-bottom:18px}
.stat{background:#fff;border-radius:12px;padding:14px;border:1px solid var(--g2);border-left:4px solid var(--pl)}
.stat.g{border-left-color:var(--s)}.stat.a{border-left-color:var(--a)}.stat.r{border-left-color:var(--d)}
.sv{font-family:'Sora',sans-serif;font-size:1.6rem;font-weight:800;color:var(--g8);line-height:1}
.sl{font-size:.62rem;color:var(--g5);text-transform:uppercase;letter-spacing:.04em;margin-top:3px}

/* ── TABLE ────────────────────────────────────────────────────── */
.tw{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;font-size:.84rem;min-width:500px}
thead th{padding:9px 12px;background:var(--g1);font-family:'Sora',sans-serif;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--g5);border-bottom:2px solid var(--g2);white-space:nowrap}
tbody tr{border-bottom:1px solid var(--g1);transition:background .1s}
tbody tr:hover{background:var(--g1)}
td{padding:10px 12px;vertical-align:middle}

/* ── BADGES ────────────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:.65rem;font-weight:700;font-family:'Sora',sans-serif;white-space:nowrap}
.sit-publicada{background:#dbeafe;color:#1d4ed8}.sit-aberta{background:#d1fae5;color:#065f46}
.sit-em_andamento{background:#e0e7ff;color:#3730a3}.sit-finalizada{background:#f1f5f9;color:#475569}
.sit-suspensa{background:#fef3c7;color:#92400e}.sit-cancelada{background:#fee2e2;color:#991b1b}
.sit-anulada{background:#fce7f3;color:#9d174d}.sit-deserta{background:#1e293b;color:#e2e8f0}
.sit-fracassada{background:#292524;color:#e7e5e4}.sit-revogada{background:#ffedd5;color:#9a3412}
.b-ok{background:#d1fae5;color:#065f46}.b-w{background:#fef3c7;color:#92400e}.b-r{background:#fee2e2;color:#991b1b}

/* ── BUTTONS ────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:5px;padding:9px 14px;font-family:'Sora',sans-serif;font-size:.8rem;font-weight:600;border-radius:var(--r);border:2px solid transparent;cursor:pointer;white-space:nowrap;transition:all .15s;text-decoration:none;line-height:1;touch-action:manipulation}
.btn-p{background:var(--p);color:#fff;border-color:var(--p)}.btn-p:hover{background:#0f2347}
.btn-s{background:#fff;color:#475569;border-color:var(--g2)}.btn-s:hover{background:var(--g1)}
.btn-d{background:var(--d);color:#fff;border-color:var(--d)}
.btn-sm{padding:6px 11px;font-size:.74rem}
.btn-ico{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r);border:1px solid var(--g2);background:#fff;cursor:pointer;color:var(--g5);transition:all .15s;font-size:.85rem;touch-action:manipulation}
.btn-ico:hover{background:var(--p);color:#fff;border-color:var(--p)}

/* ── FORM GRID ────────────────────────────────────────────────── */
.fr2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fr3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.fg{margin-bottom:12px}
label.fl{display:block;font-family:'Sora',sans-serif;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#475569;margin-bottom:4px}
.fc{width:100%;padding:10px 12px;font-family:'Source Sans 3',sans-serif;font-size:.9rem;color:var(--g8);background:#fff;border:2px solid var(--g2);border-radius:var(--r);outline:none;transition:border .2s;-webkit-appearance:none;appearance:none}
.fc:focus{border-color:var(--pl);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
textarea.fc{resize:vertical;min-height:80px}
.fh{font-size:.7rem;color:#94a3b8;margin-top:4px}
.ph{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:8px}
.ph-h{font-family:'Sora',sans-serif;font-size:1.2rem;font-weight:800;color:var(--g8)}
.bc{font-size:.7rem;color:var(--g5);margin-bottom:3px}

/* ── ALERTS ────────────────────────────────────────────────────── */
.alert{padding:10px 14px;border-radius:var(--r);margin-bottom:12px;font-size:.84rem;border-left:4px solid}
.al-ok{background:#d1fae5;color:#064e3b;border-left-color:var(--s)}
.al-err{background:#fee2e2;color:#991b1b;border-left-color:var(--d)}

/* ── PAGINATION ────────────────────────────────────────────────── */
.pag-nums{display:flex;gap:3px;flex-wrap:wrap}
.pi{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;border-radius:var(--r);border:1px solid var(--g2);background:#fff;font-family:'Sora',sans-serif;font-size:.74rem;font-weight:600;color:var(--g5);cursor:pointer;transition:all .15s;text-decoration:none;padding:0 6px;touch-action:manipulation}
.pi:hover{background:var(--g1);color:var(--p)}.pi.active{background:var(--p);color:#fff;border-color:var(--p)}

/* ── UPLOAD / DOCS ────────────────────────────────────────────── */
.upload-area{border:2px dashed var(--g2);border-radius:10px;padding:22px;text-align:center;background:var(--g1);cursor:pointer;transition:all .2s}
.upload-area:hover{border-color:var(--pl);background:#eff6ff}
.doc-item{display:flex;align-items:center;gap:9px;padding:9px 12px;background:var(--g1);border:1px solid var(--g2);border-radius:var(--r);margin-bottom:6px}

/* ── FILTER BAR ────────────────────────────────────────────────── */
.filter-bar{background:#fff;border-radius:12px;border:1px solid var(--g2);padding:14px 16px;margin-bottom:14px}
.filter-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:9px;align-items:end}

/* ── ACCESSIBILITY ────────────────────────────────────────────── */
.a11y-js{position:fixed;top:0;right:0;z-index:9999}
.a11y-bar{position:fixed;top:0;right:0;z-index:9999;display:flex;align-items:center;gap:3px;background:rgba(10,22,40,.94);padding:4px 9px;border-radius:0 0 0 10px;backdrop-filter:blur(8px)}
.a11y-btn{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14);color:rgba(255,255,255,.8);font-family:'Sora',sans-serif;font-size:.65rem;font-weight:700;padding:3px 7px;border-radius:5px;cursor:pointer;transition:all .15s;white-space:nowrap;touch-action:manipulation}
.a11y-btn:hover{background:rgba(255,255,255,.22)}.a11y-btn.on{background:var(--a);border-color:var(--a);color:#000}
.a11y-sep{width:1px;height:15px;background:rgba(255,255,255,.12);margin:0 2px}
body.hi-c{filter:contrast(160%)}.body.pb{filter:grayscale(100%)}
body.rd{letter-spacing:.07em!important;line-height:1.9!important}
.vl{position:fixed;bottom:66px;right:14px;z-index:8000;width:46px;height:46px;border-radius:50%;background:var(--p);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.2rem;cursor:pointer;box-shadow:0 4px 12px rgba(0,0,0,.3);border:2px solid rgba(255,255,255,.2);transition:transform .2s;touch-action:manipulation}
.vl:hover{transform:scale(1.1)}

/* ── PORTAL ────────────────────────────────────────────────────── */
.portal-wrap{min-height:100vh;display:flex;flex-direction:column}
.ph-bar{background:var(--p);flex-shrink:0}
.ph-inner{max-width:1200px;margin:0 auto;padding:14px 16px;display:flex;align-items:center;gap:12px}
.brasao-img{width:52px;height:52px;border-radius:50%;object-fit:contain;background:rgba(255,255,255,.1);border:3px solid rgba(255,255,255,.2);padding:3px;flex-shrink:0}
.org-name{font-family:'Sora',sans-serif;font-size:1.1rem;font-weight:800;color:#fff;line-height:1.2}
.org-sub{font-size:.74rem;color:rgba(255,255,255,.5);margin-top:2px}
.pnav-bar{background:#0f2347;flex-shrink:0;overflow-x:auto;-webkit-overflow-scrolling:touch}
.pnav-bar::-webkit-scrollbar{display:none}
.pnav-inner{max-width:1200px;margin:0 auto;padding:0 16px;display:flex;gap:0;white-space:nowrap}
.pnav{padding:10px 14px;color:rgba(255,255,255,.65);font-family:'Sora',sans-serif;font-size:.82rem;font-weight:600;border-bottom:3px solid transparent;transition:all .15s;text-decoration:none;display:inline-flex;align-items:center;gap:4px;touch-action:manipulation}
.pnav:hover,.pnav.active{color:#fff;border-bottom-color:var(--a)}
.portal-body{flex:1;background:var(--g1)}
.pc{max-width:1200px;margin:0 auto;padding:18px 16px}
.pstats{background:#fff;border-radius:12px;border:1px solid var(--g2);padding:10px 16px;margin-bottom:16px;display:grid;grid-template-columns:repeat(4,1fr)}
.pstat{text-align:center;padding:5px;border-right:1px solid var(--g1)}
.pstat:last-child{border-right:none}
.psn{font-family:'Sora',sans-serif;font-size:1.4rem;font-weight:800;color:var(--p)}
.psn.g{color:var(--s)}.psn.a{color:var(--a)}.psn.s{color:var(--g5)}
.psl{font-size:.62rem;color:var(--g5);text-transform:uppercase;letter-spacing:.04em;margin-top:1px}
.portal-footer{background:#0a1628;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0}
.pf-main{max-width:1200px;margin:0 auto;padding:24px 16px;display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px}
.pf-title{font-family:'Sora',sans-serif;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:rgba(255,255,255,.28);margin-bottom:9px}
.pf-brand{font-family:'Sora',sans-serif;font-size:.96rem;font-weight:800;color:#fff;margin-bottom:5px}
.pf-desc{font-size:.78rem;color:rgba(255,255,255,.4);line-height:1.7;margin-bottom:12px}
.pf-link{display:flex;align-items:center;gap:5px;font-size:.78rem;color:rgba(255,255,255,.48);padding:4px 0;text-decoration:none;transition:color .15s}
.pf-link:hover{color:var(--a)}
.pf-bot{max-width:1200px;margin:0 auto;padding:10px 16px;border-top:1px solid rgba(255,255,255,.06);font-size:.7rem;color:rgba(255,255,255,.22);display:flex;justify-content:space-between;flex-wrap:wrap;gap:5px}

/* ════════════════════════════════════════
   RESPONSIVE — MOBILE FIRST
   ════════════════════════════════════════ */

/* Tablet ≤768px */
@media (max-width:768px) {
  /* Admin sidebar: off-canvas */
  .sidebar{position:fixed;top:0;left:0;height:100%;transform:translateX(-100%);box-shadow:4px 0 24px rgba(0,0,0,.25)}
  .sidebar.open{transform:translateX(0)}
  .sb-overlay.open{display:block}
  .sb-toggle{display:flex}
  .content{width:100%}
  .main{padding:12px}

  /* Form grids collapse */
  .fr2,.fr3{grid-template-columns:1fr}

  /* Page header stack */
  .ph{flex-direction:column;align-items:flex-start;gap:10px}

  /* Stats wrap */
  .stats{grid-template-columns:repeat(2,1fr)}

  /* Filter grid */
  .filter-grid{grid-template-columns:1fr 1fr}

  /* Portal header */
  .ph-inner{padding:12px 14px;gap:10px}
  .brasao-img{width:42px;height:42px}
  .org-name{font-size:.95rem}

  /* Portal stats */
  .pstats{grid-template-columns:repeat(2,1fr);gap:4px}
  .pstat{border-right:none;border-bottom:1px solid var(--g1);padding-bottom:8px}
  .pstat:nth-child(odd){border-right:1px solid var(--g1)}
  .pstat:last-child,.pstat:nth-last-child(2):nth-child(odd){border-bottom:none}

  /* Portal footer */
  .pf-main{grid-template-columns:1fr;gap:18px}

  /* Tables: hide less important columns */
  .hide-mob{display:none}

  /* Doc items stack */
  .doc-item{flex-wrap:wrap;gap:6px}

  /* Buttons smaller */
  .btn{padding:8px 12px;font-size:.78rem}

  /* Cards */
  .cb{padding:14px}
  .ch{padding:11px 14px}
}

/* Mobile ≤480px */
@media (max-width:480px) {
  .stats{grid-template-columns:1fr 1fr}
  .sv{font-size:1.3rem}
  .filter-grid{grid-template-columns:1fr}
  .pnav{padding:9px 10px;font-size:.76rem}
  .brasao-img{width:36px;height:36px}
  .org-name{font-size:.88rem}
  .org-sub{display:none}
  table{font-size:.8rem}
  td,thead th{padding:8px 9px}
  .ph-h{font-size:1rem}
  .btn-sm{padding:5px 9px;font-size:.72rem}

  /* Topbar: hide user name on very small */
  .tb-name,.tb-role{display:none}
}
