*{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:6px!important;overflow:hidden}.habit-name-wrapper{display:flex;flex-direction:column;gap:2px;cursor:pointer;overflow:hidden}.habit-name-text{font-size:11px;font-weight:600;color:#2c3e50;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}.habit-freq-badge{font-size:9px;color:#888;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;font-weight:400}.edit-input{width:100%;padding:4px;border:2px solid #3498db;border-radius:4px;font-size:12px;color:#333;box-sizing:border-box}.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}.day-cell.not-applicable{background:#f5f5f5!important;cursor:default;color:#ddd}.day-cell.not-applicable:active{background:#f5f5f5!important}.day-cell.today-cell{border-top:3px solid #3498db!important}.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-text{font-size:13px}.habit-freq-badge{font-size:10px}.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:55px;min-width:55px;max-width:55px;background:#f39c12!important;color:#fff!important}.total-cell{background:#fef9e7!important;font-weight:700;font-size:11px;white-space:nowrap;padding:4px 2px!important}.total-done{color:#27ae60;font-weight:700}.total-sep{color:#bbb;margin:0 1px}.total-expected{color:#999;font-weight:400}.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}.add-habit-row{display:flex;gap:10px;align-items:center}.new-habit-input{flex:1;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{padding:12px 24px;background:#4caf50;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600;font-size:14px;white-space:nowrap}.add-habit-btn:disabled{background:#ccc;cursor:not-allowed}.freq-toggle-desktop{width:100%;padding:10px 14px;background:#f0f4ff;border:2px solid #667eea;border-radius:8px;font-size:13px;color:#667eea;cursor:pointer;text-align:left;display:flex;gap:6px;align-items:center}.freq-toggle-desktop:active{background:#e0e9ff}.frequency-selector-desktop{border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;background:#f8f9fa}.freq-section-desktop{border-bottom:1px solid #e0e0e0}.freq-section-desktop:last-child{border-bottom:none}.freq-header-desktop{width:100%;padding:12px 16px;background:#fff;border:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:14px;font-weight:600;color:#333}.freq-header-desktop.open{background:#f0f4ff;color:#667eea}.freq-body-desktop{padding:12px 16px;background:#fafafa;display:flex;flex-direction:column;gap:8px}.freq-opt{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:14px;color:#333}.freq-opt input[type=radio]{width:16px;height:16px;accent-color:#667eea;cursor:pointer}.freq-opt small{font-size:11px;color:#999;margin-left:4px}.day-picker-desktop{display:flex;gap:6px;margin-left:26px;flex-wrap:wrap}.day-btn-desktop{width:32px;height:32px;border:2px solid #e0e0e0;background:#fff;border-radius:50%;font-size:12px;font-weight:600;color:#555;cursor:pointer;transition:all .15s}.day-btn-desktop.active{background:#667eea;border-color:#667eea;color:#fff}.freq-num-desktop{display:flex;align-items:center;gap:10px;margin-left:26px}.freq-num-desktop button{width:28px;height:28px;border:2px solid #667eea;background:#fff;border-radius:6px;font-size:16px;color:#667eea;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center}.freq-num-desktop button:active{background:#f0f4ff}.freq-num-desktop span{font-size:18px;font-weight:700;color:#333;min-width:28px;text-align:center}.freq-num-desktop small{font-size:12px;color:#888}.today-header{background:#3498db!important;color:#fff!important;font-weight:700}.today-cell{border-top:3px solid #3498db!important}@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:65px;min-width:65px;max-width:65px}.actions-column{width:85px;min-width:85px;max-width:85px}}.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}.mini-day.today{border:2px solid #3498db;font-weight:700}.mini-day.today:not(.selected){background:#ebf5fb;color:#3498db}.habits-list{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.no-habits-today{text-align:center;padding:20px;color:#aaa;font-size:14px;background:#f8f9fa;border-radius:10px}.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-info{display:flex;flex-direction:column;gap:2px;min-width:0;overflow:hidden}.habit-card .habit-name{font-size:16px;font-weight:500;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.habit-freq-label{font-size:11px;color:#999;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.habit-card.completed .habit-freq-label{color:#81c784}.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}.freq-toggle-btn{width:100%;padding:12px 15px;background:#f0f4ff;border:2px solid #667eea;border-radius:10px;font-size:14px;color:#667eea;font-weight:600;cursor:pointer;text-align:left;display:flex;justify-content:space-between}.freq-toggle-btn:active{background:#e0e9ff}.frequency-selector{background:#f8f9fa;border-radius:12px;overflow:hidden;border:1px solid #e0e0e0}.freq-section{border-bottom:1px solid #e0e0e0}.freq-section:last-child{border-bottom:none}.freq-section-header{width:100%;padding:14px 16px;background:#fff;border:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:15px;font-weight:600;color:#333}.freq-section-header.open{background:#f0f4ff;color:#667eea}.freq-arrow{font-size:12px;color:#999}.freq-section-body{padding:12px 16px;background:#fafafa;display:flex;flex-direction:column;gap:10px}.freq-option{display:flex;align-items:center;gap:12px;cursor:pointer;padding:4px 0}.freq-option input[type=radio]{width:18px;height:18px;accent-color:#667eea;cursor:pointer}.freq-option span{font-size:15px;color:#333;display:flex;flex-direction:column}.freq-option small{font-size:11px;color:#999}.day-picker{display:flex;gap:6px;flex-wrap:wrap;margin-left:30px}.day-btn{width:36px;height:36px;border:2px solid #e0e0e0;background:#fff;border-radius:50%;font-size:13px;font-weight:600;color:#555;cursor:pointer;transition:all .15s}.day-btn.active{background:#667eea;border-color:#667eea;color:#fff}.freq-number-input{display:flex;align-items:center;gap:12px;margin-left:30px;padding:8px 0}.freq-number-input button{width:32px;height:32px;border:2px solid #667eea;background:#fff;border-radius:8px;font-size:18px;color:#667eea;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center}.freq-number-input button:active{background:#f0f4ff}.freq-number-input span{font-size:22px;font-weight:700;color:#333;min-width:32px;text-align:center}.freq-number-input small{font-size:13px;color:#888}.add-habit-mobile .add-btn{padding:15px;background:#4caf50;color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer}.add-habit-mobile .add-btn:disabled{background:#ccc;cursor:not-allowed}.add-habit-mobile .add-btn:not(:disabled):active{transform:scale(.98)}.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}}
