:root{
  --bg:#fbfdfd;--surface:#fff;--surface-2:#f2f8f7;--border:#e3edec;--border-strong:#d4e4e2;
  --teal-700:#0b7a73;--teal-600:#0d9488;--teal-500:#16b8a6;--teal-300:#6fd8c9;--teal-100:#d6f1ec;--teal-50:#eefaf7;
  --ink:#15302d;--text:#2a4a46;--muted:#73928d;--faint:#9db4af;
  --gold:#e8b04b;--rose:#ec7a86;--rose-bg:#fdeef0;--empty:#edf2f1;
  --shadow-sm:0 1px 2px rgba(16,48,46,.05);
  --shadow:0 2px 6px rgba(16,48,46,.06),0 10px 28px rgba(13,148,136,.07);
  --shadow-lg:0 18px 50px rgba(13,90,84,.18);
  --radius:18px;--radius-sm:13px;--maxw:430px;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;}
body{font-family:'IBM Plex Sans Thai','Noto Sans Thai','Sukhumvit Set',system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;font-feature-settings:"tnum";}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
input,select{font-family:inherit;font-size:16px;color:var(--ink);}
.app{max-width:var(--maxw);margin:0 auto;min-height:100%;background:radial-gradient(1200px 380px at 50% -120px,var(--teal-50),transparent 70%),var(--bg);position:relative;padding-bottom:96px;}

.header{position:sticky;top:0;z-index:40;padding:18px 20px 14px;background:linear-gradient(180deg,rgba(251,253,253,.96),rgba(251,253,253,.78));backdrop-filter:saturate(150%) blur(12px);-webkit-backdrop-filter:saturate(150%) blur(12px);border-bottom:1px solid var(--border);}
.brandrow{display:flex;align-items:center;justify-content:space-between;gap:12px;}
.brand{display:flex;align-items:center;gap:10px;min-width:0;}
.brand .mark{width:34px;height:34px;border-radius:11px;flex:none;background:linear-gradient(145deg,var(--teal-500),var(--teal-700));display:grid;place-items:center;color:#fff;font-size:18px;box-shadow:0 6px 16px rgba(13,148,136,.32);}
.brand h1{font-size:18px;font-weight:700;color:var(--ink);letter-spacing:-.01em;line-height:1.1;}
.brand p{font-size:11.5px;color:var(--muted);font-weight:400;}
.wallet{display:flex;align-items:center;gap:7px;flex:none;background:var(--surface);border:1px solid var(--border-strong);padding:7px 13px 7px 9px;border-radius:999px;box-shadow:var(--shadow-sm);}
.priv-entry{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;margin-top:18px;padding:14px;border-radius:var(--radius-sm);background:transparent;border:1px dashed var(--border-strong);color:var(--faint);font-size:13px;font-weight:500;transition:.15s;}
.priv-entry:active{background:var(--surface-2);}
.priv-entry svg{width:15px;height:15px;}
.datebar{display:flex;align-items:center;gap:9px;margin-bottom:14px;position:sticky;top:72px;z-index:30;background:var(--bg);padding:8px 0;border-bottom:1px solid var(--border);}
.dnav{width:44px;height:48px;border-radius:14px;flex:none;display:grid;place-items:center;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);color:var(--teal-700);transition:.15s;}
.dnav:active{transform:scale(.92);background:var(--surface-2);}
.dnav svg{width:20px;height:20px;}
.dlabel{flex:1;text-align:center;padding:7px 8px;border-radius:14px;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:.15s;}
.dlabel:active{transform:scale(.98);}
.dlabel .dl1{display:block;font-size:10.5px;color:var(--muted);font-weight:500;}
.dlabel .dl2{display:block;font-size:15px;color:var(--ink);font-weight:700;letter-spacing:-.01em;}
.dlabel.notoday{border-color:var(--teal-300);background:var(--teal-50);}
.dlabel.notoday .dl1{color:var(--teal-700);}
.wallet .bal{font-size:18px;font-weight:700;color:var(--teal-700);letter-spacing:-.02em;}
.wallet .lbl{font-size:11px;color:var(--muted);}
.coin{display:inline-block;vertical-align:-2px;flex:none;}

.view{display:none;padding:18px 16px 8px;animation:viewin .32s cubic-bezier(.2,.7,.3,1);}
.view.active{display:block;}
@keyframes viewin{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}
.section-title{font-size:13px;font-weight:600;color:var(--muted);margin:22px 4px 11px;}
.section-title:first-child{margin-top:4px;}

