/* ---- Still — calm meditation library ---- */
:root{
  --bg:#f4efe6; --surface:#fbf9f3; --card:#ffffff;
  --ink:#2f2b24; --muted:#8b8273; --line:#e6ded0;
  --sage:#6f7f5c; --sage-d:#56644a; --sage-soft:#e8ecdf;
  --clay:#c47b5a; --clay-d:#a8623f; --clay-soft:#f4e2d7;
  --shadow:0 1px 3px rgba(60,50,35,.07), 0 8px 24px rgba(60,50,35,.06);
  --radius:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
[hidden]{display:none!important}
html{-webkit-text-size-adjust:100%}
body{
  background:var(--bg); color:var(--ink);
  font:16px/1.6 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  padding-bottom:130px;
}
h1,h2,h3,h4{font-family:Georgia,"Times New Roman",serif;font-weight:600;line-height:1.25}
a{color:var(--sage-d)}
.wrap{max-width:920px;margin:0 auto;padding:0 18px}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select{font-family:inherit;font-size:1rem}

/* ---- header ---- */
header.site{background:var(--surface);border-bottom:1px solid var(--line)}
.head-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px}
.brand{display:flex;align-items:center;gap:14px}
.mark{width:34px;height:34px;border-radius:50%;border:3px solid var(--sage);
  position:relative;flex:none}
.mark::after{content:"";position:absolute;inset:0;margin:auto;width:11px;height:11px;
  border-radius:50%;background:var(--clay)}
h1{font-size:1.5rem;letter-spacing:.5px}
.tag{color:var(--muted);font-size:.83rem;margin-top:1px}
.head-actions{display:flex;gap:8px;flex:none}
.ghost-btn{border:1px solid var(--line);background:var(--card);padding:8px 13px;
  border-radius:999px;font-size:.82rem;color:var(--sage-d);white-space:nowrap}
.ghost-btn:hover{border-color:var(--sage);background:var(--sage-soft)}

/* ---- arrive panel ---- */
.arrive{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:22px;margin:24px 0 18px;box-shadow:var(--shadow)}
.arrive h2{font-size:1.28rem;margin-bottom:14px}
.feelings{display:flex;flex-wrap:wrap;gap:8px}
.feel{border:1px solid var(--line);background:var(--card);padding:8px 14px;
  border-radius:999px;font-size:.9rem;transition:.12s}
