.header-e928854 {
  position: sticky;
  top: 0;
  z-index: var(--z-header, 100);
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 3.5rem;
  padding: var(--space-sm, 0.5rem) var(--space-md, 1rem);
  padding-top: calc(var(--space-sm, 0.5rem) + env(safe-area-inset-top));
  background: var(--bg);
  border-bottom: 0.0625rem solid var(--border, rgba(0, 0, 0, 0.1));
  overflow: hidden;
}

.progress-e928854 {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  z-index: -1;
  transition: width 0.15s ease-out;
}

.left-e928854,
.right-e928854 {
  display: flex;
  align-items: center;
  gap: var(--space-xs, 0.25rem);
  min-width: 2.5rem;
}

.title-e928854 {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm, 0.5rem);
  flex: 1;
}

.titleBtn-e928854 {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 1rem;
  font-weight: 600;
  color: var(--text, #1a1a1a);
  padding: 0.375rem 0.75rem;
  background: transparent;
  border: none;
  border-radius: 0.5rem;
  transition: all 0.15s ease;
  cursor: pointer;
}

.titleBtn-e928854:hover {
  background: var(--hover, rgba(0, 0, 0, 0.05));
}

.titleBtn-e928854 svg {
  width: 0.875rem;
  height: 0.875rem;
  opacity: 0.5;
}

.titleText-e928854 {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text, #1a1a1a);
}

.subtitleBtn-e928854 {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--accent-text, #8b7355);
  padding: 0.5rem 1rem;
  background: var(--accent-soft, rgba(139, 115, 85, 0.1));
  border: 1px solid var(--border, rgba(0, 0, 0, 0.1));
  border-radius: 100px;
  box-shadow: 0 1px 2px var(--shadow, rgba(0, 0, 0, 0.05));
  transition: all 0.2s ease;
  cursor: pointer;
}

.subtitleBtn-e928854:hover {
  background: var(--hover, rgba(0, 0, 0, 0.05));
  box-shadow: 0 4px 12px var(--shadow, rgba(0, 0, 0, 0.1));
  transform: translateY(-1px);
}

.subtitleBtn-e928854:active {
  transform: translateY(0);
}

.subtitleBtn-e928854 svg {
  width: 1rem;
  height: 1rem;
  color: var(--accent-text, #8b7355);
  transition: transform 0.2s ease;
}

.subtitleBtn-e928854:hover svg {
  transform: translateY(1px);
}

.subtitleText-e928854 {
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--accent-text, #8b7355);
  padding: 0.5rem 1rem;
  background: var(--accent-soft, rgba(139, 115, 85, 0.1));
  border-radius: 100px;
}

.btn-e928854 {
  width: 2.5rem;
  height: 2.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-lg, 0.75rem);
  color: var(--text-secondary, #666);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}

.btn-e928854:hover {
  background: var(--hover, rgba(0, 0, 0, 0.05));
  color: var(--text, #1a1a1a);
}


.toggle-abf0b7a {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs, 0.5rem);
  padding: var(--space-xs, 0.5rem) var(--space-md, 1rem);
  font-size: var(--text-sm, 0.875rem);
  font-weight: var(--font-medium, 500);
  color: var(--text-secondary, #666);
  background: var(--bg-elevated, #fff);
  border: 1px solid var(--border, rgba(0, 0, 0, 0.1));
  border-radius: var(--radius-full, 9999px);
  cursor: pointer;
  transition: all 0.15s ease;
}

.toggle-abf0b7a:hover {
  border-color: var(--accent, #8b7355);
  color: var(--text, #1a1a1a);
}

.toggleActive-abf0b7a {
  background: var(--accent-soft, rgba(139, 115, 85, 0.1));
  border-color: var(--accent, #8b7355);
  color: var(--accent-text, #8b7355);
}

.toggle-abf0b7a svg {
  width: 1rem;
  height: 1rem;
}
.bookNav-ab7efea {
  width: var(--thumb-width);
  height: calc(100dvh - var(--header-height) - var(--bottom-nav-height));
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
}

@media (min-width: 64rem) {
  .bookNav-ab7efea {
    height: calc(98dvh - var(--header-height));
  }
}

.left-ab7efea {
  align-items: flex-start;
}

.right-ab7efea {
  align-items: flex-end;
}

.book-ab7efea {
  flex: 1;
  width: 100%;
  display: flex;
  align-items: center;
  padding: 0 0.25rem;
  font-size: 0.5rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.15s ease;
  color: var(--text-muted);
  white-space: nowrap;
  overflow: hidden;
}

.left-ab7efea .book-ab7efea {
  justify-content: center;
  border-radius: 0 0.375rem 0.375rem 0;
}

.right-ab7efea .book-ab7efea {
  justify-content: center;
  border-radius: 0.375rem 0 0 0.375rem;
}

.abbrev-ab7efea {
  flex-shrink: 0;
}

.full-ab7efea {
  display: none;
  margin-left: 0.25rem;
}

.right-ab7efea .full-ab7efea {
  margin-left: 0;
  margin-right: 0.25rem;
}

.book-ab7efea:hover,
.book-ab7efea.active-ab7efea {
  width: max-content;
  padding: 0 0.5rem;
  z-index: 50;
  box-shadow: 0 0.125rem 0.5rem var(--shadow);
}

.book-ab7efea:hover .abbrev-ab7efea,
.book-ab7efea.active-ab7efea .abbrev-ab7efea {
  display: none;
}

.book-ab7efea:hover .full-ab7efea,
.book-ab7efea.active-ab7efea .full-ab7efea {
  display: inline;
}

.book-ab7efea.active-ab7efea {
  font-weight: 600;
  color: var(--text);
  text-shadow:
    -0.0625rem -0.0625rem 0 var(--bg),
    0.0625rem -0.0625rem 0 var(--bg),
    -0.0625rem 0.0625rem 0 var(--bg),
    0.0625rem 0.0625rem 0 var(--bg);
}


.panel-62aa236 {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  overflow-y: auto;
}

.list-62aa236 {
  list-style: none;
  padding: 0;
  margin: 0;
}

.chapterItem-62aa236 {
  border-bottom: 1px solid var(--border);
}

.chapterRow-62aa236 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.875rem 0.5rem;
}

.chapterRow-62aa236.active-62aa236 {
  background: var(--accent-soft);
}

.chapterTitle-62aa236 {
  font-size: 1.0625rem;
  font-weight: 600;
  color: var(--text);
}

.chapterRow-62aa236.active-62aa236 .chapterTitle-62aa236 {
  color: var(--accent-text);
}

.actions-62aa236 {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.readBtn-62aa236 {
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-inverse);
  background: var(--accent);
  border-radius: 0.5rem;
  transition: all 0.15s ease;
  cursor: pointer;
}

.readBtn-62aa236:hover {
  box-shadow: 0 2px 8px var(--shadow);
  transform: translateY(-1px);
  filter: brightness(1.1);
}

.contentBtn-62aa236 {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.5rem 0.75rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-secondary);
  background: var(--bg-secondary);
  border-radius: 0.5rem;
  transition: all 0.15s ease;
  cursor: pointer;
}

.contentBtn-62aa236:hover {
  background: var(--hover);
  color: var(--text);
}

.contentBtn-62aa236 svg {
  width: 0.875rem;
  height: 0.875rem;
}

.pericopes-62aa236 {
  list-style: none;
  padding: 0.5rem 0.5rem 0.75rem 1rem;
  margin: 0;
  background: var(--bg-secondary);
  border-top: 1px solid var(--border);
}

.pericope-62aa236 {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  padding: 0.5rem 0;
}

.verseRange-62aa236 {
  flex-shrink: 0;
  min-width: 2.5rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--accent-text);
  font-variant-numeric: tabular-nums;
}

.pericopeText-62aa236 {
  font-size: 0.9375rem;
  color: var(--text-secondary);
  line-height: 1.4;
}

.verseCountBadge-62aa236 {
  font-size: 0.8125rem;
  color: var(--text-muted);
  padding: 0.375rem 0.625rem;
  background: var(--bg-secondary);
  border-radius: 0.375rem;
}

.grid-62aa236 {
  flex: 1;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(3rem, 1fr));
  grid-auto-rows: 1fr;
  gap: 0.5rem;
  align-content: start;
}

.btn-62aa236 {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 2.75rem;
  border-radius: 0.625rem;
  font-size: 1rem;
  font-weight: 500;
  background: var(--bg-secondary);
  color: var(--text-secondary);
  border: 1px solid transparent;
  transition: all 0.15s ease;
  cursor: pointer;
}

.btn-62aa236:hover {
  background: var(--hover);
  border-color: var(--accent);
  color: var(--text);
  transform: scale(1.05);
}

.btn-62aa236.active-62aa236 {
  background: var(--accent);
  color: var(--text-inverse);
  font-weight: 600;
  box-shadow: 0 2px 8px var(--shadow);
  border-color: transparent;
}

.btn-62aa236.active-62aa236:hover {
  transform: scale(1.05);
  filter: brightness(1.1);
}

.tabs-62aa236 {
  display: flex;
  gap: 0.25rem;
  padding: 0.5rem;
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border);
}

.tab-62aa236 {
  flex: 1;
  padding: 0.75rem 1rem;
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--text-secondary);
  background: transparent;
  border-radius: 0.5rem;
  transition: all 0.15s ease;
  cursor: pointer;
}

.tab-62aa236:hover {
  background: var(--hover);
  color: var(--text);
}

.tabActive-62aa236 {
  background: var(--accent);
  color: var(--text-inverse);
}

.tabActive-62aa236:hover {
  background: var(--accent);
  color: var(--text-inverse);
  filter: brightness(1.1);
}

.booksList-62aa236 {
  list-style: none;
  padding: 0.5rem;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.bookItem-62aa236 {
  width: 100%;
  padding: 0.75rem 1rem;
  font-size: 0.9375rem;
  font-weight: 500;
  text-align: left;
  color: var(--text);
  background: transparent;
  border-radius: 0.5rem;
  transition: all 0.15s ease;
  cursor: pointer;
}

.bookItem-62aa236:hover {
  background: var(--hover);
}

.bookItemActive-62aa236 {
  font-weight: 600;
  color: var(--text-inverse);
}


.torah-7845bfc {
  background: color-mix(in srgb, var(--cat-torah) 20%, transparent);
}
.torah-7845bfc.active-7845bfc { background: var(--cat-torah); }

.history-7845bfc {
  background: color-mix(in srgb, var(--cat-history) 20%, transparent);
}
.history-7845bfc.active-7845bfc { background: var(--cat-history); }

.wisdom-7845bfc {
  background: color-mix(in srgb, var(--cat-wisdom) 20%, transparent);
}
.wisdom-7845bfc.active-7845bfc { background: var(--cat-wisdom); }

.majorProphets-7845bfc {
  background: color-mix(in srgb, var(--cat-major-prophets) 20%, transparent);
}
.majorProphets-7845bfc.active-7845bfc { background: var(--cat-major-prophets); }

.minorProphets-7845bfc {
  background: color-mix(in srgb, var(--cat-minor-prophets) 20%, transparent);
}
.minorProphets-7845bfc.active-7845bfc { background: var(--cat-minor-prophets); }

.gospels-7845bfc {
  background: color-mix(in srgb, var(--cat-gospels) 20%, transparent);
}
.gospels-7845bfc.active-7845bfc { background: var(--cat-gospels); }

.acts-7845bfc {
  background: color-mix(in srgb, var(--cat-acts) 20%, transparent);
}
.acts-7845bfc.active-7845bfc { background: var(--cat-acts); }

.paul-7845bfc {
  background: color-mix(in srgb, var(--cat-paul) 20%, transparent);
}
.paul-7845bfc.active-7845bfc { background: var(--cat-paul); }

.general-7845bfc {
  background: color-mix(in srgb, var(--cat-general) 20%, transparent);
}
.general-7845bfc.active-7845bfc { background: var(--cat-general); }

.revelation-7845bfc {
  background: color-mix(in srgb, var(--cat-revelation) 20%, transparent);
}
.revelation-7845bfc.active-7845bfc { background: var(--cat-revelation); }


/* Common page styles - 2025 modern design */

/* Page layout */
.page-cb17011 {
  min-height: 100vh;
  min-height: 100dvh;
  background: var(--bg);
  padding-bottom: calc(var(--bottom-nav-height) + env(safe-area-inset-bottom));
}

@media (min-width: 64rem) {
  .page-cb17011 {
    padding-bottom: 0;
  }
}

.container-cb17011 {
  max-width: 32rem;
  margin: 0 auto;
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

/* Card */
.card-cb17011 {
  background: var(--bg-elevated);
  border-radius: var(--radius-xl);
  padding: var(--space-md);
  box-shadow: 0 0.0625rem 0.25rem var(--shadow);
}

.cardHover-cb17011 {
  transition: background 0.15s;
}

.cardHover-cb17011:hover {
  background: var(--hover);
}

/* Section */
.section-cb17011 {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.sectionTitle-cb17011 {
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding-left: var(--space-xs);
}

.sectionContent-cb17011 {
  background: var(--bg-elevated);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: 0 0.0625rem 0.25rem var(--shadow);
}

/* Empty state */
.emptyState-cb17011 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--space-2xl) var(--space-md);
}

.emptyIcon-cb17011 {
  width: 4rem;
  height: 4rem;
  margin-bottom: var(--space-lg);
  color: var(--text-muted);
  opacity: 0.5;
}

.emptyIcon-cb17011 svg {
  width: 100%;
  height: 100%;
}

.emptyTitle-cb17011 {
  font-size: var(--text-xl);
  font-weight: var(--font-semibold);
  color: var(--text);
  margin-bottom: var(--space-xs);
}

.emptyDesc-cb17011 {
  font-size: var(--text-md);
  color: var(--text-muted);
  max-width: 20rem;
}

/* Buttons */
.btnPrimary-cb17011 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-xs);
  padding: var(--space-sm) var(--space-lg);
  background: var(--accent);
  color: var(--text-inverse);
  border-radius: var(--radius-lg);
  font-weight: var(--font-semibold);
  font-size: var(--text-md);
  transition: opacity 0.15s, transform 0.15s;
}

.btnPrimary-cb17011:hover {
  opacity: 0.9;
}

.btnPrimary-cb17011:active {
  transform: scale(0.98);
}

.btnPrimary-cb17011:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.btnSecondary-cb17011 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-xs);
  padding: var(--space-sm) var(--space-lg);
  background: var(--bg-secondary);
  color: var(--text);
  border-radius: var(--radius-lg);
  font-weight: var(--font-medium);
  font-size: var(--text-md);
  transition: background 0.15s;
}

