body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--primary:#3b82f6;--primary-hover:#2563eb;--background:#fff;--surface:#f9fafb;--surface-hover:#f3f4f6;--text:#111827;--text-secondary:#6b7280;--border:#e5e7eb;--success:#10b981;--error:#ef4444;--shadow:#0000001a;--sidebar-width:320px}[data-theme=dark]{--primary:#60a5fa;--primary-hover:#93bbfc;--background:#111827;--surface:#1f2937;--surface-hover:#374151;--text:#f9fafb;--text-secondary:#9ca3af;--border:#374151;--shadow:#0000004d}*{box-sizing:border-box;margin:0;padding:0}body{background:#fff;background:var(--background);color:#111827;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;transition:background .3s ease,color .3s ease}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.toolbar{background:#f9fafb;background:var(--surface);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border);height:56px;justify-content:space-between;padding:12px 20px}.menu-btn,.toolbar{align-items:center;display:flex}.menu-btn{background:#0000;border:none;border-radius:8px;color:#111827;color:var(--text);cursor:pointer;justify-content:center;padding:8px;transition:background .2s}.menu-btn:hover{background:#f3f4f6;background:var(--surface-hover)}.app-title{color:#3b82f6;color:var(--primary);font-size:24px;font-weight:700;letter-spacing:2px}.toolbar-actions{align-items:center;color:#6b7280;color:var(--text-secondary);display:flex;gap:12px}.sync-indicator{align-items:center;border-radius:4px;cursor:help;display:flex;justify-content:center;padding:4px}.sync-cloud{color:#10b981;color:var(--success)}.sync-local{color:#ef4444;color:var(--error)}.user-actions{align-items:center;display:flex;gap:8px;margin-left:12px}.toolbar-profile-image{border-radius:50%;height:24px;object-fit:cover;width:24px}.toolbar-user-name{color:#111827;color:var(--text);font-size:14px;font-weight:500}.toolbar-guest-badge{background:#ef4444;background:var(--error);border-radius:8px;color:#fff;font-size:11px;font-weight:600;padding:2px 6px}.logout-toolbar-btn{align-items:center;background:#0000;border:none;border-radius:4px;color:#6b7280;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:6px;transition:all .2s}.logout-toolbar-btn:hover{background:#f3f4f6;background:var(--surface-hover);color:#ef4444;color:var(--error)}.sidebar{background:#f9fafb;background:var(--surface);border-right:1px solid #e5e7eb;border-right:1px solid var(--border);height:100vh;left:0;overflow-y:auto;position:fixed;top:0;transform:translateX(-100%);transition:transform .3s ease;width:320px;width:var(--sidebar-width);z-index:1000}.sidebar.open{transform:translateX(0)}.sidebar-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:16px 20px}.sidebar-header h2{font-size:20px;font-weight:600}.close-btn{align-items:center;background:#0000;border:none;border-radius:4px;color:#6b7280;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:4px}.close-btn:hover{background:#f3f4f6;background:var(--surface-hover)}.sidebar-content{padding:20px}.settings-section{margin-bottom:28px}.section-header{align-items:center;display:flex;gap:8px;margin-bottom:12px}.section-header h3{font-size:16px;font-weight:600}.about-content{background:#fff;background:var(--background);border-radius:8px;margin-top:8px;padding:12px}.about-content p{color:#6b7280;color:var(--text-secondary);font-size:13px;line-height:1.5;margin-bottom:8px}.about-content strong{font-weight:600}.about-content strong,select{color:#111827;color:var(--text)}select{background:#fff;background:var(--background);border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:6px;cursor:pointer;font-size:14px;padding:8px 12px;width:100%}.categories-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.category-item{background:#fff;background:var(--background);border-radius:6px;justify-content:space-between;padding:8px 12px}.category-info,.category-item{align-items:center;display:flex}.category-info{gap:12px}.category-color{border-radius:4px;height:20px;width:20px}.category-item button{background:#0000;border:none;border-radius:4px;color:#6b7280;color:var(--text-secondary);cursor:pointer;opacity:.6;padding:4px;transition:opacity .2s}.category-item button:hover{color:#ef4444;color:var(--error);opacity:1}.add-category{align-items:center;display:flex;gap:8px}.add-category input[type=text]{background:#fff;background:var(--background);color:#111827;color:var(--text);flex:1 1;font-size:14px;padding:8px 12px}.add-category input[type=color],.add-category input[type=text]{border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:6px}.add-category input[type=color]{cursor:pointer;height:34px;padding:2px;width:40px}.add-category button{align-items:center;background:#3b82f6;background:var(--primary);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;justify-content:center;padding:6px}.add-category button:hover{background:#2563eb;background:var(--primary-hover)}.data-actions{display:flex;gap:8px}.btn-export,.btn-import{align-items:center;background:#fff;background:var(--background);border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:6px;color:#111827;color:var(--text);cursor:pointer;display:flex;flex:1 1;font-size:14px;gap:6px;justify-content:center;padding:10px;transition:background .2s}.btn-export:hover,.btn-import:hover{background:#f3f4f6;background:var(--surface-hover)}.main-content{display:flex;flex:1 1;flex-direction:column;overflow-y:auto;transition:margin-left .3s ease}.main-content.sidebar-open{margin-left:320px;margin-left:var(--sidebar-width)}.date-navigator{background:#f9fafb;background:var(--surface);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border);gap:20px;padding:20px}.date-navigator,.nav-btn{align-items:center;display:flex;justify-content:center}.nav-btn{background:#fff;background:var(--background);border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:8px;color:#111827;color:var(--text);cursor:pointer;padding:8px;transition:all .2s}.nav-btn:hover{background:#3b82f6;background:var(--primary);border-color:#3b82f6;border-color:var(--primary);color:#fff}.date-display{align-items:center;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:4px;padding:8px 16px;position:relative;transition:background .2s}.date-display:hover{background:#f3f4f6;background:var(--surface-hover)}.date-text{color:#111827;color:var(--text);font-size:18px;font-weight:600}.day-text{color:#6b7280;color:var(--text-secondary);font-size:14px}.today-badge{background:#10b981;background:var(--success);border-radius:10px;color:#fff;font-size:11px;padding:2px 6px;position:absolute;right:-8px;top:-8px}.category-tabs{background:#fff;background:var(--background);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border);display:flex;gap:12px;padding:16px 20px}.category-tab{background:#f9fafb;background:var(--surface);border:2px solid #0000;border-radius:8px;color:#111827;color:var(--text);cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s}.category-tab:hover{background:#f3f4f6;background:var(--surface-hover)}.category-tab.active{background:#fff;background:var(--background);border-color:#3b82f6;border-color:var(--category-color,var(--primary));color:#3b82f6;color:var(--category-color,var(--primary))}.tasks-view{flex:1 1;margin:0 auto;max-width:800px;padding:24px;width:100%}.task-section{margin-bottom:32px}.major-task-section{margin-bottom:40px}.task-section .section-header{align-items:center;border-bottom:2px solid #e5e7eb;border-bottom:2px solid var(--border);display:flex;gap:12px;margin-bottom:16px;padding-bottom:12px}.task-section h2{color:#111827;color:var(--text);font-size:20px;font-weight:600}.section-subtitle{color:#6b7280;color:var(--text-secondary);font-size:13px;margin-left:auto}.tasks-list{display:flex;flex-direction:column;gap:8px}.habits-list{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.task-item{align-items:center;background:#f9fafb;background:var(--surface);border:1px solid #e5e7eb;border:1px solid var(--border);border-radius:8px;cursor:pointer;display:flex;gap:12px;min-height:48px;padding:12px 16px;transition:all .2s}.task-item:hover{background:#f3f4f6;background:var(--surface-hover);border-color:#3b82f6;border-color:var(--primary)}.task-item.major-task{background:linear-gradient(135deg,#f9fafb,#f3f4f6);background:linear-gradient(135deg,var(--surface) 0,var(--surface-hover) 100%);border:2px solid #e5e7eb;border:2px solid var(--border);font-size:16px;min-height:64px}.task-item.major-task:hover{border-color:#3b82f6;border-color:var(--primary);box-shadow:0 4px 12px #0000001a;box-shadow:0 4px 12px var(--shadow);transform:translateY(-1px)}.task-item.completed{opacity:.7}.task-item.completed .task-text{color:#6b7280;color:var(--text-secondary);text-decoration:line-through}.task-item.editing{padding:8px}.task-item.editing input{background:#fff;background:var(--background);border:1px solid #3b82f6;border:1px solid var(--primary);border-radius:4px;color:#111827;color:var(--text);flex:1 1;font-size:14px;padding:6px 8px}.task-item.empty{background:#0000;border-style:dashed}.task-item.empty:hover{background:#f9fafb;background:var(--surface);border-style:solid}.task-checkbox{align-items:center;background:#fff;background:var(--background);border:2px solid #e5e7eb;border:2px solid var(--border);border-radius:4px;cursor:pointer;display:flex;height:20px;justify-content:center;transition:all .2s;width:20px}.task-checkbox:hover{border-color:#3b82f6;border-color:var(--primary)}.task-item.completed .task-checkbox{background:#10b981;background:var(--success);border-color:#10b981;border-color:var(--success);color:#fff}.task-text{color:#111827;color:var(--text);flex:1 1;font-size:14px}.placeholder{color:#6b7280;color:var(--text-secondary);flex:1 1;font-size:14px;font-style:italic}.btn-cancel,.btn-edit,.btn-save{align-items:center;background:#0000;border:none;border-radius:4px;color:#6b7280;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:4px}.btn-edit:hover{background:#f3f4f6;background:var(--surface-hover);color:#3b82f6;color:var(--primary)}.btn-save{color:#10b981;color:var(--success)}.btn-save:hover{background:#10b981;background:var(--success);color:#fff}.btn-cancel{color:#ef4444;color:var(--error)}.btn-cancel:hover{background:#ef4444;background:var(--error);color:#fff}.habit-item{min-height:44px}.app-loading{align-items:center;background:#fff;background:var(--background);display:flex;flex-direction:column;justify-content:center;min-height:100vh}.app-loading .loading-spinner{animation:spin 1s linear infinite;border:4px solid #e5e7eb;border-left:4px solid #3b82f6;border:4px solid var(--border);border-left-color:var(--primary);border-radius:50%;height:40px;margin-bottom:16px;width:40px}.app-loading p{color:#6b7280;color:var(--text-secondary);font-size:14px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.sidebar{width:100%}.main-content.sidebar-open{margin-left:0}.habits-list{grid-template-columns:1fr}.tasks-view{padding:16px}.section-subtitle{display:none}}.sign-in-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.sign-in-card{animation:slideIn .5s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:400px;padding:40px;width:100%}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.sign-in-header{margin-bottom:32px;text-align:center}.sign-in-header h1{color:#1f2937;font-size:28px;font-weight:700;margin:0 0 8px}.sign-in-subtitle{color:#6b7280;font-size:16px;line-height:1.5;margin:0}.error-message{background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px;margin-bottom:20px;padding:12px;text-align:center}.sign-in-buttons{display:flex;flex-direction:column;gap:16px}.google-sign-in-btn,.guest-sign-in-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:16px;font-weight:500;gap:12px;justify-content:center;min-height:48px;padding:12px 24px;transition:all .2s ease}.google-sign-in-btn{background:#fff;border:2px solid #e5e7eb;color:#374151}.google-sign-in-btn:hover:not(:disabled){border-color:#d1d5db;box-shadow:0 2px 4px #0000001a}.guest-sign-in-btn{background:#667eea;color:#fff}.guest-sign-in-btn:hover:not(:disabled){background:#5a67d8;box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.google-sign-in-btn:disabled,.guest-sign-in-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.google-icon,.guest-icon{flex-shrink:0;height:20px;width:20px}.guest-icon{fill:currentColor}.divider{align-items:center;display:flex;margin:8px 0}.divider:after,.divider:before{background:#e5e7eb;content:"";flex:1 1;height:1px}.divider span{color:#9ca3af;font-size:14px;font-weight:500;padding:0 16px}.sign-in-footer{margin-top:24px;text-align:center}.guest-note,.privacy-note{color:#6b7280;font-size:12px;line-height:1.4;margin:8px 0}.guest-note{color:#f59e0b;font-weight:500}@media (max-width:480px){.sign-in-card{margin:10px;padding:24px}.sign-in-header h1{font-size:24px}}
/*# sourceMappingURL=main.ef16247d.css.map*/