/* ========================================================================
   مقامات الحريري - shared/base.css
   Palette: manuscript indigo + vermillion on warm cream
   ======================================================================== */

:root{
  --bg:#f5f1e8;--bg2:#eee9dc;--bg3:#e6e0d0;
  --ink:#1a1a2e;--ink2:#3a3850;--ink3:#605c78;
  --muted:#6b6885;--muted2:#9591a8;
  --gold:#b8312f;      /* vermillion accent (named --gold for consistency with /art) */
  --gold2:#8e2524;
  --indigo:#2d3a6e;    /* secondary accent */
  --indigo2:#1f2a56;
  --line:rgba(26,26,46,0.08);
  --line2:rgba(26,26,46,0.04);
}

*{box-sizing:border-box;margin:0;padding:0}
::selection{background:rgba(184,49,47,0.18);color:var(--ink)}
:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:4px}
html{scroll-behavior:smooth}
@media(min-width:960px){html{zoom:1.3}}

body{
  background:var(--bg);
  color:var(--ink);
  font-family:'Amiri',serif;
  font-size:21px;
  line-height:2.7;
  direction:rtl;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  font-feature-settings:'liga' 1,'calt' 1;
  opacity:1;
  transition:opacity 0.25s ease;
}
body.fade-out{opacity:0}

a{color:inherit;text-decoration:none;border-bottom:1px solid transparent;transition:border-color 0.2s,color 0.2s}
a:hover{color:var(--gold);border-bottom-color:var(--gold)}

/* ------------------------------------------------------------------------
   Typography
   ------------------------------------------------------------------------ */

h1,h2,h3{font-family:var(--heading-family);font-weight:700;color:var(--ink);line-height:1.45}
h1{font-size:clamp(32px,6vw,48px);letter-spacing:-0.3px}
h2{font-size:clamp(22px,3.8vw,32px);margin-bottom:24px}
h3{font-size:clamp(17px,2.2vw,20px);color:var(--indigo);margin:36px 0 14px;font-family:'IBM Plex Sans Arabic',sans-serif}

p{margin-bottom:20px;color:var(--ink2)}
p strong{color:var(--ink);font-weight:700}

.drop-cap::first-letter{
  float:right;
  font-family:'Aref Ruqaa',serif;
  font-size:86px;
  line-height:0.85;
  padding:10px 0 0 16px;
  color:var(--gold);
  font-weight:700;
}

/* ------------------------------------------------------------------------
   Layout primitives
   ------------------------------------------------------------------------ */

.container{max-width:var(--reading-width, 1200px);margin:0 auto;padding:0 56px}
.section{margin-bottom:56px}
.section-number{
  font-family:'IBM Plex Sans Arabic',sans-serif;
  font-size:11px;font-weight:700;letter-spacing:3px;
  color:var(--gold);
  display:inline-block;
  padding:3px 12px;
  background:rgba(184,49,47,0.06);
  border-radius:4px;
  border:1px solid rgba(184,49,47,0.12);
  margin-bottom:12px;
}

.sep{border:none;height:3px;margin:56px auto;max-width:120px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:0.3;border-radius:2px}
.sep-ornament{text-align:center;margin:40px 0;color:var(--gold);opacity:.4;font-size:18px;letter-spacing:0.4em}

/* ------------------------------------------------------------------------
   Maqama components
   ------------------------------------------------------------------------ */

@font-face{
  font-family:'Thmanyah Display';
  src:url('fonts/thmanyah/thmanyahserifdisplay-Regular.woff2') format('woff2');
  font-weight:400;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'Thmanyah Display';
  src:url('fonts/thmanyah/thmanyahserifdisplay-Medium.woff2') format('woff2');
  font-weight:500;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'Thmanyah Display';
  src:url('fonts/thmanyah/thmanyahserifdisplay-Bold.woff2') format('woff2');
  font-weight:700;font-style:normal;font-display:swap;
}

