:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0;padding:0;overflow-x:hidden}#root{text-align:left;box-sizing:border-box;border-inline:none;width:100%;min-height:100vh;margin:0;padding:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}:root{--bg:#03122b;--bg-soft:#0c1d40;--card:#102247;--card-strong:#132b57;--text:#f8fbff;--muted:#b8c4dd;--primary:#49d6ff;--primary-dark:#25b8e6;--success:#22c55e;--danger:#ef4444;--border:#ffffff1f;--shadow:0 20px 40px #00000047;--radius-lg:22px;--radius-md:16px;--radius-sm:12px}*{box-sizing:border-box}html{background:#02122b}body{background:var(--bg);color:var(--text);margin:0;font-family:Arial,Helvetica,sans-serif;overflow:hidden auto}button,input,select{font:inherit}img{max-width:100%;display:block}.btn-primary,.btn-secondary,.btn-danger,.btn-table,.btn-scanner-primary,.btn-scanner-secondary,.btn-scanner-danger{cursor:pointer;border:none;border-radius:14px;font-weight:800;transition:all .2s}.btn-primary,.btn-secondary,.btn-danger{padding:14px 18px}.btn-primary{background:var(--primary);color:#05213d}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--success);color:#052e16;box-shadow:0 10px 22px #22c55e38}.btn-secondary:hover{color:#fff;background:#16a34a}.btn-danger{color:#fff;background:#f94144;width:100%;margin-top:6px}.btn-table{white-space:nowrap;padding:9px 13px;font-size:13.5px}.btn-table.primary{color:#fff;background:#3498db}.btn-table.primary:hover{background:#217dbb}.btn-table.danger{color:#fff;background:#e74c3c}.btn-table.danger:hover{background:#c0392b}.toast-container{z-index:5000;pointer-events:none;gap:12px;width:min(360px,100vw - 24px);display:grid;position:fixed;top:20px;right:20px}.toast-notification{color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);opacity:0;border:1px solid #ffffff24;border-radius:18px;gap:8px;padding:16px 18px;transition:opacity .28s,transform .28s;display:grid;transform:translateY(-14px)scale(.96);box-shadow:0 18px 36px #00000047}.toast-notification.show{opacity:1;transform:translateY(0)scale(1)}.toast-notification.hide{opacity:0;transform:translate(24px)scale(.96)}.toast-notification.success{background:linear-gradient(#16a34af5 0%,#15803df0 100%)}.toast-notification.error{background:linear-gradient(#dc2626f5 0%,#991b1bf0 100%)}.toast-badge{letter-spacing:.06em;text-transform:uppercase;opacity:.9;font-size:12px;font-weight:900}.toast-message{font-size:14px;font-weight:700;line-height:1.45}.login-page{place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{background:var(--card);width:100%;max-width:460px;box-shadow:var(--shadow);border-radius:24px;padding:36px}.brand{align-items:center;gap:16px;margin-bottom:32px;display:flex}.brand-only-logo{justify-content:center}.brand-logo-img{object-fit:contain;width:170px;height:auto}.form{gap:18px;display:grid}.form label,.client-form label,.scanner-manual-form label,.config-form label{gap:9px;font-size:15px;font-weight:700;display:grid}.form input,.client-form input,.scanner-manual-form input,.config-form input,.config-form select{border:1px solid var(--border);border-radius:12px;outline:none;width:100%;padding:15px 16px;font-size:15.5px}.form input{color:#0f172a;background:#fff}.form input:focus,.client-form input:focus,.scanner-manual-form input:focus,.config-form input:focus,.config-form select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #49d6ff26}.app-layout{background:var(--bg);width:100%;min-height:100vh;display:block}.sidebar{z-index:100;flex-direction:column;align-items:stretch;gap:20px;width:280px;height:100vh;padding:20px 0 24px;transition:width .3s,padding .3s;display:flex;position:fixed;top:0;left:0;background:#0a1a35!important;border-right:1px solid #49d6ff26!important;box-shadow:4px 0 20px #00000026!important}.sidebar.collapsed{align-items:center;width:70px;padding:20px 0 24px}.sidebar.collapsed .sidebar-logo-img{width:40px;margin:8px auto 18px}.sidebar.collapsed .menu{max-width:100%}.sidebar.collapsed .menu-item{justify-content:center;padding:14px}.sidebar.collapsed .menu-item span{display:none}.sidebar.collapsed .menu-item svg{width:28px!important;height:28px!important}.sidebar.collapsed .sidebar-user{text-align:center;font-size:0}.sidebar.collapsed .btn-danger{justify-content:center;padding:14px}.sidebar.collapsed .btn-danger span{display:none}.sidebar.collapsed .btn-danger svg{width:28px!important;height:28px!important}.desktop-collapse-button{color:#fff;cursor:pointer;background:#ffffff1f;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;font-weight:800;transition:background .2s;display:none;position:absolute;top:16px;right:16px}.desktop-collapse-button:hover{background:#fff3}.sidebar.collapsed .desktop-collapse-button{right:50%;transform:translate(50%)}.sidebar-logo-img{object-fit:contain;align-self:center;width:160px;height:auto;margin:8px auto}.menu{scrollbar-width:thin;scrollbar-color:#ffffff40 transparent;flex:1;gap:12px;width:100%;min-height:0;display:grid;overflow:hidden auto}.menu::-webkit-scrollbar{width:6px}.menu::-webkit-scrollbar-track{background:0 0}.menu::-webkit-scrollbar-thumb{background:#ffffff40;border-radius:999px}.menu::-webkit-scrollbar-thumb:hover{background:#fff6}.sidebar-user{width:100%;color:var(--muted);text-align:center;margin:auto auto 0;padding:0 16px;font-size:14px}.menu-item{color:#fff;text-align:left;cursor:pointer;background:0 0;border:none;border-radius:0;align-items:center;gap:12px;width:100%;padding:14px 16px;font-size:18px;font-weight:700;line-height:1.4;transition:all .2s;display:flex;position:relative}.menu-item span{flex:1}.menu-item:not(:last-child):after{content:"";background:#ffffff14;height:1px;position:absolute;bottom:0;left:18px;right:18px}.menu-item:hover,.menu-item.active,.menu-item:hover:after,.menu-item.active:after{background:#ffffff1f}.content{box-sizing:border-box;flex-direction:column;width:calc(100% - 280px);min-height:100vh;margin-left:280px;padding:16px 20px 20px;transition:margin-left .3s,width .3s;display:flex;background:var(--bg)!important;border-left:none!important}.content.collapsed{width:calc(100% - 70px);margin-left:70px}.topbar{background:var(--card);border-radius:var(--radius-lg);box-shadow:var(--shadow);justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;padding:18px 20px;display:flex}.topbar h2{margin:0;font-size:30px}.topbar p{color:var(--muted);margin:6px 0 0}.api-status{color:#166534;background:#dcfce7;border-radius:999px;padding:9px 14px;font-weight:800}.cards{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}.card{background:var(--card);box-shadow:var(--shadow);border-radius:16px;padding:18px 20px}.card span{color:var(--muted);font-weight:700}.card strong{margin-top:10px;font-size:34px;display:block}.page-section,.config-card,.credenciais-header,.entradas-header,.credencial-card,.empty-credenciais,.scanner-phone-card,.qr-result-card,.entradas-cards article{background:linear-gradient(180deg, var(--card) 0%, var(--bg-soft) 100%);box-shadow:var(--shadow);border:1px solid #49d6ff29}.page-section{border-radius:var(--radius-lg);width:100%;max-width:100%;padding:24px}.config-card{border-radius:var(--radius-lg);padding:24px;overflow:hidden}.section-header,.credenciais-header,.entradas-header{justify-content:space-between;align-items:center;gap:18px;display:flex;position:relative}.section-header{margin-bottom:16px}.section-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.section-header h3,.credenciais-header h3,.entradas-header h3{margin:0;font-size:26px}.section-header p,.credenciais-header p,.entradas-header p{color:var(--muted);margin:6px 0 0}.credenciais-header,.entradas-header{border-radius:var(--radius-lg);margin-bottom:16px;padding:18px 20px}.credenciais-header strong{color:var(--primary)}.client-form{background:linear-gradient(180deg, var(--card) 0%, var(--bg-soft) 100%);border:1px solid var(--border);border-radius:16px;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px;padding:16px 18px;display:grid}.client-form input{color:var(--text);background:#2563eb24}.client-form input::placeholder{color:#9bb0d6}.client-form-actions{flex-wrap:wrap;grid-column:1/-1;justify-content:flex-end;align-items:center;gap:12px;display:flex}.form-button{align-self:end}.client-form-placeholder{color:var(--muted);background:#49d6ff14;border:1px dashed #49d6ff47;border-radius:18px;margin-bottom:26px;padding:18px 20px}.client-form-placeholder p{margin:0;font-weight:700}.config-page{gap:20px;display:grid}.config-grid{grid-template-columns:minmax(360px,430px) minmax(0,1fr);align-items:start;gap:24px;display:grid}.relatorios-page{gap:20px;display:grid}.relatorios-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:start;gap:28px;display:grid}.relatorios-tabs{gap:8px;margin-bottom:16px;display:flex}.relatorio-tab{color:#fff;cursor:pointer;background:#ffffff14;border:none;border-radius:8px;flex:1;padding:12px 16px;font-size:15px;font-weight:600;transition:all .2s}.relatorio-tab:hover{background:#ffffff1f}.relatorio-tab.active{background:var(--primary);color:#05213d}.painel-loading{color:var(--primary);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:48px 0;display:flex}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.modal-overlay{z-index:3000;background:#000000b3;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-content{background:var(--card);border-radius:16px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080}.modal-header{border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;padding:24px;display:flex}.modal-header h3{color:#fff;margin:0;font-size:24px;font-weight:700}.modal-close{color:#fff;cursor:pointer;background:#ffffff1a;border:none;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;font-size:32px;transition:all .2s;display:flex}.modal-close:hover{background:#fff3}.modal-body{padding:24px}.modal-body p{color:#ffffffb3;margin-bottom:20px;font-size:16px}.camera-container{flex-direction:column;align-items:center;gap:16px;display:flex}#camera-veiculo{border-radius:12px;width:100%;max-width:400px;overflow:hidden}#camera-veiculo video{border-radius:12px;width:100%}.fotos-preview{margin-top:24px}.fotos-preview h4{color:#fff;margin-bottom:16px;font-size:18px}.fotos-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;display:grid}.foto-item{border-radius:8px;position:relative;overflow:hidden}.foto-item img{object-fit:cover;border-radius:8px;width:100%;height:120px}.foto-item button{border-radius:6px;padding:6px 12px;font-size:12px;position:absolute;bottom:8px;right:8px}.btn-small{padding:8px 16px;font-size:14px}.modal-footer{border-top:1px solid #ffffff1a;justify-content:flex-end;gap:12px;padding:24px;display:flex}.config-card.relatorio-card{padding:30px;overflow:hidden}.relatorio-resultado{margin-top:28px}.relatorio-meta{color:#ffffff80;letter-spacing:.02em;margin-bottom:12px;font-size:13px}.relatorio-vazio{text-align:center;color:#fff6;border:1px dashed #ffffff1f;border-radius:12px;margin-top:28px;padding:32px 20px;font-size:14px}.relatorio-table-wrap{border:1px solid #ffffff14;border-radius:12px;overflow-x:auto}.relatorio-table{border-collapse:collapse;width:100%;min-width:0;font-size:13px}.relatorio-table thead tr{background:#ffffff0f}.relatorio-table th{text-align:left;text-transform:uppercase;letter-spacing:.07em;color:#ffffff8c;white-space:nowrap;border-bottom:1px solid #ffffff14;padding:11px 14px;font-size:11px;font-weight:700}.relatorio-table td{color:#ffffffd9;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle;border-bottom:1px solid #ffffff0d;max-width:240px;padding:11px 14px;overflow:hidden}.relatorio-table tbody tr:last-child td{border-bottom:none}.relatorio-table tbody tr:nth-child(2n){background:#ffffff06}.relatorio-table tbody tr:hover td{background:rgba(var(--primary-rgb,96, 165, 250), .08);color:#fff}.config-form.relatorio-form{grid-template-columns:repeat(2,minmax(0,1fr));align-items:end;gap:20px;width:100%}.relatorio-form input,.relatorio-form select{min-width:0;min-height:52px;padding:16px 18px;font-size:16px}.relatorio-submit{grid-column:1/-1;justify-self:stretch;width:100%;min-width:0;margin-top:4px}.config-form{grid-template-columns:repeat(3,minmax(140px,1fr)) auto;align-items:end;gap:16px;display:grid}.config-form input,.config-form select{color:var(--text);background:#2563eb24}.config-form input::placeholder{color:#9bb0d6}.config-form select option{color:#0f172a}.config-submit{place-self:end start;width:auto;min-width:220px}.user-form{grid-template-columns:repeat(2,1fr)}.user-form .config-submit{grid-column:1/-1;width:100%;min-width:0}.permission-note,.empty-usuarios{border-radius:14px;padding:14px 16px;font-weight:700}.permission-note{color:#fde68a;background:#ffedd529;border:1px solid #fbbf2459;margin-bottom:18px}.empty-usuarios{color:var(--muted);background:#49d6ff14}.users-table{min-width:680px}.btn-danger{width:100%;max-width:220px;margin:8px auto 0;padding:16px 18px;font-size:18px;display:block}.role-badge{text-transform:uppercase;letter-spacing:.04em;border-radius:999px;justify-content:center;align-items:center;min-width:88px;padding:6px 10px;font-size:12px;font-weight:800;display:inline-flex}.role-badge.admin{color:#fde68a;background:#fbbf242e}.role-badge.scanner{color:#a5f3fc;background:#49d6ff2e}.role-badge.supervisor{color:#ddd6fe;background:#a78bfa2e}.config-locked{text-align:center;color:var(--primary);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:64px 16px;display:flex}.config-locked p{color:#94a3b8;max-width:360px}.supervisor-modal{max-width:400px}.qr-result-card{border-radius:18px;grid-template-columns:1fr 220px;align-items:center;gap:24px;margin-bottom:28px;padding:24px;display:grid}.qr-info h3{margin:0 0 10px;font-size:24px}.qr-info p{color:var(--muted);margin:8px 0}.qr-info strong{color:var(--text)}.qr-hash{word-break:break-all}.qr-hash span{color:var(--primary);font-size:13px}.qr-actions{flex-wrap:wrap;gap:12px;margin-top:18px;display:flex}.qr-preview{background:#fff;border-radius:16px;place-items:center;padding:16px;display:grid}.qr-preview img{object-fit:contain;width:180px;height:180px}.credencial-success-panel{box-shadow:var(--shadow);background:linear-gradient(#22c55e2e 0%,#0c1d40f2 100%);border:1px solid #22c55e59;border-radius:22px;margin-bottom:26px;padding:24px}.credencial-success-copy{margin-bottom:20px}.credencial-success-copy h3{margin:0 0 8px;font-size:26px}.credencial-success-copy p{color:#d9ffe6;margin:0}.credencial-success-layout{grid-template-columns:minmax(0,1fr) 260px;align-items:start;gap:20px;display:grid}.credencial-share-card{background:linear-gradient(135deg,#0d2148 0%,#07162f 100%);border:1px solid #49d6ff33;border-radius:20px;padding:22px}.credencial-share-card.capture-card{aspect-ratio:1;text-align:center;flex-direction:column;justify-content:flex-start;align-items:center;width:min(540px,100%);padding:2px 18px 16px;display:flex}.credencial-share-brand{text-align:center;margin-inline:auto;flex-direction:column;justify-content:center;align-items:center;gap:8px;width:100%;margin-bottom:21px;display:flex}.credencial-share-brand img{object-fit:contain;width:164px;height:auto;margin-inline:auto;display:block}.credencial-share-brand span{color:var(--primary);text-transform:uppercase;letter-spacing:.04em;margin-top:-18px;font-size:14px;font-weight:800}.credencial-share-body{grid-template-columns:minmax(0,1fr) 228px;align-items:center;gap:28px;display:grid}.credencial-share-body.only-qr{grid-template-columns:1fr;justify-items:center;gap:23px;width:100%}.credencial-share-info h4{margin:0 0 18px;font-size:32px}.credencial-share-info.only-name{text-align:center;margin-inline:auto;width:100%;margin-top:-20px}.credencial-share-info.only-name h4{text-align:center;margin:0 auto;font-size:36px;line-height:1.15}.credencial-share-info p{color:#d8e6ff;margin:0 0 10px;font-size:16px}.credencial-share-info strong{color:#fff}.credencial-share-qr{margin-inline:auto;background:#fff;border-radius:18px;place-items:center;width:min(78%,420px);margin-top:-13px;padding:16px;display:grid}.paginacao{justify-content:center;align-items:center;gap:12px;margin-top:16px;padding:4px 0;display:flex}.paginacao-btn{color:#ffffffd9;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff26;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:20px;line-height:1;transition:background .15s,border-color .15s;display:flex}.paginacao-btn:hover:not(:disabled){background:#ffffff1f;border-color:#ffffff4d}.paginacao-btn:disabled{opacity:.3;cursor:not-allowed}.paginacao-info{color:#ffffff8c;text-align:center;min-width:56px;font-size:13px}.credencial-share-qr img{aspect-ratio:1;object-fit:contain;width:100%;max-width:100%}.credencial-success-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.credencial-success-actions .icon-btn{border-radius:12px;justify-content:center;align-items:center;width:56px;height:56px;padding:0;display:flex}.table-card{border:1px solid var(--border);border-radius:14px;overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:760px}th{color:#fff;text-align:left;background:#1f2937;padding:10px 12px;font-size:13px}td{border-bottom:1px solid var(--border);padding:8px 12px;font-size:13px}tr:last-child td{border-bottom:none}tr:hover td{background:#0f0274}.empty-table{text-align:center;color:var(--muted);font-weight:700}.table-actions,.credencial-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.credenciais-page{width:100%}.credenciais-list{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.credencial-card{border-radius:16px;grid-template-columns:1fr auto;align-items:center;gap:18px;padding:16px 18px;display:grid}.credencial-qr{border:2px solid var(--primary);background:#fff;border-radius:12px;place-items:center;width:106px;height:106px;padding:6px;display:grid}.credencial-qr img{object-fit:contain;width:100%;height:100%}.credencial-qr-empty{background:var(--card-strong);width:100%;height:100%;color:var(--primary);border-radius:8px;place-items:center;font-weight:900;display:grid}.credencial-info{gap:7px;display:grid}.credencial-title-row{align-items:center;gap:12px;display:flex}.credencial-title-row h4{margin:0;font-size:23px}.credencial-dot{border-radius:999px;width:14px;height:14px}.credencial-dot.usado{background:var(--success)}.credencial-dot.nao-usado{background:var(--danger)}.credencial-info p{color:var(--muted);margin:0}.credencial-info strong{color:#d8e6ff}.status-usado{color:#98f5b1;font-weight:800}.status-nao-usado{color:#ffb3b3;font-weight:800}.empty-credenciais{text-align:center;color:var(--muted);border-radius:18px;padding:24px;font-weight:800}.scanner-mobile-page{justify-content:center;align-items:flex-start;min-height:100vh;margin:0;padding:0;display:flex}.scanner-phone-card{border-radius:0 0 28px 28px;width:100%;max-width:390px;margin:0;padding:0}.scanner-brand{justify-content:center;margin-top:0;margin-bottom:22px;padding-top:0;display:flex}.scanner-brand img{width:140px;height:auto}.scanner-status{border-radius:12px;gap:4px;margin-bottom:14px;padding:14px 16px;display:grid}.scanner-status strong{font-size:15px}.scanner-status span{opacity:.9;font-size:13px}.scanner-status.success{color:#fff;background:#16a34a}.scanner-status.error{color:#fff;background:#991b1b}.scanner-status.neutral{color:#dff7ff;background:#49d6ff1f;border:1px solid #49d6ff38}.scanner-frame-area{place-items:center;width:270px;height:270px;margin:20px auto 28px;display:grid;position:relative}.qr-reader-custom{background:#0d223f;border-radius:12px;width:235px;height:235px;overflow:hidden}.qr-reader-custom video{object-fit:cover;width:100%!important;height:100%!important}.scanner-placeholder{color:#ffffff2e;background:#49d6ff0f;border-radius:12px;place-items:center;width:235px;height:235px;font-size:42px;font-weight:900;display:grid;position:absolute}.corner{border-color:var(--primary);width:42px;height:42px;position:absolute}.corner-top-left{border-top:4px solid var(--primary);border-left:4px solid var(--primary);border-radius:8px 0 0;top:0;left:0}.corner-top-right{border-top:4px solid var(--primary);border-right:4px solid var(--primary);border-radius:0 8px 0 0;top:0;right:0}.corner-bottom-left{border-bottom:4px solid var(--primary);border-left:4px solid var(--primary);border-radius:0 0 0 8px;bottom:0;left:0}.corner-bottom-right{border-bottom:4px solid var(--primary);border-right:4px solid var(--primary);border-radius:0 0 8px;bottom:0;right:0}.scanner-buttons{gap:12px;margin-bottom:26px;display:grid}.btn-scanner-primary,.btn-scanner-secondary,.btn-scanner-danger{border-radius:999px;padding:14px 18px;font-weight:900}.btn-scanner-primary{color:#05213d;background:linear-gradient(90deg,#35d2ff 0%,#58dbff 100%)}.btn-scanner-secondary{color:#fff;background:#174ee8}.btn-scanner-danger{background:var(--danger);color:#fff}.btn-scanner-secondary:disabled{opacity:.45;cursor:not-allowed}.scanner-manual-form{gap:10px;margin-top:10px;display:grid}.scanner-manual-form label{color:#d8e6ff}.scanner-manual-form input{background:var(--card-strong);color:#eaf4ff}.scanner-manual-form input::placeholder{color:#8ea7d6}.scanner-manual-form button{background:var(--success);color:#052e16;cursor:pointer;border:none;border-radius:12px;padding:13px 14px;font-weight:900}.entradas-page{width:100%}.entradas-cards{grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:24px;display:grid}.entradas-cards article{border-radius:18px;padding:22px}.entradas-cards span{color:var(--muted);margin-bottom:10px;font-weight:800;display:block}.entradas-cards strong{font-size:34px}.entradas-table-card{background:var(--card);-webkit-overflow-scrolling:touch;overflow-x:auto}.entradas-table{min-width:820px}.entradas-table th,.entradas-table td{white-space:nowrap}.entrada-status{white-space:nowrap;font-weight:900}.entrada-status.permitido{color:var(--success)}.entrada-status.negado{color:#f87171}.entrada-col-secundaria{display:none}.entrada-col-acao{display:table-cell}@media (width>=769px){.entrada-col-secundaria{display:table-cell}}@media (width<=768px){.entradas-header{flex-direction:column;align-items:flex-start;gap:12px}.entradas-header h3{font-size:20px}.entradas-header p{font-size:14px}.entradas-cards{grid-template-columns:repeat(3,1fr);gap:8px}.entradas-cards article:nth-child(3){grid-column:auto}.entradas-cards article{border-radius:12px;padding:16px}.entradas-cards span{margin-bottom:6px;font-size:11px}.entradas-cards strong{font-size:24px}.entradas-table-card{border-radius:12px}.entradas-table{min-width:100%;font-size:13px}.entradas-table th,.entradas-table td{padding:10px 8px}.entradas-table th{font-size:11px}.btn-table{padding:6px 12px;font-size:12px}.entrada-status{border-radius:6px;padding:4px 8px;font-size:11px}.modal-overlay{align-items:flex-end;padding:0}.modal-content{border-radius:16px 16px 0 0;width:100%;max-width:100%;max-height:92vh}.modal-content.fotos-modal{height:92vh;max-height:92vh;overflow:hidden}.modal-header,.modal-body,.modal-footer{padding:16px}.modal-header h3{font-size:18px}.modal-footer{flex-direction:column}.modal-footer button{width:100%}.fotos-grid{grid-template-columns:repeat(auto-fill,minmax(96px,1fr))}}.mobile-menu-button,.mobile-close-button,.mobile-overlay{display:none}@media (width>=769px){.desktop-collapse-button{display:flex}}@media (width<=1100px){.client-form,.cards{grid-template-columns:repeat(2,1fr)}.config-grid,.relatorios-grid,.config-form,.user-form{grid-template-columns:1fr}.config-submit,.user-form .config-submit{width:100%;min-width:0}}@media (width<=900px){.credenciais-header,.entradas-header,.section-header,.topbar{flex-direction:column;align-items:flex-start}.topbar h2{text-align:center;margin-left:60px;font-weight:900}.topbar{box-shadow:none;background:0 0;border-radius:0;margin-left:-16px;margin-right:-16px;padding-left:16px;padding-right:16px}.entradas-header h3,.credenciais-header h3,.section-header h3{margin-left:60px}.section-header{margin-left:-16px;margin-right:-16px;padding-left:16px;padding-right:16px}.credenciais-list{grid-template-columns:1fr}.credencial-card{grid-template-columns:1fr auto;gap:12px;padding:12px}.credencial-qr{width:80px;height:80px}.cards{grid-template-columns:1fr 1fr}.credencial-success-layout,.credencial-share-body{grid-template-columns:1fr}}@media (width<=768px){.content{padding:14px;width:100%!important;margin-left:0!important}.sidebar{z-index:2500;width:280px;max-width:84vw}.mobile-menu-button{z-index:3000;color:#05213d;cursor:pointer;background:linear-gradient(90deg,#35d2ff 0%,#58dbff 100%);border:none;border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;font-size:26px;font-weight:900;display:flex;position:fixed;top:16px;left:16px;box-shadow:0 12px 25px #0000004d}.mobile-overlay{z-index:2000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000008c;display:none;position:fixed;inset:0}.mobile-overlay.show{display:block}.sidebar{z-index:2500;border-right:none;width:280px;max-width:84vw;height:100vh;padding:22px 0;transition:transform .25s;position:fixed;top:0;left:0;overflow-y:auto;transform:translate(-110%);box-shadow:18px 0 35px #00000059}.sidebar.open{transform:translate(0)}.mobile-close-button{color:#fff;cursor:pointer;background:#ffffff1f;border:none;border-radius:12px;justify-content:center;align-items:center;width:38px;height:38px;font-size:28px;font-weight:800;display:flex;position:absolute;top:14px;right:14px}.sidebar-logo-img{width:120px;margin:38px 0 12px}.menu-item,.btn-danger{width:100%;margin-left:0}.client-form,.config-form,.cards,.qr-result-card{grid-template-columns:1fr}.section-actions,.client-form-actions{flex-direction:column;align-items:stretch;width:100%}.form-button,.btn-primary,.btn-secondary,.btn-danger{width:100%}.config-page{gap:16px}.config-card{border-radius:18px;padding:16px}.config-grid{grid-template-columns:1fr;gap:16px}.config-form,.user-form,.config-form.relatorio-form{grid-template-columns:1fr;gap:14px}.config-card.relatorio-card{padding:18px}.relatorio-submit{grid-column:1/-1}.relatorio-table td{max-width:160px;padding:9px 10px;font-size:12px}.relatorio-table th{padding:9px 10px;font-size:10px}.config-submit,.user-form .config-submit,.config-card .btn-secondary{width:100%;min-width:0}.qr-actions{flex-direction:column}.qr-preview img{width:220px;height:220px}table{min-width:850px}.entradas-table-card{-webkit-overflow-scrolling:touch;overflow-x:auto}.entradas-table{min-width:820px}.entradas-table th,.entradas-table td{white-space:nowrap;padding:12px 10px;font-size:13px}.users-table{min-width:560px}.config-card .table-card{margin-inline:-4px}.scanner-phone-card{border-radius:22px;min-height:auto}.scanner-frame-area{width:250px;height:250px}.qr-reader-custom,.scanner-placeholder{width:220px;height:220px}.credencial-success-panel,.credencial-share-card{padding:18px}.credencial-share-brand{flex-direction:column;align-items:flex-start}.credencial-share-card.capture-card .credencial-share-brand{align-items:center}.toast-container{width:min(340px,100vw - 32px);top:50%;left:auto;right:50%;transform:translate(50%,-50%)}.toast-notification{text-align:center;padding:20px 22px;font-size:16px}.toast-badge{font-size:13px}}@media (width<=560px){.content{padding-inline:12px}.topbar h2{font-size:24px}.brand-logo-img{width:140px}.client-form{grid-template-columns:1fr;padding:16px}.credencial-share-info h4{font-size:24px}.credencial-share-info.only-name h4{font-size:30px}.credencial-share-card.capture-card{width:min(420px,100%);padding:2px 14px 14px}.credencial-share-brand img{width:142px}.credencial-share-qr{width:min(86%,340px);margin-top:-4px}.config-card{padding:14px}.config-grid{grid-template-columns:1fr}.section-header h3,.credenciais-header h3,.entradas-header h3{font-size:22px}.config-form input,.config-form select{min-height:46px}.detalhes-log-grid{grid-template-columns:1fr}}.detalhes-log-grid{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;display:grid}.detalhe-item{flex-direction:column;gap:4px;display:flex}.detalhe-item label{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:12px}.detalhe-item span{color:var(--text);font-size:16px;font-weight:500}.status-permitido{color:var(--success);font-weight:600}.status-negado{color:var(--danger);font-weight:600}.fotos-veiculo-section{border-top:1px solid #ffffff1a;margin-top:24px;padding-top:24px}.fotos-veiculo-section h4{color:var(--text);margin:0 0 16px;font-size:18px}.fotos-veiculo-section p{color:var(--muted);margin:0}.foto-label{color:var(--muted);text-align:center;margin-top:8px;font-size:12px;display:block}.foto-item{cursor:pointer;transition:transform .2s}.foto-item:hover{transform:scale(1.05)}.foto-item img{border:2px solid #ffffff1a;border-radius:8px}.foto-expandida-overlay{z-index:4000;background:#000000e6}.foto-expandida-content{max-width:90vw;max-height:90vh;box-shadow:none;background:0 0;justify-content:center;align-items:center;display:flex;overflow:visible}.foto-expandida-close{color:#fff;cursor:pointer;z-index:5000;background:#fff3;border:none;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;font-size:40px;transition:all .2s;display:flex;position:fixed;top:20px;right:20px}.foto-expandida-close:hover{background:#ffffff4d}.foto-expandida-img{object-fit:contain;border-radius:8px;max-width:100%;max-height:90vh}.fotos-modal{flex-direction:column;max-height:90vh;display:flex;overflow:hidden}.fotos-modal .modal-header{flex-shrink:0}.fotos-modal .modal-body.fotos-modal-body{flex:1 1 0;min-height:0;padding:12px 16px;overflow-y:auto}.fotos-modal .fotos-actions-bar{border-top:1px solid #ffffff14;flex-shrink:0;padding:12px 16px 16px}.fotos-modal-body{padding:8px 0}.fotos-modal-body .camera-container{gap:8px}.fotos-modal-body #camera-veiculo{object-fit:cover;border-radius:10px;max-width:100%;max-height:50vh}.fotos-modal-body .fotos-preview{margin-top:10px}.fotos-modal-body .fotos-grid{grid-template-columns:repeat(3,1fr);gap:8px}.fotos-modal-body .foto-item img{height:80px}.fotos-modal-body .foto-item button{border-radius:50%;min-width:24px;min-height:24px;padding:2px 6px;font-size:14px;line-height:1;bottom:4px;right:4px}.fotos-actions-bar{justify-content:space-between;align-items:center;gap:12px;padding:12px 0 4px;display:flex}.btn-skip-fotos{color:#fffc;cursor:pointer;background:0 0;border:1px solid #ffffff40;border-radius:10px;padding:10px 20px;font-size:14px;transition:background .2s}.btn-skip-fotos:hover{background:#ffffff14}.btn-skip-fotos:disabled{opacity:.4;cursor:not-allowed}.fotos-icon-buttons{gap:10px;display:flex}.btn-icon-foto,.btn-icon-enviar{cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;transition:transform .15s,opacity .2s;display:flex}.btn-icon-foto{color:#fff;background:#ffffff26}.btn-icon-foto:hover{background:#ffffff38;transform:scale(1.08)}.btn-icon-enviar{color:#fff;background:#2563eb}.btn-icon-enviar:hover:not(:disabled){transform:scale(1.08)}.btn-icon-foto:disabled,.btn-icon-enviar:disabled{opacity:.35;cursor:not-allowed;transform:none}.spin{animation:1s linear infinite spin}.entradas-filtros-inline{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.filtro-input,.filtro-select{color:var(--text);background:#ffffff12;border:1px solid #ffffff1f;border-radius:10px;outline:none;height:38px;padding:0 14px;font-size:14px;transition:border-color .2s}.filtro-input:focus,.filtro-select:focus{border-color:#6366f180}.filtro-input{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;width:170px}.filtro-select{cursor:pointer;min-width:130px}.filtro-select option{color:#fff;background:#1e1e2e}.filtro-limpar{color:#ef4444;cursor:pointer;background:#ef444426;border:none;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;transition:background .2s;display:flex}.filtro-limpar:hover{background:#ef444440}.btn-filtrar{color:#818cf8;cursor:pointer;background:#6366f126;border:none;border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;transition:background .2s;display:flex}.btn-filtrar:hover{background:#6366f140}@media (width<=768px){.entradas-header{flex-direction:column;align-items:flex-start}.entradas-filtros-inline{gap:8px;width:100%}.filtro-input{flex:1;width:100%}.filtro-select{flex:1;min-width:0}}.dashboard-page{flex-direction:column;flex:1;gap:20px;min-height:0;display:flex}.dashboard-grid{flex:1;grid-template-columns:repeat(2,1fr);gap:16px;min-height:0;display:grid}.dash-card{background:var(--card-bg);border-radius:var(--radius-lg);border:1px solid var(--border);flex-direction:column;min-height:280px;padding:20px;display:flex}.dash-card h4{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin:0 0 16px;font-size:15px;font-weight:600}.donut-wrapper{flex:1;justify-content:center;align-items:center;margin-bottom:16px;display:flex;position:relative}.donut-center{flex-direction:column;align-items:center;display:flex;position:absolute}.donut-center strong{color:#22c55e;font-size:24px;font-weight:700}.donut-center small{color:var(--muted);text-transform:uppercase;font-size:11px}.donut-legend,.bar-legend{justify-content:center;gap:16px;margin-top:8px;display:flex}.legend-item{color:var(--muted);align-items:center;gap:6px;font-size:12px;display:flex}.legend-dot{border-radius:50%;width:8px;height:8px}.dot-green{background:#22c55e}.dot-red{background:#ef4444}.dot-blue{background:#6366f1}.bar-chart{flex:1;align-items:flex-end;gap:8px;min-height:100px;padding-top:8px;display:flex}.bar-group{flex-direction:column;flex:1;align-items:center;height:100%;display:flex}.bar-stack{flex-direction:column-reverse;flex:1;justify-content:flex-start;align-items:center;gap:2px;width:100%;max-width:32px;display:flex}.bar-permitido{background:#22c55e;border-radius:4px 4px 0 0;width:100%;transition:height .3s}.bar-negado{background:#ef4444;border-radius:4px 4px 0 0;width:100%;transition:height .3s}.bar-label{color:var(--muted);white-space:nowrap;margin-top:6px;font-size:10px}.hourly-chart{flex-direction:column;flex:1;gap:6px;display:flex;overflow-y:auto}.hour-row{align-items:center;gap:8px;display:flex}.hour-label{color:var(--muted);text-align:right;flex-shrink:0;width:30px;font-size:11px}.hour-bar-bg{background:#ffffff0a;border-radius:8px;flex:1;height:16px;overflow:hidden}.hour-bar{background:linear-gradient(90deg,#6366f1,#818cf8);border-radius:8px;min-width:4px;height:100%;transition:width .3s}.hour-count{color:var(--text);text-align:right;flex-shrink:0;width:28px;font-size:12px;font-weight:600}.top-clients{flex-direction:column;flex:1;justify-content:space-around;gap:12px;display:flex}.top-client-row{align-items:center;gap:10px;display:flex}.top-client-rank{color:#818cf8;background:#6366f126;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;font-weight:700;display:flex}.top-client-info{flex:1;min-width:0}.top-client-name{white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:13px;font-weight:500;display:block;overflow:hidden}.top-client-bar-bg{background:#ffffff0f;border-radius:3px;height:6px;overflow:hidden}.top-client-bar{background:linear-gradient(90deg,#22c55e,#4ade80);border-radius:3px;height:100%;transition:width .3s}.top-client-count{color:var(--text);text-align:right;flex-shrink:0;width:28px;font-size:13px;font-weight:700}.empty-chart{color:var(--muted);text-align:center;padding:20px 0;font-size:13px}.card-permitido{border-left:3px solid #22c55e}.card-negado{border-left:3px solid #ef4444}@media (width<=768px){.dashboard-grid{grid-template-columns:1fr}.bar-chart{height:100px}.dash-card{padding:16px}}@media (width<=560px){.cards{grid-template-columns:repeat(2,1fr)}.donut-legend,.bar-legend{flex-wrap:wrap;gap:8px}}
