:root{
  --brown:#4a382a;--brown2:#6b4f3b;--tan:#dcc4a9;--sand:#f3e7d7;--cream:#fffaf4;--gold:#bb8b54;--text:#2b2118;--muted:#756150;--white:#fff;--line:rgba(107,79,59,.22);--shadow:0 18px 55px rgba(74,56,42,.13);--radius:22px;
}
*{box-sizing:border-box}body{margin:0;font-family:Georgia,'Times New Roman',serif;background:linear-gradient(180deg,var(--cream),#f8f0e7);color:var(--text);line-height:1.55}a{color:var(--brown2);font-weight:700}.container{width:min(1120px,calc(100% - 38px));margin:auto}.narrow{width:min(760px,calc(100% - 38px))}.site-header{position:sticky;top:0;z-index:10;background:rgba(74,56,42,.96);border-bottom:1px solid rgba(255,255,255,.16);box-shadow:0 8px 35px rgba(0,0,0,.12)}.nav{height:78px;display:flex;align-items:center;justify-content:space-between;gap:18px}.brand{display:flex;align-items:center;gap:12px;color:#fff;text-decoration:none}.brand-mark{width:48px;height:48px;border-radius:16px;box-shadow:0 8px 25px rgba(0,0,0,.18)}.brand strong{display:block;font-size:1.08rem}.brand small{display:block;color:rgba(255,255,255,.75)}.nav-links{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.nav-links a{color:#fff;text-decoration:none;padding:9px 11px;border-radius:12px;background:rgba(255,255,255,.08)}.nav-links a:hover{background:rgba(255,255,255,.18)}.site-footer{padding:34px 0;color:var(--muted);text-align:center}.login-page{min-height:calc(100vh - 160px);display:grid;place-items:center;padding:40px 18px}.login-card{width:min(460px,100%);background:#fff;border:1px solid var(--line);border-radius:28px;padding:34px;box-shadow:var(--shadow);text-align:center}.login-logo{width:86px;height:86px;margin:0 auto 14px}.login-card h1{margin:0;font-size:2rem;color:var(--brown)}.lead{font-size:1.15rem;color:var(--muted)}label{display:block;text-align:left;font-weight:700;margin:14px 0 6px}input[type=text],input[type=password],input[type=search],input[type=file],input[type=email]{width:100%;padding:12px 13px;border:1px solid var(--tan);border-radius:14px;background:#fff;font:inherit}small{display:block;color:var(--muted);font-weight:400}.button{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--tan);background:#fff;color:var(--brown);border-radius:14px;padding:10px 15px;text-decoration:none;font-weight:800;cursor:pointer}.button.primary{background:var(--brown2);border-color:var(--brown2);color:#fff}.button.small{padding:7px 10px;font-size:.9rem}.actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:22px}.hero-panel{margin:34px 0 22px;padding:42px;border-radius:32px;min-height:300px;color:#fff;background:linear-gradient(120deg,rgba(74,56,42,.94),rgba(107,79,59,.82)),url('../images/staugustine-building.svg');background-size:cover;background-position:center;box-shadow:var(--shadow)}.hero-panel h1{font-size:clamp(2rem,5vw,3.6rem);line-height:1.05;margin:0 0 14px}.kicker{letter-spacing:.12em;text-transform:uppercase;font-weight:900;color:var(--gold);margin:0 0 8px}.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.card,.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}.card h2,.panel h2{margin-top:0;color:var(--brown)}.icon{display:inline-grid;place-items:center;width:44px;height:44px;border-radius:14px;background:var(--sand);color:var(--brown);font-weight:900}.page-title{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;padding:34px 0 18px}.page-title h1{margin:0;font-size:clamp(2rem,4vw,3rem);color:var(--brown)}.muted{color:var(--muted)}.searchbar,.search-panel{display:flex;gap:10px}.searchbar input,.search-panel input{min-width:260px}.search-panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);margin-bottom:20px}.file-list{display:grid;gap:10px;margin:18px 0 34px}.file-row{display:flex;align-items:center;gap:14px;padding:14px;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:0 8px 28px rgba(74,56,42,.07)}.file-icon{width:48px;min-width:48px;height:48px;border-radius:14px;background:var(--sand);display:grid;place-items:center;font-weight:900;color:var(--brown);font-size:.8rem}.file-main{flex:1;min-width:0}.file-name{font-size:1.05rem;text-decoration:none;word-break:break-word}.file-meta{font-size:.88rem;color:var(--muted);word-break:break-word}.alert,.panel.error{background:#fff1f1;border-color:#e4aaaa}.panel.warn,.alert.warn{background:#fff9e8;border-color:#ead18d}.panel.success{background:#eef9ef;border-color:#a9d7ad}.form .button{margin-top:12px}.status-table{width:100%;border-collapse:collapse}.status-table th,.status-table td{padding:10px;border-bottom:1px solid var(--line);text-align:left}.status-table th{width:230px;color:var(--brown)}code{background:var(--sand);padding:2px 5px;border-radius:6px}@media(max-width:820px){.nav{height:auto;align-items:flex-start;flex-direction:column;padding:14px 0}.nav-links{justify-content:flex-start}.grid-3{grid-template-columns:1fr}.page-title{display:block}.searchbar,.search-panel{display:block}.searchbar .button,.search-panel .button{margin-top:10px;width:100%}.hero-panel{padding:28px}}

.library-browser-layout {
  display: grid;
  grid-template-columns: minmax(360px, 42%) 1fr;
  gap: 1.5rem;
  align-items: start;
  margin-top: 1.5rem;
}

.library-preview-pane {
  position: sticky;
  top: 1.5rem;
  min-height: 520px;
}

.media-frame {
  display: block;
  width: 100%;
  min-height: 430px;
  border: 1px solid rgba(0, 0, 0, 0.15);
  border-radius: 12px;
  background: #fff;
}

.library-files-pane {
  min-width: 0;
}

@media (max-width: 980px) {
  .library-browser-layout {
    grid-template-columns: 1fr;
  }

  .library-preview-pane {
    position: static;
    min-height: auto;
  }

  .media-frame {
    min-height: 360px;
  }
}
/* =========================================================
   NSBCOG-style archive library: folder tree + media frame
   ========================================================= */

.archive-library-page {
  max-width: 100%;
}

.archive-page-title {
  margin-bottom: 1rem;
}

.archive-library-layout {
  display: grid;
  grid-template-columns: minmax(360px, 35%) 1fr;
  gap: 1.5rem;
  align-items: stretch;
  min-height: 720px;
}

.archive-tree-panel {
  border-right: 1px solid rgba(0, 0, 0, 0.45);
  padding: 1rem 1.5rem 1rem 0.5rem;
  overflow-y: auto;
  max-height: 78vh;
}

.archive-panel-title {
  margin-top: 0;
  font-size: 1.25rem;
}

.archive-tree-list {
  list-style: none;
  margin: 0;
  padding-left: 0.25rem;
}

.archive-tree-list .archive-tree-list {
  padding-left: 1.75rem;
  margin-top: 0.35rem;
}

.archive-tree-item {
  margin: 0.55rem 0;
  position: relative;
}

.archive-toggle,
.archive-toggle-spacer {
  display: inline-flex;
  width: 1.5rem;
  height: 1.5rem;
  align-items: center;
  justify-content: center;
  vertical-align: middle;
  margin-right: 0.25rem;
}

.archive-toggle {
  border: 0;
  background: transparent;
  cursor: pointer;
  font-size: 1rem;
  color: #444;
  padding: 0;
}

.archive-folder-link {
  display: inline-block;
  vertical-align: middle;
  text-decoration: none;
  color: inherit;
  font-size: 1.12rem;
  line-height: 1.45;
}

.archive-folder-link:hover {
  text-decoration: underline;
}

.archive-children {
  display: none;
}

.archive-tree-item.tree-open > .archive-children {
  display: block;
}

.archive-frame-panel {
  min-width: 0;
  padding: 0.5rem 0 0.5rem 0;
}

.archive-media-frame {
  display: block;
  width: 100%;
  min-height: 730px;
  border: 0;
  background: #fff;
}

/* Iframe body/player styling */
.archive-frame-body {
  margin: 0;
  padding: 1.25rem;
  font-family: inherit;
  background: #fff;
  color: #222;
}

.archive-player-card,
.archive-folder-view {
  max-width: 840px;
  margin: 1rem auto;
  border: 1px solid rgba(0, 0, 0, 0.75);
  border-radius: 22px;
  padding: 1.75rem;
  min-height: 480px;
  background: #fff;
}

.archive-media-title,
.archive-folder-heading {
  margin-top: 0;
  font-size: 1.45rem;
}

.archive-media-meta {
  margin: 1.25rem 0;
  font-size: 1rem;
}

.archive-media-meta p {
  margin: 0.35rem 0;
}

.archive-audio-player,
.archive-video-player {
  display: block;
  width: 100%;
  margin: 1.5rem 0 1rem;
}

.archive-image-preview {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 1.5rem auto;
}

.archive-download-row {
  margin-top: 1rem;
}

.archive-file-list {
  margin-top: 1.25rem;
}

.archive-file-row {
  display: grid;
  grid-template-columns: 92px 1fr;
  gap: 1rem;
  padding: 0.85rem 0;
  border-bottom: 1px solid rgba(0, 0, 0, 0.12);
}

.archive-file-type {
  font-weight: 700;
  font-size: 0.9rem;
}

.archive-file-link {
  font-weight: 700;
  text-decoration: none;
}

.archive-file-link:hover {
  text-decoration: underline;
}

.archive-file-meta {
  font-size: 0.92rem;
  opacity: 0.78;
  margin-top: 0.25rem;
}

.archive-empty-folder {
  margin-top: 1.5rem;
}

/* Responsive layout */
@media (max-width: 980px) {
  .archive-library-layout {
    grid-template-columns: 1fr;
  }

  .archive-tree-panel {
    border-right: 0;
    border-bottom: 1px solid rgba(0, 0, 0, 0.35);
    max-height: none;
    padding-right: 0;
  }

  .archive-media-frame {
    min-height: 620px;
  }
}
/* =========================================================
   Archive tree spacing/alignment refinements
   ========================================================= */

/* Reduce excessive vertical spacing between folder rows */
.archive-tree-item {
  margin: 0.25rem 0;
}

/* Reduce spacing above nested child groups */
.archive-tree-list .archive-tree-list {
  margin-top: 0.15rem;
  padding-left: 1.35rem;
}

/* Keep arrow and folder text centered on the same line */
.archive-tree-item {
  line-height: 1.35;
}

.archive-toggle,
.archive-toggle-spacer {
  width: 1.35rem;
  height: 1.35rem;
  margin-right: 0.25rem;
  vertical-align: middle;
  line-height: 1;
}

.archive-toggle {
  position: relative;
  top: -1px;
}

/* Folder names align more cleanly with their arrows */
.archive-folder-link {
  vertical-align: middle;
  line-height: 1.35;
}
/* =========================================================
   Fix archive folder arrow/title alignment for long names
   ========================================================= */

.archive-tree-item {
  display: grid;
  grid-template-columns: 1.35rem minmax(0, 1fr);
  column-gap: 0.25rem;
  align-items: start;
  margin: 0.25rem 0;
}

.archive-toggle,
.archive-toggle-spacer {
  grid-column: 1;
  grid-row: 1;
  width: 1.35rem;
  height: 1.35rem;
  margin-right: 0;
  align-self: start;
  line-height: 1.35;
}

.archive-folder-link {
  grid-column: 2;
  grid-row: 1;
  display: block;
  min-width: 0;
  line-height: 1.35;
  vertical-align: top;
}

.archive-children {
  grid-column: 1 / -1;
  grid-row: 2;
  margin-left: 1.6rem;
}
/* =========================================================
   Search Archive layout
   ========================================================= */

.archive-search-form-panel {
  margin-bottom: 1.5rem;
}

.archive-search-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 1rem;
  align-items: end;
}

.archive-search-form label {
  display: grid;
  gap: 0.45rem;
  font-weight: 700;
}

.archive-search-form input[type="search"] {
  width: 100%;
  min-height: 48px;
  padding: 0.85rem 1rem;
  border: 1px solid rgba(0, 0, 0, 0.18);
  border-radius: 12px;
  font-size: 1rem;
}

.archive-search-layout {
  display: grid;
  grid-template-columns: minmax(380px, 48%) 1fr;
  gap: 1.5rem;
  align-items: start;
}

.archive-search-results-panel {
  min-width: 0;
}

.archive-search-count-panel {
  margin-bottom: 1rem;
}

.archive-search-results-list {
  display: grid;
  gap: 0.85rem;
}

.archive-search-result-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 1rem;
  align-items: center;
  padding: 1rem;
  border: 1px solid rgba(0, 0, 0, 0.14);
  border-radius: 14px;
  background: #fff;
}

