:root{
  --bg:#FEF6EC;
  --ink:#2A2440;
  --muted:#7c7590;
  --card:#ffffff;
  --line:#efe7da;
  --coral:#FF7A5A;
  --coral-deep:#ec5a39;
  --teal:#2BB3A3;
  --gold:#FFC24B;
  --gold-deep:#E29A18;
  --track:#efe7da;
  --radius:26px;
  --radius-sm:16px;
  --shadow:0 10px 28px rgba(42,36,64,.09), 0 2px 6px rgba(42,36,64,.05);
  --shadow-sm:0 4px 14px rgba(42,36,64,.08);
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:"Nunito",system-ui,sans-serif;
  background:var(--bg);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  line-height:1.45;
}
h1,h2,h3,.display{font-family:"Fredoka",system-ui,sans-serif;font-weight:600;margin:0;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
input,select,textarea{font-family:inherit;font-size:1rem;}
:focus-visible{outline:3px solid var(--teal);outline-offset:2px;border-radius:8px;}

.wrap{max-width:920px;margin:0 auto;padding:0 18px 96px;}

/* ---------- generic pieces ---------- */
.star-pill{
  display:inline-flex;align-items:center;gap:6px;
  background:linear-gradient(180deg,#FFD97A,var(--gold));
  color:#6a4a06;font-weight:800;
  padding:7px 14px;border-radius:999px;box-shadow:inset 0 -2px 0 rgba(0,0,0,.06);
  font-size:1.02rem;white-space:nowrap;
}
.star-pill .s{filter:drop-shadow(0 1px 0 rgba(0,0,0,.12));}
.chip{display:inline-block;font-size:.74rem;font-weight:800;letter-spacing:.03em;
  text-transform:uppercase;padding:3px 9px;border-radius:999px;background:#f1ecf7;color:#6a5f86;}
.ghost-btn{
  background:var(--card);border:2px solid var(--line);border-radius:999px;
  padding:9px 16px;font-weight:700;color:var(--ink);box-shadow:var(--shadow-sm);
  transition:transform .12s ease;
}
.ghost-btn:active{transform:scale(.96);}
.primary-btn{
  background:var(--coral);color:#fff;border-radius:14px;padding:13px 20px;
  font-weight:800;font-size:1.02rem;box-shadow:0 6px 0 var(--coral-deep);
  transition:transform .1s ease, box-shadow .1s ease;
}
.primary-btn:active{transform:translateY(4px);box-shadow:0 2px 0 var(--coral-deep);}
.primary-btn[disabled]{background:#d8d1c6;box-shadow:0 6px 0 #bcb5aa;cursor:not-allowed;opacity:.75;}

/* ---------- HOME ---------- */
.home-head{
  background:linear-gradient(160deg,#FFE0C2 0%, #FFD1E0 55%, #E7DCFB 100%);
  border-radius:0 0 34px 34px;padding:26px 18px 30px;text-align:center;position:relative;
  box-shadow:var(--shadow-sm);
}
.home-head h1{font-size:2rem;letter-spacing:-.01em;}
.home-head .eyebrow{font-weight:800;color:#b06a4e;text-transform:uppercase;
  letter-spacing:.12em;font-size:.72rem;margin-bottom:4px;}
.verse{margin:12px auto 0;max-width:520px;font-style:italic;color:#5c5470;font-weight:600;font-size:.98rem;}
.grownups{
  position:absolute;top:16px;right:16px;background:rgba(255,255,255,.7);
  border-radius:999px;padding:8px 14px;font-weight:800;font-size:.82rem;color:#6a5f86;
  backdrop-filter:blur(4px);box-shadow:var(--shadow-sm);
}
.kid-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;margin-top:26px;}
.kid-card{
  background:var(--card);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);
  text-align:center;position:relative;overflow:hidden;transition:transform .14s ease;
  border-top:7px solid var(--kc,#4A9DF0);
}
.kid-card:active{transform:translateY(3px) scale(.99);}
.kid-card h2{font-size:1.5rem;margin-top:6px;}
.ring{display:block;margin:2px auto 10px;}
.ring .emoji{font-size:2.1rem;}
.kid-card .done-line{color:var(--muted);font-weight:700;font-size:.92rem;margin-bottom:12px;}
.kid-card .enter{font-weight:800;color:var(--kc,#4A9DF0);}

/* ---------- KID VIEW ---------- */
.kid-head{padding:18px 18px 22px;border-radius:0 0 30px 30px;color:#fff;box-shadow:var(--shadow-sm);}
.kid-head .top{display:flex;align-items:center;justify-content:space-between;gap:10px;}
.back{background:rgba(255,255,255,.25);border-radius:999px;padding:9px 15px;font-weight:800;color:#fff;}
.kid-head .who{display:flex;align-items:center;gap:10px;margin-top:14px;}
.kid-head .who .em{font-size:2.4rem;}
.kid-head .who h1{font-size:1.9rem;color:#fff;}
.kid-head .bal{margin-top:14px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.kid-head .toward{font-weight:700;font-size:.9rem;color:rgba(255,255,255,.92);}

.section{margin-top:26px;}
.section-title{display:flex;align-items:center;gap:9px;margin:0 4px 12px;}
.section-title h2{font-size:1.25rem;}
.section-title .count{color:var(--muted);font-weight:800;font-size:.9rem;}

.card{background:var(--card);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);}
.stack>*+*{margin-top:12px;}

.chore{
  display:flex;align-items:center;gap:14px;padding:15px 16px;background:var(--card);
  border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);cursor:pointer;
  transition:transform .1s ease, background .2s ease;user-select:none;
}
.chore:active{transform:scale(.985);}
.chore .box{
  width:30px;height:30px;border-radius:9px;border:3px solid var(--line);flex:0 0 auto;
  display:grid;place-items:center;transition:all .16s ease;color:#fff;font-weight:900;
}
.chore.done .box{background:var(--teal);border-color:var(--teal);}
.chore.done .title{color:var(--muted);text-decoration:line-through;}
.chore .title{font-weight:700;flex:1;}
.chore .pts{color:var(--gold-deep);font-weight:800;font-size:.9rem;white-space:nowrap;}
.pop{animation:pop .34s ease;}
@keyframes pop{0%{transform:scale(1);}40%{transform:scale(1.05);}100%{transform:scale(1);}}

.panel{background:var(--card);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);padding:16px;}
.reading-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;}
.reading-row input{flex:1;min-width:120px;padding:12px 14px;border:2px solid var(--line);border-radius:12px;background:#fdfbf7;}
.mins-input{max-width:110px;}
.read-log{display:flex;justify-content:space-between;align-items:center;padding:9px 2px;border-top:1px dashed var(--line);font-weight:600;}
.read-log .x{color:var(--muted);font-weight:900;padding:2px 8px;border-radius:8px;}
.today-mins{font-weight:800;color:var(--teal);}

.project{background:var(--card);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);padding:16px;}
.project h3{font-size:1.12rem;}
.project .desc{color:var(--muted);font-weight:600;margin:4px 0 6px;}
.project .due{font-size:.82rem;font-weight:800;color:var(--coral-deep);}
.steps{margin:12px 0 6px;}
.step{display:flex;align-items:center;gap:10px;padding:7px 0;font-weight:600;cursor:pointer;}
.step .sbox{width:22px;height:22px;border-radius:7px;border:3px solid var(--line);display:grid;place-items:center;color:#fff;font-weight:900;font-size:.8rem;}
.step.done .sbox{background:var(--teal);border-color:var(--teal);}
.step.done .stitle{color:var(--muted);text-decoration:line-through;}

.reward-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;}
.reward{background:var(--card);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);padding:16px;text-align:center;display:flex;flex-direction:column;gap:8px;}
.reward .em{font-size:2rem;}
.reward .rt{font-weight:800;font-size:.98rem;line-height:1.2;}
.reward .cost{color:var(--gold-deep);font-weight:800;}
.reward button{margin-top:auto;}
.reward .redeem{background:var(--gold);color:#6a4a06;border-radius:12px;padding:10px;font-weight:800;box-shadow:0 4px 0 var(--gold-deep);transition:transform .1s ease,box-shadow .1s ease;}
.reward .redeem:active{transform:translateY(3px);box-shadow:0 1px 0 var(--gold-deep);}
.reward .locked{background:#efe9df;color:#9a927f;border-radius:12px;padding:10px;font-weight:800;cursor:not-allowed;}

.waiting{margin-top:14px;padding:12px 14px;background:#fff6e6;border:2px dashed var(--gold);border-radius:14px;font-weight:700;color:#8a6a1f;}

.empty{color:var(--muted);font-weight:600;padding:14px 4px;}

/* ---------- CURRICULUM ---------- */
.subject-card{background:var(--card);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);overflow:hidden;}
.subject-header{display:flex;align-items:center;gap:10px;padding:14px 16px;cursor:pointer;user-select:none;transition:background .15s;}
.subject-header:hover{background:#faf6f0;}
.subject-header .subj-emoji{font-size:1.4rem;}
.subject-header .subj-name{font-weight:800;flex:1;}
.subject-header .subj-prog{font-size:.82rem;font-weight:800;color:var(--muted);}
.subject-header .subj-dot{width:10px;height:10px;border-radius:50%;}
.topic-current{padding:0 16px 14px;border-top:1px solid var(--line);}
.topic-current .tc-label{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:4px;padding-top:10px;}
.topic-current .tc-title{font-weight:700;font-size:1.02rem;}
.topic-current .tc-desc{color:var(--muted);font-weight:600;font-size:.9rem;margin-top:2px;}
.topic-check{display:flex;align-items:center;gap:10px;margin-top:8px;cursor:pointer;}
.topic-check .tbox{width:24px;height:24px;border-radius:7px;border:3px solid var(--line);display:grid;place-items:center;color:#fff;font-weight:900;font-size:.75rem;transition:all .16s ease;}
.topic-check.done .tbox{background:var(--teal);border-color:var(--teal);}
.topic-check.done .tc-title{color:var(--muted);text-decoration:line-through;}
.topic-progress-bar{height:6px;background:var(--track);border-radius:99px;margin-top:8px;overflow:hidden;}
.topic-progress-fill{height:100%;border-radius:99px;transition:width .4s ease;}

.writing-card{background:var(--card);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);overflow:hidden;}
.writing-prompt-bar{padding:16px 18px;border-bottom:1px solid var(--line);background:#fdfbf7;}
.writing-prompt-bar .wk-label{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:2px;}
.writing-prompt-bar .wk-type{display:inline-block;font-size:.7rem;font-weight:800;text-transform:uppercase;padding:2px 8px;border-radius:999px;margin-bottom:6px;}
.wk-type.creative{background:#e8f5e9;color:#2e7d32;}
.wk-type.opinion{background:#fff3e0;color:#e65100;}
.wk-type.research{background:#e3f2fd;color:#1565c0;}
.wk-type.narrative{background:#f3e5f5;color:#7b1fa2;}
.writing-prompt-bar .wk-prompt{font-weight:700;font-size:1.02rem;line-height:1.4;}
.writing-doc{position:relative;min-height:320px;padding:0;}
.writing-doc .doc-area{
  width:100%;min-height:320px;padding:22px 24px;border:none;outline:none;resize:vertical;
  font-family:"Nunito",system-ui,sans-serif;font-size:1.05rem;line-height:1.75;
  color:var(--ink);background:transparent;
  background-image:repeating-linear-gradient(transparent,transparent 31px,#e8e2d8 31px,#e8e2d8 32px);
  background-position-y:21px;
}
.writing-doc .doc-area::placeholder{color:#c4bdb0;font-style:italic;}
.writing-doc .doc-area:focus{background-color:#fffef9;}
.writing-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:1px solid var(--line);background:#fdfbf7;}
.writing-footer .word-count{font-size:.82rem;font-weight:700;color:var(--muted);}
.writing-footer .save-status{font-size:.82rem;font-weight:700;color:var(--teal);}
.writing-footer .doc-actions{display:flex;gap:8px;align-items:center;}
.writing-check{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:700;font-size:.9rem;padding:7px 14px;border-radius:10px;background:#f5f0ea;transition:background .15s;}
.writing-check:hover{background:#ede7dc;}
.writing-check.done{background:#d4edda;}
.writing-check .wbox{width:22px;height:22px;border-radius:7px;border:3px solid var(--line);display:grid;place-items:center;color:#fff;font-weight:900;font-size:.75rem;transition:all .16s ease;}
.writing-check.done .wbox{background:var(--teal);border-color:var(--teal);}
.writing-check.done .wlabel{color:#2e7d32;}

.month-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:6px;padding:0 16px 14px;}
.month-pill{padding:5px 8px;border-radius:8px;font-size:.75rem;font-weight:700;text-align:center;background:#f5f0ea;color:var(--muted);}
.month-pill.active{background:var(--ink);color:#fff;}
.month-pill.completed{background:#d4edda;color:#2e7d32;}

/* ---------- ADMIN ---------- */
.admin-head{display:flex;align-items:center;justify-content:space-between;padding:20px 4px 8px;}
.admin-head h1{font-size:1.5rem;}
.tabs{display:flex;gap:8px;overflow-x:auto;padding:10px 0 6px;-webkit-overflow-scrolling:touch;}
.tab{white-space:nowrap;padding:9px 15px;border-radius:999px;font-weight:800;background:var(--card);box-shadow:var(--shadow-sm);color:var(--muted);}
.tab.active{background:var(--ink);color:#fff;}
.badge{display:inline-block;min-width:20px;padding:0 6px;border-radius:999px;background:var(--coral);color:#fff;font-size:.72rem;font-weight:800;margin-left:6px;}

.arow{display:flex;align-items:center;gap:12px;padding:13px 15px;background:var(--card);border-radius:14px;box-shadow:var(--shadow-sm);}
.arow .grow{flex:1;min-width:0;}
.arow .name{font-weight:800;}
.arow .sub{color:var(--muted);font-weight:600;font-size:.86rem;}
.arow .mini{padding:7px 11px;border-radius:10px;background:#f2ecf7;font-weight:800;font-size:.84rem;color:#5a5175;}
.arow .mini.danger{background:#fdeaea;color:#c0392b;}
.dot{width:14px;height:14px;border-radius:50%;flex:0 0 auto;}

.add-btn{width:100%;padding:14px;border-radius:14px;border:2px dashed var(--line);background:#fff;font-weight:800;color:var(--muted);margin-top:12px;}

.field{margin-bottom:12px;}
.field label{display:block;font-weight:800;font-size:.86rem;margin-bottom:5px;color:#5a5175;}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:2px solid var(--line);border-radius:12px;background:#fdfbf7;}
.field textarea{min-height:84px;resize:vertical;}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.help{color:var(--muted);font-size:.82rem;font-weight:600;margin-top:4px;}

/* PIN gate */
.pin-wrap{max-width:360px;margin:14vh auto 0;text-align:center;padding:0 20px;}
.pin-wrap .lock{font-size:2.6rem;}
.pin-wrap h1{font-size:1.5rem;margin:8px 0 4px;}
.pin-wrap p{color:var(--muted);font-weight:600;margin:0 0 18px;}
.pin-input{width:100%;text-align:center;font-size:1.6rem;letter-spacing:.4em;padding:14px;border:2px solid var(--line);border-radius:16px;background:#fff;font-weight:800;}
.pin-err{color:var(--coral-deep);font-weight:800;margin-top:10px;min-height:20px;}

/* modal */
.overlay{position:fixed;inset:0;background:rgba(42,36,64,.44);display:grid;place-items:end center;z-index:40;padding:0;animation:fade .18s ease;}
@keyframes fade{from{opacity:0;}to{opacity:1;}}
.sheet{background:var(--bg);width:100%;max-width:560px;border-radius:26px 26px 0 0;padding:22px 20px calc(22px + env(safe-area-inset-bottom));box-shadow:0 -10px 40px rgba(0,0,0,.2);max-height:90vh;overflow-y:auto;animation:rise .24s cubic-bezier(.2,.8,.2,1);}
@keyframes rise{from{transform:translateY(40px);}to{transform:translateY(0);}}
.sheet h2{font-size:1.3rem;margin-bottom:16px;}
.sheet-actions{display:flex;gap:10px;margin-top:18px;}
.sheet-actions .primary-btn{flex:1;}
.sheet-actions .cancel{flex:0 0 auto;padding:13px 18px;border-radius:14px;font-weight:800;color:var(--muted);background:var(--card);box-shadow:var(--shadow-sm);}

/* toast + confetti */
#fx{position:fixed;inset:0;pointer-events:none;z-index:60;overflow:hidden;}
.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%);background:var(--ink);color:#fff;font-weight:800;padding:12px 20px;border-radius:999px;box-shadow:var(--shadow);animation:toastin .3s ease;z-index:70;}
@keyframes toastin{from{opacity:0;transform:translate(-50%,14px);}to{opacity:1;transform:translate(-50%,0);}}
.confetti{position:absolute;top:-14px;width:11px;height:11px;border-radius:3px;animation:fall linear forwards;}
@keyframes fall{to{transform:translateY(105vh) rotate(600deg);opacity:.9;}}

@media (max-width:520px){
  .home-head h1{font-size:1.7rem;}
  .kid-head .who h1{font-size:1.6rem;}
  .row2{grid-template-columns:1fr;}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;transition-duration:.001ms !important;}
}
