*{-webkit-tap-highlight-color:transparent}:root{--bg: #f5f0eb;--text: #3d3529;--accent: #c96442;--sonata: #b8947a;--opera: #a68b6b;--duty: #8c7a6a;--tab-bg: #ede8e2;--tab-active: #c96442}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%}body{font-family:"Noto Serif SC",Georgia,Times New Roman,serif;background-color:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{display:flex;flex-direction:column;max-width:480px;margin:0 auto}.main-content{flex:1;padding:24px 16px;overflow-y:auto}.tab-bar{display:flex;background:var(--tab-bg);border-top:1px solid #e0dbd5;flex-shrink:0}.tab-bar button{flex:1;padding:10px 0 12px;border:none;background:none;font-family:inherit;font-size:13px;color:var(--text);opacity:.5;cursor:pointer;transition:opacity .25s ease,color .25s ease;display:flex;flex-direction:column;align-items:center;gap:2px}.tab-bar button.active{opacity:1;color:var(--tab-active)}.tab-bar button:hover{opacity:.8}.tab-bar button .tab-icon{line-height:1}.page-placeholder{display:flex;align-items:center;justify-content:center;height:100%;font-size:18px;opacity:.4}.today-page{display:flex;flex-direction:column;height:100%;position:relative}.date-nav{display:flex;align-items:center;justify-content:space-between;padding:16px 4px 8px;flex-shrink:0}.date-arrow{width:44px;height:44px;border:none;background:none;font-size:24px;color:var(--text);cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s}.date-arrow:hover{background:#0000000d}.date-display{display:flex;align-items:center;gap:8px}.date-text{font-size:16px;font-weight:600;letter-spacing:.5px}.today-badge{font-size:11px;background:var(--accent);color:#fff;padding:2px 8px;border-radius:10px}.progress-bar-wrapper{display:flex;align-items:center;gap:8px;padding:0 4px 12px;flex-shrink:0}.progress-bar-track{flex:1;height:3px;background:#e5e0da;border-radius:2px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .4s ease}.progress-label{font-size:12px;opacity:.5;flex-shrink:0}.task-list{flex:1;overflow-y:auto;padding-bottom:100px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60%;opacity:.35}.empty-title{font-size:16px;margin-bottom:6px}.empty-hint{font-size:13px}.task-group{margin-bottom:12px}.group-header{display:flex;align-items:center;justify-content:space-between;padding:6px 4px;margin-bottom:6px}.group-label{font-size:12px;font-weight:600;display:flex;align-items:center;gap:6px;text-transform:uppercase;letter-spacing:1px}.group-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.group-count{font-size:12px;opacity:.4}.task-card{display:flex;align-items:center;gap:8px;padding:6px 8px;margin:2px 0;border-radius:4px;transition:opacity .3s ease,background .2s;cursor:default;user-select:none;-webkit-user-select:none;min-height:44px}.task-card:active{background:#00000008}.task-card.done{opacity:.45}.task-card.done .task-text{text-decoration:line-through}.checkbox{width:15px;height:15px;border-radius:50%;border:1.5px solid;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:10px;color:#fff;transition:background .25s,border-color .25s;padding:0}.checkbox:not(.checked){background:none}.checkbox.checked{color:#fff}.task-text{flex:1;font-size:16px;line-height:1.4;word-break:break-word}.review-page{display:flex;flex-direction:column;height:100%}.review-summary{display:flex;justify-content:space-around;padding:16px 8px;margin-bottom:8px}.summary-item{display:flex;flex-direction:column;align-items:center;gap:2px}.summary-value{font-size:24px;font-weight:600;font-family:"Noto Serif SC",Georgia,serif}.summary-label{font-size:11px;opacity:.5;letter-spacing:.5px}.review-write{padding:0 4px;display:flex;flex-direction:column;flex:1}.review-display{flex:1;padding:14px;border:1.5px solid transparent;border-radius:10px;cursor:pointer;transition:background .2s;min-height:180px}.review-display:hover{background:#00000005}.review-saved-text{font-size:15px;line-height:1.7;color:var(--text);white-space:pre-wrap}.review-placeholder{font-size:15px;line-height:1.7;color:#bfb5a8}.review-edit-block{display:flex;flex-direction:column}.review-textarea{width:100%;height:140px;min-height:120px;max-height:150px;border:1.5px solid #e0dbd5;border-radius:10px;padding:14px;font-family:"Noto Serif SC",Georgia,serif;font-size:15px;color:var(--text);background:#fff;resize:none;outline:none;line-height:1.7;transition:border-color .2s;box-sizing:border-box}.review-textarea:focus{border-color:#c9b8a8}.review-textarea::placeholder{color:#bfb5a8}.review-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}.review-cancel-btn{padding:10px 20px;border:1.5px solid #e0dbd5;border-radius:8px;background:none;font-family:inherit;font-size:14px;color:var(--text);cursor:pointer;min-height:44px}.review-save-btn{padding:10px 20px;border:none;border-radius:8px;background:var(--accent);color:#fff;font-family:inherit;font-size:14px;cursor:pointer;transition:background .2s;min-height:44px}.review-save-btn:hover{background:#b5583a}.stats-page{display:flex;flex-direction:column;height:100%;padding-bottom:16px}.range-selector{display:flex;gap:8px;padding:16px 0 12px}.range-btn{flex:1;padding:8px 4px;border:1.5px solid #e0dbd5;border-radius:8px;background:none;font-family:inherit;font-size:13px;color:var(--text);cursor:pointer;transition:all .2s;min-height:44px}.range-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.range-btn:hover:not(.active){background:#00000008}.stats-empty{display:flex;align-items:center;justify-content:center;flex:1;opacity:.35;font-size:16px}.chart-section{margin-bottom:24px}.chart{display:flex;align-items:flex-end;gap:3px;height:140px;padding:0 4px}.chart-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;min-width:0}.chart-bars{flex:1;width:100%;display:flex;flex-direction:column;justify-content:flex-end;position:relative}.chart-bar{border-radius:2px 2px 0 0;transition:height .4s ease;min-height:0}.total-bar{background:#e5e0da;width:100%;position:absolute;bottom:0}.done-bar{background:var(--accent);width:100%;position:absolute;bottom:0;z-index:1}.chart-label{font-size:9px;opacity:.5;margin-top:4px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.attr-section{margin-bottom:24px}.section-title{font-size:14px;font-weight:600;margin-bottom:12px;opacity:.7}.attr-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.attr-name{width:52px;font-size:12px;opacity:.7;flex-shrink:0}.attr-track{flex:1;height:6px;background:#e5e0da;border-radius:3px;overflow:hidden}.attr-fill{height:100%;border-radius:3px;transition:width .4s ease}.attr-count{width:24px;font-size:13px;text-align:right;opacity:.6}.rate-section{display:flex;flex-direction:column;align-items:center;padding:16px 0}.rate-value{font-size:48px;font-weight:600;font-family:"Noto Serif SC",Georgia,serif;color:var(--accent)}.rate-detail{font-size:14px;opacity:.4;margin-top:4px}.settings-page{display:flex;flex-direction:column;gap:24px;padding:16px 4px}.settings-section{display:flex;flex-direction:column}.settings-section-title{font-size:12px;font-weight:600;opacity:.4;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.settings-item{display:flex;align-items:center;justify-content:space-between;padding:14px 4px;border:none;border-bottom:1px solid #ece7e1;background:none;font-family:inherit;font-size:15px;color:var(--text);cursor:pointer;min-height:48px;text-align:left}.settings-item:last-of-type{border-bottom:none}.settings-item:hover{background:#00000005}.settings-arrow{font-size:20px;opacity:.3}.settings-error{margin-top:8px;padding:10px 12px;background:#fdf0ee;color:#c94442;border-radius:8px;font-size:13px}.import-confirm{margin-top:12px;padding:14px;background:#fff;border:1.5px solid #e0dbd5;border-radius:10px}.import-confirm-text{font-size:14px;margin-bottom:12px}.import-confirm-actions{display:flex;gap:8px;justify-content:flex-end}.import-cancel{padding:8px 16px;border:1.5px solid #e0dbd5;border-radius:8px;background:none;font-family:inherit;font-size:13px;color:var(--text);cursor:pointer;min-height:44px}.import-ok{padding:8px 16px;border:none;border-radius:8px;background:var(--accent);color:#fff;font-family:inherit;font-size:13px;cursor:pointer;min-height:44px}.settings-info{padding:12px 4px;text-align:center}.settings-app-name{font-size:20px;font-weight:600;margin-bottom:2px}.settings-version{font-size:13px;opacity:.4;margin-bottom:6px}.settings-tagline{font-size:14px;opacity:.5;font-style:italic}.toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);background:var(--text);color:#fff;padding:10px 20px;border-radius:8px;font-size:14px;z-index:100;animation:toastIn .2s ease}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.fab{position:fixed;bottom:80px;right:calc(50% - 224px);width:52px;height:52px;border-radius:50%;border:none;background:var(--accent);color:#fff;font-size:28px;cursor:pointer;box-shadow:0 4px 12px #00000026;display:flex;align-items:center;justify-content:center;transition:transform .25s ease,background .2s;z-index:10}@media(max-width:480px){.fab{right:16px}}.fab:hover{transform:scale(1.05)}.add-form-overlay{position:fixed;inset:0;background:#00000040;z-index:50;display:flex;justify-content:center;animation:fadeIn .2s ease}.add-form{width:calc(100% - 32px);max-width:448px;background:#fff;border-radius:14px;box-shadow:0 12px 32px #0000002e;padding:20px 16px 16px;margin-top:200px;align-self:flex-start;position:relative;animation:slideDown .25s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.need-selector{display:flex;gap:8px;margin-bottom:12px}.need-btn{flex:1;padding:8px 4px;border:1.5px solid;border-radius:8px;background:none;font-family:inherit;font-size:12px;cursor:pointer;transition:all .2s;min-height:44px}.need-btn:hover{opacity:.85}.add-input-row{display:flex;gap:8px}.add-input{flex:1;border:1.5px solid #e0dbd5;border-radius:8px;padding:10px 12px;font-family:inherit;font-size:14px;color:var(--text);background:var(--bg);outline:none;transition:border-color .2s}.add-input:focus{border-color:var(--accent)}.add-confirm{padding:10px 18px;border:none;border-radius:8px;background:var(--accent);color:#fff;font-family:inherit;font-size:14px;cursor:pointer;transition:background .2s;position:relative;z-index:10;display:flex;align-items:center;justify-content:center;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;min-width:44px;min-height:44px}.add-confirm:hover{background:#b5583a}.context-menu{position:fixed;z-index:100;background:#fff;border-radius:10px;box-shadow:0 6px 20px #00000026;overflow:hidden;animation:contextIn .2s ease;min-width:120px}@keyframes contextIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.context-item{display:block;width:100%;padding:12px 16px;border:none;background:none;font-family:inherit;font-size:14px;color:var(--text);text-align:left;cursor:pointer;transition:background .15s;min-height:44px}.context-item:hover{background:#0000000a}.context-item.delete{color:#c94442}.context-item.delete-confirm{color:#fff;background:#c94442}.context-item.delete-confirm:hover{background:#b33a38}.edit-overlay{position:fixed;inset:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:50;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.edit-panel{width:calc(100% - 48px);max-width:400px;background:#fff;border-radius:14px;padding:20px;box-shadow:0 12px 32px #0000002e;animation:scaleIn .2s ease}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.edit-actions{display:flex;gap:8px;margin-top:12px;justify-content:flex-end}.edit-cancel{padding:10px 18px;border:1.5px solid #e0dbd5;border-radius:8px;background:none;font-family:inherit;font-size:14px;color:var(--text);cursor:pointer;min-height:44px}.edit-save{padding:10px 18px;border:none;border-radius:8px;background:var(--accent);color:#fff;font-family:inherit;font-size:14px;cursor:pointer;min-height:44px}.edit-save:hover{background:#b5583a}