.archive-search-result-title {
  display: inline-block;
  font-weight: 700;
  font-size: 1.08rem;
  text-decoration: none;
}

.archive-search-result-title:hover {
  text-decoration: underline;
}

.archive-search-result-meta {
  margin-top: 0.35rem;
  font-size: 0.94rem;
  opacity: 0.8;
}

.archive-search-player-panel {
  position: sticky;
  top: 1.5rem;
  border: 1px solid rgba(0, 0, 0, 0.14);
  border-radius: 18px;
  padding: 1.25rem;
  background: #fff;
}

.archive-search-player-panel h2 {
  margin-top: 0;
}

.archive-search-media-frame {
  display: block;
  width: 100%;
  min-height: 620px;
  border: 1px solid rgba(0, 0, 0, 0.14);
  border-radius: 14px;
  background: #fff;
}

@media (max-width: 980px) {
  .archive-search-form {
    grid-template-columns: 1fr;
  }

  .archive-search-layout {
    grid-template-columns: 1fr;
  }

  .archive-search-player-panel {
    position: static;
  }

  .archive-search-media-frame {
    min-height: 520px;
  }
}
/* =========================================================
   Mobile-only Library application view
   Desktop library remains unchanged
   ========================================================= */

.mobile-library-view {
  display: none;
}

