:root{
--safe-top:env(safe-area-inset-top,0px);
--safe-bottom:env(safe-area-inset-bottom,0px);--bg:#f5f0e8;--bg2:#ede7d8;--sidebar:#e8e0ce;--text:#2a2018;--text2:#4a3828;--text3:#6b5a3e;--accent:#8a5a20;--accent2:#c8903a;--card:rgba(255,255,255,.6);--border:rgba(100,80,40,.14);--paper:#fdf8ee;--paper-line:rgba(180,160,120,.25);--paper-margin:rgba(220,100,100,.28);--paper-text:#2a200e;--hole:#ede7d8;--progress:linear-gradient(90deg,#8a5a20,#c8903a);--shadow:0 2px 20px rgba(80,60,30,.08)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--text);font-family:'Cormorant Garamond',Georgia,serif;min-height:100vh;transition:background .4s,color .3s;font-size:16px;line-height:1.6;touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.ui-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border-radius:20px;font-family:'Cormorant SC',serif;font-size:12px;letter-spacing:1.5px;cursor:pointer;transition:background .18s,border-color .18s,color .18s,opacity .18s;min-height:36px;padding:8px 16px;text-decoration:none}
.ui-btn-primary{background:rgba(138,90,32,.1);border:1.5px solid rgba(138,90,32,.28);color:var(--accent)}
.ui-btn-primary:hover{background:rgba(138,90,32,.16);border-color:rgba(138,90,32,.42)}
.ui-btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text3)}
.ui-btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.ui-btn-danger{background:transparent;border:1.5px solid rgba(180,60,60,.3);color:rgba(180,60,60,.78)}
.ui-btn-danger:hover{background:rgba(180,60,60,.06);border-color:rgba(180,60,60,.48)}
.ui-btn-small{min-height:30px;padding:5px 10px;font-size:11px;letter-spacing:1px;border-radius:8px}
.ui-btn-block{width:100%}
.ui-action-row{display:flex;gap:9px;margin-top:16px;flex-wrap:wrap}
.ui-action-row .ui-btn{flex:1}
.ui-overlay{display:none;position:fixed;inset:0;align-items:center;justify-content:center;background:rgba(30,20,10,.55);backdrop-filter:blur(3px);padding:16px}
.ui-modal{background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:26px;width:min(420px,calc(100vw - 32px));max-height:90vh;overflow-y:auto;animation:popIn .2s ease;box-shadow:0 14px 52px rgba(0,0,0,.18);position:relative}
.ui-modal-card{background:var(--card);border-radius:18px;padding:26px 22px;box-shadow:0 20px 60px rgba(30,20,10,.3)}
.ui-modal-close{position:absolute;top:14px;right:16px;background:none;border:none;font-size:20px;color:var(--text3);cursor:pointer;line-height:1}
.ui-modal-title{font-size:20px;font-weight:300;font-style:italic;color:var(--text);margin-bottom:18px}
.ui-kicker{font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:1.5px;color:var(--accent)}
.ui-subtle{font-size:12px;color:var(--text3);font-style:italic;margin-top:5px}
.ui-toolbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:10px 22px;background:var(--bg);border-bottom:1px solid rgba(138,90,32,.12)}
.ui-toolbar-title{font-family:'Cormorant SC',serif;font-size:11px;letter-spacing:3px;color:var(--accent);opacity:.7;text-align:center;flex:1;padding:0 12px}
.ui-toolbar-actions{display:flex;gap:6px;align-items:center}
.pwa-status{position:fixed;left:50%;bottom:calc(18px + var(--safe-bottom));transform:translateX(-50%);z-index:1600;display:none;align-items:center;gap:12px;max-width:calc(100vw - 32px);padding:10px 14px;background:rgba(42,32,24,.94);color:#fff;border:1px solid rgba(255,255,255,.12);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.28);font-size:14px;line-height:1.35}
.pwa-status.show{display:flex;animation:notifIn .22s ease}
.pwa-status button{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);border-radius:8px;color:#fff;cursor:pointer;font-family:'Cormorant SC',serif;font-size:11px;letter-spacing:1.3px;padding:6px 10px;white-space:nowrap}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes popIn{from{opacity:0;transform:scale(.93)}to{opacity:1;transform:scale(1)}}
@keyframes recPulse{0%,100%{box-shadow:0 0 0 0 rgba(220,60,60,.4)}50%{box-shadow:0 0 0 8px rgba(220,60,60,0)}}
@keyframes shimmer{0%,100%{opacity:.5}50%{opacity:1}}
@keyframes dotPulse{0%,80%,100%{opacity:.2;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}
@keyframes notifIn{0%{opacity:0;transform:translateX(-50%) translateY(12px)}100%{opacity:1;transform:translateX(-50%) translateY(0)}}
@keyframes xpFloat{0%{opacity:1;transform:translateY(0)}100%{opacity:0;transform:translateY(-40px)}}
@keyframes inkFlourish{0%{opacity:0;transform:translate(0,0) scale(.6)}20%{opacity:.9;transform:translate(-6px,-12px) scale(1)}100%{opacity:0;transform:translate(-16px,-44px) scale(1.1)}}
.ink-flourish{position:fixed;pointer-events:none;font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--accent);animation:inkFlourish 1.4s ease-out forwards;z-index:9999}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.once-seg-text:empty::before{content:attr(data-placeholder);color:rgba(120,100,70,.32);font-style:italic;pointer-events:none}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}

/* ── LAYOUT ── */
#app{display:flex;height:100vh;overflow:hidden}
#print-area{display:none}
@media print{
 body>*{display:none!important}
 #print-area{display:block!important;font-family:Georgia,serif;font-size:11pt;line-height:1.8;color:#222;max-width:700px;margin:0 auto;padding:32px}
 #print-area h1{font-size:20pt;color:#8a5a20;border-bottom:2px solid #c8a060;padding-bottom:8pt;margin-bottom:4pt}
 #print-area h2{font-size:14pt;color:#8a5a20;margin-top:28pt;margin-bottom:4pt;border-bottom:1px solid #e8d0a0;padding-bottom:3pt}
 #print-area .q{color:#7a5a20;font-style:italic;margin-top:14pt;margin-bottom:2pt;font-size:10pt}
 #print-area .a{margin-bottom:10pt;margin-left:10pt}
 #print-area .date{font-size:8pt;color:#bbb}
 #print-area p{margin:5pt 0}
 /* Read overlay print — Cmd/Ctrl+P from the read view prints the story */
 @page{size:A4;margin:2.5cm 2cm}
 #read-overlay{display:block!important;position:static!important;overflow:visible!important;background:#faf6ef!important;z-index:auto!important}
 #read-overlay>div:first-child{display:none!important}
 #read-body{max-width:none!important;margin:0!important;padding:0!important;font-family:Georgia,serif;font-size:11.5pt;line-height:1.85;color:#3a2f24!important}
 #read-body .prose p,#read-body p{margin-bottom:1.4em;text-align:justify}
 #read-body h2{font-size:18pt;color:#8a5a20;margin-top:0;page-break-after:avoid;page-break-before:always}
 #read-body h2:first-child{page-break-before:auto}
 #read-body hr{border:none;border-top:1px solid #ddd;margin:18pt 0}
 #read-body .prose p:first-of-type::first-letter,#read-body p:first-of-type::first-letter{font-size:26pt;float:left;margin-right:5px;line-height:.85;color:#8a5a20;font-style:italic}
 [id^="read-weave-row"]{display:none!important}
}
#sidebar{width:268px;flex-shrink:0;background:var(--sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;transition:background .4s;position:relative;z-index:1}
#sb-top{padding:16px 16px 12px;border-bottom:1px solid var(--border)}
.sb-eye{font-family:'Cormorant SC',serif;font-size:10px;letter-spacing:4px;color:var(--accent);margin-bottom:2px;opacity:1}
.sb-title{font-size:24px;font-weight:500;color:var(--text);font-style:italic;letter-spacing:-.3px;line-height:1.2}
.sb-tag{font-size:13px;color:var(--accent);opacity:.95;margin-top:3px;line-height:1.4;font-style:italic;letter-spacing:.3px}
#ch-nav{flex:1;overflow-y:auto;padding:8px 0}
.nav-lbl{font-family:'Cormorant SC',serif;font-size:12px;letter-spacing:3px;color:var(--text2);padding:12px 18px 6px;opacity:1;font-weight:500}
.ch-item{display:flex;align-items:center;gap:12px;padding:10px 18px;cursor:pointer;transition:all .18s;border-left:2px solid transparent}
.ch-item:hover{background:rgba(0,0,0,.04)}
.ch-item.active{border-left-color:var(--accent);background:rgba(138,90,32,.07)}
.ch-emoji{font-size:18px;flex-shrink:0}
.ch-bubble{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.cc-bubble{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:28px;margin-bottom:12px}
.ch-info{flex:1;min-width:0}
.ch-name{font-family:'Cormorant SC',serif;font-size:14px;letter-spacing:.5px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ch-prog{font-size:12px;color:var(--text2);margin-top:2px}
.ch-tick{font-size:13px;color:var(--accent);flex-shrink:0}
#sb-btns{padding:8px 8px;border-top:1px solid var(--border);display:grid;grid-template-columns:repeat(4,1fr);gap:4px}
.sb-btn{width:100%;padding:9px 2px;border-radius:12px;font-size:21px;cursor:pointer;transition:all .18s;border:1px solid;text-align:center;overflow:hidden;line-height:1.2;user-select:text;-webkit-user-select:text}
.sb-lbl{display:block;font-family:'Cormorant SC',serif;font-size:10px;letter-spacing:.3px;margin-top:3px;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;color:var(--text)}
.sb-gold{background:linear-gradient(160deg,rgba(240,180,80,.22),rgba(200,120,40,.28));border:2px solid rgba(180,80,30,.55);color:var(--text);box-shadow:0 3px 0 rgba(160,60,20,.4),0 4px 12px rgba(180,80,20,.25),inset 0 1px 0 rgba(255,220,120,.4)}
.sb-gold:hover{background:linear-gradient(160deg,rgba(138,90,32,.28),rgba(200,140,50,.32))}
.sb-ghost{background:rgba(0,0,0,.02);border-color:rgba(0,0,0,.15);color:var(--text)}
.sb-gold .sb-lbl{color:var(--accent);font-weight:700}
.sb-ghost:hover{color:var(--text2);border-color:var(--text3)}

/* ── v166 SIDEBAR REDESIGN ────────────────────────────────────────
   Tier 1 — Primary pills (Home / Book / Profile): above chapters
   Tier 2 — Explore pills (Map / Tree / Timeline): below chapters
   Tier 3 — Utility icons (Search / Style / Help / ⋯): bottom row
*/
#sb-primary{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;padding:10px 10px 8px;border-bottom:1px solid var(--border)}
.sb-prim{position:relative;display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 4px;background:rgba(0,0,0,.02);border:1px solid rgba(0,0,0,.08);border-radius:12px;cursor:pointer;color:var(--text);transition:all .2s;font-family:inherit;min-height:56px}
.sb-prim:hover{background:rgba(138,90,32,.06);border-color:rgba(138,90,32,.25);transform:translateY(-1px)}
.sb-prim.sb-active{background:rgba(138,90,32,.10);border-color:rgba(138,90,32,.35)}
.sb-prim-ico{display:block;flex-shrink:0}
.sb-pill>svg:first-child{flex-shrink:0}
.sb-prim-lbl{font-family:'Cormorant SC',serif;font-size:11px;letter-spacing:1.5px;color:var(--text2);line-height:1}
.sb-prim-gold{background:linear-gradient(160deg,rgba(240,180,80,.20),rgba(200,120,40,.22));border:1.5px solid rgba(180,80,30,.45);box-shadow:0 2px 0 rgba(160,60,20,.25),inset 0 1px 0 rgba(255,220,120,.35)}
.sb-prim-gold:hover{background:linear-gradient(160deg,rgba(240,180,80,.30),rgba(200,120,40,.30))}
.sb-prim-gold .sb-prim-lbl{color:var(--accent);font-weight:600}

#sb-explore{padding:8px 10px 4px;border-top:1px solid var(--border);display:grid;grid-template-columns:1fr 1fr 1fr;gap:5px}
.sb-pill{display:flex;align-items:center;justify-content:center;gap:5px;padding:7px 4px;background:transparent;border:1px solid rgba(0,0,0,.09);border-radius:16px;cursor:pointer;color:var(--text2);font-family:'Cormorant SC',serif;font-size:10px;letter-spacing:1px;transition:all .18s;min-height:34px}
.sb-pill:hover{background:rgba(0,0,0,.03);color:var(--text);border-color:rgba(0,0,0,.2)}
.sb-pill.sb-active{background:rgba(138,90,32,.08);border-color:rgba(138,90,32,.3);color:var(--accent)}
.sb-pill > span:first-child{font-size:13px}
#sb-explore .sb-pill > span:last-child{font-weight:600;font-size:11px;letter-spacing:.5px}
.sb-pill > svg{opacity:.8}

#sb-utils{padding:6px 10px 12px;display:flex;gap:2px;align-items:center;justify-content:space-around}
.sb-util{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:10px;cursor:pointer;color:var(--text3);font-size:16px;transition:all .18s;padding:0;line-height:1}
.sb-util:hover{background:rgba(0,0,0,.05);color:var(--text)}
#sb-more-btn{font-size:20px;letter-spacing:-1px}

#sb-more-pop button.sb-pop-item{display:flex;align-items:center;gap:10px;width:100%;background:transparent;border:none;padding:10px 12px;font-family:inherit;font-size:15px;color:var(--text);cursor:pointer;border-radius:8px;text-align:left;transition:background .15s}
#sb-more-pop button.sb-pop-item:hover{background:rgba(138,90,32,.08)}
#sb-more-pop button.sb-pop-item span{flex:1}
#main{flex:1;overflow-y:auto;background:var(--bg);transition:background .4s}
.screen{display:none}.screen.active{display:flex;flex-direction:column;animation:fadeIn .35s ease}
#screen-flow.active{position:fixed;inset:0;z-index:100;overflow-y:auto;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:0}

/* ── FLOW PICKERS (mood / direction) ── */
.flow-picker-wrap{display:none;width:100%;align-items:center;justify-content:center;min-height:100vh}
.flow-eyebrow{font-family:'Cormorant SC',serif;font-size:11px;letter-spacing:3.5px;color:var(--accent);opacity:.7;margin-bottom:10px;text-align:center}
.flow-picker{max-width:460px;width:100%;padding:52px 28px 40px;text-align:center}
.flow-picker-btn{display:block;width:100%;background:var(--paper);border:1.5px solid rgba(138,90,32,.18);border-radius:16px;padding:18px 22px;cursor:pointer;text-align:left;margin-bottom:10px;transition:border-color .18s,box-shadow .18s,transform .1s}
.flow-picker-btn:hover{border-color:rgba(138,90,32,.5);box-shadow:0 6px 24px rgba(138,90,32,.12);transform:translateY(-1px)}
.flow-picker-btn .fp-label{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--text);margin-bottom:3px}
.flow-picker-btn .fp-sub{font-family:'Cormorant Garamond',serif;font-size:15px;font-style:italic;color:var(--text3)}

/* ── FLOW CARD — main writing surface ── */
#flow-card{max-width:640px;width:100%;margin:0 auto;display:none;flex-direction:column;padding:0}
.flow-card-inner{background:var(--paper);border-radius:20px;box-shadow:0 12px 48px rgba(60,35,10,.13),0 2px 0 rgba(255,248,235,.6) inset;padding:36px 40px 32px;position:relative;overflow:hidden}
.flow-card-inner::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(transparent,transparent 31px,rgba(138,90,32,.06) 31px,rgba(138,90,32,.06) 32px);background-position:0 52px;pointer-events:none;border-radius:20px}
@media(max-width:600px){.flow-card-inner{padding:26px 22px 24px;border-radius:16px}}

