@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;600;700&display=swap";:root{--bg-gradient: linear-gradient(180deg, #f4f7fb 0%, #eef3f9 50%, #f8fbff 100%);--glass: rgba(255,255,255,.7);--card: #ffffff;--muted: #6b7280;--text: #0f172a;--accent: #2563eb;--accent-600: #1e40af;--danger: #ef4444;--success: #16a34a;--shadow-1: 0 6px 18px rgba(15,23,42,.06);--shadow-2: 0 10px 30px rgba(15,23,42,.08);--glass-border: rgba(255,255,255,.6);--radius: 12px;--max-width: 1100px;--gap: 16px;font-synthesis:none}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;color:var(--text);background:var(--bg-gradient);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.35}.app{min-height:100vh;padding:28px 24px;display:flex;flex-direction:column;gap:20px;align-items:center}.header{width:100%;max-width:var(--max-width);display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px;background:linear-gradient(180deg,#ffffffa6,#ffffff80);border-radius:14px;box-shadow:var(--shadow-1);-webkit-backdrop-filter:blur(6px) saturate(120%);backdrop-filter:blur(6px) saturate(120%);border:1px solid rgba(20,30,50,.04)}.counters{display:flex;gap:14px;align-items:center}.counter{background:linear-gradient(180deg,#ffffffe6,#f8f9faf2);padding:8px 12px;border-radius:10px;border:1px solid rgba(15,23,42,.04);box-shadow:var(--shadow-1);min-width:86px;text-align:left}.counter-label{font-size:.78rem;color:var(--muted);font-weight:600}.counter-value{font-size:1.05rem;font-weight:700;color:var(--text);margin-top:4px}@media(max-width:640px){.counters{gap:10px;flex-wrap:wrap}.counter{min-width:72px;padding:6px 10px}}.header h1{margin:0;font-size:1.25rem;font-weight:700;letter-spacing:-.01em;color:var(--text)}.filter{display:flex;gap:10px;align-items:center;color:var(--muted);font-weight:500;font-size:.95rem}.filter input{width:18px;height:18px}.filter-wrap{width:100%;max-width:var(--max-width);padding:10px 18px;box-sizing:border-box}.filter-list{display:flex;gap:30px;align-items:center;flex-wrap:wrap}.filter-item{display:inline-flex;align-items:center;cursor:pointer;gap:6px;-webkit-user-select:none;user-select:none}.filter-input{width:16px;height:16px;flex:0 0 16px}.filter-text{margin-left:0;font-size:.95rem;color:var(--muted);font-weight:500}.filter-list{display:flex;gap:18px;align-items:center;flex-wrap:wrap}.filter-select{display:inline-flex;flex-direction:column;gap:6px;min-width:140px}.filter-select-label{font-size:.78rem;color:var(--muted);font-weight:600}.filter-select-input{padding:8px 10px;border-radius:10px;border:1px solid rgba(15,23,42,.06);background:linear-gradient(180deg,#fff,#fbfdff);font-size:.95rem;color:var(--text);outline:none;box-shadow:none}.filter-sep{width:8px}@media(max-width:760px){.filter-list{gap:12px}.filter-select{min-width:120px}}@media(max-width:520px){.filter-list{gap:14px}.filter-text{font-size:.92rem}}.container{width:100%;max-width:var(--max-width);margin:0 auto}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--gap);margin-top:6px}.tile{position:relative;background:linear-gradient(180deg,#fffffffa,#f9fafcfa);border-radius:var(--radius);padding:16px 110px 14px 16px;box-shadow:var(--shadow-1);transition:transform .18s cubic-bezier(.2,.9,.28,1),box-shadow .18s,border-color .18s;border:1px solid rgba(15,23,42,.03);overflow:visible;min-height:150px;display:flex;flex-direction:column;gap:10px}.tile:hover{transform:translateY(-6px);box-shadow:var(--shadow-2);border-color:#0f172a0f}.tile.completed{opacity:.95;filter:saturate(.98)}.tick{position:absolute;left:14px;top:14px;background:linear-gradient(180deg,var(--success),#059669);color:#fff;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;box-shadow:0 6px 18px #16a34a29;z-index:3}.cross{position:absolute;left:14px;top:14px;background:linear-gradient(180deg,#ff7a70,var(--danger));color:#fff;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;box-shadow:0 6px 18px #ef444429;z-index:3}.title{margin-left:var(--tick-offset, 0);font-weight:700;font-size:1.02rem;color:var(--text);display:block;word-break:break-word;padding-right:10px}.desc{color:var(--muted);font-size:.935rem;margin-left:var(--tick-offset, 0);line-height:1.35;max-height:3.6em;overflow:hidden;text-overflow:ellipsis}.meta{display:flex;flex-direction:column;gap:6px;margin-left:var(--tick-offset, 0);color:var(--muted);font-size:.82rem;align-items:flex-start}.actions{position:absolute;right:18px;top:12px;display:flex;flex-direction:column;gap:10px;align-items:flex-end;opacity:0;transform:translateY(-4px);transition:opacity .15s ease,transform .15s ease;z-index:4;pointer-events:none}.tile:hover .actions,.actions.visible{opacity:1;transform:translateY(0);pointer-events:auto}.btn{display:inline-flex;align-items:center;gap:8px;background:#fffc;color:var(--text);border:1px solid rgba(15,23,42,.04);padding:8px 10px;font-size:.86rem;border-radius:10px;cursor:pointer;transition:background .12s,transform .08s;box-shadow:0 2px 6px #0206170a}.btn:hover{transform:translateY(-2px);background:#fffffff2}.btn.primary{background:linear-gradient(180deg,var(--accent),var(--accent-600));color:#fff;border:none;padding:8px 10px;font-weight:600;box-shadow:0 6px 18px #2563eb2e}.btn.danger{background:linear-gradient(180deg,#ff7666,var(--danger));color:#fff;border:none;box-shadow:0 6px 18px #ef444424}.checkbox{display:flex;align-items:center;gap:8px;background:linear-gradient(180deg,#fffffffa,#f8f9fa);padding:8px;border-radius:10px;border:1px solid rgba(15,23,42,.04);color:var(--muted)}.fab{position:fixed;right:28px;bottom:28px;width:64px;height:64px;border-radius:50%;background:linear-gradient(180deg,var(--accent),var(--accent-600));color:#fff;border:none;font-size:30px;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 32px #2563eb38;cursor:pointer;transition:transform .14s,box-shadow .14s;z-index:50}.fab:hover{transform:translateY(-6px);box-shadow:0 20px 40px #2563eb47}.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(0deg,#070a1970,#070a1970);z-index:60;padding:18px}.form{width:100%;max-width:640px;background:linear-gradient(180deg,#fffffffc,#fafbfdfc);padding:22px;border-radius:14px;box-shadow:0 18px 50px #02061747;border:1px solid rgba(255,255,255,.6)}.form h3{margin:0 0 8px;font-size:1.12rem;font-weight:700}.form label{display:block;margin-top:10px;font-size:.92rem;color:var(--muted);font-weight:600}.form input[type=text],.form input[type=datetime-local],.form textarea{width:100%;margin-top:6px;padding:10px 12px;border-radius:10px;border:1px solid rgba(15,23,42,.06);background:linear-gradient(180deg,#fff,#fbfdff);font-size:.96rem;color:var(--text);outline:none;transition:box-shadow .12s,border-color .12s}.form textarea{min-height:96px;resize:vertical}.form input:focus,.form textarea:focus{box-shadow:0 6px 18px #2563eb14;border-color:#2563eb2e}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}.btn[disabled]{opacity:.6;cursor:default;transform:none}.note{font-size:.86rem;color:var(--muted);margin-top:8px;padding:8px;border-radius:8px;background:linear-gradient(180deg,#f0f6ff99,#fff9);border:1px solid rgba(37,99,235,.06)}.empty{color:var(--muted);text-align:center;padding:48px 12px;background:linear-gradient(180deg,#fff9,#fff6);border-radius:12px;border:1px dashed rgba(15,23,42,.04)}:focus{outline:none}.btn:focus,.fab:focus,.form input:focus,.form textarea:focus{box-shadow:0 8px 24px #2563eb1f,0 0 0 4px #2563eb14;border-color:#2563eb2e}@media(max-width:900px){.header{padding:14px;border-radius:10px}.fab{right:18px;bottom:18px;width:56px;height:56px}.title{font-size:1rem}.desc{font-size:.92rem}}@media(max-width:520px){.grid{grid-template-columns:1fr}.header{flex-direction:column;align-items:flex-start;gap:10px}.meta{flex-direction:column;align-items:flex-start;gap:6px}}.tile .tick+.title,.tile .tick+.desc,.tile .tick+.meta,.tile .cross+.title,.tile .cross+.desc,.tile .cross+.meta{margin-left:44px}
