/* ============================================================
   DocMoates + — Wellness Sage shared theme (Chrome OS editions)
   One stylesheet shared by all six desktop apps. Each app sets
   --ac (accent) on <body data-app> and reuses these components.
   ============================================================ */
:root{
  --bg:#faf6f1; --card:#ffffff; --border:#e8ddc9; --divider:#f0e8d8;
  --ink:#3d2f24; --muted:#88715c;
  --sage:#9caf88; --sage-dark:#5c7c5c; --water:#7c9caf; --gold:#caa86a;
  --purple:#a87caf; --warm:#c8907c; --teal:#10a37f;
  --shadow:0 18px 50px -24px rgba(61,47,36,.45);
  --serif:Georgia,'Times New Roman',serif;
  --sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --ac:#5c7c5c;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);line-height:1.5;-webkit-font-smoothing:antialiased;overflow:hidden}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font:inherit;color:inherit}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#e2d6c0;border-radius:8px;border:2px solid var(--bg)}

/* ---------- app shell: title bar + sidebar + content ---------- */
.app-shell{display:flex;flex-direction:column;height:100vh}
.titlebar{height:38px;flex:none;display:flex;align-items:center;gap:10px;padding:0 14px;background:#f3ece1;border-bottom:1px solid var(--border);-webkit-app-region:drag;user-select:none}
.titlebar .brand{font-family:var(--serif);font-weight:700;font-size:14px;display:flex;align-items:center;gap:8px}
.titlebar .brand .plus{color:var(--ac)}
.titlebar .sync{margin-left:auto;font-size:11px;color:var(--muted);display:flex;align-items:center;gap:6px;-webkit-app-region:no-drag}
.titlebar .sync .dotg{width:7px;height:7px;border-radius:50%;background:#1f9d6b;display:inline-block}
.titlebar .sync.off .dotg{background:#caa86a}
.body{flex:1;display:flex;min-height:0}

.sidebar{width:204px;flex:none;background:#f6f0e6;border-right:1px solid var(--border);display:flex;flex-direction:column;padding:14px 10px;gap:3px;overflow-y:auto}
.sidebar .logo{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;color:#fff;font-family:var(--serif);font-weight:700;font-size:18px;margin:4px 6px 12px;background:var(--ac)}
.nav-item{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:10px;color:var(--muted);font-weight:600;font-size:13px;border:1px solid transparent;text-align:left;width:100%}
.nav-item .ic{font-size:15px;width:18px;text-align:center}
.nav-item:hover{background:#efe7d9;color:var(--ink)}
.nav-item.on{background:var(--ac);color:#fff;border-color:transparent}
.nav-sep{height:1px;background:var(--border);margin:8px 6px}
.nav-foot{margin-top:auto}

.content{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}
.topbar{height:56px;flex:none;display:flex;align-items:center;gap:12px;padding:0 22px;border-bottom:1px solid var(--divider)}
.topbar h1{font-family:var(--serif);font-size:20px;font-weight:700}
.topbar .spacer{flex:1}
.scroll{flex:1;overflow-y:auto;padding:22px}
.maxw{max-width:920px;margin:0 auto}

/* ---------- panes (list + detail) ---------- */
.split{display:flex;flex:1;min-height:0}
.pane{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}
.pane.scol{border-right:1px solid var(--border)}
.pane.wash{background:#fbf8f3}
.ph{padding:13px 16px;border-bottom:1px solid var(--divider);display:flex;align-items:center;gap:10px;flex:none}
.ph h3{font-family:var(--serif);font-size:15px}
.pb{padding:14px 16px;overflow-y:auto;flex:1}

/* ---------- search ---------- */
.search{flex:1;background:#fff;border:1px solid var(--border);border-radius:9px;padding:8px 12px;font-size:13px}
.search::placeholder{color:var(--muted)}

/* ---------- list rows ---------- */
.li{display:flex;gap:11px;align-items:flex-start;padding:11px 8px;border-bottom:1px solid var(--divider);width:100%;text-align:left;border-radius:9px}
.li.sel{background:#eef2e7;border-bottom-color:transparent}
.li:hover{background:#f3eee4}
.li.sel:hover{background:#eef2e7}
.av{width:32px;height:32px;border-radius:50%;flex:none;display:grid;place-items:center;color:#fff;font-weight:700;font-size:12px;background:var(--ac)}
.av.sq{border-radius:9px}
.li .tx{min-width:0;flex:1}
.li .tx .n{font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.li .tx .s{color:var(--muted);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.li .meta{color:var(--muted);font-size:11px;flex:none}
.li.unread .n{font-weight:800}

/* ---------- chips / pills / badges ---------- */
.chip{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:4px 10px;border-radius:999px;background:#eef2e7;color:var(--sage-dark);border:1px solid #dde6cf}
.chip.b{background:#e8eef2;color:#46708a;border-color:#d4e0e8}
.chip.g{background:#f6ecd2;color:#9a7b2c;border-color:#ecdcb2}
.chip.p{background:#f1e7f3;color:#7e4f8a;border-color:#e3d1e7}
.chip.w{background:#f7e2e0;color:#9a4a36;border-color:#e9cfc6}
.pill{display:inline-flex;align-items:center;font-size:12px;font-weight:600;padding:6px 13px;border-radius:999px;border:1px solid var(--border);color:var(--muted);background:#fff}
.pill:hover{border-color:var(--ac);color:var(--ink)}
.pill.on{background:var(--ac);color:#fff;border-color:transparent}
.badge{font-size:10px;font-weight:800;padding:2px 8px;border-radius:999px;background:var(--ac);color:#fff}
.dotg{width:8px;height:8px;border-radius:50%;background:#1f9d6b;display:inline-block}

/* ---------- cards / tiles / grids ---------- */
.cardx{background:#fff;border:1px solid var(--border);border-radius:13px;padding:14px}
.tile{background:#fff;border:1px solid var(--border);border-radius:13px;padding:14px;display:flex;flex-direction:column;gap:6px;text-align:left;width:100%}
.tile:hover{border-color:var(--ac);box-shadow:var(--shadow)}
.tile .em{font-size:22px}
.tile .lbl{font-weight:700}
.tile .sub{color:var(--muted);font-size:12px}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:13px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:13px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.stat{display:flex;flex-direction:column;gap:2px}
.stat b{font-family:var(--serif);font-size:26px}
.stat span{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.5px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:700;padding:9px 16px;border-radius:10px;background:var(--ac);color:#fff}
.btn:hover{filter:brightness(.95)}
.btn.ghost{background:#fff;color:var(--ink);border:1px solid var(--border)}
.btn.sm{padding:6px 12px;font-size:12px}
.btn.grad{background:linear-gradient(90deg,var(--water),var(--purple))}
.btn:disabled{opacity:.5;cursor:default}

/* ---------- inputs ---------- */
.field{width:100%;background:#fff;border:1px solid var(--border);border-radius:10px;padding:10px 12px;font-size:13px;margin-top:4px}
.field:focus{outline:none;border-color:var(--ac)}
textarea.field{resize:vertical;min-height:90px;line-height:1.6}
.label{font-size:11px;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted);font-weight:700}

/* ---------- misc helpers ---------- */
.barline{height:7px;border-radius:999px;background:#eadfca;overflow:hidden}
.barline i{display:block;height:100%;background:var(--ac)}
.colorbar{width:4px;border-radius:4px;align-self:stretch}
.row{display:flex;align-items:center;gap:9px}
.between{justify-content:space-between}
.wrap{display:flex;flex-wrap:wrap;gap:7px}
.gloss{color:var(--muted);font-size:12px}
.h-cap{font-size:11px;letter-spacing:1.4px;text-transform:uppercase;color:var(--muted);font-weight:700}
.sw{width:18px;height:18px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px var(--border)}
.emo{font-size:20px;line-height:1}
.bubble{max-width:74%;padding:10px 13px;border-radius:15px;font-size:13px;line-height:1.5}
.bubble.u{margin-left:auto;background:#f1e7f3;border:1px solid #e3d1e7}
.bubble.a{background:#f7efe4;border:1px solid #ecdcc2}
.mt6{margin-top:6px}.mt8{margin-top:8px}.mt10{margin-top:10px}.mt12{margin-top:12px}.mt16{margin-top:16px}
.empty{display:grid;place-items:center;height:100%;color:var(--muted);text-align:center;padding:30px}
.hide{display:none!important}

/* ---------- toast ---------- */
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;padding:10px 18px;border-radius:10px;font-size:13px;font-weight:600;opacity:0;transition:.25s;z-index:200;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---------- modal ---------- */
.scrim{position:fixed;inset:0;background:rgba(61,47,36,.4);display:grid;place-items:center;z-index:150;padding:24px}
.modal{background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);width:min(520px,100%);max-height:88vh;overflow:auto}
.modal .mh{padding:16px 18px;border-bottom:1px solid var(--divider);display:flex;align-items:center}
.modal .mh h3{font-family:var(--serif);font-size:18px}
.modal .mb{padding:18px}
