@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap";:root{--page-max-width: 1200px;--page-side-padding-desktop: 16px;--page-side-padding-tablet: 14px;--page-side-padding-mobile: 12px}*{box-sizing:border-box}html,body{max-width:100%;overflow-x:hidden}.App{width:100%;min-height:100vh;background:var(--background-color);overflow-x:hidden}.loading{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:18px;color:var(--text-secondary)}.page-wrapper{width:100%;max-width:100%;margin:0 auto;padding:0 var(--page-side-padding-desktop) 24px;overflow-x:hidden}.header{padding:12px 0 12px 24px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;background:var(--surface-color);position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm)}.header-title{font-family:Outfit,sans-serif;font-size:20px;font-weight:700;color:var(--text-primary);white-space:nowrap;letter-spacing:-.5px}.header-actions{display:flex;align-items:center;gap:12px;justify-content:flex-end;padding-right:0}.user-info{display:flex;align-items:center;gap:12px;padding-left:24px;border-left:1px solid var(--border-color)}.user-email{font-size:14px;color:var(--text-secondary);font-weight:500}.logout-btn{padding:8px 16px;background:transparent;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);cursor:pointer;font-size:13px;font-weight:600;color:var(--text-secondary);transition:var(--transition-base)}.logout-btn:hover{background:#f1f5f9;color:var(--text-primary);border-color:#cbd5e1}.date-selector{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.date-nav-btn{background:var(--surface-color);border:1px solid var(--border-color);padding:8px 16px;border-radius:var(--border-radius-sm);cursor:pointer;font-size:13px;font-weight:600;color:var(--text-primary);transition:var(--transition-base);white-space:nowrap}.date-nav-btn:hover{background:#f8fafc;border-color:#cbd5e1}.date-nav-btn.active{background:var(--primary-color);color:var(--text-on-primary);border-color:var(--primary-color)}.current-date{font-size:14px;font-weight:500;min-width:150px;text-align:center}.view-container{display:none}.view-container.active{display:block}.view-toggle-btn.active{background:var(--primary-color);color:var(--text-on-primary);border-color:var(--primary-color)}.main-container{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:#e9e9e7;min-height:calc(100vh - 50px);max-width:var(--page-max-width);margin:0 auto;width:100%}.left-panel,.right-panel{background:#fff;padding:24px;overflow-y:auto}.quick-actions{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap}.quick-action-btn{flex:1;min-width:100px;padding:10px 12px;background:#f7f6f3;border:1px solid #e9e9e7;border-radius:6px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:4px}.quick-action-btn:hover{background:#f0efeb;border-color:#d3d1cb}.quick-action-btn .btn-icon{font-size:20px}.quick-action-btn .btn-label{font-size:11px;color:#37352f;font-weight:500}.section-header{font-size:16px;font-weight:600;margin-bottom:16px;color:#37352f;display:flex;align-items:center;justify-content:space-between;gap:8px}.btn-category-settings-small{background:none;border:1px solid #e9e9e7;padding:6px 10px;border-radius:6px;cursor:pointer;font-size:16px;color:#37352f;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-category-settings-small:hover{background:#f7f6f3}.time-tracker-date-header{display:grid;grid-template-columns:44px 1fr 44px;align-items:center;gap:12px;margin-bottom:16px;padding:8px 0}.category-manager-modal{max-width:600px;max-height:80vh;overflow-y:auto}.btn-close-modal{width:100%;margin-top:16px;padding:10px;background:#f7f6f3;color:#37352f;border:1px solid #e9e9e7;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.btn-close-modal:hover{background:#efedea;border-color:#d3d1cb}.time-tracker-date-header .current-date{font-size:20px;font-weight:700;text-align:center;min-width:0;line-height:1.2}.time-tracker-date-header .date-nav-btn,.time-tracker-date-header .btn-category-settings{width:44px;height:44px;padding:0;font-size:16px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:none;border:1px solid #e9e9e7;cursor:pointer;color:#37352f;transition:all .2s}.time-tracker-date-header .date-nav-btn:hover,.time-tracker-date-header .btn-category-settings:hover{background:#f7f6f3}.time-tracker-date-header .btn-category-settings{font-size:20px}.wake-sleep-container{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;align-items:center;justify-content:space-between}.wake-sleep-item{padding:6px 12px;border-radius:6px;font-size:13px;background:#f7f6f3;color:#37352f;display:inline-flex;align-items:center;gap:6px;border:1px solid #e9e9e7}.wake-sleep-item .time-value{font-weight:600;color:#2383e2}.add-event-button-mobile{padding:10px 20px;border-radius:10px;font-size:14px;font-weight:600;background:#f7f6f3;color:#37352f;border:1px solid #e9e9e7;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:all .2s ease;margin-left:auto;box-shadow:0 4px 12px #d4b8964d}.add-event-button-mobile:hover{background:#f7f6f3;transform:translateY(-1px);box-shadow:0 6px 16px #c9a88266}.add-event-button-mobile:active{transform:translateY(0)}@media (max-width: 768px){.wake-sleep-container{flex-wrap:nowrap;gap:4px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.wake-sleep-container::-webkit-scrollbar{display:none}.wake-sleep-item{padding:4px 8px;font-size:11px;white-space:nowrap;flex-shrink:0}.add-event-button-mobile{padding:6px 10px;font-size:12px;white-space:nowrap;flex-shrink:0}}.timeline-grid{border:1px solid #e9e9e7;border-radius:6px;overflow:hidden;position:relative;width:100%;max-width:100%}.timeline-header{display:grid;grid-template-columns:1fr 60px 1fr;background:#f7f6f3;border-bottom:1px solid #e9e9e7;font-size:11px;font-weight:600;color:#787774}.timeline-header>div{padding:8px;text-align:center;border-right:1px solid #e9e9e7}.timeline-header>div:last-child{border-right:none}.timeline-wrapper{position:relative;background:#fff;width:100%;overflow-x:hidden}.timeline-hover-line{position:absolute;left:0;right:0;height:0;border-top:2px dotted var(--primary-color);pointer-events:none;z-index:100;display:none;opacity:.8}.timeline-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:#666}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #2383e2;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.timeline-loading p{margin:0;font-size:14px}.timeline-columns{display:grid;grid-template-columns:1fr 60px 1fr;position:absolute;width:100%;height:100%;z-index:1;pointer-events:none;max-width:100%}.timeline-column{position:relative;pointer-events:auto}.timeline-column.plan-column{border-right:1px solid #f5f5f5}.timeline-column.time-column{border-right:1px solid #f5f5f5;pointer-events:none}.time-markers{position:relative;z-index:0}.time-marker-row{height:40px;border-bottom:1px solid #f5f5f5;display:grid;grid-template-columns:1fr 60px 1fr}.time-marker-row:last-child{border-bottom:none}.time-marker-label{background:#fafafa;text-align:center;display:flex;align-items:center;justify-content:center;font-size:11px;color:#787774;font-weight:500;border-left:1px solid #e9e9e7;border-right:1px solid #e9e9e7}.time-marker-row.wake-hour .time-marker-label{color:#eb5757;font-weight:700;font-size:16px;background:#fff5f5}.time-marker-row.sleep-hour .time-marker-label{color:#2383e2;font-weight:700;font-size:16px;background:#f0f7ff}.event-block-absolute{position:absolute;left:4px;right:4px;padding:6px 8px;border-radius:10px;font-size:11px;cursor:pointer;transition:all .2s;box-shadow:0 1px 3px #00000014;line-height:1.4;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:2px;border-left:4px solid rgba(0,0,0,.06);white-space:normal;overflow:hidden;z-index:10}.event-block-absolute:hover{transform:translateY(-1px);box-shadow:0 2px 6px #00000026;z-index:20}.event-block-absolute[title]:hover:after{content:attr(title);position:absolute;background:#000000e6;color:#fff;padding:8px 12px;border-radius:6px;font-size:12px;white-space:pre-wrap;word-break:break-word;z-index:1000;bottom:120%;left:50%;transform:translate(-50%);pointer-events:none;line-height:1.4;max-width:200px;box-shadow:0 4px 12px #00000040}.event-block-absolute.plan-event{opacity:.75}.event-title{font-weight:600;font-size:11px}.event-time{font-size:10px;opacity:.7}.resize-handle{opacity:0;transition:opacity .2s}.event-block-absolute:hover .resize-handle{opacity:.3;background:#0003}.resize-handle:hover{opacity:.6!important;background:#0006!important}.category-stats-container{margin-bottom:16px;padding-bottom:12px}.category-matrix-wrapper{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.category-matrix{width:100%;border-collapse:collapse;font-size:13px;min-width:480px}.category-matrix thead th{text-align:center;background:#f7f7f7;padding:6px 4px;border-bottom:1px solid #e2e2e2;white-space:nowrap}.category-matrix tbody th{text-align:left;background:#f7f7f7;padding:6px 8px;border-bottom:1px solid #e2e2e2;width:60px;font-weight:600;white-space:nowrap}.category-matrix tbody td{padding:6px 4px;border-bottom:1px solid #f0f0f0;text-align:center;white-space:nowrap}.routine-container{margin-bottom:28px}.routine-input-row{display:flex;gap:8px;margin-bottom:14px}.routine-input-row input{flex:1;padding:10px 12px;border:1px solid #e9e9e7;border-radius:8px;font-size:14px}.routine-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px}.routine-card{position:relative;padding:8px 10px;border-radius:10px;border:1px solid #e9e9e7;background:#f7f6f3;cursor:pointer;transition:all .25s ease;min-height:56px;display:flex;flex-direction:column;justify-content:space-between}.routine-card.dragging{opacity:.5;cursor:move}.routine-card:hover{transform:translateY(-2px);box-shadow:0 4px 14px #00000014}.routine-card.completed{background:linear-gradient(135deg,#e8f5e9,#f1f8e9);border-color:#a5d6a7}.routine-title{font-size:13px;font-weight:600;line-height:1.25;color:#37352f}.routine-check{align-self:flex-end;width:22px;height:22px;border-radius:999px;border:1.5px solid #c8c8c8;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .2s;background:#fff}.routine-card.completed .routine-check{background:var(--success-color);border-color:var(--success-color);color:#fff}.routine-input-group{display:flex;gap:8px;margin-bottom:14px}.routine-input{flex:1;padding:10px 12px;border:1px solid #e9e9e7;border-radius:6px;font-size:14px}.routine-input:focus{outline:none;border-color:var(--primary-color)}.routine-actions{position:absolute;top:4px;right:4px;display:none;gap:4px}.routine-card:hover .routine-actions{display:flex}.routine-action-btn{padding:2px 6px;background:#ffffffe6;border:1px solid #e9e9e7;border-radius:4px;cursor:pointer;font-size:12px;color:#37352f;transition:all .2s}.routine-action-btn:hover{background:#fff;transform:scale(1.1)}.routine-action-btn.delete{color:#e57373}.routine-action-btn.delete:hover{background:#ffebee;border-color:#e57373}.routine-edit-mode{width:100%}.routine-edit-input{width:100%;padding:6px 8px;border:1px solid #2383e2;border-radius:4px;font-size:13px;margin-bottom:6px}.routine-edit-input:focus{outline:none;border-color:#1976d2}.routine-edit-actions{display:flex;gap:4px;justify-content:flex-end}.routine-edit-btn{padding:4px 10px;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:600;transition:all .2s}.routine-edit-btn.save{background:var(--primary-color);color:var(--text-on-primary)}.routine-edit-btn.save:hover{background:var(--primary-dark)}.routine-edit-btn.cancel{background:#f44336;color:#fff}.routine-edit-btn.cancel:hover{background:#da190b}.mood-container{margin-bottom:24px}.mood-selector{display:flex;gap:12px;justify-content:space-between}.mood-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;background:#f7f6f3;border:2px solid #e9e9e7;border-radius:8px;cursor:pointer;transition:all .2s;font-family:inherit}.mood-btn:hover{background:#f0efeb;transform:translateY(-2px);box-shadow:0 2px 8px #0000001a}.mood-btn.selected{border-color:#2383e2;background:#e3f2fd;box-shadow:0 2px 8px #2383e233}.mood-btn.selected[data-mood=good]{border-color:#4caf50;background:#e8f5e9}.mood-btn.selected[data-mood=soso]{border-color:#ff9800;background:#fff3e0}.mood-btn.selected[data-mood=bad]{border-color:#f44336;background:#ffebee}.mood-emoji{font-size:32px;line-height:1}.mood-label{font-size:13px;font-weight:500;color:#37352f}.image-upload-section{margin-bottom:24px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h3{margin:0;font-size:16px;font-weight:600;color:#37352f}.upload-btn{padding:8px 16px;background:#2383e2;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s}.upload-btn:hover{background:#1a6ec7}.images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.image-item{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;background:#e9e9e7}.image-thumbnail{width:100%;height:100%;object-fit:cover;cursor:pointer}.image-delete-btn{position:absolute;top:4px;right:4px;width:24px;height:24px;background:#0009;color:#fff;border:none;border-radius:50%;cursor:pointer;font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .2s;opacity:0}.image-item:hover .image-delete-btn{opacity:1}.image-delete-btn:hover{background:#dc3545e6}.image-upload-card{position:relative;aspect-ratio:1;border-radius:8px;border:2px dashed #d0d0ce;background:#f7f6f3;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:all .2s}.image-upload-card:hover{border-color:#2383e2;background:#fafaf9}.upload-icon{font-size:32px;color:#9b9a97;font-weight:300;line-height:1;margin-bottom:4px}.upload-text{font-size:12px;color:#787774;font-weight:500}.no-images{grid-column:1 / -1;text-align:center;padding:32px;color:#999;font-size:14px}.todo-container{margin-bottom:24px}.todo-input-group{display:flex;gap:8px;margin-bottom:12px}.todo-input{flex:1;padding:9px 12px;border:1px solid #e9e9e7;border-radius:4px;font-size:14px}.todo-input:focus{outline:none;border-color:#2383e2}.btn{padding:8px 16px;background:#f7f6f3;color:#37352f;border:none;border-radius:4px;cursor:pointer;font-size:13px;transition:all .2s;border:1px solid #e9e9e7}.btn:hover{background:#f0efeb}.todo-list{list-style:none;padding:0;margin:0}.todo-item{display:flex;align-items:center;gap:12px;padding:10px;border-bottom:1px solid #f5f5f5;transition:all .3s ease;cursor:default;background:#fff}.todo-item:hover{background:#f7f6f3}.todo-item.dragging{opacity:.5;background:#e3e2e0}.todo-drag-handle{cursor:grab;color:#9b9a97;font-size:16px;-webkit-user-select:none;user-select:none;flex-shrink:0}.todo-drag-handle:active{cursor:grabbing}.todo-checkbox{width:20px;height:20px;cursor:pointer;flex-shrink:0;margin:0}.todo-text{flex:1;font-size:14px;color:#37352f;cursor:text}.todo-text.completed{text-decoration:line-through;color:#9b9a97}.todo-edit-input{flex:1;font-size:14px;color:#37352f;border:1px solid #2383e2;border-radius:4px;padding:4px 8px;outline:none;background:#fff}.todo-edit-container{flex:1;display:flex;flex-direction:column;gap:4px}.todo-edit-categories{display:flex;gap:4px;flex-wrap:wrap}.todo-content{flex:1;display:flex;align-items:center;gap:8px}.todo-category-selector{display:flex;gap:6px;padding:8px 0;flex-wrap:wrap;margin-bottom:8px}.category-chip{padding:4px 12px;border:none;border-radius:16px;font-size:12px;cursor:pointer;transition:all .2s ease;font-weight:500}.category-chip:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.category-chip.selected{box-shadow:0 2px 6px #00000026}.category-chip-small{padding:2px 8px;border:none;border-radius:12px;font-size:11px;cursor:pointer;transition:all .2s ease;font-weight:500}.category-chip-small:hover{transform:translateY(-1px)}.todo-category-badge{padding:2px 8px;border-radius:12px;font-size:11px;color:#fff;font-weight:500;flex-shrink:0}.todo-delete{background:none;border:none;color:#eb5757;cursor:pointer;font-size:16px;opacity:0;transition:opacity .2s}.todo-item:hover .todo-delete{opacity:1}.pomodoro-start-btn{background:none;border:none;cursor:pointer;font-size:16px;padding:2px 4px;opacity:.7;transition:all .2s ease;flex-shrink:0}.pomodoro-start-btn:hover{opacity:1;transform:scale(1.1)}.pomodoro-tomatoes{display:flex;gap:2px;margin-left:8px;flex-shrink:0}.pomodoro-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.pomodoro-modal{background:#fff;border-radius:16px;padding:32px;max-width:500px;width:90%;box-shadow:0 8px 32px #0003;position:relative}.pomodoro-modal.fullscreen{max-width:100%;width:100%;height:100%;border-radius:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.pomodoro-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:4px 8px;transition:color .2s}.pomodoro-close:hover{color:#000}.pomodoro-header{text-align:center;margin-bottom:24px}.pomodoro-todo-title{font-size:18px;font-weight:600;color:#333;margin-bottom:8px}.pomodoro-count-display{font-size:14px;color:#666;display:flex;align-items:center;justify-content:center;gap:4px}.pomodoro-circle-container{position:relative;width:300px;height:300px;margin:0 auto 32px}.pomodoro-modal.fullscreen .pomodoro-circle-container{width:400px;height:400px}.pomodoro-circle{width:100%;height:100%}.pomodoro-time{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:48px;font-weight:700;color:#333;font-family:Courier New,monospace}.pomodoro-modal.fullscreen .pomodoro-time{font-size:64px}.pomodoro-controls{display:flex;gap:12px;justify-content:center;margin-bottom:16px}.pomodoro-btn{padding:12px 24px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.pomodoro-btn-primary{background:#ff6b6b;color:#fff}.pomodoro-btn-primary:hover{background:#ff5252;transform:translateY(-1px);box-shadow:0 4px 12px #ff6b6b4d}.pomodoro-btn-secondary{background:#f0f0f0;color:#666}.pomodoro-btn-secondary:hover{background:#e0e0e0;color:#333}.pomodoro-actions{display:flex;gap:8px;justify-content:center}.pomodoro-action-btn{padding:8px 16px;border:1px solid #e0e0e0;border-radius:6px;background:#fff;font-size:13px;cursor:pointer;transition:all .2s ease}.pomodoro-action-btn:hover{background:#f5f5f5;border-color:#d0d0d0}.pip-canvas{display:none}.image-upload-section{margin:16px 0}.image-grid-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-top:12px}.image-preview-container{display:contents}.image-preview{position:relative;aspect-ratio:1 / 1;border-radius:8px;overflow:hidden;border:1px solid #e9e9e7;background:#f7f6f3}.image-preview img{width:100%;height:100%;object-fit:cover}.reflection-container{margin-top:24px}.reflection-textarea{width:100%;min-height:200px;padding:12px;border:1px solid #e9e9e7;border-radius:4px;font-size:14px;font-family:inherit;resize:vertical}.reflection-textarea:focus{outline:none;border-color:#2383e2}.reflection-prompts{margin-top:12px;margin-bottom:12px;padding:12px;background:#f7f6f3;border-radius:4px;font-size:12px;color:#787774}.reflection-prompts div{margin-bottom:6px}.template-btn{padding:6px 12px;background:#f7f6f3;border:1px solid #e9e9e7;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s;color:#37352f}.template-btn:hover{background:#f0efeb;transform:scale(1.05)}.loading{text-align:center;padding:40px;color:#787774;font-size:14px}.monthly-container{max-width:var(--page-max-width);margin:0 auto;padding:24px;background:#fff}.monthly-header{display:grid;grid-template-columns:44px auto auto 1fr;align-items:center;gap:12px;margin-bottom:24px;padding:12px 0}.header-actions{display:flex;gap:12px;align-items:center;justify-content:flex-end}.header-actions .month-nav-btn{width:40px;height:40px}.current-month{font-size:24px;font-weight:700;text-align:center;color:#37352f;justify-self:center;white-space:nowrap;padding:0 8px}.month-nav-btn{width:44px;height:44px;padding:0;font-size:18px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid #e9e9e7;border-radius:10px;cursor:pointer;transition:all .2s;color:#37352f}.month-nav-btn:hover{background:#fff;transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.monthly-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:#e9e9e7;border:1px solid #e9e9e7;border-radius:8px;overflow:hidden}.monthly-day-header{background:#f7f6f3;padding:12px;text-align:center;font-weight:700;font-size:13px;color:#787774;border-bottom:2px solid #e9e9e7}.monthly-day-cell{background:#fff;padding:12px;min-height:120px;display:flex;flex-direction:column;gap:8px;cursor:pointer;transition:all .2s;border:2px solid transparent}.monthly-day-cell:hover{border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 12px #2383e226;z-index:10}.monthly-day-cell.empty{cursor:default;pointer-events:none}.monthly-day-cell.today{border-color:var(--primary-color)}.monthly-date-num{font-size:16px;font-weight:700;color:#37352f}.monthly-day-cell.today .monthly-date-num{color:var(--primary-color);font-size:18px}.monthly-thumbnail{width:100%;height:70px;object-fit:cover;border-radius:6px;margin-top:auto;-webkit-transform:translateZ(0);transform:translateZ(0)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.monthly-loading-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:20px}.loading-spinner{width:50px;height:50px;border:4px solid #e9e9e7;border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:16px;color:#787774;font-weight:500}.view-mode-selector{display:flex;gap:8px;justify-content:flex-end;align-items:center}.view-mode-selector.header-inline{margin-right:8px}.view-mode-btn{padding:8px 16px;background:#f7f6f3;border:2px solid #e9e9e7;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .12s ease;color:#37352f;min-height:40px;display:inline-flex;align-items:center;gap:8px}.view-mode-btn:hover{background:#f0efeb;transform:translateY(-2px)}.view-mode-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:var(--text-on-primary)}.monthly-timetracker-wrapper{position:relative;width:100%;height:calc(100vh - 180px);min-height:500px;max-height:900px;overflow:auto;-webkit-overflow-scrolling:touch;background:#fff}.tt-hover-line{position:absolute;left:0;right:0;height:0;border-top:2px dotted var(--primary-color);pointer-events:none;z-index:100;display:none;opacity:.8}.monthly-timetracker-wrapper .loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;padding:40px;color:#787774;font-size:14px}.monthly-timetracker{display:grid;grid-template-columns:60px repeat(31,1fr);grid-template-rows:50px repeat(24,minmax(25px,1fr));width:100%;height:100%;background:#fff;border:1px solid #e9e9e7;border-radius:8px;overflow:visible;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.tt-time-column{grid-column:1;grid-row:1 / -1;display:grid;grid-template-rows:subgrid;background:#f7f6f3;border-right:1px solid #e9e9e7;position:sticky;left:0;z-index:10}.tt-time-header{grid-row:1;height:50px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:#787774;border-bottom:2px solid #e9e9e7;background:#f7f6f3}.tt-time-cell{min-height:25px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:500;color:#787774;border-bottom:1px solid #f0f0f0;background:#fafafa}.tt-date-header{grid-row:1;height:50px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;border-bottom:2px solid #e9e9e7;border-right:1px solid #f0f0f0;background:#f7f6f3;cursor:pointer;transition:all .2s}.tt-date-header:hover{background:#f0efeb}.tt-date-header.today{background:#e3f2fd;border-bottom-color:#2383e2}.tt-date-day{font-size:11px;font-weight:700;color:#37352f;line-height:1}.tt-date-header.today .tt-date-day{color:#2383e2}.tt-date-weekday{font-size:8px;color:#787774;font-weight:500;line-height:1}.tt-day-column{display:grid;grid-template-rows:subgrid;grid-row:1 / -1;position:relative;border-right:1px solid #f0f0f0}.tt-hour-cell{min-height:25px;border-bottom:1px solid #f5f5f5;position:relative;background:#fff;pointer-events:none}.tt-wake-marker,.tt-sleep-marker{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:10px;font-weight:700;padding:2px 4px;border-radius:3px;z-index:10;pointer-events:none}.tt-wake-marker{color:#eb5757;background:#fff5f5}.tt-sleep-marker{color:#2383e2;background:#f0f7ff}.tt-event-block{position:absolute;left:2px;right:2px;padding:2px 3px;border-radius:3px;font-size:8px;line-height:1.1;overflow:hidden;cursor:pointer;transition:all .2s;border-left:2px solid rgba(0,0,0,.2);white-space:nowrap;text-overflow:ellipsis;z-index:1;pointer-events:auto}.tt-event-block:hover{transform:scale(1.05);box-shadow:0 3px 10px #00000040;z-index:100;overflow:visible}.tt-event-title{font-weight:600;font-size:8px}.tt-event-block:hover .tt-event-title{font-size:11px}.tt-event-tooltip{display:none;position:absolute;left:100%;top:0;margin-left:8px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:8px 12px;box-shadow:0 4px 12px #00000026;white-space:nowrap;z-index:1000;pointer-events:none}.tt-event-block:hover .tt-event-tooltip{display:block}.tt-tooltip-title{font-size:13px;font-weight:600;color:#1a1a1a;margin-bottom:4px}.tt-tooltip-time{font-size:11px;color:#787774}.tt-day-column.weekend .tt-hour-cell{background:#fafafa}.tt-date-header.weekend{background:#f0f0f0}.tt-date-header.weekend:hover{background:#e9e9e7}@media (min-height: 900px){.monthly-timetracker{grid-template-rows:55px repeat(24,minmax(30px,1fr))}.tt-time-header,.tt-date-header{height:55px}.tt-time-cell,.tt-hour-cell{min-height:30px}.tt-event-block,.tt-event-title{font-size:9px}}@media (max-height: 800px){.monthly-timetracker{grid-template-rows:45px repeat(24,minmax(22px,1fr))}.tt-time-header,.tt-date-header{height:45px}.tt-time-cell,.tt-hour-cell{min-height:22px}.tt-date-day{font-size:10px}.tt-date-weekday{font-size:7px}.tt-event-block{font-size:7px;padding:1px 2px}.tt-event-title{font-size:7px}}@media (max-height: 700px){.monthly-timetracker{grid-template-rows:40px repeat(24,minmax(20px,1fr))}.tt-time-header,.tt-date-header{height:40px}.tt-time-cell,.tt-hour-cell{min-height:20px}.tt-time-cell,.tt-date-day{font-size:9px}.tt-date-weekday{font-size:7px}.tt-event-block{font-size:7px;padding:1px 2px}.tt-event-title{font-size:7px}}@media (max-width: 1024px){.tt-time-column{width:50px}}@media (max-width: 768px){.monthly-timetracker-wrapper{height:calc(100vh - 180px);min-height:600px;max-height:none}.monthly-timetracker{min-width:1200px}.tt-date-header{gap:2px}.tt-time-column{width:50px}}@media (max-width: 820px),(hover: none) and (pointer: coarse) and (orientation: portrait){.main-container{grid-template-columns:1fr!important;gap:0;max-width:100%;width:100%;margin:0;border-radius:0}.left-panel,.right-panel{padding:16px;border-radius:0}}@media (max-width: 768px){.header{padding:10px 0 10px 14px}.header-title{flex-shrink:0;white-space:nowrap}.header-actions{flex-shrink:0;justify-content:flex-end;margin-left:auto}.date-selector{gap:8px}.view-toggle-btn{padding:6px 12px;font-size:13px}.section-header{font-size:17px}.routine-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.monthly-header{grid-template-columns:1fr;grid-template-rows:auto auto;gap:16px}.monthly-header>:nth-child(1),.monthly-header>:nth-child(2),.monthly-header>:nth-child(3){grid-row:1;grid-column:1}.monthly-header>:nth-child(1){justify-self:start}.monthly-header>:nth-child(2){justify-self:center}.monthly-header>:nth-child(3){justify-self:end}.header-actions{grid-row:2;grid-column:1;width:100%;justify-content:center}.view-mode-selector{width:100%;flex-direction:column;gap:8px}.view-mode-btn{width:100%;justify-content:center}}.monthly-stats-wrapper{padding:20px;max-width:100%;overflow-x:auto;background:#fafafa;min-height:600px}.stats-section{background:#fff;border-radius:12px;padding:24px;margin-bottom:24px;box-shadow:0 1px 3px #00000014}.stats-row{display:flex;gap:24px;margin-bottom:24px}.stats-half{flex:1;margin-bottom:0}.stats-section-title{font-size:18px;font-weight:600;margin-bottom:20px;color:#1a1a1a;border-bottom:2px solid #e0e0e0;padding-bottom:10px}.no-data{text-align:center;padding:40px;color:#9b9a97;font-size:14px}.stats-table-wrapper{overflow-x:auto;margin-top:16px}.stats-table{width:100%;border-collapse:collapse;font-size:13px;min-width:800px}.stats-table th,.stats-table td{border:1px solid #e0e0e0;padding:8px;text-align:center}.stats-table th{background:#f5f5f5;font-weight:600;color:#333;position:sticky;top:0;z-index:10}.stats-table .routine-name-col{min-width:150px;text-align:left;background:#fafafa}.stats-table .routine-name{text-align:left;font-weight:500;color:#1a1a1a;background:#fafafa;position:sticky;left:0;z-index:5}.stats-table .day-col{min-width:40px;padding:4px;cursor:pointer;transition:background-color .2s}.stats-table .day-col:hover{background-color:#e8e8e8}.stats-table .day-col.weekend{background-color:#fff9e6}.stats-table .day-col.today{background-color:#d4e6ff;font-weight:700}.stats-table .day-num{font-size:12px;font-weight:600}.stats-table .day-weekday{font-size:10px;color:#666;margin-top:2px}.stats-table .status-cell{font-size:16px;cursor:pointer;transition:transform .1s}.stats-table .status-cell:hover{transform:scale(1.2);background-color:#f0f0f0}.stats-table .status-cell.weekend{background-color:#fffbf5}.stats-table .status-cell.future{background-color:#f9f9f9;cursor:default}.stats-table .status-cell.future:hover{transform:none;background-color:#f9f9f9}.stats-table .percentage-col{min-width:120px;background:#fafafa}.stats-table .percentage-cell{background:#fafafa}.percentage-bar-wrapper{position:relative;width:100%;height:24px;background:#e0e0e0;border-radius:12px;overflow:hidden}.percentage-bar{height:100%;background:linear-gradient(90deg,#6fcf97,#219653);border-radius:12px;transition:width .3s ease}.percentage-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:11px;font-weight:700;color:#1a1a1a;text-shadow:0 0 2px white}.mood-pie-container{display:flex;align-items:center;justify-content:center;gap:40px;padding:20px;background:#f9f9f9;border-radius:8px;flex-wrap:wrap}.pie-chart-wrapper{width:250px;height:250px}.pie-chart{width:100%;height:100%;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.pie-legend{display:flex;flex-direction:column;gap:12px}.legend-item{display:flex;align-items:center;gap:10px}.legend-color{width:20px;height:20px;border-radius:4px;flex-shrink:0}.legend-label{font-size:14px;font-weight:500;color:#333}.mood-total{text-align:center;font-size:14px;font-weight:600;color:#666;margin-top:12px;padding-top:12px;border-top:1px solid #e0e0e0}.mood-table-graph-wrapper{overflow-x:auto;padding:20px;background:#f9f9f9;border-radius:8px}.mood-table-graph{width:100%;border-collapse:collapse;min-width:800px;background:#fff}.mood-table-graph thead th{background:#f5f5f5;border:1px solid #333;padding:8px 4px;text-align:center;font-size:12px;font-weight:600;color:#333}.mood-table-graph .mood-row-label{width:80px;background:#fff;border:none}.mood-table-graph .day-header{min-width:40px;font-size:13px}.mood-table-graph tbody tr{height:60px}.mood-table-graph .mood-label-cell{border:1px solid #333;padding:8px;text-align:left;font-weight:600;font-size:13px;background:#fafafa;white-space:nowrap}.mood-table-graph .mood-cell{border:1px solid #333;padding:0;position:relative;background:#fff}.mood-table-graph .mood-cell .cell-content{position:relative;width:100%;height:100%;min-height:60px}.mood-table-graph .mood-dot{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:12px;height:12px;background:#333;border-radius:50%;z-index:2}.mood-table-graph .line-svg{position:absolute;width:50%;height:100%;top:0;pointer-events:none;z-index:1}.mood-table-graph .line-from-prev{left:0}.mood-table-graph .line-to-next{left:50%}.mood-table-wrapper{overflow-x:auto;margin-top:20px}.mood-table{width:100%;border-collapse:collapse;font-size:13px;min-width:800px}.mood-table th,.mood-table td{border:1px solid #e0e0e0;padding:8px;text-align:center}.mood-table th{background:#f5f5f5;font-weight:600;color:#333;position:sticky;top:0;z-index:10}.mood-table .mood-label-col{min-width:100px;text-align:left;background:#fafafa}.mood-table .mood-label{text-align:left;font-weight:600;color:#1a1a1a;background:#fafafa;position:sticky;left:0;z-index:5}.mood-table .mood-cell{font-size:20px;cursor:pointer;transition:all .2s;position:relative;height:50px}.mood-table .mood-cell:hover{background-color:#f0f0f0}.mood-table .mood-cell.weekend{background-color:#fffbf5}.mood-table .mood-cell.checked{background-color:#e8f5e9}.mood-table .mood-cell.weekend.checked{background-color:#fff9c4}.routine-bar-chart{display:flex;flex-direction:column;gap:16px;margin-top:16px}.routine-bar-item{display:flex;flex-direction:column;gap:8px}.routine-bar-label{font-size:14px;font-weight:500;color:#1a1a1a}.routine-bar-container{position:relative;width:100%;height:36px;background-color:#f0f0f0;border-radius:8px;overflow:hidden}.routine-bar-fill{position:relative;height:100%;border-radius:8px;display:flex;align-items:center;justify-content:flex-end;padding-right:12px;transition:width .5s ease,background-color .3s ease;min-width:40px}.routine-bar-percentage{font-size:13px;font-weight:600;color:#333}@media (max-width: 768px){.monthly-container{padding:12px}.monthly-header{gap:8px;margin-bottom:16px}.monthly-grid{gap:1px;border-radius:6px}.monthly-day-header{padding:8px 4px;font-size:11px}.monthly-day-cell{padding:8px;min-height:100px;gap:6px}.monthly-date-num{font-size:14px}.monthly-day-cell.today .monthly-date-num{font-size:15px}.monthly-thumbnail{height:60px}.monthly-stats-wrapper{padding:12px}.stats-section{padding:16px;margin-bottom:16px}.stats-section-title{font-size:16px}.stats-row{flex-direction:column}.stats-table,.mood-table,.stats-table .day-num{font-size:11px}.stats-table .day-weekday{font-size:9px}.pie-chart-wrapper{width:200px;height:200px}.legend-label{font-size:12px}.mood-line-graph{min-width:400px}}.todo-edit-card{background:#fff;border:1px solid #2383e2;border-radius:8px;padding:12px;box-shadow:0 2px 8px #2383e226;width:100%;margin-bottom:8px}.todo-edit-input-styled{width:100%;padding:8px 10px;border:1px solid #e0e0e0;border-radius:4px;font-size:14px;margin-bottom:12px;transition:border-color .2s}.todo-edit-input-styled:focus{outline:none;border-color:#2383e2}.todo-edit-details{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.todo-edit-row{display:flex;align-items:center;gap:10px}.todo-edit-label{font-size:12px;color:#787774;font-weight:500;min-width:50px}.todo-category-selector{display:flex;flex-wrap:wrap;gap:6px;flex:1}.category-chip-tiny{padding:4px 8px;border-radius:4px;font-size:11px;border:1px solid #e9e9e7;background:#f7f6f3;color:#37352f;cursor:pointer;transition:all .2s}.category-chip-tiny:hover{background:#efedea}.category-chip-tiny.selected{background:#4a9eff;color:#fff;border-color:#4a9eff}.todo-time-input-group{display:flex;align-items:center;gap:6px}.todo-edit-time,.todo-edit-duration{padding:4px 8px;border:1px solid #e9e9e7;border-radius:4px;font-size:12px;color:#37352f}.todo-edit-duration{width:60px}.unit{font-size:12px;color:#787774}.todo-edit-actions{display:flex;justify-content:flex-end;border-top:1px solid #f0f0f0;padding-top:10px}.btn-save-edit{background:#2383e2;color:#fff;border:none;padding:6px 16px;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:background .2s}.btn-save-edit:hover{background:#1a6cb8}.no-cat-msg{font-size:11px;color:#999;font-style:italic}.todo-edit-card.compact{padding:8px;display:flex;flex-direction:column;gap:8px}.todo-edit-top-row{display:flex;gap:8px;align-items:center}.todo-edit-input-compact{flex:1;padding:6px 8px;border:1px solid #e0e0e0;border-radius:4px;font-size:14px;transition:border-color .2s}.todo-edit-input-compact:focus{outline:none;border-color:#2383e2}.btn-save-compact{background:#2383e2;color:#fff;border:none;padding:6px 12px;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap}.btn-save-compact:hover{background:#1a6cb8}.todo-edit-bottom-row{display:flex;justify-content:space-between;align-items:center;gap:12px}.todo-category-scroll{display:flex;gap:4px;overflow-x:auto;padding-bottom:2px;flex:1;scrollbar-width:none;-ms-overflow-style:none}.todo-category-scroll::-webkit-scrollbar{display:none}.category-chip-micro{padding:2px 6px;border-radius:4px;font-size:11px;border:1px solid #e9e9e7;background:#f7f6f3;color:#37352f;cursor:pointer;white-space:nowrap;transition:all .2s}.category-chip-micro:hover{background:#efedea}.category-chip-micro.selected{background:#4a9eff;color:#fff;border-color:#4a9eff}.todo-time-compact-group{display:flex;align-items:center;gap:6px;flex-shrink:0}.todo-edit-time-compact{padding:2px 4px;border:1px solid #e9e9e7;border-radius:4px;font-size:11px;color:#37352f;height:24px}.duration-wrapper{position:relative;display:flex;align-items:center}.todo-edit-duration-compact{width:70px;padding:2px 16px 2px 4px;border:1px solid #e9e9e7;border-radius:4px;font-size:11px;color:#37352f;height:24px;text-align:center}.unit-text{position:absolute;right:4px;font-size:10px;color:#999;pointer-events:none}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.modal-content{background:#fff;border-radius:16px;width:90%;max-width:480px;max-height:85vh;box-shadow:0 20px 40px #0003;animation:slideUp .3s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-content h2{margin:0;padding:24px 24px 16px;font-size:24px;font-weight:700;color:#1a1a1a;text-align:center;flex-shrink:0}.modal-content form{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.modal-scroll-content{flex:1;overflow-y:auto;padding:0 24px;-webkit-overflow-scrolling:touch}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;font-size:14px;color:#4a4a4a}.form-group input[type=text],.form-group input[type=time],.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:1px solid #e0e0e0;border-radius:12px;font-size:15px;font-family:inherit;background-color:#f9fafb;transition:all .2s ease;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#d4b896;background-color:#fff;box-shadow:0 0 0 4px #d4b89626}.form-group textarea{resize:vertical;min-height:80px}.form-row{display:flex;gap:16px}.form-row .form-group{flex:1}.checkbox-group{margin-top:8px;margin-bottom:24px}.form-group .checkbox-label{display:flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;padding:8px 0;margin-bottom:0}.checkbox-label input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:20px;height:20px;border:2px solid #cbd5e0;border-radius:6px;margin-right:10px;position:relative;cursor:pointer;transition:all .2s ease;background-color:#fff}.checkbox-label input[type=checkbox]:checked{background-color:#d4b896;border-color:#d4b896}.checkbox-label input[type=checkbox]:checked:after{content:"";position:absolute;left:6px;top:2px;width:4px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.checkbox-text{font-size:15px;color:#4a4a4a;font-weight:500}.modal-actions{display:flex;justify-content:flex-end;padding:16px 24px 24px;gap:12px;background:#fff;border-top:1px solid #f0f0f0;flex-shrink:0}.modal-actions:has(.btn-delete){justify-content:space-between}.modal-actions-right{display:flex;gap:12px}.btn-submit,.btn-cancel,.btn-delete{padding:12px 24px;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.btn-submit{background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);color:var(--text-on-primary);box-shadow:0 4px 12px #b7e5cd4d}.btn-submit:hover{transform:translateY(-1px);box-shadow:0 6px 16px #b7e5cd66}.btn-submit:active{transform:translateY(0)}.btn-cancel{background:#f1f3f4;color:#5f6368}.btn-cancel:hover{background:#e8eaed;color:#202124}.btn-delete{background:#fee2e2;color:#dc2626}.btn-delete:hover{background:#fecaca;color:#b91c1c}@media (max-width: 768px){.modal-overlay{align-items:center;justify-content:center;padding:0}.modal-content{width:90%;max-width:400px;border-radius:16px;max-height:80vh;margin:auto}.modal-content h2{font-size:20px;padding:20px 20px 12px}.modal-scroll-content{padding:0 20px}.form-group{margin-bottom:16px}.form-group label{font-size:13px;margin-bottom:6px}.form-group input[type=text],.form-group input[type=time],.form-group select,.form-group textarea{padding:10px 14px;font-size:16px;border-radius:8px;width:100%;max-width:100%;box-sizing:border-box}.form-group textarea{min-height:60px}.form-row{flex-direction:column;gap:12px}.checkbox-text{font-size:14px}.modal-actions{padding:16px 20px 20px;gap:8px;flex-wrap:wrap}.modal-actions-right{gap:8px}.btn-submit,.btn-cancel,.btn-delete{padding:12px 20px;font-size:14px;border-radius:8px}@media (max-width: 400px){.modal-actions{flex-direction:column}.modal-actions-right{width:100%;flex-direction:column}.btn-submit,.btn-cancel,.btn-delete{width:100%}}}@media (max-width: 768px) and (orientation: landscape){.modal-content{max-height:90vh}.modal-content h2{font-size:18px;padding:16px 20px 8px}.form-group{margin-bottom:12px}.modal-actions{padding:12px 20px 16px}}.event-edit-popup{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--border-radius-md);box-shadow:var(--shadow-lg);padding:16px;min-width:300px;z-index:2000}.popup-row{margin-bottom:12px}.popup-row:last-child{margin-bottom:0}.popup-title-input{width:100%;padding:8px 12px;border:none;border-bottom:1px solid var(--border-color);font-size:14px;outline:none;background:transparent;color:var(--text-primary)}.popup-title-input:focus{border-bottom-color:var(--primary-color)}.time-row{display:flex;align-items:center;gap:8px}.popup-time-input{flex:1;padding:6px 8px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);font-size:13px;outline:none;background:var(--surface-color);color:var(--text-primary)}.popup-time-input:focus{border-color:var(--primary-color)}.time-separator{color:var(--text-secondary);font-size:14px}.popup-category-select{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);font-size:13px;background:var(--surface-color);outline:none;cursor:pointer;color:var(--text-primary)}.popup-category-select:focus{border-color:var(--primary-color)}.popup-actions{display:flex;justify-content:space-between;gap:8px;margin-top:16px;padding-top:12px;border-top:1px solid var(--border-color)}.popup-btn-delete,.popup-btn-save{padding:6px 16px;border:none;border-radius:var(--border-radius-sm);font-size:13px;cursor:pointer;transition:var(--transition-base)}.popup-btn-delete{background:transparent;color:var(--error-color)}.popup-btn-delete:hover{background:#fff5f5}.popup-btn-save{background:var(--primary-color);color:var(--text-on-primary)}.popup-btn-save:hover{background:var(--primary-dark)}.routine-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.routine-modal-content{background:var(--surface-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);padding:32px;width:90%;max-width:400px;animation:slideUp .3s ease-out}.routine-modal-title{font-family:Outfit,sans-serif;font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:24px;text-align:center}.routine-modal-input{width:100%;padding:14px 16px;font-size:16px;border:2px solid var(--border-color);border-radius:var(--border-radius-md);outline:none;transition:var(--transition-base);background-color:#f8fafc;color:var(--text-primary);margin-bottom:32px}.routine-modal-input:focus{border-color:var(--primary-color);background-color:var(--surface-color);box-shadow:0 0 0 4px #b7e5cd33}.routine-modal-actions{display:flex;justify-content:stretch;gap:12px}.routine-btn-cancel,.routine-btn-save{flex:1;padding:14px;border:none;border-radius:var(--border-radius-md);font-size:15px;font-weight:600;cursor:pointer;transition:var(--transition-base)}.routine-btn-cancel{background-color:#f1f5f9;color:var(--text-secondary)}.routine-btn-cancel:hover{background-color:#e2e8f0;color:var(--text-primary)}.routine-btn-save{background-color:var(--primary-color);color:var(--text-on-primary);box-shadow:0 4px 6px #b7e5cd33}.routine-btn-save:hover{background-color:var(--primary-dark);transform:translateY(-2px);box-shadow:0 6px 12px #b7e5cd4d}.category-manager{background:#fff;border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.category-manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.category-manager-header h3{margin:0;font-size:18px;font-weight:600}.btn-add-category{background:var(--primary-color);color:var(--text-on-primary);border:none;padding:8px 16px;border-radius:var(--border-radius-sm);cursor:pointer;font-size:14px;transition:var(--transition-base)}.btn-add-category:hover{background:var(--primary-dark)}.category-form{display:flex;align-items:center;gap:10px;padding:12px;background:#f8f9fa;border-radius:var(--border-radius-sm);margin-bottom:12px}.category-name-input{flex:1;padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);font-size:14px}.category-name-input:focus{outline:none;border-color:var(--primary-color)}.category-color-picker{width:50px;height:36px;border:1px solid #ddd;border-radius:4px;cursor:pointer}.category-form-actions{display:flex;gap:6px}.btn-save,.btn-cancel,.btn-edit,.btn-delete{padding:6px 12px;border:none;border-radius:4px;cursor:pointer;font-size:13px;transition:background .2s}.btn-save{background:var(--primary-color);color:var(--text-on-primary)}.btn-save:hover{background:var(--primary-dark)}.btn-cancel{background:#9e9e9e;color:#fff}.btn-cancel:hover{background:#757575}.btn-edit{background:#2196f3;color:#fff}.btn-edit:hover{background:#0b7dda}.btn-delete{background:#f44336;color:#fff}.btn-delete:hover{background:#da190b}.category-list{max-height:400px;overflow-y:auto}.category-item{display:flex;align-items:center;justify-content:space-between;padding:12px;border:1px solid #e0e0e0;border-radius:6px;margin-bottom:8px;transition:background .2s}.category-item:hover{background:#f8f9fa}.category-info{display:flex;align-items:center;gap:12px;flex:1}.category-color-box{width:24px;height:24px;border-radius:4px;border:1px solid #ddd}.category-name{font-size:14px;font-weight:500}.category-actions{display:flex;gap:6px}.no-categories{text-align:center;padding:40px 20px;color:#757575;font-size:14px}@media (max-width: 768px){.category-manager{padding:16px}.category-form{flex-wrap:wrap}.category-name-input{min-width:200px}.category-item{flex-direction:column;align-items:flex-start;gap:12px}.category-actions{width:100%;justify-content:flex-end}}.btn-add{background:#f7f6f3;color:var(--text-primary);border:1px solid var(--border-color);padding:6px 12px;border-radius:var(--border-radius-sm);cursor:pointer;font-size:13px;transition:var(--transition-base);display:flex;align-items:center;gap:4px;font-weight:500}.btn-add:hover{background:#efedea;border-color:#d3d1cb}.todo-category-list{margin-top:16px;max-height:400px;overflow-y:auto}.todo-category-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:6px;margin-bottom:8px;background:#fff;border:1px solid #f0f0f0;transition:all .2s}.todo-category-item:hover{background:#f7f6f3;border-color:#e9e9e7}.todo-category-info{display:flex;flex-direction:column;gap:4px}.todo-category-name{font-size:14px;font-weight:500;color:#37352f}.linked-event-category{font-size:12px;color:#787774;display:flex;align-items:center;gap:6px;background:#f0f0f0;padding:2px 6px;border-radius:4px;width:fit-content}.category-color-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.empty-state{text-align:center;padding:40px 20px;color:#9b9a97;font-size:14px;background:#f9f9f9;border-radius:8px;border:1px dashed #e0e0e0;margin-top:10px}.category-edit-form{background:#f7f6f3;padding:16px;border-radius:8px;margin-bottom:16px;border:1px solid #e9e9e7}.form-group{margin-bottom:12px}.form-group label{display:block;font-size:12px;color:#787774;margin-bottom:6px;font-weight:500}.form-group input,.form-group select{width:100%;padding:8px 10px;border:1px solid #e9e9e7;border-radius:4px;font-size:14px;background:#fff;color:#37352f}.form-group input:focus,.form-group select:focus{outline:none;border-color:#2383e2;box-shadow:0 0 0 2px #2383e21a}.form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.auth-container{min-height:100vh;display:flex;background-color:#fff;overflow:hidden}.auth-brand-section{flex:1;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);display:flex;flex-direction:column;justify-content:center;align-items:center;padding:60px;color:var(--text-on-primary);text-align:center;position:relative;overflow:hidden}.auth-brand-graphics{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none;overflow:hidden}.graphic-bg-gradient{position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at center,rgba(255,255,255,.4) 0%,transparent 60%);animation:rotate-bg 20s linear infinite}@keyframes rotate-bg{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.graphic-clock-face{position:absolute;top:50%;left:50%;width:min(700px,55vmin);height:min(700px,55vmin);border:1px solid rgba(255,255,255,.4);border-radius:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);box-shadow:0 0 60px #0000000d}.graphic-clock-face:before{content:"";position:absolute;top:50%;left:50%;width:70%;height:70%;border:1px dashed rgba(255,255,255,.5);border-radius:50%;transform:translate(-50%,-50%)}.clock-center{position:absolute;top:50%;left:50%;width:2.4%;height:2.4%;background:#fff;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 10px #ffffff80;z-index:2}.clock-hand{position:absolute;top:50%;left:50%;background:linear-gradient(to top,#fff,#fff3);transform-origin:bottom center;border-radius:4px;box-shadow:0 2px 4px #0000001a}.hour-hand{width:1.2%;height:24%;margin-left:-.6%;margin-top:-24%;animation:clock-spin 120s linear infinite}.minute-hand{width:.8%;height:36%;margin-left:-.4%;margin-top:-36%;opacity:.9;animation:clock-spin 20s linear infinite}@keyframes clock-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.graphic-cards-container{position:absolute;top:0;left:0;width:100%;height:100%}.glass-card{position:absolute;background:#ffffff40;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.6);border-radius:min(24px,2.5vmin);box-shadow:0 8px 32px #0000000d;display:flex;flex-direction:column;justify-content:center;padding:min(24px,2.5vmin);gap:min(12px,1.2vmin);animation:float-card-vertical 6s ease-in-out infinite}.card-top{width:min(220px,18vmin);height:min(140px,11vmin);top:20%;right:15%;animation-delay:0s;transform:rotate(5deg)}.card-middle{width:min(190px,16vmin);height:min(190px,16vmin);top:45%;left:15%;animation-delay:-2s;transform:rotate(-5deg);align-items:center}.card-bottom{width:min(250px,20vmin);height:min(160px,13vmin);bottom:15%;right:20%;animation-delay:-4s;transform:rotate(3deg);flex-direction:row;align-items:flex-end;justify-content:space-around;padding-bottom:min(30px,3vmin)}.card-line{height:min(10px,1vmin);background:#fff9;border-radius:4px;width:100%}.card-line.short{width:60%}.card-icon{width:min(50px,4.5vmin);height:min(50px,4.5vmin);border-radius:50%;background:#fff9;margin-bottom:min(12px,1.2vmin)}.card-content{width:80%;height:min(10px,1vmin);background:#ffffff80;border-radius:4px}.card-chart-bar{width:min(28px,2.5vmin);background:linear-gradient(to top,#fff,#fff6);border-radius:4px}.card-chart-bar:nth-child(1){height:40%}.card-chart-bar:nth-child(2){height:70%}.card-chart-bar:nth-child(3){height:50%}@keyframes float-card-vertical{0%,to{transform:translateY(0) rotate(var(--rotation, 0deg))}50%{transform:translateY(-20px) rotate(var(--rotation, 0deg))}}.card-top{--rotation: 5deg}.card-middle{--rotation: -5deg}.card-bottom{--rotation: 3deg}.auth-brand-content{max-width:480px;z-index:1;animation:fadeIn .8s ease-out;position:relative;bottom:auto;left:auto;text-align:center}.auth-brand-title{display:block;font-family:Outfit,sans-serif;font-size:56px;font-weight:800;margin-bottom:20px;line-height:1.1;letter-spacing:-1px;text-shadow:0 4px 12px rgba(0,0,0,.1)}.auth-brand-subtitle{font-size:18px;opacity:.9;line-height:1.6;font-weight:500;max-width:100%;text-shadow:none}.auth-form-section{flex:1;display:flex;align-items:center;justify-content:center;padding:40px;background-color:#fff;position:relative}.auth-box{width:100%;max-width:420px;padding:0;background:transparent;animation:slideUp .6s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.auth-title{font-size:32px;font-weight:800;color:var(--text-primary);margin-bottom:12px;letter-spacing:-.5px}.auth-subtitle{color:var(--text-secondary);margin-bottom:40px;font-size:16px}.auth-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:600;color:var(--text-primary)}.form-group input{padding:16px;font-size:16px;border:2px solid var(--border-color);border-radius:var(--border-radius-md);transition:var(--transition-base);outline:none;background-color:#f8fafc;color:var(--text-primary)}.form-group input:focus{border-color:var(--primary-color);background-color:#fff;box-shadow:0 0 0 4px #b7e5cd33}.form-group input::placeholder{color:var(--text-light)}.error-message{background-color:#fff5f5;color:var(--error-color);padding:14px;border-radius:var(--border-radius-md);font-size:14px;text-align:center;border:1px solid #fed7d7;display:flex;align-items:center;justify-content:center;gap:8px}.auth-button{padding:18px;font-size:16px;font-weight:700;color:var(--text-on-primary);background:var(--primary-color);border:none;border-radius:var(--border-radius-md);cursor:pointer;transition:var(--transition-base);margin-top:12px;box-shadow:0 4px 12px #b7e5cd66}.auth-button:hover:not(:disabled){transform:translateY(-2px);background:var(--primary-dark);box-shadow:0 8px 16px #b7e5cd80}.auth-button:active:not(:disabled){transform:translateY(0)}.auth-button:disabled{opacity:.7;cursor:not-allowed;background:var(--text-light);box-shadow:none}.auth-footer{margin-top:32px;text-align:center}.auth-footer p{color:var(--text-secondary);font-size:15px}.link-button{background:none;border:none;color:var(--primary-dark);font-weight:700;font-size:15px;cursor:pointer;padding:0 4px;transition:var(--transition-base)}.link-button:hover{color:var(--secondary-color);text-decoration:underline}@media (max-width: 960px){.auth-container{flex-direction:column}.auth-brand-section{flex:0 0 auto;padding:40px 24px;min-height:200px}.auth-brand-title{font-size:36px;margin-bottom:12px}.auth-brand-subtitle{font-size:16px}.auth-form-section{flex:1;padding:40px 24px;align-items:flex-start}.auth-box{margin:0 auto}}:root{--primary-color: #B7E5CD;--primary-dark: #96D1B5;--secondary-color: #8FD3B0;--accent-color: #ed64a6;--text-on-primary: #2d3748;--background-color: #f7fafc;--surface-color: #ffffff;--text-primary: #2d3748;--text-secondary: #718096;--text-light: #a0aec0;--border-color: #e2e8f0;--error-color: #e53e3e;--success-color: #38a169;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--border-radius-sm: 6px;--border-radius-md: 12px;--border-radius-lg: 20px;--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--transition-base: all .2s ease-in-out}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--background-color);color:var(--text-primary);line-height:1.5}h1,h2,h3,h4,h5,h6{font-family:Outfit,sans-serif;font-weight:700;color:var(--text-primary)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