.btnSecondary-cb17011:hover {
  background: var(--hover);
}

.btnGhost-cb17011 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-xs);
  padding: var(--space-sm) var(--space-md);
  background: transparent;
  color: var(--text-secondary);
  border-radius: var(--radius-lg);
  font-weight: var(--font-medium);
  transition: background 0.15s, color 0.15s;
}

.btnGhost-cb17011:hover {
  background: var(--hover);
  color: var(--text);
}

.btnIcon-cb17011 {
  width: 2.5rem;
  height: 2.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-lg);
  color: var(--text-secondary);
  transition: background 0.15s, color 0.15s;
}

.btnIcon-cb17011:hover {
  background: var(--hover);
  color: var(--text);
}

.btnIcon-cb17011 svg {
  width: 1.25rem;
  height: 1.25rem;
}

/* Input */
.input-cb17011 {
  width: 100%;
  padding: var(--space-sm) var(--space-md);
  background: var(--bg-elevated);
  border: 0.0625rem solid var(--border);
  border-radius: var(--radius-lg);
  color: var(--text);
  font-size: var(--text-md);
  transition: border-color 0.15s, box-shadow 0.15s;
}

.input-cb17011::placeholder {
  color: var(--text-muted);
}

.input-cb17011:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.searchInput-cb17011 {
  width: 100%;
  padding: var(--space-sm) var(--space-md) var(--space-sm) 3rem;
  background: var(--bg-elevated);
  border: 0.0625rem solid var(--border);
  border-radius: var(--radius-xl);
  color: var(--text);
  font-size: var(--text-md);
  transition: border-color 0.15s, box-shadow 0.15s;
}