@media (max-width: 820px) {

  .archive-page-title,
  .archive-library-layout,
  .archive-tree-panel,
  .archive-frame-panel {
    display: none !important;
  }

  .mobile-library-view {
    display: block !important;
    padding: 1rem 0.35rem 2rem;
  }

  /*
   * Show mobile application-style folder navigation.
   */
  .mobile-library-view {
    display: block;
    padding: 1rem 0.35rem 2rem;
  }

  .mobile-back-row {
    margin: 0 0 1.7rem;
  }

  .mobile-go-back {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    text-decoration: none;
    font-weight: 700;
    font-size: 1.05rem;
  }

  .mobile-back-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.65rem;
    height: 2.65rem;
    border: 1px solid rgba(0, 0, 0, 0.16);
    border-radius: 999px;
    font-size: 1.8rem;
    line-height: 1;
  }

  .mobile-library-title {
    margin: 0 0 1.25rem;
    font-size: 2rem;
    line-height: 1.2;
    font-weight: 800;
    text-transform: uppercase;
  }

  .mobile-folder-list {
    display: grid;
    gap: 0.95rem;
  }

  .mobile-folder-row {
    display: grid;
    grid-template-columns: 3.2rem 1fr;
    align-items: center;
    gap: 0.9rem;
    padding: 0.2rem 0;
    text-decoration: none;
  }

  .mobile-folder-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3.2rem;
    font-size: 2.4rem;
    line-height: 1;
  }

  .mobile-folder-name {
    font-size: 1.85rem;
    line-height: 1.18;
    font-weight: 500;
  }

  .mobile-message-section {
    margin-top: 1.75rem;
  }

  .mobile-message-heading {
    margin: 0 0 0.95rem;
    font-size: 1.55rem;
    font-weight: 800;
  }

  .mobile-message-list {
    display: grid;
    gap: 0.8rem;
  }

  .mobile-message-row {
    display: grid;
    gap: 0.25rem;
    padding: 0.85rem 0.8rem;
    border: 1px solid rgba(0, 0, 0, 0.14);
    border-radius: 12px;
    text-decoration: none;
    background: #fff;
  }

  .mobile-message-title {
    font-size: 1.18rem;
    font-weight: 700;
    line-height: 1.3;
  }

  .mobile-message-meta {
    font-size: 0.98rem;
    opacity: 0.78;
  }

  .mobile-library-alert,
  .mobile-library-empty {
    margin-top: 1rem;
    padding: 1rem;
    border: 1px solid rgba(0, 0, 0, 0.16);
    border-radius: 12px;
    background: #fff;
    font-size: 1rem;
  }
}
/* =========================================================
   Mobile Library Navigation Buttons:
   Go Back + Start Over
   ========================================================= */

.mobile-media-actions {
  display: none;
}

@media (max-width: 820px) {

  .mobile-library-actions,
  .mobile-media-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    align-items: center;
    margin: 0 0 1.5rem;
  }

  .mobile-start-over {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    text-decoration: none;
    font-weight: 700;
    font-size: 1.05rem;
  }

  .mobile-start-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.65rem;
    height: 2.65rem;
    border: 1px solid rgba(0, 0, 0, 0.16);
    border-radius: 999px;
    font-size: 1.55rem;
    line-height: 1;
  }
}
/* =========================================================
   Mobile Library: reduce folder-name size
   ========================================================= */

@media (max-width: 820px) {
  .mobile-folder-name {
    font-size: 1.22rem !important;
    line-height: 1.3 !important;
    font-weight: 600;
  }

  .mobile-folder-row {
    grid-template-columns: 2.5rem 1fr !important;
    gap: 0.65rem !important;
  }

  .mobile-folder-icon {
    width: 2.5rem !important;
    font-size: 1.9rem !important;
  }
}
/* =========================================================
   Playlist rendering for Singing, Miscellaneous,
   and Children's Stories
   ========================================================= */

.archive-playlist-card {
  max-width: 840px;
  margin: 1rem auto 1.5rem;
  padding: 1.35rem 1.75rem;
  border-radius: 22px;
  background: #dbe9f1;
}

.archive-playlist-list {
  margin: 0;
  padding-left: 1.75rem;
}

.archive-playlist-item {
  margin: 0.8rem 0;
  padding-left: 0.15rem;
  font-size: 1.08rem;
  line-height: 1.35;
}

.archive-playlist-item a {
  color: inherit;
  text-decoration: none;
}

.archive-playlist-item a:hover {
  text-decoration: underline;
}

.archive-playlist-item.is-active a {
  font-weight: 800;
}

@media (max-width: 820px) {
  .archive-playlist-card {
    margin: 0.85rem auto 1.25rem;
    padding: 1rem 1.15rem;
    border-radius: 18px;
  }

  .archive-playlist-item {
    font-size: 1rem;
    margin: 0.7rem 0;
  }
}
/* =========================================================
   Mobile Library Page:
   Push footer scripture/copyright/contact farther down
   ========================================================= */

