/* Vāgdhenu — Sanskrit chant library. Shared theme + home + detail styles.
   Mobile-first, accessible: 44px targets, visible focus, reduced-motion, outdoor contrast. */
:root{
  --bg:#1a1208; --bg2:#241809; --card:#2b1d0d; --ink:#f6e7c9; --muted:#caa86a;
  --accent:#f0a23c; --accent2:#ffd27a; --line:#4a3414; --wave:#a8762a; --wave2:#ffce7d;
  --ok:#7dd48a; --tap:44px; --radius:16px;
}
*{box-sizing:border-box}
[hidden]{display:none!important}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:"Segoe UI",Roboto,system-ui,sans-serif;color:var(--ink);
  background:radial-gradient(1200px 600px at 50% -10%,#3a2710,var(--bg)) fixed;
  line-height:1.5;}
a{color:var(--accent2);text-decoration:none}
.wrap{max-width:1080px;margin:0 auto;padding:18px 16px 96px;}
.skip{position:absolute;left:-999px;top:0;background:var(--accent);color:#231400;padding:10px 14px;
  border-radius:0 0 10px 0;z-index:100}
.skip:focus{left:0}

/* ---- Focus & motion ---- */
:focus-visible{outline:3px solid var(--accent2);outline-offset:2px;border-radius:8px}
@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}

/* ---- Header / brand ---- */
.site-head{display:flex;flex-direction:column;gap:14px;padding:10px 0 4px}
.brand{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.brand h1{font-size:1.7rem;margin:0;color:var(--accent2);letter-spacing:.4px;
  text-shadow:0 2px 18px rgba(240,162,60,.35)}
.brand .tagline{color:var(--muted);font-size:.95rem}

/* ---- Search ---- */
.search{position:relative}
.search input{width:100%;min-height:var(--tap);font:inherit;font-size:1.05rem;color:var(--ink);
  background:#1d1407;border:1px solid var(--line);border-radius:12px;padding:10px 42px 10px 40px;}
.search input:focus{outline:none;border-color:var(--accent)}
.search .icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);opacity:.7;pointer-events:none}
.search .clear{position:absolute;right:6px;top:50%;transform:translateY(-50%);min-width:36px;min-height:36px}

/* ---- Controls bar ---- */
.controls{display:flex;gap:10px;align-items:center;flex-wrap:wrap;
  position:sticky;top:0;z-index:6;padding:12px 0;margin:6px 0 8px;
  background:linear-gradient(180deg,rgba(20,13,4,.94),rgba(20,13,4,.78));backdrop-filter:blur(8px)}
