/* ET Book — the Tufte typeface */
@font-face{font-family:'et-book';font-weight:400;font-style:normal;font-display:swap;
  src:url('https://cdn.jsdelivr.net/gh/edwardtufte/tufte-css/et-book/et-book-roman-old-style-figures/et-book-roman-old-style-figures.woff') format('woff')}
@font-face{font-family:'et-book';font-weight:600;font-style:normal;font-display:swap;
  src:url('https://cdn.jsdelivr.net/gh/edwardtufte/tufte-css/et-book/et-book-bold-line-figures/et-book-bold-line-figures.woff') format('woff')}

:root{
  --paper:#fffff8;
  --paper-2:#f6f1e3;
  --ink:#111111;
  --ink-soft:#5b564c;
  --ink-faint:#8a857a;
  --rust:#a8492b;
  --rust-deep:#8a3a20;
  --teal:#5f876b;
  --rule:#dcd6c4;
  --track:#e7e1cf;
  --serif:'et-book',Palatino,'Palatino Linotype','Book Antiqua','Songti SC','Songti TC',Georgia,serif;
}
@media (prefers-color-scheme: dark){
  :root{
    --paper:#161412;
    --paper-2:#211e19;
    --ink:#f4efe3;
    --ink-soft:#a8a191;
    --ink-faint:#6f685b;
    --rust:#d06a45;
    --rust-deep:#b8542f;
    --teal:#84a78b;
    --rule:#332f28;
    --track:#332f28;
  }
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{color-scheme:light dark}
html,body{margin:0;padding:0;min-height:100%;background-color:var(--paper)}
body::before{content:"";position:fixed;inset:0;background:var(--paper);z-index:-1;pointer-events:none}
body{
  color:var(--ink);
  font-family:var(--serif);
  font-size:15px; line-height:1.4; font-style:normal;
  -webkit-font-smoothing:antialiased;
  padding-bottom:calc(26px + env(safe-area-inset-bottom));
}
button,input,textarea,output{font-family:inherit;font-size:15px;font-style:normal;color:var(--ink)}
::placeholder{color:var(--ink-faint);opacity:1}

/* ---------- top bar ---------- */
.topbar{position:sticky;top:0;z-index:5;background:var(--paper);
  padding:calc(env(safe-area-inset-top) + 11px) 20px 9px;text-align:center;border-bottom:1px solid var(--rule)}
.brand{font-weight:600;letter-spacing:.02em;font-size:16px;cursor:pointer}
.sync-dot{position:absolute;left:16px;top:50%;width:9px;height:9px;border-radius:50%;
  border:none;padding:0;background:var(--ink-faint);transform:translateY(-50%)}
.sync-dot.ok{background:var(--teal)} .sync-dot.pending{background:var(--rust)}
.sync-dot.off{background:var(--ink-faint)} .sync-dot.err{background:var(--rust-deep)}

/* top-right menu */
.menu-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);
  width:36px;height:36px;background:none;border:none;cursor:pointer;padding:0}
.menu-btn span{display:block;position:relative;width:18px;height:1.6px;margin:0 auto;
  background:var(--ink-soft);border-radius:1px}
.menu-btn span::before,.menu-btn span::after{content:"";position:absolute;left:0;width:18px;height:1.6px;
  background:var(--ink-soft);border-radius:1px}
.menu-btn span::before{top:-5px} .menu-btn span::after{top:5px}
.menu{position:absolute;right:12px;top:calc(100% - 1px);min-width:118px;z-index:20;
  background:var(--paper);border:1px solid var(--rule);border-radius:3px;overflow:hidden;
  box-shadow:0 6px 18px rgba(0,0,0,.14)}
.menu[hidden]{display:none}
.menu-item{display:block;width:100%;text-align:left;background:none;border:none;
  border-bottom:1px solid var(--rule);color:var(--ink);padding:12px 16px;cursor:pointer}
.menu-item:last-child{border-bottom:none}
.menu-item:active{background:var(--paper-2)}

main{max-width:580px;margin:0 auto;padding:16px 22px 0}
.view{display:none}
.view.active{display:block}

/* ---------- segmented (snapshot / event) ---------- */
.segmented{display:flex;gap:.5em;margin-bottom:14px}
.seg{flex:0 0 auto;background:none;border:none;border-radius:3px;
  cursor:pointer;color:var(--ink-faint);padding:6px 12px}
.seg.active{color:var(--rust);background:color-mix(in srgb,var(--rust) 14%,transparent);font-weight:600}

.form{display:none}
.form.active{display:block}

