/* House Keeper v0.2 — UI base, carried from screen-board.html (the approved
   static mockup). Mobile-first; the desktop overseer table reuses the same
   tokens. */
:root{
  /* R4.2: softer, less-saturated primary blue (was #2563eb, a vivid royal blue).
     A muted slate-blue reads calmer on the Start/Accept/Add-note buttons, the
     NEW badge, links and accents. */
  --pri:#4674b0; --ink:#0f172a; --mut:#64748b; --bd:#e2e8f0;
  /* R4.4: lighten the page background a touch (was #e9edf2) so the segmented
     option boxes — especially the selected one — stand out against it. */
  --bg:#f1f4f8; --card:#fff; --slate:#1e293b;
  /* R4.1: button cap width — keep buttons roughly phone-size on wide viewports
     instead of filling the card. */
  --btn-max:260px;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);
  font:15px/1.45 -apple-system,system-ui,"Segoe UI",Roboto,sans-serif;}
a{color:inherit;text-decoration:none}

/* app shell */
.appbar{background:var(--slate);color:#fff;padding:13px 15px;display:flex;
  align-items:center;justify-content:space-between;position:sticky;top:0;z-index:5}
.appbar .t{font-weight:600;display:flex;align-items:center;gap:8px}
.appbar .back{opacity:.85}
.appbar .who{font-size:12px;opacity:.85}
.appbar .acts{display:flex;align-items:center;gap:8px}
.ibtn{background:#334155;color:#fff;border-radius:999px;padding:4px 10px;
  font-size:12px;display:inline-flex;align-items:center;gap:6px}