.hero{background:linear-gradient(155deg,var(--teal-600),var(--teal-700));color:#fff;border-radius:22px;padding:20px;box-shadow:0 16px 40px rgba(11,122,115,.28);position:relative;overflow:hidden;}
.hero::after{content:"";position:absolute;right:-50px;top:-60px;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.08);}
.hero::before{content:"";position:absolute;right:30px;bottom:-70px;width:140px;height:140px;border-radius:50%;background:rgba(255,255,255,.06);}
.hero .top{display:flex;justify-content:space-between;align-items:flex-start;position:relative;z-index:1;}
.hero .big{font-size:42px;font-weight:700;letter-spacing:-.03em;line-height:1;display:flex;align-items:center;gap:10px;}
.hero .cap{font-size:12.5px;opacity:.85;margin-top:7px;}
.hero .streak{background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.22);padding:6px 12px;border-radius:999px;font-size:12.5px;font-weight:600;display:flex;align-items:center;gap:5px;white-space:nowrap;}
.hero .progress{margin-top:18px;position:relative;z-index:1;}
.hero .progress .row{display:flex;justify-content:space-between;font-size:12px;opacity:.92;margin-bottom:6px;}
.bar{height:8px;border-radius:999px;background:rgba(255,255,255,.22);overflow:hidden;}
.bar>i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#fff,#d6f1ec);transition:width .6s cubic-bezier(.2,.7,.3,1);}

