body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}.app-header{background-color:#d5e4d2;box-shadow:0 2px 4px #0000001a;justify-content:space-between;position:-webkit-sticky;position:sticky;top:0;z-index:100}.add-button,.app-header,.menu-button{align-items:center;color:#2d3748;display:flex}.add-button,.menu-button{background:none;border:none;border-radius:4px;cursor:pointer;font-size:24px;justify-content:center;padding:4px 8px;transition:background-color .2s}.add-button:hover,.menu-button:hover{background-color:#0000000d}.app-title{align-items:center;display:flex;flex:1 1;font-size:20px;font-weight:500;gap:8px;justify-content:center;margin:0;text-align:center}.app-logo{height:42px;width:auto}.header-right{align-items:center;display:flex;gap:12px}.add-icon,.hamburger-icon{font-size:28px}.add-icon{font-weight:700}.help-overlay{align-items:center;background-color:#00000080;box-sizing:border-box;display:flex;height:100%;justify-content:center;left:0;padding:20px;position:fixed;top:0;width:100%;z-index:1000}.help-content{background:#fff;border-radius:12px;box-shadow:0 10px 25px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:800px;width:100%}.help-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #e0e0e0;border-radius:12px 12px 0 0;color:#fff;display:flex;justify-content:space-between;padding:20px 30px}.help-header h2{font-size:1.5rem;font-weight:600;margin:0}.help-close{align-items:center;background:none;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.8rem;height:32px;justify-content:center;padding:0;transition:background-color .2s;width:32px}.help-close:hover{background-color:#fff3}.help-body{flex:1 1;overflow-y:auto;padding:20px 30px 30px}.help-section{margin-bottom:2rem}.help-section:last-child{margin-bottom:0}.help-section h3{border-bottom:2px solid #667eea;color:#333;font-size:1.3rem;margin-bottom:1rem;padding-bottom:.5rem}.help-section p{color:#666;line-height:1.6;margin-bottom:1rem}.help-item{margin-bottom:1.5rem}.help-item:last-child{margin-bottom:0}.help-item h4{color:#444;font-size:1.1rem;font-weight:600}.help-item h4,.help-item p{margin-bottom:.5rem}.help-item ul{color:#666;margin:.5rem 0;padding-left:1.5rem}.help-item li{line-height:1.5;margin-bottom:.3rem}.help-section ul{color:#666;margin:1rem 0;padding-left:1.5rem}.help-section li{line-height:1.6;margin-bottom:.5rem}.help-section strong{color:#333;font-weight:600}@media (max-width:768px){.help-overlay{padding:10px}.help-content{max-height:95vh}.help-header{padding:15px 20px}.help-header h2{font-size:1.3rem}.help-body{padding:15px 20px 20px}.help-section h3{font-size:1.2rem}.help-item h4{font-size:1rem}}.help-body::-webkit-scrollbar{width:6px}.help-body::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.help-body::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.help-body::-webkit-scrollbar-thumb:hover{background:#a1a1a1}.settings-overlay{align-items:center;background-color:#00000080;box-sizing:border-box;display:flex;height:100%;justify-content:center;left:0;padding:20px;position:fixed;top:0;width:100%;z-index:1000}.settings-content{background:#fff;border-radius:12px;box-shadow:0 10px 25px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:600px;width:100%}.settings-header{align-items:center;background:linear-gradient(135deg,#4caf50,#45a049);border-bottom:1px solid #e0e0e0;border-radius:12px 12px 0 0;color:#fff;display:flex;justify-content:space-between;padding:20px 30px}.settings-header h2{font-size:1.5rem;font-weight:600;margin:0}.settings-close{align-items:center;background:none;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.8rem;height:32px;justify-content:center;padding:0;transition:background-color .2s;width:32px}.settings-close:hover{background-color:#fff3}.settings-body{flex:1 1;overflow-y:auto;padding:20px 30px 30px}.settings-section{margin-bottom:2rem}.settings-section:last-child{margin-bottom:0}.settings-section h3{border-bottom:2px solid #4caf50;color:#333;font-size:1.2rem;margin-bottom:1rem;padding-bottom:.5rem}.settings-item{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:15px 0}.settings-item:last-child{border-bottom:none}.settings-item.danger{background-color:#fef9f9;border-left:3px solid #f44336;margin-left:-15px;padding-left:15px}.settings-item-info{flex:1 1}.settings-item-info h4{color:#333;font-size:1rem;font-weight:600;margin:0 0 5px}.settings-item-info p{color:#666;font-size:.9rem;line-height:1.4;margin:0}.settings-button{border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 16px;transition:all .2s;white-space:nowrap}.settings-button.primary{background-color:#4caf50;color:#fff}.settings-button.primary:hover{background-color:#45a049}.settings-button.danger{background-color:#f44336;color:#fff}.settings-button.danger:hover{background-color:#da190b}.settings-select{background-color:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:.9rem;min-width:150px;padding:8px 12px;transition:all .2s}.settings-select:hover{border-color:#4caf50}.settings-select:focus{border-color:#4caf50;box-shadow:0 0 0 2px #4caf5033;outline:none}.export-status{border-radius:6px;font-size:.9rem;margin-top:10px;padding:8px 12px;text-align:center}.export-status.success{background-color:#e8f5e8;border:1px solid #4caf50;color:#4caf50}.export-status.error{background-color:#fef2f2;border:1px solid #f44336;color:#f44336}@media (max-width:768px){.settings-overlay{padding:10px}.settings-content{max-height:95vh}.settings-header{padding:15px 20px}.settings-header h2{font-size:1.3rem}.settings-body{padding:15px 20px 20px}.settings-item{align-items:flex-start;flex-direction:column;gap:10px}.settings-button,.toggle-switch{align-self:flex-end}}.settings-body::-webkit-scrollbar{width:6px}.settings-body::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.settings-body::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.settings-body::-webkit-scrollbar-thumb:hover{background:#a1a1a1}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:16px;position:fixed;right:0;top:0;z-index:300}.modal-content{background-color:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px}.modal-header h2{color:#333;font-size:20px;margin:0}.modal-close{align-items:center;background:none;border:none;color:#666;cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;padding:0;width:32px}.habit-form{padding:20px}.form-group{margin-bottom:20px}.form-group label{color:#333;display:block;font-weight:500;margin-bottom:8px}.form-group input[type=email],.form-group input[type=password],.form-group input[type=text],.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:4px;font-size:16px;padding:10px;width:100%}.form-group textarea{resize:vertical}.color-selector,.emoji-selector{display:flex;flex-wrap:wrap;gap:8px}.color-btn,.color-option,.emoji-btn,.emoji-option{border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;height:40px;transition:all .2s;width:40px}.emoji-btn,.emoji-option{background:#fff;font-size:20px}.color-btn.selected,.color-option.selected,.emoji-btn.selected,.emoji-option.selected{border-color:#4caf50;transform:scale(1.1)}.weekday-selector,.weekdays-selector{display:flex;flex-wrap:wrap;gap:4px}.weekday-btn,.weekday-option{background:#fff;border:2px solid #e0e0e0;border-radius:4px;cursor:pointer;flex:1 1;min-width:40px;padding:8px 4px;transition:all .2s}.weekday-btn.active,.weekday-option.checked{background-color:#4caf50;border-color:#4caf50;color:#fff}.weekday-option input[type=checkbox]{display:none}.weekday-option span{display:block;font-size:14px;font-weight:500;text-align:center}.radio-group{align-items:center;display:flex;flex-direction:row;gap:20px}.radio-group label{align-items:center;cursor:pointer;display:flex;font-weight:400;margin-bottom:0}.radio-group input[type=radio]{cursor:pointer;margin-right:6px}.goal-type-toggle{background-color:#f5f5f5;border-radius:8px;display:flex;gap:4px;padding:4px}.goal-type-toggle .toggle-option{background-color:initial;border:none;border-radius:6px;color:#666;cursor:pointer;flex:1 1;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease}.goal-type-toggle .toggle-option:hover:not(.active){background-color:#0000000d}.goal-type-toggle .toggle-option.active{background-color:#fff;box-shadow:0 1px 3px #0000001a;color:#4caf50}.weekly-goal{background-color:#f5f5f5;border-radius:4px;margin-top:12px;padding:12px}.weekday-goal-input{align-items:center;display:flex;gap:8px}.weekday-goal-input input[type=number]{text-align:center;width:60px}.weekday-goal-input input[type=number],.weekday-goal-input select{border:1px solid #ddd;border-radius:4px;font-size:16px;padding:8px}.weekday-goal-input select{width:120px}.goal-suffix{color:#666;font-size:14px}.goal-help{color:#666;font-size:12px;line-height:1.4;margin-top:8px}.form-actions{border-top:1px solid #e0e0e0;display:flex;gap:12px;justify-content:flex-end;margin:0 -20px -20px;padding:20px}.btn-cancel,.btn-primary{border:none;border-radius:4px;cursor:pointer;font-size:16px;padding:10px 20px;transition:all .2s}.btn-cancel{background-color:#f5f5f5;color:#666}.btn-cancel:hover{background-color:#e0e0e0}.btn-primary{background-color:#4caf50;color:#fff}.btn-primary:hover{background-color:#45a049}.form-hint{color:#666;display:block;font-size:12px;margin-top:4px}.toggle-switch{display:inline-block;height:24px;position:relative;width:50px}.toggle-switch input{height:0;opacity:0;width:0}.toggle-slider{background-color:#ccc;border-radius:24px;bottom:0;cursor:pointer;left:0;position:absolute;right:0;top:0;transition:.3s}.toggle-slider:before{background-color:#fff;border-radius:50%;bottom:3px;box-shadow:0 2px 4px #0003;content:"";height:18px;left:3px;position:absolute;transition:.3s;width:18px}input:checked+.toggle-slider{background-color:#4caf50}input:disabled+.toggle-slider{cursor:not-allowed;opacity:.5}input:checked+.toggle-slider:before{transform:translateX(26px)}.reminder-settings{background-color:#f9f9f9;border-radius:8px;padding:16px}.reminder-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.reminder-label{align-items:center;color:#333;display:flex;font-weight:500;gap:8px;margin:0}.reminder-time-container{align-items:center;animation:slideIn .3s ease;background-color:#fff;border:1px solid #e0e0e0;border-radius:6px;display:flex;gap:12px;margin-top:12px;padding:12px}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.reminder-time-container label{color:#666;font-weight:400;margin:0}.reminder-time-container input[type=time]{border:1px solid #ddd;border-radius:4px;font-size:14px;padding:6px 10px;width:auto}.habit-management-overlay{align-items:center;background-color:#00000080;box-sizing:border-box;display:flex;height:100%;justify-content:center;left:0;padding:20px;position:fixed;top:0;width:100%;z-index:1000}.habit-management-content{background:#fff;border-radius:12px;box-shadow:0 10px 25px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:700px;width:100%}.habit-management-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #e0e0e0;border-radius:12px 12px 0 0;color:#fff;display:flex;justify-content:space-between;padding:20px 30px}.habit-management-header h2{font-size:1.5rem;font-weight:600;margin:0}.habit-management-close{align-items:center;background:none;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.8rem;height:32px;justify-content:center;padding:0;transition:background-color .2s;width:32px}.habit-management-close:hover{background-color:#fff3}.habit-management-body{flex:1 1;overflow-y:auto;padding:20px}.no-habits{color:#666;padding:60px 20px;text-align:center}.no-habits p{font-size:1.1rem;margin:10px 0}.management-instructions{background:#f5f5f5;border-radius:8px;margin-bottom:20px;padding:12px 16px}.management-instructions p{color:#666;font-size:.9rem;margin:0}.habit-list-management{display:flex;flex-direction:column;gap:12px}.habit-item-management{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:10px;cursor:move;display:flex;gap:16px;padding:16px;transition:all .2s}.habit-item-management:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea26}.habit-item-management.dragging{background:linear-gradient(135deg,#667eea20,#764ba220);cursor:grabbing!important;opacity:.5;transform:scale(1.02)}.drag-over{background-color:#f0f4f8;border:2px dashed #667eea}.drag-handle{color:#999;cursor:grab;font-size:20px;margin-right:10px;-webkit-user-select:none;user-select:none}.drag-handle:active{cursor:grabbing}.habit-drag-handle{color:#999;cursor:grab;font-size:1.2rem;-webkit-user-select:none;user-select:none}.habit-drag-handle:active{cursor:grabbing}.habit-info{gap:12px}.habit-icon{flex-shrink:0;font-size:1.5rem}.habit-name{font-size:1.1rem;font-weight:600;margin-right:auto}.habit-details{align-items:center;display:flex;gap:10px}.habit-detail{background:#f0f0f0;border-radius:12px;color:#666;font-size:.85rem;padding:4px 10px}.habit-color-preview{border:2px solid #fff;border-radius:50%;box-shadow:0 0 0 1px #e0e0e0;height:24px;width:24px}.habit-weekdays{align-items:center;display:flex;gap:4px}.weekday-indicator{align-items:center;border-radius:4px;display:flex;font-size:.75rem;font-weight:500;height:24px;justify-content:center;transition:all .2s;width:24px}.weekday-indicator.active{background-color:#4caf50;color:#fff}.weekday-indicator.inactive{background-color:#e0e0e0;color:#999}.habit-actions{gap:8px}.action-btn{align-items:center;background:none;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:1.2rem;height:36px;justify-content:center;transition:all .2s;width:36px}.action-btn:hover{transform:scale(1.1)}.action-btn.edit{background:#e3f2fd}.action-btn.edit:hover{background:#2196f3}.action-btn.archive{background:#fff3e0}.action-btn.archive:hover{background:#ff9800}.action-btn.delete{background:#ffebee}.action-btn.delete:hover{background:#f44336}@media (max-width:768px){.habit-management-overlay{padding:10px}.habit-management-content{max-height:95vh}.habit-info{flex-wrap:wrap;gap:8px}.habit-name{min-width:150px}.habit-item-management{align-items:stretch;flex-direction:column}.habit-actions{justify-content:flex-end;margin-top:10px}}.habit-management-body::-webkit-scrollbar{width:6px}.habit-management-body::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.habit-management-body::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.habit-management-body::-webkit-scrollbar-thumb:hover{background:#a1a1a1}.archive-toggle{background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;gap:10px;padding:15px 30px}.archive-toggle-btn{background:#fff;border:2px solid #e0e0e0;border-radius:8px;color:#666;cursor:pointer;flex:1 1;font-size:1rem;padding:10px 20px;transition:all .3s ease}.archive-toggle-btn:hover{background:#f0f0f0;transform:translateY(-1px)}.archive-toggle-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;color:#fff;font-weight:600}.action-btn.restore{background:linear-gradient(135deg,#4caf50,#45a049)}.action-btn.restore:hover{box-shadow:0 4px 8px #4caf504d;transform:scale(1.1)}.badge-gallery-overlay{align-items:center;animation:fadeIn .3s ease-out;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.badge-gallery-container{animation:slideUp .3s ease-out;background:#fff;border-radius:20px;box-shadow:0 10px 40px #0003;max-height:90vh;max-width:1200px;overflow-y:auto;width:90%}.badge-gallery-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:2px solid #f0f0f0;border-radius:20px 20px 0 0;color:#fff;display:flex;justify-content:space-between;padding:20px 30px}.badge-gallery-header h2{font-size:28px;font-weight:700;margin:0}.badge-gallery-close{background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:24px;height:40px;transition:all .3s ease;width:40px}.badge-gallery-close:hover{background:#ffffff4d;transform:rotate(90deg)}.badge-stats-summary{grid-gap:20px;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));padding:30px}.stat-card{background:#fff;border-radius:15px;box-shadow:0 5px 15px #0000001a;padding:20px;text-align:center;transition:transform .3s ease}.stat-card:hover{transform:translateY(-5px)}.stat-value{color:#667eea;font-size:32px;font-weight:700;margin-bottom:5px}.stat-label{color:#666;font-size:14px}.badge-category-filter{background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;flex-wrap:wrap;gap:10px;justify-content:center;padding:20px}.filter-btn{background:#fff;border:2px solid #667eea;border-radius:20px;color:#667eea;cursor:pointer;font-weight:600;padding:8px 20px;transition:all .3s ease}.filter-btn:hover{background:#f0f0ff}.filter-btn.active{background:#667eea;color:#fff}.badge-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));padding:30px}.badge-card{background:#fff;border:2px solid #0000;border-radius:15px;box-shadow:0 5px 20px #0000001a;padding:20px;transition:all .3s ease}.badge-card.unlocked{background:linear-gradient(135deg,#fff,#fffbf0);border-color:gold}.badge-card.locked{background:#f5f5f5;opacity:.8}.badge-card:hover{box-shadow:0 10px 30px #00000026;transform:translateY(-5px)}.badge-icon-container{align-items:center;display:flex;height:100px;justify-content:center;margin-bottom:15px;position:relative}.badge-icon{font-size:60px;transition:all .3s ease}.badge-icon.shine{animation:iconShine 3s ease-in-out infinite}@keyframes iconShine{0%,to{filter:drop-shadow(0 0 10px rgba(255,215,0,.5));transform:scale(1) rotateY(0deg)}50%{filter:drop-shadow(0 0 20px rgba(255,215,0,.8));transform:scale(1.1) rotateY(1turn)}}.badge-icon.grayscale{filter:grayscale(100%);opacity:.5}.badge-lock-overlay{font-size:30px;opacity:.7;position:absolute}.badge-info{text-align:center}.badge-title{color:#333;font-size:18px;font-weight:700;margin:10px 0}.badge-description{color:#666;font-size:14px;line-height:1.4}.badge-unlocked-date{color:#4caf50;font-size:12px;font-weight:600;margin-top:10px}.badge-progress{margin-top:15px}.progress-bar{background:#e0e0e0;border-radius:4px;height:8px;margin-bottom:8px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:4px;height:100%;transition:width .3s ease}.progress-text{color:#666;font-size:12px;text-align:center}.badge-footer{background:#f8f9fa;border-radius:0 0 20px 20px;border-top:1px solid #e0e0e0;padding:30px}.achievement-summary{background:#fff;border-radius:15px;box-shadow:0 5px 15px #0000001a;padding:25px}.achievement-summary h3{color:#333;font-size:20px;margin:0 0 20px}.achievement-details{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.achievement-item{background:#f8f9fa;border-left:3px solid #667eea;border-radius:10px;display:flex;justify-content:space-between;padding:10px}.achievement-label{color:#666;font-size:14px}.achievement-value{color:#333;font-size:16px;font-weight:700}.badge-gallery-container::-webkit-scrollbar{width:10px}.badge-gallery-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.badge-gallery-container::-webkit-scrollbar-thumb{background:#667eea;border-radius:10px}.badge-gallery-container::-webkit-scrollbar-thumb:hover{background:#764ba2}@media (max-width:768px){.badge-gallery-container{max-height:95vh;width:95%}.badge-grid{gap:15px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));padding:20px}.badge-stats-summary{grid-template-columns:repeat(2,1fr);padding:20px}.stat-value{font-size:24px}.badge-icon{font-size:50px}.badge-title{font-size:16px}.badge-category-filter{padding:15px}.filter-btn{font-size:14px;padding:6px 15px}}.sidebar-overlay{background-color:#00000080;bottom:0;left:0;position:fixed;right:0;top:0;z-index:200}.sidebar{background-color:#fff;box-shadow:2px 0 4px #0000001a;display:flex;flex-direction:column;height:100%;left:-280px;position:fixed;top:0;transition:left .3s ease;width:280px;z-index:201}.sidebar.open{left:0}.sidebar-header{align-items:center;background-color:#d5e4d2;color:#2d3748;display:flex;justify-content:space-between;padding:10px}.sidebar-header h2{font-size:20px;margin:0}.close-btn{align-items:center;background:none;border:none;color:#2d3748;cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;padding:0;width:32px}.sidebar-content{flex:1 1;overflow-y:auto;padding:8px}.menu-section{border-bottom:1px solid #e0e0e0;margin-bottom:16px;padding-bottom:16px}.menu-section:last-child{border-bottom:none}.menu-item{background:none;border:none;border-radius:4px;cursor:pointer;display:block;font-size:16px;padding:12px 16px;text-align:left;transition:background-color .2s;width:100%}.menu-item:hover{background-color:#f5f5f5}.menu-item.premium{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.menu-item.premium:hover{opacity:.9}.sidebar-footer{border-top:1px solid #e0e0e0;padding:16px;text-align:center}.version{color:#999;font-size:12px;margin:0}.badge-menu-item .menu-item-content{align-items:center;display:flex;justify-content:space-between;width:100%}.badge-count{animation:pulseGlow 2s ease-in-out infinite;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;font-size:12px;font-weight:700;min-width:20px;padding:2px 8px;text-align:center}@keyframes pulseGlow{0%,to{box-shadow:0 0 5px #667eea80}50%{box-shadow:0 0 15px #667eeacc}}.week-header{background-color:#fff;border-bottom:1px solid #e0e0e0;display:flex;padding:8px 0;position:-webkit-sticky;position:sticky;top:48px;z-index:90}.week-header-day{flex:1 1;min-width:0;padding:4px;text-align:center}.week-header-day.today{background-color:#e8f5e9;border-radius:4px}.day-label{color:#666;font-size:12px;margin-bottom:2px}.week-header-day.today .day-label{color:#4caf50;font-weight:700}.day-date{color:#333;font-size:16px;font-weight:500}.week-header-day.today .day-date{color:#4caf50;font-weight:700}.badge-unlock-overlay{animation:fadeIn .3s ease-out;background:#000000e6;bottom:0;left:0;position:fixed;right:0;top:0;z-index:10000}.badge-unlock-container,.badge-unlock-overlay{align-items:center;display:flex;justify-content:center}.badge-unlock-container{height:100%;overflow:hidden;position:relative;width:100%}.intro-animation{animation:zoomIn .5s ease-out;left:50%;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%)}@keyframes zoomIn{0%{opacity:0;transform:translate(-50%,-50%) scale(0)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.pulse-ring{animation:pulse 2s ease-out infinite;border:3px solid gold;border-radius:50%;height:300px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:300px}.pulse-ring.delay-1{animation-delay:.5s}.pulse-ring.delay-2{animation-delay:1s}.unlock-text{animation:glow 2s ease-in-out infinite;color:gold;font-size:48px;font-weight:700;margin:0;position:relative;text-shadow:0 0 30px gold,0 0 60px gold;z-index:1}@keyframes glow{0%,to{text-shadow:0 0 30px gold,0 0 60px gold}50%{text-shadow:0 0 40px gold,0 0 80px gold,0 0 100px gold}}.reveal-animation{align-items:center;animation:revealScale .5s ease-out;display:flex;height:100%;justify-content:center;position:relative;width:100%}@keyframes revealScale{0%{opacity:0;transform:scale(.5) rotate(180deg)}to{opacity:1;transform:scale(1) rotate(0deg)}}.badge-glow{animation:glowPulse 2s ease-in-out infinite;background:radial-gradient(circle,#ffd7004d,#0000);border-radius:50%;height:400px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:400px}@keyframes glowPulse{0%,to{opacity:1;transform:translate(-50%,-50%) scale(1)}50%{opacity:.6;transform:translate(-50%,-50%) scale(1.2)}}.badge-container-animated{animation:float 3s ease-in-out infinite;left:50%;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%);z-index:2}@keyframes float{0%,to{transform:translate(-50%,-50%)}50%{transform:translate(-50%,calc(-50% - 10px))}}.badge-icon-large{animation:rotate 3s linear infinite;filter:drop-shadow(0 0 30px rgba(255,215,0,.8));font-size:120px;margin-bottom:20px}@keyframes rotate{0%{transform:rotateY(0deg)}to{transform:rotateY(1turn)}}.badge-name{color:gold;font-size:36px;font-weight:700;margin:10px 0;text-shadow:2px 2px 4px #00000080}.badge-description{color:#fff;font-size:18px;margin:10px 0;text-shadow:1px 1px 2px #00000080}.light-rays{height:100%;transform:translate(-50%,-50%);width:100%}.light-ray,.light-rays{left:50%;position:absolute;top:50%}.light-ray{animation:rayRotate 4s linear infinite;background:linear-gradient(180deg,#0000,gold,#0000);height:500px;opacity:.3;transform-origin:center;width:2px}@keyframes rayRotate{0%{transform:translate(-50%,-50%) rotate(0deg)}to{transform:translate(-50%,-50%) rotate(1turn)}}.light-ray.ray-0{transform:translate(-50%,-50%) rotate(0deg)}.light-ray.ray-1{transform:translate(-50%,-50%) rotate(30deg)}.light-ray.ray-2{transform:translate(-50%,-50%) rotate(60deg)}.light-ray.ray-3{transform:translate(-50%,-50%) rotate(90deg)}.light-ray.ray-4{transform:translate(-50%,-50%) rotate(120deg)}.light-ray.ray-5{transform:translate(-50%,-50%) rotate(150deg)}.light-ray.ray-6{transform:translate(-50%,-50%) rotate(180deg)}.light-ray.ray-7{transform:translate(-50%,-50%) rotate(210deg)}.light-ray.ray-8{transform:translate(-50%,-50%) rotate(240deg)}.light-ray.ray-9{transform:translate(-50%,-50%) rotate(270deg)}.light-ray.ray-10{transform:translate(-50%,-50%) rotate(300deg)}.light-ray.ray-11{transform:translate(-50%,-50%) rotate(330deg)}.celebration-animation{align-items:center;animation:celebrationEntry .5s ease-out;display:flex;flex-direction:column;height:100%;justify-content:center;position:relative;width:100%}@keyframes celebrationEntry{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.fireworks{height:100%;pointer-events:none;position:absolute;width:100%}.firework{animation:firework 3s ease-out infinite;border-radius:50%;height:10px;position:absolute;width:10px}@keyframes firework{0%{opacity:1;transform:translateY(100vh) scale(1)}20%{transform:translateY(-100px) scale(1)}40%{opacity:.8;transform:translateY(-200px) scale(50)}to{opacity:0;transform:translateY(-300px) scale(0)}}.firework-0{animation-delay:0s;background:radial-gradient(circle,gold,#ff6b6b);left:10%}.firework-1{animation-delay:.5s;background:radial-gradient(circle,#4ecdc4,#45b7d1);left:30%}.firework-2{animation-delay:1s;background:radial-gradient(circle,#ffa07a,gold);left:50%}.firework-3{animation-delay:1.5s;background:radial-gradient(circle,#98d8c8,#4ecdc4);left:70%}.firework-4{animation-delay:2s;background:radial-gradient(circle,#ff6b6b,#ffa07a);left:90%}.confetti{height:100%;overflow:hidden;pointer-events:none;position:absolute;width:100%}.confetti-piece{animation:confettiFall 3s linear infinite;height:10px;position:absolute;width:10px}@keyframes confettiFall{0%{opacity:1;transform:translateY(-100vh) rotate(0deg)}to{opacity:0;transform:translateY(100vh) rotate(2turn)}}.achievement-text{animation:bounceIn .5s ease-out;left:50%;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%);z-index:10}@keyframes bounceIn{0%{opacity:0;transform:translate(-50%,-50%) scale(0)}50%{transform:translate(-50%,-50%) scale(1.1)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.achievement-text h1{animation:rainbowText 2s linear infinite;color:#fff;font-size:48px;margin:20px 0;text-shadow:2px 2px 4px #00000080}@keyframes rainbowText{0%{color:#ff6b6b}16%{color:#ffa07a}33%{color:gold}50%{color:#4ecdc4}66%{color:#45b7d1}83%{color:#98d8c8}to{color:#ff6b6b}}.achievement-text p{color:#fff;font-size:24px;margin:10px 0}.badge-final-display{align-items:center;animation:shine 2s linear infinite;background:linear-gradient(135deg,#ffd70033,#ffd7001a);border:2px solid gold;border-radius:20px;display:inline-flex;gap:20px;margin-top:30px;padding:20px 40px}@keyframes shine{0%{box-shadow:0 0 20px #ffd70080}50%{box-shadow:0 0 40px #ffd700cc,0 0 60px #ffd70099}to{box-shadow:0 0 20px #ffd70080}}.badge-icon-final{filter:drop-shadow(0 0 10px rgba(255,215,0,.8));font-size:60px}.badge-name-final{color:gold;font-size:28px;font-weight:700;text-shadow:2px 2px 4px #00000080}.particle-effects{height:100%;overflow:hidden;pointer-events:none;position:absolute;width:100%}.particle{animation:particleFloat 3s ease-in-out infinite;background:gold;border-radius:50%;height:4px;position:absolute;width:4px}@keyframes particleFloat{0%,to{opacity:0;transform:translateY(0) scale(1)}50%{opacity:1;transform:translateY(-100px) scale(1.5)}}@media (max-width:768px){.unlock-text{font-size:32px}.badge-icon-large{font-size:80px}.badge-name{font-size:28px}.achievement-text h1{font-size:32px}.badge-final-display{padding:15px 25px}.badge-icon-final{font-size:40px}.badge-name-final{font-size:20px}}.monthly-view-container{margin:0 auto;max-width:1200px;padding:20px}.monthly-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:16px 20px}.monthly-header h1{color:var(--text-primary);font-size:24px;margin:0}.back-btn{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;padding:8px 16px;transition:all .2s ease}.back-btn:hover{background:var(--bg-hover)}.calendar-container{background:var(--bg-secondary);border-radius:12px;box-shadow:var(--shadow-sm);padding:30px}.calendar-navigation{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.calendar-navigation h2{color:var(--text-primary);font-size:20px;margin:0}.nav-btn{align-items:center;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:50%;cursor:pointer;display:flex;font-size:18px;height:40px;justify-content:center;transition:all .2s ease;width:40px}.nav-btn:hover{background:var(--bg-hover);transform:scale(1.05)}.calendar-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(7,1fr)}.weekdays{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(7,1fr);margin-bottom:10px}.weekday{color:var(--text-secondary);font-size:14px;font-weight:600;padding:10px 0;text-align:center}.days{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(7,1fr)}.day{align-items:center;aspect-ratio:1;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;position:relative;transition:all .2s ease}.day:not(.empty):hover{box-shadow:var(--shadow-md);transform:scale(1.05)}.day.empty{background:#0000;border:none;cursor:default}.day.today{border:2px solid var(--primary-color)}.day.completed{background:#4caf501a;border-color:#4caf50}.day.partial{background:#ffc1071a;border-color:#ffc107}.day.incomplete{background:#f443360d;border-color:#f443364d}.day-number{color:var(--text-primary);font-size:16px;font-weight:500}.day-value{color:var(--text-secondary);font-size:11px;margin-top:4px}.check-mark{color:#4caf50;font-size:14px;font-weight:700;position:absolute;right:5px;top:5px}.calendar-legend{border-top:1px solid var(--border-color);display:flex;gap:30px;justify-content:center;margin-bottom:20px;padding:20px}.legend-item{align-items:center;display:flex;gap:8px}.legend-color{border:1px solid var(--border-color);border-radius:4px;height:20px;width:20px}.legend-color.completed{background:#4caf5033;border-color:#4caf50}.legend-color.partial{background:#ffc10733;border-color:#ffc107}.legend-color.incomplete{background:#f443361a;border-color:#f443364d}.month-stats{border-top:1px solid var(--border-color);padding-top:20px}.month-stats h3{color:var(--text-primary);font-size:18px;margin:0 0 20px}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.month-stats .stat-item{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;display:flex;justify-content:space-between;padding:15px}.month-stats .stat-label{color:var(--text-secondary);font-size:14px}.month-stats .stat-value{color:var(--text-primary);font-size:16px;font-weight:600}.loading{color:var(--text-secondary);padding:40px;text-align:center}.monthly-view-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.monthly-view-modal{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;max-height:90vh;max-width:600px;overflow-y:auto;width:90%}.monthly-title{align-items:center;display:flex;font-size:18px;font-weight:600;gap:8px}.monthly-icon{font-size:24px}.monthly-close{align-items:center;background:none;border:none;border-radius:4px;color:#666;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;padding:0;transition:background-color .2s;width:32px}.monthly-close:hover{background-color:#f0f0f0}.monthly-navigation{align-items:center;display:flex;gap:16px;justify-content:center;padding:16px 20px}.monthly-navigation button{background:none;border:none;border-radius:4px;cursor:pointer;font-size:20px;padding:8px 12px;transition:background-color .2s}.monthly-navigation button:hover{background-color:#e0e0e0}.monthly-navigation h3{font-size:18px;font-weight:600;margin:0;min-width:150px;text-align:center}.monthly-stats{grid-gap:12px;background-color:#fafafa;border-bottom:1px solid #e0e0e0;display:grid;gap:12px;grid-template-columns:repeat(4,1fr)}.monthly-stats .stat-item{align-items:center;display:flex;flex-direction:column;gap:4px}.monthly-stats .stat-label{color:#666;font-size:12px;font-weight:400}.monthly-stats .stat-value{font-size:16px;font-weight:600}.monthly-stats .stat-completed{color:#4caf50}.monthly-stats .stat-skipped{color:#ffa726}.monthly-stats .stat-failed{color:#ef5350}.monthly-calendar{padding:20px}.weekday-headers{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(7,1fr);margin-bottom:8px}.weekday-header{color:#666;font-size:12px;font-weight:600;padding:4px;text-align:center}.calendar-day{align-items:center;aspect-ratio:1;background-color:#fff;border:2px solid #e0e0e0;border-radius:8px;display:flex;flex-direction:column;justify-content:center;min-height:48px;position:relative;transition:all .2s}.calendar-day.clickable{cursor:pointer}.calendar-day.clickable:hover{box-shadow:0 2px 8px #00000026;transform:scale(1.05)}.calendar-day.future{cursor:not-allowed;opacity:.5}.calendar-day.empty{background:none;border:none}.calendar-day.today{border-color:#2196f3;border-width:3px}.day-status{font-size:18px;font-weight:700}.day-completed{color:#fff}.day-skipped{background-color:#fff9c4;border-color:#fbc02d}.day-skipped .day-status{color:#f57c00}.day-failed{background-color:#ffebee;border-color:#f44336}.day-failed .day-status{color:#d32f2f}.day-pending{background-color:#f5f5f5}.day-empty{background-color:#fafafa;border-color:#f0f0f0}@media (max-width:768px){.monthly-view-container{padding:10px}.calendar-container{padding:15px}.day-number{font-size:14px}.day-value{font-size:10px}.weekday{font-size:12px}.days,.weekdays{gap:5px}.calendar-legend{align-items:flex-start;flex-direction:column;gap:10px;padding-left:40px}}@media (max-width:480px){.monthly-view-modal{max-height:95vh;width:95%}.monthly-stats{grid-template-columns:repeat(2,1fr)}.calendar-day{min-height:40px}}.habit-list{background-color:#f5f5f5;padding:8px}.habit-item{background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:12px;overflow:hidden}.habit-header{border-bottom:1px solid #f0f0f0;justify-content:space-between;padding:12px}.habit-header,.habit-info{align-items:center;display:flex}.habit-info{flex:1 1;gap:8px}.habit-actions{align-items:center;display:flex;gap:12px}.monthly-view-btn{background:none;border:none;cursor:pointer;font-size:18px;opacity:.7;padding:4px;transition:opacity .2s,transform .2s}.monthly-view-btn:hover{opacity:1;transform:scale(1.1)}.habit-icon{font-size:20px}.habit-name{color:#333;font-size:16px;font-weight:500}.habit-weekdays-mini{display:flex;gap:2px;margin-left:auto;margin-right:10px}.weekday-mini{align-items:center;border-radius:3px;display:flex;font-size:.7rem;font-weight:500;height:20px;justify-content:center;width:20px}.weekday-mini.active{background-color:#4caf50;color:#fff}.weekday-mini.inactive{background-color:#e0e0e0;color:#999}.habit-streak{color:#666;font-size:14px;font-weight:500;white-space:nowrap}.habit-records{display:flex;gap:4px;padding:8px}.record-cell{align-items:center;aspect-ratio:1;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;display:flex;flex:1 1;font-size:18px;font-weight:700;justify-content:center;min-width:0;transition:all .2s}.record-cell:hover:not(.status-disabled):not(.status-dayoff){box-shadow:0 2px 4px #0000001a;transform:scale(1.05)}.status-pending{background-color:#f5f5f5;border-color:#e0e0e0}.status-empty{background-color:#fff;border-color:#e0e0e0}.status-completed{border-color:#0000;color:#fff}.status-skipped{background-color:#fff9c4;border-color:#fbc02d;color:#f57c00}.status-failed{background-color:#ffebee;border-color:#f44336;color:#d32f2f}.status-disabled{background-color:#fafafa;border-color:#f0f0f0;cursor:not-allowed;opacity:.5}.status-dayoff{background-color:#e0e0e0;border-color:#bdbdbd;color:#999;cursor:not-allowed;opacity:.6}.status-icon{font-size:20px;line-height:1}.weekly-goal-display{align-items:center;display:flex;font-size:14px;gap:8px}.weekly-progress{color:#666}.weekly-streak{animation:fadeIn .3s ease;border-radius:12px;font-size:13px;font-weight:600;padding:2px 8px}.daily-streak-display{align-items:center;display:flex;font-size:14px}.daily-streak{animation:fadeIn .3s ease;border-radius:12px;font-size:13px;font-weight:600;padding:2px 8px}.streak-basic{background-color:#f3f4f6;color:#6b7280}.streak-start{background-color:#d1fae5;color:#10b981}.streak-good{background-color:#fed7aa;color:#f59e0b}.streak-fire{animation:pulse 2s infinite;background-color:#fee2e2;color:#ff6b6b}@keyframes fadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.achievement-overlay{align-items:center;bottom:0;display:flex;justify-content:center;left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:400}.achievement-animation{animation:scaleIn .3s ease-out}.achievement-content{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0003;padding:32px 48px;position:relative;text-align:center}.achievement-icon{animation:bounce .5s ease-out;color:#4caf50;font-size:64px;margin-bottom:16px}.achievement-message{animation:fadeInUp .5s ease-out .2s both;color:#333;font-size:24px;font-weight:700}.achievement-sparkles{bottom:0;left:0;pointer-events:none;position:absolute;right:0;top:0}.sparkle{animation:sparkle 1s ease-out infinite;font-size:24px;position:absolute}.sparkle:first-child{animation-delay:0s;left:20%;top:10%}.sparkle:nth-child(2){animation-delay:.2s;right:20%;top:20%}.sparkle:nth-child(3){animation-delay:.4s;bottom:20%;left:25%}.sparkle:nth-child(4){animation-delay:.6s;bottom:15%;right:25%}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes bounce{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes sparkle{0%{opacity:0;transform:scale(0) rotate(0deg)}50%{opacity:1;transform:scale(1) rotate(180deg)}to{opacity:0;transform:scale(0) rotate(1turn)}}.pwa-install-prompt-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}.pwa-install-prompt{animation:slideUp .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 8px 32px #0003;max-width:400px;padding:24px;position:relative;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.pwa-install-header{align-items:center;display:flex;gap:16px;margin-bottom:20px}.pwa-install-icon{border-radius:12px;box-shadow:0 2px 8px #0000001a;height:64px;width:64px}.pwa-install-title h3{color:#333;font-size:20px;font-weight:600;margin:0}.pwa-install-title p{color:#666;font-size:14px;margin:4px 0 0}.pwa-install-benefits{margin-bottom:24px}.benefit-item{align-items:center;color:#555;display:flex;font-size:14px;gap:12px;margin-bottom:12px}.benefit-item:last-child{margin-bottom:0}.benefit-icon{font-size:18px;text-align:center;width:24px}.pwa-install-actions{display:flex;flex-direction:column;gap:12px}.pwa-install-btn{border:none;border-radius:8px;cursor:pointer;font-size:16px;font-weight:600;outline:none;padding:12px 20px;transition:all .2s ease}.pwa-install-btn.primary{background:#4caf50;color:#fff}.pwa-install-btn.primary:hover{background:#45a049;transform:translateY(-1px)}.pwa-install-btn.secondary{background:#f5f5f5;color:#666}.pwa-install-btn.secondary:hover{background:#e8e8e8}.pwa-install-close{align-items:center;background:#f5f5f5;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:18px;height:32px;justify-content:center;position:absolute;right:16px;top:16px;transition:all .2s ease;width:32px}.pwa-install-close:hover{background:#e8e8e8;transform:scale(1.05)}@media (prefers-color-scheme:dark){.pwa-install-prompt{background:#2d3748;color:#e2e8f0}.pwa-install-title h3{color:#f7fafc}.pwa-install-title p{color:#a0aec0}.benefit-item{color:#cbd5e0}.pwa-install-btn.secondary{background:#4a5568;color:#e2e8f0}.pwa-install-btn.secondary:hover{background:#2d3748}.pwa-install-close{background:#4a5568;color:#e2e8f0}.pwa-install-close:hover{background:#2d3748}}@media (max-width:480px){.pwa-install-prompt-overlay{align-items:flex-end;padding:0}.pwa-install-prompt{border-radius:16px 16px 0 0;margin:0;max-width:none;width:100%}.pwa-install-header{flex-direction:column;text-align:center}.pwa-install-icon{height:80px;width:80px}}.main-view{background-color:#f5f5f5;display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1 1;margin:0 auto;max-width:100%;padding:0;width:100%}.loading{align-items:center;color:#666;display:flex;font-size:18px;justify-content:center;min-height:300px}.empty-state{color:#666;padding:60px 20px;text-align:center}.empty-state p{font-size:16px;margin:10px 0}.empty-state p:first-child{color:#333;font-size:20px;font-weight:700}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App{display:flex;flex-direction:column;min-height:100vh}button{background:none;border:none;cursor:pointer;font-family:inherit}button:focus{outline:2px solid #4caf50;outline-offset:2px}input,textarea{font-family:inherit}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#888;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}