:root{--bg:#101318;--surface:#171c23;--surface-2:#1e242e;--surface-3:#262e3a;--border:#2b3442;--text:#e7ebf1;--muted:#8d99a9;--faint:#5f6b7c;--accent:#5aa2ff;--accent-strong:#3b82f6;--green:#3ecf8e;--red:#ff6b6b;--amber:#f0b453;--violet:#b18cff;--radius:10px;--nav-h:62px}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:15px;line-height:1.45}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}h1{font-size:1.35rem;margin:0 0 4px;letter-spacing:-.01em}h2{font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:22px 0 8px}h3{font-size:1rem;margin:0}p{margin:0 0 8px}.muted{color:var(--muted)}.faint{color:var(--faint)}.faint,.small{font-size:.85rem}.app-shell{display:flex;min-height:100dvh}.app-main{flex:1 1;width:100%;max-width:880px;margin:0 auto;padding:16px 14px calc(var(--nav-h) + env(safe-area-inset-bottom, 0px) + 20px)}.page-head{margin-bottom:14px}.page-head .sub{color:var(--muted);font-size:.9rem}.sidebar{display:none}.tabbar{position:fixed;bottom:0;left:0;right:0;z-index:40;display:flex;justify-content:space-around;background:color-mix(in srgb,var(--surface) 92%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom,0)}.tabbar a{flex:1 1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 2px 6px;min-height:var(--nav-h);color:var(--muted);font-size:.64rem;letter-spacing:.02em;text-decoration:none}.tabbar a.active{color:var(--accent)}.tabbar a:hover{text-decoration:none}@media (min-width:900px){.tabbar{display:none}.app-main{padding:28px 32px 60px}.sidebar{width:210px;flex-shrink:0;position:-webkit-sticky;position:sticky;top:0;height:100dvh;padding:20px 12px;border-right:1px solid var(--border);background:var(--surface)}.sidebar,.sidebar .brand{display:flex;flex-direction:column}.sidebar .brand{gap:2px;font-weight:700;font-size:1.05rem;letter-spacing:.02em;padding:4px 10px 16px;color:var(--text)}.sidebar .brand-sub{font-weight:500;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--faint)}.sidebar nav{display:flex;flex-direction:column;gap:2px;flex:1 1}.sidebar nav a{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;color:var(--muted);font-size:.92rem;text-decoration:none}.sidebar nav a:hover{background:var(--surface-2);color:var(--text);text-decoration:none}.sidebar nav a.active{background:var(--surface-3);color:var(--text)}.sidebar nav a.active svg{color:var(--accent)}.sidebar .spacer{flex:1 1}}.logout-btn{display:flex;align-items:center;gap:10px;width:100%;padding:9px 10px;border:none;border-radius:8px;background:none;color:var(--muted);font-size:.92rem;font-family:inherit;cursor:pointer;text-align:left}.logout-btn:hover{background:var(--surface-2);color:var(--text)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;margin-bottom:10px}.card-title{font-weight:600;overflow-wrap:anywhere}.card-title.done{text-decoration:line-through;color:var(--muted)}.card-meta{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-top:6px;font-size:.8rem;color:var(--muted)}.notes-preview{color:var(--muted);font-size:.85rem;margin-top:4px;overflow-wrap:anywhere;white-space:pre-line}.row{display:flex;align-items:center;gap:10px}.row .grow{flex:1 1;min-width:0}.stats{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:10px;gap:10px;margin-bottom:6px}@media (min-width:640px){.stats{grid-template-columns:repeat(4,1fr)}}.stat{display:block;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;color:var(--text)}.stat,.stat:hover{text-decoration:none}.stat:hover{border-color:var(--accent)}.stat .n{font-size:1.6rem;font-weight:700;line-height:1.15}.stat .n.alert{color:var(--amber)}.stat .lbl{font-size:.78rem;color:var(--muted)}.quicklinks{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 4px}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;font-size:.72rem;font-weight:600;letter-spacing:.02em;border:1px solid var(--border);background:var(--surface-2);color:var(--muted);white-space:nowrap}.badge-accent{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 40%,transparent);background:color-mix(in srgb,var(--accent) 12%,transparent)}.badge-green{color:var(--green);border-color:color-mix(in srgb,var(--green) 40%,transparent);background:color-mix(in srgb,var(--green) 10%,transparent)}.badge-red{color:var(--red);border-color:color-mix(in srgb,var(--red) 45%,transparent);background:color-mix(in srgb,var(--red) 12%,transparent)}.badge-amber{color:var(--amber);border-color:color-mix(in srgb,var(--amber) 45%,transparent);background:color-mix(in srgb,var(--amber) 12%,transparent)}.badge-violet{color:var(--violet);border-color:color-mix(in srgb,var(--violet) 45%,transparent);background:color-mix(in srgb,var(--violet) 12%,transparent)}.chips{display:flex;flex-wrap:nowrap;gap:8px;overflow-x:auto;padding-bottom:6px;margin-bottom:10px;-webkit-overflow-scrolling:touch}.chip{flex-shrink:0;padding:7px 14px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--muted);font-size:.85rem;min-height:36px;display:inline-flex;align-items:center;gap:6px}.chip,.chip:hover{text-decoration:none}.chip:hover{color:var(--text);border-color:var(--faint)}.chip.active{background:color-mix(in srgb,var(--accent) 16%,transparent);border-color:var(--accent);color:var(--accent)}input[type=date],input[type=email],input[type=password],input[type=text],select,textarea{width:100%;padding:10px 12px;min-height:44px;border-radius:8px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-family:inherit;font-size:16px;-moz-appearance:none;appearance:none;-webkit-appearance:none}a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:1px}input::placeholder,textarea::placeholder{color:var(--faint)}textarea{min-height:80px;resize:vertical}select{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' fill='none' stroke='%238d99a9' stroke-width='2' stroke-linecap='round'/></svg>");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}input[type=date]{color-scheme:dark}label{display:block;font-size:.78rem;color:var(--muted);margin-bottom:4px}.field{margin-bottom:10px}.field-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}@media (max-width:480px){.field-grid{grid-template-columns:1fr}}button{font-family:inherit}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:40px;padding:8px 16px;border-radius:8px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-size:.9rem;font-weight:600;cursor:pointer;white-space:nowrap}.btn,.btn:hover{text-decoration:none}.btn:hover{background:var(--surface-3)}.btn:disabled{opacity:.55;cursor:default}.btn-primary{background:var(--accent-strong);border-color:var(--accent-strong);color:#fff}.btn-primary:hover{background:color-mix(in srgb,var(--accent-strong) 85%,#fff 15%)}.btn-green{color:var(--green);border-color:color-mix(in srgb,var(--green) 45%,transparent)}.btn-danger{color:var(--red);border-color:color-mix(in srgb,var(--red) 45%,transparent)}.btn-sm{min-height:34px;padding:5px 12px;font-size:.82rem}.btn-block{width:100%}.actions-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.actions-row form{display:contents}.check-btn{width:30px;height:30px;flex-shrink:0;border-radius:50%;border:2px solid var(--faint);background:transparent;cursor:pointer;color:transparent;display:inline-flex;align-items:center;justify-content:center;padding:0}.check-btn:hover{border-color:var(--green);color:var(--green)}details.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:10px}details.panel>summary{cursor:pointer;padding:12px 14px;font-weight:600;list-style:none;min-height:44px;display:flex;align-items:center;gap:8px;color:var(--accent);-webkit-user-select:none;-moz-user-select:none;user-select:none}details.panel>summary::-webkit-details-marker{display:none}details.panel>summary:before{content:"+";font-weight:700}details.panel[open]>summary:before{content:"–"}details.panel>.panel-body{padding:0 14px 14px}details.inline{margin-top:10px;border-top:1px dashed var(--border);padding-top:8px}details.inline>summary{cursor:pointer;list-style:none;color:var(--accent);font-size:.85rem;font-weight:600;min-height:32px;display:inline-flex;align-items:center;-webkit-user-select:none;-moz-user-select:none;user-select:none}details.inline>summary::-webkit-details-marker{display:none}details.inline>.inline-body{padding-top:10px}.ai-box{margin-top:10px;padding:10px 12px;border-radius:8px;border:1px solid color-mix(in srgb,var(--violet) 35%,transparent);background:color-mix(in srgb,var(--violet) 7%,transparent)}.ai-box .ai-head{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:.75rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--violet);margin-bottom:6px}.ai-box .ai-summary{font-size:.85rem;color:var(--text);margin-bottom:6px}.ai-box .ai-fields{display:flex;flex-wrap:wrap;gap:6px}.email-view{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-size:.85rem}.email-view .hdr{color:var(--muted);margin-bottom:2px;overflow-wrap:anywhere}.email-view pre{margin:8px 0 0;white-space:pre-wrap;overflow-wrap:anywhere;font-family:inherit;color:var(--text);max-height:320px;overflow-y:auto}.group-head{display:flex;align-items:baseline;gap:8px;margin:20px 0 8px}.group-head:first-child{margin-top:0}.group-head .count{color:var(--faint);font-size:.8rem}.empty{border:1px dashed var(--border);border-radius:var(--radius);padding:22px 16px;text-align:center;color:var(--faint);margin-bottom:10px}.warn-banner{border:1px solid color-mix(in srgb,var(--amber) 45%,transparent);background:color-mix(in srgb,var(--amber) 8%,transparent);color:var(--amber);border-radius:var(--radius);padding:10px 14px;font-size:.88rem;margin-bottom:10px}.quick-add{display:flex;gap:8px;margin-bottom:16px}.quick-add input{flex:1 1}.search-bar{display:flex;gap:8px;margin-bottom:14px}.search-bar input{flex:1 1}.step{display:flex;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;margin-bottom:10px}.step .step-n{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:var(--surface-3);color:var(--accent);font-size:.8rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin-top:1px}.step .step-body{flex:1 1;min-width:0}.step ul{margin:8px 0 0;padding-left:18px;font-size:.88rem;color:var(--muted)}.step li{margin-bottom:3px;overflow-wrap:anywhere}.step input[type=checkbox]{width:22px;height:22px;accent-color:var(--green);margin-top:3px;flex-shrink:0}.login-wrap{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:20px}.login-card{width:100%;max-width:360px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:26px 22px}.login-card h1{text-align:center;margin-bottom:2px;letter-spacing:.12em}.login-card .tagline{text-align:center;color:var(--muted);font-size:.85rem;margin-bottom:20px}.form-error{border:1px solid color-mix(in srgb,var(--red) 50%,transparent);background:color-mix(in srgb,var(--red) 10%,transparent);color:var(--red);border-radius:8px;padding:9px 12px;font-size:.85rem;margin-bottom:12px}.proj-row{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;margin-bottom:8px;color:var(--text);text-decoration:none}.proj-row:hover{border-color:var(--accent);text-decoration:none}.proj-row .grow{flex:1 1;min-width:0}.proj-row .name{font-weight:600}