:root{--paper: #f2f4ef;--card: #ffffff;--ink: #22322b;--muted: #6f7f74;--line: #dde3da;--fresh: #3e7c59;--rust: #d14d27;--brass: #e0a31e;--radius: 12px;font-size:16px}*{box-sizing:border-box}body{margin:0;background:var(--paper);color:var(--ink);font-family:Atkinson Hyperlegible,system-ui,sans-serif;line-height:1.5}h1,h2,h3{font-family:Bricolage Grotesque,system-ui,sans-serif;letter-spacing:-.01em;margin:0 0 .4em}h1{font-size:1.9rem;font-weight:800}h2{font-size:1.3rem;font-weight:600}h3{font-size:1.05rem;font-weight:600}a{color:var(--fresh)}.shell{max-width:880px;margin:0 auto;padding:0 1rem 4rem}.topbar{display:flex;align-items:center;gap:1.25rem;padding:.9rem 0;margin-bottom:1.5rem;border-bottom:2px solid var(--ink)}.brand{font-family:Bricolage Grotesque,sans-serif;font-weight:800;font-size:1.2rem;text-decoration:none;color:var(--ink)}.brand span{color:var(--fresh)}.topbar nav{display:flex;gap:1rem;flex-wrap:wrap}.topbar nav a{text-decoration:none;color:var(--muted);font-weight:700}.topbar nav a.active,.topbar nav a:hover{color:var(--ink)}.topbar .spacer{flex:1}.whoami{color:var(--muted);font-size:.9rem}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem 1.25rem;margin-bottom:1rem}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 720px){.grid2{grid-template-columns:1fr}}label{display:block;font-weight:700;font-size:.85rem;margin:.7rem 0 .25rem}input,select,textarea{width:100%;padding:.55rem .7rem;border:1px solid var(--line);border-radius:8px;font:inherit;background:#fff;color:var(--ink)}input:focus,select:focus,textarea:focus,button:focus-visible{outline:3px solid color-mix(in srgb,var(--fresh) 35%,transparent);outline-offset:1px}.row{display:flex;gap:.5rem;align-items:flex-end;flex-wrap:wrap}.row>*{flex:1;min-width:120px}.row>.fit{flex:0 0 auto;min-width:0}button{font:inherit;font-weight:700;cursor:pointer;border:none;border-radius:8px;padding:.55rem 1rem;background:var(--ink);color:#fff}button:hover{filter:brightness(1.12)}button.primary{background:var(--fresh)}button.ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}button.danger{background:transparent;color:var(--rust);border:1px solid var(--rust)}button:disabled{opacity:.5;cursor:default}.chore{display:flex;align-items:center;gap:.9rem;background:var(--card);border:1px solid var(--line);border-left:6px solid var(--fresh);border-radius:var(--radius);padding:.8rem 1rem;margin-bottom:.6rem}.chore.due{border-left-color:var(--brass)}.chore.overdue{border-left-color:var(--rust)}.chore .meta{flex:1;min-width:0}.chore .name{font-weight:700}.chore .sub{color:var(--muted);font-size:.85rem}.badge{font-size:.75rem;font-weight:700;padding:.15rem .55rem;border-radius:999px;white-space:nowrap}.badge.due{background:color-mix(in srgb,var(--brass) 18%,white);color:#7a5708}.badge.overdue{background:color-mix(in srgb,var(--rust) 14%,white);color:var(--rust)}.badge.ok{background:color-mix(in srgb,var(--fresh) 14%,white);color:var(--fresh)}.score-row{display:flex;align-items:baseline;gap:.8rem;padding:.6rem 0;border-bottom:1px dashed var(--line)}.score-row .rank{font-family:Bricolage Grotesque,sans-serif;font-weight:800;width:1.6rem;color:var(--muted)}.score-row .total{margin-left:auto;font-family:Bricolage Grotesque,sans-serif;font-weight:800;font-size:1.3rem}.msg{padding:.6rem .9rem;border-radius:8px;margin:.6rem 0;font-size:.92rem}.msg.error{background:color-mix(in srgb,var(--rust) 12%,white);color:var(--rust)}.msg.ok{background:color-mix(in srgb,var(--fresh) 12%,white);color:var(--fresh)}.empty{color:var(--muted);font-style:italic;padding:.5rem 0}.auth-wrap{max-width:400px;margin:8vh auto 0}.auth-wrap .brand{font-size:1.6rem;display:block;margin-bottom:1rem;text-align:center}ul.plain{list-style:none;padding:0;margin:0}@media (prefers-reduced-motion: no-preference){.chore{transition:transform .12s ease}.chore:hover{transform:translate(2px)}}