.ibtn .n{background:#ef4444;border-radius:999px;padding:0 6px;font-size:11px;font-weight:700}
.body{padding:13px;max-width:760px;margin:0 auto}

/* job cards */
.job{background:#fff;border:1px solid var(--bd);border-radius:12px;padding:11px 12px;margin-bottom:10px;display:block}
.job.new{border:1px solid #bfdbfe;background:#f5f9ff;box-shadow:0 0 0 3px #eff6ff}
.job.declined{border:1px solid #fecaca;background:#fff7f7;box-shadow:0 0 0 3px #fef2f2}
.job.moved{border:1px solid #fed7aa;background:#fffaf5;box-shadow:0 0 0 3px #fff7ed}
.job .tt{font-weight:600;margin:0 0 6px;font-size:14.5px}
.row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.meta{margin-top:7px}
.chip{font-size:11px;padding:2px 8px;border-radius:999px;white-space:nowrap;font-weight:600}
.wimpole{background:#dbeafe;color:#1e40af}
.snow{background:#fef3c7;color:#92400e}
.both{background:#e0e7ff;color:#3730a3}
.type{background:#f1f5f9;color:#475569;font-weight:500}
.own{background:#ede9fe;color:#5b21b6}
.recur{background:#f0fdfa;color:#0f766e}
.badge-new{background:var(--pri);color:#fff;font-size:10.5px;padding:2px 8px;border-radius:999px;font-weight:700;letter-spacing:.03em}
.badge-declined{background:#fee2e2;color:#b91c1c;font-size:10.5px;padding:2px 8px;border-radius:999px;font-weight:700;letter-spacing:.03em}
.badge-moved{background:#ffedd5;color:#9a3412;font-size:10.5px;padding:2px 8px;border-radius:999px;font-weight:700;letter-spacing:.03em}
.badge-note{background:#fef9c3;color:#854d0e;font-size:10.5px;padding:2px 8px;border-radius:999px;font-weight:700;letter-spacing:.03em}
.pri{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;color:var(--mut)}
.dot{width:8px;height:8px;border-radius:50%}
.high{background:#dc2626}.med{background:#d97706}.low{background:#94a3b8}
.st{font-size:11px;padding:2px 8px;border-radius:6px;font-weight:600}
.ns{background:#f1f5f9;color:#64748b}
.stnew{background:#eff6ff;color:#1d4ed8}
.accepted{background:#f1f5f9;color:#475569}
.started{background:#dbeafe;color:#1d4ed8}
.done{background:#dcfce7;color:#166534}
.datenote{font-size:11px;color:#94a3b8}
.small{font-size:11.5px;color:var(--mut)}
.req{color:#dc2626;font-size:11px;font-weight:600}
.divlabel{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:#94a3b8;margin:4px 2px 9px}
.ordiv{text-align:center;color:#94a3b8;font-size:12px;margin:18px 0 6px;border-top:1px solid var(--bd);padding-top:13px}

/* buttons + form
   R4.1: buttons keep their phone-view size on the desktop — cap the width
   (var(--btn-max)) so they don't balloon to fill the card on a wide viewport.
   width:100% lets them shrink to fit a narrow phone; max-width holds them at
   ~phone size on a wide one. */
.btn{display:block;width:100%;max-width:var(--btn-max);text-align:center;background:var(--pri);color:#fff;
  border:none;border-radius:10px;padding:11px;font-weight:600;font-size:14px;margin-top:8px;cursor:pointer}
.btn.ghost{background:#fff;color:var(--pri);border:1px solid #b9cbe2}
.btn.green{background:#16a34a}
.btn.danger{background:#fff;color:#b91c1c;border:1px solid #fecaca}
.btn.grey{background:#64748b}
.btn.disabled,.btn[disabled]{opacity:.55;cursor:default;pointer-events:none}
/* R4.3: the current-state button — shown selected but inactive, so it reads as
   "this is where the job is now", not a live action. */
.btn.current{background:#eef2f7;color:#475569;border:1.5px solid #cbd5e1;font-weight:700;cursor:default}
.accept{display:block;width:100%;max-width:var(--btn-max);text-align:center;background:var(--pri);color:#fff;
  border:none;border-radius:10px;padding:9px;font-weight:600;font-size:13.5px;margin-top:9px;cursor:pointer}
.field{margin:0 0 14px}
.field label{display:block;font-size:12.5px;font-weight:600;margin-bottom:6px}
.input,.area,select{width:100%;border:1px solid var(--bd);border-radius:9px;padding:9px 10px;font:inherit;color:var(--ink);background:#fff}
.area{min-height:60px;resize:vertical}
.seg{display:flex;gap:8px}
/* R4.4: stronger resting border (#cbd5e1, a clear slate-300, not the faint
   --bd) and a slightly off-white fill so each option box is bounded against
   the lightened page background. */
.seg label{flex:1;border:1.5px solid #cbd5e1;border-radius:9px;padding:9px;text-align:center;font-size:13px;color:var(--mut);background:#fff;cursor:pointer}
.seg input{position:absolute;opacity:0;pointer-events:none}
.seg input:checked + span{color:var(--pri);font-weight:600}
/* R4.4: the SELECTED option is unmistakably bounded — a 2px primary border and
   a soft tinted fill, with a ring so it stands clear of the neighbours. */
.seg label:has(input:checked){border:2px solid var(--pri);background:#e8eff8;color:var(--pri);font-weight:600;box-shadow:0 0 0 2px rgba(70,116,176,.18)}
.helper{font-size:11.5px;color:var(--mut);margin:6px 2px 0}
/* R4.5: friendly inline message when 'Both' is picked where the rule forbids it
   — teaches the rule instead of a raw 400 page. */
.formerror{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;border-radius:9px;padding:9px 11px;font-size:12.5px;margin:8px 2px 0}

/* signin */
.signin{display:flex;flex-direction:column;justify-content:flex-start;align-items:center;padding:36px 24px;max-width:420px;margin:0 auto}
.logo{font-size:24px;font-weight:800;letter-spacing:-.01em}
.logo .k{color:var(--pri)}
.sub{color:var(--mut);font-size:13px;margin:6px 0 26px;text-align:center}
.reask{background:#fffbeb;border:1px solid #fde68a;color:#92400e;border-radius:10px;padding:10px 12px;font-size:12.5px;width:100%;margin-bottom:18px}
.mail{font-size:38px;margin:8px 0 4px;text-align:center}

/* job detail */
.h3{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:#94a3b8;margin:16px 0 7px}
.desc{font-size:13.5px;color:#334155;white-space:pre-wrap}
.notebubble{background:#f8fafc;border:1px solid var(--bd);border-radius:10px;padding:9px 11px;font-size:13px;margin-bottom:8px}
.notemeta{font-size:11px;color:#94a3b8;margin-top:4px}
/* R4.1: the status-control row caps at phone width too; inside it each button
   fills its flex cell (so the capped pair sits side-by-side, phone-sized). */
.statusrow{display:flex;gap:8px;margin-top:6px;max-width:var(--btn-max)}
.statusrow form{flex:1}
.statusrow .btn{margin-top:0;max-width:none;width:100%}
.statusrow .reopen{margin-top:0}

/* desktop table (overseer all-jobs) */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--bd);background:#fff;flex-wrap:wrap;gap:8px}
.topbar .lt{font-weight:700;font-size:16px}
.topbar .rt{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.pill{background:#fff;border:1px solid var(--bd);border-radius:999px;padding:6px 12px;font-size:12.5px;color:#475569;display:inline-flex;gap:7px;align-items:center}
.pill.acc{background:var(--pri);color:#fff;border-color:var(--pri)}
table{width:100%;border-collapse:collapse;font-size:13px;background:#fff}
th{text-align:left;color:#94a3b8;font-size:11px;text-transform:uppercase;letter-spacing:.04em;
  padding:10px 14px;border-bottom:1px solid var(--bd);font-weight:600}
td{padding:11px 14px;border-bottom:1px solid #f1f5f9}
tr:last-child td{border-bottom:none}
.inbox-item{display:flex;align-items:center;justify-content:space-between;
  background:#fff;border:1px solid var(--bd);border-radius:12px;padding:12px;margin-bottom:10px}
.chev{color:#cbd5e1;font-size:20px}
.linklike{color:var(--pri);text-align:center;display:block;margin-top:12px;font-size:12.5px}
/* R4.6: owner filter bar on All Jobs — pill chips, wrapping, the selected one
   highlighted in the (softened) primary. */
.filterbar{display:flex;flex-wrap:wrap;gap:7px;margin:0 0 12px}
.filt{border:1px solid var(--bd);background:#fff;color:#475569;border-radius:999px;
  padding:6px 13px;font-size:12.5px;font-weight:600;cursor:pointer}
.filt.on{background:var(--pri);color:#fff;border-color:var(--pri)}
.empty{text-align:center;color:var(--mut);padding:30px 10px;font-size:13.5px}
