*{margin:0;padding:0;box-sizing:border-box}:root{--teal: #0D7377;--teal-dark: #095456;--teal-light: #e0f2f2;--gold: #C5A55A;--bg: #f8f9fa;--card: #ffffff;--text: #1a1a1a;--text-secondary: #6b7280;--border: #e5e7eb;--danger: #dc2626;--success: #16a34a;--radius: 10px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}.loading{display:flex;justify-content:center;align-items:center;min-height:100vh;color:var(--text-secondary)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,var(--teal) 0%,var(--teal-dark) 100%)}.login-card{background:var(--card);border-radius:16px;padding:32px 24px;width:100%;max-width:360px;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:28px}.login-header h1{font-size:28px;color:var(--teal);letter-spacing:2px}.login-header p{color:var(--text-secondary);margin-top:4px;font-size:14px}.login-card form{display:flex;flex-direction:column;gap:12px}.login-card input{padding:12px 14px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:15px;outline:none;transition:border-color .2s}.login-card input:focus{border-color:var(--teal)}.error{color:var(--danger);font-size:13px;text-align:center}.divider{text-align:center;margin:16px 0;color:var(--text-secondary);font-size:13px;position:relative}.divider:before,.divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background:var(--border)}.divider:before{left:0}.divider:after{right:0}.btn{padding:10px 18px;border:none;border-radius:var(--radius);font-size:15px;cursor:pointer;transition:all .2s;font-weight:500}.btn-primary{background:var(--teal);color:#fff;width:100%}.btn-primary:hover{background:var(--teal-dark)}.btn-guest{background:var(--teal-light);color:var(--teal);width:100%;border:1.5px solid var(--teal)}.btn-guest:hover{background:var(--teal);color:#fff}.btn-sm{padding:6px 14px;font-size:13px}.btn-danger{color:var(--danger);background:#fef2f2;border:1px solid #fecaca}.btn-danger:hover{background:var(--danger);color:#fff}.btn-icon{background:none;border:none;font-size:20px;cursor:pointer;color:var(--text-secondary);padding:2px 6px;line-height:1}.btn-icon:hover{color:var(--danger)}.btn:disabled{opacity:.6;cursor:not-allowed}.header{background:var(--teal);color:#fff;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.header h1{font-size:18px;letter-spacing:1px}.header-right{display:flex;align-items:center;gap:10px}.user-badge{font-size:12px;opacity:.85}.header .btn{background:#ffffff26;color:#fff}.header .btn:hover{background:#ffffff40}.tabs{display:flex;gap:0;background:var(--card);border-bottom:2px solid var(--border);padding:0 8px;overflow-x:auto}.tabs button{padding:12px 16px;border:none;background:none;font-size:14px;font-weight:500;cursor:pointer;color:var(--text-secondary);border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap}.tabs button.active{color:var(--teal);border-bottom-color:var(--teal)}.category-group{margin:16px 12px}.category-group h3{font-size:15px;color:var(--teal);padding:8px 0;border-bottom:1px solid var(--border);margin-bottom:8px}.count{font-weight:400;color:var(--text-secondary);font-size:13px}.member-view h2,.guest-view h2{padding:16px;font-size:18px}.check-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--card);border-radius:var(--radius);margin-bottom:6px;cursor:pointer;transition:all .2s;border:1px solid var(--border)}.check-item:hover{border-color:var(--teal)}.check-item.checked{background:var(--teal-light);border-color:var(--teal)}.check-item.checked .item-name{text-decoration:line-through;color:var(--text-secondary)}.check-item input[type=checkbox]{width:20px;height:20px;accent-color:var(--teal);cursor:pointer}.item-name{flex:1;font-size:14px}.item-notes{font-size:12px;color:var(--text-secondary)}.guest-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--card);border-radius:var(--radius);margin-bottom:4px;border:1px solid var(--border);flex-wrap:wrap;gap:6px}.guest-item.checked{background:var(--teal-light)}.item-meta{display:flex;gap:6px;flex-wrap:wrap}.badge{font-size:11px;padding:2px 8px;border-radius:12px;font-weight:500}.badge-person{background:#dbeafe;color:#1e40af}.badge-community{background:#fef3c7;color:#92400e}.badge-done{background:#dcfce7;color:var(--success)}.badge-pending{background:#fef9c3;color:#854d0e}.badge-unassigned{background:#f3f4f6;color:var(--text-secondary)}.badge-role{background:var(--teal-light);color:var(--teal)}.admin-item{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;margin-bottom:6px}.item-row{display:flex;justify-content:space-between;align-items:center}.item-row .item-name.checked{color:var(--success)}.assign-row{display:flex;gap:8px;margin-top:8px}.assign-row select{flex:1;padding:6px 8px;border:1px solid var(--border);border-radius:6px;font-size:13px;background:#fff}.inline-form{display:flex;gap:8px;padding:12px;background:var(--card);border-radius:var(--radius);margin:12px;border:1px solid var(--border);flex-wrap:wrap}.inline-form input,.inline-form select{flex:1;min-width:120px;padding:8px 10px;border:1px solid var(--border);border-radius:6px;font-size:14px}.user-form{padding:16px;background:var(--card);border-radius:var(--radius);margin:12px;border:1px solid var(--border);display:flex;flex-direction:column;gap:10px}.user-form h3{font-size:15px;color:var(--teal)}.user-form input,.user-form select{padding:10px 12px;border:1px solid var(--border);border-radius:6px;font-size:14px}.form-actions{display:flex;gap:8px}.users-list,.communities-list{padding:0 12px}.user-item,.community-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:var(--card);border-radius:var(--radius);margin-bottom:6px;border:1px solid var(--border)}.user-username{font-size:12px;color:var(--text-secondary)}.user-actions{display:flex;gap:6px}.empty-state{text-align:center;padding:32px 16px;color:var(--text-secondary)}@supports (padding: env(safe-area-inset-top)){.header{padding-top:calc(12px + env(safe-area-inset-top))}}
