:root{
  --bg:#0e1419; --bg2:#141c24; --surface:#19232d; --surface2:#1f2c38; --line:#2a3a48;
  --text:#e7eef3; --muted:#8499a8; --earn:#5fe39b; --earn-dim:#1d3a2c;
  --spend:#ffb24d; --spend-dim:#3a2f1a; --accent:#6ab7ff; --danger:#ff6b6b; --pending:#c9a8ff;
  --radius:16px; --display:"Bricolage Grotesque",serif; --body:"DM Sans",sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{
  background:
    radial-gradient(1200px 500px at 80% -10%, #15303a 0%, transparent 60%),
    radial-gradient(900px 600px at -10% 110%, #1c2a1f 0%, transparent 55%), var(--bg);
  color:var(--text); font-family:var(--body); -webkit-font-smoothing:antialiased;
  line-height:1.5; min-height:100vh; padding:20px 16px 60px;
}
.wrap{max-width:820px;margin:0 auto}
.loading{text-align:center;color:var(--muted);padding:80px 0}
a{color:var(--accent)}

/* login */
.login{max-width:380px;margin:9vh auto;background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:30px}
.login .logo{width:46px;height:46px;border-radius:13px;background:linear-gradient(135deg,var(--earn),var(--accent));display:grid;place-items:center;font-family:var(--display);font-weight:800;color:#0e1419;font-size:24px;margin-bottom:18px}
.login h1{font-family:var(--display);font-size:24px;font-weight:800;letter-spacing:-.02em}
.login p{color:var(--muted);font-size:13px;margin-bottom:22px}
.login .err{color:var(--danger);font-size:13px;min-height:18px;margin-top:6px}

header.top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:11px}
.logo{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--earn),var(--accent));display:grid;place-items:center;font-family:var(--display);font-weight:800;color:#0e1419;font-size:20px}
.brand h1{font-family:var(--display);font-size:21px;font-weight:800;letter-spacing:-.02em}
.brand p{font-size:12px;color:var(--muted);margin-top:-2px}
.topright{display:flex;align-items:center;gap:8px}
.who{font-size:13px;color:var(--muted)}
.iconbtn{background:var(--surface);border:1px solid var(--line);color:var(--text);min-width:40px;height:40px;border-radius:11px;font-size:14px;cursor:pointer;transition:.15s;padding:0 12px}
.iconbtn:hover{background:var(--surface2);border-color:var(--accent)}

.tabs{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}
.tab{background:var(--surface);border:1px solid var(--line);color:var(--muted);padding:9px 16px;border-radius:11px;cursor:pointer;font-weight:700;font-size:14px;font-family:var(--body);position:relative}
.tab.active{background:var(--surface2);color:var(--text);border-color:var(--accent)}
.tab .badge{position:absolute;top:-7px;right:-7px;background:var(--pending);color:#0e1419;font-size:11px;font-weight:800;border-radius:99px;min-width:19px;height:19px;display:grid;place-items:center;padding:0 5px}

.childpick{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.childpick button{background:var(--surface);border:1px solid var(--line);color:var(--muted);padding:8px 14px;border-radius:10px;cursor:pointer;font-family:var(--body);font-weight:700;font-size:13px}
.childpick button.active{background:var(--earn-dim);border-color:var(--earn);color:var(--earn)}

.hero{background:linear-gradient(160deg,var(--surface) 0%,var(--bg2) 100%);border:1px solid var(--line);border-radius:var(--radius);padding:22px;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background:radial-gradient(400px 200px at 100% 0%,rgba(95,227,155,.10),transparent 70%);pointer-events:none}
.hero .lbl{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;font-weight:700}
.balance{font-family:var(--display);font-weight:800;font-size:54px;line-height:1;margin:8px 0 4px;letter-spacing:-.03em}
.balance.zero{color:var(--spend)}
.hero .sub{font-size:13px;color:var(--muted)}
.bar{height:9px;border-radius:99px;background:#0c1217;margin-top:16px;overflow:hidden;border:1px solid var(--line)}
.bar>span{display:block;height:100%;background:linear-gradient(90deg,var(--earn),var(--accent));border-radius:99px;transition:width .4s}
.herometa{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-top:7px}

.days{display:flex;gap:7px;margin:18px 0 0}
.day{flex:1;background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:9px 4px;text-align:center;cursor:pointer;transition:.15s}
.day:hover{border-color:var(--accent)}
.day .dn{font-size:12px;color:var(--muted);font-weight:700}
.day .dot{width:18px;height:18px;border-radius:50%;border:2px solid var(--line);margin:6px auto 0;display:grid;place-items:center;font-size:11px;color:#0e1419;transition:.15s}
.day.on{background:var(--earn-dim);border-color:var(--earn)}
.day.on .dot{background:var(--earn);border-color:var(--earn)}
.day.on .dn{color:var(--earn)}
.day.today{box-shadow:0 0 0 2px var(--accent) inset}

section{margin-top:24px}
.sec-h{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:11px}
.sec-h h2{font-family:var(--display);font-size:18px;font-weight:600;letter-spacing:-.01em}
.sec-h .hint{font-size:12px;color:var(--muted)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px}

.chk{display:flex;align-items:center;gap:12px;padding:10px 4px;cursor:pointer;border-bottom:1px solid var(--line)}
.chk:last-child{border-bottom:none}
.chk .box{width:22px;height:22px;border-radius:7px;border:2px solid var(--line);flex:0 0 auto;display:grid;place-items:center;transition:.15s;font-size:13px;color:#0e1419}
.chk.done .box{background:var(--earn);border-color:var(--earn)}
.chk.done span{color:var(--muted);text-decoration:line-through}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}
.bonus{background:var(--surface);border:1px solid var(--line);border-radius:13px;padding:13px;text-align:left;cursor:pointer;transition:.15s;position:relative;font-family:var(--body)}
.bonus:hover{border-color:var(--earn);background:var(--surface2);transform:translateY(-2px)}
.bonus:active{transform:translateY(0)}
.bonus .nm{font-weight:700;font-size:14px;margin-bottom:6px;padding-right:6px;color:var(--text)}
.bonus .pts{font-size:12px;color:var(--earn);font-weight:700}
.bonus .plus{position:absolute;top:11px;right:11px;width:22px;height:22px;border-radius:50%;background:var(--earn-dim);color:var(--earn);display:grid;place-items:center;font-size:15px;font-weight:700}

.spend-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.spend-btn{background:var(--spend-dim);border:1px solid #4a3a1e;color:var(--spend);font-weight:700;padding:11px 16px;border-radius:11px;cursor:pointer;font-size:14px;font-family:var(--body)}
.spend-btn:hover{background:#46371d;border-color:var(--spend)}
.spend-custom{display:flex;gap:8px;align-items:center;margin-left:auto}
.spend-custom input{width:74px;background:var(--bg);border:1px solid var(--line);color:var(--text);padding:10px;border-radius:10px;font-family:var(--body);font-size:14px}

.logrow{display:flex;align-items:center;gap:10px;padding:9px 2px;border-bottom:1px solid var(--line);font-size:13px}
.logrow:last-child{border-bottom:none}
.logrow .tag{width:8px;height:8px;border-radius:50%;flex:0 0 auto}
.tag.e{background:var(--earn)}.tag.s{background:var(--spend)}.tag.p{background:var(--pending)}.tag.r{background:var(--danger)}
.logrow .ltxt{flex:1}
.logrow .lval{font-weight:700}
.logrow .lval.e{color:var(--earn)}.logrow .lval.s{color:var(--spend)}.logrow .lval.p{color:var(--pending)}
.logrow .undo{background:none;border:none;color:var(--muted);cursor:pointer;font-size:12px;text-decoration:underline;font-family:var(--body)}
.logrow .undo:hover{color:var(--danger)}
.empty{color:var(--muted);font-size:13px;padding:8px 2px}

.approve{display:flex;align-items:center;gap:10px;padding:12px;border:1px solid var(--line);border-radius:12px;margin-bottom:10px;background:var(--surface)}
.approve .info{flex:1}
.approve .info b{color:var(--text)}
.approve .info small{color:var(--muted);display:block}
.approve .p" {}
.btn-ok{background:var(--earn);color:#0e1419;border:none;padding:9px 14px;border-radius:10px;font-weight:700;cursor:pointer;font-family:var(--body)}
.btn-no{background:none;border:1px solid #4a2424;color:var(--danger);padding:9px 14px;border-radius:10px;font-weight:700;cursor:pointer;font-family:var(--body)}

.field{margin-bottom:16px}
.field label{display:block;font-size:12px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:7px}
.field input,.field select{width:100%;background:var(--surface);border:1px solid var(--line);color:var(--text);padding:11px;border-radius:10px;font-family:var(--body);font-size:14px}
.editrow{display:flex;gap:8px;margin-bottom:8px;align-items:center}
.editrow input.nm{flex:1;background:var(--surface);border:1px solid var(--line);color:var(--text);padding:10px;border-radius:10px;font-family:var(--body)}
.editrow input.pt{width:64px;text-align:center;background:var(--surface);border:1px solid var(--line);color:var(--text);padding:10px;border-radius:10px;font-family:var(--body)}
.editrow .del{background:var(--surface);border:1px solid var(--line);color:var(--danger);width:38px;height:40px;border-radius:10px;cursor:pointer;flex:0 0 auto}
.addbtn{background:var(--surface2);border:1px dashed var(--line);color:var(--muted);width:100%;padding:10px;border-radius:10px;cursor:pointer;font-family:var(--body);font-size:13px;font-weight:700}
.addbtn:hover{color:var(--text);border-color:var(--accent)}
.threecol{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.grp{border:1px solid var(--line);border-radius:13px;padding:16px;margin-bottom:18px}
.grp h4{font-size:14px;font-weight:700;margin-bottom:12px;font-family:var(--display)}
.btn{padding:12px 18px;border-radius:11px;font-weight:700;font-family:var(--body);font-size:14px;cursor:pointer;border:1px solid var(--line)}
.btn.primary{background:var(--earn);color:#0e1419;border-color:var(--earn)}
.btn.ghost{background:var(--surface);color:var(--text)}
.btn.warn{background:none;color:var(--danger);border-color:#4a2424}
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.userrow{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--line)}
.userrow:last-child{border-bottom:none}
.userrow .un{flex:1}
.userrow .un small{color:var(--muted)}
.pill{font-size:11px;padding:2px 8px;border-radius:99px;background:var(--surface2);color:var(--muted);font-weight:700}
.pill.parent{background:#2a3550;color:var(--accent)}
.pill.child{background:var(--earn-dim);color:var(--earn)}

.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(80px);background:var(--earn);color:#0e1419;font-weight:700;padding:12px 20px;border-radius:12px;font-size:14px;opacity:0;transition:.28s;z-index:50;box-shadow:0 8px 30px rgba(0,0,0,.4)}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}
.toast.spend{background:var(--spend)}
.toast.err{background:var(--danger);color:#fff}
