:root{--font-sans: "Inter", "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, "Roboto", sans-serif;--font-scripture: var(--font-sans);--font-commentary: var(--font-sans);--color-bg: #020617;--color-surface: #0f172a;--color-surface-muted: rgba(15, 23, 42, .8);--color-border: rgba(148, 163, 184, .2);--color-border-strong: rgba(148, 163, 184, .4);--color-card-border: rgba(148, 163, 184, .15);--color-text: #e2e8f0;--color-text-muted: #94a3b8;--color-text-hover: #f8fafc;--color-app-background: #0b1220;--color-heading: #f8fafc;--color-accent: #60a5fa;--color-accent-strong: #2563eb;--color-accent-soft: rgba(59, 130, 246, .15);--color-danger: #f87171;--color-panel: rgba(15, 23, 42, .35);--color-panel-strong: rgba(15, 23, 42, .4);--color-panel-soft: rgba(15, 23, 42, .2);--color-verse-focus-bg: rgba(252, 211, 77, .2);--color-topbar: #0b1220;--space-1: .2rem;--space-2: .4rem;--space-3: .6rem;--space-4: .8rem;--space-5: .8rem;--space-6: 1.6rem;--space-7: 2.4rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--shadow-card: 0 15px 40px rgba(2, 6, 23, .6);--shadow-card-light: 0 8px 24px rgba(15, 23, 42, .15);--layout-sidebar-width: 280px}[data-theme=light]{--color-bg: #ffffff;--color-surface: #ffffff;--color-surface-muted: #ffffff;--color-border: rgba(15, 23, 42, .1);--color-border-strong: rgba(15, 23, 42, .25);--color-card-border: rgba(15, 23, 42, .08);--color-text: #0f172a;--color-text-muted: #475569;--color-text-hover: #e9eef5;--color-app-background: #eef2f6;--color-heading: #0f172a;--color-accent: #1d4ed8;--color-accent-strong: #1e3a8a;--color-accent-soft: rgba(37, 99, 235, .1);--color-danger: #dc2626;--color-panel: #ffffff;--color-panel-strong: #ffffff;--color-panel-soft: #ffffff;--color-verse-focus-bg: rgba(253, 224, 71, .4);--color-topbar: #f1f5f9;--shadow-card: var(--shadow-card-light)}:root{font-family:var(--font-sans);--timeline-font-family: var(--font-sans);line-height:1.5;font-weight:400;color:var(--color-text);--background-color: var(--color-text-muted);text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background-color:var(--color-app-background);color:var(--color-text);font-family:var(--font-sans)}#root{min-height:100vh;background-color:var(--color-app-background)}button,input,textarea,select{font:inherit;border:none}button{cursor:pointer;border-radius:var(--radius-sm);padding:var(--space-2) var(--space-2);background:var(--color-accent);color:#fff;font-weight:600;transition:background .2s ease,transform .1s ease}button:disabled{opacity:.5;cursor:not-allowed}button:not(:disabled):hover{background:var(--color-accent-strong);color:#fff}button:not(:disabled):active{transform:translateY(1px)}[hidden]{display:none!important}.app-shell{display:grid;grid-template-columns:minmax(220px,var(--layout-sidebar-width)) 1fr;grid-template-areas:"sidebar main";min-height:100vh;background:var(--color-app-background)}[data-theme=light] .app-shell{background:var(--color-app-background)}.app-shell--sidebar-collapsed{grid-template-columns:1fr;grid-template-areas:"main"}.app-shell__sidebar{grid-area:sidebar;background:var(--color-surface);border-right:1px solid var(--color-border);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4);position:relative;z-index:1}.app-shell__sidebar--hidden{display:none}.app-shell__logo h1{margin:0;font-size:1.4rem;color:var(--color-heading)}.app-shell__logo p{margin:0;color:var(--color-text-muted);font-size:.9rem}.app-shell__nav ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-2)}.app-shell__nav a{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-2);border-radius:var(--radius-md);color:var(--color-text);text-decoration:none;background:transparent;border:1px solid transparent;transition:background .2s ease,color .2s ease,border .2s ease}.app-shell__nav a.active,.app-shell__nav a:hover{background:var(--color-accent-soft);color:var(--color-heading);border-color:var(--color-border)}.app-shell__nav-badge{font-size:.7rem;font-weight:600;color:var(--color-accent)}.app-shell__meta{margin-top:auto;font-size:.85rem;color:var(--color-text-muted);display:flex;flex-direction:column;gap:var(--space-2)}.app-shell__meta div{display:flex;flex-direction:column;gap:var(--space-1)}.app-shell__meta small{text-transform:uppercase;letter-spacing:.08em;font-size:.65rem}.app-shell__meta strong{color:var(--color-heading)}.app-shell__meta .connection-status{margin:0;color:var(--color-text-muted)}.app-shell__workspace{grid-area:main;display:flex;flex-direction:column}.app-shell__overlay{position:fixed;inset:0;background:var(--color-app-background);opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:900}.app-shell__overlay--visible{opacity:1;pointer-events:auto}@media(max-width:900px){.app-shell{grid-template-columns:1fr;grid-template-rows:auto 1fr;grid-template-areas:"sidebar" "main"}.app-shell__sidebar{position:fixed;top:0;left:0;height:100vh;width:min(320px,82vw);max-width:420px;transform:translate(0);transition:transform .25s ease;border-right:1px solid var(--color-border);border-bottom:none;padding:var(--space-4);z-index:1000;box-shadow:0 10px 30px #00000040;overflow-y:auto;background:var(--color-surface)}.app-shell__sidebar--hidden{display:block;transform:translate(-105%)}.app-shell__workspace{min-height:0}}@media(min-width:901px){.app-shell__overlay{display:none}.app-shell__sidebar--hidden{display:none;transform:none}}.app-shell__topbar{padding:var(--space-2) var(--space-6);border-bottom:1px solid var(--color-border);background-color:var(--color-topbar);display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.app-shell__topbar-left{display:inline-flex;align-items:center;gap:var(--space-2)}.app-shell__quick-nav{display:inline-flex;align-items:center;gap:var(--space-1);margin-left:var(--space-3)}.app-shell__quick-label{margin-left:var(--space-1);font-size:.85rem;color:var(--color-heading)}.app-shell__quick-nav .icon-button{display:inline-flex;align-items:center;gap:var(--space-1)}.app-shell__quick-nav .icon-button:hover .app-shell__quick-label{color:var(--color-text-hover)}.app-shell__topbar h2{margin:0;font-size:1.1rem;color:var(--color-heading)}.app-shell__topbar-actions{display:flex;gap:var(--space-3);align-items:center;margin-left:auto;justify-content:flex-end}.app-shell__topbar-buttons{display:inline-flex;align-items:center;gap:var(--space-2);flex-wrap:nowrap}.app-shell__user{display:inline-flex;align-items:center;justify-content:center;color:var(--color-heading)}.theme-toggle{display:inline-flex;align-items:center;gap:var(--space-2);background:transparent;color:var(--color-text);border:1px solid var(--color-border);padding:var(--space-2) var(--space-3)}.theme-toggle svg{width:1rem;height:1rem}.theme-toggle:hover{background:var(--color-accent-soft)}.app-shell__content{padding:var(--space-4);flex:1;overflow-y:auto}.card{background:var(--color-surface-muted);border:1px solid var(--color-card-border);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-card)}.canon-card{border:none;background:transparent;padding:0}.card h2{margin-top:0;color:var(--color-heading)}.card ul{padding-left:var(--space-4);color:var(--color-text-muted);line-height:1.6}.grid{display:grid;gap:var(--space-4)}.grid.two{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.reader-page{display:flex;flex-direction:column;gap:var(--space-3);flex:1;min-height:0;height:calc(100vh - 7rem);max-height:calc(100vh - 7rem);overflow:hidden}.reader-page[data-bible-lang=ENG]{--font-scripture: "Inter", "Segoe UI", "Roboto", system-ui, sans-serif;--font-commentary: "Inter", "Segoe UI", "Roboto", system-ui, sans-serif}.reader-page[data-bible-lang=CHT]{--font-scripture: "PingFang TC", "Microsoft JhengHei", "Heiti TC", "Noto Sans TC", "Hiragino Sans GB", "SimHei", sans-serif;--font-commentary: "PingFang TC", "Microsoft JhengHei", "Heiti TC", "Noto Sans TC", "Hiragino Sans GB", "SimHei", sans-serif;font-size:1.05rem}.reader-page[data-bible-lang=CHS]{--font-scripture: "PingFang SC", "Microsoft YaHei", "Heiti SC", "Noto Sans SC", "Hiragino Sans GB", "SimHei", sans-serif;--font-commentary: "PingFang SC", "Microsoft YaHei", "Heiti SC", "Noto Sans SC", "Hiragino Sans GB", "SimHei", sans-serif}.reader-layout{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-4);min-height:0;height:100%}.reader-layout--split{grid-template-columns:minmax(0,var(--reader-pane-width, 60%)) var(--reader-splitter-width, var(--space-3)) minmax(0,var(--context-pane-width, 40%));column-gap:0;row-gap:var(--space-4);align-items:stretch;min-height:0;height:100%}.reader-layout--split>.card{height:100%;display:flex;flex-direction:column;min-height:0;overflow:hidden}.reader-mobile-tabs{display:none;gap:var(--space-2);padding:var(--space-1);border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-panel);margin-bottom:0}.reader-mobile-tab{flex:1;border:none;border-bottom:2px solid transparent;background:transparent;color:var(--color-text-muted);padding:var(--space-2) var(--space-3);border-radius:0;font-weight:600;transition:background .2s ease,color .2s ease,border-color .2s ease}.reader-mobile-tab:hover,.reader-mobile-tab:focus-visible{background:transparent;color:var(--color-text)}.reader-mobile-tab--active{background:transparent;color:var(--color-text);border-bottom-color:var(--color-accent)}.reader-pane-stack{display:flex;flex-direction:column;gap:var(--space-4);height:100%;min-height:0}.reader-pane-stack>.reader-card{flex:1;display:flex;flex-direction:column;min-height:0}.reader-pane-stack--split{flex-direction:row}.reader-pane-stack--split>.reader-card{flex:1}.reader-splitter{width:var(--reader-splitter-width, var(--space-3));display:flex;align-items:center;justify-content:center;cursor:col-resize;touch-action:none}.reader-splitter__grip{width:4px;height:70%;border-radius:999px;background:var(--color-border);transition:background .2s ease}.reader-splitter:hover .reader-splitter__grip,.reader-splitter--active .reader-splitter__grip{background:var(--color-accent)}@media(max-width:720px){.reader-mobile-tabs{display:flex;flex-direction:row}.reader-mobile-tabs+.reader-layout{margin-top:calc(-1 * var(--space-4))}.reader-card__header{flex-wrap:wrap}.reader-card__chips--right{flex-basis:100%;justify-content:flex-end}.reader-layout,.reader-layout--split{grid-template-columns:minmax(0,1fr);gap:var(--space-4)}.reader-splitter,.context-card__toggle{display:none}}.reader-card{position:relative}.reader-card__overlay{position:absolute;inset:0;pointer-events:none;z-index:3;display:flex;align-items:flex-end}.reader-card__nav{position:relative;width:100%;margin:0 var(--space-6) var(--space-3);transform:none;display:flex;justify-content:space-between;pointer-events:none}.reader-card__header{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);flex-shrink:0;padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border)}.reader-card__header-left{display:flex;align-items:center;gap:var(--space-2);flex:1;min-width:0}.reader-panel__title{font-size:1rem;margin:0 0 var(--space-2);color:var(--color-heading)}.reader-toolbar{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:center;margin-bottom:var(--space-2);flex-shrink:0}.reader-card__body{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-3);font-size:calc(1rem * var(--reader-font-scale, 1));position:relative}.reader-text-scale{display:inline-flex;align-items:center;gap:var(--space-1);color:var(--color-text);font-size:.85rem}.button-secondary{background:transparent;border:1px solid var(--color-border);color:var(--color-text);padding:calc(var(--space-2) - 2px) var(--space-2);border-radius:var(--radius-sm);height:2rem;display:inline-flex;align-items:center;justify-content:center}.button-secondary--active{border-color:var(--color-accent);color:var(--color-accent);background:#22d3ee26}.reader-toast{position:fixed;bottom:var(--space-4);left:var(--space-4);max-width:320px;padding:var(--space-3) var(--space-4);background:var(--color-surface);color:var(--color-heading);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);z-index:30;pointer-events:none;animation:reader-toast-fade .2s ease}@keyframes reader-toast-fade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.eyebrow{margin:0 0 var(--space-1);text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;color:var(--color-text-muted)}.reader-card__chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}.reader-card__chips--left{justify-content:flex-start}.reader-card__chips--right{justify-content:flex-end}.reader-lang-select{border:1px solid var(--color-border);border-radius:999px;background:var(--color-panel);color:var(--color-heading);font-weight:600;font-size:.85rem;height:2rem;padding:0 var(--space-3);cursor:pointer}.reader-book-select,.reader-chapter-select{width:auto}.reader-lang-select:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.reader-chip{display:inline-flex;align-items:center;height:2rem;padding:0 var(--space-3);border-radius:999px;background:var(--color-accent-soft);color:var(--color-heading);font-weight:600;font-size:.85rem}.reader-chip--muted{background:#94a3b826;color:var(--color-text-muted)}.reader-chip--surface{background:var(--color-panel);color:var(--color-text)}.reader-chapter-nav{gap:var(--space-1)}.reader-summary{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2);background:var(--color-panel-strong);margin-bottom:var(--space-2);display:flex;flex-direction:column;gap:var(--space-3);flex-shrink:0}.reader-summary__meta{display:flex;flex-wrap:wrap;gap:var(--space-2)}.reader-summary__title{margin:0 0 var(--space-2);color:var(--color-heading);font-size:1rem}.reader-summary__body{color:var(--color-text);line-height:1.6}.reader-summary__status{margin:0;color:var(--color-text-muted);font-size:.9rem}.reader-summary__status--error{color:var(--color-danger)}.reader-summary--empty{align-items:center;text-align:center;background:var(--color-panel-soft)}.reader-status{margin:0 0 var(--space-3);color:var(--color-text-muted);font-size:.9rem}.reader-status--inline{margin-left:var(--space-2)}.reader-status-row{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);font-size:.9rem;color:var(--color-text-muted)}.link-button{background:none;border:none;padding:0;color:var(--color-accent);font-size:.9rem;font-weight:600;cursor:pointer}.link-button:hover{text-decoration:underline;background:none}.reader-pane{display:flex;flex-direction:column;gap:var(--space-2);flex-shrink:0}.reader-pane--split{flex-direction:row;gap:var(--space-3)}.reader-pane__column{border:none;border-radius:0;padding:var(--space-2) 0 var(--space-4);background:transparent;min-height:200px}.reader-chapter-spacer{height:var(--space-7)}.reader-pane--split .reader-pane__column{flex:1}.reader-pane__nav{z-index:4;width:2.5rem;height:2.5rem;border-radius:999px;background:var(--color-surface);color:var(--color-heading);border-color:var(--color-border);box-shadow:none;pointer-events:auto}.reader-pane__nav:active{transform:none}.reader-pane__nav:disabled{transform:none}.reader-card__nav .reader-pane__nav{pointer-events:auto}.reader-chapter-title{font-family:var(--font-scripture);font-weight:600;margin:0 0 var(--space-2);font-size:1rem;color:var(--color-heading)}.commentary-panel{font-family:var(--font-commentary);font-weight:400;display:flex;flex-direction:column;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-panel);padding:var(--space-2);height:100%}.commentary-panel__header{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.commentary-panel__header h3{margin:0;color:var(--color-heading)}.commentary-panel__header small{color:var(--color-text-muted)}.commentary-panel__body{flex:1;overflow-y:auto;padding-right:var(--space-2)}.commentary-panel__status{color:var(--color-text-muted)}.commentary-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-3)}.commentary-entry{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);background:var(--color-panel-strong)}.commentary-entry header{font-size:.85rem;color:var(--color-text-muted);margin-bottom:var(--space-2)}.commentary-entry p{margin:0;line-height:1.6;font-family:var(--font-commentary);font-weight:400}.commentary-entry--active{border-color:var(--color-accent);box-shadow:0 0 0 1px var(--color-accent-soft)}.context-tabs{display:inline-flex;gap:var(--space-2);margin-top:var(--space-3);margin-bottom:var(--space-3)}.context-tab{border:1px solid var(--color-border);background:transparent;color:var(--color-text);border-radius:999px;padding:var(--space-2) var(--space-2)}.context-tab--active{border-color:var(--color-accent);color:var(--color-accent)}.crossref-list{display:flex;flex-direction:column;gap:var(--space-3)}.crossref-group{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);background:linear-gradient(180deg,#94a3b814,#94a3b805),var(--color-panel-strong)}.crossref-group__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.crossref-group__header h4{margin:0}.crossref-group__badge{background:var(--color-accent-soft);color:var(--color-accent);font-size:.75rem;border-radius:999px;padding:0 var(--space-2)}.crossref-group ul{list-style:none;padding:0;margin:0}.crossref-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--space-2)}.crossref-grid li{display:flex;flex-direction:column;gap:var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-2)}.crossref-group small{color:var(--color-text-muted)}.crossref-actions{display:flex;gap:var(--space-2)}.crossref-selected,.context-selected{display:flex;gap:var(--space-2);align-items:baseline;margin-bottom:var(--space-3);color:var(--color-text-muted)}.history-panel{display:flex;flex-direction:column;gap:var(--space-2)}.history-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-2)}.history-entry__button{width:100%;text-align:left;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2);background:var(--color-panel-strong);display:flex;flex-direction:column;gap:var(--space-1);color:var(--color-heading)}.history-entry__button:hover{border-color:var(--color-accent)}.history-entry__label{font-weight:600}.history-entry__meta{color:var(--color-text-muted);font-size:.85rem}.modal-overlay{position:fixed;inset:0;background:#0f172a59;display:flex;align-items:center;justify-content:center;padding:var(--space-2);z-index:10}.modal{width:min(420px,100%);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4)}.modal__header{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);border-bottom:1px solid var(--color-border);padding-bottom:var(--space-2)}.modal__header h4{margin:0}.modal__body{color:var(--color-text);line-height:1.6}.modal__close{border:1px solid transparent;background:#94a3b833;border-radius:var(--radius-sm);padding:var(--space-1);color:var(--color-heading)}.verse-preview__label{font-weight:600;margin:0 0 var(--space-2)}.verse-preview--text{white-space:pre-wrap;word-break:break-word}.verse-preview__jump{margin-top:var(--space-2);align-self:flex-start;padding:var(--space-2) var(--space-3)}.landing{min-height:calc(100vh - 80px);display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-4);align-items:center;justify-content:center}.landing__hero{background:var(--color-panel-strong);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-card);max-width:720px;width:100%}.landing__eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;color:var(--color-text-muted);margin:0 0 var(--space-2)}.landing__hero h1{margin:0 0 var(--space-2)}.landing__lede{margin:0 0 var(--space-3);color:var(--color-text-muted)}.landing__skip{display:inline-flex;align-items:center;gap:var(--space-1)}.landing__login-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3);background:var(--color-surface);display:flex;flex-direction:column;gap:var(--space-2);margin:var(--space-3) 0;box-shadow:var(--shadow-card)}.route-loading{height:220px;border-radius:var(--radius-lg);background:linear-gradient(90deg,#94a3b814,#94a3b833,#94a3b814);background-size:200% 100%;animation:shimmer 1.5s infinite}.changelog-list{display:flex;flex-direction:column;gap:var(--space-4)}.changelog-entry__meta{display:flex;align-items:baseline;gap:var(--space-2);margin-bottom:var(--space-2)}.changelog-entry__date{font-size:.85rem;color:var(--color-text-muted);font-weight:600}.changelog-entry ul{margin:0;padding-left:var(--space-6)}.landing__login-header{display:flex;align-items:center;gap:var(--space-2)}.landing__login-row{display:flex;gap:var(--space-2);flex-wrap:wrap}.landing__login-row .button-primary{background:var(--color-accent);color:#fff;border:1px solid var(--color-accent)}.landing__login-label{font-weight:600;color:var(--color-heading)}.landing__login input,.landing__login-form input{padding:var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:200px;background:var(--color-surface)}.landing__login-form{display:grid;gap:var(--space-2)}.landing__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-3);width:100%;max-width:960px}@media(min-width:720px){.landing__grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.landing__skip-floating{position:fixed;right:var(--space-3);bottom:var(--space-3);display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-decoration:none;color:var(--color-heading);box-shadow:var(--shadow-card);z-index:30}.landing__tile{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-panel-strong);color:var(--color-heading);text-decoration:none;transition:border-color .12s ease,transform .12s ease}.landing__tile:hover{border-color:var(--color-accent);transform:translateY(-2px)}.landing__icon{width:42px;height:42px;border-radius:var(--radius-md);background:var(--color-accent-soft);color:var(--color-accent);display:inline-flex;align-items:center;justify-content:center}.landing__body h3{margin:0 0 var(--space-1)}.landing__body p{margin:0;color:var(--color-text-muted)}.cookie-banner{position:fixed;bottom:var(--space-3);right:var(--space-3);left:auto;max-width:360px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2);z-index:20}.cookie-banner p{margin:var(--space-1) 0 0;color:var(--color-text-muted)}.cookie-banner__actions{display:flex;justify-content:flex-end;gap:var(--space-2)}.timeline-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-3)}.timeline-event{border-left:2px solid var(--color-border);padding-left:var(--space-3)}.timeline-event--inline{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);background:var(--color-panel-strong)}.timeline-event--active{border-left-color:var(--color-accent);background:var(--color-accent-soft);border-radius:var(--radius-md);padding:var(--space-3)}.timeline-event__title{display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-1)}.timeline-year{font-weight:700;color:var(--color-heading)}.timeline-name{font-weight:600;color:var(--color-text)}.timelinejs-container{width:100%;min-height:640px;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;background:var(--color-panel-strong)}.timeline-full{display:flex;flex-direction:column;min-height:calc(100vh - 80px);gap:var(--space-4)}.timeline-full__body{flex:1;display:flex}.timeline-full__body .timelinejs-container{flex:1}.timelinejs-container--inline{min-height:115px;font-size:.9rem;line-height:1.3;overflow:visible}.timelinejs-container--inline .tl-menubar button[aria-label="Return to Title"]{display:none!important}.timeline-event__meta{display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-1)}.timeline-event__meta strong{color:var(--color-heading)}.crossref-grid--full{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.timeline-inline{margin-top:var(--space-2)}.timeline-inline__controls{display:flex;justify-content:flex-end;margin-bottom:var(--space-2)}.timeline-inline__controls--overlay{position:absolute;right:var(--space-2);top:var(--space-2);gap:var(--space-1);z-index:6;pointer-events:auto}.timeline-inline__controls--overlay .icon-button{background:var(--color-panel);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;padding:0}.timeline-inline__controls--overlay .icon-button:hover{background:var(--color-accent-strong);border-color:var(--color-accent);color:var(--color-text-hover)}.timeline-inline__body{position:relative;z-index:1}.timeline-inline__overlay{position:absolute;inset:0;background:linear-gradient(180deg,#fffc,#fff9);padding:var(--space-3);box-sizing:border-box;z-index:3;pointer-events:none}.timeline-inline__body .tl-timeline .tl-menubar button[aria-label="Go to the last slide"],.timeline-inline__body .tl-timeline .tl-menubar button[aria-label="Return to Title"]{display:none!important}.timelinejs-container--inline{position:relative;z-index:2}.canon-tree{display:flex;flex-direction:column;gap:var(--space-2)}.canon-tree--panel{border:none;padding:0;background:transparent}.canon-tree__header{display:flex;flex-wrap:wrap;justify-content:space-between;gap:var(--space-3)}.canon-tree__header h2{margin:0}.canon-tree__status{margin:0;color:var(--color-text-muted)}.canon-tree__controls{display:flex;flex-wrap:wrap;gap:var(--space-3)}.canon-tree__select{min-width:200px}.canon-dropdown{display:flex;flex-direction:column;gap:var(--space-2)}.canon-dropdown__item{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface)}.canon-dropdown__trigger{width:100%;display:flex;justify-content:space-between;align-items:center;padding:var(--space-3);background:transparent;border:none;color:var(--color-text);text-align:left}.canon-dropdown__trigger small{color:var(--color-text-muted);margin-left:var(--space-2)}.canon-dropdown__trigger:hover{background:var(--color-accent-soft)}.canon-tree__book-actions{display:flex;align-items:center;gap:var(--space-2)}.canon-tree__toggle{display:inline-flex;align-items:center;gap:var(--space-1)}.canon-tree__progress{font-size:.8rem;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);background:var(--color-accent-soft);color:var(--color-accent)}.canon-tree__progress[data-complete=true]{background:#22c55e26;color:#22c55e}.canon-tree__chevron{transition:transform .2s ease}.canon-tree__chevron--open{transform:rotate(180deg)}.canon-chapters{padding:0 var(--space-3) var(--space-3);display:flex;flex-wrap:wrap;gap:var(--space-2)}.canon-chapters__button{width:30px;height:30px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-panel-strong);color:var(--color-text);font-size:.75rem}.canon-chapters__button--active{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.context-card{display:flex;flex-direction:column;min-height:100%}.context-card__tabs{display:flex;flex-wrap:nowrap;gap:var(--space-1);margin-bottom:var(--space-2);border-bottom:1px solid var(--color-border);align-items:flex-end}.context-card__tabs--stacked{flex-direction:column;align-items:stretch;gap:var(--space-2)}.context-card__tabs--stacked .context-tab{width:100%;justify-content:center}.context-card__tabs .context-tab{border:none;background:transparent;color:var(--color-text-muted);padding:var(--space-2) var(--space-3);border-bottom:2px solid transparent;border-radius:0;display:inline-flex;align-items:center;gap:var(--space-2);font-weight:500}.context-card__tabs .context-tab--active{color:var(--color-text);border-bottom-color:var(--color-accent);font-weight:600}.context-card__toggle{margin-left:auto;display:inline-flex;align-items:center;justify-content:center;padding:var(--space-2)}.context-card__content{flex:1;display:flex;min-height:0;overflow-y:auto}.context-card--collapsed{width:auto;padding:var(--space-2)}.reader-layout--context-collapsed{grid-template-columns:minmax(0,1fr) var(--reader-splitter-width, var(--space-3)) max-content}.reader-layout--context-collapsed .context-card{width:auto}.context-card--collapsed .context-card__tabs{flex-direction:column;align-items:center;justify-content:flex-start;border-bottom:none;gap:var(--space-2)}.context-card--collapsed .context-tab{display:inline-flex;writing-mode:vertical-rl;text-orientation:mixed;padding:var(--space-1);border:1px solid transparent}.context-card--collapsed .context-tab--active{border-color:var(--color-accent);background:var(--color-panel);border-radius:var(--radius-sm)}.context-card--collapsed .context-card__toggle,.context-card--collapsed .context-card__content{display:none}.context-card__content>*{width:100%;height:100%}.context-card__loading,.context-card__empty{width:100%;border:1px dashed var(--color-border);border-radius:var(--radius-md);padding:var(--space-2);text-align:center;color:var(--color-text-muted)}.context-card .commentary-panel,.context-card .crossref-list,.context-card .timeline-list,.context-card .topic-detail,.context-card .place-detail{height:100%;display:flex;flex-direction:column}.error{color:var(--color-danger);font-weight:600}.verse-entry{margin-bottom:var(--space-3);display:block}.reader-page[data-inline-commentary=false] .verse-entry{display:inline;margin-bottom:0}.verse-entry--focused{background:var(--color-verse-focus-bg)}.verse-line{gap:var(--space-2);line-height:1.45;display:flex;align-items:baseline}.reader-page[data-inline-commentary=false] .verse-line{display:inline;line-height:1.6}.verse-text{flex:1;font-family:var(--font-scripture);font-weight:600}.reader-page[data-inline-commentary=false] .verse-text{display:inline;font-weight:500}.reader-page[data-inline-commentary=false] .verse-heading{margin-top:var(--space-3)}.verse-context-button{margin-left:var(--space-1);padding:0;display:inline-flex;align-items:center;gap:var(--space-1);font-size:.85rem;font-weight:600}.verse-context-button svg{width:14px;height:14px}.verse-marker{color:var(--color-accent);font-weight:600}.reader-page[data-inline-commentary=false] .verse-marker{margin-right:var(--space-1)}.verse-commentary{margin-top:var(--space-2);margin-left:calc(var(--space-4) + var(--space-2));display:flex;flex-direction:column;gap:var(--space-1);font-family:var(--font-commentary);font-weight:400}.verse-commentary__entry{background:transparent;border:none;border-radius:var(--radius-sm);padding:var(--space-2) var(--space-3);font-size:1em;line-height:1.4;color:var(--color-text-muted)}.verse-actions{margin-top:var(--space-2);display:flex;gap:var(--space-2);flex-wrap:wrap}.icon-button{background:#94a3b833;color:var(--color-heading);border:1px solid transparent;padding:calc(var(--space-2) - 1px) var(--space-3);font-size:.85rem;border-radius:var(--radius-sm);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-1)}.icon-button--square{padding:var(--space-2);width:2.25rem;height:2.25rem}.icon-button:hover{border-color:var(--color-border)}.skeleton-line{height:1rem;border-radius:var(--radius-sm);background:linear-gradient(90deg,#94a3b81a,#94a3b84d,#94a3b81a);background-size:200% 100%;animation:shimmer 1.5s infinite;margin-bottom:var(--space-2)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.verse-heading{font-family:var(--font-scripture);font-weight:600;margin:0;padding-top:var(--space-2);font-size:1rem;color:var(--color-heading)}.connection-status{font-size:.8rem}.settings-form{display:flex;flex-direction:column;gap:var(--space-4)}.form-field{display:flex;flex-direction:column;gap:var(--space-2)}.form-field label{font-weight:600;color:var(--color-heading)}.form-field small{color:var(--color-text-muted);font-size:.85rem}.input-control{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);color:var(--color-text);resize:vertical}.input-control:focus{outline:2px solid var(--color-accent);outline-offset:1px;border-color:transparent}.settings-form__actions{display:flex;justify-content:flex-end}.status-pill{display:inline-flex;align-items:center;border-radius:999px;padding:var(--space-1) var(--space-3);background:var(--color-border);font-weight:600;color:var(--color-text)}.status-pill--success{background:var(--color-accent-soft);color:var(--color-accent)}@media(max-width:1024px){.app-shell{grid-template-columns:1fr;grid-template-rows:auto 1fr;grid-template-areas:"sidebar" "main"}.app-shell__sidebar{border-right:none;border-bottom:1px solid var(--color-border);flex-direction:row;flex-wrap:wrap;gap:var(--space-2)}.app-shell__meta{flex-direction:row;flex-wrap:wrap;gap:var(--space-3)}.reader-grid{grid-template-columns:1fr}}@media(max-width:720px){.app-shell__sidebar{flex-direction:column}.app-shell__quick-label{display:none}.app-shell__topbar{flex-direction:row;align-items:center}.app-shell__topbar-actions{width:auto;flex-wrap:nowrap;justify-content:flex-end;align-self:center}.canon-tree__chapters{grid-template-columns:repeat(auto-fit,minmax(80px,1fr))}}.topic-detail,.place-detail,.topic-picker{display:flex;flex-direction:column;gap:var(--space-3)}.topic-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-2)}.topic-list--nested{padding-left:var(--space-2);margin-top:var(--space-2)}.button-secondary--muted{opacity:.8}.topic-detail ul,.place-detail dl{margin:0;padding-left:var(--space-2)}.place-form{display:flex;flex-direction:column;gap:var(--space-3)}
