:root {
  --bg:#0a0a0a; --bg2:#111111; --bg3:#1a1a1a; --bg4:#222222;
  --brd:#1e1e1e; --brd2:#2a2a2a; --brd3:#333333;
  --tx:#e2e8f0; --tx2:#94a3b8; --tx3:#525252; --tx4:#333333;
  --grn:#22c55e; --grn-bg:#0d1a0d; --grn-brd:#166534; --grn-tx:#86efac;
  --red:#ef4444; --red-bg:#1a0808; --red-brd:#3b1010; --red-tx:#fca5a5;
  --blu:#3b82f6; --blu-bg:#0d1a2e; --blu-brd:#1e40af; --blu-tx:#93c5fd;
  --amb:#f59e0b; --amb-bg:#1a1200; --amb-brd:#78350f; --amb-tx:#fcd34d;
  --pur:#a78bfa; --pur-bg:#130d2a; --pur-brd:#4c1d95; --pur-tx:#c4b5fd;
  --cyn:#22d3ee; --cyn-bg:#041a1f; --cyn-brd:#155e75; --cyn-tx:#67e8f9;
  --r:8px; --rl:12px;
  --topbar-h:44px;
  --nav-h:52px;
}

*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { -webkit-tap-highlight-color:transparent; }
body {
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  background:var(--bg); color:var(--tx);
  font-size:14px; line-height:1.5;
  overscroll-behavior:none;
  min-height:100vh;
}

/* ── LOGIN ── */
#login-screen {
  display:flex; align-items:center; justify-content:center;
  min-height:100vh; padding:20px;
}
.login-card {
  background:var(--bg2); border:0.5px solid var(--brd2);
  border-radius:var(--rl); padding:36px 28px;
  max-width:300px; width:100%; text-align:center;
}
.login-logo { width:80px; margin:0 auto 20px; display:block; }
.login-card p { font-size:13px; color:var(--tx2); margin-bottom:20px; }
.pin-input {
  font-size:24px; letter-spacing:12px; text-align:center;
  width:100%; padding:12px; border:0.5px solid var(--brd2);
  border-radius:var(--r); background:var(--bg3); color:var(--tx);
  margin-bottom:10px; font-family:monospace;
}
.pin-btn {
  width:100%; padding:11px; border-radius:var(--r); border:none;
  background:var(--blu); color:#fff; font-size:14px; font-weight:500; cursor:pointer;
}
.pin-err { color:var(--red); font-size:12px; margin-top:6px; min-height:16px; }

/* ── APP SHELL ── */
#app { display:none; }

/* TOPBAR — desktop */
.topbar {
  background:var(--bg2); border-bottom:0.5px solid var(--brd);
  height:var(--topbar-h); display:flex; align-items:center;
  padding:0 16px; gap:10px;
  position:sticky; top:0; z-index:100;
}
.logo { font-size:13px; font-weight:600; color:var(--tx); white-space:nowrap; }
.top-sep { width:0.5px; height:16px; background:var(--brd2); flex-shrink:0; }
.top-nav { display:flex; gap:1px; }
.top-tab {
  font-size:11px; color:var(--tx3); padding:5px 10px;
  border-radius:var(--r); cursor:pointer; white-space:nowrap;
  border:none; background:none; transition:color .15s;
}
.top-tab:hover { color:var(--tx2); }
.top-tab.active { background:var(--bg3); color:var(--tx); }
.gchip {
  margin-left:auto; display:flex; align-items:center; gap:5px;
  background:var(--grn-bg); border-radius:20px; padding:3px 10px;
  border:0.5px solid var(--grn-brd); flex-shrink:0; cursor:pointer;
}
.gdot { width:5px; height:5px; border-radius:50%; background:var(--grn); }
.gchip-val { font-size:11px; font-weight:500; color:var(--grn); }
.gchip-delta { font-size:10px; color:var(--grn-brd); }

