:root{--bg:#0b1120;--bg-soft:#0f172a;--surface:#fff;--surface-2:#f8fafc;--border:#e2e8f0;--text:#0f172a;--text-soft:#64748b;--primary:#2563eb;--primary-d:#1d4ed8;--radius:12px;--shadow:0 1px 3px rgba(15,23,42,.08),0 1px 2px rgba(15,23,42,.04);--shadow-lg:0 10px 30px rgba(15,23,42,.12)}[data-theme=dark]{--bg:#020617;--bg-soft:#0f172a;--surface:#1e293b;--surface-2:#0f172a;--border:#334155;--text:#e2e8f0;--text-soft:#94a3b8;--primary:#3b82f6;--primary-d:#2563eb;--shadow:0 1px 3px rgba(0,0,0,.4);--shadow-lg:0 10px 30px rgba(0,0,0,.5);color-scheme:dark}*{box-sizing:border-box}body,html{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--text);background:var(--surface-2);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}.shell{min-height:100vh;display:flex;flex-direction:column}.topbar{position:-webkit-sticky;position:sticky;top:0;z-index:30;gap:16px;padding:0 20px;height:60px;background:var(--bg);color:#fff;box-shadow:var(--shadow)}.brand,.topbar{display:flex;align-items:center}.brand{font-weight:700;font-size:17px;letter-spacing:.2px;gap:8px}.brand .dot{width:10px;height:10px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 4px rgba(34,197,94,.2)}.nav{display:flex;gap:4px;margin-left:12px;flex:1 1;flex-wrap:wrap}.nav a{padding:8px 12px;border-radius:8px;font-size:14px;color:#cbd5e1;font-weight:500}.nav a:hover{background:hsla(0,0%,100%,.08);color:#fff}.nav a.active{background:var(--primary);color:#fff}.topbar-right{display:flex;align-items:center;gap:14px}.user-chip{display:flex;flex-direction:column;align-items:flex-end;line-height:1.2}.user-chip .name{font-size:13px;font-weight:600}.user-chip .role{font-size:11px;color:#94a3b8}.content{flex:1 1;width:100%;max-width:1100px;margin:0 auto;padding:24px 20px 60px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.page-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}.page-head h1{font-size:22px;margin:0}.page-head p{margin:4px 0 0;color:var(--text-soft);font-size:14px}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));grid-gap:14px;gap:14px;margin-bottom:24px}.stat{padding:16px}.stat .label{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-soft);font-weight:600}.stat .value{font-size:28px;font-weight:700;margin-top:6px}.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}.tab{padding:7px 13px;border-radius:999px;font-size:13px;font-weight:600;background:var(--surface);border:1px solid var(--border);color:var(--text-soft);cursor:pointer}.tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.tabs-lg{gap:10px;border-bottom:1px solid var(--border);padding-bottom:14px;margin-bottom:16px}.tabs-lg .tab{padding:10px 20px;font-size:15px;border-radius:12px}.acesso-list{display:grid;grid-gap:14px;gap:14px}.acesso{padding:16px 18px;flex-direction:column}.acesso,.acesso-top{display:flex;gap:12px}.acesso-top{justify-content:space-between;align-items:flex-start;flex-wrap:wrap}.acesso .client{font-size:16px;font-weight:700}.acesso .meta{font-size:13px;color:var(--text-soft);margin-top:2px;display:flex;gap:14px;flex-wrap:wrap}.acesso .desc{font-size:14px;color:#334155;background:var(--surface-2);padding:10px 12px;border-radius:8px;border:1px solid var(--border)}.acesso-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.badge{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:999px;font-size:12px;font-weight:700;white-space:nowrap}.badge:before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}.badge.blue{background:#dbeafe;color:#1d4ed8}.badge.amber{background:#fef3c7;color:#b45309}.badge.violet{background:#ede9fe;color:#6d28d9}.badge.red{background:#fee2e2;color:#b91c1c}.badge.green{background:#dcfce7;color:#15803d}.badge.gray{background:#e2e8f0;color:#475569}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 15px;border-radius:9px;font-size:14px;font-weight:600;border:1px solid transparent;cursor:pointer;transition:background .12s,opacity .12s;background:var(--primary);color:#fff}.btn:hover{background:var(--primary-d)}.btn.success{background:#16a34a}.btn.success:hover{background:#15803d}.btn.warn{background:#ea580c}.btn.warn:hover{background:#c2410c}.btn.wa{background:#25d366;color:#062e16}.btn.wa:hover{background:#1ebe5a}.btn.ghost{background:var(--surface);border-color:var(--border);color:var(--text-soft)}.btn.ghost:hover{background:var(--surface-2)}.btn.sm{padding:6px 11px;font-size:13px}.btn.block{width:100%}.btn:disabled{opacity:.6;cursor:not-allowed}.form{display:grid;grid-gap:16px;gap:16px;max-width:520px}.field{display:grid;grid-gap:6px;gap:6px}.field label{font-size:13px;font-weight:600;color:#334155}.field input,.field select,.field textarea{width:100%;padding:10px 12px;border-radius:9px;border:1px solid var(--border);font-size:14px;font-family:inherit;background:var(--surface);color:var(--text)}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.15)}.field textarea{min-height:84px;resize:vertical}.row2{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px}.alert{padding:11px 14px;border-radius:9px;font-size:14px;font-weight:500}.alert.error{background:#fee2e2;color:#b91c1c;border:1px solid #fecaca}.alert.info{background:#eff6ff;color:#1e40af;border:1px solid #bfdbfe}.empty{text-align:center;padding:48px 20px;color:var(--text-soft)}.empty .big{font-size:40px;margin-bottom:8px}.login-wrap{min-height:100vh;display:grid;place-items:center;background:radial-gradient(1200px 600px at 50% -10%,#1e293b,var(--bg));padding:20px}.login-card{width:100%;max-width:400px;background:var(--surface);border-radius:16px;padding:32px;box-shadow:var(--shadow-lg)}.login-card h1{margin:0 0 4px;font-size:22px}.login-card .sub{margin:0 0 24px;color:var(--text-soft);font-size:14px}.login-hint{margin-top:18px;font-size:12px;color:var(--text-soft);line-height:1.6;background:var(--surface-2);padding:10px 12px;border-radius:9px;border:1px solid var(--border)}.table{width:100%;border-collapse:collapse;font-size:14px}.table td,.table th{text-align:left;padding:11px 14px;border-bottom:1px solid var(--border)}.table th{font-size:12px;text-transform:uppercase;letter-spacing:.4px;color:var(--text-soft);background:var(--surface-2)}.table tr:last-child td{border-bottom:none}.bell{position:relative;cursor:pointer;background:hsla(0,0%,100%,.08);border:none;color:#fff;width:38px;height:38px;border-radius:10px;display:grid;place-items:center;font-size:18px}.bell:hover{background:hsla(0,0%,100%,.16)}.bell .count{position:absolute;top:-5px;right:-5px;background:#ef4444;color:#fff;font-size:11px;font-weight:700;min-width:18px;height:18px;padding:0 4px;border-radius:999px;display:grid;place-items:center}.notif-panel{position:absolute;top:52px;right:0;width:320px;max-height:420px;overflow-y:auto;background:var(--surface);color:var(--text);border-radius:12px;box-shadow:var(--shadow-lg);border:1px solid var(--border);z-index:50}.notif-head{display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:14px}.notif-head,.notif-item{padding:12px 14px;border-bottom:1px solid var(--border)}.notif-item{font-size:13px;line-height:1.45}.notif-item.unread{background:#eff6ff}.notif-item .when{color:var(--text-soft);font-size:11px;margin-top:3px}.notif-empty{padding:28px 14px;text-align:center;color:var(--text-soft);font-size:13px}.link-btn{background:none;border:none;color:var(--primary);font-size:12px;font-weight:600;cursor:pointer;padding:0}.autocomplete{margin-top:6px;border:1px solid var(--border);border-radius:10px;overflow:hidden;box-shadow:var(--shadow);background:var(--surface)}.ac-head{padding:8px 14px;font-size:12px;font-weight:600;color:var(--text-soft);background:var(--surface-2);border-bottom:1px solid var(--border)}.ac-item{display:flex;flex-direction:column;align-items:flex-start;gap:2px;width:100%;text-align:left;padding:10px 14px;background:var(--surface);border:none;border-bottom:1px solid var(--border);cursor:pointer;font-size:14px}.ac-item:last-child{border-bottom:none}.ac-item:hover{background:var(--surface-2)}.ac-sub{font-size:12px}.ac-empty,.ac-sub{color:var(--text-soft)}.ac-empty{margin-top:6px;padding:10px 12px;font-size:13px;background:var(--surface-2);border:1px dashed var(--border);border-radius:9px}.selected-client{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;padding:11px 14px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:9px;font-size:14px}@media (max-width:640px){.row2{grid-template-columns:1fr}.nav{order:3;width:100%;margin-left:0}.topbar{height:auto;padding:10px 14px;flex-wrap:wrap}.content{padding:18px 14px 60px}}