body.fcc-app-shell-v1 #dashboard .dashboard-kid-view {
  width: 100%;
}

body.fcc-app-shell-v1 #dashboard .fcc-kid-dashboard {
  --kid-purple: #7c3aed;
  --kid-pink: #ec4899;
  --kid-blue: #38bdf8;
  --kid-mint: #34d399;
  --kid-gold: #fbbf24;
  --kid-ink: #2f2563;
  --kid-muted: #746d9a;
  min-height: calc(100vh - 120px);
  display: block;
  width: 100%;
  padding: clamp(18px, 3vw, 34px);
  border-radius: 28px;
  background:
    radial-gradient(circle at 18% 12%, rgba(236, 72, 153, 0.18), transparent 28%),
    radial-gradient(circle at 88% 8%, rgba(251, 191, 36, 0.2), transparent 24%),
    linear-gradient(135deg, #f7f0ff 0%, #eef8ff 48%, #fff6dd 100%);
  color: var(--kid-ink);
  overflow: visible;
}

body.fcc-app-shell-v1 #dashboard .fcc-kid-dashboard *,
body.fcc-app-shell-v1 #dashboard .fcc-kid-dashboard *::before,
body.fcc-app-shell-v1 #dashboard .fcc-kid-dashboard *::after {
  box-sizing: border-box;
}

body.fcc-app-shell-v1 #dashboard .kid-hero-card {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(220px, 0.65fr);
  align-items: center;
  gap: 20px;
  min-height: 230px;
  padding: clamp(24px, 4vw, 42px);
  border: 1px solid rgba(255, 255, 255, 0.78);
  border-radius: 32px;
  background:
    linear-gradient(120deg, rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0.62)),
    linear-gradient(135deg, rgba(124, 58, 237, 0.18), rgba(236, 72, 153, 0.12));
  box-shadow: 0 24px 70px rgba(76, 53, 133, 0.16);
  overflow: hidden;
}

body.fcc-app-shell-v1 #dashboard .kid-hero-card::after {
  content: "";
  position: absolute;
  right: 18px;
  bottom: -52px;
  width: min(42vw, 420px);
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(255, 255, 255, 0.4) 0 34%, transparent 35%),
    conic-gradient(from 220deg, rgba(236, 72, 153, 0.35), rgba(56, 189, 248, 0.3), rgba(52, 211, 153, 0.26), rgba(251, 191, 36, 0.32), rgba(236, 72, 153, 0.35));
  opacity: 0.6;
}

body.fcc-app-shell-v1 #dashboard .kid-hero-copy,
body.fcc-app-shell-v1 #dashboard .kid-avatar-world {
  position: relative;
  z-index: 1;
}

body.fcc-app-shell-v1 #dashboard .kid-eyebrow {
  margin: 0 0 10px;
  color: #7655c7;
  font-size: 0.78rem;
  font-weight: 850;
  text-transform: uppercase;
}

body.fcc-app-shell-v1 #dashboard .kid-hero-copy h1 {
  margin: 0;
  color: #6d28d9;
  font-size: clamp(2.2rem, 6vw, 4.8rem);
  line-height: 1;
}

body.fcc-app-shell-v1 #dashboard .kid-hero-subtitle {
  max-width: 620px;
  margin: 16px 0 0;
  color: var(--kid-muted);
  font-size: clamp(1rem, 2vw, 1.35rem);
  font-weight: 700;
}

body.fcc-app-shell-v1 #dashboard .kid-avatar-world {
  display: grid;
  place-items: center;
  min-height: 180px;
}

body.fcc-app-shell-v1 #dashboard .kid-avatar-frame {
  display: grid;
  place-items: center;
  width: clamp(132px, 22vw, 230px);
  aspect-ratio: 1;
  border: 10px solid rgba(255, 255, 255, 0.78);
  border-radius: 999px;
  background: linear-gradient(135deg, #fff, #efe3ff);
  box-shadow: 0 18px 42px rgba(84, 57, 156, 0.22);
  color: var(--kid-purple);
  font-size: clamp(3.8rem, 10vw, 7rem);
  font-weight: 900;
  overflow: hidden;
}

body.fcc-app-shell-v1 #dashboard .kid-avatar-frame img,
body.fcc-app-shell-v1 #dashboard .kid-avatar-frame .profile-avatar {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

body.fcc-app-shell-v1 #dashboard .kid-avatar-spark {
  position: absolute;
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 10px 24px rgba(76, 53, 133, 0.14);
}

body.fcc-app-shell-v1 #dashboard .kid-avatar-spark--one {
  top: 4px;
  right: 15%;
}

