*{box-sizing:border-box;margin:0;padding:0}
:root{
  color-scheme:dark;
  --bg:#05070c;
  --panel:#0b1019;
  --panel-2:#101723;
  --line:rgba(226,238,255,.105);
  --line-strong:rgba(110,195,255,.34);
  --text:#eaf2fb;
  --muted:rgba(234,242,251,.62);
  --faint:rgba(234,242,251,.4);
  --blue:#78c8ff;
  --gold:#fdcb6e;
  --green:#7ee0a1;
  --red:#ff6d8b;
}
body{height:100vh;overflow:hidden;background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}
button,input,select{font:inherit}
button{touch-action:manipulation}
a{color:inherit}
.app{height:100vh;display:grid;grid-template-columns:minmax(340px,27vw) minmax(520px,1fr) minmax(390px,30vw);grid-template-rows:64px minmax(0,1fr);background:linear-gradient(180deg,#080c14 0%,#05070c 52%,#03050a 100%)}
.top{grid-column:1/4;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:0 18px;border-bottom:1px solid var(--line);background:rgba(5,7,12,.94);backdrop-filter:blur(18px);min-width:0}
.brand{display:flex;align-items:baseline;gap:12px;min-width:0}
.brand b{font-family:Orbitron,Inter,sans-serif;font-size:17px;letter-spacing:2px;text-transform:uppercase;color:var(--blue);white-space:nowrap}
.brand span{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.top-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end;min-width:0}
.select,.search{height:36px;border:1px solid var(--line);background:rgba(255,255,255,.047);color:var(--text);border-radius:7px;padding:0 10px;outline:none}
.select{min-width:205px}
.search{width:100%;padding-right:38px;font-size:16px;background:#141b27;border-color:rgba(120,200,255,.22)}
.search:focus{border-color:var(--line-strong);box-shadow:0 0 0 3px rgba(120,200,255,.1)}
.btn,.icon-btn{height:34px;border:1px solid var(--line);background:rgba(255,255,255,.045);color:#bed0df;border-radius:7px;padding:0 10px;cursor:pointer;font-size:11px;font-weight:800}
.icon-btn{width:34px;padding:0;display:inline-grid;place-items:center;font-size:18px;line-height:1}
.btn:hover,.btn.on,.icon-btn:hover{border-color:var(--line-strong);background:rgba(120,200,255,.12);color:var(--blue)}
.side,.study{min-height:0;overflow:hidden;background:rgba(255,255,255,.018)}
.side{border-right:1px solid var(--line)}
.study{border-left:1px solid var(--line)}
.panel{padding:14px}
.search-panel{height:100%;display:flex;flex-direction:column;gap:12px;min-height:0}
.search-wrap{position:relative;display:flex;align-items:center}
.search-wrap .icon-btn{position:absolute;right:4px;top:1px;border-color:transparent;background:transparent;color:rgba(120,200,255,.72)}
.label{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:8px;letter-spacing:1.4px;text-transform:uppercase;color:rgba(120,200,255,.8);margin:2px 0 0}
.stats{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.stat{border:1px solid var(--line);background:rgba(0,0,0,.2);border-radius:8px;padding:10px}
.stat b{display:block;font-family:Orbitron,Inter,sans-serif;font-size:18px;color:#fff;line-height:1}
.stat span{display:block;margin-top:5px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:7px;text-transform:uppercase;color:var(--faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.book-list{display:flex;flex-direction:column;gap:4px;min-height:0;overflow:auto;flex:1;padding-right:2px}
.book-group{margin-top:8px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:8px;text-transform:uppercase;color:rgba(253,203,110,.74);letter-spacing:1px}
.book{display:flex;align-items:center;justify-content:space-between;gap:8px;border:1px solid transparent;background:transparent;color:#c7d6e5;border-radius:7px;padding:7px 8px;cursor:pointer;text-align:left;font-size:11px;width:100%;min-height:34px}
.book:hover,.book.on{background:rgba(120,200,255,.09);border-color:rgba(120,200,255,.2);color:#fff}
.book small{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:8px;color:var(--faint);white-space:nowrap}
.search-mode{display:flex;gap:4px;margin-top:-4px;margin-bottom:4px}
.mode-btn{height:24px;padding:0 10px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:#8da6c0;font-family:ui-monospace,monospace;font-size:9px;letter-spacing:1.1px;text-transform:uppercase;border-radius:5px;cursor:pointer;flex:1}
.mode-btn.on{background:rgba(126,224,161,.12);border-color:rgba(126,224,161,.45);color:#7ee0a1}
.mode-btn:hover{border-color:rgba(120,200,255,.4)}
.semantic-hit{padding:8px 10px;border:1px solid var(--line);border-left:3px solid #7ee0a1;background:rgba(126,224,161,.04);border-radius:6px;cursor:pointer;text-align:left;width:100%}
.semantic-hit:hover{background:rgba(126,224,161,.10)}
.semantic-hit .sh-head{display:flex;justify-content:space-between;font-size:10px;color:#fff;margin-bottom:3px}
.semantic-hit .sh-score{font-family:Orbitron,ui-monospace,monospace;color:#7ee0a1;font-size:11px}
.semantic-hit .sh-ref{font-family:ui-monospace,monospace;color:var(--gold);font-size:8.5px;letter-spacing:.8px;text-transform:uppercase}
.semantic-hit .sh-corpus{display:inline-block;padding:1px 5px;border-radius:3px;font-family:ui-monospace,monospace;font-size:8px;letter-spacing:.8px;text-transform:uppercase;margin-left:4px}
.semantic-hit .sh-corpus.arc{background:rgba(120,200,255,.14);color:#78c8ff}
.semantic-hit .sh-corpus.lxx{background:rgba(253,203,110,.14);color:var(--gold)}
.semantic-hit .sh-corpus.tr{background:rgba(126,224,161,.14);color:#7ee0a1}
.semantic-hit .sh-corpus.pseudepigrapha{background:rgba(189,123,255,.14);color:#bd7bff}
.semantic-hit .sh-corpus.ane{background:rgba(255,109,139,.13);color:#ff6d8b}
.semantic-hit .sh-preview{font-size:10px;color:rgba(232,241,248,.78);line-height:1.4;margin-top:2px}
.results{display:none;min-height:0;overflow:auto;border:1px solid rgba(120,200,255,.16);background:rgba(7,14,24,.72);border-radius:9px;padding:8px;gap:6px;flex-direction:column}
.results.show{display:flex;flex:1.5;min-height:280px}
.side.searching .book-list{flex:.65}
.reader{min-height:0;overflow:auto;padding:24px 34px}
.reader-head{max-width:980px;margin:0 auto 18px}
.crumb{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:9px;text-transform:uppercase;letter-spacing:1.2px;color:var(--blue);margin-bottom:8px}
h1{font-family:Orbitron,Inter,sans-serif;font-size:34px;line-height:1.1;letter-spacing:.2px;margin-bottom:10px}
.reader-sub{font-size:13px;line-height:1.55;color:var(--muted)}
.chapter-bar{display:flex;gap:5px;flex-wrap:wrap;margin:18px auto;max-width:980px}
.chapter{min-width:32px;height:30px;border:1px solid var(--line);background:rgba(255,255,255,.035);border-radius:6px;color:#b7c9d8;font-size:11px;cursor:pointer}
.chapter:hover,.chapter.on{border-color:rgba(253,203,110,.48);background:rgba(253,203,110,.12);color:#fff}
.verses{max-width:980px;margin:0 auto 70px;display:flex;flex-direction:column;gap:10px}
.verse{display:grid;grid-template-columns:48px minmax(0,1fr);gap:13px;border:1px solid var(--line);background:rgba(255,255,255,.026);border-radius:8px;padding:13px 15px}
.reader.rtl .verse{direction:rtl;text-align:right;grid-template-columns:minmax(0,1fr) 48px}
.reader.rtl .verse-num{order:2}
.verse-num{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;color:var(--gold);display:flex;flex-direction:column;align-items:flex-start;gap:6px}
.verse-note-badge{border:1px solid rgba(253,203,110,.4);background:rgba(253,203,110,.13);color:#ffd87a;font-family:ui-monospace,monospace;font-size:9px;padding:2px 5px;border-radius:4px;cursor:pointer;letter-spacing:.5px}
.verse-note-badge:hover{background:rgba(253,203,110,.28);color:#fff;box-shadow:0 0 10px rgba(253,203,110,.3)}
.verse-text{font-size:17px;line-height:1.75;color:rgba(245,249,252,.91)}
.compare-text{margin-top:10px;color:rgba(253,203,110,.8);font-size:14px;line-height:1.55}
.tokens{margin-top:10px;display:flex;gap:5px;flex-wrap:wrap}
.token{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:9px;border:1px solid rgba(120,200,255,.16);background:rgba(120,200,255,.06);border-radius:5px;padding:4px 5px;color:#cbe6ff}
.empty{border:1px solid var(--line);background:rgba(0,0,0,.18);border-radius:10px;padding:14px;color:var(--muted);line-height:1.55}
.study-panel{height:100%;display:flex;flex-direction:column;gap:10px;min-height:0}
.study-tabs{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.tab-btn,.lens{height:31px;border:1px solid var(--line);background:rgba(255,255,255,.035);border-radius:6px;color:#b7c9d8;font-size:9px;text-transform:uppercase;letter-spacing:.6px;cursor:pointer}
.tab-btn.on,.lens.on{border-color:rgba(120,200,255,.35);background:rgba(120,200,255,.12);color:var(--blue)}
.tab-panel{display:none;min-height:0;overflow:auto;padding-right:2px}
.tab-panel.on{display:block;flex:1}
.lens-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px}
.study-card,.analysis-card{border:1px solid var(--line);background:rgba(0,0,0,.17);border-radius:8px;padding:12px;margin-bottom:10px}
.study-card h3,.analysis-card h3{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:8px;letter-spacing:1.3px;text-transform:uppercase;color:var(--blue);margin-bottom:8px}
.study-card p,.analysis-card p{font-size:12px;line-height:1.55;color:var(--muted)}
.note-list,.data-list{display:flex;flex-direction:column;gap:6px}
.note-btn,.result-btn,.data-btn{border:0;border-left:2px solid rgba(120,200,255,.38);background:rgba(255,255,255,.04);color:rgba(232,241,248,.82);border-radius:5px;padding:8px;text-align:left;cursor:pointer;font-size:10px;line-height:1.38}
.note-btn:hover,.result-btn:hover,.data-btn:hover{background:rgba(120,200,255,.12);color:#fff}
.note-btn small,.result-btn small,.data-btn small{display:block;margin-bottom:3px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:7px;color:var(--gold);text-transform:uppercase}
.data-btn strong{display:block;font-size:12px;color:#fff;margin-bottom:3px}
.metric-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}
.metric{border:1px solid var(--line);background:rgba(255,255,255,.035);border-radius:8px;padding:9px}
.metric b{display:block;font-size:17px;color:#fff;line-height:1}
.metric span{display:block;margin-top:4px;font-size:9px;color:var(--faint);text-transform:uppercase;letter-spacing:.8px}
.viz{width:100%;height:260px;display:block;border:1px solid rgba(255,255,255,.07);background:#070b12;border-radius:8px}
.viz.tall{height:340px}
.viz.compact{height:210px}
.svg-label{font-family:Inter,system-ui,sans-serif;font-size:10px;fill:#eaf2fb;pointer-events:none}
.svg-mini{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:8px;fill:rgba(234,242,251,.52);pointer-events:none}
.svg-value{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:9px;fill:rgba(253,203,110,.9);pointer-events:none}
.svg-axis{stroke:rgba(234,242,251,.16);stroke-width:1}
.svg-grid{stroke:rgba(234,242,251,.07);stroke-width:1}
.svg-hotspot{cursor:pointer}
.svg-hotspot:hover .svg-emphasis{stroke:#fff;stroke-width:1.6}
.flag-group{display:grid;grid-template-columns:1fr;gap:8px}
.flag{border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);border-radius:8px;padding:9px}
.flag h4{font-size:12px;color:#fff;margin-bottom:4px}
.flag p{font-size:11px;color:var(--muted);line-height:1.45}
.flag code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--gold);font-size:10px}
.modal{position:fixed;inset:0;background:rgba(2,3,8,.86);backdrop-filter:blur(10px);z-index:20;display:none;align-items:center;justify-content:center;padding:26px}
.modal.show{display:flex}
.modal-box{width:min(860px,94vw);max-height:86vh;overflow:auto;border:1px solid rgba(255,255,255,.12);background:#090b16;border-radius:12px;box-shadow:0 30px 80px rgba(0,0,0,.65)}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 20px;border-bottom:1px solid var(--line)}
.modal-title{font-weight:850;font-size:18px}
.modal-body{padding:22px 26px;font-size:14px;line-height:1.75;color:rgba(235,244,252,.84);white-space:pre-wrap}
.echo-filters{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px;align-items:end}
.echo-filters label{display:flex;flex-direction:column;gap:4px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:8px;letter-spacing:1.1px;text-transform:uppercase;color:rgba(120,200,255,.78)}
.echo-filters select{height:30px;border:1px solid var(--line);background:rgba(255,255,255,.05);color:var(--text);border-radius:6px;padding:0 8px;font-size:11px}
.echo-filters .echo-toggle{flex-direction:row;align-items:center;gap:6px;grid-column:1/3;color:rgba(234,242,251,.62);text-transform:none;letter-spacing:.5px;font-size:10px;font-family:Inter,system-ui,sans-serif}
.echo-list{display:flex;flex-direction:column;gap:7px;max-height:540px;overflow-y:auto;padding-right:4px}
.echo-card{border:1px solid var(--line);background:rgba(120,200,255,.04);border-left:3px solid rgba(253,203,110,.65);border-radius:7px;padding:9px 11px;cursor:pointer;transition:background .15s,border-color .15s}
.echo-card:hover{background:rgba(253,203,110,.10);border-left-color:#fdcb6e}
.echo-card .echo-head{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:5px}
.echo-card .echo-score{font-family:Orbitron,ui-monospace,monospace;font-size:11px;color:var(--gold);letter-spacing:.5px}
.echo-card .echo-pair{font-size:12px;color:#fff;font-weight:600}
.echo-card .echo-meta{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:8px;color:var(--muted);letter-spacing:.6px;text-transform:uppercase;margin-bottom:4px}
.echo-card .echo-lemmas{display:flex;flex-wrap:wrap;gap:3px;margin-top:5px}
.echo-card .echo-lemma{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:8px;border:1px solid rgba(253,203,110,.32);background:rgba(253,203,110,.08);color:#ffd87a;padding:1px 5px;border-radius:3px}
.echo-modal-box{width:min(960px,96vw);max-height:90vh}
.echo-modal-body{padding:0}
.echo-comparison{display:grid;grid-template-columns:1fr 1fr;gap:0;min-height:300px}
.echo-side{padding:20px 24px;border-right:1px solid var(--line)}
.echo-side:last-child{border-right:0;background:rgba(253,203,110,.025)}
.echo-side h4{font-family:Orbitron,Inter,sans-serif;font-size:14px;color:var(--blue);margin-bottom:4px}
.echo-side .echo-ref{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:9px;color:var(--gold);text-transform:uppercase;letter-spacing:1.1px;margin-bottom:14px}
.echo-side .echo-text-pt{font-size:14px;line-height:1.7;color:rgba(245,249,252,.92);margin-bottom:18px;padding-bottom:18px;border-bottom:1px dashed var(--line)}
.echo-side .echo-section-title{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:8px;color:rgba(120,200,255,.7);letter-spacing:1.3px;text-transform:uppercase;margin-bottom:7px}
.echo-tokens{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:14px;direction:rtl;text-align:right;font-size:18px;line-height:1.8}
.echo-token{position:relative;padding:2px 5px;border-radius:4px;border:1px solid transparent}
.echo-token.shared{background:rgba(253,203,110,.18);border-color:rgba(253,203,110,.5);color:#ffd87a}
.echo-token small{display:block;font-family:ui-monospace,monospace;font-size:7px;color:var(--muted);direction:ltr;text-align:center}
.echo-shared-strongs{margin-top:14px;padding:10px 12px;background:rgba(253,203,110,.07);border:1px solid rgba(253,203,110,.22);border-radius:7px;grid-column:1/3}
.echo-shared-strongs h4{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:9px;color:var(--gold);letter-spacing:1.2px;text-transform:uppercase;margin-bottom:8px}
.echo-shared-strongs .strong-pill{display:inline-block;font-family:ui-monospace,monospace;font-size:11px;padding:3px 8px;margin:3px;border:1px solid rgba(253,203,110,.4);background:rgba(253,203,110,.12);color:#fff;border-radius:5px}
.echo-actions{padding:14px 24px;border-top:1px solid var(--line);display:flex;gap:8px;flex-wrap:wrap}
.nt-cit-card{border-left:3px solid var(--line);background:rgba(120,200,255,.04);border-radius:7px;padding:9px 11px;cursor:pointer;display:block;width:100%;text-align:left}
.nt-cit-card.signal-lxx_aligned{border-left-color:#7ee0a1}
.nt-cit-card.signal-lxx_weak{border-left-color:#fdcb6e}
.nt-cit-card.signal-no_lxx_signal{border-left-color:#ff6d8b}
.nt-cit-card:hover{background:rgba(120,200,255,.08)}
.nt-cit-card .nt-cit-pair{font-size:12px;color:#fff;font-weight:600;margin-bottom:3px}
.nt-cit-card .nt-cit-label{font-size:11px;color:rgba(253,203,110,.86);margin-bottom:3px}
.nt-cit-card .nt-cit-meta{font-family:ui-monospace,monospace;font-size:8px;color:var(--muted);letter-spacing:.7px;text-transform:uppercase}
.nt-cit-signal-pill{display:inline-block;padding:1px 6px;border-radius:4px;font-family:ui-monospace,monospace;font-size:8px;letter-spacing:.8px;text-transform:uppercase;margin-left:6px}
.nt-cit-signal-pill.lxx_aligned{background:rgba(126,224,161,.18);color:#7ee0a1;border:1px solid rgba(126,224,161,.4)}
.nt-cit-signal-pill.lxx_weak{background:rgba(253,203,110,.15);color:var(--gold);border:1px solid rgba(253,203,110,.4)}
.nt-cit-signal-pill.no_lxx_signal{background:rgba(255,109,139,.13);color:#ff6d8b;border:1px solid rgba(255,109,139,.36)}
.nt-cit-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:20px 24px}
.nt-cit-block{border:1px solid var(--line);border-radius:8px;padding:14px 16px;background:rgba(255,255,255,.025)}
.nt-cit-block h4{font-family:Orbitron,Inter,sans-serif;font-size:13px;margin-bottom:2px}
.nt-cit-block .nt-cit-block-ref{font-family:ui-monospace,monospace;font-size:9px;color:var(--gold);letter-spacing:1px;text-transform:uppercase;margin-bottom:10px}
.nt-cit-block .nt-cit-text{font-size:15px;line-height:1.7;color:#eaf2fb}
.nt-cit-block.lang-grc{background:linear-gradient(180deg,rgba(120,200,255,.05),rgba(120,200,255,.02));border-color:rgba(120,200,255,.22)}
.nt-cit-block.lang-grc h4{color:var(--blue)}
.nt-cit-block.lang-hbo{background:linear-gradient(180deg,rgba(253,203,110,.05),rgba(253,203,110,.02));border-color:rgba(253,203,110,.22);direction:rtl;text-align:right}
.nt-cit-block.lang-hbo h4{color:var(--gold);direction:ltr;text-align:left}
.nt-cit-block.lang-hbo .nt-cit-block-ref{direction:ltr;text-align:left}
.nt-cit-block.lang-pt h4{color:#cee5ff}
.nt-cit-block .nt-cit-overlap{margin-top:10px;padding:8px 10px;background:rgba(126,224,161,.07);border:1px solid rgba(126,224,161,.18);border-radius:6px;font-size:11px;color:#bee3ce}
.nt-cit-block .nt-cit-overlap b{color:#7ee0a1;font-family:ui-monospace,monospace}
.ane-tabs{display:flex;gap:6px;margin-bottom:10px}
.ane-tab{height:28px;padding:0 12px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:#b7c9d8;font-family:ui-monospace,monospace;font-size:9px;letter-spacing:1.2px;text-transform:uppercase;border-radius:6px;cursor:pointer}
.ane-tab.on{background:rgba(253,203,110,.12);border-color:rgba(253,203,110,.4);color:var(--gold)}
.corpus-tab{height:28px;padding:0 12px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:#b7c9d8;font-family:ui-monospace,monospace;font-size:9px;letter-spacing:1.2px;text-transform:uppercase;border-radius:6px;cursor:pointer;flex:1}
.corpus-tab.on{background:rgba(189,123,255,.12);border-color:rgba(189,123,255,.45);color:#bd7bff}
.ane-list{display:flex;flex-direction:column;gap:7px;max-height:420px;overflow-y:auto;padding-right:4px}
.ane-card{border:1px solid var(--line);border-left:3px solid rgba(253,203,110,.5);background:rgba(0,0,0,.18);border-radius:7px;padding:10px 12px;cursor:pointer;text-align:left;display:block;width:100%}
.ane-card:hover{background:rgba(253,203,110,.08)}
.ane-card h5{font-size:12px;color:#fff;margin-bottom:4px}
.ane-card .ane-meta{font-family:ui-monospace,monospace;font-size:8px;color:var(--gold);letter-spacing:.8px;text-transform:uppercase;margin-bottom:4px}
.ane-card .ane-text{font-size:11px;color:rgba(232,241,248,.7);line-height:1.45;font-style:italic}
.ane-card .ane-bib{font-family:ui-monospace,monospace;font-size:9px;color:var(--blue);margin-top:5px}
.ane-card .ane-note{font-size:11px;color:rgba(245,249,252,.7);margin-top:5px;line-height:1.4}
.ia-status{padding:8px 10px;border-radius:6px;margin-bottom:10px;font-family:ui-monospace,monospace;font-size:9px;letter-spacing:1.1px;text-transform:uppercase}
.ia-status.ok{background:rgba(126,224,161,.10);color:#7ee0a1;border:1px solid rgba(126,224,161,.32)}
.ia-status.warn{background:rgba(255,109,139,.10);color:#ff8aa3;border:1px solid rgba(255,109,139,.32)}
.ia-status.info{background:rgba(120,200,255,.07);color:#9ec8e8;border:1px solid rgba(120,200,255,.22)}
.ia-modes{display:flex;gap:4px;margin-bottom:8px}
.ia-mode-btn{flex:1;height:28px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:#bed0df;font-family:ui-monospace,monospace;font-size:9px;text-transform:uppercase;letter-spacing:1px;border-radius:5px;cursor:pointer}
.ia-mode-btn.on{background:rgba(189,123,255,.13);border-color:rgba(189,123,255,.45);color:#bd7bff}
#ia-question{width:100%;border:1px solid var(--line);background:rgba(0,0,0,.22);color:#eaf2fb;border-radius:7px;padding:10px;font-size:12px;font-family:inherit;line-height:1.5;resize:vertical;margin-bottom:8px}
#ia-question:focus{outline:none;border-color:rgba(189,123,255,.5)}
.ia-actions{display:flex;gap:6px;margin-bottom:10px}
.ia-actions select{flex:1;height:30px;border:1px solid var(--line);background:rgba(255,255,255,.05);color:var(--text);border-radius:6px;padding:0 8px;font-size:11px}
.ia-actions .ia-go{flex:0 0 auto;padding:0 16px;background:rgba(189,123,255,.15);border-color:rgba(189,123,255,.5);color:#bd7bff}
.ia-actions .ia-go:hover{background:rgba(189,123,255,.25);color:#fff}
.ia-response{border:1px solid var(--line);background:rgba(189,123,255,.04);border-left:3px solid rgba(189,123,255,.5);border-radius:7px;padding:14px 16px;font-size:13px;line-height:1.7;color:#eaf2fb;min-height:80px;white-space:pre-wrap;display:none}
.ia-response.show{display:block}
.ia-response.error{border-left-color:#ff6d8b;background:rgba(255,109,139,.06);color:#ffb4c2}
.ia-response.streaming::after{content:'▮';color:#bd7bff;animation:blink 1s infinite}
@keyframes blink{0%,50%{opacity:1}51%,100%{opacity:0}}
.patterns-tabs{display:grid;grid-template-columns:repeat(5,1fr);gap:4px;margin-bottom:10px}
.pattern-tab{height:26px;border:1px solid var(--line);background:rgba(255,255,255,.03);color:#a4b8cc;font-family:ui-monospace,monospace;font-size:8px;letter-spacing:.9px;text-transform:uppercase;border-radius:5px;cursor:pointer}
.pattern-tab.on{background:rgba(126,224,161,.13);border-color:rgba(126,224,161,.5);color:#7ee0a1}
.pattern-tab:hover{border-color:rgba(120,200,255,.4)}
.pattern-panel.hidden{display:none}
/* ============== GEMATRIA — visual refinado (gradientes, sem cor pura) ============== */
.gematria-card{
  border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(126,224,161,.07),rgba(126,224,161,.015));
  border-left:3px solid #7ee0a1;
  border-radius:8px;padding:14px;margin-bottom:10px
}
.gematria-card .gc-head{margin-bottom:10px;padding-bottom:10px;border-bottom:1px dashed rgba(126,224,161,.18)}
.gematria-card h4{font-family:Orbitron,Inter,sans-serif;font-size:24px;color:#fff;margin-bottom:5px;direction:rtl;text-align:right;line-height:1}
.gematria-card .gc-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:5px}
.gematria-card .gc-translit{font-family:Orbitron,Inter,sans-serif;font-size:13px;color:#cee5ff;letter-spacing:.4px}
.gematria-card .gc-pt{font-size:12px;color:rgba(232,241,248,.78);font-style:italic}
.gematria-card .gc-tag{font-family:ui-monospace,monospace;font-size:8px;text-transform:uppercase;letter-spacing:1px;padding:2px 7px;border-radius:10px;background:linear-gradient(135deg,rgba(189,123,255,.18),rgba(189,123,255,.05));border:1px solid rgba(189,123,255,.32);color:#d4adff}
.gematria-card .gc-freq{font-family:ui-monospace,monospace;font-size:9.5px;color:rgba(234,242,251,.55);letter-spacing:.4px}
.gematria-card .gem-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:10px}
.gematria-card .gem-stat{padding:8px 9px;background:linear-gradient(180deg,rgba(0,0,0,.28),rgba(0,0,0,.10));border:1px solid var(--line);border-radius:6px;text-align:center}
.gematria-card .gem-stat b{display:block;font-family:Orbitron,monospace;font-size:17px;color:var(--gold);line-height:1}
.gematria-card .gem-stat span{display:block;margin-top:3px;font-family:ui-monospace,monospace;font-size:8px;color:rgba(234,242,251,.5);text-transform:uppercase;letter-spacing:.9px}
.gematria-card .gc-actions{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}
.gematria-card .gc-actions .btn{font-size:10px;height:28px;padding:0 10px}

/* Filtros de relevância */
.gem-filters{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap}
.gem-filter{height:26px;padding:0 11px;border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01));color:#bed0df;font-family:ui-monospace,monospace;font-size:9px;letter-spacing:.9px;text-transform:uppercase;border-radius:14px;cursor:pointer}
.gem-filter:hover{border-color:rgba(120,200,255,.4)}
.gem-filter.on{background:linear-gradient(180deg,rgba(120,200,255,.2),rgba(120,200,255,.05));border-color:rgba(120,200,255,.55);color:#fff}
.gem-filter.rel-alta.on{background:linear-gradient(180deg,rgba(126,224,161,.22),rgba(126,224,161,.05));border-color:rgba(126,224,161,.6);color:#7ee0a1}
.gem-filter.rel-media.on{background:linear-gradient(180deg,rgba(253,203,110,.22),rgba(253,203,110,.05));border-color:rgba(253,203,110,.6);color:var(--gold)}
.gem-filter.rel-baixa.on{background:linear-gradient(180deg,rgba(150,160,180,.18),rgba(150,160,180,.03));border-color:rgba(150,160,180,.45);color:#a8b3c5}

/* Equivalências */
.gem-equiv{
  border:1px solid var(--line);
  border-radius:9px;padding:11px 12px;margin-bottom:9px;
  transition:border-color .2s
}
.gem-equiv.rel-alta{
  border-left:3px solid #7ee0a1;
  background:linear-gradient(180deg,rgba(126,224,161,.06),rgba(126,224,161,.012))
}
.gem-equiv.rel-media{
  border-left:3px solid var(--gold);
  background:linear-gradient(180deg,rgba(253,203,110,.05),rgba(253,203,110,.01))
}
.gem-equiv.rel-baixa{
  border-left:3px solid rgba(150,160,180,.4);
  background:linear-gradient(180deg,rgba(150,160,180,.04),rgba(150,160,180,.008))
}
.gem-equiv-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.gem-equiv-val{font-family:Orbitron,Inter,sans-serif;font-size:18px;color:#fff;letter-spacing:.4px;display:flex;align-items:baseline;gap:8px}
.gem-equiv-val .sigma{font-family:Georgia,serif;font-size:22px;color:var(--gold);line-height:1}
.gem-equiv-val small{font-family:ui-monospace,monospace;font-size:9px;color:rgba(234,242,251,.5);letter-spacing:.8px;text-transform:uppercase;margin-left:6px}
.gem-rel-badge{font-family:ui-monospace,monospace;font-size:8.5px;text-transform:uppercase;letter-spacing:1.1px;padding:3px 9px;border-radius:11px}
.gem-rel-badge.rel-alta{background:linear-gradient(135deg,rgba(126,224,161,.25),rgba(126,224,161,.07));border:1px solid rgba(126,224,161,.5);color:#7ee0a1}
.gem-rel-badge.rel-media{background:linear-gradient(135deg,rgba(253,203,110,.22),rgba(253,203,110,.06));border:1px solid rgba(253,203,110,.5);color:var(--gold)}
.gem-rel-badge.rel-baixa{background:linear-gradient(135deg,rgba(150,160,180,.18),rgba(150,160,180,.04));border:1px solid rgba(150,160,180,.4);color:#a8b3c5}

.gem-words{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.gem-word{
  display:flex;flex-direction:column;align-items:center;gap:1px;
  padding:6px 11px 5px;
  background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.01));
  border:1px solid var(--line);
  border-radius:7px;
  cursor:pointer;
  transition:transform .15s,border-color .15s,background .15s;
  min-width:64px
}
.gem-word:hover{
  background:linear-gradient(180deg,rgba(120,200,255,.13),rgba(120,200,255,.02));
  border-color:rgba(120,200,255,.45);
  transform:translateY(-1px)
}
.gem-word.theological{
  border-color:rgba(126,224,161,.32);
  background:linear-gradient(180deg,rgba(126,224,161,.08),rgba(126,224,161,.015))
}
.gem-word.theological:hover{
  border-color:rgba(126,224,161,.6);
  background:linear-gradient(180deg,rgba(126,224,161,.15),rgba(126,224,161,.025))
}
.gem-word .gw-text{font-family:Orbitron,Inter,sans-serif;font-size:18px;color:#fff;direction:rtl;line-height:1}
.gem-word .gw-pt{font-size:10px;color:rgba(232,241,248,.78);font-style:italic;line-height:1.1;margin-top:2px}
.gem-word .gw-translit{font-family:ui-monospace,monospace;font-size:9px;color:rgba(120,200,255,.78);letter-spacing:.4px;margin-top:1px}
.gem-word .gw-freq{font-family:ui-monospace,monospace;font-size:8px;color:rgba(234,242,251,.42);margin-top:2px;letter-spacing:.5px}

/* Detalhe expandido dos pares */
.gem-evidence{margin-top:10px;font-size:11px}
.gem-evidence summary{cursor:pointer;color:rgba(120,200,255,.7);font-family:ui-monospace,monospace;font-size:9.5px;letter-spacing:.8px;text-transform:uppercase;padding:4px 0}
.gem-evidence summary:hover{color:#78c8ff}
.gem-pair{display:grid;grid-template-columns:auto auto 1fr;gap:8px;align-items:center;padding:5px 8px;border-radius:5px;margin-top:4px;background:linear-gradient(180deg,rgba(0,0,0,.18),rgba(0,0,0,.05));border-left:2px solid transparent}
.gem-pair.rel-alta{border-left-color:#7ee0a1}
.gem-pair.rel-media{border-left-color:var(--gold)}
.gem-pair.rel-baixa{border-left-color:rgba(150,160,180,.4)}
.gem-pair .gp-words{font-family:Orbitron,Inter,sans-serif;font-size:13px;color:#fff;direction:rtl}
.gem-pair .gp-level{font-family:ui-monospace,monospace;font-size:8px;text-transform:uppercase;letter-spacing:.8px;padding:1px 6px;border-radius:9px}
.gem-pair .gp-level.rel-alta{background:rgba(126,224,161,.18);color:#7ee0a1}
.gem-pair .gp-level.rel-media{background:rgba(253,203,110,.16);color:var(--gold)}
.gem-pair .gp-level.rel-baixa{background:rgba(150,160,180,.13);color:#a8b3c5}
.gem-pair .gp-reasons{font-size:10px;color:rgba(234,242,251,.6);font-style:italic}

/* ============== PAINEL INVESTIGATIVO ============== */
.word-investigator-modal .wi-modal-box{width:min(1100px,96vw);max-height:92vh;background:linear-gradient(180deg,#0a0e17,#06080e)}
.wi-head{background:linear-gradient(180deg,rgba(189,123,255,.10),rgba(189,123,255,.02))}
#wi-title{display:flex;flex-direction:column;gap:2px}
.wi-title-main{font-family:Orbitron,Inter,sans-serif;font-size:28px;color:#fff;direction:rtl;line-height:1}
.wi-title-meta{font-family:ui-monospace,monospace;font-size:11px;color:rgba(189,123,255,.8);letter-spacing:.4px}
#wi-body{padding:20px 26px;font-size:13px}
.wi-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.wi-block{padding:16px 18px;border:1px solid var(--line);border-radius:9px;background:linear-gradient(180deg,rgba(255,255,255,.022),rgba(0,0,0,.05))}
.wi-block.wi-block-wide{grid-column:1/3}
.wi-block h4{font-family:Orbitron,Inter,sans-serif;font-size:13px;color:#bd7bff;letter-spacing:.4px;margin-bottom:11px;padding-bottom:8px;border-bottom:1px dashed rgba(189,123,255,.18)}
.wi-table{width:100%;border-collapse:collapse}
.wi-table th{text-align:left;font-family:ui-monospace,monospace;font-size:9px;font-weight:normal;text-transform:uppercase;letter-spacing:1px;color:rgba(189,123,255,.55);padding:5px 0;width:36%}
.wi-table td{padding:5px 0;color:#eaf2fb;font-size:13px}
.wi-table td.rtl{direction:rtl;text-align:right}
.wi-table td.big{font-family:Orbitron,Inter,sans-serif;font-size:18px}
.wi-table td b.gold{font-family:Orbitron,monospace;color:var(--gold);font-size:22px}

.wi-equiv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px}
.wi-eq-chip{display:flex;flex-direction:column;align-items:center;gap:2px;padding:9px 8px;border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01));border-radius:7px;cursor:pointer}
.wi-eq-chip:hover{background:linear-gradient(180deg,rgba(189,123,255,.13),rgba(189,123,255,.02));border-color:rgba(189,123,255,.5)}
.wi-eq-chip.theological{border-color:rgba(126,224,161,.32)}
.wi-eq-chip .rtl{direction:rtl;font-family:Orbitron,Inter,sans-serif;color:#fff}
.wi-eq-chip .rtl.big{font-size:17px;line-height:1}
.wi-eq-chip .wi-eq-pt{font-size:9.5px;color:rgba(232,241,248,.75);font-style:italic;text-align:center;line-height:1.2}
.wi-eq-chip .wi-eq-tr{font-family:ui-monospace,monospace;font-size:8.5px;color:rgba(120,200,255,.7)}
.wi-eq-chip .wi-eq-freq{font-family:ui-monospace,monospace;font-size:8px;color:rgba(234,242,251,.4);letter-spacing:.4px}

.wi-disclaimer{margin-top:12px;padding:10px 12px;background:linear-gradient(180deg,rgba(253,203,110,.08),rgba(253,203,110,.015));border:1px solid rgba(253,203,110,.22);border-left:3px solid var(--gold);border-radius:6px;font-size:11.5px;color:rgba(253,228,160,.86);line-height:1.55}
.wi-disclaimer b{color:#fff}
.wi-empty{color:var(--muted);font-style:italic;font-size:11px;padding:8px 0}
.wi-samples{display:flex;flex-wrap:wrap;gap:5px}
.wi-sample{padding:5px 9px;border:1px solid var(--line);background:linear-gradient(180deg,rgba(120,200,255,.07),rgba(120,200,255,.015));border-radius:5px;color:#cee5ff;font-family:ui-monospace,monospace;font-size:9.5px;cursor:pointer}
.wi-sample:hover{background:linear-gradient(180deg,rgba(120,200,255,.18),rgba(120,200,255,.04));color:#fff;border-color:rgba(120,200,255,.5)}
.wi-actions{display:flex;gap:8px;margin-top:18px;padding-top:14px;border-top:1px solid var(--line);flex-wrap:wrap}

@media (max-width:760px){
  .wi-grid{grid-template-columns:1fr}
  .wi-block.wi-block-wide{grid-column:1}
}
.acrostic-card{border:1px solid var(--line);border-left:3px solid #bd7bff;background:rgba(189,123,255,.04);border-radius:7px;padding:11px;margin-bottom:8px;cursor:pointer}
.acrostic-card:hover{background:rgba(189,123,255,.10)}
.acrostic-card h4{font-size:13px;color:#fff;margin-bottom:5px}
.acrostic-card .ac-letters{font-family:Orbitron,monospace;font-size:18px;letter-spacing:2px;color:#bd7bff;direction:rtl;text-align:right;background:rgba(0,0,0,.2);padding:8px;border-radius:5px;margin-top:5px}
.acrostic-card .ac-meta{font-family:ui-monospace,monospace;font-size:9px;color:var(--muted);letter-spacing:.8px;text-transform:uppercase}
.els-card{border:1px solid var(--line);border-left:3px solid #ff6d8b;background:rgba(255,109,139,.04);border-radius:7px;padding:11px;margin-bottom:8px}
.els-card h4{font-size:14px;color:#fff;margin-bottom:3px;display:flex;justify-content:space-between;align-items:center}
.els-card h4 .els-target{direction:rtl;font-family:Orbitron,monospace;color:#ff6d8b}
.els-card .els-hits{display:flex;flex-wrap:wrap;gap:4px;margin-top:5px}
.els-card .els-hit{font-family:ui-monospace,monospace;font-size:9px;background:rgba(255,109,139,.1);border:1px solid rgba(255,109,139,.3);border-radius:3px;padding:1px 5px;color:#ffa3b8;cursor:pointer}
.els-card .els-hit:hover{background:rgba(255,109,139,.25);color:#fff}
.chiasm-card{border:1px solid var(--line);border-left:3px solid #78c8ff;background:rgba(120,200,255,.04);border-radius:7px;padding:10px;margin-bottom:7px;cursor:pointer}
.chiasm-card:hover{background:rgba(120,200,255,.10)}
.chiasm-card h5{font-size:12px;color:#fff;margin-bottom:3px}
.chiasm-card .chi-meta{font-family:ui-monospace,monospace;font-size:9px;color:var(--blue)}
.parallel-card{border:1px solid var(--line);background:rgba(120,200,255,.03);border-radius:6px;padding:8px 10px;margin-bottom:5px;cursor:pointer}
.parallel-card:hover{background:rgba(120,200,255,.10)}
.parallel-card h5{font-size:11px;color:#fff}
.parallel-card .par-meta{font-family:ui-monospace,monospace;font-size:9px;color:var(--muted);margin-top:3px}
.canon-modal{position:fixed;inset:0;background:#03050a;z-index:30;display:flex;opacity:1;transition:opacity .35s ease}
.canon-modal.hidden{display:none;opacity:0}
.canon-canvas{position:absolute;inset:0;width:100%;height:100%;display:block;cursor:grab}
.canon-overlay-ui{position:absolute;inset:0;pointer-events:none;display:grid;grid-template-rows:auto 1fr auto;padding:16px 22px;gap:12px;z-index:2}
.canon-top{display:flex;align-items:center;justify-content:space-between;gap:18px;pointer-events:auto}
.canon-title b{font-family:Orbitron,Inter,sans-serif;font-size:14px;letter-spacing:3px;color:var(--blue);text-shadow:0 0 12px rgba(120,200,255,.4)}
.canon-title span{display:block;margin-top:4px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:9px;letter-spacing:1.2px;color:var(--muted);text-transform:uppercase}
.canon-controls{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.canon-btn{height:34px;padding:0 14px;border:1px solid rgba(120,200,255,.28);background:rgba(7,11,18,.72);color:#cee5ff;border-radius:7px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:10px;letter-spacing:1.2px;text-transform:uppercase;cursor:pointer;backdrop-filter:blur(10px)}
.canon-btn:hover{border-color:rgba(253,203,110,.5);background:rgba(253,203,110,.12);color:#fff;box-shadow:0 0 18px rgba(253,203,110,.18)}
.canon-btn.canon-close{width:38px;padding:0;font-size:18px;color:#ff8aa3;border-color:rgba(255,109,139,.36)}
.canon-btn.canon-close:hover{background:rgba(255,109,139,.18);color:#fff}
.canon-legend{position:absolute;bottom:18px;left:22px;pointer-events:auto;display:flex;flex-wrap:wrap;align-items:center;gap:14px;padding:10px 14px;border:1px solid rgba(120,200,255,.18);background:rgba(7,11,18,.78);backdrop-filter:blur(14px);border-radius:9px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:9px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);max-width:calc(100% - 320px)}
.canon-legend .dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:5px;vertical-align:middle;box-shadow:0 0 8px currentColor}
.canon-legend .dot.ot{background:#78c8ff;color:#78c8ff}
.canon-legend .dot.nt{background:#fdcb6e;color:#fdcb6e}
.canon-legend .dot.notes{background:#ffd87a;color:#ffd87a;box-shadow:0 0 12px #ffd87a}
.canon-legend .line{display:inline-block;width:22px;height:2px;margin-right:5px;vertical-align:middle;border-radius:2px}
.canon-legend .line.classic{background:linear-gradient(90deg,transparent,#fdcb6e,transparent)}
.canon-legend .line.synoptic{background:linear-gradient(90deg,transparent,#7ee0a1,transparent)}
.canon-legend .line.historical{background:linear-gradient(90deg,transparent,#78c8ff,transparent)}
.canon-info{position:absolute;top:74px;right:22px;width:280px;pointer-events:auto;border:1px solid rgba(120,200,255,.26);background:rgba(7,11,18,.86);backdrop-filter:blur(16px);border-radius:11px;padding:16px 18px;box-shadow:0 24px 60px rgba(0,0,0,.6)}
.canon-info h3{font-family:Orbitron,Inter,sans-serif;font-size:18px;color:#fff;margin-bottom:6px;letter-spacing:.4px}
.canon-info .meta{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);line-height:1.6}
.canon-info .meta.gold{color:var(--gold)}
.canon-info .links{margin:10px 0 8px;padding-left:14px;list-style:disc;color:#cee5ff;font-size:12px;line-height:1.7}
.canon-info .links small{color:var(--muted);font-size:9px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;letter-spacing:.6px}
.canon-info .hint{margin-top:8px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:9px;color:rgba(253,203,110,.72);text-transform:uppercase;letter-spacing:1.4px}
.canon-status{position:absolute;bottom:18px;right:22px;pointer-events:auto;padding:8px 14px;border:1px solid rgba(120,200,255,.2);background:rgba(7,11,18,.78);backdrop-filter:blur(10px);border-radius:7px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:9px;color:rgba(120,200,255,.86);letter-spacing:1.3px;text-transform:uppercase;transition:opacity .35s}
.canon-status.hidden{opacity:0;pointer-events:none}
@media (max-width:760px){
  .canon-info{position:absolute;top:auto;right:12px;left:12px;bottom:88px;width:auto}
  .canon-legend{bottom:12px;left:12px;right:12px;max-width:none;font-size:8px}
  .canon-overlay-ui{padding:10px 12px}
  .canon-title b{font-size:12px;letter-spacing:2px}
  .canon-btn{height:30px;padding:0 10px;font-size:9px}
}
@media (max-width:1240px){
  .app{grid-template-columns:minmax(320px,34vw) minmax(0,1fr);grid-template-rows:64px minmax(0,1fr) 390px}
  .top{grid-column:1/3}
  .study{grid-column:1/3;border-left:0;border-top:1px solid var(--line)}
  .study-panel{display:grid;grid-template-columns:260px minmax(0,1fr);grid-template-rows:auto minmax(0,1fr)}
  .study-tabs{grid-column:1/3}
  .tab-panel.on{grid-column:1/3}
}
@media (max-width:760px){
  body{height:auto;min-height:100vh;overflow:auto}
  .app{height:auto;min-height:100vh;display:block}
  .top{position:sticky;top:0;z-index:10;align-items:flex-start;padding:12px;flex-direction:column}
  .top-controls{width:100%;display:grid;grid-template-columns:1fr 1fr;justify-content:stretch}
  .select{min-width:0;width:100%}
  .top-controls .btn{width:100%}
  .side,.study,.reader{overflow:visible;border-left:0;border-right:0}
  .search-panel,.study-panel{height:auto;display:flex}
  .results.show{max-height:68vh;min-height:420px;flex:none}
  .side.searching .book-list{max-height:240px;flex:none}
  .reader{padding:18px 14px}
  .verse{grid-template-columns:38px minmax(0,1fr);padding:12px}
  .verse-text{font-size:16px}
  h1{font-size:28px}
  .study-tabs{grid-template-columns:repeat(2,1fr)}
  .metric-grid{grid-template-columns:1fr 1fr}
  .viz{height:250px}
  .viz.tall{height:320px}
}

/* === popover v2 (investigação convergente) === */
/* Investigação Convergente v2 — modal scroll contínuo */

.investigation-modal .inv-box {
  width: min(960px, 96vw);
  max-height: 92vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: linear-gradient(180deg, #0b1019 0%, #050810 100%);
  border: 1px solid var(--line-strong, rgba(120,200,255,.18));
}

.inv-head { flex: 0 0 auto; }

.inv-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  padding: 10px 22px 12px;
  border-bottom: 1px solid var(--line);
  font-size: 11px;
  color: var(--muted);
}
.inv-ref {
  font-family: ui-monospace,SFMono-Regular,Menlo,monospace;
  color: var(--gold);
  font-weight: 800;
  letter-spacing: .8px;
  text-transform: uppercase;
  font-size: 10px;
}
.inv-version {
  font-family: ui-monospace,monospace;
  font-size: 10px;
  color: #cfe2f3;
  padding: 2px 7px;
  border: 1px solid var(--line);
  border-radius: 4px;
}
.inv-sel {
  font-style: italic;
  color: rgba(245,249,252,.86);
  font-size: 12px;
  flex: 1;
  min-width: 0;
}
.inv-vtext {
  display: block;
  flex-basis: 100%;
  font-size: 13px;
  color: rgba(235,244,252,.7);
  line-height: 1.55;
  margin-top: 4px;
}

.inv-body {
  flex: 1 1 auto;
  overflow: auto;
  padding: 4px 22px 22px;
}

.inv-section {
  padding: 16px 0;
  border-bottom: 1px solid rgba(255,255,255,.05);
}
.inv-section:last-child { border-bottom: none; }

.inv-h {
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .8px;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 12px;
}

.inv-section-body { font-size: 13px; line-height: 1.7; color: rgba(235,244,252,.88); }

.inv-skel {
  color: var(--muted);
  font-size: 11px;
  padding: 6px 10px;
  border-left: 2px solid var(--line);
  font-style: italic;
}
.inv-skel.ai-pending::before {
  content: '⏳ ';
  display: inline-block;
  animation: lv-spin 1.4s linear infinite;
}
@keyframes lv-spin { to { transform: rotate(360deg); } }

.inv-empty {
  color: rgba(234,242,251,.4);
  font-size: 11px;
  font-style: italic;
  padding: 6px 10px;
  border-left: 2px dashed var(--line);
}

/* --- Texto original (hebraico/grego) --- */
.orig-rtl {
  direction: rtl;
  font-family: "SBL Hebrew","SBL BibLit","Cardo",serif;
  font-size: 22px;
  line-height: 1.9;
  color: #eaf2fb;
  padding: 12px 14px;
  background: rgba(120,200,255,.04);
  border-radius: 8px;
  border: 1px solid var(--line);
}
.orig-token {
  display: inline-block;
  padding: 1px 4px;
  border-radius: 4px;
  cursor: pointer;
  transition: background .15s ease;
}
.orig-token:hover { background: rgba(253,203,110,.18); color: #fff; }

/* --- Gematria --- */
.g-totals {
  display: flex;
  gap: 16px;
  font-size: 11px;
  color: var(--muted);
  padding: 6px 0 10px;
}
.g-totals b { color: var(--gold); font-family: ui-monospace,monospace; font-size: 13px; }
.g-list, .g-eq-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.g-list li, .g-eq-list li {
  padding: 6px 10px;
  background: rgba(255,255,255,.025);
  border-radius: 5px;
  font-size: 12px;
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}
.g-word {
  font-family: "SBL Hebrew",serif;
  font-size: 16px;
  color: #eaf2fb;
  direction: rtl;
}
.g-pt { color: var(--blue); font-size: 11px; }
.g-vals {
  font-family: ui-monospace,monospace;
  font-size: 10px;
  color: var(--muted);
  margin-left: auto;
}
.g-eq-title {
  margin: 14px 0 6px;
  font-size: 10px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .6px;
}

/* --- Ecos lexicais --- */
.echo-card {
  padding: 10px 12px;
  background: rgba(255,255,255,.025);
  border-left: 2px solid var(--blue);
  border-radius: 4px;
  margin-bottom: 8px;
}
.echo-head {
  display: flex;
  gap: 10px;
  align-items: center;
  font-size: 11px;
  margin-bottom: 4px;
  flex-wrap: wrap;
}
.echo-head b { color: var(--gold); font-size: 12px; }
.echo-score, .echo-rare {
  font-family: ui-monospace,monospace;
  font-size: 10px;
  color: var(--muted);
  padding: 1px 6px;
  border: 1px solid var(--line);
  border-radius: 3px;
}
.echo-text { font-size: 12px; line-height: 1.55; color: rgba(235,244,252,.78); margin-bottom: 4px; }
.echo-lemmas { font-size: 10px; color: var(--muted); }
.echo-lemmas code {
  font-family: ui-monospace,monospace;
  font-size: 10px;
  color: var(--blue);
  padding: 0 4px;
  background: rgba(120,200,255,.08);
  border-radius: 3px;
  margin-right: 4px;
}

/* --- Citações NT/LXX --- */
.cit-card {
  padding: 10px 12px;
  background: rgba(255,255,255,.025);
  border-left: 2px solid var(--gold);
  border-radius: 4px;
  margin-bottom: 8px;
}
.cit-row {
  display: flex;
  gap: 8px;
  align-items: baseline;
  font-size: 12px;
  margin-bottom: 4px;
  line-height: 1.55;
}
.cit-tag {
  font-family: ui-monospace,monospace;
  font-size: 9px;
  font-weight: 800;
  color: var(--gold);
  padding: 1px 5px;
  border: 1px solid var(--line);
  border-radius: 3px;
  text-transform: uppercase;
  flex: 0 0 auto;
  min-width: 30px;
  text-align: center;
}
.cit-row code {
  font-family: "SBL Greek",ui-monospace,monospace;
  font-size: 12px;
  color: #cfe2f3;
}
.cit-signal {
  font-size: 10px;
  font-family: ui-monospace,monospace;
  padding: 2px 6px;
  display: inline-block;
  border-radius: 3px;
  margin-top: 4px;
}
.cit-lxx_aligned { background: rgba(126,224,161,.12); color: #7ee0a1; }
.cit-lxx_weak { background: rgba(253,203,110,.12); color: var(--gold); }
.cit-no_lxx_signal { background: rgba(255,109,139,.12); color: #ff6d8b; }

/* --- ANE parallels --- */
.ane-card {
  padding: 12px 14px;
  background: linear-gradient(135deg,rgba(120,200,255,.04),rgba(253,203,110,.03));
  border: 1px solid var(--line);
  border-radius: 6px;
  margin-bottom: 8px;
}
.ane-corpus {
  font-size: 10px;
  font-family: ui-monospace,monospace;
  color: var(--gold);
  text-transform: uppercase;
  letter-spacing: .8px;
  margin-bottom: 4px;
}
.ane-title { font-size: 12px; color: #cfe2f3; margin-bottom: 6px; }
.ane-text { font-size: 12px; line-height: 1.6; color: rgba(235,244,252,.78); margin-bottom: 6px; font-style: italic; padding-left: 8px; border-left: 1px solid rgba(120,200,255,.15); }
.ane-notes { font-size: 11px; color: var(--muted); font-style: italic; }
.ane-subtitle { font-size: 10px; color: var(--muted); font-weight: 400; }
.ane-section { font-size: 10px; font-family: ui-monospace,monospace; color: var(--blue); margin-bottom: 4px; }
.ane-reason { font-size: 11px; color: rgba(235,244,252,.7); margin-top: 4px; line-height: 1.5; }
.ane-reason b { color: var(--gold); font-size: 10px; text-transform: uppercase; letter-spacing: .5px; }
.ane-themes { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 6px; }
.ane-theme { font-size: 9px; font-family: ui-monospace,monospace; color: var(--blue); background: rgba(120,200,255,.08); border: 1px solid rgba(120,200,255,.15); padding: 1px 6px; border-radius: 3px; }
.ane-source { font-size: 9px; color: rgba(234,242,251,.35); margin-top: 4px; font-family: ui-monospace,monospace; }

/* --- IA streaming response --- */
.inv-resp {
  font-size: 13px;
  line-height: 1.75;
  color: rgba(235,244,252,.88);
  white-space: pre-wrap;
  padding: 12px 14px;
  background: rgba(120,200,255,.025);
  border-left: 2px solid var(--blue);
  border-radius: 4px;
  min-height: 60px;
}
.inv-resp.streaming::after {
  content: '▋';
  display: inline-block;
  animation: lv-blink 1s steps(2) infinite;
  color: var(--blue);
  margin-left: 2px;
}
@keyframes lv-blink { 50% { opacity: 0; } }
.inv-resp.error {
  border-left-color: #ff6d8b;
  color: #ff6d8b;
  background: rgba(255,109,139,.05);
}

/* --- Pergunta livre --- */
.inv-free { display: flex; flex-direction: column; gap: 10px; }
.inv-free-ta {
  width: 100%;
  background: rgba(0,0,0,.32);
  border: 1px solid var(--line);
  border-radius: 7px;
  padding: 10px 12px;
  color: var(--text);
  font: inherit;
  font-size: 13px;
  resize: vertical;
}
.inv-free-ta:focus { outline: none; border-color: var(--line-strong); }
.inv-free-actions { display: flex; justify-content: flex-end; }
.inv-free-go {
  background: rgba(253,203,110,.12);
  border-color: rgba(253,203,110,.4);
  color: var(--gold);
}

/* --- Popover de seleção (minimalista — só 1 chip "Investigar") --- */
.verse-popover {
  position: absolute;
  z-index: 30;
  display: none;
  padding: 4px;
  background: rgba(10,14,22,.94);
  backdrop-filter: blur(14px);
  border: 1px solid var(--line-strong);
  border-radius: 9px;
  box-shadow: 0 14px 40px rgba(0,0,0,.6), 0 0 0 1px rgba(120,200,255,.1) inset;
  animation: lvPopIn .15s ease-out;
}
.verse-popover.show { display: inline-flex; }
.verse-popover .chip {
  height: 32px;
  padding: 0 14px;
  border-radius: 6px;
  border: 1px solid rgba(253,203,110,.4);
  background: rgba(253,203,110,.12);
  color: var(--gold);
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
}
.verse-popover .chip:hover { background: rgba(253,203,110,.24); color: #fff; }
@keyframes lvPopIn { from { opacity: 0; transform: scale(.96); } to { opacity: 1; transform: none; } }

.verse-num { transition: color .12s ease, text-shadow .12s ease; }
.verse-num[role=button]:hover { color: #ffe39b; text-shadow: 0 0 8px rgba(253,203,110,.45); }

@media (max-width: 600px) {
  .investigation-modal .inv-box { width: 100vw; max-width: 100vw; max-height: 100vh; border-radius: 0; }
  .inv-body { padding: 4px 14px 18px; }
  .orig-rtl { font-size: 19px; padding: 10px; }
}

@media (prefers-reduced-motion: reduce) {
  .verse-popover { animation: none; }
  .inv-resp.streaming::after { animation: none; }
}
