/* ── POTG Learning World — styles (POTG green theme) ── */
@import url('https://fonts.googleapis.com/css2?family=Baloo+2:wght@500;600;700;800&family=Nunito:wght@400;500;600;700&display=swap');

:root {
  --green:     #2f6b34;
  --green-dk:  #1d4a22;
  --green-md:  #3d8c44;
  --green-lt:  #eaf3e2;
  --green-soft:#f2f8ee;
  --cream:     #FAFAF7;
  --white:     #ffffff;
  --ink:       #2a2a2a;
  --ink-soft:  #555;
  --ink-faint: #999;
  --amber:     #E8963A;
  --amber-lt:  #FFF5E6;
  --coral:     #E8705A;
  --coral-lt:  #FFF0EE;
  --teal:      #3AABCC;
  --teal-lt:   #E8F7FB;
  --purple:    #8B6FCF;
  --purple-lt: #F2EEFF;
  --coin:      #D4A017;
  --success:   #3DAF73;
  --danger:    #E05C45;
  --r-sm:  12px;
  --r-md:  20px;
  --r-lg:  32px;
  --r-xl:  48px;
  --sh:    0 4px 20px rgba(0,0,0,.07);
  --sh-hover: 0 8px 32px rgba(0,0,0,.13);
  --trans: all .22s cubic-bezier(.4,0,.2,1);
}

