*{box-sizing:border-box}html,body,#root{height:100%}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;margin:0;background:#f7f8fb;color:#0f172a}.mx-auto{margin-left:auto;margin-right:auto}.max-w-md{max-width:480px}.px-4{padding-left:1rem;padding-right:1rem}.pt-3{padding-top:.75rem}.pb-6{padding-bottom:1.5rem}.card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 10px 20px #0f172a0a}.input{width:100%;padding:.75rem .9rem;border:1px solid #cbd5e1;border-radius:12px}.button{background:#111827;color:#fff;border:none;border-radius:12px;padding:.6rem .9rem}.actionbtn{border:1px solid #cbd5e1;border-radius:12px;padding:.4rem .6rem;background:#fff}.badge{font-size:10px;padding:.15rem .4rem;border-radius:9999px;background:#eef2ff;color:#3730a3}.avatar{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:9999px;background:#e2e8f0;color:#0f172a;font-size:11px}.left-accent{position:relative}.left-accent:before{content:"";position:absolute;left:0;top:0;bottom:0;width:6px;border-top-left-radius:16px;border-bottom-left-radius:16px}.left-accent.normal:before{background:#3b82f6}.left-accent.important:before{background:#f59e0b}.left-accent.sos:before{background:#ef4444}.snackbar{position:fixed;left:0;right:0;bottom:14px;margin:auto;width:min(92%,380px);border-radius:12px;background:#111827;color:#fff;padding:.7rem .9rem}.flex{display:flex}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.flex-wrap{flex-wrap:wrap}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.space-y-3>*+*{margin-top:.75rem}.space-y-4>*+*{margin-top:1rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.min-w-0{min-width:0}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.text-slate-600{color:#475569}.text-slate-500{color:#64748b}.text-slate-900{color:#0f172a}:root{--brand:#0ea5e9;--brand-50:#f0f9ff;--brand-100:#e0f2fe;--brand-200:#bae6fd;--brand-700:#0369a1;--safe-bottom:env(safe-area-inset-bottom)}.input{border-color:var(--brand-200)}.actionbtn{border-color:var(--brand-200);background:var(--brand-50)}.avatar{background:var(--brand-100);color:#083344}.actionbtn.selected{background:var(--brand-200)!important;border-color:var(--brand)!important;box-shadow:inset 0 0 0 1.5px var(--brand)}.handle{-webkit-user-select:none;user-select:none;font-size:18px;color:var(--brand-700);padding:.1rem .3rem;border-radius:8px;background:var(--brand-50);border:1px solid var(--brand-200)}.pill{font-size:10px;padding:.15rem .45rem;border-radius:9999px;border:1px solid #e6eaf0;background:#f8fafc;color:#0f172a}.pill.normal{background:#eff6ff;border-color:#bfdbfe;color:#1e40af}.pill.important{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.pill.sos{background:#fef2f2;border-color:#fecaca;color:#991b1b}.bottom-nav{position:fixed;left:0;right:0;bottom:0;background:#fff;border-top:1px solid var(--brand-200);display:grid;grid-template-columns:repeat(4,1fr);gap:.25rem;padding:.35rem 12px calc(.35rem + var(--safe-bottom)) 12px;z-index:100}.bn-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.25rem .35rem;border-radius:12px;color:var(--brand-700);font-size:12px}.bn-item.active{background:var(--brand-50);border:1px solid var(--brand-200)}.bn-label{line-height:1}.bn-count{font-size:10px;line-height:1;margin-top:2px;opacity:.8}.fab{position:fixed;left:50%;transform:translate(-50%);bottom:calc(64px + var(--safe-bottom));width:58px;height:58px;border-radius:9999px;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 24px #0369a159;z-index:110;font-size:26px}.sheet{position:fixed;top:0;right:0;bottom:0;left:0;display:none;background:#00000040;z-index:120}.sheet.open{display:flex;align-items:flex-end;justify-content:center}.sheet-panel{width:100%;max-width:520px;background:#fff;border-top-left-radius:22px;border-top-right-radius:22px;padding:14px 14px calc(14px + var(--safe-bottom));box-shadow:0 -10px 30px #0000001f;max-height:88vh;overflow:auto}.sheet-bar{width:42px;height:5px;border-radius:9999px;background:#e2e8f0;margin:6px auto 10px}.sheet-title{font-weight:600;margin:4px 6px 10px}.pb-nav{padding-bottom:120px}.icon-btn{font-size:18px;padding:.25rem .4rem}.login-bg{background:linear-gradient(180deg,#dbeafe,#fff)}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.filters{display:grid;row-gap:.6rem}.filters .row{display:flex;flex-wrap:wrap;gap:.5rem}.item-row{min-height:66px}.item-row .check{width:24px;height:24px;border-radius:9999px;border:1.5px solid #d1d8e5;background:#fff;display:flex;align-items:center;justify-content:center}.item-row .check:active{transform:scale(.96)}.item-row .check.done{background:#10b981;border-color:#10b981;color:#fff}.item-row .title{font-size:18px;font-weight:700;color:#0f172a}.item-row .desc{font-size:14px;color:#64748b}.handle{cursor:grab;-webkit-user-select:none;user-select:none;font-size:20px;padding:.2rem .5rem;border-radius:10px;background:#f1f5f9;border:1px solid #e2e8f0}.handle:active{cursor:grabbing}.card{border:1px solid #e9eef6;border-radius:18px;box-shadow:0 8px 28px #0f172a0f}.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:100;display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;background:#ffffffd9;-webkit-backdrop-filter:saturate(140%) blur(12px);backdrop-filter:saturate(140%) blur(12px);border-top:1px solid rgba(2,132,199,.12);padding:.45rem 14px calc(.45rem + var(--safe-bottom)) 14px}.bn-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;padding:.45rem .5rem;border-radius:14px;color:#0b1730;border:1px solid transparent}.bn-item .ico{width:18px;height:18px}.bn-item.active{background:linear-gradient(180deg,#f0f9ff,#e0f2fe);border-color:#bae6fd;box-shadow:inset 0 0 0 1px #0369a114}.bn-label{font-size:12px;font-weight:600}.bn-count{font-size:10px;opacity:.7}.fab{position:fixed;left:50%;transform:translate(-50%);bottom:calc(74px + var(--safe-bottom));width:64px;height:64px;border-radius:9999px;background:radial-gradient(60% 60% at 30% 30%,#38bdf8,#0ea5e9);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 18px 38px #0ea5e959,0 2px #fff9 inset;border:1px solid rgba(14,165,233,.35);font-size:28px}.fab:active{transform:translate(-50%) scale(.98)}.item-row{border-radius:18px;padding:10px 12px}.item-line{display:flex;align-items:center;gap:10px;min-height:68px}.handle{width:36px;height:36px;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;cursor:grab;color:#475569;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:10px}.check{width:28px;height:28px;border-radius:9999px;border:2px solid #cbd5e1;background:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;color:#0ea5e9}.content .title-row{display:flex;align-items:center;gap:8px}.content .title{font-weight:600;color:#0f172a;font-size:18px;line-height:1.1}.content .desc{font-size:14px;color:#64748b;margin-top:2px}.left-accent:before{width:4px}.card.filters{padding:12px}.filters .row{display:flex;flex-wrap:wrap;gap:8px}.filters .row+.row{margin-top:8px}.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:100;display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;padding:.5rem 14px calc(.5rem + var(--safe-bottom)) 14px;background:linear-gradient(180deg,#ffffffbf,#ffffffeb);-webkit-backdrop-filter:saturate(160%) blur(14px);backdrop-filter:saturate(160%) blur(14px);border-top:1px solid #e8ecf3;box-shadow:0 -10px 30px #0284c714}.bn-item{display:flex;align-items:center;justify-content:center;gap:.35rem;border-radius:14px;padding:.45rem .6rem;color:#0b1730;font-weight:600;font-size:13px;transition:.18s ease}.bn-item.active{background:linear-gradient(180deg,#e0f2fe,#f0f9ff);border:1px solid #bae6fd;box-shadow:inset 0 0 0 1px #0369a10f,0 6px 16px #0369a10f}.bn-count{font-size:11px;min-width:20px;height:20px;border-radius:9999px;display:inline-flex;align-items:center;justify-content:center;background:#e0f2fe;color:#0369a1}.fab{position:fixed;left:50%;transform:translate(-50%);bottom:calc(76px + var(--safe-bottom));width:62px;height:62px;border-radius:9999px;background:radial-gradient(60% 60% at 50% 35%,#28c7ff,#0ea5e9);color:#fff;font-size:28px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.45);box-shadow:0 10px 24px #0284c747,0 2px #fff9 inset}.seg{display:inline-flex;gap:4px;padding:4px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:9999px}.seg button{border:none;background:transparent;padding:6px 10px;border-radius:9999px;font-weight:600;font-size:12px;color:#0f172a}.seg button.active{background:#fff;border:1px solid #dbe3ee;box-shadow:0 1px 2px #0f172a0f}.filters .row.sort{justify-content:flex-end;display:flex;margin-top:6px}body{background:linear-gradient(180deg,#f1e9ff,#f7f4ff 220px,#f4edff)}.banner{margin:-8px auto 4px;max-width:640px;padding:18px 16px 48px;color:#2d1b69;background:radial-gradient(60% 80% at 20% 0%,#f9f6ff,#ece4ff 55%,#e3d7ff);border-bottom-left-radius:28px;border-bottom-right-radius:28px;border-bottom:1.5px solid var(--lavender);box-shadow:0 12px 30px #7c5cff1f inset}.banner h1{margin:0;font-size:26px;font-weight:800}.banner .sub{margin-top:4px;color:#6b7280;font-weight:600;font-size:13px}
