:root{
  --paper:#F5F8F6; --card:#FFFFFF; --ink:#22313A; --muted:#5D6E74;
  --accent:#0F7A63; --accent-dark:#0B5F4D; --accent-soft:#E3F0EB; --accent-line:#BAD8CE;
  --warn:#A96A1C; --warn-soft:#FBF1DE;
  --crit:#B3372E; --crit-soft:#FBEAE7;
  --line:#D9E1DC;
}
*{box-sizing:border-box; margin:0; padding:0;}
[hidden]{display:none !important;}
html{-webkit-text-size-adjust:100%;}
body{
  background:var(--paper); color:var(--ink);
  font-family:-apple-system,"Segoe UI",Roboto,"Noto Sans",sans-serif;
  font-size:18px; line-height:1.45;
}
.screen{display:none; min-height:100vh; max-width:560px; margin:0 auto;}
.screen.active{display:block;}
.pad{padding:16px 16px 48px; display:flex; flex-direction:column; gap:14px;}

.apphead{
  background:var(--accent); color:#fff; padding:14px 16px;
  display:flex; align-items:center; gap:10px; position:sticky; top:0; z-index:5;
}
.apphead h1{font-size:20px; font-weight:700; flex:1; text-align:center;}
.apphead .back{
  background:none; border:none; color:#fff; font-size:19px; font-weight:600;
  padding:6px 10px 6px 0; cursor:pointer;
}
.apphead .back + h1{text-align:left;}

.bar{
  background:#EDF3F0; border:1px solid var(--line); border-radius:10px;
  padding:12px 14px; font-size:17px;
}
.bar.slim{padding:8px 14px;}
.bar input[type=date]{font-size:18px; border:none; background:none; width:100%; color:var(--ink);}