/* card header */
.flow-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:26px;gap:16px}
.flow-card-meta{display:flex;flex-direction:column;gap:5px}
.flow-chapter-lbl{font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:2.5px;color:var(--accent)}
.flow-chapter-desc{font-family:'Cormorant Garamond',serif;font-size:14px;font-style:italic;color:var(--text3);opacity:.7;line-height:1.3}
#flow-mood-btn{background:none;border:none;cursor:pointer;font-family:'Cormorant Garamond',serif;font-size:15px;font-style:italic;color:var(--text3);opacity:.5;padding:0;text-align:left;line-height:1.3;transition:opacity .2s}
#flow-mood-btn:hover{opacity:1}
.flow-explore-btn{background:none;border:none;cursor:pointer;font-family:'Cormorant Garamond',serif;font-size:15px;font-style:italic;color:var(--text3);opacity:.4;padding:0;white-space:nowrap;flex-shrink:0;margin-top:3px;transition:opacity .2s}
.flow-explore-btn:hover{opacity:.9}

/* question */
#flow-question{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:400;font-style:italic;color:var(--paper-text);line-height:1.42;margin-bottom:22px}
@media(max-width:480px){#flow-question{font-size:23px}}

/* answer textarea */
#flow-answer{width:100%;min-height:140px;resize:vertical;box-sizing:border-box;font-family:'Cormorant Garamond',serif;font-size:18px;background:transparent;border:none;border-bottom:1.5px solid rgba(138,90,32,.15);border-radius:0;padding:10px 0 14px;color:var(--paper-text);line-height:1.75;outline:none;display:block}
#flow-answer::placeholder{color:var(--paper-text);opacity:.35;font-style:italic}
#flow-answer:focus{border-bottom-color:rgba(138,90,32,.4)}
.answer-aid{display:flex;flex-direction:column;gap:10px;margin:0 0 14px}
.answer-aid:empty{display:none}
.aid-help-button{align-self:flex-start;border:0;background:none;color:var(--accent);padding:4px 0;font-family:'Cormorant Garamond',serif;font-size:15px;font-style:italic;cursor:pointer;text-decoration:underline;text-decoration-color:rgba(138,90,32,.25);text-underline-offset:4px}
.aid-help-button:hover{color:var(--text);text-decoration-color:rgba(138,90,32,.55)}
.aid-conversation{padding:12px 14px;border-left:2px solid rgba(138,90,32,.28);background:rgba(138,90,32,.035)}
.aid-conversation[hidden]{display:none}
.aid-conversation-label{font-family:'Cormorant SC',serif;font-size:10px;letter-spacing:1.5px;color:var(--accent);opacity:.7;margin-bottom:5px}
.aid-conversation-actions{display:flex;align-items:center;gap:14px;margin-top:10px}
.aid-more-button,.aid-done-button{border:0;background:none;padding:3px 0;font-family:'Cormorant Garamond',serif;font-size:14px;cursor:pointer}
.aid-more-button{color:var(--accent);font-style:italic}
.aid-done-button{color:var(--text3)}
.aid-more-button:hover,.aid-done-button:hover{color:var(--text)}
.aid-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.aid-chip,.aid-ghost,.aid-mode{border:1px solid rgba(138,90,32,.2);background:rgba(138,90,32,.045);color:var(--text2);border-radius:999px;padding:7px 12px;font-family:'Cormorant Garamond',serif;font-size:14px;font-style:italic;line-height:1.15;cursor:pointer;transition:border-color .16s,background .16s,color .16s}
.aid-chip:hover,.aid-ghost:hover,.aid-mode:hover{border-color:rgba(138,90,32,.45);background:rgba(138,90,32,.09);color:var(--accent)}
.aid-mode.active{background:var(--accent);border-color:var(--accent);color:#fff}
.aid-stuck{border-color:rgba(160,90,40,.28);background:rgba(160,90,40,.08);color:var(--accent)}
.aid-label{font-family:'Cormorant SC',serif;font-size:10px;letter-spacing:2px;color:var(--accent);opacity:.68}
.aid-difficulty{font-family:'Cormorant SC',serif;font-size:10px;letter-spacing:1.8px;color:var(--text3);border:1px solid rgba(138,90,32,.16);border-radius:999px;padding:5px 9px;background:rgba(255,255,255,.22)}
.aid-example,.aid-followup{font-family:'Cormorant Garamond',serif;font-size:15px;font-style:italic;line-height:1.45;color:var(--text3);background:rgba(138,90,32,.055);border-left:3px solid rgba(138,90,32,.22);padding:9px 12px;border-radius:0 10px 10px 0}
.aid-followup{display:none}
.aid-rescue{display:none;padding:10px;border:1px solid rgba(138,90,32,.16);border-radius:12px;background:rgba(138,90,32,.035)}
.aid-rescue.show{display:block}
.aid-miniq{font-family:'Cormorant Garamond',serif;font-size:16px;font-style:italic;color:var(--text2);line-height:1.45;margin:2px 0 9px}
.aid-timer{font-family:'Cormorant SC',serif;font-size:10px;letter-spacing:2px;color:var(--accent);opacity:.8;margin-left:auto}
.aid-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:10px;background:rgba(138,90,32,.045);border:1px solid rgba(138,90,32,.16);border-radius:12px}
.aid-form input{width:100%;box-sizing:border-box;border:1px solid rgba(138,90,32,.22);border-radius:8px;background:var(--bg2);color:var(--text);padding:8px 10px;font-family:'Cormorant Garamond',serif;font-size:15px}
.aid-form .wide{grid-column:1/-1}
@media(max-width:520px){.aid-form{grid-template-columns:1fr}.aid-form .wide{grid-column:auto}.aid-chip,.aid-ghost,.aid-mode{font-size:13px;padding:7px 10px}}

/* temporal module — reuses existing .dp-input styles, just wrapper */
#flow-temporal{margin-top:18px}

/* ── MANUSCRIPT METER ── */
.flow-meter{margin:20px 0 0;padding:18px 0 0;border-top:1px solid rgba(138,90,32,.1)}
.flow-meter-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-bottom:14px}
.flow-meter-stat{text-align:center;padding:0 8px}
.flow-meter-stat:not(:last-child){border-right:1px solid rgba(138,90,32,.12)}
.flow-meter-num{font-family:'Cormorant SC',serif;font-size:22px;color:var(--accent);letter-spacing:1px;line-height:1;margin-bottom:3px;transition:all .3s ease}
.flow-meter-num.bump{animation:meterBump .35s ease}
@keyframes meterBump{0%{transform:scale(1)}50%{transform:scale(1.18);color:var(--accent)}100%{transform:scale(1)}}
.flow-meter-lbl{font-family:'Cormorant Garamond',serif;font-size:12px;font-style:italic;color:var(--text3);opacity:.6;letter-spacing:.3px}
/* ink bar */
.flow-ink-bar-wrap{position:relative;height:5px;border-radius:10px;background:rgba(138,90,32,.08);overflow:visible}
.flow-ink-bar-fill{height:100%;border-radius:10px;background:linear-gradient(90deg,rgba(138,90,32,.5) 0%,rgba(190,120,30,.9) 100%);transition:width .6s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}
.flow-ink-bar-fill::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);animation:inkShimmer 2.6s ease-in-out infinite}
@keyframes inkShimmer{0%{transform:translateX(-100%)}70%{transform:translateX(200%)}100%{transform:translateX(200%)}}
.flow-ink-nib{position:absolute;right:-5px;top:-5px;width:11px;height:11px;border-radius:50%;background:rgba(180,110,25,.8);transform:scale(0);transition:transform .25s ease,opacity .3s;opacity:0;box-shadow:0 0 6px rgba(180,110,25,.5)}
.flow-ink-nib.active{transform:scale(1);opacity:1}

/* ── ACTION ROW ── */
.flow-actions{display:flex;align-items:center;justify-content:space-between;margin-top:24px;gap:12px;padding:0 40px 32px}
@media(max-width:600px){.flow-actions{padding:0 22px 24px}}
.flow-nav-group{display:flex;align-items:center;gap:16px}
.flow-prev-btn{background:none;border:none;cursor:pointer;font-family:'Cormorant Garamond',serif;font-size:17px;font-style:italic;color:var(--text3);opacity:.45;padding:4px 0;transition:opacity .2s;white-space:nowrap}
.flow-prev-btn:hover{opacity:.9}
.flow-prev-btn:disabled{opacity:.15;cursor:default}
.flow-skip-btn{background:none;border:none;cursor:pointer;font-family:'Cormorant Garamond',serif;font-size:17px;font-style:italic;color:var(--text3);opacity:.5;padding:4px 0;transition:opacity .2s;white-space:nowrap}
.flow-skip-btn:hover{opacity:.9}
.flow-continue-btn{background:var(--accent);color:#fff;border:none;border-radius:12px;padding:13px 34px;cursor:pointer;font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:2px;transition:transform .12s,box-shadow .12s;box-shadow:0 3px 14px rgba(138,90,32,.3);flex-shrink:0}
.flow-continue-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(138,90,32,.35)}
.flow-continue-btn:active{transform:translateY(0);box-shadow:0 2px 8px rgba(138,90,32,.25)}
@media(max-width:680px){
 .pwa-status{bottom:calc(82px + var(--safe-bottom));width:calc(100vw - 28px);justify-content:space-between}
 .flow-actions{flex-wrap:wrap;align-items:stretch}
 .flow-nav-group{width:100%;justify-content:space-between;gap:10px}
 .flow-continue-btn{width:100%;min-height:48px}
}

/* ── PAGE FLIP ── */
@keyframes pageFlipOut{0%{transform:perspective(900px) rotateY(0);opacity:1}40%{transform:perspective(900px) rotateY(-12deg);opacity:.7}100%{transform:perspective(900px) rotateY(-88deg);opacity:0}}
@keyframes pageFlipIn{0%{transform:perspective(900px) rotateY(88deg);opacity:0}60%{transform:perspective(900px) rotateY(7deg);opacity:.85}100%{transform:perspective(900px) rotateY(0);opacity:1}}
.page-flip-out{animation:pageFlipOut .3s cubic-bezier(.4,0,.6,1) forwards;transform-origin:left center}
.page-flip-in{animation:pageFlipIn .38s cubic-bezier(.2,0,.4,1) forwards;transform-origin:left center}
@keyframes inkPulse{0%{transform:scale(1)}40%{transform:scale(1.6)}100%{transform:scale(1)}}