.searchInput-cb17011::placeholder {
  color: var(--text-muted);
}

.searchInput-cb17011:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.searchWrapper-cb17011 {
  position: relative;
}

.searchIcon-cb17011 {
  position: absolute;
  left: var(--space-md);
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted);
}

.searchIcon-cb17011 svg {
  width: 1.25rem;
  height: 1.25rem;
}

/* Textarea */
.textarea-cb17011 {
  width: 100%;
  min-height: 8rem;
  padding: var(--space-sm) var(--space-md);
  background: var(--bg-elevated);
  border: 0.0625rem solid var(--border);
  border-radius: var(--radius-lg);
  color: var(--text);
  font-size: var(--text-md);
  resize: vertical;
  transition: border-color 0.15s, box-shadow 0.15s;
}

.textarea-cb17011::placeholder {
  color: var(--text-muted);
}

.textarea-cb17011:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

/* Selection card */
.selectionCard-cb17011 {
  display: block;
  width: 100%;
  padding: var(--space-md);
  background: var(--bg-elevated);
  border: 0.125rem solid var(--border);
  border-radius: var(--radius-xl);
  text-align: left;
  transition: border-color 0.15s, background 0.15s;
}

.selectionCard-cb17011:hover {
  background: var(--hover);
}

.selectionCardSelected-cb17011 {
  border-color: var(--accent);
  background: var(--accent-soft);
}

