/* =====================================================================
   Sound Effects page — 1:1 layout + functions of the production
   unstuntedsfx.net Sound-Effects view (Featured hero, AI Hum card,
   Featured list, full Categories grid, and the browse results list with
   sort/filters/pager + share/trim/download), re-themed for the SaaS shell.
   All rules scoped under `.sfx-lib` so they never touch the shared app.css.
   ===================================================================== */

/* ---------- sections ---------- */
.sfx-lib .sec{margin:28px 0 0}
.sfx-lib .sec-hd{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:16px}
.sfx-lib .sec-title{font-size:18px;font-weight:700;letter-spacing:-.2px}
.sfx-lib .sec-sub{font-size:13px;color:var(--text-muted);margin-top:2px}
.sfx-lib .sec-link{font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:color .12s}
.sfx-lib .sec-link:hover{color:var(--text)}

/* ---------- top: hero + AI hum card ---------- */
.sfx-lib .sfx-top{display:grid;grid-template-columns:2fr 1fr;gap:14px;margin-top:14px}
.sfx-lib .hero-banner{position:relative;height:200px;border-radius:16px;overflow:hidden;cursor:pointer}
.sfx-lib .hero-img{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(.62) saturate(.9);transition:filter .4s}
.sfx-lib .hero-banner:hover .hero-img{filter:brightness(.76) saturate(.95)}
.sfx-lib .hero-card{
  position:absolute;bottom:18px;left:18px;max-width:260px;padding:16px 20px;
  border-radius:12px;color:#fff;pointer-events:none;
  background:linear-gradient(135deg,rgba(0,0,0,.72),rgba(0,0,0,.38));
  backdrop-filter:blur(2px);border:1px solid rgba(255,255,255,.1);
}
.sfx-lib .hero-card-eyebrow{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:6px;color:rgba(255,255,255,.6)}
.sfx-lib .hero-card-title{font-size:26px;font-weight:800;letter-spacing:-.5px;line-height:1.08;margin-bottom:8px}
.sfx-lib .hero-card-cta{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:rgba(255,255,255,.78)}
.sfx-lib .hero-card-cta svg{width:14px;height:14px}

.sfx-lib .mu-feat-ai{
  position:relative;overflow:hidden;border-radius:16px;padding:22px 24px 20px;cursor:pointer;
  display:flex;flex-direction:column;gap:5px;user-select:none;
  background:
    radial-gradient(ellipse at 92% 12%,rgba(29,155,246,.5) 0%,rgba(20,110,200,.12) 42%,transparent 70%),
    linear-gradient(155deg,#141925 0%,#0a0d13 100%);
  border:1px solid rgba(29,155,246,.18);transition:opacity .12s;
}
.sfx-lib .mu-feat-ai:hover{opacity:.94}
.sfx-lib .mu-feat-ai::before{content:'';position:absolute;right:-48px;top:50%;transform:translateY(-50%);width:160px;height:160px;border-radius:50%;border:1px solid rgba(29,155,246,.12);pointer-events:none}
.sfx-lib .mu-feat-ai::after{content:'';position:absolute;right:-84px;top:50%;transform:translateY(-50%);width:240px;height:240px;border-radius:50%;border:1px solid rgba(29,155,246,.07);pointer-events:none}
.sfx-lib .mu-feat-mic{position:absolute;right:22px;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;background:rgba(29,155,246,.12);border:1px solid rgba(29,155,246,.22);display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:1}
.sfx-lib .mu-feat-mic svg{width:22px;height:22px;color:rgba(126,194,246,.85)}
.sfx-lib .mu-feat-inner{position:relative;z-index:1;display:flex;flex-direction:column;gap:5px;padding-right:70px}
.sfx-lib .mu-feat-eyebrow{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);display:flex;align-items:center;gap:6px}
.sfx-lib .mu-feat-badge{background:var(--primary-soft);color:#7ec2f6;font-size:9px;font-weight:700;padding:2px 6px;border-radius:3px;text-transform:uppercase}
.sfx-lib .mu-feat-title{font-size:20px;font-weight:800;line-height:1.15;letter-spacing:-.35px;margin-top:2px}
.sfx-lib .mu-feat-title em{font-style:italic;color:#7ec2f6}
.sfx-lib .mu-feat-desc{font-size:11.5px;color:var(--text-muted);line-height:1.5}
.sfx-lib .mu-feat-ai-btn{
  margin-top:12px;display:inline-flex;align-items:center;gap:8px;width:fit-content;
  background:rgba(255,255,255,.96);color:#0a0a0f;font-size:13px;font-weight:700;
  padding:9px 18px;border-radius:999px;border:none;font-family:inherit;cursor:pointer;
  box-shadow:0 2px 14px rgba(0,0,0,.35);transition:transform .15s,box-shadow .15s;
}
.sfx-lib .mu-feat-ai-btn:hover{transform:scale(1.03);box-shadow:0 4px 24px rgba(29,155,246,.3)}
.sfx-lib .mu-feat-ai-btn svg{width:13px;height:13px;stroke:rgba(0,0,0,.7);fill:none;stroke-width:2;stroke-linecap:round}

/* ---------- categories grid (bright tiles, theme-independent) ---------- */
.sfx-lib .cat-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}
.sfx-lib .cat-card{
  position:relative;aspect-ratio:1;border-radius:14px;overflow:hidden;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:transform .2s var(--ease),box-shadow .2s;
}
.sfx-lib .cat-card::before{content:'';position:absolute;inset:0;background:rgba(0,0,0,.1);opacity:0;transition:opacity .2s}
.sfx-lib .cat-card:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.06)}
.sfx-lib .cat-card:hover::before{opacity:1}
.sfx-lib .cat-card:active{transform:scale(.97)}
.sfx-lib .cat-bg{position:absolute;inset:0}
.sfx-lib .cat-icon-wrap{position:relative;z-index:1;width:60px;height:60px;display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 2px 10px rgba(0,0,0,.25))}
.sfx-lib .cat-icon-wrap svg{width:50px;height:50px}
.sfx-lib .cat-name{position:absolute;bottom:0;left:0;right:0;padding:10px 10px 11px;font-size:12px;font-weight:700;letter-spacing:-.1px;z-index:1}

