body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{position:relative;text-align:center}.App.dev-mode{background-color:#f8fff8}.dev-banner{background-color:#28a745;color:#fff;font-size:14px;font-weight:700;left:0;padding:5px;position:fixed;right:0;text-align:center;top:0;z-index:1000}.admin-access-button{align-items:center;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:50%;bottom:20px;box-shadow:0 2px 5px #0000001a;cursor:pointer;display:flex;font-size:18px;height:40px;justify-content:center;position:fixed;right:20px;transition:all .2s ease;width:40px;z-index:1000}.admin-access-button:hover{box-shadow:0 4px 8px #00000026;transform:rotate(30deg)}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.leaderboard-container{background-color:#fff;border-radius:16px;box-shadow:0 4px 12px #0000001a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;margin:40px auto;max-width:600px;padding:24px 16px;position:relative}.leaderboard-logo-wrap{margin-bottom:12px;text-align:center}.leaderboard-logo-img{display:inline-block;height:auto;margin-bottom:8px;max-width:260px;width:100%}.leaderboard-subtitle{color:#555;font-size:14px;margin-bottom:16px;margin-top:0}.leaderboard-tabs{display:flex;gap:8px;justify-content:center;margin-bottom:16px}.leaderboard-tabs button{background:#fff;border:1px solid #ddd;border-radius:8px;cursor:pointer;font-size:14px;padding:6px 12px}.leaderboard-tabs .active{background-color:#000b35;border-color:#000b35;color:#fff}.cohort-dates{background-color:#e6f0ff;border-radius:999px;color:#003087;display:inline-block;font-size:14px;font-weight:600;margin:0 auto 16px;padding:6px 14px;text-align:center}body.dark-mode .cohort-dates{background-color:#003087;color:#fff}.leaderboard-list{display:flex;flex-direction:column;gap:12px}.leaderboard-item{align-items:center;background-color:#fafafa;border:1px solid #eee;border-radius:12px;display:flex;flex-wrap:wrap;height:70px;justify-content:space-between;min-height:70px;padding:10px 14px}.leaderboard-left{align-items:center;display:flex;flex:1 1;gap:10px;min-width:50%}.medal{font-size:20px;min-width:24px}.name-container{display:flex;flex-direction:column;margin-left:8px}.name,.name-row{align-items:center;display:flex}.name{font-size:16px;font-weight:600;gap:4px;white-space:nowrap}.streak-wrapper{margin-left:2px;margin-top:4px}.milestone-wrapper{margin-left:2px;margin-top:6px}.status-circle{animation:pulse 1.6s infinite;background-color:#2ecc71;border-radius:50%;box-shadow:0 0 0 #2ecc7166;display:inline-block;height:8px;margin-left:2px;width:8px}@keyframes pulse{0%{box-shadow:0 0 0 0 #2ecc7166;transform:scale(1)}70%{box-shadow:0 0 0 6px #2ecc7100;transform:scale(1.2)}to{box-shadow:0 0 0 0 #2ecc7100;transform:scale(1)}}.leaderboard-right{align-items:flex-end;color:#555;display:flex;flex:1 1;flex-direction:column;font-size:14px;gap:4px;min-width:50%;text-align:right}.steps{font-size:15px;font-weight:500}.challenges{color:#777;font-size:12px}.dark-toggle-btn{background:#0000;border:none;color:inherit;cursor:pointer;font-size:22px;position:absolute;right:16px;top:16px;z-index:100}@media (max-width:480px){.leaderboard-logo-img{margin-bottom:6px;max-width:200px}.leaderboard-item{align-items:center;flex-direction:row;gap:6px;padding:8px 10px}.name{flex:1 1;font-size:15px;text-align:left}.name,.steps{align-items:center;display:flex}.steps{font-size:14px}.challenges{font-size:11px}.challenges,.leaderboard-left{align-items:center;display:flex}.leaderboard-left{flex:1 1;gap:10px}.leaderboard-right{align-items:flex-end;color:#555;display:flex;flex:1 1;flex-direction:column;font-size:14px;gap:4px;justify-content:center;text-align:right}.dark-toggle-btn{right:12px;top:12px}}body.dark-mode{background-color:#111;color:#fff}body.dark-mode .leaderboard-container{background-color:#1e1e1e;box-shadow:none}body.dark-mode .leaderboard-item{background-color:#2a2a2a;border-color:#444}body.dark-mode .challenges,body.dark-mode .leaderboard-right,body.dark-mode .rank-label,body.dark-mode .steps{color:#ccc}body.dark-mode .leaderboard-subtitle{color:#aaa}body.dark-mode .leaderboard-tabs button{background-color:#222;border-color:#444;color:#eee}.admin-button-container{display:flex;justify-content:center;margin-top:24px;width:100%}.modern-admin-button{align-items:center;background-color:#000b35;border:none;border-radius:8px;box-shadow:0 2px 8px #000b3533;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;justify-content:center;margin:0;padding:10px 16px;transition:all .2s ease}.modern-admin-button:hover{background-color:#001a66;box-shadow:0 4px 12px #000b354d;transform:translateY(-2px)}.modern-admin-button:active{box-shadow:0 2px 4px #000b3533;transform:translateY(0)}.admin-button-icon{align-items:center;display:flex;justify-content:center}.admin-button-text{font-weight:500;letter-spacing:.5px}body.dark-mode .modern-admin-button{background-color:#2a2a2a;box-shadow:0 2px 8px #0000004d}body.dark-mode .modern-admin-button:hover{background-color:#3a3a3a;box-shadow:0 4px 12px #0006}body.dark-mode .leaderboard-tabs .active{background-color:#00b894;border-color:#00b894;color:#fff}.profit-loss-badge{align-items:center;border-radius:4px;display:inline-flex;font-size:.85rem;font-weight:600;margin-left:8px;padding:2px 6px}.profit-loss-badge .arrow-icon{font-size:.9em;margin-right:4px}.profit-loss-positive{background-color:#159f56}.profit-loss-negative{background-color:#d94242}.profit-loss-neutral{background-color:#999}.arrow-up{color:#8df096}.arrow-down{color:#f18b8b}.rank-label{margin-right:6px}.leaderboard-right .challenges,.leaderboard-right .steps,.rank-label{color:#000;font-weight:700}.profit-loss-badge{color:#fff;font-weight:700}.all-time-stats{display:flex;gap:8px;justify-content:center;margin-bottom:20px}.total-steps-box{align-items:center;background-color:#e6f0ff;border-radius:12px;box-shadow:0 2px 8px #0000000d;color:#003087;display:flex;flex-direction:column;margin-bottom:24px;padding:24px 16px 16px;text-align:center}.total-steps-number{font-size:36px;font-weight:700;margin-bottom:12px}.total-steps-label{font-size:14px;font-weight:500;margin-top:auto;opacity:.8}body.dark-mode .total-steps-box{background-color:#003087;color:#fff}body.dark-mode .total-steps-label{color:#fff}.how-it-works-link{background:none;border:none;color:#003087;cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;letter-spacing:.2px;margin:0;padding:0;position:relative;text-decoration:none;transition:all .3s ease}.how-it-works-link:after{background:#003087;bottom:-2px;content:"";height:1px;left:0;position:absolute;transition:width .3s ease;width:0}.how-it-works-link:hover{color:#000b35}.how-it-works-link:hover:after{width:100%}body.dark-mode .how-it-works-link{color:#ffffffb3}body.dark-mode .how-it-works-link:hover{color:#fff}body.dark-mode .how-it-works-link:after{background:#fff9}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background-color:#fff;border-radius:12px;box-shadow:0 10px 25px #0003;margin:0 20px;max-height:80vh;max-width:500px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:center;padding:20px 24px 16px;position:relative}.modal-header h3{color:#333;font-size:20px;font-weight:600;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:24px;height:30px;justify-content:center;padding:0;position:absolute;right:24px;top:20px;width:30px}.modal-close:hover{background-color:#f5f5f5;color:#333}.modal-body{padding:20px 24px 24px}.instruction-section{margin-bottom:20px}.instruction-section:last-child{margin-bottom:0}.instruction-section h4{color:#333;font-size:16px;font-weight:600;margin:0 0 8px}.instruction-section p{color:#555;font-size:14px;line-height:1.5;margin:0 0 8px}.instruction-section ul{margin:8px 0 0;padding-left:20px}.instruction-section li{color:#555;font-size:14px;line-height:1.5;margin-bottom:4px}body.dark-mode .modal-content{background-color:#1e1e1e}body.dark-mode .modal-header{border-bottom-color:#444}body.dark-mode .modal-header h3{color:#fff}body.dark-mode .modal-close{color:#ccc}body.dark-mode .modal-close:hover{background-color:#333;color:#fff}body.dark-mode .instruction-section h4{color:#fff}body.dark-mode .instruction-section li,body.dark-mode .instruction-section p{color:#ccc}.btn{align-items:center;background:#fff;border:1px solid #ddd;border-radius:8px;display:inline-flex;font-size:14px;font-weight:500;justify-content:center;padding:6px 12px;text-decoration:none;transition:all .2s ease}.btn-primary{border-color:#000b35}.btn-primary:hover{border-color:#001a66;color:#fff;text-decoration:none}body.dark-mode .btn{background-color:#222;border-color:#444;color:#eee}body.dark-mode .btn-primary{background-color:#00b894;border-color:#00b894;color:#fff}body.dark-mode .btn-primary:hover{background-color:#00a085;border-color:#00a085}@media (max-width:480px){.btn{box-sizing:border-box;display:inline-block;font-size:12px;max-width:calc(100% - 20px);overflow:hidden;padding:8px 12px;text-overflow:ellipsis;white-space:nowrap;width:auto}.modal-body{padding:16px 15px 20px}.modal-content{margin:0 15px;width:calc(100% - 30px)}}.admin-container{margin:0 auto;max-width:100%;padding:20px}.admin-title{color:#333;font-size:24px;margin-bottom:24px}.section-title{color:#333;font-size:20px;margin:24px 0 16px}.form-group{margin-bottom:16px}.form-group label{display:block;font-weight:500;margin-bottom:8px}.form-control{border:1px solid #ccc;border-radius:4px;font-size:16px;padding:8px 12px;transition:border-color .2s;width:100%}.form-control:focus{border-color:#4a90e2;outline:none}input[type=checkbox].form-checkbox{height:18px;width:18px}.date-controls{align-items:flex-end;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px}.date-controls .form-group{flex:1 1;min-width:200px}.btn{border:none;border-radius:4px;cursor:pointer;font-size:16px;padding:8px 16px;transition:background-color .2s,transform .1s}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(1px)}.btn-primary{background-color:#000b35;color:#fff}.btn-primary:hover{background-color:#001a66}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#5a6268}.btn-success{background-color:#007d16;color:#fff}.btn-success:hover{background-color:#00661a}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover{background-color:#c82333}.btn-icon,.btn-sm{font-size:14px;padding:4px 8px}.table-responsive{margin-bottom:24px;overflow-x:auto}.admin-table{border-collapse:collapse;margin-bottom:16px;width:100%}.admin-table td,.admin-table th{border-bottom:1px solid #ddd;padding:12px 8px}.admin-table th{background-color:#f8f9fa;font-weight:600;text-align:left}.admin-table tr:hover{background-color:#f5f5f5}.text-center{text-align:center}.action-buttons{display:flex;gap:12px;margin-bottom:24px}.add-user-section{background-color:#f8f9fa;border-radius:8px;margin-top:32px;padding:20px}.admin-environment-switcher{position:absolute;right:20px;top:20px;z-index:100}.admin-environment-indicator{background-color:#28a745;border-radius:4px;color:#fff;display:inline-block;font-weight:700;margin-bottom:10px;padding:5px 10px}.form-container{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}@media (max-width:768px){.admin-container{padding:16px}.date-controls{align-items:stretch;flex-direction:column}.form-container{grid-template-columns:1fr}.admin-table td,.admin-table th{font-size:14px;padding:8px 4px}.form-control{font-size:14px}.btn{margin-bottom:8px;width:100%}.action-buttons{flex-direction:column}}.data-sync-container{bottom:80px;position:fixed;right:20px;z-index:1000}.data-sync-button{background-color:#6c5ce7;border:none;border-radius:4px;box-shadow:0 2px 5px #0003;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease}.data-sync-button:hover{background-color:#5649c0;box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.data-sync-button:disabled{background-color:#a29bfe;cursor:not-allowed;transform:none}.sync-progress-modal{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1100}.sync-progress-content{background-color:#fff;border-radius:8px;display:flex;flex-direction:column;max-height:80vh;max-width:500px;padding:20px;width:90%}.sync-progress-content h3{color:#333;margin-bottom:16px;margin-top:0}.sync-progress-log{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;font-family:monospace;font-size:14px;margin-bottom:16px;max-height:300px;overflow-y:auto;padding:12px}.sync-progress-log p{line-height:1.4;margin:6px 0}.sync-progress-log p.success{color:#28a745;font-weight:700}.sync-progress-log p.error{color:#dc3545;font-weight:700}.sync-progress-log p.warning{color:#ffc107;font-weight:700}.sync-progress-log p.collection{color:#6610f2}.sync-progress-actions{display:flex;gap:10px;justify-content:flex-end}.close-progress-button{background-color:#6c757d}.close-progress-button,.sync-save-button{border:none;border-radius:4px;color:#fff;cursor:pointer;padding:8px 16px}.sync-save-button{background-color:#17a2b8}.close-progress-button:disabled,.sync-save-button:disabled{cursor:not-allowed;opacity:.7}@media (max-width:768px){.data-sync-container{bottom:70px;right:10px}.sync-progress-content{padding:15px;width:95%}.sync-progress-log{max-height:200px}}.environment-switcher{align-items:center;border-radius:8px;bottom:20px;box-shadow:0 2px 10px #0003;display:flex;flex-direction:column;padding:10px;position:fixed;right:20px;transition:all .3s ease;z-index:1000}.environment-switcher.production{background-color:#dc3545e6}.environment-switcher.development{background-color:#28a745e6}.environment-indicator{color:#fff;font-size:14px;font-weight:700;margin-bottom:8px}.environment-switch-button{background-color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:all .2s ease}.production .environment-switch-button{color:#dc3545}.development .environment-switch-button{color:#28a745}.environment-switch-button:hover{box-shadow:0 2px 5px #0000001a;transform:translateY(-2px)}.environment-switcher-minimal{bottom:20px;position:fixed;right:20px;z-index:1000}.environment-switch-button-minimal{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;box-shadow:0 2px 5px #0000001a;color:#6c757d;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:all .2s ease}.environment-switch-button-minimal:hover{background-color:#e9ecef;box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}@media (max-width:768px){.environment-switcher,.environment-switcher-minimal{bottom:10px;right:10px}}.streak-container{display:flex;gap:3px;margin-top:2px}.streak-dot{border-radius:50%;display:inline-block;height:6px;transition:transform .2s ease;width:6px}.streak-dot:hover{transform:scale(1.3)}.streak-completed{background-color:#2ecc71}.streak-missed{background-color:#e74c3c}body.dark-mode .streak-completed{background-color:#00b894}body.dark-mode .streak-missed{background-color:#d63031}@media (max-width:480px){.streak-container{gap:2px}.streak-dot{height:6px;width:6px}}.milestone-container{display:inline-flex;gap:4px;margin-left:8px}.milestone-badge{align-items:center;border:1px solid #fff3;border-radius:4px;box-shadow:0 1px 3px #00000026,inset 0 1px 0 #fff3;color:#fff;display:inline-flex;font-size:.75rem;font-weight:700;letter-spacing:.3px;overflow:hidden;padding:2px 5px;position:relative;text-transform:uppercase;transition:transform .2s ease,box-shadow .2s ease}.milestone-badge:hover{box-shadow:0 3px 6px #0003,inset 0 1px 0 #ffffff4d;transform:translateY(-1px)}.milestone-badge:before{animation:shimmer 3s infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%}@keyframes shimmer{0%{left:-100%}50%{left:-100%}to{left:100%}}.milestone-500k{background:linear-gradient(135deg,#d4af37,#b8860b)}.milestone-1m{background:linear-gradient(135deg,gold,#daa520)}body.dark-mode .milestone-500k{background:linear-gradient(135deg,#b8860b,#9a7209)}body.dark-mode .milestone-1m{background:linear-gradient(135deg,#daa520,#b8860b)}@media (max-width:480px){.milestone-badge{font-size:9px;padding:1px 4px}}
/*# sourceMappingURL=main.a5231c7a.css.map*/