/* Animal Sounds Library — front-end (modal/card layout) */
.asl-root{--green:#1a7a4a;--green-dark:#0f5233;--green-light:#e8f5ee;--amber:#f59e0b;--amber-light:#fef3c7;
  --text:#1c1c1c;--muted:#5a6472;--bg:#f9fafb;--white:#fff;--border:#e2e8f0;--radius:12px;--radius-sm:8px;
  font-family:'Nunito',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--text)}
.asl-root *,.asl-root *::before,.asl-root *::after{box-sizing:border-box}

/* section header */
.asl-secthdr{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin:0 0 1rem;flex-wrap:wrap}
.asl-secthdr h2{font-size:1.4rem;font-weight:800;margin:0}
.asl-secthdr a{font-size:.85rem;color:var(--green);font-weight:700;text-decoration:none}
.asl-secthdr a:hover{text-decoration:underline}

/* tabs */
.asl-tabs{display:flex;gap:.45rem;flex-wrap:wrap;margin-bottom:1.2rem}
.asl-tab{background:var(--white);border:1.5px solid var(--border);border-radius:100px;padding:6px 14px;font-size:.81rem;
  font-weight:700;cursor:pointer;color:var(--muted);transition:all .15s;font-family:inherit;line-height:1.4}
.asl-tab:hover,.asl-tab.asl-on{background:var(--green);border-color:var(--green);color:#fff}

/* search (optional, inside library) */
.asl-search{display:flex;max-width:420px;margin:0 0 1.1rem;border:1.5px solid var(--border);border-radius:100px;
  overflow:hidden;background:#fff;align-items:center;padding-left:14px}
.asl-search svg{width:18px;height:18px;color:var(--muted);flex-shrink:0}
.asl-search input{flex:1;border:none;outline:none;padding:.6rem .9rem;font-size:.92rem;font-family:inherit;background:transparent}

/* grid + cards */
.asl-count{font-size:.8rem;color:var(--muted);font-weight:700;margin:0 0 .6rem}
.asl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(165px,1fr));gap:.9rem;margin-bottom:2rem}
.asl-grid[data-cols="2"]{grid-template-columns:repeat(2,1fr)}
.asl-grid[data-cols="3"]{grid-template-columns:repeat(3,1fr)}
.asl-grid[data-cols="4"]{grid-template-columns:repeat(4,1fr)}
.asl-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);overflow:hidden;
  cursor:pointer;transition:transform .18s,border-color .18s,box-shadow .18s;position:relative}
.asl-card:hover{transform:translateY(-3px);border-color:var(--green);box-shadow:0 8px 22px rgba(15,82,51,.10)}
.asl-card:focus-visible{outline:3px solid var(--amber);outline-offset:2px}
.asl-top{aspect-ratio:1/1;background:var(--green-light);display:flex;align-items:center;justify-content:center;
  font-size:3rem;position:relative;overflow:hidden}
.asl-top img{width:100%;height:100%;object-fit:cover}
.asl-badge{position:absolute;top:8px;right:8px;background:var(--amber);color:#5c3a00;font-size:.65rem;font-weight:800;
  padding:2px 7px;border-radius:100px;text-transform:uppercase;letter-spacing:.04em}
.asl-cardbody{padding:.6rem .8rem .8rem}
.asl-cname{font-weight:800;font-size:.92rem;margin-bottom:1px;line-height:1.2}
.asl-csci{font-size:.7rem;color:var(--muted);font-style:italic;margin-bottom:.45rem}
.asl-chip2{font-size:.74rem;color:var(--green);font-weight:700;background:var(--green-light);padding:2px 8px;
  border-radius:100px;display:inline-block;margin-bottom:.5rem}
.asl-playbtn{display:flex;align-items:center;justify-content:center;gap:5px;background:var(--green);border:none;
  border-radius:100px;padding:6px 13px;color:#fff;font-size:.78rem;font-weight:700;cursor:pointer;font-family:inherit;
  transition:background .15s;width:100%}
.asl-playbtn:hover{background:var(--green-dark)}
.asl-empty{grid-column:1/-1;text-align:center;padding:2rem;color:var(--muted)}
.asl-empty b{display:block;font-size:1rem;color:var(--text);margin-bottom:.25rem}
.asl-ad{grid-column:1/-1;display:flex;justify-content:center;align-items:center;min-height:90px;
  background:#fff;border:1px dashed var(--border);border-radius:var(--radius)}

/* modal */
.asl-modalbg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.52);z-index:99999;align-items:center;
  justify-content:center;padding:1rem}
