.admin-app{display:flex;min-height:100vh;background:#f5f6fa}.main-content{flex:1;margin-left:250px;transition:margin-left .3s ease;display:flex;flex-direction:column}.main-content.sidebar-collapsed{margin-left:70px}.top-header{background:#fff;padding:1rem 1.5rem;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;align-items:center;z-index:100}.top-header h1{color:#2c3e50;font-size:1.5rem;margin:0;font-weight:600;flex:1}.user-info{display:flex;align-items:center;gap:.75rem;color:#7f8c8d;flex-shrink:0;position:relative}.user-info span{white-space:nowrap;font-weight:500}.user-info .avatar{width:36px;height:36px;background:linear-gradient(135deg,#3498db,#2980b9);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem;flex-shrink:0}.user-info .logout-btn{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:transform .2s ease;flex-shrink:0}.user-info .logout-btn:hover{transform:translateY(-1px)}.content-area{flex:1;overflow-y:auto;padding:0}.no-permission{display:flex;align-items:center;justify-content:center;height:400px;background:#fff;margin:2rem;border-radius:12px;color:#7f8c8d;font-size:1.2rem;box-shadow:0 2px 10px #0000001a}@media (max-width: 768px){.main-content,.main-content.sidebar-collapsed{margin-left:0}.top-header{padding:1rem;flex-direction:column;gap:1rem;align-items:stretch}.top-header h1{font-size:1.2rem;text-align:center}.user-info{justify-content:center;gap:.5rem}}@media (max-width: 480px){.top-header{padding:.75rem}.top-header h1{font-size:1.1rem}.user-info{flex-wrap:wrap;justify-content:center}.user-info span{text-align:center;font-size:.9rem}}@media (min-width: 769px){.top-header{align-items:center;padding-right:1rem}.user-info{margin-right:0;flex-shrink:0}}.device-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000000f;border:1px solid #f0f0f0;transition:all .3s ease;margin-bottom:16px}.device-card:hover{box-shadow:0 4px 16px #0000001a;transform:translateY(-2px)}.device-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #f5f5f5}.device-title h3{margin:0 0 4px;font-size:18px;font-weight:600;color:#2c3e50;line-height:1.4}.device-code{font-size:14px;color:#7f8c8d;font-weight:500}.device-status{display:flex;align-items:center}.status-indicator{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-indicator.online{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.status-indicator.offline{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.status-indicator.maintenance{background:#fff3cd;color:#856404;border:1px solid #ffeaa7}.device-info-grid{display:flex;flex-direction:column;gap:0;margin-bottom:24px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f8f9fa}.info-row:last-child{border-bottom:none}.info-label{font-size:14px;color:#6c757d;font-weight:500;flex-shrink:0;margin-right:16px}.info-value{font-size:14px;color:#2c3e50;font-weight:600;text-align:right;word-break:break-all}.device-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:16px;border-top:1px solid #f5f5f5}.btn-edit,.btn-delete{padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;border:1px solid;min-width:80px}.btn-edit{background:#fff;color:#007bff;border-color:#007bff}.btn-edit:hover{background:#007bff;color:#fff}.btn-edit:disabled{opacity:.6;cursor:not-allowed}.btn-delete{background:#fff;color:#dc3545;border-color:#dc3545}.btn-delete:hover{background:#dc3545;color:#fff}@media (max-width: 768px){.device-header{flex-direction:column;gap:12px;align-items:flex-start}.device-actions{flex-direction:column}.btn-edit,.btn-delete{width:100%}}.svg-background-color{background-color:transparent}.login-container{display:flex;min-height:100vh;background:#f5f7fa;align-items:center;justify-content:center;padding:20px}.login-background{width:100%;max-width:420px;position:relative}.login-card{background:#fff;border-radius:8px;padding:40px;width:100%;box-sizing:border-box;border:1px solid #e1e4e8}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:2rem}.logo{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1rem}.logo-icon{font-size:3rem}.login-header h1{color:#2c3e50;font-size:1.8rem;margin:0;font-weight:600}.login-header p{color:#7f8c8d;margin:.5rem 0 0;font-size:1rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.error-message{background:#fee;color:#e74c3c;padding:.75rem 1rem;border-radius:8px;border:1px solid #fadbd8;font-size:.9rem;text-align:center}.form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.form-group label{color:#1e293b;font-weight:500;font-size:.9rem;margin-bottom:.25rem}.form-group input[type=text],.form-group input[type=password]{padding:.8rem 1rem;border:2px solid #e1e4e8;border-radius:8px;font-size:1rem;transition:all .3s ease;background:#f8fafc;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#3b82f6;background:#fff}.captcha-group{display:flex;gap:1rem;align-items:stretch}.captcha-group input{flex:1}.captcha-code{background:#3b82f6;color:#fff;padding:.8rem 1rem;border-radius:8px;font-weight:700;font-size:1.1rem;letter-spacing:2px;min-width:80px;text-align:center;-webkit-user-select:none;user-select:none;cursor:default;display:flex;align-items:center;justify-content:center}.checkbox-group{flex-direction:row;justify-content:space-between;align-items:center;margin-bottom:1rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;color:#64748b;font-size:.9rem}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:#3b82f6}.forgot-password{color:#3b82f6;text-decoration:none;font-size:.9rem;transition:color .3s ease}.forgot-password:hover{color:#2563eb}.login-button{background:#3b82f6;color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:1rem;width:100%}.login-button:hover{transform:translateY(-2px)}.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-button.loading{background:#94a3b8}.login-tips{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #ecf0f1}.login-tips h4{color:#7f8c8d;font-size:.9rem;margin-bottom:.75rem;font-weight:500}.test-accounts{display:flex;flex-direction:column;gap:.25rem}.test-accounts div{color:#95a5a6;font-size:.8rem;font-family:monospace;background:#f8f9fa;padding:.25rem .5rem;border-radius:4px}@media (max-width: 480px){.login-background{padding:1rem}.login-card{padding:2rem}.login-header h1{font-size:1.5rem}.captcha-group{flex-direction:column;align-items:stretch}.checkbox-group{flex-direction:column;align-items:flex-start;gap:.75rem}}:root{--sidebar-bg: #ffffff}.sidebar{width:250px;height:100vh;background:#fff;color:#000;display:flex;flex-direction:column;position:fixed;left:0;top:0;transition:width .3s ease;z-index:1000;border-right:1px solid #f1f3f4}.sidebar.collapsed{width:70px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid #ecf0f1}.logo{display:flex;align-items:center;gap:.5rem}.logo-icon{font-size:1.5rem;color:#000}.logo-text{font-size:1.2rem;font-weight:600;color:#000}.collapse-btn{background:none;border:none;color:#000;font-size:1rem;cursor:pointer;padding:.25rem;border-radius:4px;transition:background .2s ease}.collapse-btn:hover{background:#0000000d}.sidebar-nav{flex:1;padding:1rem 0}.nav-item{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:none;border:none;color:#000;cursor:pointer;transition:all .2s ease;text-align:left;border-left:3px solid transparent;border-radius:6px}.nav-item:hover{background:#f0f0f0;color:#000}.nav-item.active{background:#e0e0e0;color:#000;border-left-color:#000}.nav-icon{font-size:1.2rem;min-width:1.2rem;color:#000}.nav-label{font-size:.9rem;font-weight:500;color:#000}.sidebar.collapsed .nav-item{justify-content:center;padding:.75rem}.sidebar.collapsed .nav-label{display:none}.card-demo-container{max-width:1200px;margin:0 auto;padding:24px;background-color:#f8fafc;min-height:100vh}.card-demo-container h1{color:#1e293b;font-size:32px;margin-bottom:8px}.demo-description{color:#64748b;font-size:16px;margin-bottom:32px;max-width:800px}.demo-section{margin-bottom:48px;padding-top:16px}.demo-section h2{color:#1e293b;font-size:24px;margin-bottom:24px;padding-bottom:8px;border-bottom:1px solid #e2e8f0}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;padding:8px}.demo-btn{padding:8px 16px;background-color:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.demo-btn:hover{background-color:#2563eb}.dashboard{padding:2rem}.dashboard-header{margin-bottom:2rem}.dashboard-header h2{font-size:1.8rem;color:#2c3e50;margin-bottom:.5rem}.dashboard-header p{color:#7f8c8d;font-size:1rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:8px;padding:1.5rem;border:1px solid #e1e4e8;display:flex;align-items:center;gap:1rem}.stat-icon{font-size:2.5rem;padding:1rem;background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center}.stat-content h3{font-size:1.8rem;font-weight:700;color:#2c3e50;margin-bottom:.25rem}.stat-content p{color:#7f8c8d;font-size:.9rem;margin-bottom:.5rem}.change{font-size:.8rem;font-weight:600;padding:.25rem .5rem;border-radius:4px}.change.positive{color:#27ae60;background:#27ae601a}.change.negative{color:#e74c3c;background:#e74c3c1a}.dashboard-content{display:grid;grid-template-columns:2fr 1fr;gap:2rem}.recent-transactions{background:#fff;border-radius:8px;padding:1.5rem;border:1px solid #e1e4e8}.recent-transactions h3{color:#2c3e50;margin-bottom:1rem;font-size:1.2rem}.transaction-table{width:100%}.table-header{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr .8fr;gap:1rem;padding:.75rem 0;border-bottom:2px solid #ecf0f1;font-weight:600;color:#7f8c8d;font-size:.9rem}.table-row{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr .8fr;gap:1rem;padding:1rem 0;border-bottom:1px solid #ecf0f1;align-items:center;font-size:.9rem}.table-row:hover{background:#f8f9fa}.transaction-id{color:#3498db;font-weight:500}.payment-method{color:#7f8c8d}.charts-section{display:flex;flex-direction:column;gap:1.5rem}.chart-card{background:#fff;border-radius:12px;padding:1.5rem;border:1px solid #e1e4e8}.chart-card h3{color:#2c3e50;margin-bottom:1rem;font-size:1.1rem}.chart-placeholder{height:200px;display:flex;flex-direction:column;justify-content:space-between}.chart-bars{display:flex;align-items:end;justify-content:space-around;height:160px;gap:.5rem}.bar{background:#3498db;border-radius:4px 4px 0 0;flex:1;transition:all .3s ease}.bar:hover{background:linear-gradient(to top,#2980b9,#3498db)}.chart-labels{display:flex;justify-content:space-around;font-size:.8rem;color:#7f8c8d;margin-top:.5rem}.payment-distribution{display:flex;flex-direction:column;align-items:center;justify-content:center;height:220px}.pie-chart{width:150px;height:150px;border-radius:50%;background:conic-gradient(#07c160,#07c160 216deg,#1677ff 216deg,#1677ff 360deg);position:relative;display:flex;align-items:center;justify-content:center;margin-bottom:18px}.pie-labels{display:flex;justify-content:center;gap:32px;margin-top:4px}.pie-label{font-size:1.1rem;font-weight:600;color:#1677ff;background:#f8f9fa;border-radius:6px;padding:4px 12px;box-shadow:0 1px 4px #0000000a}.pie-label.balance{color:#07c160}.pie-label.bank{color:#1677ff}.pie-chart:after{content:"";width:80px;height:80px;background:#fff;border-radius:50%;position:absolute}@media (max-width: 1024px){.dashboard-content{grid-template-columns:1fr}.charts-section{flex-direction:row}}@media (max-width: 768px){.dashboard{padding:1rem}.stats-grid{grid-template-columns:1fr}.charts-section{flex-direction:column}.table-header,.table-row{grid-template-columns:1fr 1fr 1fr;gap:.5rem}.table-header div:nth-child(n+4),.table-row div:nth-child(n+4){display:none}}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:#7f8c8d}.loading-spinner{width:40px;height:40px;border:3px solid #f3f3f3;border-top:3px solid #3498db;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:#e74c3c;text-align:center}.error-state .error-icon{font-size:3rem;margin-bottom:1rem}.error-state .error-message{font-size:1.1rem;margin-bottom:1rem}.error-state .retry-btn{background:#3498db;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;cursor:pointer;transition:transform .2s ease}.error-state .retry-btn:hover{transform:translateY(-1px)}.refresh-indicator{position:absolute;top:1rem;right:1rem;width:8px;height:8px;background:#27ae60;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:none}70%{box-shadow:none}to{box-shadow:none}}@media (max-width: 768px){.loading-state,.error-state{min-height:300px;padding:1rem}.loading-spinner{width:30px;height:30px}}.transaction-list{padding:2rem}.transaction-header{margin-bottom:2rem}.transaction-header h2{font-size:1.8rem;color:#2c3e50;margin-bottom:.5rem}.transaction-header p{color:#7f8c8d;font-size:1rem}.filters-section{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:1rem}.search-filters{display:flex;gap:1rem;flex:1}.search-box{position:relative;flex:1;max-width:400px}.search-box input{width:100%;padding:.75rem 2.5rem .75rem 1rem;border:2px solid #e1e4e8;border-radius:8px;font-size:.9rem;transition:border-color .3s ease}.search-box input:focus{outline:none;border-color:#3498db}.search-icon{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:#7f8c8d}.filter-select{padding:.75rem 1rem;border:2px solid #e1e4e8;border-radius:8px;background:#fff;font-size:.9rem;cursor:pointer}.export-btn{background:#27ae60;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:500;cursor:pointer;transition:transform .2s ease}.export-btn:hover{transform:translateY(-1px)}.transaction-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.stat-item{background:#fff;padding:1rem;border-radius:8px;border:1px solid #e1e4e8;text-align:center}.stat-label{display:block;color:#7f8c8d;font-size:.8rem;margin-bottom:.5rem}.stat-value{font-size:1.5rem;font-weight:700;color:#2c3e50}.stat-value.success{color:#27ae60}.stat-value.failed{color:#e74c3c}.stat-value.pending{color:#f39c12}.transaction-table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 10px #0000001a;margin-bottom:1.5rem}.transaction-table{width:100%;border-collapse:collapse}.transaction-table th{background:#f8f9fa;padding:1rem;text-align:left;font-weight:600;color:#2c3e50;border-bottom:2px solid #ecf0f1}.transaction-table td{padding:1rem;border-bottom:1px solid #ecf0f1;vertical-align:middle}.transaction-table tr:hover{background:#f8f9fa}.transaction-id,.order-id{color:#3498db;font-weight:500;font-family:Arial,Microsoft YaHei,Helvetica,sans-serif}.amount{font-weight:600;color:#27ae60}.payment-method{padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500}.payment-method.余额支付{background:#1677ff1a;color:#1677ff}.payment-method.银行卡支付{background:#8a2be21a;color:#8a2be2}.status.成功{color:#27ae60}.status.成功 .status-dot{background:#27ae60}.status.处理中{color:#f39c12}.status.处理中 .status-dot{background:#f39c12}.status.失败{color:#e74c3c}.status.失败 .status-dot{background:#e74c3c}.status.已退款{color:#9b59b6}.status.已退款 .status-dot{background:#9b59b6}.time-info{font-size:.9rem}.time{color:#7f8c8d;font-size:.8rem}.action-buttons{display:flex;gap:.5rem}.action-btn.view{background:#3498db;color:#fff}.action-btn.view:hover{background:#2980b9}.action-btn.refund{background:#e74c3c;color:#fff}.action-btn.refund:hover{background:#c0392b}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:2rem}.page-btn{padding:.5rem 1rem;border:2px solid #ecf0f1;background:#fff;border-radius:6px;cursor:pointer;transition:all .2s ease}.page-btn:hover{border-color:#3498db;color:#3498db}.page-info{color:#7f8c8d;font-size:.9rem}@media (max-width: 1200px){.transaction-table{font-size:.8rem}.transaction-table th,.transaction-table td{padding:.75rem .5rem}}@media (max-width: 768px){.transaction-list{padding:1rem}.filters-section{flex-direction:column;align-items:stretch}.search-filters{flex-direction:column}.transaction-table-container{overflow-x:auto}.transaction-table{min-width:800px}}.user-center{padding:24px;min-height:100vh;background:#f8fafc}.center-header{margin-bottom:32px}.center-header h2{color:#1e293b;font-size:28px;font-weight:600;margin-bottom:8px}.center-header p{color:#64748b;font-size:16px;margin:0}.center-tabs{display:flex;gap:4px;margin-bottom:32px;background:#e2e8f0;border-radius:12px;padding:6px}.tab-btn{flex:1;padding:14px 24px;border:none;background:transparent;color:#64748b;font-size:15px;font-weight:500;border-radius:8px;cursor:pointer;transition:all .3s ease;text-align:center;position:relative;min-height:48px;display:flex;align-items:center;justify-content:center}.tab-btn.active{background:#fff;color:#1e293b;transform:translateY(-1px)}.search-input{width:280px;padding:12px 16px;border:2px solid #e1e4e8;border-radius:8px;font-size:14px;background:#fff;transition:all .3s ease}.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:24px}.user-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014;transition:all .3s ease;border:1px solid #e2e8f0}.user-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001f}.user-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:20px;position:relative}.user-avatar{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#1d4ed8);display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;font-weight:600;flex-shrink:0}.user-info{min-width:0}.user-info h4{color:#1e293b;font-size:20px;font-weight:600;margin:0 0 8px}.user-phone{color:#64748b;font-size:14px;margin:0 0 4px}.user-email{color:#64748b;font-size:14px;margin:0}.user-status{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:500;white-space:nowrap;flex-shrink:0;align-self:flex-start}.user-status.active{background:#dcfce7;color:#166534}.user-status.pending{background:#fef3c7;color:#92400e}.user-status.suspended{background:#fecaca;color:#991b1b}.user-status.expired{background:#e5e7eb;color:#374151}.status-dot{width:8px;height:8px;border-radius:50%;background:currentColor;flex-shrink:0}.user-details{margin-bottom:20px}.card-number{font-family:monospace;font-size:13px!important;letter-spacing:.5px}.last-used{font-size:12px!important;color:#6b7280!important}.user-actions{display:flex;gap:8px}.action-btn.suspend{background:#fef2f2;color:#dc2626}.action-btn.suspend:hover{background:#fecaca}.action-btn.activate{background:#f0fdf4;color:#16a34a}.action-btn.activate:hover{background:#dcfce7}.applications-list{display:flex;flex-direction:column;gap:16px}.application-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014;border:1px solid #e2e8f0;transition:all .3s ease}.application-card:hover{transform:translateY(-1px);box-shadow:0 4px 16px #0000001f}.application-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.applicant-info h4{color:#1e293b;font-size:20px;font-weight:600;margin:0 0 8px}.applicant-info p{color:#64748b;font-size:14px;margin:0}.application-status{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:500;white-space:nowrap}.application-status.pending{background:#fef3c7;color:#92400e}.application-status.approved{background:#dcfce7;color:#166534}.application-status.rejected{background:#fecaca;color:#991b1b}.application-details{margin-bottom:20px}.id-card{font-family:monospace;font-size:13px!important;letter-spacing:.5px}.documents{font-size:12px!important;color:#6b7280!important}.reject-reason{font-size:12px!important;color:#dc2626!important;font-style:italic}.application-actions{display:flex;gap:8px}.action-btn.approve{background:#f0fdf4;color:#16a34a}.action-btn.approve:hover{background:#dcfce7}.action-btn.reject{background:#fef2f2;color:#dc2626}.action-btn.reject:hover{background:#fecaca}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px}.stat-card{background:#fff;border-radius:12px;padding:24px;text-align:center;box-shadow:0 2px 8px #00000014;border:1px solid #e2e8f0;transition:all .3s ease}.stat-value{font-size:32px;font-weight:700;color:#1e293b;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{padding:12px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;background:#f8fafc;transition:all .3s ease;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;background:#fff;box-shadow:0 0 0 3px #3b82f61a}.form-group textarea{resize:vertical;min-height:80px}.reject-btn{padding:12px 24px;background:#dc2626;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.reject-btn:hover{background:#b91c1c}.user-header .user-status{position:relative;top:0;right:0;margin-left:auto;margin-top:0;height:fit-content}@media (max-width: 768px){.user-header .user-status{margin-left:0;margin-top:12px;align-self:flex-start}}@media (min-width: 769px){.user-header .user-status{position:absolute;top:0;right:0}.user-header{position:relative;padding-right:100px}}@media (max-width: 768px){.user-center{padding:16px}.users-grid{grid-template-columns:1fr}.header-actions{flex-direction:column;gap:12px;align-items:stretch}.search-input{width:100%}.form-grid{grid-template-columns:1fr}.center-tabs{flex-direction:column}.tab-btn{text-align:center}.user-header{flex-direction:column;align-items:flex-start;text-align:left;gap:12px}.user-status{align-self:flex-start;margin-top:8px}}@media (max-width: 480px){.center-header h2{font-size:24px}.user-card,.application-card{padding:16px}.modal-content{width:95%;margin:16px}.modal-header,.modal-body,.modal-footer{padding:16px}.stats-grid{grid-template-columns:1fr}}.gate-system{padding:24px;min-height:100vh;background:#f8fafc}.system-header{margin-bottom:24px}.system-header h2{color:#1e293b;font-size:28px;font-weight:600;margin-bottom:8px}.system-header p{color:#64748b;font-size:16px;margin:0}.system-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:32px}.stat-card{background:#fff;border-radius:12px;padding:20px;text-align:center;border:1px solid #e1e4e8;transition:all .3s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001f}.stat-value{font-size:24px;font-weight:700;color:#1e293b;margin-bottom:8px}.stat-label{color:#64748b;font-size:14px;font-weight:500}.system-tabs{display:flex;gap:4px;margin-bottom:32px;background:#e2e8f0;border-radius:12px;padding:6px}.tab-btn{flex:1;padding:14px 20px;border:none;background:transparent;color:#64748b;font-size:15px;font-weight:500;border-radius:8px;cursor:pointer;transition:all .3s ease;text-align:center;position:relative;min-height:48px;display:flex;align-items:center;justify-content:center}.tab-btn:hover{background:#3b82f61a;color:#3b82f6;transform:translateY(-1px)}.tab-btn.active{background:#fff;color:#fff;transform:translateY(-1px)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.section-header h3{color:#1e293b;font-size:24px;font-weight:600;margin:0}.header-actions{display:flex;gap:12px;align-items:center}.active-gate-info{display:flex;align-items:center;gap:8px;color:#3b82f6;font-weight:500;font-size:14px}.search-container{position:relative}.search-input{width:280px;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;background:#fff;transition:all .3s ease}.search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.filter-select{padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;background:#fff;color:#1e293b;cursor:pointer;transition:all .3s ease}.filter-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.add-btn{display:flex;align-items:center;gap:8px;padding:12px 20px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.add-btn:hover{background:#2563eb;transform:translateY(-1px)}.add-btn span{font-size:16px;font-weight:700}.stations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:24px}.station-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014;transition:all .3s ease;border:1px solid #e2e8f0}.station-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001f}.station-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.station-info h4{color:#1e293b;font-size:20px;font-weight:600;margin:0 0 8px}.station-line{color:#3b82f6;font-size:14px;font-weight:500;margin:0 0 4px}.station-address{color:#64748b;font-size:14px;margin:0}.station-status{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:500;white-space:nowrap}.station-status.active{background:#dcfce7;color:#166534}.station-status.maintenance{background:#fef3c7;color:#92400e}.station-status.closed{background:#fecaca;color:#991b1b}.status-dot{width:8px;height:8px;border-radius:50%;background:currentColor}.station-stats{display:flex;gap:32px;margin-bottom:20px}.stat-item{display:flex;flex-direction:column;align-items:center}.stat-item .stat-value{font-size:20px;font-weight:700;color:#1e293b;margin-bottom:4px}.stat-item .stat-label{color:#64748b;font-size:12px;font-weight:500}.station-actions{display:flex;gap:8px}.action-btn{flex:1;padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.action-btn.edit{background:#f3f4f6;color:#374151}.action-btn.edit:hover{background:#e5e7eb}.action-btn.view{background:#e0f2fe;color:#0891b2}.action-btn.view:hover{background:#b3e5fc}.action-btn.select{background:#f0f9ff;color:#0284c7}.action-btn.select:hover{background:#e0f7fa}.gates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:24px}.gate-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014;transition:all .3s ease;border:1px solid #e2e8f0}.gate-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001f}.gate-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.gate-info h4{color:#1e293b;font-size:18px;font-weight:600;margin:0 0 8px}.gate-station{color:#3b82f6;font-size:14px;font-weight:500;margin:0 0 4px}.gate-location{color:#64748b;font-size:14px;margin:0}.gate-status{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:500;white-space:nowrap}.gate-status.online{background:#dcfce7;color:#166534}.gate-status.offline{background:#fecaca;color:#991b1b}.gate-status.maintenance{background:#fef3c7;color:#92400e}.gate-details{margin-bottom:20px}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f1f5f9}.detail-row:last-child{border-bottom:none}.detail-row span:first-child{color:#64748b;font-size:14px;font-weight:500}.detail-row span:last-child{color:#1e293b;font-size:14px;font-weight:600}.gate-type{padding:2px 8px;border-radius:4px;font-size:12px!important;font-weight:500!important}.gate-type.entry{background:#dcfce7;color:#166534}.gate-type.exit{background:#fecaca;color:#991b1b}.gate-type.bidirectional{background:#dbeafe;color:#1e40af}.error-high{color:#dc2626!important;font-weight:700!important}.gate-actions{display:flex;gap:8px}.scanner-container{display:grid;grid-template-columns:1fr 1fr;gap:32px;max-width:1200px;margin:0 auto}.scanner-panel{background:#fff;border-radius:12px;padding:32px;box-shadow:0 2px 8px #00000014;border:1px solid #e2e8f0}.scanner-frame{margin-bottom:24px}.scanner-area{width:100%;height:300px;border:3px dashed #e2e8f0;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#f8fafc;position:relative;overflow:hidden;transition:all .3s ease}.scanner-area.scanning{border-color:#3b82f6;background:#f0f9ff}.scan-placeholder{text-align:center;color:#64748b}.scan-icon{font-size:48px;margin-bottom:16px}.scan-placeholder p{font-size:16px;font-weight:500;margin:0}.scanning-animation{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;flex-direction:column}.scan-line{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,#3b82f6,transparent);animation:scanAnimation 2s infinite}@keyframes scanAnimation{0%{transform:translateY(0)}to{transform:translateY(297px)}}.scanning-animation p{color:#3b82f6;font-size:18px;font-weight:600;margin:0}.scanner-controls{text-align:center}.scan-btn{padding:16px 32px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:140px}.scan-btn:hover:not(:disabled){background:#2563eb;transform:translateY(-1px)}.scan-btn:disabled{background:#94a3b8;cursor:not-allowed}.gate-hint{color:#64748b;font-size:14px;margin-top:12px;margin-bottom:0}.scan-result-panel{background:#fff;border-radius:12px;padding:32px;box-shadow:0 2px 8px #00000014;border:1px solid #e2e8f0;display:flex;flex-direction:column;gap:24px}.scan-error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:20px;display:flex;align-items:center;gap:16px}.error-icon{font-size:24px;color:#dc2626}.error-message{flex:1;color:#dc2626;font-weight:500}.retry-btn{padding:8px 16px;background:#dc2626;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.retry-btn:hover{background:#b91c1c}.scan-success{display:flex;flex-direction:column;gap:24px}.user-info h4{color:#1e293b;font-size:20px;font-weight:600}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.info-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f1f5f9}.info-item:last-child{border-bottom:none}.info-item span:first-child{color:#64748b;font-size:14px;font-weight:500}.info-item span:last-child{color:#1e293b;font-size:14px;font-weight:600}.user-type{padding:2px 8px;border-radius:4px;font-size:12px!important;font-weight:500!important}.user-type.regular{background:#dbeafe;color:#1e40af}.user-type.student{background:#dcfce7;color:#166534}.user-type.senior{background:#fef3c7;color:#92400e}.user-type.staff{background:#e0e7ff;color:#3730a3}.balance{font-weight:700!important;color:#059669!important}.balance.low{color:#dc2626!important}.status{padding:2px 8px;border-radius:4px;font-size:12px!important;font-weight:500!important}.status.active{background:#dcfce7;color:#166534}.status.suspended{background:#fecaca;color:#991b1b}.status.expired{background:#e5e7eb;color:#374151}.event-actions{display:flex;gap:12px}.event-btn{flex:1;padding:16px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.event-btn:disabled{opacity:.5;cursor:not-allowed}.event-btn.entry{background:#dcfce7;color:#166534}.event-btn.entry:hover:not(:disabled){background:#bbf7d0}.event-btn.exit{background:#fecaca;color:#991b1b}.event-btn.exit:hover:not(:disabled){background:#fca5a5}.events-list{display:flex;flex-direction:column;gap:16px}.event-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014;border:1px solid #e2e8f0;transition:all .3s ease}.event-card:hover{transform:translateY(-1px);box-shadow:0 4px 16px #0000001f}.event-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.event-type{display:flex;align-items:center;gap:12px;margin-bottom:8px}.type-badge{padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.type-badge.entry{background:#dcfce7;color:#166534}.type-badge.exit{background:#fecaca;color:#991b1b}.event-time{color:#64748b;font-size:14px;font-weight:500}.event-user{display:flex;align-items:center;gap:12px}.user-name{color:#1e293b;font-size:16px;font-weight:600}.card-number{color:#64748b;font-size:14px;font-family:monospace;letter-spacing:.5px}.event-status{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:500;white-space:nowrap}.event-status.success{background:#dcfce7;color:#166534}.event-status.failed{background:#fecaca;color:#991b1b}.event-status.pending{background:#fef3c7;color:#92400e}.event-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:8px}.fare{color:#059669!important;font-weight:700!important}.balance-change{font-family:monospace;font-size:13px!important;color:#6b7280!important}.error-msg{color:#dc2626!important;font-style:italic;font-size:12px!important}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e2e8f0}.modal-header h3{color:#1e293b;font-size:20px;font-weight:600;margin:0}.close-btn{background:none;border:none;font-size:24px;color:#64748b;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s ease}.close-btn:hover{background:#f1f5f9;color:#1e293b}.modal-body{padding:24px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.form-group label{color:#1e293b;font-size:14px;font-weight:500;margin-bottom:4px}.form-group input,.form-group select{padding:12px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;background:#f8fafc;transition:all .3s ease;box-sizing:border-box}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6;background:#fff;box-shadow:0 0 0 3px #3b82f61a}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:24px;border-top:1px solid #e2e8f0}.cancel-btn{padding:12px 24px;border:2px solid #e2e8f0;background:#fff;color:#374151;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.cancel-btn:hover{background:#f9fafb;border-color:#d1d5db}.save-btn{padding:12px 24px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.save-btn:hover{background:#2563eb}@media (max-width: 768px){.gate-system{padding:16px}.stations-grid,.gates-grid,.scanner-container{grid-template-columns:1fr}.system-stats{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.header-actions{flex-direction:column;gap:12px;align-items:stretch}.search-input{width:100%}.form-grid{grid-template-columns:1fr}.system-tabs{flex-direction:column}.tab-btn{text-align:center}.info-grid,.event-details{grid-template-columns:1fr}.station-stats{justify-content:center}}@media (max-width: 480px){.system-header h2{font-size:24px}.station-card,.gate-card,.event-card{padding:16px}.scanner-panel,.scan-result-panel{padding:20px}.modal-content{width:95%;margin:16px}.modal-header,.modal-body,.modal-footer{padding:16px}.system-stats{grid-template-columns:repeat(2,1fr)}.scanner-area{height:240px}.event-actions{flex-direction:column}}.discount-strategy{padding:20px;background:#f5f5f5;min-height:100vh}.strategy-header{background:#fff;padding:20px;border-radius:8px;margin-bottom:20px;border:1px solid #e1e4e8}.strategy-header h2{margin:0 0 5px;color:#2c3e50;font-size:24px}.strategy-header p{margin:0;color:#7f8c8d;font-size:14px}.strategy-tabs{display:flex;background:#fff;border-radius:8px;padding:4px;margin-bottom:20px;border:1px solid #e1e4e8}.tab-btn{flex:1;padding:12px 20px;border:none;background:transparent;border-radius:6px;cursor:pointer;font-weight:500;transition:all .3s ease;color:#7f8c8d}.tab-btn:hover{background:#f8f9fa;color:#2c3e50}.tab-btn.active{background:#3498db;color:#fff}.tab-content{background:#fff;border-radius:8px;padding:20px;border:1px solid #e1e4e8}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid #ecf0f1}.section-header h3{margin:0;color:#2c3e50;font-size:18px}.header-actions{display:flex;gap:15px;align-items:center}.search-input{padding:8px 12px;border:1px solid #ddd;border-radius:6px;width:250px;font-size:14px}.search-input:focus{outline:none;border-color:#3498db}.create-btn{padding:8px 16px;background:#27ae60;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .3s ease}.create-btn:hover{background:#229954}.back-btn{padding:8px 16px;background:#7f8c8d;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .3s ease}.back-btn:hover{background:#6c7b7d}.categories-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-bottom:25px}.category-card{display:flex;align-items:center;gap:15px;padding:15px;background:#f8f9fa;border-radius:8px;cursor:pointer;transition:all .3s ease;border:2px solid transparent}.category-card:hover{background:#e9ecef;transform:translateY(-2px)}.category-card.active{background:#e3f2fd;border-color:#3498db}.category-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:#fff}.category-info h4{margin:0 0 4px;color:#2c3e50;font-size:14px}.category-info p{margin:0 0 4px;color:#7f8c8d;font-size:12px}.category-count{color:#3498db;font-size:12px;font-weight:500}.rules-table-container{overflow-x:auto}.rules-table{width:100%;border-collapse:collapse;font-size:14px}.rules-table th,.rules-table td{padding:12px;text-align:left;border-bottom:1px solid #ecf0f1}.rules-table th{background:#f8f9fa;font-weight:600;color:#2c3e50}.rules-table tr:hover{background:#f8f9fa}.rule-name strong{color:#2c3e50;font-size:14px}.rule-name p{margin:4px 0 0;color:#7f8c8d;font-size:12px}.rule-type{padding:4px 8px;border-radius:20px;font-size:12px;font-weight:500}.rule-type.percentage{background:#d4edda;color:#155724}.rule-type.fixed{background:#cce5ff;color:#004085}.rule-type.tiered{background:#fff3cd;color:#856404}.rule-type.combo{background:#f8d7da;color:#721c24}.discount-info span{display:block;color:#2c3e50;font-weight:500}.discount-info p{margin:4px 0 0;color:#7f8c8d;font-size:12px}.conditions{display:flex;flex-direction:column;gap:4px}.condition-tag{padding:2px 6px;background:#e9ecef;color:#495057;border-radius:4px;font-size:11px;font-weight:500;width:fit-content}.date-range{display:flex;flex-direction:column;gap:2px;font-size:12px;color:#2c3e50}.usage-info{display:flex;flex-direction:column;gap:4px;font-size:12px}.usage-bar{width:60px;height:4px;background:#e9ecef;border-radius:2px;overflow:hidden}.usage-fill{height:100%;background:#3498db;transition:width .3s ease}.status{display:inline-flex;align-items:center;gap:5px;padding:4px 8px;border-radius:20px;font-size:12px;font-weight:500}.status.active{background:#d4edda;color:#155724}.status.inactive{background:#f8d7da;color:#721c24}.status.expired{background:#e2e3e5;color:#6c757d}.status-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.rule-actions{display:flex;gap:8px;flex-wrap:wrap}.action-btn{padding:4px 8px;border:none;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s ease}.action-btn.disable{background:#f39c12;color:#fff}.action-btn.disable:hover{background:#e67e22}.form-container{max-width:800px}.form-section{margin-bottom:30px;padding:20px;background:#f8f9fa;border-radius:8px}.form-section h4{margin:0 0 15px;color:#2c3e50;font-size:16px;padding-bottom:8px;border-bottom:1px solid #dee2e6}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:15px}.form-group{display:flex;flex-direction:column;gap:5px}.form-group.full-width{grid-column:1 / -1}.form-group label{font-size:14px;color:#2c3e50;font-weight:500}.form-group input,.form-group select,.form-group textarea{padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 2px #3498db33}.checkbox-label{flex-direction:row!important;align-items:center;gap:8px;cursor:pointer}.checkbox-label input[type=checkbox]{width:auto;margin:0}.form-actions{display:flex;justify-content:flex-end;gap:15px;margin-top:30px;padding-top:20px;border-top:1px solid #dee2e6}.cancel-btn{padding:10px 20px;background:#6c757d;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .3s ease}.cancel-btn:hover{background:#5a6268}.save-btn{padding:10px 20px;background:#27ae60;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .3s ease}.save-btn:hover{background:#229954}.analytics-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}.analytics-card{display:flex;align-items:center;gap:15px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;transition:transform .3s ease;flex-direction:row!important}.analytics-card:hover{transform:translateY(-2px)}.card-icon{font-size:24px;width:50px;height:50px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#f8f9fa}.card-info h4{margin:0 0 5px;color:#7f8c8d;font-size:14px;font-weight:500}.card-value{font-size:24px;font-weight:700;color:#2c3e50;margin-bottom:5px}.card-change{font-size:12px;font-weight:500}.card-change.positive{color:#27ae60}.card-change.negative{color:#e74c3c}.card-change.neutral{color:#7f8c8d}.analytics-charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:20px}.chart-container{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a}.chart-container h4{margin:0 0 15px;color:#2c3e50;font-size:16px}.chart-placeholder{height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#f8f9fa;border-radius:6px;color:#7f8c8d;text-align:center}.chart-placeholder p{margin:5px 0;font-size:14px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 30px #0000004d}.rule-modal{width:90vw;max-width:700px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #ecf0f1}.modal-header h3{margin:0;color:#2c3e50}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#7f8c8d;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.close-btn:hover{background:#f8f9fa;color:#2c3e50}.modal-body{padding:20px}.modal-footer{display:flex;justify-content:flex-end;gap:15px;padding:20px;border-top:1px solid #ecf0f1}@media (max-width: 768px){.strategy-tabs{flex-direction:column}.header-actions{flex-direction:column;gap:10px}.search-input{width:100%}.categories-grid,.analytics-cards,.analytics-charts,.form-grid{grid-template-columns:1fr}.rule-actions{flex-direction:column}.action-btn{width:100%}.form-actions{flex-direction:column}.cancel-btn,.save-btn{width:100%}.modal-content{margin:20px;max-height:calc(100vh - 40px)}}.city-selector{min-width:160px;padding:8px 12px;border:1px solid #ddd;border-radius:6px;background:#fff;font-size:14px;margin-right:12px;cursor:pointer;transition:all .3s ease}.city-selector:hover{border-color:#3498db}.city-selector:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 2px #3498db33}.city-selector:disabled{background-color:#f8f9fa;cursor:not-allowed;opacity:.6}.city-info{display:flex;align-items:center;padding:12px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;margin-bottom:20px;font-size:14px;box-shadow:0 2px 8px #667eea4d}.city-label{font-weight:500;margin-right:8px}.city-name{font-weight:600;font-size:16px;margin-right:12px}.strategy-count{color:#ffffffe6;margin-right:12px}.loading-text{color:#fffc;font-style:italic;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:.8}50%{opacity:1}}.search-group{display:flex;align-items:center;gap:12px}.search-input{min-width:200px}.pagination-container{display:flex;justify-content:space-between;align-items:center;padding:20px;background:#fff;border-top:1px solid #e9ecef;border-radius:0 0 8px 8px}.pagination-info{display:flex;align-items:center;gap:10px;color:#6c757d;font-size:14px}.page-size-select{padding:4px 8px;border:1px solid #ddd;border-radius:4px;font-size:14px}.pagination-controls{display:flex;align-items:center;gap:8px}.page-btn{padding:8px 12px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s ease}.page-btn:hover:not(:disabled){background:#f8f9fa;border-color:#007bff}.page-btn:disabled{color:#6c757d;cursor:not-allowed;opacity:.5}.page-numbers{display:flex;align-items:center;gap:4px}.page-number{padding:8px 12px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer;font-size:14px;min-width:40px;text-align:center;transition:all .2s ease}.page-number:hover{background:#f8f9fa;border-color:#007bff}.page-number.active{background:#007bff;color:#fff;border-color:#007bff}.ellipsis{padding:8px 4px;color:#6c757d;font-size:14px}.filter-select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;background:#fff;min-width:120px}.filter-select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.search-group{display:flex;gap:12px;align-items:center;flex-wrap:wrap}@media (max-width: 768px){.pagination-container{flex-direction:column;gap:15px;align-items:stretch}.pagination-controls{justify-content:center}.search-group{flex-direction:column;align-items:stretch}.search-input,.filter-select,.city-selector{width:100%}}.strategy-detail-section{margin-bottom:24px;border:1px solid #e1e5e9;border-radius:8px;padding:16px;background:#fafbfc}.strategy-detail-section h4{margin:0 0 16px;color:#2c3e50;font-size:16px;font-weight:600;border-bottom:2px solid #3498db;padding-bottom:8px}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-item label{font-weight:500;color:#555;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.detail-item span{padding:8px 12px;background:#fff;border:1px solid #ddd;border-radius:4px;font-size:14px;color:#333}.detail-content{background:#fff;border:1px solid #ddd;border-radius:4px;padding:12px}.detail-content pre{margin:0;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:12px;line-height:1.4;color:#333;background:#f8f9fa;padding:8px;border-radius:3px;overflow-x:auto}.status.active{background-color:#d4edda;color:#155724;border-color:#c3e6cb}.status.inactive{background-color:#f8d7da;color:#721c24;border-color:#f5c6cb}.status.expired{background-color:#ffeaa7;color:#856404;border-color:#fdd835}@media (max-width: 768px){.detail-grid{grid-template-columns:1fr}.strategy-detail-section{padding:12px;margin-bottom:16px}.detail-item span{padding:6px 8px;font-size:13px}}.section-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:15px}.section-controls h4{margin:0;color:#2c3e50;font-size:18px}.city-selector{display:flex;align-items:center;gap:8px}.city-selector label{font-weight:500;color:#5a6c7d;white-space:nowrap}.city-selector select{min-width:150px;padding:8px 12px;border:1px solid #ddd;border-radius:6px;background:#fff;font-size:14px;color:#2c3e50;cursor:pointer;transition:border-color .3s ease}.city-selector select:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 2px #3498db33}.active-strategies-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-top:20px}.active-strategy-card{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 8px #0000001a;transition:transform .2s ease,box-shadow .2s ease}.active-strategy-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.strategy-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px}.strategy-header h5{margin:0;color:#2c3e50;font-size:16px;font-weight:600}.strategy-type{background:#e8f4fd;color:#2980b9;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.strategy-details .description{color:#7f8c8d;font-size:14px;margin-bottom:12px;line-height:1.4}.strategy-stats{display:flex;gap:8px;margin-bottom:10px;flex-wrap:wrap}.discount-info{background:#d5f4e6;color:#27ae60;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.condition-info{background:#fef5e7;color:#f39c12;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.strategy-period,.city-info{font-size:12px;color:#95a5a6;margin-bottom:5px}.city-info{font-weight:500;color:#8e44ad}@media (max-width: 768px){.section-controls{flex-direction:column;align-items:flex-start}.city-selector{width:100%;justify-content:space-between}.city-selector select{min-width:200px}.active-strategies-grid{grid-template-columns:1fr}}.batch-actions-bar{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;padding:12px 16px;margin-bottom:16px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000000d}.selected-info{font-weight:500;color:#495057;font-size:14px}.batch-buttons{display:flex;gap:8px}.batch-btn{padding:6px 12px;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:70px}.batch-btn:disabled{opacity:.6;cursor:not-allowed}.batch-enable{background:#28a745;color:#fff}.batch-enable:hover:not(:disabled){background:#218838}.batch-disable{background:#dc3545;color:#fff}.batch-disable:hover:not(:disabled){background:#c82333}.batch-cancel{background:#6c757d;color:#fff}.batch-cancel:hover:not(:disabled){background:#5a6268}.select-checkbox{width:16px;height:16px;cursor:pointer;accent-color:#007bff}.rules-table th:first-child,.rules-table td:first-child{width:40px;text-align:center;padding:8px 4px}@media (max-width: 768px){.batch-actions-bar{flex-direction:column;gap:12px;align-items:stretch}.batch-buttons{justify-content:space-between}.batch-btn{flex:1;min-width:auto}}.permission-management{padding:2rem}.permission-header{margin-bottom:2rem}.permission-header h2{font-size:1.8rem;color:#2c3e50;margin-bottom:.5rem}.permission-header p{color:#7f8c8d;font-size:1rem}.permission-tabs{display:flex;border-bottom:2px solid #ecf0f1;margin-bottom:2rem}.tab-btn{background:none;border:none;padding:1rem 2rem;font-size:1rem;color:#7f8c8d;cursor:pointer;transition:all .3s ease;border-bottom:3px solid transparent}.tab-btn:hover{color:#3498db}.tab-btn.active{color:#fff;border-bottom-color:#3498db;font-weight:600}.tab-content{min-height:500px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.section-header h3{color:#2c3e50;font-size:1.3rem;margin:0}.add-btn{background:#3498db;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-weight:500;cursor:pointer;transition:transform .2s ease}.add-btn:hover{transform:translateY(-2px)}.roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:2rem}.role-card{background:#fff;border-radius:12px;padding:1.5rem;border:1px solid #e1e4e8;border:1px solid #ecf0f1}.role-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.role-header h4{color:#2c3e50;margin:0;font-size:1.2rem}.user-count{background:#3498db;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.8rem;font-weight:500}.role-description{color:#7f8c8d;margin-bottom:1.5rem;font-size:.9rem}.permissions-section h5{color:#2c3e50;margin-bottom:1rem;font-size:1rem}.permissions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;margin-bottom:1.5rem}.permission-item{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem;border-radius:6px;transition:background .2s ease}.permission-item:hover{background:#f8f9fa}.permission-item input[type=checkbox]{width:16px;height:16px;accent-color:#3498db}.permission-name{font-size:.9rem;color:#2c3e50}.role-actions{display:flex;gap:.75rem;justify-content:flex-end;border-top:1px solid #ecf0f1;padding-top:1rem}.edit-btn,.delete-btn{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s ease}.edit-btn{background:#3498db;color:#fff}.edit-btn:hover{background:#2980b9}.delete-btn{background:#e74c3c;color:#fff}.delete-btn:hover{background:#c0392b}.users-table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 10px #0000001a}.users-table{width:100%;border-collapse:collapse}.users-table th{background:#f8f9fa;padding:1rem;text-align:left;font-weight:600;color:#2c3e50;border-bottom:2px solid #ecf0f1}.users-table td{padding:1rem;border-bottom:1px solid #ecf0f1;vertical-align:middle}.users-table tr:hover{background:#f8f9fa}.role-select{background:#fff;border:1px solid #ddd;border-radius:6px;padding:.5rem;font-size:.9rem;cursor:pointer}.status{display:flex;align-items:center;gap:.5rem;font-weight:500}.status-dot{width:8px;height:8px;border-radius:50%}.status.active{color:#27ae60}.status.active .status-dot{background:#27ae60}.status.inactive{color:#e74c3c}.status.inactive .status-dot{background:#e74c3c}.user-actions{display:flex;gap:.5rem}.action-btn{padding:.25rem .75rem;border:none;border-radius:4px;font-size:.8rem;cursor:pointer;transition:all .2s ease}.action-btn.edit{background:#3498db;color:#fff}.action-btn.edit:hover{background:#2980b9}.action-btn.disable{background:#e74c3c;color:#fff}.action-btn.disable:hover{background:#c0392b}.action-btn.enable{background:#27ae60;color:#fff}.action-btn.enable:hover{background:#229954}.permissions-table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 10px #0000001a}.permissions-table{width:100%;border-collapse:collapse}.permissions-table th{background:#f8f9fa;padding:1rem;text-align:left;font-weight:600;color:#2c3e50;border-bottom:2px solid #ecf0f1}.permissions-table td{padding:1rem;border-bottom:1px solid #ecf0f1;vertical-align:middle}.permissions-table tr:hover{background:#f8f9fa}.permissions-table .permission-name{font-weight:500;color:#2c3e50}.module-tag{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.8rem;font-weight:500}.permission-actions{display:flex;gap:.5rem}.action-btn.delete{background:#e74c3c;color:#fff}.action-btn.delete:hover{background:#c0392b}@media (max-width: 1200px){.roles-grid,.permissions-grid{grid-template-columns:1fr}}@media (max-width: 768px){.permission-management{padding:1rem}.permission-tabs{flex-direction:column}.tab-btn{text-align:left;border-bottom:1px solid #ecf0f1}.tab-btn.active{border-bottom-color:#3498db}.section-header{flex-direction:column;align-items:flex-start;gap:1rem}.users-table-container,.permissions-table-container{overflow-x:auto}.users-table,.permissions-table{min-width:600px}}.settings{padding:2rem;max-width:1000px}.settings-header{margin-bottom:2rem}.settings-header h2{font-size:1.8rem;color:#2c3e50;margin-bottom:.5rem}.settings-header p{color:#7f8c8d;font-size:1rem}.settings-content{display:flex;flex-direction:column;gap:2rem}.settings-section{background:#fff;border-radius:12px;padding:2rem;border:1px solid #e1e4e8}.settings-section h3{color:#2c3e50;font-size:1.3rem;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:2px solid #ecf0f1}.setting-item{display:flex;align-items:center;margin-bottom:1.5rem;gap:1rem}.setting-item:last-child{margin-bottom:0}.setting-item label{min-width:150px;color:#2c3e50;font-weight:500;font-size:.9rem}.setting-item input[type=text],.setting-item input[type=email],.setting-item input[type=number]{flex:1;padding:.75rem;border:2px solid #e1e4e8;border-radius:8px;font-size:.9rem;transition:border-color .3s ease}.setting-item input:focus{outline:none;border-color:#3498db}.unit{color:#7f8c8d;font-size:.8rem;min-width:30px}.checkbox-item{align-items:center}.checkbox-item input[type=checkbox]{width:18px;height:18px;margin-right:.5rem;accent-color:#3498db}.checkbox-item label{cursor:pointer;min-width:auto;flex:1}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.info-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f8f9fa;border-radius:8px;border-left:4px solid #3498db}.info-label{color:#7f8c8d;font-size:.9rem}.info-value{font-weight:600;color:#2c3e50}.info-value.status-online{color:#27ae60}.settings-actions{display:flex;gap:1rem;justify-content:flex-end;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a}.btn-primary{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;padding:.75rem 2rem;border-radius:8px;font-weight:500;cursor:pointer;transition:transform .2s ease}.btn-primary:hover{transform:translateY(-1px)}.btn-secondary{background:#ecf0f1;color:#2c3e50;border:none;padding:.75rem 2rem;border-radius:8px;font-weight:500;cursor:pointer;transition:background .2s ease}.btn-secondary:hover{background:#d5dbdb}.btn-danger{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff;border:none;padding:.75rem 2rem;border-radius:8px;font-weight:500;cursor:pointer;transition:transform .2s ease}.btn-danger:hover{transform:translateY(-1px)}@media (max-width: 768px){.settings{padding:1rem}.settings-section{padding:1.5rem}.setting-item{flex-direction:column;align-items:flex-start;gap:.5rem}.setting-item label{min-width:auto}.checkbox-item{flex-direction:row;align-items:center}.info-grid{grid-template-columns:1fr}.settings-actions{flex-direction:column}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#2c3e50;background-color:#f5f6fa;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:#f5f6fa;overflow-x:hidden}#root{width:100%;min-height:100vh}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media (max-width: 768px){body{font-size:14px}}
