*{box-sizing:border-box;margin:0;padding:0}:root{--primary:#4361ee;--primary-light:#e8ecff;--bg:#f4f6fb;--card:#ffffff;--text:#1a1a2e;--text-sub:#6c757d;--border:#e2e8f0;--danger:#e74c3c;--success:#27ae60;--shadow:0 2px 8px rgba(0,0,0,0.08)}body{font-family:-apple-system,BlinkMacSystemFont,Hiragino Sans,Noto Sans JP,sans-serif;background:var(--bg);color:var(--text);min-height:100dvh;font-size:15px;-webkit-font-smoothing:antialiased}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}.app-header{background:var(--primary);color:white;padding:14px 16px;display:flex;align-items:center;justify-content:space-between;position:-webkit-sticky;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px rgba(67,97,238,.3)}.app-header h1{font-size:17px;font-weight:700}.notify-btn{background:rgba(255,255,255,.2);border:none;color:white;padding:6px 12px;border-radius:20px;font-size:13px;display:flex;align-items:center;gap:4px}.tabs{display:flex;overflow-x:auto;background:white;border-bottom:1px solid var(--border);scrollbar-width:none;-ms-overflow-style:none}.tabs::-webkit-scrollbar{display:none}.tab{padding:10px 14px;background:none;color:var(--text-sub);font-size:13px;white-space:nowrap;border:none;border-bottom:3px solid transparent;transition:all .15s}.tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.assignee-filter{display:flex;gap:6px;padding:10px 16px;background:white;border-bottom:1px solid var(--border);overflow-x:auto;scrollbar-width:none}.assignee-chip{padding:4px 12px;border-radius:20px;border:1.5px solid var(--border);background:white;font-size:12px;color:var(--text-sub);white-space:nowrap;transition:all .15s}.assignee-chip.active{background:var(--primary);border-color:var(--primary);color:white;font-weight:600}.task-list{padding:12px 16px;display:flex;flex-direction:column;gap:8px}.section-label{font-size:12px;font-weight:600;color:var(--text-sub);padding:8px 0 4px;text-transform:uppercase;letter-spacing:.05em}.task-card{background:var(--card);border-radius:12px;padding:12px 14px;box-shadow:var(--shadow);border:1px solid var(--border);display:flex;gap:10px;align-items:flex-start}.task-card.completed{opacity:.6}.task-check{width:22px;height:22px;border-radius:50%;border:2px solid var(--border);background:none;flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:1px;transition:all .15s}.task-check.done{background:var(--success);border-color:var(--success);color:white;font-size:12px}.task-body{flex:1 1;min-width:0}.task-title{font-size:15px;font-weight:500;line-height:1.3;word-break:break-all}.task-title.done{text-decoration:line-through;color:var(--text-sub)}.task-badges{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}.badge{color:white}.badge,.badge-outline{padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}.badge-outline{border:1.5px solid;background:transparent}.due-label{font-size:11px;color:var(--text-sub);display:flex;align-items:center;gap:3px}.due-label.overdue{color:var(--danger);font-weight:600}.task-memo{margin-top:6px;font-size:13px;color:var(--text-sub);line-height:1.4}.task-actions{display:flex;flex-direction:column;gap:4px;flex-shrink:0}.icon-btn{background:none;border:none;padding:4px;color:var(--text-sub);font-size:16px;border-radius:6px;line-height:1}.icon-btn:active{background:var(--bg)}.fab{bottom:24px;right:20px;width:56px;height:56px;border-radius:28px;background:var(--primary);color:white;border:none;font-size:28px;box-shadow:0 4px 16px rgba(67,97,238,.4);align-items:center;justify-content:center;z-index:200}.fab,.modal-overlay{position:fixed;display:flex}.modal-overlay{inset:0;background:rgba(0,0,0,.4);z-index:300;align-items:flex-end}.modal{background:white;border-radius:20px 20px 0 0;width:100%;max-height:90dvh;overflow-y:auto;padding:20px 20px 40px}.modal-handle{width:40px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 16px}.modal h2{font-size:17px;font-weight:700;margin-bottom:20px}.form-group{margin-bottom:14px}.form-group label{display:block;font-size:12px;font-weight:600;color:var(--text-sub);margin-bottom:5px;text-transform:uppercase;letter-spacing:.04em}.form-input{width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:10px;font-size:15px;background:var(--bg);color:var(--text);outline:none;transition:border-color .15s}.form-input:focus{border-color:var(--primary);background:white}.form-select{width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:10px;font-size:15px;background:var(--bg);color:var(--text);outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer}.btn-row{display:flex;gap:10px;margin-top:20px}.btn-primary{background:var(--primary);color:white;border:none;border-radius:12px;font-weight:600}.btn-primary,.btn-secondary{flex:1 1;padding:13px;font-size:15px}.btn-secondary{background:var(--bg);color:var(--text-sub);border:1.5px solid var(--border);border-radius:12px}.empty-state{text-align:center;padding:48px 20px;color:var(--text-sub);font-size:15px}.empty-state .icon{font-size:48px;margin-bottom:12px}.checklist-section{padding:12px 16px 80px}.checklist-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.checklist-header h2{font-size:16px;font-weight:700;color:var(--primary)}.reset-btn{padding:6px 14px;border:1.5px solid var(--primary);border-radius:20px;background:none;color:var(--primary);font-size:12px;font-weight:600}.checklist-item{background:var(--card);border-radius:12px;padding:12px 14px;box-shadow:var(--shadow);border:1px solid var(--border);display:flex;align-items:center;gap:10px;margin-bottom:8px}.checklist-checkbox{width:22px;height:22px;border-radius:6px;border:2px solid var(--border);background:none;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s;font-size:12px}.checklist-checkbox.checked{background:var(--primary);border-color:var(--primary);color:white}.checklist-name{flex:1 1;font-size:15px}.checklist-name.checked{text-decoration:line-through;color:var(--text-sub)}.add-item-row{display:flex;gap:8px;margin-top:12px}.add-item-row input{flex:1 1;padding:10px 12px;border:1.5px solid var(--border);border-radius:10px;font-size:15px;background:var(--bg);color:var(--text);outline:none}.add-item-row input:focus{border-color:var(--primary);background:white}.add-item-btn{padding:10px 16px;background:var(--primary);color:white;border:none;border-radius:10px;font-size:15px;font-weight:600}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:white;border-top:1px solid var(--border);display:flex;z-index:100}.nav-item{flex:1 1;padding:10px 4px;border:none;background:none;display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--text-sub);font-size:10px}.nav-item.active{color:var(--primary);font-weight:600}.nav-item .nav-icon{font-size:22px}