:root{
  --bg:#FAFAF9;
  --card:#FFFFFF;
  --green:#4a7c59;          /* 深穩綠 accent（少量點綴）*/
  --green-deep:#3a6347;
  --green-soft:#E9F0EB;
  --ink:#1B1B1B;            /* 近純黑，高對比護眼 */
  --ink-soft:#6A6A6A;
  --line:#E6E6E4;
  --star:#F2A93B;           /* 星星金黃 */
  --star-soft:#FBEFD8;
  --yellow:#FFC93C;         /* 崴崴亮陽黃（icon／重點）*/
  --correct:#3A8F5A;
  --correct-soft:#E3F2E8;
  --wrong:#D9594A;
  --wrong-soft:#FBE8E5;
  --radius:18px;
  --shadow:0 4px 16px rgba(0,0,0,.06);
  --shadow-lift:0 10px 28px rgba(0,0,0,.12);
  --serif:'Noto Serif TC',serif;          /* 標題 */
  --zh:'Noto Sans TC',sans-serif;          /* 內文 */
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--bg);color:var(--ink);font-family:var(--zh);
  font-size:19px;line-height:1.85;font-weight:500;       /* 小二：放大、深、不細 */
  -webkit-font-smoothing:antialiased;padding-bottom:48px;
  overscroll-behavior:contain;
}
.wrap{max-width:760px;margin:0 auto;padding:0 18px;}
.hide{display:none!important;}

/* ===== 登入鎖 ===== */
#lock{position:fixed;inset:0;background:linear-gradient(165deg,var(--green),var(--green-deep));
  display:flex;align-items:center;justify-content:center;z-index:200;flex-direction:column;gap:20px;color:#fff;padding:24px;}
#lock h1{font-family:var(--serif);font-size:38px;font-weight:900;}
#lock p{opacity:.85;font-size:16px;letter-spacing:2px;}
#lock input{font-size:26px;padding:15px 18px;border-radius:14px;border:none;text-align:center;width:230px;font-family:var(--zh);letter-spacing:8px;}
#lock button{background:var(--yellow);color:#3a2e00;border:none;font-family:var(--serif);font-weight:700;
  font-size:22px;padding:14px 44px;border-radius:34px;cursor:pointer;}
#lock button:active{transform:scale(.96);}
#lock .err{color:#FFE0DA;font-size:15px;min-height:22px;font-weight:700;}

/* ===== HUD 頂部狀態列 ===== */
header{position:sticky;top:0;z-index:50;
  background:linear-gradient(135deg,var(--green),var(--green-deep));color:#fff;
  padding:calc(14px + env(safe-area-inset-top, 0px)) 0 16px;box-shadow:0 3px 14px rgba(0,0,0,.18);}
.hud{display:flex;align-items:center;gap:12px;}
.hud .title{font-family:var(--serif);font-weight:700;font-size:18px;margin-right:auto;letter-spacing:.3px;}
.hud .title small{display:block;font-size:11.5px;opacity:.85;font-weight:400;font-family:var(--zh);}
.chip{background:rgba(255,255,255,.2);border-radius:30px;padding:7px 14px;font-family:var(--serif);
  font-weight:700;font-size:16px;display:flex;align-items:center;gap:5px;white-space:nowrap;}