.asl-modalbg.asl-open{display:flex}
.asl-modal{background:var(--white);border-radius:20px;max-width:400px;width:100%;padding:1.75rem;position:relative;
  animation:asl-pop .22s ease;max-height:90vh;overflow-y:auto;font-family:'Nunito',sans-serif}
@keyframes asl-pop{from{transform:scale(.88);opacity:0}to{transform:scale(1);opacity:1}}
.asl-mclose{position:absolute;top:12px;right:14px;background:var(--bg);border:none;border-radius:50%;width:30px;height:30px;
  cursor:pointer;font-size:1rem;color:var(--muted);display:flex;align-items:center;justify-content:center}
.asl-memoji{text-align:center;font-size:4rem;margin-bottom:.4rem;line-height:1}
.asl-memoji img{width:96px;height:96px;object-fit:cover;border-radius:16px}
.asl-mname{font-size:1.5rem;font-weight:800;text-align:center;margin:0 0 .15rem}
.asl-msci{text-align:center;font-size:.82rem;color:var(--muted);font-style:italic;margin:0 0 .5rem}
.asl-mbadgewrap{text-align:center;margin-bottom:.75rem}
.asl-msound{background:var(--green-light);color:var(--green-dark);font-size:.82rem;font-weight:700;padding:3px 14px;
  border-radius:100px;display:inline-block}
.asl-audioplayer{background:var(--green-light);border-radius:var(--radius-sm);padding:.8rem 1rem;display:flex;
  align-items:center;gap:.75rem;margin-bottom:.9rem}
.asl-mplay{background:var(--green);border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;
  justify-content:center;cursor:pointer;flex-shrink:0;transition:background .15s}
.asl-mplay:hover{background:var(--green-dark)}
.asl-wave2{display:flex;gap:3px;align-items:center;height:26px;flex:1}
.asl-wave2 span{width:4px;background:var(--green);border-radius:2px;height:6px}
.asl-wave2.asl-playing span{animation:asl-wave .75s ease-in-out infinite}
.asl-wave2.asl-playing span:nth-child(2){animation-delay:.1s}
.asl-wave2.asl-playing span:nth-child(3){animation-delay:.2s}
.asl-wave2.asl-playing span:nth-child(4){animation-delay:.3s}
.asl-wave2.asl-playing span:nth-child(5){animation-delay:.15s}
@keyframes asl-wave{0%,100%{height:5px}50%{height:22px}}
.asl-mlabel{font-size:.8rem;color:var(--muted);white-space:nowrap}
.asl-mfact{background:var(--amber-light);border-radius:var(--radius-sm);padding:.75rem 1rem;font-size:.88rem;
  line-height:1.65;color:#5c3a00;margin-bottom:.9rem}
.asl-mmeta{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:1rem}
.asl-mi{background:var(--bg);border-radius:var(--radius-sm);padding:.55rem .8rem}
.asl-mi-l{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:700;margin-bottom:2px}
.asl-mi-v{font-size:.88rem;font-weight:700}
.asl-mlearn{display:block;text-align:center;background:var(--green-light);color:var(--green-dark);font-weight:700;
  font-size:.88rem;padding:.65rem;border-radius:var(--radius-sm);text-decoration:none;transition:background .15s}
.asl-mlearn:hover{background:#c7e8d6}
.asl-mcredit{text-align:center;font-size:.72rem;color:var(--muted);margin-top:.7rem}
.asl-mcredit a{color:var(--green);font-weight:700;text-decoration:none}
.asl-mcredit a:hover{text-decoration:underline}

@media(max-width:700px){.asl-grid{grid-template-columns:repeat(auto-fill,minmax(145px,1fr))}}
@media(max-width:460px){.asl-mmeta{grid-template-columns:1fr}}

/* post-view card link + inline play state */
.asl-root a.asl-cname{display:block;color:var(--text);text-decoration:none}
.asl-root a.asl-cname:hover{color:var(--green)}
.asl-card.asl-playing{border-color:var(--green);box-shadow:0 8px 22px rgba(15,82,51,.14)}
.asl-card.asl-playing .asl-playbtn{background:var(--green-dark)}
.asl-card.asl-playing .asl-top{background:#d6efe0}
