*{box-sizing:border-box}body{margin:0;font-family:Helvetica Neue,Arial,sans-serif;background:#f4f2ee;color:#2b2b2b}.loading.full-page{display:flex;align-items:center;justify-content:center;height:100vh;font-size:14px;color:#999}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center}.auth-card{background:#fff;border:1px solid #e2ddd3;border-radius:4px;padding:32px;width:320px;display:flex;flex-direction:column;gap:14px}.auth-card h1{font-size:20px;margin:0;font-weight:600}.auth-subtitle{margin:0;color:#777;font-size:13px}.auth-card label{display:flex;flex-direction:column;font-size:12px;color:#666;gap:4px}.auth-card input{font-size:14px;padding:8px 10px;border:1px solid #ddd6c9;border-radius:3px}.auth-card button[type=submit]{margin-top:6px;background:#ec6a52;color:#fff;border:none;border-radius:3px;padding:10px;font-size:14px;cursor:pointer}.auth-card button[type=submit]:disabled{opacity:.6;cursor:default}.auth-switch{background:none;border:none;color:#888;font-size:12px;cursor:pointer;text-decoration:underline;padding:0}.auth-error{color:#c0392b;font-size:12px;margin:0}.app-header{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;border-bottom:1px solid #e2ddd3;background:#fff}.app-title{font-weight:600;font-size:16px;letter-spacing:.02em}.app-header-right{display:flex;align-items:center;gap:12px;font-size:12px;color:#888}.logout-btn{background:none;border:1px solid #ddd6c9;border-radius:3px;padding:5px 10px;cursor:pointer;font-size:12px;color:#555}.week-toolbar{display:flex;align-items:center;justify-content:center;gap:14px;padding:18px 0 10px}.week-toolbar button{background:none;border:1px solid #ddd6c9;border-radius:3px;width:28px;height:28px;cursor:pointer;font-size:14px;color:#555}.week-label{font-size:13px;color:#777;min-width:180px;text-align:center}.today-btn{width:auto!important;padding:0 10px}.banner-error{max-width:600px;margin:0 auto 10px;background:#fbeceb;color:#c0392b;border:1px solid #f2c8c4;border-radius:3px;padding:8px 12px;font-size:12px;text-align:center}.loading{text-align:center;color:#999;padding:40px;font-size:13px}.board{display:flex;gap:1px;background:#e2ddd3;overflow-x:auto;padding-bottom:40px}.column{background:#f4f2ee;flex:1 0 150px;min-width:150px;padding:10px 10px 0;display:flex;flex-direction:column}.column.today{background:#fff7ec}.column-header{text-align:center;padding-bottom:8px;border-bottom:1px solid #d8d2c5;margin-bottom:6px}.column-title{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#444}.column-subtitle{font-size:11px;color:#999;margin-top:2px}.column-list{list-style:none;margin:0;padding:0;min-height:30px;flex:1}.column-list.drag-over{background:#ec6a520f}.task-item{display:flex;align-items:center;gap:6px;font-size:13px;padding:4px 2px;border-bottom:1px solid #eae5d9;line-height:1.35}.task-item.done .task-text{text-decoration:line-through;color:#aaa}.task-item .drag-handle{cursor:grab;color:#ccc;font-size:11px;flex-shrink:0}.task-item input[type=checkbox]{flex-shrink:0;margin:0}.task-text{flex:1;cursor:text;word-break:break-word}.task-edit-input{flex:1;font-size:13px;border:none;border-bottom:1px solid #ccc;background:transparent;padding:0}.task-delete{background:none;border:none;color:#ccc;cursor:pointer;font-size:15px;line-height:1;flex-shrink:0;visibility:hidden}.task-item:hover .task-delete{visibility:visible}.task-delete:hover{color:#c0392b}.add-task-form{padding:8px 0 14px}.add-task-form input{width:100%;border:none;background:none;font-size:12px;color:#999;padding:4px 2px}.add-task-form input:focus{outline:none;color:#444}.drag-clone{background:#fff;border:1px solid #ddd6c9;border-radius:3px;padding:6px 8px;box-shadow:0 4px 10px #0000001f}
