/* ── Chore Goblin — style.css (combined) ──────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}

/* ── Light theme (default) ───────────────────────────────────────── */
:root{
  --brand:#5FAB2F;--brand-l:#ECF6E0;--brand-d:#2C5E0A;
  --green:#3B6D11;--green-l:#EAF3DE;--green-d:#173404;
  --amber:#EF9F27;--amber-l:#FAEEDA;--amber-d:#633806;
  --blue:#378ADD;--blue-l:#E6F1FB;--blue-d:#0C447C;
  --pink:#D4537E;--pink-l:#FBEAF0;--pink-d:#72243E;
  --coral:#D85A30;--coral-l:#FAECE7;--coral-d:#712B13;
  --teal:#1D9E75;--teal-l:#E1F5EE;--teal-d:#085041;
  --red:#E24B4A;--red-d:#501313;
  --kid-blue:linear-gradient(135deg,#378ADD,#0C447C);
  --kid-pink:linear-gradient(135deg,#D4537E,#72243E);
  --kid-purple:linear-gradient(135deg,#7F77DD,#3C3489);
  --kid-green:linear-gradient(135deg,#639922,#3B6D11);
  --kid-amber:linear-gradient(135deg,#EF9F27,#633806);
  --kid-coral:linear-gradient(135deg,#D85A30,#712B13);
  --kid-teal:linear-gradient(135deg,#1D9E75,#085041);
  --kid-red:linear-gradient(135deg,#E24B4A,#501313);
  --bg:#f0eeff;--bg-card:#fff;--bg-page:#f7f7fb;--bg-input:#fff;
  --bg-chip:rgba(255,255,255,0.2);--bg-nav:#fff;--bg-overlay:rgba(26,26,46,0.5);
  --bg-kid-header-bubble:rgba(255,255,255,0.1);--bg-stat-chip:rgba(255,255,255,0.2);
  --bg-settings-row:#fff;--bg-settings-row-active:#f7f7fb;--bg-toggle:#ddd;
  --bg-empty:#f0eeff;--bg-p-page:#f7f7fb;
  --bg-header-start:#5FAB2F;--bg-header-end:#2C5E0A;
  --header-gradient:linear-gradient(135deg,#5FAB2F,#2C5E0A);
  --auth-bg:linear-gradient(160deg,#ECF6E0,#F4FBE9);
  --text-primary:#1a1a2e;--text-secondary:#555;--text-muted:#aaa;--text-faint:#ccc;
  --text-white:#fff;--text-header:#fff;
  --border:#eee;--border-input:#e0e0e0;--border-nav:#e8e0ff;--border-row:#f5f5f5;--border-settings:#f5f5f5;
  --shadow-card:none;--shadow-toast:none;
  --shadow-elevated:0 8px 40px rgba(95,171,47,0.18);
  --shadow-pin:0 2px 8px rgba(95,171,47,0.14);
  --shadow-float:0 2px 8px rgba(0,0,0,0.10);
  --font-display:'Fredoka One',cursive;--font-body:'Nunito',sans-serif;
}

/* ── Dark theme ───────────────────────────────────────────────────── */
[data-theme="dark"]{
  --bg:#0f1014;--bg-card:#1c1d22;--bg-page:#0f1014;--bg-input:#262830;
  --bg-chip:rgba(255,255,255,0.15);--bg-nav:#1c1d22;--bg-overlay:rgba(0,0,0,0.7);
  --bg-kid-header-bubble:rgba(255,255,255,0.07);--bg-stat-chip:rgba(255,255,255,0.15);
  --bg-settings-row:#1c1d22;--bg-settings-row-active:#262830;--bg-toggle:#3a3c44;
  --bg-empty:#1c1d22;--bg-p-page:#0f1014;
  --bg-header-start:#2C5E0A;--bg-header-end:#1a3d05;
  --header-gradient:linear-gradient(135deg,#2C5E0A,#1a3d05);
  --text-primary:#e8e9ee;--text-secondary:#a8aab2;--text-muted:#6e7079;--text-faint:#4a4c54;
  --text-white:#fff;--text-header:#fff;
  --border:#2a2c34;--border-input:#3a3c44;--border-nav:#2a2c34;--border-row:#26282f;--border-settings:#26282f;
  --brand-l:#1c2c10;--green-l:#152610;--amber-l:#2a200c;--blue-l:#0f1c2e;
  --pink-l:#2a1018;--coral-l:#2a1308;--teal-l:#0f261d;
}

/* ── Base ─────────────────────────────────────────────────────────── */
html,body{height:100%;font-family:'Nunito',sans-serif;background:var(--bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;-webkit-overflow-scrolling:touch;overscroll-behavior:none;overflow-x:hidden;transition:background 0.3s,color 0.3s}

/* ── App Shell ────────────────────────────────────────────────────── */
.app{display:-webkit-flex;display:flex;-webkit-flex-direction:column;flex-direction:column;height:100vh;max-width:800px;margin:0 auto;position:relative}
.screen{display:none;-webkit-flex-direction:column;flex-direction:column;-webkit-flex:1;flex:1}
.screen.active{display:-webkit-flex;display:flex}
.scroll-area{-webkit-flex:1;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:16px;padding-bottom:90px}

/* ── Nav Bar ──────────────────────────────────────────────────────── */
.nav-bar{position:fixed;bottom:0;left:0;width:100%;background:var(--bg-nav);border-top:1px solid var(--border-nav);display:-webkit-flex;display:flex;z-index:100;padding:6px 0 0;transition:background 0.3s,border-color 0.3s}
.nav-btn{-webkit-flex:1;flex:1;display:-webkit-flex;display:flex;-webkit-flex-direction:column;flex-direction:column;-webkit-align-items:center;align-items:center;padding:6px 0;border:none;background:none;cursor:pointer;font-family:'Nunito',sans-serif;color:var(--text-faint);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:0.5px;-webkit-transition:color 0.2s;transition:color 0.2s}
.nav-icon{font-size:22px;line-height:1;margin-bottom:2px}
.nav-btn.active-parent{color:var(--brand)}
.nav-btn.active-parent .nav-icon::after{content:'';display:block;width:6px;height:6px;border-radius:50%;background:var(--brand);margin:3px auto 0}
.nav-btn.kid-active{color:var(--kid-tab-color,var(--brand))}
.nav-btn.kid-active .nav-icon::after{
  content:'';display:block;width:6px;height:6px;border-radius:50%;
  background:var(--kid-tab-color,var(--brand));
  margin:3px auto 0;
}

/* ── Kid Header ───────────────────────────────────────────────────── */
.kid-header{padding:22px 18px 16px;color:#fff;position:relative;overflow:hidden;width:100vw;margin-left:calc(50% - 50vw)}
.kid-header::before{content:'';position:absolute;top:-30px;right:-30px;width:140px;height:140px;border-radius:50%;background:var(--bg-kid-header-bubble)}
.kid-header::after{content:'';position:absolute;bottom:-20px;left:20px;width:90px;height:90px;border-radius:50%;background:var(--bg-kid-header-bubble)}
.header-top{display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;gap:12px;position:relative;z-index:1;margin-bottom:14px}
.avatar{width:56px;height:56px;border-radius:50%;background:rgba(255,255,255,0.2);display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;-webkit-justify-content:center;justify-content:center;font-size:28px;-webkit-flex-shrink:0;flex-shrink:0}
.kid-name{font-family:'Fredoka One',cursive;font-size:26px;line-height:1}
.kid-sub{font-size:13px;opacity:0.85;margin-top:2px}
.stat-row{display:-webkit-flex;display:flex;gap:8px;position:relative;z-index:1;margin-bottom:12px;flex-wrap:wrap}
.stat-chip{background:var(--bg-stat-chip);border-radius:20px;padding:5px 12px;font-size:13px;font-weight:700;color:#fff;white-space:nowrap}
.prog-label{display:-webkit-flex;display:flex;-webkit-justify-content:space-between;justify-content:space-between;font-size:12px;font-weight:700;opacity:0.85;margin-bottom:6px;position:relative;z-index:1}
.prog-bg{background:rgba(255,255,255,0.2);border-radius:6px;height:6px;position:relative;z-index:1}
.prog-fill{background:#fff;border-radius:6px;height:100%;-webkit-transition:width 0.4s ease;transition:width 0.4s ease}

/* ── Chore Cards ──────────────────────────────────────────────────── */
.sec{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin:16px 0 8px;padding:0 2px;display:flex;justify-content:space-between;align-items:center}
.chore-card{background:var(--bg-card);border-radius:16px;border:1px solid var(--border);padding:14px 16px;margin-bottom:10px;display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;gap:12px;-webkit-transition:all 0.2s;transition:all 0.2s;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;touch-callout:none;cursor:pointer}
.chore-card:active{-webkit-transform:scale(0.97);transform:scale(0.97);opacity:0.75}
.chore-card.done{background:var(--green-l);border-color:#9FE1CB}
.chore-ico{font-size:28px;-webkit-flex-shrink:0;flex-shrink:0;-webkit-transition:-webkit-transform 0.3s;transition:transform 0.3s}
.chore-body{-webkit-flex:1;flex:1;min-width:0}
.chore-name{font-size:15px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chore-meta{font-size:12px;color:var(--text-muted);margin-top:3px}
.chore-pts{font-size:16px;font-weight:800;color:var(--text-muted);-webkit-flex-shrink:0;flex-shrink:0}
.chore-pts.earned{color:var(--green)}
.status-tag{font-size:11px;font-weight:700;padding:3px 9px;border-radius:10px;-webkit-flex-shrink:0;flex-shrink:0;margin-left:6px}
.tag-pending{background:var(--amber-l);color:var(--amber-d)}
.tag-approved{background:var(--green-l);color:var(--green-d)}
.tag-skip{background:var(--brand-l);color:var(--brand-d)}
.tag-rejected{background:var(--coral-l);color:var(--coral-d)}
.undo-btn{padding:4px 10px;border-radius:14px;border:1.5px solid var(--border-input);font-family:'Nunito',sans-serif;font-size:11px;font-weight:700;cursor:pointer;background:var(--bg-card);color:var(--text-muted);margin-left:6px;-webkit-flex-shrink:0;flex-shrink:0}

/* ── Step modal ───────────────────────────────────────────────────── */
.step-modal-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg-overlay);z-index:200;-webkit-align-items:flex-end;align-items:flex-end;-webkit-justify-content:center;justify-content:center}
.step-modal-overlay.open{display:-webkit-flex;display:flex}
.step-modal{background:var(--bg-card);border-radius:24px 24px 0 0;width:100%;max-width:800px;padding:20px;max-height:85vh;overflow-y:auto}
.step-modal-title{font-family:'Fredoka One',cursive;font-size:22px;color:var(--brand-d);margin-bottom:16px}
.step-item{display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border-row)}
.step-item:last-child{border-bottom:none}
.step-check{width:28px;height:28px;border-radius:50%;border:2.5px solid var(--border-input);display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;-webkit-justify-content:center;justify-content:center;cursor:pointer;-webkit-flex-shrink:0;flex-shrink:0;-webkit-transition:all 0.2s;transition:all 0.2s}
.step-check.done{background:var(--green);border-color:var(--green)}
.step-label{-webkit-flex:1;flex:1;font-size:15px;color:var(--text-primary)}
.step-label.done{text-decoration:line-through;color:var(--text-muted)}
.step-icon-lbl{font-size:20px}

/* ── Completion animation ─────────────────────────────────────────── */
@-webkit-keyframes choreComplete{0%{-webkit-transform:scale(1);background:var(--bg-card)}30%{-webkit-transform:scale(1.04);background:var(--green-l)}60%{-webkit-transform:scale(0.98)}100%{-webkit-transform:scale(1);background:var(--green-l)}}
@keyframes choreComplete{0%{transform:scale(1);background:var(--bg-card)}30%{transform:scale(1.04);background:var(--green-l)}60%{transform:scale(0.98)}100%{transform:scale(1);background:var(--green-l)}}
.chore-card.completing{-webkit-animation:choreComplete 0.5s ease forwards;animation:choreComplete 0.5s ease forwards;border-color:#9FE1CB;pointer-events:none}
@-webkit-keyframes checkPop{0%{-webkit-transform:scale(0);opacity:0}60%{-webkit-transform:scale(1.3);opacity:1}100%{-webkit-transform:scale(1);opacity:1}}
@keyframes checkPop{0%{transform:scale(0);opacity:0}60%{transform:scale(1.3);opacity:1}100%{transform:scale(1);opacity:1}}
.chore-card.completing .chore-ico{-webkit-animation:checkPop 0.4s ease 0.1s forwards;animation:checkPop 0.4s ease 0.1s forwards}

/* ── Long press ───────────────────────────────────────────────────── */
.chore-card.long-pressing{-webkit-transform:scale(0.97);transform:scale(0.97);opacity:0.75}

/* ── Allowance card ───────────────────────────────────────────────── */
.allowance-card{background:var(--bg-card);border-radius:16px;border:1px solid var(--border);padding:16px;margin-bottom:10px}
.al-header{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:12px}
.al-row{display:-webkit-flex;display:flex;-webkit-justify-content:space-between;justify-content:space-between;-webkit-align-items:center;align-items:center;padding:8px 0;border-bottom:1px solid var(--border-row)}
.al-row:last-child{border-bottom:none}
.al-label{font-size:14px;color:var(--text-secondary)}
.al-val{font-size:14px;font-weight:700;color:var(--text-primary)}
.al-total{font-size:16px;color:var(--green)}

/* ── Streaks ──────────────────────────────────────────────────────── */
.streak-milestones{display:-webkit-flex;display:flex;gap:10px;margin-bottom:12px}
.streak-mile{background:var(--bg-card);border-radius:12px;border:1px solid var(--border);padding:12px;-webkit-flex:1;flex:1;text-align:center}
.streak-mile-icon{font-size:22px;display:block;margin-bottom:4px}
.streak-mile-label{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--text-muted);display:block}
.streak-mile-pts{font-size:13px;font-weight:800;color:var(--brand);display:block;margin-top:2px}

/* ── Badges ───────────────────────────────────────────────────────── */
.badges-grid{display:-webkit-flex;display:flex;-webkit-flex-wrap:wrap;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.badge-item{background:var(--bg-card);border-radius:12px;border:1px solid var(--border);padding:10px 12px;display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;gap:8px;opacity:0.4;-webkit-transition:opacity 0.3s;transition:opacity 0.3s}
.badge-item.earned{opacity:1;border-color:var(--amber);background:var(--amber-l)}
.badge-icon{font-size:20px}
.badge-name{font-size:12px;font-weight:700;color:var(--text-primary)}

/* ── Rewards ──────────────────────────────────────────────────────── */
.collapsible-header{cursor:pointer;display:-webkit-flex;display:flex;-webkit-justify-content:space-between;justify-content:space-between;-webkit-align-items:center;align-items:center}
.collapsible-arrow{font-size:12px;color:var(--text-muted);-webkit-transition:-webkit-transform 0.2s;transition:transform 0.2s}
.collapsible-body{overflow:hidden;-webkit-transition:max-height 0.3s ease;transition:max-height 0.3s ease;max-height:0}
.collapsible-body.open{max-height:2000px}
.rewards-pts-display{font-size:13px;color:var(--text-muted);margin-bottom:10px;font-weight:700}
.rewards-grid{display:-webkit-flex;display:flex;-webkit-flex-direction:column;flex-direction:column;gap:8px}
.reward-card{background:var(--bg-card);border-radius:14px;border:1px solid var(--border);padding:12px 14px;display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;gap:12px}
.reward-icon{font-size:24px;-webkit-flex-shrink:0;flex-shrink:0}
.reward-body{-webkit-flex:1;flex:1}
.reward-name{font-size:15px;font-weight:700;color:var(--text-primary)}
.reward-cost{font-size:12px;color:var(--text-muted);margin-top:2px}
.redeem-btn{padding:7px 14px;border-radius:20px;border:none;font-family:'Nunito',sans-serif;font-size:12px;font-weight:700;cursor:pointer;background:var(--brand);color:#fff;-webkit-flex-shrink:0;flex-shrink:0}
.redeem-btn:disabled{background:var(--border);color:var(--text-muted)}

/* ── PIN Screen ───────────────────────────────────────────────────── */
.pin-screen{display:-webkit-flex;display:flex;-webkit-flex-direction:column;flex-direction:column;-webkit-align-items:center;align-items:center;-webkit-justify-content:center;justify-content:center;padding:40px 20px;-webkit-flex:1;flex:1}
.pin-title{font-family:'Fredoka One',cursive;font-size:28px;color:var(--brand-d);margin-bottom:6px}
.pin-sub{font-size:14px;color:var(--text-muted);margin-bottom:28px}
.pin-dots{display:-webkit-flex;display:flex;gap:14px;margin-bottom:28px}
.pin-dot{width:16px;height:16px;border-radius:50%;border:2.5px solid var(--border-input);-webkit-transition:all 0.2s;transition:all 0.2s}
.pin-dot.filled{background:var(--brand);border-color:var(--brand)}
.pin-pad{display:-webkit-flex;display:flex;-webkit-flex-direction:column;flex-direction:column;gap:4px}
.pin-row{display:-webkit-flex;display:flex;gap:4px}
.pin-key{width:70px;height:70px;border-radius:50%;border:2px solid var(--border-input);background:var(--bg-card);font-family:'Fredoka One',cursive;font-size:22px;color:var(--brand-d);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.15s;box-shadow:var(--shadow-pin);margin:6px;touch-action:manipulation;-webkit-user-select:none;user-select:none}
.pin-key:active{-webkit-transform:scale(0.91);transform:scale(0.91);background:var(--brand-l)}
.pin-blank{border-color:transparent;background:none;box-shadow:none;cursor:default}
.pin-del{font-size:18px}
.pin-error{color:var(--coral);font-size:14px;font-weight:700;margin-top:12px;min-height:20px}

/* ── Parent section in kid app ────────────────────────────────────── */
.parent-dash-hidden{display:none}
.parent-header{background:var(--header-gradient);padding:16px;position:sticky;top:0;z-index:10}
.parent-header-row{display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;-webkit-justify-content:space-between;justify-content:space-between;max-width:800px;margin:0 auto}
.parent-title{font-family:'Fredoka One',cursive;font-size:24px;color:#fff}
.parent-sub{font-size:12px;color:rgba(255,255,255,0.7);margin-top:2px}
.lock-btn{background:rgba(255,255,255,0.2);border:none;color:#fff;border-radius:20px;padding:6px 16px;font-family:'Nunito',sans-serif;font-size:13px;font-weight:700;cursor:pointer}
.panel{background:var(--bg-card);border-radius:16px;border:1px solid var(--border);padding:14px 16px;margin-bottom:12px}
.panel-title{font-size:13px;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.8px;margin-bottom:12px}
.panel-note{font-size:12px;color:var(--text-muted);margin-bottom:10px;line-height:1.5}
.stats-grid{display:-webkit-flex;display:flex;gap:10px;margin-bottom:12px;-webkit-flex-wrap:wrap;flex-wrap:wrap}
.kid-stat-card{background:var(--bg-card);border-radius:14px;border:1px solid var(--border);padding:12px;-webkit-flex:1;flex:1;min-width:120px}
.approval-row{display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border-row)}
.approval-row:last-child{border-bottom:none}
.approval-info{-webkit-flex:1;flex:1}
.approval-name{font-size:14px;font-weight:700;color:var(--text-primary)}
.approval-meta{font-size:12px;color:var(--text-muted);margin-top:2px}
.approval-actions{display:-webkit-flex;display:flex;gap:6px;-webkit-flex-shrink:0;flex-shrink:0}
.empty{text-align:center;padding:20px;color:var(--text-muted);font-size:13px}
.empty-icon{font-size:32px;margin-bottom:6px}
.add-form{display:-webkit-flex;display:flex;-webkit-flex-direction:column;flex-direction:column;gap:10px}
.form-row{display:-webkit-flex;display:flex;gap:8px;-webkit-align-items:center;align-items:center}
.form-row-mb{margin-bottom:8px}
.inp{padding:10px 12px;border-radius:10px;border:1.5px solid var(--border-input);font-family:'Nunito',sans-serif;font-size:14px;background:var(--bg-input);color:var(--text-primary);outline:none;-webkit-transition:border-color 0.2s;transition:border-color 0.2s}
.inp:focus{border-color:var(--brand)}
.inp-icon{width:44px;text-align:center;font-size:20px;padding:10px 4px;-webkit-flex-shrink:0;flex-shrink:0}
.inp-sm{width:70px;-webkit-flex-shrink:0;flex-shrink:0}
.sel{padding:10px 12px;border-radius:10px;border:1.5px solid var(--border-input);font-family:'Nunito',sans-serif;font-size:14px;background:var(--bg-input);color:var(--text-primary);outline:none}
.btn{padding:11px 18px;border-radius:10px;border:none;font-family:'Nunito',sans-serif;font-size:14px;font-weight:700;cursor:pointer;-webkit-transition:opacity 0.2s;transition:opacity 0.2s}
.btn:active{opacity:0.8}
.btn-purple{background:var(--brand);color:#fff}
.btn-full{width:100%;display:block;text-align:center;padding:12px}
.btn-danger{background:#F09595;color:#501313}
.setting-label{font-size:14px;font-weight:700;color:var(--text-secondary);white-space:nowrap}
.danger-zone{background:var(--bg-card);border-radius:16px;border:1.5px solid var(--coral-l);padding:16px;margin-bottom:12px}
.danger-title{font-size:12px;font-weight:800;text-transform:uppercase;color:var(--coral-d);margin-bottom:8px}
.danger-desc{font-size:12px;color:var(--text-muted);margin-bottom:12px}
.clear-options{display:-webkit-flex;display:flex;-webkit-flex-direction:column;flex-direction:column;gap:8px;margin-bottom:12px}
.clear-opt{display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;gap:8px;font-size:14px;color:var(--text-secondary);cursor:pointer}
.ntfy-channel{background:var(--brand-l);color:var(--brand-d);font-family:monospace;font-size:15px;font-weight:700;padding:10px 14px;border-radius:10px;margin:8px 0;text-align:center;letter-spacing:0.5px;-webkit-user-select:all;user-select:all}
.ntfy-step{display:-webkit-flex;display:flex;-webkit-align-items:flex-start;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid var(--border-row);font-size:14px;color:var(--text-secondary)}
.ntfy-step:last-of-type{border-bottom:none}
.ntfy-num{width:26px;height:26px;border-radius:50%;background:var(--brand);color:#fff;font-size:12px;font-weight:800;display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;-webkit-justify-content:center;justify-content:center;flex-shrink:0;margin-top:1px}
.al-summary{display:-webkit-flex;display:flex;gap:10px;margin-bottom:12px}
.al-card{border-radius:14px;padding:14px;-webkit-flex:1;flex:1}
.al-card-name{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:0.8px;margin-bottom:4px;color:var(--brand-d)}
.al-card-amt{font-family:'Fredoka One',cursive;font-size:26px;color:var(--brand-d)}
.al-card-sub{font-size:11px;color:var(--text-muted);margin-top:2px}
.spacer{height:40px}
.loader{display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;gap:8px;color:var(--text-muted);font-size:13px;padding:16px}
.spinner{width:18px;height:18px;border:2.5px solid var(--border);border-top-color:var(--brand);border-radius:50%;-webkit-animation:spin 0.7s linear infinite;animation:spin 0.7s linear infinite}
@-webkit-keyframes spin{to{-webkit-transform:rotate(360deg)}}
@keyframes spin{to{transform:rotate(360deg)}}
.rewards-manage-list{display:-webkit-flex;display:flex;-webkit-flex-direction:column;flex-direction:column;gap:8px}
.reward-manage-row{display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border-row);font-size:14px}
.reward-manage-row:last-child{border-bottom:none}
.cel-title{font-family:'Fredoka One',cursive;font-size:22px;color:var(--brand-d)}

/* ── Toast ────────────────────────────────────────────────────────── */
.toast,.p-toast{position:fixed;top:20px;left:50%;-webkit-transform:translateX(-50%) translateY(-200px);transform:translateX(-50%) translateY(-200px);background:#1a1a2e;color:#fff;font-family:'Fredoka One',cursive;font-size:16px;padding:12px 24px;border-radius:30px;z-index:999;-webkit-transition:-webkit-transform 0.3s ease;transition:transform 0.3s ease;pointer-events:none;max-width:88vw;text-align:center}
.toast.show,.p-toast.show{-webkit-transform:translateX(-50%) translateY(0);transform:translateX(-50%) translateY(0)}

/* ── Parent Dashboard ─────────────────────────────────────────────── */
.views-wrap{position:relative;overflow:hidden;width:100%;height:100vh;display:flex;flex-direction:column}
.view{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;background:var(--bg-page);transform:translateX(100%);transition:transform 0.3s cubic-bezier(0.4,0,0.2,1);will-change:transform;overflow-y:auto;-webkit-overflow-scrolling:touch}
.view.active{transform:translateX(0)}
.view.slide-out{transform:translateX(-30%)}
#view-main{transform:translateX(0)}
#view-main.slide-out{transform:translateX(-30%)}
.view-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:72px}

/* ── Parent header ────────────────────────────────────────────────── */
.p-header{background:var(--header-gradient);padding:16px;position:sticky;top:0;z-index:100}
.p-header-row{display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;-webkit-justify-content:space-between;justify-content:space-between;max-width:800px;margin:0 auto}
.p-header-left{display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;gap:10px}
.p-back{background:rgba(255,255,255,0.2);border:none;color:#fff;border-radius:10px;padding:8px 12px;font-size:16px;cursor:pointer;font-family:'Nunito',sans-serif;font-weight:700}
.p-title{font-family:'Fredoka One',cursive;font-size:22px;color:#fff}
.p-subtitle{font-size:12px;color:rgba(255,255,255,0.7);margin-top:2px}
.p-header-actions{display:-webkit-flex;display:flex;gap:8px}
.p-icon-btn{background:rgba(255,255,255,0.2);border:none;color:#fff;border-radius:10px;width:38px;height:38px;font-size:18px;cursor:pointer;display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;-webkit-justify-content:center;justify-content:center}
.p-header-goblin{width:44px;height:44px;object-fit:contain}
.p-page{max-width:800px;margin:0 auto;padding:16px;padding-bottom:0}

/* ── Nav clearance for parent dashboard ───────────────────────────── */
#parent-dashboard-wrap .p-page{padding-bottom:80px}

/* ── Cards ────────────────────────────────────────────────────────── */
.p-card{background:var(--bg-card);border-radius:16px;border:1px solid var(--border);margin-bottom:12px;overflow:hidden}
.p-card-header{padding:14px 16px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);border-bottom:1px solid var(--border-row);position:relative}
.p-card-header .badge-num{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:var(--amber);color:#fff;border-radius:10px;padding:2px 8px;font-size:11px;letter-spacing:0}
.p-stats{display:-webkit-flex;display:flex;gap:10px;margin-bottom:12px}
.p-stat{background:var(--bg-card);border-radius:16px;border:1px solid var(--border);padding:16px;-webkit-flex:1;flex:1;text-align:center}
.p-stat-val{font-family:'Fredoka One',cursive;font-size:32px;color:var(--brand-d)}
.p-stat-lbl{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.7px;color:var(--text-faint);margin-top:4px}
.p-stat-sub{font-size:12px;color:var(--text-muted);margin-top:4px}
.p-stat-name{font-size:13px;font-weight:700;margin-top:4px;color:var(--text-primary)}

/* ── List rows ────────────────────────────────────────────────────── */
.p-row{display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;padding:13px 16px;border-bottom:1px solid var(--border-row);gap:10px}
.p-row:last-child{border-bottom:none}
.p-row-icon{font-size:20px;width:36px;text-align:center;-webkit-flex-shrink:0;flex-shrink:0}
.p-row-body{-webkit-flex:1;flex:1}
.p-row-title{font-size:15px;font-weight:700;color:var(--text-primary)}
.p-row-sub{font-size:12px;color:var(--text-muted);margin-top:2px}
.p-row-right{font-size:14px;color:var(--text-faint)}
.p-row-badge{font-size:11px;font-weight:700;padding:3px 10px;border-radius:10px}
.badge-pending{background:var(--amber-l);color:var(--amber-d)}
.badge-approved{background:var(--green-l);color:var(--green-d)}
.badge-skip{background:var(--brand-l);color:var(--brand-d)}

/* ── Buttons ──────────────────────────────────────────────────────── */
.p-btn{padding:11px 18px;border-radius:10px;border:none;font-family:'Nunito',sans-serif;font-size:14px;font-weight:700;cursor:pointer;-webkit-transition:opacity 0.2s;transition:opacity 0.2s}
.p-btn:active{opacity:0.8}
.p-btn-approve{background:var(--green);color:#fff}
.p-btn-reject{background:var(--bg-card);color:var(--text-muted);border:1.5px solid var(--border-input)}
.p-btn-purple{background:var(--brand);color:#fff}
.p-btn-danger{background:#F09595;color:#501313}
.p-btn-full{width:100%;display:block;padding:13px;margin-top:8px;text-align:center}
.p-btn-outline{background:var(--bg-card);color:var(--brand);border:1.5px solid var(--brand)}

/* ── Settings ─────────────────────────────────────────────────────── */
.settings-group{margin-bottom:24px}
.settings-group-label{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;padding:0 4px;margin-bottom:8px}
.settings-list{background:var(--bg-settings-row);border-radius:16px;border:1px solid var(--border);overflow:hidden}
.settings-row{display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;padding:14px 16px;border-bottom:1px solid var(--border-settings);cursor:pointer;-webkit-transition:background 0.15s;transition:background 0.15s;text-decoration:none;color:inherit}
.settings-row:last-child{border-bottom:none}
.settings-row:active{background:var(--bg-settings-row-active)}
.settings-row-icon{width:34px;height:34px;border-radius:8px;display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;-webkit-justify-content:center;justify-content:center;font-size:18px;margin-right:12px;-webkit-flex-shrink:0;flex-shrink:0}
.settings-row-body{-webkit-flex:1;flex:1}
.settings-row-title{font-size:15px;font-weight:700;color:var(--text-primary)}
.settings-row-title.danger{color:var(--coral-d)}
.settings-row-sub{font-size:12px;color:var(--text-muted);margin-top:2px}
.settings-chevron{color:var(--text-faint);font-size:14px}

/* ── Forms ────────────────────────────────────────────────────────── */
.p-form-group{margin-bottom:14px}
.p-label{font-size:13px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.8px;margin-bottom:6px;display:block}
.p-inp{padding:12px 16px;border-radius:12px;border:1.5px solid var(--border-input);font-family:'Nunito',sans-serif;font-size:15px;outline:none;-webkit-transition:border-color 0.2s;transition:border-color 0.2s;width:100%;background:var(--bg-input);color:var(--text-primary)}
.p-inp:focus{border-color:var(--brand)}
.p-inp-row{display:-webkit-flex;display:flex;gap:10px}
.p-inp-icon{width:56px;text-align:center;font-size:20px;padding:12px 6px;flex-shrink:0}
.p-note{font-size:12px;color:var(--text-muted);margin-top:6px;line-height:1.5}

/* ── Color swatches ───────────────────────────────────────────────── */
.color-picker{display:-webkit-flex;display:flex;-webkit-flex-wrap:wrap;flex-wrap:wrap;gap:8px;margin-top:6px}
.color-swatch{width:32px;height:32px;border-radius:50%;cursor:pointer;border:3px solid transparent;-webkit-transition:all 0.2s;transition:all 0.2s}
.color-swatch.selected{border-color:var(--text-primary);-webkit-transform:scale(1.15);transform:scale(1.15)}
.swatch-blue{background:#378ADD}.swatch-pink{background:#D4537E}
.swatch-purple{background:#7F77DD}.swatch-green{background:#639922}
.swatch-amber{background:#EF9F27}.swatch-coral{background:#D85A30}
.swatch-teal{background:#1D9E75}.swatch-red{background:#E24B4A}

/* ── Toggle ───────────────────────────────────────────────────────── */
.p-toggle{position:relative;width:48px;height:28px;flex-shrink:0}
.p-toggle input{opacity:0;width:0;height:0}
.p-toggle-slider{position:absolute;top:0;left:0;right:0;bottom:0;background:var(--bg-toggle);border-radius:14px;-webkit-transition:0.3s;transition:0.3s;cursor:pointer}
.p-toggle input:checked + .p-toggle-slider{background:var(--brand)}
.p-toggle-slider:before{content:'';position:absolute;height:22px;width:22px;left:3px;bottom:3px;background:#fff;border-radius:50%;-webkit-transition:0.3s;transition:0.3s}
.p-toggle input:checked + .p-toggle-slider:before{-webkit-transform:translateX(20px);transform:translateX(20px)}

/* ── Overlays / modals ────────────────────────────────────────────── */
.edit-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg-overlay);z-index:300;overflow-y:auto;padding:20px}
.edit-overlay.open{display:block}
.edit-box{background:var(--bg-card);border-radius:20px;max-width:500px;margin:0 auto;padding:20px}
.edit-box-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.edit-box-title{font-family:'Fredoka One',cursive;font-size:20px;color:var(--brand-d)}
.edit-close{background:none;border:none;font-size:22px;color:var(--text-muted);cursor:pointer}
.p-btn-edit{padding:6px 12px;border-radius:8px;border:1.5px solid var(--brand);background:var(--bg-card);color:var(--brand);font-family:'Nunito',sans-serif;font-size:12px;font-weight:700;cursor:pointer}
.kid-row-actions{display:flex;gap:6px;flex-shrink:0}

/* ── Misc parent ──────────────────────────────────────────────────── */
.p-empty{text-align:center;padding:28px;color:var(--text-muted);font-size:14px}
.p-empty-icon{font-size:36px;margin-bottom:8px}
.add-form-panel{background:var(--bg-page);border-radius:14px;padding:16px;margin-top:10px;display:none}
.add-form-panel.visible{display:block}
.p-btn-row{display:-webkit-flex;display:flex;gap:10px;margin-top:10px}
.p-btn-row .p-btn{-webkit-flex:1;flex:1;text-align:center}
.log-item{display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;padding:10px 0;border-bottom:1px solid var(--border-row);font-size:13px;gap:10px}
.log-item:last-child{border-bottom:none}
.log-ava{font-size:16px;width:32px;height:32px;background:var(--brand-l);border-radius:50%;display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;-webkit-justify-content:center;justify-content:center;-webkit-flex-shrink:0;flex-shrink:0}
.log-body{-webkit-flex:1;flex:1}
.log-who{font-weight:700;color:var(--text-primary)}
.log-what{color:var(--text-muted)}
.log-pts{font-size:12px;font-weight:700;color:var(--green-d);background:var(--green-l);padding:2px 8px;border-radius:10px;flex-shrink:0}
.log-time{font-size:11px;color:var(--text-faint);flex-shrink:0}
.danger-card{background:var(--bg-card);border-radius:16px;border:1.5px solid var(--coral-l);padding:16px;margin-bottom:10px}
.kid-mgmt-card{background:var(--bg-card);border-radius:16px;border:1px solid var(--border);padding:16px;margin-bottom:10px}
.kid-mgmt-header{display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;margin-bottom:14px;gap:12px}
.kid-mgmt-ava{width:48px;height:48px;border-radius:50%;display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;-webkit-justify-content:center;justify-content:center;font-size:24px;-webkit-flex-shrink:0;flex-shrink:0}
.avatar-opt{width:44px;height:44px;border-radius:12px;border:2.5px solid transparent;display:flex;align-items:center;justify-content:center;font-size:24px;cursor:pointer;background:var(--bg-page);transition:border-color 0.15s}
.avatar-opt.selected{border-color:var(--brand)}

/* ── Theme toggle ─────────────────────────────────────────────────── */
.theme-toggle{background:var(--bg-chip);border:none;color:var(--text-header);border-radius:10px;width:38px;height:38px;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-transition:all 0.2s;transition:all 0.2s}
.theme-toggle-float{position:fixed;bottom:90px;left:12px;width:36px;height:36px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:98;box-shadow:var(--shadow-float);-webkit-transition:all 0.2s;transition:all 0.2s}

/* ── Kid color themes ─────────────────────────────────────────────── */
.color-blue .kid-header{background:linear-gradient(135deg,#378ADD,#0C447C)}
.color-pink .kid-header{background:linear-gradient(135deg,#D4537E,#72243E)}
.color-purple .kid-header{background:linear-gradient(135deg,#7F77DD,#3C3489)}
.color-green .kid-header{background:linear-gradient(135deg,#639922,#3B6D11)}
.color-amber .kid-header{background:linear-gradient(135deg,#EF9F27,#633806)}
.color-coral .kid-header{background:linear-gradient(135deg,#D85A30,#712B13)}
.color-teal .kid-header{background:linear-gradient(135deg,#1D9E75,#085041)}
.color-red .kid-header{background:linear-gradient(135deg,#E24B4A,#501313)}

/* ── Login page ───────────────────────────────────────────────────── */
html:has(.login-body),body:has(.login-body){height:auto;min-height:100dvh}
.login-body{display:flex;flex-direction:column;align-items:center;min-height:100dvh;padding:clamp(8px,3vh,40px) 12px 80px;background:#ECF6E0}
.login-card{background:#fff;border-radius:20px;width:100%;max-width:400px;border:1px solid #d4edba;box-shadow:0 4px 24px rgba(95,171,47,0.10);display:flex;flex-direction:column;overflow:visible}
.login-card-body{padding:0 20px 20px;border-radius:0 0 20px 20px}
.login-tabs{display:flex;background:#ECF6E0;border-radius:12px;padding:4px;margin-bottom:10px;margin-top:-22%;border:1px solid #d4edba;position:relative;z-index:2}
.login-card img{width:min(340px,90vw);height:auto;display:block;margin:-40px auto 8px;position:relative;flex-shrink:0;padding-top:8px}
.login-tab{flex:1;padding:8px;border:none;background:none;font-family:'Nunito',sans-serif;font-size:14px;font-weight:700;color:#888;border-radius:9px;cursor:pointer;transition:all 0.2s}
.login-tab.active{background:#fff;color:#2C5E0A;box-shadow:0 2px 8px rgba(95,171,47,0.15)}
.login-form{display:flex;flex-direction:column;gap:8px}
#form-register{padding-bottom:5px}
.login-inp{padding:11px 14px;border-radius:12px;border:1.5px solid #d4edba;font-family:'Nunito',sans-serif;font-size:15px;outline:none;transition:border-color 0.2s;width:100%;background:#fff;color:#1a1a2e}
.login-inp::placeholder{color:#aaa}
.login-inp:focus{border-color:#5FAB2F}
.login-btn{padding:13px;border-radius:12px;border:none;font-family:'Nunito',sans-serif;font-size:16px;font-weight:800;cursor:pointer;background:linear-gradient(135deg,#5FAB2F,#2C5E0A);color:#fff;transition:opacity 0.2s;width:100%;margin-top:2px}
.login-btn:active{opacity:0.85}
.login-btn:disabled{opacity:0.5;cursor:default}
.login-forgot{text-align:center;margin-top:8px;font-size:13px}
.login-forgot a{color:#5FAB2F;text-decoration:none;font-weight:700}
.login-error{background:#faeeda;color:#633806;padding:10px 14px;border-radius:10px;font-size:13px;font-weight:700;display:none;margin-bottom:4px}
.trial-note{text-align:center;font-size:12px;color:#888;margin-top:4px}
.trial-note strong{color:#5FAB2F}
.verify-screen{display:none;text-align:center;padding:12px 0 16px}
.verify-icon{font-size:44px;margin-bottom:8px}
.verify-title{font-family:'Fredoka One',cursive;font-size:22px;color:#2C5E0A;margin-bottom:8px}
.verify-msg{font-size:14px;color:#666;line-height:1.6;margin-bottom:14px}
.verify-status{font-size:13px;font-weight:700;padding:10px 14px;border-radius:10px;background:#ECF6E0;color:#2C5E0A;margin-bottom:10px}
.verify-resend{font-size:12px;color:#aaa;margin-top:8px}
.verify-resend a{color:#5FAB2F;text-decoration:none;font-weight:700}

/* Dark theme */
[data-theme="dark"] .login-body{background:#0f1014}
[data-theme="dark"] .login-card{background:#1c1d22;border-color:#2a2c34;box-shadow:none}
[data-theme="dark"] .login-card-body{background:#1c1d22}
[data-theme="dark"] .login-tabs{background:#262830;border-color:#2a2c34}
[data-theme="dark"] .login-tab{color:#6e7079}
[data-theme="dark"] .login-tab.active{background:#5FAB2F;color:#fff;box-shadow:0 2px 10px rgba(95,171,47,0.4)}
[data-theme="dark"] .login-inp{background:#262830;color:#e8e9ee;border-color:#2a2c34}
[data-theme="dark"] .login-inp::placeholder{color:#6e7079}
[data-theme="dark"] .login-inp:focus{border-color:#5FAB2F}
[data-theme="dark"] .login-error{background:#2a200c;color:#EF9F27}
[data-theme="dark"] .verify-title{color:#5FAB2F}
[data-theme="dark"] .verify-msg{color:#a8aab2}
[data-theme="dark"] .verify-status{background:#1c2c10;color:#5FAB2F}
[data-theme="dark"] .verify-resend{color:#4a4c54}

/* ── Login footer ─────────────────────────────────────────────────── */
.login-footer{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:12px;padding:8px 20px;height:44px;background:rgba(236,246,224,0.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-top:1px solid #d4edba;font-size:12px;color:#888;z-index:50}
.login-footer a{color:#5FAB2F;text-decoration:none;font-weight:700}
.login-footer a:hover{text-decoration:underline}
.login-theme-btn{background:none;border:1.5px solid #d4edba;border-radius:20px;padding:3px 10px;font-size:14px;color:#5FAB2F;cursor:pointer;font-family:'Nunito',sans-serif;transition:all 0.2s;line-height:1.4}
[data-theme="dark"] .login-footer{background:rgba(15,16,20,0.92);border-top-color:#2a2c34;color:#6e7079}
[data-theme="dark"] .login-footer a{color:#5FAB2F}
[data-theme="dark"] .login-theme-btn{border-color:#2a2c34;color:#5FAB2F}
.cf-turnstile{margin:6px 0}

/* ── Onboarding page ──────────────────────────────────────────────── */
.ob-body{min-height:100vh;background:var(--auth-bg);padding:20px;display:flex;align-items:flex-start;justify-content:center}
.ob-card{background:var(--bg-card);border-radius:24px;padding:32px;width:100%;max-width:480px;box-shadow:var(--shadow-elevated);margin:20px auto}
.ob-progress{display:flex;align-items:center;margin-bottom:28px}
.ob-dot{width:32px;height:32px;border-radius:50%;background:var(--brand-l);color:var(--text-faint);font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 0.3s}
.ob-dot.active{background:var(--brand);color:#fff}
.ob-dot.done{background:var(--green);color:#fff}
.ob-line{flex:1;height:3px;background:var(--brand-l);margin:0 6px;transition:background 0.3s}
.ob-line.done{background:var(--green)}
.ob-step{display:none}
.ob-step.active{display:block}
.ob-icon{font-size:48px;text-align:center;margin-bottom:12px}
.ob-title{font-family:'Fredoka One',cursive;font-size:26px;color:var(--brand-d);margin-bottom:8px;text-align:center}
.ob-sub{font-size:14px;color:var(--text-muted);text-align:center;margin-bottom:24px;line-height:1.5}
.ob-form-group{margin-bottom:14px}
.ob-label{font-size:13px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.8px;margin-bottom:6px;display:block}
.ob-inp{padding:12px 16px;border-radius:12px;border:1.5px solid var(--border-input);font-family:'Nunito',sans-serif;font-size:15px;outline:none;transition:border-color 0.2s;width:100%;background:var(--bg-input);color:var(--text-primary)}
.ob-inp:focus{border-color:var(--brand)}
.ob-inp-row{display:flex;gap:10px}
.ob-inp-row .ob-inp{flex:1}
.ob-inp-icon{width:56px;text-align:center;font-size:22px;padding:10px 6px;flex-shrink:0}
.ob-pin-note{font-size:12px;color:var(--text-muted);margin-top:6px}
.ob-kid-card{background:var(--brand-l);border-radius:14px;padding:14px;display:flex;align-items:center;gap:10px;margin-bottom:10px}
.ob-kid-ava{width:40px;height:40px;background:var(--brand);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.ob-kid-info{flex:1}
.ob-kid-name{font-size:15px;font-weight:700;color:var(--brand-d)}
.ob-kid-sub{font-size:12px;color:var(--text-muted);margin-top:2px}
.ob-kid-remove{background:none;border:none;color:var(--text-faint);font-size:18px;cursor:pointer;padding:4px}
.ob-add-btn{background:var(--brand-l);border:2px dashed #b8e89a;border-radius:14px;padding:14px;text-align:center;color:var(--brand);font-size:14px;font-weight:700;cursor:pointer;width:100%;transition:all 0.2s}
.ob-add-form{background:var(--bg-page);border-radius:14px;padding:16px;margin-top:10px;display:none}
.ob-add-form.visible{display:block}
.ob-push-status{padding:14px 16px;border-radius:12px;font-size:14px;font-weight:700;margin-bottom:16px;text-align:center}
.ob-push-status.unknown{background:var(--brand-l);color:var(--brand-d)}
.ob-push-status.enabled{background:var(--green-l);color:var(--green-d)}
.ob-push-status.blocked{background:var(--coral-l);color:var(--coral-d)}
.ob-tips{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.ob-tip{display:flex;align-items:flex-start;gap:12px;padding:12px;background:var(--bg-page);border-radius:12px;font-size:14px;color:var(--text-secondary);line-height:1.5}
.ob-tip-icon{font-size:22px;flex-shrink:0;margin-top:1px}
.ob-btn{padding:13px;border-radius:12px;border:none;font-family:'Nunito',sans-serif;font-size:16px;font-weight:800;cursor:pointer;width:100%;transition:opacity 0.2s;margin-top:8px}
.ob-btn:active{opacity:0.85}
.ob-btn:disabled{opacity:0.5;cursor:default}
.ob-btn-purple{background:linear-gradient(135deg,#5FAB2F,#2C5E0A);color:#fff}
.ob-btn-outline{background:var(--bg-card);color:var(--text-muted);border:1.5px solid var(--border-input)}
.ob-btn-row{display:flex;gap:10px;margin-top:8px}
.ob-btn-row .ob-btn{flex:1}
.ob-error{background:var(--amber-l);color:var(--amber-d);padding:10px 14px;border-radius:10px;font-size:13px;font-weight:700;display:none;margin-bottom:12px}
.ob-skip{font-size:12px;color:var(--text-faint);text-align:center;margin-top:12px;cursor:pointer;text-decoration:underline}

/* ── Verify page ──────────────────────────────────────────────────── */
.vp-body{min-height:100vh;background:var(--auth-bg);font-family:'Nunito',sans-serif;display:flex;align-items:center;justify-content:center;padding:20px}
.vp-card{background:var(--bg-card);border-radius:24px;padding:40px 32px;width:100%;max-width:420px;box-shadow:var(--shadow-elevated);text-align:center}
.vp-icon{font-size:56px;margin-bottom:16px}
.vp-title{font-family:'Fredoka One',cursive;font-size:28px;color:var(--brand-d);margin-bottom:12px}
.vp-msg{font-size:15px;color:var(--text-secondary);line-height:1.6;margin-bottom:24px}
.vp-note{font-size:13px;color:var(--text-muted);margin-top:16px}
.vp-btn{display:inline-block;background:linear-gradient(135deg,#5FAB2F,#2C5E0A);color:#fff;text-decoration:none;padding:14px 32px;border-radius:12px;font-size:16px;font-weight:800;font-family:'Nunito',sans-serif}
.vp-error{color:var(--coral-d);background:var(--coral-l);padding:12px 16px;border-radius:10px;font-size:14px;font-weight:700;margin-bottom:24px}

/* ── Forgot / Reset password page ────────────────────────────────── */
.fr-goblins{display:flex;justify-content:center;align-items:flex-end;padding:0;gap:0;margin-bottom:-20px;position:relative;z-index:3}
.fr-goblins img{width:200px;height:200px;object-fit:contain;margin:0 -15px}
.fr-goblins img:first-child{transform:scaleX(-1)}
.fr-error{background:var(--amber-l);color:var(--amber-d);padding:10px 14px;border-radius:10px;font-size:13px;font-weight:700;display:none;margin-bottom:12px}
.fr-state{display:none;padding-top:16px}
.fr-state.active{display:block}
.fr-title{font-family:'Fredoka One',cursive;font-size:24px;color:var(--brand-d);text-align:center;margin-bottom:6px}
.fr-sub{font-size:14px;color:var(--text-muted);text-align:center;margin-bottom:20px;line-height:1.5}
.fr-form{display:flex;flex-direction:column;gap:12px}
.fr-inp{padding:13px 16px;border-radius:12px;border:1.5px solid var(--border-input);font-family:'Nunito',sans-serif;font-size:15px;outline:none;transition:border-color 0.2s;width:100%;background:var(--bg-input);color:var(--text-primary)}
.fr-inp:focus{border-color:var(--brand)}
.fr-btn{padding:14px;border-radius:12px;border:none;font-family:'Nunito',sans-serif;font-size:16px;font-weight:800;cursor:pointer;background:linear-gradient(135deg,#5FAB2F,#2C5E0A);color:#fff;width:100%;transition:opacity 0.2s}
.fr-btn:active{opacity:0.85}
.fr-btn:disabled{opacity:0.6;cursor:default}
.fr-back{text-align:center;margin-top:16px;font-size:13px;color:var(--text-muted)}
.fr-back a{color:var(--brand);text-decoration:none;font-weight:700}
.fr-success-icon{font-size:48px;text-align:center;margin-bottom:10px}
.fr-check-msg{font-size:14px;color:var(--text-muted);text-align:center;line-height:1.6;margin-bottom:16px}
.fr-check-status{font-size:13px;font-weight:700;padding:10px 14px;border-radius:10px;background:var(--brand-l);color:var(--brand-d);text-align:center;margin-bottom:16px}
.fr-strength{height:4px;border-radius:2px;margin-top:6px;background:var(--border)}
.fr-strength-bar{height:100%;border-radius:2px;width:0%;transition:all 0.3s}
.fr-strength-label{font-size:11px;color:var(--text-muted);margin-top:4px}

/* ── Confetti animation ───────────────────────────────────────────── */
@keyframes confetti-fall{0%{transform:translateY(-20px) rotate(0);opacity:1}100%{transform:translateY(820px) rotate(720deg);opacity:0}}
.confetti-container{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:50}
.confetti-piece{position:absolute;top:-10px;animation:confetti-fall 3s ease-in forwards}

/* ── Streak Orb Track ─────────────────────────────────────────────── */
.streak-track{margin-bottom:14px}
.streak-orb-row{display:flex;align-items:center;justify-content:center;gap:0;padding:8px 0}
.streak-orb{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:80px;cursor:default}
.streak-orb-inner{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--orb-color,#FF6B35),color-mix(in srgb,var(--orb-color,#FF6B35) 60%,#000));display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 4px 14px rgba(0,0,0,0.18),0 0 0 4px rgba(255,255,255,0.15);position:relative;transition:transform 0.2s,box-shadow 0.2s}
.orb-earned .streak-orb-inner{box-shadow:0 4px 14px rgba(0,0,0,0.2),0 0 0 4px rgba(255,255,255,0.25),0 0 0 8px rgba(255,255,255,0.08);animation:orbPulse 2.4s ease-in-out infinite}
.orb-locked .streak-orb-inner{background:linear-gradient(135deg,#aaa,#888);box-shadow:0 2px 8px rgba(0,0,0,0.12)}
.streak-orb-label{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:0.5px;color:rgba(255,255,255,0.85)}
.streak-orb-pts{font-size:12px;font-weight:800;color:rgba(255,255,255,0.9)}
.streak-orb-state{font-size:10px;font-weight:700;color:rgba(255,255,255,0.6);margin-top:1px;min-height:14px;text-align:center}
.streak-orb-line{flex:1;height:3px;background:rgba(255,255,255,0.2);border-top:2px dashed rgba(255,255,255,0.3);margin:0 4px;position:relative;top:-16px}
.orb-earned + .streak-orb-line{border-top-color:rgba(255,255,255,0.7);background:rgba(255,255,255,0.4)}
@keyframes orbPulse{0%,100%{box-shadow:0 4px 14px rgba(0,0,0,0.2),0 0 0 4px rgba(255,255,255,0.25),0 0 0 8px rgba(255,255,255,0.08)}50%{box-shadow:0 4px 18px rgba(0,0,0,0.25),0 0 0 5px rgba(255,255,255,0.3),0 0 0 11px rgba(255,255,255,0.06)}}

/* ══════════════════════════════════════════════════════════════════
   PARENT DASHBOARD — iOS-inspired with Goblin twist
   ══════════════════════════════════════════════════════════════════ */

/* Page background */
#parent-dashboard-wrap{display:flex;flex-direction:column;height:100vh;background:var(--bg-page)}

/* ── Frosted glass header ─────────────────────────────────────────── */
.pd-header{
  position:sticky;top:0;z-index:100;
  background:rgba(247,247,251,0.88);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:0.5px solid var(--border);
  padding:12px 16px 10px;
  transition:background 0.3s;
}
[data-theme="dark"] .pd-header{background:rgba(15,16,20,0.88)}

.pd-header-inner{display:flex;align-items:center;justify-content:space-between;max-width:800px;margin:0 auto}
.pd-header-left{display:flex;align-items:center;gap:10px}
.pd-logo{width:42px;height:42px;object-fit:contain;border-radius:10px}
.pd-app-name{font-family:'Fredoka One',cursive;font-size:21px;color:var(--brand);line-height:1}
.pd-greeting{font-size:12px;color:var(--text-muted);margin-top:2px}
.pd-actions{display:flex;gap:6px}
.pd-icon-btn{
  width:36px;height:36px;border-radius:50%;border:none;
  background:rgba(0,0,0,0.06);
  font-size:17px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background 0.15s;
  -webkit-tap-highlight-color:transparent;
}
[data-theme="dark"] .pd-icon-btn{background:rgba(255,255,255,0.1)}
.pd-icon-btn:active{background:rgba(0,0,0,0.12)}
[data-theme="dark"] .pd-icon-btn:active{background:rgba(255,255,255,0.18)}

/* ── Scrollable body ──────────────────────────────────────────────── */
.pd-scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:80px}
.pd-page{max-width:800px;margin:0 auto;padding:12px 16px 0}

/* ── Section labels ───────────────────────────────────────────────── */
.pd-section-label{
  font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:0.8px;
  color:var(--text-muted);
  margin:20px 0 8px 2px;
  display:flex;align-items:center;gap:8px;
}
.pd-section-label:first-child{margin-top:6px}

/* Badge pill inside section label */
.pd-badge{
  background:var(--amber);color:#fff;
  border-radius:10px;padding:2px 8px;
  font-size:11px;font-weight:800;letter-spacing:0;
  display:inline-flex;align-items:center;
}

/* ── Cards ────────────────────────────────────────────────────────── */
.pd-card{
  background:var(--bg-card);
  border-radius:16px;
  border:1px solid var(--border);
  overflow:hidden;
  margin-bottom:4px;
  box-shadow:0 1px 4px rgba(0,0,0,0.06)
}

/* ── Kid overview ─────────────────────────────────────────────────── */
.pd-kids-scroll{display:flex;gap:10px;margin-bottom:4px}

.pd-kid-card{
  flex:1;
  min-width:0;
  border-radius:16px;
  padding:14px;
  color:#fff;
  position:relative;
  overflow:hidden;
  box-shadow:0 4px 16px rgba(0,0,0,0.15)
}
.pd-kid-card::before{
  content:'';position:absolute;top:-24px;right:-24px;
  width:90px;height:90px;border-radius:50%;
  background:rgba(255,255,255,0.12);
}
.pd-kid-avatar{font-size:28px;line-height:1;margin-bottom:6px;display:block;position:relative;z-index:1}
.pd-kid-name{font-family:'Fredoka One',cursive;font-size:17px;line-height:1.1;margin-bottom:4px;position:relative;z-index:1}
.pd-kid-sub{font-size:11px;opacity:0.85;margin-bottom:10px;position:relative;z-index:1}
.pd-kid-prog-bg{background:rgba(255,255,255,0.28);border-radius:4px;height:5px;position:relative;z-index:1}
.pd-kid-prog-fill{background:#fff;border-radius:4px;height:100%;transition:width 0.4s ease}
.pd-kid-pct{font-size:11px;font-weight:700;opacity:0.9;margin-top:5px;position:relative;z-index:1}

/* ── Approval / list rows ─────────────────────────────────────────── */
.pd-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:0.5px solid var(--border-row)}
.pd-row:last-child{border-bottom:none}
.pd-row-ava{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;background:var(--brand-l)}
.pd-row-body{flex:1;min-width:0}
.pd-row-title{font-size:14px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pd-row-sub{font-size:12px;color:var(--text-muted);margin-top:2px}
.pd-row-actions{display:flex;gap:6px;flex-shrink:0}

/* ── Action buttons ───────────────────────────────────────────────── */
.pd-btn-approve{padding:7px 16px;border-radius:20px;border:none;font-family:'Nunito',sans-serif;font-size:13px;font-weight:800;cursor:pointer;background:var(--green);color:#fff;transition:opacity 0.15s}
.pd-btn-reject{padding:7px 14px;border-radius:20px;border:1.5px solid var(--border-input);font-family:'Nunito',sans-serif;font-size:13px;font-weight:700;cursor:pointer;background:var(--bg-card);color:var(--text-muted);transition:opacity 0.15s}
.pd-btn-undo{padding:6px 12px;border-radius:20px;border:1.5px solid var(--border-input);font-family:'Nunito',sans-serif;font-size:12px;font-weight:700;cursor:pointer;background:var(--bg-card);color:var(--text-muted)}
.pd-btn-approve:active,.pd-btn-reject:active,.pd-btn-undo:active{opacity:0.65}

/* ── Approved today — scrollable when list is long ────────────────── */
#approved-list{max-height:380px;overflow-y:auto;-webkit-overflow-scrolling:touch}

/* ── Empty states ─────────────────────────────────────────────────── */
.pd-empty{text-align:center;padding:24px 16px;color:var(--text-muted);font-size:14px}
.pd-empty-icon{font-size:32px;margin-bottom:6px}

/* ── Desktop mode ─────────────────────────────────────────────────── */
@media (min-width:901px) {
  .desktop-mode body{background:linear-gradient(135deg,#1a1a2e 0%,#0f1f0a 100%)}
  .desktop-mode .nav-bar{max-width:900px;left:50%;transform:translateX(-50%);border-radius:16px 16px 0 0;border-left:1px solid var(--border-nav);border-right:1px solid var(--border-nav)}
  .desktop-mode .app{box-shadow:0 0 60px rgba(0,0,0,0.5);border-left:1px solid var(--border);border-right:1px solid var(--border)}
  .desktop-mode #parent-dashboard-wrap{box-shadow:0 0 60px rgba(0,0,0,0.5);border-left:1px solid var(--border);border-right:1px solid var(--border)}
  .desktop-mode #settings-wrap{box-shadow:0 0 60px rgba(0,0,0,0.5);border-left:1px solid var(--border);border-right:1px solid var(--border)}
  .desktop-mode .kid-header{width:auto;margin-left:0}
}