/* Badge */
.badge-cb17011 {
  display: inline-block;
  padding: var(--space-2xs) var(--space-xs);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  border-radius: var(--radius-md);
  background: var(--accent-soft);
  color: var(--accent-text);
}

/* Tabs */
.tabs-cb17011 {
  display: flex;
  gap: var(--space-xs);
  background: var(--bg-secondary);
  padding: var(--space-2xs);
  border-radius: var(--radius-lg);
}

.tab-cb17011 {
  flex: 1;
  padding: var(--space-xs) var(--space-md);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--text-secondary);
  transition: all 0.15s;
  text-align: center;
}

.tab-cb17011:hover {
  color: var(--text);
}

.tabActive-cb17011 {
  background: var(--bg-elevated);
  color: var(--text);
  box-shadow: 0 0.0625rem 0.25rem var(--shadow);
}

/* Progress steps */
.progressSteps-cb17011 {
  display: flex;
  gap: var(--space-xs);
}

.progressStep-cb17011 {
  flex: 1;
  height: 0.25rem;
  background: var(--border);
  border-radius: var(--radius-full);
  transition: background 0.3s;
}

.progressStepComplete-cb17011 {
  background: var(--accent);
}

/* List item */
.listItem-cb17011 {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-lg);
  transition: background 0.15s;
}

.listItem-cb17011:hover {
  background: var(--hover);
}

.listItemBorder-cb17011 {
  border-bottom: 0.0625rem solid var(--border);
}

.listItemBorder-cb17011:last-child {
  border-bottom: none;
}

/* Link */
.link-cb17011 {
  color: var(--accent-text);
  transition: opacity 0.15s;
}

.link-cb17011:hover {
  opacity: 0.8;
}

/* Text */
.textPrimary-cb17011 {
  color: var(--text);
}

.textSecondary-cb17011 {
  color: var(--text-secondary);
}

.textMuted-cb17011 {
  color: var(--text-muted);
}

.textSm-cb17011 {
  font-size: var(--text-sm);
}

.textXs-cb17011 {
  font-size: var(--text-xs);
}

.textLg-cb17011 {
  font-size: var(--text-lg);
}

.textXl-cb17011 {
  font-size: var(--text-xl);
}

.text2xl-cb17011 {
  font-size: var(--text-2xl);
}

.fontMedium-cb17011 {
  font-weight: var(--font-medium);
}

.fontSemibold-cb17011 {
  font-weight: var(--font-semibold);
}

.fontBold-cb17011 {
  font-weight: var(--font-bold);
}

/* Flex utilities */
.flex-cb17011 {
  display: flex;
}

.flexCol-cb17011 {
  flex-direction: column;
}

.flexCenter-cb17011 {
  align-items: center;
  justify-content: center;
}

.flexBetween-cb17011 {
  justify-content: space-between;
}

.gap1-cb17011 {
  gap: var(--space-2xs);
}

.gap2-cb17011 {
  gap: var(--space-xs);
}

.gap3-cb17011 {
  gap: var(--space-sm);
}

.gap4-cb17011 {
  gap: var(--space-md);
}

/* Spacing */
.mb2-cb17011 {
  margin-bottom: var(--space-xs);
}

.mb4-cb17011 {
  margin-bottom: var(--space-md);
}

.mb6-cb17011 {
  margin-bottom: var(--space-lg);
}

.mt4-cb17011 {
  margin-top: var(--space-md);
}

.mt6-cb17011 {
  margin-top: var(--space-lg);
}

.py8-cb17011 {
  padding-top: var(--space-2xl);
  padding-bottom: var(--space-2xl);
}

/* Grid */
.grid2-cb17011 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-sm);
}

/* Feature card */
.featureCard-cb17011 {
  background: var(--bg-elevated);
  border-radius: var(--radius-xl);
  padding: var(--space-md);
  text-align: center;
  box-shadow: 0 0.0625rem 0.25rem var(--shadow);
}

.featureIcon-cb17011 {
  width: 3rem;
  height: 3rem;
  margin: 0 auto var(--space-sm);
  color: var(--accent-text);
}

.featureIcon-cb17011 svg {
  width: 100%;
  height: 100%;
}

.featureTitle-cb17011 {
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  color: var(--text);
  margin-bottom: var(--space-2xs);
}

.featureDesc-cb17011 {
  font-size: var(--text-xs);
  color: var(--text-muted);
}

/* Hero */
.heroIcon-cb17011 {
  width: 6rem;
  height: 6rem;
  margin: 0 auto var(--space-lg);
  border-radius: var(--radius-xl);
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--accent), var(--accent-hover));
  box-shadow: 0 0.5rem 1.5rem var(--accent-soft);
}

.heroIcon-cb17011 svg {
  width: 3rem;
  height: 3rem;
  color: var(--text-inverse);
}

.heroTitle-cb17011 {
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  color: var(--text);
  text-align: center;
  margin-bottom: var(--space-sm);
}

.heroSubtitle-cb17011 {
  font-size: var(--text-md);
  color: var(--text-secondary);
  text-align: center;
  max-width: 20rem;
  margin: 0 auto var(--space-xl);
}