#screen-home.active,#screen-profile.active,#screen-questions.active,#screen-map.active,#screen-albums.active,#screen-tree.active,#screen-book.active,#screen-import.active,#screen-appguide.active{display:block}
.screen.active p,.screen.active li,.screen.active label{font-size:max(15px,1em)}
body.writing-focus #sidebar{opacity:.55;transition:opacity .4s ease}
body.focus-mode #sidebar{display:none!important}
body.focus-mode{background:#2a2018!important}
body.focus-mode #screen-questions{max-width:720px;margin:40px auto;padding:0 20px 80px}
body.focus-mode .notepad-wrap{box-shadow:0 20px 80px rgba(0,0,0,.4)}
body.focus-mode #q-sticky-bar{background:rgba(36,26,18,.92);border-bottom-color:rgba(200,144,58,.15)}
body.focus-mode .q-sb-btn{color:rgba(200,144,58,.85);border-color:rgba(200,144,58,.35)}
body.focus-mode .q-sb-btn:hover{background:rgba(200,144,58,.1);border-color:rgba(200,144,58,.6)}
body.focus-mode .q-sb-primary{color:#fff!important;background:var(--accent);border-color:var(--accent)}
/* Writing background chip swatches in Profile */
#prof-writing-bg{gap:10px}
#prof-writing-bg .chip{display:flex;flex-direction:column;align-items:center;gap:8px;padding:10px 14px;border-radius:14px;min-width:80px;text-align:center}
#prof-writing-bg .chip::before{content:'Aa';display:flex;align-items:center;justify-content:center;width:64px;height:40px;border-radius:8px;font-size:17px;font-family:'Cormorant Garamond',serif;font-style:italic;flex-shrink:0;transition:all .2s}
#prof-writing-bg .chip[data-val="night"]::before{background:linear-gradient(135deg,#120d0b 0%,#2a1812 100%);color:rgba(255,235,206,.85);border:1px solid rgba(255,235,206,.15)}
#prof-writing-bg .chip[data-val="soft"]::before{background:radial-gradient(circle at 50% 30%,#fff8ef,#ecd9bc);color:#3a2a18;border:1px solid rgba(138,90,32,.2)}
#prof-writing-bg .chip[data-val="desk"]::before{background:linear-gradient(135deg,#2a1a0e 0%,#3a2515 100%);color:rgba(255,220,180,.85);border:1px solid rgba(255,200,120,.2)}
#prof-writing-bg .chip[data-val="parchment"]::before{background:#f5f0e8;color:#3a2a18;border:1px solid rgba(138,90,32,.25)}

/* ── KIDS MODE body-level overrides ── */
body.kids-mode{font-family:'Quicksand','Nunito',sans-serif!important}
body.kids-mode .sb-title{font-family:'Quicksand',sans-serif}
body.kids-mode .ch-name,.kids-mode .nav-lbl{font-family:'Quicksand',sans-serif;letter-spacing:0}

/* ── HOME ── */
#screen-home{padding:44px 44px 80px;max-width:740px}
.home-greet{font-family:'Cormorant SC',serif;font-size:16px;letter-spacing:4px;color:var(--accent);margin-bottom:10px}
.home-h1{font-size:54px;font-weight:300;color:var(--text);font-style:italic;line-height:1.05;margin-bottom:10px}
.home-sub{font-size:20px;color:var(--text2);font-style:italic;margin-bottom:24px;line-height:1.6}
.home-rule{width:48px;height:1px;background:linear-gradient(90deg,var(--accent),transparent);margin-bottom:32px}
.ovr-box{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px;margin-bottom:20px;box-shadow:var(--shadow)}
.ovr-hdr{display:flex;justify-content:space-between;margin-bottom:9px}
.ovr-lbl{font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:3px;color:var(--accent)}
.ovr-nums{font-size:18px;color:var(--text3)}
.ovr-track{height:7px;background:var(--border);border-radius:4px;overflow:hidden}
.ovr-fill{height:100%;background:var(--progress);border-radius:2px;transition:width .7s ease}
/* ── BEGINNER PATH ── */
#beginner-path{margin:0 0 24px;display:none}
#beginner-path .bp-hdr{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:12px}
#beginner-path .bp-ttl{font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:3px;color:var(--accent)}
#beginner-path .bp-skip{background:none;border:none;color:var(--text3);font-size:13px;font-style:italic;cursor:pointer;padding:0}
#beginner-path .bp-progress{height:4px;background:var(--border);border-radius:2px;margin-bottom:14px;overflow:hidden}
#beginner-path .bp-fill{height:100%;background:var(--progress);border-radius:1px;transition:width .5s ease}
#beginner-path .bp-scroll{display:flex;gap:10px;overflow-x:auto;padding-bottom:8px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
#beginner-path .bp-scroll::-webkit-scrollbar{display:none}
.bp-card{flex-shrink:0;width:200px;background:var(--card);border:1.5px solid var(--border);border-radius:14px;padding:14px 16px;cursor:pointer;transition:all .18s;position:relative}
.bp-card.done{border-color:rgba(100,160,80,.4);background:rgba(100,160,80,.06)}
.bp-card:hover{border-color:var(--accent2);transform:translateY(-1px)}
.bp-card .bp-ch{font-family:'Cormorant SC',serif;font-size:10px;letter-spacing:2px;color:var(--text3);margin-bottom:6px}
.bp-card .bp-q{font-family:'Cormorant Garamond',serif;font-size:15px;color:var(--text);line-height:1.45;font-style:italic}
.bp-card .bp-done-badge{position:absolute;top:10px;right:10px;color:rgba(80,160,80,.8);font-size:14px}
.ch-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.ch-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:16px;cursor:pointer;transition:all .2s;box-shadow:var(--shadow)}
.ch-card:hover{border-color:var(--accent2);transform:translateY(-2px)}
.cc-emoji{font-size:26px;margin-bottom:10px}
.cc-name{font-family:'Cormorant SC',serif;font-size:16px;letter-spacing:1px;color:var(--accent);margin-bottom:6px}
.cc-desc{font-size:15px;color:var(--text2);font-style:italic;line-height:1.55;margin-bottom:10px}
.cc-track{height:5px;background:var(--border);border-radius:3px}
.cc-fill{height:100%;background:var(--progress);border-radius:1px;transition:width .4s}
.cc-count{font-size:12px;color:var(--text2);font-family:'Cormorant SC',serif;letter-spacing:1px;margin-top:6px}
/* Kids card style */
.kids-mode .ch-card{border-radius:18px;border-width:2px}
.kids-mode .cc-name{font-family:'Quicksand',sans-serif;font-size:12px;letter-spacing:0}
.kids-mode .home-h1{font-family:'Quicksand',sans-serif;font-style:normal}



/* ── MEMORY MAP ── */
#screen-map{max-width:900px;padding:28px 28px 80px}
#memory-map-canvas{width:100%;height:520px;border:1px solid var(--border);border-radius:16px;background:var(--card);position:relative;overflow:hidden}
.mm-node{position:absolute;border-radius:50%;display:flex;align-items:center;justify-content:center;text-align:center;cursor:pointer;transition:all .3s;box-shadow:0 4px 18px rgba(0,0,0,.18),0 1px 0 rgba(255,255,255,.3) inset;font-family:'Cormorant Garamond',Georgia,serif}
.mm-node:hover{transform:scale(1.12);z-index:10;box-shadow:0 6px 24px rgba(0,0,0,.18)}
.mm-node-label{position:absolute;font-size:13px;font-weight:600;font-family:'Cormorant SC',serif;letter-spacing:.5px;color:var(--text);white-space:nowrap;pointer-events:none;text-shadow:0 1px 4px rgba(255,255,255,.8)}

/* ── MEDIA ALBUMS ── */
#screen-albums{max-width:900px;padding:28px 28px 80px}
.alb-tabs{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}
.alb-tab{padding:8px 18px;border-radius:20px;border:1.5px solid var(--border);background:transparent;color:var(--text2);font-family:'Cormorant SC',serif;font-size:12px;letter-spacing:1px;cursor:pointer;transition:all .2s}
.alb-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}
.alb-sort{display:flex;gap:8px;margin-bottom:16px;align-items:center;flex-wrap:wrap}
.alb-sort-btn{padding:5px 12px;border-radius:14px;border:1px solid var(--border);background:var(--card);color:var(--text2);font-size:12px;cursor:pointer;transition:all .18s}
.alb-sort-btn.active{border-color:var(--accent);color:var(--accent);background:rgba(138,90,32,.07)}
.alb-tag-filter{padding:4px 10px;border-radius:12px;border:1px solid var(--border);background:var(--card);color:var(--text2);font-size:12px;cursor:pointer;font-family:inherit}
.alb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.alb-card{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden;cursor:pointer;transition:all .2s;box-shadow:var(--shadow)}
.alb-card:hover{transform:translateY(-2px);border-color:var(--accent2)}
.alb-thumb{width:100%;aspect-ratio:1;object-fit:cover;display:block;background:var(--bg2)}
.alb-thumb-audio{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:36px;background:linear-gradient(135deg,var(--bg2),var(--card))}
.alb-thumb-gps{width:100%;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:28px;background:linear-gradient(135deg,#e8f4ea,#d0e8d4);gap:4px}
.alb-card-meta{padding:8px 10px}
.alb-card-ch{font-size:10px;color:var(--accent);font-family:'Cormorant SC',serif;letter-spacing:1px}
.alb-card-ts{font-size:11px;color:var(--text2);font-style:italic;margin-top:1px}

/* ── ALBUM UPLOAD ZONE ── */
.alb-upload-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px;align-items:stretch}
.alb-upload-btn{display:flex;align-items:center;gap:7px;padding:9px 16px;border-radius:20px;border:1.5px solid var(--border);background:var(--card);color:var(--text2);font-family:'Cormorant SC',serif;font-size:12px;letter-spacing:1px;cursor:pointer;transition:all .2s;white-space:nowrap}
.alb-upload-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(138,90,32,.06)}
.alb-drop-zone{border:2px dashed var(--border);border-radius:16px;padding:28px 20px;text-align:center;color:var(--text3);font-style:italic;font-size:14px;margin-bottom:18px;transition:all .2s;cursor:pointer;background:var(--card)}
.alb-drop-zone.drag-over{border-color:var(--accent);background:rgba(138,90,32,.06);color:var(--accent)}
.alb-ch-assign{padding:5px 10px;border-radius:12px;border:1px solid var(--border);background:var(--card);color:var(--text2);font-size:12px;font-family:inherit;cursor:pointer}
.alb-rec-row{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--card);border:1.5px solid var(--border);border-radius:14px;margin-bottom:14px}
.alb-rec-btn{padding:8px 18px;border-radius:20px;background:rgba(200,60,60,.1);border:1.5px solid rgba(200,60,60,.3);color:#c83030;font-family:'Cormorant SC',serif;font-size:12px;letter-spacing:1px;cursor:pointer;transition:all .2s}
.alb-rec-btn.rec{background:rgba(200,60,60,.2);border-color:#c83030;animation:pulse 1s infinite}
.alb-rec-status{font-size:13px;color:var(--text2);font-style:italic}

.alb-empty{text-align:center;padding:60px 20px;color:var(--text3);font-style:italic;font-size:16px}
/* Lightbox */
#alb-lightbox{position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:900;display:none;align-items:center;justify-content:center;flex-direction:column;gap:12px;padding:20px}
#alb-lightbox.open{display:flex}
#alb-lb-img{max-width:90vw;max-height:70vh;border-radius:12px;object-fit:contain}
#alb-lb-audio{width:280px}
#alb-lb-video{max-width:90vw;max-height:70vh;border-radius:12px}
.alb-lb-meta{color:rgba(255,255,255,.7);font-size:13px;font-style:italic;text-align:center}
.alb-lb-close{position:fixed;top:18px;right:22px;background:rgba(255,255,255,.15);border:none;color:#fff;font-size:22px;cursor:pointer;border-radius:50%;width:38px;height:38px;display:flex;align-items:center;justify-content:center}

/* ── PHOTO AVATARS ── */
.av-photo-circle{width:72px;height:72px;border-radius:50%;object-fit:cover;border:2.5px solid var(--accent2);display:block}
.ao-avatar img{width:68px;height:68px;border-radius:50%;object-fit:cover}
.amp-av img{width:38px;height:38px;border-radius:50%;object-fit:cover}
.photo-upload-btn{padding:8px 14px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;font-size:13px;cursor:pointer;color:var(--text2);font-family:inherit;transition:all .18s}
.photo-upload-btn:hover{border-color:var(--accent);color:var(--accent)}
.photo-circle-preview{width:72px;height:72px;border-radius:50%;background:var(--bg2);border:2px dashed var(--border);display:flex;align-items:center;justify-content:center;font-size:32px;cursor:pointer;overflow:hidden;flex-shrink:0;transition:border-color .2s}
.photo-circle-preview:hover{border-color:var(--accent)}
/* ── FAMILY TREE ── */
#screen-tree{max-width:800px;padding:38px 44px 80px}
.tree-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px;margin-bottom:24px}
.tree-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:18px 14px;text-align:center;cursor:pointer;transition:all .2s;box-shadow:var(--shadow);position:relative}
.tree-card:hover{border-color:var(--accent2);transform:translateY(-2px);box-shadow:0 6px 28px rgba(0,0,0,.12)}
.tree-photo{width:76px;height:76px;border-radius:50%;object-fit:cover;margin:0 auto 10px;display:block;border:2.5px solid var(--accent2)}
.tree-emoji-av{width:76px;height:76px;border-radius:50%;background:var(--bg2);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:34px;margin:0 auto 10px}
.tree-name{font-size:15px;color:var(--text);font-weight:500;margin-bottom:3px}
.tree-rel{font-size:11px;color:var(--accent);font-family:'Cormorant SC',serif;letter-spacing:1.5px;margin-bottom:4px;text-transform:uppercase}
.tree-dates{font-size:12px;color:var(--text2);font-style:italic}
.tree-note{font-size:12px;color:var(--text2);font-style:italic;margin-top:6px;line-height:1.4}
.tree-add-card{border:2px dashed var(--border);background:transparent;color:var(--text3)}
.tree-add-card:hover{border-color:var(--accent);color:var(--accent)}
.tree-del-btn{position:absolute;top:7px;right:7px;background:rgba(200,60,60,.1);border:1px solid rgba(200,60,60,.22);border-radius:6px;padding:2px 7px;font-size:11px;color:#b83030;cursor:pointer;opacity:0;transition:opacity .2s;line-height:1.6}
.tree-card:hover .tree-del-btn{opacity:1}
#member-modal{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:820;display:none;align-items:center;justify-content:center;padding:16px}
#member-modal.open{display:flex}
.mm-box{background:var(--bg);border:1px solid var(--border);border-radius:22px;padding:28px;width:420px;max-width:100%;max-height:88vh;overflow-y:auto;animation:popIn .22s ease;box-shadow:0 14px 52px rgba(0,0,0,.18)}
.mm-lbl{font-family:'Cormorant SC',serif;font-size:11px;letter-spacing:2px;color:var(--accent);margin:14px 0 6px;display:block}
.mm-inp{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:10px;background:var(--bg2);color:var(--text);font-size:15px;font-family:inherit;outline:none;box-sizing:border-box}
.mm-inp:focus{border-color:var(--accent)}
/* ── PROFILE SCREEN ── */
#screen-profile{max-width:680px;padding:38px 44px 80px}
.prof-h{font-size:30px;font-weight:300;color:var(--text);font-style:italic;margin-bottom:6px}
.prof-sub{font-size:14px;color:var(--text2);font-style:italic;margin-bottom:28px;line-height:1.6}
.prof-sec{margin-bottom:24px}
.prof-lbl{font-family:'Cormorant SC',serif;font-size:12px;letter-spacing:3px;color:var(--accent);margin-bottom:10px;display:block}
.prof-input{width:100%;padding:10px 14px;background:var(--card);border:1.5px solid var(--border);border-radius:10px;font-family:'Cormorant Garamond',serif;font-size:16px;color:var(--text);outline:none;transition:border .2s}
.prof-input:focus{border-color:var(--accent)}
.chip-row{display:flex;gap:7px;flex-wrap:wrap}
.chip{padding:6px 14px;border-radius:20px;border:1.5px solid var(--border);background:var(--card);color:var(--text2);font-family:'Cormorant Garamond',serif;font-size:13px;cursor:pointer;transition:all .2s;user-select:none}
.chip:hover{border-color:var(--accent2);color:var(--text2)}
.chip.sel{background:rgba(138,90,32,.12);border-color:var(--accent);color:var(--accent);font-weight:500}
.kids-mode .chip{font-family:'Quicksand',sans-serif;border-radius:30px}
.prof-age-warning{font-size:12px;color:var(--accent);font-style:italic;margin-top:8px;padding:7px 12px;background:rgba(138,90,32,.07);border-radius:8px;display:none}
.prof-age-warning.show{display:block}
.prof-btns{display:flex;gap:10px;margin-top:32px}
.prof-save{flex:2;padding:13px;background:rgba(138,90,32,.1);border:1.5px solid rgba(138,90,32,.3);color:var(--accent);border-radius:12px;font-family:'Cormorant SC',serif;font-size:14px;letter-spacing:2px;cursor:pointer;transition:all .2s}
.prof-save:hover{background:rgba(138,90,32,.18)}
.prof-skip{flex:1;padding:13px;background:transparent;border:1px solid var(--border);color:var(--text3);border-radius:12px;font-family:'Cormorant SC',serif;font-size:14px;letter-spacing:2px;cursor:pointer}
.progress-reward-card{margin:-6px 0 22px;padding:13px 16px;border:1px solid rgba(138,90,32,.16);border-radius:14px;background:linear-gradient(135deg,rgba(138,90,32,.06),rgba(210,160,70,.045));color:var(--text2)}
.safety-status-card{margin:-6px 0 22px;padding:13px 16px;border:1px solid rgba(60,130,80,.18);border-radius:14px;background:linear-gradient(135deg,rgba(60,130,80,.07),rgba(138,90,32,.035));color:var(--text2);font-family:'Cormorant Garamond',serif;font-size:15px;line-height:1.45}
.safety-status-card .safety-title{font-family:'Cormorant SC',serif;font-size:10px;letter-spacing:2.4px;color:#287840;margin-bottom:5px}
.safety-status-card.warn{border-color:rgba(180,100,20,.34);background:linear-gradient(135deg,rgba(180,100,20,.09),rgba(138,90,32,.045))}
.safety-status-card.warn .safety-title{color:#9a6020}
.reward-top{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px}
.reward-title{font-family:'Cormorant SC',serif;font-size:10px;letter-spacing:2.5px;color:var(--accent)}
.reward-chip{font-family:'Cormorant Garamond',serif;font-size:14px;font-style:italic;color:var(--text3);white-space:nowrap}
.reward-copy{font-family:'Cormorant Garamond',serif;font-size:16px;font-style:italic;line-height:1.45;margin-bottom:10px}
.reward-bar{height:5px;border-radius:999px;background:rgba(138,90,32,.09);overflow:hidden}
.reward-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,rgba(138,90,32,.45),rgba(200,140,45,.9));transition:width .4s ease}
@media(max-width:520px){.reward-top{align-items:flex-start;flex-direction:column;gap:3px}.reward-chip{white-space:normal}.prof-btns{flex-wrap:wrap}.prof-save,.prof-skip{min-width:130px}}
/* Auto-theme preview strip */
.auto-theme-preview{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.atp-swatch{width:44px;height:44px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:all .2s;position:relative;overflow:hidden;flex-shrink:0}
.atp-swatch.sel{border-color:var(--accent);transform:scale(1.15)}
.atp-swatch span{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:20px}

/* ── QUESTION SCREEN — Writing Background variants ── */
#screen-questions{padding:38px 44px 80px;background:radial-gradient(circle at 50% -10%,rgba(210,140,54,.16),rgba(210,140,54,0) 38%),radial-gradient(circle at 50% 60%,rgba(170,100,40,.08),rgba(170,100,40,0) 60%),#120d0b;min-height:100vh;color:#f6e8d6}
/* Night (default) */
body.wbg-night #screen-questions,body:not(.wbg-soft):not(.wbg-desk):not(.wbg-parchment) #screen-questions{}
/* Soft — "Focused Writing Surface" v173 */
/* Room: warm yellow center → dark maroon edges */
body.wbg-soft #screen-questions{background:#1a1410;color:#f6f1e7;min-height:100vh}
/* Subtle warm glow behind notepad */
body.wbg-soft .notepad-wrap::before{background:radial-gradient(ellipse at 50% 40%,rgba(200,160,40,.28) 0%,rgba(160,30,30,.1) 50%,rgba(0,0,0,0) 75%);filter:blur(18px);inset:-60px -80px -60px;opacity:1}
/* Clean flat cream surface */
body.wbg-soft .notepad{background:#f6f1e7!important;box-shadow:0 12px 36px rgba(0,0,0,.5),0 0 0 1px rgba(138,90,32,.1);-webkit-mask-image:none;mask-image:none}
/* No ruled lines, no torn edge */
body.wbg-soft .notepad::before{background-image:none}
body.wbg-soft .notepad::after{display:none}
/* Fix 4: animation removed — was firing on every question navigation, not just screen entry */
/* Sticky bar — deep maroon tinted */
body.wbg-soft #q-sticky-bar{background:rgba(14,4,4,.94);border-bottom-color:rgba(200,144,58,.2)}
body.wbg-soft #q-sticky-bar .q-sb-btn{color:rgba(240,220,170,.82);border-color:rgba(200,144,58,.3)}
body.wbg-soft #q-sticky-bar .q-sb-primary{color:#fff;border-color:var(--accent);background:var(--accent)}
/* ← Home, breadcrumb, eye — all on dark room bg, need light warm text */
body.wbg-soft #screen-questions .q-back{color:rgba(240,215,155,.65)!important}
body.wbg-soft #screen-questions .q-bc-sep{color:rgba(200,144,58,.45)!important}
body.wbg-soft #screen-questions .q-bc-ch{color:rgba(235,200,120,.88)!important}
/* q-bc and q-ttl — on dark room background, need light colors */
body.wbg-soft #screen-questions #q-bc{color:rgba(235,200,120,.88)!important}
body.wbg-soft #screen-questions #q-ttl{color:rgba(246,238,218,.92)!important}
body.wbg-soft #screen-questions #q-eye{color:rgba(220,185,110,.7)!important;border-color:rgba(200,144,58,.25)!important;background:rgba(255,240,200,.07)!important}
/* Formatting toolbar — force dark ink on cream paper regardless of global theme */
body.wbg-soft .np-toolbar{background:rgba(246,241,231,.97)!important}
body.wbg-soft .np-toolbar .tb-btn{color:#4a3828!important;border-color:transparent}
body.wbg-soft .np-toolbar .tb-btn:hover{background:rgba(138,90,32,.1)!important;border-color:rgba(138,90,32,.2)!important}
body.wbg-soft .np-toolbar .tb-sel{color:#4a3828!important;background:rgba(255,255,255,.7)!important;border:1px solid rgba(138,90,32,.2)!important}
body.wbg-soft .np-toolbar .tb-sep{background:rgba(138,90,32,.15)!important}
/* Text on cream paper — warm dark ink */
body.wbg-soft #screen-questions .q-trk-bg{background:rgba(138,90,32,.12)}
body.wbg-soft #screen-questions .np-q-txt{color:#8a5a20!important}
body.wbg-soft #screen-questions #q-editor{color:#8a5a20!important}
body.wbg-soft #screen-questions .np-footer{background:rgba(240,234,222,.95)!important}
body.wbg-soft #screen-questions .new-answer-lbl{color:rgba(138,90,32,.48)!important}
/* Desk — warm wood & amber lamp-glow */
body.wbg-desk #screen-questions{background:radial-gradient(ellipse at 20% 10%,rgba(255,200,120,.22),rgba(255,200,120,0) 45%),radial-gradient(ellipse at 80% 80%,rgba(60,30,10,.4),rgba(60,30,10,0) 60%),linear-gradient(180deg,#2a1a0e 0%,#3a2515 100%);color:#f6e8d6;position:relative}
body.wbg-desk #screen-questions::before{content:'';position:absolute;inset:0;pointer-events:none;background:repeating-linear-gradient(90deg,rgba(255,220,180,.014) 0px,rgba(255,220,180,.014) 2px,rgba(0,0,0,0) 2px,rgba(0,0,0,0) 5px);opacity:.7;z-index:0}
body.wbg-desk #screen-questions>*{position:relative;z-index:1}
body.wbg-desk #q-sticky-bar{background:rgba(20,12,6,.88);border-bottom-color:rgba(255,220,180,.12)}
body.wbg-desk #q-sticky-bar .q-sb-btn{color:rgba(255,220,180,.85);border-color:rgba(255,220,180,.25)}
body.wbg-desk #q-sticky-bar .q-sb-primary{color:#fff;background:var(--accent);border-color:var(--accent)}
/* Fix 1: Desk — full color overrides (room elements = light warm; paper elements = dark ink) */
body.wbg-desk #screen-questions .q-back{color:rgba(255,210,150,.55)!important}
body.wbg-desk #screen-questions #q-bc{color:rgba(255,210,150,.88)!important}
body.wbg-desk #screen-questions #q-ttl{color:rgba(255,235,200,.92)!important}
body.wbg-desk #screen-questions .q-trk-bg{background:rgba(255,200,120,.12)}
body.wbg-desk #screen-questions .np-q-txt{color:var(--paper-text)!important}
body.wbg-desk #screen-questions .new-answer-lbl{color:rgba(138,90,32,.55)!important}
body.wbg-desk #screen-questions #q-editor{color:var(--paper-text)!important}
body.wbg-desk #screen-questions .np-footer{background:rgba(245,235,218,.88)!important}
body.wbg-desk .np-toolbar{background:rgba(250,244,232,.97)!important}
body.wbg-desk .np-toolbar .tb-btn{color:var(--paper-text)!important}
body.wbg-desk .np-toolbar .tb-btn:hover{background:rgba(138,90,32,.1)!important;border-color:rgba(138,90,32,.2)!important}
body.wbg-desk .np-toolbar .tb-sel{color:var(--paper-text)!important;background:rgba(255,255,255,.7)!important;border-color:rgba(138,90,32,.2)!important}
body.wbg-desk .np-toolbar .tb-sep{background:rgba(138,90,32,.15)!important}
/* Parchment (classic) */
body.wbg-parchment #screen-questions{background:var(--bg)!important;min-height:initial;color:var(--text)}
body.wbg-parchment #q-sticky-bar{background:rgba(245,240,232,.96);border-bottom-color:var(--border)}
body.wbg-parchment #q-sticky-bar .q-sb-btn{color:var(--accent);border-color:rgba(138,90,32,.28)}
body.wbg-parchment #q-sticky-bar .q-sb-btn:hover{color:var(--text);border-color:rgba(138,90,32,.5);background:rgba(138,90,32,.06)}
body.wbg-parchment #q-sticky-bar .q-sb-primary{color:#fff!important;background:var(--accent)!important;border-color:var(--accent)!important}
body.wbg-parchment #screen-questions .q-back{color:var(--text2)!important}
body.wbg-parchment #screen-questions #q-eye{color:var(--text3)!important;border-color:var(--border)!important;background:transparent!important}
body.wbg-parchment #screen-questions #q-bc{color:var(--accent)!important}
body.wbg-parchment #screen-questions #q-ttl{color:var(--text)!important}
body.wbg-parchment #screen-questions .q-trk-bg{background:rgba(138,90,32,.12)}
body.wbg-parchment #screen-questions .np-q-txt{color:var(--text)!important}
body.wbg-parchment #screen-questions .new-answer-lbl{color:var(--accent)!important}
body.wbg-parchment #screen-questions #q-editor{color:var(--paper-text)!important}
body.wbg-parchment #screen-questions .np-footer{background:rgba(245,240,232,.85)!important}
/* Journal mode — Once / Notes: always light warm background regardless of writing theme */
#screen-questions.journal-mode{background:var(--bg)!important;color:var(--text)}
#screen-questions.journal-mode .q-back{color:var(--text3)!important}
#screen-questions.journal-mode .q-back:hover{color:var(--text)!important}
#screen-questions.journal-mode #q-bc{color:var(--accent)!important}
#screen-questions.journal-mode #q-ttl{color:var(--text)!important}
#screen-questions.journal-mode #q-eye{color:var(--text3)!important;border-color:var(--border)!important;background:rgba(138,90,32,.06)!important}
#screen-questions.journal-mode .q-trk-bg{background:rgba(138,90,32,.1)!important}
.journal-add-btn{display:block;width:100%;padding:16px;background:transparent;border:none;border-top:1px dashed rgba(138,90,32,.2);color:var(--text3);font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:2px;cursor:pointer;transition:color .2s;text-align:center;margin-top:8px}
.journal-add-btn:hover{color:var(--accent)}
/* Desktop breakpoints — no max-width on screen so dark bg fills full width;
   horizontal padding centers the ~860px content column instead */
@media (min-width:900px){
 #screen-questions{max-width:none;padding:44px max(56px,calc((100% - 860px)/2)) 100px}
 .np-q-txt{font-size:clamp(24px,2.4vw,34px)!important}
 #q-editor{font-size:clamp(21px,2vw,28px)!important;line-height:2.05!important;min-height:320px!important}
}
@media (min-width:1280px){#screen-questions{padding:48px max(64px,calc((100% - 900px)/2)) 120px}}
.q-bread{display:flex;align-items:center;gap:9px;margin-bottom:18px}
.q-back{background:none;border:none;color:rgba(246,232,214,.74);cursor:pointer;font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:2px;transition:color .2s}
.q-back:hover{color:#fff5e6}
.q-bc-sep{color:rgba(245,232,214,.38);font-size:14px;opacity:.9}
.q-bc-ch{font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:2px;color:#d4b289}
.q-trk-bg{height:5px;background:rgba(255,255,255,.1);border-radius:3px;margin-bottom:24px;position:relative}
.q-trk-fill{position:absolute;left:0;top:0;height:100%;background:var(--progress);border-radius:2px;transition:width .4s}
.q-dots{position:absolute;top:-4px;left:0;right:0;display:flex;justify-content:space-between;pointer-events:none}
.q-dot{width:12px;height:12px;border-radius:50%;background:var(--bg);border:1.5px solid var(--border);cursor:pointer;pointer-events:all;transition:all .2s;flex-shrink:0}
.q-dot.answered{background:var(--accent2);border-color:var(--accent2)}
.q-dot.current{background:var(--text);border-color:var(--text)}
/* Fix 7: dark room dots — override parchment fill */
body.wbg-soft #screen-questions .q-dot,
body.wbg-desk #screen-questions .q-dot,
body:not(.wbg-soft):not(.wbg-desk):not(.wbg-parchment) #screen-questions .q-dot{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.3)}
/* Fix 3: hide empty #q-eye badge */
#q-eye:empty{display:none!important}

/* ── NOTEPAD ── */
/* Fix 6: remove dead max-width:700px (overridden by min(860px,90%)!important below) */
.notepad-wrap{position:relative;border-radius:20px;overflow:visible;animation:fadeIn .32s ease;margin:0 auto}
.notepad-wrap::before{content:'';position:absolute;inset:-50px -70px -52px;pointer-events:none;border-radius:54px;background:
 radial-gradient(circle at 50% 30%,rgba(255,223,176,.82),rgba(255,223,176,.32) 24%,rgba(255,223,176,.08) 38%,rgba(255,223,176,0) 60%);
 filter:blur(16px);opacity:1}
.mood-bg{position:absolute;inset:0;border-radius:4px 16px 16px 4px;transition:background .4s,opacity .4s;pointer-events:none;z-index:0;overflow:hidden}
/* Kids decorative background */
.kids-bg-layer{position:absolute;inset:0;border-radius:4px 16px 16px 4px;pointer-events:none;z-index:0;overflow:hidden;font-size:22px;line-height:1.5;word-break:break-all;opacity:.15;letter-spacing:2px;padding:8px;display:flex;flex-wrap:wrap;align-content:flex-start;gap:2px}
.notepad{position:relative;z-index:1;border-radius:8px;overflow:visible;min-height:440px;box-shadow:0 26px 64px rgba(0,0,0,.42),0 0 0 1px rgba(124,89,57,.24),0 2px 0 rgba(255,248,236,.42) inset;background:linear-gradient(180deg,rgba(252,246,233,.99) 0%,#f5e8d1 100%)}
.notepad:active{transform:scale(.9985);transition:transform .18s cubic-bezier(.4,0,.2,1)}
.notepad::before{content:'';position:absolute;inset:0;pointer-events:none;background-image:var(--np-lines);background-position:0 50px}
/* v164: continuous paper look — on desktop, extend ruled lines through the whole notepad
   so the question area doesn't appear as a separate solid strip */
@media (min-width:900px){
 .notepad::before{background-position:0 0}
 .np-toolbar{border-bottom:1px solid rgba(138,90,32,.06)!important}
 .mood-bar{background:transparent!important;border-bottom:1px solid rgba(0,0,0,.04)!important}
 .kids-bg-bar{background:transparent!important}
 .music-bar{background:transparent!important}
}
.notepad::after{display:none}
.np-holes{position:absolute;left:0;top:0;bottom:0;width:52px;display:flex;flex-direction:column;justify-content:space-around;align-items:center;pointer-events:none;z-index:2}
.np-holes{display:none}
.hole{width:18px;height:18px;border-radius:50%;background:var(--hole);box-shadow:inset 0 2px 4px rgba(0,0,0,.15)}

/* Toolbar row */
.np-toolbar{display:flex;align-items:center;gap:5px;padding:10px 68px;background:rgba(255,248,236,.95);border-bottom:1px solid rgba(138,90,32,.08);flex-wrap:wrap;position:relative;z-index:3;transition:max-height .25s ease,opacity .25s,padding .25s}
.np-toolbar.hidden{max-height:0!important;opacity:0!important;padding-top:0!important;padding-bottom:0!important;overflow:hidden!important;border:none!important}
.tb-btn{background:none;border:1px solid transparent;border-radius:7px;min-width:32px;height:32px;padding:0 8px;cursor:pointer;font-size:15px;color:var(--paper-text);font-family:'Cormorant Garamond',Georgia,serif;transition:all .15s;display:flex;align-items:center;justify-content:center;white-space:nowrap;gap:3px}
.tb-btn:hover{background:rgba(138,90,32,.09);border-color:rgba(138,90,32,.22)}
.tb-sep{width:1px;height:22px;background:rgba(138,90,32,.18);margin:0 4px;flex-shrink:0}
.tb-sel{background:rgba(255,255,255,.7);border:1px solid rgba(138,90,32,.18);border-radius:7px;padding:4px 8px;font-size:13px;color:var(--paper-text);cursor:pointer;font-family:'Cormorant Garamond',Georgia,serif;height:32px}
.tb-toggle{display:none}
.tb-toggle:hover{color:var(--accent);background:rgba(138,90,32,.08)}

/* Mood bar */
.mood-bar{display:flex;align-items:center;gap:6px;padding:6px 68px;background:rgba(255,255,255,.2);border-bottom:1px solid rgba(0,0,0,.04);flex-wrap:wrap;position:relative;z-index:3}
.mood-lbl{font-family:'Cormorant SC',serif;font-size:11px;letter-spacing:3px;color:var(--text3);flex-shrink:0}
.mood-swatch{width:26px;height:26px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:all .2s;flex-shrink:0}
.mood-swatch:hover{transform:scale(1.2)}
.mood-swatch.sel{border-color:var(--text);transform:scale(1.15)}
.mood-opacity-wrap{display:flex;align-items:center;gap:5px;margin-left:auto}
.mood-opacity-lbl{font-size:12px;color:var(--text3);font-family:'Cormorant SC',serif;letter-spacing:1px}
input[type=range].mood-range{width:70px;height:4px;accent-color:var(--accent)}
/* Kids backgrounds selector */
.kids-bg-bar{display:flex;align-items:center;gap:7px;padding:6px 68px;background:rgba(255,255,255,.15);border-bottom:1px solid rgba(0,0,0,.04);flex-wrap:wrap;z-index:3;position:relative}
.kids-bg-opt{font-size:20px;cursor:pointer;border-radius:8px;padding:3px 5px;border:2px solid transparent;transition:all .2s;flex-shrink:0}
.kids-bg-opt:hover{transform:scale(1.2)}
.kids-bg-opt.sel{border-color:var(--accent);background:rgba(138,90,32,.1)}
.kids-bg-opt[onclick*="none"]{font-size:13px;color:var(--text3);font-family:'Cormorant SC',serif;letter-spacing:1px;opacity:.7}

/* Music bar */
.music-bar{display:flex;align-items:center;gap:8px;padding:6px 68px;background:rgba(255,255,255,.15);border-bottom:1px solid rgba(0,0,0,.04);position:relative;z-index:3}
.music-lbl{font-family:'Cormorant SC',serif;font-size:11px;letter-spacing:3px;color:var(--text3);flex-shrink:0}
.music-title{font-size:12px;color:var(--text2);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}
.music-play-btn{width:28px;height:28px;border-radius:50%;background:var(--card);border:1px solid var(--border);cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.music-play-btn:hover{border-color:var(--accent);color:var(--accent)}
.music-add-btn{padding:3px 10px;border-radius:14px;border:1px solid var(--border);background:transparent;cursor:pointer;font-size:13px;color:var(--text3);font-family:'Cormorant SC',serif;letter-spacing:1px;transition:all .2s}
.music-add-btn:hover{border-color:var(--accent);color:var(--accent)}
.music-vol{width:60px;accent-color:var(--accent);height:3px}

/* Media canvas */
.media-canvas{position:relative;min-height:120px;margin:12px 52px 0 52px;padding:8px 0}
.media-canvas.has-items{min-height:120px;border-top:1px dashed rgba(0,0,0,.08);padding-top:12px}
.media-item{position:absolute;cursor:move;user-select:none;border-radius:8px;overflow:visible;box-shadow:0 2px 12px rgba(0,0,0,.12);touch-action:none;transition:box-shadow .15s}
.media-item img,.media-item video{width:100%;height:100%;object-fit:cover;display:block;border-radius:8px;pointer-events:none}
.media-content{width:100%;height:100%;border-radius:8px;overflow:hidden;position:relative}
.media-item:hover{box-shadow:0 4px 20px rgba(0,0,0,.22)}
.media-item.selected{box-shadow:0 0 0 2px var(--accent),0 4px 20px rgba(0,0,0,.22)}
.media-item.selected .media-frame{outline:2px solid var(--accent);outline-offset:2px}
.media-frame{width:100%;height:100%;border-radius:6px;overflow:hidden;position:relative;box-shadow:0 2px 12px rgba(0,0,0,.15)}
.media-frame img,.media-frame video{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
.media-caption{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.5);color:#fff;font-size:12px;padding:3px 6px;font-family:'Cormorant SC',serif;letter-spacing:.5px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.media-del-btn{position:absolute;top:-7px;right:-7px;width:18px;height:18px;border-radius:50%;background:#e05050;color:#fff;border:none;cursor:pointer;font-size:13px;display:none;align-items:center;justify-content:center;z-index:10;line-height:1}
.media-item.selected .media-del-btn{display:flex}
.resize-handle{position:absolute;width:10px;height:10px;background:var(--accent);border:2px solid #fff;border-radius:50%;cursor:nwse-resize;display:none;z-index:10;touch-action:none}
.media-item.selected .resize-handle{display:block}
.rh-se{bottom:-5px;right:-5px;cursor:se-resize}
.rh-sw{bottom:-5px;left:-5px;cursor:sw-resize}
.rh-ne{top:-5px;right:-5px;cursor:ne-resize}
.rh-nw{top:-5px;left:-5px;cursor:nw-resize}
.rh-n{top:-5px;left:50%;transform:translateX(-50%);cursor:n-resize}
.rh-s{bottom:-5px;left:50%;transform:translateX(-50%);cursor:s-resize}
.rh-e{top:50%;right:-5px;transform:translateY(-50%);cursor:e-resize}
.rh-w{top:50%;left:-5px;transform:translateY(-50%);cursor:w-resize}}
.media-item.aiimg .media-frame{outline:2px solid var(--accent2)}
.ai-badge{position:absolute;top:4px;left:4px;background:rgba(138,90,32,.85);color:#fff;font-size:7px;padding:2px 5px;border-radius:8px;font-family:'Cormorant SC',serif;letter-spacing:1px}

/* Writing area */
.np-inner{padding:14px 26px 20px 68px;position:relative;z-index:1}
.np-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.np-top-meta{display:flex;flex-direction:column;gap:8px;min-width:200px}
.np-top-actions{display:none}
.np-bottom-tools{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.np-tool-btn{min-height:34px;min-width:34px;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 10px;border:1px solid var(--border);border-radius:999px;background:transparent;color:var(--text2);font-family:'Cormorant SC',serif;font-size:12px;letter-spacing:1px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .18s,border-color .18s,color .18s}
.np-tool-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(138,90,32,.06)}
.np-tool-btn.listening,.np-tool-btn.rec{border-color:rgba(180,40,40,.55);background:rgba(180,40,40,.13);color:#b83030}
.np-tool-btn-wide{min-width:88px}
.speech-lang-select{min-height:34px;border:1px solid var(--border);border-radius:999px;background:var(--bg2);color:var(--text2);font-family:'Cormorant SC',serif;font-size:12px;letter-spacing:1px;padding:0 26px 0 10px;cursor:pointer}
.speech-inline-tools{display:flex;align-items:center;gap:6px;justify-content:flex-end;flex-wrap:wrap;margin-top:8px}
.toolbar-pill{padding:5px 10px;background:rgba(138,90,32,.08);border:1px solid rgba(138,90,32,.18);border-radius:999px;font-family:'Cormorant SC',serif;font-size:10px;letter-spacing:1.2px;color:var(--accent);cursor:pointer;transition:all .18s}
.toolbar-pill:hover{background:rgba(138,90,32,.14);border-color:rgba(138,90,32,.35)}
.toolbar-pill.active{background:rgba(138,90,32,.16);color:var(--accent)}
.btn-top-prev,.btn-top-skip,.btn-top-save{min-height:40px;border-radius:999px;font-family:'Cormorant SC',serif;letter-spacing:1.6px;cursor:pointer;transition:all .18s}
.btn-top-prev{background:transparent;border:1px solid var(--border);padding:10px 16px;color:var(--text2)}
.btn-top-prev:hover{border-color:rgba(138,90,32,.35);color:var(--text)}
.btn-top-skip{background:transparent;border:1px solid rgba(0,0,0,.08);padding:10px 16px;color:var(--text2)}
.btn-top-skip:hover{border-color:rgba(138,90,32,.28);color:var(--accent)}
.btn-top-save{background:rgba(138,90,32,.1);border:1px solid rgba(138,90,32,.28);color:var(--accent);padding:10px 20px;box-shadow:0 2px 10px rgba(138,90,32,.12)}
.btn-top-save:hover:not(:disabled){background:rgba(138,90,32,.18);transform:translateY(-1px)}
.btn-top-save:disabled{opacity:.28;cursor:default}
.np-q-num{font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:2px;color:var(--text2);margin-bottom:12px;opacity:.85}
.np-q-txt{font-size:clamp(22px,6vw,28px);color:var(--paper-text);line-height:1.55;margin-bottom:20px;font-weight:400;user-select:text;-webkit-user-select:text;cursor:text}
.kids-mode .np-q-txt{font-family:'Quicksand',sans-serif;font-size:18px;line-height:1.6}
.prev-answer-lbl{font-family:'Cormorant SC',serif;font-size:10px;letter-spacing:2px;color:var(--text3);opacity:.55;margin-top:4px;display:flex;justify-content:flex-end;align-items:center;gap:8px}
.prev-answer-lbl:hover{opacity:.9}
/* new answer */
.new-answer-lbl{font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:2.5px;color:var(--accent);opacity:.8;margin-bottom:10px}
#q-editor{width:100%;min-height:220px;background:transparent;border:none;outline:none;color:var(--paper-text);line-height:2.1;font-family:'Caveat',cursive;font-size:clamp(19px,5vw,23px);caret-color:var(--accent);padding-bottom:20px}
#q-editor:empty::before{content:attr(data-placeholder);color:rgba(120,100,70,.32);font-style:italic}
.np-footer{padding:10px 26px 12px 26px;border-top:1px solid rgba(0,0,0,.05);display:flex;justify-content:space-between;align-items:center;background:rgba(255,248,236,.72);border-radius:0 0 8px 8px;position:relative;z-index:3;gap:12px}
.np-wc{font-family:'Cormorant Garamond',Georgia,serif;font-size:13px;letter-spacing:.2px;color:rgba(120,100,70,.6)}
.np-hint{font-size:13px;color:rgba(120,100,70,.3);font-style:italic}

/* Media actions */
.media-actions{display:flex;gap:7px;padding:10px 0 0;flex-wrap:wrap}
.mac-btn{display:flex;align-items:center;gap:5px;padding:8px 13px;background:var(--card);border:1px solid var(--border);border-radius:8px;cursor:pointer;font-size:14px;color:var(--text3);font-family:'Cormorant Garamond',serif;transition:all .2s}
.mac-btn:hover{border-color:var(--accent);color:var(--accent)}
.mac-btn.rec{border-color:#dc3030;color:#dc3030;background:rgba(220,48,48,.07);animation:recPulse 1.5s ease infinite}
.mac-btn span.icon{font-size:17px}
.q-row{display:flex;justify-content:space-between;align-items:center;margin-top:14px}
.btn-prev{background:none;border:none;color:var(--text2);cursor:pointer;font-family:'Cormorant SC',serif;font-size:15px;letter-spacing:1px;transition:color .2s}
.btn-prev:hover{color:var(--text)}
.btn-save{background:rgba(138,90,32,.1);border:1px solid rgba(138,90,32,.28);color:var(--accent);padding:12px 26px;border-radius:26px;font-family:'Cormorant SC',serif;font-size:16px;letter-spacing:2px;cursor:pointer;transition:all .2s}
.btn-save:hover:not(:disabled){background:rgba(138,90,32,.18);transform:translateY(-1px)}
.btn-save:disabled{opacity:.22;cursor:default}
.btn-skip{background:none;border:1px solid var(--border);border-radius:8px;padding:8px 18px;color:var(--text2);font-size:15px;font-family:'Cormorant SC',serif;letter-spacing:1px;cursor:pointer}

/* Chapter complete */
.ch-complete{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:36px 32px;text-align:center;box-shadow:var(--shadow)}
.cmp-star{font-size:44px;margin-bottom:14px}
.cmp-ttl{font-size:28px;font-weight:300;color:var(--text);font-style:italic;margin-bottom:10px;line-height:1.3}
.cmp-sub{font-size:18px;color:var(--text2);font-style:italic;margin-bottom:24px;line-height:1.6}
.cmp-btns{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}
.btn-compile{background:rgba(138,90,32,.12);border:1.5px solid rgba(138,90,32,.35);color:var(--accent);padding:12px 28px;border-radius:28px;font-family:'Cormorant SC',serif;font-size:14px;letter-spacing:1.5px;cursor:pointer;transition:all .2s}
.btn-compile:hover{background:rgba(138,90,32,.22)}
.btn-nxt{background:transparent;border:1.5px solid var(--border);color:var(--text2);padding:12px 28px;border-radius:28px;font-family:'Cormorant SC',serif;font-size:14px;letter-spacing:1.5px;cursor:pointer;transition:all .2s}
.btn-nxt:hover{color:var(--text);border-color:var(--text2)}

/* ── BOOK ── */
#screen-book{padding:44px 56px 80px;max-width:760px;background:linear-gradient(180deg,rgba(200,150,60,.04) 0%,var(--bg) 200px)}
/* ── BOOK TITLE PAGE — warm parchment card ── */
.bk-tp{text-align:center;margin-bottom:44px;padding:28px 24px 32px;
  background:linear-gradient(160deg,rgba(210,155,60,.16) 0%,rgba(185,120,35,.10) 55%,rgba(165,95,20,.06) 100%);
  border-radius:20px;border:1.5px solid rgba(185,140,55,.35);
  box-shadow:0 6px 36px rgba(140,90,20,.13),inset 0 1px 0 rgba(220,180,80,.2)}
.bk-tp-eye{font-family:'Cormorant SC',serif;font-size:10px;letter-spacing:9px;color:var(--accent);margin-bottom:12px;opacity:.7}
.bk-tp-ttl{font-size:44px;font-weight:300;color:var(--text);font-style:italic;margin-bottom:10px;
  text-shadow:0 2px 16px rgba(160,100,20,.15);letter-spacing:-1px}
.bk-tp-tag{font-size:14px;color:var(--accent);font-style:italic;margin-bottom:10px;opacity:.7;letter-spacing:1px}
.bk-tp-auth{font-size:16px;color:var(--text);font-family:'Cormorant Garamond','Cormorant',Georgia,serif;
  font-style:italic;letter-spacing:1px;margin-bottom:20px;opacity:.85}
.bk-tp-rule{width:56px;height:1px;background:linear-gradient(90deg,transparent,rgba(160,100,30,.5),transparent);margin:0 auto 6px}
.bk-tp-intro{font-size:14px;color:var(--text3);font-style:italic;line-height:2.1;max-width:380px;margin:0 auto}
/* ── CHAPTER LAYOUT ── */
.bk-ch{margin-bottom:60px}
.bk-num{font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:5px;color:#b07020;
  margin-bottom:8px;opacity:1;text-transform:uppercase;font-weight:700}
.bk-ttl{font-size:37px;font-weight:400;color:var(--text);font-style:italic;margin-bottom:14px;line-height:1.2;letter-spacing:-.3px}
.bk-rule{width:48px;height:2px;background:linear-gradient(90deg,#c8821a,rgba(200,130,30,.1));margin-bottom:24px;opacity:.85}
.bk-text{font-size:19px;line-height:2.1;color:var(--text);outline:none;padding:4px;
  border-radius:6px;transition:all .2s;font-family:'Cormorant Garamond','Cormorant',Georgia,serif}
.bk-text[contenteditable=true]{background:rgba(180,120,40,.04);border:1px solid rgba(160,100,30,.2);padding:16px;border-radius:10px}
.bk-empty{font-size:14px;color:var(--text3);font-style:italic;padding:24px;
  background:rgba(180,120,40,.04);border:1px dashed rgba(160,100,30,.15);
  border-radius:12px;text-align:center;line-height:1.9}
/* ── CHAPTER ACTIONS ── */
.bk-acts{display:flex;gap:8px;margin-top:18px;flex-wrap:wrap}
.bk-act{background:rgba(160,100,30,.06);border:1px solid rgba(160,100,30,.16);
  border-radius:20px;padding:6px 16px;font-family:'Cormorant SC',serif;font-size:11px;
  letter-spacing:1.5px;color:var(--accent);cursor:pointer;transition:all .2s}
.bk-act:hover{background:rgba(160,100,30,.12);border-color:rgba(160,100,30,.4)}
.bk-act.gold{background:var(--accent);border-color:var(--accent);color:#fff}
.bk-act.gold:hover{opacity:.88}
/* ── DIVIDERS ── */
.bk-div{width:100%;height:1px;background:linear-gradient(90deg,transparent,rgba(160,100,30,.18),transparent);margin:56px 0}
/* ── PART HEADERS ── */
.bk-part{text-align:center;margin:72px 0 48px;position:relative}
.bk-part-rule{width:100%;height:1px;background:linear-gradient(90deg,transparent,rgba(160,100,30,.22),transparent);margin-bottom:20px}
.bk-part-label{font-family:'Cormorant SC',serif;font-size:9px;letter-spacing:6px;color:#b07020;opacity:.75;margin-bottom:5px;text-transform:uppercase}
.bk-part-title{font-size:17px;font-weight:300;color:var(--text3);font-style:italic;letter-spacing:.5px}
/* ── EPILOGUE ── */
.bk-epilogue{margin-top:96px;position:relative}
.bk-epilogue-top{text-align:center;margin-bottom:36px}
.bk-epilogue-top-rule{width:80px;height:1px;background:linear-gradient(90deg,transparent,rgba(160,100,30,.45),transparent);margin:0 auto 18px}
.bk-epilogue-eye{font-family:'Cormorant SC',serif;font-size:9px;letter-spacing:8px;color:var(--accent);opacity:.6;margin-bottom:8px;text-transform:uppercase}
.bk-epilogue .bk-num{letter-spacing:7px;opacity:.5;text-align:center}
.bk-epilogue .bk-ttl{font-size:29px;opacity:.88;text-align:center}
.bk-epilogue .bk-rule{margin:0 auto 22px;background:linear-gradient(90deg,transparent,rgba(160,100,30,.45),transparent);width:56px}
.bk-epilogue .bk-text{font-style:italic;line-height:2.3;color:var(--text2);font-size:17px}
.bk-epilogue .bk-in-progress p{font-style:italic}
.bk-epilogue-close{text-align:center;margin-top:52px;padding-top:28px;border-top:1px solid rgba(160,100,30,.12);font-family:'Cormorant SC',serif;font-size:9px;letter-spacing:7px;color:var(--accent);opacity:.4}

/* ── BACKUP PANEL ── */
#backup-panel{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:510;display:none;align-items:center;justify-content:center}
#backup-panel.on{display:flex}
#backup-box{background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:28px;width:420px;max-width:calc(100vw - 32px);max-height:80vh;overflow-y:auto;animation:popIn .25s ease;box-shadow:0 12px 48px rgba(0,0,0,.15)}
.bkp-ttl{font-size:20px;font-weight:300;font-style:italic;color:var(--text);margin-bottom:6px}
.bkp-sub{font-size:13px;color:var(--text3);font-style:italic;margin-bottom:18px;line-height:1.6}
.bkp-entry{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--card);border:1px solid var(--border);border-radius:10px;margin-bottom:7px;gap:10px}
.bkp-info{flex:1;min-width:0}
.bkp-date{font-size:13px;color:var(--text);margin-bottom:2px}
.bkp-stats{font-size:11px;color:var(--text3);font-style:italic}
.bkp-restore{padding:5px 12px;background:rgba(138,90,32,.08);border:1px solid rgba(138,90,32,.22);color:var(--accent);border-radius:8px;font-family:'Cormorant SC',serif;font-size:12px;letter-spacing:1.5px;cursor:pointer;transition:all .2s;flex-shrink:0}
.bkp-restore:hover{background:rgba(138,90,32,.16)}
.bkp-del{padding:5px 8px;background:transparent;border:1px solid var(--border);color:var(--text3);border-radius:8px;font-size:11px;cursor:pointer;flex-shrink:0}
.bkp-btns{display:flex;gap:8px;margin-top:16px}
.bkp-now{flex:1;padding:11px;background:rgba(138,90,32,.1);border:1.5px solid rgba(138,90,32,.28);color:var(--accent);border-radius:10px;font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:2px;cursor:pointer;transition:all .2s}
.bkp-now:hover{background:rgba(138,90,32,.18)}
.bkp-export{flex:1;padding:11px;background:transparent;border:1px solid var(--border);color:var(--text3);border-radius:10px;font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:2px;cursor:pointer;transition:all .2s}
.bkp-export:hover{border-color:var(--accent);color:var(--accent)}
.bkp-close{flex:1;padding:11px;background:transparent;border:1px solid var(--border);color:var(--text3);border-radius:10px;font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:2px;cursor:pointer}

/* ── THEME PANEL ── */
#theme-panel{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:510;align-items:flex-start;justify-content:flex-end;padding:14px}
#theme-panel.on{display:flex}
#theme-box{background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:18px 20px;width:min(480px,calc(100vw - 28px));max-height:calc(100vh - 28px);overflow-y:auto;-webkit-overflow-scrolling:touch;animation:popIn .25s ease;box-shadow:0 12px 48px rgba(0,0,0,.14)}
.tp-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.tp-ttl{font-size:18px;font-weight:300;font-style:italic;color:var(--text)}
.tp-close{background:none;border:none;color:var(--text3);cursor:pointer;font-size:24px;line-height:1;padding:4px 8px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}
.tp-sec{margin-bottom:20px}
.tp-sec-lbl{font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:2.5px;color:var(--accent);margin-bottom:10px;display:block}
.tp-themes{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.tp-theme{border-radius:11px;padding:11px 13px;cursor:pointer;border:2px solid transparent;transition:all .2s;min-height:44px}
.tp-theme:hover{transform:translateY(-1px)}
.tp-theme.sel{border-color:var(--accent)!important}
.tp-th-name{font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:2px;margin-bottom:2px}
.tp-th-desc{font-size:11px;opacity:.6;font-style:italic}
.tp-th-sw-row{display:flex;gap:3px;margin-top:8px}
.tp-th-sw{height:4px;border-radius:2px}
.tp-papers{display:flex;gap:8px;flex-wrap:wrap;padding-bottom:4px}
.tp-paper{width:64px;height:64px;border-radius:10px;cursor:pointer;border:2px solid rgba(128,128,128,.25);transition:all .18s;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:3px;position:relative}
.tp-paper.sel{border-color:var(--accent)!important}
.tp-p-line{width:70%;height:1px;border-radius:1px}
.tp-p-name{font-size:8px;font-family:'Cormorant SC',serif;position:absolute;bottom:3px;letter-spacing:.5px}
.tp-styles{display:flex;gap:8px;flex-wrap:wrap}
.tp-style{flex:1;min-width:64px;padding:11px 6px;border-radius:10px;cursor:pointer;border:1px solid var(--border);background:var(--card);text-align:center;transition:all .18s;min-height:56px;display:flex;flex-direction:column;align-items:center;justify-content:center}
.tp-style:hover,.tp-style.sel{border-color:var(--accent)}
.tp-style.sel{background:rgba(138,90,32,.1)}
.tp-st-icon{font-size:18px;margin-bottom:4px}
.tp-st-name{font-family:'Cormorant SC',serif;font-size:11px;letter-spacing:1.5px;color:var(--text3)}
.tp-fonts{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.tp-font{padding:11px 13px;border-radius:10px;cursor:pointer;border:1px solid var(--border);background:var(--card);transition:all .18s;min-height:52px;display:flex;flex-direction:column;justify-content:center}
.tp-font:hover,.tp-font.sel{border-color:var(--accent)}
.tp-font.sel{background:rgba(138,90,32,.1)}
.tp-f-name{font-size:14px;color:var(--text);margin-bottom:3px}
.tp-f-lbl{font-family:'Cormorant SC',serif;font-size:11px;letter-spacing:1.5px;color:var(--text3)}
.tp-reset-btn{width:100%;padding:11px 14px;background:transparent;border:1px solid var(--border);border-radius:10px;font-family:'Cormorant SC',serif;font-size:12px;letter-spacing:2px;color:var(--text3);cursor:pointer;transition:all .2s;margin-top:4px}
.tp-reset-btn:hover{border-color:var(--accent);color:var(--accent)}
/* Mobile: bottom sheet */
@media(max-width:680px){
 #theme-panel{align-items:flex-end!important;justify-content:center!important;padding:0!important}
 #theme-box{width:100%!important;max-width:100%!important;border-radius:24px 24px 0 0!important;max-height:86vh!important;padding:0 0 32px!important;border-left:none!important;border-right:none!important;border-bottom:none!important}
 #tp-drag-handle{display:flex!important}
 #tp-mobile-hdr{display:flex!important}
 .tp-hdr{display:none!important}
 .tp-sec-lbl{font-size:13px!important;letter-spacing:2px!important}
 .tp-th-name{font-size:14px!important}
 .tp-th-desc{font-size:12px!important}
 .tp-paper{width:70px!important;height:70px!important}
 .tp-p-name{font-size:9px!important}
 .tp-st-icon{font-size:20px!important;margin-bottom:6px!important}
 .tp-st-name{font-size:12px!important;letter-spacing:1px!important}
 .tp-f-name{font-size:15px!important}
 .tp-f-lbl{font-size:12px!important}
 .tp-fonts{gap:10px!important}
 .tp-themes{gap:10px!important}
 .tp-reset-btn{font-size:13px!important;padding:13px!important}
 #tp-inner-scroll{padding:0 20px!important}
}

/* ── MODALS ── */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.48);z-index:400;align-items:center;justify-content:center}
.modal-bg.on{display:flex}
.modal-box{background:var(--bg);border:1px solid var(--border);border-radius:18px;padding:26px;width:380px;max-width:calc(100vw - 32px);animation:popIn .25s ease;box-shadow:0 12px 48px rgba(0,0,0,.15)}
.modal-ttl{font-size:18px;font-weight:300;font-style:italic;color:var(--text);margin-bottom:14px}
.modal-input{width:100%;padding:10px 13px;background:var(--card);border:1.5px solid var(--border);border-radius:9px;font-family:'Cormorant Garamond',serif;font-size:15px;color:var(--text);outline:none;margin-bottom:10px}
.modal-input:focus{border-color:var(--accent)}
.modal-btns{display:flex;gap:9px;margin-top:4px}
.modal-save{flex:1;padding:10px;background:rgba(138,90,32,.1);border:1.5px solid rgba(138,90,32,.28);color:var(--accent);border-radius:9px;font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:2px;cursor:pointer}
.modal-cancel{flex:1;padding:10px;background:transparent;border:1px solid var(--border);color:var(--text3);border-radius:9px;font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:2px;cursor:pointer}

/* Compile overlay */
#compile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.58);z-index:300;align-items:center;justify-content:center;flex-direction:column;text-align:center}
#compile-overlay.on{display:flex}
.ov-pen{font-size:52px;animation:shimmer 2s ease infinite;margin-bottom:18px}
.ov-msg{font-size:18px;font-style:italic;color:var(--text);line-height:1.85}
.ldots{display:flex;justify-content:center;gap:8px;margin-top:18px}
.ld{width:7px;height:7px;border-radius:50%;background:var(--accent);animation:dotPulse 1.5s ease infinite}
.ld:nth-child(2){animation-delay:.25s}.ld:nth-child(3){animation-delay:.5s}

/* Crop overlay */
.crop-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:500;display:none;align-items:center;justify-content:center;flex-direction:column;gap:16px}
.crop-overlay.on{display:flex}
.crop-box{position:relative;max-width:80vw;max-height:70vh;border:3px solid #fff}
.crop-box img{display:block;max-width:80vw;max-height:70vh;user-select:none}
.crop-sel{position:absolute;border:2px dashed #fff;background:rgba(255,255,255,.1);cursor:crosshair}
.crop-btns{display:flex;gap:12px}
.crop-btn{padding:10px 24px;border-radius:24px;cursor:pointer;font-family:'Cormorant SC',serif;font-size:11px;letter-spacing:2px;border:1px solid rgba(255,255,255,.4)}
.crop-apply{background:rgba(138,90,32,.8);color:#fff;border-color:transparent}
.crop-cancel{background:rgba(255,255,255,.1);color:#fff}

/* Notif */
#notif{display:none;position:fixed;bottom:calc(20px + var(--safe-bottom));left:50%;transform:translateX(-50%);background:var(--bg);border:1px solid var(--border);border-radius:36px;padding:9px 18px;z-index:600;font-size:13px;color:var(--text);box-shadow:0 6px 26px rgba(0,0,0,.12);align-items:center;gap:8px;animation:notifIn .3s ease;white-space:nowrap;max-width:calc(100vw - 40px)}
/* v164: don't block the bottom tab bar on mobile */
@media (max-width:899px){#notif{bottom:calc(88px + var(--safe-bottom))}}
#notif button{background:none;border:none;color:var(--text3);cursor:pointer;font-size:16px;line-height:1}
button,[role="button"],.ch-item,.alb-card,.tree-card,.pin-key,.sb-btn,.ao-card{min-height:44px;min-width:44px}
.xp-burst{position:fixed;pointer-events:none;font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:2px;color:var(--accent);animation:xpFloat 1s ease forwards;z-index:600}

/* ── CAPACITOR / APP GUIDE ── */
#screen-appguide{max-width:700px;padding:38px 44px 80px}
.ag-h1{font-size:36px;font-weight:300;font-style:italic;color:var(--text);margin-bottom:8px}
.ag-sub{font-size:15px;color:var(--text3);font-style:italic;margin-bottom:32px;line-height:1.7}
.ag-step{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:20px 22px;margin-bottom:14px;box-shadow:var(--shadow)}
.ag-step-num{font-family:'Cormorant SC',serif;font-size:12px;letter-spacing:4px;color:var(--accent);margin-bottom:6px;opacity:.7}
.ag-step-ttl{font-size:18px;font-weight:400;color:var(--text);margin-bottom:8px}
.ag-step-desc{font-size:14px;color:var(--text3);line-height:1.8}
.ag-code{background:#1e1e2e;border-radius:10px;padding:14px 18px;margin:10px 0;font-family:'Courier New',monospace;font-size:13px;color:#a8d8a8;overflow-x:auto;white-space:pre}
.ag-cost{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.ag-cost-item{background:rgba(138,90,32,.07);border:1px solid rgba(138,90,32,.15);border-radius:8px;padding:6px 12px;font-size:12px;color:var(--text2)}
.ag-cost-item strong{color:var(--accent)}

/* ══ ACCOUNT PICKER OVERLAY ══════════════════════════════════ */
#account-overlay{position:fixed;inset:0;z-index:2000;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg);animation:fadeIn .4s ease;padding:24px}
#account-overlay.hidden{display:none!important;pointer-events:none!important;visibility:hidden}
.ao-brand-eye{font-family:'Cormorant SC',serif;font-size:12px;letter-spacing:7px;color:var(--accent);opacity:.7;margin-bottom:10px;text-align:center}
.ao-brand-title{font-size:54px;font-weight:300;font-style:italic;color:var(--text);text-align:center;line-height:1;margin-bottom:6px}
.ao-brand-tag{font-size:14px;color:var(--text3);font-style:italic;text-align:center;margin-bottom:44px}
.ao-cards{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;max-width:700px}
.ao-card{background:var(--card);border:1.5px solid var(--border);border-radius:24px;padding:28px 22px 22px;cursor:pointer;transition:all .25s;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px;min-width:130px;max-width:160px;position:relative;box-shadow:var(--shadow)}
.ao-card:hover{border-color:var(--accent2);transform:translateY(-4px);box-shadow:0 10px 36px rgba(138,90,32,.14)}
.ao-avatar{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:34px;border:2px solid var(--border);background:var(--bg2);margin-bottom:4px;position:relative}
.ao-lock{position:absolute;bottom:0;right:0;width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;font-size:11px;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg)}
.ao-name{font-size:16px;color:var(--text);font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:130px}
.ao-count{font-size:13px;color:var(--text2);font-style:italic}
.ao-add-card{border-style:dashed;opacity:.55}
.ao-card.ao-active{border-color:var(--accent)!important;box-shadow:0 0 0 2px rgba(138,90,32,.18),0 10px 36px rgba(138,90,32,.14)!important}
.ao-active-badge{color:var(--accent);font-size:14px}
.ao-add-card:hover{opacity:1;border-color:var(--accent);border-style:dashed}

/* ── PIN SCREEN ── */
.pin-screen{display:flex;flex-direction:column;align-items:center;gap:0;animation:popIn .25s ease;max-width:340px;width:100%}
.pin-avatar-lg{width:72px;height:72px;border-radius:50%;background:var(--bg2);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:34px;margin-bottom:12px}
.pin-who{font-size:24px;font-weight:300;font-style:italic;color:var(--text);margin-bottom:4px}
.pin-prompt{font-size:13px;color:var(--text3);font-style:italic;margin-bottom:22px}
.pin-err{color:#c03030;font-size:13px;font-style:italic;min-height:20px;margin-bottom:8px;text-align:center}
.pin-dots{display:flex;gap:14px;justify-content:center;margin-bottom:24px}
.pin-dot{width:16px;height:16px;border-radius:50%;border:2px solid var(--border);background:transparent;transition:all .2s}
.pin-dot.filled{background:var(--accent);border-color:var(--accent)}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}
.pin-dot.err{background:#c03030;border-color:#c03030;animation:shake .35s ease}
.pin-pad{display:grid;grid-template-columns:repeat(3,80px);gap:10px;margin-bottom:16px}
.pin-key{height:64px;border-radius:16px;background:var(--card);border:1px solid var(--border);font-size:24px;font-family:'Cormorant Garamond',serif;color:var(--text);cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;user-select:none;-webkit-tap-highlight-color:transparent}
.pin-key:hover{background:rgba(138,90,32,.1);border-color:var(--accent)}
.pin-key:active{transform:scale(.93)}
.pin-key.ghost{background:transparent;border-color:transparent;cursor:default}
.pin-key.del{font-size:18px;color:var(--text3)}
.pin-back-link{background:none;border:none;color:var(--text3);cursor:pointer;font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:2px;padding:6px 14px;margin-top:4px;transition:color .2s}
.pin-back-link:hover{color:var(--accent)}

/* ── CREATE ACCOUNT FORM ── */
.create-box{background:var(--bg);border:1.5px solid var(--border);border-radius:22px;padding:30px;max-width:440px;width:100%;animation:popIn .25s ease;box-shadow:var(--shadow);max-height:90vh;overflow-y:auto}
.create-ttl{font-size:24px;font-weight:300;font-style:italic;color:var(--text);margin-bottom:6px}
.create-sub{font-size:13px;color:var(--text3);font-style:italic;margin-bottom:22px;line-height:1.7}
.create-lbl{font-family:'Cormorant SC',serif;font-size:12px;letter-spacing:3px;color:var(--accent);margin-bottom:8px;display:block}
.create-inp{width:100%;padding:11px 14px;background:var(--card);border:1.5px solid var(--border);border-radius:10px;font-family:'Cormorant Garamond',serif;font-size:16px;color:var(--text);outline:none;margin-bottom:18px;transition:border .2s}
.create-inp:focus{border-color:var(--accent)}
.av-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.av-opt{width:44px;height:44px;border-radius:50%;background:var(--bg2);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:22px;cursor:pointer;transition:all .2s;user-select:none;-webkit-tap-highlight-color:transparent}
.av-opt:hover{transform:scale(1.12)}
.av-opt.sel{border-color:var(--accent);background:rgba(138,90,32,.1);transform:scale(1.12)}
.pin-setup-dots{display:flex;gap:10px;justify-content:center;margin:10px 0 12px}
.pin-setup-dot{width:12px;height:12px;border-radius:50%;border:2px solid var(--border);background:transparent;transition:all .2s}
.pin-setup-dot.filled{background:var(--accent);border-color:var(--accent)}
.pin-setup-pad{display:grid;grid-template-columns:repeat(3,60px);gap:8px;justify-content:center;margin-bottom:4px}
.pin-setup-key{height:50px;border-radius:12px;background:var(--card);border:1px solid var(--border);font-size:20px;font-family:'Cormorant Garamond',serif;color:var(--text);cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;user-select:none}
.pin-setup-key:hover{background:rgba(138,90,32,.1);border-color:var(--accent)}
.pin-setup-key:active{transform:scale(.93)}
.pin-setup-key.ghost{background:transparent;border-color:transparent;cursor:default}
.pin-setup-status{font-size:11px;color:var(--text3);font-style:italic;text-align:center;min-height:16px;margin-bottom:10px}
.create-btns{display:flex;gap:9px;margin-top:6px}
.create-go{flex:2;padding:13px;background:rgba(138,90,32,.1);border:1.5px solid rgba(138,90,32,.28);color:var(--accent);border-radius:12px;font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:2px;cursor:pointer;transition:all .2s}
.create-go:hover{background:rgba(138,90,32,.18)}
.create-cancel{flex:1;padding:13px;background:transparent;border:1px solid var(--border);color:var(--text3);border-radius:12px;font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:2px;cursor:pointer}

/* ── SIDEBAR USER PILL ── */
#sb-user-pill{display:flex;align-items:center;gap:10px;padding:11px 18px;cursor:pointer;border-bottom:1px solid var(--border);background:none;width:100%;text-align:left;transition:background .2s}
#sb-user-pill:hover{background:rgba(138,90,32,.05)}
.sup-av{width:32px;height:32px;border-radius:50%;background:var(--bg2);display:flex;align-items:center;justify-content:center;font-size:16px;border:1.5px solid var(--border);flex-shrink:0;position:relative}
.sup-lock{position:absolute;bottom:-2px;right:-2px;width:13px;height:13px;border-radius:50%;background:var(--accent);color:#fff;font-size:7px;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--sidebar)}
.sup-info{flex:1;min-width:0}
.sup-name{font-size:15px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sup-hint{font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:2px;color:var(--text3);margin-top:2px}
.sup-chevron{font-size:11px;color:var(--text3)}

/* ── ACCOUNT MANAGE PANEL ── */
#acct-manage-panel{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:800;display:none;align-items:center;justify-content:center}
#acct-manage-panel.on{display:flex}
.amp-box{background:var(--bg);border:1px solid var(--border);border-radius:22px;padding:28px;width:440px;max-width:calc(100vw - 32px);max-height:82vh;overflow-y:auto;animation:popIn .25s ease;box-shadow:0 14px 52px rgba(0,0,0,.16)}
.amp-ttl{font-size:20px;font-weight:300;font-style:italic;color:var(--text);margin-bottom:18px}
.amp-row{display:flex;align-items:center;gap:12px;padding:12px;background:var(--card);border:1px solid var(--border);border-radius:12px;margin-bottom:8px}
.amp-av{width:40px;height:40px;border-radius:50%;background:var(--bg2);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.amp-info{flex:1;min-width:0}
.amp-name{font-size:14px;color:var(--text)}
.amp-meta{font-size:13px;color:var(--text2);font-style:italic;margin-top:3px}
.amp-acts{display:flex;gap:5px;flex-wrap:wrap;justify-content:flex-end;max-width:160px}
.amp-btn{padding:7px 13px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text3);font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:1px;cursor:pointer;transition:all .2s;white-space:nowrap;min-height:40px}
.amp-btn:hover{border-color:var(--accent);color:var(--accent)}
.amp-btn.red{color:#c03030;border-color:rgba(192,48,48,.3)}
.amp-btn.red:hover{background:rgba(192,48,48,.08)}

/* ── TOOLBAR TOGGLE TAB ── */
/* toolbar-tab moved above notepad — no longer position:absolute */

/* ── MUSIC — moved to bottom actions bar, not inline in sheet ── */
.music-bar{display:none!important}  /* hide inline music bar — music is now in bottom actions */
.music-bottom{display:flex;align-items:center;gap:8px;padding:8px 0;flex-wrap:wrap}
.music-bottom-player{display:flex;align-items:center;gap:8px;padding:7px 12px;background:var(--card);border:1px solid var(--border);border-radius:10px;flex:1}
.music-bottom-title{font-size:12px;color:var(--text2);font-style:italic;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.music-bottom-btn{width:28px;height:28px;border-radius:50%;background:transparent;border:1px solid var(--border);cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}
.music-bottom-btn:hover{border-color:var(--accent);color:var(--accent)}
input[type=range].music-vol-bottom{width:60px;accent-color:var(--accent);height:3px;flex-shrink:0}

/* ── BOOK PREVIEW — in-progress chapters shown in book ── */
.bk-in-progress{font-size:16px;color:var(--text3);font-style:italic;padding:16px;border:1px solid var(--border);border-radius:10px;line-height:2.1;max-height:220px;overflow:hidden;position:relative;mask-image:linear-gradient(to bottom,black 60%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,black 60%,transparent 100%)}
.bk-preview-note{font-size:11px;color:var(--accent);font-style:italic;margin-top:6px;opacity:.7}

/* ── SHARE PANEL ── */
.share-method-ttl{font-size:15px;color:var(--text);margin-bottom:6px;display:flex;align-items:center;gap:8px}
.share-method-desc{font-size:13px;color:var(--text3);line-height:1.7;margin-bottom:12px}
.share-btn:hover{background:rgba(138,90,32,.18)}
.share-btn-ghost{padding:9px 18px;background:transparent;border:1px solid var(--border);color:var(--text3);border-radius:10px;font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:2px;cursor:pointer;transition:all .2s;display:inline-block}
.share-btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.share-music-list{margin-top:14px}
.sml-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--card);border:1px solid var(--border);border-radius:10px;margin-bottom:7px;cursor:pointer;transition:all .2s}
.sml-item:hover{border-color:var(--accent2)}
.sml-emoji{font-size:20px;flex-shrink:0}
.sml-info{flex:1}
.sml-name{font-size:14px;color:var(--text)}
.sml-meta{font-size:13px;color:var(--text3);font-style:italic;margin-top:2px}
.sml-play{width:32px;height:32px;border-radius:50%;background:rgba(138,90,32,.1);border:1px solid rgba(138,90,32,.25);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;transition:all .2s}
.sml-play:hover{background:rgba(138,90,32,.2)}
.sml-play.playing{background:var(--accent);color:#fff}

/* ══ MOBILE — sidebar becomes a slide-out drawer ════════════════ */
#mob-bar{display:none}
#mob-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.48);z-index:498}

@media (max-width: 680px){
 #app{flex-direction:column}

 /* Sidebar: hidden off-screen left, slides in when .open */
 #sidebar{
  position:fixed;top:0;left:0;bottom:0;
  width:82vw;max-width:300px;
  z-index:500;
  transform:translateX(-105%);
  transition:transform .28s cubic-bezier(.4,0,.2,1);
  box-shadow:none;
 }
 #sidebar.open{
  transform:translateX(0);
  box-shadow:4px 0 32px rgba(0,0,0,.22);
 }

 /* Tap-to-close overlay — only visible when sidebar is open */
 #mob-overlay{display:none}
 #mob-overlay.show{display:block!important;animation:fadeIn .2s ease}

 /* Main takes full width */
 #main{width:100%;padding-top:52px}

 /* Mobile top bar */
 #mob-bar{
  display:flex;align-items:center;gap:0;
  position:fixed;top:0;left:0;right:0;height:52px;
  background:var(--sidebar);border-bottom:1px solid var(--border);
  z-index:490;padding:0 4px;
 }
 #mob-hamburger{
  width:48px;height:52px;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:5px;background:none;border:none;cursor:pointer;flex-shrink:0;
  padding:0 12px;
 }
 #mob-hamburger span{display:block;width:20px;height:1.5px;background:var(--text2);border-radius:2px;transition:all .25s}
 #mob-hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
 #mob-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
 #mob-hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
 #mob-title{flex:1;text-align:center;font-size:18px;font-weight:300;font-style:italic;color:var(--text);letter-spacing:1px}
 #mob-acct{width:48px;height:52px;display:flex;align-items:center;justify-content:center;font-size:22px;background:none;border:none;cursor:pointer;flex-shrink:0}

 /* Screens: fix padding so content isn't under the bar */
 .screen{padding:20px 18px 80px!important}
 .home-h1{font-size:28px!important}
 .home-sub{font-size:17px!important}
 #home-empty-nudge{font-size:17px!important;line-height:1.7!important;padding:16px 20px!important}

 /* Notepad: full width on mobile */
 .notepad{margin:12px 8px!important;border-radius:14px!important}
 .np-holes{display:none!important}
 .np-inner{padding:16px 14px!important}
 .media-canvas{margin:8px 8px 0!important}
 .np-topbar{gap:10px}
 .np-top-actions{width:100%;justify-content:flex-end}
 .np-bottom-tools{width:100%;justify-content:flex-end}
 .toolbar-pill,.btn-top-prev,.btn-top-skip,.btn-top-save{font-size:11px;padding-left:12px;padding-right:12px}

 /* Book view */
 .book-page{padding:28px 18px!important}
 .bk-text{font-size:18px!important}
 .bk-ttl{font-size:26px!important}
 .cc-name{font-size:12px!important}
 .cc-emoji{font-size:24px!important}
 .cc-count{font-size:12px!important}
 .np-q-txt{font-size:20px!important}
 .np-q-num{font-size:12px!important}
 .ch-grid{grid-template-columns:1fr 1fr!important}

 /* Larger sidebar text on mobile */
 #sidebar .sb-eye{font-size:13px!important}
 #sidebar .sb-title{font-size:22px!important}
 #sidebar .sb-tag{font-size:12px!important}
 #sidebar .nav-lbl{font-size:11px!important}
 #sidebar .ch-name{font-size:14px!important}
 #sidebar .ch-emoji{font-size:20px!important}
 #sidebar .ch-prog{font-size:11px!important}
 #sidebar .sb-btn{font-size:22px!important;padding:9px 3px!important;min-width:44px!important}

 #sidebar .sup-name{font-size:16px!important}
 #sidebar .sup-hint{font-size:13px!important}
 #mob-bar #mob-title{font-size:20px!important}
 .notepad{border-radius:0 0 12px 12px;min-height:300px}
 .np-inner{padding:12px 14px 14px}
 .np-q-txt{font-size:18px!important;line-height:1.45!important}
 #home-body{padding:14px 12px 80px!important}
 .ch-grid{grid-template-columns:repeat(2,1fr)!important;gap:8px!important}
 .bk-ch{padding:16px 12px}
 .ao-cards{grid-template-columns:repeat(2,1fr)!important}
 .ao-card{padding:14px 8px}
 #qs-box{margin:0 8px}
}


/* ── Emoji picker ── */
#emoji-picker-panel.open{display:block!important}
.epp-tabs{display:flex;gap:4px;margin-bottom:8px;flex-wrap:wrap}
.epp-tab{background:none;border:1px solid var(--border);border-radius:20px;padding:2px 9px;font-size:12px;cursor:pointer;color:var(--text3);transition:all .15s}
.epp-tab.sel{background:var(--accent);color:#fff;border-color:var(--accent)}
.epp-grid{display:flex;flex-wrap:wrap;gap:4px;max-height:160px;overflow-y:auto}
.epp-emoji{font-size:22px;cursor:pointer;border-radius:6px;padding:2px 4px;transition:all .12s;border:1.5px solid transparent}
.epp-emoji:hover{background:var(--bg2);border-color:var(--border);transform:scale(1.18)}
.epp-search{width:100%;box-sizing:border-box;border:1px solid var(--border);border-radius:8px;padding:5px 10px;font-size:13px;background:var(--bg2);color:var(--text);margin-bottom:8px;outline:none}


/* ── GLOBAL SEARCH ───────────────────────────────────────────── */
#search-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:700;display:none;align-items:flex-start;justify-content:center;padding-top:60px}
#search-overlay.on{display:flex}
#search-box{background:var(--bg);border:1px solid var(--border);border-radius:20px;width:560px;max-width:calc(100vw - 32px);max-height:75vh;display:flex;flex-direction:column;animation:popIn .2s ease;box-shadow:0 16px 60px rgba(0,0,0,.22);overflow:hidden}
#search-input{width:100%;box-sizing:border-box;padding:16px 20px;font-size:17px;font-family:'Cormorant Garamond',serif;border:none;border-bottom:1px solid var(--border);background:transparent;color:var(--text);outline:none}
#search-input::placeholder{color:var(--text3);font-style:italic}
#search-results{overflow-y:auto;flex:1;min-height:0;padding:8px 0}
.sr-item{padding:12px 20px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .15s}
.sr-item:hover{background:var(--bg2)}
.sr-ch{font-family:'Cormorant SC',serif;font-size:9px;letter-spacing:2px;color:var(--text3);margin-bottom:3px}
.sr-q{font-size:13px;color:var(--text2);margin-bottom:4px;line-height:1.4}
.sr-snippet{font-size:12px;color:var(--text3);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sr-snippet mark{background:rgba(200,150,40,.3);color:var(--text);border-radius:2px;font-style:normal}
#search-empty{text-align:center;padding:32px 20px;font-style:italic;color:var(--text3);font-size:14px}
#search-close-row{padding:10px 16px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}
#search-count{font-family:'Cormorant SC',serif;font-size:10px;letter-spacing:1.5px;color:var(--text3)}

/* ── HELP PANEL ──────────────────────────────────────────────── */
#help-panel{position:fixed;inset:0;background:rgba(0,0,0,.52);z-index:600;display:none;align-items:center;justify-content:center;padding:20px}
#help-panel.on{display:flex}
#help-box{background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:0;width:100%;max-width:580px;height:min(78vh,680px);display:flex;flex-direction:column;animation:popIn .25s ease;box-shadow:0 16px 60px rgba(0,0,0,.25);overflow:hidden;box-sizing:border-box}
@keyframes slideUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
#help-handle{display:none}
#help-header{padding:12px 24px 0;flex-shrink:0}
#help-body{overflow-y:auto;overflow-x:hidden;padding:0 24px 24px;flex:1;min-height:0;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
#help-tabs{display:flex;gap:6px;padding:14px 24px 0;flex-shrink:0;flex-wrap:wrap;overflow-x:auto;-webkit-overflow-scrolling:touch}
.help-tab{padding:7px 14px;border-radius:20px;border:1.5px solid var(--border);background:transparent;color:var(--text3);font-family:'Cormorant SC',serif;font-size:11px;letter-spacing:1.5px;cursor:pointer;transition:all .2s;-webkit-tap-highlight-color:transparent;min-height:36px}
.help-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}
.help-sec{display:none;padding-top:18px}
.help-sec.active{display:block}
.help-h2{font-family:'Cormorant SC',serif;font-size:15px;letter-spacing:2px;color:var(--accent);margin:20px 0 8px;opacity:.9}
.help-h2:first-child{margin-top:4px}
.help-p{font-size:16px;color:var(--text2);line-height:1.8;margin-bottom:12px}
.help-step{display:flex;gap:12px;margin-bottom:12px;align-items:flex-start}
.help-num{width:24px;height:24px;border-radius:50%;background:var(--accent);color:#fff;font-family:'Cormorant SC',serif;font-size:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.help-step-text{font-size:16px;color:var(--text2);line-height:1.7;flex:1}
.help-warn{background:rgba(180,60,60,.07);border:1.5px solid rgba(180,60,60,.2);border-radius:10px;padding:12px 14px;font-size:15px;color:var(--text2);line-height:1.65;margin-bottom:12px}
.help-tip{background:rgba(138,90,32,.07);border:1.5px solid rgba(138,90,32,.18);border-radius:10px;padding:12px 14px;font-size:15px;color:var(--text2);line-height:1.65;margin-bottom:12px}
.help-tip strong,.help-warn strong{color:var(--text)}
.help-close-btn{width:100%;padding:13px;background:transparent;border:1.5px solid var(--border);border-radius:12px;font-family:'Cormorant SC',serif;font-size:12px;letter-spacing:2px;color:var(--text3);cursor:pointer;margin-top:8px;min-height:44px}
/* ? button in sidebar */
#sb-help-btn{margin-top:auto;padding:10px 18px 14px;flex-shrink:0}
#sb-help-btn button{width:100%;padding:9px;background:rgba(0,0,0,.02);border:1px solid rgba(0,0,0,.15);border-radius:10px;font-family:'Cormorant SC',serif;font-size:11px;letter-spacing:2px;color:var(--text3);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;transition:background .2s;min-height:40px}
#sb-help-btn button:hover{background:var(--bg2)}

/* ── MOBILE BOTTOM NAV ─────────────────────────────────────────── */
#mob-bottom-nav{
  display:none; /* hidden on desktop */
}
@media (max-width:680px){
  #mob-bottom-nav{
    display:flex;
    position:fixed;
    bottom:0;left:0;right:0;
    height:calc(64px + var(--safe-bottom,0px));
    padding-bottom:var(--safe-bottom,0px);
    background:var(--sidebar);
    border-top:1px solid var(--border);
    z-index:480; /* below modals/panels but above main */
    align-items:stretch;
  }
  .mob-nav-btn{
    flex:1;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:3px;
    background:transparent;
    border:none;
    cursor:pointer;
    padding:8px 4px 4px;
    min-height:64px;
    min-width:44px;
    color:var(--text3);
    -webkit-tap-highlight-color:transparent;
    transition:color .15s ease, background .15s ease;
  }
  .mob-nav-btn:active{
    background:rgba(138,90,32,.08);
  }
  .mob-nav-btn.active{
    color:var(--accent);
  }
  .mbn-icon{
    font-size:22px;
    line-height:1;
    transition:transform .15s cubic-bezier(.4,0,.2,1);
  }
  .mob-nav-btn.active .mbn-icon{
    transform:scale(1.15);
  }
  .mbn-lbl{
    font-family:'Cormorant SC',serif;
    font-size:9px;
    letter-spacing:1.5px;
    line-height:1;
    text-transform:uppercase;
  }

  /* Push main content above the bottom nav */
  #main{
    padding-bottom:calc(64px + var(--safe-bottom,0px)) !important;
  }

  /* On questions screen, notepad needs room too */
 .screen#screen-questions{
    padding-bottom:calc(80px + var(--safe-bottom,0px)) !important;
  }
  /* Flow screen needs room above the bottom nav */
  #screen-flow.active{
    padding-bottom:calc(64px + var(--safe-bottom,0px)) !important;
  }
  #home-quick-actions{
    grid-template-columns:1fr !important;
  }

  /* Top bar safe-area */
  #mob-bar{
    padding-top:var(--safe-top,0px);
    height:calc(52px + var(--safe-top,0px));
  }

  /* Reduce notepad spine hole padding on mobile */
  .np-inner{
    padding-left:18px !important;
    padding-right:14px !important;
  }
  #screen-questions{
    background:
     radial-gradient(circle at 50% 18%,rgba(236,184,110,.45) 0,rgba(236,184,110,.18) 18%,rgba(236,184,110,0) 34%),
     linear-gradient(180deg,#15100d 0%,#201712 100%) !important;
  }
  .np-holes{
    display:none !important;
  }
}

/* ── iOS / TOUCH RELIABILITY FIXES ─────────────────────────────── */

/* 1. Global tap-highlight suppression — prevents blue flash on all tappable elements */
*, *::before, *::after {
  -webkit-tap-highlight-color: transparent;
}

/* 2. Restore tap highlight only for real focusable inputs */
input, textarea, select {
  -webkit-tap-highlight-color: rgba(138,90,32,.15);
}

/* 3. touch-action on html + * to kill 300ms delay everywhere */
html {
  touch-action: manipulation;
  -webkit-text-size-adjust: 100%;
}

/* 4. pointer-events + cursor on all interactive classes (additive) */
.sb-btn, .ch-item, .ch-card, .alb-card, .tree-card,
.ao-card, .pin-setup-key, .pin-key, .amp-row,
.btn-prev, .btn-nxt, .btn-save, .btn-compile,
.bk-act, .cc-bubble, .sr-item, .av-opt, .help-tab,
.mob-nav-btn {
  cursor: pointer;
  pointer-events: auto;
  -webkit-user-select: none;
  user-select: none;
  touch-action: manipulation;
}
/* Tappable elements get pointer cursor but NOT user-select:none
   so question text and answers remain selectable/copyable */
.sb-btn,.ch-item,.ch-card,.alb-card,.tree-card,.ao-card,
.pin-setup-key,.pin-key,.amp-row,.btn-prev,.btn-nxt,.btn-save,
.btn-compile,.bk-act,.cc-bubble,.sr-item,.av-opt,.help-tab {
  cursor: pointer;
  pointer-events: auto;
  touch-action: manipulation;
}

/* 5. Allow text selection inside the editor and inputs */
#q-editor, input, textarea, [contenteditable] {
  -webkit-user-select: text !important;
  user-select: text !important;
}

/* 6. Prevent body scroll from hijacking overlay taps on iOS */
.screen.active {
  -webkit-overflow-scrolling: touch;
}

/* 7. Make ao-card (account picker) reliably tappable */
.ao-card {
  cursor: pointer;
  pointer-events: auto;
  -webkit-tap-highlight-color: rgba(138,90,32,.08);
  touch-action: manipulation;
}


/* Floated media items inside notepad */
.float-ctrl-btn{background:rgba(0,0,0,.55);border:none;color:#fff;border-radius:4px;font-size:10px;padding:2px 5px;cursor:pointer;white-space:nowrap}

#share-panel{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:510;display:none;align-items:center;justify-content:center}
#share-panel.on{display:flex}

.share-box{background:var(--bg);border:1px solid var(--border);border-radius:20px;padding:28px;width:480px;max-width:calc(100vw - 32px);max-height:86vh;overflow-y:auto;animation:popIn .25s ease;box-shadow:0 14px 52px rgba(0,0,0,.14)}

.share-ttl{font-size:22px;font-weight:300;font-style:italic;color:var(--text);margin-bottom:6px}

.share-sub{font-size:13px;color:var(--text3);font-style:italic;margin-bottom:22px;line-height:1.7}

.share-method{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px;margin-bottom:12px}

.share-btn{padding:9px 18px;background:rgba(138,90,32,.1);border:1.5px solid rgba(138,90,32,.28);color:var(--accent);border-radius:10px;font-family:'Cormorant SC',serif;font-size:13px;letter-spacing:2px;cursor:pointer;transition:all .2s;display:inline-block}

/* ── Questions sticky bar ── */
.notepad-wrap{max-width:min(860px,90%)!important}
#q-sticky-bar{position:sticky;top:0;z-index:40;background:rgba(245,240,232,.96);backdrop-filter:blur(8px);border-bottom:1px solid rgba(138,90,32,.12);padding:8px 20px;margin:0 -20px 14px;display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:nowrap}
.q-sb-left,.q-sb-right{display:flex;gap:6px;align-items:center}
.q-sb-btn{background:none;border:1px solid rgba(138,90,32,.28);border-radius:20px;padding:7px 15px;font-family:'Cormorant Garamond',Georgia,serif;font-size:14px;letter-spacing:.3px;color:var(--accent);cursor:pointer;transition:all .15s;line-height:1;white-space:nowrap}
.q-sb-btn:hover{background:rgba(138,90,32,.08);border-color:rgba(138,90,32,.5)}
.q-sb-primary{background:var(--accent);border-color:var(--accent);color:#fff!important;padding:7px 16px;box-shadow:0 2px 6px rgba(138,90,32,.22)}
.q-sb-primary:hover{background:#a06a28;border-color:#a06a28}
/* Fix 4: mute secondary actions so Save & next reads as primary */
#q-prev-btn,#q-skip-btn{opacity:.6;font-size:13px}
#q-prev-btn:hover,#q-skip-btn:hover{opacity:1}
/* Fix 2: mobile — previous hidden, adjust bar */
@media (max-width:600px){
 #q-prev-btn{display:none}
 #q-sticky-bar{padding:7px 14px}
 #q-skip-btn{opacity:.75}
}
/* Fix 7: progress dots larger on mobile */
@media (max-width:680px){.q-dot{width:16px;height:16px}}
/* Fix 10: focus mode exit button more prominent on mobile */
@media (max-width:680px){
 body.focus-mode #q-focus-btn{
  background:rgba(200,144,58,.18);
  border-color:rgba(200,144,58,.5);
  color:rgba(200,144,58,1);
  padding:8px 18px;
  font-size:14px;
 }
}
/* Fix 6: writing bg chip hover state in Profile */
#prof-writing-bg .chip:hover{border-color:rgba(138,90,32,.35)!important;background:rgba(138,90,32,.06)!important}
#prof-writing-bg .chip:hover::before{transform:scale(1.06);transition:transform .15s ease}