@media (max-width: 820px) {
  main.archive-library-page ~ footer,
  main.archive-library-page + footer {
    margin-top: 8rem !important;
    padding-top: 1.5rem !important;
  }
}
/* =========================================================
   Mobile Media Player Navigation
   ========================================================= */

.mobile-media-actions {
  display: none;
}

@media (max-width: 820px) {
  .mobile-media-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    align-items: center;
    margin: 0 0 1.35rem;
  }

  .mobile-start-over {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    text-decoration: none;
    font-weight: 700;
    font-size: 1.05rem;
  }

  .mobile-start-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.65rem;
    height: 2.65rem;
    border: 1px solid rgba(0, 0, 0, 0.16);
    border-radius: 999px;
    font-size: 1.55rem;
    line-height: 1;
  }
}

/* =========================================================
   Playlist Style — Desktop and Mobile
   ========================================================= */

.archive-playlist-player-card {
  max-width: 840px;
  margin: 1rem auto;
  padding: 0 0 1.25rem;
  text-align: center;
}

.archive-playlist-heading {
  margin: 0 0 0.25rem;
  font-size: 2rem;
  line-height: 1.2;
}

.archive-playlist-folder-label {
  margin-bottom: 0.85rem;
  font-size: 1.15rem;
}

.archive-playlist-audio {
  display: block;
  width: 100%;
  margin: 0 auto 0.75rem;
  padding: 1rem 1.5rem;
  border-radius: 28px;
  background: #dbe9f1;
  box-sizing: border-box;
}

.archive-playlist-card {
  text-align: left;
  margin-top: 0.65rem;
  padding: 1.3rem 1.8rem;
  border-radius: 22px;
  background: #dbe9f1;
}

.archive-playlist-list {
  margin: 0;
  padding-left: 1.8rem;
}

.archive-playlist-item {
  margin: 0.8rem 0;
  font-size: 1.12rem;
  line-height: 1.45;
}

.archive-playlist-item a {
  color: inherit;
  text-decoration: none;
}

.archive-playlist-item a:hover {
  text-decoration: underline;
}

.archive-playlist-item.is-active a {
  font-weight: 800;
}

@media (max-width: 820px) {
  .archive-playlist-player-card {
    margin: 0.75rem auto;
  }

  .archive-playlist-heading {
    font-size: 1.7rem;
  }

  .archive-playlist-folder-label {
    font-size: 1rem;
  }

  .archive-playlist-audio {
    padding: 0.85rem 1rem;
    border-radius: 22px;
  }

  .archive-playlist-card {
    padding: 1rem 1.15rem;
    border-radius: 18px;
  }

  .archive-playlist-item {
    margin: 0.7rem 0;
    font-size: 1.05rem;
  }
}
/* =========================================================
   Playlist player:
   Singing, Children's Stories, Sixth Seal Audiobooks,
   and selected Miscellaneous Testimonies folders
   ========================================================= */

.archive-playlist-player-card {
  max-width: 840px;
  margin: 0.75rem auto 1.5rem;
  text-align: center;
}

.archive-playlist-heading {
  margin: 0 0 0.15rem;
  font-size: 2rem;
  line-height: 1.15;
}

.archive-playlist-folder-label {
  margin: 0 0 0.8rem;
  font-size: 1.15rem;
}

.archive-playlist-audio-shell {
  margin: 0 auto 0.7rem;
  padding: 0.9rem 1.25rem;
  border-radius: 28px;
  background: #dbe9f1;
}

.archive-playlist-audio {
  display: block;
  width: 100%;
}

.archive-playlist-card {
  text-align: left;
  margin-top: 0.6rem;
  padding: 1.25rem 1.8rem;
  border-radius: 22px;
  background: #dbe9f1;
}

.archive-playlist-list {
  margin: 0;
  padding-left: 1.8rem;
}

.archive-playlist-item {
  margin: 0.8rem 0;
  font-size: 1.12rem;
  line-height: 1.45;
}

.archive-playlist-item a {
  color: inherit;
  text-decoration: none;
}

.archive-playlist-item a:hover {
  text-decoration: underline;
}

.archive-playlist-item.is-active a {
  font-weight: 800;
}

/* =========================================================
   Mobile media-player navigation buttons
   ========================================================= */

.mobile-media-actions {
  display: none;
}

@media (max-width: 820px) {
  .mobile-media-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    align-items: center;
    margin: 0 0 1.35rem;
  }

  .mobile-start-over {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    text-decoration: none;
    font-weight: 700;
    font-size: 1.05rem;
  }

  .mobile-start-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.65rem;
    height: 2.65rem;
    border: 1px solid rgba(0, 0, 0, 0.16);
    border-radius: 999px;
    font-size: 1.55rem;
    line-height: 1;
  }

  .archive-playlist-player-card {
    margin: 0.5rem auto 1.25rem;
  }

  .archive-playlist-heading {
    font-size: 1.7rem;
  }

  .archive-playlist-folder-label {
    font-size: 1rem;
  }

  .archive-playlist-audio-shell {
    padding: 0.75rem 1rem;
    border-radius: 22px;
  }

  .archive-playlist-card {
    padding: 1rem 1.15rem;
    border-radius: 18px;
  }

  .archive-playlist-item {
    margin: 0.7rem 0;
    font-size: 1.04rem;
  }
}
/* =========================================================
   NSBCOG-style playlist player
   ========================================================= */

.ta-playlist-player-card {
  max-width: 840px;
  margin: 0.75rem auto 1.5rem;
  text-align: center;
}

.ta-playlist-title {
  font-family: Garamond, "EB Garamond", Georgia, serif;
  font-size: 2rem;
  line-height: 1.15;
  font-weight: 700;
  margin-bottom: 0.2rem;
}

.ta-playlist-subtitle {
  font-family: Garamond, "EB Garamond", Georgia, serif;
  font-size: 1.15rem;
  margin-bottom: 0.7rem;
}

.ta-playlist-audio-shell {
  width: 100%;
  box-sizing: border-box;
  padding: 1rem 1.25rem;
  border-radius: 24px;
  background: #e7d5b5;;
  margin-bottom: 0.75rem;
}

.ta-playlist-audio {
  display: block;
  width: 100%;
}