button,select{font:inherit;cursor:pointer;color:var(--ink);border:1px solid var(--line);border-radius:10px;
  background:linear-gradient(180deg,#3a2811,#241809);padding:0 14px;min-height:var(--tap);transition:.15s}
button:hover,select:hover{border-color:var(--accent);color:var(--accent2)}
button:disabled{opacity:.5;cursor:default}
.primary{background:linear-gradient(180deg,var(--accent),#cf801f);color:#231400;border:none;font-weight:600}
.primary:hover{filter:brightness(1.08);color:#231400}
.controls .grow{flex:1}
.count{color:var(--muted);font-size:.9rem}
.filter-btn .n{display:inline-grid;place-items:center;min-width:22px;height:22px;margin-left:6px;
  border-radius:999px;background:var(--accent);color:#231400;font-size:.78rem;font-weight:700;padding:0 6px}

/* ---- Grid + cards ---- */
.grid{display:grid;gap:16px;grid-template-columns:1fr}
@media (min-width:560px){.grid{grid-template-columns:1fr 1fr}}
@media (min-width:900px){.grid{grid-template-columns:1fr 1fr 1fr}}
.card{display:flex;flex-direction:column;background:linear-gradient(180deg,var(--card),var(--bg2));
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:0 8px 30px rgba(0,0,0,.35);transition:border-color .2s,box-shadow .2s,transform .2s;
  color:var(--ink);min-height:100%}
a.card:hover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 12px 40px rgba(240,162,60,.22);
  transform:translateY(-2px)}
.card .thumb{aspect-ratio:16/9;background:#170f05 center/cover no-repeat;position:relative;line-height:0}
.card .thumb img{width:100%;height:100%;object-fit:cover;display:block}
.card .thumb .ph{width:100%;height:100%;display:grid;place-items:center;font-size:2.4rem;
  background:radial-gradient(circle at 35% 30%,#3a2811,#1d1407);color:var(--accent)}
.card .body{padding:12px 14px 14px;display:flex;flex-direction:column;gap:8px;flex:1}
.card .title{font-size:1.06rem;font-weight:600;margin:0;color:var(--accent2)}
.card .sk{font-family:"Noto Serif Devanagari","Tiro Devanagari Sanskrit",serif;font-size:1.15rem;
  color:var(--ink);margin:0;line-height:1.4;overflow-wrap:anywhere}
.tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}
.tag{font-size:.75rem;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:3px 9px;white-space:nowrap}
.tag.deity{color:var(--accent2);border-color:#6b4a18}
.tag.dur{margin-left:auto}
.badge-soon{position:absolute;top:8px;left:8px;background:rgba(20,13,4,.85);color:var(--muted);
  border:1px solid var(--line);border-radius:999px;padding:3px 10px;font-size:.72rem}
.card.soon{opacity:.72;cursor:default}

/* ---- Empty state ---- */
.empty{text-align:center;color:var(--muted);padding:56px 16px;border:1px dashed var(--line);
  border-radius:var(--radius);margin-top:10px}
.empty h2{color:var(--ink);margin:.2em 0}

/* ---- Filter panel (bottom sheet on mobile) ---- */
.sheet[hidden]{display:none}
.sheet{position:fixed;inset:0;z-index:20;display:flex;align-items:flex-end;justify-content:center}
.sheet .scrim{position:absolute;inset:0;background:rgba(0,0,0,.55)}
.sheet .panel{position:relative;width:100%;max-width:640px;max-height:88vh;overflow:auto;
  background:linear-gradient(180deg,var(--card),var(--bg2));border:1px solid var(--line);
  border-radius:18px 18px 0 0;padding:18px 18px 24px}
@media (min-width:680px){.sheet{align-items:center}.sheet .panel{border-radius:18px}}
.sheet h2{margin:.1em 0 .5em;font-size:1.2rem;color:var(--accent2)}
.sheet .grp{margin:14px 0}
.sheet .grp h3{font-size:.9rem;color:var(--muted);margin:0 0 8px;text-transform:uppercase;letter-spacing:.5px}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{min-height:var(--tap);display:inline-flex;align-items:center;padding:0 14px;border-radius:999px;
  border:1px solid var(--line);background:#1d1407;color:var(--ink);cursor:pointer;font-size:.9rem}
.chip[aria-pressed="true"]{background:linear-gradient(180deg,var(--accent),#cf801f);color:#231400;
  border-color:transparent;font-weight:600}
.sheet .foot{display:flex;gap:10px;position:sticky;bottom:-24px;padding-top:14px;margin-top:8px;
  background:linear-gradient(0deg,var(--card),rgba(43,29,13,.6))}
.sheet .foot .primary{flex:1}
.switch{display:flex;align-items:center;gap:10px;min-height:var(--tap);cursor:pointer}
.switch input{width:20px;height:20px;accent-color:var(--accent)}

footer{text-align:center;color:var(--muted);font-size:.8rem;margin-top:40px;opacity:.85}
.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}

/* ============================ Chant detail page ============================ */
:root{--verse-scale:1}
.detail-head{margin:6px 0 4px}
.back{display:inline-flex;align-items:center;gap:6px;min-height:var(--tap);color:var(--muted)}
.back:hover{color:var(--accent2)}
.detail-banner{display:block;width:100%;margin:8px 0 14px;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);box-shadow:0 10px 40px rgba(0,0,0,.45);line-height:0}
.detail-banner img{width:100%;height:auto;display:block}
.detail-banner .ph{aspect-ratio:16/9;display:grid;place-items:center;font-size:3.4rem;
  background:radial-gradient(circle at 40% 30%,#3a2811,#1d1407);color:var(--accent)}
.detail-title{margin:.1em 0 .1em;color:var(--accent2);font-size:1.7rem}
.detail-sk{font-family:"Noto Serif Devanagari","Tiro Devanagari Sanskrit",serif;font-size:1.5rem;
  margin:.1em 0 .5em;color:var(--ink);overflow-wrap:anywhere}
.detail-tags{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 4px;align-items:center}
.actions{display:flex;gap:10px;margin:12px 0 4px;flex-wrap:wrap}
.actions button{display:inline-flex;align-items:center;gap:8px}
.actions .ico{font-size:1.1rem}
#favBtn[aria-pressed="true"]{border-color:var(--accent);color:var(--accent2)}

.source{margin:14px 0;padding:12px 14px;border:1px solid var(--line);border-radius:12px;
  background:#1d1407;color:var(--muted);font-size:.86rem}
.source h2{font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;margin:0 0 6px;color:var(--muted)}
.source a{color:var(--accent);border-bottom:1px dotted var(--accent);overflow-wrap:anywhere}
.source .meta{margin-top:6px;opacity:.9}

/* transport bar */
.transport{position:sticky;top:0;z-index:8;display:flex;gap:8px;align-items:center;flex-wrap:wrap;
  padding:12px;margin:12px 0 16px;border:1px solid var(--line);border-radius:14px;
  background:rgba(20,13,4,.9);backdrop-filter:blur(8px)}
.transport .grp{display:flex;gap:6px;align-items:center}
.transport .sep{flex:1}
.transport .status{color:var(--muted);font-size:.85rem;min-width:120px;text-align:right}
.iconbtn{min-width:var(--tap);min-height:var(--tap);display:inline-grid;place-items:center;padding:0 10px}
.repeat[aria-pressed="true"]{background:linear-gradient(180deg,var(--accent),#cf801f);color:#231400;border:none}
.speed{display:inline-flex;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.speed button{border:none;border-radius:0;min-width:52px;background:#1d1407}
.speed button[aria-pressed="true"]{background:linear-gradient(180deg,var(--accent),#cf801f);color:#231400;font-weight:600}

/* text controls */
.textctl{display:flex;gap:8px;align-items:center;color:var(--muted);font-size:.85rem;margin:2px 0 10px;flex-wrap:wrap}
.textctl .switch{margin-left:auto}

/* verses */
.verse{background:linear-gradient(180deg,var(--card),var(--bg2));border:1px solid var(--line);
  border-radius:var(--radius);padding:14px 16px;margin:14px 0;box-shadow:0 8px 30px rgba(0,0,0,.32)}
.verse.playing{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 10px 40px rgba(240,162,60,.22)}
.vhead{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.badge{width:34px;height:34px;flex:0 0 auto;display:grid;place-items:center;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,var(--accent2),#b9731c);color:#2a1800;font-weight:700}
.vhead .spacer{flex:1}
.sk-verse{font-family:"Noto Serif Devanagari","Tiro Devanagari Sanskrit",serif;white-space:pre-wrap;
  font-size:calc(1.2rem * var(--verse-scale));line-height:1.9;margin:.2em 0 .4em;color:var(--ink);
  overflow-wrap:anywhere}
.player{display:flex;align-items:center;gap:12px;margin-top:8px}
.play{width:46px;height:46px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;font-size:1.05rem;
  background:linear-gradient(180deg,var(--accent),#cf801f);color:#231400;border:none}
.wave{flex:1;min-width:0;height:60px;cursor:pointer}
.vtime{font-variant-numeric:tabular-nums;color:var(--muted);font-size:.85rem;min-width:46px;text-align:right}
.vstatus{color:var(--muted);font-size:.8rem;margin:6px 0 0;min-height:1em}

/* toast */
.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(20px);opacity:0;
  background:#2b1d0d;color:var(--ink);border:1px solid var(--accent);border-radius:10px;padding:10px 16px;
  box-shadow:0 10px 30px rgba(0,0,0,.5);pointer-events:none;transition:.2s;z-index:30;max-width:90vw}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---- Home: view tabs + card favorite ---- */
.views{display:inline-flex;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.views .view{border:none;border-radius:0;min-height:var(--tap);background:#1d1407;color:var(--ink);
  padding:0 14px;white-space:nowrap}
.views .view[aria-selected="true"]{background:linear-gradient(180deg,var(--accent),#cf801f);
  color:#231400;font-weight:600}
.cardfav{position:absolute;top:8px;right:8px;min-width:40px;min-height:40px;border-radius:50%;
  display:grid;place-items:center;font-size:1.15rem;line-height:1;
  background:rgba(20,13,4,.7);border:1px solid var(--line);color:var(--accent2);backdrop-filter:blur(4px)}
.cardfav:hover{border-color:var(--accent);color:var(--accent2)}
.cardfav[aria-pressed="true"]{color:#ffd27a}
@media (max-width:559px){
  .views{order:-1;width:100%}
  .views .view{flex:1;padding:0 6px;font-size:.9rem}
}

.audio-note{margin:10px 0;padding:10px 14px;border:1px dashed var(--line);border-radius:12px;
  color:var(--muted);font-size:.9rem;background:#1d1407}
