/* ===== Church Web App — global styles ===== */
:root{
  --serif: 'Playfair Display', Georgia, 'Times New Roman', serif;
  --sans: 'Mulish', system-ui, sans-serif;
  /* theme vars are injected at runtime by applyTheme() */
}
*{ box-sizing:border-box; }
html,body{ margin:0; height:100%; }
body{
  font-family: var(--sans);
  background:#1c1c1c;
  color: var(--body);
  -webkit-font-smoothing: antialiased;
}
#root{ height:100%; }

button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
input, textarea{ font-family:inherit; }

/* ---- App shell ---- */
.app{
  position:fixed; inset:0;
  display:flex; flex-direction:column;
  background: var(--page);
  color: var(--body);
  overflow:hidden;
}

/* ---- Header ---- */
.hdr{
  position:relative; flex:0 0 auto;
  height:64px;
  background: var(--page);
  border-bottom:1px solid var(--border);
  display:flex; align-items:flex-end;
}
.tabs{ display:flex; align-items:flex-end; height:100%; padding-left:8px; gap:0; }
.tab{
  position:relative;
  height:42px; min-width:108px;
  margin-right:-14px;
  padding:0 30px 0 26px;
  display:flex; align-items:center; justify-content:center;
  transform: skewX(-20deg);
  background: var(--bar);
  color: var(--bar-text);
  border:1px solid var(--border);
  border-bottom:none;
  border-radius:8px 8px 0 0;
  font-size:19px; letter-spacing:.2px;
  opacity:.62;
  transition: background .15s, opacity .15s;
}
.tab > span{ transform: skewX(20deg); }
.tab:hover{ opacity:.85; }
.tab.active{
  opacity:1; z-index:5;
  background: var(--accent);
  color: var(--accent-text);
  font-weight:700;
}
.hdr-title{
  position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  font-family: var(--serif); font-weight:800;
  font-size:25px; color: var(--ink);
  white-space:nowrap; pointer-events:none;
  max-width:54%; overflow:hidden; text-overflow:ellipsis;
}
.hdr-right{
  margin-left:auto; display:flex; align-items:center; gap:14px;
  padding:0 20px 8px 0; height:100%;
}
.role-toggle{ display:flex; background:var(--bar); border:1px solid var(--border); border-radius:999px; overflow:hidden; }
.role-toggle button{ padding:5px 13px; font-size:12.5px; font-weight:700; color:var(--muted); letter-spacing:.4px; }
.role-toggle button.on{ background:var(--accent); color:var(--accent-text); }
.icon-btn{
  width:34px; height:34px; border-radius:999px;
  display:grid; place-items:center; color:var(--ink);
  border:1.6px solid var(--ink);
}
.icon-btn.plain{ border:none; font-size:22px; line-height:1; }
.menu-pop{
  position:absolute; right:16px; top:60px; z-index:60;
  background:var(--surface); color:var(--surface-text);
  border:1px solid var(--border); border-radius:12px;
  box-shadow:var(--shadow); min-width:210px; padding:6px; overflow:hidden;
}
.menu-pop button{ display:flex; align-items:center; gap:10px; width:100%; text-align:left; padding:11px 14px; border-radius:8px; font-size:14.5px; color:var(--surface-text); }
.menu-pop button:hover{ background:color-mix(in srgb, var(--accent) 16%, transparent); }
.menu-pop .div{ height:1px; background:var(--border); margin:5px 4px; }
.menu-org{ padding:10px 14px 6px; font-size:11px; letter-spacing:1.2px; text-transform:uppercase; color:var(--muted); }

/* ---- main body ---- */
.body{ flex:1 1 auto; min-height:0; position:relative; overflow:hidden; }
.pane{ position:absolute; inset:0; padding:18px; }

/* generic pill button */
.pill{
  background:var(--pill); color:var(--pill-text);
  border-radius:999px; padding:9px 20px; font-size:14.5px; font-weight:600;
  white-space:nowrap; transition:filter .15s;
}
.pill:hover{ filter:brightness(1.08); }
.pill.ghost{ background:transparent; color:var(--ink); border:1.5px solid var(--border); }
.pill.sm{ padding:6px 14px; font-size:13px; }

