/* ============================================================
   Drop Beat — Theme Styles
   ダーク基調 / ゴールドアクセント / 明朝＋セリフ / レスポンシブ
   ============================================================ */
:root{
  --bg:#0a0b12; --bgdeep:#06070c; --panel:#0f1019; --card:#14151f; --cardhi:#1b1c28;
  --line:rgba(255,255,255,.08); --linestrong:rgba(255,255,255,.14);
  --text:#f4f4f7; --sub:#a7a8b5; --muted:#6c6d7c; --faint:#494a57;
  --gold:#d4af6a; --goldbright:#ebcb86; --golddeep:#9a7a3e;
  --purple:#8a6bff; --emerald:#3ccb94; --burgundy:#8c2f3d; --burgundybright:#b0455a; --rose:#d98aa0; --danger:#c75b6a;
  --serif:"Cormorant Garamond",Georgia,serif;
  --mincho:"Shippori Mincho",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans JP",sans-serif;
  --r:16px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bgdeep);color:var(--text);font-family:var(--sans);-webkit-font-smoothing:antialiased;line-height:1.5}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}
h1,h2,h3{margin:0}
input,select,textarea{font-family:inherit}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#20212c;border-radius:8px}
::-webkit-scrollbar-track{background:transparent}

.container{max-width:1280px;margin:0 auto;padding:0 24px}
.serif{font-family:var(--serif)}
.mincho{font-family:var(--mincho)}
.gold{color:var(--gold)}
.muted{color:var(--muted)}
.sub{color:var(--sub)}
.center{text-align:center}
.hide{display:none!important}
.no-scrollbar::-webkit-scrollbar{display:none}
.no-scrollbar{-ms-overflow-style:none;scrollbar-width:none}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r)}
.brand-gradient{background:linear-gradient(135deg,#3a2a6b,#14111f)}
.hero-gradient{background:linear-gradient(135deg,#3b1c2e,#0c0a12)}
.gold-gradient{background:linear-gradient(135deg,#e2c281,#9a7a3e)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);background:var(--card);color:var(--text);
  border-radius:12px;padding:10px 16px;font-size:14px;font-weight:700;transition:.15s}
.btn:hover{border-color:var(--linestrong)}
.btn-gold{background:linear-gradient(135deg,#e2c281,#9a7a3e);color:#1a1205;border:none}
.btn-gold:hover{opacity:.94}
.btn-outline-gold{border-color:rgba(212,175,106,.5);background:rgba(212,175,106,.08);color:var(--goldbright)}
.btn-block{display:flex;width:100%;justify-content:center}
.btn-lg{padding:13px 20px;font-size:15px}
.btn-sm{padding:7px 12px;font-size:13px;border-radius:10px}

/* ---------- Header / Nav ---------- */
.site-header{position:sticky;top:0;z-index:40;background:rgba(6,7,12,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:18px;height:62px}
.brand{font-family:var(--serif);font-size:24px;letter-spacing:.5px}
.brand b{color:var(--gold);font-weight:700}
.nav-links{display:flex;gap:18px;align-items:center}
.nav-links a{font-size:14px;font-weight:600;color:var(--muted)}
.nav-links a:hover,.nav-links a.active{color:var(--text)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:12px}
.nav-search{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:8px 14px;min-width:200px}
.nav-search input{background:transparent;border:none;outline:none;color:var(--text);width:100%;font-size:13px}
.icon-btn{position:relative;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:var(--card);border:1px solid var(--line);color:var(--text)}
.badge-dot{position:absolute;top:6px;right:6px;min-width:16px;height:16px;border-radius:8px;background:var(--burgundybright);color:#fff;font-size:9px;font-weight:800;display:grid;place-items:center;padding:0 4px;border:1.5px solid var(--card)}
.avatar-link{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:14px}
.menu-toggle{display:none}

/* ---------- Hero（安全なブロック基底）---------- */
.hero{position:relative;display:block;overflow:hidden;border-radius:28px;padding:48px;margin-top:24px}
.hero:before{content:"";position:absolute;inset:0;border-radius:28px;box-shadow:inset 0 0 0 1px rgba(212,175,106,.25);pointer-events:none;z-index:0}
.hero .kicker{font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--goldbright)}
.hero h1{font-family:var(--serif);font-size:clamp(34px,5.5vw,56px);line-height:1.02;color:#fff;margin-top:10px}
.hero .sub{color:rgba(255,255,255,.8);margin-top:10px;font-size:14px}
.hero-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}

/* ---------- Featured Hero（Home：PCは横長2カラム）---------- */
.hero-featured{display:flex;align-items:center;justify-content:space-between;gap:40px;min-height:400px;padding:56px;max-width:1180px;margin-left:auto;margin-right:auto}
.hero-link{position:absolute;inset:0;z-index:2;border-radius:28px}
.hero-main{position:relative;z-index:1;max-width:640px;pointer-events:none}
.hero-side{position:relative;z-index:1;display:flex;flex-direction:column;align-items:flex-end;gap:22px;flex-shrink:0;text-align:right;pointer-events:none}
.hero-price span{display:block;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.hero-price b{font-size:30px;font-weight:800;color:var(--goldbright);line-height:1.1}
.play-fab{position:relative;z-index:3;pointer-events:auto;width:64px;height:64px;border-radius:50%;background:var(--gold);color:var(--bgdeep);display:grid;place-items:center;border:none;box-shadow:0 10px 28px rgba(0,0,0,.45);transition:transform .15s}
.play-fab:hover{transform:scale(1.06)}
/* 旧hero-cta（他ページ互換用） */
.hero-cta{display:flex;align-items:center;gap:16px;margin-top:22px}

/* ---------- Badges / chips ---------- */
.badge{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:5px 11px;font-size:11px;font-weight:700;border:1px solid}
.badge.gold{background:rgba(212,175,106,.12);color:var(--goldbright);border-color:rgba(212,175,106,.35)}
.badge.purple{background:rgba(138,107,255,.14);color:var(--purple);border-color:rgba(138,107,255,.35)}
.badge.emerald{background:rgba(60,203,148,.12);color:var(--emerald);border-color:rgba(60,203,148,.32)}
.badge.burgundy{background:rgba(176,69,90,.16);color:var(--burgundybright);border-color:rgba(176,69,90,.4)}
.badge.muted{background:rgba(255,255,255,.05);color:var(--sub);border-color:var(--line)}
.chip{flex:0 0 auto;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--sub);border-radius:999px;padding:8px 16px;font-size:14px;font-weight:600}
.chip:hover{color:var(--text);border-color:var(--linestrong)}
.chip.active{border-color:var(--gold);background:rgba(212,175,106,.14);color:var(--goldbright)}

/* ---------- Sections / rails ---------- */
.section{margin-top:40px}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:14px}
.section-head h2{font-family:var(--serif);font-size:26px;color:var(--text)}
.section-head .ja{font-size:12px;color:var(--muted);margin-left:10px}
.section-head .more{font-size:13px;font-weight:600;color:var(--muted)}
.rail{display:flex;gap:14px;overflow-x:auto;padding-bottom:6px}
.chip-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px}
.grid{display:grid;gap:14px}
.grid-beats{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}

/* ---------- Beat card ---------- */
.beat-card{width:180px;flex:0 0 auto}
.grid .beat-card{width:auto}
.beat-cover{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:1/1}
.cover{position:relative;overflow:hidden;border-radius:12px}
.cover .gloss{position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.2),rgba(255,255,255,.03) 40%,transparent 60%)}
.cover .vignette{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 45%,rgba(0,0,0,.45))}
.cover .mono{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--serif);color:rgba(255,255,255,.9);letter-spacing:1px}
.cover .ring{position:absolute;inset:0;border-radius:inherit;box-shadow:inset 0 0 0 1px rgba(255,255,255,.1)}
.beat-meta-tag{position:absolute;left:8px;top:8px;background:rgba(0,0,0,.45);box-shadow:inset 0 0 0 1px rgba(255,255,255,.15);border-radius:999px;padding:2px 8px;font-size:10px;font-weight:700;color:rgba(255,255,255,.9)}
.beat-play{position:absolute;right:8px;bottom:8px;width:40px;height:40px;border-radius:50%;background:var(--gold);color:var(--bgdeep);border:none;display:grid;place-items:center;opacity:0;transition:.15s;box-shadow:0 6px 16px rgba(0,0,0,.4)}
.beat-card:hover .beat-play{opacity:1}
.beat-title{margin-top:10px;font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.beat-sub{display:flex;justify-content:space-between;margin-top:2px}
.beat-sub .maker{font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.beat-sub .price{font-size:14px;font-weight:800;color:var(--gold);margin-left:6px}

/* ---------- Hit card (wide) ---------- */
.hit-card{display:flex;align-items:center;gap:12px;width:330px;flex:0 0 auto;padding:12px}
.hit-card .info{min-width:0;flex:1}
.hit-card .t{font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hit-card .m{font-size:12px;color:var(--muted)}
.hit-card .row{display:flex;align-items:center;gap:8px;margin-top:6px}
.hit-card .row .x{font-size:11px;font-weight:600;color:var(--faint)}
.hit-right{display:flex;flex-direction:column;align-items:center;gap:8px}
.hit-right .play{width:38px;height:38px;border-radius:50%;background:var(--gold);color:var(--bgdeep);border:none;display:grid;place-items:center}
.hit-right .price{font-size:13px;font-weight:800;color:var(--gold)}
.rank-tag{position:absolute;left:-6px;top:-6px;min-width:20px;height:20px;border-radius:10px;background:var(--gold);color:var(--bgdeep);font-size:11px;font-weight:800;display:grid;place-items:center;padding:0 5px;border:2px solid var(--card)}

/* ---------- Ranking list / rows ---------- */
.list{padding:0 14px}
.list>*+*{border-top:1px solid var(--line)}
.beat-row{display:flex;align-items:center;gap:12px;padding:10px 6px}
.beat-row:hover{background:rgba(255,255,255,.03);border-radius:10px}
.beat-row .rank{width:24px;text-align:center;font-weight:800;font-size:15px;color:var(--muted)}
.beat-row .rank.top{color:var(--gold)}
.beat-row .info{min-width:0;flex:1}
.beat-row .info .t{font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.beat-row .info .m{font-size:12px;color:var(--muted)}
.beat-row .right{display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.beat-row .right .price{font-weight:800;color:var(--gold);font-size:14px}

/* ---------- Beatmaker card ---------- */
.maker-card{width:170px;flex:0 0 auto;display:flex;flex-direction:column;align-items:center;padding:16px;text-align:center}
.maker-card .name{margin-top:12px;font-weight:700;font-size:14px}
.maker-card .genre{font-size:11px;font-weight:700;color:var(--gold)}
.maker-card .stat{font-size:10px;color:var(--muted);margin-top:2px}

/* ---------- Waveform ---------- */
.waveform{display:flex;align-items:center;gap:2px;height:48px;width:100%}
.waveform .bar{flex:1;min-width:2px;border-radius:2px;background:rgba(255,255,255,.13)}
.waveform .bar.on{background:linear-gradient(to bottom,#ebcb86,#d4af6a)}

/* ---------- Beat detail ---------- */
.detail-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:32px;margin-top:24px}
.meta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px}
.meta-cell{text-align:center;padding:12px 6px}
.meta-cell .v{font-size:18px;font-weight:800}
.meta-cell .l{font-size:10px;font-weight:700;letter-spacing:1px;color:var(--muted)}
.license-plan{width:100%;text-align:left;border:1px solid var(--line);background:transparent;border-radius:12px;padding:14px;color:var(--text);margin-bottom:10px;transition:.15s}
.license-plan:hover{border-color:var(--linestrong)}
.license-plan.active{border-color:var(--gold);background:rgba(212,175,106,.06)}
.license-plan .head{display:flex;align-items:center;justify-content:space-between}
.license-plan .pname{font-weight:700;font-size:14px}
.license-plan .pfiles{font-size:11px;color:var(--muted)}
.license-plan .pprice{font-size:17px;font-weight:800;color:var(--gold)}
.license-allows{margin-top:12px;border-top:1px solid var(--line);padding-top:12px;display:none}
.license-plan.active .license-allows{display:block}
.license-allows li{list-style:none;font-size:13px;color:var(--sub);margin:6px 0;padding-left:18px;position:relative}
.license-allows li:before{content:"✓";position:absolute;left:0;color:var(--emerald);font-weight:800}
.tag-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.tag{background:rgba(138,107,255,.12);color:rgba(207,194,255,.95);box-shadow:inset 0 0 0 1px rgba(138,107,255,.25);border-radius:999px;padding:6px 12px;font-size:12px;font-weight:600}
.raptype{background:rgba(255,255,255,.04);box-shadow:inset 0 0 0 1px var(--line);color:var(--sub);border-radius:999px;padding:8px 14px;font-size:12.5px;font-weight:600}

/* ---------- License certificate ---------- */
.cert{position:relative;overflow:hidden;border-radius:26px;border:1px solid rgba(212,175,106,.35);background:var(--card);padding:32px;box-shadow:0 0 40px rgba(212,175,106,.12);max-width:640px;margin:0 auto}
.cert .ribbon{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,#e2c281,#9a7a3e);color:#1a1205;border-radius:999px;padding:6px 12px;font-size:11px;font-weight:800;letter-spacing:1px}
.cert h1{font-family:var(--serif);font-size:30px;margin-top:18px}
.cert .row{display:flex;justify-content:space-between;padding:6px 0;font-size:14px;border-bottom:1px solid transparent}
.cert .row span:first-child{color:var(--muted)}
.cert .row span:last-child{font-weight:700}
.cert .hr{height:1px;background:var(--line);margin:18px 0}

/* ---------- Forms ---------- */
.field{margin-bottom:18px}
.field label{display:block;font-size:13px;font-weight:700;margin-bottom:8px}
.input,select.input,textarea.input{width:100%;background:var(--bgdeep);border:1px solid var(--line);border-radius:12px;padding:12px 14px;color:var(--text);font-size:15px;outline:none}
.input::placeholder{color:var(--muted)}
.checkbox-row{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--sub)}
.checkbox-row input{margin-top:3px;accent-color:#d4af6a}

/* ---------- Tabs / pills ---------- */
.seg{display:inline-flex;background:rgba(0,0,0,.25);border:1px solid var(--line);border-radius:999px;padding:5px}
.seg button{border:none;background:transparent;color:var(--muted);font-size:13px;font-weight:700;padding:9px 18px;border-radius:999px}
.seg button.active{background:rgba(212,175,106,.14);color:var(--goldbright);box-shadow:inset 0 0 0 1px rgba(212,175,106,.4)}
.subnav{display:flex;gap:6px;border-bottom:1px solid var(--line);margin-top:16px;flex-wrap:wrap}
.subnav a{display:flex;align-items:center;gap:8px;border-bottom:2px solid transparent;padding:12px 16px;font-size:14px;font-weight:700;color:var(--muted)}
.subnav a.active{border-color:var(--gold);color:var(--text)}

/* ---------- Status pills ---------- */
.st{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:700}
.st.published{background:rgba(60,203,148,.14);color:var(--emerald)}
.st.review_pending,.st.scanning{background:rgba(212,175,106,.14);color:var(--gold)}
.st.draft{background:rgba(255,255,255,.06);color:var(--muted)}
.st.rejected,.st.suspended{background:rgba(176,69,90,.16);color:var(--burgundybright)}

/* ---------- Quick stats ---------- */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.stat-card{display:grid;place-items:center;gap:4px;padding:14px}
.stat-card .v{font-size:20px;font-weight:800}
.stat-card .l{font-size:10px;color:var(--muted);font-weight:600}

/* ---------- Mini player ---------- */
.mini-player{position:fixed;left:0;right:0;bottom:0;z-index:45;background:rgba(10,11,18,.92);backdrop-filter:blur(10px);border-top:1px solid var(--linestrong);display:none}
.mini-player.show{display:block}
.mini-player .inner{display:flex;align-items:center;gap:14px;padding:10px 20px;max-width:1140px;margin:0 auto}
.mini-player .pl-info{display:flex;align-items:center;gap:10px;min-width:0;width:230px}
.mini-player .pl-info .t{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-player .pl-info .m{font-size:11px;color:var(--muted)}
.mini-player .pl-toggle{width:40px;height:40px;border-radius:50%;background:var(--text);color:var(--bgdeep);border:none;display:grid;place-items:center}

/* ---------- Role switch (demo) ---------- */
.role-switch{position:fixed;left:16px;bottom:90px;z-index:50}
.role-switch summary{list-style:none;display:inline-flex;align-items:center;gap:8px;background:rgba(20,21,31,.95);border:1px solid var(--line);border-radius:999px;padding:8px 14px;font-size:12px;font-weight:700;color:var(--sub);cursor:pointer}
.role-switch[open] summary{margin-bottom:8px}
.role-switch .panel{background:rgba(20,21,31,.97);border:1px solid var(--line);border-radius:14px;padding:10px;width:230px;box-shadow:0 12px 40px rgba(0,0,0,.5)}
.role-switch .panel a{display:block;padding:9px 12px;border-radius:10px;font-size:13px;font-weight:600;color:var(--sub)}
.role-switch .panel a:hover{background:rgba(255,255,255,.05)}
.role-switch .panel a.active{background:rgba(212,175,106,.15);color:var(--goldbright);box-shadow:inset 0 0 0 1px rgba(212,175,106,.4)}

/* ---------- Tables (admin/dashboard) ---------- */
.dbtable{width:100%;border-collapse:collapse}
.dbtable th,.dbtable td{text-align:left;padding:12px 10px;border-bottom:1px solid var(--line);font-size:13px}
.dbtable th{color:var(--muted);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.5px}

/* ---------- Home Hero（PC：2カラム 検索＋Featured）---------- */
.home-hero{position:relative;overflow:hidden;border-radius:28px;margin-top:24px;min-height:520px;
  display:grid;grid-template-columns:55% 45%;
  background:linear-gradient(135deg,#1c0c1a 0%,#0c0813 52%,#0d0a18 100%)}
.home-hero .hh-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.35}
.home-hero .hh-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(10,7,16,.7),rgba(10,7,16,.92))}
.home-hero:before{content:"";position:absolute;inset:0;border-radius:28px;box-shadow:inset 0 0 0 1px rgba(212,175,106,.22);pointer-events:none;z-index:3}
.hh-left{position:relative;z-index:2;padding:60px 56px;display:flex;flex-direction:column;justify-content:center}
.hh-label{font-size:11px;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:var(--goldbright)}
.hh-left h1{font-family:var(--serif);font-size:clamp(34px,4.4vw,54px);line-height:1.05;color:#fff;margin-top:12px}
.hh-sub{color:rgba(255,255,255,.78);font-size:14px;line-height:1.6;margin-top:14px;max-width:520px}
.search-bar{display:flex;align-items:center;gap:12px;background:rgba(0,0,0,.4);border:1px solid var(--linestrong);border-radius:16px;padding:8px 8px 8px 18px;margin-top:24px;max-width:560px}
.search-bar input{flex:1;background:transparent;border:none;outline:none;color:#fff;font-size:16px;min-width:0}
.search-bar input::placeholder{color:rgba(255,255,255,.5)}
.search-bar button{flex-shrink:0;border:none;border-radius:12px;padding:13px 22px;font-weight:800;font-size:15px}
.pop-tags{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:16px}
.pop-tags .lab{font-size:12px;color:rgba(255,255,255,.5);font-weight:600}
.pop-tags a{font-size:13px;font-weight:600;color:#fff;background:rgba(255,255,255,.08);border:1px solid var(--line);border-radius:999px;padding:7px 14px}
.pop-tags a:hover{background:rgba(212,175,106,.16);border-color:rgba(212,175,106,.4);color:var(--goldbright)}
.hh-trust{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:20px}

/* Featured（右カラムの商品カード） */
.hh-right{position:relative;z-index:2;display:flex;align-items:center;padding:40px 48px 40px 8px}
.hh-featured{position:relative;width:100%;background:rgba(0,0,0,.34);border:1px solid var(--linestrong);border-radius:20px;padding:18px;backdrop-filter:blur(4px)}
.hh-featured .fc-link{position:absolute;inset:0;z-index:1;border-radius:20px}
.hh-cover{position:relative}
.hh-art{position:relative;z-index:0;width:100%;aspect-ratio:16/10;border-radius:14px;overflow:hidden;background-size:cover;background-position:center}
.hh-art .gloss{position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.16),rgba(255,255,255,.02) 45%,transparent 60%)}
.hh-art .vignette{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 48%,rgba(0,0,0,.5))}
.hh-art .hh-mono{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--serif);font-size:64px;letter-spacing:2px;color:rgba(255,255,255,.92)}
.hh-cover .fc-flag{position:absolute;left:12px;top:12px;z-index:1;background:linear-gradient(135deg,#e2c281,#9a7a3e);color:#1a1205;font-size:10px;font-weight:800;letter-spacing:.5px;padding:5px 10px;border-radius:999px}
.hh-cover .fc-play{position:absolute;right:14px;bottom:14px;z-index:2;width:56px;height:56px;border-radius:50%;background:var(--gold);color:var(--bgdeep);border:none;display:grid;place-items:center;box-shadow:0 10px 26px rgba(0,0,0,.5)}
.hh-fmeta{position:relative;z-index:2;margin-top:14px}
.hh-fmeta .ft{font-family:var(--serif);font-size:24px;color:#fff;line-height:1.1}
.hh-fmeta .fm{font-size:13px;color:var(--sub);margin-top:3px}
.hh-fmeta .fb{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.hh-fbar{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.hh-fbar .fp span{font-size:10px;text-transform:uppercase;color:var(--muted);display:block}
.hh-fbar .fp b{font-size:22px;font-weight:800;color:var(--goldbright)}
.hh-fbar .fcta{display:flex;align-items:center;gap:8px}

/* ---------- Beat list（比較しやすい横長リスト）---------- */
.beat-list{overflow:hidden}
.blist-head,.blist-row{display:grid;grid-template-columns:42px minmax(0,2.2fr) 64px 78px 92px minmax(0,1.6fr) 96px 92px;gap:12px;align-items:center}
.blist-head{padding:10px 14px;border-bottom:1px solid var(--line)}
.blist-head span{font-size:10px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;color:var(--muted)}
.blist-row{padding:9px 14px;border-bottom:1px solid var(--line)}
.blist-row:last-child{border-bottom:none}
.blist-row:hover{background:rgba(255,255,255,.03)}
.blist-row .bl-play{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid var(--line);color:var(--gold);display:grid;place-items:center}
.blist-row:hover .bl-play{background:var(--gold);color:var(--bgdeep);border-color:var(--gold)}
.bl-title{display:flex;align-items:center;gap:10px;min-width:0}
.bl-title .tt{min-width:0}
.bl-title .tt .t{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bl-title .tt .m{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bl-cell{font-size:13px;color:var(--sub);font-weight:600}
.bl-tags{display:flex;gap:5px;overflow:hidden;flex-wrap:wrap;max-height:26px}
.bl-tags span{font-size:10px;font-weight:600;color:var(--sub);background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:999px;padding:2px 8px;white-space:nowrap}
.bl-price{font-size:14px;font-weight:800;color:var(--gold);text-align:right}
.bl-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px}
.bl-fav{background:none;border:none;color:var(--muted);display:grid;place-items:center}
.bl-fav:hover,.bl-fav.on{color:var(--rose)}
.bl-cart{width:34px;height:34px;border-radius:9px;background:rgba(212,175,106,.12);border:1px solid rgba(212,175,106,.3);color:var(--goldbright);display:grid;place-items:center}
.bl-cart:hover{background:var(--gold);color:var(--bgdeep)}
.bl-mobile{display:none}

/* ---------- All Beats 上部バー ---------- */
.ab-bar{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap}
.ab-title{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.ab-count{color:var(--muted);font-size:13px;font-weight:600}
.ab-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.ab-sort{display:flex;align-items:center;gap:8px}
.ab-sort label{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.ab-sort select{width:auto;padding:8px 12px;font-size:13px}

@media(max-width:900px){
  .home-hero{grid-template-columns:1fr;min-height:0}
  .hh-left{padding:32px 24px 8px}
  .hh-right{padding:8px 24px 32px}
  .search-bar{max-width:none}
  .hh-fmeta .ft{font-size:22px}
}
@media(max-width:860px){
  /* リストはモバイルで簡略カード化 */
  .blist-head{display:none}
  .blist-row{grid-template-columns:42px minmax(0,1fr) auto;gap:10px;padding:10px 12px}
  .bl-bpm,.bl-key,.bl-genre,.bl-tags{display:none}
  .bl-price{display:none}
  .bl-mobile{display:block;font-size:12px;color:var(--muted);margin-top:2px}
  .bl-mobile b{color:var(--gold);font-weight:800}
}

/* ---------- Page heading ---------- */
.page-head{padding-top:30px}
.page-head h1{font-family:var(--serif);font-size:32px}
.page-head .ja{font-size:14px;color:var(--muted);margin-left:8px}

/* ---------- Notice / empty ---------- */
.notice-box{display:flex;gap:8px;border:1px solid rgba(138,107,255,.25);background:rgba(138,107,255,.06);border-radius:12px;padding:14px;font-size:13px;color:var(--sub)}
.empty{padding:50px 20px;text-align:center;color:var(--muted)}

/* ---------- Footer ---------- */
.site-footer{margin-top:60px;border-top:1px solid var(--line);padding:30px 0;text-align:center}
.site-footer .b{font-family:var(--serif);font-size:20px}
.site-footer p{color:var(--faint);font-size:12px;margin-top:6px}

/* ---------- Spacing utils ---------- */
.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}.mt24{margin-top:24px}.mt32{margin-top:32px}
.flex{display:flex}.items-center{align-items:center}.gap8{gap:8px}.gap12{gap:12px}.wrap{flex-wrap:wrap}
.p20{padding:20px}.p24{padding:24px}

/* ---------- Responsive ---------- */
@media(max-width:860px){
  .nav-search{display:none}
  .nav-links{display:none}
  .nav-links.open{display:flex;position:absolute;top:62px;left:0;right:0;flex-direction:column;background:var(--bgdeep);border-bottom:1px solid var(--line);padding:14px 20px;gap:14px}
  .menu-toggle{display:grid}
  .detail-grid{grid-template-columns:1fr}
  .stat-row{grid-template-columns:repeat(2,1fr)}
  .meta-grid{grid-template-columns:repeat(3,1fr)}
  .hero{padding:28px 22px}
  .hero-featured{flex-direction:column;align-items:flex-start;gap:20px;min-height:0;padding:30px 22px}
  .hero-side{flex-direction:row;align-items:center;justify-content:space-between;width:100%;text-align:left}
  .hero-price b{font-size:24px}
  .mini-player .pl-info{width:auto;flex:1}
  .role-switch{bottom:84px}
}
@media(max-width:480px){
  .section-head h2{font-size:22px}
  .grid-beats{grid-template-columns:repeat(2,1fr)}
}