/* ---------- slider rows: label, note, slim rail + red block ---------- */
.slider-row{margin-bottom:8px}
.slider-row .head{display:flex;justify-content:space-between;align-items:baseline}
.slider-row output{color:var(--ink);min-width:1.4em;text-align:right;font-variant-numeric:oldstyle-nums}
.slider-row .tip{display:block;color:var(--ink-soft);font-size:13px;margin:0 0 -3px}
input[type=range]{
  -webkit-appearance:none;appearance:none;width:100%;height:38px;background:transparent;
  margin:0;cursor:pointer;touch-action:none;
}
input[type=range]::-webkit-slider-runnable-track{height:4px;border-radius:2px;background:var(--track)}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:26px;border-radius:2px;
  background:var(--rust);border:none;margin-top:-11px;
  transition:height .12s ease,margin-top .12s ease,background .12s ease}
input[type=range]:active::-webkit-slider-thumb{height:30px;margin-top:-13px;background:var(--rust-deep)}
input[type=range]::-moz-range-track{height:4px;border-radius:2px;background:var(--track)}
input[type=range]::-moz-range-thumb{width:24px;height:26px;border-radius:2px;background:var(--rust);border:none}

/* ---------- text fields (16px to avoid iOS focus-zoom) ---------- */
textarea,input[type=text],input[type=password]{
  width:100%;font-size:16px;background:var(--paper-2);border:1px solid var(--rule);border-radius:2px;
  padding:8px 11px;line-height:1.4;resize:vertical}
textarea:focus,input:focus{outline:none;border-color:var(--rust)}
#event-form textarea,#daily-form textarea{margin-top:6px}

/* ---------- toggles (anchors / needs / emotions) ---------- */
.toggles{margin:14px 0 2px}
.toggles .grp{display:block;color:var(--ink-soft);margin-bottom:4px;font-size:13px}
.chips{display:flex;flex-wrap:wrap}
.chip{display:inline-block;cursor:pointer;color:var(--ink-faint);
  border-radius:3px;padding:6px 9px;margin:0 .3em 4px 0}
.chip input{display:none}
.chip:has(input:checked){color:var(--rust);background:color-mix(in srgb,var(--rust) 15%,transparent);font-weight:600}
.chip.pos:has(input:checked){color:var(--teal);background:color-mix(in srgb,var(--teal) 16%,transparent)}

/* ---------- buttons ---------- */
button.primary{display:block;width:100%;margin-top:16px;background:var(--rust);color:var(--paper);
  border:none;border-radius:2px;padding:11px;cursor:pointer}
button.primary:active{background:var(--rust-deep)}
button.ghost{background:none;border:1px solid var(--rust);color:var(--rust);border-radius:2px;
  padding:9px 15px;cursor:pointer}
.row{display:flex;gap:12px;flex-wrap:wrap;margin-top:4px}

/* ---------- settings ---------- */
.section{border-top:1px solid var(--rule);padding-top:16px;margin-top:10px}
.section:first-child{border-top:none;padding-top:4px}
.section h2{font-weight:600;font-size:16px;margin:0 0 8px}
.hint{color:var(--ink-soft);margin:0 0 14px}
.hint code{font-size:.92em;font-family:inherit}
.field{display:block;color:var(--ink-soft);margin-bottom:12px}
.field input{margin-top:6px;color:var(--ink)}
.status{margin-top:12px;min-height:20px;color:var(--ink-soft)}
.status.ok{color:var(--teal)} .status.err{color:var(--rust-deep)}

/* ---------- timeline ---------- */
.timeline{margin-top:2px}
.empty{color:var(--ink-soft);text-align:center;padding:48px 16px}
.entry{padding:14px 0;border-bottom:1px solid var(--rule)}
.entry .meta{display:flex;justify-content:space-between;align-items:baseline;color:var(--ink-faint);margin-bottom:7px;font-size:13px}
.entry .badge{color:var(--ink-soft)}
.entry .unsynced{color:var(--rust)}
.entry .scores{font-variant-numeric:oldstyle-nums}
.entry .scores .num{color:var(--ink)}
.entry .scores .dot-sep{color:var(--ink-faint);margin:0 .5em}
.entry .anchors-line{color:var(--ink-soft);margin-top:6px}
.entry .note{margin-top:8px;white-space:pre-wrap;word-break:break-word}
.entry .event-body{word-break:break-word}
.entry .feel{font-variant-numeric:oldstyle-nums;margin-right:.4em}
.entry .feel.pos{color:var(--teal)} .entry .feel.neg{color:var(--rust)}
.entry .emos-line{margin-top:6px}
.entry .emo{margin-right:1em}
.entry .emo.pos{color:var(--teal)} .entry .emo.neg{color:var(--rust)}
.entry .reason{color:var(--ink-soft);margin-top:6px}
.entry .needs-line{margin-top:6px;color:var(--ink-soft)}
.entry .need{margin-right:1em}
.entry .takeaway{margin-top:8px;color:var(--ink)}
.entry .takeaway .tk{color:var(--ink-soft);margin-right:.5em}
