.logo{height:64px;display:flex;align-items:center;justify-content:center;color:#101828;font-weight:700;font-size:24px;background:#fff;gap:10px;border-bottom:1px solid #e4e7ec;border-inline-end:1px solid rgba(5,5,5,.06);cursor:pointer}@media(max-width:768px){.logo{padding:0 12px}}@media(min-width:768px){.logo{padding:0 32px}}.logo-icon{width:32px;height:32px;background:#465fff;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff}.logo-text{font-weight:700}.sidebar-content{display:flex;flex-direction:column;height:100%}.sidebar-menu{border-right:0;padding:8px 4px;flex:1;border:none}.ant-menu-sub{border-radius:10px!important}.sider{overflow:auto;height:100vh;position:fixed;left:0;top:0;bottom:0;z-index:100;background:#fff}.layout{transition:all .2s;min-height:100vh;background:#f9fafb}.header{height:64px;background:#fff;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:99;border-bottom:1px solid #e4e7ec}@media(max-width:768px){.header{padding:0 12px}}@media(min-width:768px){.header{padding:0 32px}}.header-button{font-size:20px;width:40px;height:40px;color:#667085}.header-user-info-container{display:flex;align-items:center;gap:12px}.header-user-info-name-container{text-align:right;line-height:1.2}.header-user-info-name{font-weight:500;color:#101828}.header-user-info-role{font-size:12px;color:#667085}.header-user-info-avatar{cursor:pointer;background-color:#f2f4f7;color:#667085;vertical-align:middle;border:1px solid #e4e7ec}.content{min-height:280px}@media(max-width:768px){.content{margin:12px}}@media(min-width:768px){.content{margin:32px}}.protected-route-loading{display:flex;justify-content:center;align-items:center;height:100vh}.change-password-container{max-width:600px;margin:0 auto}.change-password-card{margin-top:24px}.change-password-form-button-mt{margin-top:8px}.page-container{margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}@media(max-width:768px){.page-header{margin-bottom:12px}}.page-title{font-size:24px;font-weight:600}.page-actions{display:flex;gap:10px}.loading,.error,.empty{text-align:center;padding:40px;color:#666;font-size:16px}.mb24{margin-bottom:24px}.mb16{margin-bottom:16px}.card-cursor-pointer{cursor:pointer}.qr-code-container{height:200px;width:200px;background-color:#f0f0f0;border-radius:10px}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:#f9fafb}@media(max-width:768px){.login-card{width:100%;max-width:100%;padding:20px}}@media(min-width:768px){.login-card{width:100%;max-width:500px;background:#fff;padding:50px;box-shadow:0 8px 13px -3px #00000012;border-radius:12px;border:1px solid #e4e7ec}}.login-card-title{margin-bottom:30px;text-align:left;display:flex;justify-content:space-between;align-items:center;gap:16px}.login-card-title-text{font-size:28px;font-weight:700;color:#101828}.login-card-title-description{color:#667085;font-size:16px}.login-form-item-label{font-weight:500;color:#101828}.login-form-item-input{height:50px;border-radius:8px;border-color:#e4e7ec}.login-form-item-mb24{margin-bottom:24px}.login-form-item-mb30{margin-bottom:30px}.login-form-item-button{height:50px;font-size:16px;font-weight:600;border-radius:8px;background:#465fff;box-shadow:none}.login-footer{display:flex;justify-content:flex-end}.machine-detail-modal-no-hardware-info{margin-top:24px;padding:16px;background:#f5f5f5;border-radius:4px}.machine-detail-modal-hardware-info-container,.machine-detail-modal-hardware-info-updated-at{margin-top:24px}.machines-page-header{display:flex;justify-content:space-between;margin-bottom:16px}.machines-page-filters{display:flex;gap:15px;align-items:center;flex-wrap:wrap}.machines-page-filter{display:flex;align-items:center;gap:8px}.machines-page-filter label{font-weight:500;color:#555}.time-range-picker-popover-content{width:550px;padding:8px 0}.time-range-picker-popover-content-border-right{border-right:1px solid #f0f0f0}.time-range-picker-popover-content-quick-ranges{display:flex;flex-direction:column;gap:4px}.time-range-picker-popover-content-quick-ranges-title{padding:0 8px 8px;color:#8c8c8c;font-size:12px}.time-range-picker-popover-content-quick-ranges-button{text-align:left;padding-left:8px}.time-range-picker-popover-content-padding-left{padding-left:16px}.time-range-picker-popover-content-custom-ranges{display:flex;flex-direction:column;gap:16px}.time-range-picker-popover-content-custom-ranges-title{display:flex;flex-direction:column;gap:8px}.time-range-picker-popover-content-custom-ranges-title-text{margin-bottom:8px;color:#8c8c8c;font-size:12px}.time-range-picker-popover-content-custom-ranges-range-picker{width:100%}.time-range-picker-popover-content-custom-ranges-button-container{display:flex;justify-content:flex-end}.time-range-picker-popover-button{min-width:240px;display:flex;justify-content:space-between;align-items:center}.time-range-picker-popover-button-icon{color:#bfbfbf}.deductions-filter-row{margin-bottom:16px;display:flex;gap:24px;flex-wrap:wrap;align-items:flex-start}.filter-field{display:flex;flex-direction:column;gap:8px}.filter-label{font-size:14px;font-weight:500;color:#666}.session-info{font-size:12px}.session-billed-duration{color:#666;margin-left:8px}.deduction-amount{color:#ff4d4f}.filter-row{display:flex;gap:15px;align-items:center;flex-wrap:wrap}.filter-field{display:flex;flex-direction:row;align-items:center;gap:8px}.amount-positive{color:#52c41a}.amount-negative{color:#ff4d4f}.balance-positive{font-weight:500;color:#1890ff}.balance-negative{font-weight:500;color:#ff4d4f}.reports-container{padding:20px;max-width:1400px;margin:0 auto}.reports-header{margin-bottom:30px}.reports-header h1{margin-bottom:20px;color:#333}.report-controls{display:flex;gap:15px;align-items:center;flex-wrap:wrap}.control-group{display:flex;align-items:center;gap:8px}.control-group label{font-weight:500;color:#555}.control-group select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;background:#fff;font-size:14px;cursor:pointer}.control-group select:focus{outline:none;border-color:#007bff}.period-navigator{display:flex;gap:10px;align-items:center;margin-left:auto}.period-nav-btn{padding:8px 16px;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s}.period-nav-btn:hover{background:#007bff;color:#fff;border-color:#007bff}.current-period{font-weight:600;color:#333;min-width:100px;text-align:center}.export-btn{padding:8px 20px;background:#28a745;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s}.export-btn:hover{background:#218838}.loading{text-align:center;padding:40px;color:#666;font-size:16px}.error-message{padding:20px;background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:4px;margin:20px 0}.report-title{margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #007bff}.report-title h2{margin:0 0 8px;color:#333;font-size:28px}.report-period{margin:0;color:#666;font-size:16px}.report-section{margin-bottom:40px}.report-section:last-child{margin-bottom:0}.report-section h3{margin:0 0 20px;color:#333;font-size:20px;padding-bottom:10px;border-bottom:1px solid #eee}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.metric-card{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:20px;transition:all .2s}.metric-card:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.metric-title{font-size:14px;color:#666;margin-bottom:10px}.metric-value{font-size:24px;font-weight:600;color:#333;margin-bottom:5px}.metric-value.green{color:#28a745}.metric-value.red{color:#dc3545}.metric-change{font-size:13px;font-weight:500}.metric-change.positive-change{color:#28a745}.metric-change.negative-change{color:#dc3545}.metric-change.neutral-change{color:#6c757d}.top-machines-table{overflow-x:auto}.top-machines-table table{width:100%;border-collapse:collapse;background:#fff}.top-machines-table thead{background:#f8f9fa}.top-machines-table th{padding:12px;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #dee2e6}.top-machines-table td{padding:12px;border-bottom:1px solid #dee2e6}.top-machines-table tbody tr:hover{background:#f8f9fa}.top-machines-table .rank{font-weight:600;color:#007bff;width:60px}.top-machines-table .amount{font-weight:600;color:#28a745;text-align:right}@media print{.ant-layout-sider{display:none!important;width:0!important}.ant-layout-header{display:none!important;height:0!important}.ant-layout,.ant-layout-content{margin:0!important;padding:0!important}@page{margin:10mm}body,html{margin:0;padding:0}#root{margin:0!important;padding:0!important}.reports-container{width:100%!important;max-width:100%!important;padding:0!important;margin:0!important}.reports-header,.report-controls,.export-btn{display:none!important}.report-content{box-shadow:none;padding:15px;background:#fff;margin:0}.report-title{margin-bottom:12px;padding-bottom:8px}.report-title h2{font-size:20px;margin:0;line-height:1.2}.report-period{font-size:12px;margin:3px 0 0}.metrics-grid{display:grid!important;grid-template-columns:repeat(4,1fr)!important;gap:10px!important;margin-bottom:15px}.metric-card{break-inside:avoid;page-break-inside:avoid;background:#f8f9fa;border:1px solid #e9ecef;padding:10px 12px;box-shadow:none}.metric-title{font-size:12px;margin-bottom:6px}.metric-value{font-size:20px;margin-bottom:3px}.metric-change{font-size:11px}.metric-card:hover{box-shadow:none;transform:none}.report-section{break-inside:avoid;page-break-inside:avoid;margin-bottom:18px}.report-section h3{font-size:16px;margin-bottom:10px}.top-machines-table{break-inside:avoid;page-break-inside:avoid}.top-machines-table table{width:100%;border-collapse:collapse}.top-machines-table thead{background:#f8f9fa}.top-machines-table th,.top-machines-table td{padding:6px 10px;border:1px solid #dee2e6;font-size:13px}.top-machines-table tbody tr:hover{background:transparent}.metric-title,.metric-value,.metric-change{display:block}}@media(max-width:768px){.report-controls{flex-direction:column;align-items:stretch}.period-navigator{margin-left:0;width:100%;justify-content:space-between}.metrics-grid{grid-template-columns:1fr}}.sessions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.page-title{margin:0}.sessions-filter-row{display:flex;gap:15px;align-items:center;flex-wrap:wrap}.filter-field{display:flex;align-items:center;gap:8px}.filter-field label{font-weight:500;color:#555}.amount-pending{color:#999;font-style:italic}.tenants-header{display:flex;justify-content:space-between;margin-bottom:16px}.off-peak-rate{color:#666;font-size:12px}.off-peak-unset{color:#999}.off-peak-container{padding:12px;background:#f5f5f5;border-radius:4px}.off-peak-hint{margin-bottom:8px;font-size:12px;color:#666}.users-container{max-width:1200px;margin:0 auto}.users-create-form{display:flex;flex-direction:column;gap:12px}.users-create-row{display:flex;flex-direction:column;gap:6px}.users-create-label{font-size:13px;color:#344054}.users-create-input{border:1px solid #d0d5dd;border-radius:8px;padding:10px 12px;outline:none}.users-create-input:focus{border-color:#465fff;box-shadow:0 0 0 3px #465fff1f}.users-temp-password{display:inline-block;padding:8px 12px;border-radius:8px;background:#f2f4f7}@font-face{font-family:Outfit;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/outfit-latin-ext-400-normal-5tcqmc2S.woff2) format("woff2"),url(/assets/outfit-latin-ext-400-normal-DHm7mdGe.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Outfit;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/outfit-latin-400-normal-BGsTXAXT.woff2) format("woff2"),url(/assets/outfit-latin-400-normal-DMwTpYkH.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Outfit;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/outfit-latin-ext-500-normal-zeox_O30.woff2) format("woff2"),url(/assets/outfit-latin-ext-500-normal-DrCvqoFD.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Outfit;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/outfit-latin-500-normal-DKnIMDSk.woff2) format("woff2"),url(/assets/outfit-latin-500-normal-ClnHRwRh.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Outfit;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/outfit-latin-ext-600-normal-B85nYjL1.woff2) format("woff2"),url(/assets/outfit-latin-ext-600-normal-CWJcPgd7.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Outfit;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/outfit-latin-600-normal-B7SfZ07L.woff2) format("woff2"),url(/assets/outfit-latin-600-normal-BEfTtDA7.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Outfit;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/outfit-latin-ext-700-normal-CI4iH74K.woff2) format("woff2"),url(/assets/outfit-latin-ext-700-normal-fjS8-Gm7.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Outfit;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/outfit-latin-700-normal-Cu9v6i1X.woff2) format("woff2"),url(/assets/outfit-latin-700-normal-D4itBLBr.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--primary-color: #465fff;--primary-hover: #3641f5;--bg-color: #f9fafb;--sidebar-bg: #ffffff;--header-bg: #ffffff;--text-color: #101828;--text-secondary: #667085;--gray-200: #e4e7ec;--gray-300: #d0d5dd;--gray-800: #1d2939;--brand-50: #ecf3ff;--brand-500: #465fff}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;font-family:Outfit,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-color);color:var(--text-color)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .5s ease-out forwards}.ant-modal-container{padding:0!important}.ant-modal-header{margin-bottom:0!important;padding:16px!important;border-bottom:1px solid #f0f0f0!important}.ant-modal-title{text-align:left}.ant-modal-body{padding:16px!important}.ant-modal-footer{margin-top:0!important;padding:16px!important;border-top:1px solid #f0f0f0!important}.ant-table-pagination{margin-bottom:0!important}
