*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);font-family:Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-box{animation:slideIn .5s ease-out;background:#fff;border-radius:15px;box-shadow:0 20px 60px #0000004d;max-width:400px;padding:40px;width:100%}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.login-box h1{color:#333;font-size:28px;margin-bottom:10px;text-align:center}.subtitle{color:#666;font-size:14px;margin-bottom:30px;text-align:center}.form-group{margin-bottom:20px}.form-group label{color:#333;font-weight:500}.form-group input{border:2px solid #e0e0e0;border-radius:8px;font-size:16px;padding:12px;transition:border-color .3s;width:100%}.form-group input:focus{border-color:#667eea;outline:none}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.login-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:10px;padding:14px;transition:transform .2s,box-shadow .2s;width:100%}.login-btn:hover:not(:disabled){box-shadow:0 5px 20px #667eea66;transform:translateY(-2px)}.login-btn:disabled{cursor:not-allowed;opacity:.6}.error-message{margin-bottom:15px;padding:12px}.login-info{border-top:1px solid #e0e0e0;color:#666;font-size:13px;margin-top:25px;padding-top:25px;text-align:center}.login-info p{margin:5px 0}.login-info code{background-color:#f0f0f0;border-radius:4px;color:#333;font-weight:600;padding:2px 6px}.dashboard-container{background:#f5f7fa;min-height:100vh;padding:20px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.filters{margin-bottom:20px}.filter-select{border:2px solid #e0e0e0;padding:10px}.error-message{background-color:#fee;color:#c33;margin:20px 0;text-align:center}@media (max-width:1024px){.dashboard-container{padding:15px}.stats-grid{gap:15px}.filters{gap:10px}.filter-select{font-size:13px;padding:8px}}@media (max-width:768px){.dashboard-container{padding:10px}.stats-grid{gap:12px;grid-template-columns:1fr}.filters{flex-direction:column;gap:12px}.btn,.filter-select{font-size:14px;padding:12px;width:100%}}@media (max-width:480px){.dashboard-container{padding:8px}.stats-grid{gap:10px}}.stat-card{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;display:flex;gap:20px;padding:25px}.stat-icon{font-size:40px}.stat-info{flex:1 1}.stat-value{color:#1f2937;font-size:28px;font-weight:700}.stat-label{color:#6b7280;font-size:14px;margin-top:5px}@media (max-width:1024px){.stat-card{gap:15px;padding:20px}.stat-icon{font-size:36px}.stat-value{font-size:24px}}@media (max-width:768px){.stat-card{gap:15px;padding:18px}.stat-icon{font-size:32px}.stat-value{font-size:22px}.stat-label{font-size:13px}}@media (max-width:480px){.stat-card{gap:12px;padding:15px}.stat-icon{font-size:28px}.stat-value{font-size:20px}.stat-label{font-size:12px}}.table-container{overflow-x:auto;padding:0 30px 30px}.users-table{background:#fff;border-collapse:collapse;width:100%}thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}th{font-weight:600;text-align:left}td,th{font-size:14px;padding:15px}td{border-bottom:1px solid #e5e7eb}tbody tr:hover{background:#f9fafb}tbody tr.selected{background:#e0e7ff}.status-badge{border-radius:20px;font-size:12px;font-weight:600;padding:6px 12px;text-transform:uppercase}.status-pending{background:#fef3c7;color:#92400e}.status-paid{background:#d1fae5;color:#065f46}.action-btn{border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:all .3s}.action-btn:hover{box-shadow:0 2px 8px #00000026;transform:translateY(-1px)}.btn-info{background:#3b82f6;color:#fff;margin-right:8px}.actions-cell{align-items:center;display:flex;gap:8px}.reminder-count-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;display:inline-block;font-size:12px;font-weight:600;min-width:24px;padding:4px 8px;text-align:center}input[type=checkbox]{cursor:pointer;height:18px;width:18px}.table-container{width:100%}.mobile-cards{display:none}.desktop-table{display:table;width:100%}@media (max-width:1024px){.table-container{padding:0 15px 20px}table{font-size:13px}td,th{padding:12px}.hide-on-tablet{display:none}}@media (max-width:768px){.desktop-table{display:none}.mobile-cards{display:block;padding:0}.mobile-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:16px;padding:16px;transition:all .3s ease}.mobile-card:hover{box-shadow:0 4px 12px #0000001f;transform:translateY(-2px)}.mobile-card.selected{background:#f0f4ff;border-color:#667eea}.mobile-card-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:12px}.mobile-card-title{color:#111827;font-size:16px;font-weight:600}.mobile-card-row{border-bottom:1px solid #f3f4f6;display:flex;font-size:14px;justify-content:space-between;padding:8px 0}.mobile-card-row:last-child{border-bottom:none}.mobile-card-label{color:#6b7280;font-weight:500}.mobile-card-value{color:#111827;text-align:right}.mobile-card-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}.mobile-card-actions .action-btn{flex:1 1;font-size:13px;min-width:140px;padding:10px}.mobile-card-checkbox{margin-right:12px}}@media (max-width:480px){.mobile-card{padding:12px}.mobile-card-title{font-size:14px}.mobile-card-row{font-size:13px}.mobile-card-actions{flex-direction:column}.mobile-card-actions .action-btn{min-width:0;min-width:auto;width:100%}}.search-box{border:2px solid #e5e7eb;border-radius:8px;flex:1 1;font-size:14px;min-width:250px;padding:12px 15px;transition:all .3s}.search-box:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}@media (max-width:768px){.search-box{font-size:14px;min-width:100%;width:100%}}@media (max-width:480px){.search-box{font-size:13px;padding:10px 12px}}.modal{align-items:center;background:#00000080;display:none;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.modal.active{display:flex}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;width:90%}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:25px}.modal-header h2{color:#1f2937;font-size:20px}.close-btn{background:none;border:none;color:#6b7280;cursor:pointer;font-size:28px;line-height:1}.modal-body{padding:25px}.modal-footer{border-top:1px solid #e5e7eb;display:flex;gap:15px;justify-content:flex-end;padding:25px}.form-group{margin-top:20px}.form-group label{color:#374151;display:block;font-weight:600;margin-bottom:8px}.form-control{border:2px solid #e5e7eb;border-radius:8px;font-family:inherit;font-size:14px;padding:12px;width:100%}.form-control:focus{border-color:#667eea;outline:none}textarea.form-control{resize:vertical}.selected-users-list{background:#f9fafb;border-radius:8px;margin:15px 0;max-height:200px;overflow-y:auto;padding:15px}.selected-users-list ul{list-style:none}.selected-users-list li{border-bottom:1px solid #e5e7eb;padding:8px}@media (max-width:1024px){.modal-content{max-width:600px;width:85%}}@media (max-width:768px){.modal-content{max-height:95vh;max-width:100%;width:95%}.modal-body,.modal-footer,.modal-header{padding:20px}.modal-header h2{font-size:18px}.modal-footer{flex-direction:column-reverse;gap:10px}.modal-footer .btn{padding:12px;width:100%}}@media (max-width:480px){.modal-content{border-radius:0;max-height:100vh;width:100%}.modal-body,.modal-footer,.modal-header{padding:15px}.modal-header h2{font-size:16px}.form-group{margin-top:15px}.form-control{font-size:14px;padding:10px}}.loading{color:#6b7280;padding:40px;text-align:center}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f4f6;border-radius:50%;border-top-color:#667eea;height:40px;margin:0 auto 20px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;padding:30px}.header h1{font-size:28px;font-weight:600}.status-bar{align-items:center;display:flex;gap:15px}.status{background:#fff3;border-radius:20px;font-size:14px;padding:8px 15px}.status.connected{background:#10b98133}.status.loading{background:#fff3}.btn-primary{background:#fff;color:#667eea}.btn:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}@media (max-width:1024px){.header{padding:20px}.header h1{font-size:24px}.status-bar{gap:10px}}@media (max-width:768px){.header{flex-direction:column;gap:15px;padding:20px;text-align:center}.header h1{font-size:22px}.status-bar{flex-direction:column;gap:10px;width:100%}.status{text-align:center;width:100%}.btn{margin-top:10px;width:100%}}@media (max-width:480px){.header{padding:15px}.header h1{font-size:20px}}.App{min-height:100vh;padding:20px}.container{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;margin:0 auto;max-width:1400px;overflow:hidden}.stats-grid{grid-gap:20px;background:#f9fafb;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));padding:30px}.filters{align-items:center;background:#f9fafb;display:flex;flex-wrap:wrap;gap:15px;padding:20px 30px}.filter-select{background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;font-size:14px;padding:12px 15px}.filter-select:focus{border-color:#667eea;outline:none}.btn{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .3s}.btn:hover:not(:disabled){box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.btn-success{background:#10b981;color:#fff}.btn-secondary{background:#6b7280;color:#fff}.error-message{background:#fee2e2;border-left:4px solid #ef4444;border-radius:8px;color:#991b1b;margin:20px 30px;padding:15px}@media (max-width:768px){.stats-grid{grid-template-columns:1fr}.filters{flex-direction:column}.filter-select{width:100%}}
/*# sourceMappingURL=main.d9e1d5c7.css.map*/