.field{
  background:var(--field); color:var(--field-text);
  border:1px solid var(--border); border-radius:8px;
  padding:9px 12px; font-size:14.5px; width:100%; outline:none;
}
.field:focus{ border-color:var(--accent); }

/* ---- SLIDES ---- */
.slides-wrap{ position:absolute; inset:0; display:flex; flex-direction:column; padding:18px; gap:14px; }
.slide-stage{
  flex:1 1 auto; min-height:0; position:relative;
  background:#000; border-radius:12px; overflow:hidden;
  display:grid; place-items:center; box-shadow:var(--shadow);
}
.slide-canvas{ position:absolute; inset:0; display:grid; place-items:center; text-align:center; padding:7% 9%; }
.slide-img{ position:absolute; inset:0; width:100%; height:100%; object-fit:contain; background:#000; }
.slide-num{ position:absolute; top:14px; right:18px; color:rgba(255,255,255,.7); font-size:13px; letter-spacing:1px; }
.slide-ctl{ flex:0 0 auto; display:flex; align-items:center; justify-content:center; gap:10px; }
.sc-btn{ width:44px; height:44px; border-radius:10px; background:var(--bar); color:var(--ink); display:grid; place-items:center; border:1px solid var(--border); font-size:16px; }
.sc-btn:hover{ background:var(--accent); color:var(--accent-text); }
.sc-btn.play{ width:56px; background:var(--accent); color:var(--accent-text); }
.sc-count{ min-width:78px; text-align:center; font-size:14px; color:var(--muted); font-weight:700; }

/* ---- BIBLE ---- */
.bible-scroll{ position:absolute; inset:0; overflow:auto; padding:34px 46px 60px; }
.bible-h{ font-family:var(--serif); font-weight:800; font-size:calc(26px * var(--bfs,1)); color:var(--ink); margin:0 0 14px; }
.bible-v{ font-size:calc(19px * var(--bfs,1)); line-height:1.85; color:var(--body); text-wrap:pretty; }
.bible-v .vn{ font-weight:800; color:var(--ink); margin-right:5px; }
.bible-tools{ position:absolute; top:16px; right:18px; z-index:8; display:flex; align-items:center; gap:6px; }
.fontbtn{ height:34px; min-width:42px; padding:0 12px; border-radius:8px; background:var(--bar); color:var(--ink); border:1px solid var(--border); font-weight:700; font-size:15px; display:inline-flex; align-items:center; justify-content:center; line-height:1; white-space:nowrap; }
.fontbtn:hover{ background:var(--accent); color:var(--accent-text); }
.bible-open{ z-index:8; }
.search-panel{
  position:absolute; top:54px; right:18px; z-index:9; width:430px;
  background:var(--bar); border:1px solid var(--border); border-radius:14px;
  box-shadow:var(--shadow); padding:14px; color:var(--bar-text);
}
.sp-top{ display:flex; align-items:center; gap:10px; background:var(--field); border-radius:999px; padding:7px 8px 7px 14px; }
.sp-top .ref{ flex:1; font-size:17px; color:var(--field-text); font-weight:700; font-family:var(--serif); }
.sp-cols{ display:grid; grid-template-columns: 1fr 76px 76px; gap:8px; margin-top:12px; }
.sp-col{ height:150px; overflow:auto; border-radius:8px; scroll-snap-type:y mandatory; }
.sp-col::-webkit-scrollbar{ width:0; }
.sp-item{ scroll-snap-align:center; text-align:center; padding:8px 6px; font-size:16px; color:var(--muted); cursor:pointer; border-radius:6px; white-space:nowrap; }
.sp-item:hover{ color:var(--bar-text); }
.sp-item.sel{ background:var(--field); color:var(--field-text); font-weight:700; }
.sp-col.books .sp-item{ text-align:left; padding-left:14px; }
.sp-tests{ display:flex; gap:0; margin-top:12px; background:var(--field); border-radius:999px; overflow:hidden; width:max-content; }
.sp-tests button{ padding:7px 22px; font-size:14px; font-weight:700; color:var(--muted); }
.sp-tests button.on{ background:var(--accent); color:var(--accent-text); }

/* ---- HYMNS ---- */
.hymns-wrap{ position:absolute; inset:0; display:grid; grid-template-columns: 1fr 360px; gap:16px; padding:18px; }
.hymn-stage{ background:#000; border-radius:12px; overflow:hidden; position:relative; box-shadow:var(--shadow); display:grid; place-items:center; }
.hymn-stage iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.hymn-empty{ color:rgba(255,255,255,.55); text-align:center; font-size:15px; padding:30px; }
.hymn-side{ background:var(--surface); border:1px solid var(--border); border-radius:12px; display:flex; flex-direction:column; overflow:hidden; }
.hymn-side h3{ font-family:var(--serif); font-weight:800; font-size:22px; color:var(--ink); margin:0; padding:16px 18px 10px; }
.yt-acct{ display:flex; align-items:center; gap:10px; margin:0 14px 8px; padding:10px 12px; background:var(--field); border:1px solid var(--border); border-radius:10px; }
.yt-dot{ flex:0 0 auto; width:9px; height:9px; border-radius:999px; background:var(--muted); }
.yt-dot[data-on="true"]{ background:#2e9d5b; box-shadow:0 0 0 3px color-mix(in srgb,#2e9d5b 28%, transparent); }
.yt-info{ flex:1; font-size:12.5px; line-height:1.35; color:var(--surface-text); }
.yt-info b{ color:var(--ink); }
.yt-info span{ color:var(--muted); }
.hymn-list{ overflow:auto; padding:4px 8px 12px; }
.hymn-row{ display:flex; align-items:center; gap:10px; padding:9px 12px; border-radius:8px; cursor:pointer; color:var(--surface-text); }
.hymn-row:hover{ background:color-mix(in srgb, var(--accent) 14%, transparent); }
.hymn-row.playing{ background:var(--accent); color:var(--accent-text); }
.hymn-row .ix{ font-size:12px; opacity:.6; width:20px; text-align:right; }
.hymn-row .nm{ flex:1; font-size:15px; }
.hymn-row .pl{ font-size:13px; opacity:.7; }

/* ---- PRAYER ---- */
.prayer-wrap{ position:absolute; inset:0; display:flex; flex-direction:column; padding:24px 26px 14px; }
.prayer-cols{ flex:1 1 auto; min-height:0; display:grid; grid-template-columns:repeat(4,1fr); gap:30px; overflow-y:auto; overflow-x:hidden; }
.pcol{ display:flex; flex-direction:column; gap:6px; }
.pcol-title{ font-weight:800; font-size:20px; color:var(--ink); border:none; background:transparent; outline:none; padding:2px 0; }
.pcol-title:focus{ background:color-mix(in srgb, var(--accent) 12%, transparent); }
.pitem{ display:flex; gap:8px; align-items:flex-start; font-size:15px; line-height:1.45; color:var(--body); }
.pitem .mk{ flex:0 0 auto; color:var(--muted); min-width:18px; text-align:right; font-variant-numeric:tabular-nums; user-select:none; }
.pitem .tx{ flex:1; outline:none; padding:1px 2px; border-radius:4px; }
.pitem .tx:focus{ background:color-mix(in srgb, var(--accent) 12%, transparent); }
.pitem .del{ opacity:0; color:var(--muted); font-size:13px; padding:0 4px; }
.pitem:hover .del{ opacity:.7; }
.pcol-add{ display:flex; gap:8px; margin-top:6px; }
.pcol-add button{ font-size:12.5px; color:var(--muted); padding:3px 8px; border:1px dashed var(--border); border-radius:6px; }
.pcol-add button:hover{ color:var(--ink); border-color:var(--accent); }
.prayer-foot{ flex:0 0 auto; display:flex; align-items:center; justify-content:space-between; padding-top:12px; color:var(--muted); font-size:14px; }
.page-nav{ display:flex; align-items:center; gap:14px; }
.page-nav button{ display:flex; flex-direction:column; align-items:center; color:var(--muted); font-size:13px; }
.page-nav button:disabled{ opacity:.3; cursor:default; }
.page-nav .ar{ font-size:24px; color:var(--ink); }
.read-note{ font-size:12.5px; color:var(--muted); font-style:italic; }

/* ---- SETTINGS modal ---- */
.scrim{ position:fixed; inset:0; background:var(--scrim); z-index:80; display:grid; place-items:center; padding:24px; }
.settings{
  width:min(1240px,96vw); height:min(760px,94vh);
  background:var(--page); border-radius:14px; box-shadow:var(--shadow);
  display:grid; grid-template-columns:1fr 1fr; overflow:hidden; border:1px solid var(--border);
}
.set-col{ overflow-y:auto; overflow-x:hidden; padding:0 0 18px; }
.set-col.left{ border-right:1px solid var(--border); }
.set-head{ background:var(--bar); color:var(--bar-text); text-align:center; font-family:var(--serif); font-weight:800; font-size:24px; padding:12px; position:sticky; top:0; z-index:2; }
.set-body{ padding:18px 26px; }
.set-row{ display:flex; align-items:center; gap:12px; margin-bottom:12px; }
.set-row .lbl{ background:var(--pill); color:var(--pill-text); border-radius:999px; padding:8px 16px; font-size:13.5px; font-weight:600; white-space:nowrap; align-self:center; }
.set-row .lbl.wide{ min-width:150px; text-align:center; }
.invite{ background:var(--bar); color:var(--muted); border:1px solid var(--border); border-radius:999px; padding:8px 18px; font-size:13.5px; }
.theme-grid{ background:var(--field); border-radius:10px; padding:12px; display:flex; flex-wrap:wrap; gap:10px; flex:1; }
.theme-chip{ display:flex; gap:0; border-radius:8px; overflow:hidden; border:2px solid transparent; cursor:pointer; }
.theme-chip.sel{ border-color:var(--accent); box-shadow:0 0 0 2px var(--field), 0 0 0 4px var(--accent); }
.theme-chip i{ width:18px; height:34px; display:block; }
.theme-name{ font-size:12px; color:var(--muted); width:100%; margin-top:-4px; }
.slide-thumbs{ display:flex; flex-wrap:wrap; gap:8px; margin:4px 0 10px; }
.sthumb{ position:relative; width:104px; height:60px; border-radius:6px; overflow:hidden; border:1px solid var(--border); background:#000; }
.sthumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.sthumb-n{ position:absolute; left:4px; bottom:3px; font-size:10px; background:rgba(0,0,0,.6); color:#fff; padding:1px 5px; border-radius:999px; }
.sthumb-x{ position:absolute; top:2px; right:2px; width:18px; height:18px; border-radius:999px; background:rgba(0,0,0,.65); color:#fff; font-size:13px; line-height:1; display:grid; place-items:center; }
.sthumb-x:hover{ background:#c0392b; }
.hymn-edit{ overflow:auto; }
.he-grid{ display:grid; grid-template-columns:1fr 150px 28px; gap:8px 14px; padding:6px 26px 18px; align-items:center; }
.he-grid .th{ font-family:var(--serif); font-weight:800; font-size:22px; color:var(--ink); }
.he-grid .ht{ font-size:16px; color:var(--body); padding:5px 0; }
.he-del{ width:26px; height:26px; border-radius:999px; color:var(--muted); font-size:16px; line-height:1; display:grid; place-items:center; justify-self:center; }
.he-del:hover{ background:#c0392b; color:#fff; }
.set-foot{ grid-column:1 / -1; display:flex; gap:16px; justify-content:flex-start; padding:14px 26px; border-top:1px solid var(--border); background:var(--page); }
.set-foot .pill{ min-width:150px; text-align:center; }

/* scrollbars */
.set-col::-webkit-scrollbar, .hymn-list::-webkit-scrollbar, .bible-scroll::-webkit-scrollbar, .prayer-cols::-webkit-scrollbar, .hymn-edit::-webkit-scrollbar{ width:10px; }
::-webkit-scrollbar-thumb{ background:var(--muted); border-radius:8px; opacity:.5; }
::-webkit-scrollbar-track{ background:transparent; }

.loading{ color:var(--muted); font-size:15px; padding:20px 0; }

/* full-screen focus prompt */
.fs-prompt{
  position:fixed; left:50%; bottom:22px; transform:translateX(-50%); z-index:90;
  display:flex; align-items:center; gap:12px;
  background:var(--surface); color:var(--surface-text);
  border:1px solid var(--border); border-radius:999px;
  padding:9px 12px 9px 18px; box-shadow:var(--shadow); font-size:14px;
}
.fs-prompt .fs-x{ font-size:18px; color:var(--muted); width:26px; height:26px; border-radius:999px; }
.fs-prompt .fs-x:hover{ background:color-mix(in srgb, var(--accent) 16%, transparent); }

/* ---- Login ---- */
.login-wrap{ position:fixed; inset:0; background:var(--page); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:18px; padding:24px; }
.login-card{ width:min(420px,94vw); background:var(--surface); color:var(--surface-text); border:1px solid var(--border); border-radius:16px; box-shadow:var(--shadow); padding:34px 30px; display:flex; flex-direction:column; }
.login-mark{ width:58px; height:58px; border-radius:14px; background:var(--accent); color:var(--accent-text); display:grid; place-items:center; margin:0 auto 14px; }
.login-church{ font-family:var(--serif); font-weight:800; font-size:26px; line-height:1.18; color:var(--ink); text-align:center; margin:0 0 6px; }
.login-sub{ text-align:center; color:var(--muted); margin:0 0 18px; font-size:14.5px; }
.login-note{ background:color-mix(in srgb,var(--accent) 12%, transparent); border:1px solid var(--border); border-radius:10px; padding:11px 13px; font-size:13px; line-height:1.5; color:var(--surface-text); margin-bottom:16px; }
.login-note b{ color:var(--ink); }
.login-lbl{ font-size:12.5px; font-weight:700; color:var(--muted); margin:10px 0 5px; letter-spacing:.3px; }
.login-err{ color:#e0573e; font-size:13px; margin-top:12px; }
.login-btn{ margin-top:20px; text-align:center; justify-content:center; padding:12px; font-size:15px; }
.login-foot{ color:var(--muted); font-size:12.5px; }

/* ---- header user chip ---- */
.user-chip{ display:flex; flex-direction:column; align-items:flex-end; line-height:1.15; max-width:230px; }
.uc-role{ font-size:11px; font-weight:800; letter-spacing:.6px; text-transform:uppercase; color:var(--muted); white-space:nowrap; }
.uc-role[data-admin="true"]{ color:var(--accent); }
.uc-em{ font-size:12px; color:var(--ink); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:230px; }

/* ---- Users manager ---- */
.users-mgr{ display:flex; flex-direction:column; gap:12px; }
.users-list{ display:flex; flex-direction:column; gap:6px; }
.user-row{ display:flex; align-items:center; gap:10px; background:var(--field); border:1px solid var(--border); border-radius:9px; padding:8px 10px; }
.user-id{ flex:1; min-width:0; }
.user-em{ font-size:13.5px; color:var(--field-text); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.user-nm{ font-size:11.5px; color:var(--muted); }
.user-role{ background:var(--bar); color:var(--bar-text); border:1px solid var(--border); border-radius:7px; padding:5px 8px; font-size:13px; }
.user-badge{ font-size:11px; font-weight:800; letter-spacing:.4px; color:var(--accent); text-transform:uppercase; }
.user-x{ width:24px; height:24px; border-radius:999px; color:var(--muted); font-size:15px; display:grid; place-items:center; }
.user-x:hover{ background:#c0392b; color:#fff; }
.user-mail{ width:24px; height:24px; border-radius:999px; color:var(--muted); font-size:14px; display:grid; place-items:center; }
.user-mail:hover{ background:var(--accent); color:var(--accent-text); }
.user-x.lock{ color:var(--accent); font-size:9px; cursor:default; }
.user-add{ background:var(--field); border:1px solid var(--border); border-radius:10px; padding:12px; display:flex; flex-direction:column; gap:8px; }
.ua-title{ font-weight:800; color:var(--ink); font-size:14px; }
.ua-row{ display:flex; gap:8px; }
.ua-row .field{ flex:1; }
.ua-roles{ display:flex; background:var(--bar); border:1px solid var(--border); border-radius:999px; overflow:hidden; }
.ua-roles button{ padding:7px 16px; font-size:13px; font-weight:700; color:var(--muted); }
.ua-roles button.on{ background:var(--accent); color:var(--accent-text); }
.ua-msg{ font-size:12.5px; color:var(--ink); }
.ua-hint{ font-size:11.5px; color:var(--muted); line-height:1.45; }

/* =====================================================================
   RESPONSIVE — tablet / iPad / phone
   ===================================================================== */

/* Tablet & iPad (portrait ~768–1024) */
@media (max-width: 1024px){
  .prayer-cols{ grid-template-columns:repeat(2,1fr); column-gap:24px; }
  .hymns-wrap{ grid-template-columns:1fr 300px; }
  .bible-scroll{ padding:28px 30px 60px; }
}

/* Stack hymns video over list on smaller tablets/phones */
@media (max-width: 900px){
  .hymns-wrap{ grid-template-columns:1fr; grid-template-rows:minmax(200px,38vh) 1fr; }
  .settings{ grid-template-columns:1fr; width:100vw; height:100vh; max-width:100vw; max-height:100vh; border-radius:0; }
  .set-col.left{ border-right:none; border-bottom:1px solid var(--border); }
  .set-foot{ position:sticky; bottom:0; }
}

/* Phone / small tablet */
@media (max-width: 760px){
  .hdr{ height:auto; min-height:0; align-items:center; flex-wrap:wrap; padding:6px 8px 0; }
  .hdr-title{ position:static; transform:none; left:auto; top:auto; order:1; flex:1 1 auto;
    text-align:left; font-size:18px; max-width:none; padding-left:4px; }
  .hdr-right{ order:2; margin-left:auto; padding:0; gap:8px; height:auto; }
  .user-chip{ display:none; }
  .tabs{ order:3; width:100%; display:flex; overflow-x:auto; overflow-y:hidden; padding:6px 0 0; -webkit-overflow-scrolling:touch; scrollbar-width:none; }
  .tabs::-webkit-scrollbar{ display:none; }
  .tab{ height:38px; min-width:0; padding:0 20px 0 18px; font-size:15px; margin-right:-10px; flex:0 0 auto; }

  .pane{ padding:12px; }
  .bible-scroll{ padding:58px 16px 50px; }
  .bible-tools{ top:10px; right:10px; }
  .search-panel{ width:auto; left:10px; right:10px; top:50px; }
  .sp-cols{ grid-template-columns:1fr 64px 64px; }

  .slides-wrap{ padding:12px; gap:10px; }
  .sc-btn{ width:40px; height:40px; }
  .sc-btn.play{ width:50px; }
  .sc-count{ min-width:62px; font-size:13px; }

  .prayer-wrap{ padding:14px 14px 10px; }
  .prayer-cols{ grid-template-columns:1fr; row-gap:22px; }
  .prayer-foot{ flex-direction:column; gap:10px; align-items:flex-start; }

  .hymn-side h3{ font-size:20px; }
  .he-grid{ grid-template-columns:1fr 110px 26px; padding:6px 14px 18px; }
  .set-body{ padding:14px 16px; }
  .set-row{ flex-wrap:wrap; }
  .set-row .lbl, .set-row .lbl.wide{ min-width:0; }
  .ua-row{ flex-direction:column; }

  .menu-pop{ right:8px; }
  .fs-prompt{ left:8px; right:8px; transform:none; justify-content:center; font-size:13px; padding:8px 10px; }
  .fs-prompt span{ flex:1; }
}

/* Very small phones */
@media (max-width: 400px){
  .tab{ padding:0 14px 0 12px; font-size:14px; }
  .hdr-title{ font-size:16px; }
}

/* Coarse-pointer (touch) tweaks — larger hit targets */
@media (hover: none){
  .hymn-row{ padding:12px; }
  .sp-item{ padding:11px 6px; }
  .pitem .del{ opacity:.6; }
}
