@import"https://fonts.googleapis.com/css2?family=DM+Serif+Display&family=DM+Sans:wght@300;400;500&display=swap";:root{--color-text-primary: #1A1A1A;--color-text-secondary: #555555;--color-text-tertiary: #888888;--color-bg-primary: #FFFFFF;--color-bg-secondary: #F5F5F3;--color-border-secondary: #E0E0DD;--color-border-tertiary: #EBEBEA;--green: #1D9E75;--green-light: #9FE1CB;--green-bg: #E1F5EE;--amber: #BA7517;--amber-bg: #FAEEDA;--purple: #534AB7;--purple-bg: #EEEDFE;--coral: #D85A30;--radius-lg: 12px;--radius-md: 8px;--radius-pill: 99px;--font-serif: "DM Serif Display", serif;--font-sans: "DM Sans", sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px}body{font-family:var(--font-sans);font-weight:400;color:var(--color-text-primary);background:#2a3a2e url(/forest-bg.jpg) center/cover no-repeat fixed;min-height:100vh;-webkit-font-smoothing:antialiased}#root{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px 16px}button{font-family:var(--font-sans);font-size:inherit;cursor:pointer;border:none;background:none;outline:none}input,select{font-family:var(--font-sans);font-size:inherit;outline:none}.app{width:100%;max-width:560px;height:calc(100vh - 40px);max-height:860px;background:var(--color-bg-primary);border-radius:30px;box-shadow:0 12px 60px #00000073,0 2px 12px #00000040;display:flex;flex-direction:column;overflow:hidden}.app-header{padding:28px 20px 14px;border-bottom:1px solid var(--color-border-tertiary);flex-shrink:0;background:var(--color-bg-primary)}.app-header__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.app-header__date{font-family:var(--font-serif);font-size:3em;font-weight:400;letter-spacing:-.01em;color:var(--color-text-primary)}.app-header__right{display:flex;align-items:center;gap:6px}.save-indicator{font-size:11px;color:var(--color-text-tertiary);opacity:0;transition:opacity .2s;pointer-events:none}.save-indicator[data-status=saving],.save-indicator[data-status=saved],.save-indicator[data-status=error]{opacity:1}.save-indicator[data-status=error]{color:var(--color-danger, #e53e3e)}.streak-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-pill);font-size:12px;font-weight:500}.streak-pill--neutral{background:#ebebea;color:var(--color-text-secondary)}.streak-pill--amber{background:var(--amber-bg);color:var(--amber)}.streak-pill--coral{background:#fae8e2;color:var(--coral)}.progress-bar-wrap{display:flex;align-items:center;gap:8px}.progress-bar-track{flex:1;height:4px;background:var(--color-border-tertiary);border-radius:var(--radius-pill);overflow:hidden}.progress-bar-fill{height:100%;background:var(--green);border-radius:var(--radius-pill);transition:width .3s ease}.progress-bar-label{font-size:12px;font-weight:500;color:var(--color-text-tertiary);white-space:nowrap}.tab-bar{display:grid;grid-template-columns:1fr 1fr 1fr;border-bottom:1px solid var(--color-border-tertiary);flex-shrink:0}.tab-btn{padding:11px 0;font-size:13px;font-weight:500;color:var(--color-text-tertiary);border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.tab-btn--active{color:var(--color-text-primary);border-bottom-color:var(--green)}.cat-filter{display:flex;gap:4px;padding:12px 16px;overflow-x:auto;scrollbar-width:none}.cat-filter::-webkit-scrollbar{display:none}.cat-pill{padding:4px 12px;border-radius:var(--radius-pill);font-size:12px;font-weight:500;color:var(--color-text-secondary);background:var(--color-bg-secondary);border:1px solid var(--color-border-secondary);white-space:nowrap;transition:all .15s}.cat-pill--active{font-weight:500}.app-main{flex:1;overflow-y:auto;overscroll-behavior:contain;padding-bottom:12px}.task-list{padding:0 16px}.empty-state{padding:20px 0;font-size:13px;color:var(--color-text-tertiary);text-align:center}.task-card{background:var(--color-bg-primary);border:.5px solid var(--color-border-secondary);border-radius:var(--radius-lg);padding:12px 13px;margin-bottom:8px;transition:opacity .2s}.task-card--done{opacity:.5}.task-card--postponed{opacity:.6}.task-card__main{display:flex;align-items:flex-start;gap:10px}.task-card__body{flex:1;min-width:0}.task-title{display:block;font-size:16px;font-weight:500;color:var(--color-text-primary);word-break:break-word;margin-bottom:6px}.task-card--done .task-title{text-decoration:line-through;color:var(--color-text-tertiary)}.task-card__meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.cat-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-pill);font-size:11px;font-weight:500}.postponed-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-pill);font-size:11px;font-weight:500;background:var(--amber-bg);color:var(--amber)}.subtask-mini-bar{display:flex;align-items:center;gap:5px;flex:1;max-width:100px}.subtask-mini-fill{flex:1;height:3px;background:var(--color-border-tertiary);border-radius:var(--radius-pill);position:relative;overflow:hidden}.subtask-mini-fill:after{content:"";position:absolute;left:0;top:0;bottom:0;width:var(--w, 0%);background:var(--green-light)}.subtask-mini-label{font-size:11px;color:var(--color-text-tertiary);white-space:nowrap}.task-check{width:20px;height:20px;min-width:20px;border-radius:50%;border:1.5px solid var(--color-border-secondary);display:flex;align-items:center;justify-content:center;margin-top:1px;transition:all .15s;color:#fff}.task-check--done{background:var(--green);border-color:var(--green)}.task-check:hover{border-color:var(--green)}.task-card__actions{display:flex;gap:2px;align-items:center;opacity:0;transition:opacity .15s}.task-card:hover .task-card__actions,.task-card:focus-within .task-card__actions{opacity:1}.task-action{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--color-text-tertiary);transition:background .1s,color .1s}.task-action:hover{background:var(--color-bg-secondary);color:var(--color-text-primary)}.task-action--ai:hover{color:var(--purple)}.task-action--danger:hover{color:#c0392b}.task-edit{display:flex;align-items:center;gap:4px;margin-bottom:6px}.task-edit__input{flex:1;border:1px solid var(--color-border-secondary);border-radius:var(--radius-md);padding:4px 8px;font-size:14px;color:var(--color-text-primary);background:var(--color-bg-primary)}.task-edit__input:focus{border-color:var(--green)}.task-edit__ok,.task-edit__cancel{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--color-text-secondary)}.task-edit__ok:hover{background:var(--green-bg);color:var(--green)}.task-edit__cancel:hover{background:#fee;color:#c0392b}.task-card__expanded{margin-top:10px;padding-top:10px;border-top:1px solid var(--color-border-tertiary)}.subtask-list{list-style:none;display:flex;flex-direction:column;gap:4px}.subtask-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--color-text-secondary)}.subtask-item--done .subtask-text{text-decoration:line-through;color:var(--color-text-tertiary)}.subtask-check{width:16px;height:16px;min-width:16px;border-radius:3px;border:1.5px solid var(--color-border-secondary);background:var(--color-bg-primary);position:relative;transition:all .12s}.subtask-check--done{background:var(--green-light);border-color:var(--green)}.subtask-check--done:after{content:"";position:absolute;left:4px;top:2px;width:5px;height:8px;border:2px solid var(--green);border-top:none;border-left:none;transform:rotate(45deg)}.subtask-check:hover{border-color:var(--green)}.subtask-text{flex:1}.subtask-add-form{display:flex;gap:6px;margin-top:8px}.subtask-add-input{flex:1;padding:5px 10px;border:1px solid var(--color-border-secondary);border-radius:var(--radius-md);font-size:13px;color:var(--color-text-primary);background:var(--color-bg-primary)}.subtask-add-input:focus{border-color:var(--green)}.subtask-add-btn{width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:var(--green-bg);color:var(--green);border-radius:var(--radius-md);transition:background .1s}.subtask-add-btn:hover{background:var(--green-light)}.ai-panel{margin-top:8px;background:var(--purple-bg);border-radius:var(--radius-md);padding:10px 12px}.ai-panel__loading{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--purple)}.ai-panel__header{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--purple);margin-bottom:8px}.ai-panel__list{list-style:none;display:flex;flex-direction:column;gap:4px}.ai-panel__item{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:13px;color:var(--color-text-secondary)}.ai-panel__add{width:22px;height:22px;min-width:22px;display:flex;align-items:center;justify-content:center;border-radius:4px;color:var(--purple);background:#534ab71f;transition:background .1s}.ai-panel__add:hover{background:#534ab738}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin .8s linear infinite}.postponed-section{padding:0 16px;margin-top:8px}.postponed-section__label{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary);margin-bottom:8px}.completion-banner{margin:0 16px 8px;padding:12px 16px;background:var(--green-bg);border-radius:var(--radius-lg);color:var(--green);font-size:14px;font-weight:500;text-align:center}.add-form{display:flex;gap:6px;padding:12px 16px;background:var(--color-bg-secondary);border-top:1px solid var(--color-border-tertiary);flex-shrink:0}.add-form__input{flex:1;padding:0 12px;height:40px;border:1px solid var(--color-border-secondary);border-radius:var(--radius-md);font-size:14px;color:var(--color-text-primary);background:var(--color-bg-primary)}.add-form__input:focus{border-color:var(--green)}.add-form__select{padding:0 8px;height:40px;border:1px solid var(--color-border-secondary);border-radius:var(--radius-md);font-size:13px;color:var(--color-text-secondary);background:var(--color-bg-primary);max-width:100px}.add-form__btn{width:40px;height:40px;min-width:40px;display:flex;align-items:center;justify-content:center;background:var(--green);color:#fff;border-radius:var(--radius-md);transition:opacity .15s}.add-form__btn:hover{opacity:.88}.rollover-banner{display:flex;gap:12px;padding:14px 16px;background:var(--amber-bg);border-bottom:1px solid #F0D8A8}.rollover-banner__icon{color:var(--amber);padding-top:2px}.rollover-banner__title{font-size:14px;font-weight:500;color:var(--color-text-primary);margin-bottom:2px}.rollover-banner__sub{font-size:13px;color:var(--color-text-secondary);margin-bottom:10px}.rollover-banner__actions{display:flex;gap:6px;flex-wrap:wrap}.rollover-btn{padding:6px 12px;border-radius:var(--radius-md);font-size:13px;font-weight:500;border:1px solid var(--color-border-secondary);color:var(--color-text-secondary);background:var(--color-bg-primary);transition:background .15s}.rollover-btn:hover{background:var(--color-bg-secondary)}.rollover-btn--primary{background:var(--amber);color:#fff;border-color:var(--amber)}.rollover-btn--primary:hover{opacity:.88;background:var(--amber)}.someday-tab{padding:0 16px}.someday-tab>.add-form{margin:12px 0;padding:12px;border-radius:var(--radius-lg);border:1px solid var(--color-border-secondary);border-top:1px solid var(--color-border-secondary)}.someday-list{list-style:none;display:flex;flex-direction:column;gap:6px}.someday-item{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--color-bg-primary);border:.5px solid var(--color-border-secondary);border-radius:var(--radius-md)}.someday-item__title{flex:1;font-size:14px;color:var(--color-text-primary)}.someday-item__actions{display:flex;gap:2px;opacity:0;transition:opacity .15s}.someday-item:hover .someday-item__actions{opacity:1}.review-tab{padding:16px;display:flex;flex-direction:column;gap:16px}.review-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px}.stat-card{background:var(--color-bg-secondary);border-radius:var(--radius-lg);padding:14px 16px;display:flex;flex-direction:column;gap:4px}.stat-number{font-size:28px;font-weight:300;color:var(--color-text-primary);line-height:1}.stat-label{font-size:12px;color:var(--color-text-tertiary)}.review-streak{background:var(--color-bg-secondary);border-radius:var(--radius-lg);padding:14px 16px}.review-streak__header{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--color-text-secondary);margin-bottom:12px}.streak-dots{display:flex;gap:8px}.streak-dot{width:28px;height:28px;border-radius:50%;background:var(--color-border-tertiary);border:2px solid transparent}.streak-dot--hit{background:var(--green)}.streak-dot--today{border-color:var(--green);background:var(--color-bg-primary)}.streak-dot--hit.streak-dot--today{background:var(--green);border-color:transparent}.review-postponed{background:var(--amber-bg);border-radius:var(--radius-lg);padding:14px 16px}.review-postponed__title{font-size:13px;font-weight:500;color:var(--amber);margin-bottom:8px}.review-postponed__list{list-style:none;margin-bottom:12px;display:flex;flex-direction:column;gap:4px}.review-postponed__item{font-size:13px;color:var(--color-text-secondary);padding:4px 0}.review-postponed__actions{display:flex;gap:8px;flex-wrap:wrap}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{width:100%;max-width:380px;background:var(--color-bg-primary);border-radius:24px;padding:36px 32px;box-shadow:0 12px 60px #00000073,0 2px 12px #00000040}.auth-title{font-family:var(--font-serif);font-size:1.6rem;font-weight:400;margin-bottom:8px}.auth-sub{font-size:13px;color:var(--color-text-secondary);margin-bottom:24px}.auth-form{display:flex;flex-direction:column;gap:10px}.auth-input{padding:10px 12px;border:1px solid var(--color-border-secondary);border-radius:var(--radius-md);font-size:14px;color:var(--color-text-primary);background:var(--color-bg-primary)}.auth-input:focus{border-color:var(--green)}.auth-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;background:var(--green);color:#fff;border-radius:var(--radius-md);font-size:14px;font-weight:500;transition:opacity .15s}.auth-btn:hover:not(:disabled){opacity:.88}.auth-btn:disabled{opacity:.6;cursor:not-allowed}.auth-sent{display:flex;align-items:center;gap:10px;color:var(--green);font-size:14px}.auth-error{font-size:12px;color:#c0392b}.auth-pw-wrap{position:relative}.auth-pw-wrap .auth-input{width:100%;padding-right:40px}.auth-pw-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--color-text-tertiary);display:flex;align-items:center;padding:0}.auth-pw-toggle:hover{color:var(--color-text-primary)}.auth-links{display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:14px}.auth-switch{background:none;border:none;cursor:pointer;font-size:13px;color:var(--color-text-tertiary);text-decoration:underline;text-underline-offset:2px;padding:0}.auth-switch:hover{color:var(--color-text-primary)}@media (max-width: 600px){#root{padding:0;align-items:stretch}.app{border-radius:0;height:100vh;max-height:none;box-shadow:none}.task-card__actions,.someday-item__actions{opacity:1}.app-header__date{font-size:2.2em}.app-header{padding:20px 16px 12px}}
