/* ── Page ────────────────────────────────────────────────────────────────────── */
.page{max-width:820px;width:100%}

/* ── Login screen ────────────────────────────────────────────────────────────── */
#login-screen{
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;min-height:88vh;
}
.btn-calendar{background:linear-gradient(135deg,#4a90d9,#2c5fad);color:white}
.login-card{
  background:linear-gradient(160deg,rgba(255,255,255,.97),rgba(255,230,250,.97));
  border-radius:32px;padding:32px 28px 28px;
  border:4px solid var(--gold);width:100%;max-width:400px;
  animation:pulse-glow 3s ease-in-out infinite;position:relative;overflow:hidden;
}
.login-card::before{
  content:'';position:absolute;top:0;left:0;right:0;bottom:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);
  background-size:200% 100%;animation:shimmer 3s linear infinite;
}
.login-castle{display:block;margin:0 auto 6px;animation:float 3s ease-in-out infinite;position:relative;z-index:1}
.login-title{
  font-family:'Pacifico',cursive;font-size:34px;text-align:center;
  background:linear-gradient(135deg,#6a0572,#c2185b,#ff69b4,#f9c74f);
  background-size:300% auto;-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
  animation:shimmer 4s linear infinite;line-height:1.1;position:relative;z-index:1;
}
.login-sub{
  font-size:14px;color:var(--deep-purple);font-weight:700;
  margin:6px 0 20px;letter-spacing:1px;text-align:center;
  text-transform:uppercase;position:relative;z-index:1;
}
.who-label{
  font-size:13px;font-weight:800;color:#9b59b6;
  text-align:center;margin-bottom:10px;letter-spacing:.5px;
  text-transform:uppercase;position:relative;z-index:1;
}
.character-row{display:flex;gap:12px;margin-bottom:18px;position:relative;z-index:1}
.char-btn{
  flex:1;padding:14px 10px;border:3px solid transparent;border-radius:20px;
  cursor:pointer;font-family:'Nunito',sans-serif;font-weight:800;
  font-size:15px;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:6px;
}
.char-btn .char-icon{font-size:36px;animation:float 3s ease-in-out infinite}
.char-btn .char-name{font-size:16px}
.char-btn.sophia{background:linear-gradient(135deg,rgba(255,214,235,.6),rgba(255,182,218,.6));border-color:var(--pink);color:var(--deep-purple)}
.char-btn.mama{background:linear-gradient(135deg,rgba(232,213,245,.6),rgba(200,160,230,.6));border-color:var(--purple);color:var(--deep-purple)}
.char-btn.sophia .char-icon{animation-delay:.2s}
.char-btn.mama .char-icon{animation-delay:.5s}
.char-btn.selected.sophia{background:linear-gradient(135deg,#ff85c8,#ff69b4);border-color:#c2185b;color:white;box-shadow:0 6px 20px rgba(255,105,180,.5);transform:scale(1.04)}
.char-btn.selected.mama{background:linear-gradient(135deg,#b565e8,#9b59b6);border-color:var(--deep-purple);color:white;box-shadow:0 6px 20px rgba(155,89,182,.5);transform:scale(1.04)}
.char-btn:hover:not(.selected){transform:scale(1.02);filter:brightness(1.05)}

/* Password */
.pw-wrap{position:relative;margin-bottom:14px;z-index:1}
.pw-label{font-size:13px;font-weight:800;color:#9b59b6;display:block;margin-bottom:6px;letter-spacing:.5px;text-transform:uppercase}
.pw-input{
  width:100%;padding:13px 18px;border-radius:20px;
  border:3px solid rgba(155,89,182,.3);font-family:'Nunito',sans-serif;
  font-size:18px;font-weight:700;color:var(--deep-purple);background:rgba(255,255,255,.9);
  outline:none;transition:all .2s;letter-spacing:4px;
}
.pw-input::placeholder{letter-spacing:1px;font-size:14px;color:#c9a0d8}
.pw-input:focus{border-color:var(--pink);box-shadow:0 0 0 4px rgba(255,105,180,.2)}
.pw-input.error{border-color:#e74c3c;animation:shake .4s ease}
.login-btn{
  width:100%;padding:15px;border:none;border-radius:20px;
  font-family:'Nunito',sans-serif;font-size:18px;font-weight:800;
  cursor:pointer;transition:all .2s;background:linear-gradient(135deg,#f9c74f,#f4845f);
  color:white;text-shadow:0 1px 3px rgba(0,0,0,.2);box-shadow:0 6px 20px rgba(244,132,95,.5);
  position:relative;z-index:1;
}
.login-btn:hover{transform:scale(1.03) translateY(-2px);box-shadow:0 10px 28px rgba(244,132,95,.7)}
.login-btn:active{transform:scale(.98)}
.login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}
.error-msg{
  color:#c0392b;font-size:13px;font-weight:800;text-align:center;
  margin-top:10px;padding:8px;border-radius:12px;
  background:rgba(231,76,60,.1);display:none;position:relative;z-index:1;
}
.error-msg.show{display:block}

/* Loading screen */
#loading-screen{display:none;flex-direction:column;align-items:center;justify-content:center;min-height:80vh;gap:16px}

/* App screen */
#app-screen{display:none}

/* User bar */
.user-bar{
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(255,255,255,.15);border-radius:16px;
  padding:8px 16px;margin-bottom:16px;backdrop-filter:blur(8px);
}
.user-name{color:white;font-weight:800;font-size:14px}
.logout-btn{
  background:rgba(255,255,255,.2);color:white;border:1.5px solid rgba(255,255,255,.4);
  border-radius:20px;padding:4px 14px;font-family:'Nunito',sans-serif;
  font-size:13px;font-weight:700;cursor:pointer;transition:all .2s;
}
.logout-btn:hover{background:rgba(255,255,255,.3)}

/* Castle banner */
.castle-banner{
  background:linear-gradient(135deg,#fff0fa,#ffe0f5,#f5d0ff);
  border-radius:32px;padding:22px 28px 16px;border:4px solid var(--gold);
  margin-bottom:18px;position:relative;overflow:hidden;animation:pulse-glow 3s ease-in-out infinite;
}
.castle-banner::before{
  content:'';position:absolute;top:0;left:0;right:0;bottom:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);
  background-size:200% 100%;animation:shimmer 3s linear infinite;
}
.castle-svg{display:block;margin:0 auto 6px;filter:drop-shadow(0 4px 8px rgba(106,5,114,.4));animation:float 3s ease-in-out infinite}
.title{
  font-family:'Pacifico',cursive;font-size:40px;text-align:center;
  background:linear-gradient(135deg,#6a0572,#c2185b,#ff69b4,#f9c74f,#ff69b4,#c2185b);
  background-size:300% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;animation:shimmer 4s linear infinite;line-height:1.1;position:relative;z-index:1;
}
.subtitle{font-size:14px;color:var(--deep-purple);font-weight:700;margin-top:4px;letter-spacing:2px;text-transform:uppercase;text-align:center;position:relative;z-index:1}
.sparkles-row{display:flex;justify-content:center;gap:10px;margin-top:10px;position:relative;z-index:1}
.sparkle{font-size:22px;display:inline-block;animation:twinkle 1.5s ease-in-out infinite}
.sparkle:nth-child(2){animation-delay:.3s}.sparkle:nth-child(3){animation-delay:.6s}
.sparkle:nth-child(4){animation-delay:.9s}.sparkle:nth-child(5){animation-delay:1.2s}
.corner-deco{position:absolute;font-size:30px;animation:twinkle 2s ease-in-out infinite}
.corner-deco.tl{top:10px;left:12px;animation-delay:.2s}
.corner-deco.tr{top:10px;right:12px;animation-delay:.5s}
.corner-deco.bl{bottom:10px;left:12px;animation-delay:.8s}
.corner-deco.br{bottom:10px;right:12px;animation-delay:1.1s}

/* Mama controls */
#mama-controls{
  background:linear-gradient(160deg,rgba(255,255,255,.97),rgba(255,230,250,.97));
  border-radius:24px;overflow:hidden;margin-bottom:18px;
  box-shadow:0 8px 32px rgba(106,5,114,.25);border:3px solid var(--gold);display:none;
}
.mama-header{background:linear-gradient(135deg,#f9c74f,#f4845f,#e91e8c);padding:12px 20px;display:flex;align-items:center;gap:10px}
.mama-title{font-family:'Pacifico',cursive;font-size:19px;color:white;text-shadow:0 2px 8px rgba(0,0,0,.3)}
.mama-body{padding:14px 18px;display:flex;gap:12px;flex-wrap:wrap}
.mama-btn{padding:10px 18px;border:none;border-radius:20px;cursor:pointer;font-family:'Nunito',sans-serif;font-size:14px;font-weight:800;transition:all .2s;box-shadow:0 3px 10px rgba(0,0,0,.15)}
.mama-btn:hover{transform:scale(1.05) translateY(-2px)}
.mama-btn:active{transform:scale(.97)}
.btn-award{background:linear-gradient(135deg,#f9c74f,#f4845f);color:white}
.btn-remove{background:linear-gradient(135deg,#e91e8c,#c2185b);color:white}
.btn-reset{background:linear-gradient(135deg,#9b59b6,#6a0572);color:white}
.btn-manage{background:linear-gradient(135deg,#6a0572,#2d0036);color:white}
.mama-note{font-size:12px;color:#9b59b6;font-weight:700;padding:0 18px 12px;font-style:italic}

/* Chore sections */
.sections-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.section{background:linear-gradient(160deg,rgba(255,255,255,.97),rgba(255,230,250,.97));border-radius:24px;overflow:hidden;box-shadow:0 8px 32px rgba(106,5,114,.25);border:3px solid rgba(255,255,255,.8);animation:bounce-in .6s ease-out backwards}
.section:nth-child(1){animation-delay:.1s}.section:nth-child(2){animation-delay:.2s}
.section:nth-child(3){animation-delay:.3s}.section:nth-child(4){animation-delay:.4s}
.section-header{padding:12px 18px;display:flex;align-items:center;gap:10px}
.section-header.morning{background:linear-gradient(135deg,#ff85c8,#ff69b4,#c2185b)}
.section-header.afterschool{background:linear-gradient(135deg,#b565e8,#9b59b6,#6a0572)}
.section-header.evening{background:linear-gradient(135deg,#6a0572,#9b59b6,#c2185b)}
.section-header.weekend{background:linear-gradient(135deg,#f9c74f,#f4845f,#e91e8c)}
.section-icon{font-size:28px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));animation:float 2.5s ease-in-out infinite;flex-shrink:0}
.section-title{font-family:'Pacifico',cursive;font-size:18px;color:white;text-shadow:0 2px 8px rgba(0,0,0,.3);flex:1}
.section-badge{background:rgba(255,255,255,.3);color:white;font-size:11px;font-weight:800;padding:3px 9px;border-radius:20px;border:1.5px solid rgba(255,255,255,.6)}
.chores-list{padding:12px 14px;list-style:none;min-height:40px}
.chore-item{display:flex;align-items:flex-start;gap:9px;padding:8px 10px;margin-bottom:7px;border-radius:14px;background:rgba(255,255,255,.7);border:2px solid rgba(155,89,182,.15);cursor:pointer;transition:all .2s ease}
.chore-item:last-child{margin-bottom:0}
.chore-item:hover{background:rgba(255,214,235,.8);border-color:rgba(194,24,91,.3);transform:translateX(3px) scale(1.01)}
.chore-item.done{background:linear-gradient(135deg,rgba(248,215,255,.9),rgba(255,214,235,.9));border-color:var(--pink)}
.chore-item.done .chore-text{text-decoration:line-through;color:#b565e8;opacity:.7}
.chore-checkbox{width:26px;height:26px;border-radius:50%;border:3px solid var(--purple);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:14px;background:white;transition:all .2s;margin-top:1px}
.chore-item.done .chore-checkbox{background:linear-gradient(135deg,var(--pink),var(--purple));border-color:var(--purple);color:white;box-shadow:0 2px 8px rgba(155,89,182,.4)}
.chore-emoji{font-size:24px;flex-shrink:0;margin-top:1px}
.chore-text{font-size:13px;font-weight:700;color:#4a0060;line-height:1.4;flex:1;padding-top:2px}
.chore-sub{font-size:11px;font-weight:600;color:#9b59b6;display:block;margin-top:2px}
.chore-stars{font-size:13px;margin-left:auto;flex-shrink:0;padding-top:3px}

/* Gem / Reward section */
.reward-section{background:linear-gradient(160deg,rgba(255,255,255,.97),rgba(255,235,250,.97));border-radius:24px;overflow:hidden;box-shadow:0 8px 32px rgba(106,5,114,.25);border:3px solid rgba(255,255,255,.8);margin-bottom:16px;animation:bounce-in .6s .45s ease-out backwards}
.reward-header{background:linear-gradient(135deg,#f9c74f,#ff85c8,#b565e8);padding:12px 18px;display:flex;align-items:center;gap:10px}
.reward-title{font-family:'Pacifico',cursive;font-size:18px;color:white;text-shadow:0 2px 8px rgba(0,0,0,.3)}
.gem-tracker{padding:14px 18px;display:flex;flex-direction:column;align-items:center;gap:12px}
.gem-label{font-size:14px;font-weight:800;color:var(--deep-purple);text-align:center}
.gems-row{display:flex;gap:9px;flex-wrap:wrap;justify-content:center}
.gem{width:42px;height:42px;border-radius:12px;background:rgba(200,170,220,.3);border:3px dashed rgba(155,89,182,.4);display:flex;align-items:center;justify-content:center;font-size:22px}
.gem.earned{background:linear-gradient(135deg,#f9c74f,#f4845f);border:3px solid #f9c74f;box-shadow:0 4px 14px rgba(249,199,79,.5);animation:twinkle 1.5s ease-in-out infinite}
.gem.earned:nth-child(2n){animation-delay:.3s}.gem.earned:nth-child(3n){animation-delay:.6s}
.prize-banner{background:linear-gradient(135deg,#f9c74f,#ff85c8,#b565e8);color:white;font-weight:800;font-size:13px;padding:8px 18px;border-radius:20px;text-align:center;text-shadow:0 1px 3px rgba(0,0,0,.2);box-shadow:0 4px 14px rgba(249,199,79,.4)}
.gems-empty{font-size:13px;color:#9b59b6;font-weight:700;font-style:italic}

/* Prize shop */
.prize-card{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:16px;background:rgba(255,255,255,.7);border:2px solid rgba(155,89,182,.15);margin-bottom:10px;transition:all .2s ease}
.prize-card:last-child{margin-bottom:0}
.prize-card.affordable{background:linear-gradient(135deg,rgba(255,214,235,.8),rgba(232,213,245,.8));border-color:var(--pink);box-shadow:0 4px 16px rgba(255,105,180,.3)}
.prize-card.affordable:hover{transform:scale(1.02)}
.prize-emoji{font-size:32px;flex-shrink:0}
.prize-info{flex:1}
.prize-name{font-size:14px;font-weight:800;color:#4a0060}
.prize-cost{font-size:12px;font-weight:700;color:#9b59b6;margin-top:2px}
.prize-need{font-size:11px;font-weight:700;color:#c0392b;margin-top:2px}
.request-btn{padding:8px 16px;border:none;border-radius:16px;background:linear-gradient(135deg,#f9c74f,#f4845f);color:white;font-family:'Nunito',sans-serif;font-size:13px;font-weight:800;cursor:pointer;transition:all .2s;flex-shrink:0;box-shadow:0 3px 10px rgba(244,132,95,.4)}
.request-btn:hover{transform:scale(1.06) translateY(-2px)}
.request-btn:active{transform:scale(.97)}
.request-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* Wish list */
.wish-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:14px;margin-bottom:8px;border:2px solid rgba(155,89,182,.15);background:rgba(255,255,255,.7)}
.wish-item:last-child{margin-bottom:0}
.wish-status{font-size:11px;font-weight:800;padding:3px 10px;border-radius:20px;flex-shrink:0}
.wish-pending{background:rgba(249,199,79,.2);color:#c77f00}
.wish-approved{background:rgba(46,204,113,.15);color:#27ae60}
.wish-denied{background:rgba(231,76,60,.12);color:#c0392b}
.wish-empty{font-size:13px;color:#9b59b6;font-weight:700;font-style:italic;text-align:center;padding:8px 0}

/* Footer */
.footer{background:linear-gradient(160deg,rgba(255,255,255,.97),rgba(255,230,250,.97));border-radius:24px;padding:14px 22px;text-align:center;box-shadow:0 8px 32px rgba(106,5,114,.2);border:3px solid rgba(255,255,255,.8);animation:bounce-in .6s .55s ease-out backwards;margin-bottom:16px}
.footer-text{font-family:'Pacifico',cursive;font-size:15px;background:linear-gradient(135deg,#6a0572,#e91e8c);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.footer-sub{font-size:12px;color:#9b59b6;font-weight:700;margin-top:4px}

/* Responsive */
@media(max-width:600px){
  .sections-grid{grid-template-columns:1fr}
  .title{font-size:32px}
  body{padding:10px}
  .login-title{font-size:28px}
}