.chip.star{background:var(--yellow);color:#4a3500;}
.lvbar-wrap{margin-top:12px;}
.lvbar-top{display:flex;justify-content:space-between;font-size:12.5px;opacity:.92;margin-bottom:5px;}
.lvbar{height:10px;background:rgba(255,255,255,.28);border-radius:10px;overflow:hidden;}
.lvbar i{display:block;height:100%;background:var(--yellow);border-radius:10px;transition:width .5s ease;}
.backbtn{background:rgba(255,255,255,.18);border:none;color:#fff;font-family:var(--zh);font-size:15px;font-weight:700;
  padding:8px 16px;border-radius:30px;cursor:pointer;display:none;align-items:center;gap:4px;}
.backbtn.show{display:inline-flex;}
.backbtn:active{transform:scale(.96);}

/* ===== 通用 ===== */
.view{display:none;animation:fade .35s ease;}
.view.active{display:block;}
@keyframes fade{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
.sec-title{font-family:var(--serif);font-weight:900;font-size:26px;color:var(--ink);margin:24px 0 8px;}
.sec-desc{color:var(--ink-soft);font-size:16px;margin-bottom:16px;font-weight:400;line-height:1.7;}
.btn{font-family:var(--zh);font-size:18px;font-weight:700;padding:14px 26px;border-radius:32px;border:none;cursor:pointer;transition:.18s;}
.btn:active{transform:scale(.97);}
.btn-primary{background:var(--green);color:#fff;}
.btn-primary:hover{background:var(--green-deep);}
.btn-ghost{background:var(--card);color:var(--green-deep);border:2px solid var(--green-soft);}
.btn-star{background:var(--star);color:#4a3500;}
.btn-ask{background:var(--star-soft);color:#9A6B12;border:2px solid #F0D89A;}

/* ===== 首頁主選單 ===== */
.hero{text-align:center;padding:26px 0 6px;}
.hero .en{font-family:var(--serif);font-weight:900;font-size:30px;color:var(--ink);}
.hero .zh{color:var(--ink-soft);font-size:16px;margin-top:5px;font-weight:400;}
.hero .tag{display:inline-block;margin-top:14px;background:var(--star-soft);color:#9A6B12;font-size:15px;
  padding:7px 17px;border-radius:30px;font-weight:700;}
.menu{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:24px;}
.mcard{background:var(--card);border-radius:var(--radius);padding:24px 18px;cursor:pointer;
  box-shadow:var(--shadow);border:2px solid transparent;transition:.2s;display:flex;flex-direction:column;gap:8px;}
.mcard:hover{transform:translateY(-3px);box-shadow:var(--shadow-lift);border-color:var(--green-soft);}
.mcard .ico{font-size:34px;}
.mcard h3{font-size:20px;font-weight:900;color:var(--ink);font-family:var(--serif);}
.mcard p{font-size:14px;color:var(--ink-soft);font-weight:400;line-height:1.6;}
.taskcard{grid-column:1/-1;background:linear-gradient(120deg,var(--green-soft),#fff);border-color:var(--green-soft);}
.shopcard{grid-column:1/-1;background:linear-gradient(120deg,var(--star-soft),#fff);}
.badge{display:inline-block;background:var(--wrong);color:#fff;font-size:13px;font-weight:700;border-radius:20px;padding:2px 10px;margin-left:6px;}
.mom-link{text-align:center;margin-top:20px;}
.mom-link button{background:none;border:none;color:var(--ink-soft);font-size:14px;cursor:pointer;text-decoration:underline;font-family:var(--zh);}

/* ===== 每日任務 ===== */
.task-progress{background:var(--green-soft);border:1px solid #d6e4d9;border-radius:14px;padding:12px 16px;margin-bottom:16px;font-weight:700;color:var(--green-deep);font-size:16px;display:flex;justify-content:space-between;align-items:center;}
.tcard{background:var(--card);border-radius:16px;padding:16px 18px;margin-bottom:12px;box-shadow:var(--shadow);
  display:flex;align-items:center;gap:14px;border:2px solid transparent;transition:.2s;}
.tcard .ticon{font-size:32px;width:48px;text-align:center;flex-shrink:0;}
.tcard .tinfo{flex:1;min-width:0;}
.tcard .tname{font-size:19px;font-weight:700;font-family:var(--serif);}
.tcard .tstars{font-size:14px;color:var(--star);font-weight:700;margin-top:2px;}
.tcard .tstatus{font-size:13px;color:var(--ink-soft);font-weight:400;margin-top:2px;}
.tcard .tbtn{flex-shrink:0;}
/* 任務狀態邊框 */
.tcard.s0{border-color:var(--line);}
.tcard.s1{border-color:var(--star);background:var(--star-soft);}
.tcard.s2{border-color:var(--green);background:var(--green-soft);}
.tcard.s3{opacity:.6;border-color:var(--line);}
/* 大顆勾選圓鈕 */
.checkbtn{width:54px;height:54px;border-radius:50%;border:3px solid var(--green);background:#fff;
  font-size:26px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.15s;}
.checkbtn:active{transform:scale(.92);}
.checkbtn.checked{background:var(--star);border-color:var(--star);color:#fff;}
.claimbtn{background:var(--green);color:#fff;border:none;font-family:var(--serif);font-weight:700;font-size:17px;
  padding:13px 22px;border-radius:30px;cursor:pointer;animation:glow 1.2s ease-in-out infinite;}
.claimbtn:active{transform:scale(.95);}
@keyframes glow{0%,100%{box-shadow:0 0 0 0 rgba(74,124,89,.5);}50%{box-shadow:0 0 0 8px rgba(74,124,89,0);}}
.donetag{font-size:15px;color:var(--green);font-weight:700;}
.waittag{font-size:14px;color:var(--ink-soft);font-weight:700;}

/* ===== 測驗 ===== */
.tabs{display:flex;gap:8px;margin:16px 0 20px;flex-wrap:wrap;}
.tab{background:var(--card);border:2px solid var(--line);color:var(--ink-soft);padding:10px 22px;
  border-radius:30px;font-family:var(--zh);font-size:16px;font-weight:700;cursor:pointer;}
.tab.active{background:var(--green);color:#fff;border-color:var(--green);}
.grouppick{display:grid;gap:12px;}
.gpick{background:var(--card);border-radius:14px;padding:18px 20px;box-shadow:var(--shadow);cursor:pointer;
  border:2px solid transparent;display:flex;align-items:center;gap:14px;transition:.2s;}
.gpick:hover{border-color:var(--green-soft);transform:translateY(-2px);}
.gpick .lvtag{font-family:var(--serif);font-size:13px;padding:5px 12px;border-radius:20px;font-weight:700;}
.lv1{background:var(--correct-soft);color:#256B45;}
.lv2{background:var(--star-soft);color:#9A6B12;}
.lv3{background:var(--wrong-soft);color:#B5402F;}
.gpick h4{font-size:19px;color:var(--ink);font-family:var(--serif);}
.gpick small{color:var(--ink-soft);font-weight:400;}
.quiz-head{display:flex;align-items:center;gap:12px;margin-bottom:8px;}
.combo{font-family:var(--serif);font-size:16px;color:var(--star);font-weight:700;min-width:80px;}
.progress-wrap{flex:1;background:var(--line);height:12px;border-radius:12px;overflow:hidden;}
.progress-bar{height:100%;background:linear-gradient(90deg,var(--green),var(--correct));width:0;transition:width .4s;border-radius:12px;}
.progress-txt{font-family:var(--serif);font-size:16px;color:var(--green-deep);font-weight:700;}
.qcard{background:var(--card);border-radius:var(--radius);padding:24px 20px;box-shadow:var(--shadow);margin-top:12px;}
.qtext{font-size:23px;line-height:1.7;margin-bottom:18px;font-weight:700;font-family:var(--serif);}
.qtext .cn{display:block;font-family:var(--zh);font-size:15px;color:var(--ink-soft);margin-top:6px;font-weight:400;}
.opt{display:block;width:100%;text-align:left;background:var(--bg);border:2px solid var(--line);border-radius:14px;
  padding:17px 18px;margin-bottom:12px;font-size:20px;cursor:pointer;transition:.16s;color:var(--ink);font-weight:700;}
.opt:hover:not(:disabled){border-color:var(--green);background:var(--green-soft);}
.opt:disabled{cursor:default;}
.opt .ol{font-weight:900;color:var(--green);margin-right:10px;}
.opt.correct{background:var(--correct-soft);border-color:var(--correct);}
.opt.wrong{background:var(--wrong-soft);border-color:var(--wrong);}
.feedback{margin-top:14px;border-radius:12px;padding:15px 17px;font-size:16px;line-height:1.75;display:none;font-weight:400;}
.feedback.show{display:block;animation:fade .3s;}
.feedback.ok{background:var(--correct-soft);border-left:5px solid var(--correct);}
.feedback.no{background:var(--wrong-soft);border-left:5px solid var(--wrong);}
.feedback .ftag{font-weight:700;display:block;margin-bottom:4px;font-size:17px;}
.feedback.ok .ftag{color:#256B45;}
.feedback.no .ftag{color:#B5402F;}
.star-pop{display:inline-block;background:var(--star);color:#4a3500;font-family:var(--serif);font-weight:700;
  padding:3px 13px;border-radius:20px;margin-left:8px;animation:pop .4s ease;}
@keyframes pop{0%{transform:scale(0);}60%{transform:scale(1.25);}100%{transform:scale(1);}}
.qactions{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap;}
.done-card{text-align:center;background:var(--card);border-radius:var(--radius);padding:36px 22px;box-shadow:var(--shadow);}
.done-card .big{font-size:58px;}
.done-card .msg{color:var(--ink-soft);margin:10px 0 22px;font-weight:400;font-size:17px;}

/* ===== 商店 ===== */
.shop-head{background:linear-gradient(120deg,var(--star),#F7C45B);border-radius:var(--radius);padding:20px 22px;color:#4a3500;margin-bottom:16px;}
.shop-head .bal{font-family:var(--serif);font-size:32px;font-weight:900;}
.shop-head .lv{font-size:15px;font-weight:700;opacity:.92;}
.rcard{background:var(--card);border-radius:14px;padding:16px 18px;margin-bottom:12px;box-shadow:var(--shadow);display:flex;align-items:center;gap:14px;}
.rcard .info{flex:1;}
.rcard h4{font-size:18px;color:var(--ink);font-family:var(--serif);}
.rcard small{color:var(--ink-soft);font-weight:400;font-size:13.5px;display:block;}
.rcard .meta{font-size:13px;color:var(--ink-soft);margin-top:4px;font-weight:400;}
.rcard .cost{font-family:var(--serif);font-weight:700;color:var(--star);font-size:18px;white-space:nowrap;}
.rcard .cost s{color:var(--ink-soft);font-size:13px;font-weight:400;}
.rcard.locked{opacity:.55;}
.lockbadge{background:var(--line);color:var(--ink-soft);font-size:13px;padding:6px 13px;border-radius:20px;white-space:nowrap;}

/* ===== 媽媽後台 ===== */
.admin-sec{background:var(--card);border-radius:var(--radius);padding:18px 20px;margin-bottom:16px;box-shadow:var(--shadow);}
.admin-sec h4{font-size:18px;color:var(--green-deep);margin-bottom:12px;font-family:var(--serif);font-weight:700;}
.frow{display:flex;gap:10px;margin-bottom:10px;flex-wrap:wrap;align-items:center;}
.frow label{font-size:14.5px;color:var(--ink-soft);min-width:96px;font-weight:400;}
.frow input,.frow select{flex:1;min-width:100px;border:2px solid var(--line);border-radius:10px;padding:10px 12px;font-family:var(--zh);font-size:15px;}
.frow input:focus,.frow select:focus{outline:none;border-color:var(--green);}
.adm-reward{border:1px solid var(--line);border-radius:12px;padding:13px;margin-bottom:10px;}
.adm-reward .r1{display:flex;justify-content:space-between;align-items:center;gap:8px;}
.adm-reward .rn{font-weight:700;}
.smallbtn{font-size:13.5px;padding:7px 13px;border-radius:20px;border:none;cursor:pointer;font-family:var(--zh);font-weight:700;}
.sb-edit{background:var(--green-soft);color:var(--green-deep);}
.sb-del{background:var(--wrong-soft);color:var(--wrong);}
.sb-give{background:var(--correct);color:#fff;}
.sb-confirm{background:var(--green);color:#fff;}
.redeem-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--line);font-size:15px;gap:8px;}
.tag-given{background:var(--correct-soft);color:#256B45;font-size:12.5px;padding:4px 10px;border-radius:20px;}
.stat-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;}
.stat-cell{background:var(--bg);border-radius:12px;padding:14px;text-align:center;}
.stat-cell .n{font-family:var(--serif);font-size:25px;color:var(--green-deep);font-weight:900;}
.stat-cell .l{font-size:12.5px;color:var(--ink-soft);font-weight:400;}
.pill{display:inline-block;font-size:12px;font-weight:700;padding:3px 10px;border-radius:20px;}
.pill0{background:var(--line);color:var(--ink-soft);}
.pill1{background:var(--star-soft);color:#9A6B12;}
.pill2{background:var(--green-soft);color:var(--green-deep);}
.pill3{background:var(--correct-soft);color:#256B45;}
.dateinput{border:2px solid var(--line);border-radius:10px;padding:9px 12px;font-family:var(--zh);font-size:15px;}

/* ===== 問 AI ===== */
.sop{background:var(--card);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);margin-bottom:16px;}
.sop h4{color:var(--green-deep);font-size:18px;margin-bottom:14px;font-family:var(--serif);font-weight:700;}
.sop-step{display:flex;gap:12px;align-items:flex-start;margin-bottom:12px;font-size:16px;line-height:1.7;font-weight:400;}
.sop-num{flex-shrink:0;width:32px;height:32px;border-radius:50%;background:var(--green);color:#fff;font-family:var(--serif);font-weight:700;display:flex;align-items:center;justify-content:center;}
.quick{display:flex;flex-wrap:wrap;gap:8px;}
.quick-btn{background:var(--star-soft);color:#9A6B12;border:2px solid #F0D89A;border-radius:30px;padding:11px 17px;font-family:var(--zh);font-size:15px;font-weight:700;cursor:pointer;}
.quick-btn:active{transform:scale(.96);}
.copy-toast{display:none;margin-top:12px;background:var(--correct-soft);color:#256B45;border-radius:10px;padding:12px 15px;font-size:15px;font-weight:700;}
.copy-toast.show{display:block;animation:fade .25s;}

/* ===== 撒花 ===== */
#confetti{position:fixed;inset:0;pointer-events:none;z-index:300;overflow:hidden;}
.cft{position:absolute;top:-12px;width:11px;height:11px;border-radius:2px;animation:fall linear forwards;}
@keyframes fall{to{transform:translateY(105vh) rotate(720deg);opacity:.9;}}

@media(max-width:560px){
  body{font-size:18px;}
  .menu{grid-template-columns:1fr;}
  .stat-grid{grid-template-columns:1fr 1fr;}
  .hud .title{font-size:16px;}
}
