*{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}.habit-card.completed{background:#e8f5e9;border-color:#4caf50}.habit-check{display:flex;align-items:center;gap:12px;flex:1;cursor:pointer}.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}.habit-card.completed .checkbox{background:#4caf50;border-color:#4caf50;color:#fff}.habit-card .habit-name{font-size:16px;font-weight:500;color:#333}.habit-meta{display:flex;align-items:center;gap:8px}.habit-streak{font-size:12px;color:#888;background:#f0f0f0;padding:4px 8px;border-radius:12px}.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 input{width:100%;padding:10px;font-size:16px;border:2px solid #667eea;border-radius:8px;color:#333}.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}.app{width:100%;max-width:100%;margin:0 auto;background:#fff;padding:15px;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}}.loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:1.5rem;color:#888}
