
:root{
  --bg:#f8efe6; --peach:#ffe4d6; --pink:#ffb7d5; --pink-strong:#ff4fa3;
  --sage:#d8ead7; --cream:#fff9f5; --text:#5b4b53; --text-soft:#7b6b73;
  --shadow:0 12px 30px rgba(205, 137, 156, 0.12); --radius:24px;
}
*{box-sizing:border-box} html,body{margin:0;padding:0}
body{font-family:"Nunito",system-ui,sans-serif;background:linear-gradient(180deg,#fff7f2 0%,#fdf3ee 40%,#f7efe8 100%);color:var(--text);min-height:100vh}
.bg-blobs{position:fixed;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.blob{position:absolute;border-radius:999px;filter:blur(40px);opacity:.5}
.blob-1{width:260px;height:260px;background:#ffd5e7;top:40px;left:-60px}
.blob-2{width:320px;height:320px;background:#ffe2d1;top:180px;right:-90px}
.blob-3{width:280px;height:280px;background:#dff0dd;bottom:-70px;left:25%}
.topbar,.shell{position:relative;z-index:1}
.topbar{display:flex;justify-content:space-between;align-items:center;padding:22px 28px 8px}
.brand{display:flex;align-items:center;gap:16px}
.mascot{width:62px;height:62px;border-radius:18px;display:grid;place-items:center;background:linear-gradient(135deg,#ffd0e3,#ffe9de);box-shadow:var(--shadow);font-size:32px}
.eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;color:var(--text-soft);margin:0 0 4px;font-weight:800}
h1,h2,h3,h4{font-family:"Fredoka","Nunito",sans-serif;margin:0 0 10px} h1{font-size:2rem} h2{font-size:1.55rem} h3{font-size:1.1rem} h4{font-size:1rem}
p{line-height:1.65;margin:.35rem 0 0} code{background:#fff1f7;padding:.1rem .4rem;border-radius:8px;color:#9b3f6a}
.shell{display:grid;grid-template-columns:320px 1fr;gap:22px;padding:16px 24px 28px}
.sidebar,.content{display:flex;flex-direction:column;gap:18px}
.card{background:rgba(255,255,255,.86);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.7);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}
.soft{background:rgba(255,250,247,.92)} .gradient{background:linear-gradient(135deg,#ffe7ef 0%,#ffe9db 45%,#eef8eb 100%)}
.level-chip{display:flex;justify-content:space-between;align-items:center;background:#fff7f4;border-radius:18px;padding:12px 14px;margin-bottom:16px}
.level-chip span{color:var(--text-soft);font-size:.9rem}
.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-weight:700;color:var(--text-soft)}
.progress-bar{height:16px;background:#f3e1d8;border-radius:999px;overflow:hidden}
#progressFill{height:100%;width:0%;background:linear-gradient(90deg,var(--pink-strong),var(--pink),#ffddb1);border-radius:999px;transition:width .4s ease}
.xp-box{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px}
.xp-box>div{background:#fff7f4;border-radius:18px;padding:12px 14px}
.tiny-label{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-soft);margin:0;font-weight:800}
.nav{display:flex;flex-direction:column;gap:10px}
.nav-btn,.pill,.primary-btn,.secondary-btn{border:none;cursor:pointer;font-family:"Nunito",sans-serif;font-weight:800}
.nav-btn{text-align:left;padding:14px 16px;border-radius:16px;background:#fff6f9;color:var(--text);transition:.2s ease}
.nav-btn.active{background:linear-gradient(135deg,#ff93c3,#ffbddb);color:white}
.pill{padding:12px 16px;border-radius:999px;background:#fff1f7;color:#a34876}
.tip-box{background:linear-gradient(135deg,#eef8eb,#fff8f0)} .tip-title{font-weight:900;margin-bottom:8px}
.content .view{display:none} .content .view.active{display:block}
.hero{display:grid;grid-template-columns:1.35fr .8fr;gap:20px;align-items:center}
.hero-copy{max-width:60ch;color:var(--text-soft)}
.hero-stats{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.mini-stat{min-width:110px;background:rgba(255,255,255,.62);border-radius:18px;padding:12px 14px}
.mini-stat span{display:block;color:var(--text-soft);font-size:.84rem}
.hero-mascot{display:flex;justify-content:flex-end}
.mascot-card{width:180px;min-height:180px;border-radius:26px;background:rgba(255,255,255,.62);display:grid;place-items:center;text-align:center;padding:14px}
.mascot-big{font-size:68px}
.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}
.reward-card{background:#fff7f1;border:1px dashed #f0b4c8;border-radius:20px;padding:16px}
.section-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}
.section-head.compact{margin-bottom:8px}
.tag{background:#fff2f7;color:#a04e76;padding:8px 12px;border-radius:999px;font-size:.84rem;font-weight:800}
.muted{color:var(--text-soft)}
.mission-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:18px}
.quest-columns{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}
.mini-card{background:#fff9f5;border-radius:22px;padding:16px;border:1px solid #f8e6dd}
.mini-card.large{padding:18px}
.icon-list,#outputList,#stepsList{margin:.2rem 0 0 1.1rem;padding:0}
.hidden-box{margin-top:8px;padding:14px;border-radius:16px;background:#fff2f7;display:none}
.hidden-box.show{display:block}
.cta-row{display:flex;gap:12px;margin-top:18px;flex-wrap:wrap}
.primary-btn{background:linear-gradient(135deg,var(--pink-strong),#ff87bf);color:#fff;padding:14px 18px;border-radius:16px;box-shadow:var(--shadow)}
.secondary-btn{background:#eef8eb;color:#58725f;padding:14px 18px;border-radius:16px}
.primary-btn:disabled,.secondary-btn:disabled,.pill:disabled{opacity:.5;cursor:not-allowed}
.level-map{display:grid;gap:18px}
.level-card{border-radius:24px;padding:18px;background:#fffaf6;border:1px solid #f2e2da}
.level-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px}
.day-nodes{display:grid;grid-template-columns:repeat(auto-fill,minmax(94px,1fr));gap:10px}
.day-node{border:none;padding:12px 10px;border-radius:16px;font-weight:800;cursor:pointer}
.day-node.locked{background:#f0ece8;color:#a8979b}
.day-node.current{background:linear-gradient(135deg,#ffc0db,#ffdacc);color:#7a4d63}
.day-node.done{background:linear-gradient(135deg,#dff0dd,#bfe1c7);color:#4a6b55}
.achievement-grid,.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.achievement-card,.project-card{border-radius:22px;padding:18px;background:#fffaf6;border:1px solid #f1e4dd}
.achievement-card.locked{opacity:.62}
.achievement-icon{font-size:28px;margin-bottom:10px}
.project-card ul{margin:.4rem 0 0 1rem}
.toast{position:fixed;right:20px;bottom:20px;max-width:360px;background:#fff7fa;border:1px solid #ffd4e7;color:#8d4d6d;box-shadow:var(--shadow);padding:14px 16px;border-radius:18px;transform:translateY(18px);opacity:0;pointer-events:none;transition:.25s ease;z-index:30}
.toast.show{transform:translateY(0);opacity:1}
@media (max-width:980px){.shell{grid-template-columns:1fr}.hero,.dashboard-grid,.mission-grid,.quest-columns{grid-template-columns:1fr}.hero-mascot{justify-content:flex-start}}