.ta-playlist-list {
  text-align: left;
  margin: 0;
  padding: 1.35rem 1.8rem 1.35rem 3.4rem;
  border-radius: 22px;
  background: #e7d5b5;
  font-family: Garamond, "EB Garamond", Georgia, serif;
  font-size: 1.15rem;
  line-height: 1.45;
}

.ta-playlist-item {
  margin: 0.7rem 0;
  padding-left: 0.15rem;
}

.ta-playlist-item a {
  color: inherit;
  text-decoration: none;
}

.ta-playlist-item a:hover {
  text-decoration: underline;
}

.ta-playlist-item.active a {
  font-weight: 700;
}

@media (max-width: 820px) {
  .ta-playlist-player-card {
    margin: 0.5rem auto 1.25rem;
  }

  .ta-playlist-title {
    font-size: 1.6rem;
  }

  .ta-playlist-subtitle {
    font-size: 1rem;
  }

  .ta-playlist-audio-shell {
    padding: 0.8rem 1rem;
    border-radius: 20px;
  }

  .ta-playlist-list {
    padding: 1.15rem 1rem 1.15rem 2.4rem;
    border-radius: 18px;
    font-size: 1.05rem;
  }

  .ta-playlist-item {
    margin: 0.65rem 0;
  }
}
/* =========================================================
   Mobile media player navigation buttons
   ========================================================= */

.mobile-media-actions {
  display: none;
}

@media (max-width: 820px) {
  .mobile-media-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    align-items: center;
    margin: 0 0 1.4rem;
  }

  .mobile-start-over {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    text-decoration: none;
    font-weight: 700;
    font-size: 1.05rem;
  }

  .mobile-start-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.65rem;
    height: 2.65rem;
    border: 1px solid rgba(0, 0, 0, 0.16);
    border-radius: 999px;
    font-size: 1.55rem;
    line-height: 1;
  }
}
/* =========================================================
   Playlist: make currently playing track bold
   ========================================================= */

.ta-playlist-item.active > a,
.ta-playlist-item.active .ta-playlist-track {
  font-weight: 900 !important;
}
/* =========================================================
   Singing -> Song Albums:
   Make artist folders smaller/lighter than album titles
   Applies to desktop and mobile
   ========================================================= */

/* Desktop left-side Library tree */
.archive-folder-link.song-album-artist-link {
  font-weight: 400 !important;
  font-size: 0.95rem !important;
  opacity: 0.82;
}

.archive-tree-item.song-album-artist-item {
  margin-top: 0.12rem;
  margin-bottom: 0.12rem;
}

/* Mobile Library folder navigation */
@media (max-width: 820px) {
  .mobile-folder-row.song-album-artist-row .mobile-folder-name {
    font-weight: 400 !important;
    font-size: 1rem !important;
    line-height: 1.25 !important;
    opacity: 0.84;
  }

  .mobile-folder-row.song-album-artist-row .mobile-folder-icon {
    font-size: 1.45rem !important;
    width: 2rem !important;
  }

  .mobile-folder-row.song-album-artist-row {
    grid-template-columns: 2rem 1fr !important;
    gap: 0.5rem !important;
    padding-top: 0.1rem !important;
    padding-bottom: 0.1rem !important;
  }
}
/* =========================================================
   Desktop correction:
   Singing -> Song Albums
   Artist names smaller, album titles larger and bold
   ========================================================= */

/* Artist folders directly under Singing -> Song Albums */
.archive-folder-link.song-album-artist-link {
  font-weight: 400 !important;
  font-size: 0.98rem !important;
  opacity: 0.82 !important;
}

/* Album folders under each artist */
.archive-tree-item.song-album-artist-item
  > .archive-children
  > .archive-tree-list
  > .archive-tree-item
  > .archive-folder-link {
  font-weight: 800 !important;
  font-size: 1.13rem !important;
  opacity: 1 !important;
  line-height: 1.35 !important;
}

/* Keep album rows comfortably spaced */
.archive-tree-item.song-album-artist-item
  > .archive-children
  > .archive-tree-list
  > .archive-tree-item {
  margin-top: 0.22rem !important;
  margin-bottom: 0.22rem !important;
}
/* =========================================================
   Singing -> Song Albums:
   Restore album titles to original bold font only
   ========================================================= */

.archive-tree-item.song-album-artist-item
  > .archive-children
  > .archive-tree-list
  > .archive-tree-item
  > .archive-folder-link {
  font-weight: 700 !important;
  font-size: 1.12rem !important;
  opacity: 1 !important;
}
/* =========================================================
   Singing -> Song Albums final fix
   Artist folders smaller/lighter.
   Album title folders original bold/prominent.
   ========================================================= */

/* Artist names directly under Song Albums */
.archive-folder-link.song-album-artist-link {
  font-weight: 400 !important;
  font-size: 0.95rem !important;
  opacity: 0.78 !important;
}

/* Album titles under each artist */
.archive-folder-link.song-album-title-link {
  font-weight: 700 !important;
  font-size: 1.12rem !important;
  opacity: 1 !important;
  line-height: 1.35 !important;
}

/* Mobile artist names */
@media (max-width: 820px) {
  .mobile-folder-row.song-album-artist-row .mobile-folder-name {
    font-weight: 400 !important;
    font-size: 0.95rem !important;
    opacity: 0.78 !important;
  }

  .mobile-folder-row.song-album-title-row .mobile-folder-name {
    font-weight: 700 !important;
    font-size: 1.18rem !important;
    opacity: 1 !important;
  }
}
/* =========================================================
   Singing -> Song Albums
   Album title bold/original emphasis
   Artist smaller underneath
   ========================================================= */

.archive-library-page .archive-folder-link.song-album-entry-link {
  font-size: 1rem !important;
  font-weight: 400 !important;
  line-height: 1.25 !important;
  opacity: 1 !important;
}

.archive-library-page .archive-folder-link.song-album-entry-link .song-album-title-text {
  display: block;
  font-weight: 700 !important;
  font-size: 1.08rem !important;
  opacity: 1 !important;
  color: inherit !important;
}

.archive-library-page .archive-folder-link.song-album-entry-link .song-album-artist-text {
  display: block;
  font-weight: 400 !important;
  font-size: 0.88rem !important;
  opacity: 0.78 !important;
  margin-top: 0.08rem;
  color: inherit !important;
}