/* Label */
.label-cb17011 {
  display: block;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin-bottom: var(--space-xs);
}

/* Result count */
.resultCount-cb17011 {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin-bottom: var(--space-md);
}

/* Spinner */
.spinner-cb17011 {
  display: flex;
  justify-content: center;
  padding: var(--space-xl);
}

.spinnerCircle-cb17011 {
  width: 2rem;
  height: 2rem;
  border: 0.125rem solid var(--accent);
  border-top-color: transparent;
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}


.header-e928854 {
  position: sticky;
  top: 0;
  z-index: var(--z-header);
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 3.5rem;
  padding: var(--space-sm) var(--space-md);
  padding-top: calc(var(--space-sm) + env(safe-area-inset-top));
  background: transparent;
  border-bottom: 0.0625rem solid var(--border);
  overflow: hidden;
}

.progress-e928854 {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  z-index: -1;
  transition: width 0.15s ease-out;
}

.title-e928854 {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
}

.book-e928854 {
  display: block;
  font-size: var(--text-md);
  font-weight: var(--font-semibold);
}

.bookBtn-e928854 {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 1rem;
  font-weight: 600;
  color: var(--text);
  padding: 0.375rem 0.75rem;
  background: transparent;
  border: none;
  border-radius: 0.5rem;
  transition: all 0.15s ease;
  cursor: pointer;
}

.bookBtn-e928854:hover {
  background: var(--hover);
}

.bookBtn-e928854 svg {
  width: 0.875rem;
  height: 0.875rem;
  opacity: 0.5;
}

.chapter-e928854 {
  display: block;
  font-size: var(--text-xs);
  color: var(--text-muted);
}

.chapterBtn-e928854 {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--accent-text);
  padding: 0.5rem 1rem;
  background: var(--accent-soft);
  border: 1px solid var(--border);
  border-radius: 100px;
  box-shadow: 0 1px 2px var(--shadow);
  transition: all 0.2s ease;
  cursor: pointer;
}

.chapterBtn-e928854:hover {
  background: var(--hover);
  box-shadow: 0 4px 12px var(--shadow);
  transform: translateY(-1px);
}

.chapterBtn-e928854:active {
  transform: translateY(0);
}

.chapterBtn-e928854 svg {
  width: 1rem;
  height: 1rem;
  color: var(--accent-text);
  transition: transform 0.2s ease;
}

.chapterBtn-e928854:hover svg {
  transform: translateY(1px);
}

.btn-e928854 {
  width: 2.5rem;
  height: 2.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-lg);
  color: var(--text-secondary);
  transition: background 0.15s, color 0.15s;
}

.btn-e928854:hover {
  background: var(--hover);
  color: var(--text);
}


.bottomNav-c8dd931 {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: var(--z-modal);
  background: var(--bg-elevated);
  backdrop-filter: blur(0.75rem);
  border-top: 0.0625rem solid var(--border);
  padding-bottom: env(safe-area-inset-bottom);
  transition: background 0.2s;
}

.bottomNavInner-c8dd931 {
  display: flex;
  justify-content: space-around;
  align-items: center;
  max-width: 32rem;
  margin: 0 auto;
  padding: var(--space-xs) 0;
}

@media (min-width: 64rem) {
  .bottomNav-c8dd931 { display: none; }
}

.navItem-c8dd931 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2xs);
  padding: var(--space-xs) var(--space-sm);
  border-radius: var(--radius-lg);
  color: var(--text-muted);
  transition: all var(--duration-fast);
}

.navItem-c8dd931:hover {
  background: var(--hover);
  color: var(--text-secondary);
}

.navItem-c8dd931.active-c8dd931,
.navItem-c8dd931.active {
  color: var(--accent-text);
}

.navItem-c8dd931 span { font-size: var(--text-xs); }

.sidebar-c8dd931 {
  display: none;
  flex-direction: column;
  height: 100dvh;
  position: sticky;
  top: 0;
  overflow: hidden;
  transition: all var(--duration-normal) var(--ease-out), background 0.2s;
}

.sidebarExpanded-c8dd931 { width: var(--sidebar-width); }
.sidebarCollapsed-c8dd931 { width: var(--sidebar-collapsed); }

.sidebar-c8dd931 > * {
  width: var(--sidebar-width);
  flex-shrink: 0;
}

@media (min-width: 64rem) {
  .sidebar-c8dd931 { display: flex; }
}

.sidebarHeader-c8dd931 {
  padding: var(--space-sm);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  min-width: max-content;
}

.sidebarLogo-c8dd931 {
  width: 2.5rem;
  height: 2.5rem;
  flex-shrink: 0;
  border-radius: var(--radius-lg);
  background: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0.125rem 0.5rem var(--shadow);
  transition: transform var(--duration-fast), box-shadow var(--duration-fast);
  cursor: pointer;
}

.sidebarLogo-c8dd931:hover {
  transform: scale(1.05);
}

.sidebarTitle-c8dd931 {
  font-size: var(--text-lg);
  font-weight: var(--font-bold);
  white-space: nowrap;
  overflow: hidden;
  color: var(--text);
}

.sidebarNav-c8dd931 { flex: 1; padding: 0 var(--space-xs); overflow: hidden; }
.sidebarBottom-c8dd931 { padding: var(--space-xs); margin-top: auto; }

.sidebarItem-c8dd931 {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-2xs);
  color: var(--text-secondary);
  transition: background var(--duration-fast), color var(--duration-fast);
  overflow: hidden;
}

.sidebarItem-c8dd931 svg {
  flex-shrink: 0;
  width: 1.5rem;
  height: 1.5rem;
}

.sidebarItem-c8dd931 span {
  white-space: nowrap;
  overflow: hidden;
}

.sidebarItem-c8dd931:hover {
  background: var(--hover);
  color: var(--text);
}

