/* Therapy Aligned Clinical Wiki — shared client enhancements (loaded on every page).
   Notebook/bookmarks + read-aloud (TTS). Uses brand CSS vars with hard fallbacks so it
   styles correctly even on pages that don't define the full palette. */

/* ---------- Notebook FAB (fixed top-right, always visible) ---------- */
.ta-nb-fab{position:fixed;top:100px;right:14px;z-index:120;width:46px;height:46px;border-radius:50%;
  border:1px solid var(--clay,#C9A882);background:rgba(255,255,255,.95);color:var(--terracotta,#B5735A);
  display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 3px 14px rgba(46,34,24,.18);
  backdrop-filter:blur(4px);transition:transform .15s ease,box-shadow .15s ease;padding:0;
  font-family:var(--ui,"DM Sans",system-ui,sans-serif)}
.ta-nb-fab:hover{transform:translateY(-1px);box-shadow:0 5px 18px rgba(46,34,24,.24)}
.ta-nb-fab svg{width:22px;height:22px;display:block}
.ta-nb-fab .ta-nb-count{position:absolute;top:-5px;right:-5px;min-width:19px;height:19px;padding:0 4px;border-radius:10px;
  background:var(--sage,#7A8C74);color:#fff;font-size:.66rem;font-weight:700;display:none;align-items:center;justify-content:center;line-height:1}
.ta-nb-fab.has-items .ta-nb-count{display:flex}
.ta-nb-fab.ta-pulse{animation:ta-nb-pulse .5s ease}
@keyframes ta-nb-pulse{0%{transform:scale(1)}40%{transform:scale(1.22)}100%{transform:scale(1)}}

/* flying bookmark "ghost" that animates into the FAB */
.ta-fly{position:fixed;z-index:200;pointer-events:none;color:var(--terracotta,#B5735A);
  transition:transform .62s cubic-bezier(.5,-0.25,.4,1),opacity .62s ease}
.ta-fly svg{width:20px;height:20px;display:block}

/* ---------- Bookmark button (next to the article upvote) ----------
   Scoped under .article-vote so it beats the template's `.article-vote button{width:38px}` rule
   (which would otherwise squash this labelled button to icon width and clip the text). */
.article-vote .ta-bm{display:inline-flex;align-items:center;gap:6px;width:auto;height:auto;margin-left:4px;padding:7px 11px;
  border:1px solid var(--clay,#C9A882);border-radius:9px;background:var(--cream,#FAF7F2);color:var(--terracotta,#B5735A);
  font-family:var(--ui,"DM Sans",system-ui,sans-serif);font-size:.84rem;cursor:pointer;line-height:1}
.article-vote .ta-bm:hover{background:var(--sand,#EDE5D8)}
.article-vote .ta-bm.saved{background:var(--sage,#7A8C74);color:#fff;border-color:var(--sage,#7A8C74)}
.article-vote .ta-bm svg{width:15px;height:15px;display:block}
.article-vote .ta-bm .ta-bm-n{font-weight:700}

/* ---------- Notebook overlay (right-side drawer) ---------- */
.ta-nb-overlay{position:fixed;inset:0;z-index:10000;display:none;background:rgba(46,34,24,.42)}
.ta-nb-overlay.open{display:flex;align-items:stretch;justify-content:flex-end}
/* hide the fixed bottom-right text-resizer (z-index:9999) + read-aloud player while the drawer is open
   so they can't poke through the panel's footer */
body.ta-nb-open .zoom-controls,body.ta-nb-open .ta-player{display:none!important}
.ta-nb-panel{width:min(420px,92vw);height:100%;overflow:auto;background:var(--cream,#FAF7F2);
  box-shadow:-8px 0 30px rgba(46,34,24,.25);padding:20px 20px 26px;display:flex;flex-direction:column;gap:12px;
  font-family:var(--ui,"DM Sans",system-ui,sans-serif);animation:ta-nb-slide .22s ease}
@keyframes ta-nb-slide{from{transform:translateX(34px);opacity:.4}to{transform:none;opacity:1}}
.ta-nb-head{display:flex;align-items:center;justify-content:space-between;gap:10px;border-bottom:1px solid var(--sand,#EDE5D8);padding-bottom:10px}
.ta-nb-head h2{font-family:var(--display,"Cormorant Garamond",Georgia,serif);font-size:1.5rem;color:var(--deep,#2E2218);margin:0;font-weight:700}
.ta-nb-x{border:none;background:none;cursor:pointer;color:var(--muted,#7A6E63);line-height:1;padding:4px;display:flex}
.ta-nb-x svg{width:20px;height:20px}
.ta-nb-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;flex:1}
.ta-nb-item{display:flex;align-items:flex-start;gap:8px;background:#fff;border:1px solid var(--sand,#EDE5D8);border-radius:10px;padding:10px 12px}
.ta-nb-item a{color:var(--deep,#2E2218);text-decoration:none;font-weight:600;font-size:.9rem;flex:1;line-height:1.3}
.ta-nb-item a:hover{color:var(--terracotta,#B5735A)}
.ta-nb-rm{border:none;background:none;color:var(--muted,#7A6E63);cursor:pointer;line-height:1;padding:2px 4px;display:flex}
.ta-nb-rm svg{width:15px;height:15px}
.ta-nb-rm:hover{color:var(--terracotta,#B5735A)}
.ta-nb-empty{color:var(--muted,#7A6E63);font-size:.88rem;line-height:1.5;padding:18px 4px}
.ta-nb-actions{display:flex;gap:8px;border-top:1px solid var(--sand,#EDE5D8);padding-top:12px}
.ta-nb-btn{flex:1;font-family:inherit;font-weight:600;font-size:.84rem;padding:10px 12px;border-radius:9px;cursor:pointer;
  border:1px solid var(--clay,#C9A882);background:#fff;color:var(--deep,#2E2218)}
.ta-nb-btn.primary{background:var(--terracotta,#B5735A);color:#fff;border-color:var(--terracotta,#B5735A)}
.ta-nb-btn:disabled{opacity:.55;cursor:default}
.ta-nb-note{font-size:.72rem;color:var(--muted,#7A6E63);line-height:1.45}

/* ---------- Notebook sign-in (optional Google sync) ---------- */
.ta-nb-auth{border-bottom:1px solid var(--sand,#EDE5D8);padding-bottom:12px}
.ta-nb-signin .ta-nb-note{margin:0 0 10px}
.ta-nb-gbtn{display:flex;justify-content:center;min-height:40px}
.ta-nb-acct{display:flex;flex-direction:column;align-items:flex-start;gap:10px}
.ta-nb-who{font-size:.82rem;color:var(--bark,#5C4A3A);line-height:1.4}.ta-nb-who b{color:var(--deep,#2E2218)}
.ta-nb-acct-btns{display:flex;align-items:center;gap:10px}
.ta-nb-signout{border:1px solid var(--clay,#C9A882);background:#fff;color:var(--terracotta,#B5735A);font-family:inherit;
  font-size:.78rem;font-weight:600;border-radius:8px;padding:7px 14px;cursor:pointer}
.ta-nb-signout:hover{background:var(--sand,#EDE5D8)}
.ta-nb-forget{border:none;background:none;color:var(--muted,#7A6E63);font-family:inherit;font-size:.74rem;cursor:pointer;
  text-decoration:underline;padding:6px 2px}
.ta-nb-forget:hover{color:var(--terracotta,#B5735A)}

/* ---------- Library overlay: notebook list / detail / publish ---------- */
.ta-nb-body{display:flex;flex-direction:column;gap:2px;flex:1;min-height:0;overflow:auto}
.ta-lib-head{display:flex;align-items:center;justify-content:space-between;margin:4px 0 8px}
.ta-lib-h{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted,#7A6E63)}
.ta-lib-new{display:inline-flex;align-items:center;gap:5px;border:1px solid var(--clay,#C9A882);background:#fff;color:var(--terracotta,#B5735A);font-family:inherit;font-weight:600;font-size:.78rem;border-radius:8px;padding:6px 10px;cursor:pointer}
.ta-lib-new:hover{background:var(--sand,#EDE5D8)}.ta-lib-new svg{width:14px;height:14px}
.ta-lib-by{display:block;font-size:.7rem;font-weight:400;color:var(--muted,#7A6E63);margin-top:2px}
.ta-nb-detailby{font-family:var(--ui,"DM Sans",system-ui,sans-serif);font-size:.78rem;color:var(--muted,#7A6E63);margin:-4px 0 9px}
.ta-lib-publiclink{display:flex;align-items:center;gap:8px;justify-content:center;margin:0 0 10px;padding:9px 12px;border:1px solid var(--sand,#EDE5D8);border-left:4px solid var(--sage,#7A8C74);border-radius:9px;background:var(--cream,#FAF7F2);color:var(--bark,#5C4A3A);font-weight:600;font-size:.84rem;text-decoration:none}
.ta-lib-publiclink:hover{background:var(--sand,#EDE5D8);color:var(--terracotta,#B5735A)}
.ta-lib-publiclink svg{width:15px;height:15px;flex:0 0 auto}
.ta-lib-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:7px}
.ta-lib-open{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;background:#fff;border:1px solid var(--sand,#EDE5D8);border-left:4px solid var(--clay,#C9A882);border-radius:10px;padding:12px 14px;cursor:pointer;font-family:inherit;text-align:left}
.ta-lib-open:hover{background:var(--cream,#FAF7F2);border-left-color:var(--terracotta,#B5735A)}
.ta-lib-name{font-weight:600;color:var(--deep,#2E2218);font-size:.92rem}
.ta-lib-pub{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#4f6147;background:#e7efe4;border-radius:4px;padding:1px 5px;margin-left:6px}
.ta-lib-meta{display:flex;align-items:center;gap:3px;color:var(--muted,#7A6E63);font-size:.8rem;flex:0 0 auto}.ta-lib-meta svg{width:16px;height:16px}
.ta-nb-detailhead{margin:2px 0 4px}
.ta-nb-back{display:inline-flex;align-items:center;gap:4px;border:none;background:none;color:var(--terracotta,#B5735A);font-family:inherit;font-weight:600;font-size:.82rem;cursor:pointer;padding:4px 0}.ta-nb-back svg{width:16px;height:16px}
.ta-nb-detailname{font-family:var(--display,"Cormorant Garamond",Georgia,serif);font-size:1.4rem;font-weight:700;color:var(--deep,#2E2218);margin:0 0 8px}
.ta-nb-detailctrls{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:10px}
.ta-nb-detailctrls .ta-nb-btn{flex:0 1 auto;white-space:nowrap}  /* size each button to its label so it never clips/crams; row wraps instead */
.ta-nb-btn.danger{border-color:#d8b3a6;color:var(--terracotta,#B5735A)}
.ta-nb-addto{border:1px solid var(--sand,#EDE5D8);background:#fff;color:var(--sage,#7A8C74);cursor:pointer;border-radius:7px;padding:4px;display:flex;flex:0 0 auto}.ta-nb-addto svg{width:14px;height:14px}.ta-nb-addto:hover{background:var(--sand,#EDE5D8)}
.ta-addmenu{position:fixed;z-index:10001;background:#fff;border:1px solid var(--sand,#EDE5D8);border-radius:10px;box-shadow:0 10px 30px rgba(46,34,24,.2);padding:6px;min-width:224px;max-width:280px;font-family:var(--ui,"DM Sans",system-ui,sans-serif)}
.ta-addmenu-h{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted,#7A6E63);padding:4px 8px}
.ta-addmenu-row{display:flex;align-items:center;gap:6px;padding:4px 6px}
.ta-addmenu-row .nm{flex:1;min-width:0;font-size:.86rem;color:var(--deep,#2E2218);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ta-addmenu-row button{flex:0 0 auto;border:1px solid var(--sand,#EDE5D8);background:#fff;font-family:inherit;font-size:.74rem;font-weight:600;color:var(--bark,#5C4A3A);padding:4px 9px;border-radius:6px;cursor:pointer}
.ta-addmenu-row button[data-act="move"]{color:var(--terracotta,#B5735A);border-color:#e2c7ba}
.ta-addmenu-row button:hover{background:var(--cream,#FAF7F2)}
.ta-addmenu-none{font-size:.8rem;color:var(--muted,#7A6E63);padding:4px 8px 2px}
.ta-addmenu-sep{height:1px;background:var(--sand,#EDE5D8);margin:6px 4px}
.ta-addmenu-new{display:flex;align-items:center;gap:6px;width:100%;text-align:left;border:none;background:none;font-family:inherit;font-size:.86rem;font-weight:600;color:var(--sage,#7A8C74);padding:7px 8px;border-radius:7px;cursor:pointer}
.ta-addmenu-new svg{width:14px;height:14px}
.ta-addmenu-new:hover{background:var(--cream,#FAF7F2)}
.ta-pub-title{font-family:var(--display,"Cormorant Garamond",Georgia,serif);font-size:1.35rem;font-weight:700;color:var(--deep,#2E2218);margin:2px 0 8px}
.ta-pub-form{display:flex;flex-direction:column;gap:10px}
.ta-pub-form label{display:block;font-size:.8rem;font-weight:600;color:var(--bark,#5C4A3A)}
.ta-pub-form input{width:100%;font-family:inherit;font-size:.9rem;padding:9px 11px;margin-top:4px;border:1px solid var(--sand,#EDE5D8);border-radius:8px;background:var(--cream,#FAF7F2)}
.ta-pub-form fieldset{border:1px solid var(--sand,#EDE5D8);border-radius:10px;padding:10px 12px;margin:0}
.ta-pub-form legend{font-size:.78rem;font-weight:600;color:var(--bark,#5C4A3A);padding:0 5px}
.ta-pub-radio{display:flex;align-items:center;gap:7px;font-weight:500!important;margin:3px 0}
.ta-pub-radio input{width:auto!important;margin:0!important}
.ta-pub-credit{display:flex;flex-direction:column;gap:7px;margin-top:8px}
.ta-pub-msg{font-size:.82rem;color:var(--sage,#7A8C74);min-height:1em}
.ta-pub-btns{display:flex;gap:8px;flex-wrap:wrap}
.ta-pub-signin .ta-nb-gbtn{display:flex;justify-content:center;min-height:40px;margin-top:8px}
/* signed-in prefill on the suggestion forms */
.ta-prefill{background:#eef3ec!important;color:var(--bark,#5C4A3A)}
.ta-email-edit{display:inline-block;margin-top:4px;border:none;background:none;padding:0;cursor:pointer;
  font-family:var(--ui,"DM Sans",system-ui,sans-serif);font-size:.74rem;color:var(--terracotta,#B5735A);text-decoration:underline}

/* ---------- Read-aloud (TTS) speaker buttons ---------- */
.ta-tts-btn{display:inline-flex;align-items:center;justify-content:center;vertical-align:middle;
  border:1px solid var(--clay,#C9A882);border-radius:8px;background:var(--cream,#FAF7F2);color:var(--terracotta,#B5735A);
  cursor:pointer;padding:0;width:30px;height:30px;margin-left:8px;flex:0 0 auto}
.ta-tts-btn:hover{background:var(--sand,#EDE5D8)}
.ta-tts-btn.active{background:var(--sage,#7A8C74);color:#fff;border-color:var(--sage,#7A8C74)}
.ta-tts-btn svg{width:15px;height:15px;display:block}
.ta-tts-title{width:34px;height:34px}.ta-tts-title svg{width:17px;height:17px}
.ta-tts-h{width:24px;height:24px}.ta-tts-h svg{width:12px;height:12px}

/* ---------- Read-aloud player (fixed bottom-center) ---------- */
.ta-player{position:fixed;left:50%;transform:translateX(-50%);bottom:18px;z-index:140;display:none;align-items:center;gap:6px;
  background:var(--deep,#2E2218);color:#f4ead9;border-radius:30px;padding:7px 10px;box-shadow:0 6px 22px rgba(0,0,0,.3);
  font-family:var(--ui,"DM Sans",system-ui,sans-serif);max-width:min(94vw,470px)}
.ta-player.open{display:flex}
.ta-player .ta-pl-label{font-size:.76rem;padding:0 8px;max-width:170px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.92}
.ta-player .ta-pl-voice{font-family:var(--ui,"DM Sans",system-ui,sans-serif);font-size:.72rem;max-width:128px;color:#f4ead9;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:5px 6px;cursor:pointer;outline:none}
.ta-player .ta-pl-voice:hover{background:rgba(255,255,255,.2)}
.ta-player .ta-pl-voice option{color:#2E2218}
@media(max-width:520px){.ta-player .ta-pl-voice{max-width:92px}}
.ta-player button{width:36px;height:36px;border-radius:50%;border:none;background:rgba(255,255,255,.12);color:#f4ead9;cursor:pointer;
  display:flex;align-items:center;justify-content:center;position:relative;flex:0 0 auto}
.ta-player button:hover{background:rgba(255,255,255,.22)}
.ta-player button.ta-pl-main{background:var(--terracotta,#B5735A);color:#fff;width:42px;height:42px}
.ta-player button.ta-pl-x{background:transparent}
.ta-player svg{width:16px;height:16px;display:block}
.ta-player .ta-pl-secs{position:absolute;bottom:1px;font-size:.46rem;font-weight:700;letter-spacing:.02em}
@media(max-width:520px){.ta-player .ta-pl-label{display:none}}
/* ---------- bookmark control on search-result cards ---------- */
.ta-card-bm{display:inline-flex;align-items:center;gap:3px;border:1px solid var(--sand,#EDE5D8);background:#fff;cursor:pointer;
  color:var(--muted,#7A6E63);font-family:var(--ui,"DM Sans",system-ui,sans-serif);font-size:.72rem;font-weight:600;
  border-radius:999px;padding:2px 8px;line-height:1.3}
.ta-card-bm:hover{color:var(--terracotta,#B5735A);border-color:var(--clay,#C9A882)}
.ta-card-bm.saved{color:#fff;background:var(--sage,#7A8C74);border-color:var(--sage,#7A8C74)}
.ta-card-bm .ta-card-bmn{font-weight:700}

/* ---------- search autocomplete dropdown ---------- */
.ta-ac{position:absolute;z-index:60;left:0;right:0;top:100%;margin-top:6px;background:#fff;border:1px solid var(--sand,#EDE5D8);
  border-radius:12px;box-shadow:0 10px 30px rgba(46,34,24,.16);overflow:hidden;display:none;font-family:var(--ui,"DM Sans",system-ui,sans-serif)}
.ta-ac.open{display:block}
.ta-ac-item{display:flex;align-items:baseline;gap:8px;padding:9px 14px;cursor:pointer;border-bottom:1px solid var(--cream,#FAF7F2)}
.ta-ac-item:last-child{border-bottom:none}
.ta-ac-item.active,.ta-ac-item:hover{background:var(--cream,#FAF7F2)}
.ta-ac-item .ac-t{color:var(--deep,#2E2218);font-weight:600;font-size:.92rem}
.ta-ac-item .ac-d{color:var(--muted,#7A6E63);font-size:.74rem;margin-left:auto;white-space:nowrap}
.ta-ac-item .ac-did{color:var(--muted,#7A6E63);font-size:.78rem;padding:9px 14px}

/* "On this page" TOC: real LEFT SIDEBAR on desktop. The original inline `.toc{flex:0 0 210px;position:
   sticky}` IS the sidebar style — it just never applied because the <nav> lived inside .wrap. wiki-
   enhance.js placeToc() moves #toc to be a flex child of .layout on >980 (and back into the content as
   the accordion on <=980), so the inline CSS produces the sidebar. */
@media(min-width:981px){
  .toc{display:none}            /* hidden until placeToc() moves it out — avoids an overlap flash if the JS is slow/unavailable */
  .layout > .toc{display:block} /* once it's a direct child of .layout, the inline flex:0 0 210px + sticky make it the left sidebar */
}

@media print{.ta-nb-fab,.ta-player,.ta-bm,.ta-tts-btn,.ta-card-bm,.ta-ac{display:none!important}}

/* Article "← Explore … Therapy Aligned™ Clinical Wiki" home pill: on narrow phones the inline article
   <style> sets .wiki-mark{white-space:nowrap;font-size:1.18rem}, so the wordmark can't wrap and the pill
   becomes wider than the text column — forcing the layout viewport to expand and throwing off the page.
   wiki-enhance.css loads BEFORE that inline block, so !important is required to win the cascade. Fix:
   scale the wordmark with the viewport (clamp) AND let it wrap, and cap the pill to its container. */
@media(max-width:600px){
  .wiki-home-pill,.ta-brand .wiki-home-link{max-width:100%;flex-wrap:wrap}
  .wiki-home-pill .wiki-mark,.ta-brand .wiki-home-link .wiki-mark{
    font-size:clamp(.72rem,3.1vw,1.18rem)!important;white-space:normal!important;min-width:0;word-break:break-word}
  .wiki-home-pill .wiki-mini-mark{width:24px!important;height:24px!important}
  .wiki-home-pill{padding:7px 12px!important}
  /* Same "wider than the column throws off the page" class of bug, for article content: a wide table
     scrolls inside its own box instead of expanding the layout; figures/long tokens are capped/broken. */
  .wrap table{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .wrap img,.wrap svg{max-width:100%;height:auto}
  .wrap p,.wrap li,.wrap td,.wrap th,.wrap blockquote{overflow-wrap:break-word}
}

/* "Featured on The Bookshelf" — public notebooks that include this article, injected below the figure by
   wiki-enhance.js. A compact, scrollable mini-shelf of spines (same look as the Public Library Bookshelf). */
.ta-feat{margin:1.6em 0 0;font-family:var(--ui,"DM Sans",system-ui,sans-serif)}
.ta-feat-h{font-family:var(--display,"Cormorant Garamond",Georgia,serif);font-size:1.5rem;font-weight:600;color:var(--deep,#2E2218);margin:0 0 2px}
.ta-feat-sub{font-size:.86rem;color:var(--muted,#7A6E63);margin:0 0 10px;line-height:1.5}
.ta-feat-sub a{color:var(--link,#9C5C45);font-weight:600;text-decoration:none;border-bottom:1px solid rgba(156,92,69,.4)}
.ta-feat-sub a:hover{color:var(--terracotta,#B5735A)}
.ta-feat-window{max-height:280px;overflow-y:auto;overscroll-behavior:contain;border:1px solid var(--sand,#EDE5D8);border-radius:12px;background:var(--cream,#FAF7F2);padding:12px 12px 2px}
.ta-feat-row{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap}
.ta-feat-board{height:14px;background:#5C4A3A;border-top:2px solid #6b5544;border-radius:0 0 4px 4px;margin-top:0}
.ta-feat-spine{flex:0 0 auto;width:54px;overflow:hidden;border-radius:3px 3px 2px 2px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:10px 4px;text-decoration:none;transition:transform .14s ease}
.ta-feat-spine:hover{transform:translateY(-7px);text-decoration:none}
.ta-feat-spine:focus-visible{outline:2px solid var(--deep,#2E2218);outline-offset:2px}
.ta-feat-dot{width:7px;height:7px;border-radius:50%;background:rgba(250,247,242,.42);flex:0 0 auto}
.ta-feat-ttl{writing-mode:vertical-rl;text-orientation:mixed;font-size:12px;font-weight:600;line-height:1.2;overflow:hidden;text-align:center}
.ta-feat-up{font-size:11px;font-weight:600;white-space:nowrap}
@media(prefers-reduced-motion:reduce){.ta-feat-spine{transition:none}.ta-feat-spine:hover{transform:none}}
