:root{
  --ink:#14110f; --cream:#f3f0e9; --card:#fffaf1; --line:#111; --muted:#6a665f;
  font-family:-apple-system,BlinkMacSystemFont,'Inter','Segoe UI',sans-serif;
}
*{box-sizing:border-box}
body{margin:0;background:var(--cream);color:var(--ink);}
.wrap{max-width:860px;margin:0 auto;padding:24px;}
a{color:inherit;}

/* header */
.top{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:20px;}
.brand{font-size:30px;font-weight:800;line-height:.85;letter-spacing:-.05em;text-decoration:none;}
.brand span{display:block;}
nav{display:flex;gap:8px;}
nav a{border:1.5px solid var(--line);border-radius:999px;padding:7px 14px;font-size:13px;text-decoration:none;background:var(--card);}
nav a:hover{background:var(--line);color:#fff;}

.mockbar{border:1.5px dashed var(--line);border-radius:14px;padding:8px 12px;font-size:12px;margin-bottom:12px;background:#fffaf1;}
.flash{border:1.5px solid var(--line);border-radius:14px;padding:10px 14px;background:#fff;margin-bottom:14px;font-size:14px;}

/* cards */
.card{background:var(--card);border:1.5px solid var(--line);border-radius:22px;padding:16px 18px;box-shadow:4px 4px 0 var(--line);}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;margin-top:14px;}
.note{display:block;text-decoration:none;transition:transform .05s;}
.note:hover{transform:translate(-1px,-1px);box-shadow:6px 6px 0 var(--line);}
.note h3{margin:8px 0 6px;font-size:18px;line-height:1.15;letter-spacing:-.02em;}
.sum{margin:0;color:#222;font-size:14px;line-height:1.45;}
.sum.big{font-size:16px;margin:8px 0 4px;}
.note-top{display:flex;align-items:center;gap:8px;}
.num{font-size:12px;color:var(--muted);letter-spacing:.06em;}
.note-foot{display:flex;justify-content:space-between;align-items:center;margin-top:10px;}
.when{font-size:12px;color:var(--muted);margin-left:auto;}
.badge{font-size:12px;border:1px solid var(--line);border-radius:999px;padding:2px 8px;background:#111;color:#fff;}

/* intent tags */
.tag{font-size:11px;border-radius:999px;padding:3px 9px;border:1px solid var(--line);text-transform:lowercase;}
.tag-task{background:#e6f1fb;} .tag-idea{background:#eee9fe;} .tag-reminder{background:#fdeede;}
.tag-reference{background:#e1f5ee;} .tag-note{background:#f1efe8;}
/* connection entity kinds (CONN-2/3) */
.tag-person{background:#e6f1fb;} .tag-place{background:#e1f5ee;} .tag-project{background:#eee9fe;}
.tag-topic{background:#fdeede;}
/* CONN-8 — typed relation label on connection cards */
.rel-label{font-size:10px;color:var(--muted);text-transform:lowercase;margin-left:4px;}
/* "what you know" — derived background list on an entity page */
.know{margin:8px 0 4px;padding-left:20px;font-size:14px;line-height:1.5;color:#222;}
.know li{margin-bottom:6px;} .know a{font-weight:600;text-decoration:none;}
/* review CTA (CONN-5) — the "Review (N)" badge line on the Connections tab */
.review-cta{font-size:14px;color:var(--muted);margin:0 0 14px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.review-cta a{text-decoration:none;}
/* per-entity briefing (CONN-6) — "if you're about to talk to {name}" */
.briefing{background:var(--card);border:1.5px solid var(--line);border-radius:18px;padding:12px 16px;margin:14px 0;}
.briefing h2{margin-top:4px;}
/* proposed-action kinds (automation engine) */
.tag-event{background:#e6f1fb;} .tag-recurring{background:#eee9fe;}
.tag-route{background:#fdeede;} .tag-multi{background:#f1efe8;}

/* capture */
.capture textarea{width:100%;border:1.5px solid var(--line);border-radius:14px;padding:10px;font:inherit;resize:vertical;background:#fff;}
.capture-row{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:10px;}
button,.search-full button{font:inherit;border:1.5px solid var(--line);border-radius:999px;padding:8px 16px;background:var(--line);color:#fff;cursor:pointer;}
button:hover{opacity:.85;}
/* ghost — a secondary/outline button (light fill, dark ink), the quiet pair to
   the solid primary; matches the .chip / .mini token family. */
.ghost{background:var(--card);color:var(--ink);}
.ghost:hover{background:var(--line);color:#fff;opacity:1;}
input[type=file]{font-size:13px;}
.rec{background:var(--card);color:var(--ink);}
.rec.on{background:#a32d2d;border-color:#a32d2d;color:#fff;}

/* chips */
.chips{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0;}
.chip{border:1.5px solid var(--line);border-radius:999px;padding:6px 12px;font-size:13px;text-decoration:none;background:var(--card);}
.chip.on{background:var(--line);color:#fff;}
.chip b{font-weight:700;}

/* rows (action items) */
.row{display:flex;align-items:center;gap:10px;border-top:1px solid #e7e1d4;padding:10px 0;}
.row:first-of-type{border-top:0;}
.row.is-done .atext{text-decoration:line-through;color:var(--muted);}
.atext{flex:1;font-size:14px;}
.atext em{color:var(--muted);font-style:normal;}
.mini{font-size:12px;padding:4px 10px;border-radius:999px;border:1.5px solid var(--line);background:var(--card);color:var(--ink);text-decoration:none;cursor:pointer;}
.mini:hover{background:var(--line);color:#fff;}
form{display:inline;margin:0;}

/* misc */
.page{font-size:34px;letter-spacing:-.04em;margin:6px 0 2px;}
.group{margin:22px 0 2px;text-transform:lowercase;letter-spacing:.04em;color:var(--muted);font-size:14px;}
.lede{color:var(--muted);font-size:14px;margin:0 0 8px;}
.empty{border:1.5px dashed var(--line);border-radius:18px;padding:30px;text-align:center;color:var(--muted);}
.back{display:inline-block;margin-bottom:12px;font-size:13px;text-decoration:none;color:var(--muted);}
.detail h1{font-size:28px;letter-spacing:-.03em;margin:6px 0;}
.transcript{font-size:15px;line-height:1.6;color:#333;white-space:pre-wrap;}
.detail-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px;}
.search-full{display:flex;gap:8px;margin-bottom:8px;}
.search-full input{flex:1;border:1.5px solid var(--line);border-radius:999px;padding:9px 14px;font:inherit;background:#fff;}
.search-full select{border:1.5px solid var(--line);border-radius:999px;padding:0 10px;font:inherit;background:var(--card);}
.foot{margin-top:34px;padding-top:14px;border-top:1px solid #e7e1d4;font-size:12px;color:var(--muted);}
.foot a{color:var(--muted);}
code{background:#efe9dd;padding:1px 5px;border-radius:5px;font-size:.92em;}

/* ── Phone / PWA (mobile-first overrides) ─────────────────────────────────── */
.tabbar{display:none;}

@media (max-width:600px){
  .wrap{padding:14px 14px calc(78px + env(safe-area-inset-bottom));}
  .top{align-items:center;margin-bottom:14px;}
  .top nav{display:none;}            /* replaced by the fixed bottom tab bar */
  .brand{font-size:26px;}
  .page{font-size:26px;}
  .grid{grid-template-columns:1fr;} /* one column on a phone */
  .card{border-radius:18px;box-shadow:3px 3px 0 var(--line);}
  button,.mini,.chip,.search-full button{min-height:44px;}          /* tap targets */
  .capture textarea{min-height:96px;font-size:16px;}                /* 16px = no iOS zoom */
  .search-full input{font-size:16px;}

  .tabbar{
    display:flex;position:fixed;left:0;right:0;bottom:0;z-index:50;
    background:var(--card);border-top:1.5px solid var(--line);
    padding:8px 8px calc(8px + env(safe-area-inset-bottom));
  }
  .tabbar a{
    flex:1;text-align:center;text-decoration:none;color:var(--ink);
    font-size:13px;font-weight:600;padding:10px 4px;border-radius:12px;
  }
  .tabbar a:active{background:var(--cream);}
}