.sidebarItemActive-c8dd931 {
  background: var(--accent-soft);
  color: var(--accent-text);
  font-weight: var(--font-semibold);
}

.version-c8dd931 {
  padding: var(--space-xs) var(--space-sm);
  font-size: 0.75rem;
  color: var(--text-muted);
  text-align: center;
}

/* Page Header */
.header-c8dd931 {
  position: sticky;
  top: 0;
  z-index: var(--z-header);
  background: var(--bg);
  border-bottom: 0.0625rem solid var(--border);
  padding-top: env(safe-area-inset-top);
}

.headerInner-c8dd931 {
  display: grid;
  grid-template-columns: 2.5rem 1fr 2.5rem;
  align-items: center;
  min-height: 3.5rem;
  padding: var(--space-sm) var(--space-md);
  max-width: 32rem;
  margin: 0 auto;
}

.backBtn-c8dd931 {
  width: 2.5rem;
  height: 2.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-lg);
  color: var(--text-secondary);
  transition: background 0.15s, color 0.15s;
}

.backBtn-c8dd931:hover {
  background: var(--hover);
  color: var(--text);
}

.backBtn-c8dd931 svg {
  width: 1.25rem;
  height: 1.25rem;
}

.headerTitle-c8dd931 {
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  color: var(--text);
  margin: 0;
  text-align: center;
}

.headerSpacer-c8dd931 {
  width: 2.5rem;
}

.headerRight-c8dd931 {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  min-width: 2.5rem;
}


/* Profile page styles - 2025 modern design */

.page-e6a5d71 {
  min-height: 100vh;
  min-height: 100dvh;
  background: var(--bg);
  padding-bottom: calc(var(--bottom-nav-height) + env(safe-area-inset-bottom));
}

@media (min-width: 64rem) {
  .page-e6a5d71 {
    padding-bottom: 0;
  }
}

.container-e6a5d71 {
  max-width: 32rem;
  margin: 0 auto;
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

/* User card */
.userCard-e6a5d71 {
  background: var(--bg-elevated);
  border-radius: var(--radius-xl);
  padding: var(--space-lg);
  display: flex;
  align-items: center;
  gap: var(--space-md);
  box-shadow: 0 0.125rem 0.5rem var(--shadow);
}

.avatar-e6a5d71 {
  width: 4rem;
  height: 4rem;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), var(--accent-hover));
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.avatar-e6a5d71 svg {
  width: 1.75rem;
  height: 1.75rem;
  color: white;
  stroke: white;
}

.userInfo-e6a5d71 {
  flex: 1;
  min-width: 0;
}

.userName-e6a5d71 {
  font-size: var(--text-xl);
  font-weight: var(--font-semibold);
  color: var(--text);
  margin: 0;
}

.userId-e6a5d71 {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin-top: 0.25rem;
}

/* Section */
.section-e6a5d71 {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.sectionTitle-e6a5d71 {
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding-left: var(--space-xs);
}

.sectionContent-e6a5d71 {
  background: var(--bg-elevated);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: 0 0.0625rem 0.25rem var(--shadow);
}

/* Menu item */
.menuItem-e6a5d71 {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-md) var(--space-md);
  color: var(--text);
  text-decoration: none;
  transition: background 0.15s;
  border-bottom: 0.0625rem solid var(--border);
}

.menuItem-e6a5d71:last-child {
  border-bottom: none;
}

.menuItem-e6a5d71:hover {
  background: var(--hover);
}

.menuItem-e6a5d71:active {
  background: var(--pressed);
}

.menuIcon-e6a5d71 {
  width: 1.25rem;
  height: 1.25rem;
  color: var(--text-secondary);
  flex-shrink: 0;
}

.menuIcon-e6a5d71 svg {
  width: 100%;
  height: 100%;
}

.menuLabel-e6a5d71 {
  flex: 1;
  font-size: var(--text-md);
}

.menuArrow-e6a5d71 {
  width: 1rem;
  height: 1rem;
  color: var(--text-muted);
  flex-shrink: 0;
}

.menuArrow-e6a5d71 svg {
  width: 100%;
  height: 100%;
}

/* Connect button */
.connectBtn-e6a5d71 {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-md);
  width: 100%;
  background: none;
  border: none;
  color: var(--text);
  text-align: left;
  cursor: pointer;
  transition: background 0.15s;
  border-bottom: 0.0625rem solid var(--border);
}

.connectBtn-e6a5d71:last-child {
  border-bottom: none;
}

.connectBtn-e6a5d71:hover {
  background: var(--hover);
}

.connectBtn-e6a5d71:active {
  background: var(--pressed);
}

.connectBtn-e6a5d71:disabled {
  cursor: default;
}

.connectStatus-e6a5d71 {
  font-size: var(--text-sm);
  color: var(--text-muted);
}