/* BOTTOM NAV — mobile */
.bottomnav {
  display:none;
  position:fixed; bottom:0; left:0; right:0;
  background:var(--bg2); border-top:0.5px solid var(--brd);
  height:var(--nav-h); z-index:100;
  padding-bottom:env(safe-area-inset-bottom,0px);
}
.bottomnav-inner { display:flex; height:52px; }
.bn-item {
  flex:1; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:2px; cursor:pointer;
}
.bn-item i { font-size:20px; color:var(--tx4); }
.bn-item span { font-size:9px; color:var(--tx4); }
.bn-item.active i, .bn-item.active span { color:var(--grn); }

@media (max-width:680px) {
  .topbar { display:none; }
  .bottomnav { display:block; }
  #app { padding-bottom:calc(var(--nav-h) + env(safe-area-inset-bottom,0px)); }
  .two-col { grid-template-columns:1fr !important; }
  .stat-grid { grid-template-columns:1fr 1fr; }
}

/* ── GLUCOSE STRIP ── */
.gstrip {
  background:var(--bg); padding:10px 16px 0;
  border-bottom:0.5px solid var(--brd);
}
.gstrip-top { display:flex; align-items:flex-start; justify-content:space-between; }
.gnum-row { display:flex; align-items:baseline; gap:4px; }
.gnum { font-size:30px; font-weight:500; color:var(--grn); line-height:1; }
.garrow { font-size:16px; color:var(--grn); }
.gdelta { font-size:13px; color:#166534; }
.gstats { display:flex; gap:12px; margin-top:3px; flex-wrap:wrap; }
.gstat { font-size:11px; color:var(--tx2); }
.gstat strong { color:var(--tx); font-weight:500; }
.gstat strong.c-grn { color:var(--grn); }
.gstat strong.c-red { color:var(--red); }
.gmeta { font-size:10px; color:var(--tx3); margin-top:2px; }
.tir-row { display:flex; align-items:center; gap:8px; margin-top:5px; }
.tir-track { flex:1; max-width:200px; height:4px; border-radius:2px; background:var(--bg3); overflow:hidden; }
.tir-fill { height:100%; background:var(--grn); border-radius:2px; }
.tir-label { font-size:9px; color:var(--tx3); }
.gchart { margin-top:5px; }
.gchart svg { display:block; }
.gchart-labels { display:flex; justify-content:space-between; padding:2px 2px 0; }
.gchart-labels span { font-size:8px; color:var(--tx4); }

/* ── PAGE LAYOUT ── */
.page { display:none; }
.page.active { display:block; }

.two-col {
  display:grid; grid-template-columns:1fr 270px;
  gap:10px; padding:10px 16px;
}
.one-col { padding:10px 16px; }

/* ── PANEL ── */
.panel {
  background:var(--bg2); border-radius:var(--r);
  border:0.5px solid var(--brd); padding:10px 12px;
  margin-bottom:10px;
}
.panel:last-child { margin-bottom:0; }
.panel-title {
  font-size:9px; color:var(--tx3); text-transform:uppercase;
  letter-spacing:.07em; margin-bottom:8px; font-weight:500;
}

/* ── NEXT UP ── */
.nu-list { display:flex; flex-direction:column; gap:5px; }
.nu-item {
  display:flex; align-items:center; gap:8px;
  padding:8px 10px; background:var(--bg3);
  border-radius:var(--r); border:0.5px solid var(--brd2);
}
.nu-item.urgent { background:var(--red-bg); border-color:var(--red-brd); }
.nu-item.soon { background:var(--amb-bg); border-color:var(--amb-brd); }
.nu-icon { font-size:16px; flex-shrink:0; }
.nu-body { flex:1; min-width:0; }
.nu-name { font-size:11px; color:var(--tx); font-weight:500; }
.nu-name.urgent { color:var(--red-tx); }
.nu-sub { font-size:9px; color:var(--tx3); margin-top:1px; }
.nu-sub.urgent { color:var(--red-brd); }
.nu-btns { display:flex; gap:3px; flex-shrink:0; }
.nu-btn {
  border-radius:5px; padding:4px 8px; font-size:9px;
  cursor:pointer; border:0.5px solid; font-weight:500;
  white-space:nowrap;
}
.nu-btn.go { background:var(--grn-bg); color:var(--grn-tx); border-color:var(--grn-brd); }
.nu-btn.skip { background:var(--bg4); color:var(--tx3); border-color:var(--brd2); }
.nu-btn.log { background:var(--blu-bg); color:var(--blu-tx); border-color:var(--blu-brd); }

/* ── TIJDLIJN ── */
.tl { display:flex; flex-direction:column; max-height:400px; overflow-y:auto; }
.tl-row {
  display:flex; align-items:flex-start; gap:8px;
  padding:6px 0; border-bottom:0.5px solid var(--brd);
}
.tl-row:last-child { border-bottom:none; padding-bottom:0; }
.tl-row.alert { background:var(--red-bg); border-radius:5px; padding:6px 6px; margin:-1px 0; }
.tl-time { font-size:9px; color:var(--tx3); width:28px; flex-shrink:0; padding-top:2px; }
.tl-time.alert { color:var(--red); }
.tl-dot {
  width:8px; height:8px; border-radius:50%; flex-shrink:0; margin-top:3px;
}
.tl-dot.planned {
  background:transparent; border:0.5px dashed var(--brd3);
}
.tl-body { flex:1; min-width:0; }
.tl-name { font-size:11px; color:var(--tx2); }
.tl-name.alert { color:var(--red-tx); font-weight:500; }
.tl-name.planned { color:var(--tx4); font-style:italic; }
.tl-sub { font-size:9px; color:var(--tx3); margin-top:1px; }
.tl-sub.alert { color:#7f1d1d; }
.tl-edit { font-size:10px; color:var(--tx4); cursor:pointer; padding:2px 4px; flex-shrink:0; }
.tl-edit:hover { color:var(--tx2); }

/* ── QUICK LOG GRID ── */
.ql-grid { display:grid; grid-template-columns:1fr 1fr; gap:5px; }
.ql-btn {
  display:flex; align-items:center; gap:8px;
  padding:9px 10px; background:var(--bg3);
  border-radius:var(--r); border:0.5px solid var(--brd2);
  cursor:pointer; transition:border-color .15s;
}
.ql-btn:hover { border-color:var(--brd3); }
.ql-btn i { font-size:16px; flex-shrink:0; }
.ql-btn-body { min-width:0; }
.ql-btn-label { font-size:10px; color:var(--tx2); font-weight:500; }
.ql-btn-sub { font-size:8px; color:var(--tx3); }

/* ── MACRO BARS ── */
.mb-row {
  display:grid; grid-template-columns:80px 1fr 56px;
  align-items:center; gap:8px; margin-bottom:6px;
}
.mb-row:last-child { margin-bottom:0; }
.mb-label { font-size:10px; color:var(--tx3); }
.mb-track { height:4px; background:var(--bg3); border-radius:2px; overflow:hidden; }
.mb-fill { height:100%; border-radius:2px; }
.mb-val { font-size:9px; color:var(--tx3); text-align:right; white-space:nowrap; }

/* ── STAT CARDS ── */
.stat-grid { display:grid; grid-template-columns:1fr 1fr; gap:6px; }
.stat-card { background:var(--bg3); border-radius:var(--r); padding:9px 11px; }
.sc-label { font-size:9px; color:var(--tx3); margin-bottom:2px; }
.sc-val { font-size:18px; font-weight:500; color:var(--tx2); line-height:1.2; }
.sc-sub { font-size:9px; color:var(--tx4); margin-top:2px; }
.sc-bar { height:3px; background:var(--bg4); border-radius:2px; margin-top:5px; overflow:hidden; }
.sc-fill { height:100%; border-radius:2px; }

/* ── MED LIST ── */
.med-list { display:flex; flex-direction:column; gap:4px; }
.med-row {
  display:flex; align-items:center; gap:7px;
  padding:6px 9px; background:var(--bg3);
  border-radius:var(--r); border:0.5px solid var(--brd2);
}
.med-row.done { opacity:.4; }
.med-row.urgent { background:var(--red-bg); border-color:var(--red-brd); }
.med-dot { width:7px; height:7px; border-radius:50%; flex-shrink:0; }
.med-name { font-size:10px; color:var(--tx2); flex:1; }
.med-name.urgent { color:var(--red-tx); }
.med-time { font-size:9px; color:var(--tx3); }
.med-time.urgent { color:var(--red); }
.med-status { font-size:10px; font-weight:500; margin-left:3px; flex-shrink:0; }

/* ── TIR WEEK BARS ── */
.tir-week { display:flex; flex-direction:column; gap:5px; }
.tir-week-row { display:flex; align-items:center; gap:6px; }
.tir-week-day { font-size:9px; color:var(--tx3); width:18px; }
.tir-week-day.today { color:var(--grn); font-weight:500; }
.tir-week-track { flex:1; height:5px; background:var(--bg3); border-radius:2px; overflow:hidden; }
.tir-week-fill { height:100%; border-radius:2px; }
.tir-week-val { font-size:9px; color:var(--tx3); width:24px; text-align:right; }

/* ── KALENDER ── */
.cal-month-nav { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.cal-month-title { font-size:13px; font-weight:500; color:var(--tx); }
.cal-nav-btn {
  background:var(--bg3); border:0.5px solid var(--brd2);
  border-radius:var(--r); padding:4px 8px; cursor:pointer;
  font-size:12px; color:var(--tx2);
}
.cal-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:3px; margin-bottom:10px; }
.cal-day-label { font-size:9px; color:var(--tx3); text-align:center; padding:3px 0; }
.cal-day {
  background:var(--bg3); border-radius:5px; padding:5px 3px;
  text-align:center; cursor:pointer; border:0.5px solid var(--brd2);
  min-height:36px; display:flex; flex-direction:column; align-items:center;
}
.cal-day:hover { border-color:var(--brd3); }
.cal-day.today { border-color:var(--grn); background:var(--grn-bg); }
.cal-day.selected { border-color:var(--blu); background:var(--blu-bg); }
.cal-day.has-data { background:var(--bg4); }
.cal-day-num { font-size:10px; color:var(--tx3); }
.cal-day.today .cal-day-num { color:var(--grn); font-weight:500; }
.cal-day.selected .cal-day-num { color:var(--blu-tx); }
.cal-dot { width:4px; height:4px; border-radius:50%; background:var(--grn); margin:2px auto 0; }
.cal-day.bad .cal-dot { background:var(--red); }
.cal-day.ok .cal-dot { background:var(--amb); }

/* ── BEHEER ── */
.bh-row {
  display:flex; align-items:center; justify-content:space-between;
  padding:8px 10px; background:var(--bg3);
  border-radius:var(--r); border:0.5px solid var(--brd2); margin-bottom:4px;
}
.bh-label { font-size:11px; color:var(--tx2); }
.bh-val { font-size:10px; color:var(--tx3); margin-top:1px; }
.bh-btn {
  border-radius:5px; padding:4px 9px; font-size:10px; cursor:pointer;
  border:0.5px solid var(--brd2); background:var(--bg4); color:var(--tx2);
  white-space:nowrap; flex-shrink:0;
}
.bh-btn.grn { background:var(--grn-bg); color:var(--grn-tx); border-color:var(--grn-brd); }
.bh-btn.blu { background:var(--blu-bg); color:var(--blu-tx); border-color:var(--blu-brd); }
.toggle {
  width:30px; height:17px; background:var(--bg4);
  border-radius:9px; position:relative; cursor:pointer;
  border:0.5px solid var(--brd2); flex-shrink:0; transition:background .2s;
}
.toggle.on { background:var(--grn); border-color:var(--grn); }
.toggle-dot {
  width:13px; height:13px; background:var(--tx3);
  border-radius:50%; position:absolute; top:1px; left:1px; transition:left .2s, background .2s;
}
.toggle.on .toggle-dot { left:14px; background:#fff; }

/* ── VERSLAGEN ── */
.verslag-nav { display:flex; gap:5px; margin-bottom:10px; flex-wrap:wrap; }
.verslag-day-btn {
  background:var(--bg3); border-radius:var(--r);
  border:0.5px solid var(--brd2); padding:4px 10px;
  font-size:10px; color:var(--tx3); cursor:pointer;
}
.verslag-day-btn.active { border-color:var(--grn); color:var(--grn); background:var(--grn-bg); }
.verslag-body { line-height:1.7; }
.verslag-h {
  font-size:10px; font-weight:500; color:var(--tx3);
  text-transform:uppercase; letter-spacing:.07em;
  margin:12px 0 5px; padding-bottom:4px; border-bottom:0.5px solid var(--brd);
}
.verslag-h:first-child { margin-top:0; }
.verslag-item {
  font-size:12px; color:var(--tx3);
  padding-left:12px; position:relative; margin-bottom:3px;
}
.verslag-item::before { content:"·"; position:absolute; left:0; color:var(--tx4); }
.verslag-item strong { color:var(--tx2); font-weight:500; }
.verslag-item.good strong { color:var(--grn-tx); }
.verslag-item.alert strong { color:var(--red-tx); }
.verslag-item.warn strong { color:var(--amb-tx); }
.verslag-gen-btn {
  background:var(--blu-bg); border:0.5px solid var(--blu-brd);
  color:var(--blu-tx); border-radius:var(--r); padding:5px 12px;
  font-size:10px; cursor:pointer; margin-left:auto;
}

/* ── CLAUDE PAGE ── */
.claude-page { display:flex; flex-direction:column; height:calc(100vh - var(--topbar-h) - 240px); min-height:300px; }
.claude-messages { flex:1; overflow-y:auto; padding:10px 0; display:flex; flex-direction:column; gap:8px; }
.claude-msg {
  max-width:80%; padding:9px 12px; border-radius:var(--r);
  font-size:12px; line-height:1.6;
}
.claude-msg.user {
  background:var(--blu-bg); color:var(--blu-tx);
  border:0.5px solid var(--blu-brd); margin-left:auto;
  border-radius:var(--r) var(--r) 2px var(--r);
}
.claude-msg.ai {
  background:var(--bg3); color:var(--tx2);
  border:0.5px solid var(--brd2);
  border-radius:var(--r) var(--r) var(--r) 2px;
}
.claude-input-row {
  display:flex; gap:6px; padding-top:10px;
  border-top:0.5px solid var(--brd);
}
.claude-input-row input {
  flex:1; background:var(--bg3); border:0.5px solid var(--brd2);
  border-radius:var(--r); padding:8px 11px; color:var(--tx);
  font-size:12px; outline:none;
}
.claude-input-row input:focus { border-color:var(--blu-brd); }
.claude-send-btn {
  background:var(--blu-bg); border:0.5px solid var(--blu-brd);
  color:var(--blu-tx); border-radius:var(--r); padding:8px 14px;
  font-size:12px; cursor:pointer;
}

/* ── MODAL ── */
.modal-overlay {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.6); z-index:200;
  align-items:flex-end; justify-content:center;
}
.modal-overlay.open { display:flex; }
@media (min-width:600px) {
  .modal-overlay { align-items:center; }
  .modal-card { border-radius:var(--rl) !important; max-width:480px; max-height:85vh; }
}
.modal-card {
  background:var(--bg2); border-radius:var(--rl) var(--rl) 0 0;
  width:100%; max-width:640px; max-height:90vh; overflow-y:auto;
  border:0.5px solid var(--brd2);
}
.modal-drag { width:36px; height:3px; background:var(--brd2); border-radius:2px; margin:10px auto 0; }
.modal-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 16px 12px; border-bottom:0.5px solid var(--brd);
}
.modal-title { font-size:15px; font-weight:600; }
.modal-close {
  border:none; background:none; color:var(--tx3);
  cursor:pointer; font-size:18px; line-height:1; padding:0 0 0 10px;
}
.modal-body { padding:14px 16px; }
.modal-row { display:flex; align-items:center; gap:8px; margin-bottom:10px; flex-wrap:wrap; }
.modal-lbl { font-size:12px; color:var(--tx2); min-width:72px; flex-shrink:0; }
.modal-input {
  padding:7px 10px; border-radius:var(--r); border:0.5px solid var(--brd2);
  background:var(--bg3); color:var(--tx); font-size:13px; outline:none;
}
.modal-input:focus { border-color:var(--blu-brd); }
.modal-input[type=time] { width:100px; }
.modal-input[type=number] { width:90px; }
.modal-input.wide { width:100%; }
.modal-textarea {
  width:100%; padding:8px 10px; border-radius:var(--r);
  border:0.5px solid var(--brd2); background:var(--bg3); color:var(--tx);
  font-size:13px; resize:vertical; min-height:60px; outline:none;
}
.modal-textarea:focus { border-color:var(--blu-brd); }
.modal-footer {
  display:flex; gap:6px; padding:0 16px 16px; flex-wrap:wrap;
}
.modal-save {
  flex:1; padding:10px; border-radius:var(--r); border:none;
  background:var(--blu); color:#fff; font-size:14px; font-weight:500; cursor:pointer;
}
.modal-save:hover { background:#2563eb; }
.modal-cancel {
  padding:10px 14px; border-radius:var(--r);
  border:0.5px solid var(--brd2); background:none; color:var(--tx2);
  font-size:13px; cursor:pointer;
}
.modal-delete {
  padding:10px 14px; border-radius:var(--r);
  border:0.5px solid var(--red-brd); background:none; color:var(--red);
  font-size:13px; cursor:pointer;
}
.modal-section-title {
  font-size:9px; color:var(--tx3); text-transform:uppercase;
  letter-spacing:.07em; margin-bottom:8px; margin-top:4px;
}

/* ── TOAST ── */
.toast {
  position:fixed; bottom:80px; left:50%; transform:translateX(-50%) translateY(20px);
  background:var(--bg4); border:0.5px solid var(--brd2); color:var(--tx2);
  border-radius:var(--r); padding:8px 16px; font-size:12px;
  opacity:0; transition:opacity .2s, transform .2s; pointer-events:none; z-index:300;
  white-space:nowrap;
}
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }
.toast.ok { background:var(--grn-bg); border-color:var(--grn-brd); color:var(--grn-tx); }
.toast.err { background:var(--red-bg); border-color:var(--red-brd); color:var(--red-tx); }

/* ── GEWICHT GRAFIEK ── */
.weight-chart { margin-top:8px; }

/* ── DAGTYPE ── */
.dagtype-btn {
  display:flex; align-items:center; gap:5px;
  padding:5px 10px; border-radius:var(--r);
  border:0.5px solid var(--brd2); background:var(--bg3);
  color:var(--tx3); font-size:11px; cursor:pointer;
  transition:all .15s;
}
.dagtype-btn:hover { border-color:var(--brd3); color:var(--tx2); }
.dagtype-btn.active { background:var(--blu-bg); border-color:var(--blu-brd); color:var(--blu-tx); }
.dagtype-btn[data-type="kantoor"].active { background:var(--blu-bg); border-color:var(--blu-brd); color:var(--blu-tx); }
.dagtype-btn[data-type="thuis"].active { background:var(--grn-bg); border-color:var(--grn-brd); color:var(--grn-tx); }
.dagtype-btn[data-type="vrij"].active { background:var(--amb-bg); border-color:var(--amb-brd); color:var(--amb-tx); }

/* ── LOADING STATES ── */
.loading { color:var(--tx3); font-size:11px; padding:8px 0; text-align:center; }
.empty { color:var(--tx3); font-size:11px; padding:12px 0; text-align:center; font-style:italic; }

/* ── DIVIDER ── */
.divider { height:0.5px; background:var(--brd); margin:8px 0; }

/* ── BADGE ── */
.badge {
  display:inline-flex; align-items:center;
  border-radius:4px; padding:2px 6px; font-size:9px; font-weight:500;
}
.badge.red { background:var(--red-bg); color:var(--red-tx); border:0.5px solid var(--red-brd); }
.badge.grn { background:var(--grn-bg); color:var(--grn-tx); border:0.5px solid var(--grn-brd); }
.badge.amb { background:var(--amb-bg); color:var(--amb-tx); border:0.5px solid var(--amb-brd); }
.badge.blu { background:var(--blu-bg); color:var(--blu-tx); border:0.5px solid var(--blu-brd); }