:root{
  --reading-font: 28px;
  --reading-line: 4.6;
  --reading-word: 48px;
  --reading-width: 1200px;
  --heading-family: 'Aref Ruqaa', serif;
}
.narration{color:var(--ink2);font-size:var(--reading-font);line-height:var(--reading-line);word-spacing:var(--reading-word)}
.narration p{margin-bottom:84px}

.speaker{
  font-style:italic;
  color:var(--indigo);
  font-weight:700;
  padding-left:4px;
}

.word{
  cursor:pointer;
  transition:color 0.15s,background 0.2s,box-shadow 0.2s;
  border-radius:4px;
  padding:0 3px;
}
.word:hover{color:var(--gold);background:rgba(184,49,47,0.06)}
.word.active{
  color:var(--ink);
  background:rgba(184,49,47,0.18);
  box-shadow:0 0 0 2px rgba(184,49,47,0.18);
}
body.dark .word.active{
  background:rgba(226,106,102,0.22);
  box-shadow:0 0 0 2px rgba(226,106,102,0.22);
}
.word.search-flash{
  animation:search-flash 2.6s ease-out;
}

.plot-summary{
  max-width:640px;margin:24px auto 0;padding:0 32px;
  font-family:'IBM Plex Sans Arabic',sans-serif;
}
.plot-summary-toggle{
  display:inline-flex;align-items:center;gap:6px;
  font-family:'IBM Plex Sans Arabic',sans-serif;font-size:12px;line-height:1;
  border:1px solid var(--line);border-radius:16px;
  background:transparent;color:var(--muted);
  padding:7px 14px;cursor:pointer;transition:all 0.2s;
}
.plot-summary-toggle:hover{color:var(--gold);border-color:var(--gold)}
.plot-summary-toggle[aria-expanded="true"]{color:var(--gold);border-color:var(--gold)}
.plot-summary-chev{font-size:10px;transition:transform 0.2s}
.plot-summary-toggle[aria-expanded="true"] .plot-summary-chev{transform:rotate(180deg)}
.plot-summary-body{
  margin-top:14px;padding:18px 22px;
  border:1px solid var(--line);border-right:3px solid var(--gold);
  border-radius:10px;
  background:linear-gradient(90deg, rgba(184,49,47,0.04), transparent);
}
.plot-summary-body[hidden]{display:none}
.plot-summary-body p{
  margin:0;
  font-family:'Amiri',serif;font-size:17px;line-height:1.85;color:var(--ink2);
}
@media(max-width:600px){
  .plot-summary{padding:0 16px;margin-top:14px}
  .plot-summary-body{padding:14px 16px}
  .plot-summary-body p{font-size:15px;line-height:1.8}
}
@keyframes search-flash{
  0%{background:rgba(212,160,23,0.55);box-shadow:0 0 0 4px rgba(212,160,23,0.4)}
  100%{background:transparent;box-shadow:none}
}

.verse-box{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(0, 1fr);
  column-gap:2em;
  align-items:baseline;
  width:760px;
  max-width:100%;
  margin:18px auto;
  font-family:'Amiri',serif;
  font-size:22px;
  font-weight:400;
  color:var(--ink);
  line-height:2.0;
  word-spacing:5px;
}
.verse-box .verse{
  margin:0;padding:0;
  min-width:0;
  word-spacing:5px;
  white-space:nowrap;
  overflow:visible;
}
/* glosses inside verses must not inflate hemistich width with their inline
   margin - the popup is absolutely positioned so this margin only adds
   horizontal padding around the word itself. */
.verse-box .glossed{margin:0 2px}
.verse-box .verse:first-child{text-align:right}
.verse-box .verse:last-child{text-align:left}
/* extra breathing space at the start/end of a poetry block */
.verse-box:first-of-type{margin-top:36px}
.verse-box:last-of-type{margin-bottom:36px}
@media(max-width:900px){
  .verse-box{font-size:20px;column-gap:1.4em;width:min(620px, 100%)}
}
@media(max-width:600px){
  .verse-box{grid-template-columns:1fr;row-gap:2px;font-size:19px;line-height:1.85;margin:14px auto}
  .verse-box .verse{white-space:normal}
  .verse-box .verse:first-child,
  .verse-box .verse:last-child{text-align:center}
}