.connectStatusDone-e6a5d71 {
  color: var(--success);
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.connectStatusDone-e6a5d71 svg {
  width: 1rem;
  height: 1rem;
}


.reader-1add189 {
  height: 100dvh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.content-1add189 {
  flex: 1;
  display: flex;
  align-items: stretch;
  gap: var(--space-xs);
  height: 0;
  overflow: hidden;
}

.text-1add189 {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
  padding: 1rem;
  overflow-y: auto;
  line-height: 1.75;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.text-1add189::-webkit-scrollbar {
  display: none;
}

.verseNum-1add189 {
  font-size: 0.7em;
  color: var(--accent-text);
  vertical-align: super;
}

.verseBlock-1add189 {
  display: block;
  margin-bottom: 0.5em;
}

.chapterNav-1add189 {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.5rem 0;
  margin-top: 1rem;
  border-top: 1px solid var(--border);
}

.navSpacer-1add189 {
  height: var(--bottom-nav-height);
  flex-shrink: 0;
}

@media (min-width: 64rem) {
  .navSpacer-1add189 {
    display: none;
  }
}

.navBtn-1add189 {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.25rem;
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--text);
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 0.5rem;
  cursor: pointer;
  transition: all 0.15s ease;
}

.navBtn-1add189:hover:not(:disabled) {
  background: var(--hover);
  border-color: var(--accent);
  color: var(--accent-text);
}

.navBtn-1add189:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.navBtn-1add189 svg {
  width: 1rem;
  height: 1rem;
}


/* Settings page styles - 2025 modern design */

.page-294f62b {
  min-height: 100vh;
  min-height: 100dvh;
  background: var(--bg);
}

.container-294f62b {
  max-width: 32rem;
  margin: 0 auto;
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

/* Section */
.section-294f62b {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.sectionTitle-294f62b {
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding-left: var(--space-xs);
}

.sectionContent-294f62b {
  background: var(--bg-elevated);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: 0 0.0625rem 0.25rem var(--shadow);
}

/* Row */
.row-294f62b {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-md);
  border-bottom: 0.0625rem solid var(--border);
}

.row-294f62b:last-child {
  border-bottom: none;
}

.rowLabel-294f62b {
  font-size: var(--text-md);
  color: var(--text);
}

.rowValue-294f62b {
  font-size: var(--text-md);
  color: var(--text-secondary);
}

/* Font size controls */
.sizeControls-294f62b {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.sizeBtn-294f62b {
  width: 2.5rem;
  height: 2.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-lg);
  background: var(--bg-secondary);
  color: var(--text);
  font-weight: var(--font-medium);
  transition: background 0.15s;
}

.sizeBtn-294f62b:hover {
  background: var(--hover);
}

.sizeBtn-294f62b:active {
  background: var(--active);
}

.sizeValue-294f62b {
  width: 2rem;
  text-align: center;
  font-weight: var(--font-medium);
  color: var(--text);
}

/* Font family buttons */
.fontBtns-294f62b {
  display: flex;
  gap: var(--space-xs);
}

.fontBtn-294f62b {
  padding: var(--space-xs) var(--space-md);
  border-radius: var(--radius-lg);
  background: var(--bg-secondary);
  color: var(--text);
  transition: all 0.15s;
}

.fontBtn-294f62b:hover {
  background: var(--hover);
}

.fontBtnActive-294f62b {
  background: var(--accent);
  color: var(--text-inverse);
}

.fontBtnSerif-294f62b {
  font-family: var(--font-serif);
}

.fontBtnSans-294f62b {
  font-family: var(--font-sans);
}

/* Theme buttons */
.themeBtns-294f62b {
  display: flex;
  gap: var(--space-xs);
}

.themeBtn-294f62b {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  border: 2px solid transparent;
  transition: all 0.15s;
}

.themeBtn-294f62b:hover {
  transform: scale(1.1);
}

.themeBtnActive-294f62b {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px var(--bg), 0 0 0 4px var(--accent);
}

.themeBtnLight-294f62b {
  background: #fefdfb;
  box-shadow: inset 0 0 0 1px #e5e5e5;
}

.themeBtnSepia-294f62b {
  background: #f4ecd8;
}

.themeBtnDark-294f62b {
  background: #1a1a1a;
}

/* Install button */
.installBtn-294f62b {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  padding: var(--space-xs) var(--space-md);
  background: var(--accent);
  color: var(--text-inverse);
  border-radius: var(--radius-lg);
  font-weight: var(--font-medium);
  transition: opacity 0.15s;
}

.installBtn-294f62b:hover {
  opacity: 0.9;
}

/* Status indicators */
.installed-294f62b {
  display: flex;
  align-items: center;
  gap: var(--space-2xs);
  color: var(--accent-text);
  font-weight: var(--font-medium);
}

.installed-294f62b svg {
  width: 1rem;
  height: 1rem;
}

.hint-294f62b {
  font-size: var(--text-sm);
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: var(--space-2xs);
}

.hint-294f62b svg {
  width: 0.875rem;
  height: 0.875rem;
  display: inline;
  vertical-align: middle;
}

/* Toggle switch */
.toggle-294f62b {
  width: 3rem;
  height: 1.75rem;
  padding: 0.125rem;
  background: var(--bg-secondary);
  border-radius: 1rem;
  cursor: pointer;
  transition: background 0.2s;
}

.toggleOn-294f62b {
  background: var(--accent);
}

.toggleThumb-294f62b {
  display: block;
  width: 1.5rem;
  height: 1.5rem;
  background: white;
  border-radius: 50%;
  box-shadow: 0 0.0625rem 0.25rem var(--shadow);
  transition: transform 0.2s;
}

.toggleOn-294f62b .toggleThumb-294f62b {
  transform: translateX(1.25rem);
}


.container-b251479 {
  min-height: calc(100dvh - var(--bottom-nav-height));
  background: var(--bg);
  padding-bottom: calc(var(--bottom-nav-height) + env(safe-area-inset-bottom));
}

@media (min-width: 64rem) {
  .container-b251479 {
    min-height: 100dvh;
    padding-bottom: 0;
  }
}

.header-b251479 {
  position: sticky;
  top: 0;
  z-index: var(--z-header);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  background: var(--bg);
  border-bottom: 1px solid var(--border);
}

.title-b251479 {
  flex: 1;
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  color: var(--text);
}

.iconBtn-b251479 {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: var(--radius-lg);
  color: var(--text-secondary);
  transition: background var(--duration-fast), color var(--duration-fast);
}

.iconBtn-b251479:hover {
  background: var(--hover);
  color: var(--text);
}

.iconBtn-b251479:active {
  transform: scale(0.95);
}

.content-b251479 {
  padding: var(--space-md);
}

.filterBar-b251479 {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-sm) var(--space-md);
}

.filterToggle-b251479 {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-xs) var(--space-md);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--text-secondary);
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: all var(--duration-fast);
}

