*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;color:#e8edf7;background:#0b1220;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Inter,Arial,sans-serif}#root{width:100%;min-height:100vh}button{font-family:inherit}:root{--bg:#0b1220;--panel:#111a2e;--panel2:#162241;--line:#1f2c4d;--text:#e8edf7;--muted:#8a96b2;--accent:#3b82f6;--good:#22c55e;--bad:#ef4444;--warn:#f59e0b;--radius:14px}header{z-index:5;padding:14px 16px 8px;padding-top:max(14px, env(safe-area-inset-top));background:linear-gradient(#0b1220 80%,#0b122000);position:sticky;top:0}header h1{letter-spacing:.2px;margin:0 0 2px;font-size:18px}.sub{color:var(--muted);font-size:12px}nav.tabs{background:var(--panel);border:1px solid var(--line);border-radius:12px;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px;padding:6px;display:grid}nav.tabs button{appearance:none;color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:8px;padding:10px 8px;font-size:13px;font-weight:600;transition:all .15s}nav.tabs button.active{background:var(--panel2);color:var(--text);box-shadow:inset 0 0 0 1px var(--line)}main{padding:8px 14px 32px;padding-bottom:calc(32px + env(safe-area-inset-bottom))}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);margin:10px 0;padding:14px}.card h2{color:var(--muted);letter-spacing:.4px;text-transform:uppercase;margin:0 0 10px;font-size:14px;font-weight:600}.kpis{grid-template-columns:1fr 1fr;gap:10px;display:grid}.kpi{background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:12px}.kpi .label{color:var(--muted);text-transform:uppercase;letter-spacing:.4px;font-size:11px}.kpi .value{margin-top:4px;font-size:20px;font-weight:700}.kpi .delta{margin-top:4px;font-size:12px}.delta.up{color:var(--good)}.delta.down{color:var(--bad)}.delta.flat{color:var(--muted)}.row{border-bottom:1px dashed var(--line);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.row:last-child{border-bottom:0}.row .name{font-weight:600}.row .meta{color:var(--muted);font-size:11px}.row .amt{font-variant-numeric:tabular-nums;font-weight:700}.bar{background:var(--panel2);border-radius:999px;height:6px;margin-top:6px;overflow:hidden}.chart-wrap{height:240px;position:relative}.chart-wrap.tall{height:280px}.legend{color:var(--muted);flex-wrap:wrap;gap:8px;margin-top:8px;font-size:11px;display:flex}.dot{vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:4px;display:inline-block}.switch{background:var(--panel2);border:1px solid var(--line);border-radius:10px;flex-wrap:wrap;gap:6px;padding:4px;display:flex}.switch button{color:var(--muted);cursor:pointer;white-space:nowrap;background:0 0;border:0;border-radius:8px;flex:1;padding:8px;font-size:12px;font-weight:600}.switch button.active{background:var(--panel);color:var(--text)}.tbl-scroll{-webkit-overflow-scrolling:touch;border:1px solid var(--line);background:var(--panel2);border-radius:10px;margin-top:8px;overflow-x:auto}table.mini{border-collapse:collapse;width:100%;min-width:480px;font-size:12px}table.mini th,table.mini td{text-align:right;border-bottom:1px solid var(--line);white-space:nowrap;font-variant-numeric:tabular-nums;padding:8px}table.mini th:first-child,table.mini td:first-child{text-align:left;background:var(--panel2);z-index:1;position:sticky;left:0}table.mini thead th{background:var(--panel2);color:var(--muted);font-weight:600;position:sticky;top:0}table.mini tbody tr:last-child td{border-bottom:0}table.mini tr.total td{background:#3b82f614}.footer{color:var(--muted);text-align:center;margin-top:16px;font-size:11px}.loading{text-align:center;color:var(--muted);padding:40px;font-size:14px}.loading.erro{color:var(--bad)}.login-screen{flex-direction:column;justify-content:center;align-items:center;gap:24px;min-height:100vh;padding:24px;display:flex}.login-logo{color:var(--text);letter-spacing:.2px;font-size:22px;font-weight:700}.login-logo span{color:var(--muted);font-weight:500}.login-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);flex-direction:column;gap:16px;width:100%;max-width:320px;padding:24px;display:flex}.user-list{flex-direction:column;gap:8px;display:flex}.user-btn{background:var(--panel2);border:1px solid var(--line);cursor:pointer;color:var(--text);text-align:left;border-radius:10px;align-items:center;gap:12px;width:100%;padding:12px 14px;font-size:14px;font-weight:600;transition:border-color .15s;display:flex}.user-btn:hover{border-color:var(--accent)}.user-avatar{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:15px;font-weight:700;display:flex}.pin-area{flex-direction:column;gap:12px;display:flex}.pin-label{color:var(--muted);font-size:13px}.pin-dots{justify-content:center;gap:12px;margin:8px 0;display:flex}.pin-dot{border:2px solid var(--line);border-radius:50%;width:14px;height:14px;transition:all .15s}.pin-dot.filled{background:var(--accent);border-color:var(--accent)}.pin-keypad{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.pin-key{background:var(--panel2);border:1px solid var(--line);color:var(--text);cursor:pointer;border-radius:10px;padding:14px 8px;font-size:18px;font-weight:600;transition:background .1s}.pin-key:active{background:var(--accent)}.pin-key.del{color:var(--muted);font-size:14px}.login-error{color:var(--bad);text-align:center;font-size:12px}.back-btn{color:var(--muted);cursor:pointer;text-align:center;background:0 0;border:0;font-size:12px}.user-info{color:var(--muted);cursor:pointer;align-items:center;gap:10px;font-size:13px;display:flex}.logout-btn{border:1px solid var(--line);color:var(--muted);cursor:pointer;background:0 0;border-radius:8px;padding:4px 8px;font-size:11px}nav.tabs.tabs-3{grid-template-columns:1fr 1fr 1fr}nav.tabs.tabs-3 button{padding:9px 4px;font-size:11px}.admin-btn-new{background:var(--accent);color:#fff;cursor:pointer;border:0;border-radius:8px;padding:7px 14px;font-size:13px;font-weight:600}.admin-user-row{border-bottom:1px dashed var(--line);align-items:center;gap:12px;padding:10px 0;display:flex}.admin-user-row:last-child{border-bottom:0}.admin-badge{color:var(--accent);letter-spacing:.3px;background:#3b82f62e;border-radius:4px;margin-left:6px;padding:1px 5px;font-size:10px;font-weight:700;display:inline-block}.admin-btn-edit{background:var(--panel2);border:1px solid var(--line);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:7px;padding:5px 10px;font-size:12px}.admin-btn-del{color:var(--bad);cursor:pointer;background:#ef44441f;border:1px solid #ef44444d;border-radius:7px;padding:5px 9px;font-size:13px}.admin-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#050c18cc;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.admin-modal{background:var(--panel);border:1px solid var(--line);border-radius:18px;width:100%;max-width:320px;padding:20px}.admin-label{color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:5px;font-size:11px;display:block}.admin-input{background:var(--panel2);border:1px solid var(--line);width:100%;color:var(--text);box-sizing:border-box;border-radius:8px;outline:none;padding:10px 12px;font-size:14px}.admin-input:focus{border-color:var(--accent)}.admin-toggle-row{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;display:flex}.admin-toggle{background:var(--panel2);border:1px solid var(--line);border-radius:12px;flex-shrink:0;width:42px;height:24px;transition:background .2s;position:relative}.admin-toggle:after{content:"";background:var(--muted);border-radius:50%;width:16px;height:16px;transition:transform .2s,background .2s;position:absolute;top:3px;left:3px}.admin-toggle.on{border-color:var(--accent);background:#3b82f640}.admin-toggle.on:after{background:var(--accent);transform:translate(18px)}.admin-btn-save{background:var(--accent);color:#fff;cursor:pointer;border:0;border-radius:8px;flex:1;padding:11px;font-size:14px;font-weight:600}.admin-btn-save:disabled{opacity:.5;cursor:default}.admin-btn-cancel{background:var(--panel2);border:1px solid var(--line);color:var(--muted);cursor:pointer;border-radius:8px;flex:1;padding:11px;font-size:14px}.device-frame,.device-screen{width:100%}
