:root {
  color-scheme: light;
  --paper: #f8f4ee;
  --ink: #1f1d1a;
  --accent: #c9772b;
  --accent-dark: #8c4b1b;
  --mist: #ede6db;
  --shadow: color-mix(in srgb, var(--ink) 18%, transparent);
  --glass: rgba(255, 255, 255, 0.75);
  --surface: rgba(255, 252, 246, 0.9);
  --surface-strong: #fffaf2;
  --border-soft: color-mix(in srgb, var(--accent-dark) 14%, transparent);
  --hero-glow: color-mix(in srgb, var(--accent) 22%, transparent);
  --display-font: "Amiri", "Cormorant Garamond", "Garamond", "Palatino Linotype", serif;
  --muted: color-mix(in srgb, var(--ink) 66%, transparent);
  --muted-strong: color-mix(in srgb, var(--ink) 78%, transparent);
  --on-accent: #fffaf4;
  --control-bg: rgba(255, 252, 246, 0.94);
  --control-bg-strong: rgba(255, 252, 246, 0.98);
  --control-border: color-mix(in srgb, var(--accent-dark) 16%, transparent);
  --overlay-bg: color-mix(in srgb, var(--ink) 42%, transparent);
  --surface-shadow: color-mix(in srgb, var(--ink) 12%, transparent);
  --elevated-shadow: color-mix(in srgb, var(--ink) 18%, transparent);
  --success: #1f6d3f;
  --danger: #9f2f2f;
  --warning: #9a5926;
  --body-gradient: radial-gradient(circle at top left, #fff6e9, var(--paper) 55%, #efe4d6 100%);
  --header-gradient: linear-gradient(180deg, rgba(248, 244, 238, 0.95), rgba(248, 244, 238, 0.7));
  --viewport-zoom: 1;
  --user-zoom: 0.85;
  --ui-zoom: calc(var(--viewport-zoom) * var(--user-zoom));
  --ui-zoom-inverse: 1.1764705882;
  --site-footer-height: 0px;
  --arabic-site-font: "Amiri", "Noto Naskh Arabic", "Scheherazade New", "Traditional Arabic", serif;
  --site-heading-line-height: 1.08;
  --site-card-text-line-height: 1.48;
  --site-compact-text-line-height: 1.24;
  --saint-gold: #d69b39;
  --saint-red: #8f2635;
  --saint-blue: #1f5f7a;
}

.saints-index,
.saint-detail {
  width: min(1500px, calc(100% - clamp(24px, 5vw, 72px)));
  margin: 0 auto;
  padding-block: clamp(28px, 5vw, 72px);
}

.saints-index[dir="rtl"],
.saint-detail[dir="rtl"] {
  font-family: var(--arabic-site-font);
}

.saints-index__header {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: clamp(18px, 4vw, 42px);
  margin-bottom: clamp(22px, 4vw, 42px);
  padding-bottom: 18px;
  border-bottom: 1px solid color-mix(in srgb, var(--ink) 10%, transparent);
}

.saints-index__eyebrow,
.saint-hero__rank {
  margin: 0 0 8px;
  color: color-mix(in srgb, var(--saint-blue) 78%, var(--ink) 22%);
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

.saints-index__header h1,
.saint-hero h1 {
  margin: 0;
  color: var(--ink);
  font-family: var(--display-font);
  font-size: clamp(2.5rem, 7vw, 5.8rem);
  line-height: 0.94;
  letter-spacing: 0;
}

.saints-index__header h1 {
  padding-inline: 4px;
}

.saints-index__search {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: min(100%, 360px);
  padding: 6px;
  border: 1px solid var(--control-border);
  border-radius: 8px;
  background: var(--control-bg);
}

.saints-index__search input {
  min-width: 0;
  flex: 1;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--ink);
  font: inherit;
}

.saints-index__search button,
.saint-language-switch a,
.saint-detail__back a {
  border: 1px solid var(--control-border);
  border-radius: 8px;
  background: var(--control-bg-strong);
  color: var(--ink);
  font: inherit;
  font-weight: 800;
  text-decoration: none;
}

.saints-index__search button {
  padding: 9px 13px;
  cursor: pointer;
}

.saints-index__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: clamp(16px, 2.8vw, 26px) 0 clamp(24px, 4vw, 38px);
}

.saints-index__tags a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 36px;
  padding: 7px 11px;
  border: 1px solid color-mix(in srgb, var(--ink) 11%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, var(--surface-strong) 78%, transparent);
  color: color-mix(in srgb, var(--ink) 82%, transparent);
  font-size: 0.9rem;
  font-weight: 850;
  text-decoration: none;
}

.saints-index__tags a span:last-child {
  display: inline-grid;
  place-items: center;
  min-width: 24px;
  height: 24px;
  padding-inline: 6px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--ink) 8%, transparent);
  color: color-mix(in srgb, var(--ink) 68%, transparent);
  font-size: 0.78rem;
}

.saints-index__tags a.is-active {
  border-color: color-mix(in srgb, var(--saint-gold) 65%, var(--ink) 12%);
  background: color-mix(in srgb, var(--saint-gold) 18%, var(--surface-strong));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--saint-gold) 36%, transparent);
}

.saints-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: clamp(18px, 3vw, 36px) clamp(14px, 2.4vw, 28px);
  align-items: start;
}

.saint-card {
  position: relative;
  display: grid;
  gap: 10px;
  justify-items: center;
  min-width: 0;
  padding: 6px 4px 10px;
  border: 0;
  border-radius: 8px;
  color: var(--ink);
  text-align: center;
  text-decoration: none;
  isolation: isolate;
}

.saint-card__figure {
  position: relative;
  display: grid;
  place-items: center;
  width: 100%;
  aspect-ratio: 1;
}

.saint-card__figure::before,
.saint-hero__figure::before {
  content: "";
  position: absolute;
  inset: 13%;
  z-index: -1;
  border-radius: 999px;
  background:
    radial-gradient(circle, rgba(255, 237, 171, 0.9) 0%, rgba(214, 155, 57, 0.38) 34%, rgba(31, 95, 122, 0.16) 58%, transparent 74%);
  filter: blur(20px);
  opacity: 0;
  transform: scale(0.86);
  transition: opacity 180ms ease, transform 180ms ease;
}

.saint-card img {
  display: block;
  width: min(100%, 220px);
  height: auto;
  aspect-ratio: 1;
  object-fit: contain;
  filter: drop-shadow(0 10px 18px rgba(70, 48, 20, 0.18));
  transition: transform 180ms ease, filter 180ms ease;
}

.saint-card__name {
  max-width: 100%;
  color: color-mix(in srgb, var(--ink) 88%, transparent);
  font-size: clamp(0.92rem, 1.8vw, 1.08rem);
  font-weight: 800;
  line-height: 1.22;
  overflow-wrap: anywhere;
}

.saint-card:hover .saint-card__figure::before,
.saint-card:focus-visible .saint-card__figure::before {
  opacity: 1;
  transform: scale(1.08);
}

.saint-card:hover img,
.saint-card:focus-visible img,
.saint-card:hover .saint-card__fallback,
.saint-card:focus-visible .saint-card__fallback {
  transform: translateY(-5px) scale(1.045);
  filter:
    drop-shadow(0 0 14px rgba(255, 227, 137, 0.7))
    drop-shadow(0 16px 24px rgba(102, 62, 18, 0.26));
}

.saint-card__fallback,
.saint-hero__fallback {
  display: grid;
  place-items: center;
  border-radius: 999px;
  background:
    radial-gradient(circle at 50% 42%, rgba(255, 249, 222, 0.96), rgba(224, 178, 83, 0.58) 52%, rgba(143, 38, 53, 0.18) 100%);
  color: color-mix(in srgb, var(--saint-red) 82%, var(--ink) 18%);
  font-family: var(--display-font);
  font-weight: 900;
  box-shadow: inset 0 0 0 1px rgba(141, 91, 20, 0.18);
}

.saint-card__fallback {
  width: min(100%, 220px);
  aspect-ratio: 1;
  font-size: clamp(3rem, 7vw, 5.5rem);
  transition: transform 180ms ease, filter 180ms ease;
}

.saint-hero__fallback {
  width: min(100%, 360px);
  aspect-ratio: 1;
  font-size: clamp(5rem, 14vw, 10rem);
}

.saint-detail__back {
  margin-bottom: 18px;
}

.saint-detail__back a,
.saint-language-switch a {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 8px 13px;
}

.saint-hero {
  display: grid;
  grid-template-columns: minmax(220px, 360px) minmax(0, 1fr);
  gap: clamp(26px, 5vw, 68px);
  align-items: center;
  min-height: min(76vh, 760px);
  padding-block: clamp(10px, 3vw, 36px);
}

.saint-hero__figure {
  position: relative;
  display: grid;
  place-items: center;
  min-width: 0;
  isolation: isolate;
}

.saint-hero__figure::before {
  opacity: 0.82;
  transform: scale(1);
  filter: blur(30px);
}

.saint-hero__figure img {
  width: min(100%, 360px);
  height: auto;
  object-fit: contain;
  filter:
    drop-shadow(0 0 18px rgba(255, 229, 139, 0.34))
    drop-shadow(0 24px 38px rgba(72, 49, 20, 0.28));
}

.saint-hero__content {
  display: grid;
  gap: 14px;
  min-width: 0;
}

.saint-hero__feast,
.saint-hero__bio {
  margin: 0;
  max-width: 860px;
  color: color-mix(in srgb, var(--ink) 74%, transparent);
}

.saint-hero__feast {
  color: color-mix(in srgb, var(--saint-red) 76%, var(--ink) 24%);
  font-weight: 900;
}

.saint-hero__bio {
  font-size: clamp(1.05rem, 2vw, 1.26rem);
  line-height: 1.72;
}

.saint-language-switch {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 6px;
}

.saint-language-switch a.is-active {
  border-color: color-mix(in srgb, var(--saint-gold) 65%, var(--ink) 12%);
  background: color-mix(in srgb, var(--saint-gold) 18%, var(--surface-strong));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--saint-gold) 38%, transparent);
}

.saint-reader {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(28px, 5vw, 56px);
  padding-block-end: clamp(44px, 8vw, 96px);
}

.saint-reader__section {
  max-width: 1100px;
  width: 100%;
  margin-inline: auto;
}

.saint-reader__section h2 {
  margin: 0 0 18px;
  color: var(--ink);
  font-family: var(--display-font);
  font-size: clamp(2rem, 4vw, 3.4rem);
  line-height: 1;
  letter-spacing: 0;
}

.saint-prose,
.saint-reader__empty {
  font-size: clamp(1.08rem, 2vw, 1.28rem);
  line-height: 1.94;
}

.saint-prose p {
  margin: 0 0 1.2em;
}

.saint-hymn {
  display: grid;
  gap: 10px;
  color: var(--ink);
  font-size: clamp(1.02rem, 1.8vw, 1.22rem);
  line-height: 1.75;
}

.saint-hymn__row {
  display: grid;
  grid-template-columns: repeat(var(--part-count), minmax(0, 1fr));
  gap: 8px 16px;
  align-items: start;
  padding: 10px 0;
  border-bottom: 1px solid color-mix(in srgb, var(--ink) 9%, transparent);
}

.saint-hymn__row span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.saint-hymn__row--section {
  display: block;
  color: color-mix(in srgb, var(--saint-blue) 78%, var(--ink) 22%);
  font-weight: 900;
}

.saint-feast-toast {
  position: fixed;
  z-index: 1200;
  left: max(16px, env(safe-area-inset-left));
  bottom: calc(var(--site-footer-height, 0px) + max(70px, calc(env(safe-area-inset-bottom) + 70px)));
  width: min(108px, calc(100vw - 24px));
  display: grid;
  justify-items: center;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 180ms ease, transform 180ms ease;
}

.saint-feast-toast.is-visible {
  opacity: 1;
  transform: translateY(0);
  left: auto;
  right: max(16px, env(safe-area-inset-right));
}

.saint-feast-toast[dir="rtl"] {
  left: auto;
  right: max(16px, env(safe-area-inset-right));
}

.saint-feast-toast.is-visible[dir="rtl"] {
  left: max(16px, env(safe-area-inset-left));
  right: auto;
}

.saint-feast-toast__link {
  display: grid;
  justify-items: center;
  gap: 2px;
  min-width: 0;
  padding: 0 8px 6px;
  color: var(--ink);
  text-align: center;
  text-decoration: none;
}

.saint-feast-toast__link img {
  width: 58px;
  height: 58px;
  object-fit: contain;
  filter:
    drop-shadow(0 0 8px rgba(255, 236, 165, 0.86))
    drop-shadow(0 0 20px rgba(220, 157, 52, 0.54))
    drop-shadow(0 9px 15px rgba(102, 62, 18, 0.2));
}

.saint-feast-toast__copy {
  display: grid;
  justify-items: center;
  gap: 1px;
  min-width: 0;
}

.saint-feast-toast__label,
.saint-feast-toast__name {
  max-width: 100%;
  overflow-wrap: anywhere;
  text-shadow: 0 1px 8px color-mix(in srgb, var(--surface) 78%, transparent);
}

.saint-feast-toast__label {
  color: color-mix(in srgb, var(--saint-gold) 70%, var(--ink) 30%);
  font-size: 0.84rem;
  font-weight: 900;
  line-height: var(--site-compact-text-line-height);
}

.saint-feast-toast__name {
  color: var(--ink);
  font-size: 0.98rem;
  font-weight: 900;
  line-height: var(--site-compact-text-line-height);
}

.saint-feast-toast__close {
  position: absolute;
  inset-block-start: -6px;
  inset-inline-end: 8px;
  display: grid;
  place-items: center;
  width: 23px;
  height: 23px;
  border: 0;
  border-radius: 999px;
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  color: color-mix(in srgb, var(--ink) 58%, transparent);
  font-size: 1rem;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 4px 12px color-mix(in srgb, var(--ink) 9%, transparent);
}

.saint-feast-toast[dir="rtl"] .saint-feast-toast__close {
  inset-inline-end: auto;
  inset-inline-start: 8px;
}

@media (max-width: 1180px) {
  .saints-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .saints-index,
  .saint-detail {
    width: min(100% - 24px, 1500px);
    padding-block: 24px 48px;
  }

  .saints-index__header {
    display: grid;
    align-items: start;
  }

  .saints-index__search {
    width: 100%;
  }

  .saints-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .saint-hero {
    grid-template-columns: 1fr;
    min-height: auto;
    text-align: center;
  }

  .saint-hero__content,
  .saint-language-switch {
    justify-items: center;
    justify-content: center;
  }

  .saint-hymn__row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.library-filters__status {
  grid-column: 5;
  margin: 0;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  min-height: 24px;
  font-size: 0.95rem;
  color: color-mix(in srgb, var(--ink) 68%, transparent);
  white-space: nowrap;
  direction: ltr;
  unicode-bidi: isolate;
}

.library-grid {
  align-items: stretch;
}

.library-card {
  position: relative;
  min-height: 430px;
  display: flex;
  align-items: stretch;
  grid-template-rows: none;
  gap: 0;
  padding: 0;
  isolation: isolate;
  border: 1px solid var(--border-soft);
  border-radius: 26px;
  box-shadow: 0 18px 44px rgba(120, 84, 42, 0.1);
  background: #151311;
  overflow: hidden;
}

.library-card__media {
  position: absolute;
  inset: 0;
  aspect-ratio: auto;
  border-radius: inherit;
  background: #151311;
}

.library-card__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.9) 0%, rgba(0, 0, 0, 0.66) 34%, rgba(0, 0, 0, 0.2) 68%, rgba(0, 0, 0, 0.02) 100%);
  pointer-events: none;
}

.library-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.01);
}

.library-card__content {
  position: relative;
  z-index: 1;
  width: 100%;
  min-height: 430px;
  display: grid;
  align-content: end;
  gap: 12px;
  padding: 28px;
  color: #fff;
}

.library-card h2 {
  margin: 0;
  font-size: clamp(1.5rem, 3vw, 2rem);
  line-height: var(--site-compact-text-line-height);
}

.library-card h2 a {
  color: inherit;
  text-decoration: none;
}

.library-card h2 a:hover,
.library-card h2 a:focus-visible {
  text-decoration: underline;
  text-underline-offset: 0.16em;
}

.library-card .library-card__description {
  min-height: 0;
  color: rgba(255, 255, 255, 0.82) !important;
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

.library-card__actions {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.library-card__actions a,
.library-card__actions button {
  border: 1px solid rgba(255, 255, 255, 0.28);
  background: rgba(255, 255, 255, 0.16);
  color: #fff;
  backdrop-filter: blur(10px);
}

.library-card__actions a:first-child {
  background: #fff;
  color: #171310;
}

.library-card__bookmark.is-active {
  background: color-mix(in srgb, var(--accent) 76%, #fff 24%);
  color: #171310;
}

.library-book-reader {
  display: grid;
  gap: 24px;
  /* padding-block-end: 80px; */
  height: 100vh;
}

.library-book-reader__nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}

.library-book-reader__nav a,
.library-book-reader__nav button {
  border: 1px solid var(--border-soft);
  border-radius: 999px;
  padding: 10px 16px;
  background: var(--surface);
  color: var(--ink);
  font: inherit;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
}

.library-book-reader__nav button.is-active {
  background: var(--accent);
  color: #fff;
}

.library-book-reader__hero {
  display: grid;
  grid-template-columns: minmax(190px, 280px) minmax(0, 1fr);
  gap: clamp(20px, 4vw, 42px);
  align-items: end;
  padding: clamp(18px, 4vw, 36px);
  border: 1px solid var(--border-soft);
  border-radius: 28px;
  background: var(--surface);
}

.library-book-reader__cover {
  min-height: 340px;
  border-radius: 18px;
  overflow: hidden;
  background: color-mix(in srgb, var(--mist) 78%, transparent);
}

.library-book-reader__cover img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.library-book-reader__intro {
  display: grid;
  gap: 10px;
}

.library-book-reader__intro h1 {
  margin: 0;
  max-width: 980px;
  font-size: clamp(2.2rem, 5vw, 4.8rem);
  line-height: 1;
}

.library-book-reader__status,
.library-book-reader__author,
.library-book-reader__summary-meta {
  margin: 0;
  color: color-mix(in srgb, var(--ink) 72%, transparent);
}

.library-book-reader__summary-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
}

.library-book-reader__body,
.library-book-reader__empty {
  max-width: 980px;
  width: 100%;
  margin-inline: auto;
  padding: clamp(22px, 5vw, 54px);
  border: 1px solid var(--border-soft);
  border-radius: 22px;
  background: var(--paper);
  color: var(--ink);
  font-size: clamp(1.12rem, 2vw, 1.32rem);
  line-height: 1.92;
}

.library-book-reader__body h2,
.library-book-reader__body h3,
.library-book-reader__body h4 {
  margin: 1.8em 0 0.6em;
  line-height: 1.2;
}

.library-book-reader__body p {
  margin: 0 0 1.2em;
}

@media (max-width: 820px) {
  .library-book-reader__hero {
    grid-template-columns: 1fr;
  }

  .library-book-reader__cover {
    min-height: 420px;
  }
}

:root[data-theme="sepia"] {
  --paper: #f1e0c3;
  --ink: #2f2418;
  --accent: #a05e24;
  --accent-dark: #673812;
  --mist: #dfc9a5;
  --glass: rgba(255, 243, 222, 0.78);
  --surface: rgba(255, 244, 224, 0.92);
  --surface-strong: #fff0d1;
  --border-soft: rgba(103, 56, 18, 0.2);
  --hero-glow: rgba(160, 94, 36, 0.22);
  --muted: color-mix(in srgb, var(--ink) 68%, transparent);
  --muted-strong: color-mix(in srgb, var(--ink) 80%, transparent);
  --control-bg: rgba(255, 244, 224, 0.94);
  --control-bg-strong: rgba(255, 240, 209, 0.98);
  --control-border: rgba(103, 56, 18, 0.22);
  --overlay-bg: rgba(47, 36, 24, 0.44);
  --surface-shadow: rgba(47, 36, 24, 0.13);
  --elevated-shadow: rgba(47, 36, 24, 0.2);
  --body-gradient: radial-gradient(circle at top left, #ffe6bd, var(--paper) 58%, #dcc09a 100%);
  --header-gradient: linear-gradient(180deg, rgba(241, 224, 195, 0.95), rgba(241, 224, 195, 0.72));
}

:root[data-theme="olive"] {
  --paper: #eef0df;
  --ink: #202616;
  --accent: #72833c;
  --accent-dark: #445220;
  --mist: #dce1c8;
  --glass: rgba(250, 253, 237, 0.76);
  --surface: rgba(251, 254, 240, 0.92);
  --surface-strong: #fbfee9;
  --border-soft: rgba(68, 82, 32, 0.18);
  --hero-glow: rgba(114, 131, 60, 0.2);
  --muted: color-mix(in srgb, var(--ink) 68%, transparent);
  --muted-strong: color-mix(in srgb, var(--ink) 80%, transparent);
  --control-bg: rgba(251, 254, 240, 0.94);
  --control-bg-strong: rgba(251, 254, 233, 0.98);
  --control-border: rgba(68, 82, 32, 0.2);
  --overlay-bg: rgba(32, 38, 22, 0.44);
  --surface-shadow: rgba(32, 38, 22, 0.13);
  --elevated-shadow: rgba(32, 38, 22, 0.2);
  --body-gradient: radial-gradient(circle at top left, #fbffe4, var(--paper) 58%, #d9dfbf 100%);
  --header-gradient: linear-gradient(180deg, rgba(238, 240, 223, 0.95), rgba(238, 240, 223, 0.72));
}

:root[data-theme="midnight"] {
  color-scheme: dark;
  --paper: #111722;
  --ink: #f4efe4;
  --accent: #e1a25f;
  --accent-dark: #ffca87;
  --mist: #202b3c;
  --shadow: rgba(0, 0, 0, 0.45);
  --glass: rgba(24, 32, 45, 0.78);
  --surface: rgba(28, 37, 52, 0.92);
  --surface-strong: #1d2635;
  --border-soft: rgba(255, 218, 168, 0.18);
  --hero-glow: rgba(225, 162, 95, 0.16);
  --muted: color-mix(in srgb, var(--ink) 68%, transparent);
  --muted-strong: color-mix(in srgb, var(--ink) 82%, transparent);
  --on-accent: #17110b;
  --control-bg: rgba(28, 37, 52, 0.94);
  --control-bg-strong: rgba(35, 46, 64, 0.98);
  --control-border: rgba(255, 218, 168, 0.2);
  --overlay-bg: rgba(3, 6, 10, 0.64);
  --surface-shadow: rgba(0, 0, 0, 0.34);
  --elevated-shadow: rgba(0, 0, 0, 0.52);
  --success: #8dd9a8;
  --danger: #ff9a9a;
  --warning: #ffca87;
  --body-gradient: radial-gradient(circle at top left, #263044, var(--paper) 55%, #0d121b 100%);
  --header-gradient: linear-gradient(180deg, rgba(17, 23, 34, 0.96), rgba(17, 23, 34, 0.72));
}

:root[data-theme="dawn"] {
  --paper: #fff1e4;
  --ink: #2c1d18;
  --accent: #d65f3f;
  --accent-dark: #8f321e;
  --mist: #f4d8c6;
  --glass: rgba(255, 244, 236, 0.78);
  --surface: rgba(255, 248, 241, 0.92);
  --surface-strong: #fff8ef;
  --border-soft: rgba(143, 50, 30, 0.17);
  --hero-glow: rgba(214, 95, 63, 0.2);
  --muted: color-mix(in srgb, var(--ink) 68%, transparent);
  --muted-strong: color-mix(in srgb, var(--ink) 80%, transparent);
  --control-bg: rgba(255, 248, 241, 0.94);
  --control-bg-strong: rgba(255, 252, 246, 0.98);
  --control-border: rgba(143, 50, 30, 0.19);
  --overlay-bg: rgba(44, 29, 24, 0.44);
  --surface-shadow: rgba(44, 29, 24, 0.13);
  --elevated-shadow: rgba(44, 29, 24, 0.2);
  --body-gradient: radial-gradient(circle at top left, #ffe0ca, var(--paper) 58%, #f3c9b4 100%);
  --header-gradient: linear-gradient(180deg, rgba(255, 241, 228, 0.95), rgba(255, 241, 228, 0.72));
}

:root[data-theme="cedar"] {
  --paper: #eef2e9;
  --ink: #15251e;
  --accent: #2f7a57;
  --accent-dark: #174b34;
  --mist: #d9e5d8;
  --glass: rgba(243, 250, 241, 0.76);
  --surface: rgba(247, 252, 244, 0.92);
  --surface-strong: #f8fff4;
  --border-soft: rgba(23, 75, 52, 0.18);
  --hero-glow: rgba(47, 122, 87, 0.18);
  --muted: color-mix(in srgb, var(--ink) 68%, transparent);
  --muted-strong: color-mix(in srgb, var(--ink) 80%, transparent);
  --control-bg: rgba(247, 252, 244, 0.94);
  --control-bg-strong: rgba(248, 255, 244, 0.98);
  --control-border: rgba(23, 75, 52, 0.2);
  --overlay-bg: rgba(21, 37, 30, 0.44);
  --surface-shadow: rgba(21, 37, 30, 0.13);
  --elevated-shadow: rgba(21, 37, 30, 0.2);
  --success: #1f7a4c;
  --body-gradient: radial-gradient(circle at top left, #f4ffe9, var(--paper) 58%, #d5e3d2 100%);
  --header-gradient: linear-gradient(180deg, rgba(238, 242, 233, 0.95), rgba(238, 242, 233, 0.72));
}

:root[data-theme="lapis"] {
  --paper: #eaf1f7;
  --ink: #122238;
  --accent: #376b9e;
  --accent-dark: #1c4773;
  --mist: #d3e0ec;
  --glass: rgba(240, 247, 253, 0.76);
  --surface: rgba(246, 251, 255, 0.92);
  --surface-strong: #f8fcff;
  --border-soft: rgba(28, 71, 115, 0.18);
  --hero-glow: rgba(55, 107, 158, 0.18);
  --muted: color-mix(in srgb, var(--ink) 68%, transparent);
  --muted-strong: color-mix(in srgb, var(--ink) 80%, transparent);
  --control-bg: rgba(246, 251, 255, 0.94);
  --control-bg-strong: rgba(248, 252, 255, 0.98);
  --control-border: rgba(28, 71, 115, 0.2);
  --overlay-bg: rgba(18, 34, 56, 0.46);
  --surface-shadow: rgba(18, 34, 56, 0.13);
  --elevated-shadow: rgba(18, 34, 56, 0.2);
  --body-gradient: radial-gradient(circle at top left, #f4fbff, var(--paper) 58%, #cbddea 100%);
  --header-gradient: linear-gradient(180deg, rgba(234, 241, 247, 0.95), rgba(234, 241, 247, 0.72));
}

:root[data-theme="rose"] {
  --paper: #fbedf1;
  --ink: #321720;
  --accent: #b34867;
  --accent-dark: #7b243d;
  --mist: #edd3da;
  --glass: rgba(255, 243, 247, 0.76);
  --surface: rgba(255, 248, 250, 0.92);
  --surface-strong: #fff8fb;
  --border-soft: rgba(123, 36, 61, 0.17);
  --hero-glow: rgba(179, 72, 103, 0.18);
  --muted: color-mix(in srgb, var(--ink) 68%, transparent);
  --muted-strong: color-mix(in srgb, var(--ink) 80%, transparent);
  --control-bg: rgba(255, 248, 250, 0.94);
  --control-bg-strong: rgba(255, 251, 253, 0.98);
  --control-border: rgba(123, 36, 61, 0.2);
  --overlay-bg: rgba(50, 23, 32, 0.46);
  --surface-shadow: rgba(50, 23, 32, 0.13);
  --elevated-shadow: rgba(50, 23, 32, 0.2);
  --body-gradient: radial-gradient(circle at top left, #ffe1e9, var(--paper) 58%, #e9c8d2 100%);
  --header-gradient: linear-gradient(180deg, rgba(251, 237, 241, 0.95), rgba(251, 237, 241, 0.72));
}

:root[data-theme="contrast"] {
  color-scheme: dark;
  --paper: #050505;
  --ink: #fffdf4;
  --accent: #ffcf3f;
  --accent-dark: #ffe285;
  --mist: #151515;
  --shadow: rgba(0, 0, 0, 0.68);
  --glass: rgba(12, 12, 12, 0.84);
  --surface: rgba(18, 18, 18, 0.94);
  --surface-strong: #0d0d0d;
  --border-soft: rgba(255, 207, 63, 0.34);
  --hero-glow: rgba(255, 207, 63, 0.14);
  --muted: color-mix(in srgb, var(--ink) 74%, transparent);
  --muted-strong: color-mix(in srgb, var(--ink) 86%, transparent);
  --on-accent: #090909;
  --control-bg: rgba(22, 22, 22, 0.96);
  --control-bg-strong: rgba(8, 8, 8, 0.98);
  --control-border: rgba(255, 207, 63, 0.42);
  --overlay-bg: rgba(0, 0, 0, 0.74);
  --surface-shadow: rgba(0, 0, 0, 0.5);
  --elevated-shadow: rgba(0, 0, 0, 0.72);
  --success: #8ff0b0;
  --danger: #ff8e8e;
  --warning: #ffcf3f;
  --body-gradient: radial-gradient(circle at top left, #1b1b1b, var(--paper) 55%, #000 100%);
  --header-gradient: linear-gradient(180deg, rgba(5, 5, 5, 0.98), rgba(5, 5, 5, 0.78));
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: var(--display-font);
  font-size: 1.2rem;
  color: var(--ink);
  background: var(--body-gradient);
  background-color: var(--paper);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

html[lang="ar"] body,
body[data-auth-ui-lang="ar"] {
  font-family: var(--arabic-site-font);
  line-height: 2.22;
  --site-heading-line-height: 2.22;
  --site-card-text-line-height: 2.22;
  --site-compact-text-line-height: 2.22;
}

html {
  zoom: var(--ui-zoom);
  min-height: 100%;
}

body::before {
  content: "";
  position: fixed;
  inset: -15vh -12vw -15vh -12vw;
  background: radial-gradient(circle, var(--hero-glow), transparent 60%);
  pointer-events: none;
  z-index: 0;
}

.shell {
  width: 80%;
  margin: 0 auto;
}

@media (max-width: 1280px) {
  .shell {
    width: 96%;
  }
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 10;
  background: var(--header-gradient);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
}

.site-header .shell {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 18px 0;
  min-width: 0;
}

html[dir="rtl"] .site-header .shell {
  flex-direction: row;
}

body[data-page="editor"] .site-header .shell--editor-header {
  width: min(96vw, 1760px);
  gap: 16px;
  padding: 8px 0;
}

body[data-page="editor"] .site-header {
  background: rgba(248, 244, 238, 0.98);
}

body[data-page="editor"] .site-header .nav {
  margin-inline-start: auto;
}

.logo {
  text-decoration: none;
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink);
  flex: 0 0 auto;
}

.header-search {
  flex: 1 1 320px;
  display: flex;
  align-items: center;
  gap: 8px;
  position: relative;
  min-width: 220px;
  max-width: 460px;
  padding: 8px 10px 8px 16px;
  border-radius: 999px;
  background: var(--surface);
  border: 1px solid color-mix(in srgb, var(--accent-dark) 14%, transparent);
  box-shadow: 0 8px 24px rgba(120, 84, 42, 0.08);
}

.header-search::after,
.search-results-form::after {
  content: "";
  position: absolute;
  inset-inline: 14px;
  bottom: 7px;
  height: 3px;
  border-radius: 999px;
  background:
    linear-gradient(
      90deg,
      rgba(201, 119, 43, 0) 0%,
      color-mix(in srgb, var(--accent) 16%, transparent) 18%,
      color-mix(in srgb, var(--accent) 48%, transparent) 50%,
      color-mix(in srgb, var(--accent) 16%, transparent) 82%,
      rgba(201, 119, 43, 0) 100%);
  background-size: 180% 100%;
  opacity: 0;
  pointer-events: none;
  transform: scaleX(0.96);
  transition: opacity 160ms ease;
}

.header-search.is-loading::after,
.search-results-form.is-loading::after {
  opacity: 1;
  animation: search-loading-bar 1.05s linear infinite;
}

.header-search input,
.hero-search-form input {
  width: 100%;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--ink);
  font: inherit;
}

.header-search button,
.hero-search-form button {
  flex: 0 0 auto;
}

.search-icon-button {
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 999px;
  background: transparent;
  cursor: pointer;
  transition: background-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.search-icon-button:hover,
.search-icon-button:focus-visible {
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  transform: translateY(-1px);
}

.search-icon-button:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent) 30%, transparent);
  outline-offset: 2px;
}

.search-icon-button img {
  width: 20px;
  height: 20px;
  opacity: 0.78;
}

.site-theme-switcher {
  position: relative;
  z-index: 30;
  flex: 0 0 auto;
}

.site-theme-switcher__button {
  width: 44px;
  min-width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 1px solid color-mix(in srgb, var(--accent-dark) 18%, transparent);
  border-radius: 999px;
  background: var(--surface);
  color: var(--accent-dark);
  cursor: pointer;
  box-shadow: 0 10px 24px color-mix(in srgb, var(--ink) 8%, transparent);
  transition: border-color 0.18s ease, background 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.site-theme-switcher__button:hover,
.site-theme-switcher__button:focus-visible,
.site-theme-switcher:focus-within .site-theme-switcher__button,
.site-theme-switcher.is-open .site-theme-switcher__button {
  background: rgba(255, 247, 236, 0.98);
  border-color: color-mix(in srgb, var(--accent) 34%, transparent);
  color: var(--accent);
  transform: translateY(-1px);
  outline: none;
}

.site-theme-switcher__current-swatch,
.site-theme-switcher__swatches {
  display: inline-flex;
  align-items: center;
}

.site-theme-switcher__current-swatch {
  gap: 0;
}

.site-theme-switcher__current-swatch span,
.site-theme-switcher__swatches span {
  display: block;
  background: var(--swatch-color, var(--accent));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--ink) 18%, transparent);
}

.site-theme-switcher__current-swatch span {
  width: 12px;
  height: 22px;
}

/* Use logical border-radius so the rounded ends follow writing direction.
   In RTL the first DOM child becomes the visually rightmost element, so
   physical "999px 0 0 999px" was rounding the wrong edge. */
.site-theme-switcher__current-swatch span:first-child {
  border-start-start-radius: 999px;
  border-end-start-radius: 999px;
}

.site-theme-switcher__current-swatch span:last-child {
  border-start-end-radius: 999px;
  border-end-end-radius: 999px;
}

.site-theme-switcher__menu {
  position: absolute;
  inset-inline-end: 0;
  top: 100%;
  width: min(78vw, 430px);
  max-height: min(72vh, 520px);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(155px, 1fr));
  gap: 6px;
  padding: 10px;
  border: 1px solid color-mix(in srgb, var(--accent-dark) 14%, transparent);
  border-radius: 22px;
  background: rgba(255, 251, 245, 0.98);
  box-shadow: 0 22px 48px color-mix(in srgb, var(--ink) 16%, transparent);
  opacity: 0;
  overflow: auto;
  pointer-events: none;
  transform: translateY(8px);
  transition: opacity 0.16s ease, transform 0.16s ease;
}

.site-theme-switcher::after {
  content: "";
  position: absolute;
  inset-inline: -8px;
  top: 100%;
  height: 12px;
}

.site-theme-switcher:hover .site-theme-switcher__menu,
.site-theme-switcher:focus-within .site-theme-switcher__menu,
.site-theme-switcher.is-open .site-theme-switcher__menu {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.site-theme-switcher__menu button {
  min-height: 38px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  column-gap: 10px;
  row-gap: 1px;
  align-items: center;
  padding: 8px 10px;
  border: 0;
  border-radius: 12px;
  background: transparent;
  color: var(--ink);
  font: inherit;
  font-size: max(18px, 0.95rem);
  font-weight: 750;
  text-align: start;
  cursor: pointer;
}

.site-theme-switcher__menu button:hover,
.site-theme-switcher__menu button:focus-visible,
.site-theme-switcher__menu button.is-current {
  background: color-mix(in srgb, var(--accent) 11%, transparent);
  outline: none;
}

.site-theme-switcher__swatches {
  grid-column: 2;
  grid-row: 1 / span 2;
  align-self: center;
  gap: 2px;
  padding: 3px 6px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent-dark) 8%, transparent);
}

.site-theme-switcher__menu button > span:last-child {
  grid-column: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.site-theme-switcher__swatches span {
  width: 8px;
  height: 18px;
  border-radius: 999px;
}

.nav {
  display: flex;
  gap: 18px;
  font-size: 1.2rem;
  flex: 1 1 auto;
  min-width: 0;
  flex-wrap: nowrap;
  justify-content: flex-end;
  overflow: auto hidden;
  scrollbar-width: none;
}

.nav::-webkit-scrollbar {
  display: none;
}

.nav a {
  flex: 0 0 auto;
  text-decoration: none;
  color: var(--ink);
  position: relative;
  padding-bottom: 4px;
  white-space: nowrap;
}

.nav a::after {
  content: "";
  position: absolute;
  inset-inline-start: 0;
  bottom: 0;
  width: 0%;
  height: 2px;
  background: var(--accent);
  transition: width 0.3s ease;
}

.nav a:hover::after {
  width: 100%;
}

.nav-auth {
  flex: 0 0 auto;
  margin-inline-start: auto;
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 16px;
  border: 1px solid var(--control-border, color-mix(in srgb, var(--accent-dark) 16%, transparent));
  border-radius: 999px;
  background: var(--control-bg);
  color: var(--muted-strong);
  font: inherit;
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
  box-shadow: 0 10px 24px color-mix(in srgb, var(--ink) 8%, transparent);
  transition: background-color 0.14s ease, border-color 0.14s ease, color 0.14s ease, transform 0.14s ease;
}

.nav-auth:hover,
.nav-auth:focus-visible {
  background: color-mix(in srgb, var(--accent) 10%, var(--control-bg, transparent));
  border-color: color-mix(in srgb, var(--accent) 32%, var(--control-border, transparent));
  color: var(--accent-dark);
  outline: none;
  transform: translateY(-1px);
}

/* Account chip lives at the very end of the header shell so it's
   pinned to the inline-end edge — right in LTR, left in RTL. The
   whole chip is a single clickable trigger; there's no "click on
   the avatar to go to profile" shortcut, because users were
   confusing it with a dropdown affordance. Profile is just a
   menu item now. */
.nav-user {
  position: relative;
  flex: 0 0 auto;
  color: var(--muted-strong);
  white-space: nowrap;
  margin-inline-start: auto;
}

.nav-user__trigger {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px 12px 4px 4px;
  border: 1px solid var(--control-border, color-mix(in srgb, var(--accent-dark) 16%, transparent));
  border-radius: 999px;
  background: var(--control-bg);
  color: var(--muted-strong);
  font: inherit;
  font-weight: 600;
  white-space: nowrap;
  cursor: pointer;
  transition: background-color 0.14s ease, border-color 0.14s ease;
}

[dir="rtl"] .nav-user__trigger {
  padding: 4px 4px 4px 12px;
}

.nav-user__trigger:hover,
.nav-user:hover .nav-user__trigger,
.nav-user:focus-within .nav-user__trigger,
.nav-user.is-open .nav-user__trigger {
  background: color-mix(in srgb, var(--accent) 10%, var(--control-bg, transparent));
  border-color: color-mix(in srgb, var(--accent) 32%, var(--control-border, transparent));
}

.nav-user__trigger:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent) 36%, transparent);
  outline-offset: -2px;
}

.nav-user__avatar {
  display: inline-grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 22%, var(--surface));
  color: var(--accent-dark);
  font-weight: 800;
  font-size: 0.92rem;
  text-transform: uppercase;
}

.nav-user__name {
  max-width: 160px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.nav-user__chevron {
  width: 14px;
  height: 14px;
  flex: 0 0 14px;
  color: color-mix(in srgb, var(--ink) 60%, transparent);
  transition: transform 0.16s ease;
}

.nav-user__menu {
  position: absolute;
  top: calc(100% + 6px);
  inset-inline-end: 0;
  min-width: 220px;
  display: grid;
  gap: 2px;
  padding: 8px;
  border: 1px solid color-mix(in srgb, var(--accent) 14%, var(--border-soft, color-mix(in srgb, var(--accent-dark) 16%, transparent)));
  border-radius: 16px;
  background: var(--surface-strong);
  box-shadow: 0 18px 42px color-mix(in srgb, var(--ink) 18%, transparent);
  opacity: 0;
  pointer-events: none;
  transform: translateY(-4px);
  transition: opacity 0.16s ease, transform 0.16s ease;
  z-index: 80;
}

/* Open the menu on hover/focus-within (CSS) AND on .is-open (JS click).
   Hover gives a discoverable Google-account-chip feel; click is the
   accessible/touch path. The two coexist — hovering opens it, JS-click
   sets is-open which keeps it open after the cursor moves to the menu
   surface. */
.nav-user:hover .nav-user__menu,
.nav-user:focus-within .nav-user__menu,
.nav-user.is-open .nav-user__menu {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.nav-user:hover .nav-user__chevron,
.nav-user.is-open .nav-user__chevron {
  transform: rotate(180deg);
}

.nav-user__menu a {
  display: block;
  padding: 9px 12px;
  border-radius: 10px;
  color: var(--ink);
  text-decoration: none;
  font-weight: 600;
  font-size: 0.95rem;
}

.nav-user__menu a:hover,
.nav-user__menu a:focus-visible {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  outline: none;
}

.nav-user__menu-section {
  margin-top: 6px;
  padding: 4px 12px 2px;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted-strong);
}

.nav-user__menu-divider {
  height: 1px;
  margin: 4px 6px;
  background: color-mix(in srgb, var(--ink) 10%, transparent);
}

/* Hide the long username on narrow viewports — keep just the avatar
   chip + chevron so the header doesn't wrap. */
@media (max-width: 1180px) {
  .nav-user__name { display: none; }
  .nav-user__button { padding: 4px 6px 4px 4px; }
}

.site-language-switcher {
  position: relative;
  z-index: 30;
  flex: 0 0 auto;
}

.site-language-switcher__button {
  width: 44px;
  min-width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid color-mix(in srgb, var(--accent-dark) 18%, transparent);
  border-radius: 999px;
  background:
    radial-gradient(circle at 28% 18%, rgba(255, 232, 194, 0.72), transparent 38%),
    rgba(255, 252, 246, 0.74);
  color: var(--accent-dark);
  font: inherit;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(120, 84, 42, 0.1);
  transition: background-color 0.18s ease, border-color 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.site-language-switcher__button svg {
  width: 20px;
  height: 20px;
  flex: 0 0 auto;
}

.site-language-switcher__button:hover,
.site-language-switcher__button:focus-visible,
.site-language-switcher:focus-within .site-language-switcher__button {
  background: rgba(255, 247, 236, 0.98);
  border-color: color-mix(in srgb, var(--accent) 34%, transparent);
  color: var(--accent);
  transform: translateY(-1px);
  outline: none;
}

.site-language-switcher__menu {
  position: absolute;
  inset-inline-end: 0;
  top: 100%;
  width: min(78vw, 430px);
  max-height: min(72vh, 520px);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(155px, 1fr));
  gap: 6px;
  padding: 10px;
  border: 1px solid color-mix(in srgb, var(--accent-dark) 16%, transparent);
  border-radius: 18px;
  background: var(--control-bg-strong);
  box-shadow: 0 18px 42px color-mix(in srgb, var(--ink) 15%, transparent);
  opacity: 0;
  transform: translateY(-4px);
  overflow-y: auto;
  pointer-events: none;
  transition: opacity 0.16s ease, transform 0.16s ease;
}

.site-language-switcher:hover .site-language-switcher__menu,
.site-language-switcher:focus-within .site-language-switcher__menu {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.site-language-switcher__menu a {
  min-height: 38px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  column-gap: 10px;
  row-gap: 1px;
  align-items: center;
  padding: 8px 10px;
  border-radius: 12px;
  color: var(--ink);
  text-decoration: none;
}

.site-language-switcher__language-name,
.site-language-switcher__language-native {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.site-language-switcher__language-name {
  font-weight: 750;
}

.site-language-switcher__language-native {
  grid-column: 1;
  font-size: 0.78rem;
  color: rgba(53, 43, 35, 0.62);
}

.site-language-switcher__language-code {
  grid-column: 2;
  grid-row: 1 / span 2;
  align-self: center;
  padding: 3px 6px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: var(--muted-strong);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.04em;
}

.site-language-switcher__menu a:hover,
.site-language-switcher__menu a:focus-visible,
.site-language-switcher__menu a.is-current {
  background: color-mix(in srgb, var(--accent) 11%, transparent);
  outline: none;
}

/* ============================================================
   Reusable language picker — progressive enhancement of any
   <select data-lang-select>. Visually mirrors the header's
   .site-language-switcher__menu so every page's language
   chooser uses the same look. The native <select> remains as
   the source of truth (hidden via .lang-picker__native) so
   form-submit behaviours and existing change handlers work
   unchanged.
   ============================================================ */
.lang-picker {
  position: relative;
  display: inline-flex;
  align-items: center;
  vertical-align: middle;
  font: inherit;
}

.lang-picker__native {
  /* Hide the original <select> visually but keep it focusable for
     keyboard form-flow / accessibility tools and reachable for any
     code that reads its value. */
  position: absolute !important;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  white-space: nowrap;
}

.lang-picker__button {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  padding: 6px 12px;
  border: 1px solid var(--control-border, color-mix(in srgb, var(--accent-dark) 16%, transparent));
  border-radius: 999px;
  background: var(--control-bg);
  color: var(--ink);
  font: inherit;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.14s ease, border-color 0.14s ease, box-shadow 0.14s ease, transform 0.14s ease;
}

.lang-picker__button:hover,
.lang-picker__button:focus-visible {
  background: color-mix(in srgb, var(--accent) 8%, var(--control-bg));
  border-color: color-mix(in srgb, var(--accent) 32%, var(--control-border, color-mix(in srgb, var(--accent-dark) 16%, transparent)));
  outline: none;
  transform: translateY(-1px);
  box-shadow: 0 6px 16px color-mix(in srgb, var(--accent) 12%, transparent);
}

.lang-picker__icon {
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  color: var(--accent);
}

.lang-picker__chevron {
  width: 14px;
  height: 14px;
  flex: 0 0 14px;
  color: color-mix(in srgb, var(--ink) 60%, transparent);
  transition: transform 0.16s ease;
}

.lang-picker.is-open .lang-picker__chevron {
  transform: rotate(180deg);
}

.lang-picker__current {
  font-weight: 700;
  white-space: nowrap;
  max-width: 220px;
  overflow: hidden;
  text-overflow: ellipsis;
}

.lang-picker__menu {
  position: absolute;
  inset-inline-start: 0;
  top: calc(100% + 6px);
  width: min(78vw, 430px);
  max-height: min(72vh, 520px);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(155px, 1fr));
  gap: 6px;
  padding: 10px;
  border: 1px solid color-mix(in srgb, var(--accent) 14%, var(--border-soft, color-mix(in srgb, var(--accent-dark) 16%, transparent)));
  border-radius: 18px;
  background: var(--surface-strong);
  box-shadow: 0 18px 42px color-mix(in srgb, var(--ink) 18%, transparent);
  opacity: 0;
  transform: translateY(-4px);
  overflow-y: auto;
  pointer-events: none;
  transition: opacity 0.16s ease, transform 0.16s ease;
  z-index: 80;
}

.lang-picker.is-open .lang-picker__menu {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

/* RTL-aware: when the picker sits near the inline-end of the page,
   the menu can clip off-screen. Authors can opt into anchoring to the
   end by adding .lang-picker--end. */
.lang-picker--end .lang-picker__menu {
  inset-inline-start: auto;
  inset-inline-end: 0;
}

.lang-picker__option {
  min-height: 38px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  column-gap: 10px;
  row-gap: 1px;
  align-items: center;
  padding: 8px 10px;
  border: 0;
  border-radius: 12px;
  background: transparent;
  color: var(--ink);
  text-align: start;
  font: inherit;
  cursor: pointer;
}

.lang-picker__option-name {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 750;
}

.lang-picker__option-native {
  grid-column: 1;
  font-size: 0.78rem;
  color: color-mix(in srgb, var(--ink) 62%, transparent);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.lang-picker__option-code {
  grid-column: 2;
  grid-row: 1 / span 2;
  align-self: center;
  padding: 3px 6px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: var(--muted-strong);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.04em;
}

.lang-picker__option:hover,
.lang-picker__option:focus-visible,
.lang-picker__option.is-current {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  outline: none;
}

@media (max-width: 540px) {
  .lang-picker__menu {
    grid-template-columns: minmax(0, 1fr);
    width: min(92vw, 320px);
  }
}

.site-notification-center {
  position: relative;
  z-index: 80;
  flex: 0 0 auto;
}

.site-notification-center__button {
  position: relative;
  width: 44px;
  min-width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 1px solid color-mix(in srgb, var(--accent-dark) 18%, transparent);
  border-radius: 999px;
  background:
    radial-gradient(circle at 32% 18%, rgba(255, 232, 194, 0.66), transparent 38%),
    rgba(255, 252, 246, 0.74);
  color: var(--accent-dark);
  font: inherit;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(120, 84, 42, 0.1);
  transition: background-color 0.18s ease, border-color 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.site-notification-center__button svg {
  width: 20px;
  height: 20px;
  flex: 0 0 auto;
}

.site-notification-center__status-dot {
  position: absolute;
  inset-block-start: 8px;
  inset-inline-end: 9px;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--accent);
  box-shadow: 0 0 0 2px rgba(255, 252, 246, 0.95);
  opacity: 0;
  transform: scale(0.6);
  transition: opacity 0.16s ease, transform 0.16s ease;
}

.site-notification-center__button.is-enabled .site-notification-center__status-dot {
  opacity: 1;
  transform: scale(1);
}

.site-notification-center__button:hover,
.site-notification-center__button:focus-visible,
.site-notification-center:focus-within .site-notification-center__button,
.site-notification-center.is-open .site-notification-center__button {
  background: rgba(255, 247, 236, 0.98);
  border-color: color-mix(in srgb, var(--accent) 34%, transparent);
  color: var(--accent);
  transform: translateY(-1px);
  outline: none;
}

.site-notification-center__menu {
  position: absolute;
  inset-inline-end: 0;
  top: calc(100% + 8px);
  width: min(92vw, 380px);
  display: grid;
  gap: 8px;
  padding: 14px;
  border: 1px solid color-mix(in srgb, var(--accent-dark) 20%, transparent);
  border-radius: 8px;
  background: #fffaf3;
  color: var(--ink);
  box-shadow: 0 24px 56px color-mix(in srgb, var(--ink) 22%, transparent);
  opacity: 0;
  pointer-events: none;
  transform: translateY(-4px);
  transition: opacity 0.16s ease, transform 0.16s ease;
}

.site-notification-center.is-open .site-notification-center__menu {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.site-notification-center__header {
  display: grid;
  gap: 4px;
  padding-block-end: 2px;
}

.site-notification-center__header strong {
  font-size: 1rem;
  line-height: 1.2;
}

.site-notification-center__header span {
  color: color-mix(in srgb, var(--ink) 74%, transparent);
  font-size: 0.9rem;
  line-height: 1.35;
}

.site-notification-center__actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.site-notification-center__actions button {
  min-width: 0;
  min-height: 40px;
  border: 1px solid color-mix(in srgb, var(--accent-dark) 18%, transparent);
  border-radius: 8px;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent-dark);
  font: inherit;
  font-size: 0.94rem;
  font-weight: 800;
  line-height: 1.2;
  cursor: pointer;
}

.site-notification-center__actions button:hover,
.site-notification-center__actions button:focus-visible {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  outline: none;
}

.site-notification-center__actions button:disabled {
  cursor: not-allowed;
  opacity: 0.55;
}

.site-notification-center__toggle,
.site-notification-center__time {
  min-height: 46px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  padding: 9px 10px;
  border: 1px solid color-mix(in srgb, var(--accent-dark) 10%, transparent);
  border-radius: 8px;
  background: color-mix(in srgb, var(--accent-dark) 6%, #fffaf3);
  font-size: 0.96rem;
  font-weight: 750;
  line-height: 1.25;
}

.site-notification-center__toggle input {
  position: absolute;
  inline-size: 1px;
  block-size: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
}

.site-notification-center__toggle span:first-child,
.site-notification-center__time span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.site-notification-center__toggle span:last-child {
  position: relative;
  width: 42px;
  height: 24px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--ink) 18%, transparent);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--ink) 8%, transparent);
}

.site-notification-center__toggle span:last-child::after {
  content: "";
  position: absolute;
  inset-block-start: 3px;
  inset-inline-start: 3px;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: #fffaf3;
  box-shadow: 0 2px 8px color-mix(in srgb, var(--ink) 18%, transparent);
  transition: inset-inline-start 0.16s ease, background-color 0.16s ease;
}

.site-notification-center__toggle input:checked + span {
  background: color-mix(in srgb, var(--accent) 62%, transparent);
}

.site-notification-center__toggle input:checked + span::after {
  inset-inline-start: 21px;
}

.site-notification-center__toggle input:focus-visible + span {
  outline: 2px solid color-mix(in srgb, var(--accent) 28%, transparent);
  outline-offset: 2px;
}

.site-notification-center__time input {
  width: 116px;
  min-width: 116px;
  border: 1px solid color-mix(in srgb, var(--accent-dark) 16%, transparent);
  border-radius: 8px;
  padding: 6px 9px;
  background: var(--surface);
  color: var(--ink);
  font: inherit;
  font-size: 0.94rem;
  font-weight: 750;
}

.content {
  position: relative;
  z-index: 1;
  padding: 10px 0 20px;
  animation: fadeSlide 0.8s ease both;
  flex: 1 0 auto;
  margin-bottom: 0;
}

body[data-page="home"] .content {
  margin-top: 20px;
  margin-bottom: 0;
}

body[data-page="editor"] .content--editor {
  width: min(96vw, 1760px);
  padding: 25px 0 12px;
}

.site-footer {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 220;
  border-top: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  padding: 0;
  font-size: max(20px, 0.95rem);
  margin-top: 0;
  flex-shrink: 0;
  max-height: min(42vh, 320px);
  overflow: auto;
  background: var(--control-bg-strong);
  box-shadow: 0 -18px 42px color-mix(in srgb, var(--ink) 16%, transparent);
  opacity: 0;
  pointer-events: none;
  transform: translateY(calc(100% + 18px));
  transition: opacity 160ms ease, transform 180ms ease;
}

.site-footer.is-open {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.site-footer .shell {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
  padding: 18px 24px;
}

.site-footer-toggle {
  position: fixed;
  left: 18px;
  bottom: 18px;
  z-index: 221;
  width: 48px;
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 1px solid color-mix(in srgb, var(--ink) 12%, transparent);
  border-radius: 16px;
  background: rgba(255, 251, 245, 0.94);
  color: var(--accent-dark);
  cursor: pointer;
  box-shadow: 0 12px 26px color-mix(in srgb, var(--ink) 16%, transparent);
  transition: bottom 0.18s ease, background-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.site-footer-toggle:hover,
.site-footer-toggle:focus-visible,
.site-footer-toggle.is-open {
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  box-shadow: 0 16px 30px color-mix(in srgb, var(--ink) 18%, transparent);
}

.site-footer-toggle.is-open {
  bottom: calc(var(--site-footer-height) + 12px);
}

.site-footer-toggle:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent) 28%, transparent);
  outline-offset: 2px;
}

.site-footer-toggle svg {
  width: 24px;
  height: 24px;
  stroke: currentColor;
  stroke-width: 2.1;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: transform 0.18s ease;
}

.site-footer-toggle.is-open svg {
  transform: rotate(180deg);
}

.footer-legal-links {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 14px;
}

.footer-legal-links a {
  color: inherit;
  text-decoration-color: color-mix(in srgb, var(--accent-dark) 45%, transparent);
  text-underline-offset: 0.18em;
}

.build-indicator {
  opacity: 0.65;
  font-size: max(20px, 0.84rem);
}

.viewport-zoom-controls {
  position: static;
  z-index: auto;
  display: inline-flex;
  flex: 0 0 auto;
  gap: 6px;
  margin-inline-start: auto;
  padding: 0;
  opacity: 1;
}

html[dir="rtl"] .viewport-zoom-controls {
  margin-inline-start: auto;
}

.viewport-zoom-controls:hover,
.viewport-zoom-controls:focus-within {
  opacity: 1;
}

.viewport-zoom-controls .site-notification-center__button,
.viewport-zoom-controls .site-language-switcher__button,
.viewport-zoom-controls .site-theme-switcher__button,
.viewport-zoom-controls__button {
  opacity: 0.74;
}

.viewport-zoom-controls:hover .site-notification-center__button,
.viewport-zoom-controls:focus-within .site-notification-center__button,
.viewport-zoom-controls:hover .site-language-switcher__button,
.viewport-zoom-controls:focus-within .site-language-switcher__button,
.viewport-zoom-controls:hover .site-theme-switcher__button,
.viewport-zoom-controls:focus-within .site-theme-switcher__button,
.viewport-zoom-controls:hover .viewport-zoom-controls__button,
.viewport-zoom-controls:focus-within .viewport-zoom-controls__button,
.site-notification-center.is-open .site-notification-center__button,
.site-language-switcher:focus-within .site-language-switcher__button,
.site-theme-switcher.is-open .site-theme-switcher__button {
  opacity: 1;
}

.viewport-zoom-controls__button {
  /* Match the 44px circular sizing used by .site-theme-switcher__button
     and .site-notification-center__button so the row of header chips is
     visually flush. The previous 38px made these look cramped next to
     their neighbours. */
  width: 44px;
  min-width: 44px;
  height: 44px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid color-mix(in srgb, var(--accent-dark) 18%, transparent);
  border-radius: 999px;
  background: var(--surface);
  color: var(--accent-dark);
  /* The +/- glyphs render with a slight optical offset; sub-pixel
     line-height + tabular numeric font lock them in the bullseye. */
  font: 700 1.15rem/1 system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-variant-numeric: tabular-nums;
  cursor: pointer;
  box-shadow: 0 10px 24px color-mix(in srgb, var(--ink) 8%, transparent);
  transition: border-color 0.18s ease, background 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.viewport-zoom-controls__button:hover,
.viewport-zoom-controls__button:focus-visible {
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  outline: none;
}

body.auth-modal-open {
  overflow: hidden;
}

.auth-modal {
  position: fixed;
  inset: 0;
  z-index: 20000;
  display: grid;
  place-items: center;
  padding: 28px 20px;
  overflow-y: auto;
}

.auth-modal__backdrop {
  position: absolute;
  inset: 0;
  background: color-mix(in srgb, var(--ink) 40%, transparent);
  backdrop-filter: blur(10px);
}

.auth-modal__dialog {
  position: relative;
  z-index: 1;
  width: min(452px, 100%);
  margin: auto;
  padding: 24px 24px 22px;
  border-radius: 28px;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(252, 248, 242, 0.99)),
    rgba(255, 252, 248, 0.99);
  border: 1px solid color-mix(in srgb, var(--ink) 6%, transparent);
  box-shadow:
    0 26px 56px color-mix(in srgb, var(--ink) 18%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

.auth-modal__close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 34px;
  height: 34px;
  border: 1px solid color-mix(in srgb, var(--ink) 7%, transparent);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.96);
  color: color-mix(in srgb, var(--ink) 56%, transparent);
  font-size: 1.1rem;
  cursor: pointer;
  box-shadow: 0 6px 16px color-mix(in srgb, var(--ink) 7%, transparent);
}

body[data-auth-required="true"] .auth-modal__close {
  display: none;
}

.auth-modal__header {
  display: grid;
  gap: 6px;
  margin: 0 48px 16px 0;
  min-height: 0;
  padding: 10px 0 6px;
  color: var(--ink);
  position: relative;
  z-index: 1;
}

.auth-modal__header h2,
.auth-modal__header p {
  margin: 0;
}

.auth-modal__header h2 {
  font-size: clamp(2.35rem, 3.25vw, 2.75rem);
  line-height: 1;
  letter-spacing: -0.025em;
}

.auth-modal__tabs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 4px;
  margin-bottom: 18px;
  padding: 4px;
  border-radius: 999px;
  background: rgba(243, 236, 227, 0.72);
  border: 1px solid rgba(150, 94, 42, 0.07);
  box-shadow:
    0 8px 18px rgba(135, 84, 44, 0.045),
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

.auth-modal__tab,
.auth-modal__action {
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  background: rgba(255, 255, 255, 0.9);
  color: var(--ink);
  font: inherit;
  cursor: pointer;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.auth-modal__tab {
  min-height: 40px;
  border-radius: 999px;
  font-weight: 600;
  background: transparent;
  border-color: transparent;
  font-size: 1.25rem;
}

.auth-modal__tab.is-active {
  background: linear-gradient(180deg, #fffaf3, #fffefb);
  border-color: rgba(180, 106, 47, 0.12);
  color: #8b4e1f;
  box-shadow: 0 4px 10px color-mix(in srgb, var(--ink) 5%, transparent);
}

.auth-modal__actions {
  display: grid;
  gap: 12px;
}

.auth-modal__form {
  display: grid;
  gap: 12px;
}

.auth-modal__field {
  display: grid;
  gap: 6px;
}

.auth-modal__field span {
  font-size: 1.12rem;
  font-weight: 600;
  color: color-mix(in srgb, var(--ink) 68%, transparent);
}

.auth-modal__field input {
  width: 100%;
  min-height: 52px;
  padding: 0 16px;
  border-radius: 17px;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(251, 248, 244, 0.98));
  font: inherit;
  font-size: 1.24rem;
  color: var(--ink);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.8),
    0 1px 0 rgba(255, 255, 255, 0.55);
}

.auth-modal__field input:focus {
  outline: 2px solid color-mix(in srgb, var(--accent) 12%, transparent);
  border-color: color-mix(in srgb, var(--accent) 22%, transparent);
}

.auth-modal__submit {
  min-height: 54px;
  margin-top: 8px;
  border: 0;
  border-radius: 18px;
  background: linear-gradient(180deg, #cf8138, #bd6f2e);
  color: #fffaf4;
  font: inherit;
  font-size: 1.28rem;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 14px 26px color-mix(in srgb, var(--accent) 22%, transparent);
}

.auth-modal__submit:hover,
.auth-modal__submit:focus-visible {
  transform: translateY(-1px);
}

.auth-modal__status {
  margin-bottom: 12px;
  padding: 10px 12px;
  border-radius: 14px;
  font-size: max(20px, 0.94rem);
  line-height: 1.5;
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: #6d4017;
}

.auth-modal__status.is-error {
  background: rgba(170, 51, 51, 0.1);
  color: #8f2e2e;
}

.auth-modal__status.is-success {
  background: rgba(48, 128, 82, 0.12);
  color: #1f6d3f;
}

.auth-modal__divider {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 12px;
  align-items: center;
  margin: 14px 0 12px;
  color: color-mix(in srgb, var(--ink) 48%, transparent);
  font-size: 1.1rem;
}

.auth-modal__divider::before,
.auth-modal__divider::after {
  content: "";
  height: 1px;
  background: color-mix(in srgb, var(--ink) 10%, transparent);
}

.auth-modal__action {
  min-height: 54px;
  padding: 0 18px;
  border-radius: 18px;
  justify-content: center;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-weight: 600;
  color: #2f251c;
  background: linear-gradient(180deg, #fffdfa, #f9f2e9);
  border-color: rgba(151, 83, 35, 0.12);
  box-shadow:
    0 8px 18px color-mix(in srgb, var(--ink) 4.5%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.auth-modal__action--primary {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  border-color: color-mix(in srgb, var(--accent) 36%, transparent);
  color: var(--accent-dark);
}

.auth-modal__action-icon {
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--accent), var(--accent-dark));
  color: var(--on-accent);
  box-shadow:
    0 8px 16px rgba(180, 105, 45, 0.22),
    inset 0 1px 0 rgba(255, 238, 214, 0.24);
}

.auth-modal__action-icon svg {
  width: 17px;
  height: 17px;
  display: block;
}

.auth-modal__action span:last-child {
  font-size: 1.28rem;
  letter-spacing: -0.01em;
  line-height: 1;
}

.auth-modal__action--google {
  background: linear-gradient(180deg, #fffdfa, #f9f2e9);
  border-color: rgba(151, 83, 35, 0.12);
  color: #2f251c;
}

.auth-modal__action--google .auth-modal__action-icon {
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 88%, var(--surface)), var(--accent-dark));
}

.auth-modal__action--google .auth-modal__action-icon svg path {
  fill: currentColor !important;
}

.auth-modal__action--facebook {
  background: linear-gradient(180deg, #fffdfa, #f9f2e9);
  border-color: rgba(151, 83, 35, 0.12);
  color: #2f251c;
}

.auth-modal__action--facebook .auth-modal__action-icon {
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent-dark) 82%, var(--surface)), var(--accent-dark));
  color: var(--on-accent);
  box-shadow:
    0 8px 16px rgba(180, 105, 45, 0.22),
    inset 0 1px 0 rgba(255, 238, 214, 0.24);
}

.auth-modal__field--code {
  display: grid;
  justify-items: center;
  gap: 14px;
  text-align: center;
  width: 100%;
  padding: 10px 2px 2px;
}

.auth-modal__field--code[hidden] {
  display: none;
}

.auth-modal__code-card {
  width: min(100%, 360px);
  display: grid;
  gap: 8px;
  padding: 18px 18px 16px;
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(245, 239, 231, 0.72), rgba(255, 251, 246, 0.92));
  border: 1px solid rgba(167, 110, 62, 0.12);
  box-shadow:
    0 16px 30px rgba(109, 75, 40, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.auth-modal__code-label {
  font-size: 1.22rem;
  font-weight: 700;
  color: color-mix(in srgb, var(--ink) 80%, transparent);
}

.auth-modal__code-copy {
  margin: 0;
  color: color-mix(in srgb, var(--ink) 62%, transparent);
  line-height: 1.4;
  font-size: 1.18rem;
}

.auth-modal__code-meta {
  margin: 0;
  color: rgba(120, 75, 34, 0.86);
  font-size: max(20px, 1rem);
  line-height: 1.45;
}

.auth-modal__code-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.auth-modal__otp {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 56px));
  gap: 10px;
  justify-content: center;
  width: 100%;
}

.auth-modal__otp-input {
  width: 56px;
  min-width: 56px;
  height: 66px;
  padding: 0;
  border-radius: 20px;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  background: linear-gradient(180deg, #fffefc, #faf5ee);
  color: var(--ink);
  font: inherit;
  font-size: 1.74rem;
  font-weight: 700;
  text-align: center;
  box-shadow:
    0 12px 24px color-mix(in srgb, var(--ink) 5.5%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.88);
}

.auth-modal__otp-input:focus {
  outline: none;
  border-color: color-mix(in srgb, var(--accent) 46%, transparent);
  box-shadow:
    0 14px 28px color-mix(in srgb, var(--accent) 16%, transparent),
    0 0 0 4px color-mix(in srgb, var(--accent) 12%, transparent);
  transform: translateY(-1px);
}

.auth-modal__code-actions {
  display: grid;
  justify-items: center;
  gap: 8px;
}

.auth-modal__resend {
  min-height: 44px;
  padding: 0 18px;
  border: 1px solid rgba(166, 102, 48, 0.16);
  border-radius: 999px;
  background: rgba(255, 250, 244, 0.92);
  color: #9a5926;
  font: inherit;
  font-size: 1.02rem;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 8px 18px rgba(120, 84, 42, 0.06);
}

.auth-modal__resend:disabled {
  cursor: default;
  opacity: 0.62;
}

.auth-modal__resend-note {
  color: color-mix(in srgb, var(--ink) 50%, transparent);
  font-size: max(20px, 0.94rem);
  line-height: 1.4;
}

.auth-modal--confirming .auth-modal__tabs,
.auth-modal--confirming .auth-modal__actions,
.auth-modal--confirming .auth-modal__divider,
.auth-modal--confirming .auth-modal__field:not(.auth-modal__field--code),
.auth-modal--confirming .auth-modal__submit {
  display: none;
}

.auth-modal--confirming .auth-modal__header {
  margin: 0 44px 12px;
  text-align: center;
}

.auth-modal--confirming .auth-modal__header h2 {
  max-width: 9ch;
  margin-inline: auto;
  font-size: clamp(2.05rem, 2.9vw, 2.4rem);
  line-height: 1.02;
}

.auth-modal--confirming .auth-modal__form {
  justify-items: center;
  gap: 16px;
}

.auth-modal__tab:hover,
.auth-modal__tab:focus-visible,
.auth-modal__action:hover,
.auth-modal__action:focus-visible,
.auth-modal__submit:hover,
.auth-modal__submit:focus-visible,
.auth-modal__close:hover,
.auth-modal__close:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(120, 84, 42, 0.1);
}

.auth-modal__hint {
  display: none;
  margin: 0;
  color: color-mix(in srgb, var(--ink) 70%, transparent);
  line-height: 1.5;
  font-size: max(20px, 0.92rem);
  max-width: 34ch;
}

@media (max-width: 640px) {
  .auth-modal {
    place-items: start center;
    padding: 14px 12px 22px;
  }

  .auth-modal__dialog {
    width: min(100%, 440px);
    padding: 20px 18px 18px;
    border-radius: 26px;
  }

  .auth-modal__header {
    margin: 0 42px 14px 0;
    min-height: 0;
    padding-top: 8px;
  }

  .auth-modal__header h2 {
    font-size: 1.72rem;
  }

  .auth-modal__tabs {
    margin-bottom: 16px;
  }

  .auth-modal__field input,
  .auth-modal__submit,
  .auth-modal__action {
    min-height: 52px;
  }

  .auth-modal__action {
    gap: 10px;
    padding-inline: 16px;
  }

  .auth-modal__action-icon {
    width: 36px;
    height: 36px;
  }

  .auth-modal__otp {
    grid-template-columns: repeat(6, minmax(0, 44px));
    gap: 8px;
  }

  .auth-modal__otp-input {
    width: 44px;
    min-width: 44px;
    height: 54px;
    border-radius: 16px;
    font-size: 1.35rem;
  }

  .auth-modal__code-card {
    width: 100%;
    padding: 16px 14px 14px;
    border-radius: 18px;
  }

  .auth-modal--confirming .auth-modal__header {
    margin: 0 44px 8px 44px;
  }
}

/* @media (max-width: 1600px) {
  .auth-modal {
    padding: 14px;
  }

  .auth-modal__dialog {
    width: min(390px, 100%);
    max-height: calc(100vh - 20px);
    padding: 18px 16px 14px;
    border-radius: 22px;
  }

  .auth-modal__header {
    margin-bottom: 12px;
  }

  .auth-modal__tabs {
    margin-bottom: 10px;
  }

  .auth-modal__form,
  .auth-modal__actions {
    gap: 8px;
  }

  .auth-modal__field {
    gap: 5px;
  }

  .auth-modal__field span {
    font-size: max(20px, 0.86rem);
  }

  .auth-modal__field input,
  .auth-modal__submit,
  .auth-modal__action {
    min-height: 46px;
  }

  .auth-modal__divider {
    margin: 12px 0 10px;
  }

  .auth-modal__hint {
    display: none;
  }
} */

.hero {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 32px;
  align-items: center;
}

.hero-content h1 {
  font-size: clamp(2.4rem, 4vw, 3.5rem);
  margin: 12px 0 0;
}

.hero-tagline {
  max-width: 720px;
  margin: 18px 0 0;
  color: var(--muted-strong);
  font-size: 1.25rem;
  line-height: 1.65;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 24px;
  border-radius: 999px;
  border: 1px solid var(--accent);
  text-decoration: none;
  font-weight: 600;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.btn.primary {
  background: var(--accent);
  color: #fffaf4;
  box-shadow: 0 12px 30px color-mix(in srgb, var(--accent) 30%, transparent);
}

.btn.ghost {
  background: transparent;
  color: var(--accent-dark);
}

.btn:hover {
  transform: translateY(-2px);
}

.hero-search-card {
  background: var(--glass);
  border-radius: 28px;
  padding: 32px;
  box-shadow: 0 18px 40px var(--shadow);
  border: 1px solid color-mix(in srgb, var(--accent-dark) 12%, transparent);
}

.hero-search-card h2 {
  margin: 0 0 10px;
  font-size: clamp(1.7rem, 2vw, 2.25rem);
}

.hero-search-card p {
  margin: 0 0 22px;
  line-height: 1.6;
}

.hero-search-form {
  display: flex;
  align-items: center;
  gap: 12px;
  position: relative;
  padding: 10px 12px 10px 18px;
  border-radius: 999px;
  background: var(--control-bg);
  border: 1px solid color-mix(in srgb, var(--accent-dark) 16%, transparent);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

.hero-search-form input {
  min-height: 44px;
}

.primary-destination-cards {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 28px;
  margin-top: 48px;
}

@media (min-width: 1181px) and (min-height: 720px) {
  body[data-page="home"] .content {
    margin-top: 8px;
    padding-bottom: 10px;
  }

  body[data-page="home"] .hero {
    gap: 22px;
  }

  body[data-page="home"] .hero-search-card {
    padding: 24px 28px;
    border-radius: 22px;
  }

  body[data-page="home"] .hero-search-card h2 {
    margin-bottom: 6px;
    font-size: clamp(1.5rem, 1.7vw, 2rem);
  }

  body[data-page="home"] .hero-search-card p {
    margin-bottom: 16px;
    line-height: 1.45;
  }

  body[data-page="home"] .primary-destination-cards {
    gap: 20px;
    margin-top: 28px;
  }

  body[data-page="home"] .destination-card {
    min-height: 286px;
    padding: 22px;
    border-radius: 22px;
  }

  body[data-page="home"] .destination-card__image-wrap {
    min-height: 118px;
    padding: 0 0 12px;
  }

  body[data-page="home"] .destination-card__image {
    max-height: 132px;
  }

  body[data-page="home"] .destination-card__image--wide-book,
  body[data-page="home"] .destination-card__image--icon {
    max-height: 124px;
  }

  body[data-page="home"] .destination-card__content h3 {
    margin-bottom: 8px;
    font-size: clamp(1.42rem, 1.75vw, 1.82rem);
  }

  body[data-page="home"] .destination-card__content p {
    font-size: 1.05rem;
    line-height: 1.42;
  }
}

@media (max-width: 1180px) {
  .primary-destination-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.destination-card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 344px;
  padding: 32px;
  border-radius: 28px;
  text-decoration: none;
  color: var(--ink);
  background: #f4ebdd;
  border: 1px solid #e4d7c8;
  box-shadow: 0 14px 34px rgba(120, 84, 42, 0.10);
  transition: transform 0.24s ease, box-shadow 0.24s ease, filter 0.24s ease;
}

.destination-card:hover,
.destination-card:focus-visible {
  transform: translateY(-4px);
  box-shadow: 0 18px 40px rgba(120, 84, 42, 0.16);
}

.destination-card:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--accent) 35%, transparent);
  outline-offset: 4px;
}

.destination-card__image-wrap {
  min-height: 170px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px 0 20px;
}

.destination-card__image {
  max-width: 100%;
  max-height: 180px;
  object-fit: contain;
  filter: drop-shadow(0 14px 24px rgba(117, 84, 40, 0.10));
  transition: transform 0.24s ease, filter 0.24s ease;
}

.destination-card:hover .destination-card__image,
.destination-card:focus-visible .destination-card__image {
  transform: translateY(-2px) scale(1.02);
  filter: brightness(1.04) drop-shadow(0 16px 28px rgba(117, 84, 40, 0.14));
}

.destination-card__content h3 {
  margin: 0 0 12px;
  font-size: clamp(1.75rem, 2.2vw, 2.1rem);
  line-height: 1.1;
}

.destination-card__content p {
  margin: 0;
  font-size: 1.2rem;
  line-height: 1.55;
  color: color-mix(in srgb, var(--ink) 76%, transparent);
}

.destination-card--bible,
.destination-card--prayer,
.destination-card--synaxarium,
.destination-card--media,
.destination-card--library,
.destination-card--saints,
.destination-card--prayers,
.destination-card--search,
.destination-card--verses,
.destination-card--forum {
  background: linear-gradient(180deg, #f7f1e8 0%, #f3eadc 100%);
}

.destination-card__image--book-cover {
  border-radius: 6px;
  box-shadow: 0 16px 26px rgba(51, 37, 22, 0.20);
}

.destination-card__image--wide-book {
  max-height: 170px;
  border-radius: 10px;
  object-fit: contain;
}

.destination-card__image--icon {
  max-height: 170px;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.page-title {
  font-size: clamp(2rem, 3vw, 2.8rem);
  margin-bottom: 8px;
}

.page-subtitle {
  max-width: 700px;
  line-height: 1.6;
  margin-bottom: 32px;
}

.panel {
  background: rgba(255, 255, 255, 0.82);
  border-radius: 24px;
  padding: 24px;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  box-shadow: 0 10px 30px color-mix(in srgb, var(--ink) 8%, transparent);
}

.legal-page {
  max-width: 980px;
  margin: 0 auto;
}

.legal-doc {
  padding: clamp(20px, 2.8vw, 34px);
  background:
    radial-gradient(circle at top right, rgba(171, 118, 57, 0.12), transparent 36%),
    linear-gradient(180deg, rgba(255, 248, 238, 0.95), rgba(255, 252, 247, 0.98));
  border: 1px solid rgba(113, 66, 22, 0.12);
  box-shadow: 0 24px 60px rgba(66, 44, 20, 0.08);
}

.legal-doc__hero {
  display: grid;
  grid-template-columns: minmax(0, 1.7fr) minmax(260px, 0.9fr);
  gap: 22px;
  align-items: start;
  padding: clamp(18px, 2.2vw, 28px);
  padding-bottom: 22px;
  border-bottom: 1px solid rgba(113, 66, 22, 0.14);
  border-radius: 24px;
}

.legal-doc__hero-copy {
  min-width: 0;
}

.legal-doc__lede {
  max-width: 70ch;
  margin: 18px 0 0;
  font-size: 1.06rem;
  line-height: 1.8;
  color: rgba(45, 31, 17, 0.88);
}

.legal-doc__hero-statblock {
  display: grid;
  gap: 12px;
}

.legal-doc__stat,
.legal-doc__card {
  padding: 16px 18px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(113, 66, 22, 0.1);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

.legal-doc__stat-label {
  display: block;
  margin-bottom: 6px;
  font-size: max(20px, 0.76rem);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--accent-dark) 78%, transparent);
}

.legal-doc__stat strong {
  display: block;
  line-height: 1.55;
  font-size: max(20px, 1rem);
  color: #2d1f11;
}

.legal-doc__layout {
  display: grid;
  grid-template-columns: minmax(220px, 270px) minmax(0, 1fr);
  gap: 28px;
  margin-top: 24px;
}

.legal-doc__rail {
  display: grid;
  gap: 16px;
  align-content: start;
}

.legal-doc__card h2 {
  margin: 0 0 10px;
  font-size: 1.04rem;
}

.legal-doc__card p,
.legal-doc__card li {
  font-size: max(20px, 0.97rem);
  line-height: 1.7;
}

.legal-doc__toc {
  display: grid;
  gap: 10px;
}

.legal-doc__toc a {
  color: #6d4017;
  font-weight: 600;
  text-decoration: none;
}

.legal-doc__toc a:hover,
.legal-doc__toc a:focus-visible {
  text-decoration: underline;
  text-underline-offset: 0.18em;
}

.legal-doc__content {
  margin-top: 0;
}

.legal-doc__content section + section {
  margin-top: 28px;
}

.legal-doc__content h2 {
  margin: 0 0 10px;
  font-size: 1.45rem;
}

.legal-doc__content h3 {
  margin: 18px 0 8px;
  font-size: 1.07rem;
  color: #4b2f16;
}

.legal-doc__content p,
.legal-doc__content li {
  max-width: 76ch;
  line-height: 1.78;
}

.legal-doc__content ul,
.legal-doc__content ol {
  margin: 10px 0 0;
  padding-inline-start: 26px;
}

.legal-page__eyebrow {
  display: inline-block;
  margin-bottom: 8px;
  font-size: max(20px, 0.95rem);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--accent-dark) 78%, transparent);
}

.legal-page__content {
  margin-top: 24px;
  line-height: 1.7;
}

.legal-page__content h2 {
  margin: 26px 0 10px;
  font-size: 1.55rem;
}

.legal-page__content p,
.legal-page__content li {
  max-width: 75ch;
}

.legal-page__content ul,
.legal-page__content ol {
  margin: 10px 0 0;
  padding-inline-start: 28px;
}

@media (max-width: 920px) {
  .legal-doc__hero,
  .legal-doc__layout {
    grid-template-columns: 1fr;
  }
}

.social-symbols {
  position: absolute;
  width: 0;
  height: 0;
  overflow: hidden;
}

.social-page {
  width: min(1160px, calc(100% - 32px));
  margin: 0 auto;
  padding: 42px 0 76px;
}

.social-page[dir="rtl"] {
  font-family: var(--arabic-site-font);
}

.social-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 28px;
  align-items: end;
  padding-bottom: 26px;
  border-bottom: 1px solid var(--border-soft);
}

.social-page__eyebrow {
  margin: 0 0 10px;
  color: color-mix(in srgb, var(--accent-dark) 78%, var(--ink) 22%);
  font-size: 0.9rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

.social-hero h1 {
  margin: 0;
  color: var(--ink);
  font-family: var(--display-font);
  font-size: 4.2rem;
  line-height: 0.96;
  letter-spacing: 0;
}

.social-hero p {
  max-width: 720px;
  margin: 18px 0 0;
  color: var(--muted-strong);
  font-size: 1.16rem;
  line-height: 1.7;
}

.social-language-legend {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
  min-width: 220px;
}

.social-language-legend span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 36px;
  padding: 7px 10px;
  border: 1px solid var(--control-border);
  border-radius: 8px;
  background: var(--control-bg);
  color: var(--muted-strong);
  font-weight: 700;
}

.social-language-legend strong,
.social-profile__locale {
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 28px;
  border-radius: 8px;
  background: color-mix(in srgb, var(--accent) 16%, var(--surface));
  color: var(--accent-dark);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0;
}

.social-links-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-top: 24px;
}

.social-platform {
  display: grid;
  gap: 18px;
  min-width: 0;
  padding: 18px;
  border: 1px solid var(--border-soft);
  border-radius: 8px;
  background: var(--surface);
  box-shadow: 0 16px 36px var(--surface-shadow);
}

.social-platform__heading {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 12px;
  align-items: center;
}

.social-platform__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  border: 1px solid color-mix(in srgb, var(--accent) 34%, var(--control-border));
  border-radius: 8px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--accent) 16%, var(--surface)), color-mix(in srgb, var(--accent) 7%, var(--surface)));
  color: color-mix(in srgb, var(--accent-dark) 84%, var(--ink) 16%);
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--surface) 72%, transparent);
}

.social-platform__icon svg {
  width: 28px;
  height: 28px;
}

.social-icon-stroke {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.75;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.social-icon-fill {
  fill: currentColor;
  stroke: none;
}

.social-platform h2 {
  margin: 0;
  color: var(--ink);
  font-size: 1.3rem;
  letter-spacing: 0;
}

.social-platform__heading p {
  margin: 3px 0 0;
  color: var(--muted);
  font-size: 0.98rem;
  line-height: 1.4;
}

.social-profile-list {
  display: grid;
  gap: 10px;
}

.social-profile {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  min-height: 62px;
  padding: 10px;
  border: 1px solid var(--control-border);
  border-radius: 8px;
  background: color-mix(in srgb, var(--control-bg) 86%, transparent);
  color: var(--ink);
  text-decoration: none;
  transition: background-color 0.16s ease, border-color 0.16s ease, color 0.16s ease, transform 0.16s ease;
}

.social-profile:hover,
.social-profile:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 52%, var(--control-border));
  background: color-mix(in srgb, var(--accent) 16%, var(--control-bg));
  color: var(--accent-dark);
  outline: 0;
  transform: translateY(-1px);
}

.social-profile:focus-visible {
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 18%, transparent);
}

.social-profile__copy {
  min-width: 0;
}

.social-profile__language,
.social-profile__handle {
  display: block;
}

.social-profile__language {
  color: var(--muted);
  font-size: 0.88rem;
  font-weight: 700;
}

.social-profile__handle {
  overflow-wrap: anywhere;
  color: inherit;
  direction: ltr;
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.3;
  unicode-bidi: isolate;
}

.social-profile__arrow {
  width: 19px;
  height: 19px;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  opacity: 0.72;
}

.social-page[dir="rtl"] .social-language-legend {
  justify-content: flex-start;
}

@media (max-width: 1080px) {
  .social-links-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .social-page {
    width: min(100% - 24px, 640px);
    padding: 28px 0 58px;
  }

  .social-hero {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .social-hero h1 {
    font-size: 2.7rem;
  }

  .social-language-legend {
    justify-content: flex-start;
  }

  .social-links-grid {
    grid-template-columns: 1fr;
  }
}

.reader-panel {
  position: relative;
}

.reader-topbar {
  display: none;
  gap: 8px;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  margin-bottom: 16px;
}

.reader-ref {
  font-weight: 700;
}

.reader-sub {
  font-size: max(20px, 0.9rem);
  opacity: 0.7;
}

.bible-switcher {
  margin-bottom: 24px;
}

.reader-controls {
  display: grid;
  gap: 16px;
  margin-bottom: 24px;
}

.reader-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.reader-settings {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  align-items: center;
  font-size: max(20px, 0.95rem);
}

.reader-settings-popup {
  position: fixed;
  inset: 0;
  z-index: 25;
  display: none;
  justify-content: center;
  align-items: center;
  padding: 12px;
}

.reader-settings-popup.is-open {
  display: flex;
}

.reader-settings-popup__panel {
  position: relative;
  width: min(540px, 92vw);
  background: #fffaf4;
  border-radius: 18px;
  border: 1px solid color-mix(in srgb, var(--ink) 16%, transparent);
  box-shadow: 0 20px 50px var(--shadow);
  padding: 14px 16px;
  display: grid;
  gap: 14px;
}

.reader-settings-popup__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.reader-settings-popup__header h2 {
  margin: 0;
  font-size: 1.2rem;
}

.reader-settings-popup__close {
  font-size: 1.2rem;
  border: none;
  background: transparent;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  font-weight: 700;
  color: var(--ink);
  font-family: inherit;
  cursor: pointer;
}

.reader-settings-popup__actions {
  justify-self: end;
}

.reader-settings label {
  display: inline-flex;
  gap: 6px;
  align-items: center;
}

.compare-tabs {
  display: none;
  gap: 12px;
  margin-bottom: 16px;
}

.compare-grid {
  display: grid;
  gap: 24px;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.search-page {
  display: grid;
  gap: 28px;
}

.search-page--narrow {
  width: min(80%, 1400px);
  margin: 0 auto;
}

.search-results-top {
  display: grid;
  gap: 14px;
  padding: 18px 22px;
  border-radius: 28px;
  background: rgba(248, 244, 238, 0.92);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  box-shadow: 0 16px 34px color-mix(in srgb, var(--ink) 8%, transparent);
  backdrop-filter: blur(12px);
}

body[data-page="search"] .header-search {
  display: none;
}

body[data-page="home"] .header-search {
  display: none;
}

.search-results-form-shell {
  display: grid;
  gap: 14px;
}

.search-results-top__content {
  display: flex;
  align-items: center;
  gap: 18px;
}

.search-results-form {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  gap: 10px;
  position: relative;
  min-height: 60px;
  padding: 8px 12px 8px 22px;
  border-radius: 999px;
  background: var(--control-bg);
  border: 1px solid color-mix(in srgb, var(--accent-dark) 15%, transparent);
  box-shadow: 0 10px 26px rgba(120, 84, 42, 0.08);
}

@keyframes search-loading-bar {
  0% {
    background-position: 180% 0;
  }
  100% {
    background-position: -180% 0;
  }
}

.search-results-form input {
  width: 100%;
  border: 0;
  outline: 0;
  padding-inline: 10px;
  background: transparent;
  color: var(--ink);
  font: inherit;
  font-size: 1.08rem;
}

.search-bible-picker {
  flex: 0 0 280px;
  display: grid;
  gap: 6px;
  color: color-mix(in srgb, var(--ink) 68%, transparent);
  font-size: max(20px, 0.86rem);
  font-weight: 700;
}

.search-bible-picker select {
  width: 100%;
  min-height: 48px;
  border: 1px solid color-mix(in srgb, var(--accent-dark) 18%, transparent);
  border-radius: 999px;
  background: var(--control-bg);
  color: var(--ink);
  font: inherit;
  font-size: max(20px, 0.98rem);
  padding: 0 38px 0 16px;
  box-shadow: 0 10px 24px rgba(120, 84, 42, 0.07);
}

[dir="rtl"] .search-bible-picker select {
  padding: 0 16px 0 38px;
}

.search-quick-nav {
  position: absolute;
  inset-inline: 0;
  top: calc(100% + 10px);
  z-index: 40;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--accent-dark) 14%, transparent);
  border-radius: 24px;
  background: rgba(255, 251, 245, 0.98);
  box-shadow: 0 22px 48px color-mix(in srgb, var(--ink) 16%, transparent);
}

.search-quick-nav__list {
  display: grid;
}

.search-quick-nav__item {
  width: 100%;
  display: grid;
  gap: 4px;
  padding: 14px 18px;
  border: 0;
  border-bottom: 1px solid color-mix(in srgb, var(--ink) 6%, transparent);
  background: transparent;
  text-align: start;
  cursor: pointer;
}

.search-quick-nav__item:last-child {
  border-bottom: 0;
}

.search-quick-nav__item:hover,
.search-quick-nav__item.is-active {
  background: color-mix(in srgb, var(--accent) 9%, transparent);
}

.search-quick-nav__label {
  color: color-mix(in srgb, var(--ink) 92%, transparent);
  font-size: max(20px, 1rem);
  font-weight: 700;
}

.search-quick-nav__meta {
  color: color-mix(in srgb, var(--ink) 62%, transparent);
  font-size: max(20px, 0.9rem);
}

.advanced-search-toggle {
  border: 0;
  background: transparent;
  color: var(--accent-dark);
  font: inherit;
  font-weight: 600;
  cursor: pointer;
  padding: 10px 4px;
  white-space: nowrap;
}

.advanced-search-toggle:hover,
.advanced-search-toggle:focus-visible {
  color: var(--accent);
}

.advanced-search-toggle:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent) 28%, transparent);
  outline-offset: 4px;
  border-radius: 8px;
}

.advanced-search-panel {
  display: none;
  padding-top: 4px;
}

.advanced-search-panel.is-open {
  display: block;
}

.advanced-search-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-bottom: 14px;
}

.advanced-search-form {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  align-items: center;
}

.advanced-search-check {
  display: inline-flex;
  gap: 10px;
  align-items: center;
  min-height: 48px;
}

.search-results-shell {
  display: grid;
  grid-template-columns: minmax(240px, 280px) minmax(0, 1fr);
  gap: 36px;
  align-items: start;
}

.search-results-meta {
  position: sticky;
  top: 220px;
  display: grid;
  gap: 12px;
  padding: 18px;
  border-radius: 24px;
}

.search-results-meta__eyebrow {
  margin: 0;
  font-size: max(20px, 0.8rem);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--ink) 56%, transparent);
}

.search-results-meta h1 {
  margin: 0;
  font-size: clamp(2rem, 2.6vw, 2.7rem);
  line-height: 1.02;
}

.search-results-meta > p {
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.65;
  color: color-mix(in srgb, var(--ink) 75%, transparent);
}

.search-stats-card,
.search-empty-state {
  padding: 18px 20px;
  border-radius: 20px;
  background: var(--surface);
  border: 1px solid color-mix(in srgb, var(--accent-dark) 12%, transparent);
  box-shadow: 0 12px 26px color-mix(in srgb, var(--ink) 6%, transparent);
}

.search-bible-card {
  display: grid;
  gap: 4px;
  padding: 16px 18px;
  border-radius: 20px;
  background: linear-gradient(145deg, rgba(255, 252, 246, 0.92), rgba(245, 230, 207, 0.68));
  border: 1px solid color-mix(in srgb, var(--accent-dark) 12%, transparent);
  box-shadow: 0 12px 26px color-mix(in srgb, var(--ink) 6%, transparent);
}

.search-bible-card span,
.search-bible-card small {
  color: color-mix(in srgb, var(--ink) 62%, transparent);
  font-size: max(20px, 0.85rem);
}

.search-bible-card strong {
  color: var(--ink);
  font-size: max(20px, 1.08rem);
}

.search-stats-card__count,
.search-stats-card__scope,
.search-stats-card__hint {
  margin: 0;
}

.search-stats-card__count {
  font-size: 1.1rem;
  font-weight: 700;
}

.search-stats-card__scope,
.search-stats-card__hint {
  margin-top: 8px;
  color: color-mix(in srgb, var(--ink) 72%, transparent);
}

.search-share-button {
  width: 36px;
  height: 36px;
  min-width: 36px;
  min-height: 36px;
  padding: 0;
  border-radius: 50%;
  align-items: center;
  justify-content: center;
  align-self: center;
  flex: 0 0 auto;
}

.search-share-button svg {
  width: 18px;
  height: 18px;
}

/* The standalone share button on full-page share rails (not in result rows)
   keeps the larger 42px size for tap targets. */
.search-share-button.search-share-button--page {
  width: 42px;
  height: 42px;
  min-width: 42px;
  min-height: 42px;
}

.search-share-button--page {
  margin-top: 12px;
}

.search-share-button.is-copied {
  border-color: color-mix(in srgb, var(--success, #227741) 34%, var(--control-border));
  background: color-mix(in srgb, var(--success, #227741) 12%, var(--control-bg));
  color: color-mix(in srgb, var(--success, #227741) 82%, var(--ink));
}

.search-results-main {
  min-width: 0;
  display: grid;
  gap: 18px;
}

.search-language-warning {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px 18px;
  padding: 14px 16px;
  border-radius: 18px;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent) 22%, transparent);
  color: color-mix(in srgb, var(--ink) 82%, transparent);
}

.search-language-warning p {
  flex: 1 1 260px;
  margin: 0;
}

.search-language-warning a {
  color: var(--accent-dark);
  font-weight: 800;
  text-decoration: none;
}

.search-language-warning a:hover,
.search-language-warning a:focus-visible {
  text-decoration: underline;
}

.search-tabs {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 6px;
  padding: 8px 10px 0;
  border-radius: 22px 22px 0 0;
  border-bottom: 1px solid color-mix(in srgb, var(--ink) 12%, transparent);
}

.search-tab {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 0 18px 10px;
  color: color-mix(in srgb, var(--ink) 68%, transparent);
  font-weight: 800;
  text-decoration: none;
}

.search-tab::after {
  content: "";
  position: absolute;
  inset-inline: 12px;
  bottom: -1px;
  height: 3px;
  border-radius: 999px 999px 0 0;
  background: transparent;
}

.search-tab:hover,
.search-tab:focus-visible,
.search-tab.is-active {
  color: var(--accent-dark);
}

.search-tab.is-active::after {
  background: var(--accent);
}

.search-media-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 18px;
}

.search-media-grid--images {
  display: block;
  columns: 4 220px;
  column-gap: 18px;
}

.search-media-grid--images .search-media-card {
  width: 100%;
  display: inline-block;
  margin: 0 0 18px;
  break-inside: avoid;
}

.search-media-grid--videos {
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 24px;
}

.search-media-card {
  overflow: hidden;
  border-radius: 24px;
  background: var(--surface);
  border: 1px solid color-mix(in srgb, var(--accent-dark) 12%, transparent);
  box-shadow: 0 16px 34px color-mix(in srgb, var(--ink) 8%, transparent);
}

.search-media-card__visual {
  display: block;
  aspect-ratio: 4 / 3;
  background: color-mix(in srgb, var(--ink) 6%, transparent);
}

.search-media-grid--images .search-media-card__visual {
  aspect-ratio: auto;
}

.search-media-card__visual img,
.search-media-card__video,
.search-media-card__video-thumb img {
  width: 100%;
  height: 100%;
  min-height: 220px;
  display: block;
  object-fit: cover;
}

.search-media-grid--images .search-media-card__visual img {
  height: auto;
  min-height: 0;
  object-fit: contain;
}

.search-media-card__video {
  background: #15120f;
}

.search-media-card__video-thumb {
  position: relative;
  display: block;
  overflow: hidden;
  background: #15120f;
  color: #fffaf4;
  text-decoration: none;
}

.search-media-card__video-thumb::before {
  content: "";
  display: block;
  aspect-ratio: 16 / 9;
}

.search-media-card__video-thumb img {
  position: absolute;
  inset: 0;
  min-height: 0;
}

.search-media-card__play {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.06), rgba(0, 0, 0, 0.32));
}

.search-media-card__play svg {
  width: 62px;
  height: 62px;
  padding: 16px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.72);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.28);
}

.search-media-grid--videos .search-media-card {
  overflow: visible;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.search-media-grid--videos .search-media-card__video,
.search-media-grid--videos .search-media-card__video-thumb {
  aspect-ratio: 16 / 9;
  height: auto;
  min-height: 0;
  border-radius: 18px;
  box-shadow: 0 16px 34px color-mix(in srgb, var(--ink) 12%, transparent);
}

.search-media-grid--videos .search-media-card__body {
  padding: 12px 2px 0;
}

.search-media-card__body {
  display: grid;
  gap: 10px;
  padding: 14px;
}

.search-media-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.search-media-card__title {
  color: var(--accent-dark);
  font-weight: 800;
  text-decoration: none;
}

.search-media-card__title:hover,
.search-media-card__title:focus-visible {
  text-decoration: underline;
}

.search-media-card__body p {
  margin: 0;
  color: color-mix(in srgb, var(--ink) 72%, transparent);
  font-size: max(20px, 0.95rem);
  line-height: 1.55;
}

@media (max-width: 1000px) {
  .search-results-shell {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .search-results-meta {
    position: static;
  }
}

.search-engine-results {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 18px;
}

.search-engine-result {
  padding: 20px 22px 22px;
  border-radius: 24px;
  border-bottom: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
}

.search-engine-result__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
  font-size: max(20px, 0.92rem);
  color: color-mix(in srgb, var(--ink) 62%, transparent);
}

.search-engine-result__domain {
  color: color-mix(in srgb, var(--ink) 76%, transparent);
  font-weight: 600;
}

.search-engine-result__badge {
  padding: 6px 12px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent-dark);
  font-size: max(20px, 0.8rem);
  font-weight: 700;
}

.search-engine-result__title {
  display: inline-block;
  margin-bottom: 4px;
  color: #5e3ad8;
  text-decoration: none;
  font-size: clamp(1.3rem, 2vw, 1.55rem);
  line-height: 1.18;
}

.search-engine-result__title:hover,
.search-engine-result__title:focus-visible {
  text-decoration: underline;
}

.search-engine-result__url {
  margin: 0 0 10px;
  color: #2c6a4f;
  font-size: max(20px, 0.92rem);
  word-break: break-word;
}

.search-engine-result__snippet {
  margin: 0;
  font-size: 25px;
  line-height: 1.75;
  color: color-mix(in srgb, var(--ink) 82%, transparent);
}

.search-engine-result__snippet mark {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  color: inherit;
  border-radius: 6px;
  padding: 0 2px;
}

.compare-column {
  display: grid;
  gap: 12px;
}

.compare-column.hidden {
  display: none;
}

.verse-list {
  display: grid;
  gap: 12px;
}

.verse-list.line-breaks-off {
  display: block;
  line-height: 1.8;
}

.verse-list.line-breaks-off .verse {
  display: inline;
  padding: 0;
  border: none;
  background: transparent;
}

.verse-list.line-breaks-off .verse + .verse {
  margin-inline-start: 8px;
}

.verse {
  display: grid;
  gap: 6px;
  padding: 16px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
}

.verse.highlight {
  border-color: var(--accent);
  box-shadow: 0 6px 18px color-mix(in srgb, var(--accent) 20%, transparent);
}

.verse.hide-number .verse-number,
.reader-panel.hide-verse-numbers .verse-number {
  display: none;
}

.verse-number {
  font-weight: 700;
  color: var(--accent-dark);
}

.media-panel {
  margin-top: 32px;
}

.section-title {
  margin-bottom: 16px;
}

.media-list {
  display: grid;
  gap: 20px;
}

.media-verse {
  display: grid;
  gap: 12px;
  padding: 16px;
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--ink) 10%, transparent);
  background: rgba(255, 255, 255, 0.9);
}

.media-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}

.media-grid img {
  width: 100%;
  border-radius: 12px;
}

.selection-popover {
  position: absolute;
  z-index: 30;
  background: #fffaf4;
  border: 1px solid color-mix(in srgb, var(--ink) 15%, transparent);
  border-radius: 999px;
  box-shadow: 0 10px 24px var(--shadow);
  padding: 6px;
  display: none;
  gap: 8px;
}

.selection-popover button {
  border: none;
  background: transparent;
  padding: 6px 10px;
  cursor: pointer;
  font-weight: 600;
  font-family: inherit;
}

.reader-bottom {
  display: none;
}

.filters {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 16px;
  margin-bottom: 24px;
}

.field label {
  display: block;
  font-size: max(20px, 0.9rem);
  margin-bottom: 6px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.field input,
.field select {
  width: 100%;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--ink) 20%, transparent);
  background: #fffaf4;
  font-family: inherit;
}

.field select {
  min-height: 48px;
  font-size: max(20px, 1rem);
  line-height: 1.25;
}

select:not([multiple]) {
  --select-caret-icon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='7' viewBox='0 0 10 7'%3E%3Cpath d='M1 1.35 5 5.35 9 1.35' fill='none' stroke='%238c4b1b' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  --select-caret-position: right 12px center;
  appearance: none;
  -webkit-appearance: none;
  padding-inline-end: 30px !important;
  background-image: var(--select-caret-icon);
  background-repeat: no-repeat;
  background-position: var(--select-caret-position);
  background-size: 10px 7px;
  text-overflow: ellipsis;
}

html[dir="rtl"] select:not([multiple]),
[dir="rtl"] select:not([multiple]) {
  --select-caret-position: left 12px center;
}

select::-ms-expand {
  display: none;
}

.actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.status {
  margin: 16px 0;
  font-style: italic;
}

.library-page .status {
  padding: 16px 18px;
  border: 1px solid transparent;
  border-radius: 18px;
}

.grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 18px;
}

.media-feed-grid {
  display: grid;
  grid-template-columns: repeat(var(--downloads-masonry-columns, 4), minmax(0, 1fr));
  gap: 18px;
}

.feed-card {
  break-inside: avoid;
  margin-bottom: 18px;
  background: #fffdfa;
  border-radius: 18px;
  padding: 12px;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  display: grid;
  gap: 12px;
}

.feed-preview img,
.feed-preview video {
  width: 100%;
  border-radius: 12px;
}

.feed-preview audio {
  width: 100%;
}

.feed-meta {
  display: grid;
  gap: 6px;
  font-size: max(20px, 0.9rem);
}

.feed-links {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.feed-links a {
  color: var(--accent-dark);
  text-decoration: none;
  font-weight: 600;
}

.feed-sentinel {
  height: 1px;
}

.prayers-grid {
  display: grid;
  gap: 18px;
}

.prayer-card {
  display: grid;
  gap: 16px;
  padding: 18px;
  border-radius: 18px;
  border: 1px solid color-mix(in srgb, var(--ink) 10%, transparent);
  background: rgba(255, 255, 255, 0.9);
}

.prayer-text h3 {
  margin: 0;
}

.prayer-text p {
  margin: 0;
  line-height: 1.6;
}

.prayer-images {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.prayer-images img {
  width: 100%;
  border-radius: 12px;
}

.asset-card {
  background: #fffdfa;
  border-radius: 18px;
  padding: 16px;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  display: grid;
  gap: 12px;
  animation: rise 0.6s ease both;
}

.asset-card:nth-child(2n) {
  animation-delay: 0.08s;
}

.asset-card:nth-child(3n) {
  animation-delay: 0.14s;
}

.asset-preview {
  width: 100%;
  border-radius: 14px;
  overflow: hidden;
  background: #f1e6d8;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 160px;
}

.asset-preview img,
.asset-preview video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.asset-preview audio {
  width: 100%;
}

.asset-meta {
  font-size: max(20px, 0.9rem);
  display: grid;
  gap: 4px;
}

.asset-meta span {
  display: block;
}

.asset-meta a {
  color: var(--accent-dark);
  text-decoration: none;
  font-weight: 600;
}

.verse-card {
  display: grid;
  gap: 12px;
  margin-bottom: 24px;
}

.verse-card h2 {
  margin: 0;
}

.verse-text {
  background: rgba(255, 255, 255, 0.9);
  border-radius: 18px;
  padding: 20px;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
}

.verse-text p {
  margin: 0;
  font-size: 1.2rem;
  line-height: 1.7;
}

.bible-browser {
  display: grid;
  gap: 20px;
}

.bible-browser__hero {
  display: grid;
  gap: 14px;
  padding: 18px 22px;
  border-radius: 28px;
  background: var(--surface);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  box-shadow: 0 16px 34px color-mix(in srgb, var(--ink) 8%, transparent);
}

.bible-browser__intro {
  display: grid;
  gap: 6px;
  justify-items: center;
  text-align: center;
}

.bible-browser__eyebrow {
  margin: 0;
  font-size: max(20px, 0.82rem);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--ink) 54%, transparent);
}

.bible-browser__intro h1 {
  margin: 0;
  font-size: clamp(2.2rem, 4vw, 3.4rem);
}

.bible-browser__intro-title-link {
  color: inherit;
  text-decoration: none;
  text-decoration-thickness: 0.06em;
  text-underline-offset: 0.14em;
}

.bible-browser__intro-title-link:hover,
.bible-browser__intro-title-link:focus-visible {
  color: var(--accent-dark);
  text-decoration: underline;
}

.bible-browser__intro-title-link:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent) 22%, transparent);
  outline-offset: 4px;
  border-radius: 8px;
}

.bible-browser__intro p {
  margin: 0;
  max-width: 720px;
  line-height: 1.65;
  color: color-mix(in srgb, var(--ink) 76%, transparent);
}

.bible-browser__intro-meta {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
}

.bible-browser__intro-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: rgba(88, 52, 24, 0.88);
  font-size: max(20px, 0.92rem);
  font-weight: 600;
}

.bible-browser__navigator {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  width: 100%;
  margin: 0 auto;
}

.bible-browser__navigator-shell {
  display: grid;
  gap: 10px;
}

.bible-browser__navigator-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  width: 100%;
  min-height: 44px;
  padding: 10px 14px;
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--ink) 10%, transparent);
  background: var(--control-bg-strong);
  color: var(--ink);
  font: inherit;
  cursor: pointer;
  box-shadow: 0 10px 24px color-mix(in srgb, var(--ink) 5%, transparent);
}

.bible-browser__navigator-summary {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  color: color-mix(in srgb, var(--ink) 78%, transparent);
}

.bible-browser__navigator-summary span:not(:last-child)::after {
  content: "•";
  margin-inline-start: 8px;
  color: color-mix(in srgb, var(--ink) 32%, transparent);
}

.bible-browser__navigator-toggle-text {
  color: var(--accent-dark);
  font-weight: 600;
  white-space: nowrap;
}

.bible-browser__navigator-shell.is-collapsed .bible-browser__navigator {
  display: none;
}

.bible-browser__nav-group {
  display: grid;
  gap: 5px;
  flex: 0 1 220px;
  min-width: min(220px, 100%);
}

.bible-browser__nav-group label {
  font-size: max(20px, 0.75rem);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--ink) 60%, transparent);
}

.bible-browser__nav-group select {
  width: 100%;
  min-height: 42px;
  padding: 9px 14px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--ink) 14%, transparent);
  background: #fffaf4;
  font-family: inherit;
  font-size: max(20px, 0.95rem);
}

.bible-browser__book-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 22px;
}

.book-card,
.chapter-card {
  text-decoration: none;
  color: var(--ink);
}

.book-card {
  position: relative;
  display: grid;
  align-items: end;
  min-height: 420px;
  aspect-ratio: 9 / 16;
  padding: 18px;
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(18, 17, 15, 0.02) 0%, rgba(18, 17, 15, 0.58) 100%),
    var(--card-image),
    var(--surface);
  background-size: cover;
  background-position: center;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  box-shadow: 0 14px 28px color-mix(in srgb, var(--ink) 8%, transparent);
  transition: transform 0.22s ease, box-shadow 0.22s ease;
  overflow: hidden;
}

.book-card:hover,
.chapter-card:hover,
.book-card:focus-visible,
.chapter-card:focus-visible {
  transform: translateY(-3px);
  box-shadow: 0 18px 36px color-mix(in srgb, var(--ink) 12%, transparent);
}

.book-card::after,
.chapter-card::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(180deg, rgba(8, 7, 6, 0.02) 30%, rgba(8, 7, 6, 0.28) 62%, rgba(8, 7, 6, 0.82) 100%);
  pointer-events: none;
}

.book-card--no-image,
.chapter-card--no-image {
  background:
    linear-gradient(180deg, rgba(18, 17, 15, 0.02) 0%, rgba(18, 17, 15, 0.58) 100%),
    linear-gradient(180deg, #f7f1e8 0%, #e9dcc8 100%);
}

.book-card__preload,
.chapter-card__preload {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.book-card__body,
.chapter-card__body {
  position: relative;
  z-index: 2;
  display: grid;
  gap: 6px;
}

.book-card__meta,
.chapter-card__meta {
  font-size: max(20px, 0.86rem);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.84);
}

.book-card__body h2,
.chapter-card__label {
  margin: 0;
  color: #fff;
  font-size: clamp(1.7rem, 2vw, 2.15rem);
  line-height: 1.02;
  text-shadow: 0 4px 18px rgba(0, 0, 0, 0.32);
}

.book-card__body p {
  margin: 0;
  color: rgba(255, 255, 255, 0.92);
  text-shadow: 0 3px 12px rgba(0, 0, 0, 0.28);
}

.chapter-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 18px;
}

.chapter-card {
  position: relative;
  display: grid;
  align-items: end;
  min-height: 340px;
  aspect-ratio: 9 / 16;
  padding: 18px;
  border-radius: 20px;
  background:
    linear-gradient(180deg, rgba(18, 17, 15, 0.02) 0%, rgba(18, 17, 15, 0.58) 100%),
    var(--card-image),
    rgba(255, 252, 246, 0.92);
  background-size: cover;
  background-position: center;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  box-shadow: 0 12px 24px color-mix(in srgb, var(--ink) 6%, transparent);
  overflow: hidden;
}

.chapter-card__bookmark-indicator {
  position: absolute;
  inset-block-start: -4px;
  inset-inline-end: 11px;
  top: -4px;
  z-index: 44;
  width: 42px;
  height: auto;
  pointer-events: none;
  filter: drop-shadow(0 5px 10px rgba(0, 0, 0, 0.42));
}

.chapter-card--bookmarked::before {
  content: "";
  position: absolute;
  inset-block-start: 4px;
  inset-inline-end: 5px;
  top: 4px;
  z-index: 43;
  width: 50px;
  height: 50px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--surface) 72%, transparent);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.24);
  pointer-events: none;
}

.chapter-reader {
  --reader-text-size: 25px;
  --reader-text-family: "Cormorant Garamond", "Garamond", "Palatino Linotype", serif;
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 440px);
  gap: 24px;
  align-items: start;
  min-height: 0 !important;
}

.chapter-reader[data-reader-default-font="naskh"] {
  --reader-text-family: "Amiri", "Noto Naskh Arabic", "Scheherazade New", "Traditional Arabic", serif;
}

.chapter-reader[data-reader-default-font="naskh"] .chapter-reader__reference,
.chapter-reader[data-reader-default-font="naskh"] .chapter-reader__subtitle,
.chapter-reader[data-reader-default-font="naskh"] .chapter-reader__verses {
  font-family: var(--reader-text-family);
}

.bible-browser.is-loading {
  opacity: 0.72;
  pointer-events: none;
}

.chapter-reader__media {
  min-height: 0;
}

.chapter-reader__media-sticky {
  position: sticky;
  top: 132px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  max-height: calc(100vh - 156px);
  align-content: start;
}

.verse-audio-button {
  --audio-progress: 0%;
  --audio-progress-ratio: 0;
  --waveform-bars: 32;
  display: grid;
  grid-template-columns: 52px minmax(0, 1fr);
  align-items: center;
  gap: 16px;
  width: 100%;
  flex: 1 1 100%;
  min-width: 0;
  padding: 14px 16px;
  border-radius: 28px;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  background:
    radial-gradient(circle at 16% 10%, color-mix(in srgb, var(--accent) 14%, transparent), transparent 34%),
    linear-gradient(180deg, rgba(255, 254, 251, 0.98), rgba(249, 242, 231, 0.98));
  color: var(--ink);
  font: inherit;
  font-weight: 600;
  cursor: pointer;
  box-shadow: 0 18px 36px color-mix(in srgb, var(--ink) 8%, transparent);
  transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.verse-audio-button.is-playing {
  border-color: color-mix(in srgb, var(--accent) 34%, transparent);
  box-shadow: 0 18px 34px color-mix(in srgb, var(--accent) 16%, transparent);
}

.verse-audio-button:hover,
.verse-audio-button:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 26%, transparent);
  box-shadow: 0 20px 40px color-mix(in srgb, var(--ink) 10%, transparent);
  transform: translateY(-1px);
}

.verse-audio-button__icon {
  width: 52px;
  height: 52px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  flex: 0 0 auto;
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 16%, transparent), color-mix(in srgb, var(--accent) 26%, transparent));
  color: var(--accent-dark);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.48);
}

.verse-audio-button__icon svg {
  width: 20px;
  height: 20px;
}

.verse-audio-button__icon-pause {
  display: none;
}

.verse-audio-button.is-playing .verse-audio-button__icon-play {
  display: none;
}

.verse-audio-button.is-playing .verse-audio-button__icon-pause {
  display: block;
}

.verse-audio-button__body {
  min-width: 0;
  display: grid;
  gap: 8px;
}

.verse-audio-button__meta {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  align-items: baseline;
  gap: 2px;
  min-width: 0;
}

.verse-audio-button__label {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.verse-audio-button__waveform {
  position: relative;
  display: grid;
  grid-template-columns: repeat(var(--waveform-bars), minmax(3px, 1fr));
  align-items: center;
  gap: 3px;
  direction: ltr;
  min-height: 46px;
  padding: 7px 0;
  isolation: isolate;
  cursor: pointer;
  min-width: 0;
  unicode-bidi: isolate;
}

.verse-audio-button__bar {
  position: relative;
  z-index: 1;
  width: 100%;
  height: var(--wave-height, 12px);
  min-height: 6px;
  max-height: 42px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(96, 84, 70, 0.62), rgba(46, 40, 34, 0.34));
  overflow: hidden;
  transform-origin: center bottom;
  transition: height 0.24s ease, opacity 0.18s ease;
}

.verse-audio-button__bar::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 96%, transparent), rgba(141, 76, 20, 0.7));
  transform: scaleX(var(--bar-progress-scale, 0));
  transform-origin: left center;
  transition: transform 0.12s linear;
}

.verse-audio-button.is-playing .verse-audio-button__bar {
  opacity: 1;
}

.verse-audio-button.is-waveform-ready .verse-audio-button__bar {
  background: linear-gradient(180deg, rgba(82, 71, 60, 0.76), rgba(48, 42, 36, 0.4));
}

.verse-audio-select {
  display: grid;
  gap: 6px;
  margin-top: 10px;
  color: rgba(68, 57, 45, 0.72);
  font-size: max(20px, 0.9rem);
  font-weight: 600;
}

.verse-audio-select select {
  width: 100%;
  min-height: 42px;
  border: 1px solid color-mix(in srgb, var(--ink) 10%, transparent);
  border-radius: 16px;
  background: rgba(255, 254, 251, 0.86);
  color: var(--ink);
  font: inherit;
  padding: 8px 38px 8px 14px;
}

.verse-audio-button__time {
  min-width: 88px;
  justify-self: end;
  text-align: end;
  font-size: max(20px, 0.84rem);
  letter-spacing: 0.03em;
  color: rgba(68, 57, 45, 0.78);
  font-variant-numeric: tabular-nums;
}

@media (prefers-reduced-motion: reduce) {
  .verse-audio-button,
  .verse-audio-button__bar,
  .verse-audio-button__bar::after {
    transition: none;
  }

}

.verse-image-gallery {
  display: grid;
  gap: 12px;
}

.verse-image-gallery__item {
  display: block;
  border-radius: 18px;
  overflow: hidden;
  background: linear-gradient(180deg, #f7f1e8 0%, #f3eadc 100%);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  box-shadow: 0 12px 24px color-mix(in srgb, var(--ink) 6%, transparent);
}

.verse-image-gallery__item img {
  width: 100%;
  display: block;
  aspect-ratio: 4 / 5;
  object-fit: cover;
}

.chapter-reader__main {
  display: grid;
  gap: 18px;
  min-width: 0;
  min-height: 0;
}

.chapter-reader__navigation {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 15px;
}

.chapter-reader__nav-link {
  display: inline-flex;
  align-items: center;
  min-height: 48px;
  padding: 10px 16px;
  border-radius: 999px;
  text-decoration: none;
  background: var(--control-bg);
  border: 1px solid color-mix(in srgb, var(--ink) 10%, transparent);
  color: var(--ink);
  box-shadow: 0 10px 24px color-mix(in srgb, var(--ink) 6%, transparent);
}

.chapter-reader__nav-link--prev {
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  font-weight: bold;
}

.chapter-reader__nav-link--next {
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  font-weight: bold;
}

.chapter-reader__sheet {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  max-height: calc(100vh - 116px);
  min-height: 0;
  padding: 28px clamp(20px, 3vw, 38px);
  border-radius: 28px;
  background: var(--control-bg);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  box-shadow: 0 18px 40px color-mix(in srgb, var(--ink) 8%, transparent);
  overflow: hidden;
}

@media (min-width: 1601px) {
  .chapter-reader__sheet {
    max-height: calc(100vh - 116px);
  }
}

.chapter-reader__sheet-header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 22px;
}

.chapter-reader__reference {
  margin: 0 0 8px;
  font-size: clamp(1.9rem, 2.8vw, 2.55rem);
  line-height: 0.98;
}

.chapter-reader__subtitle {
  margin: 0;
  color: color-mix(in srgb, var(--ink) 70%, transparent);
  line-height: 1.55;
}

.chapter-reader__verses {
  display: grid;
  flex: 1 1 auto;
  gap: 10px;
  min-height: 0;
  overflow: auto;
  padding-inline-end: 8px;
  unicode-bidi: isolate;
}

.chapter-reader__actions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 10px;
  margin-top: 16px;
}

.chapter-reader__action-button {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 10px 16px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 700;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent) 22%, transparent);
  color: var(--accent-dark);
  box-shadow: 0 10px 24px color-mix(in srgb, var(--ink) 6%, transparent);
  width: 100%;
  text-align: center;
}

.chapter-reader__action-button--secondary {
  background: var(--control-bg);
  border-color: color-mix(in srgb, var(--ink) 10%, transparent);
  color: var(--ink);
}

.chapter-reader__verse {
  position: relative;
  margin: 0;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: var(--reader-text-size);
  line-height: 1.95;
  overflow: visible;
  transition: background-color 140ms ease, box-shadow 140ms ease;
}

.chapter-reader__verse:hover,
.chapter-reader__verse:focus-within,
.chapter-reader__verse.is-selected {
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  border-radius: 16px;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 14%, transparent);
  padding: 8px 12px;
  z-index: 30;
}

.chapter-reader__verse--highlight {
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  border-radius: 16px;
  padding: 10px 14px;
}

.chapter-reader__verse.is-audio-active {
  background: color-mix(in srgb, var(--accent) 13%, transparent);
  border-radius: 16px;
  padding: 10px 14px;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 28%, transparent), 0 10px 24px color-mix(in srgb, var(--accent) 10%, transparent);
  scroll-margin-block: 45%;
}

.chapter-reader__verse.is-continue-focus {
  animation: continueVersePulse 1.8s ease-in-out 0s 4;
  outline: 3px solid color-mix(in srgb, var(--accent) 48%, transparent);
  outline-offset: 4px;
}

@keyframes continueVersePulse {
  0%, 100% {
    box-shadow: 0 0 0 rgba(201, 119, 43, 0);
  }
  45% {
    box-shadow: 0 0 0 12px color-mix(in srgb, var(--accent) 16%, transparent);
  }
}

.chapter-reader--single-verse .chapter-reader__verse--highlight {
  padding: 12px 20px;
}

.chapter-reader__verse--saved {
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  border-radius: 16px;
  padding: 6px 10px;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 28%, transparent);
}

.chapter-reader__verse--favorite {
  background:
    linear-gradient(90deg, color-mix(in srgb, #d94f70 16%, transparent), transparent 58%),
    color-mix(in srgb, var(--surface) 82%, transparent);
  border-radius: 16px;
  padding: 6px 10px;
  box-shadow: inset 4px 0 0 color-mix(in srgb, #d94f70 78%, var(--accent));
}

[dir="rtl"] .chapter-reader__verse--favorite {
  background:
    linear-gradient(270deg, color-mix(in srgb, #d94f70 16%, transparent), transparent 58%),
    color-mix(in srgb, var(--surface) 82%, transparent);
  box-shadow: inset -4px 0 0 color-mix(in srgb, #d94f70 78%, var(--accent));
}

.chapter-reader__verse--bookmarked {
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--accent) 17%, transparent), transparent 62%),
    color-mix(in srgb, var(--surface) 82%, transparent);
  border-radius: 16px;
  padding: 6px 10px;
  box-shadow: inset 4px 0 0 var(--accent);
}

[dir="rtl"] .chapter-reader__verse--bookmarked {
  background:
    linear-gradient(270deg, color-mix(in srgb, var(--accent) 17%, transparent), transparent 62%),
    color-mix(in srgb, var(--surface) 82%, transparent);
  box-shadow: inset -4px 0 0 var(--accent);
}

.chapter-reader__verse-anchor {
  flex: 0 0 auto;
  color: var(--accent-dark);
  text-decoration: none;
  font-weight: 700;
  margin-inline-end: 0;
  line-height: 1.2;
}

.chapter-reader__selection-rail {
  position: absolute;
  top: 8px;
  inset-inline-start: 10px;
  display: inline-flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: 4px;
  max-width: min(520px, calc(100vw - 20px));
  padding: 3px;
  border-radius: 18px;
  background: rgba(255, 250, 243, 0.96);
  box-shadow: 0 10px 24px color-mix(in srgb, var(--ink) 12%, transparent);
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: none;
  touch-action: pan-x;
  white-space: nowrap;
  z-index: 80;
  pointer-events: auto;
}

.chapter-reader__selection-rail::-webkit-scrollbar {
  display: none;
}

.chapter-reader__selection-rail .chapter-reader__verse-state-button {
  flex: 0 0 auto;
}

.chapter-reader__verse.is-selected {
  z-index: 120;
}

.chapter-reader__selection-rail.is-floating {
  position: fixed;
  top: auto;
  left: auto;
  inset-inline-start: auto;
  z-index: 120;
  /* Glide between selections instead of jumping — paired with the JS
     fix that no longer re-parents the rail on every verse click. */
  transition: top 0.14s ease, left 0.14s ease;
  will-change: top, left;
  /* Lock in the floating background so the rail never flashes a
     transparent/inherited background between style recalcs. */
  background: rgba(255, 250, 243, 0.98);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  box-shadow: 0 12px 28px color-mix(in srgb, var(--ink) 18%, transparent);
}

:root[data-theme="midnight"] .chapter-reader__selection-rail.is-floating,
:root[data-theme="night"] .chapter-reader__selection-rail.is-floating,
:root[data-theme="dark"] .chapter-reader__selection-rail.is-floating {
  background: var(--surface-strong, rgba(28, 24, 20, 0.96));
  border-color: var(--border-soft, rgba(255, 255, 255, 0.08));
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.5);
}

.chapter-reader__verse-actions {
  display: none;
  align-items: center;
  gap: 4px;
  flex: 0 0 auto;
  margin-top: 2px;
  padding: 3px;
  border-radius: 999px;
  background: rgba(255, 250, 243, 0.92);
  box-shadow: 0 8px 18px color-mix(in srgb, var(--ink) 8%, transparent);
  pointer-events: none;
}

.chapter-reader__verse-actions--inline {
  margin-inline: 0.35em;
  vertical-align: middle;
  padding: 0;
  background: transparent;
  box-shadow: none;
}

.chapter-reader__verse-actions--inline {
  display: none;
  pointer-events: none;
}

.chapter-reader__verse-actions [data-state-type="highlight"] {
  display: none;
}

.chapter-reader__verse-actions [data-state-type="favorite"],
.chapter-reader__verse-actions [data-state-type="bookmark"],
.chapter-reader__verse-actions [data-reading-note-edit] {
  display: inline-flex;
}

.chapter-reader__verse-state-button {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--ink) 16%, transparent);
  background: var(--surface);
  color: color-mix(in srgb, var(--ink) 72%, transparent);
  cursor: pointer;
  pointer-events: auto;
  transition: background-color 160ms ease, color 160ms ease, border-color 160ms ease, transform 160ms ease;
}

.chapter-reader__verse-state-button--labeled {
  width: auto;
  min-width: 0;
  gap: 5px;
  padding-inline: 8px 9px;
  font-size: max(14px, 0.72rem);
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
}

.chapter-reader__verse-state-button--labeled span {
  white-space: nowrap;
}

.chapter-reader__verse-state-button:hover,
.chapter-reader__verse-state-button:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 38%, transparent);
  color: var(--accent-dark);
  transform: translateY(-1px);
}

.chapter-reader__verse-state-button.is-active {
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  border-color: color-mix(in srgb, var(--accent) 42%, transparent);
  color: var(--accent-dark);
}

.chapter-reader--strongs-hidden .strongs-chip {
  display: none;
}

.chapter-reader__rail-icon {
  width: 16px;
  height: 16px;
  flex: 0 0 auto;
}

.chapter-reader.is-compact .chapter-reader__verses {
  display: block;
  gap: 0;
  line-height: 1.95;
}

.chapter-reader.is-compact .chapter-reader__verse {
  margin: 0;
  display: inline;
  gap: 8px;
  padding: 0;
  background: transparent;
  box-shadow: none;
  border-radius: 0;
}

.chapter-reader.is-compact .chapter-reader__verse:hover,
.chapter-reader.is-compact .chapter-reader__verse:focus-within,
.chapter-reader.is-compact .chapter-reader__verse.is-selected {
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  border-radius: 10px;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 14%, transparent);
  padding: 2px 8px;
}

.chapter-reader.is-compact .chapter-reader__verse-actions {
  opacity: 0;
  margin-inline-start: 0.25em;
}

.chapter-reader.is-compact .chapter-reader__selection-rail {
  top: 6px;
  inset-inline-start: 6px;
}

.chapter-reader.is-compact .chapter-reader__verse--highlight,
.chapter-reader.is-compact .chapter-reader__verse--saved {
  padding: 4px 8px;
}

/* Favorite-verse highlight in compact (verse-per-paragraph) mode. The
   non-compact rule paints a block background, but in compact the verse
   is rendered inline so the rule disappeared visually. Use a tinted
   background + a left bookmark-style border with box-decoration-break
   so the highlight survives line wraps. */
.chapter-reader.is-compact .chapter-reader__verse--favorite {
  padding: 2px 8px 2px 10px;
  border-radius: 8px;
  background: linear-gradient(90deg,
    color-mix(in srgb, #d94f70 18%, transparent),
    color-mix(in srgb, #d94f70 6%, transparent) 60%,
    transparent 100%);
  box-shadow: inset 3px 0 0 color-mix(in srgb, #d94f70 78%, var(--accent));
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

[dir="rtl"] .chapter-reader.is-compact .chapter-reader__verse--favorite {
  padding: 2px 10px 2px 8px;
  background: linear-gradient(270deg,
    color-mix(in srgb, #d94f70 18%, transparent),
    color-mix(in srgb, #d94f70 6%, transparent) 60%,
    transparent 100%);
  box-shadow: inset -3px 0 0 color-mix(in srgb, #d94f70 78%, var(--accent));
}

.chapter-reader.is-compact .chapter-reader__verse.is-audio-active {
  padding: 2px 8px;
  border-radius: 10px;
  background: color-mix(in srgb, var(--accent) 18%, transparent) !important;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 30%, transparent), 0 6px 16px color-mix(in srgb, var(--accent) 12%, transparent) !important;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

.chapter-reader.is-compact .chapter-reader__verse-text {
  display: inline;
}

.chapter-reader.is-compact .chapter-reader__lead-cluster {
  float: none;
  display: inline-flex;
  vertical-align: baseline;
  margin-inline-end: 0.08em;
}

.chapter-reader.is-compact .chapter-reader__lead-cluster .chapter-reader__lead-dropcap {
  float: none;
  display: inline-block;
  margin-inline-end: 0;
  margin-top: 0;
}

.chapter-reader__verse-segment {
  margin-inline-start: 0.45em;
}

.chapter-reader:not(.is-compact) .chapter-reader__verse--highlight .chapter-reader__verse-segment {
  display: block;
  margin-block-start: 14px;
  margin-inline-start: 0;
}

.chapter-reader.is-compact .chapter-reader__verse + .chapter-reader__verse,
.chapter-reader.is-compact .chapter-reader__verse-segment {
  margin-inline-start: 0.45em;
}

.search-engine-result__actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 10px;
}

.chapter-reader__verse-text {
  display: block;
  flex: 1 1 auto;
  min-width: 0;
  font-family: var(--reader-text-family);
}

.chapter-reader__text-controls {
  position: absolute;
  right: 24px;
  bottom: 24px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  z-index: 40;
}

.reader-icon-actions .chapter-reader__text-controls {
  position: relative;
  right: auto;
  bottom: auto;
  z-index: 1000;
}

.chapter-reader__font-menu-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  min-height: 42px;
  width: 42px;
  height: 42px;
  padding: 0;
  border: 1px solid color-mix(in srgb, var(--ink) 12%, transparent);
  border-radius: 50%;
  background: var(--control-bg);
  color: var(--accent-dark);
  box-shadow: none;
  cursor: pointer;
  font: 600 max(20px, 0.82rem)/1 system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  opacity: 1;
  transition: opacity 140ms ease, background-color 140ms ease, transform 140ms ease;
}

.chapter-reader__font-menu-toggle:hover,
.chapter-reader__font-menu-toggle:focus-visible,
.chapter-reader__text-controls.is-open .chapter-reader__font-menu-toggle {
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  opacity: 1;
  outline: none;
}

.chapter-reader__font-popover {
  position: absolute;
  right: 0;
  bottom: calc(100% + 10px);
  width: min(326px, calc(100vw - 28px));
  display: grid;
  gap: 12px;
  max-width: calc(100vw - 28px);
  padding: 14px;
  border-radius: 24px;
  background:
    radial-gradient(circle at 10% 0%, rgba(255, 231, 194, 0.62), transparent 42%),
    linear-gradient(180deg, rgba(255, 253, 248, 0.98), rgba(248, 239, 225, 0.98));
  border: 1px solid rgba(145, 92, 45, 0.16);
  box-shadow:
    0 24px 60px color-mix(in srgb, var(--ink) 20%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.74);
  z-index: 10000;
  color: var(--ink);
  backdrop-filter: blur(14px);
}

.chapter-reader__font-popover[hidden] {
  display: none;
}

.chapter-reader__font-popover::before {
  content: "";
  position: absolute;
  right: 16px;
  bottom: -8px;
  width: 16px;
  height: 16px;
  transform: rotate(45deg);
  background: rgba(248, 239, 225, 0.98);
  border-right: 1px solid rgba(145, 92, 45, 0.14);
  border-bottom: 1px solid rgba(145, 92, 45, 0.14);
}

.chapter-reader__font-popover-header {
  display: grid;
  gap: 3px;
  padding-inline: 2px;
}

/* Header is a small uppercase eyebrow + a regular-weight title. The
   previous rule used 800 weight on both rows which read as shouty. */
.chapter-reader__font-popover-header span {
  color: rgba(132, 82, 39, 0.78);
  font: 600 max(18px, 0.7rem)/1.1 system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.chapter-reader__font-popover-header strong {
  color: var(--ink);
  font: 500 max(20px, 1rem)/1.15 system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  letter-spacing: -0.005em;
}

.chapter-reader__font-preview {
  min-height: 70px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px 14px;
  border-radius: 20px;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.82), rgba(255, 248, 237, 0.84)),
    repeating-linear-gradient(90deg, rgba(112, 72, 38, 0.04) 0 1px, transparent 1px 12px);
  color: color-mix(in srgb, var(--ink) 78%, transparent);
  line-height: 1.1;
  text-align: center;
  overflow: hidden;
}

.chapter-reader__font-row {
  display: grid;
  grid-template-columns: minmax(78px, auto) minmax(0, 1fr);
  align-items: center;
  gap: 10px;
}

.chapter-reader__font-row-label {
  color: color-mix(in srgb, var(--ink) 62%, transparent);
  font: 800 max(20px, 0.78rem)/1.1 system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.chapter-reader__font-stepper-group {
  min-width: 0;
  display: grid;
  grid-template-columns: 42px minmax(58px, 1fr) 42px;
  align-items: center;
  gap: 6px;
  padding: 5px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.68);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
}

.chapter-reader__font-stepper {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border: 0;
  border-radius: 50%;
  background: color-mix(in srgb, var(--ink) 7%, transparent);
  color: color-mix(in srgb, var(--ink) 82%, transparent);
  font: 800 max(20px, 0.9rem)/1 system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  cursor: pointer;
  transition: background-color 140ms ease, color 140ms ease, transform 140ms ease;
}

.chapter-reader__font-stepper:hover,
.chapter-reader__font-stepper:focus-visible {
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  outline: none;
}

.chapter-reader__font-size-value {
  min-width: 58px;
  color: color-mix(in srgb, var(--ink) 76%, transparent);
  font: 900 max(20px, 0.86rem)/1 system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  text-align: center;
  font-variant-numeric: tabular-nums;
}

.chapter-reader__font-family-select {
  width: 100%;
  min-width: 0;
  height: 46px;
  padding: 0 34px 0 12px;
  border: 1px solid color-mix(in srgb, var(--ink) 10%, transparent);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(255, 250, 242, 0.92));
  color: var(--ink);
  font: 800 max(20px, 0.86rem)/1 system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

.chapter-reader__font-family-select:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent) 18%, transparent);
  border-color: color-mix(in srgb, var(--accent) 34%, transparent);
}

.chapter-reader__font-reset {
  min-height: 42px;
  border: 1px solid color-mix(in srgb, var(--accent) 18%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: var(--accent-dark);
  font: 900 max(20px, 0.82rem)/1 system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  cursor: pointer;
  transition: background-color 140ms ease, transform 140ms ease, border-color 140ms ease;
}

.chapter-reader__font-reset:hover,
.chapter-reader__font-reset:focus-visible {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  border-color: color-mix(in srgb, var(--accent) 28%, transparent);
  outline: none;
  transform: translateY(-1px);
}

.strongs-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.9em;
  margin-inline-start: 0.18em;
  padding: 0.08em 0.38em;
  border-radius: 999px;
  vertical-align: super;
  font-size: max(20px, 0.58em);
  line-height: 1;
  font-weight: 700;
  color: var(--accent-dark);
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent) 22%, transparent);
  cursor: pointer;
  white-space: nowrap;
}

.strongs-chip:focus,
.strongs-chip:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent) 28%, transparent);
  outline-offset: 2px;
}

.strongs-chip--morph {
  background: rgba(108, 122, 137, 0.14);
  color: #8f5532;
  border-color: rgba(143, 85, 50, 0.18);
  font-size: max(20px, 0.74em);
}

.verse-note-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-inline-start: 0.18em;
  padding: 0;
  width: 1.45rem;
  height: 1.45rem;
  border: 1px solid color-mix(in srgb, var(--accent) 28%, var(--border-soft));
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 15%, var(--surface));
  color: var(--accent-dark);
  font-size: max(20px, 0.7rem);
  font-weight: 700;
  line-height: 1;
  vertical-align: super;
  cursor: pointer;
}

.verse-note-chip:focus,
.verse-note-chip:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent) 28%, transparent);
  outline-offset: 2px;
}

.verse-note-popover,
.reader-action-notice {
  z-index: 10020;
  border: 1px solid var(--border-soft);
  background: var(--surface);
  color: var(--ink);
  box-shadow: 0 22px 60px var(--surface-shadow);
}

.verse-note-popover {
  display: grid;
  gap: 12px;
  width: min(360px, calc(100vw - 24px));
  padding: 16px;
  border-radius: 20px;
}

.verse-note-popover--view {
  width: min(300px, calc(100vw - 24px));
  padding: 13px 14px;
}

.verse-note-popover strong {
  font-family: var(--display-font);
  font-size: max(20px, 1rem);
}

.verse-note-popover p {
  margin: 0;
  color: var(--muted-strong);
  line-height: 1.55;
  white-space: pre-wrap;
}

.verse-note-popover__header,
.verse-note-popover__actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.verse-note-popover__close,
.verse-note-popover__button {
  border: 1px solid var(--border-soft);
  background: var(--control-bg);
  color: var(--ink);
  cursor: pointer;
}

.verse-note-popover__close {
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  font-size: 1.25rem;
  line-height: 1;
}

.verse-note-popover__textarea {
  width: 100%;
  min-height: 130px;
  resize: vertical;
  border: 1px solid var(--control-border);
  border-radius: 16px;
  padding: 12px 14px;
  background: var(--control-bg-strong);
  color: var(--ink);
  font: inherit;
  line-height: 1.5;
}

.verse-note-popover__button {
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  font-weight: 800;
}

.verse-note-popover__button--primary {
  background: var(--accent);
  border-color: color-mix(in srgb, var(--accent) 70%, var(--border-soft));
  color: var(--on-accent);
}

.verse-note-popover__button--ghost {
  color: var(--muted-strong);
}

.reader-action-notice {
  position: fixed;
  inset-inline-end: max(18px, env(safe-area-inset-right));
  inset-block-end: calc(max(22px, env(safe-area-inset-bottom)) + var(--site-footer-height, 0px));
  display: inline-flex;
  align-items: center;
  min-height: 46px;
  max-width: min(360px, calc(100vw - 32px));
  padding: 10px 16px;
  border-radius: 999px;
  font-weight: 800;
  animation: readerNoticeIn 180ms ease-out;
}

[dir="rtl"] .reader-action-notice {
  inset-inline-end: auto;
  inset-inline-start: max(18px, env(safe-area-inset-left));
}

.reader-action-notice--success {
  border-color: color-mix(in srgb, var(--accent) 35%, var(--border-soft));
  background: color-mix(in srgb, var(--accent) 12%, var(--surface));
}

.reader-action-notice--error {
  border-color: color-mix(in srgb, #b34545 48%, var(--border-soft));
  background: color-mix(in srgb, #b34545 12%, var(--surface));
  color: color-mix(in srgb, #e06b6b 64%, var(--ink));
}

.reader-action-notice.is-leaving {
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 220ms ease, transform 220ms ease;
}

html.has-verse-study-panel {
  overflow: hidden;
}

.verse-study-panel {
  position: fixed;
  inset: 0;
  z-index: 30000;
  display: flex;
  align-items: center;
  justify-content: center;
  width: auto;
  max-height: none;
  margin: 0;
  padding: clamp(12px, 3vw, 36px);
  overflow: auto;
  background: color-mix(in srgb, var(--ink) 34%, transparent);
  backdrop-filter: blur(8px);
  text-align: start;
  overscroll-behavior: contain;
}

.verse-study-panel__dialog {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  width: min(1040px, calc(100vw - 28px));
  max-height: min(760px, calc(100dvh - 28px));
  overflow: hidden;
  border: 1px solid var(--border-soft);
  border-radius: 14px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 96%, var(--accent) 4%), var(--surface) 140px),
    var(--surface);
  color: var(--ink);
  box-shadow: 0 20px 52px var(--surface-shadow);
  font-size: max(20px, 1rem);
  line-height: 1.65;
  overflow-wrap: anywhere;
}

.verse-study-panel__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.verse-study-panel__header {
  position: sticky;
  top: 0;
  z-index: 1;
  padding: 16px 18px;
  border-bottom: 1px solid var(--border-soft);
  background: color-mix(in srgb, var(--surface) 96%, transparent);
  backdrop-filter: blur(12px);
}

.verse-study-panel__title {
  display: grid;
  gap: 2px;
}

.verse-study-panel__title strong {
  font-family: var(--display-font);
  font-size: max(23px, 1.2rem);
}

.verse-study-panel__title span,
.verse-study-panel__source span,
.verse-study-panel__empty,
.verse-study-panel__notice {
  color: var(--muted-strong);
}

.verse-study-panel__close {
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
  width: 34px;
  height: 34px;
  border: 1px solid var(--border-soft);
  border-radius: 999px;
  background: var(--control-bg);
  color: var(--ink);
  font-size: 1.25rem;
  line-height: 1;
  cursor: pointer;
}

.verse-study-panel__body {
  display: flex;
  flex-direction: column;
  gap: 18px;
  min-height: 0;
  overflow: auto;
  padding: 0 22px 22px;
}

.verse-study-panel__notice {
  margin: 0;
  padding: 10px 12px;
  border: 1px solid color-mix(in srgb, var(--accent) 26%, var(--border-soft));
  border-radius: 12px;
  background: color-mix(in srgb, var(--accent) 10%, var(--surface));
  font-weight: 700;
}

.verse-study-panel__entry {
  display: grid;
  gap: 12px;
  padding: 18px 0 22px;
  border-bottom: 1px solid var(--border-soft);
}

.verse-study-panel__entry:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

.verse-study-panel__source {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 8px;
  font-size: max(18px, 1rem);
  font-weight: 800;
  line-height: 1.25;
}

.verse-study-panel__source a {
  color: var(--accent-dark);
  text-decoration: none;
}

.verse-study-panel__source a:hover,
.verse-study-panel__source a:focus-visible {
  text-decoration: underline;
}

.verse-study-panel__source span {
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
  min-width: 2.1em;
  min-height: 1.75em;
  padding: 0 8px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 10%, var(--surface));
  color: var(--muted-strong);
  font-size: 0.85em;
  font-weight: 800;
}

.verse-study-panel__tabs {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  margin-inline: -22px;
  padding: 12px 22px 8px;
  border-bottom: 1px solid var(--border-soft);
  background: color-mix(in srgb, var(--surface) 96%, transparent);
  scrollbar-width: thin;
}

.verse-study-panel__tab {
  flex: 0 0 auto;
  max-width: min(280px, 72vw);
  padding: 11px 15px;
  overflow: hidden;
  border: 1px solid var(--border-soft);
  border-radius: 999px;
  background: color-mix(in srgb, var(--surface) 88%, var(--control-bg));
  color: var(--muted-strong);
  font: inherit;
  font-size: max(16px, 0.9rem);
  font-weight: 800;
  line-height: 1.25;
  text-overflow: ellipsis;
  white-space: nowrap;
  cursor: pointer;
}

.verse-study-panel__tab:hover,
.verse-study-panel__tab:focus-visible {
  color: var(--ink);
  border-color: color-mix(in srgb, var(--accent) 42%, var(--border-soft));
}

.verse-study-panel__tab.is-active {
  border-color: color-mix(in srgb, var(--accent) 64%, var(--border-soft));
  background: color-mix(in srgb, var(--accent) 14%, var(--surface));
  color: var(--ink);
}

.verse-study-panel__tab--summary {
  border-color: color-mix(in srgb, var(--accent) 34%, var(--border-soft));
}

.verse-study-panel__source-panels,
.verse-study-panel__source-panel {
  display: grid;
  gap: 16px;
}

.verse-study-panel__source-panel[hidden] {
  display: none;
}

.verse-study-panel__text,
.verse-study-panel__empty {
  margin: 0;
}

.verse-study-panel__text {
  color: var(--ink);
  font-family: var(--reader-text-family, "Cormorant Garamond", "Garamond", "Palatino Linotype", serif);
  font-size: max(1.35rem, calc(var(--reader-text-size, 25px) * 0.96));
  line-height: 1.72;
  white-space: pre-wrap;
}

.verse-study-panel__entry--summary .verse-study-panel__text {
  font-size: max(1.45rem, calc(var(--reader-text-size, 25px) * 1.02));
}

@keyframes readerNoticeIn {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.strongs-tooltip {
  position: fixed;
  inset: auto auto 0 0;
  max-width: min(340px, calc(100vw - 24px));
  width: max-content;
  height: auto;
  max-height: fit-content;
  min-height: 0;
  padding: 10px 12px;
  border-radius: 12px;
  background: color-mix(in srgb, var(--ink) 96%, transparent);
  color: #fffaf2;
  box-shadow: 0 18px 36px color-mix(in srgb, var(--ink) 28%, transparent);
  opacity: 0;
  transform: translateY(4px);
  pointer-events: none;
  overflow: visible;
  transition: opacity 0.16s ease, transform 0.16s ease;
  z-index: 4000;
}

.strongs-tooltip.is-open {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.strongs-tooltip[data-placement="below"] {
  transform: translateY(-4px);
}

.strongs-tooltip.is-open[data-placement="below"] {
  transform: translateY(0);
}

.strongs-tooltip__title {
  margin: 0 0 8px;
  font-size: max(20px, 0.92rem);
  font-weight: 700;
  line-height: 1.2;
}

.strongs-tooltip__meta,
.strongs-tooltip__body,
.strongs-tooltip__source,
.strongs-tooltip__usage,
.strongs-tooltip__attribution {
  line-height: 1.35;
}

.strongs-tooltip__meta {
  margin-bottom: 6px;
  color: rgba(255, 216, 154, 0.92);
  font-size: max(20px, 0.84rem);
}

.strongs-tooltip__body {
  margin-bottom: 8px;
  font-size: max(20px, 0.88rem);
}

.strongs-tooltip__source {
  margin-bottom: 8px;
  font-size: max(20px, 0.8rem);
  color: rgba(255, 250, 242, 0.74);
}

.strongs-tooltip__usage {
  margin-bottom: 8px;
  font-size: max(20px, 0.82rem);
  color: rgba(255, 250, 242, 0.82);
}

.strongs-tooltip__link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #ffd89a;
  text-decoration: none;
  font-size: max(20px, 0.86rem);
  font-weight: 600;
}

.strongs-tooltip__attribution {
  margin-top: 8px;
  font-size: max(20px, 0.76rem);
  color: rgba(255, 250, 242, 0.7);
}

.verse-note-tooltip .strongs-tooltip__body {
  margin-bottom: 0;
  white-space: pre-wrap;
}

.chapter-reader__lead-prefix {
  white-space: pre-wrap;
}

.chapter-reader__lead-dropcap {
  float: inline-start;
  font-size: calc(var(--reader-text-size) * 2.3);
  line-height: 0.8;
  font-weight: 700;
  margin-inline-end: 10px;
  margin-top: 8px;
}

.chapter-reader:not(.chapter-reader--single-verse) .chapter-reader__lead-dropcap {
  padding-block-start: 5px;
}

.verse-media-card {
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: 18px;
  border-radius: 24px;
  background: var(--control-bg);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  box-shadow: 0 14px 30px color-mix(in srgb, var(--ink) 8%, transparent);
}

.verse-media-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 14px;
}

.verse-media-card__header h3 {
  margin: 0;
  font-size: 1.35rem;
}

.verse-media-card--audio {
  padding: 10px;
  min-height: 220px !important;
}

.verse-media-card--audio .verse-media-card__header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  position: relative;
}

.verse-media-card--audio .verse-media-card__header h3 {
  grid-column: 1;
  grid-row: 1;
  min-width: 0;
}

.verse-media-card--audio .verse-audio-button {
  grid-column: 1 / -1;
  grid-row: 2;
}

.verse-audio-voice-select {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(140px, 190px);
  gap: 8px 12px;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  color: rgba(68, 57, 45, 0.72);
  font-size: max(20px, 0.84rem);
  font-weight: 700;
}

.verse-audio-voice-select span {
  white-space: nowrap;
}

.verse-audio-voice-select select {
  min-height: 38px;
  min-width: 0;
  width: 100%;
  padding: 7px 36px 7px 12px;
  border: 1px solid color-mix(in srgb, var(--accent-dark) 18%, transparent);
  border-radius: 10px;
  background: rgba(255, 251, 245, 0.84);
  color: rgba(68, 57, 45, 0.84);
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  outline: none;
}

.verse-audio-voice-select select:hover,
.verse-audio-voice-select select:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 38%, transparent);
  background: rgba(255, 248, 238, 0.96);
  color: var(--accent-dark);
}

html[dir="rtl"] .verse-audio-voice-select {
  direction: rtl;
  text-align: right;
}

html[dir="rtl"] .verse-audio-voice-select select {
  padding: 7px 12px 7px 36px;
  direction: rtl;
  text-align: right;
}

@media (max-width: 720px) {
  .verse-audio-voice-select {
    grid-template-columns: 1fr;
  }

  .verse-audio-voice-select select {
    width: 100%;
    max-width: 100%;
  }
}

.reader-icon-actions {
  display: inline-flex;
  gap: 10px;
  align-items: center;
}

.bible-browser__summary-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 7px 13px;
  border: 1px solid color-mix(in srgb, var(--accent) 54%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent-dark);
  font: inherit;
  font-weight: 800;
  cursor: pointer;
}

.bible-browser__summary-button:hover,
.bible-browser__summary-button:focus-visible {
  background: color-mix(in srgb, var(--accent) 20%, transparent);
  outline: none;
}

.verse-media-card--audio .reader-icon-actions {
  grid-column: 2;
  grid-row: 1;
  justify-self: end;
}

.verse-audio-settings-anchor {
  position: relative;
  display: inline-flex;
}

.verse-audio-settings-button.is-active {
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  color: var(--accent-dark);
}

.verse-audio-settings-popover {
  position: absolute;
  z-index: 70;
  inset-block-start: calc(100% + 8px);
  inset-inline-end: 0;
  width: min(320px, calc(100vw - 42px));
  display: grid;
  gap: 14px;
  padding: 16px;
  border: 1px solid color-mix(in srgb, var(--accent-dark) 18%, transparent);
  border-radius: 20px;
  background:
    linear-gradient(180deg, var(--control-bg-strong), rgba(249, 239, 224, 0.98));
  box-shadow: 0 22px 52px color-mix(in srgb, var(--ink) 18%, transparent);
}

html[dir="rtl"] .verse-audio-settings-popover {
  inset-inline-start: auto;
  inset-inline-end: 0;
  text-align: right;
}

.verse-audio-settings-popover[hidden] {
  display: none;
}

.verse-audio-settings-popover strong {
  margin: 0;
  color: color-mix(in srgb, var(--ink) 90%, transparent);
  font-size: max(20px, 0.98rem);
}

.verse-audio-settings-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px 12px;
  align-items: center;
  color: rgba(68, 57, 45, 0.78);
  font-size: max(20px, 0.84rem);
  font-weight: 700;
}

.verse-audio-settings-row output {
  color: var(--accent-dark);
  font-size: max(20px, 0.78rem);
}

.verse-audio-settings-row input[type="range"] {
  grid-column: 1 / -1;
  width: 100%;
  accent-color: var(--accent);
}

.verse-media-card--audio .verse-audio-button {
  grid-column: 1 / -1;
  grid-row: 2;
}

@media (max-width: 720px) {
  .verse-audio-button {
    width: 100%;
    padding: 12px;
  }

  .verse-audio-button__time {
    min-width: 72px;
    font-size: max(20px, 0.78rem);
  }
}

.verse-media-card__empty {
  display: grid;
  gap: 8px;
  min-height: 180px;
  place-items: center;
  text-align: center;
  padding: 18px;
  border-radius: 18px;
  border: 1px dashed color-mix(in srgb, var(--ink) 16%, transparent);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.84), rgba(250, 244, 233, 0.96));
}

.verse-media-card__empty p {
  margin: 0;
  max-width: 28ch;
  color: color-mix(in srgb, var(--ink) 76%, transparent);
}

.verse-media-card__meta {
  font-size: max(20px, 0.9rem);
  color: color-mix(in srgb, var(--ink) 62%, transparent);
}

.translation-compare {
  display: grid;
  gap: 18px;
}

.translation-compare__header {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 16px;
  padding: 24px 0 4px;
}

.translation-compare__header h1 {
  margin: 0 0 8px;
}

.translation-compare__header p {
  margin: 0;
}

.translation-compare__eyebrow {
  margin: 0 0 8px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: color-mix(in srgb, var(--ink) 62%, transparent);
}

.translation-compare__back {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 10px 16px;
  border-radius: 999px;
  text-decoration: none;
  color: var(--accent-dark);
  background: var(--control-bg);
  border: 1px solid color-mix(in srgb, var(--ink) 10%, transparent);
}

.translation-compare__table {
  display: grid;
  gap: 12px;
}

.translation-compare__row {
  display: grid;
  grid-template-columns: minmax(140px, 180px) minmax(0, 1fr) auto;
  gap: 0;
  border-radius: 24px;
  overflow: hidden;
  background: var(--control-bg);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  box-shadow: 0 14px 30px color-mix(in srgb, var(--ink) 8%, transparent);
}

.translation-compare__bible {
  display: grid;
  gap: 4px;
  align-content: start;
  padding: 18px 16px;
  background: color-mix(in srgb, var(--accent) 8%, transparent);
}

.translation-compare__bible a {
  color: var(--accent-dark);
  text-decoration: none;
  font-weight: 700;
  font-size: 1.35rem;
}

.translation-compare__bible span {
  color: color-mix(in srgb, var(--ink) 70%, transparent);
}

.translation-compare__passage {
  display: grid;
  gap: 10px;
  padding: 18px 18px 20px;
}

.translation-compare__passage p {
  margin: 0;
  line-height: 1.7;
}

.translation-compare__actions {
  display: flex;
  align-items: start;
  justify-content: center;
  padding: 18px 18px 18px 0;
}

.editor-workbench {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr) 320px;
  gap: 18px;
  min-height: calc(100vh - 170px);
}

body[data-page="editor"] .editor-workbench {
  grid-template-columns: 264px minmax(0, 1fr) 376px;
  gap: 12px;
  min-height: calc(100vh - 96px);
  height: calc(100vh - 96px);
  align-items: stretch;
}

.editor-sidebar {
  display: grid;
  gap: 16px;
  align-content: start;
  min-height: 0;
}

body[data-page="editor"] .editor-sidebar--inspector {
  grid-template-rows: minmax(0, 1fr) minmax(0, 1fr);
}

body[data-page="editor"] .editor-sidebar--tools {
  overflow: auto;
  padding-inline-end: 4px;
}

body[data-page="editor"] .editor-panel--layers {
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  min-height: 0;
}

body[data-page="editor"] .editor-sidebar {
  gap: 12px;
  min-height: 0;
  position: sticky;
  top: 8px;
  align-self: start;
  max-height: calc(100vh - 112px);
  overflow: hidden;
}

.editor-panel {
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 24px;
  background: #14110f;
  color: #f7efe3;
  border: 1px solid rgba(255, 244, 226, 0.08);
  box-shadow: 0 18px 36px rgba(17, 14, 12, 0.18);
  min-height: 0;
  position: relative;
}

body[data-page="editor"] .editor-panel {
  gap: 10px;
  padding: 14px;
  border-radius: 20px;
}

.editor-panel h1,
.editor-panel h2 {
  margin: 0;
}

body[data-page="editor"] .editor-panel > h2,
body[data-page="editor"] .editor-panel__split {
  min-height: 44px;
  padding: 0 2px 10px;
  border-bottom: 1px solid rgba(255, 244, 226, 0.08);
  box-shadow: inset 0 -1px 0 rgba(255, 244, 226, 0.03);
}

.editor-panel p {
  margin: 0;
  color: rgba(247, 239, 227, 0.7);
}

.editor-panel__split {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  position: sticky;
  top: 0;
  z-index: 2;
  padding-bottom: 10px;
  background: linear-gradient(180deg, #14110f 0%, #14110f 82%, rgba(20, 17, 15, 0) 100%);
}

.editor-panel__actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

body[data-page="editor"] .editor-panel__actions {
  gap: 10px;
}

.editor-toolset {
  display: grid;
  gap: 10px;
}

body[data-page="editor"] .editor-toolset {
  gap: 8px;
}

.editor-panel--create {
  min-height: 0;
  overflow: hidden;
}

.editor-panel--create.is-disabled {
  opacity: 0.55;
}

.editor-create-actions {
  display: grid;
  gap: 8px;
}

.editor-create-hint {
  font-size: max(20px, 0.82rem);
  color: rgba(247, 239, 227, 0.65);
}

.editor-create-dialog-backdrop {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: grid;
  place-items: center;
  padding: 24px;
  background: rgba(14, 11, 9, 0.72);
  backdrop-filter: blur(10px);
}

.editor-create-dialog {
  position: relative;
  z-index: 1;
  isolation: isolate;
  width: min(760px, calc(100vw - 48px));
  max-height: calc(100vh - 56px);
  overflow: auto;
  padding: 16px;
  border-radius: 24px;
  border: 1px solid rgba(255, 244, 226, 0.12);
  background: #14110f;
  box-shadow: 0 24px 54px rgba(12, 10, 8, 0.34);
  color: #f7efe3;
}

.editor-create-dialog .editor-field input,
.editor-create-dialog .editor-field select,
.editor-create-dialog .editor-inline-actions input {
  width: 100%;
  min-height: 44px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255, 244, 226, 0.14);
  background: rgba(255, 244, 226, 0.08);
  color: #f7efe3;
  box-shadow: none;
}

.editor-create-dialog .editor-field input::placeholder,
.editor-create-dialog .editor-inline-actions input::placeholder {
  color: rgba(247, 239, 227, 0.46);
}

.editor-create-dialog .editor-field select option,
.editor-create-dialog .editor-field select optgroup {
  background: #14110f;
  color: #f7efe3;
}

.editor-create-dialog .editor-field .editor-input--mini {
  width: 100%;
}

.editor-create-dialog--wide {
  width: min(1120px, calc(100vw - 48px));
  max-height: calc(100vh - 100px);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  overflow: hidden;
}

.editor-create-empty {
  display: grid;
  gap: 18px;
  margin-top: 20px;
}

.editor-create-empty h3,
.editor-template-group h3 {
  margin: 0;
  font-size: max(20px, 0.82rem);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255, 244, 226, 0.64);
}

.editor-size-preset-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 20px;
}

.editor-size-preset,
.editor-template-card {
  display: grid;
  gap: 6px;
  padding: 10px;
  border: 1px solid rgba(255, 244, 226, 0.1);
  border-radius: 14px;
  background: rgba(255, 244, 226, 0.035);
  color: inherit;
  text-align: left;
  transition: border-color 0.18s ease, background 0.18s ease, transform 0.18s ease;
}

.editor-size-preset span,
.editor-template-card span {
  color: rgba(247, 239, 227, 0.72);
  font-size: max(20px, 0.8rem);
}

.editor-template-card__meta {
  display: grid;
  gap: 2px;
}

.editor-template-card__provider {
  color: rgba(247, 239, 227, 0.54);
  font-size: max(20px, 0.68rem);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.editor-size-preset:hover,
.editor-size-preset:focus-visible,
.editor-template-card:hover,
.editor-template-card:focus-visible,
.editor-create-source__tab:hover,
.editor-create-source__tab:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 35%, transparent);
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  transform: translateY(-1px);
  outline: none;
}

.editor-create-dimension-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: end;
  gap: 10px;
  margin-top: 20px;
  padding-bottom: 30px;
}

.editor-create-empty__custom {
  margin-top: 30px;
}

.editor-create-dimension-sep {
  padding-bottom: 10px;
  color: rgba(247, 239, 227, 0.64);
  font-weight: 700;
}

.editor-create-dialog__footer {
  display: flex;
  justify-content: flex-end;
}

.editor-create-source {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 16px;
  min-height: 0;
  height: 100%;
  margin-top: 20px;
}

.editor-create-source__tabs {
  display: grid;
  gap: 8px;
  align-content: start;
  min-height: 0;
  overflow-y: auto;
  padding-right: 6px;
}

.editor-create-source__tab {
  display: flex;
  align-items: center;
  min-height: 44px;
  padding: 0 14px;
  border: 1px solid rgba(255, 244, 226, 0.1);
  border-radius: 14px;
  background: rgba(255, 244, 226, 0.035);
  color: inherit;
  text-align: left;
}

.editor-create-source__tab.is-active {
  border-color: color-mix(in srgb, var(--accent) 35%, transparent);
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  color: #fff4e3;
}

.editor-create-source__body {
  display: grid;
  min-width: 0;
  min-height: 0;
  height: 100%;
}

.editor-create-source__panel {
  display: none;
  height: 100%;
  min-height: 0;
  overflow: hidden;
}

.editor-create-source__panel.is-active {
  display: grid;
  overflow-y: auto;
}

.editor-create-source-picker {
  display: grid;
  gap: 12px;
  min-height: 100%;
}

.editor-verse-navigator--create {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.editor-verse-navigator--book {
  grid-template-columns: minmax(0, 1fr);
}

.editor-create-source-results {
  min-height: 220px;
  max-height: 360px;
  overflow: auto;
  padding-inline-end: 4px;
}

.editor-create-image-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.editor-create-image-card {
  display: grid;
  gap: 6px;
  padding: 6px;
  border: 1px solid rgba(255, 244, 226, 0.1);
  border-radius: 12px;
  background: rgba(255, 244, 226, 0.035);
  color: inherit;
  text-align: left;
}

.editor-create-image-card img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 8px;
  display: block;
  background: rgba(255, 244, 226, 0.05);
}

.editor-create-image-card span {
  font-size: max(20px, 0.76rem);
  line-height: 1.25;
  color: rgba(247, 239, 227, 0.78);
}

.editor-create-image-card.is-selected,
.editor-create-image-card:hover,
.editor-create-image-card:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 35%, transparent);
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  outline: none;
}

.editor-verse-dialog {
  width: min(920px, calc(100vw - 48px));
}

.editor-verse-dialog__body {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr);
  gap: 16px;
  margin-top: 20px;
}

.editor-verse-dialog__content {
  display: grid;
  gap: 12px;
}

.editor-verse-navigator {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  align-items: end;
}

.editor-verse-search {
  display: grid;
  gap: 10px;
}

.editor-inline-actions--verse-search {
  display: flex;
  align-items: stretch;
  flex-wrap: nowrap;
}

.editor-inline-actions--verse-search input {
  flex: 1 1 auto;
  min-width: 0;
}

.editor-inline-actions--verse-search .editor-button {
  flex: 0 0 auto;
}

.editor-verse-search-results {
  display: grid;
  gap: 8px;
  max-height: 260px;
  overflow: auto;
  padding-inline-end: 4px;
}

.editor-verse-search-results__empty {
  margin: 0;
  color: rgba(247, 239, 227, 0.72);
  font-size: max(20px, 0.92rem);
}

.editor-verse-result {
  display: grid;
  gap: 4px;
  padding: 10px 12px;
  border: 1px solid rgba(255, 244, 226, 0.1);
  border-radius: 14px;
  background: rgba(255, 244, 226, 0.035);
  color: inherit;
  text-align: left;
}

.editor-verse-result strong {
  font-size: max(20px, 0.92rem);
}

.editor-verse-result span {
  color: rgba(247, 239, 227, 0.76);
  font-size: max(20px, 0.84rem);
  line-height: 1.4;
}

.editor-verse-result.is-selected,
.editor-verse-result:hover,
.editor-verse-result:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 35%, transparent);
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  outline: none;
}

.editor-verse-preview {
  grid-column: 2;
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid rgba(255, 244, 226, 0.1);
  border-radius: 16px;
  background: rgba(255, 244, 226, 0.035);
}

.editor-verse-preview__meta {
  color: rgba(255, 244, 226, 0.78);
  font-size: max(20px, 0.9rem);
  font-weight: 700;
}

.editor-verse-preview__text {
  min-height: 72px;
  max-height: 160px;
  overflow: auto;
  color: rgba(247, 239, 227, 0.92);
  line-height: 1.55;
  white-space: pre-wrap;
  padding-inline-end: 4px;
}

.editor-template-group {
  display: grid;
  gap: 8px;
}

.editor-template-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
}

.editor-template-grid--templates {
  grid-template-columns: repeat(auto-fill, minmax(148px, 1fr));
  min-height: 0;
  height: 100%;
  overflow: auto;
  align-content: start;
  padding-right: 4px;
}

.editor-template-grid--shapes {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.editor-template-browser {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 12px;
  min-height: 100%;
  height: 100%;
}

.editor-template-browser__filters {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.editor-template-browser__scroller {
  min-height: 0;
  height: 100%;
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto auto auto;
  gap: 10px;
  overflow: hidden;
}

.editor-template-browser__loading,
.editor-template-browser__status {
  padding: 10px 2px;
  color: rgba(247, 239, 227, 0.62);
  font-size: max(20px, 0.82rem);
}

.editor-template-browser__sentinel {
  height: 1px;
}

.editor-create-dialog__footer--template {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding-bottom: 20px;
}

.editor-template-browser__selection {
  min-width: 0;
  color: rgba(247, 239, 227, 0.72);
  font-size: max(20px, 0.8rem);
}

.editor-template-card img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 8px;
  display: block;
  background: rgba(255, 244, 226, 0.05);
}

.editor-template-card {
  gap: 4px;
  padding: 6px;
  border-radius: 12px;
}

.editor-template-card--remote {
  position: relative;
}

.editor-template-card--remote.is-selected {
  border-color: color-mix(in srgb, var(--accent) 45%, transparent);
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 22%, transparent);
}

.editor-template-card--remote img {
  aspect-ratio: auto;
  height: 132px;
  object-fit: cover;
}

.editor-template-card__badge {
  position: absolute;
  top: 12px;
  right: 12px;
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(19, 16, 14, 0.86);
  border: 1px solid rgba(255, 244, 226, 0.14);
  color: rgba(255, 244, 226, 0.9);
  font-size: max(20px, 0.64rem);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.editor-template-card span {
  font-size: max(20px, 0.72rem);
}

.editor-template-card span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 600;
}

.editor-source-choice,
.editor-custom-source {
  display: grid;
  gap: 14px;
  align-content: start;
  min-height: 100%;
}

.editor-source-choice__preview {
  width: 100%;
  max-height: 520px;
  object-fit: contain;
  border-radius: 18px;
  background: rgba(255, 244, 226, 0.04);
  border: 1px solid rgba(255, 244, 226, 0.1);
}

.editor-source-choice__empty {
  margin: 0;
  color: rgba(247, 239, 227, 0.72);
}

.editor-custom-source {
  padding: 18px;
  border: 1px dashed rgba(255, 244, 226, 0.18);
  border-radius: 18px;
  background: rgba(255, 244, 226, 0.03);
}

.editor-custom-source.is-drop-target {
  border-color: color-mix(in srgb, var(--accent) 48%, transparent);
  background: color-mix(in srgb, var(--accent) 12%, transparent);
}

.editor-custom-source__actions {
  display: flex;
  gap: 8px;
}

.editor-tool,
.editor-button,
.editor-toolbar-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 10px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255, 244, 226, 0.12);
  background: rgba(255, 244, 226, 0.06);
  color: inherit;
  text-decoration: none;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}

body[data-page="editor"] .editor-tool,
body[data-page="editor"] .editor-button,
body[data-page="editor"] .editor-toolbar-button {
  min-height: 38px;
  padding: 8px 12px;
  border-radius: 12px;
}

.editor-toolbar-button--icon {
  width: 38px;
  min-width: 38px;
  padding: 0 !important;
}

.editor-tool:hover,
.editor-button:hover,
.editor-toolbar-button:hover,
.editor-tool:focus-visible,
.editor-button:focus-visible,
.editor-toolbar-button:focus-visible {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  border-color: color-mix(in srgb, var(--accent) 28%, transparent);
}

.editor-tool.is-active {
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 34%, transparent), rgba(173, 91, 31, 0.4));
  border-color: rgba(255, 216, 154, 0.24);
  color: #fff6eb;
}

.editor-toolbar-button.is-active {
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 34%, transparent), rgba(173, 91, 31, 0.4));
  border-color: rgba(255, 216, 154, 0.24);
  color: #fff6eb;
  box-shadow: inset 0 0 0 1px rgba(255, 227, 183, 0.14);
}

.editor-button--ghost,
.editor-toolbar-button--danger {
  background: rgba(255, 244, 226, 0.02);
}

.editor-toolbar-button--danger:hover,
.editor-toolbar-button--danger:focus-visible {
  background: rgba(176, 60, 42, 0.24);
  border-color: rgba(176, 60, 42, 0.34);
}

.editor-toolbar-button--icon svg,
.editor-icon-button svg,
.editor-layer-list__grab svg,
.editor-layer-list__delete svg {
  width: 18px;
  height: 18px;
  display: block;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
  vector-effect: non-scaling-stroke;
}

.editor-glyph,
.editor-glyph-stack {
  width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  flex: 0 0 auto;
}

.editor-glyph {
  background-color: currentColor;
  -webkit-mask-image: var(--editor-icon);
  mask-image: var(--editor-icon);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
}

.editor-glyph--undo { --editor-icon: url('/assets/editor-icons/undo.svg'); }
.editor-glyph--redo { --editor-icon: url('/assets/editor-icons/redo.svg'); }
.editor-glyph--zoom { --editor-icon: url('/assets/editor-icons/zoom.svg'); }
.editor-glyph--fit { --editor-icon: url('/assets/editor-icons/fit.svg'); }
.editor-glyph--grid { --editor-icon: url('/assets/editor-icons/grid.svg'); }
.editor-glyph--rulers { --editor-icon: url('/assets/editor-icons/rulers.svg'); }
.editor-glyph--crop { --editor-icon: url('/assets/editor-icons/crop.svg'); }
.editor-glyph--align-left { --editor-icon: url('/assets/editor-icons/align-left.svg'); }
.editor-glyph--align-center { --editor-icon: url('/assets/editor-icons/align-center.svg'); }
.editor-glyph--align-right { --editor-icon: url('/assets/editor-icons/align-right.svg'); }
.editor-glyph--align-top {
  --editor-icon: url('/assets/editor-icons/align-left.svg');
  transform: rotate(90deg);
}
.editor-glyph--align-middle {
  --editor-icon: url('/assets/editor-icons/align-center.svg');
  transform: rotate(90deg);
}
.editor-glyph--align-bottom {
  --editor-icon: url('/assets/editor-icons/align-right.svg');
  transform: rotate(90deg);
}
.editor-glyph--bold { --editor-icon: url('/assets/editor-icons/bold.svg'); }
.editor-glyph--italic { --editor-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 4h10v2h-3.8l-3.4 12H16v2H6v-2h3.8l3.4-12H9V4z'/></svg>"); }
.editor-glyph--underline { --editor-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M8 4v7a4 4 0 1 0 8 0V4h2v7a6 6 0 1 1-12 0V4h2zm-1 15h10v2H7v-2z'/></svg>"); }
.editor-glyph--duplicate { --editor-icon: url('/assets/editor-icons/duplicate.svg'); }
.editor-glyph--layers-stack { --editor-icon: url('/assets/editor-icons/layers-stack.svg'); }
.editor-glyph--delete { --editor-icon: url('/assets/editor-icons/delete.svg'); }
.editor-glyph--rotate { --editor-icon: url('/assets/editor-icons/rotate.svg'); }
.editor-glyph--tool-select { --editor-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M5 3l12 9-5.3 1.1 2.6 6.6-2.3.9-2.7-6.5L5 19V3z'/></svg>"); }
.editor-glyph--tool-pan { --editor-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M12 2a2 2 0 0 1 2 2v4h1V5a2 2 0 1 1 4 0v7.2c0 4.6-3 8.8-7.2 9.8A9 9 0 0 1 5 13V9a2 2 0 1 1 4 0v2h1V4a2 2 0 0 1 2-2z'/></svg>"); }
.editor-glyph--tool-pen { --editor-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M15.3 3.3l5.4 5.4-10 10-5.8 1 1-5.8 10-10zM13.9 6.1l4 4'/></svg>"); }
.editor-glyph--tool-brush { --editor-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M14.2 4.2l5.6 5.6-7.7 7.7-5.6-5.6 7.7-7.7zm-9.1 9.9c2.3 0 4 1.7 4 4 0 1.9-1.2 3.5-3 4-.8.2-1.7.3-2.6.3.4-.7.7-1.5.8-2.4.2-1.3-.1-2.4-.8-3.3.4-1.5 1.5-2.6 3-2.6z'/></svg>"); }
.editor-glyph--tool-text { --editor-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M4 5h16v3h-6v11h-4V8H4V5z'/></svg>"); }
.editor-glyph--flip-horizontal { --editor-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M11 4H4v16h7l-4.5-8L11 4zm2 0h7v16h-7l4.5-8L13 4z'/></svg>"); }
.editor-glyph--flip-vertical { --editor-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M4 11V4h16v7l-8-4.5L4 11zm0 2l8 4.5 8-4.5V20H4v-7z'/></svg>"); }
.editor-glyph--arrow {
  --editor-icon: url('/assets/editor-icons/arrow.svg');
}
.editor-glyph--arrow-up-left { transform: rotate(45deg); }
.editor-glyph--arrow-up { transform: rotate(90deg); }
.editor-glyph--arrow-up-right { transform: rotate(135deg); }
.editor-glyph--arrow-left { transform: rotate(0deg); }
.editor-glyph--arrow-right { transform: rotate(180deg); }
.editor-glyph--arrow-down-left { transform: rotate(-45deg); }
.editor-glyph--arrow-down { transform: rotate(-90deg); }
.editor-glyph--arrow-down-right { transform: rotate(-135deg); }

.editor-glyph-stack__badge {
  position: absolute;
  right: -3px;
  bottom: -5px;
  min-width: 11px;
  height: 11px;
  padding: 0 2px;
  border-radius: 999px;
  background: rgba(28, 22, 18, 0.92);
  box-shadow: 0 0 0 1px rgba(255, 244, 226, 0.16);
  color: currentColor;
  font-size: max(20px, 0.65rem);
  line-height: 11px;
  text-align: center;
  font-weight: 800;
}

.editor-toolbar-button__close-mark {
  font-size: 1.35rem;
  line-height: 1;
  color: currentColor;
  transform: translateY(-1px);
}

.editor-stepper__mark {
  font-size: 1.15rem;
  line-height: 1;
  font-weight: 700;
  color: currentColor;
}

.editor-layer-list__grip-dots {
  width: 12px;
  height: 18px;
  display: block;
  background-image:
    radial-gradient(circle, currentColor 1.2px, transparent 1.3px),
    radial-gradient(circle, currentColor 1.2px, transparent 1.3px);
  background-size: 6px 6px;
  background-position: 0 0, 6px 0;
  background-repeat: repeat-y;
  opacity: 0.7;
}

.editor-field {
  display: grid;
  gap: 8px;
}

body[data-page="editor"] .editor-field {
  gap: 6px;
}

.editor-field span,
.editor-empty-state,
.editor-layer-list__item small {
  color: rgba(247, 239, 227, 0.7);
  font-size: max(20px, 0.96rem);
}

.editor-field input,
.editor-field textarea,
.editor-field select {
  width: 100%;
  min-width: 0;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255, 244, 226, 0.12);
  background: var(--control-bg-strong);
  color: #1f1d1a;
  font: inherit;
}

body[data-page="editor"] .editor-field input,
body[data-page="editor"] .editor-field textarea,
body[data-page="editor"] .editor-field select {
  padding: 8px 10px;
  border-radius: 12px;
}

body[data-page="editor"] .editor-field--compact {
  gap: 4px;
}

.editor-field textarea {
  min-height: 128px;
  resize: none;
  line-height: 1.4;
  scrollbar-width: thin;
}

.editor-grid {
  display: grid;
  gap: 10px;
}

body[data-page="editor"] .editor-grid {
  gap: 8px;
}

body[data-page="editor"] .editor-grid--position-color {
  grid-template-columns: auto minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

body[data-page="editor"] .editor-grid--inspector-main {
  grid-template-columns: 122px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.editor-field-stack {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.editor-field-stack--drawing-properties {
  margin-top: 20px;
}

.editor-grid--two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.editor-grid--size-compact,
.editor-grid--asset-tools {
  gap: 8px 10px;
}

body[data-page="editor"] .editor-grid--size-compact .editor-field > span,
body[data-page="editor"] .editor-grid--asset-tools .editor-field > span {
  font-size: max(20px, 0.82rem);
  letter-spacing: 0.01em;
}

.editor-grid--three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.editor-grid--font {
  grid-template-columns: minmax(0, 1fr) auto;
}

.editor-grid--compact-controls {
  grid-template-columns: minmax(0, 1fr) minmax(0, 0.75fr);
}

.editor-grid--position-color .editor-field:first-child {
  width: max-content;
}

.editor-field--position-cluster {
  gap: 8px;
  padding: 8px 9px 9px;
  border-radius: 16px;
  border: 1px solid rgba(255, 244, 226, 0.12);
  background: rgba(255, 244, 226, 0.015);
  align-content: start;
  width: max-content;
  max-width: 100%;
}

.editor-field-stack--inspector-right {
  grid-column: 2;
  gap: 8px;
}

.editor-field-stack--inspector-section {
  gap: 6px;
}

.editor-field-stack--inspector-controls {
  gap: 6px;
}

.editor-field--inline-compact {
  display: grid;
  grid-template-columns: 104px minmax(0, 1fr);
  align-items: center;
  column-gap: 10px;
  row-gap: 0;
}

.editor-field--inline-compact > span {
  font-size: max(20px, 0.84rem);
  line-height: 1.15;
}

.editor-field--inline-compact-narrow {
  grid-template-columns: 84px minmax(0, 1fr);
}

.editor-field-stack--inspector-right .editor-field--inline-compact > span {
  font-size: max(20px, 0.82rem);
}

.editor-field--asset-tint {
  min-width: 0;
}

.editor-field--flip-actions {
  align-content: start;
}

.editor-field--drawing-inline {
  grid-template-columns: 84px minmax(0, 1fr);
}

.editor-field--drawing-inline .editor-color-toolbar {
  flex-wrap: nowrap;
}

.editor-field--drawing-inline .editor-range-input {
  flex: 1 1 auto;
  min-width: 0;
}

.editor-inline-action-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  width: 100%;
  padding: 0 12px;
  border-radius: 10px;
  border: 1px solid rgba(255, 244, 226, 0.14);
  background: rgba(255, 244, 226, 0.07);
  color: #f7efe3;
  font: inherit;
  font-size: max(20px, 0.82rem);
  font-weight: 700;
  cursor: pointer;
  transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.editor-inline-action-button:hover,
.editor-inline-action-button:focus-visible {
  background: color-mix(in srgb, var(--accent) 22%, transparent);
  border-color: color-mix(in srgb, var(--accent) 30%, transparent);
  color: #fff6eb;
}

.editor-icon-row--compact {
  gap: 6px;
  flex-wrap: nowrap;
  min-height: 38px;
  align-items: center;
}

.editor-inline-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

body[data-page="editor"] .editor-inline-actions {
  gap: 8px;
}

.editor-segmented {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.editor-segmented__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 12px;
  border-radius: 12px;
  border: 1px solid rgba(255, 244, 226, 0.08);
  background: rgba(255, 244, 226, 0.04);
  color: #f7efe3;
  font: inherit;
  cursor: pointer;
  transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.editor-segmented__button:hover,
.editor-segmented__button:focus-visible {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  border-color: color-mix(in srgb, var(--accent) 28%, transparent);
}

.editor-segmented__button.is-active {
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 34%, transparent), rgba(173, 91, 31, 0.4));
  border-color: rgba(255, 216, 154, 0.24);
  color: #fff6eb;
}

.editor-mini-group {
  display: inline-flex;
  align-items: end;
  gap: 8px;
}

.editor-input--mini {
  min-width: 0;
  width: 88px;
  padding-inline: 8px;
}

.editor-icon-row,
.editor-icon-grid,
.editor-compact-control,
.editor-color-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.editor-color-popover {
  position: relative;
  display: inline-flex;
  flex: none;
}

.editor-color-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-width: 58px;
  height: 34px;
  padding: 0 8px;
  border-radius: 10px;
  border: 1px solid rgba(255, 244, 226, 0.16);
  background: linear-gradient(180deg, rgba(255, 244, 226, 0.09), rgba(255, 244, 226, 0.05));
  cursor: pointer;
}

.editor-color-trigger::after {
  content: "";
  width: 8px;
  height: 8px;
  border-right: 2px solid rgba(255, 244, 226, 0.72);
  border-bottom: 2px solid rgba(255, 244, 226, 0.72);
  transform: rotate(45deg) translateY(-1px);
  flex: 0 0 auto;
}

.editor-color-trigger__swatch {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  border: 2px solid rgba(255, 244, 226, 0.18);
  box-shadow: inset 0 0 0 1px rgba(20, 17, 15, 0.16);
  background: #000000;
}

.editor-color-popover.is-open .editor-color-trigger {
  border-color: color-mix(in srgb, var(--accent) 34%, transparent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 16%, transparent);
}

.editor-color-popover__panel {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 80;
  display: grid;
  gap: 10px;
  min-width: 210px;
  padding: 12px;
  border-radius: 14px;
  border: 1px solid rgba(255, 244, 226, 0.12);
  background: #1b1511;
  box-shadow: 0 18px 32px rgba(0, 0, 0, 0.28);
}

.editor-color-popover__panel--with-swatches {
  min-width: 318px;
}

.editor-range-input--popover {
  min-width: 0;
  width: 100%;
}

.editor-popover-slider {
  display: grid;
  gap: 6px;
  width: 100%;
}

.editor-popover-field {
  display: grid;
  gap: 6px;
  width: 100%;
}

.editor-popover-checkbox {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  font-size: max(20px, 0.8rem);
}

.editor-popover-checkbox input {
  margin: 0;
}

.editor-popover-field > span,
.editor-popover-slider > span {
  font-size: max(20px, 0.76rem);
  line-height: 1.1;
  color: rgba(247, 239, 227, 0.88);
}

.editor-color-toolbar--compact {
  flex-wrap: nowrap;
}

.editor-crosspad {
  display: grid;
  grid-template-columns: repeat(3, 32px);
  grid-template-rows: repeat(3, 32px);
  gap: 3px;
  align-items: center;
  justify-content: start;
}

.editor-crosspad__button--up {
  grid-column: 2;
  grid-row: 1;
}

.editor-crosspad__button--up-left {
  grid-column: 1;
  grid-row: 1;
}

.editor-crosspad__button--up-right {
  grid-column: 3;
  grid-row: 1;
}

.editor-crosspad__button--left {
  grid-column: 1;
  grid-row: 2;
}

.editor-crosspad__button--center {
  grid-column: 2;
  grid-row: 2;
}

.editor-crosspad__button--right {
  grid-column: 3;
  grid-row: 2;
}

.editor-crosspad__button--down-left {
  grid-column: 1;
  grid-row: 3;
}

.editor-crosspad__button--down {
  grid-column: 2;
  grid-row: 3;
}

.editor-crosspad__button--down-right {
  grid-column: 3;
  grid-row: 3;
}

.editor-crosspad__button--center {
  position: relative;
}

.editor-crosspad__rotate-badge {
  position: absolute;
  right: 2px;
  bottom: 2px;
  font-size: max(20px, 9px);
  line-height: 1;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: rgba(247, 239, 227, 0.92);
  pointer-events: none;
}

.editor-rotation-strip {
  display: inline-flex;
  gap: 5px;
  margin-top: 2px;
  width: 100%;
}

.editor-rotation-strip__button {
  width: auto;
  min-width: 0;
  flex: 1 1 0;
  padding: 0 8px;
  gap: 5px;
  height: 32px;
}

.editor-rotation-strip__label {
  font-size: max(20px, 10px);
  line-height: 1;
  font-weight: 700;
  color: rgba(247, 239, 227, 0.88);
}

.editor-icon-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.editor-icon-grid--toolbar {
  display: inline-flex;
  gap: 6px;
  flex-wrap: nowrap;
}

.editor-icon-button,
.editor-icon-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  padding: 0;
  border-radius: 10px;
  border: 1px solid rgba(255, 244, 226, 0.12);
  background: rgba(255, 244, 226, 0.05);
  color: #f7efe3;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.editor-icon-button svg,
.editor-icon-toggle svg {
  width: 18px;
  height: 18px;
  display: block;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.editor-icon-button:hover,
.editor-icon-button:focus-visible,
.editor-icon-toggle:hover,
.editor-icon-toggle:focus-visible,
.editor-icon-button.is-active,
.editor-icon-toggle.is-active {
  background: color-mix(in srgb, var(--accent) 22%, transparent);
  border-color: color-mix(in srgb, var(--accent) 30%, transparent);
  color: #fff6eb;
}

.editor-color-input {
  width: 100% !important;
  height: 44px;
  padding: 0 !important;
  border-radius: 0px !important;
  border: 0px !important;
  background:
    linear-gradient(180deg, rgba(255, 244, 226, 0.12), rgba(255, 244, 226, 0.05)),
    repeating-conic-gradient(from 45deg, rgba(255, 255, 255, 0.08) 0 25%, rgba(0, 0, 0, 0.06) 0 50%) 50% / 16px 16px !important;
  box-shadow: inset 0 0 0 1px rgba(255, 244, 226, 0.16);
  overflow: hidden;
  cursor: pointer;
}

.editor-color-input::-webkit-color-swatch-wrapper {
  padding: 6px;
}

.editor-color-input::-webkit-color-swatch {
  border: 1px solid rgba(255, 244, 226, 0.18);
  box-shadow: 0 0 0 1px rgba(20, 17, 15, 0.18) inset;
}

.editor-action-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.editor-button--soft {
  padding: 10px 14px;
  border: 1px solid rgba(255, 244, 226, 0.16);
  background: linear-gradient(180deg, rgba(255, 244, 226, 0.12), rgba(255, 244, 226, 0.05));
  color: #fff6eb;
  border-radius: 12px;
}

.editor-button--soft:hover,
.editor-button--soft:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 45%, transparent);
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 18%, transparent), color-mix(in srgb, var(--accent) 8%, transparent));
}

.editor-shape-dialog {
  width: min(980px, calc(100vw - 48px));
}

.editor-shape-dialog__body {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr);
  grid-template-rows: auto minmax(0, 1fr);
  align-items: stretch;
  gap: 16px;
  margin-top: 20px;
  min-height: 420px;
  height: min(640px, calc(100vh - 220px));
}

.editor-shape-dialog__body > .editor-create-source__tabs {
  grid-column: 1;
  grid-row: 1 / span 2;
  height: 100%;
  max-height: 100%;
}

.editor-shape-dialog__filters {
  grid-column: 2;
  grid-row: 1;
  display: flex;
  align-items: end;
  gap: 12px;
}

.editor-shape-dialog__filters .editor-field {
  width: min(320px, 100%);
}

.editor-shape-dialog__content {
  grid-column: 2;
  grid-row: 2;
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 12px;
  min-width: 0;
  min-height: 0;
  overflow: hidden;
}

.editor-field--shape-search input[type="search"] {
  width: 100%;
}

.editor-template-card--shape {
  align-content: start;
}

.editor-template-grid--shapes {
  min-height: 0;
  max-height: 100%;
  overflow-y: auto;
  padding-right: 4px;
}

.editor-template-card--shape.is-selected {
  border-color: color-mix(in srgb, var(--accent) 45%, transparent);
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 22%, transparent);
}

.editor-template-card--shape img {
  object-fit: contain;
  padding: 12px;
  background:
    linear-gradient(180deg, rgba(255, 244, 226, 0.06), rgba(255, 244, 226, 0.02)),
    repeating-conic-gradient(from 45deg, rgba(255, 255, 255, 0.04) 0 25%, rgba(0, 0, 0, 0.03) 0 50%) 50% / 18px 18px;
}

.editor-template-card--shape .editor-template-card__meta {
  min-width: 0;
}

.editor-range-input {
  flex: 1 1 120px;
  min-width: 120px;
}

.editor-range-input--compact {
  flex: 1 1 88px;
  min-width: 88px;
}

.editor-color-swatches {
  display: grid;
  gap: 8px;
}

.editor-color-swatches__row {
  display: grid;
  gap: 8px;
}

.editor-color-swatches__row--eight {
  grid-template-columns: repeat(8, 28px);
}

.editor-color-swatch {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  border: 2px solid rgba(255, 244, 226, 0.2);
  background: var(--swatch);
  box-shadow: inset 0 0 0 1px rgba(20, 17, 15, 0.12);
  cursor: pointer;
}

.editor-color-swatch.is-active {
  outline: 2px solid color-mix(in srgb, var(--accent) 95%, transparent);
  outline-offset: 2px;
}

.editor-canvas-shell {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 14px;
  min-height: 0;
}

body[data-page="editor"] .editor-canvas-shell {
  gap: 10px;
}

.editor-ai-strip {
  display: grid;
  grid-template-columns: minmax(0, 1.8fr) minmax(170px, 220px) auto minmax(220px, 1fr);
  gap: 12px;
  align-items: end;
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid rgba(255, 244, 226, 0.08);
  background: #14110f;
  color: #f7efe3;
  box-shadow: 0 14px 28px rgba(17, 14, 12, 0.14);
}

.editor-ai-strip .editor-field {
  margin: 0;
}

.editor-field--ai-prompt {
  min-width: 0;
}

.editor-button--ai {
  align-self: stretch;
  min-width: 118px;
}

.editor-ai-strip__meta {
  display: grid;
  gap: 4px;
  align-self: stretch;
  align-content: center;
}

.editor-ai-strip__credits {
  font-size: max(20px, 0.88rem);
  color: #f1d9b2;
}

.editor-ai-strip__status {
  font-size: max(20px, 0.82rem);
  color: rgba(244, 236, 223, 0.76);
}

.editor-ai-strip__signin {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: rgba(244, 236, 223, 0.84);
}

.editor-stage-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 18px;
  border-radius: 24px;
  border: 1px solid rgba(255, 244, 226, 0.08);
}

body[data-page="editor"] .editor-stage-toolbar {
  gap: 10px;
  padding: 10px 14px;
  border-radius: 18px;
}

.editor-stage-toolbar__view {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
  min-width: 0;
  flex-wrap: nowrap;
}

.editor-stage-toolbar__view--text {
  justify-content: flex-start;
  gap: 5px;
}

.editor-stage-toolbar__separator {
  width: 1px;
  align-self: stretch;
  margin: 4px 9px;
  background: rgba(255, 244, 226, 0.12);
  flex: none;
}

.editor-stage-toolbar {
  background: #14110f;
  color: #f7efe3;
  box-shadow: 0 18px 36px rgba(17, 14, 12, 0.18);
}

.editor-stage-toolbar__group {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: nowrap;
  min-width: 0;
}

.editor-stage-toolbar__segment {
  display: inline-flex;
  align-items: center;
  min-width: 0;
}

.editor-stage-wrap {
  position: relative;
  overflow: hidden;
  min-height: 720px;
  border-radius: 32px;
  background:
    linear-gradient(45deg, rgba(24, 21, 18, 0.08) 25%, transparent 25%),
    linear-gradient(-45deg, rgba(24, 21, 18, 0.08) 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, rgba(24, 21, 18, 0.08) 75%),
    linear-gradient(-45deg, transparent 75%, rgba(24, 21, 18, 0.08) 75%);
  background-size: 26px 26px;
  background-position: 0 0, 0 13px, 13px -13px, -13px 0;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  box-shadow: inset 0 0 0 1px rgba(255, 252, 246, 0.3), 0 18px 40px color-mix(in srgb, var(--ink) 10%, transparent);
}

body[data-page="editor"] .editor-stage-wrap {
  min-height: 0;
  height: 100%;
  border-radius: 24px;
}

.editor-stage-wrap.has-rulers .editor-stage-viewport {
  top: 26px;
  left: 26px;
}

.editor-textbar__select {
  width: 236px;
  min-width: 236px;
  height: 38px;
  padding: 0 34px 0 12px;
  border-radius: 10px;
  border: 1px solid rgba(255, 244, 226, 0.12);
  background: rgba(255, 244, 226, 0.06);
  color: #f7efe3;
  font: inherit;
  color-scheme: dark;
  appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(247, 239, 227, 0.8) 50%),
    linear-gradient(135deg, rgba(247, 239, 227, 0.8) 50%, transparent 50%);
  background-position:
    calc(100% - 16px) calc(50% - 2px),
    calc(100% - 11px) calc(50% - 2px);
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
}

.editor-glyph--rotate-left {
  transform: scaleX(-1);
}

.editor-textbar__size {
  width: 54px;
  height: 38px;
  text-align: center;
  font-variant-numeric: tabular-nums;
  background: transparent;
  color: #f7efe3;
  border: 0;
  padding: 0 6px;
}

.editor-textbar__select option {
  background: #14110f;
  color: #f7efe3;
}

.editor-textbar__select optgroup {
  background: #14110f;
  color: rgba(247, 239, 227, 0.72);
}

.editor-stepper {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) 34px;
  align-items: center;
  height: 40px;
  border-radius: 12px;
  border: 1px solid rgba(255, 244, 226, 0.12);
  background: rgba(255, 244, 226, 0.06);
  overflow: hidden;
}

.editor-field-stack--inspector-controls .editor-stepper {
  grid-template-columns: 32px minmax(0, 1fr) 32px;
  height: 36px;
}

.editor-field-stack--inspector-controls .editor-stepper__button {
  width: 32px;
}

.editor-field-stack--inspector-controls .editor-color-trigger {
  min-width: 54px;
  height: 32px;
  padding: 0 7px;
}

.editor-field-stack--inspector-controls .editor-color-trigger__swatch {
  width: 22px;
  height: 22px;
}

.editor-stepper--toolbar {
  width: 124px;
}

.editor-stepper__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: stretch;
  width: 34px;
  padding: 0;
  border: 0;
  background: rgba(255, 244, 226, 0.04);
  color: #f7efe3;
  cursor: pointer;
  transition: background 0.18s ease, color 0.18s ease;
}

.editor-stepper__button:hover,
.editor-stepper__button:focus-visible {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  color: #fff6eb;
}

.editor-stepper__button svg {
  width: 16px;
  height: 16px;
}

.editor-stepper .editor-input--mini {
  width: 100%;
  min-width: 0;
  height: 100%;
  padding: 0 8px;
  border: 0;
  border-inline: 1px solid rgba(255, 244, 226, 0.12);
  border-radius: 0;
  background: transparent !important;
  color: inherit;
  text-align: center;
  font-variant-numeric: tabular-nums;
  box-shadow: none;
}

body[data-page="editor"] .editor-stepper .editor-input--mini {
  color: #f7efe3;
}

body[data-page="editor"] .editor-field .editor-stepper .editor-input--mini {
  color: #1f1d1a;
  background: var(--control-bg-strong) !important;
  font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
  font-size: max(20px, 0.96rem);
  font-weight: 600;
}

body[data-page="editor"] input[type="number"]::-webkit-outer-spin-button,
body[data-page="editor"] input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

body[data-page="editor"] input[type="number"] {
  -moz-appearance: textfield;
}

.editor-stage-wrap.is-drop-target {
  box-shadow: inset 0 0 0 2px color-mix(in srgb, var(--accent) 55%, transparent), 0 18px 40px color-mix(in srgb, var(--ink) 10%, transparent);
}

.editor-stage-viewport {
  position: absolute;
  inset: 0;
  overflow: hidden;
  cursor: default;
  touch-action: none;
}

.editor-ruler-corner,
.editor-ruler {
  position: absolute;
  z-index: 5;
  background: #1a1512;
  pointer-events: none;
}

.editor-ruler-corner {
  left: 0;
  top: 0;
  width: 26px;
  height: 26px;
  border-right: 1px solid rgba(255, 244, 226, 0.12);
  border-bottom: 1px solid rgba(255, 244, 226, 0.12);
}

.editor-ruler--top {
  left: 26px;
  top: 0;
  right: 0;
  height: 26px;
}

.editor-ruler--left {
  left: 0;
  top: 26px;
  bottom: 0;
  width: 26px;
}

.editor-grid-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  --editor-grid-minor: 40px;
  --editor-grid-major: 160px;
  background-image:
    linear-gradient(to right, rgba(255, 250, 243, 0.22) 1.5px, transparent 1.5px),
    linear-gradient(to bottom, rgba(255, 250, 243, 0.22) 1.5px, transparent 1.5px),
    linear-gradient(to right, rgba(255, 241, 214, 0.34) 2px, transparent 2px),
    linear-gradient(to bottom, rgba(255, 241, 214, 0.34) 2px, transparent 2px);
  background-size:
    var(--editor-grid-minor) var(--editor-grid-minor),
    var(--editor-grid-minor) var(--editor-grid-minor),
    var(--editor-grid-major) var(--editor-grid-major),
    var(--editor-grid-major) var(--editor-grid-major);
  background-position: 0 0;
}

.editor-crop-layer {
  position: absolute;
  inset: 50% auto auto 50%;
  translate: -50% -50%;
  transform-origin: center center;
}

.editor-ruler {
  overflow: hidden;
  border-color: rgba(255, 244, 226, 0.12);
}

.editor-ruler--top {
  border-bottom: 1px solid rgba(255, 244, 226, 0.12);
}

.editor-ruler--left {
  border-right: 1px solid rgba(255, 244, 226, 0.12);
}

.editor-ruler__tick {
  position: absolute;
  display: block;
  background: rgba(255, 244, 226, 0.52);
}

.editor-ruler__tick--top {
  bottom: 0;
  width: 1px;
  height: 8px;
}

.editor-ruler__tick--left {
  right: 0;
  width: 8px;
  height: 1px;
}

.editor-ruler__tick.is-major {
  background: rgba(255, 248, 238, 0.82);
}

.editor-ruler__tick--top.is-major {
  height: 13px;
}

.editor-ruler__tick--left.is-major {
  width: 13px;
}

.editor-ruler__label {
  position: absolute;
  color: rgba(255, 248, 238, 0.9);
  font-size: 0.68rem;
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: 0;
  user-select: none;
  white-space: nowrap;
  text-shadow: 0 1px 1px rgba(0, 0, 0, 0.35);
}

.editor-ruler__label--top {
  left: 4px;
  bottom: 10px;
}

.editor-ruler__label--left {
  right: 9px;
  top: 6px;
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  transform-origin: center;
}

.editor-guide-layer {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 2;
}

.editor-marquee {
  position: absolute;
  pointer-events: none;
  z-index: 2;
  border: 1px solid color-mix(in srgb, var(--accent) 95%, transparent);
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  box-shadow: inset 0 0 0 1px rgba(255, 243, 224, 0.28);
}

.editor-workbench.is-handspace .editor-stage-viewport,
.editor-tool.is-active[data-editor-tool="pan"] ~ * {
  cursor: grab;
}

.editor-surface {
  position: absolute;
  inset: 50% auto auto 50%;
  transform-origin: center center;
  translate: -50% -50%;
  box-shadow: 0 20px 46px rgba(15, 13, 11, 0.22);
}

.editor-crop-layer {
  z-index: 4;
  pointer-events: auto;
}

.editor-crop-controls {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 5;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 20px;
  border: 1px solid rgba(255, 244, 226, 0.14);
  background: rgba(20, 17, 15, 0.88);
  box-shadow: 0 16px 28px rgba(0, 0, 0, 0.22);
}

.editor-crop-controls__group {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.editor-crop-controls__separator {
  width: 1px;
  align-self: stretch;
  background: rgba(255, 244, 226, 0.12);
}

.editor-crop-control {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  padding: 0;
  border: 1px solid rgba(255, 244, 226, 0.14);
  border-radius: 16px;
  background: rgba(255, 244, 226, 0.05);
  color: #f7efe3;
  cursor: pointer;
  transition: background-color 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.editor-crop-control:hover,
.editor-crop-control:focus-visible {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  border-color: color-mix(in srgb, var(--accent) 28%, transparent);
  outline: none;
}

.editor-crop-control.is-active,
.editor-crop-control--confirm {
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 34%, transparent), rgba(173, 91, 31, 0.4));
  border-color: rgba(255, 216, 154, 0.24);
  color: #fff6eb;
}

.editor-crop-control svg {
  width: 28px;
  height: 28px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
  vector-effect: non-scaling-stroke;
}

.editor-crop-mask {
  position: absolute;
  background: rgba(12, 9, 7, 0.58);
  pointer-events: none;
}

.editor-crop-box {
  position: absolute;
  border: 2px solid rgba(255, 246, 235, 0.96);
  box-shadow: 0 0 0 9999px rgba(0, 0, 0, 0.02);
  cursor: move;
}

.editor-crop-box__label {
  position: absolute;
  top: 16px;
  right: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 64px;
  padding: 0 18px;
  border-radius: 18px;
  background: rgba(20, 17, 15, 0.86);
  color: #fff7ed;
  font-size: 3rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  white-space: nowrap;
  line-height: 1;
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.18);
}

.editor-crop-box__grid {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.editor-crop-box__center-line {
  position: absolute;
  background: rgba(255, 246, 235, 0.44);
  box-shadow: 0 0 0 1px rgba(40, 25, 12, 0.08);
}

.editor-crop-box__center-line--vertical {
  top: 0;
  bottom: 0;
  left: 50%;
  width: 1px;
  transform: translateX(-0.5px);
}

.editor-crop-box__center-line--horizontal {
  left: 0;
  right: 0;
  top: 50%;
  height: 1px;
  transform: translateY(-0.5px);
}

.editor-crop-handle {
  position: absolute;
  width: 16px;
  height: 16px;
  padding: 0;
  border: 2px solid #fff6eb;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 98%, transparent);
  box-shadow: 0 0 0 2px rgba(58, 35, 17, 0.2);
}

.editor-crop-handle--nw {
  top: -9px;
  left: -9px;
  cursor: nwse-resize;
}

.editor-crop-handle--ne {
  top: -9px;
  right: -9px;
  cursor: nesw-resize;
}

.editor-crop-handle--sw {
  bottom: -9px;
  left: -9px;
  cursor: nesw-resize;
}

.editor-crop-handle--se {
  right: -9px;
  bottom: -9px;
  cursor: nwse-resize;
}

.editor-background {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  user-select: none;
  pointer-events: none;
}

.editor-background-tint {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
}

.editor-layer-host {
  position: absolute;
  inset: 0;
  z-index: 3;
}

.editor-guide {
  position: absolute;
  background: color-mix(in srgb, var(--accent) 95%, transparent);
  box-shadow: 0 0 0 1px rgba(255, 243, 224, 0.35);
  opacity: 0.95;
}

.editor-guide--x {
  top: 0;
  bottom: 0;
  width: 1px;
}

.editor-guide--y {
  left: 0;
  right: 0;
  height: 1px;
}

.editor-layer {
  position: absolute;
  display: block;
  user-select: none;
  cursor: move;
  transform-origin: center center;
}

.editor-layer--text {
  display: block;
  white-space: pre-wrap;
  word-break: break-word;
  line-height: 1.1;
  overflow: hidden;
}

.editor-layer--asset {
  overflow: hidden;
}

.editor-layer--drawing {
  overflow: visible;
}

.editor-layer__image,
.editor-layer__tint,
.editor-layer__shape-mask,
.editor-layer__drawing {
  position: absolute;
  inset: 0;
}

.editor-layer__drawing {
  pointer-events: none;
}

.editor-layer__drawing svg {
  display: block;
  width: 100%;
  height: 100%;
  overflow: visible;
}

.editor-layer__text {
  position: absolute;
  top: 0;
  display: block;
  width: fit-content;
  max-width: 100%;
  height: auto;
  white-space: pre-wrap;
  word-break: break-word;
  line-height: 1.1;
}

.editor-layer__text-background {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.editor-layer__text-svg {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.editor-layer__text-svg svg {
  display: block;
  width: 100%;
  height: 100%;
  overflow: visible;
}

.editor-layer__move-zone {
  position: absolute;
  z-index: 1;
  pointer-events: auto;
  cursor: move;
}

.editor-layer__move-zone--top {
  top: 0;
  left: 18px;
  right: 18px;
  height: 18px;
}

.editor-layer__move-zone--right {
  top: 18px;
  right: 0;
  bottom: 18px;
  width: 18px;
}

.editor-layer__move-zone--bottom {
  right: 18px;
  bottom: 0;
  left: 18px;
  height: 18px;
}

.editor-layer__move-zone--left {
  top: 18px;
  bottom: 18px;
  left: 0;
  width: 18px;
}

.editor-layer.is-editable {
  cursor: text;
}

.editor-layer__text[contenteditable="plaintext-only"],
.editor-layer__text[contenteditable="true"] {
  user-select: text;
  cursor: text;
  outline: none;
  caret-color: currentColor;
}

.editor-layer__image {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  pointer-events: none;
}

.editor-layer__tint {
  pointer-events: none;
}

.editor-layer__shape-mask {
  pointer-events: none;
  -webkit-mask-image: var(--shape-src);
  mask-image: var(--shape-src);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
}

.editor-layer__drawing--brush svg {
  filter: saturate(1.03);
}

.editor-layer.is-selected {
  outline: 2px solid color-mix(in srgb, var(--accent) 95%, transparent);
  outline-offset: 2px;
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 15%, transparent);
}

.editor-resize-handle {
  position: absolute;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  border: 2px solid #fff6eb;
  background: color-mix(in srgb, var(--accent) 96%, transparent);
  box-shadow: 0 0 0 2px rgba(58, 35, 17, 0.25);
  padding: 0;
  touch-action: none;
  z-index: 4;
}

body[data-page="editor"] .editor-panel h1 {
  font-size: 1.45rem;
}

body[data-page="editor"] .editor-panel h2 {
  font-size: 1.08rem;
}

.editor-resize-handle--nw {
  top: -11px;
  left: -11px;
  cursor: nwse-resize;
}

.editor-resize-handle--n {
  top: -11px;
  left: calc(50% - 9px);
  cursor: ns-resize;
}

.editor-resize-handle--ne {
  top: -11px;
  right: -11px;
  cursor: nesw-resize;
}

.editor-resize-handle--e {
  top: calc(50% - 9px);
  right: -11px;
  cursor: ew-resize;
}

.editor-resize-handle--sw {
  bottom: -11px;
  left: -11px;
  cursor: nesw-resize;
}

.editor-resize-handle--s {
  bottom: -11px;
  left: calc(50% - 9px);
  cursor: ns-resize;
}

.editor-resize-handle--se {
  right: -11px;
  bottom: -11px;
  cursor: nwse-resize;
}

.editor-resize-handle--w {
  top: calc(50% - 9px);
  left: -11px;
  cursor: ew-resize;
}

.editor-zoom-readout {
  min-width: 60px;
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 10px;
  border-radius: 12px;
  border: 1px solid rgba(255, 244, 226, 0.12);
  background: rgba(255, 244, 226, 0.04);
  text-align: center;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}

.editor-layer-list {
  display: grid;
  gap: 6px;
  align-content: start;
  min-height: 0;
  height: 100%;
  overflow: auto;
  padding-inline-end: 4px;
}

.editor-layer-list__item {
  display: grid;
  grid-template-columns: auto auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  padding: 7px 10px;
  border-radius: 12px;
  border: 1px solid rgba(255, 244, 226, 0.12);
  background: rgba(255, 244, 226, 0.04);
  color: inherit;
  text-align: start;
  pointer-events: none;
}

.editor-layer-list__item span {
  font-weight: 700;
  font-size: max(20px, 0.95rem);
}

.editor-layer-list__grab {
  grid-column: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  padding: 0;
  border: 0;
  background: transparent;
  color: rgba(247, 239, 227, 0.55);
  cursor: grab;
  pointer-events: auto;
}

.editor-layer-list__grab svg {
  width: 14px;
  height: 14px;
}

.editor-layer-list__grab:active {
  cursor: grabbing;
}

.editor-layer-list__grab--placeholder {
  cursor: default;
  opacity: 0.25;
}

.editor-layer-list__meta {
  grid-column: 3;
  display: grid;
  min-width: 0;
  width: 100%;
  min-height: 22px;
  padding: 0 2px;
  border: 0;
  background: transparent;
  color: inherit;
  text-align: start;
  cursor: pointer;
  font: inherit;
  pointer-events: auto;
}

.editor-layer-list__meta span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.editor-layer-list__tail-spacer {
  grid-column: 4;
  width: 28px;
  height: 28px;
}

.editor-layer-list__check {
  grid-column: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  flex: none;
  cursor: pointer;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  position: relative;
  z-index: 2;
  pointer-events: auto;
}

.editor-layer-list__checkbox {
  width: 18px;
  height: 18px;
  border-radius: 6px;
  border: 1px solid rgba(255, 244, 226, 0.22);
  background: rgba(255, 244, 226, 0.04);
  box-shadow: inset 0 0 0 1px rgba(20, 17, 15, 0.08);
  position: relative;
}

.editor-layer-list__check.is-checked .editor-layer-list__checkbox {
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 85%, transparent), rgba(173, 91, 31, 0.92));
  border-color: rgba(255, 216, 154, 0.34);
}

.editor-layer-list__check.is-checked .editor-layer-list__checkbox::after {
  content: "";
  position: absolute;
  left: 5px;
  top: 2px;
  width: 5px;
  height: 9px;
  border: solid #fff8ef;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.editor-layer-list__delete {
  grid-column: 4;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  padding: 0;
  border: 1px solid rgba(255, 244, 226, 0.12);
  border-radius: 9px;
  background: rgba(255, 244, 226, 0.05);
  color: rgba(247, 239, 227, 0.72);
  cursor: pointer;
  pointer-events: auto;
  transition: background-color 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.editor-layer-list__delete:hover,
.editor-layer-list__delete:focus-visible {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  border-color: color-mix(in srgb, var(--accent) 28%, transparent);
  color: #fff4e3;
  outline: none;
}

.editor-layer-list__delete svg {
  width: 14px;
  height: 14px;
}

.editor-layers-opacity {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  min-height: 26px;
  margin-top: 2px;
  margin-bottom: 2px;
}

.editor-layers-opacity span,
.editor-layers-opacity strong {
  font-size: max(20px, 0.9rem);
}

.editor-layers-opacity strong {
  color: rgba(247, 239, 227, 0.78);
  font-weight: 700;
}

.editor-layers-opacity input[type="range"] {
  margin: 0;
  height: 10px;
  accent-color: #c9772b;
}

body[data-page="editor"] .editor-panel {
  gap: 12px;
}

body[data-page="editor"] .editor-sidebar--inspector .editor-panel:first-child {
  z-index: 6;
}

body[data-page="editor"] .editor-properties {
  padding-inline-end: 6px;
}

body[data-page="editor"] .editor-properties .editor-field > span {
  font-size: max(20px, 0.88rem);
  letter-spacing: 0.02em;
}

body[data-page="editor"] .editor-color-toolbar {
  gap: 6px;
  flex-wrap: nowrap;
  align-items: center;
}

body[data-page="editor"] .editor-field--inline-compact .editor-color-toolbar,
body[data-page="editor"] .editor-field--inline-compact .editor-range-input {
  min-width: 0;
}

body[data-page="editor"] .editor-field--inline-compact .editor-color-toolbar .editor-range-input {
  flex: 1 1 auto;
}

body[data-page="editor"] .editor-field--swatches .editor-color-toolbar {
  align-items: center;
}

body[data-page="editor"] .editor-field--swatches .editor-color-swatches,
body[data-page="editor"] .editor-field--swatches .editor-color-swatches__row {
  gap: 6px;
}

body[data-page="editor"] .editor-field--swatches .editor-color-toolbar {
  flex-wrap: nowrap;
}

body[data-page="editor"] .editor-color-swatch {
  width: 26px;
  height: 26px;
}

body[data-page="editor"] .editor-color-toolbar .editor-range-input {
  min-width: 0;
}

.editor-context-menu {
  position: absolute;
  z-index: 40;
  display: grid;
  min-width: 200px;
  padding: 8px;
  border-radius: 14px;
  border: 1px solid rgba(255, 244, 226, 0.1);
  background: #14110f;
  box-shadow: 0 18px 42px rgba(10, 8, 7, 0.4);
}

.editor-context-menu__item {
  display: flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: #f7efe3;
  text-align: start;
  font: inherit;
  cursor: pointer;
}

.editor-context-menu__item:hover,
.editor-context-menu__item:focus-visible {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
}

.editor-context-menu__item:disabled {
  opacity: 0.45;
  cursor: default;
}

.editor-context-menu__item--danger:hover,
.editor-context-menu__item--danger:focus-visible {
  background: rgba(176, 60, 42, 0.24);
}

.editor-context-menu__separator {
  display: block;
  height: 1px;
  margin: 6px 4px;
  background: rgba(255, 244, 226, 0.1);
}

body[data-page="editor"] .editor-properties::-webkit-scrollbar,
body[data-page="editor"] .editor-field textarea::-webkit-scrollbar {
  width: 8px;
}

body[data-page="editor"] .editor-properties::-webkit-scrollbar-thumb,
body[data-page="editor"] .editor-field textarea::-webkit-scrollbar-thumb {
  background: rgba(255, 244, 226, 0.2);
  border-radius: 999px;
}

.editor-layer-list__item.is-selected {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  border-color: color-mix(in srgb, var(--accent) 26%, transparent);
}

.editor-layer-list__item.is-drag-target {
  border-color: rgba(255, 216, 154, 0.38);
  box-shadow: inset 0 0 0 1px rgba(255, 216, 154, 0.18);
}

.editor-layer-list__item.is-dragging {
  opacity: 0.55;
}

.editor-layer-list__item--background {
  cursor: pointer;
  opacity: 0.92;
}

.editor-properties {
  min-height: 0;
  overflow: auto;
  padding-inline-end: 4px;
}

.editor-background-hit {
  position: absolute;
  inset: 0;
  z-index: 0;
  border: 0;
  background: transparent;
  padding: 0;
  cursor: pointer;
}

.editor-background-hit.is-selected {
  box-shadow: inset 0 0 0 2px color-mix(in srgb, var(--accent) 90%, transparent);
}

.editor-text-measure {
  position: absolute;
  left: -99999px;
  top: -99999px;
  visibility: hidden;
  pointer-events: none;
  white-space: pre-wrap;
  word-break: break-word;
}

.reader-icon-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  min-height: 30px;
  padding: 2px 8px;
  margin: 0;
  border-radius: 999px;
  border: 0;
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: var(--accent-dark);
  text-decoration: none;
  font-size: max(20px, 0.82rem);
  font-weight: 600;
  cursor: pointer;
  box-shadow: none;
  transition: background 0.18s ease, color 0.18s ease;
}

.reader-icon-button[data-chapter-view-toggle] {
  width: 42px;
  height: 42px;
  min-width: 42px;
  min-height: 42px;
  padding: 0;
  border-radius: 50%;
  gap: 0;
  font-weight: 500;
}

.reader-icon-actions .reader-icon-button:not([href]),
.reader-icon-actions .reader-icon-button[href][aria-label],
.reader-icon-actions .chapter-reader__font-menu-toggle {
  width: 42px;
  height: 42px;
  min-width: 42px;
  min-height: 42px;
  padding: 0;
  border-radius: 50%;
  border: 0;
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  box-shadow: none;
}

.reader-icon-actions .reader-icon-button--reading {
  width: 42px;
  height: 42px;
  min-width: 42px;
  min-height: 42px;
  padding: 0;
  border-radius: 50%;
  line-height: 1;
}

.reader-icon-actions .reader-icon-button--reading svg {
  width: 19px;
  height: 19px;
}

.reader-icon-actions .reader-icon-button--summary svg {
  width: 20px;
  height: 20px;
}

.reader-icon-actions .reader-icon-button:not([href]):hover,
.reader-icon-actions .reader-icon-button:not([href]):focus-visible,
.reader-icon-actions .reader-icon-button[href][aria-label]:hover,
.reader-icon-actions .reader-icon-button[href][aria-label]:focus-visible,
.reader-icon-actions .chapter-reader__font-menu-toggle:hover,
.reader-icon-actions .chapter-reader__font-menu-toggle:focus-visible,
.reader-icon-actions .chapter-reader__text-controls.is-open .chapter-reader__font-menu-toggle {
  background: color-mix(in srgb, var(--accent) 16%, transparent);
}

.reader-icon-actions .reader-icon-button.is-active {
  background: var(--accent);
  color: var(--on-accent);
  border-color: color-mix(in srgb, var(--accent-dark) 60%, transparent);
  box-shadow: 0 4px 12px color-mix(in srgb, var(--accent) 26%, transparent);
}

.reader-icon-actions .reader-icon-button.is-active:hover,
.reader-icon-actions .reader-icon-button.is-active:focus-visible {
  background: var(--accent-dark);
  color: var(--on-accent);
}

.reader-icon-button[data-chapter-view-toggle] .chapter-view-toggle__icon--line {
  display: none;
}

.downloads-hub,
.prayers-page {
  display: grid;
  gap: 18px;
}

.downloads-hub {
  margin-top: 0;
}

.hourly-prayers-page {
  display: grid;
  gap: 22px;
}

.hourly-prayers-page[dir="rtl"] {
  text-align: right;
}

.hourly-prayers-page[dir="rtl"],
.hourly-prayers-admin[dir="rtl"],
.hourly-prayers-admin[dir="rtl"] input,
.hourly-prayers-admin[dir="rtl"] textarea,
.hourly-prayers-admin[dir="rtl"] select {
  font-family: var(--arabic-site-font);
}

.hourly-prayers-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: clamp(16px, 2vw, 26px);
  border-radius: 22px;
}

/* Compact hero variant: smaller title, hour-dial circles inline,
   actions trail at the end. The dial replaces both the prayer-hour
   <select> and the old text-pill .hourly-prayers-tabs row. */
.hourly-prayers-hero--compact {
  flex-wrap: wrap;
  align-items: center;
  gap: clamp(10px, 1.6vw, 18px);
  padding: clamp(12px, 1.6vw, 20px) clamp(14px, 1.8vw, 22px);
}

.hourly-prayers-hero__title {
  margin: 0;
  flex: 0 0 auto;
  font-size: clamp(1.2rem, 1.4vw + 0.6rem, 1.7rem);
  font-weight: 800;
  letter-spacing: -0.005em;
  white-space: nowrap;
  color: var(--ink);
}

.hourly-prayers-hour-dial {
  flex: 1 1 540px;
  min-width: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.hourly-prayers-hour-dial__item {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-width: 84px;
  min-height: 78px;
  padding: 9px 8px;
  border: 1px solid var(--control-border);
  border-radius: 999px;
  background: var(--control-bg);
  color: var(--ink);
  text-decoration: none;
  transition: background-color 140ms ease, border-color 140ms ease, color 140ms ease, transform 140ms ease;
}

.hourly-prayers-hour-dial__item:hover,
.hourly-prayers-hour-dial__item:focus-visible {
  background: color-mix(in srgb, var(--accent) 12%, var(--control-bg));
  border-color: color-mix(in srgb, var(--accent) 40%, var(--control-border));
  color: var(--accent-dark);
  outline: none;
  transform: translateY(-1px);
}

.hourly-prayers-hour-dial__item.is-active {
  background: var(--accent);
  border-color: color-mix(in srgb, var(--accent-dark) 60%, transparent);
  color: var(--on-accent);
  box-shadow: 0 6px 18px color-mix(in srgb, var(--accent) 26%, transparent);
}

.hourly-prayers-hour-dial__glyph {
  width: 36px;
  height: 36px;
  flex: 0 0 36px;
}

.hourly-prayers-hour-dial__label {
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

@media (max-width: 720px) {
  .hourly-prayers-hour-dial__item {
    min-width: 74px;
    min-height: 70px;
    padding: 8px 6px;
  }
  .hourly-prayers-hour-dial__glyph {
    width: 30px;
    height: 30px;
  }
  .hourly-prayers-hour-dial__label {
    font-size: 0.8rem;
  }
}

.hourly-prayers-actions {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex: 0 0 auto;
}

.hourly-prayers-share {
  width: 48px;
  height: 48px;
  padding: 0;
  border-radius: 999px;
}

.hourly-prayers-share svg {
  width: 22px;
  height: 22px;
}

.hourly-prayers-filters {
  flex: 0 1 190px;
  min-width: 180px;
  display: block;
  margin: 0;
  align-items: end;
  padding: 0;
  border-radius: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

.hourly-prayers-filters .field label {
  margin-bottom: 4px;
  font-size: max(16px, 0.72rem);
}

.hourly-prayers-filters .field select {
  min-height: 44px;
  font-size: max(18px, 0.95rem);
}

.hourly-prayers-font-control {
  position: relative;
  z-index: 4;
}

.hourly-prayers-font-toggle {
  position: static;
}

.hourly-prayers-font-popover {
  top: calc(100% + 10px);
  right: 0;
  bottom: auto;
}

.hourly-prayers-font-popover::before {
  top: -8px;
  right: 18px;
  bottom: auto;
  transform: rotate(225deg);
}

[dir="rtl"] .hourly-prayers-font-popover {
  right: auto;
  left: 0;
}

[dir="rtl"] .hourly-prayers-font-popover::before {
  right: auto;
  left: 18px;
}

:root[data-theme] .hourly-prayers-font-popover {
  background: var(--surface);
  border-color: var(--border-soft);
  color: var(--ink);
  box-shadow: 0 22px 56px var(--surface-shadow);
}

:root[data-theme] .hourly-prayers-font-popover::before {
  background: var(--surface);
  border-color: var(--border-soft);
}

:root[data-theme] .hourly-prayers-font-popover .chapter-reader__font-popover-header strong,
:root[data-theme] .hourly-prayers-font-popover .chapter-reader__font-size-value,
:root[data-theme] .hourly-prayers-font-popover .chapter-reader__font-stepper,
:root[data-theme] .hourly-prayers-font-popover .chapter-reader__font-row-label {
  color: var(--ink);
}

:root[data-theme] .hourly-prayers-font-popover .chapter-reader__font-popover-header span {
  color: var(--muted);
}

:root[data-theme] .hourly-prayers-font-popover .chapter-reader__font-stepper-group,
:root[data-theme] .hourly-prayers-font-popover .chapter-reader__font-stepper {
  background: var(--control-bg);
  border-color: var(--control-border);
}

.hourly-prayers-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.hourly-prayers-tab {
  display: inline-flex;
  align-items: center;
  min-height: 46px;
  padding: 10px 16px;
  border: 1px solid var(--control-border);
  border-radius: 999px;
  background: var(--control-bg);
  color: var(--ink);
  text-decoration: none;
  box-shadow: 0 10px 24px var(--surface-shadow);
}

.hourly-prayers-tab:hover,
.hourly-prayers-tab:focus-visible,
.hourly-prayers-tab.is-active {
  background: color-mix(in srgb, var(--accent) 18%, var(--control-bg));
  border-color: color-mix(in srgb, var(--accent) 50%, var(--control-border));
  color: var(--accent-dark);
}

.hourly-prayer-book-shell {
  display: grid;
  grid-template-columns: minmax(190px, 0.26fr) minmax(0, 1fr);
  align-items: start;
  gap: clamp(16px, 2.6vw, 32px);
}

.hourly-prayer-index {
  position: sticky;
  top: 96px;
  display: grid;
  gap: 12px;
  max-height: calc(100vh - 128px);
  overflow: auto;
  overscroll-behavior: contain;
  scrollbar-width: thin;
  scrollbar-color: color-mix(in srgb, var(--accent) 55%, var(--border-soft)) color-mix(in srgb, var(--surface-strong) 86%, transparent);
  padding: 16px;
  border: 1px solid var(--border-soft);
  border-radius: 22px;
  background: var(--surface);
  color: var(--ink);
  box-shadow: 0 14px 34px var(--surface-shadow);
}

.hourly-prayer-index::-webkit-scrollbar {
  width: 10px;
}

.hourly-prayer-index::-webkit-scrollbar-track {
  background: color-mix(in srgb, var(--surface-strong) 86%, transparent);
  border-radius: 999px;
}

.hourly-prayer-index::-webkit-scrollbar-thumb {
  background: color-mix(in srgb, var(--accent) 55%, var(--border-soft));
  border: 2px solid color-mix(in srgb, var(--surface) 86%, transparent);
  border-radius: 999px;
}

.hourly-prayer-index::-webkit-scrollbar-thumb:hover {
  background: color-mix(in srgb, var(--accent) 72%, var(--border-soft));
}

.hourly-prayer-index strong {
  font-size: max(20px, 0.92rem);
  color: var(--accent-dark);
}

.hourly-prayer-index ol {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.hourly-prayer-index a {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 9px;
  padding: 10px 12px;
  border-radius: 16px;
  color: var(--ink);
  text-decoration: none;
  font-size: max(20px, 0.9rem);
  line-height: 1.25;
}

.hourly-prayer-index a span:first-child {
  min-width: 30px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: var(--control-bg);
  color: var(--accent-dark);
  font-weight: 800;
}

.hourly-prayer-index a:hover,
.hourly-prayer-index a:focus-visible,
.hourly-prayer-index a.is-active {
  background: color-mix(in srgb, var(--accent) 14%, var(--surface));
  outline: none;
}

.hourly-prayer-index a.is-active span:first-child {
  background: var(--accent);
  color: var(--on-accent);
}

/* Misc prayers index: each link is a stacked title + subtitle so
   prayers that share the same canonical title (e.g. two "صلاة قبل
   التناول" with different first lines) read as distinct entries. */
.misc-prayer-index a {
  grid-template-columns: 1fr;
  align-items: start;
  gap: 2px;
}

.misc-prayer-index__title {
  font-weight: 700;
  color: var(--ink);
}

.misc-prayer-index__subtitle {
  font-size: 0.82rem;
  color: var(--muted-strong);
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.hourly-prayer-reader {
  display: grid;
  gap: 18px;
  padding: clamp(18px, 3vw, 32px);
  border: 1px solid var(--border-soft);
  border-radius: 28px;
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--surface-strong) 74%, transparent), transparent 9%, transparent 91%, color-mix(in srgb, var(--surface-strong) 74%, transparent)),
    repeating-linear-gradient(180deg, color-mix(in srgb, var(--accent) 4%, transparent) 0 1px, transparent 1px 32px),
    var(--surface);
  color: var(--ink);
  box-shadow: 0 18px 42px var(--surface-shadow);
  font-family: var(--hourly-text-family, Georgia, "Times New Roman", serif);
}

.hourly-prayer-reader[dir="rtl"] {
  font-family: var(--hourly-text-family, "Amiri", "Noto Naskh Arabic", "Scheherazade New", "Traditional Arabic", serif);
  line-height: 2.22;
}

.hourly-prayer-reader__header {
  display: grid;
  gap: 8px;
}

.hourly-prayer-reader__header h2 {
  margin: 0;
  font-size: clamp(2rem, 4vw, 3.5rem);
}

.hourly-prayer-reader__header p,
.hourly-prayer-entry__description {
  color: var(--muted);
}

.hourly-prayer-reader__entries {
  display: grid;
  gap: 18px;
}

.hourly-prayer-entry {
  display: grid;
  gap: 12px;
  padding: clamp(16px, 2.5vw, 28px);
  border: 1px solid var(--border-soft);
  border-radius: 24px;
  background: color-mix(in srgb, var(--surface-strong) 82%, transparent);
  scroll-margin-top: 110px;
}

.hourly-prayer-entry h3 {
  margin: 0;
  color: var(--accent-dark);
  font-size: clamp(1.3rem, 2.4vw, 2rem);
}

.hourly-prayer-entry p {
  margin: 0;
  font-size: var(--hourly-text-size, clamp(1.15rem, 2vw, 1.42rem));
  line-height: 1.85;
}

.hourly-prayer-reader[dir="rtl"] .hourly-prayer-entry p {
  line-height: 2.22;
}

@media (max-width: 880px) {
  .hourly-prayers-hero {
    align-items: start;
  }

  .hourly-prayer-book-shell {
    grid-template-columns: 1fr;
  }

  .hourly-prayer-index {
    position: static;
    max-height: none;
  }

  .hourly-prayer-index ol {
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  }
}

@media (max-width: 760px) {
  .hourly-prayer-index {
    display: none;
  }
}

.downloads-tabs {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(145px, 1fr));
  gap: 10px;
}

.downloads-tab {
  display: grid;
  gap: 4px;
  min-height: 84px;
  padding: 14px;
  border: 1px solid rgba(93, 65, 39, 0.16);
  border-radius: 18px;
  background: linear-gradient(145deg, rgba(255, 251, 244, 0.98), rgba(245, 230, 211, 0.84));
  color: var(--ink);
  text-align: start;
  box-shadow: 0 12px 28px rgba(60, 42, 25, 0.08);
  cursor: pointer;
}

.downloads-tab span {
  font-family: var(--display-font);
  font-size: max(20px, 1rem);
  font-weight: 800;
}

.downloads-tab small {
  color: var(--muted);
  font-size: max(15px, 0.75rem);
  line-height: 1.35;
}

.downloads-tab.is-active {
  border-color: color-mix(in srgb, var(--accent) 52%, transparent);
  background: linear-gradient(145deg, rgba(255, 244, 227, 1), rgba(238, 207, 169, 0.92));
  color: var(--accent-dark);
}

.downloads-filter-panel {
  display: none;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 12px;
  width: 100%;
  padding: clamp(14px, 1.8vw, 22px);
  border-radius: 22px;
  box-sizing: border-box;
}

.downloads-filter-panel.is-active {
  display: grid;
}

.downloads-filter-panel--simple {
  grid-template-columns: 1fr;
  align-content: center;
  color: var(--muted);
}

.downloads-filter-panel--database {
  color: var(--ink);
}

.database-downloads-summary {
  display: flex;
  gap: 16px;
  align-items: center;
  justify-content: space-between;
  min-width: 0;
}

.database-downloads-summary strong {
  display: block;
  color: var(--ink);
  font-family: var(--display-font);
  font-size: max(22px, 1.1rem);
}

.database-downloads-summary p {
  max-width: 76ch;
  margin: 5px 0 0;
  color: color-mix(in srgb, var(--ink) 72%, transparent);
  line-height: 1.45;
}

.database-downloads-summary__link {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 16px;
  border: 1px solid color-mix(in srgb, var(--accent-dark) 22%, transparent);
  border-radius: 999px;
  background: var(--accent-dark);
  color: #fffaf4;
  font-weight: 800;
  text-decoration: none;
}

.downloads-search-field {
  min-width: min(360px, 100%);
}

.downloads-tag-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: end;
}

.downloads-tag-filter__item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 10px;
  border: 1px solid rgba(93, 65, 39, 0.14);
  border-radius: 999px;
  background: rgba(255, 250, 243, 0.78);
  color: var(--ink);
  font-size: max(15px, 0.75rem);
}

.downloads-grid {
  display: grid;
  grid-template-columns: repeat(var(--downloads-masonry-columns, 4), minmax(0, 1fr));
  gap: 14px;
}

.media-feed-grid.downloads-grid {
  columns: unset;
  column-gap: 14px;
}

.downloads-masonry-column {
  display: grid;
  align-content: start;
  gap: 14px;
  min-width: 0;
}

.downloads-card {
  display: grid;
  width: 100%;
  margin: 0;
  min-width: 0;
}

.downloads-card__preview {
  position: relative;
  display: grid;
  place-items: center;
  overflow: hidden;
  min-height: 190px;
  background: radial-gradient(circle at top, rgba(255, 255, 255, 0.96), rgba(237, 219, 196, 0.62));
}

.downloads-card--image {
  padding: 8px;
  margin: 0;
}

.downloads-card--image .downloads-card__preview {
  min-height: 0;
  border-radius: 14px;
}

.downloads-card__preview img,
.downloads-card__preview video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.downloads-card--image .downloads-card__preview img {
  display: block;
  height: auto;
  object-fit: contain;
}

.downloads-card--video .downloads-card__preview {
  cursor: pointer;
}

.downloads-card--image .downloads-card__preview[role="button"] {
  cursor: zoom-in;
}

.downloads-card__download {
  position: absolute;
  inset-block-start: 8px;
  inset-inline-end: 8px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 7px 10px;
  border: 1px solid rgba(255, 255, 255, 0.78);
  border-radius: 999px;
  background: rgba(54, 38, 23, 0.78);
  color: #fffaf4;
  font-size: max(15px, 0.72rem);
  font-weight: 800;
  text-decoration: none;
  box-shadow: 0 10px 24px rgba(38, 24, 10, 0.22);
  backdrop-filter: blur(8px);
}

.downloads-card__editor {
  position: absolute;
  inset-block-start: 8px;
  inset-inline-start: 8px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  max-width: calc(100% - 116px);
  padding: 7px 10px;
  border: 1px solid rgba(255, 255, 255, 0.78);
  border-radius: 999px;
  background: rgba(255, 250, 244, 0.9);
  color: var(--accent-dark);
  font-size: max(15px, 0.72rem);
  font-weight: 800;
  text-decoration: none;
  box-shadow: 0 10px 24px rgba(38, 24, 10, 0.18);
  backdrop-filter: blur(8px);
}

.downloads-card__placeholder {
  color: var(--muted);
  font-size: max(18px, 0.85rem);
}

.downloads-card__meta strong {
  display: block;
  color: var(--ink);
  font-family: var(--display-font);
  font-size: max(20px, 1rem);
}

.downloads-card--database {
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
  gap: 12px;
  padding: 14px;
  border-radius: 18px;
  background: #fffdfa;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  box-shadow: 0 16px 34px rgba(60, 42, 25, 0.08);
}

.database-download-card__badge {
  display: grid;
  place-items: center;
  width: 62px;
  min-height: 62px;
  padding: 8px;
  border-radius: 14px;
  background: #245c63;
  color: #fffaf4;
  font-size: max(14px, 0.72rem);
  font-weight: 900;
  line-height: 1.05;
  text-align: center;
  text-transform: uppercase;
}

.database-download-card__body {
  display: grid;
  gap: 7px;
  min-width: 0;
}

.database-download-card__title {
  margin: 0;
  color: var(--ink);
  font-family: var(--display-font);
  font-size: max(20px, 1rem);
  line-height: 1.12;
  overflow-wrap: anywhere;
}

.database-download-card__subtitle,
.database-download-card__meta {
  margin: 0;
  color: color-mix(in srgb, var(--ink) 68%, transparent);
  font-size: max(16px, 0.78rem);
  line-height: 1.35;
}

.database-download-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-top: 4px;
}

.database-download-card__download {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  background: var(--accent);
  color: #fffaf4;
  font-weight: 900;
  text-decoration: none;
  box-shadow: 0 10px 20px color-mix(in srgb, var(--accent) 18%, transparent);
}

.database-download-card__download:hover,
.database-download-card__download:focus-visible,
.database-downloads-summary__link:hover,
.database-downloads-summary__link:focus-visible {
  color: #fffaf4;
  filter: brightness(0.95);
}

.database-download-card__file {
  color: color-mix(in srgb, var(--ink) 50%, transparent);
  font-size: max(14px, 0.7rem);
  line-height: 1.3;
  overflow-wrap: anywhere;
}

@media (max-width: 620px) {
  .database-downloads-summary {
    align-items: stretch;
    flex-direction: column;
  }

  .database-downloads-summary__link {
    width: 100%;
  }

  .downloads-card--database {
    grid-template-columns: 1fr;
  }

  .database-download-card__badge {
    width: auto;
    min-height: 0;
    justify-self: start;
    padding: 7px 10px;
    border-radius: 999px;
  }
}

.downloads-card--audio {
  display: block;
  padding: 0;
  border-radius: 22px;
  background: linear-gradient(145deg, rgba(255, 250, 243, 0.96), rgba(240, 224, 202, 0.86));
  border: 1px solid rgba(93, 65, 39, 0.14);
  box-shadow: 0 16px 36px rgba(60, 42, 25, 0.08);
  transition: border-color 180ms ease, box-shadow 180ms ease, transform 180ms ease;
}

.downloads-card--audio.is-playing {
  border-color: color-mix(in srgb, var(--accent) 42%, transparent);
  box-shadow: 0 18px 44px color-mix(in srgb, var(--accent) 18%, transparent);
  transform: translateY(-1px);
}

.downloads-audio-player {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 14px;
}

.downloads-audio-player__play {
  width: 54px;
  height: 54px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 999px;
  background: var(--accent);
  color: #fffaf4;
  box-shadow: 0 12px 24px color-mix(in srgb, var(--accent) 22%, transparent);
  cursor: pointer;
}

.downloads-audio-player__play svg {
  width: 24px;
  height: 24px;
  fill: currentColor;
}

.downloads-audio-player__body {
  display: grid;
  gap: 7px;
  min-width: 0;
}

.downloads-audio-player__body strong {
  overflow: hidden;
  color: var(--ink);
  font-family: var(--display-font);
  font-size: max(20px, 1.02rem);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.downloads-audio-player__body > span,
.downloads-audio-player__time {
  color: color-mix(in srgb, var(--ink) 62%, transparent);
  font-size: max(18px, 0.82rem);
}

.downloads-audio-waveform {
  width: 100%;
  height: 48px;
  display: flex;
  align-items: center;
  gap: 3px;
  padding: 6px 8px;
  border: 1px solid rgba(93, 65, 39, 0.12);
  border-radius: 16px;
  background: rgba(255, 250, 243, 0.8);
  cursor: pointer;
  overflow: hidden;
}

.downloads-audio-waveform__bar {
  flex: 1 1 0;
  height: var(--bar-height, 42%);
  min-width: 2px;
  border-radius: 999px;
  background: rgba(93, 65, 39, 0.22);
  transition: background 140ms ease, opacity 140ms ease, transform 140ms ease;
}

.downloads-audio-waveform__bar.is-played {
  background: linear-gradient(180deg, var(--accent), #b86120);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 6%, transparent);
}

.downloads-audio-waveform:hover .downloads-audio-waveform__bar {
  opacity: 0.9;
}

.downloads-audio-waveform:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--accent) 28%, transparent);
  outline-offset: 3px;
}

.downloads-audio-player__footer {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
}

.downloads-audio-player__download {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  min-height: 36px;
  padding: 8px 12px;
  border: 1px solid color-mix(in srgb, var(--accent) 42%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: var(--accent-dark);
  font-size: 0.86rem;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
}

.downloads-audio-player__download svg {
  width: 17px;
  height: 17px;
  flex: 0 0 auto;
  fill: currentColor;
}

.downloads-audio-player__download:hover,
.downloads-audio-player__download:focus-visible {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  border-color: color-mix(in srgb, var(--accent) 58%, transparent);
  color: var(--accent-dark);
  outline: none;
}

body.has-downloads-player {
  padding-bottom: 124px;
}

.downloads-now-playing {
  position: fixed;
  inset-inline: max(14px, env(safe-area-inset-left)) max(14px, env(safe-area-inset-right));
  inset-block-end: max(14px, env(safe-area-inset-bottom));
  z-index: 1150;
  display: grid;
  grid-template-columns: 54px minmax(170px, 1.1fr) minmax(220px, 2fr) auto minmax(90px, 0.4fr) auto 42px 42px;
  gap: 12px;
  align-items: center;
  padding: 12px;
  border: 1px solid rgba(93, 65, 39, 0.16);
  border-radius: 26px;
  background: rgba(255, 250, 243, 0.96);
  box-shadow: 0 22px 70px rgba(38, 24, 10, 0.26);
  backdrop-filter: blur(14px);
  transform: translateY(14px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms ease, transform 180ms ease;
}

.downloads-now-playing.is-visible {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}

.downloads-now-playing__play,
.downloads-now-playing__collapse,
.downloads-now-playing__close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 999px;
  cursor: pointer;
}

.downloads-now-playing__play {
  width: 54px;
  height: 54px;
  background: var(--accent);
  color: #fffaf4;
  box-shadow: 0 12px 24px color-mix(in srgb, var(--accent) 22%, transparent);
}

.downloads-now-playing__close {
  width: 42px;
  height: 42px;
  background: rgba(93, 65, 39, 0.08);
  color: var(--ink);
}

.downloads-now-playing__collapse {
  width: 42px;
  height: 42px;
  background: rgba(93, 65, 39, 0.08);
  color: var(--ink);
}

.downloads-now-playing__play svg,
.downloads-now-playing__collapse svg,
.downloads-now-playing__close svg {
  width: 22px;
  height: 22px;
  fill: currentColor;
}

.downloads-now-playing__meta {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.downloads-now-playing__meta strong {
  overflow: hidden;
  color: var(--ink);
  font-family: var(--display-font);
  font-size: max(20px, 1rem);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.downloads-now-playing__meta span,
.downloads-now-playing__time {
  overflow: hidden;
  color: color-mix(in srgb, var(--ink) 62%, transparent);
  font-size: max(18px, 0.82rem);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.downloads-audio-waveform--footer {
  height: 54px;
  background: rgba(255, 255, 255, 0.58);
}

.downloads-now-playing__volume input {
  width: 100%;
  accent-color: var(--accent);
}

.downloads-now-playing__download {
  color: var(--accent-dark);
  font-size: max(18px, 0.82rem);
  font-weight: 800;
  text-decoration: none;
  white-space: nowrap;
}

@media (max-width: 980px) {
  body.has-downloads-player {
    padding-bottom: 190px;
  }

  .downloads-now-playing {
    grid-template-columns: 48px 1fr 40px 40px;
    gap: 10px;
  }

  .downloads-now-playing__play {
    width: 48px;
    height: 48px;
  }

  .downloads-now-playing__collapse,
  .downloads-now-playing__close {
    width: 40px;
    height: 40px;
  }

  .downloads-now-playing__meta,
  .downloads-audio-waveform--footer,
  .downloads-now-playing__time,
  .downloads-now-playing__volume,
  .downloads-now-playing__download {
    grid-column: 1 / -1;
  }
}

body.has-site-audio-resume:not(.reader-movie-open):not(.reader-movie-pip-open) {
  padding-bottom: 0;
}

body.has-downloads-player.has-site-audio-resume:not(.reader-movie-open):not(.reader-movie-pip-open) {
  padding-bottom: 124px;
}

.site-audio-resume {
  position: fixed;
  inset-inline-end: max(18px, env(safe-area-inset-right));
  inset-block-end: max(18px, env(safe-area-inset-bottom));
  z-index: 1160;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) 32px 32px;
  gap: 8px;
  align-items: center;
  width: min(380px, calc(100vw - 24px));
  padding: 8px;
  border: 1px solid rgba(93, 65, 39, 0.16);
  border-radius: 14px;
  background: rgba(255, 250, 243, 0.97);
  color: var(--ink);
  box-shadow: 0 14px 34px rgba(38, 24, 10, 0.16);
  backdrop-filter: blur(10px);
  transform: translateY(12px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms ease, transform 180ms ease;
}

.site-audio-resume.is-expanded {
  grid-template-rows: auto auto;
}

.site-audio-resume[hidden],
body.has-downloads-player .site-audio-resume,
body.reader-movie-open .site-audio-resume,
body.reader-movie-pip-open .site-audio-resume {
  display: none;
}

.site-audio-resume.is-visible {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}

html[dir="rtl"] .site-audio-resume {
  inset-inline-end: auto;
  inset-inline-start: max(18px, env(safe-area-inset-left));
  direction: rtl;
}

.site-audio-resume__play,
.site-audio-resume__expand,
.site-audio-resume__close {
  display: inline-grid;
  place-items: center;
  border: 0;
  border-radius: 999px;
  cursor: pointer;
}

.site-audio-resume__play {
  width: 42px;
  height: 42px;
  background: var(--accent);
  color: #fffaf4;
  box-shadow: 0 12px 24px color-mix(in srgb, var(--accent) 22%, transparent);
}

.site-audio-resume__close {
  width: 32px;
  height: 32px;
  background: rgba(93, 65, 39, 0.08);
  color: var(--ink);
}

.site-audio-resume__expand {
  width: 32px;
  height: 32px;
  background: rgba(93, 65, 39, 0.08);
  color: var(--ink);
}

.site-audio-resume__play svg,
.site-audio-resume__expand svg,
.site-audio-resume__close svg {
  width: 19px;
  height: 19px;
}

.site-audio-resume__meta {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.site-audio-resume__eyebrow {
  color: rgba(93, 65, 39, 0.58);
  font-size: 0.86rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

.site-audio-resume__meta strong,
.site-audio-resume__meta span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.site-audio-resume__meta strong {
  font-family: var(--display-font);
  font-size: 1.18rem;
  line-height: 1.05;
}

.site-audio-resume__meta span {
  color: color-mix(in srgb, var(--ink) 62%, transparent);
  font-size: 0.98rem;
  line-height: 1.15;
}

.site-audio-resume__meta .site-audio-resume__eyebrow {
  color: rgba(93, 65, 39, 0.58);
  font-size: 0.86rem;
}

.site-audio-resume__progress-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 7px;
  align-items: center;
}

.site-audio-resume__seek {
  width: 100%;
  height: 14px;
  appearance: none;
  -webkit-appearance: none;
  background: transparent !important;
  background-color: transparent !important;
  cursor: pointer;
  direction: ltr;
  unicode-bidi: isolate;
}

.site-audio-resume__seek::-webkit-slider-runnable-track {
  height: 5px;
  border-radius: 999px;
  background:
    linear-gradient(90deg, var(--accent), var(--accent-dark)) 0 / var(--audio-resume-progress, 0%) 100% no-repeat,
    rgba(93, 65, 39, 0.16);
  background-position: left center;
}

.site-audio-resume__seek::-moz-range-track {
  height: 5px;
  border-radius: 999px;
  background: rgba(93, 65, 39, 0.16);
}

.site-audio-resume__seek::-moz-range-progress {
  height: 5px;
  border-radius: 999px;
  background: var(--accent);
}

.site-audio-resume__seek::-webkit-slider-thumb {
  width: 14px;
  height: 14px;
  margin-top: -4.5px;
  border: 0;
  border-radius: 999px;
  appearance: none;
  -webkit-appearance: none;
  background: var(--accent-dark);
}

.site-audio-resume__seek::-moz-range-thumb {
  width: 14px;
  height: 14px;
  border: 0;
  border-radius: 999px;
  background: var(--accent-dark);
}

.site-audio-resume__tools {
  grid-column: 1 / -1;
  padding: 4px 6px 2px;
}

.site-audio-resume__tools[hidden] {
  display: none;
}

.site-audio-resume__volume {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  color: color-mix(in srgb, var(--ink) 68%, transparent);
  font-size: 0.9rem;
  font-weight: 800;
}

.site-audio-resume__volume input[type="range"] {
  width: 100%;
  accent-color: var(--accent);
}

.site-video-resume,
.site-movie-resume {
  position: fixed;
  inset-inline-end: max(18px, env(safe-area-inset-right));
  inset-block-end: max(18px, env(safe-area-inset-bottom));
  z-index: 1162;
  background: color-mix(in srgb, var(--surface, #fffdfa) 94%, transparent);
  border: 1px solid var(--border-soft, rgba(93, 65, 39, 0.14));
  border-radius: 14px;
  box-shadow: 0 14px 34px rgba(42, 28, 16, 0.16);
  color: var(--ink, #1f1d1a);
}

.site-video-resume[hidden] {
  display: none;
}

.site-video-resume {
  width: min(282px, calc(100vw - 24px));
  display: grid;
  grid-template-columns: minmax(0, 1fr) 38px;
  gap: 7px;
  padding: 8px;
}

.site-video-resume__video {
  grid-column: 1 / -1;
  width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: 10px;
  background: #080604;
}

.site-video-resume__meta {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.site-video-resume__meta span,
.site-video-resume__meta small,
.site-movie-resume__meta span {
  color: var(--muted, color-mix(in srgb, var(--ink) 62%, transparent));
  font-size: 0.98rem;
  line-height: 1.15;
}

.site-video-resume__meta strong,
.site-movie-resume__meta strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-family: var(--display-font);
  font-size: 1.16rem;
  line-height: 1.06;
}

.site-video-resume__play,
.site-video-resume__close,
.site-movie-resume__play,
.site-movie-resume__close {
  display: inline-grid;
  place-items: center;
  border: 0;
  border-radius: 999px;
  cursor: pointer;
}

.site-video-resume__play {
  width: 38px;
  height: 38px;
  background: var(--accent);
  color: var(--on-accent, #fffaf4);
}

.site-video-resume__close,
.site-movie-resume__close {
  position: absolute;
  inset-block-start: 8px;
  inset-inline-end: 8px;
  width: 28px;
  height: 28px;
  background: rgba(93, 65, 39, 0.12);
  color: var(--ink, #1f1d1a);
}

.site-video-resume__play svg,
.site-video-resume__close svg {
  width: 18px;
  height: 18px;
}

.site-movie-resume {
  width: min(264px, calc(100vw - 24px));
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  padding: 9px 42px 9px 10px;
}

.site-movie-resume__play {
  min-height: 36px;
  padding: 0 12px;
  background: var(--accent);
  color: var(--on-accent, #fffaf4);
  font-weight: 800;
  font-size: 0.98rem;
}

.site-movie-resume__meta {
  min-width: 0;
  display: grid;
  gap: 2px;
}

html[dir="rtl"] .site-video-resume,
html[dir="rtl"] .site-movie-resume {
  inset-inline-end: auto;
  inset-inline-start: max(18px, env(safe-area-inset-left));
  direction: rtl;
}

body.has-site-audio-resume .site-video-resume,
body.has-site-audio-resume .site-movie-resume {
  inset-block-end: calc(max(18px, env(safe-area-inset-bottom)) + 118px);
}

body.has-site-video-resume .site-movie-resume {
  inset-block-end: calc(max(18px, env(safe-area-inset-bottom)) + 300px);
}

@media (max-width: 640px) {
  .site-audio-resume {
    inset-inline: max(12px, env(safe-area-inset-left)) max(12px, env(safe-area-inset-right));
    width: auto;
    grid-template-columns: 48px minmax(0, 1fr) 36px 36px;
  }

  .site-audio-resume__expand,
  .site-audio-resume__close {
    width: 32px;
    height: 32px;
  }

  html[dir="rtl"] .site-audio-resume {
    inset-inline: max(12px, env(safe-area-inset-left)) max(12px, env(safe-area-inset-right));
  }
}

@media (max-width: 980px) {
  body.has-downloads-player.has-site-audio-resume:not(.reader-movie-open):not(.reader-movie-pip-open) {
    padding-bottom: 190px;
  }
}

.reading-continue-toast {
  position: fixed;
  /* fixed already creates a containing block for the absolute close
     button, but we add isolation so any future stacking-context
     changes inside the toast don't push the close out of the corner. */
  isolation: isolate;
  inset-inline-end: max(14px, env(safe-area-inset-right));
  inset-block-end: max(14px, env(safe-area-inset-bottom));
  z-index: 1100;
  display: grid;
  gap: 6px;
  width: min(250px, calc(100vw - 24px));
  /* Logical padding: end-side gets the 44px reservation for the X
     button so it works in both LTR and RTL without a separate dir
     override. */
  padding-block: 9px;
  padding-inline-start: 10px;
  padding-inline-end: 34px;
  border: 1px solid var(--border-soft);
  border-radius: 10px;
  background: color-mix(in srgb, var(--surface) 94%, transparent);
  color: var(--ink);
  box-shadow: 0 12px 28px var(--surface-shadow);
  backdrop-filter: blur(8px);
}

[dir="rtl"] .reading-continue-toast {
  inset-inline-end: auto;
  inset-inline-start: max(14px, env(safe-area-inset-left));
}

.reading-continue-toast__content {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.reading-continue-toast strong {
  font-family: var(--display-font);
  font-size: 1.16rem;
  line-height: 1.05;
}

.reading-continue-toast span {
  color: var(--muted);
  font-size: 0.98rem;
  line-height: 1.16;
}

.reading-continue-toast__close {
  position: absolute;
  inset-block-start: 6px;
  /* Use inset-inline-end alone — it auto-swaps to the visual right in
     LTR and visual left in RTL, so we don't need a separate RTL rule
     and it can't disagree with the LTR positioning. */
  inset-inline-end: 6px;
  display: inline-grid;
  place-items: center;
  width: 24px;
  height: 24px;
  padding: 0;
  border: 1px solid var(--border-soft);
  border-radius: 999px;
  background: var(--control-bg);
  color: var(--muted-strong);
  cursor: pointer;
  z-index: 1;
}

.reading-continue-toast__close svg {
  width: 14px;
  height: 14px;
}

.reading-continue-toast__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.reading-continue-toast__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 5px 10px;
  border: 1px solid color-mix(in srgb, var(--accent) 70%, var(--border-soft));
  border-radius: 999px;
  background: var(--accent);
  color: var(--on-accent);
  font-weight: 800;
  font-size: 0.98rem;
  text-decoration: none;
}

.reading-continue-toast__button--ghost {
  background: var(--control-bg);
  border-color: var(--border-soft);
  color: var(--muted-strong);
}

@media (max-width: 520px) {
  .reading-continue-toast,
  .site-video-resume,
  .site-movie-resume {
    inset-inline: max(10px, env(safe-area-inset-left)) max(10px, env(safe-area-inset-right));
    width: auto;
  }

  [dir="rtl"] .reading-continue-toast,
  html[dir="rtl"] .site-video-resume,
  html[dir="rtl"] .site-movie-resume {
    inset-inline: max(10px, env(safe-area-inset-left)) max(10px, env(safe-area-inset-right));
  }
}

@media (max-width: 980px) {
  .downloads-grid {
    grid-template-columns: repeat(var(--downloads-masonry-columns, 3), minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .downloads-grid {
    grid-template-columns: repeat(var(--downloads-masonry-columns, 2), minmax(0, 1fr));
  }
}

.prayers-filters,
.downloads-filters {
  align-items: end;
}

.prayers-grid--single-language {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
}

.prayer-card--typed {
  display: grid;
  gap: 14px;
  padding: 16px;
  border: 1px solid rgba(93, 65, 39, 0.14);
  border-radius: 24px;
  background: rgba(255, 250, 243, 0.92);
  box-shadow: 0 16px 36px rgba(60, 42, 25, 0.08);
}

.prayer-card--image-grid {
  position: relative;
  min-height: 320px;
  overflow: hidden;
  padding: 0;
  aspect-ratio: 1;
  background: rgba(238, 224, 204, 0.82);
}

.prayer-card__toolbar {
  position: absolute;
  z-index: 2;
  inset-block-start: 12px;
  inset-inline: 12px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  pointer-events: none;
}

.prayer-card__zip {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  border-radius: 999px;
  padding: 7px 12px;
  background: rgba(255, 250, 243, 0.9);
  color: var(--accent-dark);
  font-size: max(20px, 0.8rem);
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  box-shadow: 0 10px 22px rgba(42, 31, 19, 0.16);
  backdrop-filter: blur(10px);
}

.prayer-card__zip {
  pointer-events: auto;
}

.prayer-card__zip:hover {
  background: var(--accent);
  color: #fffaf3;
}

.prayer-card__meta {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  color: var(--accent-dark);
  font-size: max(15px, 0.75rem);
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.prayer-card__lines {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.prayer-card__lines p {
  margin: 0;
  font-size: max(20px, 1rem);
  line-height: 1.7;
}

.prayer-card__thumbs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.prayer-card__mosaic {
  width: 100%;
  height: 100%;
  gap: 0;
}

.prayer-card__thumb {
  position: relative;
  display: block;
  overflow: hidden;
  aspect-ratio: 1;
  border-radius: 14px;
  background: rgba(238, 224, 204, 0.82);
}

.prayer-card__mosaic .prayer-card__thumb {
  min-width: 0;
  min-height: 0;
  border-radius: 0;
}

.prayer-card__mosaic .prayer-card__thumb[data-prayer-quadrant="1"] {
  grid-column: 1;
  grid-row: 1;
}

.prayer-card__mosaic .prayer-card__thumb[data-prayer-quadrant="2"] {
  grid-column: 2;
  grid-row: 1;
}

.prayer-card__mosaic .prayer-card__thumb[data-prayer-quadrant="3"] {
  grid-column: 1;
  grid-row: 2;
}

.prayer-card__mosaic .prayer-card__thumb[data-prayer-quadrant="4"] {
  grid-column: 2;
  grid-row: 2;
}

[dir="rtl"] .prayer-card__mosaic .prayer-card__thumb[data-prayer-quadrant="1"] {
  grid-column: 2;
  grid-row: 1;
}

[dir="rtl"] .prayer-card__mosaic .prayer-card__thumb[data-prayer-quadrant="2"] {
  grid-column: 1;
  grid-row: 1;
}

[dir="rtl"] .prayer-card__mosaic .prayer-card__thumb[data-prayer-quadrant="3"] {
  grid-column: 2;
  grid-row: 2;
}

[dir="rtl"] .prayer-card__mosaic .prayer-card__thumb[data-prayer-quadrant="4"] {
  grid-column: 1;
  grid-row: 2;
}

.prayer-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 180ms ease;
}

.prayer-card__thumb:hover img {
  transform: scale(1.025);
}

.prayer-card__thumb span {
  position: absolute;
  inset-block-start: 6px;
  inset-inline-start: 6px;
  display: inline-grid;
  place-items: center;
  min-width: 24px;
  height: 24px;
  border-radius: 999px;
  background: rgba(255, 250, 243, 0.92);
  color: var(--accent-dark);
  font-size: 13px;
  font-weight: 800;
}

@media (max-width: 720px) {
  .downloads-tabs {
    grid-template-columns: 1fr 1fr;
  }

  .downloads-tab {
    min-height: 72px;
    padding: 12px;
  }

  .downloads-tab small {
    display: none;
  }

  .prayer-card__thumbs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.reader-icon-button[data-chapter-view-toggle].is-active .chapter-view-toggle__icon--compact {
  display: none;
}

.reader-icon-button[data-chapter-view-toggle].is-active .chapter-view-toggle__icon--line {
  display: block;
}

.reader-icon-button svg,
.share-popup__link svg {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
}

.reader-icon-button:hover,
.reader-icon-button:focus-visible {
  background: color-mix(in srgb, var(--accent) 16%, transparent);
}

.reader-icon-button.product-gallery__edit-button:hover,
.reader-icon-button.product-gallery__edit-button:focus-visible {
  background: rgba(255, 250, 243, 1);
  border-color: color-mix(in srgb, var(--accent) 28%, transparent);
  box-shadow: 0 14px 28px color-mix(in srgb, var(--ink) 16%, transparent);
  color: var(--accent-dark);
}

.product-gallery__expand-button svg {
  width: 18px;
  height: 18px;
}

.reader-icon-button:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent) 22%, transparent);
  outline-offset: 2px;
}

.product-gallery {
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
  flex: 1 1 auto;
  min-height: 0;
}

.product-gallery__thumbs {
  display: grid;
  gap: 10px;
  max-height: 520px;
  overflow: auto;
  padding-inline-end: 4px;
}

.product-gallery__thumb {
  padding: 0;
  border: 1px solid color-mix(in srgb, var(--ink) 10%, transparent);
  border-radius: 16px;
  background: var(--control-bg-strong);
  cursor: pointer;
  box-shadow: 0 8px 16px color-mix(in srgb, var(--ink) 5%, transparent);
}

.product-gallery__thumb.is-selected {
  border-color: color-mix(in srgb, var(--accent) 45%, transparent);
  box-shadow: 0 12px 24px color-mix(in srgb, var(--accent) 12%, transparent);
}

.product-gallery__thumb img {
  width: 100%;
  display: block;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.product-gallery__stage {
  min-width: 0;
  min-height: 0;
}

.chapter-reader__media-gallery {
  flex: 1 1 auto;
  min-height: 0;
}

.product-gallery__main {
  display: block;
  border-radius: 22px;
  overflow: hidden;
  background: linear-gradient(180deg, #f7f1e8 0%, #f3eadc 100%);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  box-shadow: 0 14px 30px color-mix(in srgb, var(--ink) 8%, transparent);
}

.product-gallery__main img {
  width: 100%;
  display: block;
  aspect-ratio: 4 / 5;
  object-fit: cover;
}

.chapter-reader__media-gallery .product-gallery {
  height: 100%;
}

.chapter-reader__media-gallery .product-gallery__stage {
  display: flex;
  min-height: 0;
}

.chapter-reader__media-gallery .product-gallery__main {
  height: 100%;
}

.video-gallery {
  display: grid;
  gap: 12px;
}

.video-gallery__item {
  display: grid;
  gap: 10px;
}

.video-gallery__item video {
  width: 100%;
  border-radius: 18px;
  background: #120f0a;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  box-shadow: 0 12px 24px color-mix(in srgb, var(--ink) 8%, transparent);
}

.video-gallery__actions {
  justify-content: flex-end;
}

.share-popup {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  background: color-mix(in srgb, var(--ink) 26%, transparent);
  z-index: 40;
}

.share-popup.is-open {
  display: flex;
}

.share-popup__panel {
  width: min(520px, 92vw);
  display: grid;
  gap: 18px;
  padding: 24px;
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(255, 250, 244, 0.98), rgba(247, 241, 232, 0.98));
  border: 1px solid color-mix(in srgb, var(--ink) 10%, transparent);
  box-shadow: 0 28px 64px color-mix(in srgb, var(--ink) 20%, transparent);
}

.share-popup__panel h3 {
  margin: 0;
  font-size: 1.35rem;
}

.share-popup__close {
  justify-self: end;
  width: 48px;
  height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: color-mix(in srgb, var(--ink) 6%, transparent);
  color: var(--ink);
  font: inherit;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
}

.share-popup__links {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}

.share-popup__modes {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  padding: 6px;
  border: 1px solid var(--control-border);
  border-radius: 999px;
  background: var(--control-bg);
}

.share-popup__modes[hidden] {
  display: none;
}

.share-popup__mode {
  min-height: 42px;
  border: 1px solid transparent;
  border-radius: 999px;
  background: transparent;
  color: var(--ink);
  font-weight: 800;
  cursor: pointer;
}

.share-popup__mode:hover,
.share-popup__mode:focus-visible,
.share-popup__mode.is-active {
  background: color-mix(in srgb, var(--accent) 18%, var(--control-bg));
  border-color: color-mix(in srgb, var(--accent) 42%, var(--control-border));
  color: var(--accent-dark);
  outline: none;
}

.share-popup__link {
  display: inline-grid;
  grid-template-rows: 52px auto;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-width: 76px;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--accent-dark);
  text-decoration: none;
  font: inherit;
  cursor: pointer;
  transition: transform 0.18s ease;
}

.share-popup__link:hover,
.share-popup__link:focus-visible {
  transform: translateY(-1px);
}

.share-popup__icon {
  width: 52px;
  height: 52px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 11%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent) 18%, transparent);
  box-shadow: 0 12px 24px color-mix(in srgb, var(--accent) 8%, transparent);
}

.share-popup__icon svg {
  width: 22px;
  height: 22px;
}

.share-popup__label {
  font-size: max(20px, 0.86rem);
  line-height: 1.1;
  text-align: center;
  color: color-mix(in srgb, var(--ink) 78%, transparent);
}

.image-lightbox {
  position: fixed;
  inset: 0;
  z-index: 31;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  background: color-mix(in srgb, var(--ink) 42%, transparent);
  backdrop-filter: blur(10px);
}

.image-lightbox.is-open {
  display: flex;
}

.image-lightbox__panel {
  width: min(960px, 94vw);
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 28px;
  background: var(--control-bg-strong);
  border: 1px solid color-mix(in srgb, var(--ink) 10%, transparent);
  box-shadow: 0 24px 60px color-mix(in srgb, var(--ink) 26%, transparent);
}

.image-lightbox__topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.image-lightbox__actions {
  min-width: 0;
}

.image-lightbox__close {
  width: 52px;
  height: 52px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: color-mix(in srgb, var(--ink) 6%, transparent);
  color: var(--ink);
  font: inherit;
  font-size: 2rem;
  line-height: 1;
  cursor: pointer;
}

.image-lightbox__frame {
  border-radius: 22px;
  overflow: hidden;
  background: linear-gradient(180deg, #f7f1e8 0%, #f3eadc 100%);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
}

.image-lightbox__frame img {
  width: 100%;
  max-height: 78vh;
  display: block;
  object-fit: contain;
}

.image-lightbox__gallery {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  padding: 10px;
}

.image-lightbox__gallery[hidden] {
  display: none;
}

.image-lightbox__gallery-item {
  display: grid;
  min-height: 0;
  overflow: hidden;
  border-radius: 16px;
  background: color-mix(in srgb, var(--ink) 6%, transparent);
}

.image-lightbox__gallery-item img {
  width: 100%;
  height: min(36vh, 360px);
  display: block;
  object-fit: contain;
}

.video-lightbox__panel {
  width: min(1120px, 94vw);
}

.video-lightbox__frame {
  display: grid;
  place-items: center;
  background: #15110d;
}

.video-lightbox__frame video {
  width: 100%;
  max-height: 78vh;
  display: block;
  background: #000;
}

.image-lightbox__caption {
  margin: 0;
  color: color-mix(in srgb, var(--ink) 72%, transparent);
  text-align: center;
}

.bible-browser__hero {
  display: block;
  padding: 10px 16px;
  border-radius: 24px;
}

.bible-browser__hero--reader-sidebar {
  display: none;
}

.bible-browser__hero-bar {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
  min-height: 50px;
}

.bible-browser__hero-summary {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.bible-browser__hero.is-expanded .bible-browser__hero-summary {
  display: none;
}

.bible-browser__hero-summary > span {
  display: inline-flex;
  align-items: center;
}

.bible-browser__hero-summary > span:not(:last-child)::after {
  content: "•";
  margin-inline-start: 10px;
  color: color-mix(in srgb, var(--ink) 30%, transparent);
}

.bible-browser__hero-bible {
  font-weight: 700;
}

.bible-browser__hero-book,
.bible-browser__hero-chapter {
  color: color-mix(in srgb, var(--ink) 72%, transparent);
}

.bible-browser__navigator {
  justify-content: flex-start;
  margin: 0;
}

.bible-browser__navigator-shell {
  min-width: 0;
}

.bible-browser__navigator-shell-compact {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(247, 241, 232, 0.96);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  color: color-mix(in srgb, var(--ink) 72%, transparent);
  overflow: hidden;
}

.bible-browser__navigator-shell-title {
  font-weight: 600;
  color: var(--ink);
}

.bible-browser__navigator-shell-range {
  padding: 4px 10px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 11%, transparent);
  color: var(--accent-dark);
  font-size: max(20px, 0.82rem);
}

.bible-browser__navigator-panel {
  display: grid;
  gap: 10px;
  padding-top: 8px;
}

.bible-browser__navigator-shell.is-collapsed .bible-browser__navigator-panel {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-top: 0;
}

.bible-browser__navigator-toggle {
  width: 42px;
  height: 42px;
  justify-content: center;
  padding: 0;
  border-radius: 999px;
}

.bible-browser__navigator-toggle svg {
  width: 20px;
  height: 20px;
  transition: transform 0.18s ease;
}

.bible-browser__navigator-shell:not(.is-collapsed) + .bible-browser__navigator-toggle svg {
  transform: rotate(180deg);
}

.bible-browser__navigator-reading {
  margin: 0;
  color: color-mix(in srgb, var(--ink) 64%, transparent);
  font-size: max(20px, 0.86rem);
}

.bible-browser__navigator-shell.is-collapsed .bible-browser__navigator-shell-compact {
  display: none;
}

.bible-browser__navigator-shell.is-collapsed .bible-browser__navigator {
  flex-wrap: nowrap;
  align-items: center;
  gap: 10px;
}

.bible-browser__navigator-shell.is-collapsed .bible-browser__nav-group {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex: none;
  min-width: 0;
}

.bible-browser__navigator-shell.is-collapsed .bible-browser__nav-group label {
  margin: 0;
  white-space: nowrap;
}

.bible-browser__navigator-shell.is-collapsed .bible-browser__nav-group select {
  min-height: 36px;
  width: auto;
  min-width: 120px;
}

.bible-browser__navigator-shell.is-collapsed .bible-browser__navigator-reading {
  display: none;
}

.bible-browser__navigator-shell-compact {
  display: none;
}

.bible-browser__hero-summary > * {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}

.bible-browser__hero-summary > *:not(:last-child)::after {
  content: "•";
  margin-inline-start: 10px;
  color: color-mix(in srgb, var(--ink) 30%, transparent);
}

.bible-browser__hero-bible,
.bible-browser__hero-book,
.bible-browser__hero-chapter {
  text-decoration: none;
}

.bible-browser__hero-bible {
  color: var(--ink);
}

.bible-browser__navigator-shell:not(.is-collapsed) .bible-browser__navigator {
  justify-content: center;
  margin: 0 auto;
}

.bible-browser__navigator-shell.is-collapsed .bible-browser__navigator-panel {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-top: 0;
}

.bible-browser__navigator-shell:not(.is-collapsed) .bible-browser__navigator-panel {
  display: grid !important;
  gap: 14px;
  padding-top: 8px;
}

.bible-browser__navigator-shell:not(.is-collapsed) .bible-browser__intro {
  display: grid;
  gap: 6px;
  justify-items: center;
  text-align: center;
}

.bible-browser__navigator-shell.is-collapsed .bible-browser__intro {
  display: none;
}

.product-gallery__thumb {
  position: relative;
}

.product-gallery__video-thumb {
  position: relative;
  display: block;
}

.product-gallery__video-thumb video {
  width: 100%;
  display: block;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  background: #1a1713;
}

.product-gallery__thumb-play {
  position: absolute;
  inset: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, 0.9);
  pointer-events: none;
}

.product-gallery__thumb-play svg {
  width: 22px;
  height: 22px;
  filter: drop-shadow(0 6px 16px rgba(0, 0, 0, 0.25));
}

.product-gallery__main {
  position: relative;
}

.product-gallery__edit-button {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 4;
  gap: 8px;
  min-height: 38px;
  max-width: calc(100% - 28px);
  padding: 6px 12px;
  background: rgba(255, 250, 243, 0.94);
  border-color: color-mix(in srgb, var(--ink) 10%, transparent);
  box-shadow: 0 10px 24px color-mix(in srgb, var(--ink) 12%, transparent);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.product-gallery__edit-button svg {
  width: 17px;
  height: 17px;
}

.product-gallery__edit-button span {
  overflow: hidden;
  text-overflow: ellipsis;
}

.product-gallery__edit-button.is-hidden {
  display: none;
}

.product-gallery__delete-button {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 5;
  min-width: 42px;
  min-height: 42px;
  padding: 0;
  background: rgba(255, 247, 242, 0.94);
  border-color: rgba(170, 55, 38, 0.22);
  color: #9a2d22;
  box-shadow: 0 10px 24px color-mix(in srgb, var(--ink) 12%, transparent);
}

.product-gallery__delete-button:hover,
.product-gallery__delete-button:focus-visible {
  background: rgba(170, 55, 38, 0.14);
  border-color: rgba(170, 55, 38, 0.32);
  color: #7f2118;
}

.product-gallery__delete-button[hidden] {
  display: none;
}

.product-gallery__description {
  position: absolute;
  inset-inline: 0;
  bottom: 0;
  min-height: 25%;
  display: flex;
  align-items: flex-end;
  margin: 0;
  padding: 18px;
  color: #fffaf2;
  background: linear-gradient(180deg, rgba(12, 10, 8, 0), rgba(12, 10, 8, 0.76));
  font-size: clamp(1rem, 1.8vw, 1.18rem);
  line-height: 1.42;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.55);
  pointer-events: none;
  z-index: 3;
}

.product-gallery__description[hidden] {
  display: none;
}

.downloads-card__preview {
  position: relative;
}

.downloads-card__description {
  position: absolute;
  inset-inline: 0;
  bottom: 0;
  min-height: 25%;
  display: flex;
  align-items: flex-end;
  margin: 0;
  padding: 14px;
  color: #fffaf2;
  background: linear-gradient(180deg, rgba(12, 10, 8, 0), rgba(12, 10, 8, 0.76));
  font-size: max(20px, 0.92rem);
  line-height: 1.35;
  pointer-events: none;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.55);
  z-index: 3;
}

.image-lightbox__edit {
  width: auto !important;
  height: 42px !important;
  min-width: 42px !important;
  max-width: min(280px, 46vw);
  gap: 8px;
  padding: 0 14px !important;
  border-radius: 0 !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.image-lightbox__edit svg {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
}

.image-lightbox__edit span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: max(20px, 0.95rem);
  font-weight: 700;
}

.image-lightbox__delete {
  background: rgba(170, 55, 38, 0.12) !important;
  border-color: rgba(170, 55, 38, 0.24) !important;
  color: #8d271f !important;
}

.image-lightbox__delete[hidden] {
  display: none;
}

@media (max-width: 560px) {
  .image-lightbox__edit {
    width: 42px !important;
    max-width: 42px;
    padding: 0 !important;
  }

  .image-lightbox__edit span {
    display: none;
  }
}

.product-gallery__main video {
  width: 100%;
  display: block;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  background: #1a1713;
}

.product-gallery__stage-play {
  position: absolute;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, 0.94);
  pointer-events: none;
}

.product-gallery__stage-play.is-visible {
  display: inline-flex;
}

.product-gallery__stage-play svg {
  width: 50px;
  height: 50px;
  padding: 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.18);
  border: 1px solid rgba(255, 255, 255, 0.5);
  filter: drop-shadow(0 14px 30px rgba(0, 0, 0, 0.26));
}

body.gallery-modal-open {
  overflow: hidden;
}

body.reader-summary-modal-open {
  overflow: hidden;
}

.reader-summary-modal {
  position: fixed;
  inset: 0;
  z-index: 1500;
  display: none;
  background: color-mix(in srgb, var(--surface, #fffdfa) 94%, transparent);
  color: var(--ink, #1f1d1a);
}

.reader-summary-modal.is-open {
  display: block;
}

.reader-summary-modal__panel {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  width: 100%;
  height: 100%;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface, #fffdfa) 98%, transparent), color-mix(in srgb, var(--paper, #fff7eb) 96%, transparent));
}

.reader-summary-modal__bar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: max(14px, env(safe-area-inset-top)) max(18px, env(safe-area-inset-right)) 14px max(18px, env(safe-area-inset-left));
  border-bottom: 1px solid var(--border-soft, rgba(93, 65, 39, 0.14));
  background: color-mix(in srgb, var(--surface, #fffdfa) 96%, transparent);
}

.reader-summary-modal__title-wrap {
  min-width: 0;
}

.reader-summary-modal__title-wrap span {
  display: block;
  color: var(--muted, color-mix(in srgb, var(--ink) 62%, transparent));
  font-size: 0.86rem;
  font-weight: 800;
}

.reader-summary-modal__title-wrap h2 {
  margin: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-family: var(--display-font);
  font-size: 1.6rem;
  line-height: 1.1;
}

.reader-summary-modal__controls {
  display: inline-flex;
  gap: 8px;
  align-items: center;
}

.reader-summary-modal__controls button,
.reader-summary-modal__controls output {
  display: inline-grid;
  place-items: center;
  min-width: 42px;
  min-height: 38px;
  padding: 0 10px;
  border: 1px solid color-mix(in srgb, var(--accent) 36%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: var(--accent-dark);
  font-weight: 800;
}

.reader-summary-modal__controls output {
  min-width: 64px;
  background: transparent;
}

.reader-summary-modal__close {
  font-size: 1.5rem;
  line-height: 1;
}

.reader-summary-modal__body {
  min-height: 0;
  overflow: auto;
  padding: clamp(18px, 3vw, 34px);
}

.reader-summary-modal__content {
  width: min(860px, 100%);
  margin: 0 auto;
  color: color-mix(in srgb, var(--ink, #1f1d1a) 92%, transparent);
  font-family: var(--reader-font-family, var(--display-font));
  font-size: var(--reader-summary-font-size, 24px);
  line-height: 1.72;
  white-space: pre-wrap;
}

.reader-summary-modal__content[dir="rtl"] {
  text-align: right;
}

@media (max-width: 720px) {
  .reader-summary-modal__bar {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .reader-summary-modal__controls {
    width: 100%;
    flex-wrap: wrap;
    justify-content: flex-start;
  }

  .reader-summary-modal__title-wrap h2 {
    white-space: normal;
  }
}

.gallery-modal {
  position: fixed;
  inset: 0;
  z-index: 12000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 28px;
  background:
    radial-gradient(circle at 20% 12%, rgba(255, 242, 214, 0.28), transparent 34%),
    rgba(31, 27, 22, 0.54);
  backdrop-filter: blur(12px);
}

.gallery-modal.is-open {
  display: flex;
}

.gallery-modal__panel {
  width: min(1240px, 96vw);
  height: min(880px, 92vh);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 14px;
  padding: 18px;
  border-radius: 30px;
  border: 1px solid rgba(255, 245, 228, 0.28);
  background: linear-gradient(180deg, rgba(255, 250, 242, 0.98), rgba(246, 236, 221, 0.98));
  box-shadow: 0 30px 90px rgba(13, 11, 9, 0.34);
}

.gallery-modal__topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.gallery-modal__title {
  margin: 0;
  color: var(--ink);
  font-size: clamp(1.6rem, 2vw, 2.35rem);
  line-height: 1.05;
}

.gallery-modal__close {
  width: 48px;
  height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
  color: color-mix(in srgb, var(--ink) 70%, transparent);
  font-size: 1.7rem;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 10px 24px color-mix(in srgb, var(--ink) 10%, transparent);
}

.gallery-modal__close:hover,
.gallery-modal__close:focus-visible {
  background: #fffaf2;
  color: var(--accent-dark);
  transform: translateY(-1px);
}

.gallery-modal__body {
  min-width: 0;
  min-height: 0;
}

.gallery-modal .product-gallery {
  height: 100%;
  grid-template-columns: minmax(86px, 120px) minmax(0, 1fr);
  align-items: stretch;
}

.gallery-modal .product-gallery__thumbs {
  max-height: none;
  min-height: 0;
  overflow: auto;
  padding-inline-end: 6px;
}

.gallery-modal .product-gallery__stage {
  display: flex;
  min-width: 0;
  min-height: 0;
}

.gallery-modal .product-gallery__main {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 24px;
}

.gallery-modal .product-gallery__main img,
.gallery-modal .product-gallery__main video {
  width: 100%;
  height: 100%;
  max-height: none;
  aspect-ratio: auto;
  object-fit: contain;
  background: #181512;
}

.gallery-modal .product-gallery__edit-button {
  top: 16px;
  right: 16px;
}

@media (max-width: 760px) {
  .gallery-modal {
    padding: 14px;
  }

  .gallery-modal__panel {
    width: min(100%, 96vw);
    height: 92vh;
    padding: 14px;
    border-radius: 24px;
  }

  .gallery-modal .product-gallery {
    grid-template-columns: 1fr;
    grid-template-rows: auto minmax(0, 1fr);
  }

  .gallery-modal .product-gallery__thumbs {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 72px;
    overflow: auto hidden;
    padding: 0 0 4px;
  }
}

.chapter-reader__reference {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 8px;
}

.chapter-reader__reference a {
  color: inherit;
  text-decoration: none;
}

.chapter-reader__reference-separator {
  color: color-mix(in srgb, var(--ink) 38%, transparent);
}

.share-popup__header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 14px;
}

.share-popup__eyebrow {
  margin: 0 0 4px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: max(20px, 0.74rem);
  color: color-mix(in srgb, var(--ink) 52%, transparent);
}

.share-popup__summary {
  margin: 0;
  color: color-mix(in srgb, var(--ink) 66%, transparent);
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.share-popup__copy {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 46px;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  border-radius: 16px;
  background: var(--control-bg-strong);
  color: var(--accent-dark);
  font: inherit;
  font-weight: 600;
  cursor: pointer;
}

.share-popup__copy-icon {
  width: 18px;
  height: 18px;
  display: inline-flex;
}

:root[data-theme] .share-popup__panel {
  background: var(--surface);
  color: var(--ink);
}

:root[data-theme] .share-popup__panel h3,
:root[data-theme] .share-popup__link,
:root[data-theme] .share-popup__close,
:root[data-theme] .share-popup__copy {
  color: var(--ink);
}

:root[data-theme] .share-popup__eyebrow,
:root[data-theme] .share-popup__summary,
:root[data-theme] .share-popup__label {
  color: var(--muted);
}

:root[data-theme] .share-popup__close,
:root[data-theme] .share-popup__copy,
:root[data-theme] .share-popup__icon {
  background: var(--control-bg);
  border-color: var(--control-border);
}

.empty-state {
  padding: 20px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.6);
  border: 1px dashed color-mix(in srgb, var(--ink) 20%, transparent);
}

@keyframes fadeSlide {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes rise {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* @media (max-width: 1600px) {
  :root {
    --viewport-zoom: 0.9;
  }

  .shell,
  .content {
    width: 95%;
  }

  .site-header .shell {
    padding: 16px 0;
    padding-inline: 18px;
    gap: 14px;
    flex-wrap: nowrap;
  }

  .logo {
    font-size: 1.08rem;
    letter-spacing: 0.04em;
  }

  .header-search {
    flex: 1 1 280px;
    min-width: 0;
    max-width: 360px;
    margin-inline-start: 32px;
    padding-inline: 18px 10px;
  }

  .nav {
    flex: 1 1 auto;
    min-width: 0;
    gap: 10px;
    font-size: max(20px, 0.92rem);
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none;
  }

  .nav::-webkit-scrollbar {
    display: none;
  }

  .nav a,
  .nav-user {
    white-space: nowrap;
    flex: 0 0 auto;
  }

  .content {
    padding: 10px 0 20px;
  }

  .bible-browser__hero--reader-top {
    display: none;
  }

  .bible-browser__hero--reader-sidebar {
    display: block;
  }

  .bible-browser__hero--reader-sidebar.is-expanded {
    width: min(100%, 380px);
    margin-inline-start: auto;
    padding: 16px 18px;
  }

  .bible-browser__hero--reader-sidebar.is-expanded .bible-browser__hero-bar--expanded {
    gap: 14px;
  }

  .bible-browser__hero--reader-sidebar.is-expanded .bible-browser__intro {
    justify-items: start;
    text-align: start;
  }

  .bible-browser__hero--reader-sidebar.is-expanded .bible-browser__intro h1 {
    font-size: clamp(1.7rem, 1.7vw, 2rem);
    line-height: 1.02;
  }

  .bible-browser__hero--reader-sidebar.is-expanded .bible-browser__intro p {
    font-size: max(20px, 1rem);
    line-height: 1.45;
  }

  .bible-browser__hero--reader-sidebar.is-expanded .bible-browser__navigator--expanded {
    display: grid !important;
    grid-template-columns: 1fr;
    justify-content: stretch;
    gap: 10px;
  }

  .bible-browser__hero--reader-sidebar.is-expanded .bible-browser__navigator--expanded .bible-browser__nav-group {
    flex: none;
    min-width: 0;
  }

  .bible-browser__hero--reader-sidebar.is-expanded .bible-browser__navigator--expanded .bible-browser__nav-group label {
    white-space: nowrap;
  }

  .bible-browser__hero.is-expanded {
    padding: 15px 20px;
  }

  .chapter-reader {
    grid-template-columns: minmax(0, 1.6fr) minmax(240px, 340px);
    gap: 20px;
    align-items: stretch;
  }

  .chapter-reader__main,
  .chapter-reader__media {
    align-self: stretch;
    min-height: 0;
  }

  .chapter-reader {
    height: auto;
    min-height: 0;
  }

  .chapter-reader__main {
    display: flex;
    min-width: 0;
    min-height: 0;
    height: auto;
  }

  .chapter-reader__media,
  .chapter-reader__media-sticky {
    height: auto;
  }

  .chapter-reader__media-sticky {
    position: static;
    top: auto;
    height: auto;
    max-height: none;
    overflow: visible;
  }

  .chapter-reader__sheet {
    flex: 1 1 auto;
    height: auto;
    min-height: 0;
    max-height: min(calc(100vh - 136px), 820px);
  }
} */

.grecaptcha-badge,
.rc-anchor.rc-anchor-invisible.rc-anchor-light.rc-anchor-invisible-hover {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

@media (max-width: 999px) {
  .chapter-reader {
    grid-template-columns: 1fr;
  }

  .chapter-reader__media {
    position: static;
    order: 2;
    max-height: none;
  }

  .chapter-reader__main {
    order: 1;
  }

  .chapter-reader__sheet {
    min-height: auto;
    max-height: none;
    padding: 24px 18px;
  }

  .chapter-reader__verses {
    overflow: visible;
    padding-inline-end: 0;
  }

  .chapter-reader__actions {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .site-header .shell {
    flex-wrap: wrap;
    gap: 10px;
    padding: 12px 0;
  }

  .logo {
    order: 1;
  }

  .site-header .viewport-zoom-controls {
    order: 2;
    margin-inline-start: auto;
  }

  .site-notification-center__menu {
    inset-inline-start: 0;
    inset-inline-end: auto;
  }

  html[dir="rtl"] .site-notification-center__menu {
    inset-inline-start: auto;
    inset-inline-end: 0;
  }

  .header-search {
    order: 4;
    flex: 1 1 100%;
    width: 100%;
    max-width: none;
  }

  .nav {
    order: 5;
    flex: 1 1 100%;
    width: 100%;
    max-width: 100%;
    justify-content: flex-start;
  }

  html[dir="rtl"] .nav {
    justify-content: flex-end;
  }

  .nav-auth {
    order: 3;
  }
}

@media (max-width: 640px) {
  .site-notification-center__menu {
    position: fixed;
    inset-inline: 12px;
    top: 124px;
    width: auto;
    max-height: calc(100vh - 144px);
    overflow: auto;
  }

  html[dir="rtl"] .site-notification-center__menu {
    inset-inline: 12px;
  }

  .site-notification-center__actions {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .site-header .shell {
    flex-wrap: wrap;
  }
  .logo {
    order: 1;
  }
  .site-header .viewport-zoom-controls {
    order: 2;
    margin-inline-start: auto;
  }
  .chapter-reader__selection-rail {
    inset-inline-start: 6px;
    gap: 2px;
    max-width: calc(100vw - 12px);
    padding: 2px;
  }
  .chapter-reader__verse-state-button {
    width: 26px;
    height: 26px;
  }
  .chapter-reader__verse-state-button--labeled {
    width: auto;
    gap: 3px;
    padding-inline: 5px 6px;
    font-size: max(12px, 0.62rem);
  }
  .header-search {
    order: 4;
    width: 100%;
    max-width: none;
  }
  .nav {
    order: 5;
    gap: 16px;
    font-size: 1.2rem;
    width: 100%;
    justify-content: center;
  }
  .nav-auth {
    order: 3;
  }
  .site-footer .shell {
    flex-direction: column;
    align-items: flex-start;
    padding: 18px 20px;
  }
  .hero-search-card {
    order: -1;
  }
  .hero-search-form {
    flex-direction: column;
    align-items: stretch;
    border-radius: 24px;
  }
  .hero-search-form .btn {
    width: 100%;
  }
  .primary-destination-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
  }
  .search-results-top {
    position: static;
    padding: 16px;
  }
  .search-results-top__content {
    flex-direction: column;
    align-items: stretch;
  }
  .search-bible-picker {
    flex-basis: auto;
  }
  .search-media-grid {
    grid-template-columns: 1fr;
  }
  .search-media-grid--images {
    columns: 1 100%;
  }
  .advanced-search-toggle {
    align-self: flex-start;
  }
  .advanced-search-grid {
    grid-template-columns: 1fr;
  }
  .search-page--narrow {
    width: 100%;
  }
  .search-results-shell {
    grid-template-columns: 1fr;
    gap: 22px;
  }
  .bible-browser__navigator {
    justify-content: stretch;
  }
  .chapter-reader {
    grid-template-columns: 1fr;
  }
  .chapter-reader__media {
    position: static;
    order: 2;
    max-height: none;
  }
  .chapter-reader__main {
    order: 1;
  }
  .chapter-reader__sheet {
    min-height: auto;
    max-height: none;
    padding: 24px 18px;
  }
  .chapter-reader__verses {
    overflow: visible;
    padding-inline-end: 0;
  }
  .chapter-reader__actions {
    grid-template-columns: 1fr;
  }
  .search-results-meta {
    position: static;
  }
  .reader-topbar {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }
  .reader-bottom {
    display: block;
    position: fixed;
    inset-inline: 0;
    bottom: 0;
    padding: 12px 16px;
    background: rgba(248, 244, 238, 0.96);
    border-top: 1px solid color-mix(in srgb, var(--ink) 12%, transparent);
    z-index: 20;
  }
  .reader-bottom-inner {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
    justify-content: space-between;
  }
  .reader-bottom-label {
    font-weight: 600;
  }
  .reader-panel {
    padding-bottom: 96px;
  }
  .compare-tabs {
    display: flex;
  }
  .compare-grid {
    grid-template-columns: 1fr;
  }
  .media-feed-grid {
    grid-template-columns: 1fr;
  }
  .product-gallery {
    grid-template-columns: 1fr;
  }
  .product-gallery__thumbs {
    grid-template-columns: repeat(auto-fit, minmax(64px, 1fr));
    grid-auto-flow: column;
    max-height: none;
    overflow: auto hidden;
    padding-inline-end: 0;
  }
  .chapter-reader__sheet-header,
  .verse-media-card__header {
    align-items: start;
    flex-direction: column;
  }
  .share-popup__links {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 560px) {
  .primary-destination-cards {
    grid-template-columns: 1fr;
  }
  .destination-card {
    min-height: 320px;
    padding: 28px;
  }
  .destination-card__image-wrap {
    min-height: 150px;
  }
}

[dir="rtl"] .site-header .shell {
  flex-direction: row;
}

[dir="rtl"] .nav {
  flex-direction: row-reverse;
}

[dir="rtl"] .header-search {
  flex-direction: row-reverse;
}

[hidden] {
  display: none !important;
}

.nav,
.site-footer,
.site-footer span,
.site-footer .build-indicator,
.hero-card__lead,
.hero-search-copy p,
.search-engine-result__meta,
.search-engine-result__url,
.search-results-side__card,
.search-results-side__card p,
.search-results-side__count,
.search-form-advanced label,
.reader-settings-button,
.reader-settings-popup,
.reader-settings-popup label,
.feed-links,
.feed-item__meta,
.book-card__meta,
.chapter-card__meta,
.bible-browser__nav-group label,
.bible-browser__nav-group select,
.bible-browser__navigator-reading,
.bible-browser__navigator-shell-range,
.share-popup__label,
.share-popup__eyebrow,
.chapter-reader__subtitle,
.chapter-reader__reference-separator {
  font-size: 1.2rem !important;
}

.bible-browser__hero-summary > span,
.bible-browser__hero-summary > a {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}

.bible-browser__hero-summary > span:not(:last-child)::after,
.bible-browser__hero-summary > a:not(:last-child)::after {
  content: "•";
  margin-inline-start: 10px;
  color: color-mix(in srgb, var(--ink) 30%, transparent);
}

.bible-browser__hero-range {
  color: color-mix(in srgb, var(--ink) 72%, transparent);
}

.bible-browser__navigator-shell.is-collapsed .bible-browser__navigator {
  display: flex !important;
  flex-wrap: nowrap;
  align-items: center;
  gap: 10px;
}

.bible-browser__navigator-shell.is-collapsed .bible-browser__navigator-panel {
  display: flex !important;
  align-items: center;
  gap: 12px;
  padding-top: 0;
}

.bible-browser__navigator-shell.is-collapsed .bible-browser__nav-group {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  flex: none;
  min-width: 0;
}

.bible-browser__navigator-shell.is-collapsed .bible-browser__nav-group label {
  display: inline-flex;
  margin: 0;
  white-space: nowrap;
}

.bible-browser__navigator-shell.is-collapsed .bible-browser__nav-group select {
  width: auto;
  min-width: 120px;
  min-height: 36px;
}

.bible-browser__navigator-shell:not(.is-collapsed) .bible-browser__navigator {
  display: flex !important;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  width: 100%;
  margin: 0 auto;
}

.bible-browser__navigator-shell:not(.is-collapsed) .bible-browser__nav-group {
  display: grid !important;
  gap: 5px;
  flex: 0 1 220px;
  min-width: min(220px, 100%);
}

.bible-browser__navigator-shell:not(.is-collapsed) .bible-browser__nav-group label {
  margin: 0;
  white-space: normal;
}

.bible-browser__navigator-shell:not(.is-collapsed) .bible-browser__nav-group select {
  width: 100%;
  min-height: 42px;
}

.product-gallery__main {
  display: grid;
}

.product-gallery__main img,
.product-gallery__main video {
  grid-area: 1 / 1;
}

.product-gallery__stage-play {
  grid-area: 1 / 1;
}

.chapter-reader__verse-anchor {
  vertical-align: top;
}

.chapter-reader__verse-text {
  display: inline;
}

.chapter-reader__lead-dropcap {
  margin-inline-end: 8px;
  margin-top: 0;
}

.chapter-reader__lead-prefix {
  display: none;
}

.chapter-reader__lead-dropcap {
  margin-inline-end: 0;
  margin-top: 0;
}

.bible-browser__hero.is-collapsed .bible-browser__hero-bar--expanded {
  display: none;
}

.bible-browser__hero.is-expanded .bible-browser__hero-bar--compact {
  display: none;
}

.bible-browser__hero.is-expanded .bible-browser__hero-bar--expanded {
  display: grid;
  gap: 18px;
}

.bible-browser__hero-bar--expanded .bible-browser__intro {
  display: grid;
  gap: 6px;
  justify-items: center;
  text-align: center;
}

.bible-browser__hero-bar--expanded .bible-browser__navigator {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
}

.bible-browser__hero-bar--expanded .bible-browser__nav-group {
  display: grid;
  gap: 5px;
  flex: 0 1 220px;
  min-width: min(220px, 100%);
}

.bible-browser__hero-bar--compact .bible-browser__navigator {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 10px;
}

.bible-browser__hero-bar--compact .bible-browser__nav-group {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex: none;
  min-width: 0;
}

.bible-browser__hero-bar--compact .bible-browser__nav-group label {
  margin: 0;
  white-space: nowrap;
}

.bible-browser__hero-bar--compact .bible-browser__nav-group select {
  width: auto;
  min-width: 120px;
  min-height: 36px;
}

.book-card,
.chapter-card {
  overflow: hidden;
}

.book-card__image,
.chapter-card__image {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.book-card__preload,
.chapter-card__preload {
  display: none;
}

.product-gallery__thumbs {
  max-height: 370px;
}

.product-gallery__stage-play svg {
  width: 68px;
  height: 68px;
  padding: 16px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.2);
  border: 1px solid rgba(255, 255, 255, 0.55);
}

[dir="rtl"] .hero-search-form {
  flex-direction: row-reverse;
}

@media (max-width: 720px) {
  [dir="rtl"] .hero-search-form {
    flex-direction: column;
  }
}

/* Final bible hero and gallery overrides */
.bible-browser__hero.is-collapsed .bible-browser__hero-bar--expanded {
  display: none !important;
}

.bible-browser__hero.is-expanded .bible-browser__hero-bar--compact {
  display: none !important;
}

.bible-browser__hero.is-collapsed .bible-browser__hero-bar--compact {
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 18px;
  min-height: 56px;
}

.bible-browser__hero.is-collapsed .bible-browser__hero-summary {
  display: inline-flex;
  align-items: center;
  gap: 0;
  min-width: 0;
  white-space: nowrap;
}

.bible-browser__hero.is-collapsed .bible-browser__hero-summary > span,
.bible-browser__hero.is-collapsed .bible-browser__hero-summary > a {
  display: inline-flex;
  align-items: center;
  font-size: 1.35rem;
  text-decoration: none;
}

.bible-browser__hero.is-collapsed .bible-browser__hero-summary > *:not(:last-child)::after {
  content: "/";
  margin: 0 12px;
  color: color-mix(in srgb, var(--ink) 34%, transparent);
}

.bible-browser__hero.is-collapsed .bible-browser__navigator-shell {
  width: 100%;
  min-width: 0;
}

.bible-browser__hero.is-collapsed .bible-browser__navigator-panel--compact {
  display: block !important;
}

.bible-browser__hero.is-collapsed .bible-browser__navigator--compact {
  display: flex !important;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: center;
  gap: 12px;
  min-width: 0;
}

.bible-browser__hero.is-collapsed .bible-browser__nav-group {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  flex: none;
  min-width: 0;
}

.bible-browser__hero.is-collapsed .bible-browser__nav-group label {
  margin: 0;
  white-space: nowrap;
}

.bible-browser__hero.is-collapsed .bible-browser__nav-group select {
  width: auto;
  min-width: 120px;
  min-height: 38px;
}

.bible-browser__hero.is-expanded .bible-browser__hero-bar--expanded {
  display: grid !important;
  gap: 18px;
}

.bible-browser__hero.is-expanded {
  padding: 10px 30px;
}

.bible-browser__hero.is-expanded .bible-browser__intro {
  display: grid !important;
  gap: 6px;
  justify-items: center;
  text-align: center;
}

.bible-browser__hero.is-expanded .bible-browser__navigator--expanded {
  display: flex !important;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
}

.bible-browser__hero.is-expanded .bible-browser__navigator--expanded .bible-browser__nav-group {
  display: grid !important;
  gap: 5px;
  flex: 0 1 220px;
  min-width: min(220px, 100%);
}

.bible-browser__hero.is-expanded .bible-browser__navigator--expanded .bible-browser__nav-group label {
  margin: 0;
  white-space: normal;
}

.bible-browser__hero.is-expanded .bible-browser__navigator--expanded .bible-browser__nav-group select {
  width: 100%;
  min-height: 42px;
}

.bible-browser__hero.is-expanded .bible-browser__navigator--expanded .bible-browser__nav-group--bible {
  flex-basis: 320px;
  min-width: min(320px, 100%);
}

.bible-browser__hero.is-expanded .bible-browser__navigator-toggle svg {
  transform: rotate(180deg);
}

.product-gallery__thumbs {
  max-height: 370px;
}

.product-gallery__stage-play {
  display: none;
  align-items: center;
  justify-content: center;
}

.product-gallery__stage-play.is-visible {
  display: inline-flex;
}

.reader-movie {
  position: fixed;
  inset: 0;
  z-index: 12050;
  display: none;
  align-items: center;
  justify-content: center;
  padding: clamp(14px, 3vw, 34px);
  background: rgba(17, 14, 10, 0.62);
  backdrop-filter: blur(12px);
  isolation: isolate;
  overscroll-behavior: contain;
  min-height: 100vh;
  min-height: 100dvh;
}

.reader-movie.is-open {
  display: flex;
}

body.reader-movie-open:not(.reader-movie-pip-open) {
  overflow: hidden;
}

.reader-movie__panel {
  width: min(1080px, 96vw);
  max-height: min(94vh, calc(var(--movie-viewport-height, 100vh) - 18px));
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 14px;
  padding: clamp(12px, 2vw, 20px);
  border-radius: 30px;
  background:
    radial-gradient(circle at top left, rgba(255, 232, 194, 0.22), transparent 36%),
    linear-gradient(145deg, rgba(34, 26, 18, 0.98), rgba(15, 13, 10, 0.98));
  border: 1px solid rgba(255, 245, 230, 0.18);
  box-shadow: 0 32px 90px rgba(0, 0, 0, 0.42);
  color: #fff8ec;
}

.reader-movie.is-maximized {
  padding: 0;
  background: #070604;
  width: 100vw;
  width: 100dvw;
  height: 100vh;
  height: 100dvh;
  min-height: 100vh;
  min-height: 100dvh;
}

.reader-movie.is-maximized .reader-movie__panel {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-rows: minmax(0, 1fr);
  place-items: center;
  width: 100%;
  height: 100%;
  max-height: 100%;
  min-height: 0;
  padding: 0;
  border-radius: 0;
  border: 0;
}

.reader-movie.is-maximized .reader-movie__topbar,
.reader-movie.is-maximized .reader-movie__controls {
  position: absolute;
  inset-inline: clamp(10px, 2vw, 24px);
  z-index: 4;
  max-width: min(1180px, calc(100% - 20px));
  margin-inline: auto;
  padding: clamp(8px, 1.2vw, 14px);
  border: 1px solid rgba(255, 248, 236, 0.14);
  border-radius: 24px;
  background: rgba(15, 13, 10, 0.38);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.22);
  backdrop-filter: blur(18px);
  opacity: 0.84;
  transition: opacity 180ms ease, transform 180ms ease, background-color 180ms ease;
}

.reader-movie.is-maximized .reader-movie__topbar {
  top: max(clamp(10px, 2vw, 24px), env(safe-area-inset-top));
}

.reader-movie.is-maximized .reader-movie__controls {
  bottom: max(clamp(10px, 2vw, 24px), env(safe-area-inset-bottom));
}

.reader-movie.is-maximized .reader-movie__topbar:hover,
.reader-movie.is-maximized .reader-movie__topbar:focus-within,
.reader-movie.is-maximized .reader-movie__controls:hover,
.reader-movie.is-maximized .reader-movie__controls:focus-within {
  background: rgba(15, 13, 10, 0.62);
  opacity: 0.98;
}

.reader-movie.is-maximized.is-playing.is-controls-idle:not(.is-pip) .reader-movie__topbar:not(:focus-within) {
  opacity: 0;
  pointer-events: none;
  transform: translateY(calc(-100% - 18px));
}

.reader-movie.is-maximized.is-playing.is-controls-idle:not(.is-pip) .reader-movie__controls:not(:focus-within) {
  opacity: 0;
  pointer-events: none;
  transform: translateY(calc(100% + 18px));
}

.reader-movie__topbar,
.reader-movie__controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.reader-movie__controls {
  flex-wrap: wrap;
  direction: ltr;
  text-align: left;
}

.reader-movie__topbar {
  min-width: 0;
}

.reader-movie__topbar > div:first-child {
  min-width: 0;
}

.reader-movie__top-actions {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 10px;
  flex: 0 0 auto;
}

.reader-movie__eyebrow {
  display: block;
  margin-bottom: 4px;
  font-size: 0.78rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255, 248, 236, 0.62);
}

.reader-movie__title {
  margin: 0;
  font-size: clamp(1.3rem, 2.5vw, 2rem);
  color: #fff8ec;
}

.reader-movie__close,
.reader-movie__icon-button,
.reader-movie__play {
  border: 1px solid rgba(255, 248, 236, 0.2);
  background: rgba(255, 248, 236, 0.12);
  color: #fff8ec;
  box-shadow: none;
  cursor: pointer;
}

.reader-movie__close,
.reader-movie__icon-button {
  width: 48px;
  height: 48px;
  border-radius: 999px;
}

.reader-movie__close {
  font-size: 2rem;
  line-height: 1;
}

.reader-movie__icon-button {
  display: inline-grid;
  place-items: center;
  padding: 0;
}

.reader-movie__icon-button svg {
  width: 22px;
  height: 22px;
}

.reader-movie__fullscreen-icon {
  display: none;
}

.reader-movie__fullscreen[aria-pressed="false"] .reader-movie__fullscreen-icon--enter,
.reader-movie__fullscreen[aria-pressed="true"] .reader-movie__fullscreen-icon--exit {
  display: block;
}

.reader-movie__icon-button.is-copied {
  border-color: rgba(246, 192, 106, 0.62);
  background: rgba(246, 192, 106, 0.22);
  color: #fff1c8;
}

.reader-movie__cc {
  font: 800 0.78rem/1 ui-sans-serif, system-ui, sans-serif;
  letter-spacing: 0.04em;
}

.reader-movie__cc.is-active,
.reader-movie__fullscreen.is-active,
.reader-movie__aspect-button.is-active {
  border-color: rgba(246, 192, 106, 0.7);
  background: rgba(246, 192, 106, 0.24);
  color: #fff1c8;
}

.reader-movie__aspect-group {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px;
  border: 1px solid rgba(255, 248, 236, 0.16);
  border-radius: 999px;
  background: rgba(255, 248, 236, 0.08);
}

.reader-movie__aspect-button {
  min-width: 48px;
  min-height: 40px;
  padding: 0 10px;
  border: 1px solid transparent;
  border-radius: 999px;
  background: transparent;
  color: rgba(255, 248, 236, 0.74);
  cursor: pointer;
  font: 800 0.82rem/1 ui-sans-serif, system-ui, sans-serif;
}

.reader-movie__settings-aspects {
  display: none;
  width: 100%;
  justify-content: space-between;
}

.reader-movie__play {
  width: 48px;
  height: 48px;
  min-width: 48px;
  display: inline-grid;
  place-items: center;
  padding: 0;
  border-radius: 999px;
}

.reader-movie__play-icon {
  display: none;
  width: 22px;
  height: 22px;
}

.reader-movie__play[data-movie-play-state="play"] .reader-movie__play-icon--play,
.reader-movie__play[data-movie-play-state="pause"] .reader-movie__play-icon--pause,
.reader-movie__play[data-movie-play-state="replay"] .reader-movie__play-icon--replay {
  display: block;
}

.reader-movie__master-volume {
  flex: 0 1 133px;
  min-width: 108px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: rgba(255, 248, 236, 0.78);
}

.reader-movie__master-volume svg {
  width: 20px;
  height: 20px;
  flex: 0 0 auto;
}

.reader-movie__volume-slider {
  width: min(105px, 13vw);
}

.reader-movie__stage {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  min-height: 0;
  margin-inline: auto;
  overflow: hidden;
  border-radius: 24px;
  background:
    radial-gradient(circle at 22% 18%, color-mix(in srgb, var(--accent) 28%, transparent), transparent 28%),
    radial-gradient(circle at 78% 22%, rgba(255, 224, 171, 0.18), transparent 34%),
    linear-gradient(160deg, #1e1812, #0c0b09);
  cursor: pointer;
  touch-action: manipulation;
}

.reader-movie--aspect-horizontal .reader-movie__stage {
  width: 100%;
  aspect-ratio: 16 / 9;
}

.reader-movie--aspect-square .reader-movie__stage {
  width: min(100%, 68vh);
  aspect-ratio: 1 / 1;
}

.reader-movie--aspect-vertical .reader-movie__stage {
  width: min(100%, 42vh);
  aspect-ratio: 9 / 16;
}

.reader-movie.is-maximized .reader-movie__stage {
  align-self: center;
  justify-self: center;
  max-width: 100%;
  max-height: 100%;
  border-radius: 0;
}

.reader-movie.is-maximized.reader-movie--aspect-vertical .reader-movie__stage {
  width: auto;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  border-radius: 24px;
}

.reader-movie.is-pip {
  inset: auto clamp(12px, 2vw, 24px) clamp(12px, 2vw, 24px) auto;
  width: min(440px, calc(100vw - 24px));
  height: auto;
  align-items: flex-end;
  justify-content: flex-end;
  padding: 0;
  background: transparent;
  backdrop-filter: none;
  pointer-events: none;
  z-index: 1155;
}

html[dir="rtl"] .reader-movie.is-pip {
  right: auto;
  left: clamp(12px, 2vw, 24px);
}

.reader-movie.is-pip .reader-movie__panel {
  position: relative;
  width: 100%;
  max-height: min(72vh, 560px);
  grid-template-rows: minmax(0, 1fr);
  gap: 0;
  padding: 0;
  border-radius: 24px;
  border: 0;
  background: transparent;
  box-shadow: none;
  pointer-events: auto;
  overflow: hidden;
}

.reader-movie.is-pip .reader-movie__topbar,
.reader-movie.is-pip .reader-movie__controls {
  position: absolute;
  inset-inline: 14px;
  z-index: 5;
  gap: 6px;
  padding: 6px;
  border: 1px solid rgba(255, 248, 236, 0.12);
  border-radius: 16px;
  background: rgba(15, 13, 10, 0.46);
  opacity: 0.72;
  backdrop-filter: blur(12px);
  transition: opacity 160ms ease, transform 160ms ease;
}

.reader-movie.is-pip .reader-movie__topbar {
  top: 14px;
}

.reader-movie.is-pip .reader-movie__controls {
  bottom: 14px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.reader-movie.is-pip .reader-movie__topbar:hover,
.reader-movie.is-pip .reader-movie__topbar:focus-within,
.reader-movie.is-pip .reader-movie__controls:hover,
.reader-movie.is-pip .reader-movie__controls:focus-within {
  opacity: 0.96;
}

.reader-movie.is-pip .reader-movie__eyebrow,
.reader-movie.is-pip .reader-movie__aspect-group,
.reader-movie.is-pip .reader-movie__master-volume,
.reader-movie.is-pip .reader-movie__play {
  display: none;
}

.reader-movie.is-pip .reader-movie__title {
  max-width: 17ch;
  overflow: hidden;
  font-size: 0.9rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.reader-movie.is-pip .reader-movie__icon-button,
.reader-movie.is-pip .reader-movie__close {
  width: 34px;
  height: 34px;
  min-width: 34px;
}

.reader-movie.is-pip .reader-movie__icon-button svg {
  width: 18px;
  height: 18px;
}

.reader-movie.is-pip .reader-movie__stage {
  width: 100%;
  border-radius: 18px;
}

.reader-movie.is-pip.reader-movie--aspect-vertical .reader-movie__stage {
  width: min(58%, 180px);
}

.reader-movie.is-pip.reader-movie--aspect-square .reader-movie__stage {
  width: min(72%, 270px);
}

.reader-movie.is-pip .reader-movie__subtitle {
  left: 14px;
  right: 14px;
  bottom: 64px;
}

.reader-movie.is-pip .reader-movie__subtitle p {
  font-size: calc(clamp(1rem, 4vw, 1.28rem) * var(--movie-subtitle-scale));
}

.reader-movie.is-pip .reader-movie__timeline {
  min-width: 0;
  width: 100%;
  flex-basis: auto;
  order: 0;
  gap: 7px;
}

.reader-movie.is-pip .reader-movie__time {
  min-width: 78px;
  font-size: 0.82rem;
}

.reader-movie.is-pip .reader-movie__settings {
  order: 0;
  margin-inline-start: 0;
}

.reader-movie.is-pip .reader-movie__settings-toggle {
  width: 34px;
  height: 34px;
}

.reader-movie__image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  opacity: 0;
  transform: none;
  transition: opacity 900ms ease;
}

.reader-movie__image.is-active {
  opacity: 1;
  transform: none;
}

.reader-movie__stage::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 46%;
  background: linear-gradient(180deg, transparent, rgba(0, 0, 0, 0.72));
  pointer-events: none;
}

.reader-movie__empty {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 28px;
  text-align: center;
  color: rgba(255, 248, 236, 0.64);
}

.reader-movie__empty[hidden] {
  display: none;
}

.reader-movie__subtitle {
  --movie-subtitle-scale: 1;
  position: absolute;
  left: clamp(16px, 4vw, 54px);
  right: clamp(16px, 4vw, 54px);
  bottom: max(clamp(16px, 4vw, 44px), env(safe-area-inset-bottom));
  z-index: 2;
  display: grid;
  gap: 8px;
  text-align: center;
  text-shadow: 0 4px 22px rgba(0, 0, 0, 0.72);
}

.reader-movie__subtitle[dir="rtl"] {
  direction: rtl;
}

.reader-movie__subtitle span {
  font-size: 0.9rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 236, 201, 0.78);
}

.reader-movie__subtitle span:empty {
  display: none;
}

.reader-movie--subtitles-hidden .reader-movie__subtitle {
  display: none;
}

.reader-movie__subtitle p {
  margin: 0;
  font-size: calc(clamp(1.3rem, 3.4vw, 2.35rem) * var(--movie-subtitle-scale));
  line-height: 1.45;
  color: #fffdf7;
  text-wrap: balance;
}

.reader-movie__subtitle[lang^="ar"] p {
  font-family: "Amiri", "Noto Naskh Arabic", "Scheherazade New", "Traditional Arabic", serif;
}

.reader-movie__timeline {
  flex: 1 1 320px;
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: min(260px, 100%);
}

.reader-movie__seek {
  flex: 1 1 auto;
  width: 100%;
  height: 20px;
  margin: 0;
  appearance: none;
  -webkit-appearance: none;
  background: transparent;
  cursor: pointer;
}

.reader-movie__seek::-webkit-slider-runnable-track {
  height: 6px;
  border-radius: 999px;
  background:
    linear-gradient(90deg, #f6c06a, #fff1c8) 0 / var(--movie-progress, 0%) 100% no-repeat,
    rgba(255, 248, 236, 0.2);
}

.reader-movie__seek::-moz-range-track {
  height: 6px;
  border-radius: 999px;
  background: rgba(255, 248, 236, 0.2);
}

.reader-movie__seek::-moz-range-progress {
  height: 6px;
  border-radius: 999px;
  background: linear-gradient(90deg, #f6c06a, #fff1c8);
}

.reader-movie__seek::-webkit-slider-thumb {
  width: 16px;
  height: 16px;
  margin-top: -5px;
  border: 0;
  border-radius: 999px;
  background: #fff1c8;
  box-shadow: 0 0 0 5px rgba(246, 192, 106, 0.14);
  appearance: none;
  -webkit-appearance: none;
}

.reader-movie__seek::-moz-range-thumb {
  width: 16px;
  height: 16px;
  border: 0;
  border-radius: 999px;
  background: #fff1c8;
  box-shadow: 0 0 0 5px rgba(246, 192, 106, 0.14);
}

.reader-movie__time {
  min-width: 116px;
  text-align: end;
  color: rgba(255, 248, 236, 0.72);
  white-space: nowrap;
}

.reader-movie__settings {
  position: relative;
  flex: 0 0 auto;
}

.reader-movie__settings-toggle.is-active {
  border-color: rgba(246, 192, 106, 0.62);
  background: rgba(246, 192, 106, 0.18);
}

.reader-movie__settings-popover {
  position: absolute;
  right: 0;
  bottom: calc(100% + 12px);
  z-index: 3;
  width: min(360px, calc(100vw - 48px));
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid rgba(255, 248, 236, 0.16);
  border-radius: 20px;
  background: rgba(21, 17, 13, 0.94);
  box-shadow: 0 22px 50px rgba(0, 0, 0, 0.36);
  backdrop-filter: blur(18px);
}

.reader-movie__settings-popover[hidden] {
  display: none;
}

.reader-movie__volume-row {
  display: grid;
  grid-template-columns: minmax(112px, auto) minmax(110px, 1fr) minmax(44px, auto);
  align-items: center;
  gap: 10px;
  color: rgba(255, 248, 236, 0.78);
  font-size: 0.86rem;
}

.reader-movie__volume-row span {
  white-space: nowrap;
}

.reader-movie__volume-slider,
.reader-movie__volume-row input[type="range"] {
  width: 100%;
  height: 18px;
  appearance: none;
  background: transparent;
  cursor: pointer;
}

.reader-movie__volume-slider::-webkit-slider-runnable-track,
.reader-movie__volume-row input[type="range"]::-webkit-slider-runnable-track {
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, #f6c06a 0 var(--movie-volume-percent, 100%), rgba(255, 248, 236, 0.26) var(--movie-volume-percent, 100%) 100%);
}

.reader-movie__volume-slider::-webkit-slider-thumb,
.reader-movie__volume-row input[type="range"]::-webkit-slider-thumb {
  width: 14px;
  height: 14px;
  margin-top: -5px;
  appearance: none;
  border: 0;
  border-radius: 999px;
  background: #fff8ec;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.36);
}

.reader-movie__volume-slider::-moz-range-track,
.reader-movie__volume-row input[type="range"]::-moz-range-track {
  height: 4px;
  border-radius: 999px;
  background: rgba(255, 248, 236, 0.26);
}

.reader-movie__volume-slider::-moz-range-progress,
.reader-movie__volume-row input[type="range"]::-moz-range-progress {
  height: 4px;
  border-radius: 999px;
  background: #f6c06a;
}

.reader-movie__volume-slider::-moz-range-thumb,
.reader-movie__volume-row input[type="range"]::-moz-range-thumb {
  width: 14px;
  height: 14px;
  border: 0;
  border-radius: 999px;
  background: #fff8ec;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.36);
}

.reader-movie__volume-row output {
  color: rgba(255, 241, 200, 0.88);
  font-variant-numeric: tabular-nums;
  text-align: end;
}

@media (max-width: 920px) {
  .reader-movie__topbar,
  .reader-movie__controls {
    align-items: stretch;
  }

  .reader-movie:not(.is-pip) .reader-movie__panel {
    position: relative;
    grid-template-rows: auto minmax(0, 1fr);
    gap: 10px;
    max-height: calc(100vh - 18px);
    padding: clamp(8px, 2vw, 14px);
  }

  .reader-movie:not(.is-pip) .reader-movie__topbar {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 8px;
  }

  .reader-movie:not(.is-pip) .reader-movie__topbar > div:first-child {
    max-width: none;
    min-width: 0;
  }

  .reader-movie:not(.is-pip) .reader-movie__eyebrow {
    display: none;
  }

  .reader-movie:not(.is-pip) .reader-movie__title {
    overflow: hidden;
    font-size: clamp(1rem, 3.8vw, 1.3rem);
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .reader-movie:not(.is-pip) .reader-movie__top-actions {
    flex-wrap: nowrap;
    gap: 7px;
  }

  .reader-movie:not(.is-pip) .reader-movie__top-actions > .reader-movie__aspect-group {
    display: none;
  }

  .reader-movie:not(.is-pip) .reader-movie__icon-button,
  .reader-movie:not(.is-pip) .reader-movie__close {
    width: 42px;
    height: 42px;
  }

  .reader-movie:not(.is-pip) .reader-movie__controls {
    position: absolute;
    inset-inline: clamp(8px, 1.8vw, 16px);
    bottom: max(clamp(6px, 1.6vw, 12px), env(safe-area-inset-bottom));
    z-index: 5;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 6px;
    padding: 5px 7px;
    border: 1px solid rgba(255, 248, 236, 0.16);
    border-radius: 15px;
    background: rgba(15, 13, 10, 0.46);
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.18);
    opacity: 0.72;
    backdrop-filter: blur(16px);
    transition: opacity 160ms ease, transform 160ms ease;
  }

  .reader-movie:not(.is-pip) .reader-movie__controls:hover,
  .reader-movie:not(.is-pip) .reader-movie__controls:focus-within {
    opacity: 0.98;
  }

  .reader-movie:not(.is-pip) .reader-movie__play,
  .reader-movie:not(.is-pip) .reader-movie__master-volume {
    display: none;
  }

  .reader-movie:not(.is-pip) .reader-movie__timeline {
    order: 0;
    flex-basis: auto;
    min-width: 0;
    width: 100%;
    gap: 7px;
  }

  .reader-movie:not(.is-pip) .reader-movie__time {
    min-width: 84px;
    font-size: 0.78rem;
  }

  .reader-movie:not(.is-pip) .reader-movie__settings {
    order: 0;
    margin-inline-start: 0;
  }

  .reader-movie:not(.is-pip) .reader-movie__settings-toggle {
    width: 36px;
    height: 36px;
  }

  .reader-movie:not(.is-pip) .reader-movie__settings-aspects {
    display: flex;
  }

  .reader-movie:not(.is-pip) .reader-movie__subtitle {
    bottom: max(clamp(64px, 12vw, 88px), calc(var(--movie-stage-safe-bottom, 0px) + 8px));
  }

  .reader-movie:not(.is-pip) .reader-movie__settings-popover {
    right: 0;
    bottom: calc(100% + 10px);
    width: min(360px, calc(100vw - 36px));
  }

  .reader-movie__play {
    order: 1;
  }

  .reader-movie__master-volume {
    order: 1;
    flex: 0 1 120px;
    min-width: 104px;
  }

  .reader-movie__volume-slider {
    width: min(100%, 105px);
  }

  .reader-movie__settings {
    order: 1;
    margin-inline-start: auto;
  }

  .reader-movie__aspect-group {
    order: 3;
    width: 100%;
    justify-content: space-between;
  }

  .reader-movie__aspect-button {
    flex: 1 1 0;
  }

  .reader-movie__timeline {
    order: 2;
    flex-basis: 100%;
  }

  .reader-movie__settings {
    flex-basis: auto;
    display: flex;
    justify-content: flex-end;
  }

  .reader-movie__settings-popover {
    right: 0;
  }

  .reader-movie__time {
    min-width: 116px;
  }

  .reader-movie__volume-row {
    grid-template-columns: minmax(92px, auto) minmax(90px, 1fr) minmax(40px, auto);
  }

  .reader-movie.is-maximized:not(.is-pip) .reader-movie__panel {
    grid-template-rows: minmax(0, 1fr);
    gap: 0;
    width: 100%;
    height: 100%;
    max-height: 100%;
    padding: 0;
  }
}

@media (max-width: 420px) {
  .reader-movie:not(.is-pip) .reader-movie__topbar {
    inset-inline: max(6px, env(safe-area-inset-left)) max(6px, env(safe-area-inset-right));
    padding: 6px;
  }

  .reader-movie:not(.is-pip) .reader-movie__top-actions {
    gap: 5px;
  }

  .reader-movie:not(.is-pip) .reader-movie__icon-button,
  .reader-movie:not(.is-pip) .reader-movie__close {
    width: 38px;
    height: 38px;
  }

  .reader-movie:not(.is-pip) .reader-movie__icon-button svg {
    width: 19px;
    height: 19px;
  }

  .reader-movie:not(.is-pip) .reader-movie__title {
    font-size: 0.95rem;
  }
}

.product-gallery__stage-play::before {
  content: "";
  width: 86px;
  height: 86px;
  border-radius: 999px;
  background: rgba(22, 19, 16, 0.28);
  border: 1px solid rgba(255, 255, 255, 0.52);
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.28);
  position: absolute;
}

.product-gallery__stage-play svg {
  position: relative;
  width: 50px;
  height: 50px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  filter: none;
}

.chapter-reader__media-sticky {
  overflow: auto;
  overscroll-behavior: contain;
  padding-inline-end: 2px;
}

.chapter-reader__media-gallery {
  min-height: 0;
}

.chapter-reader__media-gallery .product-gallery {
  height: auto;
  align-items: start;
}

.chapter-reader__media-gallery .product-gallery__thumbs {
  max-height: min(46vh, 430px);
}

.chapter-reader__media-gallery .product-gallery__stage {
  display: block;
  min-height: 0;
  align-self: start;
}

.chapter-reader__media-gallery .product-gallery__main {
  aspect-ratio: 4 / 5;
  height: auto;
  max-height: min(46vh, 430px);
}

.chapter-reader__media-gallery .product-gallery__main img,
.chapter-reader__media-gallery .product-gallery__main video {
  width: 100%;
  height: 100%;
  min-height: 0;
  object-fit: cover;
}

@media (max-width: 1100px) {
  .chapter-reader {
    grid-template-columns: minmax(0, 1fr) minmax(260px, 320px);
    gap: 18px;
  }

  .chapter-reader__media-sticky {
    top: 104px;
    max-height: calc(100vh - 128px);
  }

  .chapter-reader__sheet {
    max-height: calc(100vh - 96px);
  }

  .chapter-reader__media-gallery .product-gallery {
    grid-template-columns: 74px minmax(0, 1fr);
    gap: 10px;
  }
}

@media (max-width: 860px) {
  .chapter-reader {
    grid-template-columns: 1fr;
  }

  .chapter-reader__media {
    position: static;
    order: 2;
    max-height: none;
  }

  .chapter-reader__media-sticky {
    position: static;
    top: auto;
    max-height: none;
    overflow: visible;
  }

  .chapter-reader__media-gallery .product-gallery {
    grid-template-columns: 84px minmax(0, 1fr);
  }

  .chapter-reader__media-gallery .product-gallery__main {
    max-height: min(52vh, 420px);
  }
}

.chapter-reader__lead-cluster {
  float: inline-start;
  display: inline-flex;
  align-items: flex-start;
  margin-inline-end: 0;
  margin-top: 0;
}

.chapter-reader__lead-prefix-inline {
  font-size: var(--reader-text-size);
  line-height: 1.15;
  margin-inline-end: 0.08em;
  color: inherit;
}

.chapter-reader__lead-cluster .chapter-reader__lead-dropcap {
  float: none;
  display: inline-block;
  margin-inline-end: 0;
  margin-top: 0;
}

.chapter-reader__verse--highlight .chapter-reader__verse-anchor {
  display: inline-flex;
  align-items: flex-start;
}

.chapter-reader__verse--highlight .chapter-reader__lead-cluster {
  float: inline-start;
  display: inline-flex;
  vertical-align: baseline;
  margin-inline-end: 0;
}

.chapter-reader__verse--highlight .chapter-reader__verse-text {
  display: block;
  flex: 1 1 auto;
  min-width: 0;
}

.reading-dashboard {
  display: grid;
  gap: 22px;
}

.reading-dashboard__hero,
.reading-dashboard__section,
.reading-dashboard__empty {
  background: var(--surface);
  border: 1px solid var(--border-soft);
  border-radius: 28px;
  padding: 24px;
  color: var(--ink);
  box-shadow: 0 18px 40px var(--surface-shadow);
}

.reading-dashboard__eyebrow {
  margin: 0 0 8px;
  font-size: max(20px, 0.85rem);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
}

.reading-dashboard__hero h1,
.reading-dashboard__section-header h2,
.reading-dashboard__empty h2 {
  margin: 0;
}

.reading-dashboard__hero p,
.reading-dashboard__empty p {
  margin: 10px 0 0;
  color: var(--muted-strong);
  line-height: 1.6;
}

.reading-dashboard__section {
  display: grid;
  gap: 16px;
}

.reading-dashboard__section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.reading-dashboard__section-header span {
  font-size: max(20px, 0.9rem);
  font-weight: 700;
  color: var(--muted);
}

.reading-dashboard__list {
  display: grid;
  gap: 14px;
}

.reading-dashboard__card {
  display: grid;
  gap: 8px;
  padding: 16px 18px;
  border-radius: 20px;
  border: 1px solid var(--border-soft);
  background: var(--control-bg);
  color: var(--ink);
  text-decoration: none;
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.reading-dashboard__card:hover,
.reading-dashboard__card:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 14px 30px color-mix(in srgb, var(--ink) 8%, transparent);
  border-color: color-mix(in srgb, var(--accent) 24%, transparent);
}

.reading-dashboard__card--last-read {
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--accent) 18%, transparent), transparent 34%),
    var(--surface);
  color: var(--ink);
  border-color: color-mix(in srgb, var(--accent) 32%, var(--border-soft));
}

.reading-dashboard__meta,
.reading-dashboard__timestamp,
.reading-dashboard__section-empty {
  color: var(--muted);
  font-size: max(20px, 0.92rem);
}

.reading-dashboard__card p,
.reading-dashboard__section-empty {
  margin: 0;
  line-height: 1.6;
}

.reading-dashboard__card--note {
  gap: 6px;
}

.reading-dashboard__note-preview {
  color: var(--muted-strong);
  font-size: max(20px, 0.88rem);
  line-height: 1.5;
}

.ai-chat-page {
  display: grid;
  grid-template-columns: minmax(280px, 340px) minmax(0, 1fr);
  gap: 20px;
  align-items: stretch;
  /* Plain 100vh per request — the page fills the viewport top-to-bottom.
     The page itself does not scroll; only the thread inside
     .ai-chat-card--main does. */
  height: 100vh;
  min-height: 520px;
  overflow: hidden;
}

.ai-chat-page__sidebar {
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-height: 0;
  overflow-y: auto;
}

.ai-chat-card {
  background: var(--control-bg-strong);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  border-radius: 28px;
  box-shadow: 0 18px 40px color-mix(in srgb, var(--ink) 8%, transparent);
}

.ai-chat-card--sessions,
.ai-chat-card--persona {
  padding: 20px;
}

.ai-chat-card--main {
  /* 4 rows: header, disclaimer, thread (only flex row), composer.
     min-height:0 on the thread row lets it actually scroll inside the grid. */
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr) auto;
  height: 100%;
  min-height: 0;
  overflow: hidden;
}

.ai-chat-card__header,
.ai-chat-main__header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 16px;
}

.ai-chat-card__eyebrow {
  margin: 0 0 8px;
  font-size: max(20px, 0.8rem);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--accent) 92%, transparent);
}

.ai-chat-card__header h1,
.ai-chat-card__header h2,
.ai-chat-main__header h2 {
  margin: 0;
}

.ai-chat-card__copy,
.ai-chat-main__subtitle {
  margin: 10px 0 0;
  color: color-mix(in srgb, var(--ink) 72%, transparent);
  line-height: 1.6;
}

.ai-chat-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, transparent);
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 18%, transparent), color-mix(in srgb, var(--accent) 11%, transparent));
  color: var(--ink);
  font-weight: 700;
  cursor: pointer;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.ai-chat-button:hover,
.ai-chat-button:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 10px 24px color-mix(in srgb, var(--accent) 12%, transparent);
  border-color: color-mix(in srgb, var(--accent) 38%, transparent);
}

.ai-chat-button:disabled {
  cursor: not-allowed;
  opacity: 0.52;
  transform: none;
  box-shadow: none;
}

.ai-chat-button--secondary {
  background: rgba(255, 255, 255, 0.72);
}

.ai-chat-session-list,
.ai-chat-resource-list {
  display: grid;
  gap: 12px;
  margin-top: 18px;
}

.ai-chat-session-list__item,
.ai-chat-resource-card {
  display: grid;
  gap: 6px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  background: rgba(255, 255, 255, 0.88);
  text-align: start;
  color: inherit;
  text-decoration: none;
}

.ai-chat-session-list__item {
  cursor: pointer;
}

.ai-chat-session-list__placeholder {
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px dashed color-mix(in srgb, var(--accent) 24%, transparent);
  background: rgba(255, 250, 243, 0.84);
  color: color-mix(in srgb, var(--ink) 60%, transparent);
}

.ai-chat-session-list__item.is-active {
  border-color: color-mix(in srgb, var(--accent) 28%, transparent);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 14%, transparent);
}

.ai-chat-session-list__item span,
.ai-chat-resource-card p,
.ai-chat-message__resource-link {
  color: color-mix(in srgb, var(--ink) 66%, transparent);
  font-size: max(20px, 0.9rem);
}

.ai-chat-resource-card__kind {
  display: inline-flex;
  width: fit-content;
  padding: 4px 10px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: rgba(143, 85, 50, 0.92);
  font-size: max(20px, 0.78rem);
  font-weight: 700;
}

.ai-chat-main__header {
  padding: 22px 24px 18px;
  border-bottom: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
}

.ai-chat-usage {
  display: grid;
  gap: 4px;
  justify-items: end;
  white-space: nowrap;
}

.ai-chat-usage__label {
  color: color-mix(in srgb, var(--ink) 58%, transparent);
  font-size: max(20px, 0.86rem);
}

.ai-chat-thread {
  display: grid;
  gap: 18px;
  align-content: start;
  padding: 22px 24px;
  /* Critical: min-height:0 lets the grid track actually shrink so this is
     the row that scrolls; without it the row grows to fit content and the
     entire page scrolls instead. */
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--accent) 8%, transparent), transparent 36%),
    linear-gradient(180deg, rgba(255, 252, 246, 0.68), rgba(255, 255, 255, 0.92));
}

.ai-chat-empty-state {
  display: grid;
  gap: 10px;
  max-width: 640px;
  padding: 22px 24px;
  border-radius: 24px;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  background: rgba(255, 255, 255, 0.86);
}

.ai-chat-empty-state h3,
.ai-chat-empty-state p {
  margin: 0;
}

.ai-chat-loading-state {
  display: flex;
  align-items: center;
  gap: 18px;
  max-width: 640px;
  padding: 24px 26px;
  border-radius: 24px;
  border: 1px solid color-mix(in srgb, var(--accent) 16%, transparent);
  background: linear-gradient(180deg, var(--control-bg-strong), rgba(248, 241, 231, 0.96));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.62);
}

.ai-chat-loading-state strong,
.ai-chat-loading-state p {
  margin: 0;
}

.ai-chat-loading-state p {
  margin-top: 6px;
  color: color-mix(in srgb, var(--ink) 66%, transparent);
}

.ai-chat-loading-state__spinner {
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 3px solid color-mix(in srgb, var(--accent) 16%, transparent);
  border-top-color: color-mix(in srgb, var(--accent) 84%, transparent);
  animation: ai-chat-spin 0.9s linear infinite;
  flex: 0 0 auto;
}

.ai-chat-empty-state__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.ai-chat-empty-state__chips span {
  display: inline-flex;
  padding: 8px 12px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: rgba(143, 85, 50, 0.94);
  font-size: max(20px, 0.9rem);
}

.ai-chat-message {
  display: grid;
  gap: 8px;
  justify-items: start;
}

.ai-chat-message--user {
  justify-items: end;
}

.ai-chat-message__bubble {
  max-width: min(780px, 100%);
  display: grid;
  gap: 8px;
  padding: 16px 18px;
  border-radius: 22px;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 12px 28px color-mix(in srgb, var(--ink) 5%, transparent);
  text-align: start;
}

.ai-chat-message--user .ai-chat-message__bubble {
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 16%, transparent), color-mix(in srgb, var(--accent) 10%, transparent));
  border-color: color-mix(in srgb, var(--accent) 24%, transparent);
}

.ai-chat-message__role {
  color: color-mix(in srgb, var(--ink) 58%, transparent);
  font-size: max(20px, 0.82rem);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.ai-chat-message__body {
  white-space: pre-wrap;
  line-height: 1.65;
  unicode-bidi: plaintext;
}

[dir="rtl"] .ai-chat-message__body,
html[lang="ar"] .ai-chat-message__body {
  line-height: 2.22;
}

.ai-chat-message__resources {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-inline: 4px;
}

.ai-chat-message__resource-link {
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  background: rgba(255, 255, 255, 0.82);
  text-decoration: none;
}

.ai-chat-composer {
  display: grid;
  gap: 12px;
  padding: 18px 24px 24px;
  border-top: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  background: var(--control-bg-strong);
}

.ai-chat-composer__input {
  width: 100%;
  min-height: 64px;
  max-height: 220px;
  resize: none;
  padding: 18px 20px;
  border-radius: 24px;
  border: 1px solid color-mix(in srgb, var(--ink) 10%, transparent);
  background: rgba(255, 255, 255, 0.96);
  color: var(--ink);
  font: inherit;
  line-height: 1.65;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85), 0 12px 24px color-mix(in srgb, var(--ink) 4%, transparent);
  unicode-bidi: plaintext;
}

.ai-chat-composer__input:focus {
  outline: none;
  border-color: color-mix(in srgb, var(--accent) 42%, transparent);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85), 0 0 0 4px color-mix(in srgb, var(--accent) 12%, transparent);
}

.ai-chat-composer__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.ai-chat-composer__hint {
  color: color-mix(in srgb, var(--ink) 62%, transparent);
  font-size: max(20px, 0.92rem);
}

@keyframes ai-chat-spin {
  to {
    transform: rotate(360deg);
  }
}

@keyframes ai-chat-spin {
  to {
    transform: rotate(360deg);
  }
}

.ai-chat-page[dir="rtl"] {
  grid-template-columns: minmax(0, 1fr) minmax(280px, 340px);
}

.ai-chat-page[dir="rtl"] .ai-chat-page__sidebar {
  order: 2;
}

.ai-chat-page[dir="rtl"] .ai-chat-card__header,
.ai-chat-page[dir="rtl"] .ai-chat-main__header,
.ai-chat-page[dir="rtl"] .ai-chat-composer__footer {
  flex-direction: row-reverse;
}

.ai-chat-page[dir="rtl"] .ai-chat-usage {
  justify-items: start;
}

.ai-chat-page[dir="rtl"] .ai-chat-session-list__item,
.ai-chat-page[dir="rtl"] .ai-chat-resource-card {
  text-align: right;
}

.ai-chat-message[data-dir="rtl"] .ai-chat-message__bubble,
.ai-chat-message[data-dir="rtl"] .ai-chat-message__resources {
  direction: rtl;
}

.ai-chat-message[data-dir="ltr"] .ai-chat-message__bubble,
.ai-chat-message[data-dir="ltr"] .ai-chat-message__resources {
  direction: ltr;
}

.ai-chat-composer__input[data-dir="rtl"] {
  direction: rtl;
  text-align: right;
}

.ai-chat-composer__input[data-dir="ltr"] {
  direction: ltr;
  text-align: left;
}

.ai-chat-page {
  padding-block: 6px 28px;
}

.ai-chat-card,
.ai-chat-empty-state,
.ai-chat-loading-state,
.ai-chat-message__bubble,
.ai-chat-composer,
.ai-chat-session-list__item,
.ai-chat-resource-card,
.ai-chat-message__resource-link {
  background: var(--surface);
  border-color: var(--border-soft);
  color: var(--ink);
  box-shadow: 0 18px 40px var(--surface-shadow);
}

.ai-chat-session-list__item,
.ai-chat-resource-card,
.ai-chat-message__resource-link,
.ai-chat-empty-state {
  background: var(--control-bg);
}

.ai-chat-card__eyebrow,
.ai-chat-resource-card__kind {
  color: var(--accent);
}

.ai-chat-card__copy,
.ai-chat-main__subtitle,
.ai-chat-session-list__placeholder,
.ai-chat-session-list__item span,
.ai-chat-resource-card p,
.ai-chat-message__resource-link,
.ai-chat-usage__label,
.ai-chat-loading-state p,
.ai-chat-message__role,
.ai-chat-composer__hint {
  color: var(--muted-strong);
}

.ai-chat-button {
  background: var(--accent);
  border-color: color-mix(in srgb, var(--accent) 65%, var(--border-soft));
  color: var(--on-accent);
}

.ai-chat-button--secondary {
  background: var(--control-bg);
  color: var(--ink);
}

.ai-chat-session-list__placeholder {
  border-color: color-mix(in srgb, var(--accent) 34%, var(--border-soft));
  background: var(--control-bg);
}

.ai-chat-session-list__item.is-active {
  border-color: color-mix(in srgb, var(--accent) 45%, var(--border-soft));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 20%, transparent);
}

.ai-chat-resource-card__kind,
.ai-chat-empty-state__chips span {
  background: color-mix(in srgb, var(--accent) 12%, transparent);
}

.ai-chat-main__header,
.ai-chat-composer {
  border-color: var(--border-soft);
}

.ai-chat-thread {
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--accent) 10%, transparent), transparent 36%),
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 74%, transparent), var(--surface));
}

.ai-chat-loading-state {
  background: linear-gradient(180deg, var(--surface), var(--control-bg));
}

.ai-chat-loading-state__spinner {
  border-color: color-mix(in srgb, var(--accent) 18%, transparent);
  border-top-color: var(--accent);
}

.ai-chat-message--user .ai-chat-message__bubble {
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 18%, var(--surface)), color-mix(in srgb, var(--accent) 10%, var(--surface)));
  border-color: color-mix(in srgb, var(--accent) 34%, var(--border-soft));
}

.ai-chat-composer__input {
  background: var(--control-bg-strong);
  border-color: var(--control-border);
  color: var(--ink);
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--surface) 80%, transparent), 0 12px 24px var(--surface-shadow);
}

.ai-chat-composer__input:focus {
  border-color: color-mix(in srgb, var(--accent) 55%, var(--control-border));
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--surface) 80%, transparent), 0 0 0 4px color-mix(in srgb, var(--accent) 14%, transparent);
}

.image-review-page {
  display: grid;
  grid-template-columns: minmax(240px, 300px) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}

.image-review-card {
  background: var(--control-bg-strong);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  border-radius: 30px;
  box-shadow: 0 18px 40px color-mix(in srgb, var(--ink) 8%, transparent);
}

.image-review-page__sidebar {
  display: grid;
  gap: 18px;
  position: sticky;
  top: 126px;
}

.image-review-card--summary {
  padding: 22px 24px;
}

.image-review-card--summary h2,
.image-review-main__header h3 {
  margin: 0;
}

.image-review-card__eyebrow {
  margin: 0 0 8px;
  font-size: max(20px, 0.78rem);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--ink) 54%, transparent);
}

.image-review-card__copy,
.image-review-main__subtitle {
  margin: 12px 0 0;
  color: color-mix(in srgb, var(--ink) 72%, transparent);
  line-height: 1.55;
}

.image-review-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 20px 0 0;
}

.image-review-stats div {
  display: grid;
  gap: 4px;
  padding: 14px 16px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.76);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
}

.image-review-stats dt {
  font-size: max(20px, 0.88rem);
  color: color-mix(in srgb, var(--ink) 62%, transparent);
}

.image-review-stats dd {
  margin: 0;
  font-size: 1.55rem;
  font-weight: 700;
}

.image-review-guidelines {
  margin: 16px 0 0;
  padding-inline-start: 20px;
  display: grid;
  gap: 10px;
  line-height: 1.55;
  color: color-mix(in srgb, var(--ink) 78%, transparent);
}

.image-review-card--main {
  padding: 16px 18px 18px;
  display: grid;
  gap: 12px;
}

.image-review-main__header {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 14px;
}

.image-review-main__verse {
  margin: 8px 0 0;
  max-width: 86ch;
  color: color-mix(in srgb, var(--ink) 84%, transparent);
  font-size: 1rem;
  line-height: 1.45;
}

.image-review-main__verse:empty {
  display: none;
}

.image-review-votes {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

/* Two pills only: yes (▲ count) and no (▼ count). The previous Σ total
   was redundant and visually noisy. SVG arrow + tabular count. */
.image-review-vote {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 34px;
  padding: 3px 12px 3px 8px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--ink) 10%, transparent);
  background: rgba(255, 255, 255, 0.82);
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  font-size: 0.95rem;
  line-height: 1;
}

.image-review-vote svg {
  width: 16px;
  height: 16px;
  flex: 0 0 16px;
}

.image-review-vote__count {
  font-size: 0.95rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}

.image-review-vote--yes {
  color: #176d44;
  background: rgba(31, 122, 77, 0.12);
  border-color: rgba(31, 122, 77, 0.28);
}

.image-review-vote--no {
  color: #8c3823;
  background: rgba(166, 66, 42, 0.12);
  border-color: rgba(166, 66, 42, 0.26);
}

.image-review-cleanup {
  display: grid;
  gap: 10px;
}

.image-review-stage {
  position: relative;
  min-height: min(78vh, 880px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px;
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.64), rgba(255, 255, 255, 0.52)),
    radial-gradient(circle at top, color-mix(in srgb, var(--accent) 8%, transparent), transparent 55%),
    linear-gradient(45deg, rgba(0, 0, 0, 0.04) 25%, transparent 25%, transparent 75%, rgba(0, 0, 0, 0.04) 75%, rgba(0, 0, 0, 0.04)),
    linear-gradient(45deg, rgba(0, 0, 0, 0.04) 25%, transparent 25%, transparent 75%, rgba(0, 0, 0, 0.04) 75%, rgba(0, 0, 0, 0.04));
  background-size: auto, auto, 28px 28px, 28px 28px;
  background-position: center, center, 0 0, 14px 14px;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  overflow: hidden;
  touch-action: none;
}

.image-review-stage img {
  max-width: 100%;
  max-height: min(74vh, 840px);
  display: block;
  border-radius: 16px;
  box-shadow: 0 18px 42px color-mix(in srgb, var(--ink) 18%, transparent);
  background: rgba(255, 255, 255, 0.74);
  cursor: zoom-in;
  transform-origin: center center;
  transition: transform 120ms ease;
  user-select: none;
  -webkit-user-drag: none;
  will-change: transform;
}

.image-review-stage.is-zoomed img {
  cursor: grab;
}

.image-review-stage.is-panning img {
  cursor: grabbing;
  transition: none;
}

.image-review-empty {
  max-width: 420px;
  text-align: center;
  display: grid;
  gap: 8px;
  padding: 26px 24px;
  border-radius: 24px;
  background: var(--control-bg);
  border: 1px dashed color-mix(in srgb, var(--accent) 24%, transparent);
  color: color-mix(in srgb, var(--ink) 72%, transparent);
}

.image-review-empty h3,
.image-review-empty p {
  margin: 0;
}

.image-review-actions {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}

@media (max-width: 720px) {
  .image-review-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .image-review-ocr__grid {
    grid-template-columns: 1fr;
  }
}

.image-review-button {
  min-height: 52px;
  padding: 12px 16px;
  border-radius: 18px;
  border: 1px solid color-mix(in srgb, var(--ink) 10%, transparent);
  background: rgba(255, 255, 255, 0.85);
  color: var(--ink);
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

.image-review-button:hover,
.image-review-button:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 12px 28px color-mix(in srgb, var(--ink) 12%, transparent);
}

.image-review-button:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent) 24%, transparent);
  outline-offset: 2px;
}

.image-review-button:disabled {
  cursor: not-allowed;
  opacity: 0.46;
  transform: none;
  box-shadow: none;
}

.image-review-button--yes {
  background: rgba(31, 122, 77, 0.1);
  border-color: rgba(31, 122, 77, 0.24);
  color: #1f7a4d;
}

.image-review-button--no {
  background: rgba(166, 66, 42, 0.1);
  border-color: rgba(166, 66, 42, 0.22);
  color: #a6422a;
}

.image-review-button--skip {
  background: color-mix(in srgb, var(--ink) 6%, transparent);
  border-color: color-mix(in srgb, var(--ink) 16%, transparent);
  color: color-mix(in srgb, var(--ink) 70%, transparent);
}

/* Cleanup / Compare mode tabs at the top of the workspace card. */
.image-review-mode {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  background: rgba(255, 255, 255, 0.78);
  margin-bottom: 4px;
  flex-wrap: wrap;
}

.image-review-mode__tab {
  padding: 8px 16px;
  border-radius: 999px;
  border: 0;
  background: transparent;
  color: color-mix(in srgb, var(--ink) 72%, transparent);
  font: inherit;
  font-weight: 700;
  font-size: 0.86rem;
  cursor: pointer;
  transition: background-color 140ms ease, color 140ms ease;
}

.image-review-mode__tab:hover,
.image-review-mode__tab:focus-visible {
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent-dark);
  outline: none;
}

.image-review-mode__tab.is-active {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  color: var(--accent-dark);
}

/* Compare mode: 2-up grid of pair cards. */
.image-review-compare {
  display: grid;
  gap: 16px;
}

.image-review-compare__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

@media (max-width: 820px) {
  .image-review-compare__grid {
    grid-template-columns: 1fr;
  }
}

/* The whole card is the pick button — no separate "Pick this" action.
   Resets the native <button> defaults so the layout still flows like a
   plain article. */
.image-review-pair-card {
  display: grid;
  gap: 0;
  padding: 0;
  border-radius: 22px;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  background: var(--control-bg);
  cursor: pointer;
  font: inherit;
  color: inherit;
  text-align: inherit;
  transition: border-color 140ms ease, box-shadow 140ms ease, transform 140ms ease;
}

.image-review-pair-card:hover:not(:disabled),
.image-review-pair-card:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 50%, transparent);
  box-shadow: 0 18px 42px color-mix(in srgb, var(--accent) 18%, transparent);
  transform: translateY(-2px);
  outline: none;
}

.image-review-pair-card:disabled {
  cursor: not-allowed;
  opacity: 0.78;
}

/* Hide the cleanup-mode top vote tally when the workspace is showing
   the compare grid — the per-card vote overlays already carry that
   information. Driven by the .image-review-page--compare modifier
   added/removed by the mode toggle. */
.image-review-page--compare [data-image-review-votes] {
  display: none;
}

.image-review-pair-card__stage {
  position: relative;
  min-height: min(76vh, 820px);
  display: flex;
  align-items: stretch;
  justify-content: stretch;
  padding: 0;
  border-radius: 18px;
  background: color-mix(in srgb, var(--ink) 4%, transparent);
  border: 1px solid color-mix(in srgb, var(--ink) 6%, transparent);
  overflow: hidden;
}

.image-review-pair-card__stage img {
  width: 100%;
  height: 100%;
  min-height: min(76vh, 820px);
  object-fit: contain;
  border-radius: 18px;
  box-shadow: 0 12px 30px color-mix(in srgb, var(--ink) 12%, transparent);
}

/* Floating yes/no vote badges over the image so reviewers can see the
   current tally without breaking eye contact with the visual content. */
.image-review-pair-card__votes {
  position: absolute;
  inset-block-start: 12px;
  inset-inline-start: 12px;
  display: flex;
  gap: 8px;
  pointer-events: none;
  z-index: 2;
}

.image-review-pair-card__vote {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 5px 10px 5px 8px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--ink) 70%, transparent);
  color: #fff;
  font-weight: 700;
  font-size: 0.82rem;
  line-height: 1;
  letter-spacing: 0.01em;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  box-shadow: 0 6px 18px color-mix(in srgb, var(--ink) 30%, transparent);
}

.image-review-pair-card__vote svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

.image-review-pair-card__vote--yes {
  background: color-mix(in srgb, var(--success, #1f6d3f) 86%, transparent);
}

.image-review-pair-card__vote--no {
  background: color-mix(in srgb, var(--danger, #9f2f2f) 86%, transparent);
}

/* Per-card metadata is no longer rendered — the reference + scope are
   shown once at the workspace header. Selectors kept for any legacy
   markup but visually collapsed. */
.image-review-pair-card__reference,
.image-review-pair-card__meta {
  display: none;
}

.image-review-compare__actions {
  display: flex;
  justify-content: flex-end;
}

/* Reported-by-me panel: lives below the action row inside the workspace
   card. Collapsed by default; expanding fetches the user's hidden list. */
.image-review-reports {
  margin-top: 18px;
  padding: 14px 16px;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.66);
}

.image-review-reports > summary {
  cursor: pointer;
  font-weight: 800;
  color: color-mix(in srgb, var(--ink) 78%, transparent);
  list-style: none;
}

.image-review-reports > summary::-webkit-details-marker {
  display: none;
}

.image-review-reports > summary::before {
  content: "▸";
  display: inline-block;
  margin-inline-end: 6px;
  transition: transform 160ms ease;
}

.image-review-reports[open] > summary::before {
  transform: rotate(90deg);
}

.image-review-reports__hint {
  margin: 8px 0 12px;
  font-size: 0.86rem;
  color: color-mix(in srgb, var(--ink) 60%, transparent);
}

.image-review-reports__list {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
}

.image-review-reports__empty {
  margin: 6px 0;
  color: color-mix(in srgb, var(--ink) 60%, transparent);
  font-size: 0.92rem;
}

.image-review-report-card {
  display: grid;
  gap: 8px;
  padding: 10px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  background: var(--control-bg);
}

.image-review-report-card img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 10px;
  background: color-mix(in srgb, var(--ink) 8%, transparent);
}

.image-review-report-card__meta {
  display: grid;
  gap: 2px;
  font-size: 0.86rem;
}

.image-review-report-card__meta span {
  color: color-mix(in srgb, var(--ink) 60%, transparent);
  font-size: 0.78rem;
}

.image-review-report-card .image-review-button {
  min-height: 36px;
  padding: 8px 12px;
  border-radius: 12px;
  font-size: 0.86rem;
}

.image-review-button--hide {
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  border-color: color-mix(in srgb, var(--accent) 22%, transparent);
  color: var(--accent-dark);
}

.image-review-button--ocr {
  background: color-mix(in srgb, var(--info, #2563eb) 10%, transparent);
  border-color: color-mix(in srgb, var(--info, #2563eb) 28%, transparent);
  color: color-mix(in srgb, var(--info, #2563eb) 82%, var(--ink));
}

.image-review-ocr {
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  border-radius: 18px;
  background: color-mix(in srgb, var(--surface, #fff) 82%, transparent);
  padding: 14px;
}

.image-review-ocr[hidden] {
  display: none;
}

.image-review-ocr__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.image-review-ocr article {
  min-width: 0;
  display: grid;
  gap: 8px;
  align-content: start;
}

.image-review-ocr h4 {
  margin: 0;
  font-size: 0.86rem;
  color: color-mix(in srgb, var(--ink) 68%, transparent);
}

.image-review-ocr p {
  margin: 0;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
  line-height: 1.55;
}

.image-review-ocr__meta {
  margin-top: 12px !important;
  color: color-mix(in srgb, var(--ink) 62%, transparent);
  font-size: 0.85rem;
}

.image-review-status {
  margin: 0;
  color: color-mix(in srgb, var(--ink) 66%, transparent);
}

@media (max-width: 1100px) {
  .ai-chat-page {
    grid-template-columns: 1fr;
    /* On narrow viewports the sidebar stacks above the main card, so we
       can't fit everything in 100vh — let the page scroll naturally. */
    height: auto;
    min-height: 100vh;
    overflow: visible;
  }

  .ai-chat-page[dir="rtl"] {
    grid-template-columns: 1fr;
  }

  .ai-chat-page__sidebar {
    overflow-y: visible;
  }

  .ai-chat-card--main {
    min-height: 60vh;
    height: auto;
  }

  .editor-ai-strip {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .editor-ai-strip__signin {
    flex-direction: column;
    align-items: flex-start;
  }

  .image-review-page {
    grid-template-columns: 1fr;
  }

  .image-review-page__sidebar {
    position: static;
  }

  .image-review-main__header {
    flex-direction: column;
  }

  .image-review-actions {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .image-review-card--main,
  .image-review-card--summary {
    padding: 18px;
  }

  .image-review-stats {
    grid-template-columns: 1fr;
  }

  .image-review-votes {
    width: 100%;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.forum-shell {
  display: grid;
  gap: 24px;
  padding: 24px 0 48px;
}

.forum-hero {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: end;
  padding: 28px 32px;
  border-radius: 28px;
  background: linear-gradient(135deg, rgba(207, 148, 76, 0.16), rgba(247, 241, 224, 0.96));
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
}

.forum-hero--compact {
  align-items: center;
}

.forum-eyebrow {
  margin: 0 0 8px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: max(20px, 0.78rem);
  color: color-mix(in srgb, var(--ink) 58%, transparent);
}

.forum-lede {
  margin: 10px 0 0;
  max-width: 720px;
  color: color-mix(in srgb, var(--ink) 75%, transparent);
}

.forum-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: 24px;
}

.forum-card {
  padding: 24px;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  box-shadow: 0 18px 48px color-mix(in srgb, var(--ink) 5%, transparent);
}

.forum-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
}

.forum-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 18px;
  border-radius: 999px;
  text-decoration: none;
  border: 0;
  background: #b56d27;
  color: #fff;
  font-weight: 700;
  cursor: pointer;
}

.forum-category-list,
.forum-thread-list,
.forum-post-list {
  display: grid;
  gap: 14px;
}

.forum-category-card,
.forum-thread-row {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 20px;
  border-radius: 20px;
  text-decoration: none;
  color: inherit;
  background: rgba(248, 245, 237, 0.9);
  border: 1px solid color-mix(in srgb, var(--ink) 6%, transparent);
}

.forum-thread-row--pinned {
  background: rgba(255, 246, 214, 0.9);
}

.forum-category-card p,
.forum-thread-row p {
  margin: 8px 0 0;
  color: color-mix(in srgb, var(--ink) 70%, transparent);
}

.forum-thread-row span,
.forum-category-card span {
  white-space: nowrap;
  font-size: max(20px, 0.92rem);
  color: color-mix(in srgb, var(--ink) 56%, transparent);
}

.forum-breadcrumbs {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  color: color-mix(in srgb, var(--ink) 64%, transparent);
}

.forum-breadcrumbs a {
  text-decoration: none;
}

.forum-thread__header {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 20px;
}

.forum-thread__meta {
  color: color-mix(in srgb, var(--ink) 56%, transparent);
  white-space: nowrap;
}

.forum-post {
  padding: 18px 20px;
  border-radius: 20px;
  background: rgba(248, 245, 237, 0.85);
  border: 1px solid color-mix(in srgb, var(--ink) 6%, transparent);
}

.forum-post__header {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.forum-post__header span {
  color: color-mix(in srgb, var(--ink) 56%, transparent);
  font-size: max(20px, 0.92rem);
}

.forum-post__body {
  white-space: pre-wrap;
  line-height: 1.7;
}

.forum-composer {
  display: grid;
  gap: 16px;
}

.forum-composer label {
  display: grid;
  gap: 8px;
}

.forum-composer input,
.forum-composer textarea,
.forum-composer select {
  width: 100%;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--ink) 10%, transparent);
  background: rgba(255, 255, 255, 0.98);
  font: inherit;
}

.forum-composer textarea {
  resize: vertical;
  min-height: 140px;
}

.forum-composer__footer {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.contact-page {
  max-width: 880px;
  margin: 0 auto;
  display: grid;
  gap: 18px;
}

.contact-page__header,
.contact-form {
  padding: 22px 24px;
  border-radius: 24px;
  background: rgba(248, 245, 237, 0.92);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
}

.contact-page__header {
  display: grid;
  gap: 8px;
}

.contact-page__eyebrow,
.contact-page__header p {
  margin: 0;
  color: color-mix(in srgb, var(--ink) 66%, transparent);
}

.contact-page__eyebrow {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: max(20px, 0.82rem);
  font-weight: 800;
}

.contact-page__flash {
  margin: 0;
  padding: 14px 16px;
  border-radius: 16px;
}

.contact-page__flash--ok {
  background: rgba(34, 119, 65, 0.09);
  color: #245933;
}

.contact-page__flash--error {
  background: rgba(158, 34, 34, 0.1);
  color: #7e2727;
}

.contact-form {
  display: grid;
  gap: 16px;
}

.contact-form label {
  display: grid;
  gap: 8px;
  font-weight: 800;
}

.contact-form input,
.contact-form textarea {
  width: 100%;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--ink) 12%, transparent);
  background: rgba(255, 255, 255, 0.98);
  font: inherit;
}

.contact-form textarea {
  min-height: 180px;
  resize: vertical;
}

.contact-form label > span:last-child,
.contact-form__validation {
  color: #8a2f2f;
  font-size: max(20px, 0.86rem);
}

.contact-form__trap {
  position: absolute;
  left: -10000px;
  width: 1px;
  height: 1px;
  opacity: 0;
}

.contact-form__footer {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
}

.contact-form__footer span {
  color: color-mix(in srgb, var(--ink) 64%, transparent);
}

.contact-form__footer button {
  border: 1px solid color-mix(in srgb, var(--ink) 12%, transparent);
  border-radius: 999px;
  background: rgba(12, 10, 8, 0.9);
  color: #fffaf4;
  padding: 12px 18px;
  font: inherit;
  font-weight: 800;
  cursor: pointer;
}

@media (max-width: 900px) {
  .forum-grid {
    grid-template-columns: 1fr;
  }

  .forum-hero,
  .forum-thread__header,
  .forum-composer__footer,
  .forum-thread-row,
  .forum-category-card,
  .forum-post__header {
    flex-direction: column;
    align-items: flex-start;
  }
}

.image-review-admin-links,
.admin-page__actions,
.admin-user-card__actions,
.admin-hidden-review-card__actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.image-review-admin-links a,
.admin-page__link,
.admin-page__search button,
.admin-user-card__actions button,
.admin-hidden-review-card__actions button {
  border: 1px solid var(--border-soft, color-mix(in srgb, var(--ink) 12%, transparent));
  border-radius: 999px;
  background: var(--control-bg, rgba(255, 255, 255, 0.96));
  color: var(--ink);
  text-decoration: none;
  padding: 10px 16px;
  font: inherit;
  font-weight: 600;
  cursor: pointer;
  transition: background-color 0.14s ease, border-color 0.14s ease, color 0.14s ease, transform 0.14s ease;
}

.image-review-admin-links a:hover,
.image-review-admin-links a:focus-visible,
.admin-page__link:hover,
.admin-page__link:focus-visible,
.admin-page__link[aria-current="page"] {
  background: color-mix(in srgb, var(--accent) 12%, var(--control-bg, transparent));
  border-color: color-mix(in srgb, var(--accent) 36%, var(--border-soft, transparent));
  color: var(--accent-dark);
  transform: translateY(-1px);
  outline: none;
}

.admin-page {
  display: grid;
  gap: 20px;
}

.admin-page__split {
  display: grid;
  grid-template-columns: minmax(0, 1.8fr) minmax(280px, 0.9fr);
  gap: 18px;
  align-items: start;
}

.admin-dashboard-column {
  display: grid;
  gap: 18px;
}

.admin-page__header {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
}

.admin-page__eyebrow {
  margin: 0 0 8px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: max(20px, 0.82rem);
  color: color-mix(in srgb, var(--ink) 58%, transparent);
}

.admin-page__copy {
  margin: 8px 0 0;
  max-width: 72ch;
  color: color-mix(in srgb, var(--ink) 70%, transparent);
}

.admin-page__flash {
  margin: 0;
  padding: 14px 16px;
  border-radius: 16px;
}

.admin-page__flash--ok {
  background: rgba(34, 119, 65, 0.09);
  color: #245933;
}

.admin-page__flash--error {
  background: rgba(158, 34, 34, 0.1);
  color: #7e2727;
}

.admin-page__search {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.admin-page__search-hint {
  margin: -2px 0 0;
  color: color-mix(in srgb, var(--ink) 62%, transparent);
  font-size: max(20px, 0.94rem);
}

.admin-page__search input {
  flex: 1 1 320px;
  min-width: 0;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--ink) 12%, transparent);
  background: rgba(255, 255, 255, 0.98);
  font: inherit;
}

.admin-summary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 12px;
}

.admin-policy-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(260px, 0.9fr);
  gap: 16px;
}

.admin-summary-card,
.admin-audit-panel,
.admin-policy-card {
  background: rgba(248, 245, 237, 0.92);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  border-radius: 24px;
  padding: 18px 20px;
}

.admin-policy-card {
  display: grid;
  gap: 14px;
}

.admin-policy-card--muted {
  background: rgba(243, 239, 232, 0.92);
}

.admin-policy-card__header {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.admin-policy-card__header h2,
.admin-policy-card__meta dd,
.admin-policy-card__meta dt {
  margin: 0;
}

.admin-policy-card > p {
  margin: 0;
  color: color-mix(in srgb, var(--ink) 66%, transparent);
}

.admin-policy-card__form {
  display: grid;
  gap: 12px;
}

.admin-checkbox {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
}

.admin-checkbox input {
  margin-top: 3px;
}

.admin-policy-card__meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px;
}

.admin-policy-card__meta dt {
  color: color-mix(in srgb, var(--ink) 56%, transparent);
  font-size: max(20px, 0.86rem);
}

.admin-policy-card__meta dd {
  margin-top: 4px;
}

.admin-policy-card__list {
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 10px;
  color: color-mix(in srgb, var(--ink) 66%, transparent);
}

.admin-invitation-link {
  display: grid;
  grid-template-columns: minmax(0, 0.8fr) minmax(280px, 1.2fr);
  gap: 18px;
  align-items: center;
  padding: 18px 20px;
  border: 1px solid color-mix(in srgb, var(--success) 22%, transparent);
  border-radius: 18px;
  background: color-mix(in srgb, var(--success) 9%, var(--surface));
}

.admin-invitation-link h2,
.admin-invitation-link p {
  margin: 0;
}

.admin-invitation-link__copy {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
}

.admin-invitation-link__copy input,
.admin-invitation-form input[type="number"],
.admin-invitation-form__note input {
  width: 100%;
  min-height: 44px;
  padding: 9px 12px;
  border: 1px solid color-mix(in srgb, var(--accent-dark) 14%, transparent);
  border-radius: 10px;
  background: var(--surface);
  color: var(--ink);
  font: inherit;
}

.admin-invitation-link__copy button,
.admin-invitation-form button {
  min-height: 44px;
  border: 1px solid color-mix(in srgb, var(--accent-dark) 18%, transparent);
  border-radius: 10px;
  padding: 0 16px;
  background: var(--accent);
  color: var(--on-accent);
  font: inherit;
  font-weight: 800;
  cursor: pointer;
}

.admin-invitation-form__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.admin-invitation-form__grid label,
.admin-invitation-form__note {
  display: grid;
  gap: 6px;
}

.admin-invitation-form__grid span,
.admin-invitation-form__note span {
  color: color-mix(in srgb, var(--ink) 62%, transparent);
  font-size: max(20px, 0.88rem);
  font-weight: 700;
}

.admin-invitation-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
}

.admin-invitation-row__side {
  display: grid;
  justify-items: end;
  gap: 8px;
  color: color-mix(in srgb, var(--ink) 66%, transparent);
  font-size: max(20px, 0.92rem);
}

.invite-page {
  min-height: min(760px, calc(100vh - 160px));
  display: grid;
  place-items: center;
  padding: clamp(28px, 6vw, 72px) 0;
}

.invite-panel {
  width: min(680px, 100%);
  display: grid;
  gap: 18px;
  padding: clamp(24px, 5vw, 44px);
  border: 1px solid var(--border-soft);
  border-radius: 22px;
  background: var(--surface);
  box-shadow: 0 24px 54px color-mix(in srgb, var(--ink) 12%, transparent);
}

.invite-panel__eyebrow {
  margin: 0;
  color: color-mix(in srgb, var(--accent-dark) 92%, var(--ink));
  font-size: max(20px, 0.82rem);
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.invite-panel h1 {
  margin: 0;
  color: var(--ink);
  font-size: clamp(2.3rem, 5vw, 4rem);
  line-height: 1;
}

.invite-panel p {
  margin: 0;
  color: color-mix(in srgb, var(--ink) 82%, var(--surface));
  line-height: 1.55;
}

.invite-panel__details {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 10px;
  margin: 0;
}

.invite-panel__details div {
  padding: 12px 14px;
  border: 1px solid color-mix(in srgb, var(--accent-dark) 10%, transparent);
  border-radius: 12px;
  background: color-mix(in srgb, var(--accent) 6%, transparent);
}

.invite-panel__details dt {
  color: color-mix(in srgb, var(--ink) 56%, transparent);
  font-size: max(20px, 0.82rem);
  font-weight: 800;
}

.invite-panel__details dd {
  margin: 4px 0 0;
  font-weight: 800;
}

.invite-panel__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.invite-panel__primary,
.invite-panel__secondary {
  min-height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid color-mix(in srgb, var(--accent-dark) 16%, transparent);
  border-radius: 999px;
  padding: 0 18px;
  font: inherit;
  font-weight: 800;
  text-decoration: none;
  cursor: pointer;
}

.invite-panel__primary {
  background: var(--accent);
  color: var(--on-accent);
}

.invite-panel__secondary {
  background: var(--surface-strong);
  color: var(--accent-dark);
}

.admin-summary-card__label {
  margin: 0 0 10px;
  color: color-mix(in srgb, var(--ink) 58%, transparent);
  font-size: max(20px, 0.88rem);
}

.admin-summary-card strong {
  font-size: 1.7rem;
  font-weight: 700;
}

.admin-summary-card--alert {
  display: grid;
  gap: 8px;
}

.admin-summary-card--alert a {
  color: var(--accent-dark);
  font-weight: 800;
  text-decoration: none;
}

.admin-summary-card--alert a:hover,
.admin-summary-card--alert a:focus-visible {
  text-decoration: underline;
}

.admin-stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 18px;
}

.admin-statistics-page {
  color: #2f251c;
}

.admin-statistics-page .admin-page__header,
.admin-statistics-page .admin-summary-card,
.admin-statistics-page .admin-dashboard-panel,
.admin-statistics-page .admin-audit-panel {
  background: var(--control-bg-strong);
  border-color: color-mix(in srgb, var(--ink) 12%, transparent);
}

.admin-statistics-page h1,
.admin-statistics-page h2,
.admin-statistics-page strong,
.admin-statistics-page dd,
.admin-statistics-page .admin-stats-row span {
  color: #2f251c;
}

.admin-statistics-page .admin-page__copy,
.admin-statistics-page .admin-audit-panel__header p,
.admin-statistics-page .admin-dashboard-list__item p,
.admin-statistics-page .admin-dashboard-footnote,
.admin-statistics-page .admin-summary-card__label,
.admin-statistics-page .admin-stats-list dt {
  color: rgba(47, 37, 28, 0.72);
}

.admin-dashboard-panel {
  background: rgba(248, 245, 237, 0.92);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  border-radius: 24px;
  padding: 18px 20px;
  display: grid;
  gap: 14px;
}

.admin-users-list,
.admin-hidden-review-list {
  display: grid;
  gap: 16px;
}

.admin-user-card,
.admin-hidden-review-card,
.admin-empty-state {
  background: rgba(248, 245, 237, 0.92);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  border-radius: 24px;
  padding: 20px 22px;
}

.admin-contact-list {
  display: grid;
  gap: 16px;
}

.admin-contact-ticket {
  display: grid;
  gap: 14px;
  padding: 18px 20px;
  border-radius: 24px;
  background: rgba(248, 245, 237, 0.92);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
}

.admin-contact-ticket__header {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
}

.admin-contact-ticket__header h2,
.admin-contact-ticket__header p,
.admin-contact-ticket__message,
.admin-contact-ticket__reply p {
  margin: 0;
}

.admin-contact-ticket__header p,
.admin-contact-ticket__message,
.admin-contact-ticket__reply {
  color: color-mix(in srgb, var(--ink) 70%, transparent);
}

.admin-contact-ticket__status {
  display: inline-flex;
  margin-bottom: 8px;
  padding: 5px 10px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent-dark);
  font-size: max(20px, 0.78rem);
  font-weight: 800;
}

.admin-contact-ticket__message {
  white-space: pre-wrap;
  line-height: 1.65;
}

.admin-contact-ticket__reply {
  display: grid;
  gap: 6px;
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
}

.admin-contact-reply-form {
  display: grid;
  gap: 10px;
}

.admin-contact-reply-form label {
  display: grid;
  gap: 8px;
  font-weight: 800;
}

.admin-contact-reply-form textarea {
  width: 100%;
  min-height: 120px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--ink) 12%, transparent);
  background: rgba(255, 255, 255, 0.96);
  font: inherit;
  resize: vertical;
}

.admin-user-card__header,
.admin-hidden-review-card {
  display: grid;
  gap: 16px;
}

.admin-user-card__header {
  grid-template-columns: 1fr auto;
  align-items: start;
}

.admin-user-card__meta {
  margin: 6px 0 0;
  font-size: max(20px, 0.9rem);
  color: color-mix(in srgb, var(--ink) 56%, transparent);
}

.admin-user-card__badges,
.admin-user-card__stats,
.admin-hidden-review-card__meta {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.admin-user-card__stats div,
.admin-hidden-review-card__meta div {
  min-width: 160px;
}

.admin-user-card__stats dt,
.admin-hidden-review-card__meta dt {
  color: color-mix(in srgb, var(--ink) 56%, transparent);
  font-size: max(20px, 0.86rem);
}

.admin-user-card__stats dd,
.admin-hidden-review-card__meta dd {
  margin: 4px 0 0;
}

.admin-hidden-review-card__metadata {
  display: grid;
  gap: 12px;
  padding: 14px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.66);
  border: 1px solid color-mix(in srgb, var(--ink) 7%, transparent);
}

.admin-hidden-review-card__metadata label {
  display: grid;
  gap: 6px;
  color: color-mix(in srgb, var(--ink) 66%, transparent);
  font-weight: 700;
}

.admin-hidden-review-card__metadata textarea,
.admin-hidden-review-card__metadata input {
  width: 100%;
  border: 1px solid color-mix(in srgb, var(--ink) 12%, transparent);
  border-radius: 14px;
  padding: 12px 14px;
  background: var(--control-bg-strong);
  color: var(--ink);
  font: inherit;
}

.admin-hidden-review-card__metadata button {
  justify-self: start;
  border: 1px solid color-mix(in srgb, var(--ink) 12%, transparent);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.96);
  color: inherit;
  padding: 10px 16px;
  font: inherit;
  cursor: pointer;
}

.admin-user-card__notice {
  margin: 0;
  padding: 12px 14px;
  border-radius: 18px;
  background: rgba(255, 244, 230, 0.82);
  border: 1px solid color-mix(in srgb, var(--accent) 14%, transparent);
  color: color-mix(in srgb, var(--ink) 70%, transparent);
}

.admin-user-card__capabilities,
.admin-user-card__action-groups {
  display: grid;
  gap: 12px;
}

.admin-user-card__action-group {
  display: grid;
  gap: 10px;
  padding: 14px 16px;
  border-radius: 20px;
  background: rgba(248, 245, 237, 0.92);
  border: 1px solid color-mix(in srgb, var(--ink) 6%, transparent);
}

.admin-user-card__action-group strong {
  font-size: max(20px, 0.9rem);
}

.admin-user-card__action-group--danger {
  background: rgba(252, 241, 241, 0.92);
  border-color: rgba(158, 34, 34, 0.1);
}

.admin-badge {
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: max(20px, 0.84rem);
  background: color-mix(in srgb, var(--ink) 8%, transparent);
}

.admin-badge--admin {
  background: rgba(102, 74, 9, 0.12);
  color: #6e4c0f;
}

.admin-badge--reviewer {
  background: rgba(12, 92, 140, 0.12);
  color: #0d527b;
}

.admin-badge--banned,
.admin-user-card__danger {
  background: rgba(158, 34, 34, 0.12);
  color: #7e2727;
}

.admin-user-card__actions form,
.admin-hidden-review-card__actions form {
  margin: 0;
}

.admin-audit-panel {
  display: grid;
  gap: 14px;
}

.admin-audit-panel__header h2,
.admin-audit-panel__header p {
  margin: 0;
}

.admin-audit-panel__header p {
  margin-top: 8px;
  color: color-mix(in srgb, var(--ink) 62%, transparent);
}

.admin-audit-list {
  display: grid;
  gap: 10px;
}

.admin-audit-item {
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  border-radius: 18px;
  padding: 14px 16px;
  display: grid;
  gap: 8px;
}

.admin-audit-item__title {
  font-weight: 700;
}

.admin-audit-item__target {
  color: color-mix(in srgb, var(--ink) 78%, transparent);
  word-break: break-word;
}

.admin-audit-item__meta {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
  color: color-mix(in srgb, var(--ink) 56%, transparent);
  font-size: max(20px, 0.86rem);
}

.admin-audit-item__details {
  margin: 0;
  color: color-mix(in srgb, var(--ink) 64%, transparent);
  font-size: max(20px, 0.9rem);
}

.admin-top-reviewers,
.admin-dashboard-list {
  display: grid;
  gap: 10px;
}

.admin-top-reviewer,
.admin-dashboard-list__item {
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  border-radius: 18px;
  padding: 14px 16px;
}

.admin-stats-list {
  display: grid;
  gap: 10px;
  margin: 0;
}

.admin-stats-list div,
.admin-stats-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.admin-stats-list div {
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid color-mix(in srgb, var(--ink) 7%, transparent);
}

.admin-stats-list dt {
  color: color-mix(in srgb, var(--ink) 62%, transparent);
}

.admin-stats-list dd {
  margin: 0;
  font-weight: 800;
  color: var(--ink);
  white-space: nowrap;
}

.admin-stats-row span {
  flex: 0 0 auto;
  font-weight: 800;
  color: var(--ink);
}

.admin-top-reviewer {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.admin-top-reviewer p,
.admin-dashboard-list__item p {
  margin: 6px 0 0;
  color: color-mix(in srgb, var(--ink) 62%, transparent);
}

.admin-top-reviewer span {
  font-size: 1.4rem;
  font-weight: 700;
}

.admin-dashboard-footnote {
  margin: 0;
  color: color-mix(in srgb, var(--ink) 62%, transparent);
}

.hourly-prayers-admin__chooser,
.hourly-prayers-admin__meta,
.hourly-prayers-admin__form,
.hourly-prayers-admin__items,
.hourly-prayers-admin__item {
  display: grid;
  gap: 16px;
}

.hourly-prayers-admin__chooser {
  grid-template-columns: minmax(180px, 1fr) minmax(260px, 2fr) auto;
  align-items: end;
}

.hourly-prayers-admin label {
  display: grid;
  gap: 7px;
  font-weight: 700;
  color: var(--theme-text);
}

.hourly-prayers-admin input,
.hourly-prayers-admin select,
.hourly-prayers-admin textarea {
  width: 100%;
  border: 1px solid var(--theme-border);
  border-radius: 16px;
  background: var(--theme-surface-strong);
  color: var(--theme-text);
  font: inherit;
  padding: 11px 14px;
}

.hourly-prayers-admin textarea {
  resize: vertical;
  min-height: 140px;
  line-height: 1.75;
}

.hourly-prayers-admin__meta > div {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(320px, 2fr);
  gap: 14px;
}

.hourly-prayers-admin__toolbar,
.hourly-prayers-admin__item-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.hourly-prayers-admin__save {
  background: var(--theme-accent);
  color: var(--theme-accent-contrast);
}

.hourly-prayers-admin__item {
  border-inline-start: 5px solid color-mix(in srgb, var(--theme-accent) 60%, transparent);
}

@media (max-width: 760px) {
  .hourly-prayers-admin__chooser,
  .hourly-prayers-admin__meta > div {
    grid-template-columns: 1fr;
  }
}

.admin-hidden-review-card {
  grid-template-columns: minmax(220px, 320px) 1fr;
  align-items: start;
}

.admin-hidden-review-card img {
  width: 100%;
  max-width: 320px;
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: 18px;
  background: color-mix(in srgb, var(--ink) 8%, transparent);
}

.admin-hidden-review-card__body > p {
  margin: 8px 0 16px;
  color: color-mix(in srgb, var(--ink) 64%, transparent);
}

@media (max-width: 900px) {
  .admin-policy-grid,
  .admin-invitation-link,
  .admin-invitation-link__copy,
  .admin-invitation-form__grid,
  .admin-invitation-row,
  .admin-page__split,
  .admin-page__header,
  .admin-hidden-review-card,
  .admin-user-card__header {
    grid-template-columns: 1fr;
    flex-direction: column;
  }

  .admin-invitation-row__side {
    justify-items: start;
  }
}

.profile-page {
  display: grid;
  gap: 22px;
  padding: 8px 0 34px;
}

.profile-page__hero {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(260px, 0.9fr);
  gap: 18px;
  padding: 26px 28px;
  border-radius: 30px;
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--accent) 18%, transparent), transparent 28%),
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 96%, transparent), color-mix(in srgb, var(--control-bg) 94%, transparent));
  border: 1px solid var(--border-soft);
  color: var(--ink);
  box-shadow: 0 18px 36px var(--surface-shadow);
}

.profile-page__identity {
  display: flex;
  align-items: flex-start;
  gap: 20px;
}

.profile-page__identity-copy {
  display: grid;
  gap: 10px;
}

.profile-page__name-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
}

.profile-page__avatar-shell {
  flex: 0 0 auto;
}

.profile-page__avatar {
  width: 104px;
  height: 104px;
  border-radius: 28px;
  object-fit: cover;
  display: block;
  border: 1px solid rgba(151, 83, 35, 0.12);
  box-shadow: 0 14px 28px rgba(120, 84, 42, 0.12);
}

.profile-page__avatar--fallback {
  display: grid;
  place-items: center;
  background: linear-gradient(180deg, #d18a43, #b66427);
  color: #fffaf2;
  font-size: 2.6rem;
  font-weight: 700;
}

.profile-page__eyebrow {
  margin: 0 0 8px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: max(20px, 0.82rem);
  color: var(--accent);
}

.profile-page__hero h1 {
  margin: 0;
  font-size: clamp(2.2rem, 3.8vw, 3rem);
  line-height: 0.95;
}

.profile-page__type-badge {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--ink) 8%, var(--surface));
  border: 1px solid var(--border-soft);
  color: var(--muted-strong);
  font-size: max(18px, 0.84rem);
  font-weight: 700;
}

.profile-page__type-badge.is-admin {
  background: color-mix(in srgb, var(--accent) 16%, var(--surface));
  color: var(--accent-dark);
}

.profile-page__type-badge.is-ranked {
  background: rgba(232, 244, 250, 0.94);
  color: #0d527b;
}

.profile-page__type-badge.is-banned {
  background: rgba(252, 239, 239, 0.96);
  color: #8b2e2e;
}

.profile-page__subtitle {
  margin: 0;
  max-width: 52ch;
  color: var(--muted-strong);
}

.profile-page__role-list,
.profile-page__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.profile-page__role-chip,
.profile-page__meta-pill {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  background: var(--control-bg);
  border: 1px solid var(--border-soft);
  color: var(--muted-strong);
  font-size: max(20px, 0.92rem);
  font-weight: 600;
}

.profile-page__role-chip.is-positive {
  background: rgba(236, 248, 240, 0.96);
  color: #246440;
}

.profile-page__role-chip.is-warning {
  background: rgba(255, 244, 230, 0.96);
  color: var(--accent);
}

.profile-page__handle {
  margin: 0;
  color: #9a5926;
  font-weight: 700;
}

.profile-page__hero-stats {
  display: grid;
  gap: 12px;
}

.profile-page__quick-actions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}

.profile-page__hero-card,
.profile-page__panel,
.profile-page__flash {
  background: var(--surface);
  border: 1px solid var(--border-soft);
  color: var(--ink);
  box-shadow: 0 14px 30px var(--surface-shadow);
}

.profile-page__hero-card {
  display: grid;
  gap: 4px;
  padding: 16px 18px;
  border-radius: 22px;
}

.profile-page__hero-card--accent {
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 14%, var(--surface)), var(--surface));
  border-color: color-mix(in srgb, var(--accent) 30%, var(--border-soft));
}

.profile-page__hero-card span {
  color: var(--muted);
  font-size: max(20px, 0.92rem);
}

.profile-page__hero-card strong {
  font-size: 1.5rem;
}

.profile-page__inline-link {
  color: var(--accent);
  font-weight: 700;
  text-decoration: none;
}

.profile-page__flash {
  padding: 14px 16px;
  border-radius: 18px;
}

.profile-page__flash.is-success {
  background: rgba(236, 248, 240, 0.96);
  color: #246440;
}

.profile-page__flash.is-error {
  background: rgba(252, 239, 239, 0.96);
  color: #8b2e2e;
}

.profile-page__tabs {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 8px;
}

.profile-page__tab {
  padding: 11px 16px;
  border-radius: 999px;
  text-decoration: none;
  color: var(--muted-strong);
  background: var(--control-bg);
  border: 1px solid var(--border-soft);
}

.profile-page__tab.is-active {
  background: var(--accent);
  color: var(--on-accent);
  box-shadow: 0 12px 24px color-mix(in srgb, var(--accent) 22%, transparent);
}

.profile-page__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.profile-page__grid--top {
  align-items: start;
}

.profile-page__stack {
  display: grid;
  gap: 18px;
}

.profile-page__panel {
  padding: 22px;
  border-radius: 28px;
}

.profile-page__panel-header h2,
.profile-page__permission h3 {
  margin: 0;
}

.profile-page__panel-header p {
  margin: 8px 0 0;
  color: var(--muted);
}

.profile-page__panel-header--split {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
}

.profile-page__form {
  display: grid;
  gap: 14px;
  margin-top: 18px;
}

.profile-page__avatar-editor {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 18px;
  padding: 18px;
  border-radius: 24px;
  background: var(--control-bg);
  border: 1px solid var(--border-soft);
}

.profile-page__avatar-shell--editor .profile-page__avatar {
  width: 120px;
  height: 120px;
}

.profile-page__avatar-copy {
  display: grid;
  gap: 10px;
  align-content: start;
}

.profile-page__avatar-copy > p,
.profile-page__hint {
  margin: 0;
  color: var(--muted);
}

.profile-page__avatar-upload {
  display: grid;
  gap: 8px;
}

.profile-page__avatar-dropzone {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  min-height: 116px;
  padding: 16px;
  border: 1px dashed color-mix(in srgb, var(--accent) 42%, var(--border-soft));
  border-radius: 18px;
  background: color-mix(in srgb, var(--accent) 6%, var(--surface));
  cursor: pointer;
}

.profile-page__avatar-dropzone.is-dragging,
.profile-page__avatar-dropzone:focus-within {
  border-color: color-mix(in srgb, var(--accent) 72%, var(--border-soft));
  background: color-mix(in srgb, var(--accent) 11%, var(--surface));
}

.profile-page__avatar-dropzone strong {
  display: block;
  margin-bottom: 4px;
}

.profile-page__avatar-input {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.profile-page__avatar-file {
  display: block;
  margin-top: 6px;
  color: var(--muted-strong);
  font-weight: 700;
}

.profile-page__avatar-picker {
  min-height: 42px;
  padding-inline: 14px;
  border-radius: 14px;
  white-space: nowrap;
}

.profile-page__field small.profile-page__hint {
  display: block;
}

.profile-page__checkbox {
  display: inline-flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 16px;
  background: var(--control-bg);
  border: 1px solid var(--border-soft);
}

.profile-page__checkbox input {
  margin-top: 3px;
}

.profile-page__form--inline {
  margin-top: 0;
}

.profile-page__field {
  display: grid;
  gap: 6px;
}

.profile-page__field span {
  font-size: max(20px, 0.96rem);
  font-weight: 600;
  color: var(--muted-strong);
}

.profile-page__field input,
.profile-page__field textarea {
  width: 100%;
  border: 1px solid var(--control-border);
  border-radius: 18px;
  padding: 14px 16px;
  background: var(--control-bg-strong);
  color: var(--ink);
  font: inherit;
}

.profile-page__field textarea {
  resize: vertical;
}

.profile-page__validation {
  color: #9d3434;
  font-size: max(20px, 0.88rem);
}

.profile-page__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 0 20px;
  border: 0;
  border-radius: 18px;
  background: var(--accent);
  color: var(--on-accent);
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 14px 28px color-mix(in srgb, var(--accent) 22%, transparent);
}

.profile-page__button:disabled,
.profile-page__admin-actions button:disabled {
  opacity: 0.56;
  cursor: not-allowed;
  box-shadow: none;
}

.profile-page__button--secondary {
  background: var(--control-bg);
  color: var(--muted-strong);
  border: 1px solid var(--border-soft);
  box-shadow: none;
}

.profile-page__button--link {
  text-decoration: none;
}

.profile-page__field input:focus-visible,
.profile-page__field textarea:focus-visible,
.profile-page__button:focus-visible,
.profile-page__tab:focus-visible,
.profile-page__action-card:focus-visible,
.profile-page__card:focus-visible,
.profile-page__last-read a:focus-visible,
.profile-page__inline-link:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--accent) 36%, transparent);
  outline-offset: 2px;
}

.profile-page__summary-list,
.profile-page__permissions,
.profile-page__cards {
  display: grid;
  gap: 12px;
}

.profile-page__permissions {
  margin-top: 18px;
}

.profile-page__health-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
}

.profile-page__health-card {
  display: grid;
  gap: 6px;
  padding: 16px 18px;
  border-radius: 20px;
  background: var(--control-bg);
  border: 1px solid var(--border-soft);
}

.profile-page__health-card span {
  color: var(--muted);
  font-size: max(20px, 0.84rem);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.profile-page__health-card strong,
.profile-page__health-card p {
  margin: 0;
}

.profile-page__health-card p {
  color: var(--muted-strong);
}

.profile-page__health-card.is-good {
  background: rgba(241, 249, 243, 0.92);
  border-color: rgba(47, 131, 78, 0.14);
}

.profile-page__health-card.is-warning {
  background: rgba(255, 244, 230, 0.92);
  border-color: color-mix(in srgb, var(--accent) 18%, transparent);
}

.profile-page__health-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-top: 8px;
}

.profile-page__health-actions form {
  margin: 0;
}

.profile-page__health-card .profile-page__button {
  min-height: 42px;
  padding-inline: 14px;
  border-radius: 14px;
  box-shadow: none;
}

.profile-page__verification-form {
  display: grid;
  gap: 10px;
  margin-top: 10px;
  padding-top: 12px;
  border-top: 1px solid var(--border-soft);
}

.profile-page__action-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 12px;
  margin-top: 18px;
}

.profile-page__action-card {
  display: grid;
  gap: 8px;
  padding: 18px;
  border-radius: 22px;
  background: var(--control-bg);
  border: 1px solid var(--border-soft);
  color: var(--ink);
  text-decoration: none;
  box-shadow: 0 10px 22px var(--surface-shadow);
  transition: transform 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
}

.profile-page__action-card:hover,
.profile-page__action-card:focus-visible {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--accent) 26%, var(--border-soft));
  box-shadow: 0 16px 30px var(--surface-shadow);
}

.profile-page__action-card--accent,
.profile-page__action-card.is-accent {
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 14%, var(--surface)), var(--surface));
  border-color: color-mix(in srgb, var(--accent) 30%, var(--border-soft));
}

.profile-page__action-card span {
  color: var(--muted);
  font-size: max(20px, 0.88rem);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.profile-page__action-card strong {
  font-size: 1.1rem;
}

.profile-page__action-card p {
  margin: 0;
  color: var(--muted-strong);
}

.profile-page__action-card--notification {
  align-content: start;
}

.profile-page__notification-tests {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-block-start: 4px;
}

.profile-page__notification-tests .profile-page__button {
  min-height: 36px;
  padding: 7px 11px;
  border-radius: 12px;
  font-size: 0.86rem;
}

.profile-page__summary-list {
  margin-top: 18px;
}

.profile-page__summary-item {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 0;
  border-bottom: 1px solid var(--border-soft);
}

.profile-page__summary-item:last-child {
  border-bottom: 0;
}

.profile-page__summary-item span {
  color: var(--muted);
}

.profile-page__permission {
  padding: 14px 16px;
  border-radius: 18px;
  background: var(--control-bg);
  border: 1px solid var(--border-soft);
}

.profile-page__permission p {
  margin: 6px 0 0;
  color: var(--muted);
}

.profile-page__permission.is-enabled {
  background: rgba(241, 249, 243, 0.92);
  border-color: rgba(47, 131, 78, 0.14);
}

.profile-page__inline-notice {
  display: grid;
  gap: 6px;
  margin-top: 18px;
  padding: 16px 18px;
  border-radius: 20px;
  background: var(--control-bg);
  border: 1px solid var(--border-soft);
}

.profile-page__inline-notice p {
  margin: 0;
  color: var(--muted-strong);
}

.profile-page__inline-notice.is-warning {
  background: rgba(255, 244, 230, 0.96);
  border-color: color-mix(in srgb, var(--accent) 18%, transparent);
}

body.profile-avatar-crop-open {
  overflow: hidden;
}

.profile-page__crop-modal[hidden] {
  display: none;
}

.profile-page__crop-modal {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: grid;
  place-items: center;
  padding: 20px;
}

.profile-page__crop-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(24, 22, 20, 0.52);
  backdrop-filter: blur(5px);
}

.profile-page__crop-dialog {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 16px;
  width: min(540px, 100%);
  max-height: calc(100vh - 32px);
  overflow: auto;
  padding: 22px;
  border-radius: 24px;
  background: var(--surface);
  border: 1px solid var(--border-soft);
  color: var(--ink);
  box-shadow: 0 30px 70px rgba(24, 22, 20, 0.28);
}

.profile-page__crop-preview {
  width: min(360px, 100%);
  aspect-ratio: 1;
  margin-inline: auto;
  overflow: hidden;
  border-radius: 22px;
  border: 1px solid var(--border-soft);
  background:
    linear-gradient(45deg, rgba(0, 0, 0, 0.06) 25%, transparent 25%),
    linear-gradient(-45deg, rgba(0, 0, 0, 0.06) 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, rgba(0, 0, 0, 0.06) 75%),
    linear-gradient(-45deg, transparent 75%, rgba(0, 0, 0, 0.06) 75%);
  background-color: var(--control-bg);
  background-position: 0 0, 0 10px, 10px -10px, -10px 0;
  background-size: 20px 20px;
}

.profile-page__crop-preview canvas {
  display: block;
  width: 100%;
  height: 100%;
  cursor: grab;
  touch-action: none;
}

.profile-page__crop-preview canvas.is-panning {
  cursor: grabbing;
}

.profile-page__crop-zoom input {
  accent-color: var(--accent);
}

.profile-page__crop-zoom input[type="range"] {
  padding-inline: 0;
  background: transparent;
  border-color: transparent;
}

.profile-page__crop-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}

.profile-page__admin-summary {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  margin-top: 18px;
}

.profile-page__admin-summary article {
  display: grid;
  gap: 4px;
  padding: 14px 16px;
  border-radius: 18px;
  background: var(--control-bg);
  border: 1px solid var(--border-soft);
}

.profile-page__admin-summary span,
.profile-page__admin-user-meta,
.profile-page__admin-user-card small {
  color: var(--muted);
  font-size: max(18px, 0.84rem);
}

.profile-page__admin-summary strong {
  font-size: 1.35rem;
}

.profile-page__admin-toolbar {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(180px, 240px) auto auto;
  gap: 10px;
  align-items: center;
  margin-top: 18px;
}

.profile-page__admin-toolbar input,
.profile-page__admin-toolbar select {
  width: 100%;
  min-height: 50px;
  border: 1px solid var(--control-border);
  border-radius: 16px;
  padding: 0 14px;
  background: var(--control-bg-strong);
  color: var(--ink);
  font: inherit;
}

.profile-page__admin-users {
  display: grid;
  gap: 14px;
}

.profile-page__admin-user-card {
  display: grid;
  gap: 16px;
  padding: 20px;
  border-radius: 24px;
  background: var(--surface);
  border: 1px solid var(--border-soft);
  box-shadow: 0 12px 24px var(--surface-shadow);
}

.profile-page__admin-user-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: start;
}

.profile-page__admin-user-title {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.profile-page__admin-user-title h3,
.profile-page__admin-user-header p {
  margin: 0;
}

.profile-page__admin-user-meta {
  display: grid;
  gap: 4px;
  text-align: end;
}

.profile-page__admin-user-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin: 0;
}

.profile-page__admin-user-stats div {
  padding: 12px 14px;
  border-radius: 16px;
  background: var(--control-bg);
  border: 1px solid var(--border-soft);
}

.profile-page__admin-user-stats dt {
  color: var(--muted);
  font-size: max(18px, 0.82rem);
}

.profile-page__admin-user-stats dd {
  margin: 4px 0 0;
  color: var(--ink);
  font-weight: 700;
}

.profile-page__admin-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.profile-page__admin-actions form {
  margin: 0;
}

.profile-page__admin-actions button,
.profile-page__admin-edit-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 12px;
  border-radius: 12px;
  border: 1px solid var(--border-soft);
  background: var(--control-bg);
  color: var(--muted-strong);
  font: inherit;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
}

.profile-page__admin-actions .profile-page__danger-button {
  background: rgba(252, 239, 239, 0.96);
  color: #8b2e2e;
}

.profile-page__last-read {
  margin-top: 18px;
  padding: 16px 18px;
  border-radius: 20px;
  background: var(--control-bg);
}

.profile-page__last-read span,
.profile-page__security-strip span {
  display: block;
  color: var(--muted);
  font-size: max(20px, 0.9rem);
}

.profile-page__last-read a {
  display: inline-block;
  margin-top: 6px;
  color: var(--accent);
  font-weight: 700;
  text-decoration: none;
}

.profile-page__last-read p {
  margin: 8px 0 0;
  color: var(--muted-strong);
}

.profile-page__security-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
  padding: 16px 18px;
  border-radius: 22px;
  background: linear-gradient(180deg, var(--control-bg), var(--surface));
  border: 1px solid var(--border-soft);
}

.profile-page__mfa-setup,
.profile-page__mfa-state {
  display: grid;
  gap: 16px;
  margin-top: 18px;
  padding: 18px;
  border-radius: 22px;
  background: var(--control-bg);
  border: 1px solid var(--border-soft);
}

.profile-page__mfa-copy,
.profile-page__mfa-state p,
.profile-page__empty {
  margin: 0;
  color: var(--muted);
}

.profile-page__mfa-step {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}

.profile-page__mfa-step > span {
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: var(--accent);
  color: var(--on-accent);
  font-weight: 800;
  box-shadow: 0 10px 18px color-mix(in srgb, var(--accent) 22%, transparent);
}

.profile-page__mfa-step strong,
.profile-page__mfa-step p,
.profile-page__mfa-fallback p {
  margin: 0;
}

.profile-page__mfa-step p {
  color: var(--muted);
}

.profile-page__authenticator-apps {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 10px;
}

.profile-page__authenticator-apps a {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 54px;
  padding: 10px 12px;
  border-radius: 16px;
  background: var(--surface);
  border: 1px solid var(--border-soft);
  color: var(--ink);
  text-decoration: none;
  box-shadow: 0 8px 18px var(--surface-shadow);
}

.profile-page__authenticator-apps a:focus-visible,
.profile-page__authenticator-apps a:hover {
  outline: 3px solid rgba(189, 111, 46, 0.28);
  outline-offset: 2px;
  border-color: color-mix(in srgb, var(--accent) 30%, var(--border-soft));
}

.profile-page__authenticator-apps span {
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 16%, var(--surface));
  border: 1px solid color-mix(in srgb, var(--accent) 32%, var(--border-soft));
  color: var(--accent-dark);
  font-weight: 800;
}

.profile-page__authenticator-apps strong {
  font-size: max(18px, 0.96rem);
}

.profile-page__mfa-scan-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  align-items: stretch;
}

.profile-page__mfa-qr-card {
  display: grid;
  gap: 14px;
  padding: 16px;
  border-radius: 20px;
  background: var(--surface);
  border: 1px solid var(--border-soft);
  box-shadow: 0 10px 22px var(--surface-shadow);
}

.profile-page__mfa-qr-frame {
  display: grid;
  place-items: center;
  width: min(340px, 100%);
  aspect-ratio: 1;
  margin-inline: auto;
  padding: 14px;
  border-radius: 20px;
  background: #ffffff;
  border: 1px solid color-mix(in srgb, var(--ink) 12%, transparent);
}

.profile-page__mfa-qr {
  width: 100%;
  height: 100%;
  color: #111111;
}

.profile-page__mfa-secret {
  padding: 16px 18px;
  border-radius: 18px;
  background: var(--control-bg-strong);
  border: 1px dashed color-mix(in srgb, var(--accent) 28%, var(--border-soft));
  font-family: ui-monospace, SFMono-Regular, Consolas, monospace;
  font-size: 1.15rem;
  letter-spacing: 0.08em;
  overflow-wrap: anywhere;
}

.profile-page__mfa-fallback {
  display: grid;
  gap: 8px;
}

.profile-page__mfa-fallback summary {
  cursor: pointer;
  color: var(--accent);
  font-weight: 700;
}

.profile-page__mfa-fallback[open] {
  padding-top: 4px;
}

.profile-page__cards {
  margin-top: 18px;
}

.profile-page__review-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 18px;
}

.profile-page__review-preview {
  display: grid;
  gap: 16px;
  margin-top: 18px;
}

.profile-page__review-preview img {
  width: 100%;
  max-height: 360px;
  object-fit: cover;
  border-radius: 20px;
  border: 1px solid var(--border-soft);
  box-shadow: 0 12px 24px var(--surface-shadow);
}

.profile-page__review-preview-copy {
  display: grid;
  gap: 8px;
}

.profile-page__review-preview-copy strong,
.profile-page__review-preview-copy p {
  margin: 0;
}

.profile-page__review-preview-copy p {
  color: var(--muted);
}

.profile-page__review-votes {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.profile-page__review-votes span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: var(--control-bg);
  color: var(--muted-strong);
  font-size: max(20px, 0.92rem);
  font-weight: 600;
}

.profile-page__notice,
.profile-page__empty-state {
  display: grid;
  gap: 10px;
  margin-top: 18px;
  padding: 18px;
  border-radius: 22px;
  background: var(--control-bg);
  border: 1px solid var(--border-soft);
}

.profile-page__notice p,
.profile-page__empty-state p {
  margin: 0;
}

.profile-page__card {
  display: grid;
  gap: 8px;
  padding: 18px;
  border-radius: 22px;
  background: var(--surface);
  border: 1px solid var(--border-soft);
  text-decoration: none;
  color: var(--ink);
  box-shadow: 0 12px 24px var(--surface-shadow);
}

.profile-page__card span,
.profile-page__card small {
  color: var(--muted);
}

.profile-page__card p {
  margin: 0;
  color: var(--muted-strong);
}

.review-page-shell {
  display: grid;
  gap: 18px;
}

.review-page-shell__hero {
  padding: 26px 28px;
  border-radius: 30px;
  /* Theme-token-driven so the hero re-paints on midnight / dark / dawn /
     contrast. Previously baked in cream + brown; the user reported it
     "isn't styled properly" because on dark themes the cream gradient
     persisted under the dark layout. */
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--accent) 18%, transparent), transparent 32%),
    linear-gradient(180deg, var(--surface), color-mix(in srgb, var(--surface) 88%, var(--accent) 12%));
  border: 1px solid color-mix(in srgb, var(--accent) 14%, var(--border-soft));
  box-shadow: 0 18px 36px var(--surface-shadow);
  color: var(--ink);
}

.review-page-shell--images {
  gap: 12px;
}

.review-page-shell--images .review-page-shell__hero {
  padding: 14px 18px;
  border-radius: 18px;
  box-shadow: 0 10px 22px var(--surface-shadow);
}

.review-page-shell__hero h1 {
  margin: 6px 0 12px;
  color: var(--ink);
}

.review-page-shell--images .review-page-shell__hero h1 {
  margin: 2px 0 4px;
  font-size: 1.75rem;
}

.review-page-shell__hero p {
  margin: 0;
  max-width: 66ch;
  color: var(--muted-strong);
}

.review-page-shell--images .review-page-shell__hero p:not(.review-page-shell__eyebrow) {
  display: none;
}

.review-page-shell__eyebrow {
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: max(20px, 0.82rem);
  color: var(--accent);
}

.image-review-page--embedded {
  padding-top: 0;
}

/* ==========================================================
   Audio voice reviewer — sibling layout to .image-review-*
   reusing the same shape (sidebar + main card with mode tabs,
   stage, action row, votes, etc). The audio variant just
   swaps the image stage for an <audio> player.
   ========================================================== */
.audio-review-page,
.audio-review-card,
.audio-review-card--summary,
.audio-review-card--notes,
.audio-review-card--main,
.audio-review-card__eyebrow,
.audio-review-card__copy,
.audio-review-stats,
.audio-review-stats div,
.audio-review-stats dt,
.audio-review-stats dd,
.audio-review-page__sidebar,
.audio-review-main__header,
.audio-review-main__subtitle,
.audio-review-mode,
.audio-review-mode__tab,
.audio-review-cleanup,
.audio-review-stage,
.audio-review-actions,
.audio-review-button,
.audio-review-button--yes,
.audio-review-button--no,
.audio-review-button--skip,
.audio-review-button--hide,
.audio-review-empty,
.audio-review-status,
.audio-review-votes,
.audio-review-vote,
.audio-review-vote--yes,
.audio-review-vote--no,
.audio-review-vote__count,
.audio-review-compare,
.audio-review-compare__grid,
.audio-review-compare__actions,
.audio-review-pair-card,
.audio-review-pair-card__meta {
  /* Inherit nothing — the rules below set what's needed. */
}

.audio-review-page {
  display: grid;
  grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
  gap: 24px;
  align-items: start;
}

.audio-review-card {
  background: var(--control-bg-strong);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  border-radius: 30px;
  box-shadow: 0 18px 40px color-mix(in srgb, var(--ink) 8%, transparent);
}

.audio-review-page__sidebar {
  display: grid;
  gap: 18px;
  position: sticky;
  top: 126px;
}

.audio-review-card--summary,
.audio-review-card--notes {
  padding: 22px 24px;
}

.audio-review-card__eyebrow {
  margin: 0 0 8px;
  font-size: max(20px, 0.78rem);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--ink) 54%, transparent);
}

.audio-review-card__copy,
.audio-review-main__subtitle {
  margin: 12px 0 0;
  color: color-mix(in srgb, var(--ink) 72%, transparent);
  line-height: 1.55;
}

.audio-review-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 20px 0 0;
}

.audio-review-stats div {
  display: grid;
  gap: 4px;
  padding: 14px 16px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.76);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
}

.audio-review-stats dt {
  font-size: max(20px, 0.88rem);
  color: color-mix(in srgb, var(--ink) 62%, transparent);
}

.audio-review-stats dd {
  margin: 0;
  font-size: 1.55rem;
  font-weight: 700;
}

.audio-review-card--main {
  padding: 22px 24px 24px;
  display: grid;
  gap: 18px;
}

.audio-review-mode {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  background: rgba(255, 255, 255, 0.78);
  margin-bottom: 4px;
  flex-wrap: wrap;
}

.audio-review-mode__tab {
  padding: 8px 16px;
  border-radius: 999px;
  border: 0;
  background: transparent;
  color: color-mix(in srgb, var(--ink) 72%, transparent);
  font: inherit;
  font-weight: 700;
  font-size: 0.86rem;
  cursor: pointer;
  transition: background-color 140ms ease, color 140ms ease;
}

.audio-review-mode__tab:hover,
.audio-review-mode__tab:focus-visible {
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent-dark);
  outline: none;
}

.audio-review-mode__tab.is-active {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  color: var(--accent-dark);
}

.audio-review-main__header {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 18px;
}

.audio-review-stage {
  position: relative;
  min-height: min(28vh, 220px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 22px;
  border-radius: 26px;
  background:
    radial-gradient(circle at top, color-mix(in srgb, var(--accent) 8%, transparent), transparent 55%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.64), rgba(255, 255, 255, 0.5));
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
}

.audio-review-stage audio {
  width: 100%;
  max-width: 540px;
}

.audio-review-empty {
  max-width: 420px;
  text-align: center;
  display: grid;
  gap: 8px;
  padding: 26px 24px;
  border-radius: 24px;
  background: var(--control-bg);
  border: 1px dashed color-mix(in srgb, var(--accent) 24%, transparent);
  color: color-mix(in srgb, var(--ink) 72%, transparent);
}

.audio-review-empty h4,
.audio-review-empty p {
  margin: 0;
}

.audio-review-actions {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

@media (max-width: 720px) {
  .audio-review-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.audio-review-button {
  min-height: 52px;
  padding: 12px 16px;
  border-radius: 18px;
  border: 1px solid color-mix(in srgb, var(--ink) 10%, transparent);
  background: rgba(255, 255, 255, 0.85);
  color: var(--ink);
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background-color 0.18s ease;
}

.audio-review-button:hover,
.audio-review-button:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 12px 28px color-mix(in srgb, var(--ink) 12%, transparent);
  outline: none;
}

.audio-review-button:disabled {
  cursor: not-allowed;
  opacity: 0.46;
  transform: none;
  box-shadow: none;
}

.audio-review-button--yes {
  background: rgba(31, 122, 77, 0.1);
  border-color: rgba(31, 122, 77, 0.24);
  color: #1f7a4d;
}

.audio-review-button--no {
  background: rgba(166, 66, 42, 0.1);
  border-color: rgba(166, 66, 42, 0.22);
  color: #a6422a;
}

.audio-review-button--skip {
  background: color-mix(in srgb, var(--ink) 6%, transparent);
  border-color: color-mix(in srgb, var(--ink) 16%, transparent);
  color: color-mix(in srgb, var(--ink) 70%, transparent);
}

.audio-review-button--hide {
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  border-color: color-mix(in srgb, var(--accent) 22%, transparent);
  color: var(--accent-dark);
}

.audio-review-status {
  margin: 0;
  color: color-mix(in srgb, var(--ink) 66%, transparent);
}

.audio-review-votes {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.audio-review-vote {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 34px;
  padding: 3px 12px 3px 8px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--ink) 10%, transparent);
  background: rgba(255, 255, 255, 0.82);
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  font-size: 0.95rem;
  line-height: 1;
}

.audio-review-vote svg {
  width: 16px;
  height: 16px;
  flex: 0 0 16px;
}

.audio-review-vote--yes {
  color: #176d44;
  background: rgba(31, 122, 77, 0.12);
  border-color: rgba(31, 122, 77, 0.28);
}

.audio-review-vote--no {
  color: #8c3823;
  background: rgba(166, 66, 42, 0.12);
  border-color: rgba(166, 66, 42, 0.26);
}

.audio-review-compare {
  display: grid;
  gap: 16px;
}

.audio-review-compare__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

@media (max-width: 820px) {
  .audio-review-compare__grid {
    grid-template-columns: 1fr;
  }
}

.audio-review-pair-card {
  display: grid;
  gap: 10px;
  padding: 14px;
  border-radius: 22px;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  background: var(--control-bg);
}

.audio-review-pair-card audio {
  width: 100%;
}

.audio-review-pair-card__meta {
  margin: 0;
  font-size: 0.86rem;
  color: color-mix(in srgb, var(--ink) 62%, transparent);
  text-align: center;
  font-weight: 600;
}

.audio-review-compare__actions {
  display: flex;
  justify-content: flex-end;
}

@media (max-width: 1100px) {
  .audio-review-page {
    grid-template-columns: 1fr;
  }
  .audio-review-page__sidebar {
    position: static;
  }
}

/* Dark theme parity — re-paint each surface through tokens. */
:root[data-theme] .audio-review-card,
:root[data-theme] .audio-review-stats div,
:root[data-theme] .audio-review-vote,
:root[data-theme] .audio-review-button,
:root[data-theme] .audio-review-empty,
:root[data-theme] .audio-review-pair-card {
  background: var(--surface);
  border-color: var(--border-soft);
  color: var(--ink);
  box-shadow: 0 16px 38px var(--surface-shadow);
}

:root[data-theme] .audio-review-stats div,
:root[data-theme] .audio-review-vote,
:root[data-theme] .audio-review-button {
  background: var(--control-bg);
  box-shadow: none;
}

:root[data-theme] .audio-review-mode {
  background: var(--control-bg);
  border-color: var(--border-soft);
}

:root[data-theme] .audio-review-mode__tab {
  color: var(--muted-strong);
}

:root[data-theme] .audio-review-mode__tab.is-active {
  background: color-mix(in srgb, var(--accent) 22%, transparent);
  color: var(--ink);
}

:root[data-theme] .audio-review-card__eyebrow {
  color: var(--muted);
}

:root[data-theme] .audio-review-card__copy,
:root[data-theme] .audio-review-main__subtitle,
:root[data-theme] .audio-review-stats dt,
:root[data-theme] .audio-review-status,
:root[data-theme] .audio-review-pair-card__meta {
  color: var(--muted-strong);
}

:root[data-theme] .audio-review-stage {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 70%, transparent), color-mix(in srgb, var(--surface) 56%, transparent)),
    radial-gradient(circle at top, color-mix(in srgb, var(--accent) 10%, transparent), transparent 55%);
  border-color: var(--border-soft);
}

:root[data-theme] .audio-review-button--yes {
  background: color-mix(in srgb, var(--success, #1f7a4d) 16%, var(--surface));
  border-color: color-mix(in srgb, var(--success, #1f7a4d) 40%, var(--border-soft));
  color: color-mix(in srgb, var(--success, #1f7a4d) 78%, var(--ink));
}

:root[data-theme] .audio-review-button--no {
  background: color-mix(in srgb, var(--danger, #a6422a) 16%, var(--surface));
  border-color: color-mix(in srgb, var(--danger, #a6422a) 40%, var(--border-soft));
  color: color-mix(in srgb, var(--danger, #a6422a) 78%, var(--ink));
}

:root[data-theme] .audio-review-button--hide {
  background: color-mix(in srgb, var(--accent) 16%, var(--surface));
  border-color: color-mix(in srgb, var(--accent) 40%, var(--border-soft));
  color: var(--accent-dark);
}

:root[data-theme] .audio-review-button--skip {
  background: color-mix(in srgb, var(--ink) 8%, var(--surface));
  border-color: var(--border-soft);
  color: var(--muted-strong);
}

:root[data-theme] .audio-review-vote--yes {
  background: color-mix(in srgb, var(--success, #1f7a4d) 18%, var(--surface));
  border-color: color-mix(in srgb, var(--success, #1f7a4d) 40%, var(--border-soft));
  color: color-mix(in srgb, var(--success, #1f7a4d) 78%, var(--ink));
}

:root[data-theme] .audio-review-vote--no {
  background: color-mix(in srgb, var(--danger, #a6422a) 18%, var(--surface));
  border-color: color-mix(in srgb, var(--danger, #a6422a) 40%, var(--border-soft));
  color: color-mix(in srgb, var(--danger, #a6422a) 78%, var(--ink));
}

/* Keyboard shortcut hints under the workspace status line. Same shape
   for image, audio, and BG music reviewers so the typography reads
   consistently across all three. */
.image-review-shortcuts,
.audio-review-shortcuts {
  margin: 4px 0 0;
  font-size: 0.8rem;
  color: color-mix(in srgb, var(--ink) 55%, transparent);
  display: flex;
  flex-wrap: wrap;
  gap: 6px 10px;
  align-items: center;
}

.image-review-shortcuts kbd,
.audio-review-shortcuts kbd {
  display: inline-block;
  min-width: 18px;
  padding: 2px 6px;
  margin-inline-end: 2px;
  border: 1px solid color-mix(in srgb, var(--ink) 18%, transparent);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.85);
  font: 700 0.78rem/1 ui-monospace, "SF Mono", "Cascadia Mono", Menlo, Consolas, monospace;
  color: color-mix(in srgb, var(--ink) 78%, transparent);
  box-shadow: 0 1px 0 color-mix(in srgb, var(--ink) 12%, transparent);
  text-align: center;
}

:root[data-theme] .image-review-shortcuts,
:root[data-theme] .audio-review-shortcuts {
  color: var(--muted);
}

:root[data-theme] .image-review-shortcuts kbd,
:root[data-theme] .audio-review-shortcuts kbd {
  background: var(--control-bg);
  border-color: var(--border-soft);
  color: var(--ink);
  box-shadow: 0 1px 0 color-mix(in srgb, var(--ink) 18%, transparent);
}

/* Background music reviewer — two-layer stage (track + verse overlay) */
.bg-music-stage__layers {
  display: grid;
  gap: 14px;
  width: 100%;
  max-width: 640px;
}

.bg-music-stage__layer {
  display: grid;
  gap: 6px;
}

.bg-music-stage__layer-label {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: color-mix(in srgb, var(--ink) 60%, transparent);
}

.bg-music-stage__layer audio {
  width: 100%;
}

.bg-music-overlay-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
  font-size: 0.92rem;
}

:root[data-theme] .bg-music-stage__layer-label {
  color: var(--muted-strong);
}

@media (max-width: 1100px) {
  .profile-page__hero,
  .profile-page__grid {
    grid-template-columns: 1fr;
  }

  .profile-page__quick-actions,
  .profile-page__action-grid,
  .profile-page__admin-summary,
  .profile-page__admin-user-stats {
    grid-template-columns: 1fr;
  }

  .profile-page__admin-toolbar,
  .profile-page__admin-user-header {
    grid-template-columns: 1fr;
  }

  .profile-page__admin-user-meta {
    text-align: start;
  }
}

@media (max-width: 720px) {
  .profile-page__hero {
    padding: 22px 18px;
    border-radius: 24px;
  }

  .profile-page__identity {
    align-items: flex-start;
    flex-direction: column;
  }

  .profile-page__avatar-editor {
    grid-template-columns: 1fr;
  }

  .profile-page__avatar-dropzone {
    grid-template-columns: 1fr;
  }

  .profile-page__crop-dialog {
    padding: 18px;
    border-radius: 20px;
  }

  .profile-page__crop-actions .profile-page__button {
    flex: 1 1 160px;
  }

  .profile-page__role-list,
  .profile-page__meta,
  .profile-page__panel-header--split {
    flex-direction: column;
    align-items: flex-start;
  }

  .profile-page__panel {
    padding: 18px;
    border-radius: 22px;
  }

  .profile-page__security-strip {
    grid-template-columns: 1fr;
  }

  .profile-page__health-grid {
    grid-template-columns: 1fr;
  }

  .profile-page__mfa-scan-grid {
    grid-template-columns: 1fr;
  }

  .profile-page__summary-item {
    flex-direction: column;
    gap: 4px;
  }

  .profile-page__review-actions {
    flex-direction: column;
  }

  .review-page-shell__hero {
    padding: 22px 18px;
    border-radius: 24px;
  }
}

.bible-browser__eyebrow--link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  min-height: 34px;
  padding: 6px 14px;
  border-radius: 999px;
  border: 1px solid rgba(151, 83, 35, 0.16);
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  text-decoration: none;
  color: rgba(151, 83, 35, 0.86);
  font-weight: 700;
  font-size: max(20px, 0.94rem);
  letter-spacing: 0.04em;
  text-transform: none;
  box-shadow: 0 8px 18px rgba(151, 83, 35, 0.08);
}

.bible-browser__eyebrow--link:hover,
.bible-browser__eyebrow--link:focus-visible {
  color: var(--accent-dark);
}

.bible-browser__navigator-meta {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  width: 100%;
}

.bible-browser__navigator-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  color: rgba(88, 52, 24, 0.88);
  font-size: max(20px, 0.94rem);
}

.bible-browser__navigator--books {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr);
  gap: 14px;
}

.bible-browser__nav-group--hero-only {
  width: min(100%, 920px);
  max-width: 920px;
  margin: 0 auto;
}

.bible-browser__nav-group--hero-only select {
  min-height: 52px;
  padding: 12px 16px;
  font-size: max(20px, 1rem);
}

.bible-browser__hero.is-expanded .bible-browser__navigator--books {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr);
  justify-items: center;
  width: 100%;
}

.bible-browser__hero.is-expanded .bible-browser__navigator--books .bible-browser__nav-group--hero-only {
  display: grid !important;
  flex: none !important;
  width: min(100%, 920px) !important;
  max-width: 600px !important;
  min-width: 0 !important;
}

.bible-browser__hero.is-expanded .bible-browser__navigator--books .bible-browser__nav-group--hero-only select {
  width: 100% !important;
}

.bible-browser__hero.is-expanded .bible-browser__navigator--books .bible-browser__navigator-meta {
  max-width: 920px;
  margin: 0 auto;
}

@media (max-width: 720px) {
  .bible-browser__nav-group--hero-only {
    width: 100%;
  }

  .bible-browser__navigator-meta {
    justify-content: flex-start;
  }
}

body[data-page="bible-browser"]:has(.bible-browser--reader) {
  overflow: hidden;
}

body[data-page="bible-browser"]:has(.bible-browser--reader) .content {
  flex: 1 1 auto;
  min-height: 0;
  height: calc((100vh - 88px) * var(--ui-zoom-inverse));
  overflow: hidden;
  padding-bottom: 10px;
}

.bible-browser--reader {
  --reader-audio-card-height: 255px;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 14px;
  height: 100%;
  min-height: 0;
  overflow: hidden;
}

.bible-browser--reader .chapter-reader {
  height: 100%;
  min-height: 0 !important;
  align-items: stretch;
  overflow: hidden;
}

.bible-browser--reader .chapter-reader__main,
.bible-browser--reader .chapter-reader__media {
  align-self: stretch;
  height: 100%;
  min-height: 0;
  overflow: hidden;
}

.bible-browser--reader .chapter-reader__sheet {
  height: 100%;
  max-height: none;
  min-height: 0;
}

.bible-browser--reader .chapter-reader__verses {
  min-height: 0;
  overflow: auto;
  overscroll-behavior: contain;
}

.chapter-reader__verses[dir="rtl"],
.chapter-reader__verses[dir="rtl"] .chapter-reader__verse {
  direction: rtl;
  text-align: right;
}

.chapter-reader__verses[dir="ltr"],
.chapter-reader__verses[dir="ltr"] .chapter-reader__verse {
  direction: ltr;
  text-align: left;
}

.chapter-reader__verses[dir="rtl"] .chapter-reader__verse-text,
.chapter-reader__verses[dir="rtl"] .chapter-reader__verse-segment {
  direction: rtl;
  unicode-bidi: isolate;
}

.chapter-reader__verses[dir="rtl"] .chapter-reader__verse-text,
.chapter-reader__verses[dir="rtl"] .chapter-reader__verse-segment,
.chapter-reader[data-reader-default-font="naskh"] .chapter-reader__verse-text,
.chapter-reader[data-reader-default-font="naskh"] .chapter-reader__verse-segment {
  line-height: 2.22;
}

.chapter-reader__verses[dir="ltr"] .chapter-reader__verse-text,
.chapter-reader__verses[dir="ltr"] .chapter-reader__verse-segment {
  direction: ltr;
  unicode-bidi: isolate;
}

.bible-browser--reader .chapter-reader__media-sticky {
  position: static;
  top: auto;
  display: flex;
  flex-direction: column;
  gap: 16px;
  height: 100%;
  max-height: none;
  min-height: 0;
  overflow: visible;
  overscroll-behavior: auto;
  padding-inline-end: 0;
}

.bible-browser--reader .verse-media-card--audio {
  flex: 0 0 auto;
  height: auto;
  min-height: 220px;
  max-height: none;
  overflow: visible;
}

.bible-browser--reader .chapter-reader__media-gallery {
  flex: 1 1 auto;
  height: auto;
  min-height: 0;
  overflow: hidden;
}

.bible-browser--reader .chapter-reader__media-gallery .product-gallery {
  grid-template-columns: minmax(68px, 84px) minmax(0, 1fr);
  align-items: stretch;
  flex: 1 1 auto;
  height: 100%;
  min-height: 0;
  overflow: hidden;
}

.bible-browser--reader .chapter-reader__media-gallery .product-gallery__thumbs {
  align-content: start;
  max-height: none;
  min-height: 0;
  overflow: hidden auto;
  overscroll-behavior: contain;
}

.bible-browser--reader .chapter-reader__media-gallery .product-gallery__stage {
  display: flex;
  align-self: stretch;
  min-width: 0;
  min-height: 0;
  overflow: hidden;
}

.bible-browser--reader .chapter-reader__media-gallery .product-gallery__main {
  width: 100%;
  height: 100%;
  max-height: none;
  min-height: 0;
  aspect-ratio: auto;
}

.bible-browser--reader .chapter-reader__media-gallery .product-gallery__main img,
.bible-browser--reader .chapter-reader__media-gallery .product-gallery__main video {
  width: 100%;
  height: 100%;
  min-height: 0;
  object-fit: cover;
}

@media (max-width: 1300px) {
  body[data-page="bible-browser"]:has(.bible-browser--reader) .content {
    width: 96%;
  }

  body[data-page="bible-browser"]:has(.bible-browser--reader) .bible-browser__hero--reader-top,
  body[data-page="bible-browser"]:has(.bible-browser--reader) .bible-browser--reader {
    width: 100%;
  }
}

@media (max-width: 1100px) {
  .bible-browser--reader .chapter-reader__media-gallery .product-gallery {
    grid-template-columns: 74px minmax(0, 1fr);
  }
}

@media (max-width: 1060px) {
  body[data-page="bible-browser"]:has(.bible-browser--reader) .site-header .shell {
    width: 98%;
    flex-wrap: nowrap;
    gap: 10px;
    padding: 8px 0;
  }

  body[data-page="bible-browser"]:has(.bible-browser--reader) .logo {
    font-size: max(20px, 1rem);
    letter-spacing: 0.05em;
    white-space: nowrap;
  }

  body[data-page="bible-browser"]:has(.bible-browser--reader) .header-search {
    flex: 0 1 260px;
    min-width: 140px;
    max-width: 260px;
    padding: 5px 8px 5px 12px;
  }

  body[data-page="bible-browser"]:has(.bible-browser--reader) .header-search input {
    min-width: 0;
    font-size: max(20px, 0.95rem);
  }

  body[data-page="bible-browser"]:has(.bible-browser--reader) .search-icon-button--header {
    width: 32px;
    height: 32px;
  }

  body[data-page="bible-browser"]:has(.bible-browser--reader) .nav {
    flex: 1 1 auto;
    flex-wrap: nowrap;
    justify-content: flex-end;
    min-width: 0;
    gap: 12px;
    overflow: auto hidden;
    scrollbar-width: none;
    font-size: max(20px, 1rem);
  }

  body[data-page="bible-browser"]:has(.bible-browser--reader) .nav::-webkit-scrollbar {
    display: none;
  }

  body[data-page="bible-browser"]:has(.bible-browser--reader) .nav a,
  body[data-page="bible-browser"]:has(.bible-browser--reader) .nav-user {
    flex: 0 0 auto;
    white-space: nowrap;
  }

  body[data-page="bible-browser"]:has(.bible-browser--reader) .viewport-zoom-controls {
    flex: 0 0 auto;
  }

  body[data-page="bible-browser"]:has(.bible-browser--reader) .bible-browser__hero--reader-top {
    padding: 8px 12px;
  }

  body[data-page="bible-browser"]:has(.bible-browser--reader) .bible-browser__hero--reader-top.is-collapsed .bible-browser__hero-bar--compact {
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 12px;
  }

  body[data-page="bible-browser"]:has(.bible-browser--reader) .bible-browser__hero--reader-top.is-collapsed .bible-browser__navigator--compact {
    justify-content: flex-end;
    overflow: auto hidden;
    scrollbar-width: none;
  }

  body[data-page="bible-browser"]:has(.bible-browser--reader) .bible-browser__hero--reader-top.is-collapsed .bible-browser__navigator--compact::-webkit-scrollbar {
    display: none;
  }
}

@media (max-width: 1000px) {
  .bible-browser--reader {
    --reader-audio-card-height: 255px;
    height: auto;
    overflow: visible;
  }

  body[data-page="bible-browser"]:has(.bible-browser--reader) {
    overflow: auto;
  }

  body[data-page="bible-browser"]:has(.bible-browser--reader) .content {
    height: auto;
    min-height: calc((100vh - 88px) * var(--ui-zoom-inverse));
    overflow: visible;
    padding-bottom: 18px;
  }

  .bible-browser--reader .chapter-reader {
    height: auto;
    min-height: 0 !important;
    overflow: visible;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
  }

  .bible-browser--reader .chapter-reader:has(.chapter-reader__media) {
    grid-template-rows: calc((100vh - 156px) * var(--ui-zoom-inverse)) auto;
  }

  .bible-browser--reader .chapter-reader__main {
    height: calc((100vh - 156px) * var(--ui-zoom-inverse));
    min-height: calc((100vh - 156px) * var(--ui-zoom-inverse));
    max-height: calc((100vh - 156px) * var(--ui-zoom-inverse));
    overflow: hidden;
  }

  .bible-browser--reader .chapter-reader__sheet {
    height: 100%;
    min-height: 0;
    max-height: none;
  }

  .bible-browser--reader .chapter-reader__verses {
    overflow: auto;
    overscroll-behavior: contain;
  }

  .bible-browser--reader .chapter-reader__media,
  .bible-browser--reader .chapter-reader__media-sticky {
    height: auto;
    overflow: visible;
  }

  .bible-browser--reader .verse-media-card--audio {
    flex: 0 0 auto;
  }

  .bible-browser--reader .chapter-reader__media-gallery {
    height: auto;
    min-height: 420px;
  }

  .bible-browser--reader .chapter-reader__media-gallery .product-gallery {
    min-height: 390px;
  }

  .chapter-reader__text-controls {
    right: 14px;
    bottom: 14px;
  }

  .chapter-reader__font-popover {
    right: 0;
    border-radius: 22px;
    flex-wrap: wrap;
  }
}

@media (max-width: 800px) {
  body[data-page="bible-browser"]:has(.bible-browser--reader) .site-header .shell {
    flex-wrap: wrap;
    row-gap: 8px;
  }

  body[data-page="bible-browser"]:has(.bible-browser--reader) .nav {
    order: 1;
    flex: 1 1 100%;
    justify-content: center;
    max-width: 100%;
    min-width: 0;
    width: 100%;
  }

  body[data-page="bible-browser"]:has(.bible-browser--reader) .logo {
    order: 2;
  }

  body[data-page="bible-browser"]:has(.bible-browser--reader) .header-search {
    order: 3;
    flex: 1 1 180px;
    max-width: none;
  }

  body[data-page="bible-browser"]:has(.bible-browser--reader) .site-language-switcher {
    order: 4;
    margin-inline-start: auto;
  }

  body[data-page="bible-browser"]:has(.bible-browser--reader) .viewport-zoom-controls {
    order: 5;
    margin-inline-start: 0;
  }
}

@media (max-width: 730px) {
  .bible-browser--reader .chapter-reader__media-gallery .product-gallery {
    grid-template-columns: 1fr;
    grid-template-rows: auto minmax(0, 1fr);
    align-items: stretch;
    min-height: 0;
  }

  .bible-browser--reader .chapter-reader__media-gallery .product-gallery__thumbs {
    display: flex;
    flex-direction: row;
    gap: 10px;
    max-height: none;
    min-height: 0;
    overflow: auto hidden;
    padding: 0 0 4px;
    scrollbar-width: thin;
  }

  .bible-browser--reader .chapter-reader__media-gallery .product-gallery__thumb {
    flex: 0 0 72px;
    width: 72px;
  }

  .bible-browser--reader .chapter-reader__media-gallery .product-gallery__stage {
    display: block;
    overflow: visible;
  }

  .bible-browser--reader .chapter-reader__media-gallery .product-gallery__main {
    aspect-ratio: 4 / 5;
    height: auto;
    max-height: none;
  }

  .bible-browser--reader .chapter-reader__media-gallery .product-gallery__main img,
  .bible-browser--reader .chapter-reader__media-gallery .product-gallery__main video {
    height: auto;
    aspect-ratio: 4 / 5;
  }
}

@media (max-width: 960px) {
  .bible-browser:not(.bible-browser--reader) .bible-browser__hero.is-expanded {
    padding: 14px 16px;
    overflow: hidden;
  }

  .bible-browser:not(.bible-browser--reader) .bible-browser__hero.is-expanded .bible-browser__hero-bar--expanded {
    grid-template-columns: minmax(0, 1fr);
    justify-items: stretch;
    gap: 14px;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    overflow: hidden;
  }

  .bible-browser:not(.bible-browser--reader) .bible-browser__hero.is-expanded .bible-browser__intro {
    justify-items: start;
    text-align: start;
  }

  .bible-browser:not(.bible-browser--reader) .bible-browser__hero.is-expanded .bible-browser__intro h1 {
    font-size: clamp(2rem, 5vw, 2.7rem);
    line-height: 1;
  }

  .bible-browser:not(.bible-browser--reader) .bible-browser__hero.is-expanded .bible-browser__intro p {
    max-width: none;
  }

  .bible-browser:not(.bible-browser--reader) .bible-browser__hero.is-expanded .bible-browser__navigator--expanded:not(.bible-browser__navigator--books) {
    display: flex !important;
    flex-wrap: wrap;
    justify-content: stretch;
    align-items: end;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    margin: 0;
    gap: 12px;
    overflow: visible;
  }

  .bible-browser:not(.bible-browser--reader) .bible-browser__hero.is-expanded .bible-browser__navigator--expanded:not(.bible-browser__navigator--books) .bible-browser__nav-group {
    flex: 1 1 220px;
    min-width: 0;
    max-width: 100%;
  }

  .bible-browser:not(.bible-browser--reader) .bible-browser__hero.is-expanded .bible-browser__navigator--expanded:not(.bible-browser__navigator--books) .bible-browser__nav-group select {
    width: 100%;
    min-width: 0;
  }
}

@media (max-width: 500px) {
  body[data-page="bible-browser"] .bible-browser__book-grid,
  body[data-page="bible-browser"] .chapter-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
  }

  body[data-page="bible-browser"] .book-card,
  body[data-page="bible-browser"] .chapter-card {
    min-height: 0;
    aspect-ratio: 4 / 5;
    padding: 12px;
    border-radius: 18px;
  }

  body[data-page="bible-browser"] .book-card__body,
  body[data-page="bible-browser"] .chapter-card__body {
    gap: 4px;
  }

  body[data-page="bible-browser"] .book-card__meta,
  body[data-page="bible-browser"] .chapter-card__meta {
    font-size: max(20px, 0.78rem) !important;
    letter-spacing: 0.06em;
  }

  body[data-page="bible-browser"] .book-card__body h2,
  body[data-page="bible-browser"] .chapter-card__label {
    font-size: max(20px, 1.28rem);
    line-height: 1.04;
  }

  body[data-page="bible-browser"] .book-card__body p {
    font-size: max(20px, 0.95rem);
    line-height: 1.28;
  }

  body[data-page="bible-browser"] .chapter-card__bookmark-indicator {
    width: 34px;
    inset-block-start: -3px;
    inset-inline-end: 8px;
    top: -3px;
    z-index: 44;
  }

  body[data-page="bible-browser"] .chapter-card--bookmarked::before {
    width: 44px;
    height: 44px;
    inset-block-start: 4px;
    inset-inline-end: 4px;
    top: 4px;
    z-index: 43;
  }
}

select:not([multiple]) {
  background-image: var(--select-caret-icon);
  background-repeat: no-repeat;
  background-position: var(--select-caret-position);
  background-size: 7px 5px;
}

.library-page,
.ranking-page {
  display: grid;
  gap: 24px;
  padding: 24px 0 80px;
}

.library-hero,
.ranking-hero {
  padding: clamp(24px, 5vw, 52px);
  border: 1px solid var(--border-soft);
  border-radius: 34px;
  background:
    radial-gradient(circle at 16% 8%, var(--hero-glow), transparent 40%),
    var(--surface);
  box-shadow: 0 24px 70px rgba(120, 84, 42, 0.12);
}

.library-hero__eyebrow,
.ranking-hero__eyebrow {
  margin: 0 0 8px;
  color: var(--accent-dark);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-size: 0.9rem;
}

.library-hero h1,
.ranking-hero h1 {
  margin: 0;
  font-size: clamp(2.6rem, 7vw, 5.8rem);
  line-height: var(--site-heading-line-height);
}

.library-hero p,
.ranking-hero p {
  max-width: 820px;
  margin: 18px 0 0;
  font-size: 1.25rem;
  color: color-mix(in srgb, var(--ink) 78%, transparent);
}

.library-filters {
  display: grid;
  grid-template-columns: minmax(150px, 0.7fr) minmax(150px, 0.7fr) minmax(170px, 0.8fr) minmax(240px, 1.4fr) auto;
  gap: 14px;
  align-items: end;
  padding: 18px;
  border: 1px solid var(--border-soft);
  border-radius: 24px;
  background: var(--surface);
}

.library-filters label {
  display: grid;
  gap: 6px;
  font-weight: 700;
}

.library-filters input,
.library-filters select {
  width: 100%;
  min-height: 48px;
  border: 1px solid var(--border-soft);
  border-radius: 16px;
  padding: 10px 15px;
  background: var(--surface-strong);
  color: var(--ink);
  font: inherit;
}

.library-author-figures {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(104px, 1fr));
  gap: clamp(12px, 2.2vw, 22px);
  align-items: start;
}

.library-author-figure {
  position: relative;
  display: grid;
  gap: 8px;
  justify-items: center;
  min-width: 0;
  padding: 4px 4px 10px;
  border: 0;
  border-radius: 8px;
  background: transparent;
  color: var(--ink);
  font: inherit;
  text-align: center;
  cursor: pointer;
  isolation: isolate;
}

.library-author-figure__image {
  position: relative;
  display: grid;
  place-items: center;
  width: 100%;
  aspect-ratio: 1;
}

.library-author-figure__image::before {
  content: "";
  position: absolute;
  inset: 12%;
  z-index: -1;
  border-radius: 999px;
  background:
    radial-gradient(circle, rgba(255, 237, 171, 0.72) 0%, rgba(214, 155, 57, 0.3) 34%, rgba(31, 95, 122, 0.14) 58%, transparent 74%);
  filter: blur(18px);
  opacity: 0;
  transform: scale(0.86);
  transition: opacity 180ms ease, transform 180ms ease;
}

.library-author-figure img {
  display: block;
  width: min(100%, 160px);
  height: auto;
  aspect-ratio: 1;
  object-fit: contain;
  filter: drop-shadow(0 10px 18px rgba(70, 48, 20, 0.18));
  transition: transform 180ms ease, filter 180ms ease;
}

.library-author-figure__name {
  max-width: 100%;
  color: color-mix(in srgb, var(--ink) 86%, transparent);
  font-size: clamp(0.84rem, 1.45vw, 1rem);
  font-weight: 800;
  line-height: 1.22;
  overflow-wrap: anywhere;
}

.library-author-figure:hover .library-author-figure__image::before,
.library-author-figure:focus-visible .library-author-figure__image::before,
.library-author-figure.is-active .library-author-figure__image::before {
  opacity: 1;
  transform: scale(1.08);
}

.library-author-figure:hover img,
.library-author-figure:focus-visible img,
.library-author-figure.is-active img {
  transform: translateY(-4px) scale(1.04);
  filter:
    drop-shadow(0 0 13px rgba(255, 227, 137, 0.62))
    drop-shadow(0 15px 22px rgba(102, 62, 18, 0.24));
}

.library-author-figure.is-active .library-author-figure__name {
  color: var(--accent-dark);
}

.library-tags {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.library-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 11px;
  border: 1px solid var(--border-soft);
  border-radius: 999px;
  background: color-mix(in srgb, var(--surface-strong) 84%, transparent);
  font-size: 1rem;
}

.library-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 18px;
}

.ranking-card {
  border: 1px solid var(--border-soft);
  border-radius: 26px;
  background: var(--surface);
  box-shadow: 0 18px 44px rgba(120, 84, 42, 0.1);
  overflow: hidden;
}

.ranking-card h2 {
  margin: 0;
  font-size: clamp(1.5rem, 3vw, 2rem);
  line-height: var(--site-compact-text-line-height);
}

.ranking-card p {
  margin: 0;
  color: color-mix(in srgb, var(--ink) 72%, transparent);
}

.library-card__actions,
.ranking-card__actions,
.ranking-pick-actions,
.book-reader-modal__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.library-card__actions a,
.library-card__actions button,
.ranking-card__actions button,
.ranking-pick-actions button,
.book-reader-modal__actions button,
.library-load-more {
  border: 0;
  border-radius: 999px;
  padding: 10px 16px;
  background: var(--accent);
  color: white;
  font: inherit;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
}

.library-card__actions a,
.ranking-card__actions button:nth-child(2),
.book-reader-modal__actions button {
  background: var(--mist);
  color: var(--ink);
}

.ranking-card__delete {
  background: #9f2f2f !important;
  color: #fff !important;
}

.book-reader-modal[hidden] {
  display: none;
}

.book-reader-modal {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: grid;
  place-items: center;
  padding: 24px;
}

.book-reader-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(22, 18, 14, 0.42);
  backdrop-filter: blur(10px);
}

.book-reader-modal__dialog {
  position: relative;
  width: min(1180px, 96vw);
  max-height: 92vh;
  display: grid;
  gap: 18px;
  padding: 24px;
  border-radius: 32px;
  background: var(--paper);
  box-shadow: 0 30px 100px rgba(0, 0, 0, 0.32);
}

.book-reader-modal__close {
  position: absolute;
  inset-block-start: 16px;
  inset-inline-end: 16px;
  width: 42px;
  height: 42px;
  border: 0;
  border-radius: 999px;
  background: var(--surface-strong);
  color: var(--ink);
  font-size: 1.6rem;
  cursor: pointer;
}

.book-reader-modal__header {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 18px;
  padding-inline-end: 50px;
}

.book-reader-modal__header h2,
.book-reader-modal__header p {
  margin: 0;
}

.book-spread {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  min-height: min(68vh, 680px);
  perspective: 1800px;
}

.book-page {
  padding: clamp(26px, 4vw, 52px);
  border-radius: 10px 24px 24px 10px;
  background:
    linear-gradient(90deg, rgba(0, 0, 0, 0.07), transparent 9%),
    #fff8e7;
  color: #2a2118;
  box-shadow: inset 0 0 0 1px rgba(80, 50, 18, 0.08), 0 18px 36px rgba(80, 50, 18, 0.12);
  font-size: clamp(1.15rem, 2vw, 1.45rem);
  line-height: 1.75;
  overflow: auto;
}

.book-page + .book-page {
  border-radius: 24px 10px 10px 24px;
  background:
    linear-gradient(270deg, rgba(0, 0, 0, 0.07), transparent 9%),
    #fff8e7;
}

@media (min-width: 980px) {
  .book-reader-modal__dialog {
    width: min(1320px, 96vw);
  }

  .book-spread {
    align-items: stretch;
    min-height: 0;
    height: min(67vh, 680px);
    aspect-ratio: 1448 / 1086;
    gap: clamp(34px, 4vw, 62px);
    padding: clamp(86px, 8vw, 126px) clamp(112px, 8vw, 150px) clamp(92px, 8vw, 132px);
    background: url("/images/library/open-book-page.png") center / contain no-repeat;
    perspective: none;
  }

  .book-page,
  .book-page + .book-page {
    padding: clamp(12px, 1.5vw, 22px);
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    color: #2a2118;
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(1rem, 1.25vw, 1.18rem);
    line-height: 1.62;
  }
}

.ranking-duel {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  align-items: stretch;
}

.ranking-duel .ranking-pick-actions {
  grid-column: 1 / -1;
  justify-content: center;
}

.ranking-card {
  display: grid;
  gap: 12px;
  padding: 16px;
}

.ranking-card img {
  width: 100%;
  height: clamp(300px, 58vh, 660px);
  object-fit: contain;
  border-radius: 20px;
  background: color-mix(in srgb, var(--mist) 72%, transparent);
}

.ranking-card--music audio {
  width: 100%;
}

.ranking-empty {
  grid-column: 1 / -1;
  padding: 42px;
  border: 1px solid var(--border-soft);
  border-radius: 24px;
  background: var(--surface);
  text-align: center;
}

@media (max-width: 820px) {
  .library-filters,
  .ranking-duel,
  .book-spread {
    grid-template-columns: 1fr;
  }

  .library-filters__status {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }

  .book-reader-modal__header {
    align-items: start;
    flex-direction: column;
  }
}

.misc-prayers-page {
  --misc-prayer-text-size: 26px;
  --misc-prayer-line-height: 1.85;
  display: grid;
  gap: 22px;
  padding-block-end: 80px;
}

.misc-prayers-hero {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 18px;
  padding: clamp(22px, 5vw, 48px);
  border: 1px solid var(--border-soft);
  border-radius: 34px;
  background:
    radial-gradient(circle at 88% 8%, var(--hero-glow), transparent 42%),
    linear-gradient(315deg, color-mix(in srgb, var(--surface) 92%, transparent), color-mix(in srgb, var(--paper) 96%, transparent)),
    var(--surface);
  box-shadow: 0 24px 70px rgba(120, 84, 42, 0.12);
}

.misc-prayers-hero .page-subtitle {
  max-width: 820px;
}

.misc-prayers-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.misc-prayers-actions .reader-icon-button {
  width: 44px;
  height: 44px;
  border-radius: 999px;
}

.misc-prayers-filters {
  display: grid;
  grid-template-columns: minmax(220px, 1fr);
  gap: 14px;
  padding: 18px;
  border: 1px solid var(--border-soft);
  border-radius: 24px;
  background: var(--surface);
}

/* Category picker for /prayers — circle pills, one per category. Each
   anchors a GET that flips the route's category param. Mirrors the hour
   dial visual on /hourly-prayers so the two pages feel coherent. */
.misc-prayers-category-dial {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 4px 0;
}

.misc-prayers-category-dial__item {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 8px 16px;
  border: 1px solid var(--control-border);
  border-radius: 999px;
  background: var(--control-bg);
  color: var(--ink);
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
  transition: background-color 140ms ease, border-color 140ms ease, color 140ms ease, transform 140ms ease;
}

.misc-prayers-category-dial__item:hover,
.misc-prayers-category-dial__item:focus-visible {
  background: color-mix(in srgb, var(--accent) 12%, var(--control-bg));
  border-color: color-mix(in srgb, var(--accent) 40%, var(--control-border));
  color: var(--accent-dark);
  outline: none;
  transform: translateY(-1px);
}

.misc-prayers-category-dial__item.is-active {
  background: var(--accent);
  border-color: color-mix(in srgb, var(--accent-dark) 60%, transparent);
  color: var(--on-accent);
  box-shadow: 0 6px 18px color-mix(in srgb, var(--accent) 26%, transparent);
}

.misc-prayers-filters .field {
  display: grid;
  gap: 7px;
}

.misc-prayers-filters label {
  color: color-mix(in srgb, var(--ink) 78%, transparent);
  font-weight: 800;
}

.misc-prayers-filters select {
  width: 100%;
  min-height: 50px;
  border: 1px solid var(--border-soft);
  border-radius: 16px;
  padding: 10px 15px;
  background-color: var(--surface-strong);
  color: var(--ink);
  font: inherit;
}

.misc-prayer-book-shell {
  display: grid;
  grid-template-columns: minmax(230px, 0.35fr) minmax(0, 1fr);
  gap: 20px;
  align-items: start;
}

.misc-prayer-index {
  position: sticky;
  top: calc(var(--header-height, 80px) + 16px);
  max-height: min(70vh, 680px);
  overflow: auto;
  scrollbar-width: thin;
}

.misc-prayer-index ol {
  margin: 12px 0 0;
  padding: 0;
  list-style: none;
}

.misc-prayer-index li + li {
  margin-top: 6px;
}

.misc-prayer-index a {
  display: block;
  padding: 9px 11px;
  border-radius: 14px;
  color: var(--ink);
  text-decoration: none;
}

.misc-prayer-index a:hover,
.misc-prayer-index a:focus-visible,
.misc-prayer-index a.is-active {
  background: var(--mist);
  color: var(--accent-dark);
}

.misc-prayer-reader {
  display: grid;
  gap: 18px;
}

.misc-prayer-entry {
  padding: clamp(22px, 4vw, 44px);
  border: 1px solid var(--border-soft);
  border-radius: 30px;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--surface) 94%, transparent), color-mix(in srgb, var(--paper) 94%, transparent)),
    var(--surface);
  box-shadow: 0 20px 50px rgba(120, 84, 42, 0.1);
}

.misc-prayer-entry__header {
  margin-bottom: 18px;
}

.misc-prayer-entry__title-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: start;
}

.misc-prayer-share {
  width: 44px;
  height: 44px;
  border-radius: 999px;
  flex: 0 0 auto;
}

.misc-prayer-entry__header span {
  display: inline-flex;
  margin-bottom: 8px;
  color: var(--accent-dark);
  font-size: 0.92rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.misc-prayer-entry__header h2,
.misc-prayer-entry__header p,
.misc-prayer-section h3,
.misc-prayer-section p {
  margin: 0;
}

.misc-prayer-entry__header h2 {
  font-size: clamp(2rem, 5vw, 4rem);
  line-height: 0.95;
}

.misc-prayer-entry__header p {
  margin-top: 10px;
  color: color-mix(in srgb, var(--ink) 72%, transparent);
  font-size: 1.12rem;
}

.misc-prayer-section {
  display: grid;
  gap: 14px;
}

.misc-prayer-section + .misc-prayer-section {
  margin-top: 22px;
}

.misc-prayer-section h3 {
  color: var(--accent-dark);
  font-size: clamp(1.4rem, 3vw, 2rem);
}

.misc-prayer-section p {
  font-family: var(--reader-text-family, inherit);
  font-size: var(--misc-prayer-text-size);
  line-height: var(--misc-prayer-line-height);
  color: var(--ink);
}

.misc-prayers-page[dir="rtl"] .misc-prayer-section p,
.misc-prayers-page[dir="rtl"] .chapter-reader__font-preview {
  font-family: var(--reader-text-family, "Amiri", "Noto Naskh Arabic", "Scheherazade New", "Traditional Arabic", serif);
}

.misc-prayers-page[dir="rtl"] .misc-prayer-section p {
  line-height: 2.22;
}

.misc-prayer-sources {
  margin-top: 22px;
  padding-top: 16px;
  border-top: 1px solid var(--border-soft);
  color: color-mix(in srgb, var(--ink) 72%, transparent);
}

.misc-prayer-sources summary {
  cursor: pointer;
  font-weight: 800;
}

.misc-prayer-sources ul {
  display: grid;
  gap: 8px;
  margin: 12px 0 0;
  padding-inline-start: 18px;
}

.misc-prayer-sources li {
  line-height: 1.45;
}

.misc-prayer-sources span {
  margin-inline-start: 6px;
  color: var(--accent-dark);
  font-size: 0.9rem;
  font-weight: 800;
}

.misc-prayers-font-control {
  position: relative;
}

.misc-prayers-font-popover {
  top: calc(100% + 10px);
  right: 0;
  bottom: auto;
  inset-inline-end: 0;
  inset-inline-start: auto;
  width: min(340px, calc(100vw - 28px));
}

.misc-prayers-font-popover::before {
  top: -8px;
  right: 16px;
  bottom: auto;
  border: 0;
  border-top: 1px solid rgba(145, 92, 45, 0.14);
  border-left: 1px solid rgba(145, 92, 45, 0.14);
}

.misc-prayers-font-popover .chapter-reader__font-preview {
  text-align: center;
}

.misc-prayers-line-height-stepper .chapter-reader__font-size-value {
  min-width: 64px;
}

.downloads-card--prayer {
  padding: 0;
  overflow: hidden;
}

.downloads-card--prayer .prayer-card__toolbar {
  position: absolute;
  inset-block-start: 10px;
  inset-inline-end: 10px;
  z-index: 2;
}

.downloads-filter-panel__hint {
  align-self: end;
  margin: 0;
  color: color-mix(in srgb, var(--ink) 70%, transparent);
  line-height: 1.45;
}

@media (max-width: 900px) {
  .misc-prayers-hero,
  .misc-prayer-book-shell {
    grid-template-columns: 1fr;
  }

  .misc-prayers-hero {
    display: grid;
  }

  .misc-prayers-filters {
    grid-template-columns: 1fr;
  }

  .misc-prayer-index {
    position: relative;
    top: auto;
    max-height: 260px;
  }
}

/* Theme completion layer: keep older light-coded components aligned with active theme tokens. */
:root[data-theme] .site-header,
:root[data-theme] .site-footer,
:root[data-theme] .site-footer-toggle,
:root[data-theme] .header-search,
:root[data-theme] .hero-search-form,
:root[data-theme] .site-language-switcher__button,
:root[data-theme] .site-language-switcher__menu,
:root[data-theme] .site-notification-center__button,
:root[data-theme] .site-notification-center__menu,
:root[data-theme] .site-theme-switcher select,
:root[data-theme] .viewport-zoom-controls__button,
:root[data-theme] .panel,
:root[data-theme] .legal-doc,
:root[data-theme] .legal-doc__stat,
:root[data-theme] .legal-doc__card,
:root[data-theme] .hero-search-card,
:root[data-theme] .destination-card,
:root[data-theme] .book-card,
:root[data-theme] .chapter-card,
:root[data-theme] .bible-browser__hero,
:root[data-theme] .bible-browser__hero--reader-sidebar,
:root[data-theme] .bible-browser__hero--reader-top,
:root[data-theme] .bible-browser__navigator-toggle,
:root[data-theme] .bible-browser__selector,
:root[data-theme] .chapter-reader__sheet,
:root[data-theme] .chapter-reader__nav-link,
:root[data-theme] .chapter-reader__action-button--secondary,
:root[data-theme] .chapter-reader__selection-rail,
:root[data-theme] .chapter-reader__verse-actions,
:root[data-theme] .chapter-reader__verse-state-button,
:root[data-theme] .chapter-reader__font-menu-toggle,
:root[data-theme] .chapter-reader__font-popover,
:root[data-theme] .chapter-reader__font-popover::before,
:root[data-theme] .chapter-reader__font-preview,
:root[data-theme] .chapter-reader__font-family-select,
:root[data-theme] .verse-audio-button,
:root[data-theme] .verse-audio-select select,
:root[data-theme] .verse-media-card,
:root[data-theme] .verse-image-gallery__item,
:root[data-theme] .product-gallery__main,
:root[data-theme] .product-gallery__thumb,
:root[data-theme] .product-gallery__edit-button,
:root[data-theme] .image-lightbox__panel,
:root[data-theme] .gallery-modal__panel,
:root[data-theme] .gallery-modal__close,
:root[data-theme] .share-popup__panel,
:root[data-theme] .strongs-tooltip,
:root[data-theme] .translation-compare__row,
:root[data-theme] .search-results-form,
:root[data-theme] .search-engine-result,
:root[data-theme] .search-share-button--page,
:root[data-theme] .media-card,
:root[data-theme] .downloads-card,
:root[data-theme] .downloads-audio-card,
:root[data-theme] .downloads-audio-waveform,
:root[data-theme] .downloads-now-playing,
:root[data-theme] .site-audio-resume,
:root[data-theme] .reading-continue-toast,
:root[data-theme] .reader-action-notice,
:root[data-theme] .verse-note-popover,
:root[data-theme] .verse-study-panel,
:root[data-theme] .admin-page__flash,
:root[data-theme] .admin-contact-ticket,
:root[data-theme] .admin-contact-ticket__reply,
:root[data-theme] .contact-page__header,
:root[data-theme] .contact-form,
:root[data-theme] .contact-page__flash,
:root[data-theme] .profile-page__flash,
:root[data-theme] .reading-dashboard__empty,
:root[data-theme] .forum-hero,
:root[data-theme] .forum-card,
:root[data-theme] .forum-category-card,
:root[data-theme] .forum-thread-row,
:root[data-theme] .forum-post,
:root[data-theme] .forum-composer,
:root[data-theme] .forum-thread-card,
:root[data-theme] .ai-chat-card,
:root[data-theme] .ai-chat-message__bubble,
:root[data-theme] .ai-chat-message__resource-link,
:root[data-theme] .ai-chat-composer,
:root[data-theme] .ai-chat-composer__input,
:root[data-theme] .library-hero,
:root[data-theme] .library-filters,
:root[data-theme] .library-card,
:root[data-theme] .library-tag,
:root[data-theme] .ranking-hero,
:root[data-theme] .ranking-card,
:root[data-theme] .ranking-empty,
:root[data-theme] .book-reader-modal__dialog,
:root[data-theme] .book-page,
:root[data-theme] .reader-movie__panel,
:root[data-theme] .reader-movie__controls-popover,
:root[data-theme] .reader-movie__aspect-group,
:root[data-theme] .auth-modal__dialog,
:root[data-theme] .auth-modal__tabs,
:root[data-theme] .auth-modal__tab,
:root[data-theme] .auth-modal__action,
:root[data-theme] .auth-modal__close,
:root[data-theme] .auth-modal__field input,
:root[data-theme] .auth-modal__otp-input,
:root[data-theme] .editor-panel,
:root[data-theme] .editor-stage-toolbar,
:root[data-theme] .editor-source-choice__preview,
:root[data-theme] .editor-textbar__select,
:root[data-theme] .editor-segmented__button,
:root[data-theme] .editor-icon-toggle,
:root[data-theme] .editor-inline-action-button,
:root[data-theme] .editor-crop-control,
:root[data-theme] .editor-create-dialog,
:root[data-theme] .editor-context-menu,
:root[data-theme] .editor-layer-list__item {
  background-color: var(--surface);
  background-image: none;
  border-color: var(--border-soft);
  color: var(--ink);
  box-shadow: 0 16px 42px var(--surface-shadow);
}

:root[data-theme] .verse-study-panel {
  background-color: color-mix(in srgb, var(--ink) 34%, transparent);
  border-color: transparent;
  box-shadow: none;
}

:root[data-theme] .verse-study-panel__dialog,
:root[data-theme] .verse-study-panel__tab {
  background-image: none;
  border-color: var(--border-soft);
  color: var(--ink);
}

:root[data-theme] .verse-study-panel__dialog {
  background-color: var(--surface);
  box-shadow: 0 20px 52px var(--surface-shadow);
}

:root[data-theme] input:not([type="range"]),
:root[data-theme] textarea,
:root[data-theme] select,
:root[data-theme] .auth-modal__field input,
:root[data-theme] .auth-modal__otp-input,
:root[data-theme] .library-filters input,
:root[data-theme] .library-filters select,
:root[data-theme] .header-search input,
:root[data-theme] .hero-search-form input,
:root[data-theme] .ai-chat-composer__input,
:root[data-theme] .editor-textbar__select {
  background-color: var(--control-bg-strong);
  background-image: none;
  border-color: var(--control-border);
  color: var(--ink);
}

:root[data-theme] input::placeholder,
:root[data-theme] textarea::placeholder {
  color: color-mix(in srgb, var(--muted) 72%, transparent);
}

:root[data-theme] .header-search input,
:root[data-theme] .hero-search-form input,
:root[data-theme] .search-results-form input {
  background-color: transparent;
  background-image: none;
  border-color: transparent;
  color: var(--ink);
}

:root[data-theme] .auth-modal__backdrop,
:root[data-theme] .book-reader-modal__backdrop,
:root[data-theme] .gallery-modal__backdrop,
:root[data-theme] .image-lightbox__backdrop,
:root[data-theme] .editor-create-overlay {
  background: var(--overlay-bg);
}

:root[data-theme] .nav-user,
:root[data-theme] .site-language-switcher__language-native,
:root[data-theme] .site-language-switcher__language-code,
:root[data-theme] .page-subtitle,
:root[data-theme] .destination-card__content p,
:root[data-theme] .legal-doc__lede,
:root[data-theme] .chapter-reader__subtitle,
:root[data-theme] .verse-audio-select,
:root[data-theme] .verse-audio-button__time,
:root[data-theme] .library-card p,
:root[data-theme] .ranking-card p,
:root[data-theme] .downloads-now-playing__meta span,
:root[data-theme] .downloads-now-playing__time,
:root[data-theme] .site-audio-resume__eyebrow,
:root[data-theme] .site-audio-resume__meta span,
:root[data-theme] .reading-continue-toast span,
:root[data-theme] .auth-modal__field span,
:root[data-theme] .chapter-reader__font-popover-header span,
:root[data-theme] .forum-card__meta,
:root[data-theme] .ai-chat-message__meta,
:root[data-theme] .media-card__meta,
:root[data-theme] .contact-page__header p,
:root[data-theme] .contact-form__footer span,
:root[data-theme] .admin-contact-ticket__header p,
:root[data-theme] .admin-contact-ticket__message,
:root[data-theme] .admin-contact-ticket__reply {
  color: var(--muted);
}

:root[data-theme] .btn.primary,
:root[data-theme] .auth-modal__submit,
:root[data-theme] .library-card__actions button,
:root[data-theme] .library-load-more,
:root[data-theme] .ranking-card__actions button,
:root[data-theme] .ranking-pick-actions button,
:root[data-theme] .downloads-now-playing__play,
:root[data-theme] .site-audio-resume__play,
:root[data-theme] .reader-movie__play,
:root[data-theme] .product-gallery__edit-button,
:root[data-theme] .chapter-reader__action-button,
:root[data-theme] .verse-audio-button__icon,
:root[data-theme] .contact-form__footer button {
  background: var(--accent);
  border-color: color-mix(in srgb, var(--accent) 70%, var(--border-soft));
  color: var(--on-accent);
}

:root[data-theme] .btn.ghost,
:root[data-theme] .library-card__actions a,
:root[data-theme] .book-reader-modal__actions button,
:root[data-theme] .chapter-reader__action-button--secondary,
:root[data-theme] .chapter-reader__nav-link,
:root[data-theme] .downloads-now-playing__close,
:root[data-theme] .downloads-now-playing__collapse,
:root[data-theme] .site-audio-resume__expand,
:root[data-theme] .site-audio-resume__close,
:root[data-theme] .auth-modal__tab.is-active {
  background: var(--control-bg);
  border-color: var(--control-border);
  color: var(--ink);
}

:root[data-theme] .chapter-reader__verse:hover,
:root[data-theme] .chapter-reader__verse:focus-within,
:root[data-theme] .chapter-reader__verse.is-selected,
:root[data-theme] .chapter-reader__verse--highlight,
:root[data-theme] .chapter-reader__verse.is-audio-active,
:root[data-theme] .chapter-reader.is-compact .chapter-reader__verse:hover,
:root[data-theme] .chapter-reader.is-compact .chapter-reader__verse:focus-within,
:root[data-theme] .chapter-reader.is-compact .chapter-reader__verse.is-selected,
:root[data-theme] .site-language-switcher__menu a:hover,
:root[data-theme] .site-language-switcher__menu a:focus-visible,
:root[data-theme] .site-language-switcher__menu a.is-current,
:root[data-theme] .chapter-reader__font-menu-toggle:hover,
:root[data-theme] .chapter-reader__text-controls.is-open .chapter-reader__font-menu-toggle {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  border-color: color-mix(in srgb, var(--accent) 38%, var(--border-soft));
  color: var(--ink);
}

:root[data-theme] .chapter-reader__verse-state-button,
:root[data-theme] .chapter-reader__font-menu-toggle,
:root[data-theme] .reader-icon-button,
:root[data-theme] .image-lightbox__edit,
:root[data-theme] .gallery-modal__close,
:root[data-theme] .auth-modal__close {
  background: var(--control-bg);
  border-color: var(--control-border);
  color: var(--accent-dark);
  box-shadow: 0 8px 20px var(--surface-shadow);
}

:root[data-theme] .verse-audio-button__bar,
:root[data-theme] .downloads-audio-waveform__bar {
  background: color-mix(in srgb, var(--ink) 34%, var(--surface-strong));
}

:root[data-theme] .verse-audio-button__bar::after,
:root[data-theme] .downloads-audio-waveform__bar.is-played {
  background: linear-gradient(180deg, var(--accent), var(--accent-dark));
}

:root[data-theme] .ranking-card__delete,
:root[data-theme] .image-review-button--delete {
  background: var(--danger) !important;
  color: var(--on-accent) !important;
}

/* ----------------------------------------------------------
   Image-review workspace (used by /review and the embedded
   panel inside /profile?tab=moderation). Light-mode rules
   above bake in cream/dark-ink colors; the overrides below
   re-paint the panel through CSS variables so it tracks the
   active theme (midnight, dark, contrast, dawn, etc.).
   ---------------------------------------------------------- */
:root[data-theme] .image-review-card,
:root[data-theme] .image-review-stats div,
:root[data-theme] .image-review-vote,
:root[data-theme] .image-review-button,
:root[data-theme] .image-review-empty {
  background: var(--surface);
  border-color: var(--border-soft);
  color: var(--ink);
  box-shadow: 0 16px 38px var(--surface-shadow);
}

:root[data-theme] .image-review-stats div,
:root[data-theme] .image-review-vote,
:root[data-theme] .image-review-button {
  /* Compact inner cards/buttons need a softer surface so they read as
     elevated against the outer .image-review-card. */
  background: var(--control-bg);
  box-shadow: none;
}

:root[data-theme] .image-review-empty {
  border-style: dashed;
  border-color: color-mix(in srgb, var(--accent) 30%, var(--border-soft));
  background: color-mix(in srgb, var(--accent) 6%, var(--surface));
  color: var(--muted-strong);
}

:root[data-theme] .image-review-card__eyebrow {
  color: var(--muted);
}

:root[data-theme] .image-review-card__copy,
:root[data-theme] .image-review-main__subtitle,
:root[data-theme] .image-review-stats dt,
:root[data-theme] .image-review-guidelines,
:root[data-theme] .image-review-status {
  color: var(--muted-strong);
}

:root[data-theme] .image-review-stage {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 70%, transparent), color-mix(in srgb, var(--surface) 56%, transparent)),
    radial-gradient(circle at top, color-mix(in srgb, var(--accent) 10%, transparent), transparent 55%),
    repeating-linear-gradient(45deg,
      color-mix(in srgb, var(--ink) 6%, transparent) 0 8px,
      transparent 8px 24px);
  border-color: var(--border-soft);
}

:root[data-theme] .image-review-stage img {
  background: color-mix(in srgb, var(--surface) 78%, transparent);
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.45);
}

:root[data-theme] .image-review-button--yes {
  background: color-mix(in srgb, var(--success, #1f7a4d) 16%, var(--surface));
  border-color: color-mix(in srgb, var(--success, #1f7a4d) 40%, var(--border-soft));
  color: color-mix(in srgb, var(--success, #1f7a4d) 78%, var(--ink));
}

:root[data-theme] .image-review-button--no {
  background: color-mix(in srgb, var(--danger, #a6422a) 16%, var(--surface));
  border-color: color-mix(in srgb, var(--danger, #a6422a) 40%, var(--border-soft));
  color: color-mix(in srgb, var(--danger, #a6422a) 78%, var(--ink));
}

:root[data-theme] .image-review-button--hide {
  background: color-mix(in srgb, var(--accent) 16%, var(--surface));
  border-color: color-mix(in srgb, var(--accent) 40%, var(--border-soft));
  color: var(--accent-dark);
}

:root[data-theme] .image-review-button--ocr {
  background: color-mix(in srgb, var(--info, #60a5fa) 16%, var(--surface));
  border-color: color-mix(in srgb, var(--info, #60a5fa) 40%, var(--border-soft));
  color: color-mix(in srgb, var(--info, #60a5fa) 78%, var(--ink));
}

:root[data-theme] .image-review-button--skip {
  background: color-mix(in srgb, var(--ink) 8%, var(--surface));
  border-color: var(--border-soft);
  color: var(--muted-strong);
}

:root[data-theme] .image-review-ocr {
  background: var(--control-bg);
  border-color: var(--border-soft);
}

:root[data-theme] .image-review-ocr h4,
:root[data-theme] .image-review-ocr__meta {
  color: var(--muted-strong);
}

/* Mode toggle (Cleanup / Compare) — dark theme parity. */
:root[data-theme] .image-review-mode {
  background: var(--control-bg);
  border-color: var(--border-soft);
}

:root[data-theme] .image-review-mode__tab {
  color: var(--muted-strong);
}

:root[data-theme] .image-review-mode__tab:hover,
:root[data-theme] .image-review-mode__tab:focus-visible {
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  color: var(--ink);
}

:root[data-theme] .image-review-mode__tab.is-active {
  background: color-mix(in srgb, var(--accent) 22%, transparent);
  color: var(--ink);
}

/* Pair cards — dark theme. */
:root[data-theme] .image-review-pair-card {
  background: var(--surface);
  border-color: var(--border-soft);
  color: var(--ink);
}

:root[data-theme] .image-review-pair-card__stage {
  background: color-mix(in srgb, var(--surface) 78%, transparent);
  border-color: var(--border-soft);
}

:root[data-theme] .image-review-pair-card__meta {
  color: var(--muted);
}

/* Reports panel — dark theme. */
:root[data-theme] .image-review-reports {
  background: var(--control-bg);
  border-color: var(--border-soft);
}

:root[data-theme] .image-review-reports > summary {
  color: var(--ink);
}

:root[data-theme] .image-review-reports__hint,
:root[data-theme] .image-review-reports__empty,
:root[data-theme] .image-review-report-card__meta span {
  color: var(--muted);
}

:root[data-theme] .image-review-report-card {
  background: var(--surface);
  border-color: var(--border-soft);
}

:root[data-theme] .image-review-report-card img {
  background: color-mix(in srgb, var(--ink) 12%, transparent);
}

:root[data-theme] .image-review-button:focus-visible {
  outline-color: color-mix(in srgb, var(--accent) 36%, transparent);
}

:root[data-theme] .image-review-admin-links a {
  color: var(--ink);
  background: var(--control-bg);
  border-color: var(--border-soft);
}

:root[data-theme] .image-review-admin-links a:hover,
:root[data-theme] .image-review-admin-links a:focus-visible {
  background: color-mix(in srgb, var(--accent) 16%, var(--surface));
  border-color: color-mix(in srgb, var(--accent) 40%, var(--border-soft));
  color: var(--accent);
}

/* Vote pills (.image-review-vote--yes / --no / --total) re-themed via
   color-mix so the green/red/neutral palette adapts in dark themes. */
:root[data-theme] .image-review-vote--yes {
  background: color-mix(in srgb, var(--success, #1f7a4d) 18%, var(--surface));
  border-color: color-mix(in srgb, var(--success, #1f7a4d) 40%, var(--border-soft));
  color: color-mix(in srgb, var(--success, #1f7a4d) 78%, var(--ink));
}

:root[data-theme] .image-review-vote--yes::before {
  background: color-mix(in srgb, var(--success, #1f7a4d) 30%, transparent);
  color: color-mix(in srgb, var(--success, #1f7a4d) 84%, var(--ink));
}

:root[data-theme] .image-review-vote--no {
  background: color-mix(in srgb, var(--danger, #a6422a) 18%, var(--surface));
  border-color: color-mix(in srgb, var(--danger, #a6422a) 40%, var(--border-soft));
  color: color-mix(in srgb, var(--danger, #a6422a) 78%, var(--ink));
}

:root[data-theme] .image-review-vote--no::before {
  background: color-mix(in srgb, var(--danger, #a6422a) 30%, transparent);
  color: color-mix(in srgb, var(--danger, #a6422a) 84%, var(--ink));
}

/* (.image-review-vote--total was removed — the workspace now shows
   only the up-arrow + down-arrow pills.) */

:root[data-theme] .book-page {
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--ink) 10%, transparent), transparent 9%),
    var(--surface-strong);
}

:root[data-theme] .book-page + .book-page {
  background:
    linear-gradient(270deg, color-mix(in srgb, var(--ink) 10%, transparent), transparent 9%),
    var(--surface-strong);
}

:root[data-theme] .site-footer a,
:root[data-theme] .downloads-audio-player__download,
:root[data-theme] .downloads-now-playing__download,
:root[data-theme] .chapter-reader__verse-anchor,
:root[data-theme] .legal-doc__stat-label,
:root[data-theme] .library-hero__eyebrow,
:root[data-theme] .ranking-hero__eyebrow {
  color: var(--accent-dark);
}

:root[data-theme] .translation-compare__back,
:root[data-theme] .translation-compare__actions .reader-icon-button {
  background: var(--control-bg);
  border-color: var(--control-border);
  color: var(--accent-dark);
  box-shadow: 0 8px 20px var(--surface-shadow);
}

:root[data-theme] .translation-compare__back:hover,
:root[data-theme] .translation-compare__back:focus-visible,
:root[data-theme] .translation-compare__actions .reader-icon-button:hover,
:root[data-theme] .translation-compare__actions .reader-icon-button:focus-visible {
  background: color-mix(in srgb, var(--accent) 18%, var(--control-bg));
  color: var(--accent-dark);
}

:root[data-theme] .translation-compare__eyebrow,
:root[data-theme] .translation-compare__bible span {
  color: var(--muted);
}

:root[data-theme] .translation-compare__bible {
  background: color-mix(in srgb, var(--accent) 12%, var(--surface));
}

:root[data-theme] .translation-compare__bible a {
  color: var(--accent-dark);
}

/* Targeted theme QA fixes for surfaces that still had component-level light colors. */
:root[data-theme] .bible-browser__intro p,
:root[data-theme] .bible-browser__hero-book,
:root[data-theme] .bible-browser__hero-chapter,
:root[data-theme] .bible-browser__hero-range,
:root[data-theme] .bible-browser__navigator-reading,
:root[data-theme] .bible-browser__navigator-shell-range,
:root[data-theme] .bible-browser__nav-group label,
:root[data-theme] .bible-browser__navigator-meta span,
:root[data-theme] .bible-browser__selector span,
:root[data-theme] .chapter-card__meta,
:root[data-theme] .book-card__meta {
  color: var(--muted);
}

:root[data-theme] .bible-browser__intro-meta span,
:root[data-theme] .bible-browser__navigator-meta span,
:root[data-theme] .bible-browser__navigator-shell-range {
  background: color-mix(in srgb, var(--accent) 14%, var(--surface));
  border-color: color-mix(in srgb, var(--accent) 28%, var(--border-soft));
  color: var(--accent-dark);
}

:root[data-theme] .search-results-top,
:root[data-theme] .search-results-form,
:root[data-theme] .search-results-meta,
:root[data-theme] .search-results-side__card,
:root[data-theme] .search-tabs,
:root[data-theme] .search-bible-card,
:root[data-theme] .search-stats-card,
:root[data-theme] .search-empty-state,
:root[data-theme] .search-engine-result,
:root[data-theme] .search-media-card,
:root[data-theme] .search-media-card__body,
:root[data-theme] .search-form-advanced,
:root[data-theme] .search-form-controls,
:root[data-theme] .search-language-warning {
  background: var(--surface);
  background-image: none;
  border-color: var(--border-soft);
  color: var(--ink);
  box-shadow: 0 16px 42px var(--surface-shadow);
}

:root[data-theme] .admin-page__flash--ok,
:root[data-theme] .profile-page__flash.is-success {
  background: color-mix(in srgb, #2f834e 16%, var(--surface));
  border-color: color-mix(in srgb, #2f834e 36%, var(--border-soft));
  color: color-mix(in srgb, #67d895 58%, var(--ink));
}

:root[data-theme] .admin-page__flash--error,
:root[data-theme] .profile-page__flash.is-error {
  background: color-mix(in srgb, #b34545 16%, var(--surface));
  border-color: color-mix(in srgb, #b34545 40%, var(--border-soft));
  color: color-mix(in srgb, #ff8b8b 58%, var(--ink));
}

:root[data-theme] .profile-page__flash.is-info,
:root[data-theme] .search-language-warning {
  background: color-mix(in srgb, var(--accent) 10%, var(--surface));
  border-color: color-mix(in srgb, var(--accent) 28%, var(--border-soft));
  color: var(--ink);
}

:root[data-theme] .profile-page__role-chip.is-positive,
:root[data-theme] .profile-page__health-card.is-good,
:root[data-theme] .profile-page__permission.is-enabled {
  background: color-mix(in srgb, #2f834e 13%, var(--surface));
  border-color: color-mix(in srgb, #2f834e 28%, var(--border-soft));
  color: var(--ink);
}

:root[data-theme] .profile-page__role-chip.is-warning,
:root[data-theme] .profile-page__health-card.is-warning,
:root[data-theme] .profile-page__inline-notice.is-warning {
  background: color-mix(in srgb, var(--accent) 15%, var(--surface));
  border-color: color-mix(in srgb, var(--accent) 34%, var(--border-soft));
  color: var(--ink);
}

:root[data-theme] .profile-page__handle,
:root[data-theme] .profile-page__validation {
  color: var(--accent-dark);
}

:root[data-theme] .search-engine-result {
  border-bottom-color: var(--border-soft);
  box-shadow: none;
}

:root[data-theme] .search-tab,
:root[data-theme] .search-results-meta > p,
:root[data-theme] .search-results-side__card p,
:root[data-theme] .search-results-side__count,
:root[data-theme] .search-bible-picker span,
:root[data-theme] .search-bible-card span,
:root[data-theme] .search-bible-card small,
:root[data-theme] .search-stats-card__scope,
:root[data-theme] .search-stats-card__hint,
:root[data-theme] .search-engine-result__domain,
:root[data-theme] .search-engine-result__url,
:root[data-theme] .search-engine-result__snippet,
:root[data-theme] .search-media-card__body p,
:root[data-theme] .search-form-advanced label {
  color: var(--muted);
}

:root[data-theme] .search-tab:hover,
:root[data-theme] .search-tab:focus-visible,
:root[data-theme] .search-tab.is-active,
:root[data-theme] .search-bible-card strong,
:root[data-theme] .search-stats-card__count,
:root[data-theme] .search-engine-result__title,
:root[data-theme] .search-media-card__title {
  color: var(--accent-dark);
}

:root[data-theme] .search-engine-result__badge,
:root[data-theme] .search-engine-result__snippet mark {
  background: color-mix(in srgb, var(--accent) 18%, var(--surface));
  color: var(--accent-dark);
}

:root[data-theme] .downloads-tabs,
:root[data-theme] .downloads-filter-panel,
:root[data-theme] .downloads-filter-panel--simple {
  color: var(--ink);
}

:root[data-theme] .downloads-tab {
  background: var(--control-bg);
  border-color: var(--border-soft);
  color: var(--ink);
  box-shadow: 0 12px 28px var(--surface-shadow);
}

:root[data-theme] .downloads-tab span {
  color: var(--ink);
}

:root[data-theme] .downloads-tab small,
:root[data-theme] .downloads-filter-panel label,
:root[data-theme] .downloads-filter-panel--simple,
:root[data-theme] .downloads-card__placeholder,
:root[data-theme] .downloads-audio-player__body > span,
:root[data-theme] .downloads-audio-player__time {
  color: var(--muted);
}

:root[data-theme] .downloads-tab.is-active {
  background: color-mix(in srgb, var(--accent) 18%, var(--surface));
  border-color: color-mix(in srgb, var(--accent) 48%, var(--border-soft));
  color: var(--accent-dark);
}

:root[data-theme] .downloads-tab.is-active span,
:root[data-theme] .downloads-tab.is-active small {
  color: var(--accent-dark);
}

:root[data-theme] .downloads-tag-filter__item,
:root[data-theme] .downloads-card__preview,
:root[data-theme] .downloads-audio-waveform,
:root[data-theme] .downloads-now-playing__waveform {
  background: var(--control-bg);
  background-image: none;
  border-color: var(--border-soft);
  color: var(--ink);
}

:root[data-theme] .downloads-card__editor {
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  border-color: color-mix(in srgb, var(--ink) 18%, transparent);
  color: var(--accent-dark);
}

:root[data-theme] .downloads-card__download {
  background: color-mix(in srgb, var(--ink) 72%, transparent);
  border-color: color-mix(in srgb, var(--surface) 72%, transparent);
  color: var(--surface);
}

:root[data-theme] .downloads-card--audio.is-playing,
:root[data-theme] .downloads-card.is-playing {
  border-color: color-mix(in srgb, var(--accent) 48%, var(--border-soft));
  box-shadow: 0 18px 44px color-mix(in srgb, var(--accent) 22%, transparent);
}

:root[data-theme] .downloads-audio-player__play,
:root[data-theme] .downloads-now-playing__play {
  background: var(--accent);
  color: var(--on-accent);
}

:root[data-theme] .forum-hero {
  background: var(--surface);
  background-image: none;
}

:root[data-theme] .forum-category-card,
:root[data-theme] .forum-thread-row,
:root[data-theme] .forum-post,
:root[data-theme] .forum-composer {
  background: var(--control-bg);
  background-image: none;
  border-color: var(--border-soft);
  color: var(--ink);
}

:root[data-theme] .forum-thread-row--pinned {
  background: color-mix(in srgb, var(--accent) 16%, var(--surface));
}

:root[data-theme] .forum-lede,
:root[data-theme] .forum-category-card p,
:root[data-theme] .forum-thread-row p,
:root[data-theme] .forum-thread-row span,
:root[data-theme] .forum-category-card span,
:root[data-theme] .forum-thread__meta,
:root[data-theme] .forum-post__header span,
:root[data-theme] .forum-composer label {
  color: var(--muted);
}

:root[data-theme] .forum-category-card strong,
:root[data-theme] .forum-thread-row strong,
:root[data-theme] .forum-post__header strong,
:root[data-theme] .forum-card h2 {
  color: var(--ink);
}

:root[data-theme] .forum-button {
  background: var(--accent);
  border-color: color-mix(in srgb, var(--accent) 70%, var(--border-soft));
  color: var(--on-accent);
}

:root[data-theme] .legal-doc__card p,
:root[data-theme] .legal-doc__card li,
:root[data-theme] .legal-doc__content p,
:root[data-theme] .legal-doc__content li {
  color: var(--muted);
}

:root[data-theme] .legal-doc__stat strong,
:root[data-theme] .legal-doc__card h2,
:root[data-theme] .legal-doc__content h2,
:root[data-theme] .legal-doc__content h3 {
  color: var(--ink);
}

:root[data-theme] .legal-doc__toc a {
  color: var(--accent-dark);
}

:root[data-theme] .forum-eyebrow {
  color: var(--accent-dark);
}

:root[data-theme] .site-theme-switcher__button,
:root[data-theme] .site-notification-center__button,
:root[data-theme] .site-theme-switcher__menu {
  background: var(--surface);
  border-color: var(--border-soft);
  color: var(--ink);
  box-shadow: 0 16px 42px var(--surface-shadow);
}

:root[data-theme] .site-notification-center__menu {
  background: var(--surface);
  border-color: var(--border-soft);
  color: var(--ink);
  box-shadow: 0 16px 42px var(--surface-shadow);
}

/* Inner pieces of the notification-center menu — header sub-line text,
   toggle/time row backgrounds, and the time-pill input — all baked in
   light-mode colors. Re-paint them through theme tokens so dark themes
   stop showing dark text on dark surfaces. */
:root[data-theme] .site-notification-center__header span {
  color: var(--muted-strong);
}

:root[data-theme] .site-notification-center__toggle,
:root[data-theme] .site-notification-center__time {
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: var(--ink);
}

:root[data-theme] .site-notification-center__toggle span:last-child {
  background: color-mix(in srgb, var(--ink) 30%, transparent);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--ink) 16%, transparent);
}

:root[data-theme] .site-notification-center__toggle input:checked + span {
  background: color-mix(in srgb, var(--accent) 70%, transparent);
}

:root[data-theme] .site-notification-center__time input {
  background: var(--control-bg-strong);
  border-color: var(--control-border);
  color: var(--ink);
}

:root[data-theme] .site-notification-center__actions button {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  border-color: color-mix(in srgb, var(--accent) 38%, var(--border-soft));
  color: var(--accent);
}

:root[data-theme] .site-notification-center__actions button:hover,
:root[data-theme] .site-notification-center__actions button:focus-visible {
  background: color-mix(in srgb, var(--accent) 26%, transparent);
}

:root[data-theme] .site-theme-switcher__menu button {
  color: var(--ink);
}

:root[data-theme] .site-theme-switcher__menu button:hover,
:root[data-theme] .site-theme-switcher__menu button:focus-visible,
:root[data-theme] .site-theme-switcher__menu button.is-current {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  color: var(--ink);
}

:root[data-theme] .site-theme-switcher__swatches {
  background: color-mix(in srgb, var(--accent) 12%, transparent);
}

:root[data-theme] .search-results-meta {
  box-shadow: none;
}

:root[data-theme] .search-engine-result {
  border: 1px solid var(--border-soft);
  box-shadow: 0 14px 34px var(--surface-shadow);
}

:root[data-theme] .reader-movie {
  background: rgba(7, 6, 4, 0.68);
}

:root[data-theme] .reader-movie__panel,
:root[data-theme] .reader-movie__controls-popover,
:root[data-theme] .reader-movie__settings-popover {
  background:
    radial-gradient(circle at top left, rgba(255, 232, 194, 0.2), transparent 36%),
    linear-gradient(145deg, rgba(34, 26, 18, 0.98), rgba(15, 13, 10, 0.98));
  border-color: rgba(255, 245, 230, 0.2);
  color: #fff8ec;
  box-shadow: 0 32px 90px rgba(0, 0, 0, 0.42);
}

:root[data-theme] .reader-movie.is-maximized {
  background: #070604;
}

:root[data-theme] .reader-movie.is-maximized .reader-movie__topbar,
:root[data-theme] .reader-movie.is-maximized .reader-movie__controls {
  background: rgba(15, 13, 10, 0.66);
  border-color: rgba(255, 248, 236, 0.16);
  color: #fff8ec;
}

:root[data-theme] .reader-movie__title,
:root[data-theme] .reader-movie__subtitle p,
:root[data-theme] .reader-movie__play,
:root[data-theme] .reader-movie__close,
:root[data-theme] .reader-movie__icon-button {
  color: #fff8ec;
}

:root[data-theme] .reader-movie__eyebrow,
:root[data-theme] .reader-movie__time,
:root[data-theme] .reader-movie__master-volume,
:root[data-theme] .reader-movie__volume-row,
:root[data-theme] .reader-movie__subtitle span,
:root[data-theme] .reader-movie__empty {
  color: rgba(255, 248, 236, 0.74);
}

:root[data-theme] .reader-movie__close,
:root[data-theme] .reader-movie__icon-button,
:root[data-theme] .reader-movie__aspect-group,
:root[data-theme] .reader-movie__aspect-button {
  background: rgba(255, 248, 236, 0.1);
  border-color: rgba(255, 248, 236, 0.2);
}

:root[data-theme] .reader-movie__play {
  background: #f6c06a;
  border-color: rgba(255, 248, 236, 0.24);
  color: #17110b;
}

:root[data-theme] .reader-movie__cc.is-active,
:root[data-theme] .reader-movie__pip.is-active,
:root[data-theme] .reader-movie__fullscreen.is-active,
:root[data-theme] .reader-movie__aspect-button.is-active {
  background: rgba(246, 192, 106, 0.24);
  border-color: rgba(246, 192, 106, 0.7);
  color: #fff1c8;
}

:root[data-theme] .reader-movie__seek::-webkit-slider-runnable-track {
  background:
    linear-gradient(90deg, #f6c06a, #fff1c8) 0 / var(--movie-progress, 0%) 100% no-repeat,
    rgba(255, 248, 236, 0.2);
}

:root[data-theme] .reader-movie__volume-slider::-webkit-slider-runnable-track,
:root[data-theme] .reader-movie__volume-row input[type="range"]::-webkit-slider-runnable-track {
  background: linear-gradient(90deg, #f6c06a 0 var(--movie-volume-percent, 100%), rgba(255, 248, 236, 0.26) var(--movie-volume-percent, 100%) 100%);
}

:root[data-theme] .prayer-card__zip {
  background: var(--control-bg);
  border: 1px solid var(--control-border);
  color: var(--accent-dark);
  box-shadow: 0 10px 24px var(--surface-shadow);
}

:root[data-theme] .prayer-card__zip:hover,
:root[data-theme] .prayer-card__zip:focus-visible {
  background: var(--accent);
  border-color: color-mix(in srgb, var(--accent) 72%, var(--control-border));
  color: var(--on-accent);
}

:root[data-theme] body[data-page="editor"] .editor-workbench {
  color: var(--ink);
}

:root[data-theme] body[data-page="editor"] .editor-panel {
  background: var(--surface);
  border-color: var(--border-soft);
  color: var(--ink);
  box-shadow: 0 18px 36px var(--surface-shadow);
}

:root[data-theme] body[data-page="editor"] .editor-panel__split {
  background: linear-gradient(180deg, var(--surface) 0%, var(--surface) 82%, color-mix(in srgb, var(--surface) 0%, transparent) 100%);
  border-bottom-color: var(--border-soft);
  box-shadow: inset 0 -1px 0 color-mix(in srgb, var(--border-soft) 70%, transparent);
}

:root[data-theme] body[data-page="editor"] .editor-create-dialog-backdrop {
  background: color-mix(in srgb, var(--ink) 54%, transparent);
}

:root[data-theme] body[data-page="editor"] .editor-ai-strip,
:root[data-theme] body[data-page="editor"] .editor-stage-toolbar,
:root[data-theme] body[data-page="editor"] .editor-create-dialog,
:root[data-theme] body[data-page="editor"] .editor-color-popover__panel,
:root[data-theme] body[data-page="editor"] .editor-crop-controls,
:root[data-theme] body[data-page="editor"] .editor-crop-box__label,
:root[data-theme] body[data-page="editor"] .editor-ruler-corner,
:root[data-theme] body[data-page="editor"] .editor-ruler,
:root[data-theme] body[data-page="editor"] .editor-template-browser__selection,
:root[data-theme] body[data-page="editor"] .editor-source-choice,
:root[data-theme] body[data-page="editor"] .editor-create-source,
:root[data-theme] body[data-page="editor"] .editor-create-source__panel,
:root[data-theme] body[data-page="editor"] .editor-create-source__body,
:root[data-theme] body[data-page="editor"] .editor-layer-list__item,
:root[data-theme] body[data-page="editor"] .editor-template-browser__loading,
:root[data-theme] body[data-page="editor"] .editor-template-browser__status {
  background: var(--surface);
  background-image: none;
  border-color: var(--border-soft);
  color: var(--ink);
  box-shadow: 0 16px 42px var(--surface-shadow);
}

:root[data-theme] body[data-page="editor"] .editor-stage-wrap {
  background:
    linear-gradient(45deg, color-mix(in srgb, var(--ink) 6%, transparent) 25%, transparent 25%),
    linear-gradient(-45deg, color-mix(in srgb, var(--ink) 6%, transparent) 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, color-mix(in srgb, var(--ink) 6%, transparent) 75%),
    linear-gradient(-45deg, transparent 75%, color-mix(in srgb, var(--ink) 6%, transparent) 75%),
    var(--surface-strong);
  background-size: 26px 26px;
  background-position: 0 0, 0 13px, 13px -13px, -13px 0, 0 0;
  border-color: var(--border-soft);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--surface) 70%, transparent), 0 18px 40px var(--surface-shadow);
}

:root[data-theme] body[data-page="editor"] .editor-tool,
:root[data-theme] body[data-page="editor"] .editor-button,
:root[data-theme] body[data-page="editor"] .editor-toolbar-button,
:root[data-theme] body[data-page="editor"] .editor-size-preset,
:root[data-theme] body[data-page="editor"] .editor-template-card,
:root[data-theme] body[data-page="editor"] .editor-create-source__tab,
:root[data-theme] body[data-page="editor"] .editor-custom-source,
:root[data-theme] body[data-page="editor"] .editor-create-image-card,
:root[data-theme] body[data-page="editor"] .editor-verse-result,
:root[data-theme] body[data-page="editor"] .editor-verse-preview,
:root[data-theme] body[data-page="editor"] .editor-icon-button,
:root[data-theme] body[data-page="editor"] .editor-icon-toggle,
:root[data-theme] body[data-page="editor"] .editor-inline-action-button,
:root[data-theme] body[data-page="editor"] .editor-color-trigger,
:root[data-theme] body[data-page="editor"] .editor-stepper,
:root[data-theme] body[data-page="editor"] .editor-stepper__button,
:root[data-theme] body[data-page="editor"] .editor-crop-control,
:root[data-theme] body[data-page="editor"] .editor-field-stack--source,
:root[data-theme] body[data-page="editor"] .editor-layer-list__item {
  background: var(--control-bg);
  background-image: none;
  border-color: var(--control-border);
  color: var(--ink);
  box-shadow: none;
}

:root[data-theme] body[data-page="editor"] .editor-tool:hover,
:root[data-theme] body[data-page="editor"] .editor-tool:focus-visible,
:root[data-theme] body[data-page="editor"] .editor-button:hover,
:root[data-theme] body[data-page="editor"] .editor-button:focus-visible,
:root[data-theme] body[data-page="editor"] .editor-toolbar-button:hover,
:root[data-theme] body[data-page="editor"] .editor-toolbar-button:focus-visible,
:root[data-theme] body[data-page="editor"] .editor-template-card:hover,
:root[data-theme] body[data-page="editor"] .editor-template-card:focus-visible,
:root[data-theme] body[data-page="editor"] .editor-create-source__tab:hover,
:root[data-theme] body[data-page="editor"] .editor-create-source__tab:focus-visible,
:root[data-theme] body[data-page="editor"] .editor-icon-button:hover,
:root[data-theme] body[data-page="editor"] .editor-icon-button:focus-visible,
:root[data-theme] body[data-page="editor"] .editor-icon-toggle:hover,
:root[data-theme] body[data-page="editor"] .editor-icon-toggle:focus-visible {
  background: color-mix(in srgb, var(--accent) 18%, var(--control-bg));
  border-color: color-mix(in srgb, var(--accent) 42%, var(--control-border));
  color: var(--accent-dark);
}

:root[data-theme] body[data-page="editor"] .editor-tool.is-active,
:root[data-theme] body[data-page="editor"] .editor-toolbar-button.is-active,
:root[data-theme] body[data-page="editor"] .editor-segmented__button.is-active,
:root[data-theme] body[data-page="editor"] .editor-create-source__tab.is-active,
:root[data-theme] body[data-page="editor"] .editor-template-card--remote.is-selected,
:root[data-theme] body[data-page="editor"] .editor-template-card--shape.is-selected,
:root[data-theme] body[data-page="editor"] .editor-crop-control.is-active,
:root[data-theme] body[data-page="editor"] .editor-crop-control--confirm {
  background: color-mix(in srgb, var(--accent) 22%, var(--surface));
  border-color: color-mix(in srgb, var(--accent) 52%, var(--border-soft));
  color: var(--accent-dark);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 18%, transparent);
}

:root[data-theme] body[data-page="editor"] .editor-field input,
:root[data-theme] body[data-page="editor"] .editor-field textarea,
:root[data-theme] body[data-page="editor"] .editor-field select,
:root[data-theme] body[data-page="editor"] .editor-create-dialog .editor-field input,
:root[data-theme] body[data-page="editor"] .editor-create-dialog .editor-field select,
:root[data-theme] body[data-page="editor"] .editor-create-dialog .editor-inline-actions input,
:root[data-theme] body[data-page="editor"] .editor-textbar__select,
:root[data-theme] body[data-page="editor"] .editor-textbar__size,
:root[data-theme] body[data-page="editor"] .editor-stepper .editor-input--mini,
:root[data-theme] body[data-page="editor"] .editor-field .editor-stepper .editor-input--mini {
  background: var(--control-bg-strong) !important;
  background-image: none !important;
  border-color: var(--control-border);
  color: var(--ink);
  color-scheme: light dark;
}

:root[data-theme] body[data-page="editor"] .editor-create-dialog .editor-field select option,
:root[data-theme] body[data-page="editor"] .editor-create-dialog .editor-field select optgroup,
:root[data-theme] body[data-page="editor"] .editor-textbar__select option,
:root[data-theme] body[data-page="editor"] .editor-textbar__select optgroup {
  background: var(--surface);
  color: var(--ink);
}

:root[data-theme] body[data-page="editor"] .editor-field input::placeholder,
:root[data-theme] body[data-page="editor"] .editor-field textarea::placeholder,
:root[data-theme] body[data-page="editor"] .editor-create-dialog .editor-field input::placeholder,
:root[data-theme] body[data-page="editor"] .editor-create-dialog .editor-inline-actions input::placeholder {
  color: var(--muted);
  opacity: 0.72;
}

:root[data-theme] body[data-page="editor"] .editor-stage-toolbar__separator,
:root[data-theme] body[data-page="editor"] .editor-crop-controls__separator {
  background: var(--border-soft);
}

:root[data-theme] body[data-page="editor"] .editor-field span,
:root[data-theme] body[data-page="editor"] .editor-panel p,
:root[data-theme] body[data-page="editor"] .editor-create-hint,
:root[data-theme] body[data-page="editor"] .editor-empty-state,
:root[data-theme] body[data-page="editor"] .editor-layer-list__item small,
:root[data-theme] body[data-page="editor"] .editor-template-card span,
:root[data-theme] body[data-page="editor"] .editor-template-card__provider,
:root[data-theme] body[data-page="editor"] .editor-source-choice__empty,
:root[data-theme] body[data-page="editor"] .editor-ai-strip__status,
:root[data-theme] body[data-page="editor"] .editor-ai-strip__signin,
:root[data-theme] body[data-page="editor"] .editor-verse-preview__meta,
:root[data-theme] body[data-page="editor"] .editor-verse-result span {
  color: var(--muted);
}

:root[data-theme] body[data-page="editor"] .editor-ai-strip__credits,
:root[data-theme] body[data-page="editor"] .editor-template-group h3,
:root[data-theme] body[data-page="editor"] .editor-create-empty h3,
:root[data-theme] body[data-page="editor"] .editor-verse-result strong,
:root[data-theme] body[data-page="editor"] .editor-verse-preview__text {
  color: var(--ink);
}

:root[data-theme] body[data-page="editor"] .editor-grid-overlay {
  background-image:
    linear-gradient(to right, color-mix(in srgb, var(--accent) 22%, transparent) 1.5px, transparent 1.5px),
    linear-gradient(to bottom, color-mix(in srgb, var(--accent) 22%, transparent) 1.5px, transparent 1.5px),
    linear-gradient(to right, color-mix(in srgb, var(--accent) 34%, transparent) 2px, transparent 2px),
    linear-gradient(to bottom, color-mix(in srgb, var(--accent) 34%, transparent) 2px, transparent 2px);
}

:root[data-theme] body[data-page="editor"] .editor-ruler__tick,
:root[data-theme] body[data-page="editor"] .editor-ruler__tick.is-major {
  background: color-mix(in srgb, var(--ink) 52%, transparent);
}

:root[data-theme] body[data-page="editor"] .editor-ruler__label,
:root[data-theme] body[data-page="editor"] .editor-crosspad__rotate-badge,
:root[data-theme] body[data-page="editor"] .editor-rotation-strip__label {
  color: var(--muted);
  text-shadow: none;
}

/* Final shared theme coverage for controls, menus, popovers, and dialogs. */
:root[data-theme] .site-header,
:root[data-theme] .site-footer {
  border-color: var(--border-soft);
}

:root[data-theme] .site-language-switcher__button,
:root[data-theme] .site-theme-switcher__button,
:root[data-theme] .site-notification-center__button,
:root[data-theme] .viewport-zoom-controls__button,
:root[data-theme] .site-footer-toggle,
:root[data-theme] .site-footer__toggle,
:root[data-theme] .reader-icon-button,
:root[data-theme] .chapter-reader__font-menu-toggle,
:root[data-theme] .chapter-reader__font-stepper,
:root[data-theme] .chapter-reader__font-family-select,
:root[data-theme] .verse-audio-settings-button,
:root[data-theme] .verse-audio-settings-popover,
:root[data-theme] .selection-popover,
:root[data-theme] .selection-popover button,
:root[data-theme] .strongs-tooltip,
:root[data-theme] .strongs-chip,
:root[data-theme] .translation-compare__back,
:root[data-theme] .translation-compare__actions .reader-icon-button,
:root[data-theme] .auth-modal__close,
:root[data-theme] .auth-modal__tab,
:root[data-theme] .auth-modal__action,
:root[data-theme] .auth-modal__resend,
:root[data-theme] .auth-modal__otp-input,
:root[data-theme] .share-popup__close,
:root[data-theme] .share-popup__copy,
:root[data-theme] .share-popup__link,
:root[data-theme] .share-popup__mode,
:root[data-theme] .gallery-modal__close,
:root[data-theme] .book-reader-modal__close,
:root[data-theme] .book-reader-modal__actions button,
:root[data-theme] .hourly-prayers-font-toggle,
:root[data-theme] .hourly-prayers-share,
:root[data-theme] .hourly-prayers-tab,
:root[data-theme] .downloads-tab,
:root[data-theme] .downloads-tag-filter__item,
:root[data-theme] .downloads-audio-player__play,
:root[data-theme] .downloads-audio-player__download,
:root[data-theme] .downloads-now-playing__collapse,
:root[data-theme] .downloads-now-playing__close,
:root[data-theme] .site-audio-resume__expand,
:root[data-theme] .site-audio-resume__close,
:root[data-theme] .prayer-card__zip,
:root[data-theme] body[data-page="editor"] .editor-icon-button,
:root[data-theme] body[data-page="editor"] .editor-toolbar-button,
:root[data-theme] body[data-page="editor"] .editor-button,
:root[data-theme] body[data-page="editor"] .editor-tool,
:root[data-theme] body[data-page="editor"] .editor-color-trigger,
:root[data-theme] body[data-page="editor"] .editor-inline-action-button,
:root[data-theme] body[data-page="editor"] .editor-stepper__button {
  background: var(--control-bg);
  background-image: none;
  border-color: var(--control-border);
  color: var(--ink);
  box-shadow: 0 10px 24px var(--surface-shadow);
}

:root[data-theme] .site-language-switcher__button:hover,
:root[data-theme] .site-language-switcher__button:focus-visible,
:root[data-theme] .site-notification-center__button:hover,
:root[data-theme] .site-notification-center__button:focus-visible,
:root[data-theme] .site-notification-center:focus-within .site-notification-center__button,
:root[data-theme] .site-notification-center.is-open .site-notification-center__button,
:root[data-theme] .site-theme-switcher__button:hover,
:root[data-theme] .site-theme-switcher__button:focus-visible,
:root[data-theme] .site-theme-switcher:focus-within .site-theme-switcher__button,
:root[data-theme] .site-theme-switcher.is-open .site-theme-switcher__button,
:root[data-theme] .viewport-zoom-controls__button:hover,
:root[data-theme] .viewport-zoom-controls__button:focus-visible,
:root[data-theme] .site-footer-toggle:hover,
:root[data-theme] .site-footer-toggle:focus-visible,
:root[data-theme] .site-footer-toggle.is-open,
:root[data-theme] .site-footer__toggle:hover,
:root[data-theme] .site-footer__toggle:focus-visible,
:root[data-theme] .reader-icon-button:hover,
:root[data-theme] .reader-icon-button:focus-visible,
:root[data-theme] .chapter-reader__font-menu-toggle:hover,
:root[data-theme] .chapter-reader__font-menu-toggle:focus-visible,
:root[data-theme] .chapter-reader__font-stepper:hover,
:root[data-theme] .chapter-reader__font-stepper:focus-visible,
:root[data-theme] .verse-audio-settings-button:hover,
:root[data-theme] .verse-audio-settings-button:focus-visible,
:root[data-theme] .selection-popover button:hover,
:root[data-theme] .selection-popover button:focus-visible,
:root[data-theme] .auth-modal__tab:hover,
:root[data-theme] .auth-modal__tab:focus-visible,
:root[data-theme] .auth-modal__action:hover,
:root[data-theme] .auth-modal__action:focus-visible,
:root[data-theme] .auth-modal__resend:hover,
:root[data-theme] .auth-modal__resend:focus-visible,
:root[data-theme] .share-popup__close:hover,
:root[data-theme] .share-popup__close:focus-visible,
:root[data-theme] .share-popup__copy:hover,
:root[data-theme] .share-popup__copy:focus-visible,
:root[data-theme] .share-popup__link:hover,
:root[data-theme] .share-popup__link:focus-visible,
:root[data-theme] .share-popup__mode:hover,
:root[data-theme] .share-popup__mode:focus-visible,
:root[data-theme] .share-popup__mode.is-active,
:root[data-theme] .hourly-prayers-tab:hover,
:root[data-theme] .hourly-prayers-tab:focus-visible,
:root[data-theme] .hourly-prayers-tab.is-active,
:root[data-theme] .downloads-tab:hover,
:root[data-theme] .downloads-tab:focus-visible,
:root[data-theme] .downloads-tab.is-active,
:root[data-theme] .downloads-tag-filter__item:hover,
:root[data-theme] .downloads-tag-filter__item:focus-within,
:root[data-theme] body[data-page="editor"] .editor-icon-button:hover,
:root[data-theme] body[data-page="editor"] .editor-icon-button:focus-visible,
:root[data-theme] body[data-page="editor"] .editor-toolbar-button:hover,
:root[data-theme] body[data-page="editor"] .editor-toolbar-button:focus-visible,
:root[data-theme] body[data-page="editor"] .editor-button:hover,
:root[data-theme] body[data-page="editor"] .editor-button:focus-visible {
  background: color-mix(in srgb, var(--accent) 18%, var(--control-bg));
  border-color: color-mix(in srgb, var(--accent) 42%, var(--control-border));
  color: var(--accent-dark);
  outline-color: color-mix(in srgb, var(--accent) 42%, transparent);
}

:root[data-theme] .auth-modal__action--google,
:root[data-theme] .auth-modal__action--facebook {
  background: color-mix(in srgb, var(--control-bg) 88%, var(--surface));
  border-color: var(--control-border);
  color: var(--ink);
}

:root[data-theme] .auth-modal__action--google .auth-modal__action-icon,
:root[data-theme] .auth-modal__action--facebook .auth-modal__action-icon {
  background: color-mix(in srgb, var(--accent) 18%, var(--surface));
  border: 1px solid color-mix(in srgb, var(--accent) 42%, var(--control-border));
  color: var(--accent-dark);
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--surface) 72%, transparent);
}

:root[data-theme] .auth-modal__action--google .auth-modal__action-icon svg path,
:root[data-theme] .auth-modal__action--facebook .auth-modal__action-icon svg path {
  fill: currentColor !important;
}

:root[data-theme] .auth-modal__dialog,
:root[data-theme] .auth-modal__code-card,
:root[data-theme] .auth-modal__tabs,
:root[data-theme] .share-popup__modes,
:root[data-theme] .chapter-reader__font-popover,
:root[data-theme] .hourly-prayers-font-popover,
:root[data-theme] .library-book-reader__font-popover,
:root[data-theme] .site-language-switcher__menu,
:root[data-theme] .site-theme-switcher__menu,
:root[data-theme] .site-notification-center__menu,
:root[data-theme] .share-popup__panel,
:root[data-theme] .image-lightbox__panel,
:root[data-theme] .gallery-modal__panel,
:root[data-theme] .book-reader-modal__dialog,
:root[data-theme] .editor-create-dialog,
:root[data-theme] .editor-color-popover__panel,
:root[data-theme] .editor-shape-dialog__body,
:root[data-theme] .downloads-filter-panel,
:root[data-theme] .downloads-filter-panel--simple,
:root[data-theme] .downloads-now-playing,
:root[data-theme] .site-audio-resume,
:root[data-theme] .hourly-prayers-hero,
:root[data-theme] .hourly-prayers-filters,
:root[data-theme] .hourly-prayers-section,
:root[data-theme] .hourly-prayer-index,
:root[data-theme] .prayer-card,
:root[data-theme] .media-card,
:root[data-theme] .downloads-card,
:root[data-theme] .library-card,
:root[data-theme] .reading-dashboard__hero,
:root[data-theme] .reading-dashboard__section,
:root[data-theme] .reading-dashboard__empty,
:root[data-theme] .ranking-card,
:root[data-theme] .forum-card,
:root[data-theme] .ai-chat-card {
  background: var(--surface);
  background-image: none;
  border-color: var(--border-soft);
  color: var(--ink);
  box-shadow: 0 18px 44px var(--surface-shadow);
}

:root[data-theme] .site-notification-center__menu {
  background: var(--surface-strong);
  background-image: none;
  border-color: var(--border-soft);
  color: var(--ink);
  box-shadow: 0 24px 56px var(--elevated-shadow);
}

:root[data-theme] .site-notification-center__toggle,
:root[data-theme] .site-notification-center__time {
  background: color-mix(in srgb, var(--accent) 9%, var(--surface-strong));
  border-color: var(--border-soft);
  color: var(--ink);
}

:root[data-theme] .site-notification-center__actions button {
  background: color-mix(in srgb, var(--accent) 14%, var(--surface-strong));
  border-color: color-mix(in srgb, var(--accent) 38%, var(--border-soft));
  color: var(--accent);
}

:root[data-theme] .site-notification-center__actions button:hover,
:root[data-theme] .site-notification-center__actions button:focus-visible {
  background: color-mix(in srgb, var(--accent) 22%, var(--surface-strong));
}

:root[data-theme] .chapter-reader__font-popover::before,
:root[data-theme] .hourly-prayers-font-popover::before,
:root[data-theme] .library-book-reader__font-popover::before {
  background: var(--surface);
  border-color: var(--border-soft);
}

/* Library popover internal pieces — match the chapter popover dark
   theming for header sub-label, row labels, size value, stepper group
   surface, font-family select gradient, and the reset pill. */
:root[data-theme] .library-book-reader__font-popover-header span,
:root[data-theme] .library-book-reader__font-row-label,
:root[data-theme] .library-book-reader__font-size-value {
  color: var(--muted);
}

:root[data-theme] .library-book-reader__font-preview {
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--surface) 88%, transparent), color-mix(in srgb, var(--surface) 80%, transparent)),
    repeating-linear-gradient(90deg, color-mix(in srgb, var(--accent) 10%, transparent) 0 1px, transparent 1px 12px);
  border-color: var(--border-soft);
  color: var(--ink);
}

:root[data-theme] .library-book-reader__font-stepper-group {
  background: color-mix(in srgb, var(--surface) 78%, transparent);
  border-color: var(--border-soft);
}

:root[data-theme] .library-book-reader__font-stepper {
  background: color-mix(in srgb, var(--ink) 8%, transparent);
  color: var(--ink);
}

:root[data-theme] .library-book-reader__font-stepper:hover,
:root[data-theme] .library-book-reader__font-stepper:focus-visible {
  background: color-mix(in srgb, var(--accent) 22%, transparent);
}

:root[data-theme] .library-book-reader__font-family-select {
  background: linear-gradient(180deg, color-mix(in srgb, var(--surface) 92%, transparent), color-mix(in srgb, var(--surface) 80%, transparent));
  border-color: var(--control-border);
  color: var(--ink);
}

:root[data-theme] .library-book-reader__font-family-button {
  background: linear-gradient(180deg, color-mix(in srgb, var(--surface) 92%, transparent), color-mix(in srgb, var(--surface) 80%, transparent));
  border-color: var(--control-border);
  color: var(--ink);
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--surface) 70%, transparent);
}

:root[data-theme] .library-book-reader__font-family-button:hover,
:root[data-theme] .library-book-reader__font-family-button:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 38%, var(--control-border));
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, var(--surface) 70%, transparent),
    0 0 0 3px color-mix(in srgb, var(--accent) 14%, transparent);
}

:root[data-theme] .library-book-reader__font-family-menu {
  background: var(--surface);
  border-color: var(--border-soft);
  box-shadow: 0 18px 42px var(--surface-shadow);
}

:root[data-theme] .library-book-reader__font-family-menu li {
  color: var(--ink);
}

:root[data-theme] .library-book-reader__font-family-menu li:hover,
:root[data-theme] .library-book-reader__font-family-menu li:focus-visible,
:root[data-theme] .library-book-reader__font-family-menu li.is-current {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
}

:root[data-theme] .library-book-reader__font-reset {
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  border-color: color-mix(in srgb, var(--accent) 38%, var(--border-soft));
  color: var(--accent-dark);
}

:root[data-theme] .library-book-reader__font-reset:hover,
:root[data-theme] .library-book-reader__font-reset:focus-visible {
  background: color-mix(in srgb, var(--accent) 28%, transparent);
  border-color: color-mix(in srgb, var(--accent) 56%, var(--border-soft));
}

:root[data-theme] .auth-modal__status,
:root[data-theme] .auth-modal__code-meta,
:root[data-theme] .auth-modal__divider,
:root[data-theme] .auth-modal__hint,
:root[data-theme] .chapter-reader__font-popover-header span,
:root[data-theme] .chapter-reader__font-row-label,
:root[data-theme] .chapter-reader__font-size-value,
:root[data-theme] .strongs-tooltip__meta,
:root[data-theme] .strongs-tooltip__body,
:root[data-theme] .strongs-tooltip__source,
:root[data-theme] .strongs-tooltip__usage,
:root[data-theme] .strongs-tooltip__attribution,
:root[data-theme] .share-popup__eyebrow,
:root[data-theme] .share-popup__summary,
:root[data-theme] .share-popup__label,
:root[data-theme] .image-lightbox__caption,
:root[data-theme] .gallery-modal__title span,
:root[data-theme] .chapter-reader__reference-separator,
:root[data-theme] .downloads-filter-panel label,
:root[data-theme] .downloads-card__meta,
:root[data-theme] .prayer-card__meta,
:root[data-theme] .reading-dashboard__hero p,
:root[data-theme] .reading-dashboard__empty p,
:root[data-theme] .hourly-prayers-page p,
:root[data-theme] .hourly-prayers-page small {
  color: var(--muted);
}

:root[data-theme] .bible-browser__eyebrow--link,
:root[data-theme] .search-bible-picker,
:root[data-theme] .search-bible-picker span {
  color: var(--muted-strong);
}

:root[data-theme] .book-card__meta,
:root[data-theme] .chapter-card__meta,
:root[data-theme] .book-card__body p {
  color: rgba(255, 255, 255, 0.9);
  text-shadow: 0 3px 12px rgba(0, 0, 0, 0.42);
}

:root[data-theme] .book-card__body h2,
:root[data-theme] .chapter-card__label {
  color: #fff;
  text-shadow: 0 4px 18px rgba(0, 0, 0, 0.48);
}

:root[data-theme] .auth-modal__submit,
:root[data-theme] .btn.primary,
:root[data-theme] .downloads-audio-player__play,
:root[data-theme] .downloads-now-playing__play,
:root[data-theme] .site-audio-resume__play,
:root[data-theme] .product-gallery__edit-button,
:root[data-theme] .chapter-reader__action-button:not(.chapter-reader__action-button--secondary),
:root[data-theme] .prayer-card__zip:hover,
:root[data-theme] .prayer-card__zip:focus-visible {
  background: var(--accent);
  background-image: none;
  border-color: color-mix(in srgb, var(--accent) 72%, var(--border-soft));
  color: var(--on-accent);
}

:root[data-theme] .auth-modal__field input,
:root[data-theme] .auth-modal__otp-input,
:root[data-theme] .chapter-reader__font-family-select,
:root[data-theme] .downloads-filter-panel select,
:root[data-theme] .downloads-filter-panel input,
:root[data-theme] .hourly-prayers-filters select,
:root[data-theme] .hourly-prayers-admin input,
:root[data-theme] .hourly-prayers-admin textarea,
:root[data-theme] .hourly-prayers-admin select,
:root[data-theme] .search-page input,
:root[data-theme] .search-page select,
:root[data-theme] .search-page textarea,
:root[data-theme] .library-filters input,
:root[data-theme] .library-filters select,
:root[data-theme] body[data-page="editor"] input,
:root[data-theme] body[data-page="editor"] textarea,
:root[data-theme] body[data-page="editor"] select {
  background: var(--control-bg-strong);
  background-image: none;
  border-color: var(--control-border);
  color: var(--ink);
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--surface) 72%, transparent);
}

:root[data-theme] .auth-modal__divider::before,
:root[data-theme] .auth-modal__divider::after,
:root[data-theme] .chapter-reader__font-stepper-group,
:root[data-theme] .site-footer__links,
:root[data-theme] .downloads-now-playing__waveform,
:root[data-theme] body[data-page="editor"] .editor-stage-toolbar__separator {
  background: color-mix(in srgb, var(--ink) 8%, var(--surface));
  border-color: var(--border-soft);
}

:root[data-theme] .site-audio-resume__seek {
  background: transparent;
  border-color: transparent;
  box-shadow: none;
}

:root[data-theme] button svg,
:root[data-theme] a svg {
  color: currentColor;
}

/* Image-overlay actions use fixed contrast instead of theme contrast, because the
   background is unpredictable image content rather than the themed surface. */
:root[data-theme] .downloads-card__download {
  background: rgba(12, 10, 8, 0.82);
  background-image: none;
  border-color: rgba(255, 250, 244, 0.36);
  color: #fffaf4;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.55);
}

:root[data-theme] .downloads-card__download:hover,
:root[data-theme] .downloads-card__download:focus-visible {
  background: rgba(12, 10, 8, 0.92);
  border-color: rgba(255, 250, 244, 0.6);
  color: #fffaf4;
}

:root[data-theme] .downloads-card__editor {
  background: rgba(255, 250, 244, 0.92);
  background-image: none;
  border-color: rgba(12, 10, 8, 0.22);
  color: #29170f;
  text-shadow: none;
}

:root[data-theme] .downloads-card__editor:hover,
:root[data-theme] .downloads-card__editor:focus-visible {
  background: #fffaf4;
  border-color: rgba(12, 10, 8, 0.36);
  color: #29170f;
}

:root[data-theme] .reader-icon-button.product-gallery__edit-button {
  background: rgba(12, 10, 8, 0.86);
  background-image: none;
  border-color: rgba(255, 250, 244, 0.34);
  color: #fffaf4;
  font-weight: 800;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);
}

:root[data-theme="midnight"] .reader-icon-button.product-gallery__edit-button,
:root[data-theme="contrast"] .reader-icon-button.product-gallery__edit-button {
  background: rgba(12, 10, 8, 0.86);
  border-color: rgba(255, 250, 244, 0.34);
  color: #fffaf4;
}

:root[data-theme] .reader-icon-button.product-gallery__edit-button span,
:root[data-theme] .reader-icon-button.product-gallery__edit-button svg {
  color: currentColor;
}

:root[data-theme] .reader-icon-button.product-gallery__edit-button:hover,
:root[data-theme] .reader-icon-button.product-gallery__edit-button:focus-visible {
  filter: brightness(1.04);
}

:root[data-theme] .hourly-prayers-font-toggle,
:root[data-theme] .hourly-prayers-share {
  background: var(--control-bg-strong);
  border-color: var(--control-border);
  color: var(--ink);
  font-weight: 800;
}

:root[data-theme] .chapter-reader__reference-separator {
  color: var(--muted-strong);
}

:root[data-theme] .search-media-card__body .reader-icon-button {
  background: rgba(12, 10, 8, 0.86);
  background-image: none;
  border-color: rgba(255, 250, 244, 0.34);
  color: #fffaf4;
  font-weight: 800;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);
}

:root[data-theme="midnight"] .search-media-card__body .reader-icon-button,
:root[data-theme="contrast"] .search-media-card__body .reader-icon-button {
  background: rgba(12, 10, 8, 0.86);
  border-color: rgba(255, 250, 244, 0.34);
  color: #fffaf4;
}

:root[data-theme] .search-engine-result__actions .reader-icon-button {
  background: rgba(12, 10, 8, 0.86);
  background-image: none;
  border-color: rgba(255, 250, 244, 0.34);
  color: #fffaf4;
  font-weight: 800;
}

:root[data-theme] .search-engine-result__actions .search-share-button,
:root[data-theme] .search-media-card__body .search-share-button {
  background: var(--control-bg);
  background-image: none;
  border-color: var(--control-border);
  color: var(--accent-dark);
  box-shadow: 0 8px 20px var(--surface-shadow);
  text-shadow: none;
}

:root[data-theme] .strongs-tooltip__link,
:root[data-theme] .admin-page__link {
  background: var(--control-bg);
  background-image: none;
  border-color: var(--control-border);
  color: var(--accent-dark);
}

:root[data-theme] .admin-page__header,
:root[data-theme] .admin-summary-card,
:root[data-theme] .admin-dashboard-panel,
:root[data-theme] .admin-audit-panel,
:root[data-theme] .admin-empty-state,
:root[data-theme] .admin-dashboard-list__item,
:root[data-theme] .admin-stats-list div,
:root[data-theme] .library-page .status {
  background: var(--surface);
  background-image: none;
  border-color: var(--border-soft);
  color: var(--ink);
}

:root[data-theme] .search-engine-result__trail,
:root[data-theme] .admin-page__eyebrow,
:root[data-theme] .admin-page__copy,
:root[data-theme] .admin-stats-list dt {
  color: var(--muted-strong);
}

:root[data-theme] .admin-statistics-page {
  color: var(--ink);
}

:root[data-theme] .admin-statistics-page .admin-page__header,
:root[data-theme] .admin-statistics-page .admin-summary-card,
:root[data-theme] .admin-statistics-page .admin-dashboard-panel,
:root[data-theme] .admin-statistics-page .admin-audit-panel,
:root[data-theme] .admin-statistics-page .admin-dashboard-list__item,
:root[data-theme] .admin-statistics-page .admin-stats-list div {
  background: var(--surface);
  background-image: none;
  border-color: var(--border-soft);
  color: var(--ink);
}

:root[data-theme] .admin-statistics-page h1,
:root[data-theme] .admin-statistics-page h2,
:root[data-theme] .admin-statistics-page strong,
:root[data-theme] .admin-statistics-page dd,
:root[data-theme] .admin-statistics-page .admin-stats-row span {
  color: var(--ink);
}

:root[data-theme] .admin-statistics-page .admin-page__copy,
:root[data-theme] .admin-statistics-page .admin-audit-panel__header p,
:root[data-theme] .admin-statistics-page .admin-dashboard-list__item p,
:root[data-theme] .admin-statistics-page .admin-dashboard-footnote,
:root[data-theme] .admin-statistics-page .admin-summary-card__label,
:root[data-theme] .admin-statistics-page .admin-stats-list dt {
  color: var(--muted-strong);
}

:root[data-theme] body[data-page="editor"] .editor-glyph-stack__badge {
  background: rgba(12, 10, 8, 0.92);
  color: #fffaf4;
  box-shadow: 0 0 0 1px rgba(255, 250, 244, 0.24);
}

:root[data-theme] body[data-page="editor"] .editor-layers-opacity strong {
  color: var(--ink);
}

.synaxarium-page {
  display: grid;
  gap: 24px;
  min-width: 0;
  max-width: 100%;
}

body[data-page="synaxarium"] .site-footer-toggle {
  display: none;
}

.synaxarium-page[dir="rtl"],
.synaxarium-reader[dir="rtl"] {
  font-family: "Amiri", "Noto Naskh Arabic", "Scheherazade New", "Traditional Arabic", serif;
  line-height: 2.22;
}

.synaxarium-hero {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  padding: 28px;
  border: 1px solid var(--border-soft);
  border-radius: 8px;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--surface) 94%, var(--accent) 6%), var(--surface-strong));
  color: var(--ink);
  box-shadow: 0 14px 34px var(--surface-shadow);
}

.synaxarium-date-pair {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}

.synaxarium-date-pair span,
.synaxarium-today {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid var(--control-border);
  background: var(--control-bg);
  color: var(--ink);
  font-weight: 700;
  text-decoration: none;
}

.synaxarium-controls {
  display: grid;
  grid-template-columns: repeat(2, minmax(180px, 280px));
  gap: 16px;
  align-items: end;
}

.synaxarium-controls label {
  display: block;
  margin-bottom: 8px;
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
  color: var(--muted-strong);
}

.synaxarium-controls input,
.synaxarium-controls select {
  width: 100%;
  min-height: 46px;
  border-radius: 8px;
  border: 1px solid var(--control-border);
  background: var(--control-bg);
  color: var(--ink);
  padding: 8px 12px;
}

.synaxarium-layout {
  display: grid;
  grid-template-columns: minmax(300px, 430px) minmax(0, 1fr);
  gap: 24px;
  align-items: start;
}

.dual-calendar {
  display: grid;
  gap: 14px;
  padding: 18px;
  border: 1px solid var(--border-soft);
  border-radius: 8px;
  background: var(--surface);
  color: var(--ink);
  box-shadow: 0 14px 34px var(--surface-shadow);
}

.dual-calendar__header {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) 42px;
  gap: 12px;
  align-items: center;
}

.dual-calendar__nav {
  display: inline-flex;
  width: 42px;
  height: 42px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid var(--control-border);
  color: var(--accent-dark);
  background: var(--control-bg);
}

.dual-calendar__nav svg {
  width: 20px;
  height: 20px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.dual-calendar[dir="rtl"] .dual-calendar__nav svg {
  transform: scaleX(-1);
}

.dual-calendar__title {
  text-align: center;
  min-width: 0;
}

.dual-calendar__title h2 {
  margin: 0;
  font-size: 1.18rem;
}

.dual-calendar__title p {
  display: grid;
  gap: 3px;
  margin: 6px 0 0;
  color: var(--muted-strong);
  font-size: 0.9rem;
}

.dual-calendar__weekdays,
.dual-calendar__grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
}

.dual-calendar__weekdays {
  gap: 6px;
  color: var(--muted-strong);
  font-size: 0.82rem;
  font-weight: 800;
  text-align: center;
  text-transform: uppercase;
}

.dual-calendar__weekdays span {
  min-width: 0;
  overflow: hidden;
  white-space: nowrap;
}

.dual-calendar__grid {
  gap: 6px;
}

.dual-calendar__day {
  display: grid;
  align-content: center;
  gap: 3px;
  min-width: 0;
  min-height: 58px;
  padding: 7px 5px;
  border-radius: 8px;
  border: 1px solid var(--border-soft);
  background: var(--surface-strong);
  color: var(--ink);
  text-align: center;
  text-decoration: none;
}

.dual-calendar__day:hover,
.dual-calendar__day:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 45%, var(--border-soft));
  background: color-mix(in srgb, var(--accent) 12%, var(--surface-strong));
}

.dual-calendar__day.is-muted {
  opacity: 0.52;
}

.dual-calendar__day.is-today {
  border-color: color-mix(in srgb, var(--accent) 52%, var(--border-soft));
}

.dual-calendar__day.is-selected {
  background: var(--accent);
  border-color: color-mix(in srgb, var(--accent) 74%, var(--accent-dark));
  color: var(--on-accent);
}

.dual-calendar__gregorian {
  font-size: 1.05rem;
  font-weight: 900;
  line-height: 1;
}

.dual-calendar__coptic {
  min-width: 0;
  font-size: 0.8rem;
  line-height: 1.15;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.synaxarium-reader {
  display: grid;
  gap: 18px;
  min-width: 0;
  padding: 28px;
  border: 1px solid var(--border-soft);
  border-radius: 8px;
  background: var(--surface);
  color: var(--ink);
  box-shadow: 0 14px 34px var(--surface-shadow);
}

.synaxarium-reader__header h2 {
  margin: 0;
  font-size: clamp(1.6rem, 2vw, 2.2rem);
}

.synaxarium-source {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 12px;
  color: var(--muted-strong);
  font-size: 0.92rem;
}

.synaxarium-events {
  display: grid;
  gap: 20px;
}

.synaxarium-event {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 14px;
  padding-top: 20px;
  border-top: 1px solid var(--border-soft);
}

.synaxarium-event:first-child {
  padding-top: 0;
  border-top: 0;
}

.synaxarium-event__number {
  display: inline-flex;
  width: 42px;
  height: 42px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: color-mix(in srgb, var(--accent) 13%, var(--surface-strong));
  color: var(--accent-dark);
  font-weight: 900;
}

.synaxarium-event h3 {
  margin: 0 0 10px;
  font-size: 1.2rem;
  line-height: 1.35;
}

.synaxarium-event p {
  margin: 0 0 12px;
  color: color-mix(in srgb, var(--ink) 86%, transparent);
  font-size: 1.08rem;
  line-height: 1.75;
}

.synaxarium-event__source {
  display: inline-flex;
  align-items: center;
  margin-top: 4px;
  color: var(--link);
  font-size: .9rem;
  font-weight: 700;
  text-decoration: none;
}

.synaxarium-event__source:hover {
  text-decoration: underline;
}

.synaxarium-reader[dir="rtl"] .synaxarium-event p {
  font-size: 1.22rem;
  line-height: 2.22;
}

.synaxarium-empty {
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
  padding: 18px;
  border: 1px solid var(--border-soft);
  border-radius: 8px;
  background: var(--surface-strong);
}

.synaxarium-empty__icon {
  display: inline-flex;
  width: 46px;
  height: 46px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: color-mix(in srgb, var(--accent) 13%, var(--surface));
  color: var(--accent-dark);
}

.synaxarium-empty__icon svg {
  width: 23px;
  height: 23px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.synaxarium-empty h3 {
  margin: 0 0 6px;
  font-size: 1rem;
}

.synaxarium-empty p {
  margin: 0;
  color: var(--muted-strong);
  line-height: 1.6;
}

@media (max-width: 920px) {
  .synaxarium-layout {
    grid-template-columns: 1fr;
  }

  .synaxarium-controls {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 560px) {
  body[data-page="synaxarium"] {
    overflow-x: hidden;
    zoom: 1;
  }

  html[dir="rtl"] body[data-page="synaxarium"] {
    direction: ltr;
  }

  html[dir="rtl"] body[data-page="synaxarium"] .site-header,
  html[dir="rtl"] body[data-page="synaxarium"] .synaxarium-page {
    direction: rtl;
  }

  body[data-page="synaxarium"] .site-header .shell,
  body[data-page="synaxarium"] .content {
    width: 100%;
    max-width: 100%;
    margin-inline: 0;
    padding-inline: 10px;
    box-sizing: border-box;
  }

  body[data-page="synaxarium"] .header-search {
    display: none;
  }

  body[data-page="synaxarium"] .nav {
    max-width: 100%;
    flex-wrap: wrap;
    overflow: hidden;
    justify-content: center;
    gap: 10px 14px;
    font-size: max(18px, 0.95rem);
  }

  [dir="rtl"] body[data-page="synaxarium"] .nav {
    flex-direction: row;
  }

  .synaxarium-hero {
    flex-direction: column;
    padding: 22px;
    min-width: 0;
    overflow: hidden;
  }

  .dual-calendar,
  .synaxarium-reader {
    padding: 14px;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
  }

  .synaxarium-date-pair span,
  .synaxarium-controls,
  .synaxarium-controls .field {
    min-width: 0;
    max-width: 100%;
  }

  .dual-calendar__header {
    grid-template-columns: 38px minmax(0, 1fr) 38px;
  }

  .dual-calendar__nav {
    width: 38px;
    height: 38px;
  }

  .dual-calendar__day {
    min-height: 52px;
    padding-inline: 3px;
  }

  .dual-calendar__coptic {
    font-size: 0.74rem;
  }

  .synaxarium-event {
    grid-template-columns: 1fr;
  }
}

/* Library book publishing overrides. Kept at the end so they win over legacy download-card rules. */
.library-filters {
  grid-template-columns: minmax(150px, 0.7fr) minmax(150px, 0.7fr) minmax(170px, 0.8fr) minmax(240px, 1.25fr) minmax(150px, auto);
}

.library-filters__status {
  grid-column: 5;
  margin: 0;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  min-height: 24px;
  font-size: 0.95rem;
  color: color-mix(in srgb, var(--ink) 68%, transparent);
  white-space: nowrap;
}

.library-grid {
  align-items: stretch;
}

.library-card {
  position: relative;
  min-height: 430px;
  display: flex;
  align-items: stretch;
  grid-template-rows: none;
  gap: 0;
  padding: 0;
  isolation: isolate;
  background: #151311;
}

.library-card__media {
  position: absolute;
  inset: 0;
  aspect-ratio: auto;
  border-radius: inherit;
  background: #151311;
}

.library-card__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.9) 0%, rgba(0, 0, 0, 0.66) 34%, rgba(0, 0, 0, 0.2) 68%, rgba(0, 0, 0, 0.02) 100%);
  pointer-events: none;
}

.library-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.01);
}

.library-card__content {
  position: relative;
  z-index: 1;
  width: 100%;
  min-height: 430px;
  display: grid;
  align-content: end;
  gap: 12px;
  padding: 28px;
  color: #fff;
}

.library-card h2 a {
  color: inherit;
  text-decoration: none;
}

.library-card h2 a:hover,
.library-card h2 a:focus-visible {
  text-decoration: underline;
  text-underline-offset: 0.16em;
}

.library-card .library-card__description {
  min-height: 0;
  color: rgba(255, 255, 255, 0.82) !important;
}

.library-card__actions {
  align-items: center;
}

.library-card__actions a,
.library-card__actions button {
  border: 1px solid rgba(255, 255, 255, 0.28);
  background: rgba(255, 255, 255, 0.16);
  color: #fff;
  backdrop-filter: blur(10px);
}

.library-card__actions a:first-child {
  background: #fff;
  color: #171310;
}

.library-card__bookmark.is-active {
  background: color-mix(in srgb, var(--accent) 76%, #fff 24%);
  color: #171310;
}

@media (max-width: 820px) {
  .library-filters {
    grid-template-columns: 1fr;
  }

  .library-filters__status {
    grid-column: 1;
    justify-content: flex-start;
    white-space: normal;
  }
}

/* Synaxarium share and calendar refinements. */
.synaxarium-layout {
  grid-template-columns: minmax(380px, 540px) minmax(0, 1fr);
}

.synaxarium-reader__header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 16px;
}

.synaxarium-share-button,
.synaxarium-event__share,
.synaxarium-share-modal__actions button {
  border: 1px solid color-mix(in srgb, var(--accent) 42%, var(--border-soft));
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 10%, var(--surface));
  color: var(--ink);
  font-weight: 800;
  padding: 10px 14px;
  cursor: pointer;
}

.synaxarium-event__heading {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 14px;
}

.synaxarium-event__heading h3 {
  margin-inline-end: auto;
}

.synaxarium-event__share {
  flex: 0 0 auto;
  padding: 8px 12px;
  font-size: 0.88rem;
}

.synaxarium-share-modal[hidden] {
  display: none;
}

.synaxarium-share-modal {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: grid;
  place-items: center;
  padding: 20px;
}

.synaxarium-share-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(12, 10, 8, 0.58);
}

.synaxarium-share-modal__dialog {
  position: relative;
  z-index: 1;
  width: min(520px, 100%);
  display: grid;
  gap: 16px;
  padding: 22px;
  border: 1px solid var(--border-soft);
  border-radius: 8px;
  background: var(--surface);
  color: var(--ink);
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.32);
}

.synaxarium-share-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.synaxarium-share-modal__header h2,
.synaxarium-share-modal__subject,
.synaxarium-share-modal__status {
  margin: 0;
}

.synaxarium-share-modal__header button {
  width: 40px;
  height: 40px;
  border: 1px solid var(--border-soft);
  border-radius: 50%;
  background: var(--surface-strong);
  color: var(--ink);
  font-size: 1.4rem;
  line-height: 1;
}

.synaxarium-share-modal__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.dual-calendar__title h2 {
  overflow-wrap: anywhere;
}

/* Reader study panel adjustments. */
.verse-study-panel__tabs {
  overflow-x: visible;
  flex-wrap: wrap;
}

/* Library card and reader refinements. */
.library-filters {
  grid-template-columns: minmax(160px, 0.75fr) minmax(190px, 0.9fr) minmax(260px, 1.5fr) minmax(150px, auto);
}

.library-filters__status {
  grid-column: 4;
}

.library-card {
  min-height: 480px;
}

.library-card__media {
  display: block;
}

.library-card__media::after {
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.92) 0%, rgba(0, 0, 0, 0.72) 18%, rgba(0, 0, 0, 0.16) 38%, rgba(0, 0, 0, 0) 62%);
}

.library-card__content {
  min-height: 480px;
  align-content: end;
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 10px;
  padding: 0 18px 18px;
}

.library-card .library-card__description {
  align-self: end;
  max-height: 4.2em;
  margin: 0;
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.library-card__actions {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(0, 1fr);
  gap: 8px;
}

.library-card__actions a,
.library-card__actions button {
  min-width: 0;
  justify-content: center;
  padding: 9px 10px;
  white-space: nowrap;
}

.library-book-reader__toolbar,
.library-book-reader__pager {
  width: min(980px, 100%);
  margin-inline: auto;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.library-book-reader__modes {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 8px;
}

.library-book-reader__toolbar button,
.library-book-reader__pager button {
  border: 1px solid var(--border-soft);
  border-radius: 999px;
  padding: 10px 16px;
  background: var(--surface);
  color: var(--ink);
  font-weight: 800;
}

.library-book-reader__toolbar button.is-active,
.library-book-reader__toolbar button.is-active:hover,
.library-book-reader__pager button:not(:disabled):hover,
.library-book-reader__nav a:hover {
  border-color: color-mix(in srgb, var(--accent) 45%, var(--border-soft));
}

.library-book-reader__toolbar button.is-active,
.library-book-reader__toolbar [data-bookmark-page].is-active {
  background: var(--accent);
  color: var(--on-accent);
}

.library-book-reader__pager span {
  color: color-mix(in srgb, var(--ink) 70%, transparent);
  font-weight: 800;
}

@media (max-width: 920px) {
  .synaxarium-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 820px) {
  .library-filters {
    grid-template-columns: 1fr;
  }

  .library-filters__status {
    grid-column: 1;
  }

  .library-card__actions {
    grid-auto-flow: row;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* Final Synaxarium/library interaction refinements. */
.share-popup {
  z-index: 20000;
}

.synaxarium-layout {
  grid-template-columns: minmax(430px, 620px) minmax(0, 1fr);
}

.dual-calendar__title h2 {
  white-space: normal;
  overflow-wrap: normal;
  line-height: 1.12;
}

.synaxarium-share-button,
.synaxarium-event__share {
  width: 42px;
  height: 42px;
  min-width: 42px;
  display: inline-grid;
  place-items: center;
  padding: 0;
  border-radius: 50%;
  font-size: 0;
  line-height: 0;
}

.synaxarium-event__share {
  width: 36px;
  height: 36px;
  min-width: 36px;
}

.synaxarium-share-button svg,
.synaxarium-event__share svg {
  width: 18px;
  height: 18px;
}

.library-filters {
  grid-template-columns: minmax(150px, 0.8fr) minmax(190px, 1fr) minmax(280px, 1.6fr) !important;
}

.library-filters__status,
.library-load-more {
  display: none !important;
}

.library-scroll-sentinel {
  min-height: 1px;
}

.library-scroll-sentinel:not([hidden])::after {
  content: "";
  display: block;
  width: 36px;
  height: 36px;
  margin: 24px auto 0;
  border: 3px solid color-mix(in srgb, var(--accent) 18%, transparent);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: library-scroll-spin 0.9s linear infinite;
}

.library-empty {
  grid-column: 1 / -1;
  padding: 28px;
  border: 1px dashed var(--border-soft);
  border-radius: 8px;
  background: color-mix(in srgb, var(--surface) 86%, transparent);
  color: var(--muted);
  text-align: center;
}

@keyframes library-scroll-spin {
  to {
    transform: rotate(360deg);
  }
}

.library-card {
  cursor: pointer;
}

.library-card:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--accent) 76%, #fff 24%);
  outline-offset: 4px;
}

.library-card__content {
  position: absolute !important;
  inset: auto 0 0 !important;
  min-height: 96px !important;
  height: 20% !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
  gap: 0 !important;
  padding: 0 0 30px !important;
  z-index: 2;
}

.library-card .library-card__description {
  width: 100%;
  max-height: calc(100% - 30px) !important;
  padding: 0 14px 7px;
  color: rgba(255, 255, 255, 0.9) !important;
  font-size: 0.86rem;
  line-height: 1.24;
  -webkit-line-clamp: 3;
}

.library-card__actions {
  position: absolute !important;
  inset: auto 0 0 0 !important;
  height: 30px !important;
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  grid-auto-flow: unset !important;
  grid-auto-columns: unset !important;
  gap: 0 !important;
  border-top: 1px solid rgba(255, 255, 255, 0.24);
  overflow: hidden;
}

.library-card__actions a,
.library-card__actions button {
  min-height: 30px !important;
  height: 30px !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 8px !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  font-size: 0.82rem;
  line-height: 1;
}

.library-card__actions a + a,
.library-card__actions a + button,
.library-card__actions button + a,
.library-card__actions button + button {
  border-inline-start: 1px solid rgba(0, 0, 0, 0.18) !important;
}

.library-card__actions button:disabled {
  opacity: 0.72;
  cursor: not-allowed;
}

@media (max-width: 920px) {
  .synaxarium-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 820px) {
  .library-filters {
    grid-template-columns: 1fr !important;
  }

  .library-card__actions {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

/* Full Coptic calendar. */
.calendar-page {
  display: grid;
  gap: 22px;
  color: var(--ink);
}

.calendar-page[dir="rtl"] {
  font-family: "Amiri", "Noto Naskh Arabic", "Scheherazade New", "Traditional Arabic", serif;
}

.calendar-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  padding-block: 10px 4px;
}

.calendar-header h1 {
  margin: 0;
  font-size: clamp(2rem, 4vw, 3.8rem);
  line-height: 1.02;
}

.calendar-header__eyebrow {
  margin: 0 0 8px;
  color: var(--muted-strong);
  font-size: 0.82rem;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.calendar-header__meta,
.calendar-header__actions,
.calendar-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.calendar-header__meta {
  margin-top: 12px;
}

.calendar-header__meta span,
.calendar-today-link {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 8px 12px;
  border: 1px solid var(--control-border);
  border-radius: 999px;
  background: var(--control-bg);
  color: var(--ink);
  font-weight: 800;
  text-decoration: none;
}

.calendar-icon-link {
  display: inline-flex;
  width: 42px;
  height: 42px;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--control-border);
  border-radius: 50%;
  background: var(--control-bg);
  color: var(--accent-dark);
}

.calendar-icon-link svg {
  width: 20px;
  height: 20px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.calendar-page[dir="rtl"] .calendar-icon-link svg {
  transform: scaleX(-1);
}

.calendar-controls {
  justify-content: flex-start;
}

.calendar-controls .field {
  min-width: min(260px, 100%);
}

.calendar-controls label {
  display: block;
  margin-bottom: 7px;
  color: var(--muted-strong);
  font-size: 0.82rem;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.calendar-controls input,
.calendar-controls select {
  width: 100%;
  min-height: 44px;
  padding: 8px 12px;
  border: 1px solid var(--control-border);
  border-radius: 8px;
  background: var(--control-bg);
  color: var(--ink);
}

.calendar-board {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.calendar-board__weekdays,
.calendar-board__grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
}

.calendar-board__weekdays {
  gap: 8px;
  color: var(--muted-strong);
  font-size: 0.82rem;
  font-weight: 900;
  text-align: center;
  text-transform: uppercase;
}

.calendar-board__weekdays span {
  min-width: 0;
  overflow: hidden;
  white-space: nowrap;
}

.calendar-board__grid {
  gap: 8px;
}

.calendar-cell {
  position: relative;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  gap: 12px;
  min-width: 0;
  min-height: 196px;
  padding: 12px;
  border: 1px solid var(--border-soft);
  border-radius: 8px;
  background: var(--surface);
  color: var(--ink);
  text-decoration: none;
  overflow: hidden;
  box-shadow: 0 10px 28px var(--surface-shadow);
}

.calendar-cell::before,
.calendar-cell::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0;
}

.calendar-cell::before {
  background-image: var(--calendar-bg-image);
  background-position: var(--calendar-bg-position, center);
  background-size: cover;
  transform: scale(1.02);
}

.calendar-cell::after {
  background:
    linear-gradient(180deg, rgba(255, 250, 241, 0.44), rgba(255, 250, 241, 0.34)),
    radial-gradient(circle at 70% 24%, rgba(255, 236, 174, 0.18), transparent 45%);
}

.calendar-cell.has-background-image::before {
  opacity: 0.96;
}

.calendar-cell.has-background-image::after {
  opacity: 1;
}

.calendar-cell.has-background-image.is-selected::after {
  background:
    linear-gradient(180deg, rgba(255, 246, 230, 0.4), rgba(255, 240, 213, 0.3)),
    radial-gradient(circle at 70% 24%, rgba(255, 221, 121, 0.22), transparent 46%);
}

.calendar-cell > * {
  position: relative;
  z-index: 1;
}

.calendar-cell:hover,
.calendar-cell:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 48%, var(--border-soft));
  background: color-mix(in srgb, var(--accent) 8%, var(--surface));
}

.calendar-cell.is-muted {
  opacity: 0.52;
}

.calendar-cell.is-weekend {
  background: color-mix(in srgb, var(--surface) 88%, #dfe9ea 12%);
}

.calendar-cell.is-off-day {
  border-color: color-mix(in srgb, #c94d39 48%, var(--border-soft));
}

.calendar-cell.is-today {
  outline: 2px solid color-mix(in srgb, var(--accent) 58%, transparent);
  outline-offset: -4px;
}

.calendar-cell.is-selected {
  background: color-mix(in srgb, var(--accent) 14%, var(--surface));
  border-color: var(--accent);
}

.calendar-cell__topline {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
}

.calendar-cell__topline strong {
  font-size: 1.45rem;
  line-height: 1;
}

.calendar-cell__topline span {
  min-width: 0;
  color: var(--muted-strong);
  font-size: 0.82rem;
  font-weight: 800;
  line-height: 1.2;
  text-align: end;
}

.calendar-cell__saints {
  display: flex;
  min-width: 0;
  min-height: 58px;
  align-items: center;
  gap: 4px;
}

.calendar-page[dir="rtl"] .calendar-cell__saints {
  justify-content: flex-end;
}

.calendar-saint-figure {
  display: inline-grid;
  width: 58px;
  height: 58px;
  flex: 0 0 auto;
  place-items: center;
}

.calendar-saint-figure + .calendar-saint-figure {
  margin-inline-start: -18px;
}

.calendar-saint-figure img {
  width: 58px;
  height: 58px;
  object-fit: contain;
  filter:
    drop-shadow(0 0 8px rgba(255, 236, 165, 0.86))
    drop-shadow(0 0 20px rgba(220, 157, 52, 0.54))
    drop-shadow(0 9px 15px rgba(102, 62, 18, 0.2));
}

.calendar-cell__events {
  display: flex;
  min-width: 0;
  flex-wrap: wrap;
  align-content: flex-start;
  gap: 6px;
}

.calendar-event-chip {
  max-width: 100%;
  min-height: 25px;
  padding: 4px 8px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--surface-strong) 88%, var(--ink) 12%);
  color: var(--ink);
  font-size: 0.78rem;
  font-weight: 800;
  line-height: 1.2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.calendar-event-chip--off-day {
  background: #ffe3dd;
  color: #7d2418;
}

.calendar-event-chip--feast {
  background: #e4f2ff;
  color: #064c7d;
}

.calendar-event-chip--fast {
  background: #edf0de;
  color: #566118;
}

.calendar-event-chip--saint {
  background: #f2e9ff;
  color: #5e277f;
}

.calendar-event-chip--synaxarium {
  background: #f4eadc;
  color: #6d4218;
}

.calendar-event-chip--more {
  background: var(--surface-strong);
  color: var(--muted-strong);
}

.calendar-agenda {
  display: grid;
  gap: 16px;
  padding: 22px;
  border: 1px solid var(--border-soft);
  border-radius: 8px;
  background: var(--surface);
  box-shadow: 0 12px 34px var(--surface-shadow);
}

.calendar-agenda header h2,
.calendar-agenda header p {
  margin: 0;
}

.calendar-agenda header p:last-child {
  margin-top: 6px;
  color: var(--muted-strong);
  font-weight: 800;
}

.calendar-agenda__events {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 12px;
}

.calendar-agenda-event {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  padding: 14px;
  border: 1px solid var(--border-soft);
  border-radius: 8px;
  background: var(--surface-strong);
}

.calendar-agenda-event > span {
  display: inline-flex;
  min-height: 28px;
  align-items: center;
  padding: 5px 9px;
  border-radius: 999px;
  background: var(--control-bg);
  color: var(--muted-strong);
  font-size: 0.75rem;
  font-weight: 900;
  text-transform: uppercase;
}

.calendar-agenda-event h3,
.calendar-agenda-event p {
  margin: 0;
}

.calendar-agenda-event h3 {
  font-size: 1rem;
  line-height: 1.35;
}

.calendar-agenda-event h3 a {
  color: var(--ink);
  text-decoration: none;
}

.calendar-agenda-event__link {
  display: inline;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--ink);
  font: inherit;
  font-weight: inherit;
  line-height: inherit;
  text-align: inherit;
  cursor: pointer;
}

.calendar-agenda-event h3 a:hover,
.calendar-agenda-event__link:hover {
  color: var(--link);
  text-decoration: underline;
}

.calendar-agenda-event p {
  margin-top: 5px;
  color: var(--muted-strong);
  font-weight: 700;
}

.calendar-agenda__empty {
  margin: 0;
  color: var(--muted-strong);
}

.calendar-modal[hidden] {
  display: none;
}

.calendar-modal {
  position: fixed;
  inset: 0;
  z-index: 100000;
  display: grid;
  place-items: center;
  padding: 18px;
}

.calendar-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(16, 13, 10, 0.56);
}

.calendar-modal__dialog {
  position: relative;
  z-index: 1;
  width: min(520px, 100%);
  display: grid;
  gap: 18px;
  padding: 22px;
  border: 1px solid var(--border-soft);
  border-radius: 8px;
  background: var(--surface);
  color: var(--ink);
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.32);
}

.calendar-modal__dialog header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}

.calendar-modal__dialog h2 {
  margin: 0;
  font-size: clamp(1.3rem, 3vw, 1.8rem);
  line-height: 1.18;
}

.calendar-modal__dialog header button {
  width: 38px;
  height: 38px;
  flex: 0 0 auto;
  border: 1px solid var(--border-soft);
  border-radius: 50%;
  background: var(--surface-strong);
  color: var(--ink);
  font-size: 1.4rem;
  line-height: 1;
}

.calendar-modal__dialog dl {
  display: grid;
  gap: 10px;
  margin: 0;
}

.calendar-modal__dialog dl > div {
  display: grid;
  grid-template-columns: minmax(120px, 0.45fr) minmax(0, 1fr);
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--border-soft);
  border-radius: 8px;
  background: var(--surface-strong);
}

.calendar-modal__dialog dt {
  color: var(--muted-strong);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

.calendar-modal__dialog dd {
  margin: 0;
  font-weight: 800;
}

@media (max-width: 1080px) {
  .calendar-board__grid {
    gap: 6px;
  }

  .calendar-cell {
    min-height: 170px;
    padding: 10px;
  }
}

@media (max-width: 760px) {
  .calendar-header {
    display: grid;
  }

  .calendar-board {
    overflow-x: visible;
  }

  .calendar-cell {
    min-height: 118px;
    padding: 7px;
    gap: 7px;
  }

  .calendar-board__weekdays {
    gap: 4px;
    font-size: 0.68rem;
  }

  .calendar-board__grid {
    gap: 4px;
  }

  .calendar-cell__topline {
    display: grid;
    gap: 3px;
  }

  .calendar-cell__topline strong {
    font-size: 1rem;
  }

  .calendar-cell__topline span {
    font-size: 0.62rem;
    text-align: start;
  }

  .calendar-cell__saints {
    min-height: 42px;
    gap: 2px;
  }

  .calendar-saint-figure {
    width: 42px;
    height: 42px;
  }

  .calendar-saint-figure + .calendar-saint-figure {
    margin-inline-start: -14px;
  }

  .calendar-saint-figure img {
    width: 42px;
    height: 42px;
  }

  .calendar-cell__events {
    gap: 3px;
  }

  .calendar-event-chip {
    width: 100%;
    min-height: 18px;
    padding: 2px 4px;
    font-size: 0.58rem;
    border-radius: 5px;
  }

  .calendar-agenda {
    padding: 16px;
  }
}

/* Library card: split visual area from action bar so actions sit under the card. */
.library-card {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  min-height: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
  isolation: isolate;
  cursor: pointer;
}

.library-card__visual {
  position: relative;
  width: 100%;
  min-height: 430px;
  display: flex;
  align-items: stretch;
  border: 1px solid var(--border-soft);
  border-radius: 26px 26px 0 0;
  background: #151311;
  overflow: hidden;
  isolation: isolate;
}

.library-card__media {
  position: absolute !important;
  inset: 0 !important;
  border-radius: 0 !important;
  z-index: 0;
}

.library-card__content {
  position: absolute !important;
  inset: auto 0 0 0 !important;
  width: 100% !important;
  min-height: 0 !important;
  height: auto !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
  gap: 8px !important;
  padding: 18px 20px 20px !important;
  z-index: 2;
  color: #fff;
}

.library-card__title {
  margin: 0;
  font-size: 1.18rem;
  line-height: 1.22;
  font-weight: 800;
  color: #fff;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.library-card .library-card__description {
  width: 100%;
  margin: 0;
  padding: 0;
  max-height: none !important;
  color: rgba(255, 255, 255, 0.88) !important;
  font-size: 0.98rem;
  line-height: var(--site-card-text-line-height);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

.library-card__actions {
  position: static !important;
  inset: auto !important;
  height: auto !important;
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  grid-auto-flow: unset !important;
  grid-auto-columns: unset !important;
  gap: 0 !important;
  padding: 0 !important;
  border: 1px solid var(--border-soft) !important;
  border-top: 0 !important;
  border-radius: 0 0 26px 26px !important;
  overflow: hidden;
  background: var(--surface);
}

.library-card__actions a,
.library-card__actions button {
  min-height: 44px !important;
  height: 44px !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 12px !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  font-size: 0.92rem;
  font-weight: 700;
  background: transparent !important;
  color: var(--ink) !important;
  backdrop-filter: none !important;
}

.library-card__actions a:first-child {
  background: var(--accent) !important;
  color: var(--on-accent, #fff) !important;
}

.library-card__actions a + a,
.library-card__actions a + button,
.library-card__actions button + a,
.library-card__actions button + button {
  border-inline-start: 1px solid var(--border-soft) !important;
}

.library-card__actions button:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

/* Library book reader: side metadata column + main reader column.
   Sidebar position follows the book's writing direction (RTL on right, LTR on left). */
.library-book-reader__layout {
  display: grid;
  grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
  gap: clamp(18px, 2.6vw, 32px);
  align-items: start;
}

.library-book-reader__sidebar {
  position: sticky;
  top: 88px;
  align-self: start;
  max-height: 100vh;
  overflow-y: auto;
  padding: clamp(20px, 2.4vw, 28px);
  border: 1px solid var(--border-soft);
  border-radius: 22px;
  background: linear-gradient(180deg, var(--surface) 0%,
    color-mix(in srgb, var(--surface) 92%, var(--accent) 8%) 100%);
  box-shadow: 0 22px 48px
    color-mix(in srgb, var(--ink) 8%, transparent);
  font-size: 0.95rem;
}

.library-book-reader__sidebar .library-book-reader__cover {
  width: 100%;
  aspect-ratio: 3 / 4;
  border-radius: 12px;
  overflow: hidden;
  background: color-mix(in srgb, var(--mist) 78%, transparent);
}

.library-book-reader__sidebar .library-book-reader__cover img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.library-book-reader__title {
  margin: 4px 0 0;
  font-size: clamp(1.2rem, 1.6vw, 1.5rem);
  line-height: 1.2;
}

.library-book-reader__sidebar .library-book-reader__author,
.library-book-reader__sidebar .library-book-reader__status {
  margin: 0;
  font-size: 0.92rem;
  color: color-mix(in srgb, var(--ink) 70%, transparent);
}

.library-book-reader__summary-meta {
  margin: 4px 0 0;
  display: grid;
  gap: 8px;
}

.library-book-reader__summary-meta > div {
  display: grid;
  gap: 2px;
  font-size: 0.88rem;
}

.library-book-reader__summary-meta dt {
  color: color-mix(in srgb, var(--ink) 60%, transparent);
}

.library-book-reader__summary-meta dd {
  margin: 0;
  font-weight: 700;
}

.library-book-reader__sidebar .library-book-reader__nav {
  margin-top: auto;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.library-book-reader__sidebar .library-book-reader__nav a,
.library-book-reader__sidebar .library-book-reader__nav button {
  width: 100%;
  text-align: center;
  padding: 8px 12px;
  font-size: 0.92rem;
}

.library-book-reader__main {
  display: grid;
  gap: 18px;
  min-width: 0;
}

@media (max-width: 820px) {
  .library-book-reader__layout {
    grid-template-columns: 1fr;
    direction: ltr !important;
  }

  .library-book-reader__sidebar {
    position: static;
  }

  .library-book-reader__sidebar .library-book-reader__cover {
    max-width: 220px;
    margin-inline: auto;
  }
}

/* Bigger button font on library cards */
.library-card__actions a,
.library-card__actions button {
  font-size: 1rem !important;
  font-weight: 700;
  letter-spacing: 0.01em;
}

/* Library reader: bigger sidebar (full height), bigger reader font, Noto Naskh default,
   font-controls popover, body bookmark button. */

.library-book-reader__layout {
  grid-template-columns: minmax(260px, 320px) minmax(0, 1fr);
  align-items: stretch;
}

.library-book-reader__sidebar {
  position: sticky;
  top: 88px;
  align-self: start;
  max-height: 100vh;
  overflow-y: auto;
  padding: clamp(20px, 2.4vw, 28px);
  border: 1px solid var(--border-soft);
  border-radius: 22px;
  background: linear-gradient(180deg, var(--surface) 0%, color-mix(in srgb, var(--surface) 92%, var(--accent) 8%) 100%);
  box-shadow: 0 22px 48px color-mix(in srgb, var(--ink) 8%, transparent);
  font-size: 0.95rem;
}

.library-book-reader__sidebar .library-book-reader__cover {
  width: 100%;
  aspect-ratio: 3 / 4;
  margin-bottom: 6px;
  box-shadow: 0 14px 30px color-mix(in srgb, var(--ink) 18%, transparent);
}

.library-book-reader__title {
  font-size: clamp(1.4rem, 2vw, 1.85rem);
  line-height: 1.18;
  margin: 8px 0 0;
  letter-spacing: -0.005em;
}

.library-book-reader__sidebar .library-book-reader__author {
  font-size: 1.02rem;
  font-weight: 600;
  color: color-mix(in srgb, var(--ink) 80%, transparent);
}

.library-book-reader__sidebar .library-book-reader__status {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--accent-dark);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.library-book-reader__summary-meta {
  margin-top: 10px;
  padding-top: 12px;
  border-top: 1px solid color-mix(in srgb, var(--ink) 10%, transparent);
}

.library-book-reader__summary-meta dt {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.library-book-reader__summary-meta dd {
  font-size: 1.05rem;
}

.library-book-reader__sidebar .library-book-reader__nav {
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid color-mix(in srgb, var(--ink) 10%, transparent);
}

.library-book-reader__sidebar .library-book-reader__nav a,
.library-book-reader__sidebar .library-book-reader__nav button {
  font-weight: 700;
}

.library-book-reader__main {
  --reader-text-size: 22px;
  --reader-text-family: "Amiri", "Noto Naskh Arabic", "Scheherazade New", "Traditional Arabic", serif;
  display: grid;
  gap: 18px;
  min-width: 0;
  padding-top: 40px;
}

.library-book-reader__main[data-reader-default-font="serif"] {
  --reader-text-family: "Cormorant Garamond", "Garamond", "Palatino Linotype", serif;
}

.library-book-reader__body {
  position: relative;
  font-family: var(--reader-text-family);
  font-size: var(--reader-text-size);
  line-height: 1.95;
}

.library-book-reader__body p,
.library-book-reader__body li {
  font-size: var(--reader-text-size);
  line-height: 1.95;
}

.library-book-reader__layout[dir="rtl"] .library-book-reader__body,
.library-book-reader__layout[dir="rtl"] .library-book-reader__body p,
.library-book-reader__layout[dir="rtl"] .library-book-reader__body li {
  line-height: 2.22;
}

.library-book-reader__body h2 { font-size: calc(var(--reader-text-size) * 1.25); }
.library-book-reader__body h3 { font-size: calc(var(--reader-text-size) * 1.12); }
.library-book-reader__body h4 { font-size: calc(var(--reader-text-size) * 1.04); }

.library-book-reader__source-page-label {
  color: color-mix(in srgb, var(--ink) 56%, transparent);
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 0.82rem !important;
  font-weight: 800;
  letter-spacing: 0;
  margin-bottom: 0.65rem !important;
}

.library-book-reader__toolbar {
  flex-wrap: wrap;
}

/* RTL books: physically reverse the prev/next pager so the "Previous"
   pill sits on the right (the natural backwards direction in RTL). */
.library-book-reader__layout[dir="rtl"] .library-book-reader__pager {
  flex-direction: row-reverse;
}

.library-book-reader__toolbar-right {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.library-book-reader__bookmark.is-active {
  background: var(--accent) !important;
  color: var(--on-accent, #fff) !important;
  border-color: color-mix(in srgb, var(--accent) 70%, var(--ink) 30%) !important;
}

.library-book-reader__text-controls {
  position: relative;
  display: inline-flex;
}

.library-book-reader__font-toggle {
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 1px solid var(--border-soft);
  border-radius: 999px;
  background: var(--surface);
  color: var(--ink);
  font-family: inherit;
  font-size: 1rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0;
  cursor: pointer;
}

.library-book-reader__font-toggle:hover,
.library-book-reader__text-controls.is-open .library-book-reader__font-toggle {
  background: color-mix(in srgb, var(--accent) 14%, var(--surface));
}

/* Library book reader font popover — mirrors the chapter-page version
   (.chapter-reader__font-popover) so the two readers feel like the same
   product. Same gradient surface, same arrow, same stepper layout, same
   typography. */
.library-book-reader__font-popover {
  position: absolute;
  inset-inline-end: 0;
  inset-block-start: calc(100% + 10px);
  width: min(320px, calc(100vw - 28px));
  max-width: calc(100vw - 28px);
  display: grid;
  gap: 14px;
  padding: 16px;
  border-radius: 20px;
  background: var(--surface-strong);
  border: 1px solid color-mix(in srgb, var(--accent-dark) 14%, transparent);
  box-shadow: 0 20px 48px color-mix(in srgb, var(--ink) 18%, transparent);
  z-index: 10000;
  color: var(--ink);
}

.library-book-reader__font-popover[hidden] {
  display: none;
}

.library-book-reader__font-popover::before {
  content: "";
  position: absolute;
  inset-inline-end: 16px;
  inset-block-start: -7px;
  width: 12px;
  height: 12px;
  transform: rotate(45deg);
  background: var(--surface-strong);
  border-inline-start: 1px solid color-mix(in srgb, var(--accent-dark) 14%, transparent);
  border-block-start: 1px solid color-mix(in srgb, var(--accent-dark) 14%, transparent);
}

.library-book-reader__font-popover-header {
  display: grid;
  gap: 2px;
  padding-inline: 2px;
  margin-block-end: 2px;
}

.library-book-reader__font-popover-header span {
  color: var(--muted-strong);
  font: 700 0.7rem/1.1 system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.library-book-reader__font-popover-header strong {
  color: var(--ink);
  font: 600 1.02rem/1.2 system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  letter-spacing: -0.005em;
}

.library-book-reader__font-preview {
  min-height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  background: var(--control-bg);
  color: color-mix(in srgb, var(--ink) 78%, transparent);
  line-height: 1.1;
  text-align: center;
  overflow: hidden;
}

.library-book-reader__font-row {
  display: grid;
  grid-template-columns: minmax(78px, auto) minmax(0, 1fr);
  align-items: center;
  gap: 10px;
}

.library-book-reader__font-row--select {
  grid-template-columns: minmax(78px, auto) minmax(0, 1fr);
}

.library-book-reader__font-row-label {
  color: var(--muted-strong);
  font: 600 0.86rem/1.1 system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.library-book-reader__font-stepper-group {
  min-width: 0;
  display: grid;
  grid-template-columns: 38px minmax(58px, 1fr) 38px;
  align-items: center;
  gap: 6px;
  padding: 4px;
  border-radius: 999px;
  background: var(--control-bg);
  border: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
}

.library-book-reader__font-stepper {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border: 0;
  border-radius: 50%;
  background: color-mix(in srgb, var(--ink) 7%, transparent);
  color: color-mix(in srgb, var(--ink) 82%, transparent);
  font: 700 0.95rem/1 system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  cursor: pointer;
  transition: background-color 140ms ease, color 140ms ease, transform 140ms ease;
}

.library-book-reader__font-stepper:hover,
.library-book-reader__font-stepper:focus-visible {
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  outline: none;
}

.library-book-reader__font-size-value {
  min-width: 58px;
  color: var(--ink);
  font: 700 0.95rem/1 system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  text-align: center;
  font-variant-numeric: tabular-nums;
}

/* Native <select> kept as the source of truth but visually hidden — the
   custom .library-book-reader__font-family dropdown replaces it. */
.library-book-reader__font-family-select {
  position: absolute !important;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  white-space: nowrap;
}

.library-book-reader__font-family {
  position: relative;
  width: 100%;
  min-width: 0;
}

.library-book-reader__font-family-button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  width: 100%;
  height: 42px;
  padding: 0 14px 0 16px;
  border: 1px solid color-mix(in srgb, var(--ink) 12%, transparent);
  border-radius: 12px;
  background: var(--control-bg);
  color: var(--ink);
  font: 600 0.95rem/1 system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  cursor: pointer;
  text-align: start;
  transition: border-color 0.14s ease, box-shadow 0.14s ease;
}

.library-book-reader__font-family-button:hover,
.library-book-reader__font-family-button:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 36%, transparent);
  outline: none;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 14%, transparent);
}

.library-book-reader__font-family-current {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.library-book-reader__font-family-chevron {
  flex: 0 0 16px;
  width: 16px;
  height: 16px;
  color: color-mix(in srgb, var(--ink) 60%, transparent);
  transition: transform 0.16s ease;
}

.library-book-reader__font-family.is-open .library-book-reader__font-family-chevron {
  transform: rotate(180deg);
}

.library-book-reader__font-family-menu {
  position: absolute;
  inset-inline-start: 0;
  inset-inline-end: 0;
  top: calc(100% + 6px);
  max-height: min(360px, 52vh);
  overflow: auto;
  list-style: none;
  margin: 0;
  padding: 6px;
  border: 1px solid color-mix(in srgb, var(--accent-dark) 14%, transparent);
  border-radius: 14px;
  background: var(--surface-strong);
  box-shadow: 0 18px 42px color-mix(in srgb, var(--ink) 18%, transparent);
  z-index: 10001;
}

.library-book-reader__font-family-menu li {
  padding: 9px 12px;
  border-radius: 10px;
  color: var(--ink);
  font-size: 0.95rem;
  cursor: pointer;
  transition: background-color 120ms ease;
}

.library-book-reader__font-family-menu li:hover,
.library-book-reader__font-family-menu li:focus-visible,
.library-book-reader__font-family-menu li.is-current {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  outline: none;
}

.library-book-reader__font-reset {
  min-height: 42px;
  border: 1px solid color-mix(in srgb, var(--accent) 18%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: var(--accent-dark);
  font: 900 max(20px, 0.82rem)/1 system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  cursor: pointer;
  transition: background-color 140ms ease, transform 140ms ease, border-color 140ms ease;
}

.library-book-reader__font-reset:hover,
.library-book-reader__font-reset:focus-visible {
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  border-color: color-mix(in srgb, var(--accent) 36%, transparent);
  transform: translateY(-1px);
  outline: none;
}

@media (max-width: 820px) {
  .library-book-reader__sidebar {
    position: static;
    max-height: none;
  }
}

/* Keep share links visually clean inside themed popups. */
:root[data-theme] .share-popup__link,
:root[data-theme] .share-popup__link:hover,
:root[data-theme] .share-popup__link:focus-visible {
  background: transparent !important;
  background-image: none !important;
  border-color: transparent !important;
  box-shadow: none !important;
}

:root[data-theme] select:not([multiple]) {
  background-image: var(--select-caret-icon) !important;
  background-repeat: no-repeat !important;
  background-position: var(--select-caret-position) !important;
  background-size: 10px 7px !important;
}

:root[data-theme] .hourly-prayers-filters {
  background: transparent !important;
  background-image: none !important;
  border-color: transparent !important;
  box-shadow: none !important;
}

.admin-localization-toolbar {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(150px, 0.35fr) minmax(180px, 0.65fr) auto;
  gap: 12px;
  align-items: end;
  margin: 22px 0;
}

.admin-empty-state--danger {
  border-color: color-mix(in srgb, #b91c1c 36%, var(--border-soft));
  color: #b91c1c;
}

.admin-localization-toolbar .field {
  display: grid;
  gap: 6px;
}

.admin-localization-panel .admin-audit-panel__header h2 {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: baseline;
}

.admin-localization-panel .admin-audit-panel__header h2 span {
  font-size: 0.78rem;
  color: var(--muted);
}

.admin-localization-panel .admin-audit-panel__header p {
  overflow-wrap: anywhere;
}

.admin-localization-table {
  display: grid;
  gap: 10px;
}

.admin-localization-row {
  display: grid;
  grid-template-columns: minmax(180px, 0.55fr) minmax(260px, 1fr) minmax(260px, 1fr);
  gap: 10px;
  align-items: stretch;
  padding: 12px;
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  background: color-mix(in srgb, var(--surface) 92%, transparent);
}

.admin-localization-row--head {
  padding-block: 8px;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
}

.admin-localization-key {
  display: grid;
  gap: 8px;
  align-content: start;
}

.admin-localization-key code {
  white-space: normal;
  overflow-wrap: anywhere;
}

.admin-localization-key span {
  width: fit-content;
  padding: 3px 8px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  color: var(--accent-strong);
  font-size: 0.76rem;
  font-weight: 700;
}

.admin-localization-cell {
  display: grid;
  gap: 6px;
}

.admin-localization-cell span {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
}

.admin-localization-cell textarea {
  width: 100%;
  min-height: 96px;
  resize: vertical;
}

.admin-localization-cell textarea[readonly] {
  color: color-mix(in srgb, var(--ink) 78%, transparent);
  background: color-mix(in srgb, var(--mist) 64%, transparent);
}

.admin-localization-save {
  justify-content: flex-end;
  margin-top: 16px;
}

@media (max-width: 980px) {
  .admin-localization-toolbar,
  .admin-localization-row {
    grid-template-columns: 1fr;
  }

  .admin-localization-row--head {
    display: none;
  }
}

:root[data-theme] .share-popup__icon {
  background: color-mix(in srgb, var(--accent) 22%, var(--surface));
  border-color: color-mix(in srgb, var(--accent) 32%, var(--control-border));
  color: var(--ink);
}

:root[data-theme] .share-popup__icon svg {
  color: var(--ink);
}

/* Profile cards: per-entry actions row (favorites, bookmarks, notes). */
.profile-page__card--actionable {
  display: flex;
  flex-direction: column;
  padding: 0;
  overflow: hidden;
}

.profile-page__card--actionable .profile-page__card-body {
  display: block;
  padding: 20px 22px 16px;
  text-decoration: none;
  color: inherit;
  font-size: 1.05rem;
  line-height: 1.55;
}

.profile-page__card--actionable .profile-page__card-body:hover {
  background: color-mix(in srgb, var(--accent) 6%, transparent);
}

.profile-page__card--actionable .profile-page__card-body span {
  display: inline-block;
  font-size: 1.05rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: color-mix(in srgb, var(--ink) 65%, transparent);
}

.profile-page__card--actionable .profile-page__card-body strong {
  display: block;
  margin: 6px 0 8px;
  font-size: 1.45rem;
  line-height: 1.25;
}

.profile-page__card--actionable .profile-page__card-body p {
  margin: 4px 0 6px;
  font-size: 1.18rem;
  line-height: 1.6;
}

.profile-page__card--actionable .profile-page__card-body small {
  display: block;
  font-size: 1.08rem;
  color: color-mix(in srgb, var(--ink) 60%, transparent);
}

.profile-page__card-verse {
  margin: 6px 0 10px;
  padding: 10px 14px;
  border-inline-start: 3px solid color-mix(in srgb, var(--accent) 60%, transparent);
  background: color-mix(in srgb, var(--accent) 6%, transparent);
  font-style: italic;
  font-size: 1.2rem;
  line-height: 1.65;
  color: color-mix(in srgb, var(--ink) 82%, transparent);
}

.profile-page__card-actions {
  display: flex;
  gap: 4px;
  padding: 8px 12px;
  border-top: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
  background: color-mix(in srgb, var(--ink) 3%, transparent);
}

.profile-page__card-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: color-mix(in srgb, var(--ink) 65%, transparent);
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease;
}

.profile-page__card-action:hover,
.profile-page__card-action:focus-visible {
  background: color-mix(in srgb, var(--accent) 16%, transparent);
  color: var(--accent-dark);
  outline: none;
}

.profile-page__card--library .profile-page__card-body span {
  color: var(--accent-dark);
}

/* AI Chat header: persona selector + bio on one side, daily-limit + session
   tag on the other. The disclaimer sits between header and thread. */
.ai-chat-main__header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 18px 24px;
  padding-bottom: 16px;
  border-bottom: 1px solid color-mix(in srgb, var(--ink) 8%, transparent);
}

.ai-chat-main__persona-block {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.ai-chat-main__persona-field {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 12px;
}

.ai-chat-main__persona-label {
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: color-mix(in srgb, var(--ink) 70%, transparent);
  text-transform: uppercase;
}

.ai-chat-persona-select {
  width: 100%;
  padding: 12px 16px;
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  background: var(--surface);
  color: var(--ink);
  font: inherit;
  font-size: 1.15rem;
  font-weight: 800;
  cursor: pointer;
}

.ai-chat-persona-select:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent) 60%, transparent);
  outline-offset: 2px;
}

.ai-chat-main__persona-bio {
  margin: 0;
  font-size: 1rem;
  line-height: 1.55;
  color: color-mix(in srgb, var(--ink) 75%, transparent);
}

.ai-chat-main__usage-block {
  display: grid;
  justify-items: end;
  align-content: start;
  gap: 4px;
}

.ai-chat-usage__value {
  font-variant-numeric: tabular-nums;
  font-size: 1.1rem;
}

.ai-chat-session-tag {
  font-size: 0.85rem;
  color: color-mix(in srgb, var(--ink) 60%, transparent);
}

/* One tight pill, capped at 22px tall, expands on hover/focus to reveal the
   full notice. The grid row (auto) collapses to whatever this height is. */
.ai-chat-disclaimer {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 6px 16px 4px;
  padding: 3px 10px;
  min-height: 24px;
  max-height: 24px;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--accent) 22%, var(--border-soft));
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 7%, transparent);
  color: var(--muted-strong);
  font-size: 0.8rem;
  line-height: 1.25;
  transition: max-height 0.18s ease;
}

.ai-chat-disclaimer:hover,
.ai-chat-disclaimer:focus-within {
  max-height: 240px;
}

.ai-chat-disclaimer__icon {
  flex: 0 0 16px;
  height: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: var(--accent);
  color: var(--on-accent, #fff);
  font-weight: 900;
  font-size: 0.74rem;
}

.ai-chat-disclaimer__body {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
  flex: 1 1 auto;
}

.ai-chat-disclaimer:hover .ai-chat-disclaimer__body,
.ai-chat-disclaimer:focus-within .ai-chat-disclaimer__body {
  -webkit-line-clamp: unset;
  display: block;
  white-space: normal;
}

.ai-chat-disclaimer__body strong {
  font-weight: 800;
  margin-inline-end: 4px;
}

@media (max-width: 720px) {
  .ai-chat-main__header {
    grid-template-columns: 1fr;
  }
  .ai-chat-main__usage-block {
    justify-items: start;
  }
}

.ai-chat-persona-bio {
  margin-top: 10px;
  font-size: 0.92rem;
  line-height: 1.55;
  color: color-mix(in srgb, var(--ink) 78%, transparent);
  min-height: 1.55em;
}

.ai-chat-message__resources-heading {
  margin: 0 0 6px;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--ink) 60%, transparent);
}

.ai-chat-message__resource-link {
  display: block;
  padding: 6px 10px;
  border-radius: 8px;
  text-decoration: none;
  color: var(--accent-dark);
  font-size: 0.92rem;
}

.ai-chat-message__resource-link:hover,
.ai-chat-message__resource-link:focus-visible {
  background: color-mix(in srgb, var(--accent) 12%, transparent);
}

/* Search-page TSK pill: a true bordered pill that reads clearly across
   light AND dark themes. The previous default looked too faint, so we
   now ship the saturated accent fill as the DEFAULT state and use a
   softer surface tint on hover/focus. Sized to share a baseline with
   the .search-share-button next to it. */
.search-tsk-button.reader-icon-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  min-width: 70px;
  height: 36px;
  min-height: 36px;
  padding: 0 16px;
  align-self: center;
  flex: 0 0 auto;
  border: 1px solid color-mix(in srgb, var(--accent) 60%, var(--border-soft));
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 26%, var(--surface));
  color: var(--accent-dark);
  font-size: 0.84rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  line-height: 1;
  text-transform: uppercase;
  text-decoration: none;
  white-space: nowrap;
  transition: background 0.14s ease, color 0.14s ease, border-color 0.14s ease, transform 0.14s ease;
}

.search-tsk-button.reader-icon-button:hover,
.search-tsk-button.reader-icon-button:focus-visible {
  background: color-mix(in srgb, var(--accent) 12%, var(--surface));
  border-color: color-mix(in srgb, var(--accent) 32%, var(--border-soft));
  transform: translateY(-1px);
  outline: none;
}

/* Dark themes: accent-dark text disappears against a dark surface — flip
   default to a saturated solid-accent fill with on-accent text, hover
   softens to a translucent tinted surface. */
:root[data-theme="midnight"] .search-tsk-button.reader-icon-button,
:root[data-theme="night"] .search-tsk-button.reader-icon-button,
:root[data-theme="dark"] .search-tsk-button.reader-icon-button {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--on-accent, #fffaf4);
}

:root[data-theme="midnight"] .search-tsk-button.reader-icon-button:hover,
:root[data-theme="midnight"] .search-tsk-button.reader-icon-button:focus-visible,
:root[data-theme="night"] .search-tsk-button.reader-icon-button:hover,
:root[data-theme="night"] .search-tsk-button.reader-icon-button:focus-visible,
:root[data-theme="dark"] .search-tsk-button.reader-icon-button:hover,
:root[data-theme="dark"] .search-tsk-button.reader-icon-button:focus-visible {
  background: color-mix(in srgb, var(--accent) 22%, transparent);
  border-color: color-mix(in srgb, var(--accent) 50%, transparent);
  color: var(--on-accent, #fffaf4);
}

/* AI-Chat: typing indicator (3 bouncing dots) shown while waiting for the
   assistant reply. Mounted as a fake message, replaced when the answer
   arrives. */
.ai-chat-message--typing .ai-chat-message__bubble {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 32px;
}

.ai-chat-typing-dots {
  display: inline-flex;
  gap: 4px;
}

.ai-chat-typing-dots span {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--ink) 55%, transparent);
  animation: ai-chat-typing-bounce 1s ease-in-out infinite;
}

.ai-chat-typing-dots span:nth-child(2) { animation-delay: 0.15s; }
.ai-chat-typing-dots span:nth-child(3) { animation-delay: 0.3s; }

@keyframes ai-chat-typing-bounce {
  0%, 80%, 100% { transform: translateY(0); opacity: 0.45; }
  40% { transform: translateY(-4px); opacity: 1; }
}

/* Session list rows: a single open-button that holds the title + a small
   relative-time pill, with an absolute delete button on the inline-end. */
.ai-chat-session-list__item {
  position: relative;
  padding: 0;
  padding-inline-end: 36px;
  background: transparent;
  border: 0;
  box-shadow: none;
  border-radius: 14px;
  overflow: hidden;
}

.ai-chat-session-list__item-open {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 10px;
  width: 100%;
  margin: 0;
  padding: 10px 14px;
  background: color-mix(in srgb, var(--surface-strong) 92%, transparent);
  border: 1px solid var(--border-soft);
  border-radius: 14px;
  color: var(--ink);
  text-align: start;
  font: inherit;
  cursor: pointer;
  transition: background 0.14s ease, border-color 0.14s ease, box-shadow 0.14s ease, transform 0.14s ease;
}

.ai-chat-session-list__item-open strong {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 0.94rem;
  font-weight: 700;
  line-height: 1.3;
  color: var(--ink);
}

.ai-chat-session-list__item-time {
  flex: 0 0 auto;
  padding: 2px 8px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: color-mix(in srgb, var(--ink) 64%, transparent);
  font-size: 0.7rem;
  font-weight: 600;
  line-height: 1.3;
  white-space: nowrap;
}

.ai-chat-session-list__item-open:hover,
.ai-chat-session-list__item-open:focus-visible {
  background: color-mix(in srgb, var(--accent) 8%, var(--surface-strong));
  border-color: color-mix(in srgb, var(--accent) 32%, var(--border-soft));
  outline: none;
  transform: translateY(-1px);
  box-shadow: 0 6px 14px color-mix(in srgb, var(--accent) 12%, transparent);
}

.ai-chat-session-list__item.is-active .ai-chat-session-list__item-open {
  background: color-mix(in srgb, var(--accent) 14%, var(--surface-strong));
  border-color: color-mix(in srgb, var(--accent) 42%, var(--border-soft));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 22%, transparent);
}

.ai-chat-session-list__item-preview {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  margin: 4px 0 2px;
  font-size: 0.86rem;
  line-height: 1.4;
  color: color-mix(in srgb, var(--ink) 60%, transparent);
}

.ai-chat-session-list__item-delete {
  position: absolute;
  inset-inline-end: 8px;
  inset-block-start: 8px;
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: color-mix(in srgb, var(--ink) 50%, transparent);
  cursor: pointer;
  font-size: 1rem;
  line-height: 1;
  opacity: 0.6;
  transition: opacity 0.12s ease, background 0.12s ease, color 0.12s ease;
}

.ai-chat-session-list__item-delete:hover,
.ai-chat-session-list__item-delete:focus-visible {
  background: color-mix(in srgb, #c8442b 22%, transparent);
  color: #c8442b;
  opacity: 1;
  outline: none;
}

/* "Delete current session" button in the main header. */
.ai-chat-button--danger {
  background: transparent;
  border: 1px solid color-mix(in srgb, #c8442b 50%, var(--border-soft));
  color: #c8442b;
  font-weight: 700;
}

.ai-chat-button--danger:hover,
.ai-chat-button--danger:focus-visible {
  background: color-mix(in srgb, #c8442b 14%, transparent);
}

/* Video citation cards (YouTube-style: thumbnail + title + meta). */
.ai-chat-message__videos {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 10px;
  margin-top: 10px;
}

.ai-chat-video-card {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 0;
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  background: var(--surface);
  text-decoration: none;
  color: inherit;
  overflow: hidden;
  transition: transform 0.12s ease, box-shadow 0.12s ease;
}

.ai-chat-video-card:hover,
.ai-chat-video-card:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 8px 20px color-mix(in srgb, var(--ink) 14%, transparent);
  outline: none;
}

.ai-chat-video-card__thumb {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: color-mix(in srgb, var(--ink) 12%, var(--surface));
  background-size: cover;
  background-position: center;
}

.ai-chat-video-card__play {
  position: absolute;
  inset-inline-end: 8px;
  inset-block-end: 8px;
  width: 26px;
  height: 26px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.65);
  color: #fff;
  font-size: 0.82rem;
}

.ai-chat-video-card__timestamp {
  position: absolute;
  inset-inline-start: 8px;
  inset-block-end: 8px;
  padding: 3px 7px;
  border-radius: 4px;
  background: rgba(0, 0, 0, 0.78);
  color: #fff;
  font-size: 0.8rem;
  font-variant-numeric: tabular-nums;
}

.ai-chat-video-card__title {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  padding: 6px 10px 0;
  font-size: 0.92rem;
  font-weight: 700;
  line-height: 1.3;
}

.ai-chat-video-card__meta {
  padding: 0 10px 10px;
  font-size: 0.78rem;
  color: color-mix(in srgb, var(--ink) 60%, transparent);
}

/* Header alignment for the new "delete session" pill. */
.ai-chat-main__usage-block {
  position: relative;
}

.ai-chat-main__usage-block .ai-chat-button--danger {
  margin-top: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 0.78rem;
}