body.fcc-app-shell-v1 #dashboard .kid-avatar-spark--two {
  bottom: 8px;
  left: 13%;
}

body.fcc-app-shell-v1 #dashboard .kid-quick-actions {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
  margin: 20px 0;
  padding: 18px;
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 18px 50px rgba(76, 53, 133, 0.12);
}

body.fcc-app-shell-v1 #dashboard .kid-action-btn {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  min-height: 76px;
  padding: 14px 16px;
  border-radius: 22px;
  color: var(--kid-ink);
  text-decoration: none;
  font-weight: 850;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.7);
  transition: transform 180ms ease, box-shadow 180ms ease;
}

body.fcc-app-shell-v1 #dashboard .kid-action-btn:hover,
body.fcc-app-shell-v1 #dashboard .kid-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 42px rgba(76, 53, 133, 0.16);
}

body.fcc-app-shell-v1 #dashboard .kid-action-icon {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
  font-size: 1.75rem;
}

body.fcc-app-shell-v1 #dashboard .kid-action-arrow {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.58);
}

body.fcc-app-shell-v1 #dashboard .kid-action-btn--purple { background: linear-gradient(135deg, #ede2ff, #dac7ff); }
body.fcc-app-shell-v1 #dashboard .kid-action-btn--gold { background: linear-gradient(135deg, #fff4bf, #ffe091); }
body.fcc-app-shell-v1 #dashboard .kid-action-btn--pink { background: linear-gradient(135deg, #ffe2ef, #ffc4dd); }
body.fcc-app-shell-v1 #dashboard .kid-action-btn--blue { background: linear-gradient(135deg, #e1f3ff, #c4e7ff); }
body.fcc-app-shell-v1 #dashboard .kid-action-btn--mint { background: linear-gradient(135deg, #d9fbef, #b8f0dc); }

body.fcc-app-shell-v1 #dashboard .kid-main-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 18px;
  width: 100%;
}

body.fcc-app-shell-v1 #dashboard .kid-card {
  min-width: 0;
  overflow: hidden;
  padding: 22px;
  border: 1px solid rgba(255, 255, 255, 0.74);
  border-radius: 26px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 14px 38px rgba(76, 53, 133, 0.11);
  animation: kid-card-pop 360ms ease both;
  transition: transform 180ms ease, box-shadow 180ms ease;
}

body.fcc-app-shell-v1 #dashboard .kid-today-card,
body.fcc-app-shell-v1 #dashboard .kid-chores-card,
body.fcc-app-shell-v1 #dashboard .kid-points-card {
  grid-column: span 4;
}

body.fcc-app-shell-v1 #dashboard .kid-rewards-card {
  grid-column: span 4;
}

body.fcc-app-shell-v1 #dashboard .kid-onix-card,
body.fcc-app-shell-v1 #dashboard .kid-message-card,
body.fcc-app-shell-v1 #dashboard .kid-encouragement-card {
  grid-column: span 4;
}

body.fcc-app-shell-v1 #dashboard .kid-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

body.fcc-app-shell-v1 #dashboard .kid-card-title {
  margin: 0;
  font-size: 1.18rem;
  line-height: 1.2;
}

body.fcc-app-shell-v1 #dashboard .kid-card-header a {
  color: var(--kid-purple);
  font-size: 0.88rem;
  font-weight: 850;
  text-decoration: none;
}

body.fcc-app-shell-v1 #dashboard .kid-list {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

body.fcc-app-shell-v1 #dashboard .kid-list-item,
body.fcc-app-shell-v1 #dashboard .kid-chore-item,
body.fcc-app-shell-v1 #dashboard .kid-reward-item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  min-height: 54px;
  padding: 12px;
  border-radius: 18px;
  background: #f8f4ff;
}

body.fcc-app-shell-v1 #dashboard .kid-chore-item {
  grid-template-columns: minmax(0, 1fr) auto;
}

body.fcc-app-shell-v1 #dashboard .kid-list-time {
  color: var(--kid-purple);
  font-weight: 900;
}

body.fcc-app-shell-v1 #dashboard .kid-list-main,
body.fcc-app-shell-v1 #dashboard .kid-chore-title,
body.fcc-app-shell-v1 #dashboard .kid-reward-name {
  min-width: 0;
  font-weight: 850;
}

body.fcc-app-shell-v1 #dashboard .kid-chore-meta,
body.fcc-app-shell-v1 #dashboard .kid-reward-cost,
body.fcc-app-shell-v1 #dashboard .kid-muted {
  display: block;
  color: var(--kid-muted);
  font-size: 0.88rem;
  font-weight: 700;
}

body.fcc-app-shell-v1 #dashboard .kid-status-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}

