*{box-sizing:border-box}body{font-family:-apple-system,system-ui,Arial;margin:0;background:#f7f7fb;color:#111;font-size:16px}.wrap{max-width:1000px;margin:0 auto;padding:18px}.card{background:#fff;border:1px solid #eee;border-radius:14px;padding:20px;box-shadow:0 1px 2px #0000000f;margin:12px 0;overflow:hidden}.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.muted{color:#666;font-size:14px}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:18px;letter-spacing:1px}.pill{display:inline-block;padding:4px 10px;background:#eee;border-radius:999px;font-weight:700}hr{border:0;border-top:1px solid #eee;margin:18px 0}.danger{color:#b00020}.max420{max-width:420px}input,select,button{height:42px;font-size:15px}input,select{padding:10px 12px;border:1px solid #ddd;border-radius:10px;width:100%;background:#fff}button{padding:10px 16px;border:0;border-radius:10px;font-weight:700;cursor:pointer;white-space:nowrap}button.primary{background:#111;color:#fff}button.light{background:#eee;color:#333}button:disabled{opacity:.6;cursor:not-allowed}.paid-checkbox{width:14px;height:14px;transform:scale(.75);margin:0;cursor:pointer}button.btn-edit-name:hover,button.btn-promote:hover{opacity:1!important}.admin-toggle{display:inline-flex;align-items:center;background:#eee;border-radius:999px;padding:3px;gap:3px}.admin-toggle button{background:transparent;border-radius:999px;padding:8px 14px;font-weight:800}.admin-toggle button.active{background:#111;color:#fff}.table-scroll{width:100%;overflow-x:auto;margin-top:10px;border-radius:8px;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse;min-width:400px}th,td{padding:12px 8px;border-bottom:1px solid #f0f0f0;text-align:left}.pill.sm{font-size:12px;padding:2px 8px;border-radius:999px;font-weight:800}.pill.sm.zero,.pill.sm.open{background:#eee}.pill.sm.done{background:#e9f7ef}.pill.sm.skipped{background:#fdecea}button.btn-pill-check{border-radius:999px;padding:6px 12px;display:inline-flex;align-items:center;gap:4px;font-size:13px;white-space:nowrap;flex-shrink:0}button.btn-pill-check svg{width:14px;height:14px;stroke:currentColor;stroke-width:3;fill:none;flex-shrink:0}@media (max-width: 380px){button.btn-pill-check{padding:5px 10px;font-size:12px;gap:3px}button.btn-pill-check svg{width:12px;height:12px}}@media (max-width: 420px){.wrap{padding:14px}.card{padding:16px;border-radius:12px}h1{font-size:22px;margin:8px 0 10px}h2{font-size:18px}h3{font-size:16px}.muted{font-size:13px}.mono{font-size:16px}input,select,button{height:38px;font-size:14px}input,select{padding:8px 10px}button{padding:8px 12px}}@media (min-width: 421px) and (max-width: 520px){.wrap{padding:16px}.card{padding:18px}h1{font-size:24px;margin:10px 0 12px}h2{font-size:19px}h3{font-size:17px}.muted{font-size:13.5px}.mono{font-size:17px}input,select,button{height:40px;font-size:14.5px}input,select{padding:9px 11px}button{padding:9px 13px}}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:100}.sheet{position:fixed;bottom:0;left:0;right:0;max-height:92vh;background:#fff;border-radius:18px 18px 0 0;box-shadow:0 -4px 32px #00000024;z-index:101;display:flex;flex-direction:column;overflow:hidden}.sheet-header{padding:16px 20px 14px;border-bottom:1px solid #eee;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.sheet-body{flex:1;overflow-y:auto;padding:18px 20px 48px;-webkit-overflow-scrolling:touch}.chore-cards{display:grid;gap:12px}.chore-card{border-radius:14px;border:1px solid #e8e8e8;padding:16px;cursor:pointer;background:#fafafa}.chore-card:active{transform:scale(.99)}.chore-card-top{display:flex;gap:10px;align-items:flex-start;justify-content:space-between}.chore-card-title{min-width:0;font-size:16px}.chore-card-title b{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chore-card-pills{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;flex-shrink:0}.chore-card-meta{margin-top:8px;display:grid;gap:4px}.pill.sm.on{background:#e9f7ef;color:#166534}.field-label{font-size:12px;font-weight:700;color:#555;margin-bottom:4px}.notif-wrap{position:relative}.notif-bell{position:relative;background:none;border:none;padding:4px 6px;cursor:pointer;height:auto;min-width:auto;display:flex;align-items:center;justify-content:center;border-radius:8px}.notif-bell:hover{background:#eee}.notif-badge{position:absolute;top:-2px;right:-2px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;padding:0 3px;border-radius:999px;display:flex;align-items:center;justify-content:center;line-height:1}.notif-panel{position:absolute;top:calc(100% + 6px);right:0;width:min(300px,calc(100vw - 28px));max-height:400px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;z-index:1000;overflow:hidden;border:1px solid #eee}.notif-panel-header{padding:12px 16px;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center}.notif-mark-all{font-size:12px;color:#3b82f6;background:none;border:none;cursor:pointer;height:auto;min-width:auto;padding:0;font-weight:600}.notif-list{max-height:340px;overflow-y:auto;-webkit-overflow-scrolling:touch}.notif-item{display:flex;gap:10px;align-items:flex-start;padding:10px 14px;border-bottom:1px solid #f0f0f0;cursor:pointer}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:#fafafa}.notif-item.unread{background:#f0f9ff}.notif-item.unread:hover{background:#e0f2fe}.notif-icon{font-size:18px;flex-shrink:0;line-height:1.4}.notif-body{flex:1;min-width:0}.notif-msg{font-size:14px}.notif-item.unread .notif-msg{font-weight:600}.notif-empty{padding:20px;text-align:center;color:#888;font-size:14px}
