*{margin:0;padding:0;box-sizing:border-box}html{overflow-x:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#f0f2f5;color:#333;min-height:100vh;overflow-x:hidden}#root{width:100%;max-width:100%;overflow-x:hidden}.header{text-align:center;margin-bottom:20px}.header h1{font-size:20px;color:#333;margin-bottom:12px}.year-selector{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap}.year-selector button{padding:8px 12px;background:#2196f3;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;display:flex;align-items:center;gap:4px}.year-selector button:active{transform:scale(.95)}.current-year{font-size:18px;font-weight:700;color:#333;padding:0 5px}@media(min-width:768px){.header h1{font-size:26px}.year-selector button{padding:10px 16px;font-size:14px}.current-year{font-size:22px;padding:0 15px}}.month-selector{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:20px}.month-selector button{padding:10px 5px;border:2px solid #e0e0e0;background:#fff;border-radius:6px;cursor:pointer;font-weight:600;font-size:12px;color:#555;transition:all .2s}.month-selector button:active{transform:scale(.95)}.month-selector button.active{background:#4caf50;color:#fff;border-color:#4caf50}@media(min-width:500px){.month-selector{grid-template-columns:repeat(6,1fr)}}@media(min-width:768px){.month-selector{grid-template-columns:repeat(12,1fr);gap:8px}.month-selector button{padding:12px 8px;font-size:13px}}.habit-name{text-align:left!important;font-weight:500;background:#ecf0f1!important;color:#2c3e50;padding:8px 6px!important;font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.habit-name span{cursor:pointer;display:block;overflow:hidden;text-overflow:ellipsis}.edit-input{width:100%;padding:4px;border:2px solid #3498db;border-radius:4px;font-size:12px;color:#333}.day-cell{cursor:pointer;height:32px;transition:background .15s;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.day-cell:active{background:#c8e6c9}.day-cell.completed{background:#4caf50;color:#fff;font-weight:700;font-size:14px}.actions-cell{background:#ecf0f1!important;padding:4px 2px!important}.actions-cell>div{display:flex;gap:2px;justify-content:center}.edit-btn,.delete-btn{padding:4px;border:none;border-radius:4px;cursor:pointer;font-size:12px;background:#fff;min-width:28px;min-height:28px;display:flex;align-items:center;justify-content:center}.edit-btn:active{background:#3498db}.delete-btn:active{background:#e74c3c}@media(min-width:768px){.habit-name{font-size:13px;padding:10px 8px!important}.day-cell{height:36px}.edit-btn,.delete-btn{font-size:14px;min-width:32px;min-height:32px}}.tracker-container{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid #ddd;border-radius:8px;max-width:100%}.tracker{width:100%;border-collapse:collapse;font-size:13px;table-layout:fixed}.tracker th,.tracker td{border:1px solid #e0e0e0;text-align:center;padding:6px 4px;overflow:hidden}.tracker th{background:#2c3e50;color:#fff;font-weight:600;font-size:11px}.habit-column{width:90px;min-width:90px;max-width:90px;text-align:left!important}.tracker th:not(.habit-column):not(.total-column):not(.actions-column),.tracker td:not(.habit-name):not(.total-cell):not(.actions-cell){width:auto;min-width:24px}.total-column{width:45px;min-width:45px;max-width:45px;background:#f39c12!important;color:#fff!important}.total-cell{background:#fef9e7!important;color:#9a7b0a!important;font-weight:700;font-size:12px}.actions-column{width:70px;min-width:70px;max-width:70px}.add-habit-wrapper{padding:15px;background:#f8f9fa;border:1px solid #ddd;border-top:none;border-radius:0 0 8px 8px}.add-habit-container{display:flex;flex-direction:column;gap:10px}.new-habit-input{width:100%;padding:12px;border:2px dashed #4CAF50;border-radius:6px;font-size:16px;color:#333;background:#fff}.new-habit-input::placeholder{color:#888}.new-habit-input:focus{outline:none;border-style:solid;border-color:#4caf50}.add-habit-btn{width:100%;padding:12px;background:#4caf50;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;font-size:14px}.add-habit-btn:disabled{background:#ccc;cursor:not-allowed}@media(min-width:768px){.tracker{font-size:14px}.tracker th{font-size:12px}.habit-column{width:120px;min-width:120px;max-width:120px}.tracker th:not(.habit-column):not(.total-column):not(.actions-column),.tracker td:not(.habit-name):not(.total-cell):not(.actions-cell){min-width:28px}.total-column,.total-cell{width:55px;min-width:55px;max-width:55px}.actions-column{width:85px;min-width:85px;max-width:85px}.add-habit-container{flex-direction:row;align-items:center}.new-habit-input{flex:1}.add-habit-btn{width:auto;padding:12px 24px}}.today-header{background:#3498db!important;color:#fff!important;font-weight:700}.today-cell,.today-cell.completed{border-top:3px solid #3498db!important}.mobile-view{padding:10px 0}.day-selector{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:15px;padding:15px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff}.day-selector button{width:44px;height:44px;border:none;background:#fff3;color:#fff;border-radius:50%;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}.day-selector button:disabled{opacity:.3;cursor:not-allowed}.day-selector button:active:not(:disabled){background:#fff6}.day-display{text-align:center}.day-number{display:block;font-size:36px;font-weight:700;line-height:1}.day-name{font-size:14px;opacity:.9}.mini-calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:20px;padding:10px;background:#f8f9fa;border-radius:10px}.mini-day{aspect-ratio:1;border:none;background:#fff;border-radius:6px;font-size:12px;font-weight:500;color:#555;cursor:pointer;position:relative}.mini-day:active{transform:scale(.95)}.mini-day.selected{background:#667eea;color:#fff}.mini-day.has-completed:after{content:"";position:absolute;bottom:3px;left:50%;transform:translate(-50%);width:5px;height:5px;background:#4caf50;border-radius:50%}.mini-day.selected.has-completed:after{background:#fff}.habits-list{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.habit-card{display:flex;align-items:center;justify-content:space-between;padding:15px;background:#fff;border:2px solid #e0e0e0;border-radius:12px;transition:all .2s;overflow:hidden}.habit-card.completed{background:#e8f5e9;border-color:#4caf50}.habit-check{display:flex;align-items:center;gap:12px;flex:1;cursor:pointer;min-width:0;overflow:hidden}.checkbox{width:32px;height:32px;border:2px solid #ccc;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;color:#4caf50;background:#fff;flex-shrink:0}.habit-card.completed .checkbox{background:#4caf50;border-color:#4caf50;color:#fff}.habit-card .habit-name{font-size:16px;font-weight:500;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.habit-meta{display:flex;align-items:center;gap:8px;flex-shrink:0;margin-left:8px}.habit-streak{font-size:12px;color:#888;background:#f0f0f0;padding:4px 8px;border-radius:12px;white-space:nowrap}.habit-card.completed .habit-streak{background:#c8e6c9;color:#2e7d32}.habit-meta .edit-btn,.habit-meta .delete-btn{width:36px;height:36px;border:none;background:#f5f5f5;border-radius:8px;cursor:pointer;font-size:16px}.habit-meta .edit-btn:active{background:#e3f2fd}.habit-meta .delete-btn:active{background:#ffebee}.habit-edit{width:100%}.habit-edit input{width:100%;padding:10px;font-size:16px;border:2px solid #667eea;border-radius:8px;color:#333;box-sizing:border-box}.month-progress{margin-bottom:20px;padding:15px;background:#f8f9fa;border-radius:10px}.progress-label{font-size:14px;color:#555;margin-bottom:8px}.progress-bar{height:10px;background:#e0e0e0;border-radius:5px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#4caf50,#8bc34a);border-radius:5px;transition:width .3s}.add-habit-mobile{display:flex;flex-direction:column;gap:10px}.add-habit-mobile input{padding:15px;border:2px dashed #4CAF50;border-radius:10px;font-size:16px;color:#333}.add-habit-mobile input::placeholder{color:#888}.add-habit-mobile input:focus{outline:none;border-style:solid}.add-habit-mobile button{padding:15px;background:#4caf50;color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer}.add-habit-mobile button:disabled{background:#ccc;cursor:not-allowed}.add-habit-mobile button:not(:disabled):active{transform:scale(.98)}.mini-day.today{border:2px solid #3498db;font-weight:700}.mini-day.today:not(.selected){background:#ebf5fb;color:#3498db}.todo-list-container{padding:10px 0}.todo-summary{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.todo-count{font-size:13px;padding:6px 12px;border-radius:20px;font-weight:500}.todo-count.pending{background:#fff3e0;color:#e65100}.todo-count.done{background:#e8f5e9;color:#2e7d32}.todo-section{margin-bottom:20px}.todo-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.todo-section-title{font-size:14px;font-weight:600;color:#555;text-transform:uppercase;letter-spacing:.5px;margin:0 0 10px}.todo-section-header .todo-section-title{margin-bottom:0}.completed-title{color:#999}.clear-completed-btn{font-size:12px;padding:4px 10px;border:1px solid #e0e0e0;border-radius:6px;background:#fafafa;color:#888;cursor:pointer}.clear-completed-btn:active{background:#ffebee;border-color:#ef9a9a}.todo-items{display:flex;flex-direction:column;gap:8px}.todo-item{display:flex;align-items:center;justify-content:space-between;padding:12px 15px;background:#fff;border:2px solid #e0e0e0;border-radius:12px;border-left:4px solid #ff9800;transition:all .2s;overflow:hidden}.todo-item.completed{background:#f9f9f9;border-color:#e8e8e8;border-left-color:#4caf50;opacity:.7}.todo-check{display:flex;align-items:center;gap:12px;flex:1;min-width:0;cursor:pointer;overflow:hidden}.todo-checkbox{width:28px;height:28px;border:2px solid #ff9800;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;color:#fff;background:#fff;flex-shrink:0;transition:all .2s}.todo-item.completed .todo-checkbox{background:#4caf50;border-color:#4caf50}.todo-info{display:flex;flex-direction:column;gap:2px;min-width:0;overflow:hidden}.todo-name{font-size:15px;font-weight:500;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.todo-item.completed .todo-name{text-decoration:line-through;color:#999}.todo-date{font-size:11px;color:#aaa}.todo-actions{display:flex;align-items:center;gap:6px;flex-shrink:0;margin-left:8px}.todo-edit-btn,.todo-delete-btn{width:34px;height:34px;border:none;background:#f5f5f5;border-radius:8px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center}.todo-edit-btn:active{background:#e3f2fd}.todo-delete-btn:active{background:#ffebee}.todo-edit{width:100%}.todo-edit input{width:100%;padding:10px;font-size:15px;border:2px solid #ff9800;border-radius:8px;color:#333;box-sizing:border-box}.todo-empty{text-align:center;padding:30px 20px;background:#f8f9fa;border-radius:12px;margin-bottom:20px}.todo-empty-icon{font-size:40px;display:block;margin-bottom:8px}.todo-empty-text{font-size:16px;font-weight:600;color:#555;margin:0 0 4px}.todo-empty-sub{font-size:13px;color:#999;margin:0}.add-todo{display:flex;flex-direction:column;gap:10px}.add-todo input{padding:15px;border:2px dashed #ff9800;border-radius:10px;font-size:16px;color:#333}.add-todo input::placeholder{color:#888}.add-todo input:focus{outline:none;border-style:solid}.add-todo button{padding:15px;background:#ff9800;color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer}.add-todo button:disabled{background:#ccc;cursor:not-allowed}.add-todo button:not(:disabled):active{transform:scale(.98)}:root{--user-color: #4A90D9}.app{width:100%;max-width:100%;margin:0 auto;background:#fff;padding:0 12px 12px;min-height:100vh}@media(min-width:768px){.app{padding:20px;margin:15px auto;max-width:calc(100% - 30px);min-height:auto;border-radius:12px;box-shadow:0 2px 10px #0000001a}}@media(min-width:1400px){.app{max-width:1350px}}.user-tabs-container{position:sticky;top:0;z-index:100;background:#fff;margin:0 -12px;padding:12px 12px 0;border-bottom:1px solid #f0f0f0}.user-tabs{display:flex;gap:10px;justify-content:center}.user-tab{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 28px;border:2.5px solid #e0e0e0;border-radius:50px;background:#fff;cursor:pointer;font-size:.95rem;font-weight:600;color:#888;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;min-width:120px}.user-tab:active{transform:scale(.96)}.user-tab.active{color:#fff;border-color:transparent;box-shadow:0 4px 15px #00000026;transform:scale(1.02)}.user-tab:not(.active):hover{border-color:#ccc;color:#555;background:#fafafa}.user-tab-emoji{font-size:1.2rem;line-height:1}.user-tab-name{font-size:.95rem;letter-spacing:.3px}.section-tabs{display:flex;gap:0;margin-top:12px;border-bottom:none}.section-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border:none;background:transparent;cursor:pointer;font-size:.85rem;font-weight:600;color:#aaa;border-bottom:3px solid transparent;transition:all .2s ease;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;position:relative}.section-tab:active{background:#f5f5f5}.section-tab.active{color:#333;border-bottom-color:var(--user-color)}.section-tab-icon{font-size:1rem;line-height:1}.section-tab-label{font-size:.85rem;letter-spacing:.3px}.section-tab-badge{background:#ff5722;color:#fff;font-size:.65rem;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center;line-height:1.3;animation:badgePop .3s ease}@keyframes badgePop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.todos-view-wrapper{padding-top:12px;max-width:600px;margin:0 auto}.active-indicator{display:none}.loading{display:flex;flex-direction:column;justify-content:center;align-items:center;height:60vh;gap:16px}.loading p{font-size:1rem;color:#aaa;font-weight:500}.loading-spinner{width:40px;height:40px;border:4px solid #f0f0f0;border-top-color:var(--user-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(min-width:768px){.user-tabs-container{position:relative;margin:0;padding:16px 0 0;border-bottom:none}.user-tab{padding:12px 36px;font-size:1rem;min-width:140px}.user-tab:hover:not(.active){transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.user-tab-emoji{font-size:1.3rem}.section-tabs{max-width:400px;margin:12px auto 0}.section-tab{padding:12px 20px;font-size:.9rem}.section-tab:hover:not(.active){color:#666;background:#fafafa;border-radius:8px 8px 0 0}.section-tab-icon{font-size:1.1rem}.section-tab-label{font-size:.9rem}.todos-view-wrapper{padding-top:20px;max-width:700px}}