body.fcc-app-shell-v1 #dashboard .kid-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 34px;
  padding: 7px 11px;
  border-radius: 999px;
  background: #f0e9ff;
  color: #5b21b6;
  font-size: 0.85rem;
  font-weight: 850;
}

body.fcc-app-shell-v1 #dashboard .kid-primary-cta,
body.fcc-app-shell-v1 #dashboard .kid-onix-prompts button {
  min-height: 42px;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--kid-purple), #a855f7);
  color: #fff;
  padding: 10px 14px;
  font-weight: 900;
  cursor: pointer;
}

body.fcc-app-shell-v1 #dashboard .kid-points-value {
  color: #5b21b6;
  font-size: clamp(2.8rem, 6vw, 4rem);
  font-weight: 950;
  line-height: 1;
}

body.fcc-app-shell-v1 #dashboard .kid-next-reward {
  display: grid;
  gap: 9px;
  margin-top: 18px;
  padding: 14px;
  border-radius: 20px;
  background: #f8f4ff;
  font-weight: 850;
}

body.fcc-app-shell-v1 #dashboard .kid-progress {
  display: block;
  height: 12px;
  min-width: 90px;
  border-radius: 999px;
  background: #e7ddff;
  overflow: hidden;
}

body.fcc-app-shell-v1 #dashboard .kid-progress-bar {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--kid-purple), var(--kid-pink), var(--kid-gold));
}

body.fcc-app-shell-v1 #dashboard .kid-reward-item {
  grid-template-columns: auto minmax(0, 1fr) auto;
}

body.fcc-app-shell-v1 #dashboard .kid-reward-item .kid-progress {
  grid-column: 1 / -1;
}

body.fcc-app-shell-v1 #dashboard .kid-reward-icon {
  font-size: 1.8rem;
}

body.fcc-app-shell-v1 #dashboard .kid-onix-card {
  background: linear-gradient(135deg, rgba(124, 58, 237, 0.14), rgba(255, 255, 255, 0.92));
}

body.fcc-app-shell-v1 #dashboard .kid-onix-prompts {
  display: grid;
  gap: 10px;
}

body.fcc-app-shell-v1 #dashboard .kid-onix-prompts button {
  background: #fff;
  color: var(--kid-purple);
  box-shadow: 0 8px 22px rgba(76, 53, 133, 0.12);
  text-align: left;
}

body.fcc-app-shell-v1 #dashboard .kid-message-preview {
  padding: 14px;
  border-radius: 20px;
  background: #eff8ff;
}

body.fcc-app-shell-v1 #dashboard .kid-message-preview p {
  margin: 6px 0;
  font-weight: 850;
}

body.fcc-app-shell-v1 #dashboard .kid-empty-state {
  display: block;
  padding: 14px;
  border-radius: 18px;
  background: #f8f4ff;
  color: var(--kid-muted);
  font-weight: 800;
}

body.fcc-app-shell-v1 #dashboard .kid-encouragement-card {
  display: grid;
  place-items: center;
  text-align: center;
  background: linear-gradient(135deg, #fff, #fff4cf);
}

body.fcc-app-shell-v1 #dashboard .kid-encouragement-orb {
  display: grid;
  place-items: center;
  width: 88px;
  height: 88px;
  margin-bottom: 12px;
  border-radius: 999px;
  background: #fff1b8;
  font-size: 3rem;
}

body.fcc-app-shell-v1 #dashboard .kid-encouragement-card p {
  margin: 0;
  color: var(--kid-ink);
  font-size: 1.08rem;
  font-weight: 850;
}

@keyframes kid-card-pop {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 1180px) {
  body.fcc-app-shell-v1 #dashboard .kid-quick-actions,
  body.fcc-app-shell-v1 #dashboard .kid-main-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.fcc-app-shell-v1 #dashboard .kid-card,
  body.fcc-app-shell-v1 #dashboard .kid-today-card,
  body.fcc-app-shell-v1 #dashboard .kid-chores-card,
  body.fcc-app-shell-v1 #dashboard .kid-points-card,
  body.fcc-app-shell-v1 #dashboard .kid-rewards-card,
  body.fcc-app-shell-v1 #dashboard .kid-onix-card,
  body.fcc-app-shell-v1 #dashboard .kid-message-card,
  body.fcc-app-shell-v1 #dashboard .kid-encouragement-card {
    grid-column: auto;
  }
}

