:root{color-scheme:light dark}*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Roboto,Helvetica Neue,Arial,sans-serif;font-size:16px;line-height:1.5;-webkit-text-size-adjust:100%;background:#fafafa;color:#222}#root{display:flex;justify-content:center;min-height:100vh}.page{width:100%;max-width:480px;padding:16px}h1{font-size:1.5rem;margin:16px 0}a{color:#2563eb;text-decoration:none}a:hover,a:focus{text-decoration:underline}button{font:inherit;padding:8px 16px;border:1px solid #cbd5e1;background:#f8fafc;border-radius:6px;cursor:pointer}button:hover,button:focus{background:#e2e8f0}.auth{max-width:360px;margin:60px auto;padding:24px}.auth h1{font-size:28px;margin:0 0 4px;color:#2563eb}.auth h2{font-size:18px;margin:0 0 16px;color:#555;font-weight:500}.auth form{display:flex;flex-direction:column;gap:12px}.auth input{padding:12px;border:1px solid #ddd;border-radius:6px;font:inherit;background:#fff;color:inherit}.auth input:focus{outline:none;border-color:#2563eb}.auth button{padding:12px;border:none;background:#2563eb;color:#fff;border-radius:6px;font:inherit;font-weight:600;cursor:pointer}.auth button:hover,.auth button:focus{background:#1d4ed8}.auth button:disabled{opacity:.5;cursor:default}.auth a{color:#2563eb;text-align:center;text-decoration:none;font-size:14px}.error{color:#c33;font-size:13px;padding:8px;background:#fee;border-radius:4px}.settings{padding:24px}.settings h1{font-size:22px;margin:0 0 16px}.settings .user-email{color:#666;font-size:14px;margin:0 0 16px}.settings button{display:block;width:100%;padding:12px;margin:8px 0;border:1px solid #ddd;background:#fff;border-radius:6px;font:inherit;cursor:pointer;text-align:center}.settings button:hover,.settings button:focus{background:#f1f5f9}.board{padding:16px}.board header{display:flex;justify-content:space-between;align-items:center}.board h1{font-size:22px;margin:0}.board .header-actions{display:flex;align-items:center;gap:12px}.board .refresh-btn{background:none;border:none;font-size:22px;color:#666;cursor:pointer;padding:0 4px;line-height:1}.board .refresh-btn:disabled{opacity:.5;cursor:default}.settings-link{color:#666;font-size:22px;text-decoration:none}.tabs{display:flex;gap:4px;margin:16px 0;border-bottom:1px solid #e5e5e5}.tabs button{flex:1;padding:10px;background:none;border:none;font:inherit;cursor:pointer;color:#666;border-bottom:2px solid transparent}.tabs button.active{color:#2563eb;border-bottom-color:#2563eb;font-weight:600}.overdue h2{color:#c33;font-size:14px;margin:16px 0 8px}.task-card{display:block;padding:12px;margin:8px 0;background:#fff;border:1px solid #e5e5e5;border-radius:8px;text-decoration:none;color:inherit}.task-card.overdue{background:#fef2f2;border-color:#fecaca}.task-card .title{font-size:15px;margin-bottom:4px}.task-card .meta{color:#888;font-size:12px}.empty{text-align:center;color:#888;margin:40px 0}.task-detail{padding:16px}.task-detail header{margin-bottom:16px}.task-detail header button{background:none;border:none;color:#2563eb;font:inherit;cursor:pointer}.task-detail .actions{display:flex;flex-direction:column;gap:8px}.task-detail .actions button{padding:12px;border:1px solid #ddd;background:#fff;border-radius:6px;font:inherit;cursor:pointer}.task-detail .actions button.danger{color:#c33;border-color:#fecaca}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:flex-end;z-index:100}.sheet{width:100%;background:#fff;border-radius:12px 12px 0 0;padding:16px 16px 32px;display:flex;flex-direction:column;gap:8px}.sheet h3{margin:0 0 8px}.sheet button{padding:14px;border:1px solid #e5e5e5;background:#fff;border-radius:8px;font:inherit;cursor:pointer}.empty-state{padding:24px;background:#f0f9ff;border-radius:12px;margin-top:16px}.empty-state h2{margin-top:0;color:#0369a1}.empty-state ol{padding-left:20px;color:#333;line-height:1.8}.empty-state .empty-caption{color:#888;font-size:13px;margin:12px 0 0;text-align:center}
