:root{--blue: #3b82f6;--blue-dark: #2563eb;--blue-bg: #eff6ff;--blue-light: #dbeafe;--text: #374151;--text-light: #6b7280;--heading: #111827;--border: #e5e7eb;--border-dark: #d1d5db;--bg: #f9fafb;--bg-alt: #f3f4f6;--white: #ffffff;--green: #10b981;--green-bg: #d1fae5;--yellow: #eab308;--yellow-bg: #fef9c3;--orange: #f59e0b;--orange-bg: #fff7ed;--red: #ef4444;--red-dark: #dc2626;--red-bg: #fee2e2;--shadow-sm: 0 1px 2px rgba(0,0,0,.06);--shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.1), 0 2px 4px -1px rgba(0,0,0,.06);--r: 8px;--r-lg: 12px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Roboto,sans-serif;font-size:13px;color:var(--text);background:var(--bg);line-height:1.5}button,input,select,textarea{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}.navbar{position:sticky;top:0;z-index:100;height:60px;background:var(--white);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:8px;box-shadow:var(--shadow-sm)}.navbar-logo{font-size:18px;font-weight:700;color:var(--heading);letter-spacing:-.3px;white-space:nowrap;margin-right:8px}.navbar-logo span{color:var(--blue)}.navbar-nav{display:flex;align-items:center;gap:2px;flex:1}.nav-item{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--r);font-weight:500;color:var(--text-light);border:none;background:none;white-space:nowrap;transition:background .15s,color .15s}.nav-item:hover{background:var(--bg-alt);color:var(--text)}.nav-item.active{background:var(--blue-bg);color:var(--blue)}.nav-item svg{flex-shrink:0}.navbar-user{display:flex;align-items:center;gap:10px;margin-left:auto}.user-avatar{width:34px;height:34px;border-radius:50%;background:var(--blue-light);color:var(--blue-dark);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}.user-info{line-height:1.3}.user-name{font-weight:600;color:var(--heading);font-size:13px}.user-role{font-size:11px;color:var(--text-light)}.app-body{display:flex;height:calc(100vh - 60px);overflow:hidden}.sidebar{width:260px;flex-shrink:0;background:var(--white);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.sidebar-head{padding:14px 16px 10px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.sidebar-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-light)}.sidebar-body{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:14px}.search-input{width:100%;padding:8px 10px;border:1px solid var(--border-dark);border-radius:var(--r);background:var(--white);color:var(--text);font-size:13px;outline:none;transition:border-color .15s,box-shadow .15s}.search-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #3b82f61f}.search-input::placeholder{color:var(--text-light)}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-light);display:flex;align-items:center;justify-content:space-between}.filter-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:99px;background:var(--blue);color:#fff;font-size:10px;font-weight:700}.filter-select{width:100%;border:1px solid var(--border-dark);border-radius:var(--r);background:var(--white);color:var(--text);font-size:12px;outline:none;cursor:pointer;transition:border-color .15s}.filter-select:focus{border-color:var(--blue);box-shadow:0 0 0 3px #3b82f61f}.filter-select option{padding:4px}.filter-select option:checked{background:var(--blue-light);color:var(--blue-dark)}.cashin-opts{display:flex;gap:6px}.cashin-opt{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:6px;border:1px solid var(--border-dark);border-radius:var(--r);cursor:pointer;font-size:12px;font-weight:500;color:var(--text-light);background:var(--white);transition:all .15s}.cashin-opt.active-in{border-color:var(--green);background:var(--green-bg);color:#065f46}.cashin-opt.active-out{border-color:var(--blue);background:var(--blue-light);color:var(--blue-dark)}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.content-head{padding:12px 16px;border-bottom:1px solid var(--border);background:var(--white);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-shrink:0}.content-head-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.views-list{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.view-btn{padding:5px 12px;border-radius:99px;border:1px solid var(--border-dark);background:var(--white);color:var(--text);font-size:12px;font-weight:500;display:flex;align-items:center;gap:5px;transition:all .15s}.view-btn:hover{border-color:var(--blue);color:var(--blue)}.view-btn.active{background:var(--blue);border-color:var(--blue);color:#fff}.view-btn-del{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:#ffffff4d;border:none;padding:0;cursor:pointer;color:inherit;line-height:1;font-size:11px}.stats-bar{display:flex;gap:1px;background:var(--border);border-bottom:1px solid var(--border);flex-shrink:0}.stat-item{flex:1;padding:10px 16px;background:var(--white);display:flex;align-items:center;gap:10px}.stat-icon{width:32px;height:32px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px}.stat-icon.blue{background:var(--blue-light)}.stat-icon.red{background:var(--red-bg)}.stat-icon.orange{background:var(--orange-bg)}.stat-icon.green{background:var(--green-bg)}.stat-label{font-size:11px;color:var(--text-light)}.stat-value{font-size:18px;font-weight:700;color:var(--heading);line-height:1.2}.stat-value.red{color:var(--red-dark)}.stat-value.orange{color:var(--orange)}.stat-value.green{color:var(--green)}.table-wrap{flex:1;overflow:auto}.atm-table{width:100%;border-collapse:collapse;font-size:13px}.atm-table thead{position:sticky;top:0;z-index:10;background:var(--bg-alt)}.atm-table th{padding:8px 10px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-light);border-bottom:1px solid var(--border-dark);white-space:nowrap;-webkit-user-select:none;user-select:none}.atm-table th.sortable{cursor:pointer}.atm-table th.sortable:hover{color:var(--text);background:var(--border)}.atm-table th.sort-asc,.atm-table th.sort-desc{color:var(--blue);background:var(--blue-bg)}.sort-icon{display:inline-block;margin-left:4px;opacity:.5}.sort-asc .sort-icon,.sort-desc .sort-icon{opacity:1}.atm-table td{padding:6px 10px;border-bottom:1px solid var(--border);vertical-align:middle;white-space:nowrap;max-width:200px;overflow:hidden;text-overflow:ellipsis}.atm-table tbody tr{cursor:pointer;transition:background .1s}.atm-table tbody tr:hover{background:var(--bg-alt)}.atm-table tbody tr.selected{background:var(--blue-bg)}.atm-table tbody tr.selected td{border-bottom-color:var(--blue-light)}.atm-table td.atmid{font-weight:700;color:var(--heading)}.atm-table td.serial{font-family:Courier New,monospace;font-size:12px}.atm-table td.muted{color:var(--text-light)}@media(max-width:1362px){.col-cashin,.col-typpreven,.col-regioncit,.col-regiondn{display:none}}@media(max-width:1250px){.col-customer{display:none}}@media(max-width:1050px){.col-model{display:none}}.battery-icon{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600}.battery-icon.full,.battery-icon.good{color:var(--green)}.battery-icon.medium,.battery-icon.low{color:var(--orange)}.battery-icon.critical,.battery-icon.overdue{color:var(--red-dark)}.battery-icon.overdue .spin-warning{animation:blink 1.2s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.badge{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;font-size:12px;font-weight:700;line-height:1}.badge-in{background:var(--green-bg);color:#065f46}.badge-out{background:var(--blue-light);color:var(--blue-dark)}.pagination{padding:10px 16px;border-top:1px solid var(--border);background:var(--white);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-shrink:0}.pagination-info{font-size:12px;color:var(--text-light)}.pagination-info strong{color:var(--text)}.pagination-btns{display:flex;align-items:center;gap:6px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--r);border:1px solid var(--border-dark);background:var(--white);color:var(--text);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.btn:hover{background:var(--bg-alt);border-color:#9ca3af}.btn:disabled{opacity:.5;cursor:default}.btn-primary{background:linear-gradient(135deg,var(--blue) 0%,var(--blue-dark) 100%);color:#fff;border-color:transparent}.btn-primary:hover{filter:brightness(1.08);background:linear-gradient(135deg,var(--blue) 0%,var(--blue-dark) 100%)}.btn-sm{padding:5px 10px;font-size:12px;border-radius:6px}.btn-danger{color:var(--red-dark);border-color:#fca5a5}.btn-danger:hover{background:var(--red-bg)}.btn-icon{padding:6px;border-radius:6px}.btn-link{background:none;border:none;padding:0;color:var(--blue);font-size:12px;cursor:pointer}.btn-link:hover{text-decoration:underline}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#11182766;z-index:200;display:flex;justify-content:center;align-items:flex-start;padding-top:60px}.drawer{width:50%;min-width:560px;max-width:860px;max-height:calc(100vh - 80px);background:var(--white);display:flex;flex-direction:column;border-radius:0 0 var(--r-lg) var(--r-lg);box-shadow:0 8px 32px #0000002e;animation:slideDown .22s ease}@keyframes slideDown{0%{transform:translateY(-24px);opacity:0}to{transform:translateY(0);opacity:1}}.drawer-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-shrink:0}.drawer-atmid{font-size:20px;font-weight:700;color:var(--heading);line-height:1.2}.drawer-sub{font-size:12px;color:var(--text-light);margin-top:2px}.drawer-body{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:16px}.drawer-section{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}.drawer-section-head{padding:10px 14px;background:var(--bg-alt);border-bottom:1px solid var(--border);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-light);display:flex;align-items:center;justify-content:space-between}.drawer-section-body{padding:12px 14px;display:flex;flex-direction:column;gap:10px}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.detail-field span{font-size:11px;color:var(--text-light);display:block}.detail-field strong{font-size:13px;color:var(--heading);font-weight:600}.field-row{display:flex;flex-direction:column;gap:4px}.field-label{font-size:11px;font-weight:600;color:var(--text-light)}.field-input{padding:8px 10px;border:1px solid var(--border-dark);border-radius:var(--r);font-size:13px;color:var(--text);width:100%;outline:none;background:var(--white);transition:border-color .15s,box-shadow .15s}.field-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #3b82f61f}.field-input:disabled{background:var(--bg-alt);color:var(--text-light)}textarea.field-input{min-height:72px;resize:vertical}.project-item{padding:10px 0;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:3px}.project-item:last-child{border-bottom:none;padding-bottom:0}.project-name{font-weight:600;color:var(--heading)}.project-meta{font-size:11px;color:var(--text-light)}.drawer-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;flex-shrink:0}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:24px}.auth-card{background:var(--white);border-radius:16px;box-shadow:0 20px 60px #0003;width:100%;max-width:460px;overflow:hidden}.auth-card-head{background:linear-gradient(135deg,#667eea,#764ba2);padding:28px 32px;text-align:center;color:#fff}.auth-logo{font-size:24px;font-weight:700}.auth-logo-sub{font-size:13px;opacity:.85;margin-top:4px}.auth-card-body{padding:28px 32px;display:flex;flex-direction:column;gap:16px}.auth-tabs{display:flex;border-bottom:1px solid var(--border);gap:0}.auth-tab{flex:1;padding:10px;border:none;background:none;font-size:13px;font-weight:600;color:var(--text-light);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s}.auth-tab.active{color:var(--blue);border-bottom-color:var(--blue)}.auth-field{display:flex;flex-direction:column;gap:5px}.auth-field label{font-size:12px;font-weight:600;color:var(--text)}.auth-input{padding:10px 12px;border:1px solid var(--border-dark);border-radius:var(--r);font-size:13px;color:var(--text);width:100%;outline:none;transition:border-color .15s,box-shadow .15s}.auth-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #3b82f61f}.auth-error{background:var(--red-bg);border:1px solid #fca5a5;color:#991b1b;border-radius:var(--r);padding:10px 14px;font-size:13px}.auth-success{background:var(--green-bg);border:1px solid #6ee7b7;color:#065f46;border-radius:var(--r);padding:10px 14px;font-size:13px}.auth-hint{font-size:11px;color:var(--text-light);text-align:center}.state-loading{display:flex;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-light);gap:10px}.spin{animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.state-empty{padding:40px 20px;text-align:center;color:var(--text-light);font-size:13px}.state-error{margin:12px 16px;background:var(--red-bg);border:1px solid #fca5a5;color:#991b1b;border-radius:var(--r);padding:10px 14px;font-size:13px}.users-section{border-top:1px solid var(--border);padding:16px;background:var(--white);flex-shrink:0}.users-section-head{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-light);margin-bottom:10px}.user-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);gap:12px}.user-row:last-child{border-bottom:none}.user-row-name{font-weight:600;color:var(--heading);font-size:13px}.user-row-email{font-size:11px;color:var(--text-light)}.role-select{padding:4px 8px;border:1px solid var(--border-dark);border-radius:6px;font-size:12px;background:var(--white);cursor:pointer}.admin-page{flex:1;display:flex;flex-direction:column;overflow:hidden}.admin-tabs{display:flex;gap:2px;padding:12px 16px 0;background:var(--white);border-bottom:1px solid var(--border);flex-shrink:0}.admin-tab{display:flex;align-items:center;gap:7px;padding:9px 16px;border:none;background:none;color:var(--text-light);font-size:13px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;border-radius:var(--r) var(--r) 0 0;transition:all .15s}.admin-tab:hover{color:var(--text);background:var(--bg-alt)}.admin-tab.active{color:var(--blue);border-bottom-color:var(--blue);background:var(--blue-bg)}.admin-subtabs{display:flex;gap:4px}.admin-subtab{padding:6px 16px;border:1px solid var(--border);background:var(--white);color:var(--text-light);font-size:12px;font-weight:500;border-radius:99px;cursor:pointer;transition:all .15s}.admin-subtab:hover{color:var(--text);border-color:var(--border-dark)}.admin-subtab.active{background:var(--blue);border-color:var(--blue);color:var(--white)}.admin-content{flex:1;overflow-y:auto;padding:20px;background:var(--bg)}.admin-section{background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}.admin-table{width:100%;border-collapse:collapse;font-size:13px}.admin-table thead{background:var(--bg-alt)}.admin-table th{padding:10px 14px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-light);border-bottom:1px solid var(--border-dark);white-space:nowrap}.admin-row td{padding:9px 14px;border-bottom:1px solid var(--border);vertical-align:middle}.admin-row:last-child td{border-bottom:none}.admin-row:hover{background:var(--bg-alt)}.admin-row.editing{background:var(--blue-bg)}.admin-row.add-row{background:var(--bg)}.admin-row.add-row:hover{background:var(--bg-alt)}.admin-cell-main{font-weight:500;color:var(--heading)}.admin-cell-muted{color:var(--text-light)}.admin-badge{display:inline-flex;align-items:center;justify-content:center;padding:2px 8px;line-height:2;border-radius:5px;background:var(--blue-light);color:var(--blue-dark);font-size:11px;font-weight:700}.admin-loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--text-light)}.admin-section-title-standalone{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-light);margin-bottom:8px}.admin-section-title{padding:10px 14px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-light);background:var(--bg-alt);border-bottom:1px solid var(--border-dark)}.nav-dropdown{position:absolute;top:calc(100% + 6px);right:0;background:var(--white);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-md);min-width:160px;z-index:200;overflow:hidden}.nav-dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:9px 14px;border:none;background:none;color:var(--text);font-size:13px;text-align:left;cursor:pointer;transition:background .12s}.nav-dropdown-item:hover{background:var(--bg-alt)}.nav-dropdown-item+.nav-dropdown-item{border-top:1px solid var(--border)}.nav-dropdown-danger{color:var(--red)}.nav-dropdown-danger:hover{background:var(--red-bg)}.sync-notice{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:var(--blue-bg);border:1px solid var(--blue-light);border-radius:var(--r);color:var(--blue-dark);font-size:13px;font-weight:500}.toggle-btn{position:relative;display:inline-flex;align-items:center;width:36px;height:20px;border-radius:10px;border:none;background:var(--border-dark);padding:0;transition:background .2s;cursor:pointer}.toggle-btn:disabled{opacity:.5;cursor:not-allowed}.toggle-btn.toggle-on{background:var(--green)}.toggle-knob{position:absolute;left:3px;width:14px;height:14px;border-radius:50%;background:var(--white);box-shadow:0 1px 3px #00000040;transition:left .2s}.toggle-on .toggle-knob{left:19px}.app-init{min-height:100vh;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px;color:var(--text-light)}