@media (max-width: 760px) {
  body.fcc-app-shell-v1 #dashboard .fcc-kid-dashboard {
    padding: 14px;
    border-radius: 0;
  }

  body.fcc-app-shell-v1 #dashboard .kid-hero-card,
  body.fcc-app-shell-v1 #dashboard .kid-quick-actions,
  body.fcc-app-shell-v1 #dashboard .kid-main-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  body.fcc-app-shell-v1 #dashboard .kid-hero-card {
    min-height: 0;
    padding: 22px;
  }

  body.fcc-app-shell-v1 #dashboard .kid-quick-actions {
    padding: 12px;
  }

  body.fcc-app-shell-v1 #dashboard .kid-action-btn {
    min-height: 64px;
  }

  body.fcc-app-shell-v1 #dashboard .kid-chore-item,
  body.fcc-app-shell-v1 #dashboard .kid-reward-item {
    grid-template-columns: minmax(0, 1fr);
  }

  body.fcc-app-shell-v1 #dashboard .kid-primary-cta {
    width: 100%;
  }
}

/* ─── Avatar tap-to-edit button ──────────────────────────────────────────── */

body.fcc-app-shell-v1 #dashboard .kid-avatar-tap-btn {
  display: contents; /* pass-through so layout is unchanged */
  border: 0;
  background: none;
  padding: 0;
  cursor: pointer;
}
body.fcc-app-shell-v1 #dashboard .kid-avatar-tap-btn:focus-visible .kid-avatar-frame {
  outline: 3px solid #7c3aed;
  outline-offset: 4px;
}
body.fcc-app-shell-v1 #dashboard .kid-avatar-tap-btn:hover .kid-avatar-frame {
  box-shadow: 0 18px 42px rgba(84,57,156,0.35), 0 0 0 4px rgba(124,58,237,0.22);
  transform: scale(1.03);
  transition: transform 180ms ease, box-shadow 180ms ease;
}

/* ─── Theme: Choose Style Button ──────────────────────────────────────────── */

body.fcc-app-shell-v1 #dashboard .kid-choose-theme-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 14px;
  padding: 8px 16px;
  border: 0;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.55);
  box-shadow: 0 4px 14px rgba(76, 53, 133, 0.12);
  color: var(--kid-ink, #2f2563);
  font-size: 0.85rem;
  font-weight: 850;
  cursor: pointer;
  transition: background 160ms ease, transform 140ms ease;
}
body.fcc-app-shell-v1 #dashboard .kid-choose-theme-btn:hover {
  background: rgba(255, 255, 255, 0.82);
  transform: translateY(-1px);
}

/* ─── Hero Card: Per-Theme Modifier Classes ───────────────────────────────── */

/* Base: hero card theme modifier overrides the default bg + pseudo */
body.fcc-app-shell-v1 #dashboard .kid-hero-card[class*="fcc-kid-hero--"] {
  transition: background 400ms ease;
}

