/* ════════════════════════════════════════════════════
   Call of the Void — Neurosparkly Support Book (phone app)
   Visual DNA preserved from the original support book.
   ════════════════════════════════════════════════════ */
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
:root{
  --pink:#FF6EB4;--pink-d:#d94d96;--pink-l:#FFE8F4;--pink-ll:#fff0f8;
  --blue:#5BB8F5;--blue-d:#2E86C1;--blue-l:#DDF0FF;--blue-ll:#f0f9ff;
  --purple:#A78BFA;--purple-d:#6D28D9;--purple-l:#EDE9FE;--purple-ll:#f5f3ff;
  --mint:#34D399;--mint-d:#059669;--mint-l:#D1FAE5;--mint-ll:#f0fdf4;
  --white:#fff;--off:#FAFAFA;--ink:#1a1a2e;--body:#2d2d44;--border:#E5E7EB;--line:#D1D5DB;
  --shadow:0 10px 36px rgba(167,139,250,.18),0 3px 12px rgba(255,110,180,.10);
  --shadow-sm:0 4px 16px rgba(120,90,180,.10);
  --ts:1; /* text scale multiplier */
  /* themeable backgrounds */
  --page-bg:radial-gradient(1200px 700px at 80% -10%, #f3e9ff 0%, transparent 55%),radial-gradient(1000px 800px at -10% 110%, #ffe7f4 0%, transparent 55%),linear-gradient(160deg,#efe7ff 0%,#e6f3ff 45%,#ffeaf5 100%);
  --cover-bg:linear-gradient(165deg,#ede0ff 0%,#c8e8ff 38%,#ffd8f0 72%,#ffecd8 100%);
  --cover-ink:#d94d96;--cover-ink2:#6D28D9;--cover-sub:#2E86C1;
}
html,body{height:100%;}
body{
  font-family:'Nunito',sans-serif;color:var(--body);
  background:var(--page-bg);
  background-attachment:fixed;
  min-height:100dvh;display:flex;justify-content:center;align-items:stretch;
}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
textarea,input{font-family:inherit;}

/* ── PHONE FRAME (centered column; reads as an app on desktop) ── */
#phone{
  width:100%;max-width:440px;background:var(--off);min-height:100dvh;
  position:relative;overflow:hidden;display:flex;flex-direction:column;
  box-shadow:0 30px 90px rgba(80,50,140,.22);
}
/* medium screens: floating phone with bezel */
@media(min-width:480px) and (max-width:899px){
  body{padding:22px 0;}
  #phone{min-height:auto;height:calc(100dvh - 44px);border-radius:40px;border:10px solid #15131f;}
  #phone::after{content:'';position:absolute;top:14px;left:50%;transform:translateX(-50%);width:120px;height:26px;background:#15131f;border-radius:0 0 18px 18px;z-index:300;pointer-events:none;}
}

/* ── DESKTOP SHELL (sidebar app) ── */
.sidebar{display:none;}
@media(min-width:900px){
  body{padding:0;align-items:stretch;}
  #phone{max-width:none;width:100vw;height:100dvh;min-height:0;border:none;border-radius:0;
    flex-direction:row;background:transparent;box-shadow:none;overflow:hidden;}
  .sidebar{display:flex;flex-direction:column;width:262px;flex-shrink:0;padding:26px 16px 20px;gap:5px;
    background:rgba(255,255,255,.82);backdrop-filter:blur(14px);border-right:1px solid rgba(180,150,210,.18);z-index:80;}
  .calm .sidebar{background:#fff;backdrop-filter:none;}
  .viewport{background:transparent;}
  .tabbar{display:none;}
  .screen{max-width:700px;margin:0 auto;padding-bottom:48px;}
  .appbar{border-radius:0 0 22px 22px;}
  #cover,#finish{padding-left:30px;padding-right:30px;}
}
.sb-logo{width:62px;height:62px;border-radius:50%;background:#fff;padding:6px;object-fit:contain;box-shadow:var(--shadow-sm);margin-left:6px;}
.sb-brand{font-family:'Fredoka One',cursive;font-size:17px;line-height:1.1;margin:13px 6px 1px;
  background:linear-gradient(135deg,var(--pink-d),var(--purple-d));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.sb-org{font-size:10.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#a99fbb;margin:0 6px 18px;}
.sb-tab{display:flex;align-items:center;gap:13px;padding:12px 14px;border-radius:15px;font-weight:800;font-size:15px;color:#8a8099;text-align:left;transition:background .18s,color .18s;}
.sb-tab .si{font-size:21px;filter:grayscale(.5);opacity:.6;transition:.18s;}
.sb-tab:hover{background:rgba(167,139,250,.1);}
.sb-tab.on{background:#fff;color:var(--purple-d);box-shadow:var(--shadow-sm);}
.sb-tab.on .si{filter:none;opacity:1;}
.sb-foot{margin-top:auto;padding:14px 8px 0;font-size:11px;font-weight:700;color:#a99fbb;line-height:1.5;}
.sb-foot b{font-family:'Fredoka One',cursive;color:var(--pink-d);font-weight:400;display:block;font-size:12.5px;margin-bottom:3px;}

/* ── SCROLL VIEWPORT ── */
.viewport{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;position:relative;scroll-behavior:smooth;}
.calm .viewport{scroll-behavior:auto;}

/* ════════════ COVER ════════════ */
#cover{position:absolute;inset:0;z-index:250;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:34px 26px;text-align:center;overflow:hidden;
  background:var(--cover-bg);}
#cover.hide{opacity:0;transform:scale(1.04);pointer-events:none;transition:opacity .5s,transform .5s;}
.cover-deco{position:absolute;font-size:22px;opacity:.45;white-space:nowrap;}
.cover-deco.top{top:42px;left:50%;transform:translateX(-50%);}
.cover-deco.bot{bottom:30px;left:50%;transform:translateX(-50%);}
.cover-logo{width:148px;height:148px;object-fit:contain;border-radius:50%;background:rgba(255,255,255,.7);padding:12px;box-shadow:0 12px 40px rgba(167,139,250,.3);margin-bottom:18px;animation:floaty 5s ease-in-out infinite;}
.cover-org{font-family:'Fredoka One',cursive;font-size:12px;color:var(--cover-sub);letter-spacing:.14em;text-transform:uppercase;margin-bottom:10px;}
.cover-title{font-family:'Fredoka One',cursive;font-size:clamp(30px,9vw,40px);line-height:1.08;margin-bottom:10px;
  background:linear-gradient(135deg,var(--cover-ink),var(--cover-ink2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.cover-sub{font-style:italic;font-weight:700;font-size:16px;color:var(--cover-sub);margin-bottom:26px;line-height:1.5;}
.start-btn{background:linear-gradient(135deg,var(--pink),var(--purple-d));color:#fff;padding:16px 44px;font-family:'Fredoka One',cursive;font-size:19px;border-radius:100px;box-shadow:0 8px 28px rgba(167,139,250,.5);transition:transform .2s,box-shadow .2s;}
.start-btn:active{transform:scale(.96);}
.cover-handle{font-family:'Fredoka One',cursive;color:var(--cover-sub);font-size:13px;margin-top:24px;}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* ════════════ TOP BAR ════════════ */
.appbar{position:sticky;top:0;z-index:60;display:flex;align-items:center;gap:12px;padding:14px 18px 12px;
  background:rgba(255,255,255,.82);backdrop-filter:blur(14px);border-bottom:1px solid rgba(180,150,210,.16);}
.calm .appbar{background:#fff;backdrop-filter:none;}
.appbar .back{width:38px;height:38px;border-radius:12px;background:var(--off);display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--body);flex-shrink:0;transition:transform .15s;}
.appbar .back:active{transform:scale(.9);}
.appbar-title{font-family:'Fredoka One',cursive;font-size:18px;line-height:1.1;flex:1;min-width:0;}
.appbar-title small{display:block;font-family:'Nunito';font-weight:700;font-size:11px;color:#9b91ab;letter-spacing:.04em;}

/* ════════════ SCREENS ════════════ */
.screen{display:none;padding:0 0 118px;animation:rise .34s ease;}
.screen.active{display:block;}
.screen-pad{padding:16px 18px 0;}
.calm .screen,.reduce-motion .screen{animation:none;}
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ════════════ HOME / TODAY ════════════ */
.greet{font-family:'Fredoka One',cursive;font-size:25px;line-height:1.15;margin-bottom:3px;color:var(--ink);}
.greet-sub{font-weight:700;font-size:13.5px;color:#8a8099;margin-bottom:18px;}

/* progress ring hero */
.hero-card{background:#fff;border-radius:26px;padding:22px;box-shadow:var(--shadow);margin-bottom:16px;
  display:flex;align-items:center;gap:18px;position:relative;overflow:hidden;}
.hero-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--purple-ll),var(--pink-ll));opacity:.6;z-index:0;}
.calm .hero-card::before{display:none;}
.ring-wrap{position:relative;flex-shrink:0;z-index:1;}
.ring-wrap svg{transform:rotate(-90deg);display:block;}
.ring-bg{fill:none;stroke:var(--purple-l);stroke-width:11;}
.ring-fg{fill:none;stroke:url(#ringgrad);stroke-width:11;stroke-linecap:round;transition:stroke-dashoffset .9s cubic-bezier(.2,.8,.2,1);}
.ring-pct{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.ring-pct b{font-family:'Fredoka One',cursive;font-size:26px;color:var(--purple-d);line-height:1;}
.ring-pct span{font-size:10px;font-weight:800;color:#a99fbb;letter-spacing:.06em;text-transform:uppercase;}
.hero-txt{z-index:1;flex:1;}
.hero-txt h3{font-family:'Fredoka One',cursive;font-size:16px;color:var(--ink);margin-bottom:4px;}
.hero-txt p{font-size:13px;font-weight:700;color:#7c7289;line-height:1.55;}

/* resume card */
.resume-card{display:flex;align-items:center;gap:14px;width:100%;text-align:left;background:linear-gradient(135deg,var(--pink),var(--purple-d));color:#fff;
  border-radius:22px;padding:17px 19px;box-shadow:0 10px 28px rgba(167,139,250,.4);margin-bottom:16px;transition:transform .15s;}
.resume-card:active{transform:scale(.98);}
.resume-card .rc-emoji{font-size:30px;flex-shrink:0;}
.resume-card .rc-body{flex:1;min-width:0;}
.resume-card .rc-k{display:block;font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;opacity:.85;}
.resume-card .rc-t{display:block;font-family:'Fredoka One',cursive;font-size:17px;line-height:1.15;margin-top:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.resume-card .rc-arrow{font-size:22px;flex-shrink:0;}

/* section heading */
.row-head{display:flex;align-items:baseline;justify-content:space-between;margin:22px 2px 11px;}
.row-head h2{font-family:'Fredoka One',cursive;font-size:18px;color:var(--ink);}
.row-head a{font-size:12.5px;font-weight:800;color:var(--purple-d);}

/* mood snapshot mini */
.mood-mini{display:flex;align-items:center;gap:13px;width:100%;background:#fff;border-radius:20px;padding:15px 17px;box-shadow:var(--shadow-sm);margin-bottom:6px;border:2px solid var(--blue-l);transition:transform .15s;}
.mood-mini:active{transform:scale(.98);}
.mood-mini .mm-emoji{font-size:30px;}
.mood-mini .mm-body{flex:1;text-align:left;}
.mood-mini .mm-t{font-family:'Fredoka One',cursive;font-size:15px;color:var(--blue-d);}
.mood-mini .mm-s{font-size:12.5px;font-weight:700;color:#8a8099;margin-top:1px;}
.mood-mini .mm-go{font-size:18px;color:var(--blue-d);}

/* connect / contact card */
.connect-card{background:#fff;border-radius:24px;padding:18px 17px 14px;box-shadow:var(--shadow);position:relative;overflow:hidden;margin-bottom:4px;}
.connect-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--purple-ll),var(--pink-ll));opacity:.7;z-index:0;}
.calm .connect-card::before{display:none;}
.connect-head{display:flex;align-items:flex-start;gap:12px;position:relative;z-index:1;margin-bottom:13px;}
.connect-head .ch-em{font-size:26px;flex-shrink:0;line-height:1.2;}
.connect-head .ch-t{font-family:'Fredoka One',cursive;font-size:16px;color:var(--purple-d);}
.connect-head .ch-s{font-size:12.5px;font-weight:700;color:#8a8099;line-height:1.45;margin-top:3px;}
.connect-list{display:flex;flex-direction:column;gap:9px;position:relative;z-index:1;}
.connect-row{display:flex;align-items:center;gap:12px;background:#fff;border-radius:16px;padding:11px 13px;box-shadow:var(--shadow-sm);transition:transform .15s;text-decoration:none;color:inherit;}
.connect-row:active{transform:scale(.98);}
.connect-row .cr-em{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0;}
.connect-row.t-pink   .cr-em{background:var(--pink-l);}
.connect-row.t-blue   .cr-em{background:var(--blue-l);}
.connect-row.t-purple .cr-em{background:var(--purple-l);}
.connect-row .cr-body{flex:1;min-width:0;}
.connect-row .cr-t{display:block;font-family:'Fredoka One',cursive;font-size:14.5px;color:var(--ink);}
.connect-row .cr-s{display:block;font-size:12px;font-weight:700;color:#8a8099;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.connect-row .cr-go{font-size:19px;font-weight:800;color:#c4bcd2;flex-shrink:0;}

/* ════════ GLIMMER JAR ════════ */
.glimmer-box{margin:4px 0 16px;}
.glimmer-jarwrap{position:relative;padding-top:14px;}
/* jar lid */
.glimmer-jarwrap::before{content:'';position:absolute;top:6px;left:50%;transform:translateX(-50%);
  width:124px;height:16px;border-radius:7px 7px 4px 4px;
  background:linear-gradient(180deg,#fff,#f4ecff);box-shadow:0 3px 8px rgba(140,110,200,.18);z-index:2;}
.glimmer-jar{
  position:relative;min-height:172px;padding:24px 16px 18px;
  border-radius:16px 16px 30px 30px;
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(255,255,255,.7), transparent 60%),
    linear-gradient(180deg,#fbf6ff 0%,#f2ecff 60%,#efe7ff 100%);
  border:2.5px solid #fff;
  box-shadow:inset 0 10px 24px rgba(150,110,210,.12), inset 0 -8px 18px rgba(255,210,140,.12), var(--shadow-sm);
  overflow:hidden;
  display:flex;flex-wrap:wrap;gap:10px;align-content:flex-end;justify-content:center;
}
/* soft glow pooling at the bottom of the jar */
.glimmer-jar::after{content:'';position:absolute;left:0;right:0;bottom:0;height:60px;pointer-events:none;
  background:radial-gradient(80% 100% at 50% 120%, rgba(255,206,120,.34), transparent 70%);}
.glimmer-light{
  position:relative;z-index:1;width:48px;height:48px;border-radius:50%;flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;font-size:22px;line-height:1;
  background:radial-gradient(circle at 50% 34%, #fffef8, #ffe7b6);
  box-shadow:0 0 0 3px rgba(255,255,255,.7), 0 4px 12px rgba(255,180,80,.4), 0 0 16px rgba(255,206,120,.6);
  animation:glimmerTwinkle 3.6s ease-in-out infinite;animation-delay:var(--gd,0s);
  transition:transform .15s;
}
.glimmer-light:active{transform:scale(.86);}
.glimmer-light.is-new{animation:glimmerPop .6s cubic-bezier(.2,1.5,.4,1);}
@keyframes glimmerTwinkle{
  0%,100%{box-shadow:0 0 0 3px rgba(255,255,255,.7),0 4px 10px rgba(255,180,80,.32),0 0 12px rgba(255,206,120,.45);}
  50%{box-shadow:0 0 0 3px rgba(255,255,255,.85),0 4px 14px rgba(255,180,80,.5),0 0 22px rgba(255,214,130,.8);}
}
@keyframes glimmerPop{0%{transform:scale(0) translateY(26px);opacity:0;}60%{transform:scale(1.18) translateY(0);opacity:1;}100%{transform:scale(1);}}
.glimmer-empty{margin:auto;text-align:center;color:#a99fbb;font-weight:800;font-size:12.5px;line-height:1.5;display:flex;flex-direction:column;align-items:center;gap:7px;padding:10px 6px;}
.glimmer-empty span{max-width:210px;}
.glimmer-empty{font-size:13px;}
.glimmer-empty::first-line{font-size:30px;}
.glimmer-count{text-align:center;font-family:'Fredoka One',cursive;font-size:12.5px;color:var(--purple-d);margin:11px 0 12px;}
.glimmer-add{display:flex;gap:8px;margin-bottom:13px;}
.glimmer-input{flex:1;min-width:0;border:2px solid var(--purple-l);background:#fff;border-radius:14px;
  padding:11px 13px;font-size:13.5px;font-weight:700;color:var(--ink);outline:none;transition:border-color .15s;}
.glimmer-input::placeholder{color:#b3a9c4;font-weight:700;}
.glimmer-input:focus{border-color:var(--purple);}
.glimmer-addbtn{flex:0 0 auto;border-radius:14px;padding:0 16px;font-family:'Fredoka One',cursive;font-size:13px;
  color:#fff;background:linear-gradient(135deg,var(--purple),var(--purple-d));box-shadow:0 4px 12px rgba(109,40,217,.3);}
.glimmer-addbtn:active{transform:scale(.96);}
.glimmer-ideas-label{font-size:11.5px;font-weight:800;color:#9b91ab;margin-bottom:9px;}
.glimmer-ideas{display:flex;flex-wrap:wrap;gap:7px;}
.glimmer-chip{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1.5px solid var(--border);
  border-radius:13px;padding:8px 11px;font-size:12.5px;font-weight:800;color:var(--body);
  box-shadow:var(--shadow-sm);transition:transform .14s,border-color .14s;}
.glimmer-chip .gc-e{font-size:15px;}
.glimmer-chip:active{transform:scale(.95);border-color:var(--purple);}
.reduce-motion .glimmer-light{animation:none!important;}
.calm .glimmer-jar{background:linear-gradient(180deg,#fbf8ff,#f3eeff);}

/* ════════ CHECK-IN: needs + glimmer ════════ */
.needs-card .sc-sub{margin-bottom:13px;}
.needs-grid{display:flex;flex-wrap:wrap;gap:8px;}
.need-chip{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1.5px solid var(--border);
  border-radius:14px;padding:9px 12px;font-size:13px;font-weight:800;color:var(--body);
  transition:transform .14s,border-color .14s,background .14s,box-shadow .14s;}
.need-chip .nc-e{font-size:15px;}
.need-chip:active{transform:scale(.95);}
.need-chip.on{background:var(--purple-l);border-color:var(--purple);color:var(--purple-d);
  box-shadow:0 4px 12px rgba(167,139,250,.28);}
.li-needs{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px;}
.li-need{font-size:11px;font-weight:800;color:var(--purple-d);background:var(--purple-ll);
  border-radius:8px;padding:3px 7px;}
.li-glimmer{font-size:12px;font-weight:800;color:var(--pink-d);margin-top:6px;
  background:var(--pink-ll);border-radius:8px;padding:5px 9px;display:inline-block;}

/* garden */
.garden{background:#fff;border-radius:22px;padding:18px 18px 16px;box-shadow:var(--shadow-sm);margin-bottom:6px;}
.garden-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.garden-h h3{font-family:'Fredoka One',cursive;font-size:15px;color:var(--mint-d);}
.garden-h .gc{font-size:12px;font-weight:800;color:#a99fbb;}
.garden-plot{background:linear-gradient(180deg,#f4fff9,#e9fbf1);border-radius:16px;padding:14px;min-height:74px;display:flex;flex-wrap:wrap;gap:7px;align-content:center;justify-content:center;border:2px dashed var(--mint-l);}
.calm .garden-plot{background:var(--mint-ll);}
.flower{font-size:23px;animation:bloom .5s ease backwards;}
.reduce-motion .flower,.calm .flower{animation:none;}
@keyframes bloom{from{transform:scale(0) rotate(-40deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}
.garden-empty{font-size:12.5px;font-weight:700;color:#9aa0a8;text-align:center;width:100%;line-height:1.5;}

/* ════════════ CHAPTER LIST ════════════ */
.chip-streak{display:inline-flex;align-items:center;gap:7px;background:#fff;border-radius:100px;padding:8px 15px;box-shadow:var(--shadow-sm);font-weight:800;font-size:13px;color:var(--pink-d);margin-bottom:16px;}
.chap-card{display:flex;align-items:center;gap:15px;width:100%;text-align:left;background:#fff;border-radius:22px;padding:16px;margin-bottom:13px;
  box-shadow:var(--shadow-sm);border:2.5px solid transparent;transition:transform .15s,box-shadow .2s;position:relative;overflow:hidden;}
.chap-card:active{transform:scale(.985);}
.chap-emoji{width:56px;height:56px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0;color:#fff;}
.chap-info{flex:1;min-width:0;}
.chap-k{font-size:10.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;opacity:.7;}
.chap-t{font-family:'Fredoka One',cursive;font-size:16.5px;line-height:1.12;margin:2px 0 8px;color:var(--ink);}
.chap-bar{height:8px;background:var(--off);border-radius:8px;overflow:hidden;}
.chap-bar i{display:block;height:100%;border-radius:8px;transition:width .7s cubic-bezier(.2,.8,.2,1);}
.chap-meta{font-size:11px;font-weight:800;margin-top:5px;color:#9b91ab;}
.chap-badge{position:absolute;top:11px;right:13px;font-size:19px;opacity:0;transform:scale(.4);transition:.3s;}
.chap-card.done .chap-badge{opacity:1;transform:scale(1);}

/* theme accents for chapter cards/screens */
.t-pink   .chap-emoji,.t-pink   .chap-bar i{background:linear-gradient(135deg,var(--pink),var(--pink-d));}
.t-blue   .chap-emoji,.t-blue   .chap-bar i{background:linear-gradient(135deg,var(--blue),var(--blue-d));}
.t-purple .chap-emoji,.t-purple .chap-bar i{background:linear-gradient(135deg,var(--purple),var(--purple-d));}
.t-mint   .chap-emoji,.t-mint   .chap-bar i{background:linear-gradient(135deg,var(--mint),var(--mint-d));}
.t-pink.chap-card:active{border-color:var(--pink-l);}
.t-blue.chap-card:active{border-color:var(--blue-l);}
.t-purple.chap-card:active{border-color:var(--purple-l);}
.t-mint.chap-card:active{border-color:var(--mint-l);}

/* ════════════ CHAPTER DETAIL ════════════ */
.ch-hero{border-radius:24px;padding:22px;color:#fff;margin-bottom:16px;position:relative;overflow:hidden;}
.ch-hero .che{font-size:42px;line-height:1;margin-bottom:8px;}
.ch-hero h1{font-family:'Fredoka One',cursive;font-size:25px;line-height:1.08;margin-bottom:9px;}
.ch-hero p{font-size:13.5px;font-weight:700;line-height:1.62;opacity:.96;}
.ch-hero .che-big{position:absolute;right:-18px;top:-14px;font-size:120px;opacity:.13;transform:rotate(-12deg);pointer-events:none;}
.th-pink .ch-hero{background:linear-gradient(135deg,var(--pink),var(--pink-d));}
.th-blue .ch-hero{background:linear-gradient(135deg,var(--blue),var(--blue-d));}
.th-purple .ch-hero{background:linear-gradient(135deg,var(--purple),var(--purple-d));}
.th-mint .ch-hero{background:linear-gradient(135deg,var(--mint),var(--mint-d));}

/* topic accordion card */
.topic{background:#fff;border-radius:20px;margin-bottom:13px;box-shadow:var(--shadow-sm);overflow:hidden;border:2px solid transparent;}
.th-pink .topic{border-color:var(--pink-l);}
.th-blue .topic{border-color:var(--blue-l);}
.th-purple .topic{border-color:var(--purple-l);}
.th-mint .topic{border-color:var(--mint-l);}
.topic-head{display:flex;align-items:center;gap:12px;width:100%;text-align:left;padding:15px 16px;}
.topic-head .te{font-size:24px;flex-shrink:0;}
.topic-head .tn{font-family:'Fredoka One',cursive;font-size:16px;line-height:1.15;flex:1;color:var(--ink);}
.topic-head .tdone{font-size:16px;opacity:0;transition:.25s;}
.topic.answered .topic-head .tdone{opacity:1;}
.topic-head .tdone.pop{animation:bloompop .65s cubic-bezier(.2,.9,.3,1.4);}
@keyframes bloompop{0%{transform:scale(0) rotate(-30deg)}55%{transform:scale(1.5) rotate(8deg)}100%{transform:scale(1) rotate(0)}}
.reduce-motion .topic-head .tdone.pop{animation:none;}
.topic-head .tcaret{font-size:14px;color:#bdb4cc;transition:transform .3s;flex-shrink:0;}
.topic.open .topic-head .tcaret{transform:rotate(180deg);}
.topic-body{display:none;padding:0 16px 18px;}
.topic.open .topic-body{display:block;animation:rise .3s ease;}
.reduce-motion .topic.open .topic-body{animation:none;}
.topic-def{font-size:14px;line-height:1.7;font-weight:600;color:var(--body);padding:4px 2px 14px;}

/* sub-label pills */
.sublabel{display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:100px;font-family:'Fredoka One',cursive;font-size:12px;color:#fff;margin:6px 0 11px;}
.th-pink .sublabel.supp{background:var(--pink-d);}.th-pink .sublabel.refl{background:var(--pink);}
.th-blue .sublabel.supp{background:var(--blue-d);}.th-blue .sublabel.refl{background:var(--blue);}
.th-purple .sublabel.supp{background:var(--purple-d);}.th-purple .sublabel.refl{background:var(--purple);}
.th-mint .sublabel.supp{background:var(--mint-d);}.th-mint .sublabel.refl{background:var(--mint);}

/* support = tap-to-try checklist */
.try-list{display:flex;flex-direction:column;gap:7px;margin-bottom:6px;}
.try-item{display:flex;align-items:flex-start;gap:10px;width:100%;text-align:left;padding:11px 13px;border-radius:13px;font-size:13px;font-weight:700;line-height:1.45;transition:transform .12s,background .2s;}
.try-item:active{transform:scale(.99);}
.try-box{width:24px;height:24px;border-radius:8px;border:2.5px solid;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:14px;transition:.2s;background:#fff;}
.th-pink .try-item{background:var(--pink-ll);}.th-pink .try-box{border-color:var(--pink);color:var(--pink-d);}
.th-blue .try-item{background:var(--blue-ll);}.th-blue .try-box{border-color:var(--blue);color:var(--blue-d);}
.th-purple .try-item{background:var(--purple-ll);}.th-purple .try-box{border-color:var(--purple);color:var(--purple-d);}
.th-mint .try-item{background:var(--mint-ll);}.th-mint .try-box{border-color:var(--mint);color:var(--mint-d);}
.try-item.tried .try-box{background:currentColor;}
.try-item.tried .try-box::after{content:'✓';color:#fff;}
.th-pink .try-item.tried .try-box{background:var(--pink-d);}
.th-blue .try-item.tried .try-box{background:var(--blue-d);}
.th-purple .try-item.tried .try-box{background:var(--purple-d);}
.th-mint .try-item.tried .try-box{background:var(--mint-d);}
.try-item.tried .try-txt{opacity:.6;}

/* divider */
.t-divider{height:2px;border-radius:2px;margin:16px 0;}
.th-pink .t-divider{background:var(--pink-l);}.th-blue .t-divider{background:var(--blue-l);}
.th-purple .t-divider{background:var(--purple-l);}.th-mint .t-divider{background:var(--mint-l);}

/* reflect prompts */
.prompt{margin-bottom:15px;}
.prompt-q{font-family:'Klee One',cursive;font-weight:600;font-size:16px;line-height:1.55;margin-bottom:9px;color:var(--ink);}
.answer{width:100%;min-height:108px;border:2.5px solid var(--border);border-radius:14px;padding:13px 15px;font-size:calc(14px * var(--ts));font-weight:600;line-height:1.7;color:var(--body);background:var(--off);resize:vertical;outline:none;transition:border-color .2s,background .2s;}
.answer:focus{background:#fff;}
.th-pink .answer:focus{border-color:var(--pink);}.th-blue .answer:focus{border-color:var(--blue);}
.th-purple .answer:focus{border-color:var(--purple);}.th-mint .answer:focus{border-color:var(--mint);}
.answer::placeholder{color:#C4C9D4;font-weight:600;}
.saved-tag{font-size:11px;font-weight:800;color:var(--mint-d);margin-top:5px;height:14px;opacity:0;transition:opacity .25s;}
.saved-tag.show{opacity:1;}

/* affirmation */
.affirm{border-radius:14px;padding:13px 16px;font-family:'Klee One',cursive;font-weight:600;font-size:14.5px;line-height:1.6;display:flex;gap:11px;align-items:flex-start;margin-top:14px;border:2px solid;}
.affirm .ai{font-size:20px;flex-shrink:0;}
.th-pink .affirm{background:var(--pink-l);color:#8b1a60;border-color:var(--pink);}
.th-blue .affirm{background:var(--blue-l);color:#1a4f7a;border-color:var(--blue);}
.th-purple .affirm{background:var(--purple-l);color:#4c1d95;border-color:var(--purple);}
.th-mint .affirm{background:var(--mint-l);color:#065f46;border-color:var(--mint);}

/* checkpoint */
.checkpoint{border-radius:22px;padding:20px;margin:18px 0;border:2.5px solid;}
.th-pink .checkpoint{background:var(--pink-l);border-color:var(--pink);}
.th-blue .checkpoint{background:var(--blue-l);border-color:var(--blue);}
.th-purple .checkpoint{background:var(--purple-l);border-color:var(--purple);}
.th-mint .checkpoint{background:var(--mint-l);border-color:var(--mint);}
.checkpoint h3{font-family:'Fredoka One',cursive;font-size:18px;margin-bottom:5px;}
.th-pink .checkpoint h3{color:var(--pink-d);}.th-blue .checkpoint h3{color:var(--blue-d);}
.th-purple .checkpoint h3{color:var(--purple-d);}.th-mint .checkpoint h3{color:var(--mint-d);}
.checkpoint .cks{font-size:13px;font-weight:700;font-style:italic;opacity:.8;margin-bottom:12px;}

/* chapter footer nav */
.ch-foot{display:flex;gap:11px;margin-top:20px;}
.btn{padding:14px 22px;border-radius:100px;font-family:'Fredoka One',cursive;font-size:15px;transition:transform .15s,box-shadow .2s;flex:1;text-align:center;}
.btn:active{transform:scale(.97);}
.btn-ghost{background:#fff;color:var(--body);border:2.5px solid var(--border);flex:0 0 auto;padding:14px 20px;}
.btn-pink{background:linear-gradient(135deg,var(--pink),var(--pink-d));color:#fff;box-shadow:0 6px 18px rgba(217,77,150,.35);}
.btn-blue{background:linear-gradient(135deg,var(--blue),var(--blue-d));color:#fff;box-shadow:0 6px 18px rgba(46,134,193,.32);}
.btn-purple{background:linear-gradient(135deg,var(--purple),var(--purple-d));color:#fff;box-shadow:0 6px 18px rgba(109,40,217,.32);}
.btn-mint{background:linear-gradient(135deg,var(--mint),var(--mint-d));color:#fff;box-shadow:0 6px 18px rgba(5,150,105,.3);}

/* ════════════ CHECK-IN ════════════ */
.checkin-intro{font-size:13.5px;font-weight:700;color:#7c7289;line-height:1.6;margin-bottom:20px;}
.slider-card{background:#fff;border-radius:22px;padding:20px;box-shadow:var(--shadow-sm);margin-bottom:14px;}
.slider-card h3{font-family:'Fredoka One',cursive;font-size:16px;color:var(--ink);margin-bottom:3px;}
.slider-card .sc-sub{font-size:12.5px;font-weight:700;color:#9b91ab;margin-bottom:14px;}
.emoji-readout{text-align:center;font-size:54px;line-height:1;margin:6px 0 12px;transition:transform .2s;}
.emoji-readout b{display:block;font-family:'Fredoka One',cursive;font-size:15px;margin-top:8px;color:var(--purple-d);}
.eslider{-webkit-appearance:none;appearance:none;width:100%;height:16px;border-radius:100px;outline:none;}
.eslider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:38px;height:38px;border-radius:50%;background:#fff;border:3px solid var(--purple-d);box-shadow:0 4px 12px rgba(109,40,217,.35);cursor:grab;}
.eslider::-moz-range-thumb{width:38px;height:38px;border-radius:50%;background:#fff;border:3px solid var(--purple-d);box-shadow:0 4px 12px rgba(109,40,217,.35);cursor:grab;}
.eslider.mood{background:linear-gradient(90deg,#c8b6f0,#A78BFA,#5BB8F5,#34D399);}
.eslider.energy{background:linear-gradient(90deg,#ffd8ec,#FF6EB4,#d94d96);}
.eslider.sensory{background:linear-gradient(90deg,#DDF0FF,#5BB8F5,#2E86C1);}
.slider-scale{display:flex;justify-content:space-between;font-size:18px;margin-top:8px;padding:0 4px;}
.slider-scale span{opacity:.5;}
.spoons{text-align:center;font-size:30px;letter-spacing:2px;margin:4px 0 10px;min-height:38px;}
.checkin-save{width:100%;margin-top:4px;}
.log-list{margin-top:8px;}
.log-item{display:flex;align-items:center;gap:12px;background:#fff;border-radius:16px;padding:12px 15px;box-shadow:var(--shadow-sm);margin-bottom:9px;}
.log-item .li-em{font-size:26px;}
.log-item .li-body{flex:1;}
.log-item .li-date{font-weight:800;font-size:13px;color:var(--ink);}
.log-item .li-detail{font-size:12px;font-weight:700;color:#9b91ab;margin-top:1px;}

/* ════════════ SETTINGS ════════════ */
.set-group{background:#fff;border-radius:22px;padding:8px 18px;box-shadow:var(--shadow-sm);margin-bottom:16px;}
.set-row{display:flex;align-items:center;gap:13px;padding:15px 0;border-bottom:1.5px solid var(--off);}
.set-group .set-row:last-child{border-bottom:none;}
.set-row .sr-em{font-size:23px;width:30px;text-align:center;flex-shrink:0;}
.set-row .sr-body{flex:1;min-width:0;}
.set-row .sr-t{font-weight:800;font-size:14.5px;color:var(--ink);}
.set-row .sr-d{font-size:12px;font-weight:700;color:#9b91ab;line-height:1.4;margin-top:1px;}
/* toggle */
.toggle{width:52px;height:30px;border-radius:100px;background:var(--border);position:relative;flex-shrink:0;transition:background .25s;}
.toggle.on{background:var(--mint);}
.toggle::after{content:'';position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;background:#fff;box-shadow:0 2px 6px rgba(0,0,0,.2);transition:transform .25s;}
.toggle.on::after{transform:translateX(22px);}
/* segmented (font size) */
.seg{display:flex;background:var(--off);border-radius:12px;padding:4px;gap:4px;flex-shrink:0;}
.seg button{padding:7px 13px;border-radius:9px;font-weight:800;font-size:13px;color:#9b91ab;transition:.18s;}
.seg button.on{background:#fff;color:var(--purple-d);box-shadow:var(--shadow-sm);}
.set-action{width:100%;text-align:left;display:flex;align-items:center;gap:13px;padding:15px 0;}
.set-action .sa-arrow{margin-left:auto;font-size:18px;color:#bdb4cc;}
.danger{color:#dc2626 !important;}

/* ════════════ BOTTOM NAV ════════════ */
.tabbar{display:flex;background:rgba(255,255,255,.9);backdrop-filter:blur(16px);border-top:1px solid rgba(180,150,210,.18);
  padding:8px 6px calc(8px + env(safe-area-inset-bottom));position:absolute;bottom:0;left:0;right:0;z-index:70;}
.calm .tabbar{background:#fff;backdrop-filter:none;}
.tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:7px 0;border-radius:14px;transition:transform .15s;}
.tab:active{transform:scale(.9);}
.tab .ti{font-size:22px;filter:grayscale(.55);opacity:.55;transition:.2s;transform:scale(.92);}
.tab .tl{font-size:10px;font-weight:800;color:#a99fbb;letter-spacing:.02em;transition:.2s;}
.tab.on .ti{filter:none;opacity:1;transform:scale(1.12);}
.tab.on .tl{color:var(--purple-d);}

/* ════════════ FINISH ════════════ */
#finish{position:absolute;inset:0;z-index:240;display:none;flex-direction:column;align-items:center;justify-content:center;
  padding:34px 28px;text-align:center;overflow-y:auto;
  background:var(--cover-bg);}
#finish.show{display:flex;}
#finish .fin-emoji{font-size:64px;margin-bottom:10px;animation:floaty 4s ease-in-out infinite;}
#finish h2{font-family:'Fredoka One',cursive;font-size:30px;line-height:1.12;margin-bottom:12px;
  background:linear-gradient(135deg,var(--cover-ink),var(--cover-ink2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
#finish p{font-size:14px;font-weight:700;line-height:1.7;color:var(--body);max-width:320px;margin-bottom:8px;}
#finish .fin-logo{width:100px;height:100px;border-radius:50%;background:rgba(255,255,255,.7);padding:8px;object-fit:contain;margin:18px 0 6px;box-shadow:var(--shadow);}
#finish .fin-handle{font-family:'Fredoka One',cursive;font-size:14px;color:var(--pink-d);}
#finish .fin-actions{display:flex;flex-direction:column;gap:11px;width:100%;max-width:300px;margin-top:20px;}

/* ════════════ CONFETTI ════════════ */
#confetti{position:absolute;inset:0;pointer-events:none;z-index:400;overflow:hidden;}
.confetti-bit{position:absolute;top:-40px;font-size:22px;will-change:transform;animation:fall linear forwards;}
@keyframes fall{to{transform:translateY(120vh) rotate(540deg);}}

/* ════════════ MODAL / TOAST ════════════ */
.toast{position:absolute;left:50%;bottom:92px;transform:translateX(-50%) translateY(20px);z-index:500;
  background:var(--ink);color:#fff;padding:12px 22px;border-radius:100px;font-weight:800;font-size:13.5px;
  box-shadow:0 10px 30px rgba(0,0,0,.3);opacity:0;transition:opacity .3s,transform .3s;pointer-events:none;white-space:nowrap;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.sheet-backdrop{position:absolute;inset:0;z-index:450;background:rgba(26,26,46,.45);backdrop-filter:blur(2px);opacity:0;pointer-events:none;transition:opacity .3s;display:flex;align-items:flex-end;}
.sheet-backdrop.show{opacity:1;pointer-events:auto;}
.sheet{width:100%;background:#fff;border-radius:28px 28px 0 0;padding:24px 22px calc(28px + env(safe-area-inset-bottom));transform:translateY(100%);transition:transform .34s cubic-bezier(.2,.8,.2,1);max-height:82%;overflow-y:auto;}
.sheet-backdrop.show .sheet{transform:translateY(0);}
.sheet-grip{width:42px;height:5px;border-radius:5px;background:var(--border);margin:0 auto 16px;}
.sheet h3{font-family:'Fredoka One',cursive;font-size:20px;margin-bottom:8px;color:var(--ink);}
.sheet p{font-size:13.5px;font-weight:700;line-height:1.6;color:#6f6680;margin-bottom:16px;}

/* font scale hooks */
.fs-l{--ts:1.16;}
.fs-s{--ts:.9;}
.fs-l .topic-def,.fs-l .greet-sub,.fs-l .hero-txt p{font-size:calc(14px*var(--ts));}
.fs-l .prompt-q{font-size:calc(16px*var(--ts));}

/* reduce motion global */
.reduce-motion *,.reduce-motion *::before,.reduce-motion *::after{animation-duration:.001s !important;transition-duration:.001s !important;}

/* dyslexia-friendly */
.dys,.dys textarea,.dys input,.dys button{font-family:'Verdana','Nunito',sans-serif !important;letter-spacing:.02em;}
.dys .prompt-q,.dys .affirm{font-family:'Verdana','Nunito',sans-serif !important;}
.dys .answer{line-height:1.9;}

/* ════════════ THEMES (palette swaps; surfaces stay light) ════════════ */
body[data-theme="tide"]{
  --pink:#2FB6A0;--pink-d:#178978;--pink-l:#D2F0EB;--pink-ll:#ecf9f6;
  --blue:#45B2E0;--blue-d:#1E7DA8;--blue-l:#D6EDF9;--blue-ll:#eef7fc;
  --purple:#6189EF;--purple-d:#2E54BF;--purple-l:#DEE6FB;--purple-ll:#eef2fd;
  --mint:#E0A24E;--mint-d:#B0741E;--mint-l:#F6E8CD;--mint-ll:#fbf3e3;
  --page-bg:radial-gradient(1200px 700px at 80% -10%,#dde9f6 0%,transparent 55%),radial-gradient(1000px 800px at -10% 110%,#def0f2 0%,transparent 55%),linear-gradient(160deg,#e6edf6 0%,#dfeef1 45%,#eaf2f8 100%);
  --cover-bg:linear-gradient(165deg,#d9e6f4 0%,#cfe9ee 38%,#dbe7f6 72%,#e8f0f8 100%);
  --cover-ink:#2E54BF;--cover-ink2:#178978;--cover-sub:#1E7DA8;
  --shadow:0 10px 36px rgba(46,84,191,.16),0 3px 12px rgba(30,125,168,.10);
  --shadow-sm:0 4px 16px rgba(46,84,191,.12);
}

/* theme picker */
.theme-row{display:flex;gap:11px;overflow-x:auto;padding:2px 2px 8px;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
.theme-row::-webkit-scrollbar{display:none;}
.theme-card{flex:0 0 auto;width:90px;border-radius:18px;background:#fff;box-shadow:var(--shadow-sm);border:2.5px solid transparent;transition:transform .15s,border-color .15s;overflow:hidden;text-align:center;}
.theme-card:active{transform:scale(.96);}
.theme-card.on{border-color:var(--purple-d);}
.theme-swatch{height:48px;display:flex;}
.theme-swatch span{flex:1;}
.theme-name{font-weight:800;font-size:11.5px;color:var(--body);padding:7px 4px 9px;display:flex;align-items:center;justify-content:center;gap:4px;line-height:1;}
.theme-card.on .theme-name{color:var(--purple-d);}
.theme-check{color:var(--mint-d);font-size:12px;}

/* ════════════ NEED A MOMENT (grounding) ════════════ */
.moment-btn{display:flex;align-items:center;gap:13px;width:100%;text-align:left;background:#fff;border-radius:20px;padding:15px 17px;
  box-shadow:var(--shadow-sm);margin-bottom:6px;border:2px solid var(--purple-l);transition:transform .15s;}
.moment-btn:active{transform:scale(.98);}
.moment-btn .mb-em{font-size:30px;flex-shrink:0;}
.moment-btn .mb-body{flex:1;min-width:0;text-align:left;}
.moment-btn .mb-t{display:block;font-family:'Fredoka One',cursive;font-size:15px;color:var(--purple-d);}
.moment-btn .mb-s{display:block;font-size:12.5px;font-weight:700;color:var(--muted,#8a8099);margin-top:1px;}
.moment-btn .mb-go{font-size:18px;color:var(--purple-d);}
.moment-btn.cards-btn{margin-bottom:16px;}

#moment{position:absolute;inset:0;z-index:260;display:none;overflow:hidden;
  background:radial-gradient(130% 90% at 50% 0%, #2c2358 0%, #1a1535 45%, #0d0a1c 100%);}
#moment.show{display:block;}
#voidCanvas{position:absolute;inset:0;width:100%;height:100%;display:block;touch-action:none;}
.moment-close{position:absolute;top:15px;right:15px;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.16);
  backdrop-filter:blur(6px);font-size:16px;color:#fff;display:flex;align-items:center;justify-content:center;
  border:1.5px solid rgba(255,255,255,.25);z-index:3;}
.moment-close:active{transform:scale(.9);}
.moment-cap{position:absolute;top:30px;left:0;right:0;z-index:2;text-align:center;padding:0 30px;pointer-events:none;}
.moment-cap-t{font-family:'Fredoka One',cursive;font-size:21px;color:#fff;text-shadow:0 2px 18px rgba(150,120,255,.6);}
.moment-cap-s{font-weight:700;font-size:12.5px;color:rgba(255,255,255,.78);margin-top:6px;line-height:1.5;}
.moment-hint{position:absolute;left:50%;top:96px;transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none;
  transition:opacity .6s ease;opacity:1;width:max-content;max-width:88%;}
.moment-hint.hide{opacity:0;}
.mh-chip{background:rgba(255,255,255,.13);backdrop-filter:blur(6px);border:1.5px solid rgba(255,255,255,.22);
  color:rgba(255,255,255,.92);font-weight:800;font-size:12px;padding:8px 14px;border-radius:100px;white-space:nowrap;
  box-shadow:0 2px 14px rgba(120,90,255,.25);}

/* ════════════ NEURODIVERSITY INTRO (sky map) ════════════ */
.neuro-card{border-radius:22px;overflow:hidden;box-shadow:var(--shadow);margin-bottom:16px;background:#fff;}
.neuro-head{position:relative;width:100%;text-align:left;padding:17px 44px 16px 18px;color:#fff;overflow:hidden;
  background:radial-gradient(130% 120% at 80% -10%, #34306b 0%, #211c47 48%, #14112e 100%);}
.nh-stars{position:absolute;inset:0;display:flex;gap:7%;justify-content:space-around;align-items:flex-start;padding-top:9px;
  font-size:13px;color:rgba(255,255,255,.5);pointer-events:none;}
.nh-stars span:nth-child(2n){color:#ffe9b3;font-size:10px;}
.nh-stars span:nth-child(3n){opacity:.4;}
.nh-title{position:relative;font-family:'Fredoka One',cursive;font-size:20px;text-shadow:0 2px 16px rgba(140,120,255,.6);}
.nh-sub{position:relative;font-weight:700;font-size:12.5px;color:rgba(255,255,255,.8);margin-top:3px;}
.nh-sub i{font-style:italic;color:#ffe9b3;}
.nh-caret{position:absolute;right:16px;top:50%;transform:translateY(-50%);font-size:15px;color:rgba(255,255,255,.85);transition:transform .25s;}
.neuro-card.open .nh-caret{transform:translateY(-50%) rotate(180deg);}
.neuro-body{max-height:0;overflow:hidden;transition:max-height .35s ease;}
.neuro-card.open .neuro-body{max-height:1400px;}
.neuro-inner{padding:16px 18px 18px;}
.neuro-def{margin-bottom:13px;}
.nd-term{font-family:'Fredoka One',cursive;font-size:14.5px;color:var(--purple-d);margin-bottom:5px;}
.nd-term span{font-family:'Nunito',sans-serif;font-weight:800;font-size:11.5px;color:#a99fbb;font-style:italic;}
.neuro-def p{font-size:13.5px;font-weight:600;color:var(--body);line-height:1.6;}
.neuro-def p b{color:var(--ink);font-weight:800;}
.neuro-aside{background:var(--purple-ll);border-radius:14px;padding:11px 13px;font-size:12.5px;font-weight:700;color:var(--body);line-height:1.55;margin:4px 0 13px;}
.neuro-aside b{color:var(--purple-d);}
.neuro-close{font-family:'Klee One',cursive;font-size:13.5px;font-weight:600;color:var(--pink-d);line-height:1.6;text-align:center;
  border-top:1.5px dashed var(--border);padding-top:13px;}
/* home welcome variant */
.neuro-home{border:2px solid var(--purple-l);}
.neuro-welcome{background:radial-gradient(130% 120% at 80% -10%, #34306b 0%, #211c47 48%, #14112e 100%);
  color:#ffe9b3;font-weight:800;font-size:11.5px;letter-spacing:.04em;text-align:center;padding:11px 14px 0;}
.neuro-dismiss{display:block;width:100%;margin-top:14px;border-radius:14px;padding:13px;
  font-family:'Fredoka One',cursive;font-size:14px;color:#fff;
  background:linear-gradient(135deg,var(--purple),var(--purple-d));box-shadow:0 4px 14px rgba(109,40,217,.3);transition:transform .15s;}
.neuro-dismiss:active{transform:scale(.97);}
.moment-done{position:absolute;left:50%;bottom:calc(26px + env(safe-area-inset-bottom));transform:translateX(-50%);z-index:2;
  background:rgba(255,255,255,.15);backdrop-filter:blur(7px);color:#fff;border:1.5px solid rgba(255,255,255,.32);
  padding:13px 26px;border-radius:100px;font-family:'Fredoka One',cursive;font-size:14px;white-space:nowrap;transition:transform .15s;}
.moment-done:active{transform:translateX(-50%) scale(.96);}

/* ════════════ AFFIRMATION CARD PULL ════════════ */
.cards-btn{border-color:var(--mint-l);}
#cards{position:absolute;inset:0;z-index:260;display:none;flex-direction:column;align-items:center;justify-content:center;
  padding:30px 26px calc(30px + env(safe-area-inset-bottom));
  background:radial-gradient(130% 90% at 50% 0%, #2c2358 0%, #1a1535 45%, #0d0a1c 100%);overflow:hidden;}
#cards.show{display:flex;}
#cardSky{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;}
#cards .moment-close,#cards .cards-cap,.card-stage,.cards-again{z-index:2;}
#cards .moment-close{position:absolute;top:15px;right:15px;}
.cards-cap{position:absolute;top:30px;left:0;right:0;z-index:2;text-align:center;padding:0 30px;pointer-events:none;}
.cards-cap-t{font-family:'Fredoka One',cursive;font-size:21px;color:#fff;text-shadow:0 2px 18px rgba(150,120,255,.6);}
.cards-cap-s{font-weight:700;font-size:12.5px;color:rgba(255,255,255,.78);margin-top:6px;line-height:1.5;max-width:300px;margin-left:auto;margin-right:auto;}
.card-stage{position:relative;display:flex;align-items:center;justify-content:center;perspective:1300px;margin-top:18px;}
.affcard{width:248px;height:344px;cursor:pointer;}
.affcard-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .62s cubic-bezier(.4,.15,.2,1);}
.affcard.flipped .affcard-inner{transform:rotateY(180deg);}
.affcard-face{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;
  border-radius:22px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  padding:26px 22px;overflow:hidden;}
/* back of card */
.affcard-back{background:radial-gradient(120% 100% at 50% 0%, #3a3170 0%, #221c49 55%, #14112e 100%);
  border:2.5px solid rgba(190,170,255,.35);box-shadow:0 18px 50px rgba(20,10,50,.6), inset 0 0 40px rgba(120,90,220,.2);gap:12px;}
.affcard-back .ab-stars{display:flex;gap:10px;color:#ffe9b3;font-size:13px;opacity:.85;}
.affcard-back .ab-mark{font-size:46px;color:#ffe7a8;text-shadow:0 0 22px rgba(255,210,120,.8);}
.affcard-back .ab-word{font-family:'Fredoka One',cursive;font-size:17px;
  background:linear-gradient(135deg,#ffd6ec,#c7b3ff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.affcard-back .ab-tap{margin-top:6px;font-weight:800;font-size:11.5px;letter-spacing:.06em;color:rgba(255,255,255,.62);
  border:1.5px solid rgba(255,255,255,.28);border-radius:100px;padding:7px 15px;}
/* front (revealed affirmation) — echoes the printed deck */
.affcard-front{transform:rotateY(180deg);background:#fffdf7;border:2.5px solid #4a3a63;
  box-shadow:0 18px 50px rgba(20,10,50,.55);}
.af-text{font-family:'Klee One',cursive;font-weight:600;color:#2a2340;line-height:1.34;text-wrap:balance;z-index:1;}
.af-author{margin-top:14px;font-family:'Klee One',cursive;font-weight:600;font-size:14px;color:#8a5a9a;z-index:1;}
.af-star{position:absolute;color:#f6c84c;filter:drop-shadow(0 1px 0 #d9a93a);}
.af-s1{top:18px;right:22px;font-size:20px;}
.af-s2{top:40px;right:44px;font-size:12px;opacity:.8;}
.af-s3{bottom:22px;left:22px;font-size:18px;}
.af-s4{bottom:42px;left:46px;font-size:11px;opacity:.8;}
.cards-again{margin-top:26px;opacity:0;transform:translateY(8px);pointer-events:none;transition:opacity .4s,transform .4s;
  background:rgba(255,255,255,.15);backdrop-filter:blur(7px);color:#fff;border:1.5px solid rgba(255,255,255,.32);
  padding:13px 26px;border-radius:100px;font-family:'Fredoka One',cursive;font-size:14px;white-space:nowrap;z-index:2;}
.cards-again.show{opacity:1;transform:translateY(0);pointer-events:auto;}
.cards-again:active{transform:scale(.96);}
.card-spark{position:absolute;pointer-events:none;color:#ffe7a8;font-size:15px;z-index:5;
  animation:cardSpark .9s ease-out forwards;text-shadow:0 0 8px rgba(255,210,120,.8);}
@keyframes cardSpark{0%{transform:translate(-50%,-50%) scale(.3);opacity:0;}
  30%{opacity:1;}100%{transform:translate(calc(-50% + var(--dx)),calc(-50% + var(--dy))) scale(1);opacity:0;}}
.reduce-motion .affcard-inner{transition:transform .01s;}
.reduce-motion .card-spark{display:none;}

/* favorite star on card + saved drawer */
.af-fav{position:absolute;top:12px;left:12px;width:34px;height:34px;border-radius:50%;z-index:3;
  display:flex;align-items:center;justify-content:center;font-size:18px;line-height:1;color:#c9a0c4;
  background:rgba(255,255,255,.7);box-shadow:0 2px 8px rgba(120,60,120,.18);transition:transform .15s,color .15s;}
.af-fav.on{color:#e0568f;}
.af-fav:active{transform:scale(.86);}
.fav-open{position:absolute;left:50%;transform:translateX(-50%);bottom:calc(22px + env(safe-area-inset-bottom));z-index:2;
  background:rgba(255,255,255,.14);backdrop-filter:blur(7px);border:1.5px solid rgba(255,255,255,.3);
  color:#fff;font-family:'Fredoka One',cursive;font-size:12.5px;padding:9px 14px;border-radius:100px;transition:transform .15s;}
.fav-open:active{transform:translateX(-50%) scale(.95);}
.fav-open span{opacity:.85;}
.favs-scrim{position:absolute;inset:0;z-index:4;background:rgba(10,8,24,.55);backdrop-filter:blur(2px);
  opacity:0;pointer-events:none;transition:opacity .3s;}
.favs-scrim.show{opacity:1;pointer-events:auto;}
.favs-panel{position:absolute;top:0;right:0;bottom:0;width:min(82%,330px);z-index:5;
  background:linear-gradient(180deg,#241d4a,#16122f);box-shadow:-12px 0 40px rgba(0,0,0,.45);
  transform:translateX(100%);transition:transform .34s cubic-bezier(.4,.1,.2,1);
  display:flex;flex-direction:column;padding:calc(18px + env(safe-area-inset-top)) 0 0;}
.favs-panel.show{transform:translateX(0);}
.favs-head{display:flex;align-items:center;justify-content:space-between;padding:4px 18px 14px;border-bottom:1.5px solid rgba(255,255,255,.1);}
.favs-title{font-family:'Fredoka One',cursive;font-size:16px;color:#ffe9b3;}
.favs-close{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;font-size:15px;
  display:flex;align-items:center;justify-content:center;}
.favs-close:active{transform:scale(.9);}
.favs-list{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:14px;display:flex;flex-direction:column;gap:10px;}
.favs-empty{margin:auto;text-align:center;color:rgba(255,255,255,.6);font-weight:700;font-size:13px;line-height:1.5;
  display:flex;flex-direction:column;align-items:center;gap:10px;padding:24px 10px;}
.favs-empty span{max-width:200px;}
.favs-empty{font-size:13px;}
.favs-empty::first-line{font-size:34px;}
.fav-item{display:flex;align-items:flex-start;gap:10px;background:#fffdf7;border-radius:14px;padding:13px 13px;
  box-shadow:0 4px 14px rgba(0,0,0,.25);}
.fav-item-body{flex:1;min-width:0;}
.fav-item-t{font-family:'Klee One',cursive;font-weight:600;font-size:14.5px;color:#2a2340;line-height:1.34;}
.fav-item-a{font-family:'Klee One',cursive;font-weight:600;font-size:12.5px;color:#8a5a9a;margin-top:5px;}
.fav-item-x{flex-shrink:0;width:26px;height:26px;border-radius:50%;background:#f3e7ef;color:#a06797;font-size:12px;
  display:flex;align-items:center;justify-content:center;}
.fav-item-x:active{transform:scale(.88);}

/* add-to-home-screen instructions */
.how-steps{margin:4px 0 2px;padding-left:0;list-style:none;counter-reset:hs;display:flex;flex-direction:column;gap:11px;}
.how-steps li{position:relative;padding-left:38px;font-weight:700;font-size:13.5px;color:var(--body);line-height:1.45;counter-increment:hs;}
.how-steps li::before{content:counter(hs);position:absolute;left:0;top:-1px;width:26px;height:26px;border-radius:50%;
  background:linear-gradient(135deg,var(--purple),var(--purple-d));color:#fff;font-family:'Fredoka One',cursive;font-size:13px;
  display:flex;align-items:center;justify-content:center;}
.how-ic{display:inline-block;margin:0 1px;}
.how-note{margin-top:12px;font-size:12px;font-weight:700;color:#9b91ab;line-height:1.45;}
