:root{
    /* Paleta da marca GEOGRAPHIC */
    --c1:#fafdd3; --c2:#ecf39e; --c3:#aacc00; --c4:#31572c; --c5:#132a13;
    --card:#ffffff; --ink:#16240f; --muted:#6f8060;
    --line:#e4ecc7; --brand:#31572c; --brand2:#234020; --accent:#aacc00; --soft:#f4f8df;
    --green:#31572c; --red:#c0392b; --amber:#c98a00; --violet:#5a8c2a;
    --font-brand:'Poppins',-apple-system,Segoe UI,Arial,sans-serif;
    --font-body:'Nunito Sans',-apple-system,Segoe UI,Roboto,Arial,sans-serif;
    --shadow:0 1px 3px rgba(19,42,19,.10),0 1px 2px rgba(19,42,19,.05);
  }
  *{box-sizing:border-box}
  body{margin:0;font-family:var(--font-body);background:#f7f9ec;color:var(--ink);font-size:14px}
  header{background:linear-gradient(120deg,var(--c4),var(--c5));color:#fff;padding:12px 20px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;position:sticky;top:0;z-index:50}
  .brand{display:flex;align-items:center;gap:11px}
  .mark-badge{background:var(--c1);border-radius:11px;padding:5px 8px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
  .brand .mark{height:34px;width:auto;display:block}
  .wordmark{font-family:var(--font-brand);line-height:1}
  .wordmark .wm{font-weight:800;font-size:20px;letter-spacing:.3px}
  .wordmark .wm .geo{color:var(--c2)} .wordmark .wm .graphic{color:var(--c3)}
  .wordmark .tag{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--c2);opacity:.85;margin-top:2px;font-weight:600}
  header h1{font-size:18px;margin:0;font-weight:700;letter-spacing:.2px;font-family:var(--font-brand)}
  nav{display:flex;gap:4px;margin-left:8px;flex-wrap:wrap;font-family:var(--font-brand)}
  nav button{background:transparent;color:#d7e3bb;border:0;padding:8px 14px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600}
  nav a.nav-link{background:transparent;color:#d7e3bb;border:0;padding:8px 14px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;text-decoration:none;display:inline-block}
  nav a.nav-link.active{background:rgba(170,204,0,.22);color:#fff}
  nav a.nav-link:hover{color:#fff}
  .grow{flex:1}
  .btn{border:0;border-radius:9px;padding:9px 14px;font-size:14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;font-family:var(--font-brand)}
  .btn.primary{background:var(--accent);color:var(--c5)}
  .btn.primary:hover{background:#98b800}
  .btn.ghost{background:rgba(255,255,255,.14);color:#fff}
  .btn.ghost:hover{background:rgba(255,255,255,.24)}
  header a.btn{text-decoration:none}
  .btn.sm{padding:6px 10px;font-size:13px}
  .btn.light{background:var(--soft);color:var(--ink)}
  .btn.light:hover{background:var(--c2)}
  .btn.brand{background:linear-gradient(120deg,var(--c4),var(--c5));color:#fff}
  .btn.brand:hover{background:linear-gradient(120deg,var(--brand2),var(--c5))}
  main{padding:20px;max-width:1500px;margin:0 auto}
  .view{display:none}
  .view.active{display:block}

  /* KPIs */
  .kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:18px}
  .kpi{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px;box-shadow:var(--shadow)}
  .kpi .lab{color:var(--muted);font-size:12.5px;font-weight:600;text-transform:uppercase;letter-spacing:.4px}
  .kpi .val{font-size:26px;font-weight:800;margin-top:6px;font-family:var(--font-brand)}
  .kpi .sub{font-size:12px;color:var(--muted);margin-top:2px}
  .kpi.g .val{color:var(--green)} .kpi.b .val{color:var(--brand)} .kpi.a .val{color:var(--amber)} .kpi.v .val{color:var(--violet)} .kpi.r .val{color:var(--red)}
  .kpi input{margin-top:9px;width:100%;padding:6px 8px;font-size:13px}
  .kpi .sub.range{margin-top:6px}
  .clickable{cursor:pointer;transition:transform .08s,box-shadow .12s,border-color .12s}
  .clickable:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(19,42,19,.16);border-color:var(--accent)}
  .bar.clickable:hover{transform:none;box-shadow:none}
  .bar.clickable:hover .name{color:var(--brand);text-decoration:underline}

  .grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
  @media(max-width:900px){.grid2{grid-template-columns:1fr}}
  .panel{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px;box-shadow:var(--shadow);margin-bottom:16px}
  .panel h3{margin:0 0 12px;font-size:15px;font-family:var(--font-brand);color:var(--c4)}
  .bar{display:flex;align-items:center;gap:10px;margin:7px 0}
  .bar .name{width:140px;font-size:13px;color:var(--c4);flex-shrink:0}
  .bar .track{flex:1;background:var(--soft);border-radius:6px;height:18px;overflow:hidden}
  .bar .fill{height:100%;border-radius:6px;background:var(--brand)}
  .bar .num{width:120px;text-align:right;font-size:12.5px;color:var(--muted);flex-shrink:0}

  /* Filters */
  .filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px;align-items:center}
  .filters-clientes{display:grid;grid-template-columns:repeat(4,minmax(0,1fr)) auto auto;gap:10px;width:100%;align-items:center;margin-bottom:16px}
  .filters-clientes .filter-field{width:100%;min-width:0}
  .filters-clientes .filters-count{white-space:nowrap;font-weight:600}
  .filters-clientes .btn.brand{align-self:stretch;display:inline-flex;align-items:center;justify-content:center;padding:9px 14px;min-height:42px}
  input,select,textarea{font-family:inherit;font-size:14px;padding:9px 11px;border:1px solid var(--line);border-radius:9px;background:#fff;color:var(--ink);outline:none}
  input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(170,204,0,.22)}
  .search{flex:1;min-width:200px}

  /* Table */
  .tablewrap{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:auto;box-shadow:var(--shadow)}
  table{border-collapse:collapse;width:100%;min-width:760px}
  th,td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line);font-size:13.5px;white-space:nowrap}
  th{background:var(--c2);font-family:var(--font-brand);font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--c4);position:sticky;top:0;cursor:pointer;user-select:none}
  tbody tr:hover{background:var(--soft);cursor:pointer}
  td.wrap{white-space:normal;min-width:160px;max-width:260px}
  .tag{display:inline-block;padding:3px 9px;border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap}
  .muted{color:var(--muted)}
  .overdue{color:var(--red);font-weight:700}
  .due-soon{color:var(--amber);font-weight:700}
  .empty{padding:40px;text-align:center;color:var(--muted)}

  /* Kanban */
  .kanban{display:flex;gap:14px;overflow-x:auto;padding-bottom:10px}
  .col{background:var(--soft);border-radius:14px;padding:10px;min-width:260px;width:260px;flex-shrink:0}
  .col h4{margin:2px 4px 10px;font-size:13px;display:flex;justify-content:space-between;align-items:center;font-family:var(--font-brand);color:var(--c4)}
  .col h4 .cnt{background:#fff;border-radius:999px;padding:1px 9px;font-size:12px;color:var(--muted)}
  .col .val{font-size:11.5px;color:var(--muted);font-weight:600}
  .ccard{background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px;margin-bottom:9px;cursor:pointer;box-shadow:var(--shadow)}
  .ccard:hover{border-color:var(--brand)}
  .ccard .n{font-weight:700;font-size:13.5px}
  .ccard .m{font-size:12px;color:var(--muted);margin-top:3px}
  .ccard .v{font-size:12.5px;font-weight:700;color:var(--green);margin-top:5px}

  /* Modal */
  .overlay{position:fixed;inset:0;background:rgba(15,23,42,.55);display:none;z-index:100;padding:20px;overflow:auto}
  .overlay.open{display:block}
  .modal{background:#fff;max-width:820px;margin:24px auto;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.3);overflow:hidden}
  .modal.modal-lg{max-width:960px}
  #configOverlay.open{display:flex;align-items:center;justify-content:center;padding:24px}
  #configOverlay .modal.modal-lg{width:100%;max-width:960px;margin:0;min-height:min(88vh,860px);max-height:94vh;display:flex;flex-direction:column}
  #configOverlay .modal.modal-lg .cfg-body{flex:1;display:flex;flex-direction:column;min-height:0;max-height:none;overflow:hidden}
  #configOverlay .modal.modal-lg .cfg-panel{flex:1;display:flex;flex-direction:column;min-height:0}
  #configOverlay .modal.modal-lg .cfg-rows{flex:1;max-height:none;min-height:380px}
  .modal header{background:var(--card);color:var(--ink);border-bottom:1px solid var(--line);position:static}
  .modal header h2{font-size:17px;margin:0;font-family:var(--font-brand);color:var(--c4)}
  .modal .body{padding:18px;max-height:70vh;overflow:auto}
  .modal footer{padding:14px 18px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end;background:var(--soft)}
  .form{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  @media(max-width:640px){.form{grid-template-columns:1fr}}
  .field{display:flex;flex-direction:column;gap:5px}
  .field.full{grid-column:1/-1}
  .field label{font-size:12.5px;font-weight:600;color:var(--c4)}
  .field input,.field select,.field textarea{width:100%}
  /* Config listas modal */
  .cfg-intro{margin:0 0 14px;font-size:13.5px;line-height:1.45}
  .cfg-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
  .cfg-tab{border:1px solid var(--line);background:var(--soft);color:var(--c4);border-radius:999px;padding:7px 14px;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font-brand)}
  .cfg-tab.active{background:linear-gradient(120deg,var(--c4),var(--c5));color:#fff;border-color:transparent}
  .cfg-tab.active .muted{color:rgba(255,255,255,.85)}
  .cfg-tab:hover:not(.active){background:var(--c2)}
  .cfg-panel-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
  .cfg-panel-head h3{margin:0;font-size:15px;font-family:var(--font-brand);color:var(--c4)}
  .cfg-rows{display:flex;flex-direction:column;gap:8px;max-height:340px;overflow:auto;padding-right:4px}
  .cfg-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}
  .cfg-row input{width:100%}
  .cfg-row-del{border:0;background:#fee2e2;color:var(--red);border-radius:8px;width:38px;height:38px;cursor:pointer;font-size:16px;line-height:1;flex-shrink:0}
  .cfg-row-del:hover{background:#fecaca}
  .cfg-empty{padding:24px;text-align:center;color:var(--muted);background:var(--soft);border-radius:10px;border:1px dashed var(--line)}
  #cfgAddRow.btn.brand,#cfgSave.btn.brand{background:linear-gradient(120deg,var(--c4),var(--c5));color:#fff}
  #cfgAddRow.btn.brand:hover,#cfgSave.btn.brand:hover{background:linear-gradient(120deg,var(--brand2),var(--c5))}
  .toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--c5);color:#fff;padding:11px 18px;border-radius:10px;box-shadow:0 10px 30px rgba(0,0,0,.3);z-index:200;opacity:0;transition:opacity .25s;pointer-events:none}
  .toast.show{opacity:1}
  a.wa{color:var(--green);text-decoration:none;font-weight:600}
  a.wa:hover{text-decoration:underline}
  .cad{font-size:13px;color:#334155}
  .cad li{margin:5px 0}
  .menu{position:relative}
  .menu .pop{display:none;position:absolute;right:0;top:110%;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 10px 30px rgba(0,0,0,.18);min-width:210px;z-index:60;overflow:hidden}
  .menu.open .pop{display:block}
  .menu .pop button{display:block;width:100%;text-align:left;background:#fff;border:0;padding:11px 14px;font-size:13.5px;cursor:pointer;color:var(--ink)}
  .menu .pop button:hover{background:var(--soft)}
  .menu .pop hr{border:0;border-top:1px solid var(--line);margin:0}
  /* LOGIN */
  body.locked{overflow:hidden}
  .login-gate{position:fixed;inset:0;background:linear-gradient(120deg,var(--c4),var(--c5));display:flex;align-items:center;justify-content:center;z-index:500;padding:20px}
  .login-box{background:#fff;border-radius:16px;padding:30px;width:100%;max-width:360px;box-shadow:0 20px 60px rgba(0,0,0,.35);text-align:center}
  .login-mark{height:66px;width:auto;display:block;margin:0 auto 20px}
  .login-sub{color:var(--muted);margin:0 0 20px;font-size:13px}
  .login-field{text-align:left;margin-bottom:14px}
  .login-field label{display:block;font-size:12.5px;font-weight:600;color:var(--c4);margin-bottom:5px}
  .login-field input{width:100%;margin-bottom:0}
  .login-pw-wrap{position:relative}
  .login-pw-wrap input{padding-right:44px}
  .login-pw-toggle{position:absolute;right:4px;top:50%;transform:translateY(-50%);border:0;background:transparent;padding:6px 8px;cursor:pointer;color:var(--muted);border-radius:6px;display:flex;align-items:center;justify-content:center;line-height:0}
  .login-pw-toggle:hover{color:var(--c4);background:var(--soft)}
  .login-pw-toggle svg{width:20px;height:20px;display:block}
  .login-pw-toggle .icon-hide{display:none}
  .login-pw-toggle.visible .icon-show{display:none}
  .login-pw-toggle.visible .icon-hide{display:block}
  .login-err{color:var(--red);font-size:13px;min-height:18px;margin-bottom:8px;font-weight:600;text-align:center}
  .login-lockout{color:var(--amber);font-size:13px;font-weight:600;text-align:center;margin-bottom:10px;min-height:18px}
  .login-lockout:empty{display:none}
  .login-actions{display:flex;justify-content:center;margin-top:4px}
  .login-actions .btn{min-width:160px;justify-content:center}
  .login-actions .btn.primary:disabled{opacity:.55;cursor:not-allowed}
  .login-box.is-locked .login-field input:disabled{opacity:.65;cursor:not-allowed;background:var(--soft)}
  /* USUÁRIO / ADMIN */
  .user-tag{color:var(--c2);font-size:13px;font-weight:600;margin-right:4px;white-space:nowrap}
  .perms{display:flex;flex-wrap:wrap;gap:10px 18px;padding:10px;background:var(--soft);border-radius:10px}
  .chk{display:flex;align-items:center;gap:7px;font-size:13.5px;cursor:pointer}
  .chk.adminchk{flex-basis:100%;border-top:1px dashed var(--line);padding-top:9px;margin-top:3px}
  .utbl{width:100%;border-collapse:collapse}
  .utbl th,.utbl td{padding:9px 10px;border-bottom:1px solid var(--line);font-size:13.5px;text-align:left;white-space:nowrap}
  .utbl th{font-family:var(--font-brand);font-size:11.5px;text-transform:uppercase;color:var(--muted);background:var(--soft)}
  .badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11.5px;font-weight:600}
  .badge.on{background:#aacc0022;color:#5a7d00} .badge.off{background:#c0392b22;color:#c0392b}
  .badge.adm{background:#31572c22;color:#31572c}
  .pill{display:inline-block;padding:1px 7px;border-radius:6px;font-size:11px;background:var(--c2);color:var(--c4);margin:1px;font-weight:600}