.acts{display:flex;flex-direction:column;gap:10px;}
.act{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);transition:border-color .2s,background .2s;overflow:hidden;}
.act .head{display:flex;align-items:center;gap:13px;padding:13px 14px;}
.act.done{background:var(--teal-50);border-color:var(--teal-100);}
.act .ic{width:42px;height:42px;border-radius:12px;flex:none;display:grid;place-items:center;font-size:21px;background:var(--surface-2);border:1px solid var(--border);}
.act.done .ic{background:#fff;border-color:var(--teal-100);}
.act .mid{flex:1;min-width:0;}
.act .nm{font-size:15px;font-weight:600;color:var(--ink);line-height:1.25;display:flex;align-items:center;gap:7px;flex-wrap:wrap;}
.donetag{font-size:10.5px;font-weight:600;color:var(--teal-700);background:var(--teal-100);padding:2px 8px;border-radius:999px;display:inline-flex;align-items:center;gap:3px;}
.act .sub{font-size:12px;color:var(--muted);margin-top:3px;display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.reward-chip{color:var(--teal-700);font-weight:600;display:inline-flex;align-items:center;gap:3px;}
.earned-chip{color:var(--teal-600);font-weight:600;display:inline-flex;align-items:center;gap:4px;}

/* lighter check */
.check{width:30px;height:30px;border-radius:50%;flex:none;border:2px solid var(--border-strong);background:var(--surface);display:grid;place-items:center;transition:.2s;color:transparent;}
.check.on{background:var(--teal-100);border-color:var(--teal-300);color:var(--teal-700);animation:pop .3s cubic-bezier(.2,1.3,.4,1);}
@keyframes pop{0%{transform:scale(.6);}100%{transform:scale(1);}}
.check svg{width:16px;height:16px;}

.numwrap{display:flex;align-items:center;gap:7px;flex:none;}
.numwrap input{width:74px;text-align:center;padding:8px 6px;border-radius:10px;border:1.5px solid var(--border-strong);background:var(--surface-2);font-weight:600;font-size:15px;}
.numwrap input:focus{outline:none;border-color:var(--teal-500);background:#fff;}
.numwrap .unit{font-size:12px;color:var(--muted);min-width:22px;}
.btn-save{width:36px;height:36px;border-radius:11px;flex:none;display:grid;place-items:center;background:var(--surface-2);border:1.5px solid var(--border-strong);color:var(--teal-700);transition:.15s;}
.btn-save:active{transform:scale(.92);background:var(--teal-100);border-color:var(--teal-300);}
.btn-save svg{width:16px;height:16px;}

/* sub area inside cards */
.subarea{padding:0 14px 13px;display:flex;flex-direction:column;gap:9px;}
.opt-row{display:flex;gap:7px;flex-wrap:wrap;align-items:center;}
.opt-label{font-size:12.5px;color:var(--muted);min-width:56px;}
.chip-btn{padding:7px 13px;border-radius:999px;font-size:13px;font-weight:600;background:var(--surface-2);border:1.5px solid var(--border);color:var(--text);transition:.15s;display:inline-flex;align-items:center;gap:5px;}
.chip-btn:active{transform:scale(.95);}
.chip-btn.on{background:var(--teal-600);border-color:var(--teal-600);color:#fff;box-shadow:0 4px 10px rgba(13,148,136,.22);}
.chip-btn .pt{font-size:11px;opacity:.75;}
.chip-btn.on .pt{opacity:.9;}
.mc-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 12px;border-radius:11px;background:var(--surface-2);border:1px solid var(--border);transition:.15s;}
.mc-item.on{background:var(--teal-50);border-color:var(--teal-100);}
.mc-item .l{font-size:13.5px;font-weight:500;color:var(--ink);}
.mc-item .r{display:flex;align-items:center;gap:8px;}
.mc-item .rp{font-size:11.5px;color:var(--teal-700);font-weight:600;}
.mini-check{width:24px;height:24px;border-radius:7px;border:2px solid var(--border-strong);display:grid;place-items:center;color:transparent;transition:.15s;background:#fff;}
.mc-item.on .mini-check{background:var(--teal-600);border-color:var(--teal-600);color:#fff;}
.mini-check svg{width:13px;height:13px;}
.add-line{padding:8px 12px;border-radius:11px;border:1.5px dashed var(--border-strong);color:var(--teal-700);font-weight:600;font-size:13px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;gap:6px;transition:.15s;}
.add-line:active{background:var(--teal-50);}
.sess-chip{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 11px;border-radius:11px;background:var(--teal-50);border:1px solid var(--teal-100);font-size:13px;}
.sess-chip .info{color:var(--ink);font-weight:500;}
.sess-chip .pts{color:var(--teal-700);font-weight:600;font-size:12px;}
.sess-chip button{color:var(--rose);font-size:18px;line-height:1;padding:0 4px;}
.reading-chip{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 11px;border-radius:11px;background:var(--surface-2);border:1px solid var(--border);font-size:13px;}
.reading-chip .bpv{font-weight:600;color:var(--ink);}
.reading-chip .bpt{font-size:11px;color:var(--muted);}
.reading-chip button{color:var(--rose);font-size:18px;line-height:1;padding:0 4px;}
.bp-tag{display:inline-block;padding:1px 8px;border-radius:999px;font-size:10.5px;font-weight:600;border:1px solid transparent;margin-left:2px;}
.bedtime-lbl{display:inline-block;padding:2px 10px;border-radius:999px;font-size:11.5px;font-weight:600;margin-left:6px;}
.bedtime-lbl.bt-good{background:#10b9811a;color:#10b981;border:1px solid #10b98133;}
.bedtime-lbl.bt-bad{background:#dc26261a;color:#dc2626;border:1px solid #dc262633;}
.sleep-hint{font-size:11.5px;color:var(--muted);padding:6px 4px 0;line-height:1.5;}
.sleep-hint b{color:var(--ink);font-weight:600;}
.hidden-toggle{display:block;width:100%;margin:14px 0 6px;padding:10px 14px;background:var(--surface-2);border:1.5px dashed var(--border-strong);border-radius:12px;color:var(--muted);font-size:13px;font-weight:600;cursor:pointer;transition:.15s;}
.hidden-toggle:hover{background:var(--surface);color:var(--ink);}
.hidden-acts{margin-top:8px;display:none;}
.hidden-acts.open{display:flex;flex-direction:column;gap:10px;}
.drefresh{margin-left:6px;background:var(--teal-50)!important;color:var(--teal-700)!important;border-color:var(--teal-100)!important;}
.drefresh:hover{background:var(--teal-100)!important;}
.logic-block{background:var(--surface-2);border-radius:12px;padding:12px 14px;margin-bottom:10px;}
.logic-block h4{margin:0 0 6px;font-size:14px;font-weight:700;color:var(--ink);}
.logic-block p{margin:4px 0;font-size:12.5px;color:var(--muted);line-height:1.55;}
.logic-block ul{margin:4px 0 0;padding-left:18px;font-size:12.5px;color:var(--muted);line-height:1.7;}
.logic-block ul li{margin-bottom:2px;}
.logic-block b{color:var(--ink);font-weight:600;}
.bp-live{margin-top:10px;}
.bp-live-hint{display:block;font-size:12px;color:var(--muted);text-align:center;padding:10px;border:1px dashed var(--border-strong);border-radius:10px;line-height:1.5;}
.bp-live-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 14px;border-radius:12px;border:1.5px solid transparent;}
.bp-live-val{font-size:22px;font-weight:700;}
.bp-live-tag{padding:4px 12px;border-radius:999px;font-size:13px;font-weight:600;color:#fff;}
.med-empty{font-size:12.5px;color:var(--muted);padding:4px 2px;}
.tapgrid{display:flex;flex-wrap:wrap;gap:8px;}
.tapicon{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-size:24px;line-height:1;background:var(--surface-2);border:1.5px solid var(--border);filter:grayscale(1);opacity:.4;transition:.15s;}
.tapicon:active{transform:scale(.86);}
.tapicon.on{background:var(--teal-50);border-color:var(--teal-300);filter:none;opacity:1;}
.ml-select{width:100%;font-size:17px;font-weight:600;padding:13px 12px;border-radius:13px;border:1.5px solid var(--border-strong);background:var(--surface);color:var(--ink);text-align:center;text-align-last:center;appearance:none;-webkit-appearance:none;}
.earned-chip.neg{background:rgba(224,122,95,.13);color:#c0522e;}
.reward-chip.neutral{background:rgba(224,122,95,.12);color:#c0522e;}
.hist-filter{display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:space-between;margin-bottom:10px;}
.hf-dates{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--muted);}
.hf-dates input[type=date]{font-size:13px;padding:8px 9px;border-radius:10px;border:1px solid var(--border-strong);background:var(--surface);color:var(--ink);}
.hf-btns{display:flex;gap:7px;}
.chip-btn.export{background:var(--teal-600);color:#fff;border-color:var(--teal-600);}
.chip-btn.export:active{transform:scale(.94);}
.hist-sum{font-size:12.5px;color:var(--muted);margin-bottom:8px;font-weight:500;}
.hist-empty{font-size:13px;color:var(--faint);text-align:center;padding:18px;background:var(--surface-2);border-radius:14px;}

.shopgrid{display:grid;grid-template-columns:1fr 1fr;gap:11px;}
.reward{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 14px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:10px;position:relative;overflow:hidden;}
.reward.afford{border-color:var(--teal-100);box-shadow:var(--shadow);}
.reward.afford::before{content:"";position:absolute;inset:0;background:linear-gradient(160deg,var(--teal-50),transparent 60%);pointer-events:none;}
.reward .ic{font-size:34px;line-height:1;position:relative;}
.reward .nm{font-size:14.5px;font-weight:600;color:var(--ink);line-height:1.3;position:relative;min-height:38px;}
.reward .cost{display:flex;align-items:center;gap:5px;font-size:16px;font-weight:700;color:var(--teal-700);position:relative;}
.reward .costnote{font-size:11px;color:var(--muted);position:relative;}
.reward .redeemed{font-size:11px;color:var(--faint);position:relative;}
.btn-redeem{margin-top:2px;padding:9px;border-radius:11px;font-weight:600;font-size:13.5px;text-align:center;background:var(--teal-600);color:#fff;box-shadow:0 5px 13px rgba(13,148,136,.26);transition:.15s;position:relative;}
.btn-redeem:active{transform:scale(.97);}
.btn-redeem.locked{background:var(--surface-2);color:var(--faint);box-shadow:none;border:1px solid var(--border);}
.btn-redeem .needmore{font-size:11.5px;font-weight:500;}

.hist .row{display:flex;align-items:center;gap:11px;padding:11px 13px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);margin-bottom:8px;}
.hist .row .ic{font-size:20px;}
.hist .row .nm{flex:1;font-size:14px;font-weight:500;color:var(--ink);}
.hist .row .dt{font-size:11.5px;color:var(--muted);}
.hist .row .amt{font-size:13px;font-weight:600;color:var(--rose);}

.stats{display:grid;grid-template-columns:1fr 1fr;gap:11px;}
.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:15px 16px;box-shadow:var(--shadow-sm);}
.stat .v{font-size:26px;font-weight:700;color:var(--ink);letter-spacing:-.02em;line-height:1;display:flex;align-items:baseline;gap:5px;}
.stat .v small{font-size:13px;font-weight:500;color:var(--muted);}
.stat .k{font-size:12px;color:var(--muted);margin-top:6px;}
.stat.accent{background:linear-gradient(150deg,var(--teal-600),var(--teal-700));border:none;color:#fff;}
.stat.accent .v,.stat.accent .k{color:#fff;}
.stat.accent .v small{color:rgba(255,255,255,.8);}

.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);margin-bottom:11px;}
.panel h3{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:3px;}
.panel .hint{font-size:11.5px;color:var(--muted);margin-bottom:14px;}

.heat-scroll{overflow-x:auto;padding-bottom:6px;-webkit-overflow-scrolling:touch;}
.heat-months{display:flex;gap:3px;margin-bottom:5px;font-size:10px;color:var(--faint);height:13px;}
.heat-grid{display:flex;gap:3px;}
.heat-col{display:flex;flex-direction:column;gap:3px;}
.heat-cell{width:13px;height:13px;border-radius:3.5px;background:var(--empty);}
.heat-legend{display:flex;align-items:center;gap:5px;justify-content:flex-end;margin-top:12px;font-size:11px;color:var(--muted);}
.heat-legend .heat-cell{width:11px;height:11px;}

.chart-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:10px;}
.chart-latest{font-size:24px;font-weight:700;color:var(--ink);letter-spacing:-.02em;display:flex;align-items:baseline;gap:5px;}
.chart-latest small{font-size:13px;color:var(--muted);font-weight:500;}
.delta{font-size:12.5px;font-weight:600;padding:3px 9px;border-radius:999px;}
.delta.down{color:var(--teal-700);background:var(--teal-50);}
.delta.up{color:var(--rose);background:var(--rose-bg);}
.delta.flat{color:var(--muted);background:var(--surface-2);}
.chart svg{width:100%;display:block;}
.chart-panel{cursor:pointer;}
.chart-panel:active{transform:scale(.995);}
.zoomhint{text-align:center;font-size:11.5px;color:var(--teal-600);margin-top:8px;font-weight:500;}
.zoomhead{display:flex;align-items:center;justify-content:space-between;gap:10px;}
.zoomctl{display:flex;align-items:center;gap:8px;}
.zoomctl button{width:38px;height:38px;border-radius:11px;background:var(--surface-2);border:1px solid var(--border-strong);font-size:22px;font-weight:600;color:var(--teal-700);display:grid;place-items:center;}
.zoomctl button:active{transform:scale(.9);}
.zoomctl span{font-size:13px;font-weight:600;color:var(--muted);min-width:26px;text-align:center;}
.zoomwrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--border);border-radius:14px;background:var(--surface-2);margin:10px 0;padding:6px;}
.zoomwrap svg{display:block;}
.chart-empty{font-size:13px;color:var(--faint);text-align:center;padding:24px 0;}
.legend2{display:flex;gap:16px;justify-content:center;margin-top:10px;font-size:12px;color:var(--muted);}
.legend2 span{display:flex;align-items:center;gap:6px;}
.legend2 i{width:14px;height:3px;border-radius:2px;display:inline-block;}
.legend-drinks{flex-wrap:wrap;gap:8px 14px;}
.legend-drinks i{width:12px;height:12px;border-radius:3px;}
.drink-stats{display:flex;justify-content:space-around;margin:10px 0 4px;padding:10px 6px;background:var(--surface-2);border-radius:10px;text-align:center;font-size:11.5px;color:var(--muted);}
.drink-stats b{display:block;font-size:18px;color:var(--ink);font-weight:700;margin-bottom:1px;}
.drink-stats small{display:block;}

.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.cal-head .mo{font-size:16px;font-weight:600;color:var(--ink);}
.cal-nav{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:.15s;}
.cal-nav:active{transform:scale(.93);}
.cal-nav svg{width:18px;height:18px;color:var(--teal-700);}
.cal-dows{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;margin-bottom:6px;}
.cal-dows span{text-align:center;font-size:11px;color:var(--faint);font-weight:500;}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;}
.cal-day{aspect-ratio:1;border-radius:11px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:var(--surface);border:1px solid var(--border);font-size:13.5px;color:var(--text);position:relative;transition:.12s;}
.cal-day.blank{background:transparent;border:none;}
.cal-day.has:active{transform:scale(.94);}
.cal-day.today{border:1.5px solid var(--teal-500);font-weight:700;color:var(--teal-700);}
.cal-day .dot{width:6px;height:6px;border-radius:50%;background:var(--teal-300);}
.cal-day.lvl2 .dot{background:var(--teal-500);}
.cal-day.lvl3 .dot{background:var(--teal-700);}
.cal-day .cnt{position:absolute;top:4px;right:5px;font-size:9px;color:var(--teal-600);font-weight:600;}

.set-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:13px;box-shadow:var(--shadow-sm);margin-bottom:10px;}
.set-row{display:flex;align-items:flex-end;gap:9px;}
.set-row+.set-row{margin-top:9px;}
.fld{display:flex;flex-direction:column;gap:4px;}
.fld label{font-size:10.5px;color:var(--muted);font-weight:500;padding-left:2px;}
.fld input,.fld select{padding:9px 10px;border-radius:10px;border:1.5px solid var(--border-strong);background:var(--surface-2);font-size:14px;font-weight:500;width:100%;}
.fld input:focus,.fld select:focus{outline:none;border-color:var(--teal-500);background:#fff;}
.fld.ic-fld{flex:none;width:54px;}
.fld.ic-fld input{text-align:center;font-size:20px;padding:8px 4px;}
.fld.flex1{flex:1;min-width:0;}
.fld.sm{width:84px;flex:none;}
.set-del{width:32px;height:32px;border-radius:9px;flex:none;display:grid;place-items:center;background:var(--rose-bg);color:var(--rose);transition:.15s;}
.set-del:active{transform:scale(.9);}
.set-del svg{width:16px;height:16px;}
.set-name{font-size:13.5px;font-weight:600;color:var(--ink);margin-bottom:9px;display:flex;align-items:center;gap:7px;}
.pt-grid{display:flex;flex-wrap:wrap;gap:8px;}
.pt-fld{display:flex;flex-direction:column;gap:3px;width:calc(50% - 4px);}
.pt-fld label{font-size:10.5px;color:var(--muted);}
.pt-fld input{padding:8px 10px;border-radius:9px;border:1.5px solid var(--border-strong);background:var(--surface-2);font-size:14px;font-weight:600;width:100%;}
.pt-fld input:focus{outline:none;border-color:var(--teal-500);background:#fff;}
.btn-add{width:100%;padding:12px;border-radius:var(--radius-sm);border:1.5px dashed var(--border-strong);color:var(--teal-700);font-weight:600;font-size:14px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;gap:7px;transition:.15s;}
.btn-add:active{background:var(--teal-50);}
.data-btns{display:flex;flex-direction:column;gap:9px;}
.btn-wide{padding:13px;border-radius:var(--radius-sm);font-weight:600;font-size:14px;display:flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--border);background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm);transition:.15s;}
.btn-wide:active{transform:scale(.99);}
.btn-wide svg{width:17px;height:17px;}
.btn-wide.danger{color:var(--rose);background:var(--rose-bg);border-color:#f8d8dc;}
.btn-wide.primary{color:#fff;background:var(--teal-600);border:none;box-shadow:0 6px 16px rgba(13,148,136,.24);}
.btn-wide.lock{color:var(--ink);background:var(--surface-2);}
.app-name-input{width:100%;padding:13px 14px;border-radius:var(--radius-sm);border:1.5px solid var(--border-strong);background:var(--surface-2);font-size:16px;font-weight:600;color:var(--ink);}
.app-name-input:focus{outline:none;border-color:var(--teal-500);background:#fff;}
.note{font-size:12px;color:var(--muted);line-height:1.6;background:var(--teal-50);border:1px solid var(--teal-100);border-radius:var(--radius-sm);padding:12px 14px;display:flex;gap:9px;}
.note .b{font-size:16px;flex:none;}

.nav{position:fixed;left:0;right:0;bottom:0;z-index:50;max-width:var(--maxw);margin:0 auto;background:rgba(255,255,255,.9);backdrop-filter:saturate(160%) blur(16px);-webkit-backdrop-filter:saturate(160%) blur(16px);border-top:1px solid var(--border);display:grid;grid-template-columns:repeat(5,1fr);padding:9px 6px calc(9px + env(safe-area-inset-bottom));}
.nav button{display:flex;flex-direction:column;align-items:center;gap:3px;padding:5px 2px;border-radius:12px;color:var(--faint);transition:.18s;}
.nav button svg{width:23px;height:23px;stroke-width:1.9;transition:.18s;}
.nav button span{font-size:10px;font-weight:500;}
.nav button.active{color:var(--teal-700);}
.nav button.active svg{transform:translateY(-1px);stroke-width:2.2;}
.nav button:active{transform:scale(.9);}

.overlay{position:fixed;inset:0;z-index:100;background:rgba(16,40,38,.42);backdrop-filter:blur(3px);display:none;align-items:flex-end;justify-content:center;overscroll-behavior:contain;touch-action:none;}
.overlay.open{display:flex;animation:fade .2s;}
html.modal-open,body.modal-open{overscroll-behavior:none;}
.overlay .sheet{touch-action:auto;overscroll-behavior:contain;}
@keyframes fade{from{opacity:0;}to{opacity:1;}}
.sheet{width:100%;max-width:var(--maxw);background:var(--surface);border-radius:26px 26px 0 0;padding:8px 20px calc(26px + env(safe-area-inset-bottom));box-shadow:var(--shadow-lg);animation:slideup .34s cubic-bezier(.2,.8,.25,1);max-height:88vh;overflow-y:auto;}
@keyframes slideup{from{transform:translateY(100%);}to{transform:none;}}
.grab{width:40px;height:4px;border-radius:999px;background:var(--border-strong);margin:8px auto 16px;}
.sheet h2{font-size:18px;font-weight:700;color:var(--ink);}
.sheet .sub{font-size:13px;color:var(--muted);margin-top:3px;margin-bottom:18px;}
.sheet-form{display:flex;flex-direction:column;gap:14px;}
.sheet-form .fld label{font-size:11.5px;}
.sheet-day-list{display:flex;flex-direction:column;gap:9px;margin-bottom:6px;}
.sheet-day-list .row{display:flex;align-items:center;gap:11px;padding:11px 13px;background:var(--surface-2);border-radius:12px;}
.sheet-day-list .row .ic{font-size:20px;}
.sheet-day-list .row .nm{flex:1;font-size:14px;font-weight:500;color:var(--ink);}
.sheet-day-list .row .val{font-size:12.5px;color:var(--muted);}
.sheet-day-list .row .e{font-size:13px;font-weight:600;color:var(--teal-700);}
.sheet-empty{text-align:center;color:var(--faint);font-size:14px;padding:20px 0;}
.confirm-actions{display:flex;gap:11px;margin-top:8px;}
.confirm-actions button{flex:1;padding:14px;border-radius:14px;font-weight:600;font-size:15px;transition:.15s;}
.confirm-actions button:active{transform:scale(.97);}
.btn-ghost{background:var(--surface-2);color:var(--text);}
.btn-confirm{background:var(--teal-600);color:#fff;box-shadow:0 6px 16px rgba(13,148,136,.26);}
.celebrate-ic{font-size:64px;text-align:center;margin:6px 0 4px;animation:bounce .6s cubic-bezier(.2,1.4,.4,1);}
@keyframes bounce{0%{transform:scale(0) rotate(-15deg);}60%{transform:scale(1.15);}100%{transform:scale(1);}}
.celebrate-txt{text-align:center;}
.celebrate-txt h2{font-size:20px;}
.celebrate-txt p{font-size:14px;color:var(--muted);margin-top:6px;margin-bottom:8px;}
.live-cost{text-align:center;font-size:15px;font-weight:600;color:var(--ink);background:var(--surface-2);padding:12px;border-radius:13px;}
.live-cost b{color:var(--teal-700);font-size:18px;}

.toasts{position:fixed;left:0;right:0;bottom:108px;z-index:130;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none;}
.toast{background:var(--ink);color:#fff;padding:11px 18px;border-radius:999px;font-size:14px;font-weight:600;box-shadow:0 10px 28px rgba(16,48,46,.3);display:flex;align-items:center;gap:8px;animation:toastin .3s cubic-bezier(.2,.9,.3,1);}
@keyframes toastin{from{opacity:0;transform:translateY(14px) scale(.9);}to{opacity:1;transform:none;}}
.toast.out{animation:toastout .3s forwards;}
@keyframes toastout{to{opacity:0;transform:translateY(-8px) scale(.95);}}

.confetti{position:fixed;inset:0;z-index:140;pointer-events:none;overflow:hidden;}
.confetti i{position:absolute;top:-12px;width:9px;height:14px;border-radius:2px;animation:fall linear forwards;}
@keyframes fall{to{transform:translateY(110vh) rotate(640deg);opacity:.9;}}

.reveal{animation:reveal .45s cubic-bezier(.2,.7,.3,1) backwards;}
@keyframes reveal{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}
.empty-block{text-align:center;padding:30px 16px;color:var(--faint);}
.empty-block .e{font-size:38px;margin-bottom:8px;}
.empty-block p{font-size:14px;}

/* private zone */
.priv-streaks{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-bottom:14px;}
.priv-streak{background:linear-gradient(150deg,var(--teal-600),var(--teal-700));color:#fff;border-radius:var(--radius-sm);padding:15px;text-align:center;}
.priv-streak .v{font-size:30px;font-weight:700;line-height:1;}
.priv-streak .k{font-size:11.5px;opacity:.9;margin-top:5px;}
.pinpad-display{text-align:center;font-size:30px;letter-spacing:10px;color:var(--ink);height:42px;font-weight:700;}
.pinpad{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:18px;}
.pinkey{padding:16px;border-radius:14px;background:var(--surface-2);font-size:20px;font-weight:600;color:var(--ink);transition:.12s;}
.pinkey:active{transform:scale(.94);background:var(--teal-50);}
.pinkey.fn{font-size:14px;color:var(--muted);}

/* ===== auth gate (login + pin) ===== */
.authgate{position:fixed;inset:0;z-index:200;background:radial-gradient(1200px 380px at 50% -120px,var(--teal-50),transparent 70%),var(--bg);display:none;flex-direction:column;align-items:center;justify-content:center;padding:20px 14px;overflow-y:auto;}
.authgate.open{display:flex;animation:fade .25s;}
#authgateInner{width:100%;display:flex;flex-direction:column;align-items:center;}
.authbox{width:100%;max-width:360px;text-align:center;}
.pinwrap{width:100%;max-width:340px;text-align:center;}
.authlogo{width:64px;height:64px;border-radius:20px;margin:0 auto 18px;background:linear-gradient(145deg,var(--teal-500),var(--teal-700));display:grid;place-items:center;color:#fff;font-size:32px;box-shadow:0 12px 28px rgba(13,148,136,.32);}
.authgate h2{font-size:21px;font-weight:700;color:var(--ink);}
.authsub{font-size:13.5px;color:var(--muted);margin-top:6px;margin-bottom:24px;line-height:1.6;}
.authfield{text-align:left;margin-bottom:13px;}
.authfield label{display:block;font-size:12px;color:var(--muted);font-weight:500;margin-bottom:5px;padding-left:3px;}
.authfield input{width:100%;padding:14px 15px;border-radius:13px;border:1.5px solid var(--border-strong);background:var(--surface);font-size:16px;color:var(--ink);}
.authfield input:focus{outline:none;border-color:var(--teal-500);}
.authbtn{width:100%;padding:15px;border-radius:13px;background:var(--teal-600);color:#fff;font-size:15.5px;font-weight:600;box-shadow:0 8px 20px rgba(13,148,136,.26);transition:.15s;margin-top:6px;}
.authbtn:active{transform:scale(.98);}
.authbtn:disabled{opacity:.6;}
.autherr{font-size:13px;color:var(--rose);margin-top:12px;min-height:18px;font-weight:500;}
.pindots{display:flex;justify-content:center;gap:20px;margin:28px 0 6px;height:18px;}
.pindot{width:15px;height:15px;border-radius:50%;background:var(--border-strong);transition:.15s;}
.pindot.on{background:var(--teal-600);transform:scale(1.1);}
.pingrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:24px;}
.pinbtn{aspect-ratio:1;display:grid;place-items:center;border-radius:50%;background:var(--surface);border:1px solid var(--border);font-size:34px;font-weight:600;color:var(--ink);box-shadow:var(--shadow-sm);transition:transform .08s,background .12s,color .12s;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation;}
.pinbtn:active{transform:scale(.9);background:var(--teal-600);border-color:var(--teal-600);color:#fff;}
.pinbtn.blank{background:transparent;border:none;box-shadow:none;}
.pinbtn.fn{font-size:15px;color:var(--muted);}
.pinbio{margin-top:18px;display:inline-flex;align-items:center;gap:8px;color:var(--teal-700);font-size:14px;font-weight:600;padding:10px 18px;border-radius:12px;background:var(--teal-50);border:1px solid var(--teal-100);}
.pinbio:active{transform:scale(.96);}
.pinbio svg{width:20px;height:20px;}
.pinlogout{margin-top:22px;font-size:13px;color:var(--faint);background:none;text-decoration:underline;}

/* ===== footer + sleep time + tapmore ===== */
.app-footer{margin-top:26px;padding:18px 0 4px;text-align:center;border-top:1px solid var(--border);}
.app-footer .af-name{font-size:14px;font-weight:700;color:var(--ink);}
.app-footer .af-ver{font-size:12px;font-weight:600;color:var(--teal-600);background:var(--teal-50);padding:1px 7px;border-radius:999px;margin-left:4px;}
.app-footer .af-by{font-size:12.5px;color:var(--muted);margin-top:5px;}
.app-footer .af-build{font-size:11px;color:var(--faint);margin-top:3px;}
.reorder-row{display:flex;align-items:center;gap:12px;padding:13px 14px;background:var(--surface);border:1px solid var(--border);border-radius:13px;margin-bottom:8px;box-shadow:var(--shadow-sm);cursor:grab;user-select:none;-webkit-user-select:none;touch-action:pan-y;}
.reorder-row:active{cursor:grabbing;}
.reorder-row .rdrag{color:var(--faint);font-size:18px;padding:0 2px;}
.reorder-row .ric{font-size:20px;line-height:1;}
.reorder-row .rnm{font-size:14.5px;color:var(--ink);font-weight:500;}
.reorder-ghost{opacity:.35;}
.reorder-chosen{box-shadow:var(--shadow-lg);border-color:var(--teal-300);}
.set-section{border:1px solid var(--border);border-radius:14px;margin-bottom:10px;background:var(--surface);overflow:hidden;box-shadow:var(--shadow-sm);}
.set-head{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:15px 16px;background:none;border:none;cursor:pointer;font-family:inherit;text-align:left;}
.set-head .sh-t{font-size:15px;font-weight:600;color:var(--ink);}
.set-head .sh-arrow{width:20px;height:20px;flex:none;color:var(--muted);transition:transform .25s;}
.set-section.open .sh-arrow{transform:rotate(180deg);}
.set-section.open .set-head{border-bottom:1px solid var(--border);}
.set-body{padding:14px 16px 18px;}
.set-mini-label{display:block;font-size:12px;color:var(--muted);font-weight:500;margin-bottom:6px;padding-left:2px;}
.sync-badge{position:fixed;left:14px;bottom:86px;z-index:125;display:flex;align-items:center;padding:8px 13px;border-radius:999px;font-size:12.5px;font-weight:600;box-shadow:var(--shadow);opacity:0;transform:translateY(8px);pointer-events:none;transition:opacity .25s,transform .25s;max-width:calc(100% - 28px);}
.sync-badge.show{opacity:1;transform:translateY(0);}
.sync-badge.saving{background:#fff4e0;color:#92670c;border:1px solid #f0c14b;}
.sync-badge.saved{background:var(--teal-50);color:var(--teal-700);border:1px solid var(--teal-100);}
.sync-badge.offline{background:#fdecef;color:#b3334b;border:1px solid #f3c2cc;}
.time-in{font-size:15px;font-weight:600;padding:7px 10px;border-radius:10px;border:1.5px solid var(--border-strong);background:var(--surface-2);color:var(--ink);}
.time-in:focus{outline:none;border-color:var(--teal-500);background:#fff;}
.wake-lbl{font-size:12.5px;color:var(--teal-700);font-weight:600;background:var(--teal-50);padding:5px 10px;border-radius:999px;}
.tapicon.tapmore{filter:none;opacity:1;background:var(--teal-50);border-color:var(--teal-300);border-style:dashed;color:var(--teal-700);font-size:26px;font-weight:300;}
.med-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 12px;border-radius:11px;background:var(--surface-2);border:1px solid var(--border);}
.med-row+.med-row{margin-top:8px;}
.med-info{min-width:0;flex:1;}
.med-nm{font-size:13.5px;font-weight:600;color:var(--ink);}
.med-sub{font-size:11.5px;color:var(--muted);margin-top:2px;}
.med-meals{display:flex;gap:6px;flex:none;flex-wrap:wrap;justify-content:flex-end;}
.meal-pill{min-width:30px;height:30px;padding:0 11px;border-radius:9px;border:1.5px solid var(--border-strong);background:#fff;color:var(--muted);font-size:12.5px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;transition:.15s;}
.med-times-lbl{font-size:11px;color:var(--muted);font-weight:500;margin:6px 2px 2px;}
.meal-pill.on{background:var(--teal-600);border-color:var(--teal-600);color:#fff;}
.meal-pill svg{width:14px;height:14px;}
.meal-pill:active{transform:scale(.9);}
