@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap";:root{font-family:Space Grotesk,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;font-weight:400;color:#0f172a;background-color:#f6f9ff;--bg-page: #f6f9ff;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--bg-surface: #ffffff;--bg-subtle: #eef2ff;--border: #e0e7ff;--text-muted: #4b5563;--accent: #2563eb;--accent-strong: #22d3ee;--success: #16a34a;--danger: #ef4444;--shadow-soft: 0 18px 50px rgba(37, 99, 235, .08);--header-bg: rgba(246, 249, 255, .88);--nav-active-bg: rgba(37, 99, 235, .12);--card-border: linear-gradient(120deg, rgba(37, 99, 235, .25), rgba(34, 211, 238, .2))}[data-theme=dark]{color:#e2e8f0;background-color:#050915;--bg-page: #050915;--bg-surface: #0c1426;--bg-subtle: #0a1020;--border: #162036;--text-muted: #a0aec0;--accent: #7dd3fc;--accent-strong: #38bdf8;--shadow-soft: 0 16px 44px rgba(0, 0, 0, .45);--header-bg: rgba(12, 20, 38, .9);--nav-active-bg: rgba(56, 189, 248, .16);--card-border: linear-gradient(120deg, rgba(56, 189, 248, .28), rgba(125, 211, 252, .12))}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background-color:var(--bg-page);color:inherit;position:relative;overflow-x:hidden}body:before{content:"";position:fixed;inset:-20% auto auto -10%;width:540px;height:540px;background:radial-gradient(circle at 30% 30%,rgba(34,211,238,.18),transparent 55%),radial-gradient(circle at 70% 20%,rgba(37,99,235,.12),transparent 55%);filter:blur(40px);z-index:0;pointer-events:none}body[data-theme=dark]:before{background:radial-gradient(circle at 25% 25%,rgba(56,189,248,.16),transparent 55%),radial-gradient(circle at 70% 18%,rgba(168,85,247,.12),transparent 55%);filter:blur(55px)}#root{min-height:100vh}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit;color:inherit}button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--accent);outline-offset:3px;box-shadow:0 0 0 3px #2563eb2e}[data-theme=dark] button:focus-visible,[data-theme=dark] a:focus-visible,[data-theme=dark] input:focus-visible,[data-theme=dark] textarea:focus-visible,[data-theme=dark] select:focus-visible{outline-color:#38bdf8;box-shadow:0 0 0 3px #38bdf838}img{max-width:100%;display:block}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app-shell{min-height:100vh;display:flex;flex-direction:column;position:relative;z-index:1}.app-content{flex:1;width:min(1400px,100%);margin:0 auto;padding:1.25rem 1rem 3rem}.top-bar{display:flex;justify-content:center;align-items:center;gap:.75rem;padding:.35rem 1rem;background:linear-gradient(90deg,#2563eb14,#22d3ee14);color:#0f172a;font-weight:600;font-size:.95rem}[data-theme=dark] .top-bar{background:linear-gradient(90deg,#38bdf829,#2563eb1f);color:#e2e8f0}.top-bar a{color:inherit;font-weight:700;text-decoration:underline;text-decoration-thickness:2px}.site-header{position:sticky;top:0;z-index:10;background:linear-gradient(180deg,#ffffffeb,#ffffffdb);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);box-shadow:0 12px 36px #0000000f}[data-theme=dark] .site-header{background:linear-gradient(180deg,#080c14f5,#080c14e6);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom-color:#162036}.site-header__inner{width:min(1400px,100%);margin:0 auto;padding:.9rem 1.25rem;display:flex;align-items:center;gap:1rem}.brand{display:inline-flex;align-items:center;gap:.6rem;font-weight:700;letter-spacing:-.02em;color:#0b1220}[data-theme=dark] .brand{color:#e2e8f0}[data-theme=dark] .brand small{color:#cbd5e1!important}.brand-mark{display:inline-flex;width:2.4rem;height:2.4rem;align-items:center;justify-content:center;border-radius:.75rem;background:linear-gradient(135deg,#2563eb,#22d3ee);color:#fff;font-size:1.2rem;box-shadow:0 12px 30px #2563eb40}.brand__subtitle{color:#cbd5e1;font-weight:500}.header-actions{margin-left:auto;display:flex;align-items:center;gap:.6rem}.navbar ul{list-style:none;display:flex;align-items:center;gap:1.15rem;padding:.15rem 0;margin:0}.navbar{margin-left:1.5rem;flex:1 1 auto;min-width:0;display:flex;justify-content:center;align-items:center;padding:.1rem 0;border-bottom:1px solid rgba(15,23,42,.08)}.navbar__brand{display:none;align-items:center;gap:.5rem;font-weight:700;color:#0f172a;letter-spacing:-.01em;margin-bottom:.4rem}[data-theme=dark] .navbar__brand{color:#e2e8f0}.navbar__rail{display:none;align-items:center;justify-content:space-between;gap:1rem;width:100%}.navbar__close{display:none;background:transparent;border:none;color:inherit;font-weight:700;letter-spacing:.06em;text-transform:uppercase;cursor:pointer}.nav-link{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .1rem;color:var(--text-muted);font-weight:800;letter-spacing:-.02em;text-transform:uppercase;line-height:1.1;border-bottom:2px solid transparent;transition:color .14s ease,border-color .14s ease,transform .14s ease}.nav-link:hover{color:#0f172a;border-bottom-color:var(--accent);transform:translateY(-1px)}.nav-link--active{color:#0f172a;border-bottom-color:#0f172a}.nav-link:focus-visible{outline:2px solid var(--accent);outline-offset:2px}[data-theme=dark] .nav-link{color:#cbd5e1}[data-theme=dark] .nav-link:hover,[data-theme=dark] .nav-link--active{color:#fff;border-bottom-color:#7dd3fc}[data-theme=dark] .nav-link:focus-visible{outline-color:#38bdf8}.navbar__mobile-actions{display:none;margin-top:2rem;gap:.65rem}.nav-toggle{display:none;min-width:48px;height:auto;border-radius:12px;border:1px solid var(--border);background:var(--bg-surface);align-items:center;justify-content:center;gap:6px;padding:10px 12px;margin-left:auto}.nav-toggle__label{font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:.8rem;margin-right:6px}.nav-toggle__icon{display:inline-flex;align-items:center;justify-content:center}.site-footer{border-top:1px solid var(--border);padding:clamp(1.25rem,2vw + .5rem,2.25rem) clamp(1.25rem,4vw,2.5rem);background:linear-gradient(135deg,#fffffff5,#f6f9fff0);box-shadow:0 -12px 32px #0000000a}.site-footer__inner{width:min(1200px,100%);margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.1rem;color:var(--text-muted);font-size:.95rem}.site-footer__brand{display:inline-flex;align-items:center;gap:.75rem;color:#0f172a}[data-theme=dark] .site-footer__brand{color:#e2e8f0}.brand-mark--mini{width:2rem;height:2rem;font-size:1.05rem;box-shadow:0 10px 24px #2563eb40}.site-footer__title{font-weight:800;letter-spacing:-.01em}.site-footer__subtitle{margin:.15rem 0 0;color:var(--text-muted)}.site-footer__links{display:inline-flex;align-items:center;justify-content:flex-end;gap:.75rem;flex-wrap:wrap}.site-footer a{color:inherit;text-decoration:underline;text-decoration-thickness:1px}[data-theme=dark] .site-footer{color:#cbd5e1;background:linear-gradient(135deg,#080e1cf5,#081222eb);border-top-color:#162036}[data-theme=dark] .site-footer a{color:#7dd3fc}@media(max-width:720px){.site-footer{text-align:center}.site-footer__brand,.site-footer__links{justify-content:center}}.dashboard-page,.today-page,.categories-page,.completed-page,.settings-page,.not-found-page{display:flex;flex-direction:column;gap:1.25rem;width:100%}.settings-page{width:min(820px,100%);margin:0 auto;align-items:center;text-align:center}.dashboard-page h2,.today-page h1,.categories-page h1,.completed-page h1,.settings-page h1,.not-found-page h1{margin:0}.dashboard-page p,.today-page p,.categories-page p,.completed-page p,.settings-page p,.not-found-page p{color:var(--text-muted);margin:0}.dashboard-grid{display:grid;grid-template-columns:1fr;gap:1.4rem;align-items:start}.dashboard-column{background:var(--bg-surface);border:1px solid var(--border);border-radius:20px;padding:1.5rem;box-shadow:var(--shadow-soft);position:relative;overflow:hidden;width:100%}.dashboard-column:before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:var(--card-border);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}[data-theme=dark] .dashboard-column{background:linear-gradient(145deg,#0c1426e0,#080e1cfa)}.dashboard-column__header{display:flex;flex-direction:column;gap:.9rem;align-items:flex-start;justify-content:flex-start;margin-bottom:1rem;padding:.5rem .25rem;width:100%}.dashboard-column__header--list{flex-direction:row;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.dashboard-column__header--list p{margin-top:.15rem}.dashboard-column__actions{display:inline-flex;gap:.65rem}.dashboard-inline-form{border:1px dashed var(--border);border-radius:14px;padding:1rem;margin:.25rem 0 1rem;background:var(--bg-subtle)}[data-theme=dark] .dashboard-inline-form{background:#38bdf80f}.dashboard-inline-form__header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.5rem}.dashboard-inline-form__header h3{margin:0}.task-filters{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-end;width:100%;background:var(--bg-subtle);border:1px solid var(--border);border-radius:14px;padding:.9rem 1rem}.task-filters>label{flex:1 1 0;min-width:180px}.task-filters__clear{flex:0 0 auto;align-self:flex-end}@media(max-width:720px){.task-filters{gap:.6rem}.task-filters>label{flex:1 1 0;min-width:140px}}.task-form{display:flex;flex-direction:column;gap:1.1rem}.task-form__fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.85rem}.task-form label span,.task-filters label span,.settings-form label span{display:block;font-size:.96rem;color:var(--text-muted);margin-bottom:.35rem;letter-spacing:-.01em}.task-filters__clear{align-self:flex-end;border:1px dashed var(--border);background:transparent;color:var(--text-muted);border-radius:12px;padding:.65rem .85rem;cursor:pointer;transition:border-color .15s ease,color .15s ease,transform .12s ease}.task-filters__clear:hover{border-color:var(--accent);color:#0f172a;transform:translateY(-1px)}[data-theme=dark] .task-filters__clear{color:#e2e8f0;border-color:#38bdf8;background:#38bdf814}[data-theme=dark] .task-filters__clear:hover{color:#f8fafc;border-color:#7dd3fc;background:#38bdf81f}.task-form input,.task-form textarea,.task-form select,.task-filters input,.task-filters select,.settings-form input,.settings-form select{width:100%;border:1px solid var(--border);border-radius:12px;padding:.75rem .85rem;background:linear-gradient(135deg,rgba(37,99,235,.04),transparent);box-shadow:inset 0 1px #fff9;transition:border-color .15s ease,box-shadow .15s ease}[data-theme=dark] .task-form input,[data-theme=dark] .task-form textarea,[data-theme=dark] .task-form select,[data-theme=dark] .task-filters input,[data-theme=dark] .task-filters select,[data-theme=dark] .settings-form input,[data-theme=dark] .settings-form select{background:linear-gradient(145deg,#38bdf814,#0c1426e6);box-shadow:inset 0 1px #ffffff0f;color:#e2e8f0;border-color:#23304a}[data-theme=dark] .task-form input::placeholder,[data-theme=dark] .task-form textarea::placeholder,[data-theme=dark] .task-filters input::placeholder,[data-theme=dark] .settings-form input::placeholder{color:#94a3b8}[data-theme=dark] select,[data-theme=dark] input,[data-theme=dark] textarea{background-color:#0f172a;color:#e2e8f0;border-color:#23304a}[data-theme=dark] input[type=date]::-webkit-calendar-picker-indicator{filter:invert(1) brightness(2)}[data-theme=dark] option{background-color:#0f172a;color:#e2e8f0}[data-theme=dark] input[type=date]{color-scheme:dark}[data-theme=dark] input[type=date]:focus{box-shadow:0 10px 30px #38bdf82e,0 0 0 3px #38bdf838}.task-form textarea{min-height:90px}.task-form input:focus,.task-form textarea:focus,.task-form select:focus,.task-filters input:focus,.task-filters select:focus,.settings-form input:focus,.settings-form select:focus{outline:none;border-color:#93c5fd;box-shadow:0 10px 30px #2563eb1f,0 0 0 3px #2563eb29}.task-form__actions{display:flex;justify-content:flex-end;gap:.65rem;margin-top:.35rem}.task-list{display:grid;gap:.75rem}.task-list__empty{margin:0;padding:1.5rem;border:1px dashed var(--border);border-radius:14px;color:var(--text-muted);background:var(--bg-subtle);text-align:center;display:grid;gap:.5rem;align-items:center;justify-items:center}.task-list__empty-icon{font-size:1.5rem}.task-list__empty-title{font-weight:700;color:#0b1220;margin:0}.task-list__empty-copy{margin:0;color:var(--text-muted)}.task-item{border:1px solid var(--border);border-radius:16px;padding:1.1rem;background:var(--bg-surface);box-shadow:var(--shadow-soft);display:grid;gap:.6rem;transition:transform .12s ease,box-shadow .15s ease,border-color .15s ease}.task-item:hover{transform:translateY(-2px);border-color:#2563eb66;box-shadow:0 18px 38px #0f172a1f}.task-item.is-complete{border-color:#10b98173;background:linear-gradient(135deg,#4ade8014,#3b82f60a);opacity:.96}[data-theme=dark] .task-item.is-complete{background:linear-gradient(135deg,#3b82f61f,#10b9811f);border-color:#7dd3fc59}.task-item.is-complete h3{text-decoration:line-through;color:var(--text-muted)}.task-item header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.task-item h3{margin:0}.task-item__description{margin:0;color:var(--text-muted)}.task-item__meta{margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.5rem}.task-item__meta dt{font-size:.85rem;color:var(--text-muted)}.task-item__meta dd{margin:0;font-weight:600}.due{font-weight:700}.due--today{color:#2563eb}.due--upcoming{color:#15803d}.due--overdue{color:#b91c1c}.task-item__actions{display:flex;flex-wrap:wrap;gap:.5rem}.status-badge{padding:.25rem .65rem;border-radius:999px;font-size:.85rem;font-weight:600;color:#0f172a;background:#e2e8f0;box-shadow:inset 0 1px #fff9}.status-done{background:linear-gradient(135deg,#10b9811f,#10b9812e);color:#0f5132}.status-pending{background:linear-gradient(135deg,#2563eb24,#22d3ee29);color:#0c4a6e}[data-theme=dark] .status-done{color:#bbf7d0;background:linear-gradient(135deg,#10b9813d,#38bdf81f)}[data-theme=dark] .status-pending{color:#e0f2fe;background:linear-gradient(135deg,#38bdf82e,#3b82f624)}.priority-high{color:#b91c1c;font-weight:700}.priority-medium{color:#b45309;font-weight:700}.priority-low{color:#15803d;font-weight:700}[data-theme=dark] .priority-high{color:#fca5a5}[data-theme=dark] .priority-medium{color:#fbbf24}[data-theme=dark] .priority-low{color:#6ee7b7}.settings-form{display:grid;gap:.9rem;max-width:520px}.settings-page header{width:100%}.settings-page .settings-form{width:min(580px,100%);text-align:left}.settings-form__actions{display:flex;gap:.6rem;justify-content:flex-end;flex-wrap:wrap}.auth-page{min-height:70vh;display:flex;align-items:center;justify-content:center}.auth-card{width:min(720px,100%);background:var(--bg-surface);border:1px solid var(--border);border-radius:22px;box-shadow:var(--shadow-soft);padding:2rem;display:grid;gap:.75rem}[data-theme=dark] .auth-card{background:linear-gradient(145deg,#0c1426f0,#080e1cf5)}.eyebrow{margin:0;color:var(--text-muted);letter-spacing:.12em;text-transform:uppercase;font-weight:800;font-size:.9rem}.auth-subtitle{margin:0;color:var(--text-muted);max-width:56ch}.auth-form{display:grid;gap:.85rem;margin-top:.25rem}.auth-form label span{display:block;margin-bottom:.35rem;color:var(--text-muted);font-size:.95rem}.auth-form input{width:100%;border:1px solid var(--border);border-radius:14px;padding:.75rem .85rem;background:linear-gradient(135deg,rgba(37,99,235,.04),transparent);box-shadow:inset 0 1px #fff9}.auth-form input:focus{outline:none;border-color:#93c5fd;box-shadow:0 10px 30px #2563eb1f,0 0 0 3px #2563eb29}[data-theme=dark] .auth-form input{background:linear-gradient(145deg,#38bdf814,#0c1426e6);color:#e2e8f0;border-color:#23304a}[data-theme=dark] .auth-form input:focus{border-color:#38bdf8;box-shadow:0 10px 30px #38bdf82e,0 0 0 3px #38bdf838}.auth-actions{display:flex;flex-wrap:wrap;gap:.65rem;margin-top:.5rem}.auth-checklist{display:grid;gap:.5rem;margin:.25rem 0 .5rem}.auth-checklist__item{display:inline-flex;gap:.5rem;align-items:center;padding:.6rem .8rem;border-radius:12px;background:var(--bg-subtle);border:1px solid var(--border);color:#0f172a}[data-theme=dark] .auth-checklist__item{background:#38bdf814;color:#e2e8f0}.auth-checkmark{width:1.6rem;height:1.6rem;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#fff;font-weight:800;font-size:.95rem;box-shadow:0 12px 26px #2563eb40}.auth-footnote{margin:.25rem 0 0;color:var(--text-muted)}.auth-link{font-weight:700;color:var(--accent)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;border-radius:999px;border:1px solid var(--border);padding:.6rem 1rem;background:linear-gradient(135deg,#ffffffe6,#ffffffb3);font-weight:700;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .15s ease,background .12s ease}.btn:active{transform:translateY(1px)}.btn:hover{border-color:#cbd5e1;box-shadow:0 12px 26px #0f172a14}[data-theme=dark] .btn{background:linear-gradient(145deg,#ffffff14,#ffffff0a);border-color:#23304a;color:#e2e8f0;box-shadow:0 10px 22px #00000059}[data-theme=dark] .btn:hover{border-color:#38bdf8bf;box-shadow:0 14px 30px #38bdf82e}.btn--primary{background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#fff;border:none;box-shadow:0 16px 32px #2563eb4d}[data-theme=dark] .btn--primary{box-shadow:0 18px 32px #38bdf847;border:1px solid rgba(125,211,252,.2);background:linear-gradient(135deg,#38bdf8,#2563eb)}.btn--ghost{background:transparent;border-color:var(--border);color:#0f172a}[data-theme=dark] .btn--ghost{background:#ffffff05;border-color:#23304a;color:#e2e8f0}[data-theme=dark] .btn--ghost:hover{background:#38bdf814}.btn--danger{background:#fee2e2;border-color:#fecdd3;color:#b91c1c}[data-theme=dark] .btn--danger{background:linear-gradient(135deg,#f8717142,#f8717124);border-color:#7f1d1d;color:#fecdd3;box-shadow:0 12px 28px #f871712e}.btn--sm{padding:.45rem .85rem;font-size:.95rem}.btn--lg{padding:.8rem 1.2rem;font-size:1rem}.btn--block{width:100%}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-soft);padding:1rem}.card__header{margin-bottom:.75rem}.card__title{margin:0}.card__description{margin:.25rem 0 0;color:var(--text-muted)}.card__body{display:grid;gap:.75rem}@media(max-width:1100px){.site-header__inner{gap:.6rem}.navbar,.header-actions{display:none}.nav-toggle{display:inline-flex}.dashboard-grid{grid-template-columns:1fr;gap:1rem}}@media(max-width:1100px){.site-header{position:sticky}.navbar{position:fixed;inset:0;width:100%;min-height:100vh;margin:0;background:var(--bg-surface);border:0;padding:1.25rem 1.25rem 6rem;box-shadow:0 24px 48px #00000024;border-radius:0;overflow-y:auto;flex-direction:column;gap:1.25rem;align-items:stretch;z-index:30}.navbar--open{display:flex}.navbar ul{flex-direction:column;gap:.75rem;align-items:flex-start;width:100%;padding-bottom:2.5rem}.navbar ul li{width:100%;padding:.75rem 0;border-bottom:1px solid var(--border)}.navbar ul li:last-child{border-bottom:none}.navbar ul .nav-link{width:100%;padding:.65rem .25rem;font-size:1.05rem;border-bottom:none}.navbar__rail{position:sticky;top:0;padding-bottom:.5rem;background:var(--bg-surface);z-index:1}.navbar__close{display:inline-flex;margin-left:auto}.navbar__brand{display:inline-flex;align-items:center;gap:.5rem;font-size:1.05rem}.navbar__rail{display:flex}.navbar__mobile-actions{display:grid;grid-template-columns:1fr 1fr;margin-top:auto;position:sticky;bottom:0;left:0;right:0;padding-top:1rem;gap:.65rem;width:100%;background:linear-gradient(180deg,transparent 0%,var(--bg-surface) 45%,var(--bg-surface) 100%);border-top:1px solid var(--border)}.app-content{padding:1rem 1rem 2.5rem}.dashboard-column{padding:1rem;border-radius:16px}.task-item{padding:.95rem}.dashboard-column__header{align-items:flex-start;gap:.75rem}.task-filters{margin-top:.25rem}}@media(max-width:540px){.site-header__inner{padding:.75rem 1rem}.brand{font-size:.95rem}.navbar__mobile-actions{grid-template-columns:1fr}.task-item__actions{flex-direction:column}.task-form__actions{flex-direction:column;align-items:stretch}.auth-card{padding:1.25rem;border-radius:16px}.auth-actions{flex-direction:column;align-items:stretch}.dashboard-column__header--list{align-items:flex-start}.dashboard-column__actions{width:100%}}