/* MAGICAL (default – no override needed, inherits base styles) */
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--magical .kid-eyebrow { color: #7655c7; }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--magical h1              { color: #6d28d9; }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--magical .kid-hero-subtitle { color: #746d9a; }

/* SPACE */
body.fcc-app-shell-v1 #dashboard .fcc-kid-dashboard--space {
  background:
    radial-gradient(circle at 18% 12%, rgba(99,102,241,0.28), transparent 34%),
    radial-gradient(circle at 88% 8%, rgba(139,92,246,0.22), transparent 30%),
    linear-gradient(135deg, #0d1117 0%, #0f172a 50%, #1e1b4b 100%);
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--space {
  background:
    linear-gradient(120deg, rgba(15,12,41,0.96), rgba(25,23,71,0.9)),
    linear-gradient(135deg, #0f0c29, #302b63);
  border-color: rgba(99,102,241,0.45);
  box-shadow: 0 24px 70px rgba(67,56,202,0.35);
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--space::after {
  background:
    radial-gradient(circle, rgba(255,255,255,0.08) 0 34%, transparent 35%),
    conic-gradient(from 180deg, rgba(99,102,241,0.45), rgba(34,211,238,0.4), rgba(139,92,246,0.4), rgba(99,102,241,0.45));
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--space .kid-eyebrow       { color: rgba(165,180,252,0.9); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--space h1                  { color: #ffffff; }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--space .kid-hero-subtitle  { color: rgba(255,255,255,0.8); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--space .kid-avatar-frame   { background: linear-gradient(135deg,#1e1b4b,#312e81); border-color: rgba(165,180,252,0.5); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--space .kid-avatar-spark   { background: rgba(99,102,241,0.28); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--space .kid-choose-theme-btn { background: rgba(99,102,241,0.22); color: #c7d2fe; }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--space .kid-choose-theme-btn:hover { background: rgba(99,102,241,0.38); }

/* SPORTS */
body.fcc-app-shell-v1 #dashboard .fcc-kid-dashboard--sports {
  background:
    radial-gradient(circle at 25% 15%, rgba(74,222,128,0.22), transparent 38%),
    radial-gradient(circle at 80% 85%, rgba(21,128,61,0.18), transparent 32%),
    linear-gradient(135deg, #052e16 0%, #14532d 55%, #166534 100%);
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--sports {
  background: linear-gradient(120deg, rgba(22,101,52,0.95), rgba(5,46,22,0.9));
  border-color: rgba(74,222,128,0.4);
  box-shadow: 0 24px 70px rgba(21,128,61,0.3);
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--sports::after {
  background:
    radial-gradient(circle, rgba(255,255,255,0.08) 0 34%, transparent 35%),
    conic-gradient(from 90deg, rgba(74,222,128,0.45), rgba(187,247,208,0.4), rgba(74,222,128,0.45));
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--sports .kid-eyebrow      { color: rgba(187,247,208,0.9); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--sports h1                 { color: #ffffff; }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--sports .kid-hero-subtitle { color: rgba(255,255,255,0.85); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--sports .kid-avatar-frame  { background: linear-gradient(135deg,#14532d,#166534); border-color: rgba(134,239,172,0.5); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--sports .kid-avatar-spark  { background: rgba(74,222,128,0.28); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--sports .kid-choose-theme-btn { background: rgba(74,222,128,0.2); color: #bbf7d0; }

/* GAMER */
body.fcc-app-shell-v1 #dashboard .fcc-kid-dashboard--gamer {
  background:
    radial-gradient(circle at 15% 20%, rgba(139,92,246,0.3), transparent 36%),
    radial-gradient(circle at 85% 10%, rgba(167,139,250,0.22), transparent 30%),
    linear-gradient(135deg, #0d0d1a 0%, #1a1040 55%, #251550 100%);
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--gamer {
  background: linear-gradient(120deg, rgba(30,14,80,0.96), rgba(18,10,60,0.92));
  border-color: rgba(139,92,246,0.5);
  box-shadow: 0 24px 70px rgba(109,40,217,0.38);
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--gamer::after {
  background:
    radial-gradient(circle, rgba(255,255,255,0.06) 0 34%, transparent 35%),
    conic-gradient(from 200deg, rgba(139,92,246,0.5), rgba(167,139,250,0.4), rgba(99,102,241,0.45), rgba(139,92,246,0.5));
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--gamer .kid-eyebrow       { color: rgba(216,180,254,0.9); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--gamer h1                  { color: #ffffff; }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--gamer .kid-hero-subtitle  { color: rgba(255,255,255,0.82); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--gamer .kid-avatar-frame   { background: linear-gradient(135deg,#312e81,#4c1d95); border-color: rgba(167,139,250,0.5); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--gamer .kid-avatar-spark   { background: rgba(139,92,246,0.3); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--gamer .kid-choose-theme-btn { background: rgba(139,92,246,0.22); color: #ddd6fe; }

/* DINO */
body.fcc-app-shell-v1 #dashboard .fcc-kid-dashboard--dino {
  background:
    radial-gradient(circle at 20% 18%, rgba(134,239,172,0.2), transparent 36%),
    linear-gradient(135deg, #052e16 0%, #14532d 60%, #15803d 100%);
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--dino {
  background: linear-gradient(120deg, rgba(5,46,22,0.96), rgba(22,101,52,0.88));
  border-color: rgba(134,239,172,0.4);
  box-shadow: 0 24px 70px rgba(22,163,74,0.28);
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--dino::after {
  background:
    radial-gradient(circle, rgba(255,255,255,0.06) 0 34%, transparent 35%),
    conic-gradient(from 120deg, rgba(134,239,172,0.4), rgba(217,249,157,0.35), rgba(134,239,172,0.4));
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--dino .kid-eyebrow       { color: rgba(187,247,208,0.95); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--dino h1                  { color: #ffffff; }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--dino .kid-hero-subtitle  { color: rgba(255,255,255,0.88); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--dino .kid-avatar-frame   { background: linear-gradient(135deg,#14532d,#052e16); border-color: rgba(134,239,172,0.5); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--dino .kid-avatar-spark   { background: rgba(134,239,172,0.28); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--dino .kid-choose-theme-btn { background: rgba(134,239,172,0.2); color: #bbf7d0; }

/* OCEAN */
body.fcc-app-shell-v1 #dashboard .fcc-kid-dashboard--ocean {
  background:
    radial-gradient(circle at 20% 15%, rgba(125,211,252,0.28), transparent 36%),
    radial-gradient(circle at 85% 80%, rgba(3,105,161,0.22), transparent 32%),
    linear-gradient(135deg, #082f49 0%, #0c4a6e 55%, #0369a1 100%);
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--ocean {
  background: linear-gradient(120deg, rgba(8,47,73,0.96), rgba(12,74,110,0.9));
  border-color: rgba(125,211,252,0.45);
  box-shadow: 0 24px 70px rgba(3,105,161,0.32);
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--ocean::after {
  background:
    radial-gradient(circle, rgba(255,255,255,0.08) 0 34%, transparent 35%),
    conic-gradient(from 180deg, rgba(125,211,252,0.45), rgba(56,189,248,0.4), rgba(14,165,233,0.4), rgba(125,211,252,0.45));
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--ocean .kid-eyebrow       { color: rgba(186,230,253,0.95); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--ocean h1                  { color: #ffffff; }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--ocean .kid-hero-subtitle  { color: rgba(255,255,255,0.87); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--ocean .kid-avatar-frame   { background: linear-gradient(135deg,#075985,#0369a1); border-color: rgba(125,211,252,0.5); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--ocean .kid-avatar-spark   { background: rgba(125,211,252,0.28); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--ocean .kid-choose-theme-btn { background: rgba(125,211,252,0.18); color: #bae6fd; }

/* ART */
body.fcc-app-shell-v1 #dashboard .fcc-kid-dashboard--art {
  background:
    radial-gradient(circle at 18% 12%, rgba(251,191,36,0.25), transparent 32%),
    radial-gradient(circle at 80% 80%, rgba(249,115,22,0.2), transparent 34%),
    radial-gradient(circle at 50% 50%, rgba(167,243,208,0.15), transparent 50%),
    linear-gradient(135deg, #fffbeb 0%, #fff7ed 50%, #fefce8 100%);
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--art {
  background:
    linear-gradient(120deg, rgba(255,255,255,0.88), rgba(255,251,235,0.78)),
    linear-gradient(135deg, rgba(251,191,36,0.2), rgba(249,115,22,0.14));
  border-color: rgba(251,191,36,0.45);
  box-shadow: 0 24px 70px rgba(180,83,9,0.14);
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--art::after {
  background:
    radial-gradient(circle, rgba(255,255,255,0.5) 0 34%, transparent 35%),
    conic-gradient(from 60deg, rgba(251,191,36,0.4), rgba(249,115,22,0.35), rgba(167,243,208,0.3), rgba(251,191,36,0.4));
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--art .kid-eyebrow       { color: #92400e; }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--art h1                  { color: #78350f; }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--art .kid-hero-subtitle  { color: #57534e; }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--art .kid-avatar-frame   { background: linear-gradient(135deg,#fef3c7,#fde68a); border-color: rgba(251,191,36,0.55); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--art .kid-choose-theme-btn { background: rgba(251,191,36,0.22); color: #92400e; }

/* SUPERHERO */
body.fcc-app-shell-v1 #dashboard .fcc-kid-dashboard--superhero {
  background:
    radial-gradient(circle at 15% 20%, rgba(239,68,68,0.28), transparent 36%),
    radial-gradient(circle at 88% 80%, rgba(251,191,36,0.22), transparent 32%),
    linear-gradient(135deg, #1c0505 0%, #450a0a 55%, #7f1d1d 100%);
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--superhero {
  background: linear-gradient(120deg, rgba(127,29,29,0.97), rgba(28,5,5,0.93));
  border-color: rgba(252,165,165,0.4);
  box-shadow: 0 24px 70px rgba(185,28,28,0.35);
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--superhero::after {
  background:
    radial-gradient(circle, rgba(255,255,255,0.07) 0 34%, transparent 35%),
    conic-gradient(from 240deg, rgba(239,68,68,0.5), rgba(251,191,36,0.45), rgba(239,68,68,0.5));
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--superhero .kid-eyebrow       { color: rgba(254,202,202,0.95); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--superhero h1                  { color: #ffffff; }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--superhero .kid-hero-subtitle  { color: rgba(255,255,255,0.88); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--superhero .kid-avatar-frame   { background: linear-gradient(135deg,#7f1d1d,#b91c1c); border-color: rgba(252,165,165,0.5); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--superhero .kid-avatar-spark   { background: rgba(239,68,68,0.28); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--superhero .kid-choose-theme-btn { background: rgba(239,68,68,0.2); color: #fca5a5; }

/* ANIMALS */
body.fcc-app-shell-v1 #dashboard .fcc-kid-dashboard--animals {
  background:
    radial-gradient(circle at 20% 15%, rgba(251,191,36,0.22), transparent 34%),
    radial-gradient(circle at 80% 75%, rgba(217,249,157,0.2), transparent 36%),
    linear-gradient(135deg, #fefce8 0%, #f0fdf4 50%, #fef9c3 100%);
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--animals {
  background:
    linear-gradient(120deg, rgba(255,255,255,0.88), rgba(254,252,232,0.78)),
    linear-gradient(135deg, rgba(251,191,36,0.18), rgba(217,249,157,0.14));
  border-color: rgba(251,191,36,0.42);
  box-shadow: 0 24px 70px rgba(146,64,14,0.13);
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--animals::after {
  background:
    radial-gradient(circle, rgba(255,255,255,0.48) 0 34%, transparent 35%),
    conic-gradient(from 30deg, rgba(251,191,36,0.38), rgba(217,249,157,0.35), rgba(252,211,77,0.32), rgba(251,191,36,0.38));
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--animals .kid-eyebrow       { color: #92400e; }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--animals h1                  { color: #78350f; }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--animals .kid-hero-subtitle  { color: #57534e; }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--animals .kid-avatar-frame   { background: linear-gradient(135deg,#fef3c7,#d9f99d); border-color: rgba(251,191,36,0.5); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--animals .kid-choose-theme-btn { background: rgba(251,191,36,0.22); color: #92400e; }

/* PRINCESS */
body.fcc-app-shell-v1 #dashboard .fcc-kid-dashboard--princess {
  background:
    radial-gradient(circle at 18% 12%, rgba(244,114,182,0.28), transparent 34%),
    radial-gradient(circle at 85% 80%, rgba(251,207,232,0.3), transparent 36%),
    linear-gradient(135deg, #fff1f5 0%, #fce7f3 50%, #fdf2f8 100%);
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--princess {
  background:
    linear-gradient(120deg, rgba(255,255,255,0.88), rgba(252,231,243,0.78)),
    linear-gradient(135deg, rgba(244,114,182,0.2), rgba(251,207,232,0.14));
  border-color: rgba(244,114,182,0.42);
  box-shadow: 0 24px 70px rgba(190,24,93,0.15);
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--princess::after {
  background:
    radial-gradient(circle, rgba(255,255,255,0.5) 0 34%, transparent 35%),
    conic-gradient(from 300deg, rgba(244,114,182,0.45), rgba(251,207,232,0.4), rgba(216,180,254,0.38), rgba(244,114,182,0.45));
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--princess .kid-eyebrow       { color: #be185d; }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--princess h1                  { color: #9d174d; }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--princess .kid-hero-subtitle  { color: #be185d; }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--princess .kid-avatar-frame   { background: linear-gradient(135deg,#fce7f3,#fbcfe8); border-color: rgba(244,114,182,0.55); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--princess .kid-choose-theme-btn { background: rgba(244,114,182,0.2); color: #be185d; }

/* MINIMAL */
body.fcc-app-shell-v1 #dashboard .fcc-kid-dashboard--minimal {
  background: linear-gradient(135deg, #f9fafb 0%, #f3f4f6 50%, #ffffff 100%);
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--minimal {
  background:
    linear-gradient(120deg, rgba(255,255,255,0.95), rgba(249,250,251,0.88)),
    linear-gradient(135deg, rgba(156,163,175,0.12), rgba(107,114,128,0.08));
  border-color: rgba(209,213,219,0.8);
  box-shadow: 0 24px 70px rgba(0,0,0,0.07);
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--minimal::after {
  opacity: 0.15;
}
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--minimal .kid-eyebrow       { color: #6b7280; }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--minimal h1                  { color: #111827; }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--minimal .kid-hero-subtitle  { color: #6b7280; }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--minimal .kid-avatar-frame   { background: linear-gradient(135deg,#f3f4f6,#e5e7eb); border-color: rgba(209,213,219,0.8); }
body.fcc-app-shell-v1 #dashboard .fcc-kid-hero--minimal .kid-choose-theme-btn { background: rgba(107,114,128,0.12); color: #374151; }

/* ─── Theme Picker Modal ──────────────────────────────────────────────────── */

.fcc-kid-theme-picker {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 240ms ease;
}
.fcc-kid-theme-picker--visible {
  opacity: 1;
  pointer-events: auto;
}
.fcc-kid-theme-picker__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 12, 41, 0.55);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.fcc-kid-theme-picker__panel {
  position: relative;
  z-index: 1;
  width: min(92vw, 680px);
  max-height: 88vh;
  overflow-y: auto;
  padding: clamp(22px, 4vw, 40px);
  border: 1px solid rgba(255,255,255,0.7);
  border-radius: 32px;
  background: linear-gradient(135deg, rgba(255,255,255,0.97), rgba(245,240,255,0.96));
  box-shadow: 0 32px 80px rgba(76,53,133,0.25), 0 0 0 1px rgba(124,58,237,0.08);
  transform: translateY(14px) scale(0.98);
  transition: transform 260ms ease;
}
.fcc-kid-theme-picker--visible .fcc-kid-theme-picker__panel {
  transform: translateY(0) scale(1);
}
.fcc-kid-theme-picker__close {
  position: absolute;
  top: 18px;
  right: 20px;
  width: 38px;
  height: 38px;
  border: 0;
  border-radius: 999px;
  background: rgba(124,58,237,0.1);
  color: #6d28d9;
  font-size: 1rem;
  font-weight: 900;
  cursor: pointer;
  transition: background 150ms ease;
}
.fcc-kid-theme-picker__close:hover { background: rgba(124,58,237,0.2); }
.fcc-kid-theme-picker__title {
  margin: 0 0 6px;
  font-size: clamp(1.3rem, 3vw, 1.8rem);
  font-weight: 950;
  color: #2f2563;
}
.fcc-kid-theme-picker__subtitle {
  margin: 0 0 24px;
  color: #746d9a;
  font-size: 1rem;
  font-weight: 700;
}
.fcc-kid-theme-picker__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 14px;
}

/* Theme card */
.fcc-kid-theme-card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 100px;
  padding: 16px 12px;
  border: 2px solid transparent;
  border-radius: 22px;
  background: #f3f4f6;
  cursor: pointer;
  font-weight: 850;
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}
.fcc-kid-theme-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 30px rgba(76,53,133,0.18);
}
.fcc-kid-theme-card__icon { font-size: 2.2rem; line-height: 1; }
.fcc-kid-theme-card__label { font-size: 0.82rem; font-weight: 850; color: #2f2563; }
.fcc-kid-theme-card__check {
  position: absolute;
  top: 8px;
  right: 10px;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  background: #7c3aed;
  color: #fff;
  font-size: 0.75rem;
  font-weight: 900;
  display: grid;
  place-items: center;
}
.fcc-kid-theme-card--active {
  border-color: #7c3aed;
  box-shadow: 0 0 0 3px rgba(124,58,237,0.18);
}

/* Per-card background accents */
.fcc-kid-theme-card--magical   { background: linear-gradient(135deg,#ede9fe,#fce7f3); }
.fcc-kid-theme-card--space     { background: linear-gradient(135deg,#e0e7ff,#c7d2fe); }
.fcc-kid-theme-card--sports    { background: linear-gradient(135deg,#dcfce7,#bbf7d0); }
.fcc-kid-theme-card--gamer     { background: linear-gradient(135deg,#ede9fe,#ddd6fe); }
.fcc-kid-theme-card--dino      { background: linear-gradient(135deg,#d1fae5,#a7f3d0); }
.fcc-kid-theme-card--ocean     { background: linear-gradient(135deg,#e0f2fe,#bae6fd); }
.fcc-kid-theme-card--art       { background: linear-gradient(135deg,#fef9c3,#fed7aa); }
.fcc-kid-theme-card--superhero { background: linear-gradient(135deg,#fee2e2,#fecaca); }
.fcc-kid-theme-card--animals   { background: linear-gradient(135deg,#fef9c3,#d9f99d); }
.fcc-kid-theme-card--princess  { background: linear-gradient(135deg,#fce7f3,#fbcfe8); }
.fcc-kid-theme-card--minimal   { background: linear-gradient(135deg,#f9fafb,#f3f4f6); }
.fcc-kid-theme-card--surprise  { background: linear-gradient(135deg,#f0e6ff,#e0f2fe,#dcfce7); }

/* ─── Surprise / Toast ────────────────────────────────────────────────────── */

.fcc-kid-theme-toast {
  position: fixed;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%) translateY(16px);
  z-index: 10000;
  padding: 14px 24px;
  border-radius: 999px;
  background: linear-gradient(135deg,#7c3aed,#a855f7);
  color: #fff;
  font-size: 1rem;
  font-weight: 900;
  box-shadow: 0 12px 36px rgba(76,53,133,0.28);
  opacity: 0;
  transition: opacity 300ms ease, transform 300ms ease;
  pointer-events: none;
  white-space: nowrap;
}
.fcc-kid-theme-toast--visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

@media (max-width: 560px) {
  .fcc-kid-theme-picker__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .fcc-kid-theme-card { min-height: 82px; }
  .fcc-kid-theme-toast { font-size: 0.88rem; padding: 12px 18px; white-space: normal; text-align: center; max-width: 85vw; }
}