/* Mobile */
@media (max-width: 820px) {
  .mobile-folder-row.song-album-entry-row .song-album-title-text {
    display: block;
    font-weight: 700 !important;
    font-size: 1.02rem !important;
    opacity: 1 !important;
  }

  .mobile-folder-row.song-album-entry-row .song-album-artist-text {
    display: block;
    font-weight: 400 !important;
    font-size: 0.84rem !important;
    opacity: 0.78 !important;
    margin-top: 0.08rem;
  }
}
/* =========================================================
   Desktop only:
   Hide Go Back button inside media player / playlist frame.
   Keep Start Over visible.
   Mobile still shows Go Back + Start Over.
   ========================================================= */

@media (min-width: 821px) {
  body.archive-frame-body .mobile-media-actions .mobile-go-back {
    display: none !important;
  }
}
/* =========================================================
   Desktop only:
   Hide Go Back in the media frame.
   Start Over remains and reloads the full Library page.
   Mobile still shows Go Back and Start Over.
   ========================================================= */

@media (min-width: 821px) {
  body.archive-frame-body .mobile-media-actions .mobile-go-back {
    display: none !important;
  }
}
/* =========================================================
   Folder pages:
   Go Back + Start Over
   Media player pages:
   Start Over only
   ========================================================= */

.folder-media-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  align-items: center;
  margin: 0 0 1.35rem;
}

.folder-go-back,
.folder-start-over {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  text-decoration: none;
  font-weight: 700;
  font-size: 1.05rem;
}

/* Keep media player actions clean */
.mobile-media-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  align-items: center;
  margin: 0 0 1.35rem;
}
/* =========================================================
   Go Back button is mobile-only.
   Desktop media frame shows Start Over only.
   ========================================================= */

@media (min-width: 821px) {
  body.archive-frame-body .mobile-media-actions .mobile-go-back {
    display: none !important;
  }
}

@media (max-width: 820px) {
  body.archive-frame-body .mobile-media-actions .mobile-go-back {
    display: inline-flex !important;
  }
}
/* =========================================================
   Mobile Library folder navigation buttons
   ========================================================= */

@media (max-width: 820px) {
  .mobile-library-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    align-items: center;
    margin: 0 0 1.5rem;
  }

  .mobile-go-back,
  .mobile-start-over {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    text-decoration: none;
    font-weight: 700;
    font-size: 1.05rem;
  }
}
/* =========================================================
   Media player navigation:
   Mobile gets Go Back + Start Over.
   Desktop media frame shows Start Over only.
   ========================================================= */

.mobile-media-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  align-items: center;
  margin: 0 0 1.35rem;
}

.mobile-go-back,
.mobile-start-over {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  text-decoration: none;
  font-weight: 700;
  font-size: 1.05rem;
}

@media (min-width: 821px) {
  body.archive-frame-body .mobile-media-actions .mobile-go-back {
    display: none !important;
  }
}

@media (max-width: 820px) {
  body.archive-frame-body .mobile-media-actions .mobile-go-back {
    display: inline-flex !important;
  }
}
/* =========================================================
   Upload Media page redesign
   ========================================================= */

.upload-media-page {
  max-width: 1500px;
}

.upload-media-layout {
  display: grid;
  grid-template-columns: minmax(320px, 0.95fr) minmax(360px, 1fr);
  gap: 1.5rem;
  align-items: start;
}

.upload-form-card,
.upload-folder-card {
  background: #fffaf0;
  border: 1px solid rgba(187, 139, 84, 0.45);
  border-radius: 22px;
  padding: 1.5rem;
  box-shadow: 0 10px 25px rgba(58, 42, 30, 0.08);
}

.upload-field {
  display: grid;
  gap: 0.35rem;
  margin-bottom: 1.05rem;
}

.upload-field label {
  font-weight: 800;
  font-size: 1.05rem;
}

.upload-field input[type="text"],
.upload-field input[type="date"],
.upload-field input[type="file"] {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid rgba(58, 42, 30, 0.35);
  border-radius: 10px;
  padding: 0.7rem 0.85rem;
  font-size: 1rem;
  background: #fff;
}

.upload-field input[type="date"] {
  font-size: 1.05rem;
  cursor: pointer;
}

.upload-field small {
  color: rgba(58, 42, 30, 0.72);
}

.upload-date-preview {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #efe1c8;
  border-radius: 12px;
  padding: 0.85rem 1rem;
  margin: 0.5rem 0 1.25rem;
  font-size: 0.98rem;
}

.upload-date-preview strong {
  font-size: 1.05rem;
}

.upload-submit {
  width: 100%;
  justify-content: center;
  font-size: 1.1rem;
  padding: 0.85rem 1rem;
}

.upload-folder-card {
  min-height: 620px;
}

.upload-folder-card-title h2 {
  margin: 0;
  font-size: 1.65rem;
}

.upload-folder-card-title p {
  margin-top: 0.25rem;
  color: rgba(58, 42, 30, 0.75);
}

.upload-folder-tree {
  margin-top: 1rem;
  border: 2px solid rgba(187, 139, 84, 0.65);
  border-radius: 12px;
  background: #fff;
  padding: 1rem;
  max-height: 650px;
  overflow: auto;
}

.upload-folder-tree-list {
  list-style: none;
  margin: 0;
  padding-left: 1rem;
}

.upload-folder-tree > .upload-folder-tree-list {
  padding-left: 0;
}

.upload-folder-tree-item {
  margin: 0.15rem 0;
}

.upload-folder-select {
  width: 100%;
  border: 0;
  background: transparent;
  display: flex;
  align-items: center;
  gap: 0.45rem;
  text-align: left;
  font-family: Garamond, "EB Garamond", Georgia, serif;
  font-size: 1.15rem;
  color: #2d2017;
  padding: 0.2rem 0.25rem;
  cursor: pointer;
  border-radius: 8px;
}

.upload-folder-select:hover,
.upload-folder-select.is-selected {
  background: #efe1c8;
}

.upload-folder-arrow {
  width: 1rem;
  opacity: 0.8;
}

.upload-folder-name {
  line-height: 1.25;
}

.upload-folder-children {
  margin-left: 1rem;
}

@media (max-width: 900px) {
  .upload-media-layout {
    grid-template-columns: 1fr;
  }

  .upload-folder-card {
    min-height: unset;
  }

  .upload-folder-tree {
    max-height: 520px;
  }
}
/* =========================================================
   Upload page folder tree accordion
   ========================================================= */

.upload-folder-children.is-collapsed {
  display: none !important;
}

.upload-folder-select {
  user-select: none;
}

