:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:#1f2937;background-color:#f5f7fb;line-height:1.5}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:linear-gradient(180deg,#f8fbff,#eef2ff)}#root{min-height:100vh}.page-shell{width:min(760px,92%);margin:0 auto;padding:2rem 0 3rem}.page-header{position:relative;margin-bottom:1rem;padding:1.7rem 1.5rem 1.35rem 14.75rem;background:linear-gradient(135deg,#fff,#eef4ff);border:1px solid #dbeafe;border-radius:18px;box-shadow:0 12px 30px #2563eb1f;overflow:visible}.page-header-copy{position:relative;z-index:1}.brand-title{display:flex;align-items:center;justify-content:flex-start;gap:.65rem}.hero-sparky-peek{position:absolute;left:.4rem;top:50%;transform:translateY(-50%);width:225px;max-width:38vw;height:auto;object-fit:contain;filter:drop-shadow(0 18px 28px rgba(22,101,52,.22));pointer-events:none}.page-header h1{margin:0;color:#1d4ed8;font-size:2.2rem}.page-header p{margin-top:.4rem;color:#4b5563}.install-link-row{margin-top:.3rem}.install-link-row a{color:#1d4ed8;font-weight:600;text-decoration:none}.install-link-row a:hover{text-decoration:underline}.card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:1.25rem;box-shadow:0 10px 25px #1e40af12;margin-bottom:1rem}label{display:block;margin-top:.85rem;margin-bottom:.35rem;font-weight:600}input,textarea,select,button{width:100%;font:inherit}input,textarea,select{border:1px solid #d1d5db;border-radius:10px;padding:.65rem .75rem;background:#fff}button{margin-top:1rem;border:none;border-radius:10px;padding:.75rem .9rem;background-color:#2563eb;color:#fff;font-weight:700;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.7}.story-sections{display:grid;gap:.8rem}.story-section{border:1px solid #e5e7eb;border-radius:10px;padding:.85rem;background:#f9faff}.story-section h3{margin:0 0 .35rem;color:#1e3a8a;font-size:1rem}.story-section p{margin:0}.progress-text{margin-top:0;margin-bottom:.45rem;color:#1e3a8a;font-weight:700}.quest-type-text{margin-top:0;margin-bottom:.35rem;color:#334155;font-size:.95rem;text-transform:capitalize}.progress-track{width:100%;height:10px;border-radius:999px;background:#dbeafe;margin-bottom:.9rem;overflow:hidden}.progress-fill{height:100%;background:#2563eb;transition:width .22s ease}.challenge-word{margin-top:0;margin-bottom:.6rem;font-size:1.1rem;font-weight:700;color:#1d4ed8}.word-highlight{background:#fde68a;padding:0 .15rem;border-radius:4px}.feedback-text{margin-bottom:0;font-weight:600}.feedback-text.success{color:#14532d}.feedback-text.error{color:#b91c1c}.completion-text{margin-top:0;margin-bottom:.8rem;color:#1e3a8a;font-weight:700}.completion-panel{border:1px solid #bfdbfe;background:#eff6ff;border-radius:12px;padding:.9rem;margin-top:.7rem}.completion-reward{text-align:center;padding-bottom:.75rem}.completion-star{font-size:2.5rem;line-height:1;margin-bottom:.25rem}.completion-title{margin:0 0 .3rem;color:#1e3a8a;font-size:1.35rem}.completion-name{margin:0 0 .15rem;font-size:1.05rem;color:#1d4ed8;font-weight:700}.completion-story-name{margin:0 0 .4rem;color:#334155;font-size:.9rem;font-style:italic}.completion-xp{display:inline-block;background:#16a34a;color:#fff;font-size:.95rem;font-weight:700;padding:.3rem .9rem;border-radius:999px;margin-bottom:.6rem}.hearts-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;flex-wrap:wrap}.hearts-label{font-size:.9rem;font-weight:600;color:#1e3a8a}.hearts-display{font-size:1.15rem;letter-spacing:.05rem}.xp-badge{margin-left:auto;background:#16a34a;color:#fff;font-size:.8rem;font-weight:700;padding:.2rem .55rem;border-radius:999px}.secondary-button{background:#0f172a}.secondary-button .btn-sparky-icon{width:24px;height:24px;object-fit:cover;border-radius:50%;vertical-align:middle;margin-right:6px}.letter-boxes{display:flex;gap:6px;justify-content:center;flex-wrap:wrap;margin:10px 0 14px}.letter-box{width:42px;height:42px;border:2px solid #d1d5db;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;background:#fff}.letter-box-revealed{border-color:#16a34a;background:#dcfce7;color:#15803d}.letter-box-space{width:18px}.choice-prompt{font-weight:600;margin-bottom:4px;color:#374151}.choice-buttons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin:12px 0}.choice-button{padding:16px 28px;font-size:1.15rem;font-weight:700;border:2.5px solid #7c3aed;border-radius:14px;background:#fff;color:#7c3aed;cursor:pointer;min-width:110px;transition:background .15s,color .15s}.choice-button:hover,.choice-button:active{background:#7c3aed;color:#fff}.loading-text{margin:0;color:#1e3a8a;font-weight:600}.error-card{border-color:#fecaca;background:#fff1f2}.error-text{color:#b91c1c;margin-top:.75rem;margin-bottom:0}@media(max-width:640px){.page-header{padding:10rem 1rem 1rem;text-align:center}.page-header-copy{position:static}.brand-title{justify-content:center}.hero-sparky-peek{left:50%;bottom:auto;top:-1.1rem;transform:translate(-50%);width:210px;max-width:62vw}.page-header h1{font-size:1.9rem}.card{padding:1rem}}
