@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;padding-top:70px}.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:fixed;top:0;left:0;right:0;width:100%;z-index:1000;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:45% 55%;gap:1px;background:#e9e9e7;min-height:calc(100vh - 50px);max-width:var(--page-max-width);margin:0 auto;width:100%;overflow-anchor:none}.left-panel,.right-panel{background:#fff;padding:24px;overflow-y:visible;overflow-anchor:none}.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:0 12px;height:38px;border-radius:6px;cursor:pointer;font-size:14px;color:#37352f;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap}.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;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;touch-action:pan-y;overflow-anchor:none}.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;word-break:break-word;overflow-wrap:anywhere}.event-time{font-size:10px;opacity:.7}.resize-handle{opacity:0;transition:opacity .2s}.event-block-absolute.event-active .resize-handle{opacity:.3;background:#0003}.event-block-absolute.event-active .resize-handle:hover{opacity:.6!important;background:#0006!important}.event-block-absolute.event-active{box-shadow:0 0 0 2px var(--primary-color);transition:box-shadow .2s}@media (max-width: 768px){.event-block-absolute.long-press-active{transform:scale(1.02);box-shadow:0 4px 12px #b7e5cd66;transition:transform .1s ease-out}.event-block-absolute.event-active .resize-handle{opacity:.4;background:#00000026}}.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:#fff;border:1px 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-wrapper{position:relative;width:100%;height:100%}.image-skeleton{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px}.image-thumbnail{width:100%;height:100%;object-fit:cover;cursor:pointer;display:block}.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:1px dashed #d0d0ce;background:#fff;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}.image-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:fadeIn .2s ease-in-out}.image-modal-content{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;animation:zoomIn .2s ease-in-out}.image-modal-media{width:90vw;max-width:900px;height:calc(90vh - 60px);display:flex;align-items:center;justify-content:center}@keyframes zoomIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.image-modal-content img{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 10px 40px #00000080}.image-modal-nav{position:fixed;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;border:none;background:#ffffff26;color:#fff;font-size:28px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10001}.image-modal-nav:hover{background:#ffffff40;transform:translateY(-50%) scale(1.08)}.image-modal-prev{left:24px}.image-modal-next{right:24px}.image-modal-close{position:absolute;top:-40px;right:0;width:36px;height:36px;background:#ffffff26;color:#fff;border:none;border-radius:50%;cursor:pointer;font-size:24px;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.image-modal-close:hover{background:#ffffff40;transform:scale(1.1)}.image-modal-filename{margin-top:16px;color:#ffffffe6;font-size:14px;text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 768px){.image-modal-prev{left:12px}.image-modal-next{right:12px}.image-modal-nav{width:40px;height:40px;font-size:24px}}.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;display:flex;flex-direction:column;gap:0}.todo-item{display:flex;flex-direction:column;align-items:stretch;position:relative;padding:6px 4px;border-bottom:1px solid #efefef;border-radius:0;transition:all .3s ease;cursor:default;background:transparent;width:100%}.todo-item:hover{box-shadow:none}.todo-item:hover>.todo-content-wrapper{background:#0000000a}.todo-item.dragging{background:#f0f0f0;z-index:1000;box-shadow:0 8px 24px #0003}.todo-item.dragging-collapsed{height:0;padding:0;margin:0;border:0;overflow:hidden}.todo-item.dragging-collapsed .todo-content-wrapper{min-height:0;padding:0}.todo-item.suppress-border{border-bottom-color:transparent}.todo-content-wrapper{display:flex;align-items:center;gap:10px;width:100%;background:#fff;transition:padding .28s cubic-bezier(.2,.7,.2,1),background-color .2s ease,background-position .28s ease;position:relative}.todo-content-wrapper.drop-before:before,.todo-content-wrapper.drop-after:after{content:"";position:absolute;left:0;right:0;height:4px;background-color:#4a9eff;border-radius:2px}.todo-content-wrapper.drop-before:before{top:-2px}.todo-content-wrapper.drop-after:after{bottom:-2px}.todo-content-wrapper.drop-inside{background-color:#eaf3ff;outline:2px solid #4a9eff;outline-offset:-2px}.todo-tree-branch{position:absolute;left:-14px;top:22px;width:14px;height:1px;background-color:#e0e0e0}.todo-drag-handle{cursor:grab;color:#9b9a97;font-size:16px;-webkit-user-select:none;user-select:none;flex-shrink:0;position:absolute;left:-16px;top:50%;transform:translateY(-50%);opacity:0;pointer-events:none;transition:opacity .2s ease}.todo-item:hover .todo-drag-handle{opacity:1;pointer-events:auto}.todo-drag-handle:active{cursor:grabbing}.expand-button-spacer{display:inline-block;width:3px;height:14px;margin-right:0}.expand-button{display:inline-flex;align-items:center;justify-content:center;width:3px;height:14px;padding:0;margin-right:0;line-height:1}.todo-leading{display:inline-flex;align-items:center;gap:3px}.todo-checkbox{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:18px;height:18px;border:.5px solid #b6b6b6;border-radius:6px;cursor:pointer;flex-shrink:0;margin:0;background-color:#fff;display:grid;place-content:center;transition:all .2s}.todo-checkbox:checked{background-color:#5ba585;border-color:#5ba585}.todo-checkbox:checked:after{content:"";width:5px;height:9px;border:solid white;border-width:0 2.5px 2.5px 0;transform:rotate(45deg);margin-top:-2px}.todo-checkbox:hover{border-color:#cbd5e0}.todo-text{flex:1;font-size:13px;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:4px}.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 6px;border-radius:12px;font-size:10px;color:#fff;font-weight:500;flex-shrink:0}.todo-eisenhower-controls{display:flex;align-items:center;gap:6px;margin-left:auto}.todo-eisenhower-row{display:flex;gap:6px;flex-wrap:wrap}.eisenhower-chip{border:1px solid #e3e3e1;background:#f7f6f3;color:#37352f;border-radius:999px;padding:4px 10px;font-size:11px;cursor:pointer;transition:all .2s ease}.eisenhower-chip.active{background:#4a9eff;border-color:#4a9eff;color:#fff}.eisenhower-chip.tiny{padding:2px 6px;font-size:10px}.todo-quadrant-badge{border-radius:8px;padding:2px 6px;font-size:10px;font-weight:600;color:#1f2937;background:#e5e7eb}.todo-quadrant-badge.quadrant-Q1{background:#fee2e2;color:#991b1b}.todo-quadrant-badge.quadrant-Q2{background:#ffedd5;color:#9a3412}.todo-quadrant-badge.quadrant-Q3{background:#fef9c3;color:#854d0e}.todo-quadrant-badge.quadrant-Q4{background:#e5e7eb;color:#374151}.todo-matrix{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:12px}.todo-matrix-cell{border:1px solid #e6e6e4;border-radius:10px;background:#fff;padding:10px;min-height:140px}.todo-matrix-cell.drop-active{border-color:#4a9eff;box-shadow:0 0 0 2px #4a9eff26}.todo-matrix-title{display:flex;justify-content:space-between;font-size:12px;font-weight:600;color:#525252;margin-bottom:8px}.todo-matrix-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.todo-matrix-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:6px 8px;border-radius:8px;background:#f9fafb}.todo-matrix-text{font-size:12px;color:#1f2937}.todo-matrix-text.completed{text-decoration:line-through;color:#9ca3af}.todo-matrix-actions{display:flex;align-items:center;gap:4px}.todo-matrix-empty{font-size:12px;color:#9b9a97;padding:4px 0}.btn-category-settings-small.active{background:#eaf3ff}.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:#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}.pomodoro-modal{background:#fff;border-radius:24px;padding:40px;max-width:420px;width:90%;box-shadow:0 20px 60px #00000026;position:relative;display:flex;flex-direction:column;align-items:center;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}.pomodoro-modal.fullscreen{max-width:100%;width:100%;height:100%;border-radius:0;padding:0;justify-content:center}.pomodoro-content-wrapper{display:flex;flex-direction:column;align-items:center;width:100%}.pomodoro-modal.fullscreen .pomodoro-content-wrapper{height:100%;justify-content:center}.pomodoro-timer-section{display:flex;flex-direction:column;align-items:center;width:100%}.pomodoro-modal.fullscreen .pomodoro-timer-section{max-width:600px;align-items:center}.pomodoro-close{position:absolute;top:20px;right:20px;background:#f1f2f6;border:none;width:36px;height:36px;border-radius:50%;font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#747d8c;transition:all .2s;z-index:10}.pomodoro-close:hover{background:#e4e5e9;color:#2f3542;transform:rotate(90deg)}.pomodoro-header{text-align:center;margin-bottom:20px;width:100%}.pomodoro-modal.fullscreen .pomodoro-header{text-align:center;margin-bottom:40px}.pomodoro-todo-title{font-size:22px;font-weight:800;color:#2c3e50;margin-bottom:12px;line-height:1.3}.pomodoro-modal.fullscreen .pomodoro-todo-title{font-size:32px}.pomodoro-count-display{font-size:15px;font-weight:600;color:#7f8c8d;background:#f8f9fa;padding:8px 16px;border-radius:20px;display:inline-flex;align-items:center;gap:6px}.pomodoro-modal.fullscreen .pomodoro-count-display{font-size:18px;padding:10px 20px}.pomodoro-circle-container{position:relative;width:100%;max-width:340px;aspect-ratio:1;height:auto;margin:20px auto;display:flex;justify-content:center;align-items:center}.pomodoro-modal.fullscreen .pomodoro-circle-container{height:55vh;width:auto;aspect-ratio:1;max-height:500px;margin:0 auto 30px}.pomodoro-hamster-wrapper{position:absolute;top:42%;left:50%;transform:translate(-50%,-50%);width:80%;height:60%;z-index:1;display:flex;justify-content:center;align-items:center;overflow:visible}.pomodoro-hamster-wrapper .hamster-container{transform:scale(.85);margin-bottom:0;height:100%;width:100%}.pomodoro-modal.fullscreen .pomodoro-hamster-wrapper .hamster-container{transform:scale(1.2)}.pomodoro-circle{width:100%;height:100%;transform:rotate(-90deg);position:relative;z-index:2;pointer-events:none}.pomodoro-time{position:absolute;bottom:18%;left:50%;transform:translate(-50%);font-size:42px;font-weight:800;color:#2c3e50;font-variant-numeric:tabular-nums;letter-spacing:-1px;text-align:center;z-index:3;text-shadow:0 2px 10px rgba(255,255,255,.8)}.pomodoro-modal.fullscreen .pomodoro-time{font-size:64px;bottom:15%;margin-bottom:0}.pomodoro-controls{display:flex;gap:12px;width:100%;justify-content:center;margin-bottom:16px}.pomodoro-modal.fullscreen .pomodoro-controls{justify-content:center}.pomodoro-btn{padding:16px 32px;border:none;border-radius:16px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);flex:1;max-width:140px;display:flex;align-items:center;justify-content:center}.pomodoro-btn:active{transform:scale(.95)}.pomodoro-btn-primary{background:#ff6b6b;color:#fff;box-shadow:0 4px 12px #ff6b6b4d}.pomodoro-btn-primary:hover{background:#ff5252;transform:translateY(-2px);box-shadow:0 8px 20px #ff6b6b66}.pomodoro-btn-secondary{background:#f1f2f6;color:#57606f}.pomodoro-btn-secondary:hover{background:#e4e5e9;color:#2f3542}.pomodoro-actions{display:flex;gap:16px}.pomodoro-modal.fullscreen .pomodoro-actions{justify-content:center}.pomodoro-action-btn{background:none;border:none;color:#a4b0be;font-size:14px;font-weight:600;cursor:pointer;padding:8px 12px;border-radius:8px;transition:all .2s}.pomodoro-action-btn:hover{color:#747d8c;background:#f1f2f6}@media (max-width: 480px){.pomodoro-modal{padding:24px;width:95%}.pomodoro-circle-container{max-width:280px}.pomodoro-modal.fullscreen{padding:20px;justify-content:center}.pomodoro-modal.fullscreen .pomodoro-circle-container{width:100%;max-width:300px;height:auto;aspect-ratio:1;margin:0 auto 30px}.pomodoro-modal.fullscreen .pomodoro-header{text-align:center;margin-bottom:20px}.pomodoro-modal.fullscreen .pomodoro-controls,.pomodoro-modal.fullscreen .pomodoro-actions{justify-content:center}.pomodoro-modal.fullscreen .pomodoro-time{font-size:48px;bottom:15%}.pomodoro-modal.fullscreen .pomodoro-hamster-wrapper .hamster-container{transform:scale(1)}.pomodoro-time{font-size:36px;bottom:15%}.pomodoro-todo-title{font-size:18px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pageFlip{0%,to{transform:rotateY(0)}25%{transform:rotateY(-15deg)}50%{transform:rotateY(0)}75%{transform:rotateY(15deg)}}@keyframes pageFlipLeft{0%,to{transform:skewY(0)}33%{transform:skewY(-8deg)}66%{transform:skewY(5deg)}}@keyframes pageFlipRight{0%,to{transform:skewY(0)}33%{transform:skewY(8deg)}66%{transform:skewY(-5deg)}}.hamster-reading .left-page{animation:pageFlipLeft 1.5s ease-in-out infinite;transform-origin:center}.hamster-reading .right-page{animation:pageFlipRight 1.5s ease-in-out infinite;transform-origin:center}.pomodoro-modal.fullscreen .hamster-reading{width:280px;height:280px}.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}.template-buttons{display:flex;gap:8px;align-items:center}.template-btn{padding:6px 12px;background:#f7f6f3;color:#37352f;border:1px solid #e9e9e7;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s;white-space:nowrap}.template-btn:hover{background:#e9e9e7;border-color:#d0d0ce}.template-btn-manage{background:#2383e2;color:#fff;border-color:#2383e2}.template-btn-manage:hover{background:#1a6ec7;border-color:#1a6ec7}.template-modal{width:90%;max-width:600px}.template-textarea{width:100%;min-height:300px;padding:12px;border:1px solid #e9e9e7;border-radius:4px;font-size:14px;font-family:inherit;resize:vertical}.template-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-wrapper{position:relative;width:100%;height:70px;margin-top:auto}.monthly-thumbnail-skeleton{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:6px}.monthly-thumbnail{width:100%;height:70px;object-fit:cover;border-radius:6px;display:block;-webkit-transform:translateZ(0);transform:translateZ(0)}.monthly-events-list{display:flex;flex-direction:column;gap:2px;margin-bottom:4px;overflow:hidden;margin-left:-12px;margin-right:-12px;width:calc(100% + 24px)}.monthly-event-item{font-size:10px;padding:2px 4px;border-radius:3px;border-left-width:2px;border-left-style:solid;white-space:normal;overflow:hidden;text-overflow:ellipsis;line-height:1.3;font-weight:600;margin-left:12px;margin-right:12px;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.monthly-event-item.continuation-left{border-top-left-radius:0;border-bottom-left-radius:0;border-left:none;margin-left:0;padding-left:16px}.monthly-event-item.continuation-right{border-top-right-radius:0;border-bottom-right-radius:0;margin-right:0}.monthly-event-spacer{height:18px;margin-bottom:2px}.monthly-event-more{font-size:10px;color:#888;padding-left:14px}@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:auto;min-height:500px;overflow-x:auto;overflow-y:visible;-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;position:relative}.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}.tt-calendar-tooltip{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:8px;box-shadow:0 4px 12px #00000026;min-width:200px;max-width:300px;pointer-events:none}.tt-tooltip-item{display:flex;align-items:flex-start;gap:8px;padding:4px 0;border-bottom:1px solid #f0f0f0}.tt-tooltip-item:last-child{border-bottom:none}.tt-tooltip-color{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0}.tt-tooltip-content{flex:1}.tt-has-events-dot{width:4px;height:4px;background-color:#eb5757;border-radius:50%;position:absolute;top:4px;right:4px}.stats-calendar-tooltip{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:8px;box-shadow:0 4px 12px #00000026;min-width:200px;max-width:300px;pointer-events:none}.stats-tooltip-item{display:flex;align-items:flex-start;gap:8px;padding:4px 0;border-bottom:1px solid #f0f0f0}.stats-tooltip-item:last-child{border-bottom:none}.stats-tooltip-color{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0}.stats-tooltip-content{flex:1}.stats-tooltip-title{font-size:13px;font-weight:500;color:#333;margin-bottom:2px}.stats-tooltip-time{font-size:12px;color:#666}.stats-has-events-dot{width:4px;height:4px;background-color:#eb5757;border-radius:50%;position:absolute;top:2px;right:2px}.day-col{position:relative}@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){.App{padding-top:120px}.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}.header{padding:12px 16px;flex-direction:column;align-items:flex-start;gap:12px;height:auto}.header-title{width:100%;text-align:left}.header>.header-actions{width:100%;justify-content:space-between;margin-left:0;padding-right:0}.user-info{padding-left:0;border-left:none}.user-email{display:none}.logout-btn{white-space:nowrap;padding:6px 12px}.date-selector{gap:8px;justify-content:flex-start;flex-wrap:nowrap}.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))}.timeline-grid{max-width:100%;overflow-x:auto}.timeline-columns{grid-template-columns:1fr 50px 1fr;max-width:100%;min-width:100%}.timeline-header{grid-template-columns:1fr 50px 1fr}.time-tracker-date-header{padding:12px 0}.current-date{font-size:16px}.left-panel,.right-panel,.main-container{max-width:100vw;overflow-x:hidden}}.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;position:sticky;left:0;z-index:15}.stats-table .routine-name,.stats-table .mood-label{text-align:left;font-weight:700;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}.category-time-cell{font-size:11px;cursor:pointer;transition:all .2s;text-align:center;padding:8px 4px}.category-time-cell:hover{transform:scale(1.05);font-weight:600}.category-time-cell.weekend{background-color:#fffbf5}.category-label{font-size:13px;padding:8px 12px;text-align:left;font-weight:700;border-right:1px solid #e0e0e0;background:#fafafa;white-space:nowrap;position:sticky;left:0;z-index:5}.category-label-content{display:flex;align-items:center;gap:8px}.category-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.category-total-time{font-size:12px;font-weight:600;color:#333;text-align:center}.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:8px}.monthly-header{gap:8px;margin-bottom:16px;grid-template-columns:44px 1fr 44px;grid-template-rows:auto auto}.monthly-header .header-actions{grid-column:1 / -1;grid-row:2;margin-top:8px}.current-month{font-size:20px}.view-mode-selector.header-inline{width:100%}.view-mode-btn{padding:8px 10px;white-space:nowrap}.monthly-grid{gap:1px;border-radius:6px}.monthly-day-header{padding:8px 4px}.monthly-day-cell{padding:6px;min-height:100px;gap:4px}.monthly-event-item{padding:3px 4px;line-height:1.3;white-space:normal;overflow:hidden;text-overflow:ellipsis;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.monthly-event-spacer{height:16px}.monthly-event-more{padding:2px 4px}.monthly-thumbnail-wrapper,.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}@media (max-width: 480px){.monthly-container{padding:6px}.monthly-header{gap:6px;margin-bottom:12px;grid-template-columns:44px 1fr 44px}.current-month{font-size:18px}.view-mode-btn{padding:6px 8px}.monthly-grid{gap:1px}.monthly-day-header{padding:6px 2px}.monthly-day-cell{padding:4px;min-height:90px;gap:3px}.monthly-event-item{padding:2px 3px;line-height:1.2;white-space:normal;overflow:hidden;text-overflow:ellipsis;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.monthly-event-spacer{height:14px}.monthly-event-more{padding:1px 3px}.monthly-thumbnail-wrapper,.monthly-thumbnail{height:50px}.monthly-events-list{gap:2px}}.toastui-editor-mode-switch,.toastui-editor-tabs,.toastui-editor-md-tab-container,.toastui-editor .tab-item{display:none!important}.toastui-editor-defaultUI{background-color:#fff}.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: #4F46E5;--primary-dark: #4338CA;--secondary-color: #10B981;--text-main: #1F2937;--text-sub: #4B5563;--bg-light: #F9FAFB;--bg-white: #FFFFFF;--bg-dark: #111827;--gradient-hero: linear-gradient(135deg, #EEF2FF 0%, #E0E7FF 100%)}.landing-container{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:var(--text-main);background-color:var(--bg-white);overflow-x:hidden}.landing-header{position:fixed;top:0;left:0;right:0;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;border-bottom:1px solid rgba(0,0,0,.05)}.landing-nav{display:flex;justify-content:space-between;align-items:center;padding:15px 40px;max-width:1200px;margin:0 auto}.nav-logo{display:flex;align-items:center;gap:10px;font-size:1.5rem;font-weight:700;color:var(--primary-color)}.mobile-menu-btn{display:none}.nav-links{display:flex;justify-content:space-between;align-items:center;flex:1;margin-left:40px}.nav-menu{display:flex;gap:30px}.nav-link{background:none;border:none;font-size:1rem;color:var(--text-sub);cursor:pointer;font-weight:500;transition:color .2s;padding:5px 0}.nav-link:hover{color:var(--primary-color)}.nav-auth{display:flex;gap:15px}.btn-text{background:none;border:none;font-size:1rem;color:var(--text-sub);cursor:pointer;padding:10px 20px;font-weight:500}.btn-text:hover{color:var(--primary-color)}.btn-primary{background-color:var(--primary-color);color:#fff;border:none;padding:10px 24px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.btn-primary:hover{background-color:var(--primary-dark)}.btn-secondary{background-color:#fff;color:var(--primary-color);border:1px solid var(--primary-color);padding:10px 24px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.btn-secondary:hover{background-color:#eef2ff}.btn-lg{padding:14px 32px;font-size:1.1rem}.btn-xl{padding:18px 40px;font-size:1.2rem}.hero-section{display:flex;align-items:center;justify-content:space-between;padding:140px 40px 80px;max-width:1200px;margin:0 auto;gap:60px}.hero-content{flex:1;max-width:600px}.hero-title{font-size:3.5rem;line-height:1.2;font-weight:800;margin-bottom:24px;color:#111827}.highlight{color:var(--primary-color);position:relative;display:inline-block}.highlight:after{content:"";position:absolute;bottom:5px;left:0;width:100%;height:12px;background-color:#4f46e533;z-index:-1}.hero-subtitle{font-size:1.25rem;color:var(--text-sub);line-height:1.6;margin-bottom:40px}.hero-cta{display:flex;gap:16px}.hero-image{flex:1;display:flex;justify-content:center}.dashboard-preview{width:100%;max-width:500px;aspect-ratio:4/3;background:#fff;border-radius:20px;box-shadow:0 20px 50px #0000001a;border:1px solid #E5E7EB;padding:20px;display:flex;flex-direction:column;gap:15px;transform:perspective(1000px) rotateY(-5deg) rotateX(5deg);transition:transform .3s ease}.dashboard-preview:hover{transform:perspective(1000px) rotateY(0) rotateX(0)}.preview-header{height:40px;background:#f3f4f6;border-radius:10px;width:100%}.preview-body{flex:1;display:flex;gap:15px}.preview-sidebar{width:80px;background:#f3f4f6;border-radius:10px;height:100%}.preview-content{flex:1;display:flex;flex-direction:column;gap:15px}.preview-chart{height:120px;background:#eef2ff;border-radius:10px;border:1px dashed #C7D2FE}.preview-list{flex:1;display:flex;flex-direction:column;gap:10px}.preview-item{height:30px;background:#f9fafb;border-radius:6px;border:1px solid #E5E7EB}.problem-section{padding:100px 40px;background-color:#f3f4f6;text-align:center}.problem-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px;max-width:1200px;margin:60px auto 40px}.problem-card{background:#fff;padding:30px;border-radius:16px;box-shadow:0 4px 6px #0000000d}.problem-icon{font-size:3rem;margin-bottom:20px}.problem-card p{font-size:1.1rem;color:var(--text-sub);line-height:1.6}.problem-solution-arrow{font-size:3rem;color:var(--primary-color);margin:20px 0;animation:bounce 2s infinite}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.problem-conclusion h3{font-size:1.8rem;color:var(--primary-color);font-weight:700}.solution-section{padding:100px 40px;background-color:var(--bg-white);text-align:center}.solution-values{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:20px;max-width:1000px;margin:60px auto 0;text-align:left}.value-item{display:flex;align-items:center;gap:15px;font-size:1.2rem;color:var(--text-main);padding:20px;background:#eef2ff;border-radius:12px}.check-icon{font-size:1.5rem}.features-section{padding:100px 40px;background-color:var(--bg-light)}.landing-section-header{text-align:center;max-width:700px;margin:0 auto 60px;display:block}.landing-section-header h2{font-size:2.5rem;font-weight:700;margin-bottom:16px;color:#111827}.landing-section-header p{font-size:1.2rem;color:var(--text-sub)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:40px;max-width:1200px;margin:0 auto}.feature-card{background:#fff;padding:40px;border-radius:16px;box-shadow:0 4px 6px #0000000d;transition:transform .3s ease,box-shadow .3s ease}.feature-card:hover{transform:translateY(-5px);box-shadow:0 10px 20px #0000001a}.feature-icon-wrapper{font-size:3rem;margin-bottom:20px;background:#eef2ff;width:80px;height:80px;display:flex;align-items:center;justify-content:center;border-radius:20px}.feature-card h3{font-size:1.5rem;font-weight:700;margin-bottom:12px;color:#111827}.feature-card p{color:var(--text-sub);line-height:1.6}.workflow-section{padding:100px 40px;max-width:1200px;margin:0 auto}.workflow-steps{display:flex;justify-content:space-between;align-items:flex-start;margin-top:60px}.step{flex:1;text-align:center;padding:0 20px}.step-time{display:inline-block;padding:8px 16px;background-color:var(--primary-color);color:#fff;border-radius:20px;font-weight:600;margin-bottom:20px}.step h3{font-size:1.5rem;margin-bottom:12px;color:#111827}.step p{color:var(--text-sub);line-height:1.6}.step-divider{font-size:2rem;color:#d1d5db;padding-top:10px}.differentiation-section{padding:100px 40px;background-color:var(--bg-light)}.comparison-table-wrapper{max-width:1000px;margin:0 auto;overflow-x:auto}.comparison-table{width:100%;border-collapse:collapse;background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 6px #0000000d}.comparison-table th,.comparison-table td{padding:20px;text-align:left;border-bottom:1px solid #E5E7EB}.comparison-table th{background-color:#f9fafb;font-weight:700;font-size:1.1rem}.comparison-table .highlight-col{background-color:#eef2ff;color:var(--primary-dark);font-weight:600}.trust-section{padding:80px 40px;background-color:#fff;text-align:center}.pricing-section{padding:100px 40px;background-color:var(--bg-white);text-align:center}.pricing-card{max-width:400px;margin:0 auto;background:#fff;border-radius:20px;box-shadow:0 10px 30px #0000001a;border:2px solid var(--primary-color);padding:40px;position:relative;overflow:hidden}.pricing-card:before{content:"BEST VALUE";position:absolute;top:20px;right:-30px;background:var(--secondary-color);color:#fff;padding:5px 40px;transform:rotate(45deg);font-size:.8rem;font-weight:700}.pricing-header{margin-bottom:30px}.pricing-header h3{font-size:1.5rem;color:var(--primary-color);margin-bottom:10px}.price{font-size:3rem;font-weight:800;color:#111827;margin-bottom:10px}.period{font-size:1rem;color:var(--text-sub);font-weight:400}.pricing-features ul{list-style:none;padding:0;margin:0 0 30px;text-align:left}.pricing-features li{padding:10px 0;border-bottom:1px solid #F3F4F6;color:var(--text-main)}.pricing-features li:last-child{border-bottom:none}.btn-full{width:100%;padding:16px;font-size:1.1rem}.trust-grid{display:flex;justify-content:center;gap:40px;flex-wrap:wrap;margin-top:40px}.trust-item{display:flex;align-items:center;gap:10px;font-size:1.2rem;color:var(--text-sub);padding:15px 30px;background:#f9fafb;border-radius:50px}.faq-section{padding:100px 40px;background-color:var(--bg-light)}.faq-list{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:15px}.faq-item{background:#fff;border-radius:16px;box-shadow:0 2px 4px #0000000d;overflow:hidden;cursor:pointer;transition:all .3s ease}.faq-item:hover{box-shadow:0 4px 12px #0000001a}.faq-question{padding:25px 30px;display:flex;justify-content:space-between;align-items:center}.faq-question h3{font-size:1.1rem;margin:0;color:#111827;font-weight:600}.faq-toggle-icon{font-size:1.5rem;color:var(--primary-color);font-weight:300;transition:transform .3s ease}.faq-item.active .faq-toggle-icon{transform:rotate(180deg)}.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease;background-color:#f9fafb}.faq-item.active .faq-answer{max-height:200px;padding:0 30px 25px;border-top:1px solid #F3F4F6}.faq-answer p{margin:0;color:var(--text-sub);line-height:1.6;padding-top:20px}.bottom-cta-section{padding:100px 40px;background-color:var(--primary-color);color:#fff;text-align:center}.bottom-cta-content h2{font-size:2.5rem;font-weight:700;margin-bottom:30px}.cta-benefits{display:flex;justify-content:center;gap:30px;margin-bottom:40px;flex-wrap:wrap}.cta-benefits span{font-size:1.2rem;font-weight:500}.bottom-cta-content .btn-primary{background-color:#fff;color:var(--primary-color)}.bottom-cta-content .btn-primary:hover{background-color:#f3f4f6}.landing-footer{background-color:#111827;color:#9ca3af;padding:80px 40px 40px}.footer-content{max-width:1200px;margin:0 auto 60px;display:flex;justify-content:space-between}.footer-brand .logo-text{color:#fff;font-size:1.5rem;font-weight:700;display:block;margin-bottom:10px}.footer-links{display:flex;gap:80px}.link-group h4{color:#fff;font-size:1.1rem;margin-bottom:20px}.link-group a{display:block;color:#9ca3af;text-decoration:none;margin-bottom:12px;transition:color .2s}.link-group a:hover{color:#fff}.footer-bottom{max-width:1200px;margin:0 auto;padding-top:40px;border-top:1px solid #374151;text-align:center;font-size:.9rem}@media (max-width: 768px){.landing-nav{padding:15px 20px}.mobile-menu-btn{display:block;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-main);padding:5px}.nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;padding:20px;box-shadow:0 4px 6px -1px #0000001a;margin-left:0;gap:20px;border-top:1px solid #eee;align-items:stretch}.nav-links.active{display:flex}.nav-menu{flex-direction:column;align-items:center;gap:15px;width:100%}.nav-auth{flex-direction:column;width:100%;gap:10px}.nav-auth button{width:100%;text-align:center}.nav-link{width:100%;text-align:center;padding:10px}.hero-section{flex-direction:column;text-align:center;padding:100px 20px 60px;gap:40px}.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.1rem}.hero-cta{flex-direction:column;width:100%}.hero-cta .btn-primary,.hero-cta .btn-secondary{width:100%;justify-content:center;display:flex}.hero-image{width:100%;margin-top:20px}.dashboard-preview{transform:none;aspect-ratio:auto;width:100%;max-width:100%;margin:20px auto 0;padding:15px;border-radius:12px;border-width:1px;border-color:#e5e7eb;height:auto;min-height:300px}.dashboard-preview:hover{transform:none}.preview-sidebar{display:none}.preview-header{height:30px;margin-bottom:10px}.preview-chart{height:100px}.features-section,.problem-section,.solution-section,.workflow-section,.pricing-section,.faq-section,.bottom-cta-section{padding:60px 20px}.landing-section-header h2{font-size:2rem}.workflow-steps{flex-direction:column;gap:20px;align-items:center}.step-divider{display:block;transform:rotate(90deg);margin:10px 0;color:#d1d5db;width:fit-content}.step{padding:20px;background:#f9fafb;border-radius:16px;width:100%}.step p br{display:none}.landing-section-header h2{font-size:1.8rem;word-break:keep-all}.solution-values{grid-template-columns:1fr}.value-item{flex-direction:column;text-align:center}.pricing-card{width:100%;padding:30px 20px}.faq-question{padding:20px}.faq-question h3{font-size:1rem}.bottom-cta-content h2{font-size:2rem}.landing-footer{padding:60px 20px 30px}.footer-content{flex-direction:column;gap:40px}.footer-links{flex-direction:column;gap:30px}}.settings-modal{max-width:500px;width:90%;max-height:85vh;overflow-y:auto;padding:0;border-radius:12px;box-shadow:0 10px 25px #00000026;background:#fff}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:0 20px;border-bottom:1px solid #eee}.settings-header-left{display:flex;align-items:center;gap:12px}.btn-back{background:none;border:none;font-size:20px;color:#333;cursor:pointer;padding:0;line-height:1;display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;transition:background-color .2s}.btn-back:hover{background-color:#f0f0f0}.settings-header h2{margin:0;font-size:20px;font-weight:600;color:#333}.btn-close-icon{background:none;border:none;font-size:24px;color:#999;cursor:pointer;padding:0;line-height:1;transition:color .2s}.btn-close-icon:hover{color:#333}.settings-body{padding:24px}.settings-list{display:flex;flex-direction:column}.settings-item{display:flex;align-items:center;padding:16px;border-radius:12px;cursor:pointer;transition:background-color .2s;border:1px solid transparent}.settings-item:hover{background-color:#f8f9fa;border-color:#eee}.settings-item-icon{font-size:24px;margin-right:16px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background-color:#e3f2fd;border-radius:8px}.settings-item-content{flex:1}.settings-item-title{font-size:16px;font-weight:600;color:#333;margin-bottom:4px}.settings-item-desc{font-size:13px;color:#666}.settings-item-arrow{font-size:20px;color:#ccc;margin-left:12px}.settings-section{margin-bottom:0}.section-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.section-icon{font-size:20px}.settings-section h3{margin:0;font-size:16px;font-weight:600;color:#333}.settings-description{color:#666;font-size:14px;margin-bottom:20px;line-height:1.5}.icloud-input-container{display:flex;gap:10px;margin-bottom:24px}.icloud-url-input{flex:1;padding:10px 12px;font-size:14px;border:1px solid #ddd;border-radius:8px;outline:none;transition:border-color .2s}.icloud-url-input:focus{border-color:#007bff}.icloud-url-input:disabled{background-color:#f5f5f5;color:#888}.btn-subscribe,.btn-unsubscribe{padding:0 20px;font-size:14px;font-weight:500;border:none;border-radius:8px;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-subscribe{background-color:#007bff;color:#fff}.btn-subscribe:hover:not(:disabled){background-color:#0056b3}.btn-subscribe:disabled{background-color:#ccc;cursor:not-allowed}.btn-unsubscribe{background-color:#fff;color:#dc3545;border:1px solid #dc3545}.btn-unsubscribe:hover{background-color:#dc3545;color:#fff}.settings-help-card{background-color:#f8f9fa;padding:20px;border-radius:12px;border:1px solid #eee}.settings-help-card h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#333}.settings-help-card ol{margin:0;padding-left:20px;color:#555;font-size:13px;line-height:1.6}.settings-help-card li{margin-bottom:6px}.settings-help-card li:last-child{margin-bottom:0}.settings-help-card strong{color:#333;font-weight:600}.settings-btn{font-size:18px;padding:8px 12px;background-color:transparent;border:none;cursor:pointer;transition:background-color .2s;border-radius:4px}.settings-btn:hover{background-color:#0000000d}.calendar-list{margin-bottom:24px}.calendar-list-title{font-size:14px;font-weight:600;color:#333;margin:0 0 12px}.calendar-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background-color:#f8f9fa;border-radius:8px;margin-bottom:8px;border:1px solid #eee}.calendar-item-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.calendar-color-indicator{width:12px;height:12px;border-radius:50%;flex-shrink:0}.calendar-item-info{flex:1;min-width:0}.calendar-item-name{font-size:14px;font-weight:600;color:#333;margin-bottom:4px;display:flex;align-items:center;gap:6px}.calendar-type-icon{font-size:16px}.calendar-item-url{font-size:12px;color:#666;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calendar-item-actions{display:flex;gap:8px;flex-shrink:0}.btn-toggle-calendar{width:28px;height:28px;border-radius:50%;border:2px solid #ddd;background:#fff;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-toggle-calendar.enabled{background-color:#28a745;border-color:#28a745;color:#fff}.btn-toggle-calendar.disabled{background-color:#fff;border-color:#ddd;color:#999}.btn-delete-calendar{width:28px;height:28px;border-radius:50%;border:none;background-color:#dc3545;color:#fff;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-delete-calendar:hover{background-color:#c82333}.add-calendar-form{background-color:#f8f9fa;padding:20px;border-radius:12px;border:1px solid #eee;margin-bottom:20px}.form-title{font-size:14px;font-weight:600;color:#333;margin:0 0 16px}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;font-weight:600;color:#555;margin-bottom:6px}.form-input{width:100%;padding:10px 12px;font-size:14px;border:1px solid #ddd;border-radius:8px;outline:none;transition:border-color .2s;box-sizing:border-box}.form-input:focus{border-color:#007bff}.color-picker{display:flex;gap:8px;flex-wrap:wrap}.color-option{width:32px;height:32px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:all .2s}.color-option:hover{transform:scale(1.1)}.color-option.selected{border-color:#333;box-shadow:0 0 0 2px #fff,0 0 0 4px #333}.btn-add-calendar{width:100%;padding:12px;background-color:var(--primary-color);color:var(--text-on-primary);border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:8px}.btn-add-calendar:hover:not(:disabled){background-color:var(--primary-dark)}.btn-add-calendar:disabled{background-color:#ccc;cursor:not-allowed}.calendar-type-selector{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.type-option{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;background-color:#fff;border:2px solid #ddd;border-radius:8px;cursor:pointer;transition:all .2s}.type-option:hover{border-color:#007bff;background-color:#f8f9fa}.type-option.selected{border-color:#007bff;background-color:#e3f2fd}.type-icon{font-size:24px}.type-name{font-size:12px;font-weight:500;color:#333;text-align:center;line-height:1.2}.help-section{margin-bottom:16px}.help-section:last-child{margin-bottom:0}.help-section strong{display:block;margin-bottom:6px;font-size:13px}.help-section ol{margin:0;padding-left:20px}.help-section li{font-size:12px;line-height:1.5;margin-bottom:4px}.calendar-edit-form{width:100%;background-color:#fff;padding:16px;border-radius:8px;border:2px solid #007bff;box-sizing:border-box}.form-label-small{display:block;font-size:13px;font-weight:600;color:#37352f;margin-bottom:6px}.form-input-small{width:100%;padding:10px 12px;font-size:14px;border:1px solid #e9e9e7;background-color:#f7f6f3;border-radius:6px;outline:none;transition:all .2s;box-sizing:border-box;color:#37352f}.form-input-small:focus{background-color:#fff;border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.color-picker-inline{display:flex;align-items:center;gap:12px}.color-input{flex:1;height:36px;border:1px solid #e9e9e7;background-color:#f7f6f3;border-radius:6px;cursor:pointer;outline:none;padding:2px;min-width:100px}.predefined-colors{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.color-option-small{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all .2s;padding:0}.color-option-small:hover{transform:scale(1.1)}.color-option-small.selected{border-color:#333;box-shadow:0 0 0 2px #fff,0 0 0 4px #333}.edit-actions{display:flex;gap:8px;margin-top:20px;align-items:center}.btn-save-edit,.btn-cancel-edit,.btn-delete-edit{height:36px;padding:0 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-save-edit{flex:1;background-color:var(--primary-color);color:var(--text-on-primary);border:none}.btn-save-edit:hover:not(:disabled){background-color:var(--primary-dark)}.btn-save-edit:disabled{background-color:#ccc;cursor:not-allowed}.btn-cancel-edit{flex:1;background-color:#fff;color:#37352f;border:1px solid #e9e9e7}.btn-cancel-edit:hover{background-color:#f7f6f3}.btn-delete-edit{background-color:#fff;color:#dc3545;border:1px solid #dc3545;margin-right:auto;min-width:60px}.btn-delete-edit:hover{background-color:#fff5f5}.btn-edit-calendar{width:28px;height:28px;border-radius:50%;border:none;background-color:#007bff;color:#fff;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-edit-calendar:hover{background-color:#0056b3}.color-picker-with-input{display:flex;flex-direction:column;gap:12px}.color-picker-with-input .color-input{width:60px;height:40px}.btn-show-add-form{width:100%;padding:12px;background-color:var(--primary-color);border:none;border-radius:8px;color:var(--text-on-primary);font-size:14px;cursor:pointer;margin-bottom:20px;display:flex;align-items:center;justify-content:center;gap:8px;transition:background-color .2s}.btn-show-add-form:hover{background-color:var(--primary-dark)}.btn-icon-edit{width:28px;height:28px;border:none;background:none;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;color:#94a3b8;transition:all .2s}.btn-icon-edit:hover{background-color:#e2e8f0;color:#3b82f6}: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;overflow-anchor:none}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}