*, *::before, *::after { box-sizing: border-box; margin:0; padding:0; }
html { font-size:16px; -webkit-text-size-adjust:100%; }
body {
  font-family: 'Nunito', system-ui, sans-serif;
  background: var(--green-soft);
  color: var(--ink);
  min-height:100vh;
  overflow-x:hidden;
}
/* While intro is showing, make entire browser background forest green */
body.on-intro { background: #0d2b10; }

/* ── Screens ── */
.screen { display:none; min-height:100vh; flex-direction:column; }
.screen.active { display:flex; }

/* ── Global header (kept for non-home screens) ── */
.g-header {
  background: var(--green);
  color: #fff;
  padding: 12px 20px;
  display: flex; align-items:center; gap:12px;
  position:sticky; top:0; z-index:100;
  box-shadow: 0 2px 12px rgba(0,0,0,.2);
}
.g-header .brand { font-family:'Baloo 2'; font-size:1rem; font-weight:700; flex:1; }
.g-header .brand span { font-size:.72rem; opacity:.8; display:block; font-weight:500; }
.g-stat { display:flex; align-items:center; gap:4px; background:rgba(255,255,255,.15); border-radius:20px; padding:4px 10px; font-size:.82rem; font-weight:700; }
.g-stat .sv { color:#fff; }
#sound-btn { background:transparent; border:none; color:#fff; font-size:1.1rem; cursor:pointer; padding:4px; }

/* ── Premium home header ── */
.home-header {
  background: linear-gradient(135deg, var(--green-dk) 0%, var(--green) 100%);
  color:#fff; padding:11px 16px;
  display:flex; align-items:center; gap:10px;
  position:sticky; top:0; z-index:100;
  box-shadow:0 3px 16px rgba(0,0,0,.25);
}
.hh-brand { display:flex; align-items:center; gap:8px; flex:1; }
.hh-logo { font-size:1.5rem; }
.hh-title { font-family:'Baloo 2'; font-size:1rem; font-weight:800; line-height:1.1; }
.hh-sub { font-size:.62rem; opacity:.75; font-weight:500; }
.hh-stats { display:flex; gap:5px; align-items:center; }
.hh-stat { display:flex; align-items:center; gap:3px; border-radius:14px; padding:4px 8px; font-size:.78rem; font-weight:800; }
.hh-stat.flame { background:rgba(255,120,0,.25); color:#ffb04a; }
.hh-stat.star  { background:rgba(255,220,0,.2);  color:#ffe066; }
.hh-stat.coin  { background:rgba(212,160,23,.3);  color:#ffd04f; }

/* ── Intro video splash ── */
#screen-intro {
  background: linear-gradient(160deg, #0d2b10 0%, #1a4a1a 35%, #2e7d35 70%, #1d5c25 100%);
}
.intro-splash {
  position:absolute; top:0; left:0; right:0; bottom:0; cursor:pointer;
  display:flex; flex-direction:column; z-index:10;
  border:none; background:transparent; padding:0; font:inherit;
  -webkit-appearance:none; appearance:none;
}
.intro-splash-photo {
  position:absolute; top:0; left:0; right:0; bottom:0;
  background:url('../images/guides/rosie.jpg') center center / contain no-repeat;
}
.intro-splash-fade {
  position:absolute; bottom:0; left:0; right:0; height:40%;
  background:linear-gradient(transparent, rgba(0,0,0,.72));
  pointer-events:none;
}
.intro-tap-hint {
  position:absolute; bottom:38px; left:0; right:0; text-align:center;
  color:rgba(255,255,255,.82); font-family:'Nunito'; font-size:.88rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase;
  animation:tapFade 2.2s ease-in-out infinite;
}
@keyframes tapFade { 0%,100%{opacity:.4} 50%{opacity:1} }
.intro-subtitle-box {
  position:absolute; bottom:56px; left:8%; right:8%; z-index:30;
  background:rgba(0,0,0,.72); color:#fff; padding:10px 16px; border-radius:12px;
  font-family:'Nunito'; font-size:1.05rem; font-weight:700; text-align:center;
  line-height:1.45; pointer-events:none;
  text-shadow:0 1px 4px rgba(0,0,0,.5);
}
.intro-skip-btn {
  position:absolute; bottom:28px; right:18px;
  background:rgba(0,0,0,.45); border:1px solid rgba(255,255,255,.4); color:rgba(255,255,255,.85);
  padding:8px 18px; border-radius:20px; font-family:'Nunito'; font-size:.8rem;
  font-weight:700; cursor:pointer; z-index:20;
}
.intro-brand-overlay {
  position:absolute; top:20px; left:18px; display:flex; align-items:center; gap:8px;
  pointer-events:none; z-index:20;
}
.intro-logo { font-size:2rem; filter:drop-shadow(0 2px 6px rgba(0,0,0,.8)); }
.intro-title { font-family:'Baloo 2'; font-size:1.1rem; font-weight:800; color:#fff; text-shadow:0 2px 10px rgba(0,0,0,.8); }
.intro-sub { font-size:.7rem; color:rgba(255,255,255,.85); font-weight:600; text-shadow:0 1px 6px rgba(0,0,0,.8); }

/* ── Workbook Picker screen ── */
#screen-wb-picker { background:#f0f4ee; }
.wbp-body { padding:14px; }
.wbp-intro { font-family:'Baloo 2'; font-size:1.1rem; font-weight:700; color:var(--green-dk); margin-bottom:14px; }
.wbp-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:12px; }
.wbp-card {
  display:flex; flex-direction:column; align-items:flex-start;
  padding:0; border-radius:18px; border:none; cursor:pointer;
  background:var(--wbc); color:#fff; font-family:'Nunito'; text-align:left;
  box-shadow:0 4px 16px rgba(0,0,0,.18); transition:var(--trans);
  overflow:hidden; position:relative; min-height:110px;
}
.wbp-card::after {
  content:'›'; position:absolute; bottom:10px; right:14px;
  font-size:1.4rem; opacity:.6; font-weight:800;
}
.wbp-card:hover { transform:translateY(-3px); box-shadow:0 8px 28px rgba(0,0,0,.25); filter:brightness(1.08); }
.wbp-card-inner { padding:14px 14px 28px; width:100%; box-sizing:border-box; }
.wbp-icon { font-size:1.8rem; line-height:1; margin-bottom:7px; display:block; }
.wbp-card strong { font-size:.92rem; font-weight:800; display:block; line-height:1.2; }
.wbp-card small  { font-size:.68rem; opacity:.82; font-weight:600; line-height:1.4; margin-top:3px; display:block; }
.wbp-all {
  width:100%; padding:16px; border-radius:18px; border:none; cursor:pointer;
  background:linear-gradient(135deg,var(--green-dk),var(--green)); color:#fff;
  font-family:'Baloo 2'; font-size:1rem; font-weight:700;
  box-shadow:0 4px 16px rgba(47,107,52,.3); transition:var(--trans);
}
.wbp-all:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(47,107,52,.4); }

/* ── Free trial pitch screen ── */
.trial-screen { background:linear-gradient(160deg,#0d2b10 0%,#1a4a1a 40%,#2f6b34 100%); padding:0; overflow-y:auto; }
.trial-rosie { position:relative; height:240px; flex-shrink:0; }
.trial-rosie-img { width:100%; height:240px; object-fit:cover; object-position:center 10%; display:block; }
.trial-speech-wrap { position:absolute; bottom:14px; left:12px; right:12px; }
.trial-speech {
  background:rgba(0,0,0,.72); color:#fff; border-radius:16px; padding:12px 16px;
  font-family:'Nunito'; font-size:.88rem; font-weight:700; line-height:1.5;
  backdrop-filter:blur(4px);
}
.trial-card { background:#fff; border-radius:24px 24px 0 0; padding:24px 20px 36px; margin-top:-12px; }
.trial-badge {
  display:inline-block; background:var(--green-soft); color:var(--green-dk);
  border:2px solid var(--green); border-radius:20px; padding:5px 14px;
  font-size:.8rem; font-weight:800; margin-bottom:14px;
}
.trial-heading { font-family:'Baloo 2'; font-size:1.3rem; color:#1a2a1a; margin:0 0 16px; line-height:1.3; }
.trial-perks { list-style:none; padding:0; margin:0 0 16px; display:flex; flex-direction:column; gap:10px; }
.trial-perks li { font-size:.88rem; color:#333; line-height:1.4; font-weight:600; }
.trial-note { font-size:.75rem; color:#888; text-align:center; margin-bottom:18px; line-height:1.5; }
.trial-cta {
  width:100%; padding:18px; background:var(--green); color:#fff; border:none;
  border-radius:var(--r-lg); font-family:'Baloo 2'; font-size:1.1rem; font-weight:800;
  cursor:pointer; transition:var(--trans); margin-bottom:10px; display:block;
}
.trial-cta:hover { background:var(--green-dk); transform:translateY(-2px); }
.trial-skip { display:block; width:100%; background:none; border:2px solid #ddd; border-radius:12px; color:#555; font-family:'Nunito'; font-size:.9rem; font-weight:700; cursor:pointer; text-align:center; padding:11px; margin-top:4px; }
.trial-skip:hover { border-color:#aaa; color:#333; }

/* ── Registration screen ── */
.reg-screen { background:var(--green-soft); overflow-y:auto; }
.reg-rosie-strip {
  display:flex; align-items:center; gap:12px;
  background:var(--green-dk); padding:16px; flex-shrink:0;
}
.reg-rosie-thumb { width:56px; height:56px; border-radius:50%; object-fit:cover; border:3px solid rgba(255,255,255,.4); flex-shrink:0; }
.reg-speech { color:#fff; font-family:'Nunito'; font-size:.88rem; font-weight:700; line-height:1.5; }
.reg-card { padding:20px 16px 36px; }
.reg-heading { font-family:'Baloo 2'; font-size:1.3rem; color:var(--green-dk); margin:0 0 18px; }
.reg-fields { display:flex; flex-direction:column; gap:14px; margin-bottom:14px; }
.reg-label { font-size:.8rem; font-weight:800; color:#555; text-transform:uppercase; letter-spacing:.04em; }
.reg-input {
  display:block; width:100%; padding:14px 16px; border:2px solid #dde8dd;
  border-radius:14px; font-family:'Nunito'; font-size:1rem; font-weight:600;
  background:#fff; box-sizing:border-box; margin-top:4px; outline:none; transition:border-color .15s;
}
.reg-input:focus { border-color:var(--green); }
.reg-age-row { display:flex; flex-wrap:wrap; gap:8px; margin-top:6px; }
.reg-age-btn {
  padding:8px 14px; border-radius:20px; border:2px solid #dde8dd; background:#fff;
  font-family:'Nunito'; font-size:.9rem; font-weight:700; cursor:pointer; transition:all .15s;
}
.reg-age-btn.selected { background:var(--green); color:#fff; border-color:var(--green); }
.reg-privacy { font-size:.72rem; color:#aaa; text-align:center; margin:0 0 16px; line-height:1.5; }
.reg-submit {
  width:100%; padding:18px; background:var(--green); color:#fff; border:none;
  border-radius:var(--r-lg); font-family:'Baloo 2'; font-size:1.1rem; font-weight:800;
  cursor:pointer; transition:var(--trans); margin-bottom:10px; display:block;
}
.reg-submit:hover { background:var(--green-dk); transform:translateY(-2px); }
.reg-skip { display:block; width:100%; background:none; border:none; color:#aaa; font-family:'Nunito'; font-size:.82rem; font-weight:700; cursor:pointer; text-align:center; padding:8px; }

/* ── Age selection (pet creator step 4) ── */
.age-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.age-btn {
  display:flex; flex-direction:column; align-items:center; gap:4px;
  padding:16px 10px; border-radius:18px; border:2.5px solid #e8f0e8; background:#fff;
  cursor:pointer; transition:all .15s; font-family:'Nunito'; text-align:center;
}
.age-btn:hover { border-color:var(--green); background:var(--green-soft); }
.age-btn.selected { border-color:var(--green); background:var(--green-soft); box-shadow:0 0 0 3px rgba(47,107,52,.15); }
.age-emoji { font-size:1.9rem; line-height:1; }
.age-btn strong { font-size:.88rem; font-weight:800; color:var(--green-dk); }
.age-btn span   { font-size:.72rem; color:#777; }

/* ── Profile panel ── */
.hh-profile-btn {
  width:32px; height:32px; border-radius:50%; border:2.5px solid rgba(255,255,255,.7);
  color:#fff; font-weight:800; font-size:.85rem; cursor:pointer;
  font-family:'Baloo 2'; display:flex; align-items:center; justify-content:center;
  flex-shrink:0; transition:transform .15s;
}
.hh-profile-btn:hover { transform:scale(1.1); }
.profile-panel { position:fixed; inset:0; z-index:999; }
.pp-overlay { position:absolute; inset:0; background:rgba(0,0,0,.5); border:none; padding:0; cursor:pointer; -webkit-appearance:none; appearance:none; }
.pp-sheet {
  position:absolute; bottom:0; left:0; right:0;
  background:#fff; border-radius:24px 24px 0 0;
  padding:20px 16px 36px; max-height:82vh; overflow-y:auto;
  box-shadow:0 -8px 40px rgba(0,0,0,.2);
}
.pp-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.pp-header h3 { font-family:'Baloo 2'; font-size:1.1rem; margin:0; color:var(--green-dk); }
.pp-close { background:#f0f0f0; border:none; border-radius:50%; width:32px; height:32px; cursor:pointer; font-size:1rem; display:flex; align-items:center; justify-content:center; }
.pp-list { display:flex; flex-direction:column; gap:10px; margin-bottom:14px; }
.pp-profile-card {
  display:flex; align-items:center; gap:12px;
  padding:14px; border-radius:16px; border:2px solid #eee;
  cursor:pointer; transition:all .15s; background:#fff;
  width:100%; font-family:'Nunito'; text-align:left;
}
.pp-profile-card:hover { border-color:var(--green); background:var(--green-soft); }
.pp-profile-card.active { border-color:var(--green); background:var(--green-soft); }
.pp-avatar {
  width:46px; height:46px; border-radius:50%; color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:1.3rem; font-weight:800; font-family:'Baloo 2'; flex-shrink:0;
}
.pp-profile-info { flex:1; min-width:0; }
.pp-name { font-weight:800; font-size:.95rem; color:#1a2a1a; }
.pp-tick { font-size:.72rem; background:var(--green); color:#fff; border-radius:8px; padding:1px 6px; margin-left:6px; font-weight:700; }
.pp-meta { font-size:.75rem; color:#777; margin-top:2px; }
.pp-stats { font-size:.7rem; color:#999; margin-top:3px; }
.pp-add-btn {
  width:100%; padding:14px; border-radius:16px; border:2px dashed #ccc;
  background:transparent; cursor:pointer; font-family:'Nunito';
  font-weight:700; font-size:.9rem; color:#666; transition:all .15s;
}
.pp-add-btn:hover { border-color:var(--green); color:var(--green); background:var(--green-soft); }

/* ── Workbook Activities section ── */
.wb-section { padding:0 16px 16px; }
.wb-section-hdr {
  display:flex; align-items:baseline; gap:8px;
  font-family:'Baloo 2'; font-size:1.1rem; color:var(--green-dk);
  margin-bottom:12px; padding-left:4px;
}
.wb-count { font-size:.75rem; color:var(--ink-faint); font-weight:500; }
.wb-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.wb-card {
  display:flex; flex-direction:column; align-items:center; gap:6px;
  padding:14px 6px; border:2px solid var(--wc,var(--green-lt)); border-radius:var(--r-md);
  background:#fff; cursor:pointer; transition:var(--trans); font-family:'Nunito';
}
.wb-card:hover { background:var(--wc); border-color:var(--wc); transform:translateY(-2px); box-shadow:var(--sh-hover); }
.wb-card:hover .wb-label { color:#fff; }
.wb-icon  { font-size:1.8rem; line-height:1; }
.wb-label { font-size:.78rem; font-weight:700; color:var(--ink); transition:color .2s; }

/* ── Bottom nav ── */
.bottom-nav {
  position:fixed; bottom:0; left:0; right:0; z-index:90;
  background:#fff; border-top:2px solid var(--green-lt);
  display:flex; align-items:stretch;
  box-shadow: 0 -4px 20px rgba(0,0,0,.08);
}
.bnav-btn {
  flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:3px; padding:10px 4px; border:none; background:transparent; cursor:pointer;
  font-family:'Nunito'; font-size:.7rem; font-weight:700; color:var(--ink-soft);
  transition: var(--trans);
}
.bnav-btn .bn-icon { font-size:1.4rem; line-height:1; }
.bnav-btn.active, .bnav-btn:hover { color:var(--green); }
.bnav-btn.active .bn-icon { transform:scale(1.15); }
.page-body { padding-bottom: 80px; }

/* ─────────────────────────────── PET CREATOR ─────────────────────────────── */
#screen-pet-create { background: var(--green-dk); align-items:center; justify-content:center; }
.pc-wrap {
  background:#fff; border-radius:var(--r-lg); max-width:480px; width:calc(100%-32px);
  padding:28px 24px; margin:20px auto; box-shadow: var(--sh-hover);
}
.pc-top { text-align:center; margin-bottom:20px; }
.pc-top h2 { font-family:'Baloo 2'; font-size:1.5rem; color:var(--green-dk); }
.pc-top p  { color:var(--ink-soft); font-size:.88rem; margin-top:4px; }
.pc-dots { display:flex; gap:6px; justify-content:center; margin:12px 0; }
.pc-dot { width:10px; height:10px; border-radius:50%; background:var(--green-lt); transition:var(--trans); }
.pc-dot.active { background:var(--green); transform:scale(1.2); }
.pc-step { display:none; }
.pc-step.active { display:block; }
.pc-step h3 { font-family:'Baloo 2'; font-size:1.1rem; color:var(--green); margin-bottom:14px; }
.pc-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.pc-choice {
  display:flex; flex-direction:column; align-items:center; gap:4px;
  padding:10px 6px; border:2px solid var(--green-lt); border-radius:var(--r-sm);
  background:#fff; cursor:pointer; font-size:.75rem; font-weight:700; color:var(--ink);
  transition:var(--trans); font-family:'Nunito';
}
.pc-choice:hover { border-color:var(--green-md); background:var(--green-lt); }
.pc-choice.selected { border-color:var(--green); background:var(--green-lt); box-shadow:0 0 0 2px var(--green); }
.pc-emoji { font-size:2rem; line-height:1; }
.pc-name-wrap { margin-top:12px; }
.pc-name-wrap input {
  width:100%; padding:14px 16px; border:2px solid var(--green-lt); border-radius:var(--r-md);
  font-family:'Nunito'; font-size:1rem; color:var(--ink); outline:none; transition:var(--trans);
}
.pc-name-wrap input:focus { border-color:var(--green); }
.pc-preview {
  text-align:center; padding:20px 0;
  display:flex; flex-direction:column; align-items:center; gap:8px;
}
.pc-big-emoji { font-size:5rem; line-height:1; transition:filter .3s; }
.pc-preview-name { font-family:'Baloo 2'; font-size:1.2rem; color:var(--green-dk); }
.pc-nav { display:flex; gap:10px; margin-top:20px; }
.pc-nav button {
  flex:1; padding:14px; border-radius:var(--r-md); border:none; font-family:'Baloo 2';
  font-size:1rem; font-weight:700; cursor:pointer; transition:var(--trans);
}
.pc-nav .pc-back { background:var(--green-lt); color:var(--green-dk); }
.pc-nav .pc-next { background:var(--green); color:#fff; }
.pc-nav .pc-next:hover { background:var(--green-dk); transform:translateY(-2px); }

/* ─────────────────────────────── HOME SCREEN ─────────────────────────────── */
#screen-home { background:#f0f4ee; }
.page-body { padding-bottom:80px; }

/* ── Game card (shared base) ── */
.game-card {
  margin:12px 14px 10px; border-radius:22px; box-shadow:0 6px 28px rgba(0,0,0,.1);
  overflow:hidden; border:2px solid transparent;
}

/* ── Pet Game Card ── */
.pet-game-card {
  background:linear-gradient(140deg,#e8f5ea,#f5f9f2);
  padding:14px 14px 12px; transition:background .5s, border-color .5s;
}
.pgc-top { display:flex; gap:12px; align-items:center; margin-bottom:10px; }
.pgc-left { flex-shrink:0; }
.pgc-right { flex:1; display:flex; flex-direction:column; gap:5px; }
.pgc-name-row { display:flex; align-items:center; gap:7px; }
.pgc-name { font-family:'Baloo 2'; font-size:1.3rem; font-weight:800; color:var(--green-dk); }
.pgc-mood { background:rgba(255,255,255,.8); border-radius:20px; padding:3px 10px; font-size:.78rem; font-weight:700; }
.pgc-coins { font-size:.78rem; font-weight:700; color:#8a5800; background:rgba(212,160,23,.18); border-radius:12px; padding:3px 10px; display:inline-block; margin-top:2px; }

/* Care tip */
.care-tip { display:flex; align-items:center; gap:8px; padding:7px 10px; border-radius:10px; background:rgba(255,255,255,.65); }
.ct-icon { font-size:1.3rem; flex-shrink:0; }
.ct-body { display:flex; flex-direction:column; }
.ct-body strong { font-size:.8rem; font-weight:800; color:var(--ink); line-height:1.2; }
.ct-body span   { font-size:.7rem; color:var(--ink-soft); font-weight:600; }

/* Care strip */
.care-strip { display:grid; grid-template-columns:repeat(4,1fr); gap:7px; }
.care-btn {
  display:flex; flex-direction:column; align-items:center; gap:2px;
  padding:9px 4px 7px; border-radius:14px; border:none; cursor:pointer;
  font-family:'Nunito'; font-size:.7rem; font-weight:800; line-height:1.2;
  transition:var(--trans); color:#fff;
}
.care-btn span { font-size:.7rem; }
.care-btn em   { font-size:.6rem; font-style:normal; opacity:.85; }
.care-btn:hover { transform:translateY(-2px); filter:brightness(1.08); box-shadow:0 4px 12px rgba(0,0,0,.15); }
.care-feed  { background:linear-gradient(135deg,#e05c45,#f08060); }
.care-play  { background:linear-gradient(135deg,#3daf73,#5dd490); }
.care-walk  { background:linear-gradient(135deg,#2f6b34,#4a9a52); }
.care-groom { background:linear-gradient(135deg,#8B6FCF,#b09ae0); }
.care-btn:first-child { font-size:1.3rem; }

/* ── Quest strip ── */
.quests-strip {
  display:flex; align-items:center; gap:8px;
  padding:0 14px 10px; overflow-x:auto; scrollbar-width:none;
}
.quests-strip::-webkit-scrollbar { display:none; }
.qs-label { font-family:'Baloo 2'; font-size:.82rem; font-weight:800; color:var(--green-dk); white-space:nowrap; flex-shrink:0; }
.quest-pills { display:flex; gap:7px; overflow-x:auto; scrollbar-width:none; }
.quest-pills::-webkit-scrollbar { display:none; }
.qpill {
  display:flex; align-items:center; gap:5px; white-space:nowrap;
  padding:6px 12px; border-radius:20px; border:2px solid var(--green-lt);
  background:#fff; font-size:.75rem; font-weight:700; color:var(--ink);
  flex-shrink:0;
}
.qpill em { font-style:normal; color:var(--amber); font-weight:800; }
.qpill-done { background:var(--green-lt); border-color:var(--green); color:var(--green-dk); opacity:.85; }
.qpill-bar { width:40px; height:5px; background:rgba(0,0,0,.1); border-radius:3px; overflow:hidden; display:inline-block; vertical-align:middle; }
.qpill-fill { height:100%; background:var(--green); border-radius:3px; transition:width .4s; }

/* ── Learning Hub ── */
.learn-hub { margin:0 14px 10px; }
.lh-header { display:flex; align-items:baseline; gap:8px; margin-bottom:9px; }
.lh-title { font-family:'Baloo 2'; font-size:1.1rem; font-weight:800; color:var(--green-dk); }
.lh-badge {
  font-size:.63rem; font-weight:700; background:var(--green); color:#fff;
  border-radius:10px; padding:2px 8px; white-space:nowrap;
}
.lh-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-bottom:8px; }
.lh-card {
  display:flex; align-items:center; gap:10px; padding:13px 14px;
  border-radius:18px; border:none; cursor:pointer; font-family:'Nunito';
  text-align:left; transition:var(--trans); box-shadow:0 3px 12px rgba(0,0,0,.1);
}
.lh-card:hover { transform:translateY(-3px); box-shadow:0 8px 24px rgba(0,0,0,.16); filter:brightness(1.04); }
.lhc-guide-photo { width:48px; height:48px; border-radius:50%; background:#fff5 center/cover no-repeat; border:2px solid rgba(255,255,255,.5); flex-shrink:0; }
.lhc-icon { font-size:1.9rem; flex-shrink:0; }
.lhc-text { display:flex; flex-direction:column; }
.lhc-text strong { font-size:.9rem; font-weight:800; }
.lhc-text span   { font-size:.68rem; opacity:.85; font-weight:600; margin-top:1px; }
.lhc-maths   { background:linear-gradient(135deg,#f5a623,#e88020); color:#fff; }
.lhc-english { background:linear-gradient(135deg,#e05c45,#c83e2a); color:#fff; }
.lhc-memory  { background:linear-gradient(135deg,#3aabcc,#2080a8); color:#fff; }
.lhc-logic   { background:linear-gradient(135deg,#8b6fcf,#6644b0); color:#fff; }

/* Workbook banner */
.lh-workbook {
  display:flex; align-items:center; gap:12px; width:100%;
  padding:14px 16px; border-radius:18px; border:none; cursor:pointer;
  background:linear-gradient(135deg,var(--green-dk),var(--green));
  color:#fff; font-family:'Nunito'; text-align:left;
  transition:var(--trans); box-shadow:0 4px 16px rgba(47,107,52,.35);
}
.lh-workbook:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(47,107,52,.45); filter:brightness(1.06); }
.lhwb-icon { font-size:2rem; flex-shrink:0; }
.lhwb-text { flex:1; display:flex; flex-direction:column; }
.lhwb-text strong { font-size:.95rem; font-weight:800; }
.lhwb-text span   { font-size:.68rem; opacity:.8; margin-top:2px; font-weight:600; }
.lhwb-arrow { font-size:1.6rem; opacity:.7; font-weight:300; }

/* ── Animal fact strip ── */
.fact-strip {
  display:flex; align-items:flex-start; gap:9px;
  margin:0 14px 10px; padding:12px 14px; border-radius:16px;
  background:#fff; box-shadow:0 2px 10px rgba(0,0,0,.07);
}
.fs-emoji { font-size:1.3rem; flex-shrink:0; margin-top:1px; }
.fs-text { font-size:.8rem; color:var(--ink); line-height:1.55; font-weight:600; }
.fs-text::before { content:'Did you know? '; font-family:'Baloo 2'; font-weight:800; color:var(--green); }

/* Keep old subject card rules (used elsewhere) */
.subj-card {
  background:#fff; border-radius:var(--r-md); padding:18px 16px; cursor:pointer;
  box-shadow:var(--sh); transition:var(--trans); border:2px solid transparent; text-align:left;
}
.subj-card:hover { transform:translateY(-3px); box-shadow:var(--sh-hover); }
.subj-icon { font-size:2rem; margin-bottom:8px; display:block; }
.subj-card h4 { font-family:'Baloo 2'; font-size:.95rem; color:var(--ink); margin-bottom:3px; }
.subj-card p  { font-size:.75rem; color:var(--ink-soft); }
.subj-card .subj-guide { font-size:.7rem; font-weight:700; margin-top:6px; }

/* ── Pet display ── */
.pet-frame { position:relative; display:inline-flex; flex-direction:column; align-items:center; width:90px; }
.pet-acc-top { font-size:1.6rem; line-height:1; min-height:1.8rem; text-align:center; }
.pet-body { font-size:3.5rem; line-height:1; animation:petFloat 2.8s ease-in-out infinite; }
@keyframes petFloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-6px)} }
.pet-mood-hungry .pet-body { animation:petSlow 3.5s ease-in-out infinite; }
.pet-mood-sad    .pet-body { animation:petSad 2s ease-in-out infinite; filter:grayscale(30%); }
.pet-mood-tired  .pet-body { animation:none; opacity:.8; }
.pet-mood-happy  .pet-body { animation:petBounce 1.4s ease-in-out infinite; }
@keyframes petSlow   { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-3px)} }
@keyframes petSad    { 0%,100%{transform:translateX(0)} 25%{transform:translateX(-2px)} 75%{transform:translateX(2px)} }
@keyframes petBounce { 0%,100%{transform:translateY(0) scale(1)} 50%{transform:translateY(-10px) scale(1.03)} }
.pet-speech {
  position:absolute; bottom:-8px; left:50%; transform:translateX(-50%);
  background:var(--green-dk); color:#fff; border-radius:var(--r-sm);
  padding:5px 10px; font-size:.68rem; font-weight:600; white-space:nowrap;
  opacity:0; transition:opacity .3s; pointer-events:none; z-index:10; max-width:200px; white-space:normal; text-align:center;
}
.pet-speech.visible { opacity:1; }
.pet-speech::before { content:''; position:absolute; top:-6px; left:50%; transform:translateX(-50%); border:6px solid transparent; border-bottom-color:var(--green-dk); border-top:none; }

/* ── Stat bars ── */
.stat-row { display:flex; align-items:center; gap:8px; margin-bottom:7px; font-size:.78rem; }
.stat-icon { width:18px; text-align:center; }
.stat-lbl  { width:48px; font-weight:600; color:var(--ink-soft); }
.stat-bar-wrap { flex:1; height:8px; background:var(--green-lt); border-radius:6px; overflow:hidden; }
.stat-bar { height:100%; border-radius:6px; transition:width .6s ease; }
.bar-hunger { background: linear-gradient(90deg,var(--coral),var(--amber)); }
.bar-happy  { background: linear-gradient(90deg,var(--green),var(--green-md)); }
.bar-energy { background: linear-gradient(90deg,var(--teal),#5dd4f0); }
.bar-health { background: linear-gradient(90deg,var(--purple),#b89ee0); }
.stat-num { width:28px; text-align:right; font-weight:700; font-size:.72rem; color:var(--ink-soft); }

/* ─────────────────────────── ONBOARDING ─────────────────────────────────── */
#screen-onboarding { background:var(--green-soft); justify-content:center; align-items:center; padding:24px 16px; }
.ob-wrap { max-width:480px; width:100%; }
.ob-header { display:flex; align-items:center; gap:12px; margin-bottom:20px; }
.ob-mascot-big { font-size:3.5rem; }
.ob-title-wrap h2 { font-family:'Baloo 2'; font-size:1.2rem; }
.ob-title-wrap p  { font-size:.82rem; color:var(--ink-soft); }
.ob-bubble {
  background:#fff; border-radius:var(--r-md); padding:14px 18px;
  box-shadow:var(--sh); font-size:.9rem; margin-bottom:16px; border-left:4px solid var(--green);
}
.ob-progress { display:flex; align-items:center; gap:10px; margin-bottom:16px; }
.ob-bar-wrap { flex:1; height:8px; background:var(--green-lt); border-radius:6px; overflow:hidden; }
#ob-fill { height:100%; background:var(--green); border-radius:6px; transition:width .4s ease; }
#ob-count { font-size:.8rem; font-weight:700; color:var(--ink-soft); white-space:nowrap; }

/* ─────────────────────────── LEARNING (new game design) ─────────────────── */
.ls-screen { background:#1a2a1a; flex-direction:column; }

.ls-header {
  background:var(--ls-color,var(--green)); color:#fff; padding:10px 14px;
  display:flex; align-items:center; gap:10px; flex-shrink:0;
  box-shadow:0 3px 12px rgba(0,0,0,.3);
}
.ls-back { background:rgba(255,255,255,.2); border:none; color:#fff; border-radius:10px; padding:6px 12px; font-family:'Nunito'; font-size:.85rem; cursor:pointer; white-space:nowrap; }
.ls-hdr-mid { flex:1; display:flex; flex-direction:column; align-items:center; gap:4px; }
.ls-subj-name { font-family:'Baloo 2'; font-size:1rem; font-weight:800; }
.ls-pips { display:flex; gap:5px; }
.ls-pip { width:32px; height:7px; border-radius:4px; background:rgba(255,255,255,.25); transition:background .3s; }
.ls-pip.pip-done { background:#fff; }
.ls-pip.pip-current { background:rgba(255,255,255,.65); }
.ls-hdr-stats { display:flex; gap:8px; font-size:.8rem; font-weight:800; white-space:nowrap; }

/* Guide + pet strip */
.ls-guide-strip {
  display:flex; align-items:center; gap:10px;
  padding:12px 14px 8px; flex-shrink:0;
}
.ls-guide-wrap { display:flex; flex-direction:column; align-items:center; gap:4px; flex-shrink:0; }
.ls-guide-photo {
  width:72px; height:72px; border-radius:50%;
  background:#333 center/cover no-repeat;
  border:3px solid rgba(255,255,255,.4);
  box-shadow:0 4px 16px rgba(0,0,0,.4);
}
.ls-guide-name { font-size:.65rem; font-weight:800; color:rgba(255,255,255,.8); text-align:center; font-family:'Baloo 2'; }
.ls-speech {
  flex:1; background:#fff; border-radius:0 18px 18px 18px;
  padding:12px 14px; font-size:.88rem; line-height:1.5; color:var(--ink);
  box-shadow:0 4px 16px rgba(0,0,0,.15); min-height:56px;
  border-left:4px solid var(--ls-color,var(--green));
}
.ls-pet-wrap { flex-shrink:0; }

/* Question card */
.ls-q-card {
  background:#fff; margin:0 14px 10px; border-radius:20px;
  padding:20px 18px; box-shadow:0 6px 24px rgba(0,0,0,.2);
  animation:slideIn .3s ease; flex-shrink:0;
}
@keyframes slideIn { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }
.ls-q-text {
  font-family:'Baloo 2'; font-size:1.1rem; line-height:1.65; color:var(--ink);
  white-space:pre-wrap;
}

/* BIG coloured answer buttons */
.ls-answers {
  display:grid; grid-template-columns:1fr 1fr; gap:10px;
  padding:0 14px; flex-shrink:0;
}
.ls-opt {
  display:flex; flex-direction:column; align-items:flex-start;
  padding:16px 14px; border-radius:18px; border:none; cursor:pointer;
  font-family:'Nunito'; color:#fff; transition:transform .15s, filter .15s;
  min-height:80px; text-align:left;
}
.ls-opt-letter { font-size:.7rem; font-weight:900; opacity:.75; margin-bottom:4px; letter-spacing:.05em; }
.ls-opt-text   { font-size:1rem; font-weight:800; line-height:1.3; }
.ls-opt:hover:not(:disabled) { transform:scale(1.03); filter:brightness(1.08); }
.ls-opt:disabled { cursor:default; }
.ls-opt.opt-correct { outline:4px solid #fff; filter:brightness(1.1); animation:popIn .35s ease; }
.ls-opt.opt-wrong   { opacity:.45; filter:grayscale(30%); }
@keyframes popIn { 0%{transform:scale(1)} 50%{transform:scale(1.08)} 100%{transform:scale(1)} }

/* Question photo (real animal image) */
.ls-q-photo { margin:-20px -18px 14px; border-radius:16px 16px 0 0; overflow:hidden; max-height:200px; }
.ls-q-photo img { width:100%; height:200px; object-fit:cover; display:block; }
.ls-q-visual { font-size:1.6rem; text-align:center; letter-spacing:.1em; margin-bottom:10px; line-height:1.4; }

/* Photo-based answer grid */
.ls-photo-answers { display:grid; grid-template-columns:1fr 1fr; gap:10px; padding:0 14px; flex-shrink:0; }
.ls-photo-opt {
  border:3px solid #eee; border-radius:14px; overflow:hidden; cursor:pointer;
  background:#fff; padding:0; transition:transform .15s, border-color .15s;
  display:flex; flex-direction:column;
}
.ls-photo-opt img { width:100%; height:110px; object-fit:cover; display:block; }
.lpo-label { padding:6px 8px; font-family:'Nunito'; font-size:.8rem; font-weight:800; text-align:center; color:#333; }
.ls-photo-opt:hover:not(:disabled) { transform:scale(1.04); border-color:var(--green); }
.ls-photo-opt:disabled { cursor:default; }
.ls-photo-opt.opt-correct { border-color:#3daf73; box-shadow:0 0 0 3px rgba(61,175,115,.35); }
.ls-photo-opt.opt-wrong   { opacity:.4; }

/* IXL-style wrong-answer explanation panel */
.wrong-panel {
  position:fixed; bottom:0; left:0; right:0; z-index:500;
  background:#fff; border-radius:24px 24px 0 0;
  padding:20px 18px 32px; max-height:72vh; overflow-y:auto;
  box-shadow:0 -8px 40px rgba(0,0,0,.25);
  flex-direction:column; gap:12px;
  animation:slideUpPanel .3s ease;
}
@keyframes slideUpPanel { from{transform:translateY(100%)} to{transform:translateY(0)} }
.wp-header { background:#FFF3CD; border-radius:14px; padding:14px 16px; }
.wp-sorry { font-family:'Baloo 2'; font-size:1.2rem; color:#c0392b; font-weight:800; margin-bottom:4px; }
.wp-correct-row { font-size:.9rem; color:#333; font-weight:600; }
.wp-correct-row strong { color:#27a98e; font-size:1rem; }
.wp-explain-label {
  font-family:'Baloo 2'; font-size:1rem; font-weight:800; color:var(--green-dk);
  border-left:4px solid var(--green); padding-left:10px;
}
.wp-steps { display:flex; flex-direction:column; gap:8px; }
.wp-step { display:flex; align-items:flex-start; gap:10px; font-size:.9rem; line-height:1.5; color:#333; }
.wp-step-dot { font-size:1rem; flex-shrink:0; margin-top:1px; }
.wp-got-it {
  width:100%; padding:16px; background:var(--green); color:#fff; border:none;
  border-radius:var(--r-lg); font-family:'Baloo 2'; font-size:1.05rem; font-weight:800;
  cursor:pointer; transition:var(--trans); margin-top:4px;
}
.wp-got-it:hover { background:var(--green-dk); }

/* Feedback */
.ls-feedback { padding:0 14px 14px; }
.ls-feedback.hidden { display:none; }
.ls-next-btn {
  width:100%; padding:16px; background:var(--green); color:#fff; border:none;
  border-radius:var(--r-lg); font-family:'Baloo 2'; font-size:1.05rem; font-weight:800;
  cursor:pointer; transition:var(--trans); margin-top:10px;
}
.ls-next-btn:hover { background:var(--green-dk); transform:translateY(-2px); }

/* Round complete screen */
#screen-round { background:var(--green-dk); justify-content:center; align-items:center; padding:20px; position:relative; overflow:hidden; }
#confetti-stage-round { position:fixed; top:0;left:0;right:0;height:100vh; pointer-events:none; z-index:1; }
.round-wrap {
  background:#fff; border-radius:var(--r-xl); max-width:420px; width:100%;
  padding:30px 24px; text-align:center; box-shadow:0 20px 60px rgba(0,0,0,.3);
  position:relative; z-index:2;
}
.round-pet { margin-bottom:10px; display:flex; justify-content:center; }
.round-title { font-family:'Baloo 2'; font-size:1.8rem; color:var(--green-dk); margin-bottom:8px; }
.round-score { font-family:'Baloo 2'; font-size:2.8rem; color:var(--green); font-weight:800; margin-bottom:4px; }
.round-coins { background:var(--amber-lt); color:#8a5a00; border-radius:14px; padding:6px 14px; font-size:.9rem; font-weight:700; display:inline-block; margin-bottom:12px; }
.round-fact { background:var(--green-soft); border-radius:14px; padding:12px 14px; font-size:.82rem; color:var(--ink); line-height:1.5; margin-bottom:18px; text-align:left; }
.round-fact strong { font-family:'Baloo 2'; color:var(--green-dk); display:block; margin-bottom:4px; }
.round-btn { width:100%; padding:16px; background:var(--green); color:#fff; border:none; border-radius:var(--r-lg); font-family:'Baloo 2'; font-size:1.1rem; font-weight:700; cursor:pointer; transition:var(--trans); margin-bottom:8px; }
.round-btn:hover { background:var(--green-dk); transform:translateY(-2px); }
.round-btn-sec { background:none; border:2px solid var(--green-lt); border-radius:var(--r-lg); padding:12px; width:100%; font-family:'Nunito'; font-size:.9rem; font-weight:700; color:var(--ink-soft); cursor:pointer; transition:var(--trans); }
.round-btn-sec:hover { border-color:var(--green); color:var(--green); }

/* Keep old .back-btn / .option-btn etc. for onboarding/compat */
.back-btn { background:rgba(255,255,255,.2); border:none; color:#fff; border-radius:10px; padding:6px 12px; font-family:'Nunito'; font-size:.85rem; cursor:pointer; }
.learn-subj-label { flex:1; font-family:'Baloo 2'; font-size:1rem; font-weight:700; }
.learn-hdr-stats { display:flex; gap:8px; font-size:.78rem; font-weight:700; }
.learn-hdr-stats span { background:rgba(255,255,255,.2); border-radius:12px; padding:3px 8px; }
.q-card { background:#fff; border-radius:var(--r-lg); padding:22px 20px; box-shadow:var(--sh); }
.q-text { font-family:'Baloo 2'; font-size:1.05rem; line-height:1.5; margin-bottom:16px; color:var(--ink); }
.opts-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.option-btn { padding:13px 10px; border:2px solid var(--green-lt); border-radius:var(--r-md); background:#fff; font-family:'Nunito'; font-size:.9rem; font-weight:700; color:var(--ink); cursor:pointer; text-align:left; transition:var(--trans); }
.option-btn:hover:not(:disabled) { border-color:var(--green-md); background:var(--green-lt); }
.option-btn:disabled { cursor:default; }
.option-btn.correct { border-color:var(--success); background:#edfaf3; color:#1a7245; }
.option-btn.wrong   { border-color:var(--danger);  background:#fdf0ee; color:#992b1a; }
.feedback-zone { margin-top:14px; }
.feedback-zone.hidden { display:none; }
.next-btn { width:100%; padding:14px; background:var(--green); color:#fff; border:none; border-radius:var(--r-md); font-family:'Baloo 2'; font-size:1rem; font-weight:700; cursor:pointer; }

/* ─────────────────────────── LEVEL UP ─────────────────────────────────── */
#screen-levelup { background:var(--green-dk); justify-content:center; align-items:center; padding:24px 16px; position:relative; overflow:hidden; }
.lu-wrap {
  background:#fff; border-radius:var(--r-xl); max-width:440px; width:100%;
  padding:36px 28px; text-align:center; box-shadow: 0 20px 60px rgba(0,0,0,.3);
  position:relative; z-index:2;
}
.lu-mascot { font-size:4rem; animation:petBounce 1s ease-in-out infinite; margin-bottom:8px; }
.lu-wrap h2 { font-family:'Baloo 2'; font-size:2rem; color:var(--green-dk); margin-bottom:4px; }
.lu-level-row { display:flex; align-items:center; justify-content:center; gap:12px; font-family:'Baloo 2'; font-size:1.1rem; margin:12px 0; color:var(--ink-soft); }
.lu-new-lv { background:var(--green); color:#fff; border-radius:var(--r-lg); padding:6px 20px; font-size:1.6rem; animation:popIn .5s cubic-bezier(.175,.885,.32,1.275); }
@keyframes popIn { from{transform:scale(0) rotate(-10deg)} to{transform:scale(1) rotate(0)} }
.lu-msg { font-size:.9rem; color:var(--ink-soft); line-height:1.5; margin:12px 0 20px; }
.lu-stats { display:flex; justify-content:center; gap:20px; margin-bottom:24px; }
.lu-stat { display:flex; flex-direction:column; align-items:center; gap:3px; }
.lu-stat .lsv { font-family:'Baloo 2'; font-size:1.5rem; color:var(--green-dk); font-weight:800; }
.lu-stat label { font-size:.72rem; color:var(--ink-faint); font-weight:700; text-transform:uppercase; letter-spacing:.05em; }
.lu-continue-btn {
  width:100%; padding:16px; background:var(--green); color:#fff; border:none;
  border-radius:var(--r-lg); font-family:'Baloo 2'; font-size:1.1rem; font-weight:700;
  cursor:pointer; transition:var(--trans);
}
.lu-continue-btn:hover { background:var(--green-dk); transform:translateY(-2px); }
/* Confetti */
#confetti-stage { position:fixed; top:0;left:0;right:0; height:100vh; pointer-events:none; z-index:1; }
.confetti-piece { position:absolute; top:-10px; animation:confettiFall linear forwards; }
@keyframes confettiFall { to{transform:translateY(110vh) rotate(720deg); opacity:0;} }

/* ─────────────────────────── SHOP ───────────────────────────────────────── */
#screen-shop { background:var(--green-soft); }
.shop-header { background:var(--green); color:#fff; padding:16px 20px; }
.shop-header h2 { font-family:'Baloo 2'; font-size:1.2rem; }
.shop-coins-bar { background:#fff; padding:12px 16px; display:flex; align-items:center; gap:8px; box-shadow:var(--sh); }
.shop-coins-bar span { font-family:'Baloo 2'; font-size:1.1rem; color:var(--green-dk); font-weight:800; }
.shop-coins-label { color:var(--ink-soft); font-size:.82rem; flex:1; }
.shop-tabs { display:flex; gap:0; border-bottom:2px solid var(--green-lt); background:#fff; padding:0 16px; }
.shop-tab {
  padding:12px 16px; border:none; background:transparent; font-family:'Nunito'; font-size:.85rem;
  font-weight:700; color:var(--ink-soft); cursor:pointer; border-bottom:3px solid transparent; margin-bottom:-2px;
  transition:var(--trans);
}
.shop-tab.active, .shop-tab:hover { color:var(--green); border-bottom-color:var(--green); }
.shop-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; padding:16px; }
.shop-card {
  background:#fff; border-radius:var(--r-md); padding:16px 14px; text-align:center;
  box-shadow:var(--sh); cursor:pointer; transition:var(--trans); border:2px solid transparent;
}
.shop-card:hover:not(.owned) { transform:translateY(-3px); box-shadow:var(--sh-hover); border-color:var(--green-lt); }
.shop-card.owned { border-color:var(--green-lt); opacity:.75; }
.shop-emoji { font-size:2.2rem; margin-bottom:8px; }
.shop-name  { font-family:'Baloo 2'; font-size:.9rem; color:var(--ink); margin-bottom:4px; }
.shop-desc  { font-size:.72rem; color:var(--ink-soft); margin-bottom:8px; line-height:1.4; }
.shop-cost  { background:var(--amber-lt); color:#8a5a00; border-radius:12px; padding:4px 10px; font-size:.8rem; font-weight:700; display:inline-block; }
.shop-cost.cant-afford { background:#fdf0ee; color:var(--danger); }

/* ─────────────────────────── TOAST ─────────────────────────────────────── */
#toast {
  position:fixed; bottom:90px; left:50%; transform:translateX(-50%) translateY(20px);
  background:var(--green-dk); color:#fff; border-radius:var(--r-lg); padding:12px 22px;
  font-size:.88rem; font-weight:700; box-shadow:var(--sh-hover); z-index:200;
  opacity:0; transition:opacity .3s, transform .3s; pointer-events:none; max-width:340px; text-align:center;
}
#toast.visible { opacity:1; transform:translateX(-50%) translateY(0); }

/* ── Responsive ── */
@media(max-width:380px) {
  .subject-grid { grid-template-columns:1fr; }
  .pc-grid { grid-template-columns:repeat(3,1fr); }
  .opts-grid { grid-template-columns:1fr; }
}
@media(min-width:600px) {
  .home-pet-section, .learn-body { max-width:560px; margin-left:auto; margin-right:auto; }
  .learn-section { max-width:560px; margin:0 auto; }
  .lu-wrap, .pc-wrap { margin:40px auto; }
}

/* ── Stories / Creature Files buttons on home ─────────────────────────────── */
.lh-stories-btn {
  display:flex; align-items:center; gap:12px;
  width:100%; padding:14px 16px; margin-top:10px;
  background:#fff; border:2px solid #f0f0ee; border-radius:var(--r-md);
  text-align:left; cursor:pointer; transition:var(--trans);
  box-shadow:var(--sh); text-decoration:none; color:inherit;
}
.lh-stories-btn:hover { transform:translateY(-2px); box-shadow:var(--sh-hover); border-color:var(--green-lt); }
.lh-stories-btn .lhwb-icon {
  width:44px; height:44px; border-radius:12px; display:grid; place-items:center;
  font-size:1.4rem; flex-shrink:0;
}
.lh-stories-btn .lhwb-text { flex:1; }
.lh-stories-btn .lhwb-text strong { display:block; font-family:'Baloo 2'; font-size:.95rem; color:var(--ink); }
.lh-stories-btn .lhwb-text span { font-size:.75rem; color:var(--ink-soft); }
.lh-stories-btn .lhwb-arrow { font-size:1.4rem; color:var(--ink-faint); }

/* ── Workbook card hover preview ──────────────────────────────────────────── */
#screen-wb-picker { position:relative; }
.wbp-preview {
  position:absolute; z-index:200; width:280px;
  background:#fff; border-radius:18px; box-shadow:0 12px 40px rgba(0,0,0,.18);
  border:1px solid #e8eae4; padding:16px;
  opacity:0; transform:translateY(8px) scale(.97);
  transition:opacity .18s, transform .18s;
  pointer-events:none;
}
.wbp-preview.wbpp-visible {
  opacity:1; transform:translateY(0) scale(1);
  pointer-events:auto;
}
.wbpp-icon-wrap { margin-bottom:10px; }
.wbpp-icon {
  width:42px; height:42px; border-radius:12px;
  display:inline-grid; place-items:center;
  font-size:1.3rem; background:var(--green);
}
.wbpp-title { font-family:'Baloo 2'; font-size:1.05rem; font-weight:800; color:var(--ink); margin-bottom:2px; }
.wbpp-age { font-size:.72rem; font-weight:700; color:var(--ink-faint); text-transform:uppercase; letter-spacing:.04em; margin-bottom:6px; }
.wbpp-desc { font-size:.83rem; color:var(--ink-soft); line-height:1.5; margin:0 0 8px; }
.wbpp-items { margin:0; padding:0 0 0 14px; }
.wbpp-items li { font-size:.78rem; color:var(--ink-soft); line-height:1.7; }

/* ── Education.com-style workbook card improvements ───────────────────────── */
.wbp-card {
  position:relative; overflow:hidden;
}
.wbp-card::after {
  content:'Hold for preview';
  position:absolute; bottom:0; left:0; right:0;
  background:rgba(0,0,0,.5); color:#fff; font-size:.6rem; font-weight:700;
  text-align:center; padding:3px; opacity:0;
  transition:opacity .2s;
}
@media(hover:hover) {
  .wbp-card:hover::after { opacity:0; } /* desktop: tooltip handles it */
}
@media(hover:none) {
  .wbp-card:active::after { opacity:1; } /* mobile: show on press */
}