.feel:hover{border-color:var(--clay)}
.feel.on{background:var(--clay);color:#fff;border-color:var(--clay)}
.time-row{display:flex;align-items:center;gap:12px;margin-top:16px;flex-wrap:wrap}
.time-label{color:var(--muted);font-size:.9rem}
.time-opts{display:flex;gap:6px;flex-wrap:wrap}
.time{border:1px solid var(--line);background:var(--card);padding:6px 12px;
  border-radius:999px;font-size:.85rem}
.time.on{background:var(--sage);color:#fff;border-color:var(--sage)}
.pick-action{display:flex;align-items:center;gap:14px;margin-top:18px}
.primary-btn{background:var(--sage);color:#fff;padding:11px 22px;border-radius:999px;
  font-size:.95rem;font-weight:600}
.primary-btn:hover{background:var(--sage-d)}
.primary-btn:disabled{opacity:.45;cursor:default}
.text-btn{color:var(--muted);font-size:.85rem;text-decoration:underline;text-underline-offset:3px}
.text-btn:hover{color:var(--clay-d)}

/* ---- recommendation ---- */
.reco{background:var(--clay-soft);border:1px solid #e7c9b6;border-radius:var(--radius);
  padding:20px;margin-bottom:20px}
.reco .lead{font-size:.82rem;text-transform:uppercase;letter-spacing:1.4px;
  color:var(--clay-d);font-weight:700;margin-bottom:8px}
.reco h3{font-size:1.3rem;margin-bottom:6px}
.reco .why{color:#6b5847;font-size:.9rem;margin-bottom:14px}
.reco .alts{margin-top:16px;border-top:1px solid #e7c9b6;padding-top:12px}
.reco .alts h4{font-size:.78rem;text-transform:uppercase;letter-spacing:1px;
  color:var(--clay-d);margin-bottom:8px}
.reco .alt{display:flex;justify-content:space-between;gap:10px;padding:7px 0;
  font-size:.9rem;cursor:pointer;border-bottom:1px dashed #e7c9b6}
.reco .alt:last-child{border:0}
.reco .alt:hover{color:var(--clay-d)}
.reco .alt .d{color:var(--muted);flex:none}

/* ---- controls ---- */
.controls{margin-bottom:8px}
#search{width:100%;padding:13px 16px;border:1px solid var(--line);border-radius:999px;
  background:var(--card);box-shadow:var(--shadow)}
#search:focus{outline:none;border-color:var(--sage)}
.views{display:flex;gap:4px;margin:14px 0 10px;flex-wrap:wrap}
.view-tab{padding:7px 14px;border-radius:999px;font-size:.86rem;color:var(--muted)}
.view-tab.on{background:var(--ink);color:var(--bg)}
.view-tab .count{font-size:.72rem;opacity:.7;margin-left:5px}
.view-tab .count:empty{display:none}

.filters{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}
.filters summary{list-style:none;cursor:pointer;padding:11px 16px;display:flex;
  justify-content:space-between;font-size:.9rem;font-weight:600}
.filters summary::-webkit-details-marker{display:none}
.filters[open] .chev{transform:rotate(180deg)}
.chev{transition:.15s;color:var(--muted)}
.filter-body{padding:4px 16px 16px;border-top:1px solid var(--line)}
.fgroup{margin-top:14px}
.fgroup h4{font-size:.74rem;text-transform:uppercase;letter-spacing:1.2px;
  color:var(--muted);margin-bottom:8px}
.chips{display:flex;flex-wrap:wrap;gap:6px}
.chip{border:1px solid var(--line);background:var(--card);padding:5px 11px;
  border-radius:999px;font-size:.82rem;color:var(--ink)}
.chip:hover{border-color:var(--sage)}
.chip.on{background:var(--sage);color:#fff;border-color:var(--sage)}
.chip .n{opacity:.6;font-size:.74rem;margin-left:4px}
.sort-group select{padding:7px 10px;border:1px solid var(--line);border-radius:8px;
  background:var(--card)}
#clearFilters{margin-top:16px;display:inline-block}

.result-meta{color:var(--muted);font-size:.85rem;margin:16px 0 10px}

/* ---- cards ---- */
.grid{display:grid;gap:13px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px 16px 14px;box-shadow:var(--shadow);transition:.12s}
.card.playing{border-color:var(--clay);box-shadow:0 0 0 2px var(--clay-soft),var(--shadow)}
.card-top{display:flex;justify-content:space-between;gap:12px}
.card h3{font-size:1.08rem;margin-bottom:5px}
.card-meta{color:var(--muted);font-size:.8rem;display:flex;gap:9px;flex-wrap:wrap;align-items:center}
.dur-badge{background:var(--sage-soft);color:var(--sage-d);font-weight:600;
  padding:2px 9px;border-radius:999px;font-size:.78rem;white-space:nowrap}
.type-talk{background:#ece6f0;color:#6a5a7a}
.fav-btn{font-size:1.3rem;line-height:1;flex:none;color:var(--line);
  transition:.12s;align-self:flex-start}
.fav-btn:hover{color:var(--clay)}
.fav-btn.on{color:var(--clay)}
.card .desc{font-size:.9rem;color:#5a5448;margin:9px 0;max-height:4.8em;overflow:hidden;
  position:relative}
.card .desc.open{max-height:none}
.card .desc-toggle{font-size:.8rem;color:var(--sage-d);text-decoration:underline;
  text-underline-offset:2px}
.card-tags{display:flex;flex-wrap:wrap;gap:5px;margin:8px 0 11px}
.tg{font-size:.72rem;padding:2px 8px;border-radius:999px;background:var(--bg);
  color:var(--muted);border:1px solid var(--line)}
.tg.tech{background:var(--sage-soft);color:var(--sage-d);border-color:transparent}
.card-foot{display:flex;align-items:center;gap:10px}
.play-btn{background:var(--clay);color:#fff;padding:8px 18px;border-radius:999px;
  font-size:.86rem;font-weight:600;display:flex;align-items:center;gap:6px}
.play-btn:hover{background:var(--clay-d)}
.play-btn.is-playing{background:var(--sage)}
.resume-tag{font-size:.78rem;color:var(--clay-d)}
.ext-link{font-size:.8rem;color:var(--muted);margin-left:auto}
.progress-line{height:3px;background:var(--line);border-radius:2px;margin-top:10px;overflow:hidden}
.progress-line i{display:block;height:100%;background:var(--clay)}

.empty{text-align:center;padding:40px 0;color:var(--muted)}
.more-btn{display:block;margin:18px auto;border:1px solid var(--line);background:var(--card);
  padding:10px 26px;border-radius:999px;font-size:.88rem;color:var(--sage-d)}
.more-btn:hover{border-color:var(--sage)}

/* ---- footer ---- */
.site-foot{color:var(--muted);font-size:.8rem;padding-top:30px;padding-bottom:20px}
.site-foot p{margin-bottom:6px}
.built{opacity:.7}

/* ---- sticky player ---- */
.player{position:fixed;left:0;right:0;bottom:0;background:var(--surface);
  border-top:1px solid var(--line);box-shadow:0 -4px 20px rgba(60,50,35,.1);z-index:40;
  padding-bottom:env(safe-area-inset-bottom)}
.player-inner{display:flex;align-items:center;gap:14px;padding:10px 18px;flex-wrap:wrap}
.p-main{display:flex;align-items:center;gap:11px;min-width:200px;flex:1}
.p-play{width:42px;height:42px;border-radius:50%;background:var(--clay);color:#fff;
  font-size:1rem;flex:none}
.p-play:hover{background:var(--clay-d)}
.p-meta{min-width:0}
.p-title{font-size:.9rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.p-sub{font-size:.76rem;color:var(--muted)}
.p-scrub{display:flex;align-items:center;gap:9px;flex:2;min-width:220px}
.p-time{font-size:.74rem;color:var(--muted);font-variant-numeric:tabular-nums;flex:none}
#pSeek{flex:1;accent-color:var(--clay);height:4px}
.p-ctrls{display:flex;align-items:center;gap:4px}
.p-ctrls button{padding:6px 9px;border-radius:8px;font-size:.8rem;color:var(--muted)}
.p-ctrls button:hover{background:var(--bg);color:var(--ink)}
.p-ctrls .sleep.on{color:var(--clay);font-weight:700}
.sleep-menu{display:flex;gap:6px;align-items:center;padding:8px 18px;
  border-top:1px solid var(--line);font-size:.82rem;flex-wrap:wrap}
.sleep-menu span{color:var(--muted)}
.sleep-menu button{border:1px solid var(--line);padding:5px 11px;border-radius:999px;
  background:var(--card);font-size:.8rem}
.sleep-menu button:hover{border-color:var(--clay)}
.sleep-menu .off{color:var(--clay-d)}

/* ---- modal ---- */
.modal-host{position:fixed;inset:0;background:rgba(47,43,36,.5);z-index:60;
  display:flex;align-items:center;justify-content:center;padding:18px}
.modal{background:var(--surface);border-radius:var(--radius);max-width:560px;width:100%;
  max-height:88vh;overflow-y:auto;padding:26px;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.modal h2{font-size:1.45rem;margin-bottom:4px}
.modal h3{font-size:1.15rem;margin:2px 0 8px}
.modal .close-x{position:sticky;top:0;float:right;font-size:1.3rem;color:var(--muted);
  margin:-8px -8px 0 0}
.modal p{margin-bottom:10px}
.modal .small{font-size:.86rem;color:var(--muted)}

/* RAIN steps */
.rain-step{display:none}
.rain-step.on{display:block}
.rain-letter{display:inline-flex;align-items:center;justify-content:center;width:46px;
  height:46px;border-radius:50%;background:var(--sage);color:#fff;font-family:Georgia,serif;
  font-size:1.5rem;font-weight:700;margin-bottom:10px}
.rain-prompts{list-style:none;margin:12px 0}
.rain-prompts li{padding:9px 12px;background:var(--card);border:1px solid var(--line);
  border-radius:10px;margin-bottom:7px;font-size:.92rem}
.rain-dots{display:flex;gap:7px;margin:16px 0}
.rain-dots i{width:9px;height:9px;border-radius:50%;background:var(--line)}
.rain-dots i.on{background:var(--sage)}
.rain-nav{display:flex;justify-content:space-between;gap:10px;margin-top:18px}
.rain-timer{text-align:center;font-family:Georgia,serif;font-size:2.4rem;color:var(--sage-d);
  margin:14px 0}
.modal .primary-btn{font-size:.9rem;padding:10px 20px}

@media(max-width:620px){
  .head-inner{flex-wrap:wrap}
  .tag{display:none}
  .p-scrub{order:3;flex-basis:100%;min-width:0}
  .arrive{padding:18px}
  .reco{padding:16px}
}

/* toast */
.toast{position:fixed;left:50%;transform:translateX(-50%);bottom:140px;z-index:80;
  background:var(--ink);color:var(--bg);padding:10px 18px;border-radius:999px;
  font-size:.86rem;box-shadow:var(--shadow);animation:tin .25s}
@keyframes tin{from{opacity:0;transform:translate(-50%,8px)}}