.upload-folder-arrow {
  display: inline-block;
  width: 1.2rem;
  text-align: center;
}
/* Upload page: add spacing below success message */
.upload-media-page .panel.success {
  margin-bottom: 1.75rem !important;
}
/* =========================================================
   Desktop MediaFrame child-folder browser
   ========================================================= */

.archive-child-folder-browser {
  padding: 1rem 1.25rem;
}

.archive-frame-back {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  text-decoration: none;
  font-weight: 700;
  margin-bottom: 0.9rem;
}

.archive-frame-folder-list {
  display: grid;
  gap: 0.65rem;
  margin-top: 1rem;
}

.archive-frame-folder-row {
  display: grid;
  grid-template-columns: 2.4rem 1fr;
  align-items: center;
  gap: 0.65rem;
  text-decoration: none;
  color: inherit;
  padding: 0.25rem 0.35rem;
  border-radius: 10px;
}

.archive-frame-folder-row:hover {
  background: #efe1c8;
}

.archive-frame-folder-icon {
  font-size: 1.75rem;
  line-height: 1;
}

.archive-frame-folder-name {
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.25;
}
/* Media player file list: show date where AUDIO used to appear */
.archive-file-date {
  font-weight: 700 !important;
  font-size: 0.95rem !important;
  white-space: nowrap;
}
/* =========================================================
   Media player navigation buttons
   ========================================================= */

.archive-media-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  align-items: center;
  margin: 0 0 1.25rem;
}

.archive-media-action {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  text-decoration: none;
  font-weight: 700;
  font-size: 1.05rem;
  color: inherit;
}

.archive-media-action-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.55rem;
  height: 2.55rem;
  border: 1px solid rgba(0, 0, 0, 0.16);
  border-radius: 999px;
  font-size: 1.45rem;
  line-height: 1;
  background: #efe1c8;
}

.archive-media-action:hover .archive-media-action-icon {
  background: #e7d5b5;
}
/* Admin page spacing and helper links */
.admin-helper-link {
  margin-top: 0.85rem;
  margin-bottom: 0;
}

.admin-helper-link a {
  font-weight: 700;
  text-decoration: underline;
}

/* =========================================================
   Admin page spacing correction:
   remove space above Library card;
   add space below Library card before Update Library Index.
   ========================================================= */

.admin-library-section {
  margin-top: 0 !important;
  margin-bottom: 2.5rem !important;
}

/* Upload page: Create Folder panel under Library Folders */
.upload-create-folder-form {
  margin-top: 1.75rem;
  padding-top: 1.25rem;
  border-top: 1px solid rgba(187, 139, 84, 0.45);
  display: grid;
  gap: 0.85rem;
}

.upload-create-folder-form h3 {
  margin: 0;
  font-size: 1.35rem;
}

.upload-create-folder-form label {
  display: grid;
  gap: 0.35rem;
  font-weight: 700;
}

.upload-create-folder-form input[type="text"] {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid rgba(58, 42, 30, 0.35);
  border-radius: 10px;
  padding: 0.65rem 0.8rem;
  font-size: 1rem;
  background: #fff;
}

.upload-create-folder-note {
  margin: 0;
  font-size: 0.92rem;
  color: rgba(58, 42, 30, 0.78);
}

/* =========================================================
   DESKTOP ONLY: Singing > Song Albums
   Album title = same style as folder headings, bold.
   Artist after dash = same font/size, not bold.
   ========================================================= */

@media (min-width: 769px) {
  body .archive-library-page .archive-tree-list .archive-tree-item.song-album-title-item > a.archive-folder-link.song-album-title-link,
  body .archive-tree-list .archive-tree-item.song-album-title-item > a.archive-folder-link.song-album-title-link {
    font-family: Georgia, "Times New Roman", serif !important;
    font-size: 1.55rem !important;
    font-weight: 800 !important;
    line-height: 1.18 !important;
    color: #1f1a14 !important;
    text-decoration: none !important;
  }

  body .archive-library-page .archive-tree-list .archive-tree-item.song-album-title-item > a.archive-folder-link.song-album-title-link .song-album-title-text,
  body .archive-tree-list .archive-tree-item.song-album-title-item > a.archive-folder-link.song-album-title-link .song-album-title-text {
    font-family: Georgia, "Times New Roman", serif !important;
    font-size: 1.55rem !important;
    font-weight: 800 !important;
    line-height: 1.18 !important;
    color: #1f1a14 !important;
  }

  body .archive-library-page .archive-tree-list .archive-tree-item.song-album-title-item > a.archive-folder-link.song-album-title-link .song-album-artist-text,
  body .archive-tree-list .archive-tree-item.song-album-title-item > a.archive-folder-link.song-album-title-link .song-album-artist-text {
    font-family: Georgia, "Times New Roman", serif !important;
    font-size: 1.55rem !important;
    font-weight: 400 !important;
    line-height: 1.18 !important;
    color: #1f1a14 !important;
  }
}
/* =========================================================
   FIX: Song Albums styling - DESKTOP ONLY
   Desktop: album title bold like folder headings.
   Artist after dash: same font/size, not bold.
   Mobile: undo album-specific styling so mobile stays normal.
   ========================================================= */

/* Undo prior mobile-specific Song Album font overrides */
@media (max-width: 768px) {
  .mobile-folder-row.song-album-title-row .mobile-folder-name,
  .mobile-folder-row.song-album-artist-row .mobile-folder-name,
  .mobile-folder-row.song-album-entry-row .mobile-folder-name,
  .mobile-folder-row.song-album-title-row .song-album-title-text,
  .mobile-folder-row.song-album-title-row .song-album-artist-text,
  .mobile-folder-row.song-album-entry-row .song-album-title-text,
  .mobile-folder-row.song-album-entry-row .song-album-artist-text {
    font-family: inherit !important;
    font-size: inherit !important;
    font-weight: inherit !important;
    line-height: inherit !important;
  }
}

