:root{--bg:#fff;--surface:#f5f5f7;--surface-2:#ececef;--border:#e5e5ea;--text:#1c1c1e;--muted:#8e8e93;--accent:#7c5cff;--accent-soft:#efeaff;--accent-2:#ffd60a;--danger:#ff453a;--r:16px;--hdr-h:56px;--addbar-h:72px;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px);color:var(--text);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--bg);overscroll-behavior-y:none}button{font:inherit;color:inherit;cursor:pointer;background:0 0;border:none}input{font:inherit;color:inherit}.screen{min-height:100%;padding-bottom:calc(var(--addbar-h) + var(--safe-bottom));flex-direction:column;display:flex}.empty{color:var(--muted);text-align:center;padding:48px 24px;font-size:18px}.hdr{z-index:10;height:calc(var(--hdr-h) + var(--safe-top));padding:var(--safe-top) 12px 0;background:var(--bg);border-bottom:1px solid var(--border);align-items:center;gap:8px;display:flex;position:sticky;top:0}.hdr__title{letter-spacing:-.02em;white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:30px;font-weight:800;overflow:hidden}.hdr__back{width:40px;height:44px;color:var(--accent);place-items:center;display:grid}.hdr__spacer{width:4px}.hdr__right{align-items:center;display:flex}.hdr__icon{width:44px;height:44px;color:var(--text);border-radius:50%;place-items:center;display:grid}.list{flex:1;padding:12px 16px 24px}.cat{margin-bottom:28px}.cat__head{text-align:left;align-items:center;gap:8px;width:100%;padding:6px 4px;display:flex}.cat__name{letter-spacing:-.01em;font-size:22px;font-weight:800}.cat__emoji{border-radius:11px;flex:none;place-items:center;width:38px;height:38px;font-size:21px;line-height:1;display:grid}.cats{flex-direction:column;flex:1;gap:12px;padding:12px 16px 24px;display:flex}.catcard{text-align:left;border-radius:20px;align-items:center;gap:14px;width:100%;padding:18px;display:flex}.catcard__emoji{background:#fff9;border-radius:15px;flex:none;place-items:center;width:52px;height:52px;font-size:28px;line-height:1;display:grid}.catcard__body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.catcard__name{letter-spacing:-.01em;color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:22px;font-weight:800;overflow:hidden}.catcard__meta{color:#1c1c1e8c;font-size:15px;font-weight:600}.catcard__chevron{color:#1c1c1e66;flex:none}.cat__lists{flex-direction:column;gap:8px;margin-top:8px;display:flex}.listrow{background:var(--surface);border-radius:var(--r);color:var(--text);justify-content:space-between;align-items:center;padding:18px 20px;font-size:20px;font-weight:600;text-decoration:none;display:flex}.listrow__name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.listrow__count{background:var(--accent);color:#fff;border-radius:16px;justify-content:center;align-items:center;min-width:32px;height:32px;padding:0 10px;font-size:16px;font-weight:700;display:inline-flex}.listrow--add{background:var(--accent-soft);justify-content:flex-start;gap:10px}.listrow--add__icon{color:var(--accent);flex:none}.listrow__input{width:100%;color:var(--accent);background:0 0;border:none;outline:none;flex:1;font-size:20px;font-weight:600}.listrow__input::placeholder{color:var(--accent);opacity:.7}.items{flex-direction:column;flex:1;gap:10px;padding:12px 16px 24px;display:flex}.row{border-radius:var(--r);position:relative;overflow:hidden}.row__bg{color:#fff;align-items:center;font-size:26px;display:flex;position:absolute;inset:0}.row__bg--validate{background:var(--accent);justify-content:flex-start;padding-left:24px}.row__bg--delete{background:var(--danger);justify-content:flex-end;padding-right:24px}.row__fg{background:var(--surface);touch-action:pan-y;align-items:center;gap:14px;min-height:64px;padding:16px 18px;display:flex;position:relative}.row__fg--done .row__text{color:var(--muted);text-decoration:line-through}.row__text{word-break:break-word;flex:1;font-size:21px;font-weight:600;line-height:1.25}.row__cam{background:var(--surface-2);width:40px;height:40px;color:var(--muted);border-radius:12px;flex:none;place-items:center;font-size:24px;display:grid}.row__thumb{border-radius:12px;flex:none;width:48px;height:48px;padding:0;overflow:hidden}.row__thumb img{object-fit:cover;width:100%;height:100%;display:block}.row__check{color:var(--border);flex:none;place-items:center;padding:0;display:grid}.row__check--on{color:var(--accent)}.row__badge{color:var(--accent);flex:none}.row__chevron{color:var(--muted);flex:none}.addbar{padding:12px 16px calc(12px + var(--safe-bottom));background:var(--bg);border-top:1px solid var(--border);align-items:center;gap:10px;display:flex;position:fixed;bottom:0;left:0;right:0}.addbar__input{border-radius:var(--r);border:1px solid var(--border);background:var(--surface);outline:none;flex:1;height:52px;padding:0 18px;font-size:19px}.addbar__input:focus{border-color:var(--accent)}.addbar__btn{border-radius:var(--r);background:var(--accent);color:#fff;flex:none;place-items:center;width:52px;height:52px;font-size:28px;display:grid}.addbar__btn:disabled{opacity:.5}.addbar__attach{border-radius:var(--r);background:var(--surface);border:1px solid var(--border);width:52px;height:52px;color:var(--muted);flex:none;place-items:center;display:grid}.addbar__attach--on{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.pin{min-height:100%;padding:32px 24px calc(32px + var(--safe-bottom));flex-direction:column;justify-content:center;align-items:center;gap:18px;display:flex}.pin__brand{letter-spacing:-.03em;font-size:38px;font-weight:800}.pin__hint{color:var(--muted);min-height:24px;font-size:18px}.pin__dots{gap:16px;margin:4px 0 12px;display:flex}.pin__dot{border:2px solid var(--border);border-radius:50%;width:16px;height:16px}.pin__dot--on{background:var(--accent);border-color:var(--accent)}.pin__dots--error .pin__dot{border-color:var(--danger)}.pin__pad{grid-template-columns:repeat(3,76px);gap:16px;display:grid}.pin__key{background:var(--surface);border-radius:50%;place-items:center;height:76px;font-size:30px;font-weight:600;display:grid}.pin__key--fn{color:var(--muted);background:0 0}.pin__validate{width:260px;margin-top:12px}.btn{border-radius:var(--r);background:var(--surface);justify-content:center;align-items:center;height:52px;padding:0 22px;font-size:18px;font-weight:600;display:inline-flex}.btn--icon{gap:8px}.btn--primary{background:var(--accent);color:#fff}.btn--primary:disabled{opacity:.4}.btn--danger-text{color:var(--danger);background:0 0}.settings{flex-direction:column;gap:28px;padding:20px 16px;display:flex}.settings__block{flex-direction:column;gap:14px;display:flex}.settings__h2{font-size:22px;font-weight:800}.settings__note{color:var(--muted);font-size:16px;line-height:1.4}.toggle{background:var(--surface);border-radius:var(--r);justify-content:space-between;align-items:center;padding:18px 20px;font-size:19px;font-weight:600;display:flex}.toggle__knob{background:var(--surface-2);border-radius:15px;width:52px;height:30px;transition:background .2s;position:relative}.toggle__knob:after{content:"";background:#fff;border-radius:50%;width:24px;height:24px;transition:transform .2s;position:absolute;top:3px;left:3px}.toggle--on .toggle__knob{background:var(--accent)}.toggle--on .toggle__knob:after{transform:translate(22px)}.toggle:disabled{opacity:.5}.viewer{z-index:100;background:#000000eb;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.viewer__img{border-radius:8px;max-width:100%;max-height:100%}.viewer__close{top:calc(16px + var(--safe-top));color:#fff;font-size:30px;position:absolute;right:20px}.sheet__backdrop{z-index:90;background:#00000059;position:fixed;inset:0}.sheet{z-index:91;background:var(--bg);padding:8px 20px calc(24px + var(--safe-bottom));border-radius:24px 24px 0 0;max-height:88vh;position:fixed;bottom:0;left:0;right:0;overflow-y:auto}.sheet__grab{background:var(--border);border-radius:3px;width:44px;height:5px;margin:8px auto 14px}.sheet__body{flex-direction:column;gap:16px;display:flex}.detail__title{letter-spacing:-.02em;background:0 0;border:none;outline:none;width:100%;padding:4px 0;font-size:26px;font-weight:800}.detail__status{border-radius:var(--r);background:var(--accent-soft);color:var(--accent);align-self:flex-start;align-items:center;gap:8px;padding:12px 18px;font-size:17px;font-weight:700;display:inline-flex}.detail__status--done{background:var(--surface);color:var(--muted)}.detail__section{flex-direction:column;gap:10px;display:flex}.detail__label{text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-size:14px;font-weight:700}.detail__photo{position:relative}.detail__photo img{object-fit:cover;border-radius:var(--r);width:100%;max-height:280px;display:block}.detail__photo-del{color:#fff;background:#0000008c;border-radius:50%;place-items:center;width:34px;height:34px;display:grid;position:absolute;top:10px;right:10px}.detail__top{align-items:center;gap:8px;display:flex}.detail__del-icon{width:40px;height:40px;color:var(--danger);border-radius:50%;flex:none;place-items:center;display:grid}.detail__comment{text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);width:100%;color:var(--text);white-space:pre-wrap;word-break:break-word;padding:14px 16px;font-size:18px;line-height:1.4}.detail__status--footer{justify-content:center;width:100%;margin-top:8px}.detail__note{border:1px solid var(--border);border-radius:var(--r);background:var(--surface);resize:none;outline:none;width:100%;padding:14px 16px;font-size:18px;line-height:1.4}.detail__note:focus{border-color:var(--accent)}.detail__delete{align-self:flex-start;margin-top:4px}.catform__head{align-items:center;gap:12px;display:flex}.catform__preview{border-radius:14px;flex:none;place-items:center;width:48px;height:48px;font-size:26px;line-height:1;display:grid}.picker{flex-wrap:wrap;gap:10px;display:flex}.picker__emoji{background:var(--surface);border:2px solid #0000;border-radius:12px;place-items:center;width:46px;height:46px;font-size:24px;display:grid}.picker__emoji--on{border-color:var(--accent);background:var(--accent-soft)}.picker__color{border:3px solid #0000;border-radius:50%;width:40px;height:40px}.picker__color--on{border-color:var(--text)}