.saj{
  background:linear-gradient(90deg,transparent,rgba(45,58,110,0.04),transparent);
  border-radius:4px;
  padding:2px 6px;
}

.saj-sep{
  color:var(--gold);
  opacity:0.45;
  margin:0 0.35em;
  font-size:0.7em;
  font-family:'Amiri',serif;
  display:inline-block;
  vertical-align:0.15em;
  user-select:none;
  letter-spacing:0;
}

.illustration{
  margin:40px 0;
  text-align:center;
}
.illustration img,.illustration .placeholder{
  display:block;
  margin:0 auto;
  max-width:100%;
  border-radius:10px;
  border:1px solid var(--line);
  box-shadow:0 4px 20px rgba(26,26,46,0.08);
}
.illustration .placeholder{
  background:linear-gradient(135deg,var(--bg2),var(--bg3));
  min-height:260px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--muted);
  font-family:'IBM Plex Sans Arabic',sans-serif;
  font-size:12px;
  letter-spacing:2px;
}
.illustration figcaption{
  margin-top:12px;
  font-family:'IBM Plex Sans Arabic',sans-serif;
  font-size:12px;
  color:var(--muted);
  font-style:italic;
}

/* ------------------------------------------------------------------------
   Pullquote, callouts, note-aside (kept from /art)
   ------------------------------------------------------------------------ */

.pullquote{margin:36px 0;padding:26px 32px;border-right:4px solid var(--gold);background:var(--bg2);font-family:'Amiri',serif;font-size:20px;font-style:italic;color:var(--ink);line-height:1.95;border-radius:0 12px 12px 0;position:relative}
.pullquote::before{content:'\201C';position:absolute;top:-12px;right:18px;font-size:80px;color:var(--gold);opacity:.12;font-family:serif;line-height:1}
.pullquote cite{display:block;margin-top:8px;font-size:13px;font-style:normal;font-family:'IBM Plex Sans Arabic',sans-serif;color:var(--muted)}