.filterToggle-b251479:hover {
  border-color: var(--accent);
}

.filterToggleActive-b251479 {
  background: var(--accent-soft);
  border-color: var(--accent);
  color: var(--accent-text);
}

.filterToggle-b251479 svg {
  width: 1rem;
  height: 1rem;
}

.filterLabel-b251479 {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--text-sm);
  color: var(--text-secondary);
  cursor: pointer;
}

.filterLabel-b251479 input[type="checkbox"] {
  width: 1.125rem;
  height: 1.125rem;
  accent-color: var(--accent);
}

.grid-b251479 {
  display: grid;
  gap: var(--space-sm);
}

.songbookCard-b251479 {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-md);
  background: var(--bg-elevated);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  transition: all var(--duration-fast);
}

.songbookCard-b251479:hover {
  border-color: var(--accent);
  box-shadow: 0 0.25rem 1rem var(--shadow);
  transform: translateY(-2px);
}

.songbookCard-b251479:active {
  transform: translateY(0);
}

.songbookIcon-b251479 {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.5rem;
  height: 3.5rem;
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, var(--accent), var(--accent-dark, var(--accent)));
  color: var(--text-inverse);
  flex-shrink: 0;
}

.songbookInfo-b251479 {
  flex: 1;
  min-width: 0;
}

.songbookName-b251479 {
  font-size: var(--text-md);
  font-weight: var(--font-semibold);
  color: var(--text);
  margin-bottom: var(--space-3xs);
}

.songbookDesc-b251479 {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin-bottom: var(--space-2xs);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.historyCollapsed-b251479 {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.historyExpanded-b251479 {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
}

.expandBtn-b251479 {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2xs);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--accent-text);
  padding: var(--space-xs) 0;
  background: none;
  border: none;
  cursor: pointer;
  transition: opacity var(--duration-fast);
}

.expandBtn-b251479:hover {
  opacity: 0.8;
}

.songbookCount-b251479 {
  font-size: var(--text-xs);
  color: var(--text-muted);
}

.chevron-b251479 {
  color: var(--text-muted);
  flex-shrink: 0;
  transition: transform var(--duration-fast);
}

.songbookCard-b251479:hover .chevron-b251479 {
  transform: translateX(4px);
  color: var(--accent);
}

.songList-b251479 {
  display: flex;
  flex-direction: column;
}

.songItem-b251479 {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-md);
  transition: background var(--duration-fast);
}

.songItem-b251479:hover {
  background: var(--hover);
}

.songNumber-b251479 {
  width: 2.5rem;
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--accent);
  text-align: center;
  flex-shrink: 0;
}

.songInfo-b251479 {
  flex: 1;
  min-width: 0;
}

.songTitle-b251479 {
  font-size: var(--text-md);
  font-weight: var(--font-medium);
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.songFirstLine-b251479 {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.songKey-b251479 {
  font-size: var(--text-xs);
  font-weight: var(--font-medium);
  padding: var(--space-3xs) var(--space-xs);
  background: var(--accent-soft);
  color: var(--accent-text);
  border-radius: var(--radius-sm);
  flex-shrink: 0;
}

.empty-b251479 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-3xl) var(--space-md);
  text-align: center;
}

.emptyIcon-b251479 {
  width: 4rem;
  height: 4rem;
  color: var(--text-muted);
  margin-bottom: var(--space-md);
  opacity: 0.5;
}

.emptyText-b251479 {
  font-size: var(--text-md);
  color: var(--text-muted);
}

.skeleton-b251479 {
  background: linear-gradient(90deg, var(--hover) 25%, var(--bg-elevated) 50%, var(--hover) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  border-radius: var(--radius-md);
}

@keyframes shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

.skeletonCard-b251479 {
  height: 5.5rem;
  margin-bottom: var(--space-sm);
}

.skeletonItem-b251479 {
  height: 3.5rem;
  margin-bottom: var(--space-2xs);
}

.searchInput-b251479 {
  flex: 1;
  height: 2.5rem;
  padding: 0 var(--space-md);
  font-size: var(--text-md);
  color: var(--text);
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  outline: none;
  transition: border-color var(--duration-fast), box-shadow var(--duration-fast);
}

.searchInput-b251479::placeholder {
  color: var(--text-muted);
}

.searchInput-b251479:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}

.songDetail-b251479 {
  padding: var(--space-md);
}

.songHeader-b251479 {
  margin-bottom: var(--space-lg);
}

.songDetailTitle-b251479 {
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  color: var(--text);
  margin-bottom: var(--space-xs);
}

.songMeta-b251479 {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.songSection-b251479 {
  margin-bottom: var(--space-lg);
}

.sectionLabel-b251479 {
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: var(--space-xs);
}

.songLine-b251479 {
  margin-bottom: var(--space-2xs);
  font-family: var(--font-mono, monospace);
  font-size: var(--text-md);
  line-height: var(--leading-relaxed);
}

.chordLine-b251479 {
  font-weight: var(--font-bold);
  color: var(--accent);
  white-space: pre;
  min-height: 1.25em;
}

.textLine-b251479 {
  color: var(--text);
  white-space: pre-wrap;
}

.transposeControls-b251479 {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}

.transposeBtn-b251479 {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: var(--radius-full);
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  color: var(--text);
  transition: all var(--duration-fast);
}

.transposeBtn-b251479:hover {
  background: var(--hover);
  border-color: var(--accent);
}

.transposeBtn-b251479:active {
  transform: scale(0.9);
}

.transposeValue-b251479 {
  min-width: 3rem;
  text-align: center;
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--text-secondary);
}