button.big, label.big{
  display:flex; align-items:center; justify-content:center; width:100%;
  min-height:60px; padding:14px; border-radius:14px; cursor:pointer;
  font-size:19px; font-weight:700; font-family:inherit;
  border:2px solid var(--ink); background:var(--card); color:var(--ink);
  text-align:center;
}
button.big.primary{background:var(--accent); border-color:var(--accent); color:#fff;}
button.big.primary:active{background:var(--accent-dark);}
button.big.tall{min-height:76px; font-size:21px;}
button.big.ghost{border-style:dashed; border-color:var(--muted); color:var(--muted); font-weight:600;}
button.big.danger{color:var(--crit); border-color:var(--crit);}
button.big:disabled{opacity:.45; cursor:default;}
button.link{background:none; border:none; color:var(--accent); font-size:16px; text-decoration:underline; cursor:pointer;}

.card{
  background:var(--card); border:1.5px solid var(--line); border-radius:12px;
  padding:14px 16px; font-size:17px;
}
.card.ok{border-color:var(--accent-line); background:var(--accent-soft);}
.card.warn{border-color:var(--warn); background:var(--warn-soft);}
.card.crit{border-color:var(--crit); background:var(--crit-soft);}
.card .row{display:flex; justify-content:space-between; align-items:center; padding:4px 0; gap:8px;}
.card .row strong{font-size:20px;}

.hint{color:var(--muted); font-size:16px;}
.hint.center{text-align:center;}

/* review cards */
.entry{
  background:var(--card); border:1.5px solid var(--line); border-radius:12px; padding:12px 14px;
  display:flex; flex-direction:column; gap:6px;
}
.entry.warn{border-color:var(--warn); background:var(--warn-soft);}
.entry.crit{border-color:var(--crit); background:var(--crit-soft);}
.entry .who{font-weight:700; font-size:19px;}
.entry .id{color:var(--muted); font-size:14px; font-family:ui-monospace,Menlo,monospace;}
.entry .dose{font-size:17px;}
.entry .why{font-size:15.5px; color:var(--warn); font-weight:600;}
.entry.crit .why{color:var(--crit);}
.entry .actions{display:flex; gap:8px; margin-top:6px; flex-wrap:wrap;}
.entry .actions button{
  flex:1; min-height:48px; border-radius:10px; font-size:16px; font-weight:700;
  border:2px solid var(--ink); background:#fff; cursor:pointer; font-family:inherit; min-width:110px;
}
.entry .actions button.yes{background:var(--accent); border-color:var(--accent); color:#fff;}
.entry .actions button.no{color:var(--crit); border-color:var(--crit);}
.entry .edit{display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-top:6px;}
.entry .edit label{font-size:14px; color:var(--muted); display:flex; flex-direction:column; gap:2px;}
.entry .edit input{font-size:20px; padding:10px; border:1.5px solid var(--line); border-radius:8px; width:100%; font-family:inherit;}
.entry .edit .wide{grid-column:1 / -1;}

.okfold{background:var(--accent-soft); border:1.5px solid var(--accent-line); border-radius:12px;}
.okfold summary{padding:14px 16px; font-weight:700; font-size:17px; cursor:pointer; list-style-position:inside;}
.okfold .listrow{border-top:1px solid var(--accent-line);}

.listrow{
  display:flex; justify-content:space-between; align-items:center; gap:10px;
  padding:12px 14px; background:var(--card); border-bottom:1px solid var(--line);
  cursor:pointer;
}
.listrow:first-child{border-radius:12px 12px 0 0;}
.listrow:last-child{border-radius:0 0 12px 12px; border-bottom:none;}
.listrow .nm{font-weight:600;}
.listrow .num{font-family:ui-monospace,Menlo,monospace; font-size:15px; text-align:right; white-space:nowrap;}
#browse-list, #search-results, #client-days{border:1.5px solid var(--line); border-radius:12px; overflow:hidden; background:var(--card);}
#browse-list:empty, #search-results:empty, #client-days:empty{border:none;}

.search{
  width:100%; font-size:19px; padding:14px; border:2px solid var(--line); border-radius:12px;
  font-family:inherit; background:var(--card);
}
.chips{display:flex; gap:8px; flex-wrap:wrap;}
.chip{
  border:1.5px solid var(--line); background:var(--card); border-radius:999px;
  padding:9px 16px; font-size:16px; font-weight:600; cursor:pointer; font-family:inherit;
}
.chip.on{background:var(--ink); border-color:var(--ink); color:#fff;}

.photo-thumb{
  display:flex; align-items:center; gap:12px; background:var(--accent-soft);
  border:1.5px solid var(--accent-line); border-radius:12px; padding:10px 14px; margin-bottom:10px;
}
.photo-thumb img{width:64px; height:64px; object-fit:cover; border-radius:8px;}
.photo-thumb .rm{margin-left:auto; background:none; border:none; color:var(--crit); font-size:22px; cursor:pointer;}
label.photo-add{border-style:dashed; color:var(--accent); border-color:var(--accent);}

.progress{display:flex; align-items:center; gap:14px; padding:14px; background:var(--card);
  border:1.5px solid var(--line); border-radius:12px; font-size:17px;}
.spinner{width:28px; height:28px; border:4px solid var(--accent-soft); border-top-color:var(--accent);
  border-radius:50%; animation:spin 1s linear infinite; flex:none;}
@keyframes spin{to{transform:rotate(360deg);}}
@media (prefers-reduced-motion: reduce){.spinner{animation:none;}}

button:focus-visible, input:focus-visible, .chip:focus-visible, summary:focus-visible{
  outline:3px solid var(--accent); outline-offset:2px;
}

.rowcrop{
  width:100%; border:1.5px solid var(--line); border-radius:8px; background:#fff;
  margin:4px 0; display:block;
}
.entry.vok{border-color:var(--accent-line); background:var(--accent-soft);}
button.mini{
  flex:1; min-height:44px; border-radius:10px; font-size:15px; font-weight:700;
  border:2px solid var(--ink); background:#fff; cursor:pointer; font-family:inherit;
}
button.mini.yes{background:var(--accent); border-color:var(--accent); color:#fff;}
#browse-list .entry{border-radius:0; border-bottom:none;}
#browse-list .entry:last-child{border-bottom:1.5px solid var(--line);}

.attach-row{display:flex; gap:10px; overflow-x:auto; padding:4px 2px;}
.attach-row a{
  flex:0 0 auto; display:flex; flex-direction:column; align-items:center; gap:4px;
  text-decoration:none; color:var(--muted); font-size:12px; font-weight:600;
}
.attach-row img{
  width:74px; height:74px; object-fit:cover; border-radius:10px;
  border:1.5px solid var(--line); background:#fff;
}
.attach-row .xlsx-chip{
  width:74px; height:74px; border:1.5px solid var(--accent-line); border-radius:10px;
  background:var(--accent-soft); display:flex; flex-direction:column;
  align-items:center; justify-content:center; font-size:22px; color:var(--accent);
  text-align:center; line-height:1.1;
}
.attach-row .xlsx-chip span{font-size:11px; font-weight:700;}

#pin-overlay{
  position:fixed; inset:0; background:var(--paper); z-index:50;
  display:flex; align-items:center; justify-content:center; padding:24px;
}
.pin-box{
  width:100%; max-width:380px; background:var(--card); border:1.5px solid var(--line);
  border-radius:16px; padding:28px 22px; display:flex; flex-direction:column; gap:14px;
  text-align:center;
}
.pin-box h2{font-size:24px;}
.pin-box input{
  font-size:32px; text-align:center; letter-spacing:10px; padding:12px;
  border:2px solid var(--line); border-radius:12px; width:100%; font-family:inherit;
}