/* ---------- featured / trending rows ---------- */
.sfx-lib .trending-list{display:flex;flex-direction:column}
.sfx-lib .tr-row{
  display:grid;grid-template-columns:32px 1fr 80px 56px 84px;align-items:center;gap:12px;
  margin:0 -12px;padding:10px 12px;border-bottom:1px solid var(--border);
  cursor:pointer;position:relative;border-radius:10px;transition:background .1s;
}
.sfx-lib .tr-row:hover{background:var(--card)}
.sfx-lib .tr-row.playing{background:rgba(29,155,246,.06)}
.sfx-lib .tr-rank{font-size:13px;font-weight:700;color:var(--text-dim);font-variant-numeric:tabular-nums;text-align:center;transition:opacity .1s}
.sfx-lib .tr-row:hover .tr-rank,.sfx-lib .tr-row.playing .tr-rank{opacity:0}
.sfx-lib .tr-play-btn{position:absolute;left:12px;width:26px;height:26px;border-radius:50%;background:#fff;display:none;align-items:center;justify-content:center;border:none;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.4);transition:transform .12s}
.sfx-lib .tr-play-btn:hover{transform:scale(1.08)}
.sfx-lib .tr-play-btn svg{width:9px;height:9px;fill:var(--bg);color:var(--bg);margin-left:1px}
.sfx-lib .tr-play-btn .ip{display:block}.sfx-lib .tr-play-btn .ipa{display:none}
.sfx-lib .tr-row:hover .tr-play-btn,.sfx-lib .tr-row.playing .tr-play-btn{display:flex}
.sfx-lib .tr-row.playing .tr-play-btn{background:var(--primary)}
.sfx-lib .tr-row.playing .tr-play-btn svg{fill:#fff;color:#fff}
.sfx-lib .tr-row.playing .tr-play-btn .ip{display:none}.sfx-lib .tr-row.playing .tr-play-btn .ipa{display:block}
.sfx-lib .tr-main{min-width:0;display:flex;align-items:center;gap:10px}
.sfx-lib .tr-thumb{width:38px;height:38px;border-radius:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
.sfx-lib .tr-body{min-width:0}
.sfx-lib .tr-name{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:3px;transition:color .12s}
.sfx-lib .tr-row:hover .tr-name,.sfx-lib .tr-row.playing .tr-name{color:var(--primary)}
.sfx-lib .tr-cat{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sfx-lib .tr-wave{width:80px;height:26px;display:flex;align-items:center;gap:1.5px;overflow:hidden;flex-shrink:0}
.sfx-lib .tr-wb{width:2px;border-radius:1px;background:rgba(255,255,255,.16);transition:background .15s}
.sfx-lib .tr-row:hover .tr-wb{background:rgba(29,155,246,.45)}
.sfx-lib .tr-row.playing .tr-wb{background:var(--primary)}
.sfx-lib .tr-dur{font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums;text-align:center;white-space:nowrap}
.sfx-lib .tr-acts{display:flex;align-items:center;gap:10px;justify-content:flex-end;opacity:0;transform:translateX(6px);transition:opacity .15s,transform .15s var(--ease)}
.sfx-lib .tr-row:hover .tr-acts,.sfx-lib .tr-row.playing .tr-acts{opacity:1;transform:translateX(0)}
.sfx-lib .tr-act,.sfx-lib .tr-act-dl{width:30px;height:30px;padding:0;margin:0;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text-muted);transition:color .12s var(--ease),transform .12s var(--ease)}
.sfx-lib .tr-act:hover{color:var(--text);transform:scale(1.14)}
.sfx-lib .tr-act-dl:hover{color:var(--primary);transform:scale(1.14)}
.sfx-lib .tr-act:active,.sfx-lib .tr-act-dl:active{transform:scale(.92)}
.sfx-lib .tr-act svg,.sfx-lib .tr-act-dl svg{width:18px;height:18px;stroke-width:1.9}
.sfx-lib .tr-skel{height:60px;background:var(--panel-2);border-radius:10px;margin-bottom:2px;animation:fadeUp .4s var(--ease) both}

/* ---------- browse: bar + toolbar ---------- */
.sfx-lib .browse-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin:6px 0 10px}
.sfx-lib .browse-bar-left{display:flex;align-items:center;gap:14px;min-width:0}
.sfx-lib .back-btn{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted);cursor:pointer;background:none;border:none;font-family:inherit;white-space:nowrap;transition:color .12s}
.sfx-lib .back-btn:hover{color:var(--text)}
.sfx-lib .back-btn svg{width:14px;height:14px}
.sfx-lib .browse-title{font-size:18px;font-weight:700;letter-spacing:-.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sfx-lib .browse-count{font-size:12px;color:var(--text-muted);flex-shrink:0}
.sfx-lib .filter-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:8px}
.sfx-lib .dur-pill{padding:6px 14px;border-radius:999px;border:1px solid var(--border-2);font-size:12px;font-weight:500;color:var(--text-muted);cursor:pointer;background:transparent;font-family:inherit;transition:all .15s var(--ease)}
.sfx-lib .dur-pill:hover{border-color:rgba(255,255,255,.22);color:#cfdde2}
.sfx-lib .dur-pill.active{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:700;box-shadow:0 0 0 3px var(--primary-soft)}
.sfx-lib .sort-sel{
  background:var(--panel-2);border:1px solid var(--border-2);border-radius:999px;
  padding:7px 30px 7px 14px;font-size:12px;font-weight:500;color:var(--text-muted);
  cursor:pointer;appearance:none;-webkit-appearance:none;font-family:inherit;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2393a8b0' stroke-width='2.4' stroke-linecap='round'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat:no-repeat;background-position:right 11px center;transition:border-color .15s var(--ease);
}
.sfx-lib .sort-sel:hover{border-color:rgba(255,255,255,.22)}

/* ---------- browse: list header + rows ---------- */
.sfx-lib .tl-head{display:grid;grid-template-columns:52px 1fr 110px 60px 226px;padding:0 16px;height:34px;align-items:center;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.sfx-lib .th{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);user-select:none;cursor:pointer;display:flex;align-items:center;gap:3px;transition:color .12s}
.sfx-lib .th:hover{color:var(--text-muted)}
.sfx-lib #list{padding-bottom:128px}
.sfx-lib .track{
  display:grid;grid-template-columns:52px 1fr 110px 60px 226px;align-items:center;padding:0 16px;height:64px;
  border:0;border-bottom:1px solid var(--border);cursor:pointer;position:relative;background:transparent;border-radius:0;
  transition:background .1s;animation:fadeUp .4s var(--ease) both;
}
.sfx-lib .track:hover{background:var(--card)}
.sfx-lib .track.playing{background:rgba(29,155,246,.07);box-shadow:inset 3px 0 0 var(--primary)}
.sfx-lib .ti-cell{position:relative;width:52px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sfx-lib .tnum{font-size:12px;color:var(--text-dim);font-variant-numeric:tabular-nums;transition:opacity .1s}
.sfx-lib .tplay{position:absolute;width:36px;height:36px;border-radius:50%;background:#fff;display:none;align-items:center;justify-content:center;border:none;cursor:pointer;box-shadow:0 4px 14px rgba(0,0,0,.5);transition:transform .15s,background .12s}
.sfx-lib .tplay:hover{transform:scale(1.08)}
.sfx-lib .tplay svg{width:12px;height:12px;fill:var(--bg);color:var(--bg);margin-left:2px}
.sfx-lib .tplay .ip{display:block}.sfx-lib .tplay .ipa{display:none}
.sfx-lib .track:hover .tnum,.sfx-lib .track.playing .tnum{opacity:0}
.sfx-lib .track:hover .tplay,.sfx-lib .track.playing .tplay{display:flex}
.sfx-lib .track.playing .tplay{background:var(--primary)}
.sfx-lib .track.playing .tplay svg{fill:#fff;color:#fff}
.sfx-lib .track.playing .tplay .ip{display:none}.sfx-lib .track.playing .tplay .ipa{display:block}
.sfx-lib .t-info{display:flex;align-items:center;gap:12px;min-width:0;padding-right:16px}
.sfx-lib .t-art{width:44px;height:44px;border-radius:8px;background:var(--panel-2);flex-shrink:0;overflow:hidden}
.sfx-lib .t-art img{width:100%;height:100%;object-fit:cover;display:block}
.sfx-lib .t-body{min-width:0;flex:1}
.sfx-lib .t-name{font-size:14px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px;letter-spacing:-.1px;transition:color .12s}
.sfx-lib .track:hover .t-name,.sfx-lib .track.playing .t-name{color:var(--primary)}
.sfx-lib .t-meta{display:flex;align-items:center;gap:6px;overflow:hidden}
.sfx-lib .t-cat{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:1}
.sfx-lib .t-fmt{font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:2px 6px;border-radius:3px;background:var(--primary-soft);color:#7ec2f6;flex-shrink:0}
.sfx-lib .t-tags{display:flex;gap:4px;flex-shrink:0}
.sfx-lib .ttag{font-size:10px;padding:2px 7px;border-radius:999px;border:1px solid var(--border);color:var(--text-dim);white-space:nowrap;transition:all .12s}
.sfx-lib .track:hover .ttag{border-color:var(--border-2);color:var(--text-muted)}
.sfx-lib .t-wave{height:28px;display:flex;align-items:center;gap:1.5px;overflow:hidden}
.sfx-lib .wb{width:2px;border-radius:2px;background:rgba(255,255,255,.16);transition:background .15s}
.sfx-lib .track:hover .wb{background:rgba(29,155,246,.45)}
.sfx-lib .track.playing .wb{background:var(--primary)}
.sfx-lib .t-dur{font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums;text-align:center}
.sfx-lib .t-acts{display:flex;align-items:center;gap:8px;justify-content:flex-end;opacity:0;transform:translateX(6px);transition:opacity .15s,transform .15s var(--ease)}
.sfx-lib .track:hover .t-acts,.sfx-lib .track.playing .t-acts{opacity:1;transform:translateX(0)}
.sfx-lib .ta,.sfx-lib .ta-dl{width:32px;height:32px;padding:0;margin:0;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text-muted);transition:color .12s var(--ease),transform .12s var(--ease)}
.sfx-lib .ta:hover{color:var(--text);transform:scale(1.14)}
.sfx-lib .ta-dl:hover{color:var(--primary);transform:scale(1.14)}
.sfx-lib .ta:active,.sfx-lib .ta-dl:active{transform:scale(.92)}
.sfx-lib .ta svg,.sfx-lib .ta-dl svg{width:19px;height:19px;stroke-width:1.9}
.sfx-lib .row-check{position:absolute;left:0;width:18px;height:18px;border:1px solid var(--border-2);border-radius:6px;background:var(--panel-2);opacity:0;transition:opacity .12s,border-color .12s,background .12s}
.sfx-lib .track:hover .row-check,.sfx-lib .track.selected .row-check{opacity:1}
.sfx-lib .track.selected .row-check{background:var(--primary);border-color:var(--primary)}
.sfx-lib .track.selected .row-check::after{content:"";width:8px;height:5px;border-left:2px solid #fff;border-bottom:2px solid #fff;display:block;transform:rotate(-45deg);margin:4px auto 0}
.sfx-lib .track.selected{background:rgba(29,155,246,.08)}
.sfx-lib .ta.is-fav,.sfx-lib .tr-act.is-fav{color:#ff6b9d}
.sfx-lib .save-search{height:28px;border:1px solid var(--border-2);border-radius:999px;background:var(--card);color:var(--text);font-size:12px;font-weight:650;padding:0 11px;cursor:pointer}
.sfx-lib .save-search:hover{border-color:var(--primary);background:var(--primary-soft)}
.bulkbar{position:fixed;left:50%;bottom:88px;z-index:72;display:none;align-items:center;gap:8px;transform:translateX(-50%);background:var(--panel);border:1px solid var(--border-2);border-radius:999px;box-shadow:var(--shadow-lg);padding:8px 10px 8px 14px}
.bulkbar.show{display:flex}
.bulkbar b{font-size:13px;margin-right:4px}
.bulkbar button{height:30px;border-radius:999px;background:var(--card);border:1px solid var(--border);color:var(--text);padding:0 10px;font-size:12px;font-weight:650;cursor:pointer}
.bulkbar button:hover{background:var(--card-hover);border-color:var(--primary)}
.hm-steps{display:flex;justify-content:center;gap:7px;margin:14px 0 2px}
.hm-steps span{font-size:11px;font-weight:700;color:var(--text-dim);border:1px solid var(--border);border-radius:999px;padding:4px 9px}
.hm-steps span.on{color:#7ec2f6;background:var(--primary-soft);border-color:rgba(29,155,246,.28)}

/* ---------- states + pager ---------- */
.sfx-lib .state-msg{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:80px 24px;color:var(--text-muted);font-size:14px;text-align:center}
.sfx-lib .sk-row{height:64px;border-bottom:1px solid var(--border);animation:fadeUp .4s var(--ease) both}
.sfx-lib .pager{display:flex;align-items:center;justify-content:center;gap:3px;padding:26px 16px 120px}
.sfx-lib .pgb{min-width:34px;height:34px;padding:0 6px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all .12s}
.sfx-lib .pgb:hover{background:var(--card);color:var(--text)}
.sfx-lib .pgb.active{background:var(--primary);color:#fff;font-weight:700}
.sfx-lib .pgb.arr{color:var(--text-dim);font-size:16px}
.sfx-lib .pgb.arr:hover{color:var(--text);background:var(--card)}
.sfx-lib .pgdots{color:var(--text-dim);width:34px;text-align:center}

/* search mic button */
.sfx-lib .search .mic{width:34px;height:34px;flex:none;border-radius:50%;display:grid;place-items:center;background:var(--primary);color:#fff;border:none;cursor:pointer;transition:background .15s}
.sfx-lib .search .mic:hover{background:var(--primary-2)}
.sfx-lib .search .mic svg{width:16px;height:16px;color:#fff}

/* ---------- responsive ---------- */
@media (max-width:1024px){
  .sfx-lib .sfx-top{grid-template-columns:1fr}
  .sfx-lib .cat-grid{grid-template-columns:repeat(4,1fr)}
  .sfx-lib .tl-head,.sfx-lib .track{grid-template-columns:52px 1fr 60px 210px}
  .sfx-lib .t-wave,.sfx-lib .tl-head .th:nth-child(3){display:none}
}
@media (max-width:680px){
  .sfx-lib .cat-grid{grid-template-columns:repeat(2,1fr)}
  .sfx-lib .tl-head,.sfx-lib .track{grid-template-columns:44px 1fr 56px;padding:0 12px}
  .sfx-lib .t-acts,.sfx-lib .tl-head span:nth-child(5){display:none}
  .bulkbar{left:12px;right:12px;bottom:130px;transform:none;border-radius:14px;justify-content:center;flex-wrap:wrap}
  .sfx-lib .t-dur{text-align:right}
  .sfx-lib .tr-row{grid-template-columns:32px 1fr 84px}
  .sfx-lib .tr-wave,.sfx-lib .tr-dur{display:none}
}

/* =====================================================================
   Modals — share / trim / download / add-to-playlist (appended to body)
   ===================================================================== */
.mo-ov{position:fixed;inset:0;z-index:900;background:rgba(8,16,19,.72);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .2s}
.mo-ov.open{opacity:1;pointer-events:auto}
.mo-box{background:var(--panel);border:1px solid var(--border-2);border-radius:16px;padding:28px;width:100%;max-width:420px;position:relative;transform:scale(.96) translateY(6px);transition:transform .2s;max-height:88vh;overflow-y:auto;box-shadow:var(--shadow-lg)}
.mo-ov.open .mo-box{transform:none}
.mo-box h3{font-size:16px;font-weight:700;letter-spacing:-.2px;margin-bottom:5px}
.mo-tname{font-size:13px;color:var(--text-muted);margin-bottom:20px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mo-x{position:absolute;top:14px;right:14px;width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:var(--text-muted);cursor:pointer;transition:background .12s}
.mo-x:hover{background:rgba(255,255,255,.16);color:#fff}
.mo-x svg{width:11px;height:11px}
.mo-btn{width:100%;padding:12px;border-radius:10px;font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;transition:opacity .12s,background .12s;margin-bottom:8px}
.mo-btn:last-child{margin-bottom:0}
.mo-btn-ac{background:var(--primary);color:#fff;border:none}
.mo-btn-ac:hover{background:var(--primary-2)}
.mo-btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border-2)}
.mo-btn-ghost:hover{border-color:rgba(255,255,255,.22);color:#fff}
.mo-btn-outline{background:transparent;border:1px solid var(--border-2);color:var(--text-muted)}
.mo-btn-outline:hover{border-color:rgba(255,255,255,.22);color:#fff;background:rgba(255,255,255,.04)}
.mo-btn:disabled{opacity:.45;cursor:not-allowed}
.mo-btn svg{width:14px;height:14px}
.dl-footer{text-align:center;font-size:11px;color:var(--text-dim);margin-top:12px;letter-spacing:.01em}
.dl-upsell{background:var(--primary-soft);border:1px solid rgba(29,155,246,.2);border-radius:8px;padding:10px 14px;font-size:12px;color:var(--text-muted);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.dl-upsell svg{width:13px;height:13px;color:var(--primary);flex-shrink:0}
.dl-upsell a{color:var(--primary)}
.share-link-row{display:flex;gap:8px;margin-bottom:14px}
.share-url{flex:1;background:var(--panel-2);border:1px solid var(--border-2);border-radius:8px;padding:8px 12px;font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.share-copy{padding:0 14px;border-radius:8px;background:var(--primary);color:#fff;font-size:12px;font-weight:700;border:none;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .12s}
.share-copy:hover{background:var(--primary-2)}
.share-copy.ok{background:#22c55e;color:#fff}
.share-socials{display:flex;gap:8px}
.share-soc{flex:1;padding:9px;border-radius:8px;background:var(--panel-2);border:1px solid var(--border);font-size:12px;font-weight:500;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .12s;text-decoration:none}
.share-soc:hover{border-color:var(--border-2);color:#fff;background:var(--card)}
.share-soc svg{width:13px;height:13px}
.mo-box-wide{max-width:520px}
.trim-wave{position:relative;width:100%;height:96px;background:var(--panel-2);border-radius:8px;overflow:hidden;margin:14px 0 8px;user-select:none;touch-action:none;border:1px solid var(--border-2)}
.trim-wave canvas{width:100%;height:100%;display:block}
.trim-dim{position:absolute;top:0;bottom:0;background:rgba(0,0,0,.52);pointer-events:none}
.trim-dim-l{left:0}.trim-dim-r{right:0}
.trim-hl{position:absolute;top:0;bottom:0;width:3px;background:var(--primary);transform:translateX(-50%);cursor:ew-resize;z-index:2}
.trim-hl::before,.trim-hl::after{content:'';position:absolute;left:50%;transform:translateX(-50%);width:12px;height:14px;background:var(--primary);border-radius:3px}
.trim-hl::before{top:-1px}.trim-hl::after{bottom:-1px}
.trim-times{display:flex;justify-content:space-between;font-variant-numeric:tabular-nums;font-size:11px;color:var(--text-muted);margin-bottom:14px;padding:0 2px}
.trim-times b{color:var(--text);font-weight:600;font-size:12px;display:inline-block;margin-right:2px}
.trim-row{display:flex;gap:8px;margin-top:2px}
.trim-row .mo-btn{margin-bottom:0;flex:1}
.trim-load{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--text-muted);background:var(--panel-2)}
.trim-hint{font-size:11px;color:var(--text-muted);text-align:center;margin-top:10px}
.addpl-list{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;max-height:280px;overflow-y:auto}
.addpl-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:10px 12px;cursor:pointer;color:var(--text);transition:all .12s}
.addpl-item:hover{background:var(--card);border-color:var(--border-2)}
.addpl-item svg{width:15px;height:15px;color:var(--text-muted);flex-shrink:0}
.addpl-item-name{flex:1;font-size:13.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.addpl-item-count{font-size:11.5px;color:var(--text-dim);flex-shrink:0}
.addpl-item-in{border-color:var(--primary);background:var(--primary-soft)}
.addpl-item-in:hover{background:var(--primary-soft)}
.addpl-check{width:14px;height:14px;color:var(--primary);flex-shrink:0;margin-left:2px}
.addpl-empty{color:var(--text-dim);font-size:13px;text-align:center;padding:18px 8px;margin-bottom:14px}

/* =====================================================================
   Light-mode adjustments (the toggle adds `.light` on <html>)
   ===================================================================== */
html.light .sfx-lib .wb,html.light .sfx-lib .tr-wb{background:rgba(0,0,0,.16)}
html.light .sfx-lib .track:hover .wb,html.light .sfx-lib .tr-row:hover .tr-wb{background:rgba(29,155,246,.5)}
html.light .sfx-lib .track.playing,html.light .sfx-lib .tr-row.playing{background:rgba(29,155,246,.10)}
html.light .sfx-lib .tplay,html.light .sfx-lib .tr-play-btn{background:#13252a}
html.light .sfx-lib .tplay svg,html.light .sfx-lib .tr-play-btn svg{fill:#fff;color:#fff}
html.light .sfx-lib .dur-pill:hover,html.light .sfx-lib .sort-sel:hover{border-color:rgba(0,0,0,.28);color:#0e1f25}
html.light .sfx-lib .ta:hover,html.light .sfx-lib .tr-act:hover{color:#0e1f25}
html.light .mo-x{background:rgba(0,0,0,.06)}
html.light .mo-x:hover{background:rgba(0,0,0,.12);color:#0e1f25}
html.light .mo-btn-ghost:hover,html.light .mo-btn-outline:hover{border-color:rgba(0,0,0,.28);color:#0e1f25}

/* =====================================================================
   Hum / AI sound search modal (mic on the search bar) — wired to the
   live unstuntedsfx.net /api/search. Themed + refined for clarity.
   ===================================================================== */
.hm-ov{position:fixed;inset:0;z-index:980;display:flex;align-items:center;justify-content:center;padding:20px;background:rgba(6,9,13,.78);backdrop-filter:blur(14px);opacity:0;pointer-events:none;transition:opacity .22s var(--ease)}
.hm-ov.show{opacity:1;pointer-events:auto}
.hm-box{position:relative;width:100%;max-width:480px;background:var(--panel);border:1px solid var(--border-2);border-radius:22px;padding:22px 24px 24px;box-shadow:var(--shadow-lg);transform:scale(.96) translateY(8px);transition:transform .24s var(--ease);max-height:90vh;overflow-y:auto}
.hm-ov.show .hm-box{transform:none}
.hm-x{position:absolute;top:14px;right:14px;width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:var(--text-muted);cursor:pointer;border:none;transition:background .12s,color .12s;z-index:2}
.hm-x:hover{background:rgba(255,255,255,.16);color:#fff}
.hm-x svg{width:13px;height:13px}
.hm-tabs{display:flex;gap:4px;background:var(--panel-2);border:1px solid var(--border);border-radius:12px;padding:4px;width:fit-content;margin:2px auto 18px}
.hm-tab{display:flex;align-items:center;gap:7px;padding:8px 16px;border-radius:9px;font-size:13px;font-weight:600;color:var(--text-muted);background:none;border:none;cursor:pointer;font-family:inherit;transition:all .15s var(--ease)}
.hm-tab svg{width:15px;height:15px}
.hm-tab.active{background:var(--primary);color:#fff;box-shadow:0 6px 16px -8px var(--primary-glow)}
.hm-content{text-align:center;min-height:300px;display:flex;flex-direction:column;align-items:center;justify-content:center}

/* mic orb */
.hm-orb-stage{position:relative;width:150px;height:150px;display:grid;place-items:center;margin:6px auto 4px}
.hm-orb-glow{position:absolute;inset:-20px;border-radius:50%;background:radial-gradient(circle,var(--primary-glow) 0%,transparent 70%);opacity:.5;filter:blur(6px)}
.hm-mic-wrap{position:relative;width:96px;height:96px;display:grid;place-items:center}
.hm-ring{position:absolute;inset:0;border-radius:50%;border:1px solid rgba(29,155,246,.4);animation:hmRing 2.4s ease-out infinite}
.hm-ring-2{inset:-14px;border-color:rgba(29,155,246,.28);animation-delay:.5s}
.hm-ring-3{inset:-28px;border-color:rgba(29,155,246,.16);animation-delay:1s}
@keyframes hmRing{0%{transform:scale(.85);opacity:.9}100%{transform:scale(1.25);opacity:0}}
.hm-mic{position:relative;z-index:2;width:84px;height:84px;border-radius:50%;background:linear-gradient(145deg,#2aa6ff,#1276d6);display:grid;place-items:center;color:#fff;cursor:pointer;box-shadow:0 0 0 1px rgba(255,255,255,.14) inset,0 14px 40px -8px var(--primary-glow);transition:transform .16s var(--ease),box-shadow .16s}
.hm-mic:hover{transform:scale(1.06)}
.hm-mic:active{transform:scale(.97)}
.hm-mic svg{width:34px;height:34px}
.hm-timer-wrap{position:absolute;inset:0;transform:rotate(-90deg)}
.hm-timer-track{fill:none;stroke:rgba(255,255,255,.1);stroke-width:4}
.hm-timer-prog{fill:none;stroke:#f87171;stroke-width:4;stroke-linecap:round;transition:stroke-dashoffset .1s linear}
.hm-countdown{position:absolute;bottom:-2px;right:-2px;width:26px;height:26px;border-radius:50%;background:var(--panel);border:1px solid var(--border-2);display:grid;place-items:center;font-size:11px;font-weight:700;color:#f87171;z-index:3}
.hm-tap-chip{display:inline-flex;align-items:center;gap:6px;margin:14px auto 0;padding:6px 13px;border-radius:999px;background:var(--primary-soft);color:#7ec2f6;font-size:12px;font-weight:600}
.hm-tap-chip svg{width:13px;height:13px;fill:currentColor}
.hm-label{font-size:19px;font-weight:800;letter-spacing:-.3px;margin-top:14px}
.hm-sub{font-size:13px;color:var(--text-muted);line-height:1.5;margin-top:6px;max-width:34ch}
.hm-sub em{color:var(--text);font-style:normal;font-weight:600}
.hm-canvas{width:200px;height:48px;margin-top:14px;display:block}

/* describe */
.hm-field{display:flex;gap:8px;width:100%;max-width:380px;margin-top:6px}
.hm-input{flex:1;height:46px;background:var(--panel-2);border:1px solid var(--border-2);border-radius:12px;padding:0 16px;color:var(--text);font-size:14px;outline:none;font-family:inherit;transition:border-color .15s,box-shadow .15s}
.hm-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}
.hm-send{width:46px;height:46px;flex:none;border-radius:12px;background:var(--primary);color:#fff;display:grid;place-items:center;border:none;cursor:pointer;transition:background .15s}
.hm-send:hover{background:var(--primary-2)}
.hm-send svg{width:18px;height:18px}

/* analyzing */
.hm-spinner{width:42px;height:42px;border-radius:50%;border:3px solid var(--primary-soft);border-top-color:var(--primary);animation:spin .8s linear infinite;margin-bottom:6px}
.hm-dots{display:flex;gap:6px;margin-top:14px}
.hm-dot{width:7px;height:7px;border-radius:50%;background:var(--primary);animation:hmBlink 1.3s infinite both}
.hm-dot:nth-child(2){animation-delay:.2s}.hm-dot:nth-child(3){animation-delay:.4s}
@keyframes hmBlink{0%,80%,100%{opacity:.25;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}

/* results */
.hm-results{display:flex;flex-direction:column;gap:8px;width:100%;margin-top:8px;text-align:left}
.hm-res-card{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:9px 12px;transition:border-color .15s,background .15s}
.hm-res-card:hover{border-color:var(--border-2);background:var(--card-hover)}
.hm-res-play{width:38px;height:38px;flex:none;border-radius:10px;background:var(--panel-2);border:none;display:grid;place-items:center;cursor:pointer;color:#fff;transition:background .15s,transform .12s}
.hm-res-play:hover{background:var(--primary);transform:scale(1.05)}
.hm-res-play svg{width:16px;height:16px;margin-left:1px}
.hm-res-body{flex:1;min-width:0}
.hm-res-name{font-size:13.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hm-res-cat{font-size:11.5px;color:var(--text-muted);margin:2px 0 5px}
.hm-res-bar-wrap{height:4px;border-radius:3px;background:rgba(255,255,255,.1);overflow:hidden}
html.light .hm-res-bar-wrap{background:rgba(0,0,0,.1)}
.hm-res-bar{height:100%;width:0;border-radius:3px;background:linear-gradient(90deg,var(--primary),#5fc0ff);transition:width .5s var(--ease)}
.hm-res-pct{font-size:12px;font-weight:700;color:#7ec2f6;font-variant-numeric:tabular-nums;flex:none}
.hm-res-use{width:36px;height:36px;flex:none;border-radius:10px;background:var(--primary-soft);border:1px solid rgba(29,155,246,.3);display:grid;place-items:center;cursor:pointer;color:var(--primary);transition:all .15s}
.hm-res-use:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.hm-res-use svg{width:15px;height:15px}

.hm-actions{display:flex;gap:8px;justify-content:center;margin-top:18px}
.hm-actions button{padding:9px 18px;border-radius:10px;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;background:var(--panel-2);border:1px solid var(--border-2);color:var(--text-muted);transition:all .15s}
.hm-actions button:hover{color:var(--text);border-color:rgba(255,255,255,.22)}
.hm-actions button:first-child{background:var(--primary);border-color:var(--primary);color:#fff}
.hm-actions button:first-child:hover{background:var(--primary-2)}
.hm-err{font-size:14px;color:#f87171;line-height:1.5;max-width:32ch}
html.light .hm-x{background:rgba(0,0,0,.06)}
html.light .hm-actions button:hover{color:#0e1f25}