/* Desktop-only Song Albums formatting */
@media (min-width: 769px) {
  .archive-tree-list .archive-folder-link.song-album-title-link,
  .archive-tree-list .archive-folder-link.song-album-entry-link {
    font-family: Georgia, "Times New Roman", serif !important;
    font-size: 1.55rem !important;
    line-height: 1.18 !important;
    color: #1f1a14 !important;
    text-decoration: none !important;
  }

  .archive-tree-list .archive-folder-link.song-album-title-link .song-album-title-text,
  .archive-tree-list .archive-folder-link.song-album-entry-link .song-album-title-text {
    font-family: Georgia, "Times New Roman", serif !important;
    font-size: 1.55rem !important;
    font-weight: 800 !important;
    line-height: 1.18 !important;
    color: #1f1a14 !important;
  }

  .archive-tree-list .archive-folder-link.song-album-title-link .song-album-artist-text,
  .archive-tree-list .archive-folder-link.song-album-entry-link .song-album-artist-text {
    font-family: Georgia, "Times New Roman", serif !important;
    font-size: 1.55rem !important;
    font-weight: 400 !important;
    line-height: 1.18 !important;
    color: #1f1a14 !important;
  }
}

/* =========================================================
   FINAL DESKTOP-ONLY OVERRIDE: Singing > Song Albums
   - Direct artist/base folders under Song Albums: same font/size as Song Albums, NOT bold.
   - Album folders: same font/size as Song Albums.
   - Text before dash: bold.
   - Text after dash: same font/size, NOT bold.
   - Mobile folder rows are intentionally reset to their normal mobile styling.
   ========================================================= */

@media (max-width: 768px) {
  .mobile-folder-row.song-album-artist-row .mobile-folder-name,
  .mobile-folder-row.song-album-title-row .mobile-folder-name,
  .mobile-folder-row.song-album-entry-row .mobile-folder-name,
  .mobile-folder-row.song-album-title-row .song-album-title-text,
  .mobile-folder-row.song-album-title-row .song-album-artist-text,
  .mobile-folder-row.song-album-entry-row .song-album-title-text,
  .mobile-folder-row.song-album-entry-row .song-album-artist-text {
    font-family: inherit !important;
    font-size: inherit !important;
    font-weight: inherit !important;
    line-height: inherit !important;
    opacity: inherit !important;
  }
}

@media (min-width: 769px) {
  body .archive-library-page .archive-tree-panel .archive-folder-link.song-album-artist-link,
  body .archive-library-page .archive-tree-panel .archive-folder-link.song-album-title-link,
  body .archive-library-page .archive-tree-panel .archive-folder-link.song-album-entry-link {
    font-family: Georgia, "Times New Roman", serif !important;
    font-size: 1.12rem !important;
    line-height: 1.35 !important;
    color: inherit !important;
    opacity: 1 !important;
    text-decoration: none !important;
  }

  body .archive-library-page .archive-tree-panel .archive-folder-link.song-album-artist-link {
    font-weight: 400 !important;
  }

  body .archive-library-page .archive-tree-panel .archive-folder-link.song-album-title-link,
  body .archive-library-page .archive-tree-panel .archive-folder-link.song-album-entry-link,
  body .archive-library-page .archive-tree-panel .archive-folder-link.song-album-title-link .song-album-title-text,
  body .archive-library-page .archive-tree-panel .archive-folder-link.song-album-entry-link .song-album-title-text {
    font-family: Georgia, "Times New Roman", serif !important;
    font-size: 1.12rem !important;
    font-weight: 800 !important;
    line-height: 1.35 !important;
    color: inherit !important;
    opacity: 1 !important;
  }

  body .archive-library-page .archive-tree-panel .archive-folder-link.song-album-title-link .song-album-artist-text,
  body .archive-library-page .archive-tree-panel .archive-folder-link.song-album-entry-link .song-album-artist-text {
    font-family: Georgia, "Times New Roman", serif !important;
    font-size: 1.12rem !important;
    font-weight: 400 !important;
    line-height: 1.35 !important;
    color: inherit !important;
    opacity: 1 !important;
  }
}

/* Album playlist player: main album title and artist subtitle */
.ta-playlist-title {
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 2rem !important;
  font-weight: 800 !important;
  line-height: 1.15 !important;
}

.ta-playlist-subtitle {
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: 1.35rem !important;
  font-weight: 400 !important;
  line-height: 1.25 !important;
}
/* Upload page: add space above the post-upload admin note */
.upload-media-page > .panel.warn {
  margin-top: 2rem !important;
}

/* =========================================================
   Delete Folder admin page
   ========================================================= */

.delete-folder-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.95fr);
  gap: 2rem;
  align-items: start;
}

.delete-folder-card {
  background: #fffaf0;
  border: 1px solid rgba(187, 139, 84, 0.45);
  border-radius: 18px;
  padding: 1.35rem;
  box-shadow: 0 12px 35px rgba(58, 42, 30, 0.08);
}

.delete-folder-form {
  display: grid;
  gap: 1rem;
}

.delete-folder-form label {
  display: grid;
  gap: 0.4rem;
  font-weight: 700;
}

.delete-folder-form input[type="text"] {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid rgba(58, 42, 30, 0.35);
  border-radius: 10px;
  padding: 0.65rem 0.8rem;
  font-size: 1rem;
  background: #fff;
}

.delete-folder-form small {
  font-weight: 400;
  color: rgba(58, 42, 30, 0.7);
}

.delete-folder-button-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
}

.button.danger {
  background: #8a2f24 !important;
  color: #fff !important;
  border-color: #8a2f24 !important;
}

.button.danger.stronger {
  background: #5f1711 !important;
  border-color: #5f1711 !important;
}

.delete-folder-tree {
  border: 1px solid rgba(187, 139, 84, 0.45);
  border-radius: 12px;
  padding: 0.9rem;
  background: #fff;
  max-height: 520px;
  overflow: auto;
}

.delete-folder-tree-list {
  list-style: none;
  margin: 0;
  padding-left: 0;
}

.delete-folder-children {
  margin-left: 1.15rem;
}

.delete-folder-children.is-collapsed {
  display: none !important;
}

.delete-folder-select {
  appearance: none;
  border: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.25rem 0;
  text-align: left;
}

.delete-folder-select.is-selected .delete-folder-name {
  font-weight: 800;
  text-decoration: underline;
}

.delete-folder-arrow {
  display: inline-block;
  width: 1.1rem;
  text-align: center;
}

@media (max-width: 900px) {
  .delete-folder-layout {
    grid-template-columns: 1fr;
  }
}

/* Admin page: hard spacer before Update Library Index */
.admin-before-update-spacer {
  display: block !important;
  height: 2.75rem !important;
  width: 100% !important;
  clear: both !important;
}
/* Delete Folder page: Go Back button */
.delete-folder-back-row {
  margin: 0 0 1.5rem;
}
