/* Little — full-viewport PWA styles. Tokens per design spec §2.1. */
@font-face{font-family:'Bricolage';src:local('Bricolage Grotesque');font-weight:600 700;font-display:swap}
:root{
  --bg:#F6F5F1; --surface:#FFFFFF; --ink:#2B2A33; --ink-soft:#6B6975; --ink-faint:#9C99A6;
  --line:#ECEAE4; --track:#EEECF5; --muted:#F1EFEA;
  --indigo:#5B5AD6; --indigo-soft:#EBEBFB; --indigo-ink:#4342B0;
  --apricot:#E1863B; --apricot-soft:#FBEEE0; --apricot-ink:#B7691F;
  --sage:#5F9C7E; --sage-soft:#E7F1EB; --sage-ink:#3F7B5E;
  --teal:#3E97A0; --teal-soft:#E2F1F2; --teal-ink:#2C757D;
  --rose:#C77A93; --rose-soft:#F6E8ED; --rose-ink:#A3546D;
  --radius:20px; --shadow:0 1px 2px rgba(20,19,25,.04),0 8px 24px rgba(20,19,25,.06);
  --font:'Hanken Grotesk',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --display:'Bricolage',var(--font); --mono:'IBM Plex Mono',ui-monospace,'SFMono-Regular',Menlo,monospace;
}
:root[data-theme=dark]{
  --bg:#141319; --surface:#1E1D26; --ink:#EDEBF2; --ink-soft:#A6A3B2; --ink-faint:#6E6B7A;
  --line:#2A2933; --track:#2A2836; --muted:#232230;
  --indigo:#8886F0; --indigo-soft:#26243A; --indigo-ink:#B4B2F7;
  --apricot:#E8A05C; --apricot-soft:#372A1E; --apricot-ink:#F0B98A;
  --sage:#77B393; --sage-soft:#1F3128; --sage-ink:#9AD0B2;
  --teal:#5FB6BE; --teal-soft:#1D3033; --teal-ink:#84CBD2;
  --rose:#D492A6; --rose-soft:#33222A; --rose-ink:#E3A6B7;
  --shadow:0 1px 2px rgba(0,0,0,.3),0 10px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{background:var(--bg);color:var(--ink);font-family:var(--font);-webkit-font-smoothing:antialiased;overflow:hidden;touch-action:manipulation}
#app{display:flex;flex-direction:column;height:100dvh;max-width:520px;margin:0 auto;position:relative}
.view{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 18px calc(96px + env(safe-area-inset-bottom));scroll-behavior:smooth}
.apphead{display:flex;align-items:center;justify-content:space-between;padding:calc(14px + env(safe-area-inset-top)) 0 12px;position:sticky;top:0;background:linear-gradient(var(--bg) 75%,transparent);z-index:5}
.apphead .h{font-family:var(--display);font-weight:700;font-size:26px;letter-spacing:-.02em}
.apphead .sub{color:var(--ink-soft);font-size:13px;margin-top:1px}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--indigo);color:#fff;display:grid;place-items:center;font-weight:700;font-family:var(--display);border:none;cursor:pointer}
.page{display:none}.page.on{display:block;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.sectlabel{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);margin:22px 2px 10px}
.center{text-align:center}.left{text-align:left}
/* ---- nav ---- */
.nav{position:absolute;left:0;right:0;bottom:0;display:flex;justify-content:space-around;align-items:center;padding:8px 6px calc(8px + env(safe-area-inset-bottom));background:color-mix(in srgb,var(--surface) 88%,transparent);backdrop-filter:blur(18px);border-top:1px solid var(--line);z-index:20}
.nav a{display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--ink-faint);text-decoration:none;font-size:11px;font-weight:600;padding:4px 14px;cursor:pointer}
.nav a svg{width:24px;height:24px}
.nav a.on{color:var(--indigo)}
/* ---- home ---- */
.hero2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.hcard{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 12px 14px;text-align:center}
.hcard .cap{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint)}
.ring{position:relative;width:130px;height:130px;margin:8px auto 4px}
.ring .center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ring .big{font-family:var(--mono);font-weight:600;font-size:24px;letter-spacing:-.02em}
.ring .lbl{font-size:10.5px;color:var(--ink-soft);max-width:78px;line-height:1.2;margin-top:2px}
.breathe{animation:breathe 4s ease-in-out infinite;transform-origin:center;transition:stroke-dashoffset .6s}
@keyframes breathe{0%,100%{opacity:1}50%{opacity:.78}}
.hcard .pred{font-family:var(--mono);font-size:12.5px;color:var(--ink-soft);margin-top:6px;min-height:16px}
.pred .learn{color:var(--ink-faint)}
.since3{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px}
.scard{background:var(--surface);border-radius:16px;box-shadow:var(--shadow);padding:12px 8px;text-align:center}
.scard .si{width:22px;height:22px;margin:0 auto 4px}
.scard .v{font-family:var(--mono);font-weight:600;font-size:15px}
.scard .k{font-size:10.5px;color:var(--ink-soft);margin-top:2px}
.scard.sleep .si{color:var(--indigo)}.scard.diaper .si{color:var(--sage)}.scard.feed .si{color:var(--apricot)}
.today{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.trow{display:flex;align-items:center;gap:12px;padding:13px 15px;border-bottom:1px solid var(--line)}
.trow:last-child{border-bottom:none}
.trow .ti{width:34px;height:34px;border-radius:10px;display:grid;place-items:center}.trow .ti svg{width:19px;height:19px}
.trow.feed .ti{background:var(--apricot-soft);color:var(--apricot-ink)}
.trow.sleep .ti{background:var(--indigo-soft);color:var(--indigo-ink)}
.trow.diaper .ti{background:var(--sage-soft);color:var(--sage-ink)}
.trow .tt{flex:1}.trow .a{font-weight:600;font-size:14.5px}.trow .b{font-size:12px;color:var(--ink-soft)}
.trow .num{font-family:var(--mono);font-weight:600;font-size:18px}
/* ---- log ---- */
.strip{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border-radius:16px;overflow:hidden;box-shadow:var(--shadow);margin-top:4px}
.stcell{background:var(--surface);padding:12px 10px;text-align:center}
.stcell .k{font-size:10.5px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.05em;font-weight:700}
.stcell .v{font-family:var(--mono);font-weight:600;font-size:15px;margin-top:3px}
.stcell.feed .v{color:var(--apricot-ink)}.stcell.sleep .v{color:var(--indigo-ink)}.stcell.diaper .v{color:var(--sage-ink)}
.tiles{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px}
.tile{grid-column:span 1;display:flex;align-items:center;gap:12px;background:var(--surface);border:none;border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;text-align:left;cursor:pointer;color:var(--ink);position:relative}
.tile.wide{grid-column:span 2}
.tile .ic{width:44px;height:44px;border-radius:13px;display:grid;place-items:center;flex-shrink:0}.tile .ic svg{width:24px;height:24px}
.tile.feed .ic{background:var(--apricot-soft);color:var(--apricot-ink)}
.tile.diaper .ic{background:var(--sage-soft);color:var(--sage-ink)}
.tile.sleep .ic{background:var(--indigo-soft);color:var(--indigo-ink)}
.tile .name{font-family:var(--display);font-weight:600;font-size:17px}
.tile .hint{font-size:12px;color:var(--ink-soft);margin-top:2px}
.tile .go{position:absolute;right:14px;color:var(--ink-faint)}
.mini{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.mbtn{display:flex;flex-direction:column;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--line);border-radius:15px;padding:13px 6px;cursor:pointer;color:var(--ink);font-size:12px;font-weight:600}
.mbtn svg{width:22px;height:22px;color:var(--rose)}
#recentBox .ev:first-child{border-radius:14px 14px 0 0}#recentBox .ev:last-child{border-radius:0 0 14px 14px}
.empty,.tl-empty{background:var(--surface);border-radius:14px;box-shadow:var(--shadow);padding:22px;text-align:center;color:var(--ink-faint);font-size:13.5px}
/* ---- event rows ---- */
.ev{display:flex;gap:12px;align-items:flex-start;background:var(--surface);box-shadow:var(--shadow);padding:12px 14px;margin-bottom:1px}
.eic{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;flex-shrink:0}.eic svg{width:19px;height:19px}
.ev.feed .eic{background:var(--apricot-soft);color:var(--apricot-ink)}
.ev.sleep .eic{background:var(--indigo-soft);color:var(--indigo-ink)}
.ev.diaper .eic{background:var(--sage-soft);color:var(--sage-ink)}
.ev.pump .eic{background:var(--teal-soft);color:var(--teal-ink)}
.ev.other .eic{background:var(--rose-soft);color:var(--rose-ink)}
.ev .body{flex:1;min-width:0}
.ev .l1{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.ev .ttl{font-weight:600;font-size:14.5px}
.ev .clock{font-family:var(--mono);font-size:12px;color:var(--ink-soft)}
.ev .l2{font-size:12.5px;color:var(--ink-soft);margin-top:2px;display:flex;justify-content:space-between;gap:8px}
.miniwho{width:17px;height:17px;border-radius:50%;background:var(--muted);color:var(--ink-soft);font-size:10px;font-weight:700;display:inline-grid;place-items:center;flex-shrink:0}
.evphoto{display:block;margin-top:8px;width:100%;max-height:220px;object-fit:cover;border-radius:11px;background:var(--muted)}
.evphoto.photomissing{display:none}
/* ---- milestone photo picker ---- */
.photobtn{border:1px dashed var(--line);background:var(--muted);border-radius:12px;padding:12px;width:100%;font-family:var(--font);font-weight:600;color:var(--ink-soft);cursor:pointer}
.photoprev{position:relative;border-radius:12px;overflow:hidden}
.photoprev img{display:block;width:100%;max-height:240px;object-fit:cover}
.photox{position:absolute;top:8px;right:8px;width:30px;height:30px;border:none;border-radius:50%;background:rgba(0,0,0,.55);color:#fff;font-size:15px;line-height:1;cursor:pointer}
/* ---- timeline ---- */
.tlbar{position:sticky;top:64px;background:linear-gradient(var(--bg) 80%,transparent);padding-bottom:8px;z-index:4}
.tlsearch{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:13px;padding:10px 13px}
.tlsearch svg{width:18px;height:18px;color:var(--ink-faint);flex-shrink:0}
.tlsearch input{border:none;background:none;outline:none;flex:1;font-family:var(--font);font-size:14.5px;color:var(--ink)}
.tlrow{display:flex;gap:8px;margin-top:8px}
.tldate{flex:1;border:1px solid var(--line);background:var(--surface);border-radius:11px;padding:9px 12px;font-family:var(--font);color:var(--ink)}
.tlclear{border:1px solid var(--line);background:var(--surface);border-radius:11px;padding:0 16px;font-weight:600;color:var(--ink-soft);cursor:pointer}
.daybar{display:flex;justify-content:space-between;align-items:baseline;margin:18px 2px 8px}
.daybar .d{font-family:var(--display);font-weight:700;font-size:16px}
.daybar .s{font-size:11.5px;color:var(--ink-faint)}
.tl{border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}
.tl .ev{margin-bottom:1px}
/* ---- trends ---- */
.seg{display:flex;background:var(--muted);border-radius:13px;padding:4px;gap:3px}
.seg button{flex:1;border:none;background:none;padding:9px 6px;border-radius:10px;font-family:var(--font);font-weight:600;font-size:13px;color:var(--ink-soft);cursor:pointer}
.seg button.on{background:var(--surface);color:var(--ink);box-shadow:0 1px 3px rgba(0,0,0,.08)}
.seg.small button{padding:7px 10px;font-size:12.5px}
.statgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:14px 0}
.stat{background:var(--surface);border-radius:15px;box-shadow:var(--shadow);padding:14px}
.stat .v{font-family:var(--mono);font-weight:600;font-size:20px}.stat .v small{font-size:12px;color:var(--ink-soft)}
.stat .k{font-size:11.5px;color:var(--ink-soft);margin-top:3px}
.chartcard{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;margin-bottom:12px}
.chartcard .ct{font-family:var(--display);font-weight:600;font-size:16px}
.chartcard .cs{font-size:11.5px;color:var(--ink-faint);margin:2px 0 12px}
.bars{display:flex;align-items:flex-end;gap:6px;height:110px;padding-bottom:18px}
.bcol{flex:1;min-width:0;position:relative;display:flex;flex-direction:column;justify-content:flex-end;height:100%;cursor:pointer}
.bcol .bar{width:100%;border-radius:6px 6px 3px 3px;min-height:3px;transition:height .4s,opacity .12s}
.bcol.feed .bar{background:var(--apricot)}.bcol.sleep .bar{background:var(--indigo)}.bcol.diaper .bar{background:var(--sage)}
/* labels are absolutely positioned so their text width can never widen a bar column */
.bcol .bl{position:absolute;top:calc(100% + 4px);left:50%;transform:translateX(-50%);white-space:nowrap;font-size:10px;color:var(--ink-faint);font-weight:600}
.bcol.sel .bar{opacity:1;outline:2px solid var(--ink);outline-offset:1px}
.bcol:not(.sel) .bar{opacity:.9}
.bars.dense{gap:2px}
.bars.dense .bl{font-size:9px}
.obs{background:var(--indigo-soft);border:1px solid color-mix(in srgb,var(--indigo) 30%,transparent);border-radius:15px;padding:14px 16px;font-size:13.5px;line-height:1.5;color:var(--indigo-ink);margin-top:4px}
/* ---- backdrop + sheets ---- */
.backdrop{position:fixed;inset:0;background:rgba(20,19,25,.42);opacity:0;pointer-events:none;transition:opacity .3s;z-index:40}
.backdrop.show{opacity:1;pointer-events:auto}
.sheet{position:fixed;left:0;right:0;bottom:0;max-width:520px;margin:0 auto;background:var(--surface);border-radius:24px 24px 0 0;z-index:50;transform:translateY(100%);transition:transform .34s cubic-bezier(.32,.72,0,1),visibility 0s .34s;visibility:hidden;max-height:92dvh;display:flex;flex-direction:column}
.sheet.open{transform:translateY(0);visibility:visible;transition:transform .34s cubic-bezier(.32,.72,0,1),visibility 0s 0s;box-shadow:0 -8px 40px rgba(20,19,25,.18)}
.infobtn{margin-left:6px;width:17px;height:17px;border-radius:50%;border:none;background:var(--muted);color:var(--ink-faint);font-size:11px;font-weight:700;line-height:17px;text-align:center;padding:0;cursor:pointer;vertical-align:middle}
.infobtn:active{background:var(--indigo-soft);color:var(--indigo-ink)}
.pi-block{margin-bottom:14px}
.pi-block .h{font-family:var(--display);font-weight:600;font-size:15px;margin-bottom:3px}
.pi-block .b{font-size:13.5px;color:var(--ink-soft);line-height:1.5}
.grab{width:40px;height:4px;border-radius:2px;background:var(--line);margin:10px auto 2px}
.sheet-head{display:flex;align-items:center;justify-content:space-between;padding:8px 20px 12px}
.sheet-head .title{font-family:var(--display);font-weight:700;font-size:20px}
.sheet-head .x{border:none;background:var(--muted);width:32px;height:32px;border-radius:50%;font-size:14px;color:var(--ink-soft);cursor:pointer}
.sheet-body{padding:4px 20px 8px;overflow-y:auto}
.sheet-foot{padding:12px 20px calc(18px + env(safe-area-inset-bottom));border-top:1px solid var(--line)}
.fld{margin-bottom:16px}
.lab,.lab2{font-size:13px;font-weight:600;color:var(--ink-soft);margin-bottom:8px}
.subnote{font-size:12px;color:var(--ink-faint);margin-top:8px;line-height:1.45}
.opts{display:grid;gap:8px}.grid2{grid-template-columns:1fr 1fr}.grid3{grid-template-columns:repeat(3,1fr)}.grid4{grid-template-columns:repeat(4,1fr)}
.opt{border:1.5px solid var(--line);background:var(--surface);border-radius:12px;padding:12px 8px;font-family:var(--font);font-weight:600;font-size:14px;color:var(--ink);cursor:pointer;text-align:center}
.opt.on{border-color:var(--indigo);background:var(--indigo-soft);color:var(--indigo-ink)}
.opt.full{width:100%}.opt.left{text-align:left}
.stepper{display:flex;align-items:center;justify-content:space-between;background:var(--muted);border-radius:14px;padding:8px}
.step{width:46px;height:46px;border:none;border-radius:11px;background:var(--surface);box-shadow:var(--shadow);font-size:22px;color:var(--ink);cursor:pointer}
.amt{font-family:var(--mono);font-weight:600;font-size:26px}.amt small{font-size:13px;color:var(--ink-soft);margin-left:3px}
.timerbox{display:flex;align-items:center;justify-content:space-between;background:var(--muted);border-radius:14px;padding:12px 16px}
.tval{font-family:var(--mono);font-weight:600;font-size:30px}
.tbtns{display:flex;gap:8px}
.tbtn{border:none;border-radius:11px;padding:11px 20px;font-family:var(--font);font-weight:700;font-size:14px;cursor:pointer}
.tbtn.go{background:var(--indigo);color:#fff}.tbtn.stop{background:var(--apricot);color:#fff}.tbtn.sw{background:var(--surface);color:var(--ink);box-shadow:var(--shadow)}
.txt,.numin{width:100%;border:1.5px solid var(--line);background:var(--surface);border-radius:12px;padding:12px 14px;font-family:var(--font);font-size:15px;color:var(--ink);outline:none;resize:none}
.numin{font-family:var(--mono);font-size:22px;text-align:center}
.txt:focus,.numin:focus{border-color:var(--indigo)}
.switchrow{display:flex;align-items:center;justify-content:space-between;gap:12px}
.switchrow .t{font-weight:600;font-size:14.5px}.switchrow .d{font-size:12px;color:var(--ink-soft)}
.switch{width:50px;height:30px;border-radius:16px;border:none;background:var(--line);position:relative;cursor:pointer;flex-shrink:0;transition:background .2s}
.switch .knob{position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.2);transition:transform .2s}
.switch.on{background:var(--sage)}.switch.on .knob{transform:translateX(20px)}
.when{display:flex;flex-wrap:wrap;align-items:center;gap:7px}
.wchip{border:1.5px solid var(--line);background:var(--surface);border-radius:10px;padding:8px 12px;font-family:var(--font);font-weight:600;font-size:13px;color:var(--ink-soft);cursor:pointer}
.wchip.on{border-color:var(--indigo);background:var(--indigo-soft);color:var(--indigo-ink)}
.whenval{margin-left:auto;font-family:var(--mono);font-size:13px;color:var(--ink-soft)}
.timeinput{margin-top:10px;width:100%;border:1.5px solid var(--line);background:var(--surface);border-radius:11px;padding:10px 12px;font-family:var(--mono);color:var(--ink)}
.total{display:flex;justify-content:space-between;padding:12px 4px 2px;font-size:14px;color:var(--ink-soft)}.total b{font-family:var(--mono);color:var(--ink)}
.save{width:100%;border:none;border-radius:14px;background:var(--indigo);color:#fff;padding:15px;font-family:var(--font);font-weight:700;font-size:16px;cursor:pointer}
.hidden{display:none!important}
/* session */
.session{position:relative;background:var(--indigo);color:#fff;border-radius:var(--radius);padding:18px;margin-top:14px;overflow:hidden;text-align:center}
.session .glow{position:absolute;inset:0;background:radial-gradient(120px 60px at 50% 0,rgba(255,255,255,.25),transparent)}
.session .r1{font-size:13px;font-weight:600;opacity:.9;position:relative}
.session .rec{display:inline-block;width:8px;height:8px;border-radius:50%;background:#fff;margin-right:6px;animation:blink 1.4s infinite}
@keyframes blink{50%{opacity:.35}}
.session .time{font-family:var(--mono);font-weight:600;font-size:36px;margin:4px 0;position:relative}
.session .meta{font-size:12px;opacity:.85;position:relative}
.session .stop{margin-top:12px;background:#fff;color:var(--indigo);border:none;border-radius:12px;padding:11px 26px;font-weight:700;font-family:var(--font);cursor:pointer;position:relative}
/* toast */
.toast{position:fixed;left:50%;bottom:calc(96px + env(safe-area-inset-bottom));transform:translate(-50%,20px);background:var(--ink);color:var(--bg);padding:12px 20px;border-radius:13px;font-size:14px;font-weight:600;opacity:0;pointer-events:none;transition:all .3s;z-index:80;display:flex;align-items:center;gap:8px;max-width:90%}
.toast.show{opacity:1;transform:translate(-50%,0)}
.toast .tk{width:8px;height:8px;border-radius:50%;background:var(--sage)}
/* setup */
.setup{position:fixed;inset:0;background:var(--bg);z-index:100;overflow-y:auto;padding:calc(24px + env(safe-area-inset-top)) 28px calc(28px + env(safe-area-inset-bottom));max-width:520px;margin:0 auto}
.setup-top{display:flex;justify-content:flex-end;margin-bottom:20px}
.setup-top .seg{width:190px}
.setup .mark{width:60px;height:60px;border-radius:18px;background:var(--indigo);color:#fff;font-family:var(--display);font-weight:700;font-size:32px;display:grid;place-items:center;margin-bottom:20px}
.setup h2{font-family:var(--display);font-weight:700;font-size:27px;letter-spacing:-.02em}
.setup p{color:var(--ink-soft);font-size:15px;line-height:1.5;margin:8px 0 24px}
.lab2{margin-top:14px}
.setup-input{width:100%;max-width:100%;min-width:0;-webkit-appearance:none;appearance:none;border:1.5px solid var(--line);background:var(--surface);border-radius:13px;padding:14px 16px;font-family:var(--font);font-size:16px;color:var(--ink);outline:none;margin-bottom:4px}
.setup-input:focus{border-color:var(--indigo)}
.setup .save{margin-top:24px}
.setup-note{text-align:center;color:var(--ink-faint);font-size:12.5px;margin-top:16px;line-height:1.45}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
/* W3 — entry edit/delete sheet */
.ev{cursor:pointer}
.ee-sum{padding:10px 12px;background:var(--muted);border-radius:12px;margin-bottom:14px}
.ees-t{font-family:var(--display);font-weight:600;font-size:15px}
.ees-d{font-family:var(--mono);font-size:12.5px;color:var(--ink-soft);margin-top:3px}
.opt.full.left.danger{color:var(--rose);margin-top:14px}
.opt.full.left.danger.armed{background:var(--rose);color:#fff;border-color:var(--rose)}
.dur2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
/* Trends: range sub-toggle + readout + growth axis (bar/label/sel rules live with .bars above) */
.seg.sub{margin-top:8px}
.seg.sub button{font-size:12px;padding:7px 6px}
.readout{min-height:18px;margin-top:8px;text-align:center;font-family:var(--mono);font-size:12.5px;color:var(--ink)}
.readout:empty{display:none}
.growthsvg{height:auto;display:block;margin-top:6px}
.growthsvg .axl{font-family:var(--mono);font-size:8px;fill:var(--ink-soft)}
.hcard[data-endnap]{cursor:pointer}
/* Setup brand wordmark: "L" lands, then "ittle" cascades out of it */
.brandmark{font-family:var(--display);font-weight:700;font-size:46px;line-height:1;color:var(--indigo);letter-spacing:-.01em;margin-bottom:22px;display:inline-flex}
.brandmark span{display:inline-block}
.brandmark.play span:first-child{animation:brandlead .42s cubic-bezier(.2,.8,.3,1) both}
.brandmark.play span:not(:first-child){opacity:0;transform:translateY(12px);animation:brandin .5s cubic-bezier(.2,.7,.3,1) forwards}
.brandmark.play span:nth-child(2){animation-delay:.12s}
.brandmark.play span:nth-child(3){animation-delay:.20s}
.brandmark.play span:nth-child(4){animation-delay:.28s}
.brandmark.play span:nth-child(5){animation-delay:.36s}
.brandmark.play span:nth-child(6){animation-delay:.44s}
@keyframes brandin{to{opacity:1;transform:none}}
@keyframes brandlead{from{transform:scale(1.35)}to{transform:none}}
@media (prefers-reduced-motion:reduce){.brandmark.play span{opacity:1!important;transform:none!important;animation:none!important}}
/* Breast per-side minutes overlay (opens over the Feed sheet) */
#bfMinsBtn{display:flex;align-items:center;gap:8px}
.bfval{margin-left:auto;color:var(--indigo);font-family:var(--mono);font-size:13px}
.bfmins{position:fixed;inset:0;z-index:60;display:flex;align-items:center;justify-content:center;padding:24px;background:rgba(20,19,25,.5)}
.bfmins.hidden{display:none}
.bfmins-card{background:var(--surface);border-radius:20px;padding:22px 20px;width:100%;max-width:360px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:16px}
.bfmins-title{font-family:var(--display);font-weight:700;font-size:18px}
.bfmins-row{display:flex;align-items:center;gap:12px}
.bfmins-row .lab{font-weight:600;font-size:14.5px}
.bfmins-row .stepper{margin-left:auto}