.callout{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:22px 26px;margin:28px 0}
.callout.indigo{border-color:rgba(45,58,110,0.22);background:linear-gradient(135deg,var(--bg2),#ebeaf5)}
.callout.vermillion{border-color:rgba(184,49,47,0.22);background:linear-gradient(135deg,var(--bg2),#f8e4e2)}
.callout-title{font-family:'IBM Plex Sans Arabic',sans-serif;font-size:11px;font-weight:700;letter-spacing:2px;color:var(--indigo);margin-bottom:10px}
.callout.vermillion .callout-title{color:var(--gold)}
.callout p{margin-bottom:8px;font-size:17px}
.callout p:last-child{margin-bottom:0}

.note-aside{background:var(--bg2);border:1px solid rgba(45,58,110,0.18);border-radius:10px;padding:18px 22px;margin:26px 0;font-size:16px;color:var(--ink2);line-height:1.85}
.note-aside .note-label{font-family:'IBM Plex Sans Arabic',sans-serif;font-size:10px;font-weight:700;letter-spacing:2px;color:var(--indigo);margin-bottom:6px}

/* ------------------------------------------------------------------------
   Person and reference popups (popup DOM is created by base.js)
   ------------------------------------------------------------------------ */

.person{display:inline;cursor:pointer;border-bottom:1px dotted var(--indigo)}
.person:hover{border-bottom-color:var(--gold);color:var(--gold)}

.ref-mark{
  display:inline-block;width:18px;height:18px;line-height:18px;text-align:center;
  font-family:'IBM Plex Sans Arabic',sans-serif;font-size:10px;font-weight:700;
  color:var(--muted);background:var(--bg3);border-radius:50%;
  vertical-align:super;margin:0 2px;cursor:pointer;opacity:0.7;transition:all 0.2s;
}
.ref-mark:hover{opacity:1;color:var(--gold);background:rgba(184,49,47,0.1)}

/* Inline above-the-word gloss (classical manuscript style).
   Wrap a word with <span class="glossed"><span class="word">...</span><span class="gloss">...</span></span>
   and the gloss is rendered in parens, muted, floating directly above. */
.glossed{
  position:relative;
  display:inline-block;
}
.glossed{
  position:relative;
  display:inline-block;
  line-height:1;
  vertical-align:baseline;
  margin:0 14px;
}
.glossed > .gloss{
  position:absolute;
  bottom:100%;
  right:0;
  font-family:'IBM Plex Sans Arabic',sans-serif;
  font-size:12.5px;
  line-height:1.35;
  color:var(--gold);
  opacity:0.85;
  width:max-content;
  max-width:160px;
  max-height:calc(1.35em * 2);
  overflow:hidden;
  text-align:right;
  margin-bottom:14px;
  pointer-events:none;
  user-select:none;
  letter-spacing:0;
  word-spacing:normal;
  font-weight:500;
  z-index:2;
  transition:opacity 0.2s,max-width 0.2s;
}
.glossed:hover > .gloss{
  opacity:1;z-index:5;
  max-width:320px;max-height:none;
  background:var(--bg);
  padding:6px 10px;border-radius:8px;
  box-shadow:0 3px 14px rgba(26,26,46,0.12);
  pointer-events:auto;
}
.glossed > .gloss::before{content:'('}
.glossed > .gloss::after{content:')'}
.glossed:hover > .gloss{opacity:1}
body.dark .glossed > .gloss{color:var(--gold);opacity:0.7}
body.gloss-off .glossed{margin:0}
body.gloss-off .glossed > .gloss{display:none}

/* Inline-beside-word gloss display (uses normal flow, not absolute) */
body.gloss-inline .glossed{display:inline;margin:0 2px}
body.gloss-inline .glossed > .gloss{
  position:static;display:inline;
  margin:0 2px 0 0;font-size:13px;
  max-width:none;max-height:none;
  opacity:0.7;line-height:inherit;
  background:none;box-shadow:none;padding:0;
  pointer-events:none;
}
body.gloss-inline .glossed:hover > .gloss{
  background:none;box-shadow:none;padding:0;max-width:none;
}
body.gloss-inline .verse-box .glossed{margin:0 2px}

.mq-popup{
  position:absolute;z-index:200;
  background:var(--bg);border:1px solid var(--line);border-radius:10px;
  padding:14px 18px;max-width:280px;
  box-shadow:0 8px 24px rgba(26,26,46,0.12);
  font-family:'IBM Plex Sans Arabic',sans-serif;font-size:13.5px;line-height:1.7;
  color:var(--ink2);
  opacity:0;transform:translateY(4px);
  transition:opacity 0.18s,transform 0.18s;
  pointer-events:none;
}
.mq-popup.open{opacity:1;transform:translateY(0);pointer-events:auto}
.mq-popup-name{font-family:'Aref Ruqaa',serif;font-size:16px;color:var(--ink);margin-bottom:4px}

/* ------------------------------------------------------------------------
   Floating audio button (stub)
   ------------------------------------------------------------------------ */

.audio-fab{
  position:fixed;bottom:24px;left:24px;z-index:50;
  width:52px;height:52px;border-radius:50%;border:1px solid var(--line);
  background:var(--bg);color:var(--muted);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 16px rgba(26,26,46,0.08);
  transition:all 0.2s;
}
.audio-fab:not(:disabled):hover{color:var(--gold);border-color:var(--gold);transform:translateY(-2px)}
.audio-fab:disabled{cursor:not-allowed;opacity:0.4}
.audio-fab svg{width:20px;height:20px}
.audio-fab.playing{color:var(--gold);border-color:var(--gold);background:rgba(184,49,47,0.08)}
.audio-fab.playing svg{display:none}
.audio-fab.playing::before{
  content:'';
  width:14px;height:14px;
  background:var(--gold);
  border-radius:2px;
  display:block;
}

.audio-scrubber{
  position:fixed;bottom:36px;left:88px;z-index:49;
  display:flex;align-items:center;gap:10px;
  padding:8px 14px;
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow:0 4px 16px rgba(26,26,46,0.08);
  font-family:'IBM Plex Sans Arabic',sans-serif;
  font-size:11px;color:var(--muted);
  max-width:calc(100vw - 110px);
}
.audio-scrubber[hidden]{display:none}
.audio-time{min-width:36px;text-align:center;font-variant-numeric:tabular-nums;letter-spacing:-0.2px}
.audio-track{
  position:relative;width:240px;height:18px;cursor:pointer;
  display:flex;align-items:center;
}
.audio-track::before{
  content:'';position:absolute;left:0;right:0;top:50%;
  height:3px;margin-top:-1.5px;background:var(--line);border-radius:2px;
}
.audio-fill{
  position:absolute;right:0;top:50%;height:3px;margin-top:-1.5px;
  background:var(--gold);border-radius:2px;width:0;
  transition:width 0.08s linear;
}
.audio-thumb{
  position:absolute;top:50%;width:11px;height:11px;border-radius:50%;
  background:var(--gold);transform:translate(50%,-50%);right:0;
  opacity:0;transition:opacity 0.15s,transform 0.1s;
}
.audio-track:hover .audio-thumb,
.audio-track.dragging .audio-thumb,
.audio-track:focus .audio-thumb{opacity:1}
.audio-track.dragging .audio-fill{transition:none}
.audio-speed{
  font-family:'IBM Plex Sans Arabic',sans-serif;
  font-size:11px;line-height:1;
  border:1px solid var(--line);border-radius:12px;
  background:transparent;color:var(--muted);
  padding:5px 9px;min-width:36px;
  cursor:pointer;white-space:nowrap;font-variant-numeric:tabular-nums;
  transition:all 0.15s;
}
.audio-speed:hover{color:var(--gold);border-color:var(--gold)}
.audio-speed.active{color:var(--gold);border-color:var(--gold);background:rgba(184,49,47,0.06)}
@media(max-width:600px){
  .audio-scrubber{left:72px;bottom:18px;padding:6px 12px;gap:8px}
  .audio-track{width:140px}
  .audio-time{min-width:30px}
  .audio-speed{padding:4px 7px;min-width:32px;font-size:10px}
}

/* ------------------------------------------------------------------------
   Dark-mode toggle button
   ------------------------------------------------------------------------ */

.theme-toggle{
  width:34px;height:34px;border:1px solid var(--line);border-radius:50%;
  background:transparent;cursor:pointer;color:var(--muted);
  display:flex;align-items:center;justify-content:center;
  transition:all 0.2s;
}
.theme-toggle:hover{color:var(--gold);border-color:var(--gold)}
.theme-toggle svg{width:16px;height:16px}

/* ------------------------------------------------------------------------
   Tashkeel toggle button
   ------------------------------------------------------------------------ */

.tashkeel-toggle{
  font-family:'Amiri',serif;
  font-size:15px;line-height:1;
  border:1px solid var(--line);border-radius:16px;
  background:transparent;color:var(--muted);
  padding:5px 14px 7px;
  cursor:pointer;white-space:nowrap;
  transition:all 0.2s;
}
.tashkeel-toggle:hover{color:var(--gold);border-color:var(--gold)}
body.tashkeel-minimal .tashkeel-toggle{color:var(--indigo);border-color:rgba(45,58,110,0.4)}
body.tashkeel-off .tashkeel-toggle{color:var(--muted2);border-style:dashed}
body.tashkeel-minimal .tashkeel-toggle:hover,
body.tashkeel-off .tashkeel-toggle:hover{color:var(--gold);border-color:var(--gold);border-style:solid}

.gloss-toggle{
  font-family:'IBM Plex Sans Arabic',sans-serif;
  font-size:12px;line-height:1;
  border:1px solid var(--line);border-radius:16px;
  background:transparent;color:var(--muted);
  padding:6px 12px;
  cursor:pointer;white-space:nowrap;
  transition:all 0.2s;
}
.gloss-toggle:hover{color:var(--gold);border-color:var(--gold)}
body.gloss-off .gloss-toggle{color:var(--muted2);border-style:dashed}
body.gloss-off .gloss-toggle:hover{color:var(--gold);border-color:var(--gold);border-style:solid}

.reading-fab{
  position:fixed;bottom:24px;right:24px;z-index:50;
  width:52px;height:52px;padding:0;
  border-radius:50%;border:1px solid var(--line);
  box-sizing:border-box;
  background:var(--bg);color:var(--muted);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 16px rgba(26,26,46,0.08);
  font-family:'IBM Plex Sans Arabic',sans-serif;
  font-size:15px;font-weight:600;
  transition:all 0.2s;
}
.reading-fab:hover{color:var(--gold);border-color:var(--gold);transform:translateY(-2px)}
body.reading-settings-open .reading-fab{color:var(--gold);border-color:var(--gold);background:rgba(184,49,47,0.06)}
.rs-aa{letter-spacing:-0.5px;font-family:'IBM Plex Sans Arabic',sans-serif;font-weight:600}
@media(max-width:600px){
  .reading-fab{bottom:16px;right:16px;width:44px;height:44px;font-size:14px}
}

.reading-settings{
  font-family:'IBM Plex Sans Arabic',sans-serif;
}
.reading-fab-panel{
  position:fixed;bottom:88px;right:24px;z-index:51;
  width:340px;max-width:calc(100vw - 48px);
  padding:16px 18px;
  border:1px solid var(--line);border-radius:14px;
  background:var(--bg);
  box-shadow:0 10px 32px rgba(26,26,46,0.14);
}
@media(max-width:600px){
  .reading-fab-panel{bottom:72px;right:16px;width:calc(100vw - 32px);padding:14px 16px}
}
.reading-settings[hidden]{display:none}
.rs-row{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;gap:12px;
  padding:8px 0;
  border-bottom:1px solid var(--line);
}
.rs-row:last-of-type{border-bottom:none}
.rs-label{font-size:12px;color:var(--muted);min-width:120px}
.rs-value{
  font-size:11px;color:var(--muted2);min-width:42px;text-align:left;
  font-variant-numeric:tabular-nums;
}
.rs-slider{
  width:100%;accent-color:var(--gold);
  cursor:pointer;
}
.rs-seg{display:flex;gap:4px}
.rs-seg button{
  font-family:'IBM Plex Sans Arabic',sans-serif;font-size:11px;
  border:1px solid var(--line);border-radius:8px;
  background:transparent;color:var(--muted);
  padding:5px 10px;cursor:pointer;
  transition:all 0.15s;
}
.rs-seg button:hover{color:var(--gold);border-color:var(--gold)}
.rs-seg button.active{color:var(--gold);border-color:var(--gold);background:rgba(184,49,47,0.06)}
.rs-reset{
  display:block;margin:14px auto 0;
  font-family:'IBM Plex Sans Arabic',sans-serif;font-size:11px;
  border:1px solid var(--line);border-radius:8px;
  background:transparent;color:var(--muted);
  padding:6px 14px;cursor:pointer;
}
.rs-reset:hover{color:var(--gold);border-color:var(--gold)}
@media(max-width:600px){
  .reading-settings{margin:10px 16px 0;padding:14px 16px}
  .rs-row{grid-template-columns:auto 1fr;gap:8px}
  .rs-value{display:none}
  .rs-row:has(.rs-seg){grid-template-columns:auto 1fr}
}

.page-search-toggle{
  font-family:'IBM Plex Sans Arabic',sans-serif;
  font-size:12px;line-height:1;
  border:1px solid var(--line);border-radius:16px;
  background:transparent;color:var(--muted);
  padding:6px 12px;
  cursor:pointer;white-space:nowrap;
  transition:all 0.2s;
}
.page-search-toggle:hover{color:var(--gold);border-color:var(--gold)}
body.page-search-open .page-search-toggle{color:var(--gold);border-color:var(--gold)}

.page-search-bar{
  max-width:640px;margin:14px auto 0;padding:0 32px;
  display:flex;align-items:center;gap:8px;
}
.page-search-bar[hidden]{display:none}
.page-search-input{
  flex:1;padding:9px 14px;
  border:1px solid var(--line);border-radius:10px;
  font-family:'Amiri',serif;font-size:16px;
  background:var(--bg2);color:var(--ink);outline:none;
  transition:border-color 0.15s,box-shadow 0.15s;
}
.page-search-input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(184,49,47,0.08)}
.page-search-count{
  font-family:'IBM Plex Sans Arabic',sans-serif;font-size:12px;
  color:var(--muted);min-width:48px;text-align:center;
}
.page-search-step,.page-search-close{
  width:32px;height:32px;border:1px solid var(--line);border-radius:8px;
  background:transparent;color:var(--muted);cursor:pointer;font-size:14px;
  transition:all 0.15s;display:flex;align-items:center;justify-content:center;
}
.page-search-step:hover,.page-search-close:hover{color:var(--gold);border-color:var(--gold)}
.page-search-step:disabled{opacity:0.35;cursor:default}
.page-search-step:disabled:hover{color:var(--muted);border-color:var(--line)}
@media(max-width:600px){
  .page-search-bar{padding:0 16px;gap:6px}
  .page-search-count{min-width:40px;font-size:11px}
}

.word.page-search-hit{background:rgba(212,160,23,0.22);border-radius:3px}
.word.page-search-hit.page-search-current{
  background:rgba(184,49,47,0.32);
  box-shadow:0 0 0 2px rgba(184,49,47,0.4);
}
body.dark .word.page-search-hit{background:rgba(212,160,23,0.28)}
body.dark .word.page-search-hit.page-search-current{
  background:rgba(226,106,102,0.4);
  box-shadow:0 0 0 2px rgba(226,106,102,0.5);
}

/* ------------------------------------------------------------------------
   Dark mode
   ------------------------------------------------------------------------ */

body.dark{
  --bg:#15131a;--bg2:#1e1c26;--bg3:#2a2834;
  --ink:#ece8dc;--ink2:#c8c3b4;--ink3:#8c8698;
  --muted:#8a85a0;--muted2:#5c586e;
  --gold:#e26a66;--gold2:#ce4e4a;
  --indigo:#8894c8;--indigo2:#6b7ab5;
  --line:rgba(236,232,220,0.1);--line2:rgba(236,232,220,0.05);
}
body.dark .illustration .placeholder{background:linear-gradient(135deg,var(--bg2),var(--bg3))}
body.dark .callout.indigo{background:linear-gradient(135deg,var(--bg2),#1f203a)}
body.dark .callout.vermillion{background:linear-gradient(135deg,var(--bg2),#2a1f21)}

/* ------------------------------------------------------------------------
   Responsive
   ------------------------------------------------------------------------ */

@media(max-width:1200px){
  .container{padding:0 32px}
}
@media(max-width:960px){
  .container{padding:0 24px}
  .narration{font-size:23px;line-height:3.6;word-spacing:22px}
  .narration p{margin-bottom:48px}
  .drop-cap::first-letter{font-size:72px}
}
@media(max-width:720px){
  .container{padding:0 16px}
  body{font-size:18px;line-height:2.2}
  .narration{font-size:20px;line-height:2.6;word-spacing:8px}
  .narration p{margin-bottom:24px}
  .drop-cap::first-letter{font-size:48px;padding:4px 0 0 10px}
  h1{font-size:24px}
  h2{font-size:19px}
  .illustration{margin:24px 0}
  .audio-fab{bottom:16px;left:16px;width:44px;height:44px}
  /* Glosses: absolute positioning breaks at narrow widths. Render inline. */
  .glossed{display:inline;margin:0}
  .glossed > .gloss{
    position:static;display:inline;
    margin:0 2px 0 0;
    font-size:10px;max-width:none;max-height:none;
    opacity:0.7;
  }
  .glossed:hover > .gloss{background:transparent;box-shadow:none;padding:0}
}
